How To Use Power Automate + Azure OpenAI GPT Models

How To Use Power Automate + Azure OpenAI GPT Models

You can use Power Automate to call Azure OpenAI and return a response from the latest GPT models. Azure OpenAI is a safe way to use GPT that doesn’t use your company data for model training. And its low-cost consumption-pricing model is ideal for high-volume use-cases. AI Prompts in Power Platform are simpler to setup and deploy to makers but you should consider Azure OpenAI when more power is needed.

Table of Contents
• Introduction: The Helpdesk Ticket Priority AutomationCreate A New Azure OpenAI ResourceLaunch Azure OpenAI StudioDeploy A GPT Model In Azure OpenAI StudioAdd A System Message To The GPT Deployment In Chat PlaygroundSend A Chat Message To The GPT Model In Chat PlaygroundCreate A Power Automate Flow To Call Azure OpenAIGet A Chat Completion From The GPT Model In Azure OpenAIInclude The System & User Messages In The HTTP Action BodyReturn The Message Content From The Azure OpenAI ResponseRun The Power Automate Flow To Call Azure OpenAI




Introduction: The Helpdesk Ticket Priority Automation

An I/T department uses Power Automate and a GPT model provided by Azure OpenAI to read all incoming helpdesk tickets and assign a priority level.



After the GPT model reads the ticket it responds with High-Priority, Medium-Priority or Low-Priority




Create A New Azure OpenAI Resource

To deploy a GPT model in Azure we must first create an Azure OpenAI resource where it will be hosted. Open the Azure Portal and go to the Azure OpenAI service.



Create a new Azure Open AI resource.



Fill-in the project details for subscription, resource group, region, name and pricing tier. Then press next.



Continue pressing the next button until the review + submit step. Then press Create.




Launch Azure OpenAI Studio

To work with the resource we created we must open it in Azure OpenAI studio. Select the resource to view its details.



On the the Overview page select Go to Azure OpenAI Studio.




Deploy A GPT Model In Azure OpenAI Studio

A GPT model must be deployed to make it available for use in Power Automate. Go to the deployments tab and deploy a base model.



Choose your preferred GPT model and press Confirm. This tutorial uses GPT-4o-mini but you can select any model from the list. Each model has different abilities and costs.



Use the default deployment name, model version and set the deployment type to global standard. Increase the Tokens per Minute Rate Limit to the maximum allowed value. Then deploy the model.



Details of the model deployment will appear on the next screen.




Add A System Message To The GPT Deployment In Chat Playground

The chat playground allows developers to configure and test their GPT deployment before using it in Power Automate. Go to the chat tab and select the deployment that was just setup.



The system message gives the model instructions and context on how to respond to any incoming chat message. We will tell the GPT model the how to categorize incoming helpdesk tickets by priority level. Then we will ask it to respond with one of the following options: high-priority, medium-priority or low-priority



Copy and paste this text into the system message field and press the Apply Changes button.

You are an I/T Helpdesk triage bot. Your job is to review all incoming support tickets and categorize them based on their severity: High-priority, Medium-priority or Low-priority.

High-priority tickets, like critical system outages, are flagged for immediate attention

Medium-priority tickets, like customer complaints or technical issues, are scheduled for addressing based on availability

Low-priority tickets, like general inquiries or feature requests, are queued for resolution after higher-priority issues are handled

After you review a support ticket to determine the severity respond with the category that has the best match. Only include one of these phrases in the response: “High-priority”, “Medium-priority”, “Low-priority.




Send A Chat Message To The GPT Model In Chat Playground

When a chat message is sent to the GPT model, it first looks at the instructions in the system message and uses them to create a response. We will input text formatted as a support ticket email into chat window and see what priority level is assigned by GPT.



Copy and paste this text into the chat window and press the Send button.

Subject: Unable to Download Invoice
From: [email protected]
To: [email protected]
Date: September 30, 2024

Hi,
I’m unable to download my invoice from the billing section of my account. When I click the “Download” button, nothing happens. Could you please assist?

Account Email: [email protected]
Browser: Safari (version 16.5)
Device: MacBook Air

Thanks,
Jane



The response returned in the chat window is “medium-priority.”




Create A Power Automate Flow To Call Azure OpenAI

We want to build a Power Automate flow that gets an helpdesk ticket email message, sends it to Azure OpenAI and returns a priority level for the ticket. Open Power Automate and create a new flow with a manual trigger.



Add a Data Operations – Compose action to the flow with the same system message that was used in Chat Playground.



Then add a 2nd Compose action below it with the helpdesk ticket formatted as an email. We are simplifying the helpdesk ticket use-case to make it easier to follow. In the real-world we might have used an Office 365 Outlook – When A New Email Arrives trigger and collected values from it in the user message.




Get A Chat Completion From The GPT Model In Azure OpenAI

We must use an HTTP action to call the chat completions endpoint in Azure OpenAI and return the message sent in response. Create an HTTP action in the flow and use the POST method.



The URI for the Azure OpenAI chat completions endpoint looks like this. Your specific endpoint will have a different resource name (matthewdevaneyazureopenai), deployment name (gpt-4o-mini) and API version (2024-02-15-preview)

https://matthewdevaneyazureopenai.openai.azure.com/openai/deployments/gpt-4o-mini/chat/completions?api-version=2024-02-15-preview



To get your own URI for the flow open Chat Playground and select View Code.



Use the complete web address found in the ENDPOINT variable.



Also include the following header values in the HTTP request. The api-key is also found in the footer of the sample code menu.

HeaderValue
Content-Typeapplication/json
api-key********************************




Include The System & User Messages In The HTTP Action Body

The body of the HTTP action includes the system message, the user message and a few other configuration values.



Use this code in the body of the HTTP action. System and user message values come from the Compose actions we setup earlier in the flow.

{
  "messages": [
    {
      "role": "system",
      "content": [
        {
          "type": "text",
          "text": @{outputs('Compose:_System_Instructions')}
        }
      ]
    },
    {
      "role": "user",
      "content": [
        {
          "type": "text",
          "text": @{outputs('Compose:_User_Message')}
        }
      ]
    }
  ],
  "temperature": 0.7,
  "top_p": 0.95,
  "max_tokens": 800
}



The structure for the HTTP action body can be found in the payload variable of the sample code.




Return The Message Content From The Azure OpenAI Response

The response from Azure OpenAI contains many details all we want to know is the helpdesk ticket priority. Add a Data Operations – Compose action to the flow and write an expression to get the message content.



Use this code to get the content of the first message returned by Azure OpenAI.

first(body('HTTP:_Chat_Completions')?['choices'])?['message']?['content']




Run The Power Automate Flow To Call Azure OpenAI

Save the flow and test it with hardcoded system instructions and a user message.



The body of the HTTP action returns “medium-priority.”



And we can see the output in the Compose action following the HTTP action.




Questions?

If you have any questions or feedback about How To Use Power Automate + Azure Open AI GPT Models please leave a message in the comments section below. You can post using your email address and are not required to create an account to join the discussion.

Matthew Devaney

Subscribe
Notify of
guest

8 Comments
Oldest
Newest
Inline Feedbacks
View all comments
Temidayo Longe
Temidayo Longe
3 months ago

This is good Matthew. Well documented and well done. The low-cost consumption-pricing model is a life-saver

Alex Chong
Alex Chong
2 months ago

Hi Matthew,

For the body of the HTTP action, there is no User role and content in the sample code screenshot. How did you know you need to include that?

As for my case, my User content is broken down into something like this. Can you provide some insights on this? Thanks.

[
            {
                “type”: “text”,
                “text”: “Subject: Unable to Download Invoice”
            },
            {
                “type”: “text”,
                “text”: “From: [email protected]
            },
            {
                “type”: “text”,
                “text”: “To: [email protected]
            }
]

K Paul
K Paul
2 months ago

Hi Matthew thank you for this very informative flow that I have successfully implemented, just one question, Is the HTTP connector a premium one, as I am able to use it even though I dont have a premium subscription.

Manfred
Manfred
2 months ago

Thank you for the excellent instructions. Is it also possible to submit a document?

Barak
Barak
28 days ago

Hi,
Thanks,
I have a problem, as soon as I send several lines of text I get an error:
[{‘type’: ‘json_invalid’, ‘loc’: (‘body’, 121), ‘msg’: ‘JSON decode error’, ‘input’: {}, ‘ctx’: {‘error’: ‘Expecting value’}}]
Is it not possible to send several lines in a query?
When I send one line I get a response from AI