Install
openclaw skills install huawei-cloud-flexus-l-server-opsBased on Huawei Cloud Flexus L API for instance management and operations. Supports querying instance list and details, querying traffic packages, batch start/stop/reboot instances, resetting passwords, and modifying instance information. Suitable for daily operations, lifecycle management, configuration changes, traffic monitoring, and other scenarios for Flexus L instances. Triggers: Flexus L, Huawei Cloud ops, query instance, start, stop, reboot, reset password, modify info, check traffic, traffic package (中文触发词: L实例运维,查询L实例,L实例开机,L实例关机,L实例重启,L实例重置密码,查询L实例流量包).
openclaw skills install huawei-cloud-flexus-l-server-ops⚠️ Security Execution Rules (Highest Priority):
This skill provides complete operational capabilities for Huawei Cloud Flexus L instances, covering instance lifecycle management, configuration modification, monitoring queries, and other core scenarios.
OpenClaw Agent → Flexus L Ops Skill → Huawei Cloud SDK → Huawei Cloud Services
│ │ │
│ │ ├─ Flexus L (instance/lifecycle/password)
│ │ └─ BSS (traffic query)
│ │
└─ scripts/ └─ huaweicloudsdk{core,ecs,bss,config}
Core Components:
Typical Problem Scenarios:
Trigger Keywords:
| English Keyword | Chinese Keyword |
|---|---|
| Flexus L | Flexus L |
| Huawei Cloud Ops | 华为云运维 |
| Query Instance | 查询实例 |
| Start/Stop/Reboot | 开机/关机/重启 |
| Reset Password | 重置密码 |
| Update Info | 修改信息 |
| Query Traffic | 查流量 |
| Traffic Package | 流量包 |
| List All Servers | 查所有服务器 |
| My Servers | 我的服务器有哪些 |
| List All Instances | 列出所有实例 |
pip3 install huaweicloudsdkcore huaweicloudsdkecs huaweicloudsdkconfig huaweicloudsdkbss \
-i https://repo.huaweicloud.com/repository/pypi/simple
Different operations MUST use the corresponding script. Do NOT use other scripts' commands.
| Operation | Must Use Script | Correct Command | ❌ Wrong Command |
|---|---|---|---|
| Query Flexus L instances | query_instances.py | query_instances.py list | password_unified.py list |
| Query instance details | query_instances.py | query_instances.py detail -i <ID> | lifecycle.py list |
| Start/Stop/Reboot | lifecycle.py | lifecycle.py stop --instance-id <ID> | query_instances.py stop |
| Reset password | password_unified.py | password_unified.py reset --instance-id <ID> --password <pwd> | lifecycle.py reset |
| Modify server info | update_server.py | update_server.py --instance-id <ID> --name <name> | query_instances.py update |
After any lifecycle operation (start/stop/reboot), MUST query and report the final status to user.
Example feedback format:
✅ Operation completed
Instance: your-instance-name
Status: Running
Public IP: <IP>
This ensures the user knows the operation has completed successfully.
| Script | Function | Commands |
|---|---|---|
| query_instances.py | Instance query tool ⭐ | list, detail, free-resources, traffic, traffic-region |
| lifecycle.py | Lifecycle management | stop, start, reboot |
| password_unified.py | Password reset | test, list, reset |
| update_server.py | Modify server info | --name, --description, --hostname |
| Script | Function |
|---|---|
| auth.py | Authentication management |
| params.py | Parameter processing |
See Execution Flow for operation steps.
Required Parameters:
| Operation | Required Parameters | Description |
|---|---|---|
| Query Instance Details | instance-id | Instance ID |
| Start/Stop/Reboot | instance-id | Instance ID (supports multiple) |
| Reset Password | instance-id, password | Instance ID + new password |
| Modify Info | instance-id + (name/description/hostname) | Instance ID + at least one modification |
| Query Traffic by Region | target-region | Target region code |
| Query Traffic by ID | traffic_ids | Traffic package ID list |
Optional Parameters:
| Parameter | Description | Required | Default | Example |
|---|---|---|---|---|
| --region | Target region code (supports Chinese names) | No | cn-north-4 | --region cn-north-4 |
| --ak | Huawei Cloud Access Key AK (can be temporary AK) | No | HW_ACCESS_KEY env var | --ak AXXX... |
| --sk | Huawei Cloud Access Key SK (can be temporary SK) | No | HW_SECRET_KEY env var | --sk SXXX... |
| --security-token | Security token for temporary credentials (required when using temporary AK/SK) | No | HW_SECURITY_TOKEN env var | --security-token XXXX... |
Region Parameter Support:
cn-north-4North-China-Beijing4Beijing4, Guangzhou, ShanghaiGet credentials from environment variables first, automatic check, no need to ask user.
Decision Logic:
| Credential Status | Next Step |
|---|---|
| ✅ HW_ACCESS_KEY + HW_SECRET_KEY + HW_SECURITY_TOKEN exist | Execute script directly (Recommended: Temporary AK/SK authentication, higher security level, pass --ak --sk --security-token parameters) |
| ✅ HW_ACCESS_KEY + HW_SECRET_KEY exist (no Token) | Execute script directly (Permanent AK/SK authentication, pass --ak --sk parameters) |
| ❌ Environment variables not found | Prompt user to configure credentials (prefer environment variables, do NOT ask directly) |
| ❌ Authentication failed | Prompt user to check or reconfigure credentials (prefer environment variables, do NOT ask directly) |
⚠️ Security Recommendations:
Credential Missing or Authentication Failed Message:
❌ Credentials not configured or authentication failed
Please configure Huawei Cloud credentials. For security, we recommend using temporary AK/SK + Security Token method via environment variables:
- HW_ACCESS_KEY: Access Key AK
- HW_SECRET_KEY: Secret Key SK
- HW_SECURITY_TOKEN: Security Token (Recommended)
⚠️ Security Note: Temporary credentials are more secure, please prefer using them!
Note: We prioritize obtaining credentials from environment variables and NEVER ask users to input AK/SK directly. However, we still support parsing credentials if user voluntarily provides them via other methods (e.g., conversation input, config file).
After credentials are verified, ask user what operation to perform:
⚠️ Instance Validation (When user provides instance ID/name):
python3 {baseDir}/scripts/query_instances.py free-resources --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
⚠️ Important Notes:
1. Instance Type Confirmation: Before executing any operation, remind user that this skill only supports Flexus L instances
2. Server ID Guidance: If user hasn't specified a server ID to operate on, guide user to query all instances or specific server
Query all instances across regions:
python3 {baseDir}/scripts/query_instances.py list --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Query instances in specific region:
python3 {baseDir}/scripts/query_instances.py list --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Required Parameters:
python3 {baseDir}/scripts/query_instances.py detail --instance-id <ID> --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
⚠️ Error Handling: If query fails with "server not found" and user didn't specify region, tell user to check region, instance type, and ID.
Required Parameters:
python3 {baseDir}/scripts/lifecycle.py start --instance-id <ID1> --instance-id <ID2> --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
⚠️ Dangerous Operation: Must Confirm Twice
🔒 Instance Type Restriction: This operation ONLY supports Flexus L instances, NOT all ECS instances. Must verify instance type before execution.
Required Parameters:
Must confirm twice before execution:
python3 {baseDir}/scripts/lifecycle.py stop --instance-id <ID1> --instance-id <ID2> --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
⚠️ Dangerous Operation: Must Confirm Twice
🔒 Instance Type Restriction: This operation ONLY supports Flexus L instances, NOT all ECS instances. Must verify instance type before execution.
Required Parameters:
Must confirm twice before execution:
python3 {baseDir}/scripts/lifecycle.py reboot --instance-id <ID1> --instance-id <ID2> --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Required Parameters:
⚠️ Important: After resetting password, the instance MUST be rebooted for the new password to take effect.
Must confirm with user before reboot:
python3 {baseDir}/scripts/password_unified.py reset --instance-id <ID> --password <new_password> --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Reboot Command:
python3 {baseDir}/scripts/lifecycle.py reboot --instance-id <ID> --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Required Parameters:
python3 {baseDir}/scripts/update_server.py --instance-id <ID> --name "new_name" --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Option 1: Query by Traffic Package ID
Required Parameters:
⚠️ Special Note: Traffic package query uses Beijing-1 region (cn-north-1) by default, traffic package ID can be from any region
python3 {baseDir}/scripts/query_instances.py traffic <traffic_id_1> <traffic_id_2> --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
Option 2: Query by Region ⭐ Recommended
Required Parameters:
python3 {baseDir}/scripts/query_instances.py traffic-region --target-region cn-east-3 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
If user asks "how to find server ID" or "don't know server ID", first provide console lookup steps:
You can find server ID through the following ways:
Option 1: Via Huawei Cloud Console
1. Login to Huawei Cloud Console
2. Go to Flexus Application Server L instance list
3. Click instance name to enter details page
4. In basic information, click "Cloud Host VM"
5. View cloud host ID in cloud host information
6. Click copy button after ID to quickly copy
Help Document: https://support.huaweicloud.com/intl/zh-cn/flexusl_faq/faq_01_0003.html
Then append the following, offer automatic query option:
Option 2: I can also help query all servers under your account
Would you like me to list all instances under your account? I can query directly for you.
If user agrees, execute list all instances:
python3 {baseDir}/scripts/query_instances.py list --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
| Region Code | Region Name |
|---|---|
| cn-north-4 | North China-Beijing 4 |
| cn-north-1 | North China-Beijing 1 |
| cn-south-1 | South China-Guangzhou |
| cn-east-3 | East China-Shanghai 1 |
| ap-southeast-1 | China-Hong Kong |
| ap-southeast-2 | Asia Pacific-Singapore |
This skill supports automatic region name conversion, can use Chinese names or English codes:
# Use region code
python3 {baseDir}/scripts/query_instances.py list --region cn-north-4 --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
# Use region name (auto-convert)
python3 {baseDir}/scripts/query_instances.py list --region "North-China-Beijing4" --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
python3 {baseDir}/scripts/query_instances.py list --region "Beijing4" --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
python3 {baseDir}/scripts/query_instances.py list --region "Guangzhou" --ak "$HW_ACCESS_KEY" --sk "$HW_SECRET_KEY" [--security-token "$HW_SECURITY_TOKEN"]
⚠️ Traffic package query uses Beijing-1 region (cn-north-1) by default
This skill includes the following reference documents: