This skill should be used when the user asks to "activate site", "provision website", "activate a Power Pages website", "activate portal", "provision portal", "turn on my site", "enable website", or wants to activate/provision a Power Pages website in their Power Platform environment via the Power Platform REST API.
Install with Tessl CLI
npx tessl i github:microsoft/power-platform-skills --skill activate-site85
Quality
83%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Provision a new Power Pages website in a Power Platform environment via the Power Platform REST API.
Prerequisite: This skill expects an existing Power Pages code site created via
/power-pages:create-site. Run that skill first if the site does not exist yet.
pac auth who.Initial request: $ARGUMENTS
Goal: Ensure PAC CLI is installed and authenticated, and verify the user is logged in to Azure CLI (scripts handle token acquisition internally).
Run pac help to check if the PAC CLI is installed and available on the system PATH.
pac helpIf the command fails (command not found / not recognized):
Tell the user: "PAC CLI is not installed. You can install it by running:"
dotnet tool install --global Microsoft.PowerApps.CLI.ToolIf dotnet is also not available, direct the user to https://aka.ms/PowerPlatformCLI for full installation instructions.
After installation, verify by running pac help again.
Run pac auth who to check current authentication status.
pac auth whoIf authenticated: Extract these values from the output:
Environment ID:Organization ID: (this is the Dataverse org ID)Cloud: (e.g., Public, UsGov, UsGovHigh, UsGovDod, China)If not authenticated: Follow the same authentication flow as deploy-site — ask the user for their environment URL and run pac auth create --environment "<URL>".
Verify the user is logged in to Azure CLI (the activation scripts acquire tokens internally):
az account showIf az is not installed or not logged in: Instruct the user to install Azure CLI and run az login.
Before gathering parameters, check whether the site is already activated by running the shared activation status script:
node "${CLAUDE_PLUGIN_ROOT}/scripts/check-activation-status.js" --projectRoot "<PROJECT_ROOT>"Where <PROJECT_ROOT> is the directory containing powerpages.config.json (use Glob with **/powerpages.config.json to locate it if not already known).
The script reads siteName from powerpages.config.json, looks up the websiteRecordId via pac pages list, queries the Power Platform GET websites API, and matches the response against both the websiteRecordId (exact GUID match) and name (case-insensitive). It outputs a JSON result to stdout.
Evaluate the result:
activated is true: The site is already provisioned. Inform the user: "Your site <siteName> is already activated at <websiteUrl>. No further provisioning is needed." Suggest next steps (Phase 5.3) and stop — do NOT proceed to Phase 2.activated is false: Proceed to Phase 2.error is present: The check could not complete. Proceed to Phase 2 (do not block the activation flow due to a failed check).Goal: Determine the site name, generate or accept a subdomain, and look up the website record ID needed for the activation API call.
Look for powerpages.config.json in the current directory or one level of subdirectories using Glob:
**/powerpages.config.jsonRead the file and extract the siteName field. If not found, ask the user for the site name using AskUserQuestion.
CRITICAL — This step is MANDATORY. You MUST ask the user about the subdomain before proceeding. Do NOT skip this step or auto-select a subdomain without user input.
Run the subdomain generator script to create a random suggestion:
node "${CLAUDE_PLUGIN_ROOT}/skills/activate-site/scripts/generate-subdomain.js"This outputs a string like site-a3f2b1. Resolve the correct site URL domain from the Cloud value obtained in Phase 1.2:
| Cloud | Site URL Domain |
|---|---|
Public | powerappsportals.com |
UsGov | powerappsportals.us |
UsGovHigh | high.powerappsportals.us |
UsGovDod | appsplatform.us |
China | powerappsportals.cn |
Present the generated subdomain to the user and ask them to accept or enter their own using AskUserQuestion:
| Question | Header | Options |
|---|---|---|
Your site subdomain will be: <suggestion> (full URL: https://<suggestion>.<siteUrlDomain>). Would you like to use this subdomain or enter your own? | Subdomain | Use <suggestion> (Recommended), Enter a custom subdomain |
If custom: The user provides their own subdomain via "Other" free text input. Validate it is lowercase, alphanumeric with hyphens only, and 3-50 characters.
Run pac pages list to get the website record ID:
pac pages listParse the output to find the website record that matches the site name. Extract the Website Record ID (GUID). If pac pages list returns no results or the command is not available, set websiteRecordId to $null — the API will create a new website record.
Goal: Present all activation parameters to the user and get explicit approval before making the API call.
Present all activation parameters to the user using AskUserQuestion:
| Question | Header | Options |
|---|---|---|
Ready to activate your Power Pages site with these settings:\n\n- Site name: <siteName>\n- Subdomain: <subdomain>.powerappsportals.com\n- Environment ID: <environmentId>\n\nProceed with activation? | Activate | Yes, activate the site (Recommended), No, cancel |
If "No": Stop the skill and inform the user they can re-run it later.
If "Yes": Proceed to Phase 4.
Goal: POST to the Power Platform websites API to start provisioning, poll until completion, and report the result.
Run the shared activation script, passing all parameters gathered in Phases 1–2:
node "${CLAUDE_PLUGIN_ROOT}/skills/activate-site/scripts/activate-site.js" --siteName "<siteName>" --subdomain "<subdomain>" --organizationId "<organizationId>" --environmentId "<environmentId>" --cloud "<cloud>" --websiteRecordId "<websiteRecordId>"Omit --websiteRecordId if it is null/empty.
The script acquires an Azure CLI token, POSTs to the websites API, extracts the Operation-Location header, and polls every 10 seconds for up to 5 minutes (refreshing the token periodically). It outputs a JSON result to stdout.
Note: This script may run for up to 5 minutes while polling. Use a Bash timeout of at least 360 seconds (6 minutes).
Evaluate the JSON output:
status value | statusCode / errorCode | Action |
|---|---|---|
Succeeded | — | Provisioning complete. The result includes siteUrl. Proceed to Phase 5. |
Failed | 400 + SubdomainConflict (or error message mentions subdomain) | Subdomain already taken. Loop back to Phase 2 action 2.2 for a new subdomain, then re-run the script. |
Failed | 401 | Token expired. Ask the user to run az login and retry. |
Failed | 403 | Insufficient permissions. Inform user they need the "Power Pages site creator" or "System Administrator" role. |
Failed | 409 | Website already exists. Inform user and suggest using /power-pages:deploy-site instead. |
Failed | 429 or 5xx | Throttling or server error. Wait 5 seconds and re-run the script once. |
Failed | other | Present the error to the user and help troubleshoot. |
Running | — | Provisioning still in progress after 5 minutes. Inform the user it may take up to 15 minutes and suggest checking the Power Platform admin center. |
error field | — | Prerequisite failure (missing args, no token). Present the error and help troubleshoot. |
siteUrl, Failed with error details, or Running with timeout advisory)Goal: Show the user the final site URL and suggest next steps.
Present the activation summary using the siteUrl from the script output:
Power Pages site activated successfully!
Site Name: <siteName>
Site URL: <siteUrl>
Environment: <environmentName> (<environmentId>)
Status: ProvisionedThe script already resolves the correct cloud-specific site URL domain, so use the siteUrl value directly.
Reference:
${CLAUDE_PLUGIN_ROOT}/references/skill-tracking-reference.md
Follow the skill tracking instructions in the reference to record this skill's usage. Use --skillName "ActivateSite".
After the summary, suggest:
/power-pages:setup-datamodel/power-pages:add-sample-dataUse TaskCreate at the start to track progress through each phase:
| Task | Description |
|---|---|
| Phase 1 | Verify Prerequisites — PAC CLI auth, Cloud detection, Azure CLI login, activation status check |
| Phase 2 | Gather Parameters — site name, subdomain, website record ID |
| Phase 3 | Confirm — user approval of activation parameters |
| Phase 4 | Activate & Poll — run activation script, handle result |
| Phase 5 | Present Summary — show site URL and next steps |
Mark each task complete with TaskUpdate as you finish each phase.
/power-pages:deploy-site instead.Begin with Phase 1: Verify Prerequisites
8ccaae8
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.