Skip to main content

Event callbacks

The Connect platform can send callbacks (also known as webhooks) to your retailer site when an order changes status. Work with your Instacart Connect representative to enable the callbacks that make sense for your fulfillment workflows. To receive callbacks, you need to create webhooks that include an endpoint for OAuth 2.0 authentication. For more information, see Authentication for callbacks. The order in which event callbacks are sent or received is not guaranteed. For more information, see Callback errors and retries.

info

In some cases, you might receive the same callback status multiple times for the same order. This can occur when an order transitions back to a previous status, which then causes some of the steps in the workflow to be repeated.

The following table lists the available callbacks and identifies which fulfillment workflows can use them.

CallbacksDeliveryPickupLast mile delivery
Brand new
Acknowledged
Picking
Order item replacement
Order item refund
Checkout
Delivering
Order location
Late delivery
Customer missing
Staged1
Customer acknowledged
Pickup runner started
Unable to find customer
Runner not found
Pickup Geofence reached
Late pickup
Delivered
Rescheduled
Canceled
Tip adjustment
At store
Acknowledged for delivery
Bags verified
Arrival at customer
At store ETA
Rating updated
Rating reminder
1 This callback is sent only when the shopper who picks the order is different from the shopper who delivers the order.
note

Dispatch last mile delivery workflows can use the same callbacks as last mile delivery workflows.

Callback descriptions

The following example callbacks show the JSON payload for each event.

For delivery orders, the store_location field might not be returned until after the picking callback event occurs.

Optionally, you can add the retailer_id field to all your callbacks. To enable this option, contact your Instacart representative to update your site configuration.

Brand new

This event occurs when an order is successfully created in the Instacart system.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.brand_new",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true,
"is_certified_delivery": true,
"order_created_with_big_bulky": true,
"delivery_window": {
"starts_at": "2020-07-07T17:00:00Z",
"ends_at": "2020-07-07T18:00:00Z"
}
}
}

Acknowledged

This event occurs when an order is acknowledged by a shopper.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.acknowledged",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true
}
}

Picking

This event occurs when a shopper begins fulfilling an order.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.picking",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Order item replacement

This event occurs when a shopper replaces an order item.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.order_item_replacement",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true,
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"requested_item_upc": "123456789012",
"delivered_item_upc": "036000291457",
"requested_item_rrc": "675643210909",
"delivered_item_rrc": "329439334443",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": true,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"requested_item_upc": "097264536743",
"delivered_item_upc": "036000291457",
"requested_item_rrc": "321984628343",
"delivered_item_rrc": "329439334443",
"scan_code": "2387549",
"substitution_status": ""
}
]
}
}

Order item refund

This event occurs when a shopper refunds an order item.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.order_item_refund",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true,
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": false,
"refunded": true,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "2387549",
"substitution_status": ""
}
]
}
}

Checkout​

This event occurs when all picking for the order has been completed.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.checkout",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"post_checkout_link": "<post_checkout_link>",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"delivered_item_upc": "036000291457",
"delivered_item_rrc": "329439334443",
"requested_item_upc": "036000291457",
"requested_item_rrc": "329439334443",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": true,
"refunded": false,
"item_upc": "432000291667",
"item_rrc": "252439332211",
"delivered_item_upc": "432000291667",
"delivered_item_rrc": "252439332211",
"requested_item_upc": "432000291667",
"requested_item_rrc": "252439332211",
"scan_code": "2387549",
"substitution_status": ""
}
],
"delivery_window": {
"starts_at": "2020-07-07T17:00:00Z",
"ends_at": "2020-07-07T18:00:00Z"
},
"is_express": true,
"is_instacartplus": true
}
}

Delivering

This event occurs when the order has left the store location and is being delivered.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.delivering",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"delivery_eta": "2020-07-07T17:30:00Z",
"is_express": true,
"is_instacartplus": true,
"is_certified_delivery": true,
"order_created_with_big_bulky": true,
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": true,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "2387549",
"substitution_status": ""
}
],
"delivery_window": {
"starts_at": "2020-07-07T17:00:00Z",
"ends_at": "2020-07-07T18:00:00Z"
},
"bags_count": 3,
"pos_payment_method": "UNSPECIFIED"
}
}

Order location

This event occurs while the order is in the delivering status and the Order location callback frequency parameter is set in the retailer's Connect client configuration. The Order location callback frequency parameter specifies how often to send this event callback. The event updates the shopper's location at the specified interval until the order changes status. To set or change the interval, contact your Instacart representative.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.order_location",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"coordinates": {
"latitude": 1,
"longitude": 1
}
}
}

Late delivery

This event occurs when the delivery time of an order has changed.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.late_delivery",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"new_window": {
"starts_at": "2020-07-07T17:00:00Z",
"ends_at": "2020-07-07T18:00:00Z"
}
}
}

Customer missing

This event occurs when a shopper attempts to deliver an order and the customer is missing.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.customer_mia",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Staged

This event occurs when the shopping and checkout are complete and the order has been placed in the staging area. When enabled in the context of the delivery workflow, this callback is sent only when the shopper who picks the order is different from the shopper who delivers the order.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.staged",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true,
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": true,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "2387549",
"substitution_status": ""
}
],
"pickup_link": "retailer.com/xyz",
"bags_count": 3
}
}

Customer acknowledged

This event occurs when the runner is collecting the bags from the staging area.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment:customer_acknowledged",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"shopper_display_name": "Chris",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Pickup runner started

This event occurs when the pickup runner is heading outside with bags.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.pickup_runner_started",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Unable to find customer

This event occurs when the pickup runner was unable to find the customer.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment:unable_to_find_customer",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Runner not found

This event occurs when no pickup runner was available. The message to the customer explains that the curbside pickup has transitioned to an in-store pickup.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment:runner_not_found",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Pickup Geofence reached

This event occurs when the customer reaches the virtual Geofence for the store. The message to the customer contains any additional pickup instructions.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment:pickup_geofence_reached",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Late pickup

This event occurs when the pickup time of an order has changed.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.late_pickup",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"new_window": {
"starts_at": "2020-07-07T17:00:00Z",
"ends_at": "2020-07-07T18:00:00Z",
"store_location": "WEST-23243"
}
}
}

Delivered

This event occurs when the order has been successfully delivered or picked up by a customer.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.delivered",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true,
"is_certified_delivery": true,
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": true,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "2387549",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": false,
"refunded": false,
"item_upc": "",
"item_rrc": "",
"scan_code": "2387549",
"substitution_status": "",
"shopper_provided_item_name": "Apples",
"shopper_provided_item_price": {
"amount": 6.99,
"currency": "USD"
}
}
],
"bags_count": 3,
"pos_payment_method": "UNSPECIFIED",
"has_partner_picker_shopper": true
}
}

Rescheduled

This event occurs when an order has been rescheduled and will be fulfilled at another time.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.rescheduled",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"new_window": {
"starts_at": "2020-07-07T17:00:00Z",
"ends_at": "2020-07-07T18:00:00Z"
}
}
}

Canceled

This event occurs when an order has been canceled for any reason. The cancellation_reason field identifies who or what triggered the cancellation. The cancellation_type describes the cancellation. You can use this information in customer notifications. For more information about the cancellation reasons and cancellation types, see Cancellation reasons and cancellation types.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.canceled",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"cancellation_reason": "customer_driven",
"cancellation_type": "duplicate order",
"pos_payment_method": "UNSPECIFIED"
}
}

Tip adjustment

This event occurs when the tip for an order has successfully been updated after delivery is complete.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.tip_adjustment",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"is_express": true,
"is_instacartplus": true,
"order_items": [
{
"line_num": "1",
"qty": 1.0,
"qty_unit": "each",
"qty_fulfilled": 1.0,
"qty_fulfilled_unit": "each",
"qty_requested": 1.0,
"qty_requested_unit": "each",
"replaced": false,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "8743528",
"substitution_status": ""
},
{
"line_num": "2",
"qty": 0.92,
"qty_unit": "lb",
"qty_fulfilled": 0.92,
"qty_fulfilled_unit": "lb",
"qty_requested": 0.84,
"qty_requested_unit": "lb",
"replaced": true,
"refunded": false,
"item_upc": "036000291457",
"item_rrc": "329439334443",
"scan_code": "2387549",
"substitution_status": ""
}
]
}
}

At store

This event occurs when a shopper arrives at the store to pick up a last mile delivery order.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.at_store",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Acknowledged for delivery

This event occurs when a last mile delivery order is acknowledged by a shopper.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.acknowledged_for_delivery",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Bags verified

This event occurs when a shopper has verified the bags of a last mile delivery order at the store.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.bags_verified",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

Arrival at customer

This event occurs when a shopper has arrived at the customer's location with their last mile delivery order.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.arrival_at_customer",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243"
}
}

At store ETA

Once a last mile delivery order is acknowledged, this event is emitted every two minutes with the shopper's estimated time of arrival to the store location.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.at_store_eta",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"driver_eta": "2020-07-07T16:55:22Z",
"bag_label": "Singh"
}
}

Rating updated

This event occurs when the order rating is created or updated through the API.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.rating_updated",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "retailer.com/xyz",
"store_location": "WEST-23243",
"rating_value": "STARS5",
"highlights": ["SMOOTH_DELIVERY"],
"thank_you_note": "thanks!"
}
}

Rating reminder

This event occurs one hour after the order is delivered or picked up. This callback is sent when the order does not have a rating at the time the event occurs.

{
"event_id": 1201895966044343904,
"event_name": "fulfillment.rating_reminder",
"event_timestamp": "2020-07-07T16:35:22Z",
"event_metadata": {
"order_id": "b7fab7ae-11fc-4453-98e1-a2f5421a2b81",
"order_url": "WEST-23243",
"store_location": "WEST-23243"
}
}

Object descriptions

The following objects are used in callbacks.

note

Fields marked with * are not always present.

Order Callback object

FieldTypeDescription
event_idintegerThe ID of the event that triggered the callback.
event_namestringThe name of the event that triggered the callback. For valid values, see the event_name in each of the callbacks.
event_timestampstringThe time the event occurred in ISO 8601 format.
event_metadataEventMetadataMetadata related to the event.

EventMetadata object

FieldTypeDescription
order_idstringThe ID of the order relevant to the event.
order_urlstringThe URL to view the order status.
store_location*stringThe location code of the store where the order is fulfilled.
is_express*booleanDeprecated. Indicates whether the order received Instacart+ membership benefits.
is_instacartplus*booleanIndicates whether the order received Instacart+ membership benefits.
is_certified_delivery*booleanIndicates whether the order requires certified delivery.
order_created_with_big_bulky*booleanIndicates whether the order included big and bulky items at order creation.
post_checkout_link*stringDelivery. The URL link to the Connect Post Checkout app of the given order; nil if Connect Post Checkout app is not enabled.
delivery_window*DeliveryWindowDelivery. The expected time window the order will be delivered within.
new_window*DeliveryWindowThe expected time window the order will be delivered or ready for pickup.
order_items*Array(OrderItem)The items included in the order.
cancellation_reason*stringThe reason the order was canceled, such as who or what triggered the cancellation.
cancellation_type*stringThe type of cancellation.
pickup_link*stringPickup. A link to the pickup status page that allows users to notify the retailer they are at the store.
bags_count*integerThe number of bags for the order.
bag_label*stringA user-friendly label that helps shoppers identify the order.
has_partner_picker_shopper*booleanIndicates whether a partner shopper picked the order. To enable this field, contact your Instacart representative.
delivery_eta*stringThe estimated time of arrival of the order in ISO 8601 format.
driver_eta*stringThe estimated time of arrival of the shopper to the store location in ISO 8601 format.
coordinatesCoordinatesThe coordinates.
rating_value*stringThe star rating value for the completed order.
highlights*stringThe highlights for the completed order.
thank_you_note*stringThe completion message for the order feedback.
pos_payment_method*stringThe payment method used at the point of sale (POS).

DeliveryWindow object

FieldTypeDescription
starts_atstringThe time the delivery or pickup window begins in ISO 8601 format.
ends_atstringThe time the delivery or pickup window ends in ISO 8601 format.

OrderItem object

FieldTypeDescription
line_numstringThe item's line number in the order.
qtyfloatThe quantity of the item.
qty_unitstringThe quantity type, either each or lb.
qty_fulfilledfloatThe fulfilled quantity of the item.
qty_fulfilled_unitstringThe fulfilled quantity type, either each or lb.
qty_requestedfloatThe customer requested quantity of the item.
qty_requested_unitstringThe customer requested quantity type, either each or lb.
replacedbooleanIndicates whether the item was replaced.
refundedbooleanIndicates whether the item was refunded.
item_upc*stringThe item's universal product code (UPC).
item_rrc*stringThe item's retailer reference code (RRC).
delivered_item_upc*stringThe delivered item's universal product code (UPC).
delivered_item_rrc*stringThe delivered item's retailer reference code (RRC).
requested_item_upc*stringThe requested item's universal product code (UPC).
requested_item_rrc*stringThe requested item's retailer reference code (RRC).
scan_code*stringThe scan code of the item.
substitution_status*stringThe user's approval status of the substitution. One of PENDING, APPROVED, or REJECTED.
shopper_provided_item_name*stringThe item name provided by shoppers for items that they added.
shopper_provided_item_price*Shopper_provided_item_priceThe item price provided by shoppers for items that they added.

Shopper_provided_item_price object

FieldTypeDescription
amountfloatThe amount of a specified currency.
currencystringThe currency type in ISO 4217 format. For example: USD.

Coordinates object

FieldTypeDescription
latitudenumberThe latitude.
longitudenumberThe longitude.

Cancellation reasons and cancellation types

The following table describes the list of valid cancellation reasons:

Cancellation ReasonDescription
customer_drivenThe customer triggered the cancellation.
instacart_drivenInstacart triggered the cancellation.
retailer_drivenThe retailer triggered the cancellation.
shopper_drivenThe shopper triggered the cancellation.
unbatchableThe Instacart batch system triggered the cancellation.
otherThe cancellation was triggered by another source.

The following table describes the list of valid cancellation types and identifies the cancellation reason for each cancellation type:

Cancellation ReasonCancellation TypeDescription
customer_drivenduplicate orderThe customer reported the order as a duplicate order.
customer_drivencustomer app navigation issueThe customer reported an app navigation issue.
customer_drivencustomer requested since order is earlyThe customer requested the cancellation because the order would be early.
customer_drivencustomer requested since order is lateThe customer requested the cancellation because the order would be late.
customer_drivencustomer miaThe shopper reported that the customer is unavailable.
customer_drivenincorrect customer information (phone/address)The customer requested the cancellation because of incorrect information, such as the incorrect phone number or address.
customer_drivencustomer requested to cancelThe customer requested the cancellation.
customer_drivencancelled by customerThe customer canceled the order.
instacart_drivenfraudulent customerInstacart canceled the fraudulent customer’s order.
instacart_drivenmanual_fraudInstacart canceled the fraudulent order.
instacart_drivenmissing charge log for deliveryInstacart canceled the order because of the missing charge log for delivery.
instacart_drivensystem errorInstacart canceled the order because of a system error.
retailer_drivencard decline on reauthThe order was canceled because the payment card was declined.
retailer_drivenshopper initiated out of stockThe shopper canceled the order because items were out of stock.
retailer_drivenfulfillment initiated out of stockThe retailer canceled the order because items were out of stock.
retailer_drivensingle item order out of stockThe retailer canceled the single item order because the item was out of stock.
retailer_driventoo many out of stock itemsThe retailer canceled the order because many of the items were out of stock.
retailer_drivenstore early closureThe retailer canceled the order because of early store closure.
retailer_drivencancelled by retailerThe retailer canceled the order.
shopper_drivenshopper unable to complete orderThe shopper was unable to complete the order.
shopper_drivenshopper could not find addressThe shopper was unable to find the address.
unbatchableunable to reschedule unbatchableInstacart canceled the order because the batched order could not be rescheduled.
unbatchableunable to reschedule as no option foundInstacart canceled the order because the order could not be rescheduled.
unbatchableunbatchableInstacart canceled the order because the order could not be batched.
otherotherThe order was canceled for other reasons.
otherInstacart Connect order with all items refundedInstacart Connect canceled the order and refunded all items.
otherOnLine Pay FailureThe online payment failed.
othermass cancellationThe retailer canceled all store orders due to a store issue.
otherunknownThe order was canceled for unknown reasons.
othernoneThe order was canceled without a reason.

Callback errors and retries

If a callback endpoint returns an error, Connect retries the event callback five times at the following intervals: 4 seconds, 16 seconds, 64 seconds, 256 seconds, and 1024 seconds. If another event occurs during the retries and its callback is successful before the failed callback succeeds, the events can be received out of order.

Best practice

Monitor the callback endpoint to catch and resolve issues early.

The Instacart Connect operations team also checks for repeated retries and attempts to contact the retailer about issues.