Skip to main content
An Order represents the physical fulfillment event. In V2, Orders are not first-class API resources - they’re created as a side effect of the Gifts flow. An Order can be created either directly by your system in the Direct Fulfillment model (via the two-step gift-claim flow), or automatically by Snappy when a recipient claims their gift in the Triggered Gifting model.
Want to understand how Orders fit into the bigger picture? Check out the Core Concepts & Data Models page.
Looking for the V3 endpoints? See Orders (V3). V3 introduces Orders as first-class resources with a dedicated POST /v3/orders endpoint that replaces the V2 two-step flow - and adds direct order retrieval, listing, and cancellation by orderId. Both V2 and V3 are supported in parallel.
This page focuses on the Direct Fulfillment model, where your system places orders directly. If you’re working with the Triggered Gifting model, Orders are created automatically when recipients claim their gift - see Gifts for details.

The Order Object

In V2, the Order object is returned as part of the Gift object. A Gift can hold multiple Orders - for example, if an original Order was cancelled and a new one was placed. The active Order’s delivery details are surfaced at the top level of the Gift object for convenience.

Core Fields

FieldTypeDescription
idstringUnique identifier for the Order
statusstringCurrent status of the Order. See Order Statuses below
orderRecipientobjectThe recipient details used for this specific Order. Contains firstName, lastName, and country
orderedProductsarrayThe products included in this Order. See Ordered Products below

Ordered Products

FieldTypeDescription
orderedProducts[].selectedProduct.variantIdstringThe Variant ID of the product ordered
orderedProducts[].selectedProduct.titlestringThe title of the ordered product
orderedProducts[].selectedProduct.typestringThe product type (e.g. physicalGift, digital)
orderedProducts[].selectedProduct.orderStatusstringThe fulfillment status of this specific product within the Order
orderedProducts[].deliveryDetailsobjectDelivery details for this product. See Delivery Details below

Delivery Details

FieldTypeDescription
deliveryDetails.statusstringCurrent delivery status. See Delivery Statuses below
deliveryDetails.carrierstringThe shipping carrier handling the delivery
deliveryDetails.trackingNumberstringThe carrier’s tracking number
deliveryDetails.trackingLinkstringA direct link to the carrier’s tracking page
deliveryDetails.deliveryDates.outForDeliverystringISO 8601 timestamp of when the item was marked out for delivery
deliveryDetails.deliveryDates.estimatedstringISO 8601 timestamp of the estimated delivery date
deliveryDetails.deliveryDates.deliveredAtstringISO 8601 timestamp of when the item was delivered

Order Statuses

StatusDescription
activeThe Order is active and being processed
cancelledThe Order has been cancelled

Delivery Statuses

StatusDescription
orderReceivedThe fulfillment request has been received
processingThe item is being prepared for shipment
inTransitThe item has been picked up by the carrier
outForDeliveryThe item is expected to be delivered today
deliveredThe item has reached its final destination
Use Webhooks to track delivery status changes in real time rather than polling. See Webhook Event Types.

Key Concepts & Business Rules

An Order is a sub-entity of a Gift

In V2, the Order lives within a Gift - even when your system places the order directly via the Direct Fulfillment flow, a Gift object is created internally and the Order is attached to it. V3 changes this: Orders are first-class resources you can retrieve, list, and cancel directly by orderId.

Variants are required - not Products

When placing an order, you must always specify the variantId, not the productId. Every Product has at least one Variant, even if it has no variations. See Products & Variants.

Orders can only be cancelled before processing

Once an Order has been picked up by the fulfillment partner and is in transit, it can no longer be cancelled. Use the order-out-of-stock and order-canceled webhook events to handle edge cases proactively.

A Gift can have multiple Orders but only one is active

A Gift maintains a history of all Orders placed against it. If an Order is cancelled, a new one can be placed against the same Gift - but only one Order is active at any time. The Gift’s top-level deliveryDetails always reflects the active Order. The orders array on the Gift object contains the full Order history, including cancelled ones..

Address validation reduces fulfillment failures

Invalid or incomplete shipping addresses are a common cause of fulfillment failures. We recommend calling POST /v2/orders/addresses/validate before placing any order, especially when addresses are entered by end users in your platform UI.

Billing is triggered at Order creation

The Billing Method is debited when an Order is successfully placed. If the Billing Method has insufficient funds at the time of the request, the order will not be processed.

Order Status vs. Delivery Status

The top-level Order status indicates the lifecycle of the transaction (active vs. cancelled). The actual shipping progress is tracked inside the deliveryDetails.status of each ordered product.

How to Work with Orders (V2)

Claim a Gift Claiming a Gift programmatically places an Order on behalf of the recipient. Provide the selected variant and shipping address - Snappy creates the Order, debits the Billing Method, and begins fulfillment.
POST /v2/gifts/{giftId}/claim
Required fields:
  • variantId - the specific product Variant to order
  • recipient - the order recipient’s contact details and shipping address
Common use cases:
  • Auto-claim fallback - a Gift sent through Triggered Gifting hasn’t been claimed by the recipient within a defined window. Your system auto-claims with a pre-selected variant and a known shipping address, ensuring the gift still goes out.
  • Embedded Marketplace - your platform creates a Gift via POST /v2/gifts and immediately claims it on the recipient’s behalf, placing the Order in a single flow inside your UI.
Use the giftId to track order delivery status via GET /v2/gifts/{giftId} or Webhooks.
V3 introduces POST /v3/orders as a single-call alternative for placing orders without the Gift-and-claim pattern. If you’re starting a new integration, consider V3 Orders.
Cancel an Order Cancel an order that has not yet been processed or shipped. A successful request returns the cancelled order ID and its updated status:
POST /v2/gifts/{giftId}/cancel
Orders can only be cancelled before they have been processed or shipped. Once a shipment is in transit, cancellation is no longer possible.
Validate Order Address Validate a shipping address before placing an order. Use this endpoint to catch address errors early and reduce the likelihood of fulfillment failures:
POST /v2/orders/addresses/validate
We recommend calling this endpoint as part of your order placement flow, especially when addresses are entered by end users in your platform UI.
Autocomplete Order Address Retrieve address suggestions based on a partial input string. Useful for building address input fields in your platform UI that help users enter accurate shipping addresses:
GET /v2/orders/addresses/autocomplete
Last modified on June 18, 2026