Stores

Stores let you model the context your customers shop in.

Stores can be used to model, for example, physical retail locations, brand stores, or regions. They allow to define what subset of resources within a project is available in the context of a store.

Currently, a Store can hold Carts, Orders, Shopping Lists, Customers, and Products. For managing the availability of product assortments for your store, use Product Selections. Additional settings like languages or channels for inventory and pricing can be defined in the Store and used to query Product Projections that only contain localized values, inventory data and Prices that are suitable for the Store.

Permissions can be granted for particular Stores only. For example, with an OAuth Scope like manage_orders:acme-inc:luxury-brand, an API Client can only access Carts and Orders inside the luxury-brand Store, but not within the budget-brand Store. For more information, see the Helpers section.

Representations

Store

id
String

Unique ID of the Store.

version
Int

Current version of the Store.

key
String

User-defined unique and immutable identifier for the Store.

MinLength: 2MaxLength: 256Pattern: ^[A-Za-z0-9_-]+$
name

Name of the Store.

languages
Array of Locale

Languages configured for the Store.

countries
Array of StoreCountry

Countries defined for the Store.

distributionChannels
Array of ChannelReference

Product Distribution Channels allowed for the Store.

supplyChannels
Array of ChannelReference

Inventory Supply Channels allowed for the Store.

productSelections

Controls availability of Products for this Store via Product Selections:

  • Leave empty if all Products in the Project should be available in this Store.
  • If only inactive Product Selections with IndividualExclusion ProductSelectionMode are provided, all the Products are availlable in this Store.
  • If all the Product Selections provided are inactive and there's at least a Product Selection of mode Individual, no Product is availlable in this Store.
  • If at least an active Product Selection is provided, only active Product Selections are considered to compute the availlability in this Store.
custom

Custom fields for the Store.

createdAt

Date and time (UTC) the Store was initially created.

createdByBETA

Present on resources created after 1 February 2019 except for events not tracked.

lastModifiedAt

Date and time (UTC) the Store was last updated.

lastModifiedByBETA

Present on resources created after 1 February 2019 except for events not tracked.

StoreCountry

code

Two-digit country code as per ISO 3166-1 alpha-2External link icon.

StoreDraft

key
String

User-defined unique and immutable identifier for the Store. Keys can only contain alphanumeric characters, underscores, and hyphens.

MinLength: 2MaxLength: 256Pattern: ^[A-Za-z0-9_-]+$
name

Name of the Store.

languages
Array of Locale

Languages defined in Project. Only languages defined in the Project can be used.

countries
Array of StoreCountry

Countries defined for the Store.

distributionChannels

ResourceIdentifier of a Channel with ProductDistribution ChannelRoleEnum.

supplyChannels

ResourceIdentifier of a Channel with InventorySupply ChannelRoleEnum.

productSelections

Controls availability of Products for this Store via active/inactive Product Selections:

  • Leave empty if all Products in the Project should be available in this Store.
  • If only inactive Product Selections with IndividualExclusion ProductSelectionMode are provided, all the Products are available in this Store.
  • If all the Product Selections provided are inactive and there's at least a Product Selection of mode Individual, no Product is available in this Store.
  • If at least an active Product Selection is provided, only active Product Selections are considered to compute the availability in this Store.
custom

Custom fields for the Store.

StorePagedQueryResponse

PagedQueryResult with results containing an array of Store.

limit
Int
offset
Int

Number of elements skipped.

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, total is subject to a limit.

results
Array of Store

Stores matching the query.

StoreReference

id
String

Unique ID of the referenced Store.

typeId
String
"store"

References a Store.

obj

Contains the representation of the expanded Store. Only present in responses to requests with Reference Expansion for Stores.

StoreResourceIdentifier

id
String

Unique ID of the referenced Store. Either id or key is required.

key
String

Unique key of the referenced Store. Either id or key is required.

typeId
String
"store"

References a Store.

StoreKeyReference

Reference to a Store by its key.

key
String

Unique and immutable key of the referenced Store.

typeId
String
"store"

References a Store.

ProductSelectionSetting

productSelection

Reference to a ProductSelection.

active
Boolean

If true, all Products assigned to this Product Selection are part of the Store's assortment.

ProductSelectionSettingDraft

Resource Identifier of a ProductSelection.

active
Boolean

Set to true if all Products assigned to the Product Selection should become part of the Store's assortment.

Default: false

Get Store

Get Store by ID

GET
https://api.{region}.commercetools.com/{projectKey}/stores/{id}
OAuth 2.0 Scopes:
view_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

id
String

id of the Store.

Query parameters:
expand
The parameter can be passed multiple times.
Response:
Request Example:cURL
curl --get https://api.{region}.commercetools.com/{projectKey}/stores/{id} -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}'
Clipboard icon
200 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Get Store by Key

GET
https://api.{region}.commercetools.com/{projectKey}/stores/key={key}
OAuth 2.0 Scopes:
view_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

key
String

key of the Store.

Query parameters:
expand
The parameter can be passed multiple times.
Response:
Request Example:cURL
curl --get https://api.{region}.commercetools.com/{projectKey}/stores/key={key} -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}'
Clipboard icon
200 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Query Stores

GET
https://api.{region}.commercetools.com/{projectKey}/stores
OAuth 2.0 Scopes:
view_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

Query parameters:
where
The parameter can be passed multiple times.
/^var[.][a-zA-Z0-9]+$/
Any string parameter matching this regular expression

Predicate parameter values.

The parameter can be passed multiple times.
sort
The parameter can be passed multiple times.
expand
The parameter can be passed multiple times.
limit
Int
offset
Int

Number of elements skipped.

withTotal
Boolean

Controls the calculation of the total number of query results. Set to false to improve query performance when the total is not needed.

Request Example:cURL
curl --get https://api.{region}.commercetools.com/{projectKey}/stores -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}'
Clipboard icon
200 Response Example: StorePagedQueryResponsejson
{
"limit" : 20,
"offset" : 0,
"count" : 2,
"total" : 2,
"results" : [ {
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}, {
"id" : "c2f93209-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-1234314",
"name" : {
"en" : "second store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1973-01-01T00:00:00.001Z",
"lastModifiedAt" : "1973-01-01T00:00:00.001Z"
} ]
}
Clipboard icon

Create Store

POST
https://api.{region}.commercetools.com/{projectKey}/stores
OAuth 2.0 Scopes:
manage_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

Query parameters:
expand
The parameter can be passed multiple times.
Request Body:StoreDraftasapplication/json
Response:
201Storeasapplication/json
Request Example:cURL
curl https://api.{region}.commercetools.com/{projectKey}/stores -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}' \
--header 'Content-Type: application/json' \
--data-binary @- << DATA
{
"key" : "random-key-123",
"name" : {
"en" : "main store"
}
}
DATA
Clipboard icon
201 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Specific error codes:

Update Store

Update Store by ID

POST
https://api.{region}.commercetools.com/{projectKey}/stores/{id}
OAuth 2.0 Scopes:
manage_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

id
String

id of the Store.

Query parameters:
expand
The parameter can be passed multiple times.
Request Body:
application/json
version
Int

Expected version of the Store on which the changes should be applied. If the expected version does not match the actual version, a ConcurrentModification error is returned.

actions
Array of StoreUpdateAction

Update actions to be performed on the Store.

Response:
200Storeasapplication/json
Request Example:cURL
curl https://api.{region}.commercetools.com/{projectKey}/stores/{id} -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}' \
--header 'Content-Type: application/json' \
--data-binary @- << DATA
{
"version" : 1,
"actions" : [ {
"action" : "setName",
"name" : {
"en" : "New Name"
}
} ]
}
DATA
Clipboard icon
200 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Update Store by Key

POST
https://api.{region}.commercetools.com/{projectKey}/stores/key={key}
OAuth 2.0 Scopes:
manage_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

key
String

key of the Store.

Query parameters:
expand
The parameter can be passed multiple times.
Request Body:
application/json
version
Int

Expected version of the Store on which the changes should be applied. If the expected version does not match the actual version, a ConcurrentModification error is returned.

actions
Array of StoreUpdateAction

Update actions to be performed on the Store.

Response:
200Storeasapplication/json
Request Example:cURL
curl https://api.{region}.commercetools.com/{projectKey}/stores/key={key} -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}' \
--header 'Content-Type: application/json' \
--data-binary @- << DATA
{
"version" : 1,
"actions" : [ {
"action" : "setName",
"name" : {
"en" : "New Name"
}
} ]
}
DATA
Clipboard icon
200 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Update actions

Set Name

This update action produces the StoreNameSet Message.

action
String
"setName"
name

Value to set.

Example: json
{
"action" : "setName",
"name" : {
"en" : "New Name"
}
}
Clipboard icon

Set Languages

This update action produces the StoreLanguagesChanged Message. Adding a language other than the ones defined in the Project returns a ProjectNotConfiguredForLanguages error.

action
String
"setLanguages"
languages
Array of Locale

Value to set.

Example: json
{
"action" : "setLanguages",
"languages" : [ "en" ]
}
Clipboard icon

Set Countries

This update action produces the StoreCountriesChanged Message.

action
String
"setCountries"
countries
Array of StoreCountry

New value to set.

Example: json
{
"action" : "setCountries",
"countries" : [ {
"code" : "DE"
}, {
"code" : "IT"
} ]
}
Clipboard icon

Add Country

This update action produces the StoreCountriesChanged Message. It has no effect if the given country is already present in a Store.

action
String
"addCountry"
country

Value to append to countries.

Example: json
{
"action" : "addCountry",
"country" : {
"code" : "DE"
}
}
Clipboard icon

Remove Country

This update action produces the StoreCountriesChanged Message. It has no effect if a given country is not present in a Store.

action
String
"removeCountry"
country

Value to remove from countries.

Example: json
{
"action" : "removeCountry",
"country" : {
"code" : "DE"
}
}
Clipboard icon

Set Distribution Channels

This update action produces the StoreDistributionChannelsChanged Message.

Setting a Channel without the ProductDistribution ChannelRoleEnum returns a MissingRoleOnChannel error.

action
String
"setDistributionChannels"
distributionChannels

Value to set. If not defined, the Store's distributionChannels are unset.

Example: json
{
"action" : "setDistributionChannels",
"distributionChannels" : [ {
"typeId" : "channel",
"id" : "12345"
} ]
}
Clipboard icon

Add Distribution Channel

This update action produces the StoreDistributionChannelsChanged Message. It has no effect if a given distribution channel is already present in a Store.

Adding a Channel without the ProductDistribution ChannelRoleEnum returns a MissingRoleOnChannel error.

action
String
"addDistributionChannel"
distributionChannel

Value to append.

Example: json
{
"action" : "addDistributionChannel",
"distributionChannel" : {
"typeId" : "channel",
"id" : "12345"
}
}
Clipboard icon

Remove Distribution Channel

This update action produces the StoreDistributionChannelsChanged Message.

action
String
"removeDistributionChannel"
distributionChannel

Value to remove. ResourceIdentifier of a Channel with the ProductDistribution ChannelRoleEnum.

Example: json
{
"action" : "removeDistributionChannel",
"distributionChannel" : {
"typeId" : "channel",
"id" : "12345"
}
}
Clipboard icon

Set Supply Channels

Setting a supply channel produces the StoreSupplyChannelsChanged Message.

Setting a Channel without the InventorySupply ChannelRoleEnum returns a MissingRoleOnChannel error.

action
String
"setSupplyChannels"
supplyChannels

Value to set. If not defined, the Store's supplyChannels are unset.

Example: json
{
"action" : "setSupplyChannels",
"supplyChannels" : [ {
"typeId" : "channel",
"id" : "12345"
} ]
}
Clipboard icon

Add Supply Channel

This action has no effect if a given supply channel is already present in a Store.

Adding a supply channel produces the StoreSupplyChannelsChanged Message.

Adding a Channel without the InventorySupply ChannelRoleEnum returns a MissingRoleOnChannel error.

action
String
"addSupplyChannel"
supplyChannel

Value to append.

Example: json
{
"action" : "addSupplyChannel",
"supplyChannel" : {
"typeId" : "channel",
"id" : "12345"
}
}
Clipboard icon

Remove Supply Channel

This update action produces the StoreSupplyChannelsChanged Message.

action
String
"removeSupplyChannel"
supplyChannel

Value to remove. ResourceIdentifier of a Channel with the InventorySupply ChannelRoleEnum.

Example: json
{
"action" : "removeSupplyChannel",
"supplyChannel" : {
"typeId" : "channel",
"id" : "12345"
}
}
Clipboard icon

Add Product Selection

To make all included Products available to your customers of a given Store, add the Product Selections to the respective Store. This action has no effect if the given Product Selection is already present in the Store and has the same active flag.

action
String
"addProductSelection"

Product Selection to add to the Store either activated or deactivated.

active
Boolean

Set to true to make all Products assigned to the referenced Product Selection available in the Store.

Default: false
Example: json
{
"action" : "addProductSelection",
"productSelection" : {
"typeId" : "product-selection",
"id" : "e7ba4555-b1bb-483d-92d8-2c4a10778427"
},
"active" : false
}
Clipboard icon

A Store can incorporate multiple Product Selections, which is useful if a Product Selection is shared between Stores. For example, you may want to create a shared Product Selection as your base catalog which is supplemented by individual Product Selections for each Store.

Information icon

A Store without any Product Selection includes all Products of a Project.

The number of Product Selections configured for a Store is limited to 100.

Remove Product Selection

This action has no effect if the given Product Selection is not in the Store.

action
String
"removeProductSelection"

Value to remove. The removed Product Selection is made offline.

Example: json
{
"action" : "removeProductSelection",
"productSelection" : {
"typeId" : "product-selection",
"id" : "e7ba4555-b1bb-483d-92d8-2c4a10778427"
}
}
Clipboard icon

Set Product Selections

Instead of adding or removing Product Selections individually, you can also change all the Store's Product Selections in one go using this update action. The Store will only contain the Product Selections specified in the request.

action
String
"setProductSelections"
productSelections

Value to set.

  • If provided, Product Selections for which active is set to true are available in the Store.
  • If not provided or provided as empty array, the action removes all Product Selections from this Store, meaning all Products in the Project are available in this Store.
Example: json
{
"action" : "setProductSelections",
"productSelections" : [ {
"productSelection" : {
"typeId" : "product-selection",
"id" : "e7ba4555-b1bb-483d-92d8-2c4a10778427"
},
"active" : false
}, {
"productSelection" : {
"typeId" : "product-selection",
"id" : "a7ba45e5-b1c2-482d-94d5-2c1a10118426"
},
"active" : true
} ]
}
Clipboard icon

The number of Product Selections configured for a Store is limited to 100.

Change Product Selection Active

ProductSelection in a Store can be activated or deactivated using this update action.

action
String
"changeProductSelectionActive"

Current Product Selection of the Store to be activated or deactivated.

active
Boolean

Set to true if all Products assigned to the Product Selection should become part of the Store's assortment.

Default: false
Example: json
{
"action" : "changeProductSelectionActive",
"productSelection" : {
"typeId" : "product-selection",
"id" : "e7ba4555-b1bb-483d-92d8-2c4a10778427"
},
"active" : true
}
Clipboard icon

Set Custom Type

action
String
"setCustomType"

Defines the Type that extends the Store with Custom Fields. If absent, any existing Type and Custom Fields are removed from the Store.

fields

Sets the Custom Fields fields for the Store.

Example: json
{
"action" : "setCustomType",
"type" : {
"id" : "{{type-id}}",
"typeId" : "type"
},
"fields" : {
"exampleStringTypeField" : "TextString"
}
}
Clipboard icon

Set CustomField

action
String
"setCustomField"
name
String

Name of the Custom Field.

value

If value is absent or null, this field will be removed if it exists. Removing a field that does not exist returns an InvalidOperation error. If value is provided, it is set for the field defined by name.

Example: json
{
"action" : "setCustomField",
"name" : "ExampleStringTypeField",
"value" : "TextString"
}
Clipboard icon

Delete Store

Delete Store by ID

DELETE
https://api.{region}.commercetools.com/{projectKey}/stores/{id}
OAuth 2.0 Scopes:
manage_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

id
String

id of the Store.

Query parameters:
version
Int

Last seen version of the resource.

expand
The parameter can be passed multiple times.
Response:
Request Example:cURL
curl -X DELETE https://api.{region}.commercetools.com/{projectKey}/stores/{id}?version={version} -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}'
Clipboard icon
200 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Delete Store by Key

DELETE
https://api.{region}.commercetools.com/{projectKey}/stores/key={key}
OAuth 2.0 Scopes:
manage_stores:{projectKey}
Path parameters:
region
String

Region in which the Project is hosted.

projectKey
String

key of the Project.

key
String

key of the Store.

Query parameters:
version
Int

Last seen version of the resource.

expand
The parameter can be passed multiple times.
Response:
Request Example:cURL
curl -X DELETE https://api.{region}.commercetools.com/{projectKey}/stores/key={key}?version={version} -i \
--header 'Authorization: Bearer ${BEARER_TOKEN}'
Clipboard icon
200 Response Example: Storejson
{
"id" : "c2f93299-c967-44af-8c2a-d2220bf39eb2",
"version" : 1,
"key" : "random-key-12314",
"name" : {
"en" : "big store"
},
"languages" : [ ],
"countries" : [ ],
"distributionChannels" : [ ],
"supplyChannels" : [ ],
"productSelections" : [ ],
"createdAt" : "1971-01-01T00:00:00.001Z",
"lastModifiedAt" : "1972-01-01T00:00:00.001Z"
}
Clipboard icon

Helpers in the HTTP and GraphQL APIs

commercetools Commerce provides some helper methods for accessing resources within a specified Store.

In-Store representations

The In Store methods provide access to resources projected to the specified Store. Store-projected representations are supported for

Resources in StoreAPI methods
Product ProjectionsGet
CartsGet, Query, Create, Replicate, Update, Delete
My CartsGet, Get active Cart, Query, Create, Update, Delete
OrdersGet by ID, Query, Create from Cart, Update by ID, Delete by ID
Get by OrderNumber, Update by OrderNumber, Delete by OrderNumber
My OrdersGet by ID, Query, Create from Cart
Shopping ListsGet, Query, Create, Update, Delete
My Shopping ListsGet, Query, Create, Update, Delete
Information icon

To access to those endpoints your API Client requires store-related scopes, such as manage_orders:{project-key}:{store-key}.

Products available in Store

Store's active Product Selection(s) form its assortment. Or, in other words, a Product is considered available in a Store if it is:

  • not excluded by any of that Store's active Product Selection with IndividualExclusion ProductSelectionMode.
  • included in at least one of that Store's active Product Selections with Individual ProductSelectionMode.

When a Product is part of a Store's active Product Selection and has associated Variant Selection, its In-Store representation is projected such that only selected Product Variants are present.

When a Store has two, or more, active Product Selection(s) that contain the same Product but have different Variant Selections, Product's In-Store representation is resolved in following manner:

If Product's Variant Selection excludes all of the Product's Variants or if the Product is assigned to a Product Selection with mode IndividualExclusion without specifying any Variant Exclusion, the Product is considered as absent in the Store.

Information icon

The Store configuration is cached up to one minute as it is not expected to change frequently. Take that delay into account when fetching any projected Product in the Store.

GraphQL query fields

The top-level fields inStore and inStores are available to only query resources belonging to specified Stores. For example, the following query only returns IDs of Carts created in the luxury-brand Store, and the total field counts only Carts within that Store:

query {
inStore(key: "luxury-brand") {
carts {
results {
id
}
total
}
}
}
Clipboard icon

Similarly, inStores(keys: ["luxury-brand", "budget-brand"]) performs the queries only within these two Stores.

Both can either be used with regular OAuth permissions (for example manage_orders:project-key) or with the store-based OAuth permissions (for example manage_orders:project-key:store-key). For the inStores example, the OAuth scope must contain manage_orders:project-key:luxury-brand or manage_orders:project-key:budget-brand, else an insufficient_scope error is returned.

GraphQL mutations

Mutations on Carts, Orders, and Customers have an optional argument called storeKey. In the following example, the Cart is created in the Store luxury-brand:

mutation {
createCart(draft: { currency: "USD" }, storeKey: "luxury-brand") {
id
}
}
Clipboard icon

The following update to the Cart is only performed if the Cart is in the Store luxury-brand:

mutation {
updateCart(
id: "123e4567-e89b-12d3-a456-426655440000"
version: 1
actions: [{ addLineItem: { sku: "..." } }]
storeKey: "luxury-brand"
) {
id
}
}
Clipboard icon

This can either be used with regular OAuth permissions (for example manage_orders:project-key) or with the store-based OAuth permissions (for example manage_orders:project-key:store-key).