POST
/
v1
/
order_batches
curl --request POST \
  --url https://api.ongoody.com/v1/order_batches \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
  "from_name": "John",
  "message": "Thank you!",
  "send_method": "link_multiple_custom_list",
  "payment_method_id": null,
  "workspace_id": null,
  "card_id": "69d000ba-47cd-4eea-96d3-09687aab9116",
  "recipients": [
    {
      "first_name": "Alena",
      "last_name": "Kenter",
      "email": "alena@ongoody.com"
    },
    {
      "first_name": "Michael",
      "last_name": "Franci",
      "email": "michael@ongoody.com"
    }
  ],
  "cart": {
    "items": [
      {
        "product_id": "bb662a72-f2ce-480a-afe5-d10d9019183e",
        "quantity": 1
      }
    ]
  }
}'
{
  "id": "6669ae79-5e8c-4d14-9c12-d3ad6d728d3a",
  "send_status": "complete",
  "from_name": "John",
  "message": "Thank you!",
  "orders_count": 2,
  "orders_preview": [
    {
      "id": "068d54c9-21f4-43dc-a0a9-33f9ed829e4e",
      "status": "created",
      "individual_gift_link": "https://gifts.ongoody.com/gift/tj4t56vLDhHa55mVeK2WqQbR",
      "recipient_first_name": "Alena",
      "recipient_last_name": "Kenter",
      "recipient_email": "alena@ongoody.com",
      "card_id": "69d000ba-47cd-4eea-96d3-09687aab9116",
      "message": "Thank you!",
      "thank_you_note": null,
      "view_count_recipient": 0,
      "is_swapped": false,
      "order_batch_id": "6669ae79-5e8c-4d14-9c12-d3ad6d728d3a",
      "expires_at": null,
      "cart": {
        "id": "7a30aa54-f44f-448e-b68f-1b7f77261f3e",
        "items": [
          {
            "id": "58e52184-3abe-4fd7-96ae-d719c56b2e3f",
            "quantity": 1,
            "product": {
              "id": "bb662a72-f2ce-480a-afe5-d10d9019183e",
              "name": "Cookies",
              "brand": {
                "id": "aade3744-84d5-43c6-a694-da6df2aa7f4a",
                "name": "Cookie Company"
              }
            }
          }
        ]
      },
      "shipments": [],
      "amounts": {
        "amount_product": 1000,
        "amount_shipping": 1000,
        "amount_processing_fee": 100,
        "amount_pre_tax_total": 2100,
        "amount_tax": null,
        "amount_total": null,
        "amount_global_relay_cost": null
      },
      "sender": {
        "first_name": "Test",
        "last_name": "User",
        "email": "15557016483@test.ongoody.com"
      },
      "workspace_id": "dd5aaa10-2d83-4306-ba0c-bc59f998d5a3",
      "workspace_name": "Test Team",
      "original_cart": null,
      "original_amounts": null,
      "reference_id": "492XRYR9RBMDPIBGEZDBKY3Y",
      "payment_link": null
    },
    {
      "id": "b41da10d-92c1-4a04-93d9-afd00767bc2f",
      "status": "created",
      "individual_gift_link": "https://gifts.ongoody.com/gift/11dM9Cnp8352mmGvmsRvyXOf",
      "recipient_first_name": "Michael",
      "recipient_last_name": "Franci",
      "recipient_email": "michael@ongoody.com",
      "card_id": "69d000ba-47cd-4eea-96d3-09687aab9116",
      "message": "Thank you!",
      "thank_you_note": null,
      "view_count_recipient": 0,
      "is_swapped": false,
      "order_batch_id": "6669ae79-5e8c-4d14-9c12-d3ad6d728d3a",
      "expires_at": null,
      "cart": {
        "id": "7a30aa54-f44f-448e-b68f-1b7f77261f3e",
        "items": [
          {
            "id": "58e52184-3abe-4fd7-96ae-d719c56b2e3f",
            "quantity": 1,
            "product": {
              "id": "bb662a72-f2ce-480a-afe5-d10d9019183e",
              "name": "Cookies",
              "brand": {
                "id": "aade3744-84d5-43c6-a694-da6df2aa7f4a",
                "name": "Cookie Company"
              }
            }
          }
        ]
      },
      "shipments": [],
      "amounts": {
        "amount_product": 1000,
        "amount_shipping": 1000,
        "amount_processing_fee": 100,
        "amount_pre_tax_total": 2100,
        "amount_tax": null,
        "amount_total": null,
        "amount_global_relay_cost": null
      },
      "sender": {
        "first_name": "Test",
        "last_name": "User",
        "email": "15557016483@test.ongoody.com"
      },
      "workspace_id": "dd5aaa10-2d83-4306-ba0c-bc59f998d5a3",
      "workspace_name": "Test Team",
      "original_cart": null,
      "original_amounts": null,
      "reference_id": "DRXAP1R7L48HCBATPPSJDE5N",
      "payment_link": null
    }
  ],
  "recipients_count": 2,
  "recipients_preview": [
    {
      "first_name": "Alena",
      "last_name": "Kenter",
      "email": "alena@ongoody.com"
    },
    {
      "first_name": "Michael",
      "last_name": "Franci",
      "email": "michael@ongoody.com"
    }
  ],
  "cart": {
    "id": "7a30aa54-f44f-448e-b68f-1b7f77261f3e",
    "items": [
      {
        "id": "58e52184-3abe-4fd7-96ae-d719c56b2e3f",
        "quantity": 1,
        "product": {
          "id": "bb662a72-f2ce-480a-afe5-d10d9019183e",
          "name": "Cookies",
          "brand": {
            "id": "aade3744-84d5-43c6-a694-da6df2aa7f4a",
            "name": "Cookie Company"
          }
        }
      }
    ]
  },
  "is_scheduled_send": false,
  "scheduled_send_on": null,
  "expires_at": null,
  "send_method": "link_multiple_custom_list",
  "batch_name": "Alena Kenter and Michael Franci",
  "card_id": "69d000ba-47cd-4eea-96d3-09687aab9116",
  "sender": {
    "first_name": "Test",
    "last_name": "User",
    "email": "15557016483@test.ongoody.com"
  },
  "workspace_id": "dd5aaa10-2d83-4306-ba0c-bc59f998d5a3",
  "workspace_name": "Test Team",
  "reference_id": "6YF58HLYCYQLRXDRH71EAVTB"
}

For a guide on how to create an order batch, see the Getting Started guide for the Automation API Getting Started guide or the Commerce API Getting Started guide.

Order batches with 10 or fewer recipients

Order batches with 10 or fewer recipients are created synchronously, and the returned status field will be completed. The orders and order links are available immediately inside the orders_preview field (which returns the first 10 orders).

Order batches with more than 10 recipients

Order batches with more than 10 recipients are created asynchronously, and the order batch will have a status of pending. The orders and gift links won’t be available until the order batch is finished processing synchronously. You can check the status of the order batch by calling the /order_batches/:id endpoint, or by receiving a webhook notification on the order_batch.completed event.

Once an order batch is created, you can access all of the orders by calling the /order_batches/:id/orders endpoint, where you can paginate through the list of orders. If your use case always sends 10 or fewer orders at a time, you can just use the orders_preview field on the order batch which gives you the first 10 orders.

Authorizations

Authorization
string
header
required

Your Goody API key.

Body

application/json

Input parameters for an order batch.

cart
object
required
from_name
string
required

The name of the sender of the order (typically a gift), to be displayed as "from".

recipients
object[]
required
send_method
enum<string>
required

The method for sending a order batch. email_and_link sends a gift email to the recipient (specify email for each recipient). link_multiple_custom_list generates a gift link without an automatic email. direct_send ships the product directly to the recipient (specify mailing_address for each recipient). For more information, see Send Methods.

Available options:
email_and_link,
link_multiple_custom_list,
direct_send
card_id
string

The digital greeting card to attach to gifts. A card must be specified if a message is specified, since the message is displayed after the card is opened.

expires_at
string | null

The date and time at which the order batch will expire. If not specified, the order batch does not expire. An expiry must be set for orders paid using account balance. ISO 8601 format.

international_gift_cards_enabled
boolean

Whether to enable international gift cards on this order. If true and the international_shipping_tier is standard, then international gift cards can be swapped to. If false, then international gift cards are not available to be swapped to.

international_shipping_tier
enum<string>

Whether to enable international shipping on this order. disabled (default) only enables US shipping on this order. standard combined with international_gift_cards_enabled enables international gift cards. full enables the full global catalog for 100+ countries, with additional tax, duties, and freight costs.

Available options:
disabled,
standard,
full
message
string

For gifts, a message for the gift to be displayed in the digital unwrapping and email notifications, if enabled.

payment_method_id
string

The payment method used to pay for this order batch. If not specified, defaults to the first payment method on the account. If the account has no payment methods, then the order batch creation will fail.

reserved_options
object | null

For approved API partners only.

scheduled_send_on
string | null

The date and time at which the order batch will be sent. If not specified, the order batch is sent immediately. If an order batch is scheduled to be sent in the future, then orders will not be created until the scheduled send time. ISO 8601 format.

swap
enum<string>

What method to use to allow recipients to swap their gift. single (default) allows the recipient to swap the gift for one item, with hidden gift prices. multiple allows them to swap for multiple items up to the gift cost, with gift prices shown. disabled disables swapping on the gift. For gift collections (gift of choice), this must not be disabled.

Available options:
single,
multiple,
disabled
workspace_id
string

Workspace to create the order batch in. If not specified, creates the order batch in the oldest workspace the user has access to.

Response

201 - application/json

An order batch is the primary resource created by the API. Order batches contain an array of orders.

cart
object
required

The cart that was sent for this order batch. This is the original cart that was created for this order batch. If individual orders were swapped, this still remains the same, whereas orders' cart would change if they were swapped.

from_name
string
required

The name of the sender. This is displayed on the order and notifications.

id
string
required
orders_count
integer
required

The total number of orders in this order batch. This might be blank if the order batch is scheduled for the future, or it could be fewer than the recipient count if the order batch is in the process of being sent.

orders_preview
object[]
required

A preview of the first 10 orders in this order batch. To paginate through all of the orders, use the /order_batches/:id/orders endpoint with ?page&per_page. If your use case never sends more than 10 orders in a single batch, you can use this field instead of calling /order_batches/:id/orders. For order batches with more than 10 recipients, this array will be empty while the orders are asynchronously created in the background.

recipients_count
integer
required

The total number of recipients in this order batch.

recipients_preview
object[]
required

A preview of the first 10 recipients in this order batch. To see all of the recipients, use /order_batches/:id/recipients. Recipients contain the original contact information provided for each recipient when the order batch was created.

reference_id
string
required

The reference ID displayed on receipts and other locations as the ID for this order batch.

send_status
enum<string>
required

The pending status indicates that an order batch is being prepared to be sent out. If it is not scheduled, it is being sent asynchronously. If it is scheduled, it will stay in pending state until the scheduled time is reached, at which point it will be processed and moved to complete. When it is in pending status, no orders are created yet. When the order batch is in complete status, all orders are created and available.

Available options:
pending,
complete,
failed,
canceled
sender
object
required

The sender of the order batch.

batch_name
string | null

An internal name for the order batch, falling back to an auto-generated batch name. Not displayed to recipients.

card_id
string | null

The digital greeting card on this order batch.

expires_at
string | null

The date and time the order batch is set to expire. ISO 8601, UTC.

is_scheduled_send
boolean

Whether this order batch was set up as a scheduled send. This stays as true after the scheduled send is complete. To determine if the order batch is scheduled to be sent for the future, check if status is pending and scheduled_send_on is in the future. When a order batch is scheduled, orders are only created on the scheduled send date.

message
string | null

The message in this order batch, provided by the sender.

scheduled_send_on
string | null

The date and time the order batch is scheduled to be sent. This will be null if the order batch is not a scheduled send. This field remains after the scheduled send completes. ISO 8601, UTC.

send_method
enum<string>

The method for sending a order batch. email_and_link sends a gift email to the recipient (specify email for each recipient). link_multiple_custom_list generates a gift link without an automatic email. direct_send ships the product directly to the recipient (specify mailing_address for each recipient). For more information, see Send Methods.

Available options:
email_and_link,
link_multiple_custom_list,
direct_send
workspace_id
string | null

Organizations are sub-divided into workspaces. Order batches are contained in workspaces, identified by this ID.

workspace_name
string | null