TeamsのリアクションをPower Automate側で取得する方法を聞かれたので、メモ。
やりたいこと
TeamsのチャネルへのリアクションをPower Automateで取得し、Power Apps側に表示したいときのお話。
data:image/s3,"s3://crabby-images/c5cf4/c5cf40c79148ab380977af735372f30f03c3b615" alt=""
data:image/s3,"s3://crabby-images/c5cf4/c5cf40c79148ab380977af735372f30f03c3b615" alt=""
Power Automateの構築
まずはPower Automateの構築から。最終的にこんなフローになる。
data:image/s3,"s3://crabby-images/c6fc5/c6fc57943781e3e2ec1add7dcf45bfd37b17edf7" alt=""
data:image/s3,"s3://crabby-images/c6fc5/c6fc57943781e3e2ec1add7dcf45bfd37b17edf7" alt=""
まずは引数として「チーム(グループ)ID」と「チャネルID」「メッセージID」を受け取る。
data:image/s3,"s3://crabby-images/24480/24480c24fe0cea904698939228dd88080230f89f" alt=""
data:image/s3,"s3://crabby-images/24480/24480c24fe0cea904698939228dd88080230f89f" alt=""
続いて「メッセージ詳細を取得する」アクションと受け取った引数を使用し、メッセージの詳細を取得。
data:image/s3,"s3://crabby-images/c5596/c5596310744fe74f1f90417b5d729f68e1dbd7e8" alt=""
data:image/s3,"s3://crabby-images/c5596/c5596310744fe74f1f90417b5d729f68e1dbd7e8" alt=""
そしたら、メッセージに含まれる「reactions」プロパティを「JSONの解析」アクションにかけてあげる。
※コンテンツに入れる式は↓
※コンテンツに入れる式は↓
outputs('メッセージ詳細を取得する')?['body/reactions']
※スキーマはこちら。うまく動かない場合はフローを一度動かし、「メッセージ詳細を取得する」アクションの出力から作成してください。
{ "type": "array", "items": { "type": "object", "properties": { "reactionType": { "type": "string" }, "displayName": { "type": "string" }, "reactionContentUrl": {}, "createdDateTime": { "type": "string" }, "user": { "type": "object", "properties": { "application": {}, "device": {}, "user": { "type": "object", "properties": { "@@odata.type": { "type": "string" }, "id": { "type": "string" }, "displayName": {}, "userIdentityType": { "type": "string" } } } } } }, "required": [ "reactionType", "displayName", "createdDateTime", "user" ] } }
最後に取得したリアクションのオブジェクトをPower Appsで扱いやすい形に変えるため、「選択」アクションを使用。(任意)
data:image/s3,"s3://crabby-images/42e8d/42e8ddac06c3c01990f1a2efcec1e7b9263760d3" alt=""
data:image/s3,"s3://crabby-images/42e8d/42e8ddac06c3c01990f1a2efcec1e7b9263760d3" alt=""
user_idとuser_nameはオブジェクトの深い位置にあるので、間違えないよう注意。
// リアクションしたユーザーのID item()?['user']?['user']?['id'] // リアクションしたユーザーの名前 item()?['user']?['user']?['displayName']
最後に「選択」アクションのbodyをPower Apps側に戻す。
body('選択')['body']
以上でPower Automateの構築は完了。
Power Appsの構築と動作確認
Power Appsはこんな感じで「チーム」「チャネル」を選択し、一覧に「メッセージ」を表示するよう構築。
data:image/s3,"s3://crabby-images/c8c58/c8c58cd113574868e38370929f27153024a80d75" alt=""
data:image/s3,"s3://crabby-images/c8c58/c8c58cd113574868e38370929f27153024a80d75" alt=""
リアクションを取得するためのボタンではPower Automateを呼び出し、戻り値のJSONを解析してテーブル変数「reactions」に代入する。
With({ret:getReactions.Run(cmbGroup.Selected.id, cmbChannel.Selected.id, glyMessages.Selected.id).reactions}, UpdateContext({reactions: ForAll(ParseJSON(ret) As reaction, { type:reaction.type, reaction_name:reaction.reaction_name, dateTime:reaction.dateTime, user_id:reaction.user_id, user_name:reaction.user_name } ) }); )
あとはreactionsの中身をリストボックスとかギャラリーに表示すれば、こんな感じでリアクションを取得することができる。
data:image/s3,"s3://crabby-images/77435/774355d17279c33d3b2b4b0588a3fa0c6ad47b1a" alt=""
data:image/s3,"s3://crabby-images/77435/774355d17279c33d3b2b4b0588a3fa0c6ad47b1a" alt=""
おまけ:リアクションしたユーザーの詳細が欲しい場合
ユーザーIDはこんな感じでEntraIDのGUIDの取得になる。
data:image/s3,"s3://crabby-images/212f8/212f8fea5a3942b551ccbd2aac7529e93dc9cbd4" alt=""
data:image/s3,"s3://crabby-images/212f8/212f8fea5a3942b551ccbd2aac7529e93dc9cbd4" alt=""
user_nameプロパティとかは設定されないこともあるため、ユーザーの詳細を取得したい場合はPower Apps側かPower Automate側でOffice365ユーザーコネクタのUserProfileV2関数を使用し、取得する必要がある。
data:image/s3,"s3://crabby-images/325f4/325f431d4c82d4fb61e43e872cea492067e5ea06" alt=""
data:image/s3,"s3://crabby-images/325f4/325f431d4c82d4fb61e43e872cea492067e5ea06" alt=""
こんな感じでユーザー名が取得できる
data:image/s3,"s3://crabby-images/ea79e/ea79e22ec3747e397339dbe8bef8645c6127c7d8" alt=""
data:image/s3,"s3://crabby-images/ea79e/ea79e22ec3747e397339dbe8bef8645c6127c7d8" alt=""