Install
openclaw skills install ucs-policy-governorHuawei Cloud UCS (Universal Cloud Service) policy governance and compliance management skill using hcloud CLI. Use this skill when the user wants to: (1) manage UCS policy instances - create/update/query/delete, (2) manage UCS policy definitions - query/list, (3) enable/disable policies on clusters or fleet groups, (4) check policy enforcement job status, (5) audit fleet compliance and review policy enforcement status. Trigger: user mentions "UCS policy", "UCS 策略", "UCS governance", "UCS 治理", "UCS compliance", "UCS 合规", "policy instance", "策略实例", "policy definition", "策略定义", "enable policy", "启用策略", "disable policy", "禁用策略", "fleet compliance", "舰队合规", "policy audit", "策略审计", "UCS 策略管理", "UCS 合规治理", "policy governance", "策略治理"
openclaw skills install ucs-policy-governorThis skill provides policy governance and compliance management capabilities for Huawei Cloud UCS (Universal Cloud Service) using the hcloud CLI, covering policy instance lifecycle, policy definitions, policy enforcement, and compliance auditing.
Architecture: hcloud CLI → UCS Service API → PolicyInstance/PolicyDefinition/PolicyJob resources
Related Skills:
ucs-cluster-onboarding-manager - Cluster registration, lifecycle, fleet grouping, and access managementCapabilities:
Typical Use Cases:
hcloud version to verify installationprintf "y\n" | hcloud version to accept privacy statementecho $HUAWEI_CLOUD_AK or echo $HUAWEI_CLOUD_SK to check credentialsHUAWEI_CLOUD_AK, HUAWEI_CLOUD_SK, HUAWEI_CLOUD_REGIONConfiguration Method (Environment Variables Only):
export HUAWEI_CLOUD_AK=<your-ak>
export HUAWEI_CLOUD_SK=<your-sk>
export HUAWEI_CLOUD_REGION=cn-north-4
⚠️ Important Security Notes:
| API Action | Permission | Purpose |
|---|---|---|
ucs:clusterPolicyInstance:create | Create policy | Create cluster-level policy instances |
ucs:clusterGroupPolicyInstance:create | Create policy | Create fleet group-level policy instances |
ucs:policyInstance:update | Update policy | Modify policy instances |
ucs:policyInstance:get | Get policy | View policy instance details |
ucs:policyInstance:delete | Delete policy | Remove policy instances |
ucs:policyInstance:list | List policies | List all policy instances |
ucs:policyDefinition:list | List definitions | List available policy definitions |
ucs:policyDefinition:get | Get definition | View policy definition details |
ucs:clusterPolicy:enable | Enable policy | Enable cluster-level policy enforcement |
ucs:clusterPolicy:disable | Disable policy | Disable cluster-level policy enforcement |
ucs:clusterGroupPolicy:enable | Enable policy | Enable fleet group-level policy enforcement |
ucs:clusterGroupPolicy:disable | Disable policy | Disable fleet group-level policy enforcement |
ucs:policyJob:list | List jobs | List policy enforcement jobs |
ucs:policyJob:get | Get job | View policy enforcement job details |
See IAM Permission Policies for complete policy JSON.
Permission Failure Handling:
references/iam-policies.mdSee Task: Policy Management for detailed workflows.
# Create a cluster-level policy instance
hcloud UCS CreateClusterPolicyInstance --clusterid=<ucs-cluster-id> --constraintTemplateID=<template-id> --enforcementAction=deny --namespaces.1=default --namespaces.2=production --parameters='{"maxReplicas":"3"}' --cli-region=cn-north-4
# Create a fleet group-level policy instance
hcloud UCS CreateClusterGroupPolicyInstance --clustergroupid=<fleet-group-id> --constraintTemplateID=<template-id> --enforcementAction=warn --parameters='{"cpuLimit":"2"}' --cli-region=cn-north-4
# Update a policy instance
hcloud UCS UpdatePolicyInstance --policyinstanceid=<instance-id> --constraintTemplateID=<new-template-id> --enforcementAction=warn --parameters='{"cpuLimit":"4"}' --cli-region=cn-north-4
# Show policy instance details
hcloud UCS ShowPolicyInstance --policyinstanceid=<instance-id> --cli-region=cn-north-4
# Delete a policy instance
hcloud UCS DeletePolicyInstance --policyinstanceid=<instance-id> --cli-region=cn-north-4
# List all policy instances (no filter parameters available)
hcloud UCS ListPolicyInstances --cli-region=cn-north-4
# List all available policy definitions (no filter parameters available)
hcloud UCS ListPolicyDefinitions --cli-region=cn-north-4
# Show policy definition details
hcloud UCS ShowPolicyDefinition --policydefinitionid=<definition-id> --cli-region=cn-north-4
# Enable a policy on a cluster
hcloud UCS EnableClusterPolicy --clusterid=<ucs-cluster-id> --cli-region=cn-north-4
# Enable a policy on a fleet group
hcloud UCS EnableClusterGroupPolicy --clustergroupid=<fleet-group-id> --cli-region=cn-north-4
# Enable a policy on a cluster with retry
hcloud UCS EnableClusterPolicy --clusterid=<ucs-cluster-id> --retry=true --cli-region=cn-north-4
# Disable a policy on a cluster
hcloud UCS DisableClusterPolicy --clusterid=<ucs-cluster-id> --cli-region=cn-north-4
# Disable a policy on a fleet group
hcloud UCS DisableClusterGroupPolicy --clustergroupid=<fleet-group-id> --cli-region=cn-north-4
See Task: Compliance Audit for detailed workflows.
# List policy enforcement jobs
hcloud UCS ListPolicyJobs --cli-region=cn-north-4
# List policy enforcement jobs filtered by kind
hcloud UCS ListPolicyJobs --kind=EnablePolicy --cli-region=cn-north-4
# Show a specific policy enforcement job
hcloud UCS ShowPolicyJob --jobid=<job-id> --cli-region=cn-north-4
| Parameter | Required/Optional | Description | Default |
|---|---|---|---|
--cli-region | Required | Huawei Cloud region ID | Config value or HUAWEI_CLOUD_REGION |
| Parameter | Required | Description | Constraints |
|---|---|---|---|
--clusterid | Yes* | Target UCS cluster ID | Required for CreateClusterPolicyInstance |
--clustergroupid | Yes* | Target fleet group ID | Required for CreateClusterGroupPolicyInstance |
--constraintTemplateID | No | Constraint template ID | References existing constraint template |
--enforcementAction | No | Enforcement action | warn or deny |
--namespaces.[N] | No | Target namespaces array | Array index starting from 1 |
--parameters | No | Policy parameters object | JSON object string |
--policyinstanceid | Yes | Instance ID (for get/update/delete) | Used in Show/Update/Delete operations |
--retry | No | Retry flag for enable | Query param for EnableClusterPolicy/EnableClusterGroupPolicy |
*Note: --clusterid is required for cluster-level operations (CreateClusterPolicyInstance, EnableClusterPolicy, DisableClusterPolicy). --clustergroupid is required for fleet group-level operations (CreateClusterGroupPolicyInstance, EnableClusterGroupPolicy, DisableClusterGroupPolicy).
| Parameter | Required | Description | Constraints |
|---|---|---|---|
--policydefinitionid | Yes | Definition ID | Used in ShowPolicyDefinition |
| Parameter | Required | Description | Constraints |
|---|---|---|---|
--jobid | Yes | Policy job ID | Used in ShowPolicyJob |
--kind | No | Job type filter | Default EnablePolicy, used in ListPolicyJobs |
[to be verified — UCS responses follow k8s-style format based on verified ShowClusterList/ListPolicyDefinitions patterns]
UCS API returns Kubernetes-style objects, not flat JSON. Based on verified ShowClusterList and ListPolicyDefinitions responses, policy instance responses likely use a k8s-style object structure with kind, apiVersion, metadata, spec, and status fields rather than flat fields like id, constraintTemplateID, enforcementAction.
Key Fields (expected, format to be verified):
metadata.uid (not flat id)spec.constraintTemplateIDspec.enforcementAction (warn or deny)status.phase (Enabled, Disabled, Pending)Response Example (verified):
{
"items": [
{
"kind": "ConstraintTemplate",
"apiVersion": "templates.gatekeeper.sh/v1beta1",
"metadata": {
"name": "k8srequiredresources",
"uid": "3b900254-0086-11ee-924e-0255ac1000d3",
"creationTimestamp": "2023-06-01T14:11:41Z",
"annotations": {
"name-chinese": "K8sRequiredResources",
"tag-chinese": "集群安全策略",
"description-chinese": "..."
}
},
"spec": {
"type": "general",
"officialTag": "ClusterSecurityPolicies",
"level": "1",
"targetKind": "Pod",
"official": true,
"description": "Requires containers to have defined resources set...",
"constraintTemplate": {
"kind": "ConstraintTemplate",
"apiVersion": "templates.gatekeeper.sh/v1",
"metadata": { "name": "k8srequiredresources" },
"spec": {
"crd": {
"spec": {
"names": { "kind": "K8sRequiredResources" },
"validation": { "openAPIV3Schema": { "properties": {} } }
}
},
"targets": [
{
"target": "admission.k8s.gatekeeper.sh",
"rego": "...",
"libs": []
}
]
}
}
}
}
]
}
Key Fields:
metadata.name: Constraint template name (used as constraintTemplateID in CreateClusterPolicyInstance, not flat id)metadata.uid: Definition UUIDspec.officialTag: Policy category/tag (not flat category)spec.level: Severity level (not flat severity)spec.targetKind: Target resource type (e.g., Pod)spec.description: Policy descriptionspec.constraintTemplate.spec.crd.spec.validation.openAPIV3Schema.properties: Parameter definitions (not flat parameters array)spec.type: Policy type (e.g., general)spec.official: Whether this is an official (built-in) policyResponse Example (verified for empty result):
When no jobs exist, returns { "items": null }. When populated, likely k8s-style objects based on verified UCS pattern:
{
"items": null
}
[to be verified for populated response — likely k8s-style objects with kind, apiVersion, metadata, spec, status fields]
Key Fields (expected, format to be verified):
metadata.uid (not flat jobid)spec.kind (EnablePolicy, etc.)status.phase (Success, Failed, InProgress)See Verification Method for step-by-step verification.
| Region Name | Region ID |
|---|---|
| North China - Beijing 4 | cn-north-4 |
| North China - Beijing 1 | cn-north-1 |
| East China - Shanghai 1 | cn-east-3 |
| East China - Shanghai 2 | cn-east-2 |
| South China - Guangzhou | cn-south-1 |
| South China - Shenzhen | cn-south-4 |
| Southwest China - Guiyang 1 | cn-southwest-2 |
| Asia Pacific - Bangkok | ap-southeast-2 |
| Asia Pacific - Singapore | ap-southeast-1 |
| Asia Pacific - Hong Kong | ap-southeast-3 |
| Europe - Paris | eu-west-0 |
--constraintTemplateID to reference constraint templates, not --policy_definition_idCreateClusterGroupPolicyInstance for consistent enforcementEnableClusterPolicy, then roll out to production fleet groups using EnableClusterGroupPolicyListPolicyJobs and ShowPolicyJob to monitor enforcement task statuswarn for initial rollout (violations reported but not blocked), then switch to deny for strict enforcementDisableClusterPolicy/DisableClusterGroupPolicy before deleting to prevent sudden enforcement gaps--namespaces.[N] to scope policy enforcement to specific namespaces| Document | Description |
|---|---|
| UCS Policy API Guide | hcloud UCS policy API reference |
| IAM Permission Policies | Required permissions and policy JSON |
| Verification Method | Step-by-step verification |
| Common Pitfalls | Troubleshooting guides |
| Task: Policy Management | Policy instance CRUD workflows |
| Task: Compliance Audit | Compliance and audit workflows |
hcloud UCS <Operation> formatCreateClusterPolicyInstance for cluster-level and CreateClusterGroupPolicyInstance for fleet group-level policiesEnableClusterPolicy/DisableClusterPolicy for clusters and EnableClusterGroupPolicy/DisableClusterGroupPolicy for fleet groupsListPolicyJobs and ShowPolicyJob to check enforcement task status--cli-region is availableSee Common Pitfalls & Solutions for detailed troubleshooting guides.
Quick Reference:
| Pitfall | Symptom | Quick Fix |
|---|---|---|
| Wrong create operation | Create fails with wrong scope | Use CreateClusterPolicyInstance for clusters, CreateClusterGroupPolicyInstance for fleet groups |
| Constraint template not found | Create fails | Use ListPolicyDefinitions to find valid template ID |
| Cluster not registered | EnableClusterPolicy fails | Register cluster with ucs-cluster-onboarding-manager |
| Fleet group empty | Policy not enforced anywhere | Add clusters to fleet group first |
| Wrong param names | Command fails (underscore vs camelCase) | Use --policyinstanceid not --instance_id, --clusterid not --cluster_id |
| GetPolicyAssignment used | Operation not found | Use ListPolicyJobs/ShowPolicyJob instead |
| List filter params used | Unexpected behavior | ListPolicyInstances/ListPolicyDefinitions have no filter params, only --cli-region |