Content API Tutorial

In this tutorial, we'll learn how to upload content to the Content Store API and how to retrieve it

Prepare the Content

Create a file containing a JSON dictionary, mapping contentId to a JSON blob.

echo '{"testid": {"name": "Content Test"}}' > /tmp/contentbatch.json

There's an optional limit to the number of top-level records to ensure safe processing. Dev has a default limit of 25 records per batch. Prod does not have a default limit but we'd recommend keeping to less than 100 records per batch.

Upload the Content

Use the following CURL command to upload the content to the Content Store.

curl "https://{yourcontenturl}.promoted.ai/v1/content/batch?source=default" -X PUT -H "Content-Type: application/json" --data "@/tmp/contentbatch.json" -H 'x-api-key: $API_KEY' -v

Expected Response: HTTP status code of 200.

Note: This will save the items with a source named default. The Content Store allows writing separate documents per source for the same content ID. This capability enables multiple writers to write content data without coordination. Refer to the Sources documentation for an in-depth understanding.

🚧

Caution: The API key might contain non-alphanumeric characters. Depending on the shell you're using, be cautious about how you quote it.

Retrieve the Test Document

Use the CURL command below to fetch the test document.

curl "https://{yourcontenturl}.promoted.ai/v1/content/testid?source=default" -H "Content-Type: application/json" -H 'x-api-key: $API_KEY' -v

Expected Response: HTTP status code of 200.

Expected Response Body:

{"name":"Dan Test"}

Delete the Test Document

Use the CURL command below to soft delete the test document.

curl "https://{yourcontenturl}.promoted.ai/v1/content/testid?source=default" -X DELETE -H "Content-Type: application/json" -H 'x-api-key: $API_KEY' -v

Expected Response: HTTP status code of 200.

Expected Response Body:

{"message":"OK"}