Forum Discussion
Forward Adaptive Card
Hi Janhvi - Could you please let us know if you have any further queries?
Prasad_Das-MSFT
This webhook seems to be compatible only with channels. But our requirement is to forward adaptive card in a personal chat.
- Prasad_Das-MSFTNov 28, 2023Microsoft
Janhvi - As you have already mentioned using this API we can send adaptive card to personal chat/group chat or channel.
POST https://graph.microsoft.com/v1.0/chats/{chat-id}/messages { "subject": null, "body": { "contentType": "html", "content": "<attachment id=\"74d20c7f34aa4a7fb74e2b30004247c5\"></attachment>" }, "attachments": [ { "id": "74d20c7f34aa4a7fb74e2b30004247c5", "contentType": "application/vnd.microsoft.card.thumbnail", "contentUrl": null, "content": "{\r\n \"title\": \"This is an example of posting a card\",\r\n \"subtitle\": \"<h3>This is the subtitle</h3>\",\r\n \"text\": \"Here is some body text. <br>\\r\\nAnd a <a href=\\\"http://microsoft.com/\\\">hyperlink</a>. <br>\\r\\nAnd below that is some buttons:\",\r\n \"buttons\": [\r\n {\r\n \"type\": \"messageBack\",\r\n \"title\": \"Login to FakeBot\",\r\n \"text\": \"login\",\r\n \"displayText\": \"login\",\r\n \"value\": \"login\"\r\n }\r\n ]\r\n}", "name": null, "thumbnailUrl": null } ] }
In the above example the request body is already in JSON format. However, it seems like the "content" field in the "attachments" array is a stringified JSON.
As it has html content, you are interested in something easier. So, you can use Power Automate/Flow to send adaptive card in personal chat or channel following below document.Create flows that post adaptive cards to Microsoft Teams - Power Automate | Microsoft Learn
Thanks,
Prasad Das
------------------------------------------------------------------------------------------
If the response is helpful, please click "**Mark as Best Response**" and like it. You can share your feedback via Microsoft Teams Developer Feedback link. Click here to escalate.
- ray2408Nov 28, 2023Brass Contributor
{ "body": { "contentType": "html", "content": "<attachment id=\"74d20c7f34aa4a7fb74e2b30004247c5\"></attachment>" }, "attachments": [ { "id": "74d20c7f34aa4a7fb74e2b30004247c5", "contentType": "application/vnd.microsoft.card.adaptive", "contentUrl": null, "content": "{ \"type\": \"AdaptiveCard\", \"body\": [ { \"type\": \"Container\", \"items\": [ { \"type\": \"Image\", \"url\": \"\", \"size\": \"medium\", \"height\": \"auto\" }, { \"type\": \"TextBlock\", \"text\": \"Welcome to Adaptive Cards!\", \"size\": \"large\", \"weight\": \"bolder\" }, { \"type\": \"TextBlock\", \"text\": \"Click the button below for more information.\", \"wrap\": true } ] }, { \"type\": \"ActionSet\", \"actions\": [ { \"type\": \"Action.OpenUrl\", \"title\": \"Learn More\", \"url\": \"https://adaptivecards.io\" } ] } ], \"speak\": \"Welcome to Adaptive Cards! Click the button below for more information.\", \"$schema\": \"http://adaptivecards.io/schemas/adaptive-card.json\", \"version\": \"1.2\"}", "name": null, "thumbnailUrl": null } ] }
POST /chats/{chat-id}/messages
ON using the above API we are able to forward this type of adaptive card to a particular user.
But the content is not exactly the same format we use for adaptive card. Can you please tell how to create this format out of normal adaptive cards json data?- Prasad_Das-MSFTNov 30, 2023Microsoft
ray2408 - There is no tool available for this type of conversion. We have to manually do that.
For example, if this is your adaptive card JSON:{ "$schema": "http://adaptivecards.io/schemas/adaptive-card.json", "type": "AdaptiveCard", "version": "1.2", "speak": "Welcome to Adaptive Cards! Click the button below for more information.", "body": [ { "type": "Container", "items": [ { "type": "TextBlock", "text": "Welcome to Adaptive Cards!", "size": "large", "weight": "bolder" }, { "type": "TextBlock", "text": "Click the button below for more information.", "wrap": true } ] }, { "type": "ActionSet", "actions": [ { "type": "Action.OpenUrl", "title": "Learn More", "url": "https://adaptivecards.io" } ] } ] }
the converted format would be as below:
{\"type\": \"AdaptiveCard\", \"body\": [ { \"type\": \"Container\", \"items\": [ { \"type\": \"TextBlock\", \"text\": \"Welcome to Adaptive Cards!\", \"size\": \"large\", \"weight\": \"bolder\" }, { \"type\": \"TextBlock\", \"text\": \"Click the button below for more information.\", \"wrap\": true } ] }, { \"type\": \"ActionSet\", \"actions\": [ { \"type\": \"Action.OpenUrl\", \"title\": \"Learn More\", \"url\": \" https://adaptivecards.io\" } ] } ], \"speak\": \"Welcome to Adaptive Cards! Click the button below for more information.\", \"$schema\": \" http://adaptivecards.io/schemas/adaptive-card.json\" , \"version\": \"1.2\"}