本記事は、Microsoft Power Automate Advent Calendar 2024 12月13日担当分の記事です。
この記事では、Power Automate for desktop (デスクトップ フロー) から、Microsoft Teams のチャネルにメッセージを投稿する方法を記載します。
はじめに
Power Automate for desktop から Teams のチャネルに投稿する方法については、いくつかの方法があります。私も以前に、その方法をまとめた記事を書きましたが、その後 PAD のアップデートで新たな方法が追加されたり、逆に Teams のセキュリティ強化や Microsoft 365 の更新により、利用が制限されたり非推奨となった方法もあります。
今回は、これらのアップデートをもとに現時点で利用可能な方法についてまとめます。
目次
1.クラウドコネクタ (Teams コネクター) の利用
2. Power Automate の Teams Webhook の利用
3. チャネルのメールアドレスを利用
1.クラウドコネクタ (Teams コネクター) の利用
Power Automate for desktop では、クラウドフローで利用可能なコネクターも利用可能になっています。その中で Teams のコネクターも利用できるように更新されています。
この方法は UI 操作だけで設定できること、また、クラウド フローを利用しているユーザーであれば使い慣れた方法でもあるので、利用しやすい方法なのではないかなと思います。
本方法は、Power Automate Premium ライセンスが必要なので、組織アカウントでもライセンスが無いユーザーや Microsoft アカウントをで利用しているユーザーでは、利用できないことを留意してください。
この方法については、のりじさんが必要な設定含めて丁寧にまとめられているため、具体的な内容についてはリンクの記事をご参考ください。(のりじさん、リンクへの許諾ありがとうございます。)
2. Power Automate の Teams Webhook の利用
クラウドフローのトリガーとして用意されている、Teams の受信用 Webhook に対してリクエストを送信して、投稿する方法が考えられます。こちらは Premium ライセンスは不要です。
従来、Teams の Incoming Webhook にリクエストを送信して投稿する方法 (Link)がありましたが、この方法は非推奨となり、2024年いっぱいで利用できなくなります。
後継として利用が推奨されているのが、この Power Automate を利用した方法となります。
手順1 クラウドフローの作成
構成の方法は、Power Automate (クラウドフロー) 上で、テンプレートから作成する方法と、Teams 上の Workflow アプリ (これも Power Automate) から作成する方法があります。
Teams 上で構成する方法は以下のサポート記事にまとめっています。
Power Automate 上で構成する場合は、以下のテンプレートを探して、テンプレートをもとに作成するだけです。
いずれの方法でもクラウドフローが作成される動作となり、作成したフローはクラウドフローの画面上から参照できます。
作成されたフローを開き、トリガーに設定された HTTP URL をメモ帳などに控えます。あとで利用します。
チャネル (またはチャット) に投稿するアクションで、どのチームに対して投稿するか設定します。(Teams 上から構成している場合は、既に設定が入っている場合があります。)
手順2 Power Automate for desktop からの投稿
手順 1 で設定したフローに対して、Power Automate for desktop から [Web サービスを呼び出します] アクションを使ってリクエストを送信することでメッセージを投稿できます。
この時、投稿には各項目に以下の情報を指定します。
No | プロパティ | 設定値 |
---|---|---|
1 | URL: | 手順1 で取得した Webhook の URL ※注意点を後述します |
2 | メソッド: | POST |
2 | 受け入れる: | application/json |
2 | コンテンツ タイプ: | application/json |
3 | 要求本文: | 欄外に記載 |
4 | 要求本文をエンコードします: | False |
{
"type": "message",
"attachments": [
{
"contentType": "application/vnd.microsoft.card.adaptive",
"contentUrl": null,
"content": {
"$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
"type": "AdaptiveCard",
"version": "1.5",
"body": [
{
"type": "TextBlock",
"text": "Power Automate for desktop からの投稿"
}
]
}
}
]
}
要求本文についてもう少し解説すると、こちらは JSON 形式で Adaptive Cards が構成を指定しています。
指定要素の内、赤枠箇所で Adaptive Cards の構成を行います。
構成については、Adaptive Cards のリファレンスを参考に構成することも勿論できますが、Adaptive Cards Desinger を使用して、GUI で表示を構成して作成された [CARD PAYLOAD EDITOR] の JSON を赤枠箇所に張り付けることでも利用できます。
Adaptive Cards Desinger
利用する際には、[Select host app:] を Microsoft Teams に切り替えて利用します。
Adaptive Cards の Content 部を差し替えたら実行できるかを確認します。この時にメッセージに関するテキストを PAD の変数を利用して動的にメッセージを切り替えることもできます。以下では、現在の日付時刻がセットされた変数を指定します。
3. [Outlook からのメール メッセージの送信] アクションから、 チャネルのメールアドレス向けに投稿
Teams のチャネルが持っているメールアドレス宛の投稿です。
Teams を起動し、チームのチャネルを右クリックし、表示されるメニューから [メール アドレスを取得] を選択します。
表示されたウィンドウで [詳細設定] をクリックし、どのユーザーからこのメールアドレス宛に送信できるか選択します。
送信可能なユーザーを限定することは、セキュリティリスクを低減させることにもつながるので、特に理由がない限りは [このチームのメンバーのみ] が良いかなと思います。
チャネルのメール アドレスは、コピーしてメモ帳などのテキストエディタに張り付けておきます。
このあと使用するのは、<> の中のメール アドレス部分のみです。
次に、Power Automate for deskotp 側でメール送信に関するアクションを設定します。
[Outlook を起動します] アクションを追加した後、[Outlook からのメール メッセージの送信] アクションを追加しプロパティを設定します。設定値は下記の通りとなります。
No | プロパティ | 設定値 |
---|---|---|
1 | アカウント: | 自分のメールアドレス |
2 | 宛先: | チャネルのメールアドレス |
3 | 件名: | Power Automate Desktop からの送信 |
4 | 本文: | 送信テストです |
本方法を利用する場合は、チャネル宛のメール送信に関する制限もあわせて確認するのが良いと思います。
おわりに
今回 3 つの方法を紹介しましたが、利用しているライセンスの要件や組織の許可で利用できる機能が異なるので、状況に即して利用を検討されてみてください。