Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
Microsoft Power Platform CLI (command-line interface) is a simple, single-stop developer command-line interface that empowers developers and app makers to create code components.
Microsoft Power Platform CLI tooling is the first step toward a comprehensive application life-cycle management (ALM) story where the enterprise developers and ISVs can create, build, debug, and publish their extensions and customizations quickly and efficiently. For more information, go to What is Microsoft Power Platform CLI?
With this feature, the Microsoft Power Platform CLI enables CI/CD (Continuous Integration/Continuous Deployment) of a Power Pages site configuration. You can now check in the website configuration to source control and move the website configuration to any environment using Microsoft Power Platform CLI.
Note
- This feature is generally available starting with Power Platform CLI version 1.9.8. To learn about installing the latest version, go to Install Microsoft Power Platform CLI.
- With Power Platform CLI version 1.32, the pac powerpages command was changed to pac pages. With pac cli version 1.27, the pac paportal command was changed to pac powerpages. Both powerpages and paportal will continue to work, but we recommend using pages going forward.
Why use Microsoft Power Platform CLI for website development?
With the Microsoft Power Platform CLI, you can now use offline-like capability for website customization by making changes to the website content. And once all customizations or changes are saved, you can upload the website configuration back to Microsoft Dataverse. When you download website content using Microsoft Power Platform CLI, the content is structured in YAML and HTML formats making it easy to customize, enabling a pro-development experience.
Here's a list of features and capabilities that portals benefits from with the support for Microsoft Power Platform CLI:
Ease of use
- Support for download/upload of website configuration data to/from the local file system 
- Build on existing Microsoft Power Platform CLI tool. 
Application lifecycle management (ALM)
- Track changes to website configuration within an organization 
- Move configuration files across organizations or tenants 
Pro-dev and enterprise support
- Helps integrate seamlessly with any source control tools, such as "git" 
- Easily set up CI/CD pipelines 
Install Microsoft Power Platform CLI
For step-by-step instructions, refer to Install Microsoft Power Platform CLI.
Supported tables
Portals support for Microsoft Power Platform CLI is limited to the following tables.
adx_ad
adx_adplacement
adx_blog
adx_blogpost
adx_botconsumer
adx_communityforum
adx_communityforumaccesspermission
adx_contentsnippet
adx_entityform
adx_entityformmetadata
adx_entitylist
adx_entitypermission
adx_forumthreadtype
adx_pagetemplate
adx_poll
adx_polloption
adx_pollplacement
adx_portallanguage
adx_publishingstate
adx_redirect
adx_shortcut
adx_sitemarker
adx_sitesetting
adx_tag
adx_urlhistory
adx_webfile
adx_webform
adx_webformmetadata
adx_webformstep
adx_weblink
adx_weblinkset
adx_webpage
adx_webpageaccesscontrolrule
adx_webrole
adx_website
adx_websiteaccess
adx_websitebinding (only download)
adx_websitelanguage
adx_webtemplate
annotation
Important
- Custom tables and portal template-specific tables (such as blog, community, or ideas portal) aren't supported for customization using Microsoft Power Platform CLI.
- Image file attachments to ad (adx_ad) records aren't downloaded using the Power Platform CLI. As a workaround, use the Image URL field, or by adding an HTML reference in the Copy field to a web file record containing an image file.
Install and verify Microsoft Power Platform CLI for portals
To learn about installing Microsoft Power Platform CLI, go to Install Microsoft Power Platform CLI.
After installing Microsoft Power Platform CLI, open a command-prompt and run pac to verify that the output contains "paportal" - the command for Power Apps portals.
 
Microsoft Power Platform CLI commands for portals
Microsoft Power Platform CLI command for portals is "paportal".
The following sections provide more details about different properties of the "paportal" command.
Parameters
| Property Name | Description | Example | 
|---|---|---|
| list | Lists all portal websites from the current Dataverse environment. You can add the -v parameter to indicate if the site is using the standard or enhanced data model | pac pages list | 
| download | Download portal website content from the current Dataverse environment. It has the following parameters: - path: Path where the website content is downloaded (alias: -p) - webSiteId: Portal website ID to download (alias: -id) - overwrite: (Optional) true - to overwrite existing content; false - to fail if the folder already has website content (alias: -o) - modelVersion: 1or2to indicate if the site data to be downloaded uses the standard (1) or enhanced data model (2). | pac pages download --path "C:\portals" --webSiteId f88b70cc-580b-4f1a-87c3-41debefeb902 --modelVersion 2 | 
| upload | Upload portal website content to the current Dataverse environment. It has the following parameter: - path: Path where the website content is stored (alias: -p) -deploymentProfile: Upload portal data with environment details defined through profile variables in the deployment-profiles/[profile-name].deployment.yaml file - modelVersion: 1or2to indicate if the site data to be uploaded uses the standard (1) or enhanced data model (2).- forceUploadAll: Pushes all local files to the environment. Use this when you think the remote state is corrupt, out of sync, or when the last download came from a different branch. | pac pages upload --path "C:\portals\starter-portal" --deploymentProfile "profile-name" --modelVersion 2 | 
Note
- When you download a portal from Environment A and upload it to Environment B, the PAC CLI performs a full upload. This behavior occurs because change tracking uses Manifest Files, which don't carry state information across environments.
- Delta uploads—where only modified files are uploaded—are supported only when both the download and upload operations happen within the same environment. In this case, PAC CLI detects local changes and uploads only the updated files. To learn more about how change tracking works, see Manifest Files.
- Use --forceUploadAll in these situations. (This parameter is currently CLI-only. Azure DevOps tasks don't surface it yet.)
- Pipeline state drift (you rebased or cherry-picked commits, so the last server state no longer matches your branch).
- Suspected delta failure (for example, only partial changes appear after a normal upload).
 
Use deployment profile
The deploymentProfile switch allows you to define a set of variables for the environment in YAML format. For example, you can have different deployment profiles (such as dev, test, prod) that have different schema details defined in the profile.
If you're creating test profile, you can create file under deployment-profiles with the name "test.deployment.yml" (that is, <profileTag>.deployment.yml). And you can run command with tag (<profileTag>) to use this profile:
pac pages upload --path "C:\portals\starter-portal" --deploymentProfile test --modelVersion 2
In this file, you can have the table (entity) name with table ID, list of attributes, and the values that you want to override while uploading the portal configuration using the deploymentProfile parameter.
Additionally, you can use the OS variable to access the operating system's environment variables.
Here's an example of this "test.deployment.yml" profile YAML file that has unique schema details:
adx_sitesetting:
    - adx_sitesettingid: 4ad86900-b5d7-43ac-1234-482529724970
      adx_value: ${OS.FacebookAppId} 
      adx_name: Authentication/OpenAuth/Facebook/AppId
    - adx_sitesettingid: 5ad86900-b5d7-43ac-8359-482529724979
      adx_value: contoso_sample
      adx_name: Authentication/OpenAuth/Facebook/Secret
adx_contentsnippet:
    - adx_contentsnippetid: b0a1bc03-0df1-4688-86e8-c67b34476510
      adx_name: PowerBI/contoso/sales
      adx_value:  https://powerbi.com/group/contoso/sales
Note
To learn about all commands used in CLI in addition to portals, go to Common commands in Microsoft Power Platform CLI.
Manifest files
When you download the website content using pac pages download CLI command, along with downloading the site content it also generates two manifest files;
- Environment manifest file (org-url-manifest.yml)
- Delete tracking manifest file (manifest.yml)
Environment manifest file (org-url-manifest.yml)
The environment manifest file is generated every time when the pac pages download command is run.
After every download, the PAC CLI tool reads the existing environment manifest file and updates the entries deleted in the environment, or creates the environment manifest file if it doesn't exist.
When you run the pac pages upload command to upload the portal website content. It reads the environment manifest file and identifies the changes made since last download and only uploads the updated content. This helps in optimizing the upload process as only updated website content get uploaded, instead of uploading the all the content on every upload command.
The environment manifest file is readonly when it connects to the same environment (environment URL matches with file name), to avoid accidental changes.
Note
- The environment manifest file isn't designed to track the changes when deploying the website to different environments.
- The environment manifest file is designed to be used by developers for deploying locally in their developer environment and should be added to git ignore list.
Delete tracking manifest file (manifest.yml)
This file is used for tracking the deleted records from the environment.
When website content is downloaded with pac pages download command, this adds the deleted records from environment manifest file (org-url-manifest.yml) to manifest.yml file. So, when you upload the website content using the pac pages upload command it deletes the files from the environment (even to a different environment). This file isn't deleted, and it gets used regardless which environment you're connected. This file needs to be considered when pushing changes to the source control in order to consider deleting items in the target environment.
Note
In order to delete the site content records in one environment and also delete the same content records in another environment using the PAC CLI, you'll need to run the pac pages download command before and after the deleting the website record content. The manifest.yml will track these changes and remove the corresponding records in the target environment when the pac pages upload command is run.
Use the Visual Studio Code extension
You can also use VS Code extension Power Platform VS Code Extension to benefit built-in Liquid language from IntelliSense, code completion assistance, hinting, and interact with the Microsoft Power Platform CLI using the VS Code Integrated Terminal. More information: Use the Visual Studio Code extension (preview)
More considerations
- An error is reported if your file path exceeds the maximum path length limitation. More information: Maximum path length limitation in Windows
- For duplicate records such as a duplicate web page name, Microsoft Power Platform CLI creates two different folders—one with the name of the web page, and the other with the same name prefixed with a hash code. For example, "My-page" and "My-page-hash-code".
Next steps
Tutorial: Use Microsoft Power Platform CLI with portals