Group Cart Discounts and apply the best discount from the group to a cart.
100 Cart Discounts, and each Project can have up to 100 Discount Groups.Representations
DiscountGroup
| id​String​ | Unique identifier of the DiscountGroup. | 
| version​Int​ | Current version of the DiscountGroup. | 
| key​String​ | User-defined unique identifier of the DiscountGroup.MinLength: 2​MaxLength:Â256​Pattern:Â^[A-Za-z0-9_-]+$​ | 
| name​ | Name of the DiscountGroup. | 
| description​ | Description of the DiscountGroup. | 
| sortOrder​String​ | Value between  0and1that determines the order in which the CartDiscount from the DiscountGroup is applied; a CartDiscount with a higher value is prioritized.The sort order is unique among all DiscountGroups and CartDiscounts. | 
| isActive​Boolean​ | A DiscountGroup must be active for its CartDiscounts to be considered during discount application.Default: true​ | 
| createdAt​DateTime​ | Date and time (UTC) the DiscountGroup was initially created. | 
| createdBy​BETACreatedBy​ | IDs and references that created the DiscountGroup. | 
| lastModifiedAt​DateTime​ | Date and time (UTC) the DiscountGroup was last updated. | 
| lastModifiedBy​BETA | IDs and references that last modified the DiscountGroup. | 
{
  "id": "{{discount-group-id}}",
  "version": 1,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}DiscountGroupDraft
| key​String​ | User-defined unique identifier for the DiscountGroup.MinLength: 2​MaxLength:Â256​Pattern:Â^[A-Za-z0-9_-]+$​ | 
| name​ | Name of the DiscountGroup. | 
| description​ | Description for the DiscountGroup. | 
| sortOrder​String​ | Value between  0and1that determines the order in which the CartDiscount from the DiscountGroup will be applied; a CartDiscount with a higher value will be prioritized.The sort order must be unique among all DiscountGroups and CartDiscounts. | 
| isActive​Boolean​ | A DiscountGroup must be active for its CartDiscounts to be considered during discount application.Default: true​ | 
{
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true
}DiscountGroupPagedQueryResponse
| limit​Int​ | Number of results requested.Default: 20​Minimum:Â0​Maximum:Â500​ | 
| offset​Int​ | Number of elements skipped.Default: 0​Maximum:Â10000​ | 
| count​Int​ | Actual number of results returned. | 
| total​Int​ | Total number of results matching the query.
This number is an estimation that is not strongly consistent.
This field is returned by default.
For improved performance, calculating this field can be deactivated by using the query parameter  withTotal=false.
When the results are filtered with a Query Predicate,totalis subject to a limit. | 
| results​Array of DiscountGroup​ | DiscountGroups matching the query. | 
DiscountGroupReference
| id​String​ | Unique identifier of the referenced DiscountGroup. | 
| typeId​ | discount-groupType of referenced resource. | 
| obj​ | Contains the representation of the expanded DiscountGroup.
Only present in responses to requests with Reference Expansion for DiscountGroups. | 
DiscountGroupResourceIdentifier
id or key is required.
If both are set, an InvalidJsonInput error is returned.| id​String​ | Unique identifier of the referenced DiscountGroup.
Required if  keyis absent. | 
| key​String​ | User-defined unique identifier of the referenced DiscountGroup.
Required if  idis absent. | 
| typeId​ | discount-groupType of referenced resource. If given, it must match the expected ReferenceTypeId of the referenced resource. | 
Get DiscountGroup
Get DiscountGroup by ID
id.view_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| idString​ | idof the DiscountGroup. | 
| expand | The parameter can be passed multiple times. | 
application/jsoncurl --get https://api.{region}.commercetools.com/{projectKey}/discount-groups/{id} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" {
  "id": "{{discount-group-id}}",
  "version": 1,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}Get DiscountGroup by Key
key.view_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| keyString​ | keyof the DiscountGroup. | 
| expand | The parameter can be passed multiple times. | 
application/jsoncurl --get https://api.{region}.commercetools.com/{projectKey}/discount-groups/key={key} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" {
  "id": "{{discount-group-id}}",
  "version": 1,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}Query DiscountGroups
Retrieves all DiscountGroups in the Project.
view_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| where | The parameter can be passed multiple times. | 
| sort | The parameter can be passed multiple times. | 
| expand | The parameter can be passed multiple times. | 
| limitInt​ | Number of results requested. Default:  20​Minimum:  0​Maximum:  500​ | 
| offsetInt​ | Number of elements skipped. Default:  0​Maximum:  10000​ | 
| withTotalBoolean​ | Controls the calculation of the total number of query results. Set to  falseto improve query performance when thetotalis not needed.Default:  true​ | 
| var.<varName>String​ | Predicate parameter values. The parameter can be passed multiple times. | 
DiscountGroupPagedQueryResponse
asapplication/jsoncurl --get https://api.{region}.commercetools.com/{projectKey}/discount-groups -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" {
  "limit": 20,
  "offset": 0,
  "count": 1,
  "total": 1,
  "results": [
    {
      "id": "{{discount-group-id}}",
      "version": 1,
      "key": "black-friday-sale",
      "name": {
        "en": "Black Friday Sale"
      },
      "description": {
        "en": "10% discount on all items in cart"
      },
      "sortOrder": "0.01",
      "isActive": true,
      "createdAt": "2024-11-21T13:08:15.962Z",
      "lastModifiedAt": "2024-11-21T13:08:15.962Z",
      "lastModifiedBy": {
        "clientId": "{{client-id}}",
        "isPlatformClient": false
      },
      "createdBy": {
        "clientId": "{{client-id}}",
        "isPlatformClient": false
      }
    }
  ]
}Check if DiscountGroup exists
Check if DiscountGroup exists by ID
id.
Returns a 200 status if a DiscountGroup exists, or a 404 status otherwise.view_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| idString​ | idof the DiscountGroup. | 
curl --head https://api.{region}.commercetools.com/{projectKey}/discount-groups/{id} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" Check if DiscountGroup exists by Key
key.
Returns a 200 status if a DiscountGroup exists, or a 404 status otherwise.view_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| keyString​ | keyof the DiscountGroup. | 
curl --head https://api.{region}.commercetools.com/{projectKey}/discount-groups/key={key} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" Check if DiscountGroup exists by Query Predicate
200 status if any DiscountGroups match the query predicate, or a 404 status otherwise.view_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| where | The parameter can be passed multiple times. | 
curl --head https://api.{region}.commercetools.com/{projectKey}/discount-groups -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" Create DiscountGroup
manage_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| expand | The parameter can be passed multiple times. | 
application/jsonapplication/jsoncurl https://api.{region}.commercetools.com/{projectKey}/discount-groups -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" \
--header 'Content-Type: application/json' \
--data-binary @- << DATA 
{
  "key" : "black-friday-sale",
  "name" : {
    "en" : "Black Friday Sale"
  },
  "description" : {
    "en" : "10% discount on all items in cart"
  },
  "sortOrder" : "0.01",
  "isActive" : true
}
DATA{
  "id": "{{discount-group-id}}",
  "version": 1,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}Update DiscountGroup
Update DiscountGroup by ID
manage_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| idString​ | idof the DiscountGroup. | 
| expand | The parameter can be passed multiple times. | 
application/json| version​Int​ | Expected version of the DiscountGroup on which the changes should be applied.
If the expected version does not match the actual version, a ConcurrentModification error will be returned. | 
| actions​Array of DiscountGroupUpdateAction​ | Update actions to be performed on the DiscountGroup. | 
application/jsoncurl https://api.{region}.commercetools.com/{projectKey}/discount-groups/{id} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" \
--header 'Content-Type: application/json' \
--data-binary @- << DATA 
{
  "version" : 1,
  "actions" : [ {
    "action" : "setKey",
    "key" : "my-new-discount-group-key"
  } ]
}
DATA{
  "id": "{{discount-group-id}}",
  "version": 2,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": false,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}Update DiscountGroup by Key
manage_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| keyString​ | keyof the DiscountGroup. | 
| expand | The parameter can be passed multiple times. | 
application/json| version​Int​ | Expected version of the DiscountGroup on which the changes should be applied.
If the expected version does not match the actual version, a ConcurrentModification error will be returned. | 
| actions​Array of DiscountGroupUpdateAction​ | Update actions to be performed on the DiscountGroup. | 
application/jsoncurl https://api.{region}.commercetools.com/{projectKey}/discount-groups/key={key} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}" \
--header 'Content-Type: application/json' \
--data-binary @- << DATA 
{
  "version" : 1,
  "actions" : [ {
    "action" : "setKey",
    "key" : "my-new-discount-group-key"
  } ]
}
DATA{
  "id": "{{discount-group-id}}",
  "version": 2,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": false,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}Update actions
Set Key
| action​String​ | "setKey" | 
| key​String​ | New value to set.MinLength: 2​MaxLength:Â256​Pattern:Â^[A-Za-z0-9_-]+$​ | 
{
  "action": "setKey",
  "key": "new-key"
}Set Name
| action​String​ | "setName" | 
| name​ | New value to set. If empty, any existing value will be removed. | 
{
  "action": "setName",
  "name": {
    "en": "New name",
    "de": "Neuer Name"
  }
}Set Description
| action​String​ | "setDescription" | 
| description​ | Value to set. If empty, any existing value will be removed. | 
{
  "action": "setDescription",
  "description": {
    "en": "New description",
    "de": "Neue Beschreibung"
  }
}Set SortOrder
| action​String​ | "setSortOrder" | 
| sortOrder​String​ | New value to set (between  0and1).
A CartDiscount with a higher value will be prioritized.The sort order must be unique among all DiscountGroups and CartDiscounts. | 
{
  "action": "setSortOrder",
  "sortOrder": "0.2"
}Set IsActive
| action​String​ | "setIsActive" | 
| isActive​Boolean​ | New value to set. A DiscountGroup must be active for its CartDiscounts to be considered during discount application. | 
{
  "action": "setIsActive",
  "isActive": false
}Delete DiscountGroup
A DiscountGroup can only be deleted if it is not referenced by any CartDiscount.
Delete DiscountGroup by ID
manage_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| idString​ | idof the DiscountGroup. | 
| versionInt​ | Last seen version of the resource. | 
| expand | The parameter can be passed multiple times. | 
application/jsoncurl -X DELETE https://api.{region}.commercetools.com/{projectKey}/discount-groups/{id}?version={version} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}"{
  "id": "{{discount-group-id}}",
  "version": 1,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}Delete DiscountGroup by Key
manage_cart_discounts:{projectKey}| regionString​ | Region in which the Project is hosted. | 
| projectKeyString​ | keyof the Project. | 
| keyString​ | keyof the DiscountGroup. | 
| versionInt​ | Last seen version of the resource. | 
| expand | The parameter can be passed multiple times. | 
application/jsoncurl -X DELETE https://api.{region}.commercetools.com/{projectKey}/discount-groups/key={key}?version={version} -i \
--header "Authorization: Bearer ${BEARER_TOKEN}"{
  "id": "{{discount-group-id}}",
  "version": 1,
  "key": "black-friday-sale",
  "name": {
    "en": "Black Friday Sale"
  },
  "description": {
    "en": "10% discount on all items in cart"
  },
  "sortOrder": "0.01",
  "isActive": true,
  "createdAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedAt": "2024-11-21T13:08:15.962Z",
  "lastModifiedBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  },
  "createdBy": {
    "clientId": "{{client-id}}",
    "isPlatformClient": false
  }
}