How to incorporate Procore REST API's into Power Automate to create Procore User(s)

This will be a four part series giving you a step-by-step walk-through on how to:

      1. Create an MS Graph custom connector for groups
      2. Create an MS Graph custom connector for group members
      3. Create Procore API custom connector to GET all users
      4. Create POST Procore API to create a new user in Procore using Power Automate

    What is Procore?

    Procore is the #1 software dedicated to the construction industry. Procore enhances collaboration, safety, and communication in all aspects of the project life line from precon to closeout in one system.

    Use case

    Add users to Procore automatically as users are added to Azure AD, based on Microsoft E1, E3, E5, E5 with PSTN, E5 with PSTN and International Calling, and F3 licensing assignment.

    Step-by-Step Guide

    For our specific use case, we wanted to pull all Microsoft and Office Licensing group configured for group based licensing for all E1, E3, E5, and F3 licenses. Then retrieve all the group members to compare to users in Procore when adding new users via Power Automate.

    STEP 1.

    Develop the query in MS Graph to GET all Microsoft/Office license groups.

    MS Graph can be accessed here: https://developer.microsoft.com/en-us/graph/graph-explorer

    The query was as follows: https://graph.microsoft.com/v1.0/groups?$filter=startswith(displayName, ‘License – Microsoft’) or startswith(displayName, ‘License – Office’)

    In our particular case, our group based licensing for Microsoft/Office started with “License – Microsoft” and “License – Office”. In your case it might be different. Adjust the query for your specific needs accordingly. Once you have the query you need:

    STEP 2.

    Create the MS Graph custom connector to GET Microsoft/Office License groups in Power Automate or Power Apps. I used Power Automate to create the custom connector as follows:

        1. Go to Power Automate design studio: https://make.powerautomate.com
        2. Data –> Custom connectors –> New custom connectors –> Create from blank
        3. General –>
        4. Security –>

          Enter Client ID, Client Secret, Authorization URL, Tenant ID, and Resource URL (https://graph.microsoft.com), all else defaults. When you click “Create connector”, Redirect URL will automatically be generated. NOTE: Information can be obtained from the Azure portal for the app registration you will need to create to access MS Graph API’s. This article will not cover creating the app registration in Azure. Instruction can be found here: Register a Microsoft Graph application – Azure AD B2C | Microsoft Learn
        5. Definition –>

          a. General

          Enter anything you wish to call your connector in Summary, Description, and Operation ID fields.

          b. Request
          Click on +Import from sample –> Select GET –> In the URL enter https://graph.microsoft.com/v1.0/groups/?{$filter} –> Import

          This will add $filter to the Query section of the request.

          c. Parameter
          Click the dropdown arrow –> Edit. Make sure you see $filter in the Name, and the end of the query after $filter= in MS Graph. Which in our case was as shown. All else as defaults. Click <- Back.

          d. Response
          Click + Add default response –> Copy the output (Response preview) in MS Graph, and paste it the Body section of the Response. No Header information needed. –> Import

          e. Validation
          You should see a green check mark if all went well. If not, make sure the Response body is correct. NOTE: In some cases, you will need to add the square brackets [ ] around the body request if the output is expecting an array. If it outputs an object, then remove the square brackets and surround the body with the curly brackets { } instead.

          Click Update connector. Now you are ready to Test.

          f. Test
          Click New connection –> Sign-in using your Microsoft credentials. NOTE: Microsoft Account will need to have access the the Microsoft Graph API app registration in Azure. Click Test operation. Once you have successfully tested the operation, you will see a Status (200) along with the Body response. Make sure you see Schema validation succeeded at the bottom.

           

      1.  

      STEP 3.

      Develop the query in MS Graph to GET all Microsoft/Office license groups members.

          • MS Graph can be accessed from here: https://developer.microsoft.com/en-us/graph/graph-explorer 

        The MS Graph query was as follow: https://graph.microsoft.com/v1.0/groups/{group-id}/members

        STEP 4.

        Create the MS Graph custom connector to GET all group members based on group-id.

            1. Same process as above for General and Security.
            2. Definition
              Same process as before except in the Request + Import from sample URL, enter https://graph.microsoft.com/v1.0/groups/{group-id}/members. A group-id parameter will be entered in the Path section of the request.

              Nothing left to do in the parameter section. Leave as default.
            3. Response
              Retrieve response body from the output in MS Graph. Take note of the square [ ] or curly { } brackets and enter them as needed. Make sure validation succeeded. Update connector –> Test. If all went well, we are ready to build the Procore API custom connector.

               

          STEP 5.

           

          Create Procore Developers account and sandbox/production application. NOTE: You must have a Procore developer account and a Sandbox application created and added to your production Procore environment to create the custom connector.

          The Procore developer account can be created here: https://developers.procore.com.

          Once you have created the developer account and a Sandbox application has been created, you will need to add the developer application to your production site in order to query your Procore production environment via the REST API’s. To add the Procore developer application to your environment:

              • Login to Procore at https://procore.com

              • Select Apps dropdown (upper right hand corner)

              • Select App Management

              • Select Install App dropdown –> Install Custom App

              • Enter the App Version Key/ID
                The ID can be obtained from your Procore developer portal under Manage Manifests.

            Additionally, in the Procore developer portal, make note of the Sandbox OAuth Credentials and Production OAuth Credentials. We will need those to create our Procore API custom connector in the next steps.

            NOTE: The Procore API documentation can be accessed here: https://developers.procore.com/reference/rest/v1/docs/rest-api-overview.

            STEP 6.

            Create Procore API custom connector to GET all company users.

                1. General
                  In the Host section, depending on if you want to query the Procore API using your Sandbox environment or your production environment, you will use the following URL’s:

                  Sandbox: sandbox.procore.com (the Base URL) will be the part from the Sandbox URL in your Procore developers portal. (see above)
                  Production: api.procore.com

                1. Security


                      • Client ID and Client Secret: From the Procore developer portal

                      • Authorization URL: https://login.procore.com/oauth/authorize

                      • Token URL: https://login.procore.com/oauth/token

                      • Refresh URL: https://login.procore.com/oauth/token

                      • Leave everything else as defaults. Redirect URL will be created automatically after creating the connector.

                  1. Definition
                    In the Actions section –> New action
                    General
                    Give any name you choose for Summary, Description, and Operation ID.

                    Request
                    Click on + Import from sample and enter the information as follows:

                    Note: company-id will be created in the Path section of the request.

                    Response
                    You can use Postman to explore the Procore API’s. Instructions on creating the Postman workspace for Procore can be found here: https://procore.github.io/documentation/postman
                    Once you have created the workspace, you can test the Procore API’s then use the response body for this section of the configuration. Or, you can access the Procore API documentation which is filled with all the required information needed. Procore API documentation and the example response bodies can be accessed here: https://developers.procore.com/reference/rest/v1/company-users?version=1.0

                    Validation
                    If validation succeeded. Create the connector (if you haven’t already done so) or Update connector then Test.

                    Test
                    Click New connection –> Sign-in to either your Procore production or Procore developer account depending on which URL you are using.
                    Enter company-id. The company-id can be found in the URL after logging in to your Procore production site. If all goes well, we are ready to create the POST Users to Procore API custom connector.

                STEP 7.

                Create Procore API custom connector to POST company user(s).

                    1. General and Security
                      Same as above

                    1. Definition
                      In the Actions section, click –> New action
                      Enter anything you wish for Summary, Description, and Operation ID.

                      Request
                      Click on + Import from sample and enter the following information:

                      Verb: POST
                      URL: https://api.procore.com/rest/v1.0/projects/{project-id}/users
                      Headers: Content-Type
                      Body:
                      {
                      “first_name”: “”,
                      “last_name”: “”,
                      “email_address”: “”
                      }

                      NOTE: Procore only cares about the Body information when creating an account. You will see in the next steps how this information plays a role in creating the new user(s) via Power Automate.

                      Click –> Import

                      Response
                      Again this can be obtained from testing the API calls within Postman. Use the body response from Postman for this information. Or you can access the Procore API documentation for the example response bodies as needed. (see STEP 6.)

                      Validation
                      Once succeeded, click on Create or Update connector, then Test

                      Test

                          • New connection –> Sign-in to Procore

                          • Enter Project-id (obtained by signing in to Procore and opening a particular project. You will see the project-id in the URL). In our case, we add users to the Sandbox Test Project and use the project-id accordingly.

                          • Content-Type: application/json

                          • Enter a test first_name, last_name, and email_address –> Test operation
                            If you see Status (200), A new Procore user has been added. We are now ready to move on to the fun part!

                     

                    STEP 8.

                     

                    Create the Power Automate flow using all of the custom connectors created from the previous steps to POST user(s) to Procore as soon as they are added to any of the group based licensing groups in Active Directory.

                     

                    Here is a sample of what the flow looks like.

                    1. Go to https://make.powerautomate.com
                    2. Click + Create –> Select Scheduled Flow –> Set Recurrence to anything you like. I set ours to run every hour on the hour M-Fri from 5:00am to 5:00pm PST.
                    3. Click + New Step –> Add an action –> Custom –> Select custom connector to GET Microsoft/Office License Groups.
                    4. Add Parse JSON action to parse the output of the GET Microsoft/Office License Groups custom connector to JSON. You can use the same body response when you created the custom connector in STEP 2 to create the Schema. Click Generate from sample.
                    5. Test the flow to make sure you are getting valid schema output in the Parse JSON action.
                    6. Click + New Step –> Select GET All Procore Users custom connector
                    7. Add another Parse JSON action to parse the output of the GET All Procore Users custom connector to JSON. Again, you can use the same body response obtained when you created the custom connector from the Procore API documentation.
                    8. Add Initialize variable –> Name: varProcoreUser – Type: Array – Value: leave blank –> Rename to Initialize varProcoreUser.
                    9. Add Apply to each loop –> Rename to For each Procore User Email. Here we will loop through getting all Procore User(s) first_name, last_name, and email_address based on the output of the Parse JSON Procore Users action.
                    10. Add Append to array variable action and enter the information as seen below.
                    11. Add a Compose action –> Rename to Procore User Email –> Enter Current Item for the Apply to each loop (rename to For each Procore User Email).

                    NOTE: The tolower function in Power Automate is to ensure all email address are in lower case when comparing Procore User email to Group member email in the next action.

                    12. Add another Initialize variable action. Name: varGroupMember – Type: Array – Value: leave blank

                    13. Add another Apply to each loop –> Rename to For each Group Member. This action will loop through each group ID obtained from the GET Microsoft/Office License groups connector and then GET the respective group members.

                    14. Add GET Group Members custom connector action 

                    15. Add Parse to JSON action –> Rename to Parse JSON Group Members.

                     

                    16. Add another Apply to each loop nested inside the previous Apply to each loop –> Rename to For each Group Member Email. This action will loop through each Parse JSON Group Members values and Append to array variable the outputs of givenName, surname, and userPrincipalName. Then output the array variable to a Compose action.

                     

                    17. Add Append to array variable –> Rename to Append to array varGroupMember

                     

                    18. Add Compose action –> Rename to Group Member Email

                    19. Add another Initialize variable action –> Rename to Initialize varFinalResult –> Name: varFinalResult – Type: Array – Value: leave blank

                     

                    20. Add yet another Initialize variable action –> Rename to Initialize varHTML –> Name: varHTML – Type: Array – Value: leave blank

                    21. Add another Apply to each loop –> Rename to For each Procore Email vs Group Email. This action will loop through each group member email and check against the Procore user email to check if the email exists in Procore or not. Then based on the condition action, if no or false, the Procore user(s) will be created.

                     

                    22. Add Condition control –> variables(‘varProcoreUser’) contains item()

                    23. In the “If no” section of the Condition control –> Add POST Procore User custom connector –> Compose Action –> Append to array variable (rename to Append to varFinalResult)
                    This will POST the Procore user if the email address does not exist in Procore, then send the output to a Compose action then send the Compose action to the array variable varFinalResult.

                    24. Add another Compose action outside the previous loop –> Inputs varFinalResult

                     

                    25. Add another Condition control to check if the output of the previous Compose action is empty or not. If so, do nothing. If not, then Create HTML table –> Style HTML Table –> Send an email (V2)

                     

                    				
                    					Style HTML code:
                    <style>
                    
                    table {
                    
                      border: 1px solid #1C6EA4;
                    
                      background-color: #EEEEEE;
                    
                      width: 100%;
                    
                      text-align: left;
                    
                      border-collapse: collapse;
                    }
                    
                    table td, table th {
                    
                      border: 1px solid #AAAAAA;
                    
                      padding: 3px 2px;
                    
                    }
                    
                    table tbody td {
                    
                      font-size: 13px;
                    
                    }
                    
                    table thead {
                    
                      background: #1C6EA4;
                    
                      border-bottom: 2px solid #444444;
                    
                    }
                    
                    table thead th {
                    
                      font-size: 15px;
                    
                      font-weight: bold;
                    
                      color: #FFFFFF;
                    
                      border-left: 2px solid #D0E4F5;
                    
                    }
                    
                    table thead th:first-child {
                    
                      border-left: none;
                    
                    } </style>
                    				
                    			

                    Whew! That’s it. You have now created the ability to automatically POST Procore Users as soon as they are added to a Microsoft Group. If you have any questions, please hit me up on my blog or at https://linkedin.com/in/mxmurillo. Have a wonderful day!

                    Get in Touch

                    Ready for Worry-Free IT? We can help.

                    Copyright 2025 © All rights Reserved. The IT Geeks.

                    Share this:

                    Like this:

                    Like Loading...

                    Need Help?

                    We're Here To Assist You

                    Schedule Your Appointment.

                    Feel free to schedule your appointment, and we will be more than happy to assist you with all of your IT needs.
                    This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.

                    Need Help?

                    We're Here To Assist You

                    Something isn’t Clear?

                    Feel free to contact us, and we will be more than happy to answer all of your questions.

                    This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.