DocumentationUpdate Template

Update Template

Update an existing image template.

ℹ️

You will need to authenticate to use this API. See authentication.

💡

The template system supports various Handlebars helpers for dynamic content manipulation. Check out the Template Helpers section to learn about available helpers for formatting dates, performing calculations, manipulating strings, and more.

Request

PUT https://api.ojo.so/v1/template/:templateId

Path Parameters

ParameterTypeDescription
templateIdstringThe unique identifier of the template to update

Headers

HeaderValueDescription
Content-Typeapplication/jsonSpecify that the request body is JSON

Request Body

FieldTypeDescription
htmlstringThe HTML content of the template (must be Base64 encoded)
variablesobject(Optional) Variables used in the template

The HTML content must be Base64 encoded. You can encode your HTML content using our HTML Encoder, or use standard Base64 encoding functions available in your programming language:

// JavaScript example
const encodedHtml = btoa('<div>Hello World!</div>');
# Python example
import base64
encoded_html = base64.b64encode('<div>Hello World!</div>'.encode()).decode()

Dynamic Template

You can update your template with Handlebars expressions and generate images by providing the necessary data. When making a request to generate an image, include a modify object in your request body with the data to populate your Handlebars placeholders. Learn how to create image with variables.

Example:

{
  "templateId": "template-uuid-123",
  "modify": {
    "title": "Welcome to Our Site",
    "user": {
      "name": "Alice Smith"
    },
    "showDetails": true,
    "items": ["Item 1", "Item 2", "Item 3"]
  }
}
curl --request PUT \
  --url https://api.ojo.so/v1/template/<Replace with template ID> \
  --header 'Authorization: Bearer <API Key>' \
  --header 'Content-Type: application/json' \
  --data '{
    "html": "...encoded HTML content...",
    "variables": {
      "title": "Updated Template Title",
      "content": "This is the updated content."
    }
  }'

Response

Template successfully updated.

{
  "id": "template-uuid-1",
  "message": "Template updated successfully"
}