/* * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with * the License. A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions * and limitations under the License. */ package com.amazonaws.services.outposts.model; import java.io.Serializable; import javax.annotation.Generated; import com.amazonaws.protocol.StructuredPojo; import com.amazonaws.protocol.ProtocolMarshaller; /** *
* A summary of line items in your order. *
* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class OrderSummary implements Serializable, Cloneable, StructuredPojo { /** ** The ID of the Outpost. *
*/ private String outpostId; /** ** The ID of the order. *
*/ private String orderId; /** ** The type of order. *
*/ private String orderType; /** ** The status of the order. *
*
     * PREPARING - Order is received and is being prepared.
     * 
     * IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see the
     * LineItem status.
     * 
     * COMPLETED - Order is complete.
     * 
     * CANCELLED - Order is cancelled.
     * 
     * ERROR - Customer should contact support.
     * 
     * The following statuses are deprecated: RECEIVED, PENDING, PROCESSING,
     * INSTALLING, and FULFILLED.
     * 
* The status of all line items in the order. *
*/ private java.util.Map* The submission date for the order. *
*/ private java.util.Date orderSubmissionDate; /** ** The fulfilment date for the order. *
*/ private java.util.Date orderFulfilledDate; /** ** The ID of the Outpost. *
* * @param outpostId * The ID of the Outpost. */ public void setOutpostId(String outpostId) { this.outpostId = outpostId; } /** ** The ID of the Outpost. *
* * @return The ID of the Outpost. */ public String getOutpostId() { return this.outpostId; } /** ** The ID of the Outpost. *
* * @param outpostId * The ID of the Outpost. * @return Returns a reference to this object so that method calls can be chained together. */ public OrderSummary withOutpostId(String outpostId) { setOutpostId(outpostId); return this; } /** ** The ID of the order. *
* * @param orderId * The ID of the order. */ public void setOrderId(String orderId) { this.orderId = orderId; } /** ** The ID of the order. *
* * @return The ID of the order. */ public String getOrderId() { return this.orderId; } /** ** The ID of the order. *
* * @param orderId * The ID of the order. * @return Returns a reference to this object so that method calls can be chained together. */ public OrderSummary withOrderId(String orderId) { setOrderId(orderId); return this; } /** ** The type of order. *
* * @param orderType * The type of order. * @see OrderType */ public void setOrderType(String orderType) { this.orderType = orderType; } /** ** The type of order. *
* * @return The type of order. * @see OrderType */ public String getOrderType() { return this.orderType; } /** ** The type of order. *
* * @param orderType * The type of order. * @return Returns a reference to this object so that method calls can be chained together. * @see OrderType */ public OrderSummary withOrderType(String orderType) { setOrderType(orderType); return this; } /** ** The type of order. *
* * @param orderType * The type of order. * @return Returns a reference to this object so that method calls can be chained together. * @see OrderType */ public OrderSummary withOrderType(OrderType orderType) { this.orderType = orderType.toString(); return this; } /** ** The status of the order. *
*
     * PREPARING - Order is received and is being prepared.
     * 
     * IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see the
     * LineItem status.
     * 
     * COMPLETED - Order is complete.
     * 
     * CANCELLED - Order is cancelled.
     * 
     * ERROR - Customer should contact support.
     * 
     * The following statuses are deprecated: RECEIVED, PENDING, PROCESSING,
     * INSTALLING, and FULFILLED.
     * 
     *        PREPARING - Order is received and is being prepared.
     *        
     *        IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see
     *        the LineItem status.
     *        
     *        COMPLETED - Order is complete.
     *        
     *        CANCELLED - Order is cancelled.
     *        
     *        ERROR - Customer should contact support.
     *        
     *        The following statuses are deprecated: RECEIVED, PENDING,
     *        PROCESSING, INSTALLING, and FULFILLED.
     *        
* The status of the order. *
*
     * PREPARING - Order is received and is being prepared.
     * 
     * IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see the
     * LineItem status.
     * 
     * COMPLETED - Order is complete.
     * 
     * CANCELLED - Order is cancelled.
     * 
     * ERROR - Customer should contact support.
     * 
     * The following statuses are deprecated: RECEIVED, PENDING, PROCESSING,
     * INSTALLING, and FULFILLED.
     * 
     *         PREPARING - Order is received and is being prepared.
     *         
     *         IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see
     *         the LineItem status.
     *         
     *         COMPLETED - Order is complete.
     *         
     *         CANCELLED - Order is cancelled.
     *         
     *         ERROR - Customer should contact support.
     *         
     *         The following statuses are deprecated: RECEIVED, PENDING,
     *         PROCESSING, INSTALLING, and FULFILLED.
     *         
* The status of the order. *
*
     * PREPARING - Order is received and is being prepared.
     * 
     * IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see the
     * LineItem status.
     * 
     * COMPLETED - Order is complete.
     * 
     * CANCELLED - Order is cancelled.
     * 
     * ERROR - Customer should contact support.
     * 
     * The following statuses are deprecated: RECEIVED, PENDING, PROCESSING,
     * INSTALLING, and FULFILLED.
     * 
     *        PREPARING - Order is received and is being prepared.
     *        
     *        IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see
     *        the LineItem status.
     *        
     *        COMPLETED - Order is complete.
     *        
     *        CANCELLED - Order is cancelled.
     *        
     *        ERROR - Customer should contact support.
     *        
     *        The following statuses are deprecated: RECEIVED, PENDING,
     *        PROCESSING, INSTALLING, and FULFILLED.
     *        
* The status of the order. *
*
     * PREPARING - Order is received and is being prepared.
     * 
     * IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see the
     * LineItem status.
     * 
     * COMPLETED - Order is complete.
     * 
     * CANCELLED - Order is cancelled.
     * 
     * ERROR - Customer should contact support.
     * 
     * The following statuses are deprecated: RECEIVED, PENDING, PROCESSING,
     * INSTALLING, and FULFILLED.
     * 
     *        PREPARING - Order is received and is being prepared.
     *        
     *        IN_PROGRESS - Order is either being built, shipped, or installed. For more information, see
     *        the LineItem status.
     *        
     *        COMPLETED - Order is complete.
     *        
     *        CANCELLED - Order is cancelled.
     *        
     *        ERROR - Customer should contact support.
     *        
     *        The following statuses are deprecated: RECEIVED, PENDING,
     *        PROCESSING, INSTALLING, and FULFILLED.
     *        
* The status of all line items in the order. *
* * @return The status of all line items in the order. */ public java.util.Map* The status of all line items in the order. *
* * @param lineItemCountsByStatus * The status of all line items in the order. */ public void setLineItemCountsByStatus(java.util.Map* The status of all line items in the order. *
* * @param lineItemCountsByStatus * The status of all line items in the order. * @return Returns a reference to this object so that method calls can be chained together. */ public OrderSummary withLineItemCountsByStatus(java.util.Map* The submission date for the order. *
* * @param orderSubmissionDate * The submission date for the order. */ public void setOrderSubmissionDate(java.util.Date orderSubmissionDate) { this.orderSubmissionDate = orderSubmissionDate; } /** ** The submission date for the order. *
* * @return The submission date for the order. */ public java.util.Date getOrderSubmissionDate() { return this.orderSubmissionDate; } /** ** The submission date for the order. *
* * @param orderSubmissionDate * The submission date for the order. * @return Returns a reference to this object so that method calls can be chained together. */ public OrderSummary withOrderSubmissionDate(java.util.Date orderSubmissionDate) { setOrderSubmissionDate(orderSubmissionDate); return this; } /** ** The fulfilment date for the order. *
* * @param orderFulfilledDate * The fulfilment date for the order. */ public void setOrderFulfilledDate(java.util.Date orderFulfilledDate) { this.orderFulfilledDate = orderFulfilledDate; } /** ** The fulfilment date for the order. *
* * @return The fulfilment date for the order. */ public java.util.Date getOrderFulfilledDate() { return this.orderFulfilledDate; } /** ** The fulfilment date for the order. *
* * @param orderFulfilledDate * The fulfilment date for the order. * @return Returns a reference to this object so that method calls can be chained together. */ public OrderSummary withOrderFulfilledDate(java.util.Date orderFulfilledDate) { setOrderFulfilledDate(orderFulfilledDate); return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getOutpostId() != null) sb.append("OutpostId: ").append(getOutpostId()).append(","); if (getOrderId() != null) sb.append("OrderId: ").append(getOrderId()).append(","); if (getOrderType() != null) sb.append("OrderType: ").append(getOrderType()).append(","); if (getStatus() != null) sb.append("Status: ").append(getStatus()).append(","); if (getLineItemCountsByStatus() != null) sb.append("LineItemCountsByStatus: ").append(getLineItemCountsByStatus()).append(","); if (getOrderSubmissionDate() != null) sb.append("OrderSubmissionDate: ").append(getOrderSubmissionDate()).append(","); if (getOrderFulfilledDate() != null) sb.append("OrderFulfilledDate: ").append(getOrderFulfilledDate()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof OrderSummary == false) return false; OrderSummary other = (OrderSummary) obj; if (other.getOutpostId() == null ^ this.getOutpostId() == null) return false; if (other.getOutpostId() != null && other.getOutpostId().equals(this.getOutpostId()) == false) return false; if (other.getOrderId() == null ^ this.getOrderId() == null) return false; if (other.getOrderId() != null && other.getOrderId().equals(this.getOrderId()) == false) return false; if (other.getOrderType() == null ^ this.getOrderType() == null) return false; if (other.getOrderType() != null && other.getOrderType().equals(this.getOrderType()) == false) return false; if (other.getStatus() == null ^ this.getStatus() == null) return false; if (other.getStatus() != null && other.getStatus().equals(this.getStatus()) == false) return false; if (other.getLineItemCountsByStatus() == null ^ this.getLineItemCountsByStatus() == null) return false; if (other.getLineItemCountsByStatus() != null && other.getLineItemCountsByStatus().equals(this.getLineItemCountsByStatus()) == false) return false; if (other.getOrderSubmissionDate() == null ^ this.getOrderSubmissionDate() == null) return false; if (other.getOrderSubmissionDate() != null && other.getOrderSubmissionDate().equals(this.getOrderSubmissionDate()) == false) return false; if (other.getOrderFulfilledDate() == null ^ this.getOrderFulfilledDate() == null) return false; if (other.getOrderFulfilledDate() != null && other.getOrderFulfilledDate().equals(this.getOrderFulfilledDate()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getOutpostId() == null) ? 0 : getOutpostId().hashCode()); hashCode = prime * hashCode + ((getOrderId() == null) ? 0 : getOrderId().hashCode()); hashCode = prime * hashCode + ((getOrderType() == null) ? 0 : getOrderType().hashCode()); hashCode = prime * hashCode + ((getStatus() == null) ? 0 : getStatus().hashCode()); hashCode = prime * hashCode + ((getLineItemCountsByStatus() == null) ? 0 : getLineItemCountsByStatus().hashCode()); hashCode = prime * hashCode + ((getOrderSubmissionDate() == null) ? 0 : getOrderSubmissionDate().hashCode()); hashCode = prime * hashCode + ((getOrderFulfilledDate() == null) ? 0 : getOrderFulfilledDate().hashCode()); return hashCode; } @Override public OrderSummary clone() { try { return (OrderSummary) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.outposts.model.transform.OrderSummaryMarshaller.getInstance().marshall(this, protocolMarshaller); } }