To begin, you will need:
- Power Apps and Power Automate (seeded licenses) enabled and rolled out across your organisation.
- Power Apps environment with a Dataverse database deployed. You may use the default environment, however a production environment is recommended. If you do not have capacity to create a Dataverse database, you may need to use the default environment.
- Billable Azure Subscription in the same tenant to which you will deploy Provision Assist.
- Service account (used by Logic Apps to connect to SPO, Outlook and Teams) with an appropriate Microsoft 365 license (This account should NOT be an admin). This account CAN have MFA.
- Service account for sensitivity label functionality (applying sensitivity labels), if you wish to use it. This can be the same account as the above if you wish however at the time of writing this account CANNOT use MFA due to restrictions in the Microsoft Graph.
- Windows 10/11 machine on which to execute the PowerShell deployment script.
- PowerShell 7 downloaded and installed - https://learn.microsoft.com/en-us/powershell/scripting/install/installing-powershell-on-windows?view=powershell-7.4.
- Azure CLI (Command Line Interface) - https://learn.microsoft.com/en-us/cli/azure/install-azure-cli.
- Firewall/Proxy configured to allow connectivity using the Azure CLI - please test the 'az login' cmdlet works before proceeding.
- Global Administrator (to execute the
createentraidapp.ps1
script and create/authorize the PnP app registration). - A user account with Owner rights to the Azure Subscription that is also a SharePoint, Power Platform and Teams Administrator.
- A certificate (self-signed is ok) to use for Microsoft Graph and SharePoint REST API authentication (Optional as the deployment script will create a self-signed cert for you if preffered).
- App Registration for PnP PowerShell (see below).
PnP PowerShell no longer supports the 'multi-tenant app registration' option. This previously created an app registration automatically for PnP PowerShell with all neccessary permissions.
In order to authenticate and use PnP PowerShell moving forward, it is neccessary to create your own app registration with the required permissions.
Before you execute the deployment script for Provision Assist, make sure you have created this app registration and have the certificate file and password to hand.
The minimum permissions required for the PnP app registration to be able to run the deployment script are:
Microsoft Graph
- Group.Create
- Group.Read.All
SharePoint
- Sites.FullControl.All
Once the Provision Assist deployment is complete, you may delete the PnP PowerShell app registration or remove the above permissions if you no longer require them.
You can find more details on the changes to PnP PowerShell authentication here.
Please see this video for details of how to create and use the app registration.
If Sites.FullControl.All is a concern, you may create the SharePoint site for Provision Assist manually and make sure the name in the parameters.json file matches the name of the site you created.
The Provision Assist deployment script requires PowerShell 7 and no longer supports 5.1. Please ensure PowerShell 7 is installed before installing the PowerShell modules listed below.
The following PowerShell modules are used by the deployment script and must be installed before executing the script:
- PnP.PowerShell
- Az
- ImportExcel
- WriteAscii
- Download the latest release of Provision Assist.
- Launch PowerShell 7 as an Administrator.
- Set the PowerShell Execution Policy to 'Unrestricted' by running the following cmdlet -
Set-ExecutionPolicy -ExecutionPolicy unrestricted
You will find a parameters.json file in the Scripts folder. Please update all the parameters with the correct values for your tenant.
Replace <<value>>
with appropriate values for all required parameters.
You may refer to the following to understand each parameter:
-
tenantId
- Id of the tenant to deploy to. Can be found in the Azure Active Directory blade. -
spoTenantName
- Name of the SharePoint tenant excluding .sharepoint.com e.g.contoso
. -
requestsSiteName
- Name of the SharePoint site to store requests made by users, can include spaces (URL/Alias automatically generated). If the site exists, it will prompt to overwrite and will apply the PnP provisioning template. -
requestsSiteDesc
- Description of the site that will be created above. -
managedPath
- Managed path configured in the tenant e.g. 'sites' or 'teams' (no forward slash). -
subscriptionId
- Azure subscription to deploy the solution to (MUST be associated with the Entra ID directory of the Microsoft 365 tenant that you wish to deploy this solution to). -
region
- Azure region in which to create the resources. The internal name should be used e.g.uksouth
. The location MUST support Automation and Logic Apps. See Valid Azure locations. -
resourceGroupName
- Name for a new resource group to deploy the solution to - the script will create this resource group. -
appName
- Name for the Entra ID app that will be created e.g.ProvisionAssist
. -
createSelfSignedCert
- Specifies whether to create a self-signed certificate as part of the deployment. If set to true, a self-signed cert will be created through the Azure CLI with the name specified in the 'certName' parameter. -
certName
- Name for the self-signed certificate e.g. 'provisionassist'. If you are creating your own certificate, this parameter is still mandatory and should match the name of your certificate. -
certValidityDays
- Number of days that the certificate is valid for (if 'createSelfSignedCert' is set to true). The default is 365 days. -
pnpAppId
- Id of the PnP Entra app registration that you created when configuring PnP PowerShell. -
pnpCertPath
- Path to the PnP certificate on your local machine that you created when configuring PnP PowerShell. -
siteLogoPath
(Optional) - Path to a company logo (ideally stored in SharePoint) that all users can access to set as the logo for created sites. Please ensure this path is to an image, if you don't have an image leave this blank. -
serviceAccountUPN
- UPN of Service Account to be used for the solution - used to connect the Logic App API connections. Service account should be a standard Microsoft 365 user who has SPO/Exchange/Teams licenses enabled. Refer to Assign licenses to users for more details. -
isEdu
- Specifies whether the current tenant is an Education tenant. If set to true, the Education Teams Templates will be deployed. These will be skipped if set to false or left blank -
KeyVaultName
- Name to use for the Key Vault that is provisioned by the deployment script. The Key Vault stores the app id and secret of the Entra ID app that this solution uses. This ensures that these are held securely. The name of the key vault must be unique across the Azure region that you are deploying to. If a key vault matching the name provided exists in the current subscription, it can be used. PLEASE NOTE - IF YOU USE AN EXISTING KEY VAULT, IT WILL BE OVERWRITTEN AND CONFIGURATION SUCH AS ROLE ASSIGNMENTS WILL BE LOST. WE RECOMMEND USING A DEDICATED KEY VAULT FOR PROVISION ASSIST. The script will validate that the name is available and if not, an alternative name will need to be provided. -
enableSensitivity
- Enable the Sensitivity Label functionality. Note - this will require you to have a Service Account with NO MFA, this can be the same service account as above if you wish. -
skipApplySPOTemplate
- Skip applying the PnP template to the SharePoint site. Leave false unless you have a specific reason to skip this.
The first step is to execute the dedicated script responsible for creating the Entra ID app and granting admin consent for the Microsoft Graph API permissions.
This part of the deployment requires a user account with Global Administrator access.
- Launch a PowerShell 7 window as an Administrator.
- Navigate to the 'Scripts' folder.
- Execute the createentraidapp script in the PowerShell window -
.\createentraidapp.ps1
- Enter a name for the Entra ID app when prompted (This must be the same name as the 'appName' parameter in the parameters.json file).
- Wait for the script to complete.
The next step of deployment is to execute the deploy script.
Ensure the account you are using at this stage has owner rights to the Azure Subscription and is also a SharePoint Administrator.
The deployment script generates a secret for the Entra ID app created above. The default expiry period for this secret is to 1 year, for details on how refresh the secret when it expires, see Refreshing app secret.
As the script uses various PowerShell modules to perform deployment, it will prompt for authentication a number of times.
- Launch a PowerShell 7 window as an Administrator.
- Navigate to the 'Scripts' folder.
- Execute the deploy script in the PowerShell window -
.\deploy.ps1
You will be prompted during the script to enter the password for the PnP app registration certificate.
If you chose to enable the Sensitivity Label functionality, a dialog will be displayed prompting for the password for the Service Account. Please complete the prompt.
When the message "DEPLOYMENT COMPLETED SUCCESSFULLY is displayed, move onto the next stage of the deployment.
If the script fails for any reason, it can be re-executed as many times as require without the need to delete any resources
When the script was executed, it created a number of API connections that need to be authorized manually. In Microsoft Azure portal go to the resource group that was created by the script.
- Click on the API connection with the name "provisionassist-o365".
- Go to "Edit API connection" on the left menu.
- Click "Authorize". Use the Service Account to authenticate.
- Repeate the above actions for "provisionassist-o365users", "provisionassist-spo" and "provisionassist-teams" API connections.
Approval of requests in the solution can take place in two ways:
- Power Automate Approval action (Approval Email and Approvals app in Teams).
- Microsoft Teams Adaptive Card Approval (Adaptive card posted into a Teams channel).
Approvals for requests use a single Power Automate flow which runs when the status of a request in the 'Provisioning Requests' list changes to 'Submitted' (user submits the request in the Power App).
Follow the steps to configure the Provison Assist settings depending on which approval method you wish to implement.
The settings for the Provision Assist solution can be found in the 'Provisioning Request Settings' list and are in the form of a key/value pair (Title/Value), both the Title and Value columns are single line of text.
- Navigate to the SharePoint site created as part of the deployment.
- Locate the 'Provisioning Request Settings' list and navigate to it.
- Edit the 'ApproverEmail' list item and set the 'Value' field to a Email/UPN of a single user OR a Microsoft 365 Group.
- Ensure the value of the 'PostToTeams' list item is set to false.
- Save the changes to the list item.
Approvals are now configured to use Power Automate Approvals tasks.
- Create (OR use an existing) Microsoft Teams Team to use for the approval adaptive cards. You may wish to connect the Provision Assist SharePoint site (group) to a new Teams Team.
- Create (OR use an existing) channel in the same team for the approval cards. This is where they will be posted.
- Add the appropriate users that will approve requests to the team.
- In the Teams client, click on the elipsis and select 'Get link to channel'.
- Click 'Copy' to copy the link to the clipboard.
- Extract the Group Id and Channel Id from the string value as shown below:
https://teams.microsoft.com/l/channel/19%3af221b1abbb214c4b8b5fe3d7e4074194%40thread.tacv2/Request%2520Approvals?groupId=320312d1-e925-433f-80bc-4422f5395edf&tenantId=32292181-0169-456b-b0a4-95fa4c5773a4
The text shown in red is the Group Id. The text shown in green is the Channel Id.
- Navigate to the SharePoint site created as part of the deployment.
- Location the 'Provisioning Request Settings' list and navigate to it.
- Edit the 'PostToTeams' list item and set the 'Value' field to true.
- Edit the 'TeamsChannelID' list item and set the 'Value' field to the id of the channel that you extracted above.
- Edit the 'TeamsTeamID' list item and set the 'Value' field to the id of the group that you extracted above.
- Add the service account to the team as a member, this is required or the adaptive cards will not be posted.
The approvals will now use adaptive cards in Teams. Please revisit this section of the deployment guide if you want to switch to Power Automate Approvals in the future.
- Sign in with the service account that you created for the Provision Assist solution. This is an important step, you must not use the account that you used to deploy the resources.
- Navigate to the Power Apps portal.
- Click on 'Solutions' in the left pane and click 'Import solution'.
- Browse and select the ProvisionAssist managed solution file.
- Click 'Next'.
- Click 'Next'.
- Create new connections for each connection used by Provision Assist, ensure you sign in using the service account.
- Click 'Next' once the connections have been connected.
- The next step is to update the environment variables used by the solution. Either select the SharePoint site created by the deployment in the drop down OR if it is not visible, enter the URL.
- Using each drop down, connect each environment variable to the appropriate SharePoint list by matching the name.
- Click 'Import'.
- When the solution has imported a message will be displayed.
The solution has now been imported.
In order for this flow to be executed from the Power App (when users are checking to ensure the availability of their desired collaboration space) by users, the 'Provisioning Requests' list needs to be added as a 'Run only user' for the flow.
This ensures that all users who have access to the list can execute this flow through the app.
At the time of writing there is a known bug that prevents the selection of your SharePoint site and list UNTIL the flow is edited for the first time, please ensure you follow all the steps below.
Follow the steps below to do this.
- Navigate to the Power Apps portal as the service account.
- Click 'Flows' in the left hand pane and locate the Check Space Availability flow.
- Click on the flow.
- Click 'Edit' in the top menu.
- Click 'Save' in the top menu without making any changes.
- Click the back arrow.
- Click 'Edit' next to 'Run only users'.
- In the pane that appears, select the 'SharePoint' tab.
- Select the Provision Assist site and 'Provisioning Requests' list in the drop downs beneath.
- Set the values in the 'Connections Used' drop downs to use the connection from the owner of the flow.
The Provisioning Request Approval is turned off by default and needs to be turned on.
Follow the steps below to turn it on.
- Navigate to the Power Apps portal as the service account.
- Click 'Flows' in the left hand pane and locate the Provisioning Request Approval flow.
- Click on the flow.
- Click 'Turn on' in the top menu.
Before Provision Assist can be rolled out, the Power App and SharePoint site need to be shared with all users to will submit requests.
Follow the steps below to share the app and the SharePoint site:
- Navigate to the Power Apps portal as the service account.
- Select the Provision Assist Power App and click 'Share' on the top menu.
- Enter users or groups to share the app with. You may wish to give some users 'Owner' rights to edit the app. This will avoid the need to sign in with the service account when making changes.
If you don't have a group you can add users individually or share with everyone across your tenant by sharing with the 'Everyone' group. (To keep the communication official, you should take out the checkbox to 'Send an email invitation to new users.') You can also share the app with other admins by granting them Co-Owner rights.
- Choose whether or not to send an email invitation and click 'Share'.
- The users will now have access to the Power App.
Note: Every user accessing the app for the first time will be prompted to consent to accessing the data sources. The user should click on 'Allow' to proceed. This can be bypassed by using the Power Apps admin PowerShell module. See this documentation for more details. It is recommended to disable the consent popup using PowerShell before production deployment.
Next, we will share the flows that are used by Provision Assist with admins that wish to view flow runs/edit the flows. This step is optional but will avoid the need to sign in with the service account when viewing flow runs. Repeat these steps for each flow.
Two flows are provided with the Provision Assist solution, these are:
- Provisioning Request Approval - Provides an approval process for requests, see Approval flow for more details.
- Check Space Availability - Checks to see if a space matching the supplied Title/URL already exists. This flow is executed when the 'Verify' button is clicked in the Power App. It uses the 'Office 365 Groups' connector to check for a group with the same details and also checks the 'Provisioning Requests' list for a matching request. Users may only proceed if the space does not exist or a request matching the same name does not already exist. If a request is found in the list and it was created by the SAME user, they are prompted to edit the other request instead.
- Navigate to the Power Apps portal as the service account.
- Click 'Flows' in the left pane. You will find two flows that are used by Provision Assist - Provisioning Request Approval and Check Space Availability.
- Select the 'Provisioning Request Approval' flow and click 'Share' on the top menu.
-
Enter users or groups to share the flow with, select 'OK' in the 'Before you share' dialog that appears.
-
Repeat these steps for the 'Check Space Availability' flow.
-
These users will now have access to the flows.
The steps below will share the SharePoint site with end users, giving them access to create/edit requests only and not edit any of the backend settings of Provision Assist.
- Navigate to the SharePoint site created during the deployment.
- Click 'Settings' (gear) icon at the top right corner.
- Click 'Site permissions'.
- Click 'Advanced Permissions settings'.
- Click the Grant Permission option from the top menu bar and search for the user name or type the email address of the user to whom you want to share the site OR select a group containing the users.
- Click 'Show Options' and under the permission level, select the visitors group (this will grant the users read-only access to the site initially).
- Navigate to the 'Provisioning Requests' list and follow these steps to break permission inheritance. Give the Visitors group 'Edit' rights (this will ensure that users can create requests).
Note: Every user accessing the app for the first time will be prompted to consent to accessing the data sources. The user should click on 'Allow' to proceed. This can be bypassed by using the Power Apps admin PowerShell module. See the Solution Overview for more details. It is recommended to disable the consent popup using PowerShell before production deployment.
- Navigate to the Power Apps portal as the account you wish to install the app for and click 'Apps' in the left pane, you should see the Provision Assist Power App. You may need to select the correct Environment in which you deployed the solution from the Environment menu at the top.
- Select the app and click 'Add to Teams' from the top menu bar.
At this point you have two options:
Add the app to Teams globally using policies in the Teams Admin Center OR sideload the app into the Teams client and install for the current logged in user only.
- If you wish to sideload the app, click the 'Add to Teans' option in the dialog that appears. The Teams client will open (you may choose the web client or desktop) and the app will install for the current logged in user.
If you wish to roll the app out via policies, please refer to our general documentation on docs.microsoft.com for how to upload to the Teams Admin Center and deploy globally.
There are a few supporting Logic Apps which should be executed manually after the initial deployment.
These are set to use recurrent triggers and run weekly by default. You can change the run frequency of these to a schedule that suits your organization.
Details of what these are and what they do can be seen below:
- GetHubSites (Retrieves all Hub Sites in the tenant and creates these as list items in the 'Hub Sites' list in the SharePoint site.)
- GetSiteTemplates (Retrieves all SharePoint Site Templates deployed in the tenant and creates these as list items in the 'Site Templates' list in the SharePoint site.)
- GetTeamsTemplates (Retrieves Teams Templates configured in the Teams Admin Center and creates references to these as list items in the 'Teams Templates' list in the SharePoint site.)
- SyncGroupSettings (Gets group settings - Blocked Words and Classifications from Entra ID and updates list items in the 'Provisioning Request Settings' list in the SharePoint site.)
- SyncLabels (Retrieves all Sensitivity labels from Purview in the tenant and adds these to the 'IP Labels' list in the SharePoint site.)
Follow these steps to run them 'on demand':
- Navigate to the Azure Portal (portal.azure.com).
- Locate the required Logic App e.g. GetHubSites. You can either search for the logic app in the search bar or locate the resource group created as part of the deployment, click on it and locate the logic app in there.
- Select the logic app.
- Click on 'Run Trigger' > 'Run'.
- Once the logic app has executed, you should see a status of 'Succeeded' in the run history.
- Repeat the steps to execute each logic app.
Before Hub Sites and Site Templates are visible to end users in the Power App, they must be 'Enabled'.
There is a Yes/No column named 'Enabled' in the 'Hub Sites' and 'Site Templates' lists. If you wish to make a specific template visible to end users please edit the list items and set the value of the column to true.
The reason for this column is to allow admins the flexibility to show/hide Site Templates and Hub Sites.
The Provision Assist Power App leverages a setting in the 'Provisioning Request Settings' list to determine whether or not to display the 'settings' screen to a user in the app. Settings for the solution can be configured via this screen as an alternative to using the settings list in the SharePoint site. At the time of writing this screen is experimental and should be considered a work in progress. Settings should be visible to Administrators of Provision Assist only. Before following the steps, please create one of the following (or use an existing) which will contain the admins for Provision Assist:
- Microsoft 365 Group (can be the same one used for the Provision Assist SPO site) OR
- Microsoft Teams Team OR
- AAD Security Group
Obtain the id of the resource you created or an existing one you will reuse and follow the steps below:
- Navigate to the SharePoint site created as part of the deployment.
- Location the 'Provisioning Request Settings' list and navigate to it.
- Edit the 'AdminGroupId' list item and set the 'Value' field to the id from above.
- Save the list item.
The admins group is now set up and configured.
If you do not wish to use the provided Power Automate approval process, you can enable 'Auto approval' through the 'Provisioning Request Settings' list.
To turn this on, simply navigate to the settings list, edit the list item named 'EnableAutoApproval' and set the Value column to 'true'.
When users submit requests through the Power App, the status will be set to 'Approved' meaning the approval flow will not run and therefore the provisioning process will start straight away.