Latest carts with a specific product from a specific market
How to use the Metrics API to get the most recently created carts containing a specific SKU, from a specific market
The problem
You want to get the last ten created carts that contain a specific product and are associated with a specific market, over a selected date and time range, chronologically ordered by date of creation.
The solution
Query
You need to perform a search query setting the required query keys as follows and adding the optional ones based on your needs:
limit
10
sort_by
order.created_at
Filter
Set the desired date and time range using the date_from and date_to keys and add an additional filter on the line items field to restrict the related search on carts that contain the desired SKU only:
codes
"in": [ "TSHIRT0001" ]
Then add an additional filter on the market field to restrict the related search on the carts associated with the selected market only:
names
"in": [ "North America" ]
In the example below, since the date_field isn't specified in the date filter, the default value current_date will be used, meaning that the results will count all the orders that changed their status within the selected date and time range (read more about this).
Example
The following request uses the Metrics API to get the latest carts containing a specific SKU and associated with a specific market:
curl -g -X POST \
'https://{{your_domain}}.commercelayer.io/metrics/carts/search' \
-H 'Accept: application/vnd.api.v1+json' \
-H 'Content-Type: application/vnd.api+json' \
-H 'Authorization: Bearer {{your_access_token}}' \
-d '{
"search": {
"limit": 10,
"sort": "desc",
"sort_by": "order.created_at",
"fields": [ "order.created_at", "order.status", "order.total_amount_with_taxes", "customer.email", "market.*", "line_items.*" ]
},
"filter": {
"order": {
"date_from": "2021-01-01T00:00:00Z",
"date_to": "2021-12-31T23:59:00Z"
},
"line_items": {
"codes": {
"in": [ "TSHIRT0001" ]
}
},
"market": {
"names": {
"in": [ "North America" ]
}
}
}
}'On success, the API responds with a 200 OK status code, returning the requested fields in the data object and additional information alongside pagination in the meta object:
{
"data": [
{
"id": "pjochkYMdJ",
"created_at": "2021-12-28T18:18:18.399Z",
"total_amount_with_taxes": 19.0,
"status": "draft",
"market": {
"number": "1234",
"name": "North America",
"id": "yzXKjYzaCx"
},
"line_items": [
{
"tax_amount": 0.0,
"options_amount": 0.0,
"quantity": 1,
"updated_at": "2022-07-08T17:00:01.857Z",
"total_amount": -10.0,
"item_type": "fixed_price_promotions",
"name": "JANCAMPAIGN22",
"discount": 0.0,
"id": "kXCqtWXZbq",
"unit_amount": -10.0,
"tax_rate": 0.0
},
{
"tax_amount": 0.0,
"code": "TSHIRT0001",
"options_amount": 0.0,
"quantity": 1,
"updated_at": "2022-07-08T17:00:01.775Z",
"total_amount": 29.0,
"item_type": "skus",
"name": "Man T-shirt 1st Edition",
"discount": -10.0,
"id": "ypCptwaBlJ",
"unit_amount": 29.0,
"tax_rate": 0.0
}
]
},
{
"id": "pOCnhmEdxd",
"created_at": "2021-12-28T13:51:05.513Z",
"total_amount_with_taxes": 19.0,
"status": "draft",
"market": {
"number": "1234",
"name": "North America",
"id": "yzXKjYzaCx"
},
"line_items": [
{
"tax_amount": 0.0,
"options_amount": 0.0,
"quantity": 1,
"updated_at": "2022-09-14T11:30:44.134Z",
"total_amount": -10.0,
"item_type": "fixed_price_promotions",
"name": "VISACAMPAIGN22",
"discount": 0.0,
"id": "kXbztgQVOR",
"unit_amount": -10.0,
"tax_rate": 0.0
},
{
"tax_amount": 0.0,
"code": "TSHIRT0001",
"options_amount": 0.0,
"quantity": 1,
"updated_at": "2021-12-28T13:51:05.703Z",
"total_amount": 29.0,
"item_type": "skus",
"name": "Man T-shirt 1st Edition",
"discount": -10.0,
"id": "NlQvtgWvBV",
"unit_amount": 29.0,
"tax_rate": 0.0
}
]
},
{ ... }
],
"meta": {
"pagination": {
"record_count": 123,
"cursor": "LS0tCi0gJzIwMjEtMTItMzFUMjM6NDE6M=="
},
"type": "search",
"trace_id": "fe571ea2-8a4f-4a5e-bd26-ac54651bb2e4",
"mode": "test",
"organization_id": "xYZkjABcde",
"market_ids": [ "yzXKjYzaCx", "..." ]
}
}Similar cases
Just changing a couple of query keys and/or filter parameters you can address lots of very similar use cases, such as:
Last updated

