リンク展開

重要

このセクションのコード サンプルは、v4.6 以降のバージョンの Bot Framework SDK に基づいています。 以前のバージョンのドキュメントをお探しの場合は、ドキュメントの Resources フォルダーにある メッセージ拡張機能 - v3 SDK セクションを参照してください。

このドキュメントでは、開発者ポータルを使用してアプリ マニフェストにリンク解除を追加する方法と手動で説明します。 リンクの展開を解除すると、特定のドメインの URL が新規作成メッセージ領域に貼り付けられているときに、アプリが呼び出しアクティビティを受信するように登録できます。 invoke には、メッセージ作成領域に貼り付けられた完全な URL が含まれ、ユーザーが展開できるカードを使用して応答し、追加情報やアクションを提供できます。 これは検索コマンドと同様に機能し、URL は検索語として機能します。 アプリをインストールせずに、Microsoft Teams へのリンク展開を追加できるようになりました。

Teams やその他のアプリにインストールされているかインストールされていない Teams アプリのリンク展開エクスペリエンスを示すスクリーンショット。

注:

  • リンク展開の結果は、30 分間キャッシュされます。
  • リンクの展開では、アダプティブ カード バージョン 1.3 以前がサポートされています。
  • リンク解除には、メッセージング拡張機能コマンドは必要ありません。 ただし、マニフェストには、メッセージング拡張機能の必須プロパティであるため、少なくとも 1 つのコマンドが必要です。 詳細については、「 compose extensions」を参照してください。
  • モバイル クライアントの場合、リンク展開は、認証を必要としないリンクに対してのみサポートされます。

次の図は、Teams デスクトップ クライアントとモバイル クライアントでのリンク展開の例です。

リンクが Teams 作成メッセージ領域に貼り付けると、リンクは作業項目の詳細を含むカードに展開されます。

チームの新規作成メッセージ領域に貼り付けた Azure Dev Ops リンクのリンク展開の例のスクリーンショット。

リンクの展開の詳細については、次のビデオを参照してください。


アプリ マニフェストにリンク展開を追加するには、アプリ マニフェスト JSON の composeExtensions セクションに新しい messageHandlers 配列を追加します。 配列は、開発者ポータルの助けを借りて追加することも、手動で追加することもできます。 ドメイン一覧には、ドメインの 1 つのセグメントに一致するワイルドカードを *.example.com 含めることができます。 と一致 a.b.example.comさせる必要がある場合は、 を使用 *.*.example.comします。

注:

直接またはワイルドカードを使用して、コントロールに含まれていないドメインを追加しないようにします。 たとえば、 yourapp.onmicrosoft.com は有効ですが *.onmicrosoft.com 、無効です。 最上位のドメインは、たとえば*.com*.org、禁止されています。

  1. Microsoft Teams クライアントから 開発者ポータル を開き、[ アプリ ] タブを選択します。

    アプリが赤で強調表示された開発者ポータルを示すスクリーンショット。

    注:

    Teams クライアントにアプリを追加していない場合は、開発者ポータル アプリを追加する必要があります。

    検索と開発者ポータルが赤で強調表示されている Teams を示すスクリーンショット。

  2. アプリ マニフェストを読み込みます。

    アプリ情報を示す開発者ポータルのスクリーンショット。

  3. [アプリの機能] で [メッセージング拡張機能] を選択し、[既存のボットの選択] または [新しいボットの作成] を選択します。

    アプリ機能とメッセージング拡張機能が赤で強調表示されているアプリ機能のスクリーンショット。

    [既存のボットの選択] が赤で強調表示されているメッセージング拡張機能のスクリーンショット。

  4. [保存] を選択します。

  5. [プレビュー リンク] セクションで [ドメインの追加] を選択し、有効なドメインを入力します。

  6. [追加] を選択します。 次の図にこのプロセスを示します。

    開発者ポータルのメッセージ ハンドラー セクションのスクリーンショット。

注:

Microsoft Entra ID経由で認証が追加された場合は、ボットを使用して Teams のリンクを削除します

まず、配列を messageHandlers アプリ マニフェストに追加し、メッセージ拡張機能がリンクと対話できるようにする必要があります。 次の例は、リンク展開を手動で追加する方法を説明しています。

...
{
  "composeExtensions": [
    {
      "botId": "abc123456-ab12-ab12-ab12-abcdef123456",
      "messageHandlers": [
        {
          "type": "link",
          "value": {
            "domains": [
              "*.trackeddomain.com"
            ]
          }
        }
      ]
    }
  ]
}
...

完全なマニフェスト例については、マニフェスト リファレンスを参照してください。

アプリ マニフェストにドメインを追加した後、要求を処理するように Web サービス コードを更新する invoke 必要があります。 受信した URL を使用してサービスを検索し、カード応答を作成します。 複数のカードで応答する場合は、最初のカード応答のみが使用されます。

注:

ボットからの応答には、プロパティを preview 含める必要があります。

次の種類のカードがサポートされています。

詳細については、「アクション タイプ invoke」を参照してください。

次のコードは、要求の例です invoke

ボットに送信された invoke の例を次に示します。

   {
     "type": "invoke",
     "name": "composeExtension/queryLink",
     "value": {
       "url": "https://theurlsubmittedbyyouruser.trackeddomain.com/id/1234"
     }
   }

応答の例:

{
 "composeExtension":
   {
     "type": "result",
     "attachmentLayout": "list",
     "attachments": 
     [
       {
         "contentType": "application/vnd.microsoft.card.adaptive",
         "preview": 
          {
            "contentType": "application/vnd.microsoft.card.adaptive",
            "content": << Card Payload >>
          },
          "contentType": "application/vnd.microsoft.card.adaptive",
          "content": << Card Payload >>
       }
      ]
   }
}
      

Microsoft Teams でコンテンツを共有する最も一般的な方法は、リンク経由です。 リンクの場合、Teams はリンクのプレビューをアダプティブ カードに展開し、画像、タイトル、説明などの情報を表示します。

Microsoft Teams にアプリをインストールしなくても、リンクのリッチ アンファール プレビューを表示できます。 schema.org メタデータJSON-LD 形式で Web サイトに追加し、製品に一致するマイクロ機能テンプレートを使用します。 Teams では、これらのテンプレートを使用して、Microsoft Teams のリンクのリッチ プレビューを削除します。

Web サイトに schema.org を既に追加している場合は、Teams メッセージ作成領域に貼り付けることで、リンクのリッチ アンファール プレビューを表示できます。

Teams メッセージ作成領域にリンクが貼り付けられたときのリッチ アンファール プレビュー エクスペリエンスの例を示すスクリーンショット。

Web サイトに schema.org を追加していない場合は、次の手順に従って、リッチアンファール プレビュー エクスペリエンスを手動でチェックできます。

  1. JSON-LD 形式schema.org メタデータを Web サイトに追加します。

  2. Web サイトで、サポートされている@type属性をチェックし、スクリプト タグ の下にメタデータをコピーしますapplication/ld+json

  3. アダプティブ カード デザイナーを開き、新しいファイルを作成します。

  4. サンプル データ エディターで、Web サイトの json メタデータを貼り付けます。

    アダプティブ カード Designerのサンプル データ エディター セクションの Web サイト メタデータの例を示すスクリーンショット。

  5. マイクロ機能テンプレートを確認し、 カード ペイロード エディターでテンプレート コードを追加します。

    スクリーンショットは、アダプティブ カード Designerのカード ペイロード エディターに追加されたマイクロ機能テンプレートの例を示しています。

    必要に応じて、 サンプル データ エディターでテンプレートから Web サイトのメタデータに新しい属性を追加します。

  6. アダプティブ カードの展開解除エクスペリエンスをプレビューするには、[ プレビュー モード] を選択します。

詳細については、「 Web サイトリンクのマイクロ機能」を参照してください。

ゼロ インストール リンク展開は、ユーザーが Teams でアプリを検出またはインストールする前でも、共有リンクのプレビューを展開解除するのに役立ちます。 アプリをインストールまたは認証する前に、新 invoke しい要求でカードを匿名で展開したり、事前認証されたアダプティブ カード プレビューを作成したりできます。

次の図は、ゼロ インストール リンクの展開を有効にして使用するためのシーケンシャル フローを示しています。

リンクが展開されていないコード ユーザー フローのスクリーンショット。

ゼロ インストール リンクの展開準備を整えるには、次の手順に従います。

  1. マニフェスト スキーマで プロパティsupportsAnonymizedPayloadsを true に設定します。

  2. 新しい invoke 要求 composeExtensions/anonymousQueryLinkを処理するようにアプリを設定します。

    新しい invoke 要求の例:

    マニフェストの 'invoke' 要求 'composeExtensions/anonymousQueryLink' 宣言のスクリーンショット。

    要求ペイロードの invoke 例:

    {
       "name":"composeExtension/anonymousQueryLink",
       "type":"invoke",
       "timestamp":"2021-12-02T08:12:21.148Z",
       "localTimestamp":"2021-12-02T00:12:21.148-08:00",
       "id":"f:43d59e15-6114-bd53-08c3-b232aa648ec1",
       "channelId":"msteams",
       "serviceUrl":"https://smba.trafficmanager.net/amer/",
       "from":{
          "id":"redacted",
          "name":"redacted"
       },
       "conversation":{
          "isGroup":true,
          "conversationType":"groupChat",
          "tenantId":"redacted",
          "id":" redacted",
          "name":" redacted"
       },
       "recipient":{
          "id":"28:85fa138c-7654-4236-86eb-466160687029",
          "name":"test bot"
       },
       "entities":[
          {
             "locale":"en-US",
             "country":"US",
             "platform":"Mac",
             "timezone":"America/Los_Angeles",
             "type":"clientInfo"
          }
       ],
       "channelData":{
          "tenant":{
             "id":" redacted"
          },
          "source":{
             "name":"compose"
          }
       },
       "value":{
          "url":"https://test.test.com/test"
       },
       "locale":"en-US",
       "localTimezone":"America/Los_Angeles"
    }
    
  3. ペイロードに応答します composeExtensions/anonymousQueryLink

    1. 認証以外のシナリオの場合: as result と カードを含むtype応答を送信する必要があります。 次のテンプレートを使用します。

      {
        "composeExtension": {
          "type": "result",
          "attachmentLayout": "list",
          "attachments": [
            {
              "contentType": "application/vnd.microsoft.teams.card.o365connector",
              "content": {
                "sections": [
                  {
                    "activityTitle": "[85069]: Create a cool app",
                    "activityImage": "https://placekitten.com/200/200"
                  },
                  {
                    "title": "Details",
                    "facts": [
                      {
                    "name": "Assigned to:",
                    "value": "[Larry Brown](mailto:larryb@example.com)"
                      },
                      {
                    "name": "State:",
                    "value": "Active"
                      }
                    ]
                  }
                 ]
               }
            }
          ]
        }
      }
      
    2. 認証シナリオの場合: 添付ファイルにtype省略可能な事前認証カードと同様authの応答を送信する必要があります。 次のテンプレートを使用します。

      {
         "composeExtension": {
            "type": "auth",
            "attachmentLayout": "list",
            "attachments": [
               {
                 "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
                 "type": "AdaptiveCard",
                 "version": "1.5",
                 "actions": [],
                 "body": [
                   {
                     "type": "TextBlock",
                     "size": "medium",
                     "weight": "bolder",
                     "text": "Zero-install test app"
                  },
                  {
                     "type": "TextBlock",
                     "text": "Link your account with this app for a full experience",
                     "wrap": true
                  }
                 ]
               }
            ]
         }
      }
      
  4. 事前認証カード (認証のみ): カード プレビューを作成して、アプリをインストールしていないユーザーのリンクを削除します。 事前テンプレート化されたカードを作成するか、ユーザーが更新する関連するプレースホルダー フィールドを追加できます。 ユーザーは、アプリをインストールする前に、アプリについて学習できます。

    カスタマイズされたカードを作成し、関連するフィールドを追加できます。 ユーザーは、フィールドに従って必要な情報を入力できます。 次の図は、カスタマイズされたカード プレビューを示しています。

    ユーザーが更新するフィールドを含むカスタマイズされたカードのスクリーンショット。

    次の図は、既定のプレビュー カードを示しています。

    コードの展開を解除するリンクのスクリーンショット。既定のプレビュー カード。

    注:

    メッセージ作成領域にリンクを貼り付けた後、Teams はリンクをカードに展開し、ユーザーにアプリへのサインインを求めます。 ユーザーがアプリにサインインしない場合、リンクはチャットのカードとして投稿されません。

  5. 利点と制限事項:

    ゼロ インストール リンクの展開は、次のようなユーザーに強化されたエクスペリエンスを提供するのに役立ちます。

    • アプリをインストールする前に、ユーザーが Teams で共有するリンクのプレビューの展開を解除します。
    • プレースホルダー フィールドを含むプレビューを表示するために、アプリ用のウェルカム カードを作成します。

展開されていないゼロ インストール リンクをテストするときは、個人用アプリとしてアプリをインストールしないでください。 代わりに、アプリを Teams にアップロードします。

注:

Microsoft Visual Studio デバッガーからテスト アプリを直接実行しないでください。

ゼロ インストール リンクの展開をテストするには、次の手順に従います。

  1. Microsoft Teams 管理センターにサインインします。

  2. 左側のウィンドウで、[Teams アプリ] [アプリ>の管理] の順に選択します。

    Teams でカスタム アプリをアップロードするための Teams 管理センターとセクションのスクリーンショット。

  3. [ + 新しいアプリのアップロード] を選択します

    Teams 管理センターとカスタム アプリをアップロードする場所のスクリーンショット

  4. [アップロード] を選択します。

  5. [ 開く ] を選択して、テスト アプリケーションの zip ファイルをアップロードします。

  6. アプリのアップロードが成功したら、[Teams Apps Built for your org]\(組織用に構築されたTeams>アプリ>\) に移動します。

    組織がアップロードされた Teams アプリを持つ Teams クライアントのスクリーンショット

  7. 呼び出し要求を composeExtensions/anonymousQueryLink テストするには、アプリケーションで anonymousQueryLink 要求を実装するメソッドにブレークポイントを設定します。

ユーザーが会議でリンクを共有すると、Teams アプリはアダプティブ カードへのリンクを展開します。 リンク展開の結果は、30 分間 Teams にキャッシュされます。 アプリを更新してキャッシュ ポリシーを設定し、アプリのキャッシュを削除できます。 このアクションは、アプリのリンクが Teams の別のコンテキストで共有されている場合に、アダプティブ カードにさまざまなコンテンツを表示するのに役立ちます。

リンクの展開を解除するキャッシュを削除するには、 プロパティの下にある と同様setcachepolicyに をtype使用してボットをsuggestedActions更新します。 Teams は、 を使用してアプリ リンクの結果を "type": "setCachePolicy"キャッシュしません。

プロパティの次の JSON ペイロードの suggestedActions 例:

"suggestedActions": {
            "actions": [
                {
                    "type": "setCachePolicy",
                    "value": "{\"type\":\"no-cache\"}"
                }
            ]
        },

ステップ バイ ステップのガイド

このステップバイステップ ガイドに従うと、ボットを使用して Teams でリンクを展開できます。

コード サンプル

サンプルの名前 説明 .NET Node.js マニフェスト
ゼロ インストール リンクの展開。 このサンプルでは、構成ページで Search ベースのメッセージング拡張機能を使用する方法を示します。 このサンプルでは、ゼロ インストール リンクの展開も備えています。 表示 表示 表示

関連項目