Need Help?

Intro

Endpoint: https://api.omnisend.com/v5/products

Guide: How to: sync products catalog, categories

Example:

Create a product

In order to create product one by one use the POST /products endpoint. Here's an example using the curl command to create a new product:

curl --location 'https://api.omnisend.com/v5/products' \
--header 'X-Forwarded-For: 127.0.0.0.1' \
--header 'Content-Type: application/json' \
--header  'X-API-KEY: BRAND_API_KEY' \
--data '{
    "id": "product-id-123",
    "url": "http://www.example.com/products/prod-666",
    "defaultImageUrl": "http://www.example.com/images/products/default.png",
    "title": "Product title",
    "description": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Proin ut volutpat neque. Etiam vel vulputate neque. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis fringilla ex ex, eget tincidunt metus ornare eu.",
    "vendor": "Pear",
    "type": "Plastic",
    "status": "inStock",
    "currency": "UZS",
    "createdAt": "2022-06-18T00:00:01Z",
    "updatedAt": "2022-07-11T00:00:01Z",
    "variants": [
        {
            "id": "product-variant-id-123",
            "title": "Product variant title",
            "sku": "123",
            "price": 28.99,
            "strikeThroughPrice": 30.99,
            "status": "inStock",
            "defaultImageUrl": "http://www.example.com/images/variant/default.png",
            "url": "http://www.example.com/variant/prod-11",
            "images": [
                "http://www.example.com/images/variant/1.png",
                "http://www.example.com/images/variant/2.png",
                "http://www.example.com/images/variant/3.png"
            ],
            "description": "variant description"
        }
    ],
    "images": [
        "http://www.example.com/images/products/1.png",
        "http://www.example.com/images/products/2.png",
        "http://www.example.com/images/products/3.png"
    ],
    "tags": [
        "tag1",
        "tag2",
        "tag3"
    ],
    "categoryIDs": [
        "category-1",
        "category-2"
    ]
}'
'

Update product

Use the PUT /products/{productID} endpoint to replace an existing product.

Here's an example using the curl command:

curl --location --request PUT 'https://api.omnisend.com/v5/products/product-id-123' \
--header 'X-API-KEY: X-API-KEY: BRAND_API_KEY' \
--header 'accept: application/json' \
--header 'content-type: application/json' \

--data '
{
  "id":"product-id-123",
  "title": "Container for mojo",
  "status": "inStock",
  "url": "http://www.example.com/products/prod-666",
  "currency": "USD",
   "variants": [
        {
            "id": "product-variant-id-123",
            "title": "Product variant title",
            "sku": "123",
            "price": 28.99,
            "strikeThroughPrice": 30.99,
            "status": "inStock",
            "defaultImageUrl": "http://www.example.com/images/variant/default.png",
            "url": "http://www.example.com/variant/prod-11",
            "images": [
                "http://www.example.com/images/variant/1.png",
                "http://www.example.com/images/variant/2.png",
                "http://www.example.com/images/variant/3.png"
            ],
            "description": "variant description"
        }
    ]
  }
'

Create/update products in batch

Using the batch endpoint to create/update products saves time, minimises API calls, reduces rate limit risks, and improves scalability.

We recommend keeping the payload size limited to a maximum of 1MB to ensure optimal performance and efficient data transmission.

Use POST /batches endpoint to create/update multiple products. Here is an example for creating products:

curl --request POST \
     --url https://api.omnisend.com/v5/batches \
     --header 'X-API-KEY: MERCHANT_API_KEY' \
     --header 'accept: application/json' \
     --header 'content-type: application/json' \
     --data '
{
    "method": "POST",
    "endpoint": "products",
    "items": [
        {
            "categoryIDs": [
                "cat123"
            ],
            "id": "abc123",
            "title": "Shirts",
            "status": "inStock",
            "currency": "USD",
            "productUrl": "http://www.example.com/products/prod-666"
        }
    ]
}
'

Change method to PUT if you need to update multiple products.

Create products category

In order to create products category use the POST /product-categories endpoint. Here's an example using the curl command:

curl --request POST \
     --url https://api.omnisend.com/v5/product-categories \
     --header 'X-API-KEY: BRAND_API_KEY' \
     --header 'accept: application/json' \
     --header 'content-type: application/json' \
     --data '
{
  "categoryID": "cat667",
  "title": "Containers"
}
'

Update products category

You can update/replace products category using the PATCH /product-categories/{categoryID} endpoint. Here's an example using curl command:

curl --request PATCH \
     --url https://api.omnisend.com/v5/product-categories/cat123 \
     --header 'X-API-KEY: BRAND_API_KEY' \
     --header 'accept: application/json' \
     --header 'content-type: application/json' \
     --data '
{
  "title": "New title2"
}
'