今回は、Power Automate の Teamsコネクタの 「チャットやチャネルのアダプティブ カードを更新する」アクションのチョッとしたテクニックのご紹介です。
「チャットやチャネルのアダプティブ カードを更新する」アクション
「チャットやチャネルのアダプティブ カードを更新する」アクションの動作イメージや利用手順などは @MiTo60448639 さんの記事がわかりやすいと思います。
Docs はこちら。
アダプティブカード関連の Docs はコチラ。
知らない機能を利用する際などは公式の基本情報もチャンとチェックしないと、ですね。読みにくいけど😇
そのアクション、個別チャットにアプローチできない問題?
紹介しているアクションですが、ターゲットに指定できる[投稿先]が
- Channel ・・・ チームのチャネルをターゲットにする場合に選択
- Group chat ・・・ 会議チャットやグループチャットをターゲットにする場合に選択
の 2 つしか選択肢に表示されません。
一見すると、いわゆる個別チャット(1対1 のチャット)には対応してないようにみえます。投稿先に”カスタム値の入力”とあるので、それを利用したらイケるんじゃないかな?とも思ったのですが、既に先人が「ダメですね」という調査結果を共有してくれていました。
んー、個別チャットにポストしたアダプティブカードも更新したいなぁ、という状況になった当方。色々と試行錯誤を繰り返し、調べて試して実現する方法を見つけましたヨッ!!
個別チャットのアダプティブカードを更新する方法
さて、本題。当方が発見した方法です。
おことわり
記事投稿時点(2022/08/07)の仕様、方法になります。将来的なアップデートで変更になる可能性があります。また、当方が調査して検証した限りの内容を多分に含みます。その点を予めご了承のうえ続きを確認ください。
説明用のフロー全体像
当記事の説明で利用するフロー全体像は下記です。シンプルに仕上がっております。
動作イメージ
左側が Power Automate のフロー画面、右側が Teams の個別チャット(1対1のチャット)へアダプティブカードを送信して、更新している画面です。
#PowerAutomate Update an adaptive card in one on one chat. pic.twitter.com/3AmG0CgD06
— やま (Yama) (@yamad365) August 7, 2022
図で説明すると、下記のようなイメージです。
シンプルに仕上がっておりますね。
フローの説明 あるいは 実現方法の解説
個別チャットに投稿したアダプティブカードを更新する手段を案内していきましょう。フローの各アクションに説明用の番号を付与しておきます。
①アダプティブカードを投稿して応答を待機する
更新される前のアダプティブカードを投稿しているアクションです。検索すると先人たちの例が見つかると思います。ので、詳細は割愛ッ!
②アレイのフィルター処理 でターゲットを取得
このアレイ(配列)のフィルター処理がキモです。アクションを展開すると下記のようになっています。端的に言うと「①で投稿したメッセージの URL 情報から ”conversation ID” を取得」しています。
[差出人]に指定している関数は下記。
split( outputs('アダプティブ_カードを投稿して応答を待機する')?['body/messageLink'] , '/' )
①のアクションで投稿したメッセージの ”messageLink” の URL を "/" で分解しています。
アレイのフィルター条件、左辺は ”item()" を指定します。これは、上記 split 関数で分解された各アイテムですね。
真ん中の条件は ”次のもので始まる” で、右辺は ”19:” と入力しています。これで「分解された結果のアイテムの中で、"19:” から始まるモノ」のみが抽出されてきます。
この ”19:~” という値が重要です。まずはフローの全容を説明してしまいますので、現時点でピンときてない方も「この後の処理で必要な情報が取れるらしいぞ」という理解で現時点はオッケーです。ってコトで次へ行きましょう。
③投稿済みのアダプティブカードを更新する
さて、問題の「チームのチャネルかグループチャットしか更新できなそう」なアクションへの対応です。
[投稿先]は ”Group chat” を選択してください。
[Message ID] は ① のアクション結果にある ”messageId” です。
1つ飛ばして[Adaptive Card]はお好きな JSON をどうぞ。
[Group chat]へ下記を指定します。
first(body('アレイのフィルター処理'))
前述②で処理したターゲットを指定しています。first 関数を利用している意図がわからない方は是非ともご自分で調べて把握してください。長くなるので詳細にはふれませんが、このアクションがエラーになった際の情報が非常に不親切なんですよ。エラーメッセージから誤っている内容が推測しづらいので多少知識を持って挑戦しないとアカン系のアクションだと個人的に考えています。なので、ここらへん、自力で処理できないとツライです。頑張って学習や検証などを各位で実施してください!
これで、動作イメージのように「個別チャットへ投稿したアダプティブカードを更新する」が実現できます。
”conversation ID” 解説 あるいは ② の更なる補足
②の処理で、"/" で split(分割)して "19:" で始まる対象を取得していたのは、③の解説で何となく想定できたかと思います。[Group chat]の項目へ指定するための ID を生成していたんですね。
Teams の個別チャットやグループチャット、チームのチャネル スレッド等は各々『その場所を一意に表す値』を持っています。その値、今回の場合は「URL に含まれている」を確認するイチバン簡単な方法は、ブラウザーで Teams を起動して確認する方法でした。
グループチャットの場合
グループチャットの場合、”19:” で始まり、末尾が”@thread.v2”になるようです。
例)htt㎰: // teams.microsoft.com / _# / conversations / 19:b1e~中略~00@thread.v2 ?ctx=chat
個別チャットの場合
個別チャットの場合は ”19:” で始まり、末尾が”@unq.gbl.spaces”になるようです。
実在のユーザーであろうと、フローボットであろうと当ルールは確認した限りでは同一でした。
例)htt㎰: // teams.microsoft.com / _# / conversations / 19:5e8~中略~ec87@unq.gbl.spaces ?ctx=chat
そのものズバリではないですが、参考になりそうな情報を下記にしておきます。
グループチャットであろうと、個別チャットであろうと「ターゲットになる ID(今回は URL の一部)」が指定できれば『ソコにあるアダプティブカードを更新する』が可能になる、です。なので、ターゲットとなる場所が明確であれば、固定の値をアクションの該当箇所へ設定するだけでも同じ結果を期待できます。当方は、将来的に複数の対象へアプローチしたかったので汎用性を考慮した内容でフローの作成をしてみました。
まとめ
Power Automate で用意されていたアクションの項目と、Microsoft 365(今回は Teams)の仕様というか動きというかをジックリ眺めて試していたら辿り着いた、という感じです。実はもっと簡単に実現できる方法があるかもしれません。Docs など、どこにも「個別チャットのアダプティブカードを更新する方法」は明記されてないので、他に手段をお持ちの方は是非とも情報公開してほしいです。
アクションの標準で選択肢に「個別チャット」が用意されていれば、こんな苦労しなくて済んだのに・・・。今後の VerUp に期待しましょう。(VerUp でもっと柔軟に実現できる日が来たら、この記事は”当時を物語る断片”として歴史になる・・・のかな?w)
それでは、皆さま。素晴らしい Power Platform Life を!