forked from microsoft/powerplatform-build-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
update readme and other repo and task library documents (microsoft#88)
Co-authored-by: david@DAVID-PC <[email protected]>
- Loading branch information
1 parent
a8590b5
commit 072f46d
Showing
5 changed files
with
183 additions
and
48 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
# Contributing | ||
|
||
This project will welcome contributions and suggestions in the near future. | ||
|
||
Once this project is ready to welcome contributions and suggestions: Most contributions require you to agree to a | ||
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us | ||
the rights to use your contribution. For details, visit <https://cla.opensource.microsoft.com>. | ||
|
||
When you submit a pull request, a CLA bot will automatically determine whether you need to provide | ||
a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions | ||
provided by the bot. You will only need to do this once across all repos using our CLA. | ||
|
||
## Setting Up Local Dev Environment | ||
|
||
Windows, macOS or Linux: | ||
|
||
- [Node.js LTS (currently v16)](https://nodejs.org/en/download/) | ||
- gulp CLI: ```npm install -g gulp-cli``` | ||
- [git](https://git-scm.com/downloads) | ||
- [VS Code](https://code.visualstudio.com/Download) or your different favorite editor | ||
- recommended VSCode extensions: | ||
- [EditorConfig for VS Code (editorconfig.editorconfig)](https://github.com/editorconfig/editorconfig-vscode) | ||
- [ESLint (dbaeumer.vscode-eslint)](https://github.com/Microsoft/vscode-eslint) | ||
- [GitLens (eamodio.gitlens)](https://github.com/eamodio/vscode-gitlens) | ||
- [markdownlint (davidanson.vscode-markdownlint)](https://github.com/DavidAnson/vscode-markdownlint) | ||
|
||
- TEMPORARY: | ||
- Create a PAT for the Azure DevOps org ```msazure``` with scope: package(read) and add it as local environment variable. | ||
|
||
```Powershell | ||
[Environment]::SetEnvironmentVariable('AZ_DevOps_Read_PAT', '<yourPAT>', [EnvironmentVariableTarget]::User) | ||
``` | ||
- Create a PAT in GitHub to read packages, and enable SSO for the microsoft organization. Then add it to your *~/.npmrc* file or use the `npm login` command as documented [here](https://docs.github.com/en/packages/guides/configuring-npm-for-use-with-github-packages#authenticating-with-a-personal-access-token). This will only be needed until the `@microsoft/powerplatform-cli-wrapper` repo is made public. | ||
If developing on Linux or macOS, you will also need to install `git-lfs`. (It is prepackaged with the Git installer for Windows.) Follow the [instructions here](https://docs.github.com/en/github/managing-large-files/installing-git-large-file-storage) for your environment. | ||
## Build and Run | ||
Clone, restore modules, build and run: | ||
```bash | ||
git clone https://github.com/microsoft/powerplatform-build-tools.git pp-build-tools | ||
cd pp-build-tools | ||
npm ci | ||
gulp ci | ||
``` | ||
|
||
## How to make GitHub Actions and Build Tools compatible with latest PAC CLI? | ||
|
||
[Please refer steps in Cli-Wrapper](https://github.com/microsoft/powerplatform-cli-wrapper/blob/main/README.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,63 +1,31 @@ | ||
# Power Platform Build Tools | ||
|
||
[data:image/s3,"s3://crabby-images/8e096/8e0965fea8d1cd0c494b113d52a4eae343d41abd" alt="PullRequest"](https://github.com/microsoft/powerplatform-build-tools/actions/workflows/PullRequest.yml) | ||
[data:image/s3,"s3://crabby-images/4ff7d/4ff7dcace1efb3857cf11f25e688fc7a0a677b69" alt="Official Build"](https://dev.azure.com/dynamicscrm/OneCRM/_build/latest?definitionId=15006&branchName=main) | ||
|
||
Power Platform Build Tools automate common build and deployment tasks related to Power Platform. | ||
This includes synchronization of solution metadata (a.k.a. solutions) between development environments and source control, | ||
generating build artifacts, deploying to downstream environments, provisioning/de-provisioning of environments, | ||
and the ability to perform static analysis checks against your solution using the PowerApps checker service. | ||
|
||
Learn more about the Build Tools [here](https://aka.ms/buildtoolsdoc). | ||
|
||
## Setting Up Local Dev Environment | ||
|
||
Windows, macOS or Linux: | ||
|
||
- [Node.js LTS (currently v14)](https://nodejs.org/en/download/) | ||
- gulp CLI: ```npm install -g gulp-cli``` | ||
- [git](https://git-scm.com/downloads) | ||
- [VS Code](https://code.visualstudio.com/Download) or your different favorite editor | ||
- recommended VSCode extensions: | ||
- [EditorConfig for VS Code (editorconfig.editorconfig)](https://github.com/editorconfig/editorconfig-vscode) | ||
- [ESLint (dbaeumer.vscode-eslint)](https://github.com/Microsoft/vscode-eslint) | ||
- [GitLens (eamodio.gitlens)](https://github.com/eamodio/vscode-gitlens) | ||
- [markdownlint (davidanson.vscode-markdownlint)](https://github.com/DavidAnson/vscode-markdownlint) | ||
|
||
- TEMPORARY: | ||
- Create a PAT for the Azure DevOps org ```msazure``` with scope: package(read) and add it as local environment variable. | ||
|
||
```Powershell | ||
[Environment]::SetEnvironmentVariable('AZ_DevOps_Read_PAT', '<yourPAT>', [EnvironmentVariableTarget]::User) | ||
``` | ||
Each tasks wraps the existing [Power Platform CLI](https://aka.ms/PowerPlatformCLI). | ||
|
||
- Create a PAT in GitHub to read packages, and enable SSO for the microsoft organization. Then add it to your *~/.npmrc* file or use the `npm login` command as documented [here](https://docs.github.com/en/packages/guides/configuring-npm-for-use-with-github-packages#authenticating-with-a-personal-access-token). This will only be needed until the `@microsoft/powerplatform-cli-wrapper` repo is made public. | ||
## Feedback & Questions | ||
|
||
If developing on Linux or macOS, you will also need to install `git-lfs`. (It is prepackaged with the Git installer for Windows.) Follow the [instructions here](https://docs.github.com/en/github/managing-large-files/installing-git-large-file-storage) for your environment. | ||
## Getting Started | ||
Clone, restore modules, build and run: | ||
```bash | ||
git clone https://github.com/microsoft/powerplatform-build-tools.git pp-build-tools | ||
cd pp-build-tools | ||
npm install | ||
gulp ci | ||
``` | ||
Please use the issues tracker in the home repo: <https://github.com/microsoft/powerplatform-build-tools/issues> | ||
|
||
## Contributing | ||
|
||
This project welcomes contributions and suggestions. Most contributions require you to agree to a | ||
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us | ||
the rights to use your contribution. For details, visit <https://cla.opensource.microsoft.com>. | ||
This project will welcome contributions in the near future. At this stage, we're not ready for contributions, | ||
but do welcome your suggestions via this repository's issue tracker. | ||
|
||
When you submit a pull request, a CLA bot will automatically determine whether you need to provide | ||
a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions | ||
provided by the bot. You will only need to do this once across all repos using our CLA. | ||
See details in [CONTRIBUTING](CONTRIBUTING.md) | ||
|
||
### Code of Conduct | ||
|
||
This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/). | ||
For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or | ||
contact [[email protected]](mailto:[email protected]) with any additional questions or comments. | ||
See details in [CODE_OF_CONDUCT](CODE_OF_CONDUCT.md) | ||
|
||
### Security issues | ||
|
||
|
@@ -71,6 +39,3 @@ Use of Microsoft trademarks or logos in modified versions of this project | |
must not cause confusion or imply Microsoft sponsorship. | ||
Any use of third-party trademarks or logos are subject to those third-party's policies. | ||
|
||
### How to make GitHub Actions and Build Tools compatible with latest PAC CLI? | ||
|
||
[Please refer steps in Cli-Wrapper](https://github.com/microsoft/powerplatform-cli-wrapper/blob/main/README.md) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
**Power Platform Build Tools** | ||
============================== | ||
|
||
Overview | ||
-------- | ||
|
||
Use Power Platform Build Tools to automate common build and deployment tasks | ||
related to Power Platform. This includes synchronization of solution metadata | ||
(a.k.a. solutions) between development environments and source control, | ||
generating build artifacts, deploying to downstream environments, | ||
provisioning/de-provisioning of environments, and the ability to perform | ||
static analysis checks against your solution using the PowerApps checker | ||
service. | ||
|
||
Learn more about the Build Tools [here](https://aka.ms/buildtoolsdoc). | ||
|
||
# Release Notes | ||
{{NextReleaseVersion}}: | ||
- Tasks are now implemented using [PowerPlatform CLI](https://aka.ms/PowerPlatformCLI) | ||
- Crossplatform support: Tasks can run on either Windows or Linux build agents | ||
(exception: PackageDeploy requires Windows) | ||
- ToolInstaller task: still required as first task, but it will no longer require runtime | ||
access to PowershellGallery nor nuget.org feeds | ||
- All tasks are backwards compatible to their previous PowerShell implementation (version 1.0.41 and older) | ||
|
||
1.0.41: | ||
- add Staging Solution API for ImportSolution with EnvironmentVariables | ||
|
||
1.0.40: | ||
- updated ToolInstaller default versions to latest PowerApps.Admin module and SolutionPackager package | ||
- add support for modern SiteMap (requires SolutionPackager from CoreTools pkg 9.1.0.90 or newer) | ||
- update to latest MSAL & latest Dataverse service client with fix for MaxConnectionTimeout (now 10 min) for task DeleteSolution | ||
- fix DeployPackage: renew OAuth access token if package deployment exceeds 60 min | ||
- New-CrmServicePrincipal.ps1 script now creates secrets with a default expiration date (see https://aka.ms/buildtools-spn) | ||
|
||
1.0.35: | ||
- PowerApps Checker: new optional parameter to exclude files from checker | ||
- CreateEnvironment: only warn if region, language, currency or template key cannot be enumerate before actual createEnv call to BAP | ||
- Update ToolInstaller to latest modules & packages | ||
- preview support for ImportSolution with ConnectionReferences and EnvironmentVariables, see 'Deployment Settings File' parameter | ||
- update to linking with latest PackageDeployer nupkg to avoid MethodNotFoundException when PD sets new DeploymentStage property in ImportProgressStatus | ||
- fix silent crash within PowerShell in DeployPackage (type conversion to CrmServiceClient failed when assigning CrmConnection cmdlet property) | ||
|
||
1.0.23: | ||
- Apply Solution Upgrade task: | ||
- New task to apply solution upgrade after solution import task has been used with the "Import as holding solution" option to stage the solution for upgrade | ||
- Delete Solution task: | ||
- New task to delete solution | ||
- Update ToolInstaller to latest modules & packages | ||
- Enabled Service Principal based authentication for Restore environment management tasks (ResetEnv with SPN authN is still being worked on) | ||
|
||
1.0.22: | ||
- Fix DeployPackage error: Cannot load package info/method not found error in CoreObjects | ||
- Updating to default ToolInstaller to latest PackageDeploy PS module and linking instance tasks with latest connect control | ||
|
||
1.0.20: | ||
- Avoid PSGallery module and Nuget pkg install errors, ensure the build agent user's PS session has latest modules for PackageManagement and PowerShellGet | ||
|
||
1.0.19: | ||
- Fix ToolInstaller: limit nuget.org calls to API V2, since PS system package provider has no support for V3 API | ||
|
||
1.0.17: | ||
- All environment CRUD tasks now solely depend on PowerApps.Administration module (OnlineManagementAPI is retired) | ||
ToolInstaller task will ignore version for the OnlineManagemementAPI module | ||
- Deploy Package task timeout issue fixed: provides an option to increase the default 60 minutes timeout | ||
- Create, Copy, Restore, and Reset Environment tasks create/update the following newly added pipeline variables: | ||
- "BuildTools.OrganizationId" pipeline variable with the connected environment's organization id | ||
- "BuildTools.OrgUniqueName" pipeline variable with the connected environment's unique name | ||
- Create Environment task: | ||
- editable option for Environment type, Region, Language, and Currency input fields | ||
- removed "Developer Edition" app from app/templates list | ||
- added new environment type "Trial (subscription-based)" | ||
- Power Platform Checker: | ||
- added geography support for Germany | ||
|
||
- Known issue: ResetEnvironment with appID/SPN authN will result in the AppUser being removed; | ||
service side fix is being worked on | ||
mitigation: use username/password service connection for now or Backup/Restore | ||
|
||
1.0.13 | ||
- Export solution task 4 minute timout failures fixed: | ||
Export is now working asynchronously by default: | ||
- available in all public clouds now, except in scale groups for enterprises who opted in for slow-deployments | ||
- will become available in sovereign clouds as the CDS service deployments continue over the next weeks | ||
- Note: an environment that has not received the CDS service update will fail with a 400 Bad Request error. Uncheck the asynchronous option to mitigate. | ||
- Create Environment task: | ||
- options to provide the app name(s) that are not available in the template/app list | ||
- enabled app/template list for both Sandbox and Production environment types | ||
- Backup, restore, copy tasks no longer require full TenantAdmin privilege: SystemAdmin on the environment is sufficient. This is a partial fix as long as task authenticates with username/password; when using AppID/ | ||
ClientSecret, the user must have TenantAdmin privileges for now | ||
- Added log information such as connection, logged-in user and organization details | ||
- Updated ToolInstaller default version of following runtime dependencies to latest versions | ||
- PowerAppsAdminVersion: 2.0.76 | ||
- CrmSdkCoreToolsVersion: 9.1.0.49 | ||
|
||
1.0.8: | ||
- Enabled Service Principal based authentication for Create/Delete/Copy/Backup/Restore environment management tasks | ||
- Service Principal is currently not available for Reset environment task. Only username/password is supported | ||
|
||
1.0.4: | ||
- Surface AAD errors if username/password authentication requires MFA (avoid task time out) | ||
- Fix support/feedback email | ||
|
||
1.0.3 | ||
- Updated ToolInstaller default version of runtime dependencies to latest versions | ||
- Pack/UnpackSolution tasks: handle file/folder paths with spaces (and validated other tasks tolerate paths with spaces) | ||
- Enable TiP endpoint support: all tasks can connect to TiP endpoints as well | ||
|
||
1.0.1 | ||
First General Availability release: | ||
- 2 choices for task authentication with Power Platform endpoints: | ||
- Azure DevOps ServiceConnection "Power Platform" to authenticate with Service Principal/Client Secret; | ||
this is the preferred way to authenticate in an MFA-enabled tenant | ||
- Generic ServiceConnection using username/password authentication | ||
(Note: this authentication is not MFA capable since Azure DevOps tasks run non-interactive) | ||
- Create and configure Azure AppId/Service Principal & ClientSecret with <https://aka.ms/buildtools-spn> | ||
- Pipeline variable "BuildTools.EnvironmentUrl": | ||
- Create, Copy and Restore Environment tasks create/overwrite "BuildTools.EnvironmentUrl" pipeline variable to store new environment url | ||
- All other tasks reference environment url from "BuildTools.EnvironmentUrl" pipeline variable if defined, otherwise reference the url from the active ServiceConnection |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters