Ad Text Generation API
Harness the capabilities of AdLLM™, our proprietary AI model trained on over a billion high-converting ad texts, to create compelling and impactful ad copy effortlessly.
Overview
The Ad Text Generation API is a core feature designed to generate conversion-focused ad texts with the power of AdLLM Spark — the first AdLLM built specifically for crafting high-performing ad texts. This API empowers users with full control over the content and format of their ads, ensuring flexibility and customization.
What sets Ad Text Generation apart is its integration of proven copywriting frameworks, such as:
Before-After-Bridge: Highlighting the transformation enabled by the product/service.
AIDA (Attention, Interest, Desire, Action): Guiding users from initial attention to final conversion.
These methodologies are extensively tested and continuously optimized to maximize conversions, ensuring the generated ad texts deliver top performance.
Seamless Multi-Format Support
Ad Text Generation is not limited to a single ad type. It supports various ad formats, offering tailored packages for platforms like:
Meta Dynamic Ad Creatives
Google Performance Max Ads
With this feature, marketers and developers can generate all necessary ad texts for these formats within a single project, eliminating the need for time-consuming manual copywriting.
Key Benefits
✅ Conversion-optimized ad texts powered by AdLLM Spark. ✅ Full creative control over text content and format. ✅ Proven frameworks designed for performance. ✅ Multi-platform ad format support in a unified workflow. ✅ Saves significant time and effort in the ad creation process.
With Ad Text Generation API, you can skip the hassle of writing copy from scratch and instantly get ready-to-use, optimized ad texts tailored to your campaign needs.
Authorization
All endpoints requires the following headers for authentication and identification:
Authorization
Bearer token for authentication
Bearer <YOUR_BEARER_TOKEN>
x-api-key
API key for client identification
<YOUR_API_KEY>
x-api-secret
API secret for secure access
<YOUR_API_SECRET>
Accept
Expected response format
application/json
Required Headers
POST /api/v1/Text/Generation/Ads
This endpoint generates advertising text (ad copy) based on provided product details, target audience, and customization options. It is designed to create compelling ad texts tailored to specific marketing needs, supporting various text types, tones, languages, and emoji selections.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
GUID
Yes
The unique identifier (GUID) of the application making the request.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
GUID
Yes
The unique identifier (GUID) of the user initiating the request.
2581c740-8e9d-4d63-96bc-5665bb9a646b
processName
string
No
The name of the ad generation process. If empty, it defaults to productName
. Max 1000 chars.
Alo Yoga Ad Campaign
productName
string
Yes
The name of the product being advertised. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Alo Yoga Clothing and Accessories
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Alo Yoga offers a wide range of yoga leggings...
targetAudience
string
No
The intended audience for the ad. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Yoga Enthusiasts
type
int
Yes
The type of ad text to generate. See AdTextType. Default: 1
(SharpTechnique).
1
tone
string
No
The tone of the ad text. See AdTextTones. Max 1000 characters.
Professional
outputLanguage
string
Yes
The language of the generated ad text (e.g., en
, es
, English
, Spanish
). Max 100 chars.
es
webSiteUrl
string
No
The website URL related to the product. Max 2083 characters.
https://www.aloyoga.com/
cta
string
No
The call-to-action for the ad. Max 1000 chars. Can be fetched as adGoal
or cta
via /ProductDescription endpoint
.
Get Sales
emojiSelection
int
Yes
Emoji usage in the ad text. See AdTextEmojiSelection. Default: 2
(ChosenByAi).
2
customRequest
string
No
Custom instructions for text generation (e.g., specific phrasing). Max 5000 characters.
Mention our patented technology; avoid 'cheap'
Enum: AdTextType
Refer to AdTextType for valid values (0-35). Examples:
1
: SharpTechnique (default)2
: GateFramework3
: LiftMethod
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Enum: AdTextEmojiSelection
Refer to AdTextEmojiSelection for valid values:
0
: WithEmojis1
: WithoutEmojis2
: ChosenByAi (default)
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON object containing the generated ad texts and metadata:
Response Parameters
id
int
The unique identifier of the ad text generation process.
102
createdAt
string
The UTC timestamp when the process was created (ISO 8601 format).
2025-03-06T04:31:56.2825674Z
updatedAt
string
The UTC timestamp when the process was last updated (ISO 8601 format).
2025-03-06T04:32:07.2719168Z
adTexts
array
A list of generated ad text objects.
See below
adTexts[].id
int
The unique identifier of the ad text.
1145
adTexts[].value
string
The generated ad text content.
Encuentra tu ajuste perfecto con Alo Yoga 🧘♂️
adTexts[].favorited
bool
Indicates if the ad text has been marked as a favorite.
false
adTexts[].createdAt
string
The UTC timestamp when the ad text was created (ISO 8601 format).
2025-03-06T04:32:07.2718587Z
adTexts[].updatedAt
string
The UTC timestamp when the ad text was last updated (ISO 8601 format).
2025-03-06T04:32:07.2718587Z
adTexts[].conversionScore
string
A score indicating the predicted effectiveness of the ad text (0-100).
91
adTexts[].type
int
The type of ad text, matching the request type
. See AdTextType.
1
PUT /api/v1/Text/Generation/Ads
This endpoint updates and regenerates advertising text (ad copy) for an existing ad text generation process identified by its id
. It allows modification of product details, target audience, and customization options to produce updated ad texts tailored to specific marketing needs, supporting various text types, tones, languages, and emoji selections.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
id
int
Yes
The unique identifier of the ad text generation process to update.
103
applicationId
GUID
Yes
The unique identifier (GUID) of the application making the request.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
GUID
Yes
The unique identifier (GUID) of the user initiating the request.
2581c740-8e9d-4d63-96bc-5665bb9a646b
processName
string
No
The name of the ad generation process. If empty, defaults to productName
. Max 1000 chars.
Alo Yoga Ad Campaign
productName
string
Yes
The name of the product being advertised. Max 1000 chars. Can be fetched via /ProductDescription endpoint
.
Alo Yoga Clothing and Accessories
productDescription
string
Yes
A detailed description of the product. Max 5000 chars. Can be fetched via /ProductDescription endpoint
.
Alo Yoga offers a wide range of yoga leggings...
targetAudience
string
No
The intended audience for the ad. Max 1000 chars. Can be fetched via /ProductDescription endpoint
.
Yoga Enthusiasts
type
int
Yes
The type of ad text to generate. See AdTextType. Default: 1
(SharpTechnique).
1
tone
string
No
The tone of the ad text. See AdTextTones. Max 1000 chars.
Friendly
outputLanguage
string
Yes
The language of the generated ad text (e.g., en
, es
, English
, Spanish
). Max 100 chars.
English
webSiteUrl
string
No
The website URL related to the product. Max 2083 chars.
https://www.aloyoga.com/
cta
string
No
The call-to-action for the ad. Max 1000 chars. Can be fetched as adGoal
or cta
via /ProductDescription endpoint
.
Get Sales
emojiSelection
int
Yes
Emoji usage in the ad text. See AdTextEmojiSelection. Default: 2
(ChosenByAi).
2
customRequest
string
No
Custom instructions for text generation (e.g., specific phrasing). Max 5000 chars.
Mention our patented technology; avoid 'cheap'
Enum: AdTextType
Refer to AdTextType for valid values (0-35). Examples:
1
: SharpTechnique (default)2
: GateFramework3
: LiftMethod
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Enum: AdTextEmojiSelection
Refer to AdTextEmojiSelection for valid values:
0
: WithEmojis1
: WithoutEmojis2
: ChosenByAi (default)
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON object containing the updated ad texts and metadata:
Response Parameters
id
int
The unique identifier of the ad text generation process.
103
createdAt
string
The UTC timestamp when the process was created (ISO 8601 format).
2025-03-06T10:29:59.635468Z
updatedAt
string
The UTC timestamp when the process was last updated (ISO 8601 format).
2025-03-06T10:30:40.7224539Z
adTexts
array
A list of generated ad text objects.
See below
adTexts[].id
int
The unique identifier of the ad text.
1174
adTexts[].value
string
The generated ad text content.
Free Shipping & Returns! Find Your Perfect Fit with Alo Yoga
adTexts[].favorited
bool
Indicates if the ad text has been marked as a favorite.
false
adTexts[].createdAt
string
The UTC timestamp when the ad text was created (ISO 8601 format).
2025-03-06T10:30:40.7224528Z
adTexts[].updatedAt
string
The UTC timestamp when the ad text was last updated (ISO 8601 format).
2025-03-06T10:30:40.7224528Z
adTexts[].conversionScore
string
A score indicating the predicted effectiveness of the ad text (0-100).
96
adTexts[].type
int
The type of ad text, matching the request type
. See AdTextType.
1
GET /api/v1/Text/Generation/UserAd
This endpoint retrieves a list of ad text generation processes for a specific user and optionally a specific process ID. It returns detailed information about the process, including generated ad texts, product details, and customization settings such as type, tone, and emoji selection.
Request
The request is sent as a GET
request with query parameters:
Request JSON Format
Since this is a GET
request, there is no request body. However, the query parameters can be represented as a JSON object for clarity:
Request Parameters
userId
GUID
Yes
The unique identifier (GUID) of the user whose ad processes are retrieved.
2581c740-8e9d-4d63-96bc-5665bb9a646b
adTextGeneratorProcessId
int
No
The unique identifier of a specific ad text generation process to retrieve.
103
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON array containing the ad text generation processes and their associated ad texts. Below is an example response (shortened for brevity):
Response Parameters
id
int
The unique identifier of the ad text generation process.
103
type
int
The type of ad text generated. See AdTextType.
1
productName
string
The name of the product being advertised.
Alo Yoga Clothing and Accessories
productDescription
string
A detailed description of the product.
Alo Yoga offers a wide range of yoga leggings...
processName
string
The name of the ad generation process.
Alo Yoga Clothing and Accessories
websiteUrl
string
The website URL related to the product.
https://www.aloyoga.com/
createdAt
string
The UTC timestamp when the process was created (ISO 8601 format).
2025-03-06T10:29:59.635468Z
updatedAt
string
The UTC timestamp when the process was last updated (ISO 8601 format).
2025-03-06T10:30:40.722453Z
cta
string
The call-to-action for the ad.
Get Sales
tone
string
The tone of the generated ad text. See AdTextTones.
Friendly
outputLanguage
string
The language of the generated ad text.
English
targetAudience
string
The intended audience for the ad.
Yoga Enthusiasts
emojiSelection
int
Emoji usage in the ad text. See AdTextEmojiSelection.
2
adTexts
array
A list of generated ad text objects.
See below
adTexts[].id
int
The unique identifier of the ad text.
1174
adTexts[].value
string
The generated ad text content.
Free Shipping & Returns! Find Your Perfect Fit with Alo Yoga
adTexts[].favorited
bool
Indicates if the ad text has been marked as a favorite.
false
adTexts[].createdAt
string
The UTC timestamp when the ad text was created (ISO 8601 format).
2025-03-06T10:30:40.722452Z
adTexts[].updatedAt
string
The UTC timestamp when the ad text was last updated (ISO 8601 format).
2025-03-06T10:30:40.722452Z
adTexts[].conversionScore
string
A score indicating the predicted effectiveness of the ad text (0-100).
96
adTexts[].type
int
The type of ad text, matching the process type
. See AdTextType.
1
Enum: AdTextType
Refer to AdTextType for valid values (0-35). Examples:
1
: SharpTechnique (default)2
: GateFramework3
: LiftMethod
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Enum: AdTextEmojiSelection
Refer to AdTextEmojiSelection for valid values:
0
: WithEmojis1
: WithoutEmojis2
: ChosenByAi (default)
GET /api/v1/Text/Generation/ApplicationAllAds
This endpoint retrieves all ad text generation processes associated with a specific application ID. It returns detailed information about each process, including generated ad texts, product details, and customization settings such as type, tone, and emoji selection.
Request
The request is sent as a GET
request with a query parameter:
Request JSON Format
Since this is a GET
request, there is no request body. However, the query parameter can be represented as a JSON object for clarity:
Request Parameters
applicationId
GUID
Yes
The unique identifier (GUID) of the application whose ad processes are retrieved.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON array containing the ad text generation processes and their associated ad texts. Below is a simplified example response with fewer adTexts
entries to illustrate the structure:
Response Parameters
id
int
The unique identifier of the ad text generation process.
1
type
int
The type of ad text generated. See AdTextType.
1
productName
string
The name of the product being advertised.
Alo Yoga Clothing and Accessories
productDescription
string
A detailed description of the product.
Alo Yoga offers a wide range of yoga leggings...
processName
string
The name of the ad generation process.
Alo Yoga Clothing and Accessories
websiteUrl
string
The website URL related to the product.
https://www.aloyoga.com/
createdAt
string
The UTC timestamp when the process was created (ISO 8601 format).
2025-01-23T04:04:15.296926Z
updatedAt
string
The UTC timestamp when the process was last updated (ISO 8601 format).
2025-01-23T04:05:53.269815Z
cta
string
The call-to-action for the ad.
Get Sales
tone
string
The tone of the generated ad text. See AdTextTones.
Friendly
outputLanguage
string
The language of the generated ad text.
English
targetAudience
string
The intended audience for the ad.
Yoga Enthusiasts
emojiSelection
int
Emoji usage in the ad text. See AdTextEmojiSelection.
2
adTexts
array
A list of generated ad text objects.
See below
adTexts[].id
int
The unique identifier of the ad text.
19
adTexts[].value
string
The generated ad text content.
Elevate Your Yoga Style
adTexts[].favorited
bool
Indicates if the ad text has been marked as a favorite.
false
adTexts[].createdAt
string
The UTC timestamp when the ad text was created (ISO 8601 format).
2025-01-23T04:05:53.269811Z
adTexts[].updatedAt
string
The UTC timestamp when the ad text was last updated (ISO 8601 format).
2025-01-23T04:05:53.269811Z
adTexts[].conversionScore
string
A score indicating the predicted effectiveness of the ad text (0-100).
93
adTexts[].type
int
The type of ad text, matching the process type
. See AdTextType.
1
Enum: AdTextType
Refer to AdTextType for valid values (0-35). Examples:
1
: SharpTechnique (default)2
: GateFramework3
: LiftMethod
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Enum: AdTextEmojiSelection
Refer to AdTextEmojiSelection for valid values:
0
: WithEmojis1
: WithoutEmojis2
: ChosenByAi (default)
GET /api/v1/Text/Generation/ProductDescription
This endpoint retrieves product-related information (e.g., product name, description, target audience) by scraping content from a specified website URL. It supports customization options such as preferred language and an advanced scraping mode.
Request
The request is sent as a GET
request with query parameters:
Request JSON Format
Since this is a GET
request, there is no request body. However, the query parameters can be represented as a JSON object for clarity:
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
url
string
Yes
The website URL to scrape for product information. Must be a valid URL.
https://www.caffettiera.ca/
preferredLanguage
string
No
The preferred language for the extracted content (e.g., "en" for English). Defaults to "en".
en
advanceMode
bool
No
Indicates whether to use advanced mode to scrape website content, utilizing a scraping API with JavaScript rendering. Defaults to false
.
false
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON object containing the extracted product-related information:
Response Parameters
productName
string
The name of the product extracted from the website. May be null if not found.
Caffettiera
productDescription
string
The detailed description of the product extracted from the website. May be null if not found.
Caffettiera is a 90’s inspired Italian bar...
targetAudience
string
The target audience information extracted from the website. May be null if not found.
Coffee enthusiasts
adGoal
string
The advertising goal extracted from the website content. May be null if not found.
Get Store Visits
language
string
The language identified from the website content. May be null if not identified.
English
cta
string
The call-to-action (CTA) text extracted from the website content. May be null if not found.
Visit us today!
POST /api/v1/Text/Generation/AdStrategies
This endpoint generates a list of advertising strategies based on provided product details, target audience, and advertising goals. Parameters such as productName
, productDescription
, targetAudience
, and adGoal
can be fetched from the response of the GET /api/v1/Text/Generation/ProductDescription
endpoint.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
productName
string
Yes
The name of the product being advertised. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera is a 90’s inspired Italian bar...
targetAudience
string
Yes
The intended audience for the ad. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Coffee Enthusiasts
adGoal
string
Yes
The advertising goal for the campaign. Max 1000 characters. Can be fetched via /ProductDescription endpoint
as adGoal
or cta
.
Get Store Visits
currentStrategies
array
No
A list of current strategies already in use (optional). Each item is a string.
["Limited Time Offer", "Exclusive Discount"]
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON array containing the generated ad strategies:
Response Parameters
adStrategyShortName
string
The short name of the advertising strategy.
Limited Time Offer
rationale
string
The rationale or reasoning behind the strategy.
A 'Limited Time Offer' creates urgency...
fontAwesomeIcon
string
The FontAwesome icon representing the strategy.
fa-solid fa-clock
POST /api/v1/Text/Generation/AdCopies
This endpoint generates ad copies consisting of headlines, punchlines, and call-to-actions based on provided product details, strategy, tone, and other customization options. The strategy
parameter can be fetched as adStrategyShortName
from the POST /api/v1/Text/Generation/AdStrategies
endpoint.
Additionally, this endpoint serves as an alternative to provide diverse headlines
, punchlines
, and actiontext
(as call-to-actions) for the following image generation endpoints before image creation:
POST /api/v1/Image/Generation/AdCreativesByKind
POST /api/v1/Image/Editing/AdCreativesByTasks
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
productName
string
Yes
The name of the product being advertised. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera is a 90’s inspired Italian bar...
strategy
string
No
The advertising strategy to apply. Max 2000 characters. Can be fetched as adStrategyShortName
from /AdStrategies endpoint
.
Limited Time Offer
cta
string
Yes
The call-to-action text for the ad. Max 1000 characters. Can be fetched as adGoal
or cta
via /ProductDescription endpoint
.
Visit Us Today!
outputLanguage
string
Yes
The language of the generated ad copy (e.g., "en", "English", "es", "Spanish"). Max 100 characters.
en
tone
string
Yes
The tone of the ad copy (e.g., "Professional", "Informal", "Friendly"). Max 1000 characters. See AdTextTones.
Professional
targetAudience
string
Yes
The intended audience for the ad. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Coffee Enthusiasts
isLongHeadline
bool
Yes
Determines if headlines should be long and detailed (true) or short and concise (false, typically 13-17 words).
true
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON object containing the generated ad copies, including headlines, punchlines, and call-to-actions. Below is a shortened example for brevity:
Response Parameters
headlines
array
A collection of generated headlines. Each item is a string.
"Craving Authentic Italian Coffee in Montreal?"
punchlines
array
A collection of generated punchlines. Each item is a string.
"Taste Italy in Every Sip"
callToActions
array
A collection of generated call-to-action objects.
See below
callToActions[].cta
string
The call-to-action text.
"Taste Italy Today!"
callToActions[].fontAwesomeIcon
string
The FontAwesome icon associated with the call-to-action.
"fa-solid fa-coffee"
POST /api/v1/Text/Craft/ChangeSentiment
This endpoint changes the sentiment of a given text (e.g., a headline) based on provided product details and customization options like tone and language.
It can be used to optimize outputs from the POST /api/v1/Text/Generation/AdCopies
endpoint, refining headlines, punchlines, or call-to-actions to better suit the desired sentiment.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
headLine
string
Yes
The text (e.g., headline) to change sentiment for. Max 500 characters. Can be fetched from /AdCopies endpoint
as headlines
.
Craving true Italian espresso in Montreal's heart?
productName
string
Yes
The name of the product. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera is a 90’s inspired Italian bar...
tone
string
No
The desired tone of the text (e.g., "Professional", "Informal", "Friendly"). Max 500 characters. See AdTextTones.
Informal
language
string
No
The language of the text (e.g., "en", "English"). Max 10 characters.
en
textLimit
int
No
The character limit for the output text. Must be between 1 and 1000. Defaults to 40.
40
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a single string representing the text with its sentiment changed:
Response Parameters
(response)
string
The text with its sentiment changed based on the provided inputs and tone.
"Espresso vibes in Montreal?"
POST /api/v1/Text/Craft/MakeShorten
This endpoint shortens a given headline based on provided product details and customization options like tone, language, and a text limit.
It can be used to optimize outputs from the POST /api/v1/Text/Generation/AdCopies
endpoint, refining headlines to be more concise while preserving their core message.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
headLine
string
Yes
The headline to shorten. Max 500 characters. Can be fetched from /AdCopies endpoint
as headlines
.
Craving true Italian espresso in Montreal's heart?
productName
string
Yes
The name of the product. Max 1000 characters. Can be fetched via /ProductDescription enpoint
.
Caffettiera
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera is a 90’s inspired Italian bar...
tone
string
No
The desired tone of the text (e.g., "Professional", "Informal", "Friendly"). Max 500 characters. See AdTextTones.
Informal
language
string
No
The language of the text (e.g., "en", "English"). Max 10 characters.
en
textLimit
int
No
The character limit for the shortened text. Must be between 1 and 1000. Defaults to 40.
40
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a single string representing the shortened headline. (Note: The original input did not provide an example response, so an assumed example is included based on the endpoint’s purpose):
Response Parameters
(response)
string
The shortened version of the provided headline, adhering to the text limit.
"Craving Italian espresso?"
POST /api/v1/Text/Craft/Translate
This endpoint translates a given text (e.g., a headline) into a specified target language based on provided product details and customization options.
It can be used to translate outputs from the POST /api/v1/Text/Generation/AdCopies
endpoint, such as headlines, punchlines, or call-to-actions, into different languages for broader reach.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
headLine
string
Yes
The text (e.g., headline) to translate. Max 500 characters. Can be fetched from /AdCopies endpoint
as headlines
.
Craving true Italian espresso in Montreal's heart?
productName
string
Yes
The name of the product. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera is a 90’s inspired Italian bar...
tone
string
No
The desired tone of the text (e.g., "Professional", "Informal", "Friendly"). Max 500 characters. See AdTextTones.
Informal
language
string
No
The target language for translation (e.g., "en", "English", "es", "Spanish"). Max 10 characters. If omitted, translation may not occur as expected.
Spanish
textLimit
int
No
The character limit for the translated text. Must be between 1 and 1000. Defaults to 40.
40
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a single string representing the translated text:
Response Parameters
(response)
string
The translated version of the provided text in the specified target language.
"¿Deseas espresso italiano en Montreal?"
POST /api/v1/Text/Craft/CreateVariations
This endpoint creates multiple variations of a given headline based on provided product details and customization options like tone and language.
It can be used to vary outputs from the POST /api/v1/Text/Generation/AdCopies
endpoint, generating alternative headlines, punchlines, or call-to-actions for greater diversity.
Request
The request is sent as multipart/form-data
with the following parameters:
Request JSON Format
Below is an example of how the request parameters would look if represented as a JSON object (though the actual request uses multipart/form-data
):
Request Parameters
applicationId
Guid
Yes
The unique identifier (GUID) of the application making the request. Must be a valid GUID string.
4f7d8a9c-b5e6-4d3e-b7a9-d5c3e1b7a4f6
userId
Guid
Yes
The unique identifier (GUID) of the user initiating the request. Must be a valid GUID string.
2581c740-8e9d-4d63-96bc-5665bb9a646b
headLine
string
Yes
The headline to create variations for. Max 500 characters. Can be fetched from /AdCopies endpoint
as headlines
.
Craving true Italian espresso in Montreal's heart?
productName
string
Yes
The name of the product. Max 1000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera
productDescription
string
Yes
A detailed description of the product. Max 5000 characters. Can be fetched via /ProductDescription endpoint
.
Caffettiera is a 90’s inspired Italian bar...
tone
string
No
The desired tone of the variations (e.g., "Professional", "Informal", "Friendly"). Max 500 characters. See AdTextTones.
Informal
language
string
No
The language of the variations (e.g., "en", "English"). Max 10 characters.
en
textLimit
int
No
The character limit for each variation. Must be between 1 and 1000. Defaults to 40.
40
Enum: AdTextTones
Refer to AdTextTones for valid values. Examples:
Professional
Informal
Friendly
Example Requests
cURL
HTTP Request
Response
Response JSON Format
A successful response returns a 200 OK
status with a JSON array containing multiple variations of the provided headline:
Response Parameters
(response)
array
A list of string variations of the provided headline, adhering to the text limit and tone.
"Italian Espresso in Montreal!"
Common Error Responses in Ad Text Generation API
This section outlines the common error responses (excluding 200 OK
) that may occur across endpoints in the Ad Text Generation API feature. These errors include authorization issues (401 Unauthorized
), client-side request issues (400 Bad Request
), and server-side failures (500 Internal Server Error
), along with validation errors. Error messages are categorized into business:
and engine:
keys:
business:
Represents errors originating from the business logic layer, providing user-friendly messages about why the request failed (e.g., missing resources, invalid inputs).engine:
Represents errors from the engine layer, offering technical details for developers to debug underlying issues (e.g., exceptions, service failures).
These responses are designed to help customers understand issues and assist developers in troubleshooting integrations.
Authorization Error Response
HTTP Status Code: 401 Unauthorized
Description: This error occurs when the request lacks valid authentication credentials. Common causes include a missing or invalid API token (x-api-key
or x-api-secret
) or an ApplicationId
that does not match any registered application in the token.
Response Body:
Guidance: Ensure the x-api-key
and x-api-secret
headers are included and valid. Verify that the ApplicationId
matches the one associated with your API credentials.
Bad Request Error Response
HTTP Status Code: 400 Bad Request
Description: This error indicates that the request is malformed, contains invalid data, or fails validation. It can stem from missing required fields, incorrect parameter formats, or business logic failures (e.g., no data found for the request). Below are several examples showcasing different scenarios.
Example 1: Validation Error (Single Field)
Description: Returned when a single parameter has an invalid value.
Guidance: Check the parameter named type
and ensure it conforms to the expected format or range (e.g., an enum value).
Example 2: Validation Error (Multiple Fields)
Description: Returned when multiple required fields are missing or invalid.
Guidance: Review the request body or parameters (e.g., multipart/form-data
) and provide valid values for all required fields. Refer to the endpoint’s documentation for expected formats.
Example 3: Business and Engine Error (Resource Not Found)
Description: Returned when a specific resource cannot be found, with details from both business and engine layers.
Guidance: Verify the AdTextGeneratorProcessId
, UserId
, and ApplicationId
. The resource may not exist or the IDs may be incorrect.
Example 4: Business and Engine Error (Product Description Not Found)
Description: Returned when a product description cannot be retrieved for the given URL.
Guidance: Ensure the provided URL is valid and contains extractable product information. Check the ApplicationId
and UserId
as well.
Example 5: Business and Engine Error (Invalid URL Format)
Description: Returned when the URL format is invalid.
Guidance: Correct the URL format (e.g., include https://
and a valid domain). The example ww.caffettier
is malformed.
Example 6: Validation Error (Invalid GUIDs)
Description: Returned when UserId
or ApplicationId
are not valid GUIDs.
Guidance: Ensure UserId
and ApplicationId
are valid GUIDs (e.g., 2581c740-8e9d-4d63-96bc-5665bb9a646b
). Partial or malformed GUIDs are not accepted.
Internal Server Error Response
HTTP Status Code: 500 Internal Server Error
Description: This error indicates an unexpected server-side failure, such as an unhandled exception or service issue. It typically includes both business:
and engine:
messages for context and debugging.
Response Body:
Guidance: This is a server-side issue. Retry the request later. If the problem persists, contact support with the traceId
for assistance in diagnosing the issue.
General Notes on Error Responses
TraceId: Each error includes a unique
traceId
in theextensions
object (or top-level for some400
responses) to help track and debug issues. Provide this ID when contacting support.Business vs. Engine Errors:
business:
messages are user-facing, explaining what went wrong in a high-level context (e.g., "ProductName is required").engine:
messages are technical, aimed at developers, detailing the underlying issue (e.g., "Invalid URL format").
HTTP Standards: The
type
field links to RFC 7231 or RFC 9110 sections for HTTP status code definitions, ensuring compliance with industry standards.Validation Errors: For
400 Bad Request
, validation errors list specific fields and issues. Check the endpoint’s documentation for required fields and formats.Contact Support: For persistent
500
errors or unclear400
/401
issues, use thetraceId
to report the problem to the support team.
Last updated