The goal of this project is to provide to the Power Platform community
a kit
that will help people start their DevOps journey with the Power Plaform
.
The content of this repository is mainly for advanced makers
with experience with ALM concepts and programming skills.
We will try to make this starter kit useful for you.
- Create a Power Platform environment and the corresponding Power Platform service connection in Azure DevOps using a pipeline you can trigger manually
- Create a Power Platform Power Platform service connection associated to an existing environment using a pipeline you can trigger manually
- Delete a Power Platform environment and the corresponding Power Platform service connection in Azure DevOps using a pipeline you can trigger manually
- Delete a Power Platform Power Platform service connection associated to an existing environment using a pipeline you can trigger manually
Power-Platform-ALM-Starter-Kit
│ README.md
│ LICENSE
| CODE_OF_CONDUCT.md
└───Pipelines
└───└───Templates
│ │ │ create-powerplatform-environment-template.yml: Pipeline template for the creation of a Dataverse environment
│ │ │ create-powerplatform-service-endpoint-template.yml: Pipeline template for the creation of a Power Platform service connection in Azure DevOps
│ │ │ delete-powerplatform-service-endpoint-template.yml: Pipeline template for the deletion of a Power Platform service connection in Azure DevOps
│ │ │ generate-powerplatform-environment-domainname-template.yml: Pipeline template for the generation of a Power Platform environment DomainName based on the EnvironmentName provided
│ │ │ generate-powerplatform-environment-url-template.yml: Pipeline template for the generation of the URL of a Power Platform environment based on the EnvironmentName provided
│ │ │
└───└───Utils
│ │ │ create-powerplatform-environment-and-service-endpoint.yml: Pipeline used to create of a Dataverse environment if it does not exist (search based on the name provided) and generate the associated Power Platform service connection in Azure DevOps
│ │ │ delete-powerplatform-environment-and-service-endpoint.yml: Pipeline used to delete a Dataverse environment and delete the associated Power Platform service connection in Azure DevOps
│ │ │ delete-powerplatform-service-endpoint.yml: Pipeline used to delete a Power Platform service connection in Azure DevOps
│ │ │ powerplatform-service-connection-test.yml: Pipeline used to test a Power Platform service connection with its name provided
│ │ │
└───Configuration
│ │ powerplatform-spn-template.json: Body request template for the creation of a Power Platform service connection in Azure DevOps
│ │ DataverseEnvironmentConfiguration.txt: Template for the configuration of the Dataverse environment to create
└───Scripts
└───└───Tests
│ │ │ New-DataverseEnvironment.Tests.ps1: Test script of the New-DataverseEnvironment PowerShell function
│ │ New-DataverseEnvironment.ps1: PowerShell function for the creation of a Dataverse environment if it does not exist (search based on the name provided)
To use this starter kit, you will need to have the following components already available:
- an Azure DevOps organization
- an Azure DevOps project with a repository
- the Power Platform Build Tools extension installed in your Azure DevOps organization
- a PAT (Personal access token) created for the considered Azure DevOps organization with
Full access
(at the moment, we are not able to clearly identify the access needed to enable a service connection for all pipelines) - Add the following permissions to your project Build Service user account in your repository settings (Project Settings > Repositories > Security tab > "YourProjectName Build Service [...]" > Permission > Allow)
- Contribute
- Create tag
- Read
- Bypass policies when pushing - if you want to create your Dataverse environments from a branch with policies (⚠ not recommended)
Note: In a multi-tenant scenario, you will need to follow the steps below related to the Azure AD app registration for each considered tenant where you want to manage Dataverse environments.
- an app registration registered in Azure Active Directory with (at least):
- the following permissions with admin consent granted:
Dynamics CRM.user_impersonation
- a client secret generated and stored somewhere safe
- the correct account type selected (single tenant or multitenant) depending on your scenario
- the following permissions with admin consent granted:
- run the New-PowerAppManagementApp PowerShell command of the Microsoft.PowerApps.Administration.PowerShell specifying the Application (client) ID of the app registration you registered previously in Azure AD
> Add-PowerAppsAccount
> New-PowerAppManagementApp -ApplicationId 00000000-0000-0000-0000-000000000000
- an application user created on one of your existing Dataverse environments (for example a Production Dataverse environment you already have) with the System Administrator security role using the Application (client) ID of the app registration you registered previously in Azure AD
- a Power Platform service connection created in the considered Azure DevOps project associated to the Dataverse environment we talked about in the previous step using the information (Application (client) ID, Directory (tenant) ID and Client Secret) of the app registration you registered previously in Azure AD
- Copy the
Pipelines
,Configuration
andScripts
folders of this repository - Paste it at the root of the repository in the Azure DevOps project you want to use
- Update the DataverseEnvironmentConfiguration.txt configuration file in the Configuration folder with the configuration you want for your environments (you can use the content of the Resources section of this page to help you complete this step)
- Create pipelines from all YAML pipeline definitions in the
Pipelines/Utils
folder (Pipelines > New pipeline > Azure Repos Git (YAML) > "NameOfRepositoryWithPipelineDefinitions" > Existing Azure Pipelines YAML File > "BranchWithPipelineDefinitions" > /Pipelines/Utils/...) - Create a variable group in your Azure DevOps project with the following name and with the variables below:
power-platform-environment-management-variable-group
ApplicationId
(secret type variable recommended): Application (client) ID of your app registration in Azure Active DirectoryAzureDevOpsOrganizationURL
: URL of the Azure DevOps organization you are working in (ex: https://dev.azure.com/demonstration/)ClientSecret
(⚠ secret type variable strongly recommended): Client secret of your app registration in Azure Active DirectoryDataverseEnvironmentConfigurationFileName
: Full name (with extension) of the file you want to use for the configuration of the Dataverse environments to create (ex: DataverseEnvironmentConfiguration.txt)PatToken
(⚠ secret type variable strongly recommended): Value of the PAT (Personal access token) we talked about in the Prerequisites section abovePowerPlatformEnvironmentURLBase
: Base of the URL (linked to the location) you want to consider for your Dataverse environments to create (ex: crm12.dynamics.com)TenantId
(secret type variable recommended): ID of your app registration in Azure Active Directory
- Test the pipelines
You can use the commands below from the Microsoft.PowerApps.Administration.PowerShell PowerShell module to find the information for configuration file for the creation of the Dataverse environments:
- Get-AdminPowerAppEnvironmentLocations to get all the supported locations for your Dataverse environment
- Get-AdminPowerAppCdsDatabaseLanguages to get all the supported languages for a specific location for your Dataverse environment
- Get-AdminPowerAppCdsDatabaseTemplates to get all the supported applications for a specific location for your Dataverse environment
- Get-AdminPowerAppCdsDatabaseCurrencies to get all the supported currencies for a specific location for your Dataverse environment
For the PowerPlatformEnvironmentURLBase
variable in the power-platform-environment-management-variable-group
variable group, you can find the available values in the Datacenter regions Microsoft documentation page.
- Fork this repository.
- Create a branch:
git checkout -b <branch_name>
. - Make your changes and commit them:
git commit -m '<commit_message>'
- Push to the original branch:
git push origin <project_name>/<location>
- Create a pull request targeting the
main
branch of this repository
Alternatively see the GitHub documentation on creating a pull request.
Thanks to the following people who have contributed to this project:
Benedikt Bergmann 📖 |
Raphael Pothin 📖 |
If needed, you can contact us on twitter:
This project is licensed under the MIT license.