In this blog, we will showcase how to setup Azure Logic App and how to integrate it with PowerApps using Power Automate HTTP Post Request.
Scenario
We have an Excel file that contains students’ data. This Excel file is located on a SharePoint site. We want to enable the user to search for the student id in PowerApps and get the details of the student.
1. Setting up Azure Logic App
Create an Azure account if you don’t have one already.
Go to the Azure portal.
data:image/s3,"s3://crabby-images/42546/42546d472529cd47b6da6dd4d7ec494c8841a4d6" alt="Azure Portal"
Click on the “Create a resource” button.
data:image/s3,"s3://crabby-images/31a1e/31a1ee486903057a883a1c7bc9cb684aa191746b" alt="Create Azure Resource"
Search and select “Logic Apps” by Microsoft.
data:image/s3,"s3://crabby-images/26dd5/26dd5646d37c3118e1152b2f182f088a267d6b19" alt="Logic App in Azure"
Click on the “Create” button.
data:image/s3,"s3://crabby-images/dff6d/dff6da86adb0d2aff924ba54b28d13315a72512c" alt="Creating Azure Logic App"
Select the “Subscription”, and “Resource group”, write the “Name”, and click on the “Review + Create” button.
data:image/s3,"s3://crabby-images/a16e2/a16e2257a0851c10e965ef8f3c8aad3a7a1c24dd" alt="Configuration of Azure Logic Apps"
Click on the “Create” button.
data:image/s3,"s3://crabby-images/30f2f/30f2f4844fe2b86e64f75e1fb5856d126d5fae6f" alt="Create Azure Logic App"
The Logic App resource is successfully created.
data:image/s3,"s3://crabby-images/20fd6/20fd6985e5e9a7259815905baf4ae116df472c4d" alt="Logic App is created"
2. Creating an Integration Account
Go to the Azure portal and click on the “Create resource” button.
data:image/s3,"s3://crabby-images/27d3c/27d3c8a6c798e323ff1b3ed72d94eaf87c46309e" alt="Creating Azure Resource"
Search and select “Integration Account” by Microsoft.
data:image/s3,"s3://crabby-images/a0951/a0951789a692e6c8c1375a7565471c52014dbdda" alt="Searching Microsoft Integration Account"
Click on the “Create” button.
data:image/s3,"s3://crabby-images/f0280/f0280f3af559aa5d022e981f5ff94086d4715b8c" alt="Creating Azure Integration Account"
Select the “Resource group”, write the “Name”, and click on the “Review + Create” button.
data:image/s3,"s3://crabby-images/f1cd5/f1cd58bcef31531d8847d5d45ddeb17f60b6bc6e" alt="Creating Azure Integration account"
Click on the “Create” button.
data:image/s3,"s3://crabby-images/8127d/8127d4e5519d009b50dfb36ba59aa4eb51bab715" alt="Create button of Microsoft Integration Account"
Open the “Logic App” resource that you have created in the first step.
Open the “Workflow Settings”, select “Integration Account”, and click on the “Save” button.
data:image/s3,"s3://crabby-images/8780a/8780ab363a36d1d98afe23a87f08c9a1d993cc60" alt="Configuring Workflow setting"
3. Design the Logic App
Open the “Logic App” resource.
Open the “Logic app designer” and select the “HTTP Request-Response” template.
data:image/s3,"s3://crabby-images/c6acb/c6acb3e0d7b535526d35654dc6e4c7694481fcb8" alt="HTTP Template Azure Logic App"
You will see the following screen.
data:image/s3,"s3://crabby-images/e7a03/e7a03bee85684223d85f8e04f3c3e8751ec6fe4e" alt="Azure Logic App"
Copy the “URL” of the trigger action to use in the next steps.
data:image/s3,"s3://crabby-images/f779f/f779fca0a9d28b722e8b5cf948f4914ab222019f" alt="URL Of HTTP Trigger"
Copy and paste the following schema in the trigger action.
Schema
{
“properties”: {
“ID”: {
“type”: “integer”
}
},
“type”: “object”
}
data:image/s3,"s3://crabby-images/f5ebf/f5ebf07804f681825e2eefa570bb76af53bba448" alt="Post Schema in HTTP Trigger"
Add a “Get a row” action.
Select the “Site”, select the “Library”, select the “File”, select the “Table”, and select the “Key column”.
In the “Key Value”, add the “ID” coming from the trigger action.
data:image/s3,"s3://crabby-images/f88be/f88bec45cb07a17f4d441e3c74e76140ffb1348c" alt="Get a row action in Logic App"
Open the “Response” action.
In the “Body” field, pass the “Body” of the “Get a row” action.
data:image/s3,"s3://crabby-images/fc551/fc5519f20e9cd21d4558d3273e3aea43bccddf0f" alt="Logic App Response action"
The Logic app is ready, save it.
4. Create the Power Automate flow
Now we create a Power Automate flow that will bridge the Azure Logic App and the PowerApps.
Create an “Instant” flow.
data:image/s3,"s3://crabby-images/6e3d0/6e3d0e3aa2f5b0f770d4bbd3accc319219d2d4b0" alt="Power Automate Instant flow"
Add an “Initialize variable” action.
In the “Name” field write “varID”, select “Integer” in the “Type” field, and for the “Value” field click on “Ask in PowerApps”.
data:image/s3,"s3://crabby-images/80102/80102e2a9ca5fdd30177d1e1052b02a19ccd6eef" alt="Power Automate Intialize variable"
Add an “HTTP” action and do the following configurations.
Method: Post
URL: URL of Logic App trigger
Body:
{
“ID”: varID variable
}
data:image/s3,"s3://crabby-images/fcf57/fcf57be0ea1ad2f1fa2cb0f791d9012f2e95f15f" alt="Power Automate HTTP Trigger action"
Add a “Respond to PowerApps” action.
Write “Result” as the parameter name and “body(‘HTTP’)” as an expression.
data:image/s3,"s3://crabby-images/afc32/afc3264f3f6fc7af46b21bfbee5e9c0052c408a3" alt="PowerApps respond action"
The flow is ready, save it.
5. Integrate with PowerApps
We have a Canvas application with a “Button” and “Labels” to show the results.
data:image/s3,"s3://crabby-images/bb096/bb096d7969ab1880edf5d9a728d2141524262c49" alt="PowerApps Canvas application"
Connect the Power Automate flow that we created in the previous step.
You can click here to see how to connect Power Automate flow with PowerApps.
data:image/s3,"s3://crabby-images/a5c78/a5c788cb10e2054e11701d8ba6ab472fe1aab3b0" alt="Connecting flow with PowerApps"
Select the “OnSelect” property of the “Search” button, copy the code given below, and paste it into the top bar.
Code:
Set(
varResult,
GetDataFromLogicApp.Run(Value(SearchInput.Text)).result
)
data:image/s3,"s3://crabby-images/45118/45118d27fff6339ea28bc20748de78aa38f4727f" alt="Power Automate code in PowerApps"
The flow returns the result in a JSON string format so we can present the results as follows.
Select the “Label” and use the following code to show the “First Name” of the student.
Code:
Text(ParseJSON(varResult).FirstName)
data:image/s3,"s3://crabby-images/8cdaa/8cdaa94a6e3de184ec65a1659340533f65c83353" alt="PowerApps show text code"
Replace the column name and do the same for the other Labels.
data:image/s3,"s3://crabby-images/301e7/301e74600f1806981c4118e2a7f4cbb796b1bb05" alt="PowerApps show label code"
6. Test the app
Play the app, and search for a student id.
data:image/s3,"s3://crabby-images/15a63/15a63f338a3a601c656e355d9c0180356b91c84a" alt="Play PowerApps"
Conclusion
We can use Azure Logic Apps with PowerApps using Power Automate flow. To do this, create a Logic App in Azure, copy the URL of the HTTP trigger, send an HTTP request from Power Automate flow, and return the results to PowerApps.