Skill flagged — suspicious patterns detected

ClawHub Security flagged this skill as suspicious. Review the scan results before using.

Alibabacloud Opensearch App Manage

v0.0.2

Alibaba Cloud OpenSearch instance management skill. Create and query OpenSearch instances. Note: OpenSearch instance and OpenSearch app group are synonymous...

0· 62·0 current·0 all-time
byalibabacloud-skills-team@sdk-team

Install

OpenClaw Prompt Flow

Install with OpenClaw

Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for sdk-team/alibabacloud-opensearch-app-manage.

Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "Alibabacloud Opensearch App Manage" (sdk-team/alibabacloud-opensearch-app-manage) from ClawHub.
Skill page: https://clawhub.ai/sdk-team/alibabacloud-opensearch-app-manage
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.

Command Line

CLI Commands

Use the direct CLI path if you want to install manually and keep every step visible.

OpenClaw CLI

Canonical install target

openclaw skills install sdk-team/alibabacloud-opensearch-app-manage

ClawHub CLI

Package manager switcher

npx clawhub@latest install alibabacloud-opensearch-app-manage
Security Scan
Capability signals
CryptoCan make purchasesRequires OAuth tokenRequires sensitive credentials
These labels describe what authority the skill may exercise. They are separate from suspicious or malicious moderation verdicts.
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Suspicious
medium confidence
!
Purpose & Capability
The skill claims to manage Alibaba Cloud OpenSearch (create/list/describe instances) and the SKILL.md explicitly requires the Aliyun CLI and valid Alibaba Cloud credentials. However the registry metadata declares no required binaries, no primary credential, and no required env vars. That mismatch (metadata says 'none' but instructions require aliyun CLI and account credentials) is incoherent and should be fixed by the publisher.
Instruction Scope
The runtime instructions stay within the stated purpose (create/list/describe app groups) and do not instruct arbitrary file reads or sending data to unknown remote endpoints. They do require changing local CLI configuration (enable ai-mode, set user-agent, enable auto-plugin-install) and require verifying credentials exist via `aliyun configure list`. The doc explicitly forbids echoing AK/SK or accepting credentials in chat, which is good. Still, enabling automatic plugin installs and running plugin updates grants the CLI permission to fetch and execute plugins — this is relevant to scope and worth reviewing.
Install Mechanism
There is no formal install spec in the package metadata, but the SKILL.md instructs running a remote install script via `curl -fsSL https://aliyuncli.alicdn.com/setup.sh | bash` and also provides wget/tar examples. Using the vendor CDN (alicdn.com) is standard for Alibaba, but recommending a curl|bash pattern is higher-risk and should be executed manually by users who trust the source. The lack of an install spec in metadata (while instructing installs in docs) is an inconsistency.
!
Credentials
The skill clearly requires Alibaba Cloud credentials (AK/SK, STS, or profile) to operate, and the docs describe environment variables (ALIBABA_CLOUD_ACCESS_KEY_ID, etc.) and CLI profiles as valid sources. However the registry metadata declares no required environment variables or primary credential. This omission is disproportionate and may mislead users into installing a skill without realizing it needs sensitive cloud credentials to run.
Persistence & Privilege
The skill does not request 'always: true' and has no code that persists across agents. It does instruct changing the Aliyun CLI configuration (enable ai-mode, set user-agent, enable auto-plugin-install), which modifies local CLI behavior for the duration of operations and may persist until reverted. The SKILL.md instructs to disable ai-mode after use, but enabling auto-plugin-install may have lingering effects; users should be aware of these local config changes.
What to consider before installing
Key things to consider before installing/using this skill: - Metadata mismatch: The package metadata does not declare that the Aliyun CLI or Alibaba Cloud credentials are required, but the SKILL.md clearly does. Treat this as a packaging error; the skill will need access to your Alibaba credentials to work. - Do not paste credentials into chat: The documentation forbids sending AK/SK in conversation — follow that. Configure credentials via aliyun configure, environment variables, or a named profile instead. - Install the CLI manually and cautiously: The docs suggest running a remote install script (curl | bash) from alicdn.com. If you trust Alibaba's CDN, you can use it, but best practice is to review the script before running it or install via your package manager/Homebrew where possible. - Be aware of config changes: The skill asks you to enable ai-mode and auto-plugin-install and to update plugins. These change local CLI behavior and can cause the CLI to auto-download plugins in future runs. Revert or audit these settings if you are unsure. - Principle of least privilege: Create/attach a RAM policy with only the required permissions (opensearch:CreateAppGroup, ListAppGroups, DescribeAppGroup) and avoid using root credentials. - Ask the publisher for fixes: Prefer a skill package that declares required binaries and the primaryEnv in metadata, and that provides an install spec (or explicitly labels itself instruction-only). If you cannot verify the source/publisher, treat this as higher risk. What would change this assessment: If the publisher updates the registry metadata to list the Aliyun CLI as a required binary and declares the expected credential sources (or a primaryEnv), and if the documentation gave a safer install path (e.g., pkg manager or checksumed release) instead of unexamined curl|bash, this would reduce the concerns and could become 'benign'.

Like a lobster shell, security has layers — review code before you run it.

latestvk97fdm4chpez8yg5avkd5p47tn85fg6w
62downloads
0stars
2versions
Updated 4h ago
v0.0.2
MIT-0

OpenSearch Instance Management

Manage Alibaba Cloud OpenSearch instances, including creation and query operations.

Terminology: OpenSearch instance and OpenSearch app group are synonymous. This document uses "instance" uniformly.

Scenario Description

OpenSearch is Alibaba Cloud's intelligent search service. This skill covers core instance management operations:

  1. Create Instance - Create a new OpenSearch instance
  2. List Instances - Get the list of instances under the current account
  3. Describe Instance - Get detailed information of a specific instance

Architecture: OpenSearch Instance (AppGroup)

Alibaba Cloud OpenSearch Instance Management
├── CreateAppGroup     (Create Instance)
├── DescribeAppGroup   (Describe Instance)
└── ListAppGroups      (List Instances)

Installation

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 update, or see references/cli-installation-guide.md for installation instructions.

Pre-check: Aliyun CLI plugin update required

[MUST] run aliyun configure set --auto-plugin-install true to enable automatic plugin installation. [MUST] run aliyun plugin update to ensure that any existing plugins are always up-to-date.

# Install/Upgrade Aliyun CLI
curl -fsSL https://aliyuncli.alicdn.com/setup.sh | bash
aliyun version  # Ensure >= 3.3.3

# Enable auto plugin installation
aliyun configure set --auto-plugin-install true

# Update plugins
aliyun plugin update

[MUST] CLI User-Agent — Every aliyun CLI command invocation must include: --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

[MUST] AI-Mode — Before executing CLI commands, run:

  1. aliyun configure ai-mode enable
  2. aliyun configure ai-mode set-user-agent --user-agent "AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage" After all CLI operations complete, run: aliyun configure ai-mode disable

Authentication

Pre-check: Alibaba Cloud Credentials Required

Security Rules (MUST FOLLOW):

  • NEVER read, echo, or print AK/SK values
  • NEVER ask the user to input AK/SK directly in the conversation
  • NEVER use aliyun configure set with literal credential values
  • NEVER accept AK/SK provided directly by users in the conversation
  • ONLY read credentials from environment variables or pre-configured CLI profiles

⚠️ CRITICAL: Handling User-Provided Credentials

If a user attempts to provide AK/SK directly (e.g., "My AK is xxx, SK is yyy"):

  1. STOP immediately - Do NOT execute any command
  2. Reject the request politely with the following message:
    For your account security, please do not provide Alibaba Cloud AccessKey ID and AccessKey Secret directly in the conversation.
    
    Please use the following secure methods to configure credentials:
    
    Method 1: Interactive configuration via aliyun configure (Recommended)
        aliyun configure
        # Enter AK/SK as prompted, credentials will be securely stored in local config file
    
    Method 2: Configure via environment variables
        export ALIBABA_CLOUD_ACCESS_KEY_ID=<your-access-key-id>
        export ALIBABA_CLOUD_ACCESS_KEY_SECRET=<your-access-key-secret>
    
    After configuration, please retry your request.
    
  3. Do NOT proceed with any Alibaba Cloud operations until credentials are properly configured

Check CLI configuration:

   aliyun configure list

Check the output for a valid profile (AK, STS, or OAuth identity).

If no valid credentials exist, STOP here.


RAM Permissions

[MUST] RAM Permission Pre-check: Before executing any operation, ensure the current user has the required RAM permissions. See references/ram-policies.md for detailed permission list.


Parameter Confirmation

IMPORTANT: Parameter Confirmation — Before executing any command or API call, ALL user-customizable parameters (e.g., instance name, instance type, charge type, quota spec, etc.) MUST be confirmed with the user. Do NOT assume or use default values without explicit user approval.

Required Parameters

ParameterRequiredDescriptionDefault
nameYesInstance nameNone
typeYesInstance type: standard (High-performance) / enhanced (Industry Algorithm)None
chargeTypeNoCharge type: POSTPAY / PREPAYPOSTPAY
quota.specYesSpec type (see table below)None
quota.docSizeYesStorage capacity (GB)None
quota.computeResourceYesCompute resource (LCU)None
domainNoIndustry type (required for enhanced type, see table below)general
orderConditionalSubscription order info (required when PREPAY)None
order.durationConditionalSubscription period quantityNone
order.pricingCycleConditionalPeriod unit: Year / MonthNone
order.autoRenewNoAuto-renewalfalse

Spec Types

Spec CodeDescription
opensearch.share.commonShared Common
opensearch.private.commonDedicated Common
opensearch.private.computeDedicated Compute
opensearch.private.storageDedicated Storage

Industry Types (for enhanced type only)

Industry CodeDescription
generalGeneral (default)
ecommerceE-commerce
esportsGaming
communityContent Community
educationEducation

Core Workflow

Note: OpenSearch APIs use ROA (RESTful) style. You can use --body to specify the HTTP request body as a JSON string. See examples in each task below.

Idempotency: For write operations (create, restart, delete, etc.), you MUST use --client-token parameter for idempotency.

  • Use a UUID format unique identifier as clientToken
  • When request times out or fails, you can safely retry with the same clientToken; recommend waiting 10s before retry
  • Repeated requests with the same clientToken will not execute the operation multiple times
  • Generation: uuidgen (macOS/Linux) or [guid]::NewGuid() (PowerShell)

Task 1: Create OpenSearch Instance

# Generate idempotency token
CLIENT_TOKEN=$(uuidgen)

aliyun opensearch create-app-group \
  --client-token "$CLIENT_TOKEN" \
  --body '{
    "name": "<instance_name>",
    "type": "<standard|enhanced>",
    "chargeType": "<POSTPAY|PREPAY>",
    "quota": {
      "docSize": <storage_GB>,
      "computeResource": <compute_LCU>,
      "spec": "<spec_type>"
    }
  }' \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Optional Parameters (add in body):

  • domain - Industry type (only for enhanced type): general (default) / ecommerce / esports / community / education

Idempotency and Dry-run Support (via Query parameters):

  • --dryRun true - Dry-run mode, validates parameters without actual creation
  • --client-token <unique_id> - Idempotency token, same token multiple requests only creates once

Example: Create an enhanced (Industry Algorithm) pay-as-you-go instance (E-commerce)

# Generate idempotency token
CLIENT_TOKEN=$(uuidgen)

aliyun opensearch create-app-group \
  --client-token "$CLIENT_TOKEN" \
  --body '{
    "name": "my_search_instance",
    "type": "enhanced",
    "chargeType": "POSTPAY",
    "domain": "ecommerce",
    "quota": {
      "docSize": 100,
      "computeResource": 2000,
      "spec": "opensearch.private.common"
    }
  }' \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Example: Create a standard (High-performance) instance

# Generate idempotency token
CLIENT_TOKEN=$(uuidgen)

aliyun opensearch create-app-group \
  --client-token "$CLIENT_TOKEN" \
  --body '{
    "name": "my_standard_instance",
    "type": "standard",
    "chargeType": "POSTPAY",
    "quota": {
      "docSize": 50,
      "computeResource": 1000,
      "spec": "opensearch.share.common"
    }
  }' \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Example: Create a subscription (prepaid) instance

Note: Subscription instances MUST provide order parameter

# Generate idempotency token
CLIENT_TOKEN=$(uuidgen)

aliyun opensearch create-app-group \
  --client-token "$CLIENT_TOKEN" \
  --body '{
    "name": "my_prepay_instance",
    "type": "enhanced",
    "chargeType": "PREPAY",
    "domain": "ecommerce",
    "quota": {
      "docSize": 100,
      "computeResource": 2000,
      "spec": "opensearch.private.common"
    },
    "order": {
      "duration": 1,
      "pricingCycle": "Year",
      "autoRenew": true
    }
  }' \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Dry-run Mode Example (validates parameters only, no actual creation):

aliyun opensearch create-app-group \
  --dryRun true \
  --body '{
    "name": "my_search_instance",
    "type": "enhanced",
    "chargeType": "POSTPAY",
    "quota": {
      "docSize": 100,
      "computeResource": 2000,
      "spec": "opensearch.private.common"
    }
  }' \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Idempotent Creation Example (prevents duplicate creation):

# Generate idempotency token
CLIENT_TOKEN=$(uuidgen)

aliyun opensearch create-app-group \
  --client-token "$CLIENT_TOKEN" \
  --body '{
    "name": "my_search_instance",
    "type": "enhanced",
    "chargeType": "POSTPAY",
    "quota": {
      "docSize": 100,
      "computeResource": 2000,
      "spec": "opensearch.private.common"
    }
  }' \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Task 2: List Instances

aliyun opensearch list-app-groups \
  --engine-type ha3 \
  --page-number <page> \
  --page-size <size> \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Supported Filter Parameters:

  • --engine-type ha3 - Engine type (default ha3, must specify)
  • --name <instance_name> - Filter by name
  • --instance-id <instance_id> - Filter by instance ID
  • --type <standard|enhanced> - Filter by type
    • standard: High-performance
    • enhanced: Industry Algorithm
  • --sort-by <field> - Sort field

Example: List instances

aliyun opensearch list-app-groups \
  --engine-type ha3 \
  --page-number 1 \
  --page-size 10 \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Task 3: Describe Instance

aliyun opensearch describe-app-group \
  --app-group-identity <instance_name_or_id> \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Example: Get instance details

aliyun opensearch describe-app-group \
  --app-group-identity my_search_instance \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Response includes:

  • Basic info (instanceId, name, type, status)
  • Quota info (quota: docSize, computeResource, spec)
  • Billing info (chargeType, chargingWay)
  • Version info (currentVersion, versions)
  • Status info (lockMode, produced)
  • Engine info (engineType)

Success Verification

For operation verification, see references/verification-method.md

Quick Verification

Verify Instance Creation:

aliyun opensearch describe-app-group \
  --app-group-identity <instance_name> \
  --connect-timeout 3 \
  --read-timeout 10 \
  --user-agent AlibabaCloud-Agent-Skills/alibabacloud-opensearch-app-manage

Check if result.instanceId field is non-empty; if non-empty, instance creation succeeded.


Resource Cleanup

To delete instances, please use OpenSearch Console.


API and Command Reference

For complete API list, see references/related-apis.md

OperationCLI CommandAPI Action
Create Instancealiyun opensearch create-app-groupCreateAppGroup
List Instancesaliyun opensearch list-app-groupsListAppGroups
Describe Instancealiyun opensearch describe-app-groupDescribeAppGroup

Best Practices

Write Operation Parameter Confirmation (Required)

Important: Before executing write operations (create instance, etc.), you MUST confirm the following parameters with the user:

Pre-creation Confirmation Checklist:

ParameterDescriptionExample
RegionInstance regioncn-hangzhou / cn-shanghai / cn-beijing
Instance Name (name)User-specified name (lowercase, numbers, underscores)my_search_instance
Instance Type (type)High-performance / Industry Algorithmstandard / enhanced
Charge Type (chargeType)Pay-as-you-go / SubscriptionPOSTPAY / PREPAY
Spec Type (quota.spec)Shared / Dedicatedopensearch.share.common
Storage (quota.docSize)In GB100
Compute (quota.computeResource)In LCU2000
Industry (domain)Only for enhanced typeecommerce / general
Subscription Period (order)Only for PREPAY1 Year / 6 Months

Confirmation Flow Example:

You are about to create the following OpenSearch instance, please confirm:

- Region: cn-hangzhou (China East 1)
- Instance Name: my_search_instance
- Instance Type: Industry Algorithm (enhanced)
- Industry: E-commerce (ecommerce)
- Charge Type: Pay-as-you-go (POSTPAY)
- Spec Type: Dedicated Common (opensearch.private.common)
- Storage: 100 GB
- Compute: 2000 LCU

Confirm creation? (yes/no)

Idempotency Best Practices

For write operations (create, restart, delete), follow these idempotency best practices:

  1. Generate unique Token before each operation: Use uuidgen to generate UUID
  2. Reuse Token on timeout retry: If request times out, retry with the same clientToken
  3. Use different Token for different operations: Each independent operation needs a new clientToken
  4. Token validity: clientToken is typically valid for 24 hours
# Example: Safe retry pattern
CLIENT_TOKEN=$(uuidgen)
echo "Using clientToken: $CLIENT_TOKEN"

# First attempt
aliyun opensearch create-app-group --client-token $CLIENT_TOKEN ...

# If timeout, retry with same Token
aliyun opensearch create-app-group --client-token $CLIENT_TOKEN ...

Other Best Practices

  1. Naming Convention: Instance name must start with a letter, only lowercase letters, numbers, and underscores (_) allowed, hyphens (-) are forbidden, max 30 characters
    • ✅ Correct: my_search_instance, video_search, product_search_2024
    • ❌ Incorrect: my-search-instance, My_Search, 123_search
  2. Quota Planning: Plan storage and compute resources based on actual data volume and query requirements
  3. Charge Type Selection:
    • Test/Dev environment: Use pay-as-you-go (POSTPAY)
    • Production environment: Consider subscription (PREPAY) to reduce costs
    • Note: Subscription instances MUST provide order parameter (including duration and pricingCycle)
  4. Instance Type Selection:
    • High-performance (standard): Suitable for general search scenarios
    • Industry Algorithm (enhanced): Suitable for specific industry scenarios, requires domain parameter
  5. Industry Selection (Industry Algorithm):
    • E-commerce: ecommerce
    • Gaming: esports
    • Content Community: community
    • Education: education
    • General: general (default)
  6. Spec Selection:
    • Shared Common: Suitable for small-scale scenarios
    • Dedicated: Suitable for production environments, more stable performance
  7. Resource Cleanup: Delete unused pay-as-you-go instances promptly to avoid unnecessary costs

Reference Links

DocumentDescription
references/related-apis.mdComplete API List
references/ram-policies.mdRAM Policies
references/verification-method.mdVerification Methods
references/cli-installation-guide.mdCLI Installation Guide
references/acceptance-criteria.mdAcceptance Criteria

Comments

Loading comments...