Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bot Connector service is not using latest Adaptive Cards #87

Closed
v-kydela opened this issue Jun 6, 2019 · 48 comments
Closed

Bot Connector service is not using latest Adaptive Cards #87

v-kydela opened this issue Jun 6, 2019 · 48 comments
Assignees
Labels
bug Something isn't working customer-replied-to Required for internal Azure reporting. Do not delete. Do not change color. customer-reported As opposed to development work item. P0

Comments

@v-kydela
Copy link

v-kydela commented Jun 6, 2019

[Edit by corinagum]:

Conclusion: Bot Connector service needs to be updated with latest Adaptive Cards

Screenshots

MicrosoftTeams-image

MicrosoftTeams-image (1)

Version

<script src="https://cdn.botframework.com/botframework-webchat/master/webchat.js"></script>

Describe the bug

Adaptive Cards 1.1 introduced media elements. Web Chat supports Adaptive Cards 1.1 but doesn't render those elements. However, Emulator uses Web Chat and does render them. This is impacting at least one customer: https://stackoverflow.com/a/56177322/2122672

To Reproduce

Steps to reproduce the behavior:

  1. Build a bot that sends an Adaptive Card with a media element
  2. Observe that the media is displayed correctly in Emulator
  3. Observe that the media is not displayed in Web Chat

Expected behavior

Any channel that supports Adaptive Cards 1.1 should render media elements

Additional context

Example card:

{
  "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
  "version": "1.1",
  "type": "AdaptiveCard",
  "body": [
    {
      "type": "TextBlock",
      "text": "Sample"
    },
    {
      "type": "Media",
      "poster": "https://adaptivecards.io/content/poster-video.png",
      "sources": [
        {
          "mimeType": "video/mp4",
          "url": "https://adaptivecardsblob.blob.core.windows.net/assets/AdaptiveCardsOverviewVideo.mp4"
        }
      ]
    }
  ]
}

[Bug]

@corinagum
Copy link

Thanks @v-kydela.

We actually began investigations over Teams. Let me share what I was looking into. I still haven't found the cause of this discrepancy.

  • My initial thought was that Emulator is using attachment middleware to render the video, but I wasn't able to find corresponding code in the Emulator repo. I also think this is the wrong approach because the host config is probably what controls this rendering.
  • I know that Web Chat's host config doesn't have the MediaConfig prop defined for Adaptive Cards. i was wondering if the host config for Emulator happens to define MediaConfig, but it looks like Emulator is depending on Web Chat's.

@corinagum
Copy link

looping in @tonyanziano

@tonyanziano
Copy link

@corinagum I looked through the Emulator code for handling attachments and I was unable to find any special logic for the rendering of video / media cards. Also, like you said, we are relying on Web Chat's default host config and do not pass a custom one in when rendering Web Chat.

@corinagum
Copy link

@tonyanziano thanks for the help

@tdurnford
Copy link

I'm having the same issue with videos in AdaptiveCards, but VideoCard attachments are working fine.
@v-kydela Might be a viable solution to unblock the customer for the moment.

const card = CardFactory.videoCard(
    '2018 Imagine Cup World Championship Intro',
    [{ url: 'https://adaptivecardsblob.blob.core.windows.net/assets/AdaptiveCardsOverviewVideo.mp4' }],
    [{
        type: 'openUrl',
        title: 'Lean More',
        value: 'https://channel9.msdn.com/Events/Imagine-Cup/World-Finals-2018/2018-Imagine-Cup-World-Championship-Intro'
    }],
    {
        subtitle: 'by Microsoft',
        text: 'Microsoft\'s Imagine Cup has empowered student developers around the world to create and innovate on the world stage for the past 16 years. These innovations will shape how we live, work and play.'
    }
);

await turnContext.sendActivity({
    attachments: [card]
});

Also seems related to this Adaptive Cards issue microsoft/AdaptiveCards#2272

@v-kydela
Copy link
Author

v-kydela commented Jun 6, 2019

Thank you @tdurnford

I did see that issue, but it looks like the discussion ended before Adaptive Cards 1.1 were ever supported in Web Chat

@tdurnford
Copy link

tdurnford commented Jun 6, 2019

It looks like the media element is being stripped out of the Adaptive Card somewhere between the Bot and WebChat.

AdaptiveCard

{
  "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
  "version": "1.1",
  "type": "AdaptiveCard",
  "body": [
    {
      "type": "TextBlock",
      "text": "**AdaptiveCard with Video**"
    },
    {
      "type": "Media",
      "poster": "https://adaptivecards.io/content/poster-video.png",
      "sources": [
        {
          "mimeType": "video/mp4",
          "url": "https://adaptivecardsblob.blob.core.windows.net/assets/AdaptiveCardsOverviewVideo.mp4"
        }
      ]
    }
  ]
}

DirectLine

import { DirectLine } from 'botframework-directlinejs';

global.XMLHttpRequest = require('xhr2');
global.WebSocket = require('ws');

var directLine = new DirectLine({
    secret: '<WEBCHAT_SECRET>'
});

directLine.postActivity({
  from: { id: 'myUserId', name: 'myUserName' }, 
  type: 'message',
  text: 'start'
}).subscribe();

directLine.activity$
.filter(activity => activity.from.name !== 'myUserName' && activity.attachments)
.subscribe(
    ({ attachments: [{content}] }) => console.log("Card ", content)
);

Output

Card  {
  type: 'AdaptiveCard',
  version: '1.1',
  body: [ { type: 'TextBlock', text: '**AdaptiveCard with Video**' } ]
}

The Adaptive Card sent by the bot has a media element, but the attachment received and processed by DirectLineJs does not.

@EricDahlvang
Copy link
Member

@tdurnford is correct. The WebChat and Direct Line connector service Adaptive Cards version is 1.0.6

WebChat is on version ~1.1.3 https://github.com/microsoft/BotFramework-WebChat/blob/master/packages/bundle/package.json#L36 and is able to render the card. Since the emulator is receiving messages directly, and not through the connector service: it can render these cards.

This issue should be moved to https://github.com/microsoft/BotFramework-Services/

@v-kydela
Copy link
Author

v-kydela commented Jun 7, 2019

Good catch @EricDahlvang. But why would the connector service even have an Adaptive Cards version if it's not responsible for rendering anything? Also, stripping out elements is useless because if the Adaptive Cards version is higher than the channel client supports, the card won't render even with the special elements removed.

@corinagum corinagum changed the title Web Chat supports Adaptive Cards 1.1 but doesn't render video Bot Connector service is not using latest Adaptive Cards Jun 7, 2019
@corinagum corinagum transferred this issue from microsoft/BotFramework-WebChat Jun 7, 2019
@tdurnford
Copy link

The DirectLine connector service maps the incoming activities from JSON to C# Objects, and since the connector service uses AdaptiveCards v1.0.6 it is not able to map AdaptiveCards attributes from v1.1.0 or greater. As a result, it drops items/media in the card like videos. Right or wrong, the limiting factor for AdaptiveCards in Web Chat is the AdaptiveCards version in the connector service. Ideally, the connector service would leave attachments as JSON and let the client handle the attachment scheme.

@tdurnford
Copy link

tdurnford commented Jun 11, 2019

As a temporary workaround, you can set the contentType of the attachment to a custom value as exemplified in the Customization Card Components Web Chat Sample and change the type back to an AdaptiveCard before Web Chat renders it. By changing the contentType, the DirectLine Connector Service treats the AdaptiveCard as JSON and does not map it to a C# Object. As a result, the card does not lose any of the elements that are only available in newer versions of AdaptiveCards. Adding an attachment middleware to Web Chat allows you to monitor for the custom attachment and change the type back to an AdaptiveCard. For more details, take a look at the code snippets below.

Bot - NodeJs SDK

Set the attachment contentType property to 'application/vnd.microsoft.card.custom' when sending the AdaptiveCard.

const card = CardFactory.adaptiveCard({
    "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
    "version": "1.1",
    "type": "AdaptiveCard",
    "body": [
      {
        "type": "TextBlock",
        "text": "AdaptiveCard with Video"
      },
      {
        "type": "Media",
        "poster": "https://adaptivecards.io/content/poster-video.png",
        "sources": [
          {
            "mimeType": "video/mp4",
            "url": "https://adaptivecardsblob.blob.core.windows.net/assets/AdaptiveCardsOverviewVideo.mp4"
          }
        ]
      }
    ]
  });
card.contentType = 'application/vnd.microsoft.card.custom';

await context.sendActivity({
  attachments: [card]
});

Web Chat Attachment Middleware

In the attachment middleware, change the custom contentType back to 'application/vnd.microsoft.card.adaptive'.

const attachmentMiddleware = () => next => card => {
  if (card.attachment.contentType === 'application/vnd.microsoft.card.custom'){
    card.attachment.contentType = 'application/vnd.microsoft.card.adaptive'
  }
  return next(card)
};

window.WebChat.renderWebChat({
  directLine,
  attachmentMiddleware
}, document.getElementById('webchat'));

Screenshot

image

This is not a long term solution to the issue, and still needs to be addressed in the connector service.

@mathurvarun84
Copy link

mathurvarun84 commented Jun 12, 2019

We are also facing the same issue. Is the video card issue is fixed in web chat or do we need to go with an above workaround?

@v-kydela
Copy link
Author

@mathurvarun84 - It is not fixed yet. Use the workaround.

@mathurvarun84
Copy link

@corinagum we also faced the same issue. when we are sending media based adaptive cards (version 1.1) then the webchat is failing to show the videos (we have the latest version of webchat). However, the above workaround solves our issue. But we can't use the above workaround as we have other channels for our bot too and they can't render custom content type adaptive cards. Any permanent fix for this issue? If you want I can send you our card json as well.

@v-kydela
Copy link
Author

@mathurvarun84 - What channels? I don't think there are any other channels that support Adaptive Cards 1.1, but in any case that's irrelevant because this issue is about Direct Line.

@tdurnford
Copy link

tdurnford commented Jun 18, 2019

@mathurvarun84 If you only want to apply the work around to AdaptiveCards being sent to Web Chat, you can check if the incoming activity's channel id is 'directline' before changing the content type. This should allow you to send AdaptiveCards to channels that support them while still using the work around for Web Chat.

const card = CardFactory.adaptiveCard(Card);
if (turnContext.activity.channelId === 'directline') {
    card.contentType = 'application/vnd.microsoft.card.custom';
}

await turnContext.sendActivity({ attachments: [ card ]})

Hope this helps!

@mathurvarun84
Copy link

mathurvarun84 commented Jun 18, 2019

Hi tdurnford
we have two channels one is directline and one is webchat. You mean to say that this issue exists if the channel is directline but doesn't if the channel is webchat. However, this is not the case it seems as for us both of it are failing.

Also, may I know why it is failing anyway if we have adaptive cards 1.2.0 in the webchat so ideally, it should support.

One more thing....does webchat support application/vnd.microsoft.card.videocard?? If we send the content as vidoecard (created by botbuilder) will that work in webchat.

@v-kydela
Copy link
Author

@mathurvarun84 - Direct Line and Web Chat are not two distinct channels. Direct Line is a channel and Web Chat is a Direct Line client. That means Web Chat is a client application with a user interface that can be used to interact with the bot through the Direct Line channel.

Do you mean you have two clients? Are you using Web Chat in addition to your own Direct Line client?

@mathurvarun84
Copy link

I apologize... .yes we have two clients... we are using salesforce which uses directline channel and we use normal app service in azure to use webchat as the channel (via the token)

@tdurnford
Copy link

tdurnford commented Jun 18, 2019

In that case, you can add channel data to each activity sent from Web Chat to distinguish messages sent specifically from Web Chat.

Web Chat Store

<script src="https://unpkg.com/simple-update-in/dist/simple-update-in.production.min.js"></script>
const store = createStore(
  {},
  ({ dispatch}) => next => async action => {
     if (action.type === 'DIRECT_LINE/POST_ACTIVITY') {
      action = window.simpleUpdateIn(action, ['payload', 'activity', 'channelData', 'channel'], () => 'webchat');
    } else if ( ... ) {
      ...
   } ...
    return next(action)
  }
);

Bot

const card = CardFactory.adaptiveCard(Card);
if (turnContext.activity.channelData && turnContext.activity.channelData.channel === 'webchat') {
    card.contentType = 'application/vnd.microsoft.card.custom';
}

await turnContext.sendActivity({ test: 'hello', attachments: [ card ]})

For more details, take a look at the Backchannel Piggyback on Outgoing Activities sample.

Hope this helps!

@v-kydela
Copy link
Author

@mathurvarun84 - Does the Salesforce client support Adaptive Cards 1.1?

@v-kydela
Copy link
Author

@corinagum - Has this been fixed?

@corinagum
Copy link

Web Chat has been bumped to 1.2, but the issue linked above will finish up some of the work I missed.

@v-kydela
Copy link
Author

@corinagum - Has the Direct Line connector service been updated to Adaptive Cards 1.2 (or become version-independent)? Can this issue be closed or has it not been addressed?

@v-kydela
Copy link
Author

v-kydela commented Jul 18, 2019

I just tested again and Direct Line is still stripping out media elements from Adaptive Cards. That's interesting because the new wrap property works in choice sets. I guess Direct Line removes unrecognized elements but not unrecognized properties.

@compulim
Copy link

compulim commented Jul 19, 2019

Is there service team aware of AC 1.0.6 in their code base? If not, we should. CK and Daniel are probably good starting point.

@CoHealer
Copy link

Opened a bug in DevOps for investigation & costing.

@jameslew
Copy link

jameslew commented Aug 9, 2019

To the earlier questions; we have scheduled the work to update Adaptive Cards to v1.2. It is a little trickier than expected, some of our clients are still using Adaptive Cards 0.5 and the 1.2 version breaks compatibility with them and we're looking for a solution that doesn't break existing bots while unblocks those wishing to use 1.2 features.

@jameslew jameslew added bug Something isn't working customer-reported As opposed to development work item. labels Aug 9, 2019
@v-kydela
Copy link
Author

v-kydela commented Aug 9, 2019

@jameslew - From what you're saying, am I correct in understanding that when Direct Line deserializes an Adaptive Card using the 1.2 schema it removes tokens that are used by the 0.5 schema, which some Direct Line clients use?

If that is true then it's an even more persuasive case in favor of the recommendation made by TJ and me. To explain, there seem to be two possible fixes for the Web Chat problem:

  1. Update Direct Line to use Adaptive Cards 1.2 (which Corina stated in her edit at the top of the post)
  2. Update Direct Line to not have an Adaptive Cards version and just forward the JSON without deserializing it, allowing all validation to be done by the client

I had already thought option 2 would be best because it would be a permanent solution. That is to say, we wouldn't run into this problem again for future versions of Adaptive Cards. But based on what you're saying, it sounds like option 2 would also allow for more backward compatibility in addition to more forward compatibility.

@sgellock sgellock added customer-replied-to Required for internal Azure reporting. Do not delete. Do not change color. and removed customer-replied-to Required for internal Azure reporting. Do not delete. Do not change color. customer-reported As opposed to development work item. labels Aug 15, 2019
@compulim
Copy link

compulim commented Sep 4, 2019

@ckkashyap has a work item to bump Adaptive Cards in Direct Line channel to use 1.2.

I am unsure how current version (1.0.x) vs. 1.2. Looking at AC changelog but didn't see anything related to it.

Agree to @v-kydela that the best option is don't touch JSON. But need to fully understand why we do it today and what is the advantage. If we passthru JSON, what features we missed.

When bumping to 1.2, if the behavior changed, we will need to find a way to tell customers how our change will break stuff, and schedule, etc. In this case, we will need to loop in PM to coordinate.

FYI, in Direct Line Streaming Extensions, it is passthru. In my believe, we should reduce the difference of DL REST/WS and DL SE as much as we could.

@jameslew jameslew added customer-replied-to Required for internal Azure reporting. Do not delete. Do not change color. customer-reported As opposed to development work item. P0 labels Oct 3, 2019
@cwhitten
Copy link
Member

cwhitten commented Nov 1, 2019

@jameslew when it this scheduled to be addressed? We continue to get complaints from customers on the WebChat project.

@dandriscoll
Copy link
Member

I have status on this from our last standup -- we are waiting on a bugfixed version of Adaptive Cards and are targeting ~11/22 for a fix in production.

@paulio
Copy link

paulio commented Nov 4, 2019

Potential dumb question warning ;) A client is suggesting that when they use Web Sockets they don't see the issue. I confess I don't know too much about this, is there any truth/reason for this?

@dandriscoll
Copy link
Member

It's a good question but I can't think of a reason for that as the processing occurs inbound from the bot, not outbound to the client (over GET vs. Web Socket). Not all cards trigger the issue in the current library.

@v-kydela
Copy link
Author

v-kydela commented Nov 4, 2019

@dandriscoll - Does the fix account for future versions of Adaptive Cards by allowing Adaptive Cards that Direct Line doesn't understand pass through unchanged? Or does the fix just incorporate the latest version of Adaptive Cards without changing the underlying design of Direct Line?

@PiLp
Copy link

PiLp commented Nov 18, 2019

I am also experiencing the same issue as brett-1hw in #2912, the adaptive card is rendering but cuts off when it should display ActionSets. I am also interacting with the bot using DirectLine.

@paulio
Copy link

paulio commented Nov 22, 2019

Any news on the target release of 22nd Nov?

@ckkashyap
Copy link

Hi @paulio ,
Bot Framework services have been updated with AdaptiveCard 1.2.4 - as of last evening. Please let us know if you see any issues.
Regards,
Kashyap

@MIRo2k
Copy link

MIRo2k commented Nov 25, 2019

hello @ckkashyap , you can confirm which components and versions we have to update ??

@ckkashyap
Copy link

Hi @MIRo2k ,
We have upgraded the Adaptive Cards library used by the channels - to version 1.2.4. You don't really "have to" update anything. This upgrade fixes certain bugs in the channel such as dropping actionset from the adaptive card json payload.
HTH
Regards,
Kashyap

@paulio
Copy link

paulio commented Nov 28, 2019

FYI it seems to be working :)

@ckkashyap
Copy link

Thanks @paulio - I am going to close this issue.

@rvallireply
Copy link

rvallireply commented Dec 5, 2019

Hello,
I built and deployed the ITSM experimental skill for Virtual Assistant sample, and the Web Chat has an OpenUrl action in an ActionSet that still gives issues:

**

The card could not be rendered. It is either malformed or uses features not supported by this host.

**

using a 1.2.4 Adaptive Cards, on westeurope.

this is the card payload in the sample, it works in the Bot Emulator but not in Web Chat. If I remove the ActionSet element it renders without error:


{
  "type": "AdaptiveCard",
  "id": "KnowledgeCard",
  "body": [
    {
      "type": "Container",
      "backgroundImage": "",
      "items": [
        {
          "type": "ColumnSet",
          "columns": [
            {
              "type": "Column",
              "horizontalAlignment": "Center",
              "verticalContentAlignment": "Center",
              "items": [
                {
                  "type": "Image",
                  "horizontalAlignment": "Center",
                  "url": "",
                  "width": "35px",
                  "height": "35px"
                }
              ],
              "width": "auto"
            },
            {
              "type": "Column",
              "verticalContentAlignment": "Center",
              "items": [
                {
                  "type": "TextBlock",
                  "horizontalAlignment": "Left",
                  "size": "Medium",
                  "color": "Light",
                  "text": "{Title}",
                  "wrap": true
                }
              ],
              "width": "stretch"
            }
          ]
        },
        {
          "type": "TextBlock",
          "size": "Small",
          "color": "Light",
          "text": "{UpdatedTime}"
        },
        {
          "type": "TextBlock",
          "size": "Small",
          "color": "Light",
          "text": "{Number}"
        }
      ]
    },
    {
      "type": "TextBlock",
      "wrap": true,
      "text": "{Content}",
      "maxLines": 5
    },
    {
      "type": "ActionSet",
      "actions": [
        {
          "type": "Action.OpenUrl",
          "title": "{UrlTitle}",
          "url": "{UrlLink}"
        }
      ]
    },
    {
      "type": "Container",
      "separator": true,
      "items": [
        {
          "type": "TextBlock",
          "horizontalAlignment": "Right",
          "size": "Small",
          "color": "default",
          "text": "{ProviderDisplayText}"
        }
      ]
    }
  ],
  "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
  "version": "1.0",
  "speak": "{Speak}"
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working customer-replied-to Required for internal Azure reporting. Do not delete. Do not change color. customer-reported As opposed to development work item. P0
Projects
None yet
Development

No branches or pull requests