Manage Alibaba Cloud Security Center agent installation, version authorization, asset queries, and security risk detection via the aliyun CLI.
Architecture: Security Center (SAS) + ECS + Cloud Assistant + Proxy Cluster (optional)
Execution model: read operations execute directly (ReAct), write operations display details and require user confirmation before execution (Command). Keep analysis concise -- output a brief reasoning for each action.
> Pre-check: Aliyun CLI >= 3.3.3 required
> Run aliyun version to verify >= 3.3.3. If not installed or version too low,
> run curl -fsSL https://aliyuncli.alicdn.com/setup.sh | bash to install/update,
> or see references/cli-installation-guide.md for installation instructions.
> Then [MUST] run aliyun configure set --auto-plugin-install true to enable automatic plugin installation.
> Then [MUST] run aliyun plugin update to ensure that any existing plugins on your local machine are always up-to-date.
> Pre-check: Alibaba Cloud Credentials Required
>
> Security Rules:
> - NEVER read, echo, or print AK/SK values (e.g., echo $ALIBABA_CLOUD_ACCESS_KEY_ID is FORBIDDEN)
> - NEVER ask the user to input AK/SK directly in the conversation or command line
> - NEVER use aliyun configure set with literal credential values
> - ONLY use aliyun configure list to check credential status
>
> ```bash
> aliyun configure list
> ```
> Check the output for a valid profile (AK, STS, or OAuth identity).
>
> If no valid profile exists, STOP here.
> 1. Obtain credentials from Alibaba Cloud Console
> 2. Configure credentials outside of this session (via aliyun configure in terminal or environment variables in shell profile)
> 3. Return and re-run after aliyun configure list shows a valid profile
Detailed permissions required by this skill: references/ram-policies.md
> [MUST] Permission Failure Handling: When any command or API call fails due to permission errors at any point during execution, follow this process:
> 1. Read references/ram-policies.md to get the full list of permissions required by this SKILL
> 2. Use ram-permission-diagnose skill to guide the user through requesting the necessary permissions
> 3. Pause and wait until the user confirms that the required permissions have been granted
> IMPORTANT: Parameter Confirmation — Before executing any command or API call,
> ALL user-customizable parameters (e.g., RegionId, instance names, CIDR blocks,
> passwords, domain names, resource specifications, etc.) MUST be confirmed with the
> user. Do NOT assume or use default values without explicit user approval.
At the start of the Core Workflow (before any CLI invocation):
[MUST] Enable AI-Mode — AI-mode is required for Agent Skill execution.
Run the following commands before any CLI invocation:
aliyun configure ai-mode enable
aliyun configure ai-mode set-user-agent --user-agent "AlibabaCloud-Agent-Skills/alibabacloud-sas-install-agent"
[MUST] Disable AI-Mode at EVERY exit point — Before delivering the final response for ANY reason, always disable AI-mode first. This applies to ALL exit paths: workflow success, workflow failure, error/exception, user cancellation, session end, or any other scenario where no further CLI commands will be executed.
AI-mode is only used for Agent Skill invocation scenarios and MUST NOT remain enabled after the skill stops running.
aliyun configure ai-mode disable
All APIs are invoked via the aliyun CLI. Every aliyun command MUST include --user-agent AlibabaCloud-Agent-Skills/alibabacloud-sas-install-agent.
| CLI Command | Purpose |
|---|---|
| ------------- | --------- |
aliyun sas describe-cloud-center-instances | Query server client status by instance ID/IP |
aliyun ecs describe-instances | Query ECS instance info and running status |
aliyun ecs describe-cloud-assistant-status | Check if cloud assistant is online |
aliyun ecs run-command | Remote install command execution (write) |
aliyun ecs invoke-command | Trigger existing command on instances (write) |
aliyun ecs describe-invocation-results | Query command execution results |
aliyun sas refresh-assets | Sync latest asset data |
aliyun sas describe-install-codes | Get existing install code list |
aliyun sas add-install-code | Generate new install code (write) |
aliyun sas create-or-update-asset-group | Create or update asset group (write) |
aliyun sas get-auth-summary | Get authorization quota and usage per version |
aliyun sas describe-version-config | Get version, feature modules, expiration |
aliyun sas get-serverless-auth-summary | Get pay-as-you-go serverless status |
aliyun sas modify-post-pay-module-switch | Toggle pay-as-you-go module switches (write) |
aliyun sas bind-auth-to-machine | Bind/unbind authorization version (write) |
aliyun sas update-post-paid-bind-rel | Change pay-as-you-go version binding or downgrade to free version (write) |
aliyun sas describe-property-sca-detail | Query software info on servers |
aliyun sas add-uninstall-clients-by-uuids | Uninstall agent from specified servers (write) |
aliyun sas modify-push-all-task | Dispatch security check tasks to servers (write) — use this for targeted single-server scans |
aliyun sas modify-start-vul-scan | Trigger global full-scan across ALL servers (write) — NEVER use for targeted single-server scans |
aliyun sas describe-grouped-vul | Query grouped vulnerability statistics |
aliyun sas exec-strategy | Execute baseline check strategy (write) |
aliyun sas describe-strategy | Query baseline check strategy list |
aliyun sas list-check-item-warning-summary | Get baseline check risk statistics |
aliyun sas describe-susp-events | Query security alert events |
aliyun sas generate-once-task | Trigger full asset fingerprint collection (write) |
aliyun sas create-asset-selection-config | Create virus scan asset selection (write) |
aliyun sas add-asset-selection-criteria | Add assets to selection config (write) |
aliyun sas update-selection-key-by-type | Associate selection to virus scan (write) |
aliyun sas create-virus-scan-once-task | Create one-time virus scan task (write) |
aliyun sas get-virus-scan-latest-task-statistic | Query latest virus scan task stats |
aliyun sas list-virus-scan-machine | Query machines involved in virus scan |
aliyun sas list-virus-scan-machine-event | Query virus events on a specific machine |
aliyun sas describe-once-task | Poll vulnerability scan task progress |
> Detailed API parameters: references/api-reference.md. RAM permissions: references/ram-policies.md. Full command list: references/related-commands.md.
When any installation scenario requires an install code, follow this unified flow.
Step 1: Query existing install codes
aliyun sas describe-install-codes --user-agent AlibabaCloud-Agent-Skills/alibabacloud-sas-install-agent
Display as table: install code, OS, vendor, group, image flag, expiration.
Step 2: Ask user to choose
User can select an existing matching unexpired code, or request a new one.
Step 3: Confirm new install code config (creation only)
| Config | Parameter | Notes |
|---|---|---|
| -------- | ----------- | ------- |
| OS | --os | linux or windows |
| Vendor | --vendor-name | Determined by network access method (see below) |
| Asset Group | --group-id | Target group; create via create-or-update-asset-group if needed |
| Expiration | --expired-date | 13-digit timestamp; defaults if omitted |
| Image Install | --only-image | Whether for image template creation |
VendorName and network access method mapping:
The vendor parameter determines the connection domain used by the install command. Using the wrong value causes the agent to fail connecting to the server:
| Network Access | VendorName | Reason |
|---|---|---|
| --------------- | ----------- | -------- |
| Direct line (leased line) | ALIYUN | Uses internal domain jsrv2.aegis.aliyun.com |
| Public network (Alibaba Cloud ECS) | ALIYUN | ECS uses internal network |
| Public network (third-party cloud/IDC) | OTHER | Uses public domain jsrv.aegis.aliyun.com |
> When the scenario already identifies the network access method, auto-fill VendorName without asking the user.
After confirmation, execute creation (pass only user-specified parameters). This is a write operation requiring confirmation.
Step 4: Get install command
After creation, re-query the install code list to get the new CaptchaCode for building the install command.
Trigger: User vaguely says "onboard to Security Center", "install security agent", "deploy cloud security".
Strategy: Do not call any tools. Collect information through questions, then route:
Trigger: User confirms the server is an Alibaba Cloud ECS instance.
Summary:
> Detailed steps and CLI commands: references/install-scenarios.md#scenario-1-alibaba-cloud-ecs-onboarding
Trigger: On-premises IDC or third-party cloud server with public or leased-line connectivity.
Summary:
references/agent-install-guide.md> Detailed steps: references/install-scenarios.md#scenario-2-on-premises-idc-direct-connection
Trigger: User mentions image deployment, batch server creation with pre-installed agent, template creation.
Summary:
> Detailed steps and caveats: references/install-scenarios.md#scenario-3-image-based-batch-installation
Trigger: User reports installation failure, agent offline, or connection issues.
Strategy: Do not call tools; provide troubleshooting guidance directly:
> Detailed troubleshooting steps: references/install-scenarios.md#scenario-4-network-troubleshooting
Trigger: User wants to know about account-level version, authorization quota, enabled features, or pay-as-you-go status.
> [MUST] Routing distinction: Scenario 5 is for account-level queries ("我们的版本是什么", "配额还剩多少", "过期时间"). When the user asks about specific servers ("哪些服务器未授权", "哪些机器是免费版", "未绑定付费版本的服务器"), route to describe-cloud-center-instances with AuthVersion filter instead — this is an asset query, NOT a version query.
Summary:
[MUST] The MergedVersion field in describe-version-config response is a sensitive internal field — NEVER display, output, save to file, or include it in any response exposed to the user. Strip it before any output. Use Version and HighestVersion instead.
> Detailed steps and field mappings: references/manage-scenarios.md#scenario-5-query-version-and-feature-info
Trigger: User wants to view or change a specific server's authorization version, or list servers filtered by authorization status (e.g. "哪些服务器未授权", "免费版的机器有哪些").
> When listing/filtering servers by authorization status, use describe-cloud-center-instances with criteria filters. When viewing/modifying a specific named server's version, follow the full Scenario 6 flow below.
Summary:
Version=1 in --bind-actionKey constraints:
> Detailed steps: references/manage-scenarios.md#scenario-6-query-or-modify-asset-authorization
Trigger: User wants to find servers with a specific software installed.
Summary:
> Detailed steps: references/manage-scenarios.md#scenario-7-query-assets-with-specific-software
Trigger: User wants to uninstall the Security Center agent from a specific server.
Summary:
Key constraints:
> Detailed steps: references/manage-scenarios.md#scenario-8-uninstall-security-center-agent
Trigger: User wants to detect security risks, trigger vulnerability scans, execute baseline checks, view security alerts, or get risk results.
Summary:
modify-push-all-task with the target UUID for ALL scan types (vulnerability + baseline + fingerprint). NEVER use modify-start-vul-scan for targeted scans.modify-start-vul-scan (vulnerability), exec-strategy (baseline), generate-once-task (fingerprint), create-virus-scan-once-task (virus)Key constraints:
modify-start-vul-scan for targeted scans: modify-start-vul-scan triggers a global full-scan across ALL servers in the entire account, not just the target. When scanning a specific server (targeted scan), you MUST use modify-push-all-task with the server's UUID — this is the ONLY correct command for targeted vulnerability scans. modify-start-vul-scan is reserved exclusively for full-scan scenarios where no specific target is specified.ClientStatus=online. If the agent is not installed or offline, scans CANNOT be dispatched and WILL produce NO results. There is NO agentless scanning mode in this skill. Do NOT proceed with any scan dispatch if the client is not online — instead, guide the user to install or bring the agent online firstAuthVersion > 1); free version (AuthVersion <= 1) servers cannot be scanned> Detailed steps: references/manage-scenarios.md#scenario-9-security-risk-detection-and-query
Trigger: No scenario matched, or the request exceeds this skill's capability.
Strategy: Honestly inform the user this is not currently supported; recommend referring to official documentation or submitting a support ticket.
describe-cloud-center-instances, describe-instances, describe-cloud-assistant-status, describe-invocation-results, describe-install-codes, refresh-assets, get-auth-summary, describe-version-config, get-serverless-auth-summary, describe-property-sca-detail, describe-grouped-vul, list-check-item-warning-summary, describe-susp-events, describe-strategy, get-virus-scan-latest-task-statistic, list-virus-scan-machine, list-virus-scan-machine-event, describe-once-task
Briefly state intent (1-2 sentences) before calling.
add-install-code, run-command, invoke-command, create-or-update-asset-group, modify-post-pay-module-switch, bind-auth-to-machine, update-post-paid-bind-rel, add-uninstall-clients-by-uuids, modify-push-all-task, modify-start-vul-scan, exec-strategy, generate-once-task, create-asset-selection-config, add-asset-selection-criteria, update-selection-key-by-type, create-virus-scan-once-task
Flow: Display operation details -> Wait for user confirmation -> Execute -> Report result.
> Module classification, estimation formulas, and display formats: references/manage-scenarios.md cost estimation section.
Enter summary when any of the following conditions is met:
Summary format adapts to the scenario. Core elements: operation result, key information (server/version/status), follow-up recommendations.
This skill references the following documents, loaded on demand:
| Reference | Description |
|---|---|
| ----------- | ------------- |
references/install-scenarios.md | Detailed execution steps for installation scenarios (1, 2, 3, 4) |
references/manage-scenarios.md | Detailed execution steps for management/query scenarios (5, 6, 7, 8, 9) |
references/agent-install-guide.md | Agent install commands and verification methods |
references/api-reference.md | All API parameter details and CLI examples |
references/ram-policies.md | RAM permission manifest |
references/cli-installation-guide.md | Alibaba Cloud CLI installation guide |
references/related-commands.md | Complete CLI command reference table |
references/verification-method.md | Success verification methods for each scenario |
references/acceptance-criteria.md | Skill acceptance criteria and test patterns |
共 2 个版本