Power AppsでGraph APIの情報を使用したいことがあり、カスタムコネクタを作成したので、作り方をメモ。
Power BI APIへのカスタムコネクタのつくり方はこちら
data:image/s3,"s3://crabby-images/a86b9/a86b935a9ee1d0103fd8a3909d1ccaba770f5c56" alt=""
data:image/s3,"s3://crabby-images/a86b9/a86b935a9ee1d0103fd8a3909d1ccaba770f5c56" alt=""
Power AppsやPower AutomateからPower BI APIを呼び出すカスタムコネクタを作成する手順を解説
Power AppsやPower Automateで、PowerBIからワークスペースとかグループ、タイルの情報を引っ張ってこようと思うと、標準のコネクタではどうしても機能が足りない。そこで、今回PowerBIとのカスタムコネクタを作成した...
Azureへアプリを登録する
まずはAzureへアプリの登録を行う。
続いて、アプリの登録を選択し、
data:image/s3,"s3://crabby-images/cd01f/cd01f2cb97bdf7eca374219dee68f1c50c82203a" alt=""
data:image/s3,"s3://crabby-images/cd01f/cd01f2cb97bdf7eca374219dee68f1c50c82203a" alt=""
「新規登録」を選んで、
data:image/s3,"s3://crabby-images/aa55d/aa55de549b40f3cba4786938920540221a07f004" alt=""
data:image/s3,"s3://crabby-images/aa55d/aa55de549b40f3cba4786938920540221a07f004" alt=""
アプリ名をいい感じに付けて、登録。
※リダイレクトURLは後で設定。
data:image/s3,"s3://crabby-images/02d9e/02d9ed9fb386cf29dda3d3e4a4d3ab54973f71e0" alt=""
※リダイレクトURLは後で設定。
data:image/s3,"s3://crabby-images/02d9e/02d9ed9fb386cf29dda3d3e4a4d3ab54973f71e0" alt=""
アプリが登録されるので、クライアントID(アプリID)をメモし、「証明書とシークレット」へ移動。
data:image/s3,"s3://crabby-images/8347d/8347d09bfaf4bd6f78d31934166d2a1724a27c62" alt=""
data:image/s3,"s3://crabby-images/8347d/8347d09bfaf4bd6f78d31934166d2a1724a27c62" alt=""
新しいクライアントシークレットを押して、
data:image/s3,"s3://crabby-images/e99d0/e99d020cd6e9bb01d7645a9ab797ad64165f90c3" alt=""
data:image/s3,"s3://crabby-images/e99d0/e99d020cd6e9bb01d7645a9ab797ad64165f90c3" alt=""
適切な有効期限を付けて、追加。
data:image/s3,"s3://crabby-images/bf597/bf5978624a0e966a616572a5165afbd589f96ac1" alt=""
data:image/s3,"s3://crabby-images/bf597/bf5978624a0e966a616572a5165afbd589f96ac1" alt=""
クライアントシークレットキーが払い出されるので、これもメモ。
data:image/s3,"s3://crabby-images/d0fb1/d0fb1c3c3a1ff00d70a6e038ee27047e8797838d" alt=""
data:image/s3,"s3://crabby-images/d0fb1/d0fb1c3c3a1ff00d70a6e038ee27047e8797838d" alt=""
そしたら一旦Power Appsへ移動。
Power Apps カスタムコネクタの作成
Power Appsへ移動したら、[データ]->[カスタムコネクタ]を選択し、[カスタムコネクタの新規作成]から[一から作成]を選ぶ。
data:image/s3,"s3://crabby-images/e8a6b/e8a6b61701cf922be4350930cc45177233c4088b" alt=""
data:image/s3,"s3://crabby-images/e8a6b/e8a6b61701cf922be4350930cc45177233c4088b" alt=""
名前は適当に。
data:image/s3,"s3://crabby-images/4d0be/4d0bee4cc4857b33da637136ddc15788fa04ee00" alt=""
data:image/s3,"s3://crabby-images/4d0be/4d0bee4cc4857b33da637136ddc15788fa04ee00" alt=""
そしたらこんな画面へ遷移するので、
data:image/s3,"s3://crabby-images/5942e/5942ec6d6bc60005ecaff14c844197d4e60dc38f" alt=""
- スキーマ:HTTPS
- ホスト:graph.microsoft.com
を入力して、「セキュリティ」を押下。
認証タイプは「OAuth 2.0」を選択。
data:image/s3,"s3://crabby-images/6b506/6b50667b6a0a76bba3dc85be03a02f0e6d450c0d" alt=""
data:image/s3,"s3://crabby-images/6b506/6b50667b6a0a76bba3dc85be03a02f0e6d450c0d" alt=""
残りの情報はこんな感じ。
data:image/s3,"s3://crabby-images/b189a/b189a0a7c024ce7969674cf422d23fd0105d4daf" alt=""
- IDプロバイダー:Azure Active Directory
- Client id:AzureADでメモしたクライアントID
- Client secret:AzureADでメモしたシークレットキー
- LoginURL、TenantID:そのまま
- Resource URL:https://graph.microsoft.com
- スコープ:https://graph.microsoft.com/.default
そうしたら、「コネクタの作成」を押す。
するとリダイレクトURLが出るのでメモして、Azureへ戻る。
data:image/s3,"s3://crabby-images/54c7f/54c7f02eec39570089b433f9291600b9ecf65d9d" alt=""
data:image/s3,"s3://crabby-images/54c7f/54c7f02eec39570089b433f9291600b9ecf65d9d" alt=""
Azure リダイレクトURLの設定
Azureへ移動したら、左のメニューの[認証]を選択し、[プラットフォームを追加]を押す。
data:image/s3,"s3://crabby-images/6847e/6847e6e55f1af7b270fe111da5420e43d31f29c0" alt=""
data:image/s3,"s3://crabby-images/6847e/6847e6e55f1af7b270fe111da5420e43d31f29c0" alt=""
WebアプリケーションのWebを選んで、
data:image/s3,"s3://crabby-images/19d28/19d2883fd5056b63d64055a54c621dc77182efc7" alt=""
data:image/s3,"s3://crabby-images/19d28/19d2883fd5056b63d64055a54c621dc77182efc7" alt=""
先ほどのリダイレクトURLを入力し、[構成]を押す。
data:image/s3,"s3://crabby-images/46d4f/46d4f7c9ed31bdbe56982027c45b9447ac84f2e3" alt=""
data:image/s3,"s3://crabby-images/46d4f/46d4f7c9ed31bdbe56982027c45b9447ac84f2e3" alt=""
追記:AzureにAPIのアクセス許可を追加する
ここからは実際にカスタムコネクタを使用してGraph APIを呼び出す際に必要な設定について。
作成したカスタムコネクタからGraphAPIを呼び出す際、APIごとに以下のようにアクセス許可を設定する必要がある。
data:image/s3,"s3://crabby-images/916d0/916d0ec68e1ea84d3a9255f894bcc78767406508" alt=""
data:image/s3,"s3://crabby-images/916d0/916d0ec68e1ea84d3a9255f894bcc78767406508" alt=""
例えばこちらの記事で紹介する「連絡可能」みたいなユーザーのステータスを表示したい場合、
data:image/s3,"s3://crabby-images/f14e2/f14e20b83a02e306e081863c52a4754caec91274" alt=""
data:image/s3,"s3://crabby-images/f14e2/f14e20b83a02e306e081863c52a4754caec91274" alt=""
Power Apps Graph APIでTeamsに表示されるユーザーのステータス(連絡可能、不在 など)を取得する
Power Appsでユーザーを表示するときに、Teamsとかに表示される「連絡可能」みたいなステータスを表示したいという要望があったので、GraphAPI経由でステータスを取得する方法をメモ。Teamsのステータス情報今回表示したいのはこ...
[アクセス許可の追加]から、
data:image/s3,"s3://crabby-images/63061/63061d6c78e265b1a803441d59f62284715e850a" alt=""
data:image/s3,"s3://crabby-images/63061/63061d6c78e265b1a803441d59f62284715e850a" alt=""
[Microsoft Graph]を選択して、
data:image/s3,"s3://crabby-images/6736c/6736cdaea8bf1f660659f39f47ecbb0a92ebf5e9" alt=""
data:image/s3,"s3://crabby-images/6736c/6736cdaea8bf1f660659f39f47ecbb0a92ebf5e9" alt=""
今回は[委任されたアクセス許可]を選び、
data:image/s3,"s3://crabby-images/be9ea/be9ea5dac5b695198683e115da2de16b0e08e2e4" alt=""
data:image/s3,"s3://crabby-images/be9ea/be9ea5dac5b695198683e115da2de16b0e08e2e4" alt=""
Presenceの読取許可を与えてあげる。
data:image/s3,"s3://crabby-images/b52a3/b52a316473cb6f706da801e917c0b5fa4277978c" alt=""
data:image/s3,"s3://crabby-images/b52a3/b52a316473cb6f706da801e917c0b5fa4277978c" alt=""
これでこのカスタムコネクタを使用して、Presenceを取得することができるようになり、「連絡可能」みたいなステータスを表示することができる。
※使用するGraph APIによって必要な許可が異なるので、別のAPIを呼び出したい場合は上記以外の設定が必要。
GraphAPIへの接続はひとまず完了したので、Power Appsへ戻って接続テストをする。
Power Apps 接続テスト
Power Appsへ戻ったら、[4.テスト]->[新しい接続]を選択。
data:image/s3,"s3://crabby-images/0224e/0224e2726706e059ef723259a5509af3cffd849d" alt=""
data:image/s3,"s3://crabby-images/0224e/0224e2726706e059ef723259a5509af3cffd849d" alt=""
作成を押して、
data:image/s3,"s3://crabby-images/6f2fc/6f2fcf06294e179dd95a20d7c9ff67f3651bae9a" alt=""
data:image/s3,"s3://crabby-images/6f2fc/6f2fcf06294e179dd95a20d7c9ff67f3651bae9a" alt=""
権限のあるアカウントを選択。
data:image/s3,"s3://crabby-images/488bb/488bb08de6b9c4bad1b1cb9eb05a722d49e77a48" alt=""
data:image/s3,"s3://crabby-images/488bb/488bb08de6b9c4bad1b1cb9eb05a722d49e77a48" alt=""
からの承認。
data:image/s3,"s3://crabby-images/b4f9b/b4f9b18fba7924bf077c1664481f48b34389cb33" alt=""
data:image/s3,"s3://crabby-images/b4f9b/b4f9b18fba7924bf077c1664481f48b34389cb33" alt=""
できた!
data:image/s3,"s3://crabby-images/3f8e1/3f8e194f20e03a5b01e63c9a6e530cf2849008e5" alt=""
data:image/s3,"s3://crabby-images/3f8e1/3f8e194f20e03a5b01e63c9a6e530cf2849008e5" alt=""
これでGraphAPIへのカスタムコネクタの作成は完了。
コメント
いつも良記事ありがとうございます!非常に参考にさせていただいております!
自分が迷ってしまったので、Azure に API のアクセス許可で Presence.Read.All の設定手順も追加するといいと思いました。
ちなみに Azure に API のアクセス許可を設定したあとにカスタムコネクタの接続を作成しないと、API のアクセス許可が反映されないようでした。
いつも勉強させていただいてます!ねこポータルの続編期待しています!
naono様
コメントありがとうございます!
ご指摘いただいた通りAPIアクセス許可についての設定を追記しました。
ねこポータルも時間を見つけて続編を書きたいと思いますので、今後ともブログ「仕事のあれこれ」をどうぞよろしくお願い致します。
意見を取り入れていただきありがとうございます!分かりやすくなり嬉しいです!
こちらこそよろしくお願い致します。キャプチャが豊富で分かりやすく、助かっています。