Cancel a dispatch last mile delivery order
POST /v2/fulfillment/lastmile/orders/{order_id}/cancel
warning
This endpoint works only with dispatch last mile delivery orders.
Cancels a dispatch last mile delivery order.
To successfully perform this operation, the order's status value must be brand_new. In other words, once a shopper is assigned and status moves to acknowledged, you can no longer use this endpoint to cancel the order.
Security
| Name | In | Description | 
|---|---|---|
| Authorization | header | The Authorization header with the bearer token acquired during authentication. | 
Parameters
| Name | In | Type | Required | Description | 
|---|---|---|---|---|
| order_id | path | string |  | The ID of the order. | 
Request
| Field | Type | Required | Description | 
|---|---|---|---|
| user_id | string |  | The ID of the user. | 
Request examples
- cURL
- Java
- Python
- Go
curl --request POST \
  --url 'https://connect.instacart.com/v2/fulfillment/lastmile/orders/{order_id}/cancel' \
  --header 'Accept: application/json' \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
  "user_id": "string"
}'
HttpResponse<String> response = Unirest.post("https://connect.instacart.com/v2/fulfillment/lastmile/orders/{order_id}/cancel")
  .header("Accept", "application/json")
  .header("Content-Type", "application/json")
  .header("Authorization", "Bearer <token>")
  .body("{\n  \"user_id\": \"string\"\n}")
  .asString();
import http.client
conn = http.client.HTTPSConnection("connect.instacart.com")
payload = "{\n  \"user_id\": \"string\"\n}"
headers = {
    'Accept': "application/json",
    'Content-Type': "application/json",
    'Authorization': "Bearer <token>"
    }
conn.request("POST", "/v2/fulfillment/lastmile/orders/{order_id}/cancel", payload, headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
package main
import (
	"fmt"
	"strings"
	"net/http"
	"io/ioutil"
)
func main() {
	url := "https://connect.instacart.com/v2/fulfillment/lastmile/orders/{order_id}/cancel"
	payload := strings.NewReader("{\n  \"user_id\": \"string\"\n}")
	req, _ := http.NewRequest("POST", url, payload)
	req.Header.Add("Accept", "application/json")
	req.Header.Add("Content-Type", "application/json")
	req.Header.Add("Authorization", "Bearer <token>")
	res, _ := http.DefaultClient.Do(req)
	defer res.Body.Close()
	body, _ := ioutil.ReadAll(res.Body)
	fmt.Println(res)
	fmt.Println(string(body))
}
Response
| Field | Type | Required | Description | 
|---|---|---|---|
| id | string |  | The ID of the order. | 
| status | string |  | The current order status. | 
| order_url | string |  | Link to view the order. | 
| created_at | string |  | The time of order creation in ISO 8601 format. | 
| cancellation_reason | string |  | The reason the order was canceled. | 
| locale | string |  | The order's locale in POSIX format. Example: en_US. | 
| is_express | boolean |  | Deprecated. Use `is_instacartplus` instead. Indicates whether the order received Instacart+ membership benefits. Defaults to false. | 
| is_instacartplus | boolean |  | Indicates whether the order received Instacart+ membership benefits. Defaults to false. | 
| metadata | Hash |  | The order-level metadata. | 
| fulfillment_details | OrderFulfillmentDetails |  | The order delivery details. | 
OrderFulfillmentDetails Object
| Field | Type | Required | Description | 
|---|---|---|---|
| store_location | string |  | The location code of the store where the order was fulfilled. The store_location is often the same as the location_code that was used to create the order. However, orders can be fulfilled from a different store location. | 
| window_starts_at | string |  | The start time of the delivery window in ISO 8601 format. | 
| window_ends_at | string |  | The end time of the delivery window in ISO 8601 format. | 
| delivered_at | string |  | The time the order was delivered in ISO 8601 format. | 
| bag_count | integer |  | The number of bags in the order. | 
| handoff_window_starts_at | string |  | The start time of the handoff window in ISO 8601 format. | 
| handoff_window_ends_at | string |  | The end time of the handoff window in ISO 8601 format. | 
Response examples
200 Success
- 200Order canceled
{
  "id": "12345676789012345678780",
  "status": "canceled",
  "order_url": "https://example.com/example-order",
  "created_at": "2018-02-22T00:00:00Z",
  "cancellation_reason": "shopper_driven",
  "locale": "en_US",
  "is_express": true,
  "is_instacartplus": true,
  "fulfillment_details": {
    "window_starts_at": "2018-02-22T00:00:00Z",
    "window_ends_at": "2018-02-22T00:30:00Z"
  }
}
4XX Errors
Error responses return either a single error or multiple errors.
| HTTP Code | Cause | Error Message | Error Code | Error Meta | 
|---|---|---|---|---|
| 400 | Order could not be cancelled at this time | "The order could not be cancelled at this time, try again later." | 2003 | {"wait":"30"} | 
| 400 | Too late to cancel order | "too_late" | 1001 | {"key":"order_id"} | 
| 400 | Request could not be processed at this time | "The request could not be completed at this time, try again later." | 2003 | {"wait":"30"} | 
| 400 | User Not Found | "User Not Found" | 1001 | {"key":"user_id"} | 
| 404 | Order not found | "Resource not found" | 4000 | Not applicable |