Change History
View changes made to resources within a Composable Commerce Project.
Change History is a historical log of changes (create, update, and delete) made to supported entity types within a Project.
The default offering of Audit Log (Audit Log Basic) only tracks changes made in the Merchant Center. With Audit Log Basic, changes originating from other sources, such as APIs, will not show in the query results.
Hosts
The Change History API has different hosts than the HTTP API and is hosted at the following URLs:
Region | API URL |
---|---|
North America (Google Cloud, Iowa) | https://history.us-central1.gcp.commercetools.com/ |
North America (AWS, Ohio) | https://history.us-east-2.aws.commercetools.com/ |
Europe (Google Cloud, Belgium) | https://history.europe-west1.gcp.commercetools.com/ |
Europe (AWS, Frankfurt) | https://history.eu-central-1.aws.commercetools.com/ |
Australia (Google Cloud, Sydney) | https://history.australia-southeast1.gcp.commercetools.com/ |
If the documentation refers to https://history.{region}.commercetools.com
, replace the {region}
placeholder with the actual value.
Representations
Representations are JSON objects submitted or received as payload to API requests or responses.
Record
Captures the differences between the previous and next version of a resource.
The maximum number of Records that can be stored and their retention period are subject to a limit.
version Int | Version of the resource after the change. For more information on how the version is incremented, see Optimistic Concurrency Control. |
previousVersion Int | Version of the resource before the change. |
type String | Indicates the type of change.
For creation, update, or deletion, the value is |
modifiedBy | Information about the user or API Client who performed the change. |
modifiedAt String | Date and time (UTC) the change was made. |
label | Information that describes the resource after the change. |
previousLabel | Information that describes the resource before the change. |
changes Array of Change | Shows the differences in the resource between The value is not identical to the actual array of update actions sent and is not limited to update actions (see, for example, Optimistic Concurrency Control). |
resource | ResourceIdentifier of the changed resource. |
stores Array of KeyReference | |
businessUnit | Reference to the Business Unit associated with the Change. |
withoutChanges Boolean |
The version number of the resource can be increased even without any change in the resource. |
{"version": 2,"previousVersion": 1,"type": "ResourceUpdated","modifiedAt": "2020-03-22T23:00:00.000Z","modifiedBy": {"isPlatformClient": true,"id": "example_user_123","type": "user","customer": {"id": "test1","typeId": "customer"}},"resource": {"id": "some_entity_id_123","typeId": "product","key": "some_entity_key_123"},"label": {"value": "some_label","type": "StringLabel"},"previousLabel": {"value": "some_label","type": "StringLabel"},"withoutChanges": false,"stores": [],"businessUnit": {"typeId": "business-unit","key": "some_business_unit_key_123"},"changes": [{"change": "setKey","previousValue": "Key 1","nextValue": "Key 2","type": "SetKeyChange"}]}
RecordPagedQueryResponse
PagedQueryResult with results
containing an array of Record.
limit Int | Number of results requested. Default:20 Maximum: 500 |
count Int | Actual number of results returned. |
total Int | Total number of results matching the query. This number is an estimation and not strongly consistent. |
offset Int | Number of elements skipped. Default:0 Maximum: 10 000 |
results Array of Record | Records matching the query. |
{"limit": 20,"offset": 0,"count": 1,"total": 0,"results": [{"version": 2,"previousVersion": 1,"type": "ResourceUpdated","modifiedAt": "2020-03-22T23:00:00.000Z","modifiedBy": {"isPlatformClient": true,"id": "example_user_123","type": "user","customer": {"id": "test1","typeId": "customer"}},"resource": {"id": "some_entity_id_123","typeId": "product","key": "some_entity_key_123"},"label": {"value": "some_label","type": "StringLabel"},"previousLabel": {"value": "some_label","type": "StringLabel"},"withoutChanges": false,"stores": [{"key": "store-1","typeId": "store"}],"businessUnit": {"typeId": "business-unit","key": "some_business_unit_key_123"},"changes": [{"change": "setKey","previousValue": "Key 1","nextValue": "Key 2","type": "SetKeyChange"}]}]}
ModifiedBy
Information about the user or API Client who performed the change. This is a variant of LastModifiedBy.
id String | ID of the Merchant Center user who made the change. Present only if |
isPlatformClient Boolean |
|
type String | Indicates who performed the change.
|
clientId String | ID of the API Client that made the change. Present only if the change was made using an API Client. |
anonymousId String | Present only if the change was made using a token from an anonymous session. |
customer | The Customer who made the change. Present only if the change was made using a token from the password flow. |
associate | The Associate who made the change in the context of a Business Unit. Present only if the Associate acts on behalf of a company using the associate endpoints. |
{"isPlatformClient": true,"id": "example_user_123","type": "user","customer": {"id": "test1","typeId": "customer"}}
Source
Source of change for the resource.
MerchantCenter
The change was made through the Merchant Center.
ImpEx
The change was made through the now-decommissioned ImpEx tool.
ApiClient
The change was made through an API Client.
ChangeHistoryResourceType
Value of resource types supported in Change History.
associate-role
for AssociateRole
business-unit
for BusinessUnit
cart-discount
for CartDiscount
category
for Category
channel
for Channel
customer
for Customer
customer-group
for CustomerGroup
discount-code
for DiscountCode
inventory-entry
for InventoryEntry
key-value-document
for CustomObject
order
for Order
payment
for Payment
product
for Product
product-discount
for ProductDiscount
product-selection
for ProductSelection
product-type
for ProductType
quote-request
for QuoteRequest
quote
for Quote
review
for Review
shopping-list
for ShoppingList
staged-quote
for StagedQuote
state
for State
store
for Store
tax-category
for TaxCategory
type
for Type
zone
for Zone
Label
Provides descriptive information specific to the change.
AssociateRoleLabel
key String | User-defined unique identifier of the Associate Role. |
type String | "AssociateRoleLabel" |
name String | Name of the Associate Role. |
BusinessUnitLabel
key String | User-defined unique identifier of the Business Unit. |
type String | "BusinessUnitLabel" |
name String | Name of the Business Unit. |
CustomerLabel
customerNumber String | User-defined unique identifier of the Customer. |
type String | "CustomerLabel" |
firstName String | Given name (first name) of the Customer. |
lastName String | Family name (last name) of the Customer. |
CustomObjectLabel
key String | User-defined unique identifier of the CustomObject within the defined |
type String | "CustomObjectLabel" |
container String | Namespace to group Custom Objects. |
LocalizedLabel
type String | "LocalizedLabel" |
value | Changed value. |
OrderLabel
type String | "OrderLabel" |
customerEmail String | Email address of the Customer that the Order belongs to. |
orderNumber String | User-defined unique identifier of the Order that is unique across a Project. |
PaymentLabel
key String | User-defined unique identifier of the Payment. |
type String | "PaymentLabel" |
amountPlanned | Money value the Payment intends to receive from the Customer. |
ProductLabel
type String | "ProductLabel" |
slug | User-defined identifier used in a deep-link URL for the Product. |
name | Name of the Product. |
QuoteRequestLabel
QuoteLabel
ReviewLabel
key String | User-defined unique identifier of the Review. |
type String | "ReviewLabel" |
title String | Title of the Review. |
StagedQuoteLabel
StringLabel
type String | "StringLabel" |
value String | Changed value. |
DateStringFilter
This data type consists of one enum value: "now"
.
PlatformInitiatedChange
Updates that are triggered automatically as a result of a user-initiated change.
excludeAll
changeLineItemName
changeReviewRatingStatistics
setApplicationVersion
setIsValid
setVariantAvailability
Query Records
The view_audit_log:{projectKey}
scope is required, and depending on the resource type queried, their respective scopes must be granted.
view_associate_roles:{projectKey}
view_audit_log:{projectKey}
view_business_units:{projectKey}
view_cart_discounts:{projectKey}
view_categories:{projectKey}
view_customers:{projectKey}
view_customers:{projectKey}:{storeKey}
view_customer_groups:{projectKey}
view_discount_codes:{projectKey}
view_key_value_documents:{projectKey}
view_orders:{projectKey}
view_orders:{projectKey}:{storeKey}
view_payments:{projectKey}
view_products:{projectKey}
view_product_selections:{projectKey}
view_quotes:{projectKey}
view_quote_requests:{projectKey}
view_shopping_lists:{projectKey}
view_shopping_lists:{projectKey}:{storeKey}
view_states:{projectKey}
view_staged_quotes:{projectKey}
view_stores:{projectKey}
view_tax_categories:{projectKey}
view_types:{projectKey}
region String | The Region in which the project is hosted. |
projectKey String |
|
expand Boolean | If |
limit Int | Number of results requested. Default: 20 |
offset Int | Number of elements skipped. Default: 0 |
resourceTypes | Can be used to filter Records of specified resource types. By default, the API returns the Records of all supported resource types. The parameter can be passed multiple times. |
date.from | Can be DateTime, non-negative integer, or Default: 24 |
date.to | Can be DateTime, non-negative integer, or Default: now |
userId String | ID of the Merchant Center user who made the change. Can be used to query changes made by a Merchant Center user. |
clientId String | ID of the API Client that made the change. |
customerId String | ID of the Customer who made the change using a token from the password flow. |
associateId String | ID of the Associate that made the change. Only Changes to Business Units, Orders, Quote Requests, and Quotes can be filtered. |
businessUnit String |
|
type String | Can be Can be used to filter for a specific type of change (creation, update, or deletion). |
resourceId String | ID of the changed resource. |
resourceKey String | Key of the changed resource. Only Changes to Business Units, Associate Roles, Products, and Stores can be filtered. |
source | Source of the change. |
changes String | Restrict the types of Changes returned by passing the value of the The parameter can be passed multiple times. |
stores String |
The parameter can be passed multiple times. |
excludePlatformInitiatedChanges | Excludes Changes initiated by background processes by passing the values of the
The parameter can be passed multiple times. |
application/json
curl --get https://history.{region}.commercetools.com/{projectKey} -i \--header "Authorization: Bearer ${BEARER_TOKEN}"
{"limit": 20,"offset": 0,"count": 1,"total": 0,"results": [{"version": 2,"previousVersion": 1,"type": "ResourceUpdated","modifiedAt": "2020-03-22T23:00:00.000Z","modifiedBy": {"isPlatformClient": true,"id": "example_user_123","type": "user","customer": {"id": "test1","typeId": "customer"}},"resource": {"id": "some_entity_id_123","typeId": "product","key": "some_entity_key_123"},"label": {"value": "some_label","type": "StringLabel"},"previousLabel": {"value": "some_label","type": "StringLabel"},"withoutChanges": false,"stores": [{"key": "store-1","typeId": "store"}],"businessUnit": {"typeId": "business-unit","key": "some_business_unit_key_123"},"changes": [{"change": "setKey","previousValue": "Key 1","nextValue": "Key 2","type": "SetKeyChange"}]}]}
Query Records for specific resource type
The view_audit_log:{projectKey}
scope is required, and depending on the resource type queried, their respective scopes must be granted.
view_associate_roles:{projectKey}
view_audit_log:{projectKey}
view_business_units:{projectKey}
view_cart_discounts:{projectKey}
view_categories:{projectKey}
view_customers:{projectKey}
view_customer_groups:{projectKey}
view_discount_codes:{projectKey}
view_key_value_documents:{projectKey}
view_orders:{projectKey}
view_orders:{projectKey}:{storeKey}
view_payments:{projectKey}
view_products:{projectKey}
view_product_selections:{projectKey}
view_quotes:{projectKey}
view_quote_requests:{projectKey}
view_shopping_lists:{projectKey}
view_states:{projectKey}
view_staged_quotes:{projectKey}
view_stores:{projectKey}
view_tax_categories:{projectKey}
view_types:{projectKey}
region String | The Region in which the project is hosted. |
projectKey String |
|
resourceType String | Resource type for which a query is made.
The value must be one of the following:
|
expand Boolean | If |
limit Int | Number of results requested. Default: 20 |
offset Int | Number of elements skipped. Default: 0 |
date.from | Can be DateTime, non-negative integer, or Default: 24 |
date.to | Can be DateTime, non-negative integer, or Default: now |
userId String | ID of the Merchant Center user who made the change. Can be used to query changes made by a Merchant Center user. |
clientId String | ID of the API Client that made the change. |
customerId String | ID of the Customer who made the change using a token from the Password Flow. |
associateId String | ID of the Associate that made the change. Only Changes to Business Units, Orders, Quote Requests, and Quotes can be filtered. |
businessUnit String |
|
type String | Can be |
resourceKey String | Key of the changed resource. Only Changes to Business Units, Associate Roles, Products, and Stores can be filtered. |
source | Source of the change. |
changes String | Restrict the types of Changes returned by passing the value of the The parameter can be passed multiple times. |
stores String |
The parameter can be passed multiple times. |
excludePlatformInitiatedChanges | Exclude Changes initiated by background processes by passing the values of the
The parameter can be passed multiple times. |
application/json
curl --get https://history.{region}.commercetools.com/{projectKey}/{resourceType} -i \--header "Authorization: Bearer ${BEARER_TOKEN}"
{"limit": 20,"offset": 0,"count": 1,"total": 0,"results": [{"version": 2,"previousVersion": 1,"type": "ResourceUpdated","modifiedAt": "2020-03-22T23:00:00.000Z","modifiedBy": {"isPlatformClient": true,"id": "example_user_123","type": "user","customer": {"id": "test1","typeId": "customer"}},"resource": {"id": "some_entity_id_123","typeId": "product","key": "some_entity_key_123"},"label": {"value": "some_label","type": "StringLabel"},"previousLabel": {"value": "some_label","type": "StringLabel"},"withoutChanges": false,"stores": [{"key": "store-1","typeId": "store"}],"businessUnit": {"typeId": "business-unit","key": "some_business_unit_key_123"},"changes": [{"change": "setKey","previousValue": "Key 1","nextValue": "Key 2","type": "SetKeyChange"}]}]}
Query Records by resource ID
The view_audit_log:{projectKey}
scope is required, and depending on the resource type queried, their respective scopes must be granted.
view_associate_roles:{projectKey}
view_audit_log:{projectKey}
view_business_units:{projectKey}
view_cart_discounts:{projectKey}
view_orders:{projectKey}
view_orders:{projectKey}:{storeKey}
view_categories:{projectKey}
view_products:{projectKey}
view_customers:{projectKey}
view_customer_groups:{projectKey}
view_discount_codes:{projectKey}
view_key_value_documents:{projectKey}
view_payments:{projectKey}
view_product_selections:{projectKey}
view_quotes:{projectKey}
view_quote_requests:{projectKey}
view_shopping_lists:{projectKey}
view_states:{projectKey}
view_staged_quotes:{projectKey}
view_stores:{projectKey}
view_tax_categories:{projectKey}
view_types:{projectKey}
region String | The Region in which the project is hosted. |
projectKey String |
|
resourceType String | Resource type for which a query is made.
The value must be one of the following:
|
id String | ID of the resource for which a query is made. |
expand Boolean | If |
limit Int | Number of results requested. Default: 20 |
offset Int | Number of elements skipped. Default: 0 |
date.from | Can be DateTime, non-negative integer, or Default: 24 |
date.to | Can be DateTime, non-negative integer, or Default: now |
userId String | ID of the Merchant Center user who made the change. Can be used to query changes made by a Merchant Center user. |
clientId String | ID of the API Client that made the change. |
customerId String | ID of the Customer who made the change using a token from the Password Flow. |
associateId String | ID of the Associate that made the change. Only Changes to Business Units, Orders, Quote Requests, and Quotes can be filtered. |
businessUnit String |
|
type String | Can be |
source | Source of the change. |
changes String | Restrict the types of Changes returned by passing the value of the The parameter can be passed multiple times. |
stores String |
The parameter can be passed multiple times. |
excludePlatformInitiatedChanges | Exclude Changes initiated by background processes by passing the values of the
The parameter can be passed multiple times. |
application/json
curl --get https://history.{region}.commercetools.com/{projectKey}/{resourceType}/{id} -i \--header "Authorization: Bearer ${BEARER_TOKEN}"
{"limit": 20,"offset": 0,"count": 1,"total": 0,"results": [{"version": 2,"previousVersion": 1,"type": "ResourceUpdated","modifiedAt": "2020-03-22T23:00:00.000Z","modifiedBy": {"isPlatformClient": true,"id": "example_user_123","type": "user","customer": {"id": "test1","typeId": "customer"}},"resource": {"id": "some_entity_id_123","typeId": "product","key": "some_entity_key_123"},"label": {"value": "some_label","type": "StringLabel"},"previousLabel": {"value": "some_label","type": "StringLabel"},"withoutChanges": false,"stores": [{"key": "store-1","typeId": "store"}],"businessUnit": {"typeId": "business-unit","key": "some_business_unit_key_123"},"changes": [{"change": "setKey","previousValue": "Key 1","nextValue": "Key 2","type": "SetKeyChange"}]}]}
Query Records with GraphQL
GraphQL uses HTTP POST requests to query data. Access to resources is granted by the same scopes that are used on the REST API endpoints.
The view_audit_log:{projectKey}
scope is required, and depending on the resource type queried, their respective scopes must be granted too—for example, to filter queries by Categories, provide the view_categories:{projectKey}
scope too.
Execute a GraphQL request.
view_audit_log:{projectKey}
view_categories:{projectKey}
region String | The Region in which the project is hosted. |
projectKey String |
|
application/json
application/json
curl https://history.{region}.commercetools.com/{projectKey}/graphql -i \--header "Authorization: Bearer ${BEARER_TOKEN}" \--header 'Content-Type: application/json' \--data-binary @- << DATA{"query" : "query getCategoryChanges($startDate: DateFilterValue!, $endDate: DateFilterValue!){categories(date:{from:$startDate to:$endDate}) {results {type modifiedAt changes {previousValue nextValue change} resource{id} }}}","operationName" : "getCategoryChanges","variables" : {"startDate" : "2024-09-07T08:53:28.471Z","endDate" : "2024-11-07T08:53:28.471Z"}}DATA
{"data": {"categories": {"results": [{"type": "ResourceUpdated","modifiedAt": "2024-11-07T08:53:28.471Z","changes": [{"previousValue": {"en": "Old name for Category"},"nextValue": {"en": "New name for Category"},"change": "changeName"}],"resource": {"id": "cd260fc9-c575-4ba3-8789-cc4c9980ee4e"}},{"type": "ResourceCreated","modifiedAt": "2024-10-22T22:39:44.201Z","changes": [],"resource": {"id": "ffae2221-40c4-410d-bd13-e0fa4b6a4dd6"}}]}}}
Interactive GraphQL console
You can also use the Apollo GraphQL console to query Records. It lets you explore the documentation for supported GraphQL queries and introspect the GraphQL schema.
In the console, go to Connection settings and enter the values for the following:
For Endpoint, enter:
https://history.{region}.commercetools.com/{projectKey}/graphqlFor Shared headers, select
Authorization
as the header key and enterBearer {bearerToken}
as the value.