-
Notifications
You must be signed in to change notification settings - Fork 120
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Updated always-reply-to-request sample
- Loading branch information
Showing
11 changed files
with
2 additions
and
237 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,76 +1,4 @@ | ||
# Pattern: Always respond to a request | ||
|
||
## Summary | ||
|
||
A pattern for making sure that the Flow always provides a responds to a request. | ||
|
||
data:image/s3,"s3://crabby-images/e6e45/e6e45a7448077c2f7ad8ff67d4ab9cc11ddfcd4a" alt="picture of the flow" | ||
|
||
## Applies to | ||
|
||
* [Microsoft Power Automate](https://docs.microsoft.com/en-us/power-automate/getting-started) | ||
* [Azure Logic Apps](https://docs.microsoft.com/en-us/azure/logic-apps/logic-apps-overview) | ||
|
||
## Compatibility | ||
|
||
data:image/s3,"s3://crabby-images/01759/017590008d112be30e52c29d412b5274a93a912b" alt="Premium License" | ||
data:image/s3,"s3://crabby-images/068a2/068a260eee7ab7497937ec10fccda4de26bb01d7" alt="On-Premises Connectors" | ||
data:image/s3,"s3://crabby-images/d3ff8/d3ff845a882c4cab009cc0f3e41b19ec426fe1a9" alt="Custom Connectors" | ||
|
||
## Authors | ||
|
||
Solution|Author(s) | ||
--------|--------- | ||
always-reply-to-request | [Remy Blok](https://github.com/remyblok), Prodware | ||
|
||
## Version history | ||
|
||
Version|Date|Comments | ||
-------|----|-------- | ||
1.0|May 02, 2021|Initial release | ||
|
||
## Features | ||
|
||
Power Automate has the ability to be called by 3th parties using HTTP requests or via the API. In these cases the caller will wait for the Flow to respond. If the Flow does not respond you get an HTTP 500 error from the Flow runtime with the message `The server did not receive a response from an upstream server.` | ||
|
||
This pattern makes sure that you always respond to the caller. Also in case you Flow fails you can then send back relevant information on why the flow has failed. In this sample it returns the error that occurred in the Scope. But responses to the end user with a descriptive message is always preferred. | ||
|
||
Requests and responses are used in multiple areas: | ||
* Per this sample, using `HTTP Request`-trigger and `HTTP Response`-action to create a Flow that is callable via HTTP by any party that can handle HTTP | ||
* When using the Flow as a [child Flow](https://docs.microsoft.com/en-us/power-automate/create-child-flows). The trigger will be `Manual trigger`, the response will be a `Respond to PowerApp` or a `HTTP Response` action | ||
* When starting a [Flow from a Canvas Power App](https://docs.microsoft.com/en-us/powerapps/maker/canvas-apps/using-logic-flows). In this case the trigger is `PowerApps`, the response will be a `Respond to PowerApp` or a `HTTP Response` action | ||
|
||
In this sample we use a Scope to contain all the logic of the Flow. By setting the 'Configure run after' on the error `Response`-action to run only on error we can differentiate the error between sending a OK or an Error message. By default any action's 'Configure run after' is set to 'is successful'. | ||
data:image/s3,"s3://crabby-images/f5fe6/f5fe65929a6637a946848a641208efcaea17f3b9" alt="Go to Run After" | ||
data:image/s3,"s3://crabby-images/76235/762357113366a5abb37a8ca235b049ea94ad7053" alt="Go to Run After" | ||
|
||
Note: you can setup the responses to use the [Asynchronous pattern](https://docs.microsoft.com/en-us/azure/connectors/connectors-native-http#asynchronous-request-response-behavior). This is useful for long running flows. In this case the error will also be correctly returned as result for your long running flow. This can also be used when the Flow is used as a child flow using the `Respond to PowerApps`-action. It does *not* work when the Flow is called from a Power App. | ||
|
||
Note 2: The reason that the OK response is outside the Scope in stead of having one of more responses inside the Scope, is to make sure the schema of the result is the same. Since there is only one place where the result (and it's schema) is defined, changes to the result (schema) are easily realized. Since you are basically setting up an API having a single consistent schema for all responses is recommended. | ||
|
||
## Minimal Path to Awesome | ||
|
||
* [Download](solution/always-reply-to-request.zip) the `.zip` from the `solution` folder | ||
* [Import](https://flow.microsoft.com/en-us/blog/import-export-bap-packages/) the `.zip` file using **My Flows** > **Import** > **Upload** within Microsoft Flow. | ||
|
||
## Disclaimer | ||
|
||
**THIS CODE IS PROVIDED *AS IS* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.** | ||
|
||
## Help | ||
|
||
We do not support samples, but we this community is always willing to help, and we want to improve these samples. We use GitHub to track issues, which makes it easy for community members to volunteer their time and help resolve issues. | ||
|
||
If you encounter any issues while using this sample, [create a new issue](https://github.com/pnp/powerautomate-samples/issues/new?assignees=&labels=Needs%3A+Triage+%3Amag%3A%2Ctype%3Abug-suspected&template=bug-report.yml&sample=always-reply-to-request&authors=@remyblok&title=always-reply-to-request%20-%20). | ||
|
||
For questions regarding this sample, [create a new question](https://github.com/pnp/powerautomate-samples/issues/new?assignees=&labels=Needs%3A+Triage+%3Amag%3A%2Ctype%3Abug-suspected&template=question.yml&sample=always-reply-to-request&authors=@remyblok&title=always-reply-to-request%20-%20). | ||
|
||
Finally, if you have an idea for improvement, [make a suggestion](https://github.com/pnp/powerautomate-samples/issues/new?assignees=&labels=Needs%3A+Triage+%3Amag%3A%2Ctype%3Abug-suspected&template=suggestion.yml&sample=always-reply-to-request&authors=@remyblok&title=always-reply-to-request%20-%20). | ||
|
||
## For more information | ||
|
||
- [Create your first flow](https://docs.microsoft.com/en-us/power-automate/getting-started#create-your-first-flow) | ||
- [Microsoft Power Automate documentation](https://docs.microsoft.com/en-us/power-automate/) | ||
|
||
|
||
<img src="https://telemetry.sharepointpnp.com/powerautomate-samples/samples/exception-handing-in-do-until-loop" /> | ||
> [!Important] | ||
> This sample has now been migrated to the a [different repository](https://github.com/pnp/powerplatform-samples/tree/main/samples/always-reply-to-request). |
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file was deleted.
Oops, something went wrong.
Binary file removed
BIN
-2.14 KB
samples/always-reply-to-request/solution/always-respond-to-request.zip
Binary file not shown.
1 change: 0 additions & 1 deletion
1
...request/sourcecode/Microsoft.Flow/flows/64422a3f-e728-4a13-adea-13637bba1429/apisMap.json
This file was deleted.
Oops, something went wrong.
1 change: 0 additions & 1 deletion
1
.../sourcecode/Microsoft.Flow/flows/64422a3f-e728-4a13-adea-13637bba1429/connectionsMap.json
This file was deleted.
Oops, something went wrong.
91 changes: 0 additions & 91 deletions
91
...uest/sourcecode/Microsoft.Flow/flows/64422a3f-e728-4a13-adea-13637bba1429/definition.json
This file was deleted.
Oops, something went wrong.
1 change: 0 additions & 1 deletion
1
samples/always-reply-to-request/sourcecode/Microsoft.Flow/flows/manifest.json
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.