Conversation Ads API
Warning
Deprecation Notice
The Marketing Version 202401 (Marketing January 2024) has been sunset. We recommend that you migrate to the versioned APIs as well as migrate to the new Content and Community Management APIs to avoid disruptions. See the Migration page for more details.
If you haven’t yet migrated and have questions, submit a request on the LinkedIn Developer Support Portal.
Linkedin is introducing its next generation of APIs to create and manage Conversation Ads, enabling advertisers to better deliver automated messages to a targeted LinkedIn member's inbox. This API replaces the previous /sponsoredConversations API.
Permissions
Permission | Description |
---|---|
rw_ads |
Manage and read an authenticated member's Ad Accounts. In addition, authenticated member must have READ access for a Company Page. Have one of the following Ad Account roles:ACCOUNT_BILLING_ADMIN ACCOUNT_MANAGER CAMPAIGN_MANAGER CREATIVE_MANAGER |
r_ads |
Read an authenticated member's Ad Account. Restricted to Ad Accounts in which the authenticated member has one of the following Ad Account roles. ACCOUNT_BILLING_ADMIN ACCOUNT_MANAGER CAMPAIGN_MANAGER CREATIVE_MANAGER VIEWER |
See Account Access Controls for more information on ad account roles.
Workflow
- Create a
SponsoredConversation
. - If you are using attachments in a conversation, upload SponsoredMessageContent Asset.
- Create a tree of SponsoredMessageContent to represent a conversation.
- Update
SponsoredConversation
with reference to firstSponsoredMessageContent
. - Create an AdInMailContent using GuidedReplies as sub-content by using the Urn of the completed Sponsored Conversation.
- Create a DRAFT conversation ad creative with the
adInMailContent URN
returned in the previous step as its content reference. See Create and Manage Creatives. - Test the DRAFT conversation ad.
- Make any necessary modifications based on testing.
Note
The creative should be in DRAFT status.
- Activate the creative by updating the creative status to ACTIVE.
Note
The creative will be directed to the review queue after activation.
Sponsored Conversations
This section explains how to manage sponsored ad conversations.
SponsoredConversation Schema
Field | Type | Description |
---|---|---|
id | SponsoredConversationUrn | (read-only) ID key for the current conversation. |
parentAccount | Sponsored Account URN | (create-only) The parent account associated with this conversation. |
firstMessageContent | Sponsored Message Content URN | (update-only) Update the conversation with its first message content. |
headlineText | optional string | The conversation headline's text. This text is displayed both in the headline view and detail view, specified by the advertiser. When absent headline will display first line of the first message content. |
Field | Type | Description |
---|---|---|
id | SponsoredConversationUrn | (read-only) ID key for the current conversation. |
parentAccount | Sponsored Account URN | (create-only) The parent account associated with this conversation. |
firstMessageContent | Sponsored Message Content URN | (update-only) Update the conversation with its first message content. |
Validations:
- The specified
parentAccount
must exist and be valid - The user must have the permission to manage the account
- You cannot set the
firstMessageContent
when initially creating asponsoredConversation
. It can only be set by a subsequent partial update call.
Create a Sponsored Conversation
POST https://api.linkedin.com/rest/conversationAds
{
"parentAccount": "urn:li:sponsoredAccount:520866471"
}
Successful response will have Status 201 Created
and the ID in the x-linkedin-id
response header. For example,urn:li:sponsoredConversation:164380864
Get a Sponsored Conversation
Sample Response
{
"id": "urn:li:sponsoredConversation:185204",
"parentAccount": "urn:li:sponsoredAccount:520866471"
}
Sample Response
{
"id": "urn:li:sponsoredConversation:2988042",
"parentAccount": "urn:li:sponsoredAccount:504513845",
"headlineText": "subject of this ad"
}
Update a Sponsored Conversation
In the following example, the firstMessageContent
field is changed to point to the first message of the conversation.
POST https://api.linkedin.com/rest/conversationAds/{conversationUrn}
{
"patch": {
"$set": {
"firstMessageContent": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:185204:14253)"
}
}
}
A successful response returns a 204 No Content
HTTP status code.
Batch Get Sponsored Conversations
GET https://api.linkedin.com/rest/conversationAds?ids=List({conversation-urn1},{conversation-urn2})'
Sample Response
{
"statuses": {
"urn:li:sponsoredConversation:704255": 200,
"urn:li:sponsoredConversation:703695": 200
},
"results": {
"urn:li:sponsoredConversation:704255":
{
"id": "urn:li:sponsoredConversation:704255",
"parentAccount": "urn:li:sponsoredAccount:520866471"
},
"urn:li:sponsoredConversation:703695":
{
"id": "urn:li:sponsoredConversation:703695",
"parentAccount": "urn:li:sponsoredAccount:520866471",
}
},
"errors": {}
}
Sponsored Message Contents
SponsoredMessageContent Schema
Field | Type | Description | Required |
---|---|---|---|
id | SponsoredMessageContentUrn | (read-only) The ID key for this message | Yes |
sponsoredConversation | SponsoredConversationUrn | The conversation to which this message belongs | Yes |
nextAction | SponsoredMessageContentUrn or SponsoredMessageOption[] | Indicates whether this message’s next action is another message or an array of options | No |
bodySource | Either a text string, an AdFormUrn, or a mediaAttachment consisting of an ImageUrn and an optional text string | A message can consist of either simple text, or a lead generation form, or an image attachment with an optional attachment text | Yes |
SponsoredMessageOption Schema
Field | Type | Details | Required |
---|---|---|---|
replyType | String. Allowed values: |
The type of the reply this option will generate | Yes |
nextContent | SponsoredMessageContentUrn | The next message this option will generate | No |
optionText | String | The text displayed on the button | Yes |
landingPage | URL | If specified, the button will redirect to this url | No |
Validations
The following validations occur when managing SponsoredMessageContent
, otherwise it will throw validation errors (4xx error code).
All SponsoredMessageContents
within a conversation has the following tree level checks:
- The maximum number of
SponsoredMessageContents
within a conversation is 25 - All
SponsoredMessageContentUrn
references must exist - Cyclical references between the message nodes are not allowed
Individual SponsoredMessageContent
Checks:
- If the
bodySource
is aleadGenerationForm
:- The message type must be
OPTION_PROVIDING
- It must have at least one
LEAD_GENERATION_THANK_YOU
SponsoredMessageOption
- The
leadGenerationForm
account needs to match the ConversationparentAccount
- The message type must be
- If the
bodySource
is text:- The text length must be less than or equal to 500 characters
- If the
bodySource
ismediaAttachment
:- The attachment must be an
imageUrn
- The text length must be less than or equal to 500 characters
- The attachment must be an
- If
nextAction
is an array ofSponsoredMessageOption
, the array must consist of at least 1SponsoredMessageOption
but no more than 5
Individual SponsoredMessageOption
Validations:
optionText
must be between 1 and 35 characters- If the type of the option is
LEAD_GENERATION
:- The
nextAction
field must exist and is required to point to aSponsoredMessageContent
with a bodySource of typeleadGenerationForm
- The
- If the type of the option is
LEAD_GENERATION_THANK_YOU
:- The
bodySource
of thisSponsoredMessageContent
must beleadGenerationForm
- Note that the
optionText
will always be set to the thank you message from the ad form regardless of the input provided for theSponsoredMessageOption
optionText
.
- The
- If the type of the option is
EXTERNAL_WEBSITE
:- The landingPage field must exist
- The
nextAction
must not point to aSponsoredMessageContent
with abodySource
of typeleadGenerationForm
- If the type of the option is
SIMPLE_REPLY
:- The
landingPage
must not exist - The
nextAction
must exist - The
nextAction
must not point to aSponsoredMessageContent
with abodySource
of typeleadGenerationForm
- The
- If the type of the option is
UNKNOWN
:- This is always invalid
Create Sponsored Message Content
Note
{conversationAdsId}
is returned in the response header as shown in the first step when you create a Sponsored Conversation using (POST /conversationAds)
.
POST https://api.linkedin.com/rest/conversationAds/{conversationAdsId}/sponsoredMessageContents
{
"bodySource": {
"text": "test message"
}
}
POST https://api.linkedin.com/rest/conversationAds/{conversationAdsId}/sponsoredMessageContents
{
"bodySource": {
"mediaAttachment": {
"attachment": "urn:li:image:C5506AQGB9eP_4gNpEQ",
"text": "test text"
}
}
}
POST https://api.linkedin.com/rest/conversationAds/{conversationAdsId}/sponsoredMessageContents
{
"bodySource": {
"leadGenerationForm": "urn:li:adForm:434835"
},
"nextAction":{
"options":[
{
"replyType": "LEAD_GENERATION_THANK_YOU",
"optionText": "Visit website"
}
]
}
}
POST https://api.linkedin.com/rest/conversationAds/{conversationAdsId}/sponsoredMessageContents
{
"bodySource": {
"leadGenerationForm": "urn:li:adForm:434835"
},
"nextAction":{
"options":[
{
"replyType": "LEAD_GENERATION_THANK_YOU",
"optionText": "Visit website"
},
{
"replyType": "SIMPLE_REPLY",
"nextContent": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14253)",
"optionText": "Simple reply"
},
{
"replyType": "EXTERNAL_WEBSITE",
"optionText": "Visit website",
"landingPage": "http://www.linkedin.com"
}
]
}
}
A successful response returns a 201 Created
HTTP status code and the ID in the x-linkedin-id response
header, e.g. "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14277)"
.
Get Sponsored Message Content
GET https://api.linkedin.com/rest/conversationAds/{conversationUrn}/sponsoredMessageContents/{messageUrn}
Sample Response
{
"id": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14277)",
"sponsoredConversation": "urn:li:sponsoredConversation:186604",
"bodySource": {
"leadGenerationForm": "urn:li:adForm:434835"
},
"nextAction":{
"options":[
{
"replyType": "LEAD_GENERATION_THANK_YOU",
"optionText": "Visit website"
},
{
"replyType": "SIMPLE_REPLY",
"nextContent": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14253)",
"optionText": "Simple reply"
},
{
"replyType": "EXTERNAL_WEBSITE",
"optionText": "Visit website",
"landingPage": "http://www.linkedin.com"
}
]
}
}
Get All Sponsored Message Content
GET https://api.linkedin.com/rest/conversationAds/{conversationUrn}/sponsoredMessageContents
Sample Response
{
"paging": {
"start": 0,
"count": 10,
"links": []
},
"elements": [
{
"id": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14277)",
"sponsoredConversation": "urn:li:sponsoredConversation:186604",
"bodySource": {
"leadGenerationForm": "urn:li:adForm:434835"
},
"nextAction":{
"options":[
{
"replyType": "LEAD_GENERATION_THANK_YOU",
"optionText": "Visit website"
},
{
"replyType": "SIMPLE_REPLY",
"nextContent": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14253)",
"optionText": "Simple reply"
},
{
"replyType": "EXTERNAL_WEBSITE",
"optionText": "Visit website",
"landingPage": "http://www.linkedin.com"
}
]
}
},
{
"id": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14278)",
"sponsoredConversation": "urn:li:sponsoredConversation:186604",
"bodySource": {
"text": "Sample text"
},
"nextAction":{
"options":[
{
"replyType": "EXTERNAL_WEBSITE",
"optionText": "Other website",
"landingPage": "http://www.microsoft.com"
}
]
}
}
]
}
Update Sponsored Message Content
In the following example, the bodySource
text field is updated.
POST https://api.linkedin.com/rest/conversationAds/{conversationUrn}/sponsoredMessageContents/{messageUrn}
{
"patch": {
"$set": {
"bodySource": {
"text": "New updated text"
}
}
}
}
A successful response returns a 204 No Content
HTTP status code.
Batch Create Sponsored Message Content
POST https://api.linkedin.com/rest/conversationAds/{conversationAdsId}/sponsoredMessageContents
{
"elements": [ {
"bodySource": {
"leadGenerationForm": "urn:li:adForm:434835"
},
"nextAction":{
"options":[
{
"replyType": "LEAD_GENERATION_THANK_YOU",
"optionText": "Visit website"
},
{
"replyType": "SIMPLE_REPLY",
"nextContent": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14253)",
"optionText": "Simple reply"
},
{
"replyType": "EXTERNAL_WEBSITE",
"optionText": "Visit website",
"landingPage": "http://www.linkedin.com"
}
]
}
},{
"bodySource": {
"text": "Sample text"
},
"nextAction":{
"options":[
{
"replyType": "EXTERNAL_WEBSITE",
"optionText": "Other website",
"landingPage": "http://www.microsoft.com"
}
]
}
}]
}
Batch Update Sponsored Message Content
POST https://api.linkedin.com/rest/conversationAds/{conversationUrn}/sponsoredMessageContents?ids=List({message-urn1},{message-urn2})
{
"entities": {
"urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14277)": {
"patch": {
"$set": {
"bodySource": {
"text": "New updated text"
}
}
}
},
"urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14278)": {
"patch": {
"$set": {
"bodySource": {
"text": "New updated text2"
}
}
}
}
}
}
Sample Response
{
"elements": [
{
"location": "/conversationAds/urn:li:sponsoredConversation:186604/sponsoredMessageContents/urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14250)",
"status": 204,
"id": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14250)"
},
{
"location": "/conversationAds/urn:li:sponsoredConversation:186604/sponsoredMessageContents/urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14251)",
"status": 204,
"id": "urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14251)"
}
]
}
Batch Delete Sponsored Message Content
DELETE https://api.linkedin.com/rest/conversationAds/{conversationUrn}/sponsoredMessageContents?ids=List({message-urn1},{message-urn2})'
{
"results": {
"urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14277)": {
"status": 204
},
"urn:li:sponsoredMessageContent:(urn:li:sponsoredConversation:186604,14278)": {
"status": 204
}
},
"errors": {}
}