Subscribe to Back in Stock Alert
Subscribe to Back In Stock Product Alert for a product using Create API
Introduction
By using the Create API, it's possible to subscribe shoppers to back in stock product alerts or custom topics of your choosing for a shopper.
Endpoint
Endpoint | request type | API Type |
---|---|---|
https://{{Swym API Endpoint }}/storeadmin/bispa/subscriptions/create | POST | shopper |
Authorization
Back In Stock Product Alerts API's follows Basic Authentication. In the Authorization header of your request.
Headers:
Header | Required | Sample value | Description |
---|---|---|---|
user-agent | Yes | "mobileApp" | User-Agent header of the app used to access the API (mobileApp) |
Content-Type | Yes | application/x-www-form-urlencoded | MIME type, also known as a media type or content type, that is used to encode and transfer data over the internet. |
Authorization | Yes | Basic {{ BASE 64 Encoded PID : API KEY}} | PID and API Key needs to be encoded to base 64 format. |
Form Data
Field | Type | Required | Description |
---|---|---|---|
medium | string | required | medium (email) |
mediumvalue | string | required | email of the Shopper. |
products | string | required | Stringified array of products to subscribe. |
topics | array | required | Read more about topics |
addtomailinglist | int64 | optional | Subscribe user to mailing list 0 is opt out and 1 is opt in |
extras | string | optional | Extra info if you have any, limited to 2048 characters. |
Example Curl
curl -X POST '{{Swym API Endpoint}}/storeadmin/bispa/subscriptions/create' \
--header 'Accept: application/json' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--header 'Authorization: Basic {{BASE64-ENCODING-OF-"PID:API Key"}}' \
--data-urlencode 'products=[{"epi":37993071378625, "empi":6229447573697, "du":"https://www.demo.swym.it/products/butterfly-sharon-cummings"}]' \
--data-urlencode 'medium=email' \
--data-urlencode '[email protected]'
--data-urlencode 'topics=["backinstock"]'
--data-urlencode 'addtomailinglist=1'
curl -X POST '{{Swym API Endpoint}}/storeadmin/bispa/subscriptions/create' \
--header 'Accept: application/json' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--header 'Authorization: Basic {{BASE64-ENCODING-OF-"PID:API Key"}}' \
--data-urlencode 'products=[{"epi":37993071378625, "empi":6229447573697, "du":"https://www.demo.swym.it/products/butterfly-sharon-cummings"}]' \
--data-urlencode 'medium=email' \
--data-urlencode '[email protected]'
--data-urlencode 'topics=["backinstock","comingsoon"]'
--data-urlencode 'addtomailinglist=1'
Curl Placeholders
Assuming these values are provided above, the curl command should work correctly. However, if there are any issues with the API endpoint or the data being passed in the request, there could still be errors that need to be resolved before you can test these APIS.
Placeholders | Descriptions |
---|---|
{{Swym API Endpoint}} | This needs to be replaced with the actual Swym API endpoint URL. |
{{API Key}} | This needs to be replaced with the actual API Key |
{{PID}} | This needs to be replaced with the actual PID value. |
Success Response
The below responses are what you would get based on subscribing to a single topic or for multiple topics.
{
"message":"Successful",
"products":[
{
"bt":"3M",
"dt":"3M CGXL-GU General Purpose Extra Large Nitrile Palm Nylon Lining Comfort Grip Glove, Gray",
"empi":8142224425277,
"sku":"3MCGXLGU",
"du":"https://demoswym.myshopify.com/products/3mcgxlgu",
"pid":"+yFr2xLY3LCQ=",
"stk":0,
"epi":44645297750333,
"iu":"https://cdn.shopify.com/s/files/1/0708/0139/1933/products/3MCGXLGU_620x620.jpg?v=1677090238",
"uri":"https://demoswym.myshopify.com/products/3mcgxlgu?variant=44645297750333",
"pr":10.0,
"vi":""
}
],
"topics":[
"backinstock"
]
}
{
"message":"Successful",
"products":[
{
"bt":"3M",
"dt":"3M CGXL-GU General Purpose Extra Large Nitrile Palm Nylon Lining Comfort Grip Glove, Gray",
"empi":8142224425277,
"sku":"3MCGXLGU",
"du":"https://demoswym.myshopify.com/products/3mcgxlgu",
"pid":"+yFr2xLY3LCQ=",
"stk":0,
"epi":44645297750333,
"iu":"https://cdn.shopify.com/s/files/1/0708/0139/1933/products/3MCGXLGU_620x620.jpg?v=1677090238",
"uri":"https://demoswym.myshopify.com/products/3mcgxlgu?variant=44645297750333",
"pr":10.0,
"vi":""
}
],
"topics":[
"backinstock",
"comingsoon"
]
}
Error Response:
If the request is unsuccessful, the API will return a JSON response with an error message and an HTTP status code indicating the type of error that occurred.
Status Code | Type | Description |
---|---|---|
400 | Bad Request | Your request is invalid, change your request params and query and try again. |
401 | Unauthorised | You are performing an action on a resource that is not granted to the current logged-in user. Additionally, for REST APIs, this could mean your API key is wrong. |
403 | Forbidden | You are not allowed to request this data. |
404 | Not Found | The specified requested data could not be found. |
429 | Too Many Requests | You're raising too many requests! Slow down! |
500 | Internal Server Error -- | We had a problem with our server. Try again later. |
503 | Service Unavailable | We're temporarily offline for maintenance. Please try again later. |
Topic
In Swym's backend, "topics" are specific keywords that define a customer's journey. Each topic has an associated email template and predetermined logic with rules that you can assign and control. These rules can then be used to send emails to the user through the email templates (medium).
Essentially, topics help to streamline the process of sending personalised and relevant emails to customers based on their actions and behaviours on your website.
Here is a sample table to explain some topics used above.
Topic Name | Description | Use Cases | Trigger type |
---|---|---|---|
backinstock | The restock notification topic is specifically related to inventory levels. If a user wants to receive a product alert for when an item is back in stock, they need to be subscribed to this particular topic. | Subscribe for an out of stock product alert. | Automatic |
comingsoon | A tag based topic or a manual trigger topic where the product is not stock dependent as such of back in stock | Let a shopper that a there was a product launch | Manual |
custom topic | you may request custom topic, based on your requirement we may facilitate that provided it is related to this API | any custom use case | Automatic / Manual. |
Email Service Provider Support.
We support integration with many third-party Email Service Providers (ESPs) to send alert details. To see the list of supported partners, please visit your Swym Admin Dashboard > Integrations
Other References
Product
To find and subscribe a product on your e-commerce platform, it's necessary to provide the following mandatory information for each item in the array:
Property Name | Data Type | Required | Description |
---|---|---|---|
product.epi | int/string | Yes | Variant id of the product to be added |
product.empi | int/string | Yes | Product id of the product to be added |
product.du | string | Yes | Canonical uri of the product to be added |
Things to Consider
Inventory Updates.
Inventory must be handled by the platform.
it's necessary for your e-commerce platform, such as Shopify, Bigcommerce, or Magento, to manage your inventory. In other words, if your inventory is not managed by your e-commerce platform, this API will not be compatible with your system
Frontend Stock Checks.
Ensure Product Availability Before Requesting Subscriptions
Please note that our backend does not pre-stock, pre-quantity check, or pre-validate product topics for subscriptions created from this API. Therefore, it's important to ensure that users can only subscribe to alerts for products that are out of stock or based on topic before making a request.
Updated about 1 month ago