Manage Stackable Coupons (v1.0)
Download OpenAPI specification:Download
Use this API to manage stackable coupons for your business.
Important: This resource is different than the legacy coupons resource, which is used to create legacy coupons and coupon definitions in the platform.
Create coupon
Use this method to create a coupon definition for your business.
You can create a coupon of any of the promotion types, and they are applied via coupon codes associated to the coupon definition.
Authorizations:
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Request Body schema: application/json
a new coupon definition
active | boolean Indicates whether the coupon is active or not |
name required | string The name of the coupon |
description | string |
localizedTimezone | boolean Optional, this property determines local timezone validity for the promotion. If true, UTC is assumed with no timezone required in "validFrom" and "validTo". If false, timezone must be specified in those fields. |
validFrom required | string(?:^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}$)|(?:... The date the promotion becomes valid. If localizedTimezone is false, timezone can be indicated at the end of the string. |
validTo | string(?:^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}$)|(?:... The date the promotion becomes invalid. If localizedTimezone is false, timezone can be indicated at the end of the string. |
Array of objects | |
singleUse | boolean Indicates whether the coupon codes are single use or not. |
required | object |
stores | Array of strings Indicates in which stores the coupon can be used. A list of IDs states that the coupon can be used in the given stores while an empty array states that the coupon can be used in any store. |
consumers | Array of strings Indicates by which consumers the coupon can be used. A list of IDs states that the coupon can be used by the given consumers while an empty array states that the coupon can be used by any consumers. |
Responses
Request samples
- Payload
{- "name": "Cart level percentage coupon",
- "description": "A coupon with type CartLevelPercentage",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": {
- "kind": "CartLevelPercentage",
- "discount": 10
}, - "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": 10
}
], - "singleUse": false,
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
]
}
Response samples
- 201
- 400
- 500
{- "coupon": {
- "id": "7c9f2605-9fb3-5444-8fee-47fe51608efe",
- "active": false,
- "name": "Coupon for hoodies",
- "description": "A coupon for hoodies",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": {
- "kind": "CartLevelPercentage",
- "discount": 10
}, - "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": 10
}
], - "codes": [ ],
- "singleUse": false,
- "createdAt": "2021-12-31T00:00:00",
- "updatedAt": "2021-12-31T00:00:00",
- "createdBy": "store-employee-1",
- "updatedBy": "store-employee-1",
- "tenant": "newstore",
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
], - "version": "2"
}, - "links": {
- "self": "/coupon/6297992e-58ac-4000-8000-3766e65e2e3c"
}
}
List coupons
Retrieves all coupons created for your business via NewStore Omnichannel Manager or the Create coupon method.
Authorizations:
query Parameters
count required | integer The number of promotions to get at once |
page required | integer The page number |
name | string The names of the coupons you want to get (it can be a list of comma separated values) |
code | string The codes for which you want to get the coupons (it can be a list of comma separated values) |
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Responses
Response samples
- 200
- 400
- 500
{- "items": [
- {
- "coupon": {
- "id": "7c9f2605-9fb3-5444-8fee-47fe51608efe",
- "active": true,
- "name": "Coupon for hoodies",
- "description": "A coupon for hoodies",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": {
- "kind": "CartLevelPercentage",
- "discount": 5
}, - "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": 10
}
], - "codes": [
- {
- "id": "628e411f-5fa1-4000-8000-7ef82f43053f",
- "name": "HOODIE2022",
- "redemptions": 0,
- "active": true
}
], - "singleUse": false,
- "createdAt": "2021-12-31T00:00:00",
- "updatedAt": "2021-12-31T00:00:00",
- "createdBy": "store-employee-1",
- "updatedBy": "store-employee-1",
- "tenant": "newstore",
- "version": "2",
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
]
}, - "links": {
- "self": "/coupon/7c9f2605-9fb3-5444-8fee-47fe51608efe"
}
}, - {
- "coupon": {
- "id": "6cxtew5ec-9fb3-5478-9cre6-8ue3289y",
- "active": false,
- "name": "Coupon for t-shirts",
- "description": "A coupon for t-shirts",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": {
- "kind": "CartLevelPercentage",
- "discount": 3
}, - "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": 5
}
], - "codes": [
- {
- "id": "6283d0e7-9487-4000-8000-d387d2d71138",
- "name": "TSHIRT2022",
- "redemptions": 0,
- "active": true
}
], - "singleUse": false,
- "createdAt": "2021-11-01T00:00:00",
- "updatedAt": "2021-11-01T00:00:00",
- "createdBy": "store-employee-2",
- "updatedBy": "store-employee-2",
- "tenant": "newstore",
- "version": "1",
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
]
}, - "links": {
- "self": "/coupon/6cxtew5ec-9fb3-5478-9cre6-8ue3289y"
}
}
], - "links": {
- "next": "/coupon?count=25&page=2",
- "previous": ""
}, - "pagination": {
- "count": 2,
- "page": 1,
- "total": 3
}
}
Get coupons
Retrieves the specified coupon definition by ID. To retrieve the coupon ID, use the List coupons method.
Authorizations:
path Parameters
id required | string |
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Responses
Response samples
- 200
- 404
- 500
{- "coupon": {
- "id": "7c9f2605-9fb3-5444-8fee-47fe51608efe",
- "active": false,
- "name": "Promotion for hoodies",
- "description": "A promotion for hoodies",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": {
- "kind": "CartLevelPercentage",
- "discount": 10
}, - "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": 10
}
], - "codes": [
- {
- "id": "62839b62-80ff-4000-8000-01b47275b242",
- "name": "CODE1",
- "redemptions": 0,
- "active": true
}, - {
- "id": "6283d0e7-9487-4000-8000-d387d2d71138",
- "name": "CODE2",
- "redemptions": 0,
- "active": true
}
], - "singleUse": true,
- "createdAt": "2021-12-31T00:00:00",
- "updatedAt": "2021-12-31T00:00:00",
- "createdBy": "store-employee-1",
- "updatedBy": "store-employee-1",
- "tenant": "newstore",
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
], - "version": "1"
}, - "links": {
- "self": "/coupon/7c9f2605-9fb3-5444-8fee-47fe51608efe"
}
}
Update coupon
Updates the specified coupon definition with new information. Use this method to switch
a coupon to an active
state or change the currencies that the coupon can be applied
to, and so on.
Given the nature of the update, the complete object needs to be passed in the request.
The only property that cannot be updated is the category
.
To retrieve the coupon ID, use the List coupons method.
Authorizations:
path Parameters
id required | string |
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Request Body schema: application/json
The updated coupon
tenant | string |
version required | string |
active | boolean Indicates whether the coupon is active or not |
name | string The name of the coupon |
description | string |
localizedTimezone | boolean Optional, this property determines local timezone validity for the promotion. If true, UTC is assumed with no timezone required in "validFrom" and "validTo". If false, timezone must be specified in those fields. |
validFrom | string(?:^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}$)|(?:... The date the promotion becomes valid. If localizedTimezone is false, timezone can be indicated at the end of the string. |
validTo | string(?:^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}$)|(?:... The date the promotion becomes invalid. If localizedTimezone is false, timezone can be indicated at the end of the string. |
Array of objects | |
singleUse | boolean Indicates whether the coupon codes associated to this coupon definition are single use or not. |
object | |
stores | Array of strings Indicates in which stores the coupon can be used. A list of IDs states that the coupon can be used in the given stores while an empty array states that the coupon can be used in any store. |
consumers | Array of strings Indicates by which consumers the coupon can be used. A list of IDs states that the coupon can be used by the given consumers while an empty array states that the coupon can be used by any consumers. |
Responses
Request samples
- Payload
{- "id": "62839b62-80ff-4000-8000-01b47275b241",
- "name": "My Coupon",
- "description": "My Coupon Description",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": [
- {
- "kind": "CartLevelPercentage",
- "discount": 10
}
], - "active": true,
- "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": "0.00000"
}
], - "version": "6f419b7b-1529-4c33-a5ba-a07762850db1",
- "singleUse": false,
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
]
}
Response samples
- 200
- 400
- 404
- 409
- 500
{- "coupon": {
- "id": "7c9f2605-9fb3-5444-8fee-47fe51608efe",
- "active": false,
- "name": "Coupon for hoodies",
- "description": "A coupon for hoodies",
- "localizedTimezone": false,
- "validFrom": "2022-01-01T00:00:00+01:00",
- "validTo": "2022-04-01T00:00:00+01:00",
- "category": {
- "kind": "CartLevelPercentage",
- "discount": 10
}, - "currencies": [
- {
- "code": "EUR",
- "minimumCartValue": 10
}
], - "codes": [ ],
- "singleUse": false,
- "createdAt": "2021-12-31T00:00:00",
- "updatedAt": "2021-12-31T00:00:00",
- "createdBy": "store-employee-1",
- "updatedBy": "store-employee-1",
- "tenant": "newstore",
- "stores": [
- "f9c7b6ec-b296-4eba-b083-c8b53d14407d",
- "b25fd287-90cb-421c-a2b7-27691742f55b"
], - "consumers": [
- "2dbb6700-d847-11ed-afa1-0242ac120002",
- "3c8eb0de-d847-11ed-afa1-0242ac120002"
], - "version": "2"
}, - "links": {
- "self": "/coupon/6297992e-58ac-4000-8000-3766e65e2e3c"
}
}
Create coupon codes
Use this method to create coupon codes associated to a coupon definition. To retrieve the coupon ID, use the List coupons method.
You don't need the Label
property in the request payload while creating coupons.
Authorizations:
path Parameters
id required | string |
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Request Body schema: application/json
a list of new coupon codes
codes required | Array of strings |
Responses
Request samples
- Payload
{- "codes": [
- "CODE1",
- "CODE2"
]
}
Response samples
- 201
- 400
- 404
- 500
{- "links": [
- {
- "self": "/coupon/62839b62-80ff-4000-8000-01b47275b241/code/629868d2-58ac-4000-8000-3766e65e2e3d"
}, - {
- "self": "/coupon/62839b62-80ff-4000-8000-01b47275b241/code/62986960-0b13-4000-8000-1a636b395759"
}
], - "codes": [
- {
- "id": "629868d2-58ac-4000-8000-3766e65e2e3d",
- "name": "CODE1",
- "redemptions": 0,
- "active": true
}, - {
- "id": "62986960-0b13-4000-8000-1a636b395759",
- "name": "CODE2",
- "redemptions": 0,
- "active": true
}
]
}
Get coupon codes
Use this method to retrieve coupon codes.
Authorizations:
path Parameters
id required | string |
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Responses
Response samples
- 200
- 404
- 500
{- "links": [
- {
- "self": "/coupon/6398b3a2-9ff8-4000-8000-c557ac5c2431/code/6398b3a3-9ff8-4000-8000-c557ac5c2432"
}, - {
- "self": "/coupon/6398b3a2-9ff8-4000-8000-c557ac5c2431/code/6398b3a3-9ff8-4000-8000-c557ac5c2433"
}, - {
- "self": "/coupon/6398b3a2-9ff8-4000-8000-c557ac5c2431/code/6398b3a3-9ff8-4000-8000-c557ac5c2434"
}
], - "codes": [
- {
- "id": "6398b3a3-9ff8-4000-8000-c557ac5c2432",
- "name": "TESTCODE1",
- "redemptions": 0,
- "active": true
}, - {
- "id": "6398b3a3-9ff8-4000-8000-c557ac5c2433",
- "name": "TESTCODE2",
- "redemptions": 0,
- "active": true
}, - {
- "id": "6398b3a3-9ff8-4000-8000-c557ac5c2434",
- "name": "TESTCODE3",
- "redemptions": 0,
- "active": true
}
]
}
Update coupon codes
Use this method to update the specified coupon code, you can switch a coupon code to an active
state or not.
Authorizations:
path Parameters
coupon_id required | string |
code_id required | string |
header Parameters
x-request-id | string |
tenant required | string |
user-id required | string |
Request Body schema: application/json
The updated coupon codes
Responses
Request samples
- Payload
{- "id": "6398b3a3-9ff8-4000-8000-c557ac5c2432",
- "name": "TESTCODE1",
- "redemptions": 0,
- "active": false
}
Response samples
- 400
- 500
{- "message": "string",
- "status": 0,
- "causes": [
- "string"
], - "id": "string",
- "type": "string",
- "code": "string"
}
Create Coupon Codes Import
Use this method to create coupon codes by importing a CSV file.
Authorizations:
path Parameters
id required | string The ID of the coupon. |
header Parameters
tenant required | string |
user-id required | string |
Request Body schema: multipart/form-data
Create coupon codes import request by importing a CSV file containing coupon codes.
import required | string <application/octet-stream> [a-zA-Z0-9-%_@&!] CSV file. |
Responses
Response samples
- 202
- 400
- 500
{- "codesImport": {
- "id": "646b39ac-14e7-4000-8000-8fb14bc22cec",
- "status": "CREATED",
- "processed": 1000,
- "created": 700,
- "errors": 300,
- "updatedAt": "2023-05-22 11:27:53.639 +0000 UTC"
}
}
List Coupon Codes Import
Use this method to retrieve a list of coupon codes imports.
Authorizations:
query Parameters
count required | integer The number of coupon codes imports to get at once |
page required | integer The page number |
header Parameters
tenant required | string |
user-id required | string |
Responses
Response samples
- 200
- 400
- 500
{- "items": [
- {
- "codesImport": {
- "id": "646b51b9-14e7-4000-8000-8fb14bc22d15",
- "status": "CREATED",
- "processed": 1000,
- "created": 700,
- "errors": 300,
- "updatedAt": "2023-05-22 11:27:53.639 +0000 UTC"
}, - "links": {
- "self": "/coupon/646b3cb3-14e7-4000-8000-8fb14bc22d03/code/import/646b51b9-14e7-4000-8000-8fb14bc22d15"
}
}, - {
- "codesImport": {
- "id": "646b51b9-14e7-4000-8000-8fb14bc22d15",
- "status": "CREATED",
- "processed": 700,
- "created": 300,
- "errors": 400,
- "updatedAt": "2023-05-23 10:27:53.639 +0000 UTC"
}, - "links": {
- "self": "/coupon/646b3cb3-14e7-4000-8000-8fb14bc22d03/code/import/646b46b1-14e7-4000-8000-8fb14bc22d0b"
}
}
], - "links": {
- "next": "/coupon/64677e31-14e7-4000-8000-8fb14bc22ce6/code/import?count=2&page=1",
- "previous": ""
}, - "pagination": {
- "count": 2,
- "page": 1,
- "total": 220
}
}
Get Coupon Codes Import
Use this method to retrieve a specified coupon codes import.
Authorizations:
path Parameters
id required | string The ID of the coupon. |
import_id required | string The ID of the imported coupon code. |
header Parameters
tenant required | string |
user-id required | string |
Responses
Response samples
- 200
- 400
- 404
- 500
{- "codesImport": {
- "id": "646b51b9-14e7-4000-8000-8fb14bc22d15",
- "status": "CREATED",
- "processed": 1000,
- "created": 700,
- "errors": 300,
- "updatedAt": "2023-05-22 11:27:53.639 +0000 UTC"
}, - "links": {
- "self": "/coupon/646b3cb3-14e7-4000-8000-8fb14bc22d03/code/import/646b51b9-14e7-4000-8000-8fb14bc22d15"
}
}
Create a coupon code redemption
Use this method to redeem a coupon code. It redeem the coupon for legacy or for the stackable coupons according to the internal configuration for the given tenant.
This method is not idempotent and should be called when the coupon was used. If the order for which this coupon was used failes, the coupon is unredeemed automatically at a later stage.
After a successful execution a 200 status is returned.
Authorizations:
Request Body schema: application/json
The redemption request
codes | Array of strings |
consumerId | string |
channelType | string |
catalogTotal | number |
currency | string |
orderId | string |
Responses
Request samples
- Payload
{- "value": {
- "codes": [
- "SUMMER2022",
- "DRESS10"
], - "consumerId": "consumer-id-123",
- "channelType": "store",
- "catalogTotal": 100,
- "currency": "USD",
- "orderId": "2b89a5e0-1f1f-4374-b6d3-272341193cc7"
}
}
Response samples
- 400
- 500
{- "message": "string",
- "status": 0,
- "causes": [
- "string"
], - "id": "string",
- "type": "string",
- "code": "string"
}