Power AppsからPower Automateを呼び出した際に、「502 BadGateway, The server did not receive a response from an upstream server. Request tracking id ~~~」というエラーが出たと言われたで、対処法をメモ。
エラー
Power AppsからPower Automateを呼び出そうとしたとき、こんな502エラーが出ることがある。
data:image/s3,"s3://crabby-images/9e9d3/9e9d31c0bb523bfc74a14a73c688be6e203abefa" alt=""
data:image/s3,"s3://crabby-images/9e9d3/9e9d31c0bb523bfc74a14a73c688be6e203abefa" alt=""
Power Automate単体でのテストは成功しているときは、まず「Power Appへの応答」アクションの使い方をチェックする必要がある。
原因の一つ:Power Appsへの応答アクション
このエラーの原因の一つは「Power Appsへの応答」アクションが呼び出されていないこと。
例えばこんな単純なフローがあったとき、
data:image/s3,"s3://crabby-images/4105d/4105df588fa1aa6402448fdcd8eafef3b85335dc" alt=""
data:image/s3,"s3://crabby-images/4105d/4105df588fa1aa6402448fdcd8eafef3b85335dc" alt=""
「エラー時だけPower Appsにメッセージを返そう」として「Power Appsの応答アクション」の実行条件をフローが失敗したときのみにしていると、このエラーが起きる。
data:image/s3,"s3://crabby-images/36b94/36b94c449c5db52eba8420315c75347a5cd05aee" alt=""
data:image/s3,"s3://crabby-images/36b94/36b94c449c5db52eba8420315c75347a5cd05aee" alt=""
解消方法:成功時もPower Appsへの応答アクションを呼び出すようにする
解消方法は、(値を返す必要がなくても)成功時にも「Power Appsへの応答」アクションを呼び出すようにしてあげること。
data:image/s3,"s3://crabby-images/faa31/faa31fbbec7a7675fbab494b07f6022d52a71ff9" alt=""
data:image/s3,"s3://crabby-images/faa31/faa31fbbec7a7675fbab494b07f6022d52a71ff9" alt=""
するとPower AppsからPower Automateへの呼び出しは無事成功する。
data:image/s3,"s3://crabby-images/466f6/466f6e34964f7806f478f2ab0b9416b80ad5d741" alt=""
data:image/s3,"s3://crabby-images/466f6/466f6e34964f7806f478f2ab0b9416b80ad5d741" alt=""
おまけ:応答のスキーマは合わせる必要がある
Power Appへの応答の出力は、フローを通して一致させる必要がある。
data:image/s3,"s3://crabby-images/f79fb/f79fbf2565447d3874b2f551bf8e452ab09ed414" alt=""
data:image/s3,"s3://crabby-images/f79fb/f79fbf2565447d3874b2f551bf8e452ab09ed414" alt=""
そのため、エラー時と成功時でPower Appsへの応答を返したい場合は、こんな感じでJSONに詰めて応答し、Power Apps側でParseJSONを使用して応答を利用することになるかと。
data:image/s3,"s3://crabby-images/89658/89658dbaa698edf89f05400bb49afdd9489ddb8f" alt=""
data:image/s3,"s3://crabby-images/89658/89658dbaa698edf89f05400bb49afdd9489ddb8f" alt=""