はじめに
Graph API のアクセス許可として、Teams のアプリの場合だけ使用できる "リソース固有の同意" というアクセス許可があります。リソース固有の同意について、簡単にまとめてみました。
リソース固有の同意とは?
"リソース固有の同意" は Teams アプリに対して、アプリが追加されたチームやチャットの情報のみ取得することを許可するアクセス許可です。
リソース固有の同意 (Resource-Specific Consent) は省略して RSC と記載されます。この記事でも以降は RSC と表記します。
ここでの "Teams アプリ" は Teams クライアント上からチームやチャットに追加できる様々なアプリのことを指しています。
(参考:Teams アプリのリソース固有の同意)
https://learn.microsoft.com/ja-jp/microsoftteams/platform/graph-api/rsc/resource-specific-consent
チャットボットの例
ユーザー委任権限とアプリケーション許可権限の問題点
例えば、チャットボットの Teams アプリの場合、ユーザーが入力したメッセージの情報を Graph API で取得し、適切な応答を返す必要があります。
Graph API にはユーザー委任権限とアプリケーション許可権限があります。
ユーザー委任権限は特定のユーザーがサインインすることでアプリに自身の代わりアクセス許可を付与する方法なので、チャットボットには利用できません。
アプリケーション許可権限の場合は、チャットボットから利用することができます。しかし、アプリケーション許可権限ではアクセス許可を付与すると、アプリがテナント全体のメッセージを閲覧することが可能になってしまいます。
※ 参考
RSC の利用
そこで Teams アプリの場合には、RSC を使用します。RSC では Entra ID アプリケーションではなく、Teams アプリに対してアクセス許可を付与します。
RSC が付与された Teams アプリは、アプリが追加されたチームやグループチャット内の情報のみ、参照することが可能です。
RSC を使用したチャットボットアプリのサンプル
RSC を使用したチャットボットアプリのサンプルが Github で公開されています。
以下の手順でサンプルアプリを Teams クライアントに追加して、簡単に試すことができます。
■ 1. Github からサンプルアプリの zip ファイルをダウンロードする
- Github のリンクをブラウザで開き、[demo-manifest] フォルダをクリックします
-
[Bot-RSC.zip] をクリックします
- 右側のダウンロードボタンをクリックし、"Bot-RSC.zip" をダウンロードします
■ 2. Teams 管理センターからサンプルアプリをアップロードする
※ この手順は Teams 管理者のユーザーで行ってください。
- Teams 管理センターから [Teams のアプリ] - [アプリの管理] - [アクション] - [新しいアプリのアップロード] をクリックします
-
[アップロード] をクリックし、ダウンロードした "Bot-RSC.zip" をアップロードします
- 検索ボックスに "RSC Sample" と入力し、サンプルアプリが追加されていることを確認します
■ 3. Teams クライアントからサンプルアプリを利用する
- Teams クライアントで "[アプリ]" を開き、検索ボックスに "RSC Sample" と入力し [追加] をクリックします
-
[アクセス許可] タブにアプリを追加する際に同意するアクセス許可が表示されます (これが RSC です)
[追加] をクリックします
- サンプルアプリを追加する任意のチャネルを選択し、[移動] をクリックします
- 追加したサンプルアプリによってチャネルにメッセージが投稿されます
そのまま [投稿] をクリックして、チャットボットとメンションします
- チャットボットがチャネルのメッセージを取得して、入力内容に応じて応答を返していることが確認できます
Teams アプリへの RSC の設定方法
Teams アプリには以下の方法で RSC を設定します。
manifest.json
"Bot-RSC.zip" を展開すると、フォルダ内に "manifest.json" というファイルが存在します。"manifest.json" はアプリの設定情報を記載するファイルです。
"manifest.json" の [authorization] - [permissions] - [resourceSpecific] でアプリに設定する RSC のアクセス許可を設定します。
Bot-RSC サンプルアプリでは、RSC によってアプリがインストールされたチャネルやグループチャットのメッセージを読み取ることができるアクセス許可を設定していることが分かります。
Teams Developer Portal
Teams Developer Portal でもアプリの設定を変更することができます。
- Developer Portal ブラウザから任意のユーザーで Developer Portal を開きます
[アプリ] - [アプリのインポート] をクリックし、"Bot-RSC.zip" をアップロードします
-
[構成する] - [権限] をクリックし、[チームのアクセス許可] - [Application] を展開します
- "ChannelMessage.Read.Group" アクセス許可が設定されていることが分かります
(参考:Teams の開発者ポータル)
https://learn.microsoft.com/ja-jp/microsoftteams/platform/concepts/build-and-test/teams-developer-portal