Exercise - Generate text with GPT in AI Builder and Power Automate

Completed

In this exercise, you'll build a Microsoft Power Automate flow that uses the Create text with GPT using a prompt model in AI Builder to extract information from an email that a customer has sent requesting a real estate showing. The Create text with GPT model extracts the customer's name, address of the property that they want to view, and the date and time of the showing from the email. Then, the model sends a message to a Microsoft Teams channel with the extracted information.

You can use this extracted information to create a record in a Dataverse table. However, that action is beyond the scope of this lab.

Create an automated cloud flow

  1. Sign in to Power Automate.

  2. On the left pane, select Create > Automated cloud flow.

    Screenshot of the Create option and the Automated cloud flow action.

  3. Name the flow Extract details for Real Estate Showing.

  4. In the Search all triggers box, enter when an email arrives and then select the When a new email arrives (V3) trigger.

    Screenshot of the flow name and the Office 365 Outlook trigger.

  5. Select Create.

  6. Select the When a new email arrives (V3) trigger to open the trigger details pane.

  7. Select Show all for the advanced parameters and then in Subject Filter, enter [Query].

    Screenshot of the When a new email arrives trigger with the Subject Filter property highlighted.

    Note

    This step ensures that the flow only runs when the subject of the email contains the word "Query" (for the purpose of this lab).

    In a real scenario, you might have a separate email address that handles customer queries, so you won't need to filter by subject.

Add a GPT prompt to the cloud flow

  1. Under the flow trigger, select Add an action and then select AI Builder.

  2. Select Create text with GPT using a prompt in the list of actions.

    Screenshot of the Create text with GPT action in Power Automate.

  3. Select Prompt and then select New Custom Prompt.

  4. Name the prompt Extract Real Estate Showing Details

  5. Paste the following text into the Prompt box:

    Extract "Name", "Address", "Date", and "Time" from the text below.
    
    When the text below has less than a couple of words, answer that you can't extract information.
    
    [Start of text]
    Good day,
    
    I hope this email finds you well. My name is <Your name>, and I am currently in the market for a new property. I came across your listing for the property located at 210 Pine Road, Portland, OR 97204, and am very interested in learning more about it.
    
    I would like to kindly request a viewing of this property on September 15th at 3:30 PM. I believe this time is within the normal hours for showings, but if there are any conflicts or alternate time suggestions, please let me know at your earliest convenience.
    [End of text]
    

    Screenshot of the full prompt in the Create prompt window.

    The preceding prompt uses the basic formula for creating a GPT prompt (instruction and context), where the first part of the prompt is the instruction component:

    Extract "Name", "Address", "Date", and "Time" from the text below. When the text below has less than a couple of words, answer that you can't extract information.

    The following text is the context component of the formula:

    [Start of text] context [End of text]

    The instruction tells the model what it should do. The context is the information that the model needs to follow the instruction. In an automation task, the instruction is constant and dynamic content provides the context, which you'll update in the next step.

  6. Select Test prompt to see if GPT extracts the correct information from the text.

    After a few seconds of preparing a response, the GPT model should be able to extract the relevant information from the example prompt:

    Screenshot of the extracted information from the prompt.

  7. Select the Input drop-down from the right side Prompt settings.

  8. Select + Add Input and name it BodyInput.

  9. Delete the example email between the [Start of text] and [End of text] from the Prompt.

  10. With your cursor still between [Start of text] and [End of text], select the + Insert button, and then select BodyInput.

    Screenshot of the updated prompt text together with the email body dynamic content.

  11. Select Save custom prompt.

  12. Now a new field called BodyInput will appear on the AI Builder action. Select this field and then select the Body dynamic content of the email from the trigger.

    Screenshot of the body input field.

    Whenever an email arrives, GPT attempts to extract the relevant information from the email body.

    AI-generated content can be factually incorrect, inappropriate, or biased. We strongly recommend that you institute a practice of inserting human oversight in workflows that use AI-generated text before it's posted or used anywhere.

    Now, you'll add an approval step so that a human can review the extracted information.

Add an approval step into the cloud flow

  1. Select Add an action and then search for and select Approvals.

  2. In the list of actions, select Start and wait for an approval of text.

  3. In the Title box, enter Review extracted information.

  4. In the Suggested text box, add the Text dynamic content from the Create text with GPT using a prompt action.

  5. Select Switch to Advanced Mode and then in the Assigned To box, enter the email address that you're using for this lab.

  6. In the Details box, enter the following text:

    Please review the extracted information and edit as necessary.

    Screenshot displaying the action of adding dynamic content to the Start and wait for an approval of text action.

  7. Select Add an action, search for Control, and then select Condition.

  8. Select the Choose a value box and then select Outcome from the Dynamic content.

  9. Select is equal to for the condition and then enter Approve for Choose a value.

    Screenshot of the Condition action with the Outcome value.

  10. In the True box, select Add an action. Search for Microsoft Teams and then select Post message in a chat or channel.

    Note

    If you need to sign in to create a connection to Microsoft Teams, follow the prompts on screen to sign in.

  11. Select Flow bot from the Post as dropdown menu, and then select Chat with Flow bot from the Post in dropdown menu.

  12. Select Switch to Advanced Mode and then in the Recipient box, enter the email address that you're using for this lab.

  13. For the Message box, enter the following text:

    Please add the following Real Estate Showing Request.
    
    Client Email:
    
  14. With the cursor next to Client Email, select Add dynamic content and then select the From option from the When a new email arrives action.

  15. Beneath the Client Email line, select the Accepted text dynamic content from the Start and wait for an approval of text action.

    Screenshot of the updated Post message in a chat or channel action with the Accepted text dynamic content.

    This step sends a direct Teams message to you with the Client Email and the Accepted text from the approval action to remind you to create a record in the Real Estate Showings app from Microsoft Power Apps.

    You can automate the record creation by converting the extracted entities into a JSON object and then using that object to create a record in the Real Estate Showings app and Dataverse table. However, that action is beyond the scope of this lab.

    In the If no box, you can add a Send an email action to notify the sender that insufficient information was provided for booking the showing. However, you can add that action in your own time.

  16. For now, save the flow by selecting Save.

Test the flow

  1. Select Test > Manually and then select Test.

  2. From any email address, send an email to the email address that you're using for this lab with the subject of [Query] - New Booking Request and the following body content:

    Hello,
    
    I trust you're doing well. I'm John Doe and I'm actively searching for a new home. Your listing for the property at 789 Maple Avenue, Lexington, KY 40502 has caught my attention, and I'm eager to find out more.
    
    Could I arrange to see the property on September 29th at 1:45 PM? I think this falls within your usual showing times, but if that doesn't work for you or if you have other time options, I'd appreciate it if you could inform me as soon as possible.
    
  3. Open Outlook, which should show the email that you've sent to yourself followed by the Approval request with the extracted information, as shown in the following screenshot.

    Screenshot of the Approval request in the Outlook inbox.

  4. Select Approve and Submit and then open Teams. After the request is approved, you should receive a message from the flow bot with the extracted information, as shown in the following image.

    Screenshot of the Teams message confirming the extracted date.

  5. Return to your Power Automate flow, where the flow should show a successful run.

  6. In the top-left corner of the screen, select Back. This will take you to the Extract details for Real Estate Showing flow details page.

Add the flow to the Real Estate Solution

  1. On the left navigation pane, select Solutions.

  2. Select the Real Estate Solution.

  3. On the top command bar, select Add existing > Automation > Cloud flow.

  4. Select the Outside Dataverse tab and then select the Extract details for Real Estate Showing flow.

    Select Add.