Skip to content

Latest commit

 

History

History
88 lines (78 loc) · 12 KB

order.md

File metadata and controls

88 lines (78 loc) · 12 KB

Order

Contains all information related to a single order to process with Square, including line items that specify the products to purchase. Order objects also include information about any associated tenders, refunds, and returns.

All Connect V2 Transactions have all been converted to Orders including all associated itemization data.

Structure

Order

Fields

Name Type Tags Description Getter
Id String Optional The order's unique ID. String getId()
LocationId String Required The ID of the seller location that this order is associated with.
Constraints: Minimum Length: 1
String getLocationId()
ReferenceId String Optional A client-specified ID to associate an entity in another system
with this order.
Constraints: Maximum Length: 40
String getReferenceId()
Source OrderSource Optional Represents the origination details of an order. OrderSource getSource()
CustomerId String Optional The ID of the customer associated with the order.

You should specify a customer_id on the order (or the payment) to ensure that transactions
are reliably linked to customers. Omitting this field might result in the creation of new
instant profiles.
Constraints: Maximum Length: 191
String getCustomerId()
LineItems List<OrderLineItem> Optional The line items included in the order. List getLineItems()
Taxes List<OrderLineItemTax> Optional The list of all taxes associated with the order.

Taxes can be scoped to either ORDER or LINE_ITEM. For taxes with LINE_ITEM scope, an
OrderLineItemAppliedTax must be added to each line item that the tax applies to. For taxes
with ORDER scope, the server generates an OrderLineItemAppliedTax for every line item.

On reads, each tax in the list includes the total amount of that tax applied to the order.

IMPORTANT: If LINE_ITEM scope is set on any taxes in this field, using the deprecated
line_items.taxes field results in an error. Use line_items.applied_taxes
instead.
List getTaxes()
Discounts List<OrderLineItemDiscount> Optional The list of all discounts associated with the order.

Discounts can be scoped to either ORDER or LINE_ITEM. For discounts scoped to LINE_ITEM,
an OrderLineItemAppliedDiscount must be added to each line item that the discount applies to.
For discounts with ORDER scope, the server generates an OrderLineItemAppliedDiscount
for every line item.

IMPORTANT: If LINE_ITEM scope is set on any discounts in this field, using the deprecated
line_items.discounts field results in an error. Use line_items.applied_discounts
instead.
List getDiscounts()
ServiceCharges List<OrderServiceCharge> Optional A list of service charges applied to the order. List getServiceCharges()
Fulfillments List<Fulfillment> Optional Details about order fulfillment.

Orders can only be created with at most one fulfillment. However, orders returned
by the API might contain multiple fulfillments.
List getFulfillments()
Returns List<OrderReturn> Optional A collection of items from sale orders being returned in this one. Normally part of an
itemized return or exchange. There is exactly one Return object per sale Order being
referenced.
List getReturns()
ReturnAmounts OrderMoneyAmounts Optional A collection of various money amounts. OrderMoneyAmounts getReturnAmounts()
NetAmounts OrderMoneyAmounts Optional A collection of various money amounts. OrderMoneyAmounts getNetAmounts()
RoundingAdjustment OrderRoundingAdjustment Optional A rounding adjustment of the money being returned. Commonly used to apply cash rounding
when the minimum unit of the account is smaller than the lowest physical denomination of the currency.
OrderRoundingAdjustment getRoundingAdjustment()
Tenders List<Tender> Optional The tenders that were used to pay for the order. List getTenders()
Refunds List<Refund> Optional The refunds that are part of this order. List getRefunds()
Metadata Map<String, String> Optional Application-defined data attached to this order. Metadata fields are intended
to store descriptive references or associations with an entity in another system or store brief
information about the object. Square does not process this field; it only stores and returns it
in relevant API calls. Do not use metadata to store any sensitive information (such as personally
identifiable information or card details).

Keys written by applications must be 60 characters or less and must be in the character set
[a-zA-Z0-9_-]. Entries can also include metadata generated by Square. These keys are prefixed
with a namespace, separated from the key with a ':' character.

Values have a maximum length of 255 characters.

An application can have up to 10 entries per metadata field.

Entries written by applications are private and can only be read or modified by the same
application.

For more information, see Metadata.
Map<String, String> getMetadata()
CreatedAt String Optional The timestamp for when the order was created, at server side, in RFC 3339 format (for example, "2016-09-04T23:59:33.123Z"). String getCreatedAt()
UpdatedAt String Optional The timestamp for when the order was last updated, at server side, in RFC 3339 format (for example, "2016-09-04T23:59:33.123Z"). String getUpdatedAt()
ClosedAt String Optional The timestamp for when the order reached a terminal state, in RFC 3339 format (for example "2016-09-04T23:59:33.123Z"). String getClosedAt()
State String Optional The state of the order. String getState()
Version Integer Optional The version number, which is incremented each time an update is committed to the order.
Orders not created through the API do not include a version number and
therefore cannot be updated.

Read more about working with versions.
Integer getVersion()
TotalMoney Money Optional Represents an amount of money. Money fields can be signed or unsigned.
Fields that do not explicitly define whether they are signed or unsigned are
considered unsigned and can only hold positive amounts. For signed fields, the
sign of the value indicates the purpose of the money transfer. See
Working with Monetary Amounts
for more information.
Money getTotalMoney()
TotalTaxMoney Money Optional Represents an amount of money. Money fields can be signed or unsigned.
Fields that do not explicitly define whether they are signed or unsigned are
considered unsigned and can only hold positive amounts. For signed fields, the
sign of the value indicates the purpose of the money transfer. See
Working with Monetary Amounts
for more information.
Money getTotalTaxMoney()
TotalDiscountMoney Money Optional Represents an amount of money. Money fields can be signed or unsigned.
Fields that do not explicitly define whether they are signed or unsigned are
considered unsigned and can only hold positive amounts. For signed fields, the
sign of the value indicates the purpose of the money transfer. See
Working with Monetary Amounts
for more information.
Money getTotalDiscountMoney()
TotalTipMoney Money Optional Represents an amount of money. Money fields can be signed or unsigned.
Fields that do not explicitly define whether they are signed or unsigned are
considered unsigned and can only hold positive amounts. For signed fields, the
sign of the value indicates the purpose of the money transfer. See
Working with Monetary Amounts
for more information.
Money getTotalTipMoney()
TotalServiceChargeMoney Money Optional Represents an amount of money. Money fields can be signed or unsigned.
Fields that do not explicitly define whether they are signed or unsigned are
considered unsigned and can only hold positive amounts. For signed fields, the
sign of the value indicates the purpose of the money transfer. See
Working with Monetary Amounts
for more information.
Money getTotalServiceChargeMoney()
TicketName String Optional A short-term identifier for the order (such as a customer first name,
table number, or auto-generated order number that resets daily).
Constraints: Maximum Length: 30
String getTicketName()
PricingOptions OrderPricingOptions Optional Pricing options for an order. The options affect how the order's price is calculated.
They can be used, for example, to apply automatic price adjustments that are based on preconfigured
pricing rules.
OrderPricingOptions getPricingOptions()
Rewards List<OrderReward> Optional A set-like list of Rewards that have been added to the Order. List getRewards()
NetAmountDueMoney Money Optional Represents an amount of money. Money fields can be signed or unsigned.
Fields that do not explicitly define whether they are signed or unsigned are
considered unsigned and can only hold positive amounts. For signed fields, the
sign of the value indicates the purpose of the money transfer. See
Working with Monetary Amounts
for more information.
Money getNetAmountDueMoney()

Example (as JSON)

{
  "id": "id2",
  "location_id": "location_id6",
  "reference_id": "reference_id0",
  "source": {
    "name": "name4"
  },
  "customer_id": "customer_id0",
  "line_items": [
    {
      "uid": "uid8",
      "name": "name8",
      "quantity": "quantity4",
      "quantity_unit": {
        "measurement_unit": {
          "custom_unit": {
            "name": "name2",
            "abbreviation": "abbreviation4"
          },
          "area_unit": "IMPERIAL_ACRE",
          "length_unit": "IMPERIAL_INCH",
          "volume_unit": "METRIC_LITER",
          "weight_unit": "IMPERIAL_WEIGHT_OUNCE"
        },
        "precision": 54,
        "catalog_object_id": "catalog_object_id0",
        "catalog_version": 12
      },
      "note": "note4",
      "catalog_object_id": "catalog_object_id2"
    }
  ]
}