volcengine-api
Query and answer questions about Volcengine API specifications. Trigger this skill whenever a user asks about Volcengine API parameters, error codes, request...
Description
name: volcengine-api description: > Query and answer questions about Volcengine API specifications. Trigger this skill whenever a user asks about Volcengine API parameters, error codes, request methods, enum values, required fields, response structures, pagination, parameter dependencies, or API comparisons — even if they don't explicitly say "API". Typical triggers include questions like "What parameters does DescribeInstances have?", "What values does Status support?", "What does InvalidInstanceId.NotFound mean?", "Does Volcengine have a batch tag deletion API?", "Which APIs does ECS support?", "How do I pass parameters to CreateDatabase?", "Is ChargeType required?", "What fields does DescribeInstances return?", "How do I paginate instance lists?", "What's the difference between these two APIs?", "RunInstances returns InvalidParameterValue". When the user needs runnable SDK code, hand off to the volcengine-sdk-generator skill. When the user needs CLI-based operations, hand off to the volcengine-cli skill. Supports both Chinese and English prompts.
Volcengine API Query Assistant
Answer user questions about Volcengine APIs by querying the API Explorer for authoritative, up-to-date information.
Applicable Scenarios
| Scenario | Example Questions |
|---|---|
| Find an API | "How do I list ECS instances?", "Is there a batch tag creation API?" |
| Query parameters | "What are the required params for RunInstances?", "What values does ChargeType accept?" |
| Response structure | "What fields does DescribeInstances return?", "What statuses can Status have?" |
| Parameter dependencies | "If I set Ipv6Isp, how should I fill Ipv6MaskLen?", "When is SpotPriceLimit required?" |
| Pagination | "How do I paginate instance queries?", "How does NextToken work?" |
| Error codes | "What does InvalidInstanceId.NotFound mean?", "CreateVpc returns QuotaExceeded" |
| Browse services | "Which APIs does ECS have?", "What operations does VPC support?" |
| API comparison | "What's the difference between DescribeInstances and DescribeInstancesByIds?" |
Workflow
Step 1: Understand User Intent
Determine what the user is looking for:
| Intent | Signal | Query Path |
|---|---|---|
| Find an API | Describes an operation but doesn't know the API name | Search (2e) or Services (2a) -> API list (2c) -> Details (2d) |
| Query parameters | Knows the API name, asks about params/enums/required fields | Go directly to Details (2d) |
| Query response | Asks about return fields or status values | Go directly to Details (2d), focus on response schema |
| Query parameter dependencies | Asks "when is X required?" or "how does X relate to Y?" | Go directly to Details (2d), focus on conditional rules in descriptions |
| Query error codes | Provides an error code or error message | Error code handling (Step 3) |
| Browse a service | Asks what capabilities a service offers | Services (2a) -> API list (2c) |
| Compare APIs | Asks about differences between two APIs | Query Details (2d) for each, compare params and functionality |
Step 2: Query API Information Progressively
Start from the appropriate sub-step based on what is already known. When the user describes a requirement in natural language, Search (2e) is often faster than browsing level by level.
2a. Query service list (when the service is unknown)
GET https://api.volcengine.com/api/common/explorer/services
Each service in the response contains:
ServiceCode: service identifier (e.g.,ecs,vpc)ServiceCn: Chinese name (e.g., "cloud server", "virtual private cloud")Product: product identifier (e.g.,ECS,VPC)RegionType:regionalorglobal
Match the most appropriate ServiceCode based on the user's description.
2b. Query version list (when the version is unknown)
GET https://api.volcengine.com/api/common/explorer/versions?ServiceCode={ServiceCode}
Each version contains:
Version: version string (e.g.,2020-04-01)IsDefault:1indicates the default version
Prefer the version with IsDefault=1. If none is marked default, use the latest version.
2c. Query API list (when the specific API is unknown)
GET https://api.volcengine.com/api/common/explorer/apis?ServiceCode={ServiceCode}&Version={Version}&APIVersion={Version}
The response groups APIs by category. Each API contains:
Action: API name (e.g.,DescribeInstances)NameCn: Chinese name (e.g., "Query instance list")ApiGroup: group name (e.g., "Instance", "Image")Description: functional descriptionUsageScenario: usage scenariosAttentions: constraints and caveats
Match user intent using Action, NameCn, and Description.
2d. Query API details (core step)
GET https://api.volcengine.com/api/common/explorer/api-swagger?ServiceCode={ServiceCode}&Version={Version}&APIVersion={Version}&ActionName={ActionName}
Returns the full Swagger/OpenAPI specification for the API. Extract key information as follows.
HTTP Method
The key under paths["/{ActionName}"] (get or post) indicates the HTTP method.
Request Parameters
Parameter location depends on the HTTP method:
GET requests: parameters are in paths["/{ActionName}"].get.parameters. Each parameter includes:
name: parameter namerequired: whether it is requiredschema.type: data typeschema.description: parameter description (often contains enum values, conditional rules, and value ranges)schema.enum: allowed values (if any)schema.default: default value (if any)schema.example: example value (if any)
Arrays and nested objects in GET parameters use naming conventions:
- Arrays:
ParamName.N(N starts from 1), e.g.,InstanceIds.1,InstanceIds.2 - Nested objects:
Parent.Child, e.g.,TagFilters.N.Key,TagFilters.N.Values.N
POST requests: parameters are in paths["/{ActionName}"].post.requestBody.content["application/json"].schema, using JSON Schema:
properties: parameter definitions, keyed by namerequired: array of required parameter names
POST parameters often have nested structures that require recursive parsing:
type: object-> inspectpropertiesfor child parameterstype: array-> inspectitemsfor element structure$ref: "#/components/schemas/XxxObject"-> look up the definition incomponents.schemasand expand recursively
Present nested parameters in a tree structure:
- InstanceId (string, required): instance ID
- DatabasePrivileges (array, optional): database privilege list
- AccountName (string, required): account name
- AccountPrivilege (string, required): privilege type — enum: ReadWrite, ReadOnly, ...
- AccountPrivilegeDetail (string, optional): privilege detail, comma-separated
Parameter Dependencies
Many parameters have conditional dependencies, typically described in the description field. Watch for:
- Conditionally required: e.g., "required when
EnableIpv6is true" - Mutually exclusive: e.g., "when
Ipv6CidrBlockis specified,Ipv6MaskLenis ignored" - Value constraints: e.g., "when
Ipv6Ispis BGP, only 56 is supported" - Prerequisites: e.g., "
TagFilters.N.Values.NrequiresTagFilters.N.Keyto be set first"
Highlight these dependencies in the answer to help users avoid misconfiguration.
Pagination Parameters
Volcengine APIs use two common pagination patterns, identifiable from the Swagger parameters:
- Token-based: uses
MaxResults(page size) +NextToken(continuation token). The response includesNextToken; an empty value means the last page. - Offset-based: uses
PageSize+PageNumber(orOffset/Limit). The response includesTotalCount.
Specify which pagination pattern the API uses, along with default values and upper limits.
Response Structure
The response schema is defined at paths["/{ActionName}"].{method}.responses["200"].content["application/json"].schema, and may reference components.schemas via $ref.
Key response information:
- Field names, types, and descriptions
- Enum fields and their possible values (e.g.,
Status: RUNNING / STOPPED / CREATING) - Nested object structures (e.g., fields within each item in an
Instancesarray)
The info.x-demo section also provides useful reference — responseDemo[0].Code shows the complete response structure with example values.
Request/Response Examples
In the info.x-demo array:
requestDemo[0].Code: request example (shows how parameters are filled)responseDemo[0].Code: response example (shows the full return structure with sample values)
These are official examples and highly valuable. Proactively include them in the answer.
Associated Error Codes
In paths["/{ActionName}"].{method}.responses["x-error-code"].content["application/json"].schema.oneOf, each error code contains:
code: error code identifier (e.g.,InvalidInstanceId.NotFound)http_code: HTTP status code (e.g., 400, 404, 409, 429, 500)message: English descriptiondescription: Chinese description
2e. Search APIs (quick lookup)
When the user describes a requirement in natural language, searching is often the fastest approach. This can be used alongside steps 2a–2c.
GET https://api.volcengine.com/api/common/search/all?Query={keyword}&Channel=api
Search terms can be in Chinese or English. If one keyword yields poor results, try synonyms, different granularity, or English Action-name style (e.g., "DescribeXxx").
Each result contains:
BizInfo.Action: API nameBizInfo.ServiceCode: service identifierBizInfo.ServiceCn: service Chinese nameBizInfo.Version: versionHighlight: matched highlight text
After finding the target API, use step 2d to get full details.
Step 3: Handle Error Code Queries
Error code queries need special handling because the same error code (e.g., InvalidParameter) may appear across dozens of APIs with different meanings.
Common Error Code Categories
| Category | Common Patterns | Typical Cause |
|---|---|---|
| Parameter error | InvalidParameter, InvalidParameterValue, MissingParameter |
Typo in parameter name, value outside enum range, missing required parameter |
| Resource not found | InvalidXxx.NotFound, ResourceNotFound |
Wrong resource ID, resource in a different region, already deleted |
| Resource status | InvalidXxx.InvalidStatus, IncorrectInstanceStatus |
Current resource state does not allow this operation (e.g., modifying config without stopping the instance) |
| Quota/limit | QuotaExceeded, LimitExceeded |
Account quota or API rate limit exceeded |
| Permission denied | UnauthorizedOperation, Forbidden |
IAM policy not authorized, sub-account lacks permissions |
| Throttling | Throttling, RequestLimitExceeded |
API call rate too high — reduce request rate or use exponential backoff |
| Server error | InternalError, ServiceUnavailable |
Temporary server-side issue, usually retryable |
| Resource conflict | ResourceInUse, DuplicateXxx, OperationConflict |
Resource is in use or name already exists |
When the user provides a specific API name
Query the API Swagger via step 2d and locate the error code in x-error-code. This is the most accurate approach because the same error code can have different meanings across APIs.
Combine the description (Chinese) and message (English) fields to provide:
- Error meaning
- Specific trigger conditions in the context of this API
- Troubleshooting steps and resolution suggestions
When the user provides only the error code
- Ask for context first: ask which API triggered the error — this enables precise diagnosis. The same
InvalidParametermeans entirely different things inRunInstancesvs.CreateVpc. - If the user provides a service name but no API name: infer the most likely API from the error pattern and context, then query its Swagger to confirm.
- Fallback search: if the user cannot provide more context, use the error code search endpoint:
GET https://api.volcengine.com/api/common/search/all?Query={error_code}&Channel=error_code
Each result contains:
Type:error_codeBizInfo.ServiceCode: service identifierBizInfo.ServiceCn: service Chinese nameBizInfo.Version: versionURL: error code documentation linkHighlight: matched highlight text
Since the same error code appears across multiple services, results may be numerous. Filter by any context the user has provided (service name, operation type, scenario).
Step 4: Compose the Answer
Organize a clear, professional answer based on the question type. Core principle: center on the user's question — extract the information the user needs rather than dumping the entire Swagger.
Finding an API
- Recommend the API and explain why
- Briefly describe its functionality and use case
- List core required parameters
- If multiple candidates exist, compare their use cases and let the user choose
Querying Parameters
- State the HTTP method (GET/POST)
- Required parameters first: list with type, description, and enum values
- Use tree structure for nested parameters, marking required/optional at each level
- Parameter dependencies: highlight conditional requirements, mutual exclusions, and value constraints
- Describe the pagination pattern and default values separately
- Show the request example (from x-demo)
- Group optional parameters by function (filters, sorting, advanced config) and list briefly
Querying Response Structure
- List key return fields with type and description
- Show all possible values for enum fields
- Use tree structure for nested objects
- Show the response example (from x-demo responseDemo)
Querying Error Codes
- Error meaning (Chinese and English descriptions)
- Error category (parameter error / resource not found / permission denied, etc.)
- Common causes
- Specific troubleshooting steps and resolution suggestions
- For throttling errors, recommend a retry strategy
Browsing Service Capabilities
- Organize the API list by
ApiGroup - Show Action name + Chinese name + one-line description for each API
- If there are many APIs, prioritize core/commonly-used ones
Comparing APIs
- Describe the functional purpose of each API
- Compare applicable scenarios
- Compare parameter differences (which is simpler, which is more flexible)
- Provide a usage recommendation
Query Efficiency Tips
- API name known: go directly to 2d — one step
- Service name known: 2b -> 2c -> 2d, or search in parallel via 2e
- Only a natural-language description: prefer 2e search — faster than browsing level by level
- Completely uncertain: combine 2a (service list) + 2e (keyword search)
- Error code lookup: if an API name is available, go to 2d; otherwise, ask the user for context first
Important Notes
- Always fetch the latest data from the API Explorer endpoints — Volcengine APIs are updated frequently, so do not rely on memory
- Match the answer language to the user's language (Chinese question -> Chinese answer, English -> English)
- If the user's description is ambiguous, list possible options and ask for confirmation rather than guessing
- If the user needs runnable SDK code, direct them to the
volcengine-sdk-generatorskill - If the user needs CLI-based operations, direct them to the
volcengine-cliskill - When presenting parameter information, enum values, conditional rules, and value ranges in the description field are the most valuable content — do not omit them
- If a network error occurs during queries, inform the user and suggest retrying later
Reviews (0)
No reviews yet. Be the first to review!
Comments (0)
No comments yet. Be the first to share your thoughts!