Orders associated with a specific promotion

How to use the Metrics API to get the total number of orders that triggered a specific promotion

The problem

You want to get the total number of orders to which a specific promotion (identified by its type and name) was applied, over a selected date and time range.

The solution

Query

You need to perform a stats query setting the required query keys as follows and adding the optional ones based on your needs:

Key
Value

field

order.id

operator

value_count

Filter

Set the desired date and time range using the date_from and date_to keys and add additional filters on the line items field to restrict the related computation to the orders that triggered the desired promotion:

Attribute
Operator

types

"in": [ "percentage_discount_promotions" ]

names

"in": [ "Percentage 50" ]

As shown in the example below, use placed_at as the date_field in the date filter if you want the results to count all the orders that were placed in the selected date and time range (read more about this).

Example

The following request uses the Metrics API to get the total number of orders that triggered a specific promotion:

curl -g -X POST \
  'https://{{your_domain}}.commercelayer.io/metrics/orders/stats' \
  -H 'Accept: application/vnd.api.v1+json' \
  -H 'Content-Type: application/vnd.api+json' \
  -H 'Authorization: Bearer {{your_access_token}}' \
  -d '{
    "stats": {
      "field": "order.id",
      "operator": "value_count"
    },
    "filter": {
      "order": {
        "date_from": "2021-01-01T00:00:00Z",
        "date_to": "2021-12-31T23:59:00Z",
        "date_field": "placed_at"
      },
      "line_items": {
        "types": {
          "in": [ "percentage_discount_promotions" ]
        },
        "names": {
          "in": [ "Percentage 50" ]
        }
      }
    }
  }'

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