Claude-skill-registry cloud-functions
Complete guide for CloudBase cloud functions development - runtime selection, deployment, logging, invocation, and HTTP access configuration.
git clone https://github.com/majiayu000/claude-skill-registry
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/cloud-functions" ~/.claude/skills/majiayu000-claude-skill-registry-cloud-functions && rm -rf "$T"
skills/data/cloud-functions/SKILL.mdCloud Functions Development
Use this skill when developing, deploying, and managing CloudBase cloud functions (Node.js serverless functions).
When to use this skill
Use this skill for cloud function operations when you need to:
- Create and deploy Node.js cloud functions
- Understand runtime limitations and selection
- Query function logs and monitor execution
- Invoke cloud functions from applications
- Configure HTTP access for cloud functions
Do NOT use for:
- CloudRun backend services (use
skill)cloudrun-development - Multi-language backend services (use
skill)cloudrun-development - Database operations (use database skills)
How to use this skill (for a coding agent)
-
Understand runtime limitations
- Runtime CANNOT be changed after function creation
- Must select correct runtime during initial creation
- If runtime needs to change, must delete and recreate function
-
Choose the right runtime
- Check supported runtimes list below
- Default:
(recommended)Nodejs18.15 - Consider Node.js version compatibility with dependencies
-
Deploy functions correctly
- Use
for new functionscreateFunction - Use
for code updates (runtime cannot be changed)updateFunctionCode - Provide correct
(parent directory of function folder)functionRootPath
- Use
-
Query logs properly
- Use
for log list (basic info)getFunctionLogs - Use
with RequestId for detailed logsgetFunctionLogDetail - Note time range limitations (max 1 day interval)
- Use
Core Knowledge
Runtime Environment
⚠️ CRITICAL: Runtime cannot be modified after function creation
Once a cloud function is created with a specific runtime, the runtime cannot be changed. If you need a different runtime:
- Delete the existing function
- Create a new function with the desired runtime
Supported Node.js Runtimes:
(Default, Recommended)Nodejs18.15Nodejs16.13Nodejs14.18Nodejs12.16Nodejs10.15Nodejs8.9
Runtime Selection Guidelines:
- Use
for new projects (default, most modern)Nodejs18.15 - Choose older versions only if dependencies require specific Node.js versions
- Consider security updates and support lifecycle
- Test thoroughly with selected runtime before deployment
Function Structure
Cloud functions require:
-
Function Directory: Contains function code
- Must have
(or specified entry file)index.js - Must export handler:
exports.main = async (event, context) => {} - Include
with dependenciespackage.json
- Must have
-
Function Root Path: Parent directory containing function directories
- Example: If function is at
/project/cloudfunctions/myFunction/
should befunctionRootPath/project/cloudfunctions/- Important: Do NOT include function name in root path
- Example: If function is at
-
Entry Point: Default is
withindex.jsexports.main- Can be customized via
parameterhandler
- Can be customized via
Function Deployment
Creating New Functions:
Use
createFunction tool (see MCP tool documentation for full parameter list):
- Important: Always specify
explicitly (defaults tofunc.runtime
)Nodejs18.15 - Provide
as parent directory of function folders (absolute path)functionRootPath - Use
to overwrite existing functionforce=true
Updating Function Code:
Use
updateFunctionCode tool:
- ⚠️ Note: Only updates code, cannot change runtime
- If runtime needs to change, delete and recreate function
Deployment Best Practices:
- Always specify runtime explicitly when creating functions
- Use absolute paths for
functionRootPath - Don't upload node_modules - dependencies installed automatically
- Test locally before deployment when possible
- Use environment variables for configuration, not hardcoded values
Function Logs
Querying Logs:
Primary Method: Use
getFunctionLogs and getFunctionLogDetail tools (see MCP tool documentation).
Alternative Method (Plan B): If tools unavailable, use
callCloudApi:
- Get Log List - Use
action:GetFunctionLogs
callCloudApi({ service: "tcb", action: "GetFunctionLogs", params: { EnvId: "{envId}", FunctionName: "functionName", Offset: 0, Limit: 10, StartTime: "2024-01-01 00:00:00", EndTime: "2024-01-01 23:59:59", LogRequestId: "optional-request-id", Qualifier: "$LATEST" } })
- Get Log Details - Use
action (requires LogRequestId from step 1):GetFunctionLogDetail
callCloudApi({ service: "tcb", action: "GetFunctionLogDetail", params: { StartTime: "2024-01-01 00:00:00", EndTime: "2024-01-01 23:59:59", LogRequestId: "request-id-from-log-list" } })
Log Query Limitations:
cannot exceed 10000Offset + Limit
andStartTime
interval cannot exceed 1 dayEndTime- Use pagination for large time ranges
Log Query Best Practices:
- Query logs within 1-day windows
- Use RequestId for specific invocation debugging
- Combine list and detail queries for comprehensive debugging
- Check logs after deployment to verify function behavior
Invoking Cloud Functions
From Web Applications:
import cloudbase from "@cloudbase/js-sdk"; import cloudbaseSDK from "@cloudbase/js-sdk"; const cloudbase = cloudbaseSDK.init({ env: 'your-env-id', region: 'ap-shanghai', accessKey: 'your-access-key' }); // Call cloud function const result = await cloudbase.callFunction({ name: "functionName", data: { /* function parameters */ } });
From Mini Programs:
wx.cloud.callFunction({ name: "functionName", data: { /* function parameters */ } }).then(res => { console.log(res.result); });
From Node.js Backend:
const cloudbase = require("@cloudbase/node-sdk"); const app = cloudbase.init({ env: "your-env-id" }); const result = await app.callFunction({ name: "functionName", data: { /* function parameters */ } });
From HTTP API:
Use CloudBase HTTP API to invoke functions:
- Endpoint:
https://api.cloudbase.net/v1/{envId}/functions/{functionName}/invoke - Requires authentication token
- See
skill for detailshttp-api
HTTP Access Configuration
HTTP Access vs HTTP API:
- HTTP API: Uses CloudBase API endpoint (
) with authentication tokenhttps://api.cloudbase.net/v1/{envId}/functions/{functionName}/invoke - HTTP Access: Creates direct HTTP/HTTPS endpoint for standard REST API access (GET, POST, etc.) without SDK or CloudBase API format
Creating HTTP Access:
Primary Method: Use
createFunctionHTTPAccess tool (see MCP tool documentation).
Alternative Method (Plan B): If tool unavailable, use
callCloudApi with CreateCloudBaseGWAPI:
callCloudApi({ service: "tcb", action: "CreateCloudBaseGWAPI", params: { EnableUnion: true, Path: "/api/users", ServiceId: "{envId}", Type: 6, Name: "functionName", AuthSwitch: 2, PathTransmission: 2, EnableRegion: true, Domain: "*" // Use "*" for default domain, or custom domain name } })
Key Parameters:
- Cloud Function type (required)Type: 6
- No auth (1 = with auth)AuthSwitch: 2
- Default domain, or specify custom domainDomain: "*"
Access URL:
https://{envId}.{region}.app.tcloudbase.com/{path} or https://{domain}/{path}
Function Configuration
Environment Variables:
Set via
func.envVariables when creating/updating:
{ envVariables: { "DATABASE_URL": "mysql://...", "API_KEY": "secret-key" } }
⚠️ CRITICAL: Environment Variable Update Constraint
When updating environment variables for existing functions:
- MUST first query current environment variables using
withgetFunctionList
to get the function's current configurationaction=detail - MUST merge new environment variables with existing ones
- DO NOT directly overwrite - this will delete existing environment variables not included in the update
Correct Update Pattern:
// 1. First, get current function details const currentFunction = await getFunctionList({ action: "detail", name: "functionName" }); // 2. Merge existing envVariables with new ones const mergedEnvVariables = { ...currentFunction.EnvVariables, // Existing variables ...newEnvVariables // New/updated variables }; // 3. Update with merged variables await updateFunctionConfig({ funcParam: { name: "functionName", envVariables: mergedEnvVariables } });
Why This Matters:
- Direct overwrite will delete all environment variables not included in the update
- This can break function functionality if critical variables are removed
- Always preserve existing configuration when making partial updates
Timeout Configuration:
Set via
func.timeout (in seconds):
- Default timeout varies by runtime
- Maximum timeout depends on runtime version
- Consider function execution time when setting
Timer Triggers:
Configure via
func.triggers:
- Type:
(only supported type)timer - Config: Cron expression (7 fields: second minute hour day month week year)
- Examples:
- 2:00 AM on 1st of every month"0 0 2 1 * * *"
- 9:30 AM every day"0 30 9 * * * *"
VPC Configuration:
For accessing VPC resources:
{ vpc: { vpcId: "vpc-xxxxx", subnetId: "subnet-xxxxx" } }
MCP Tools Reference
Function Management:
- List functions or get function detailsgetFunctionList
- Create new cloud functioncreateFunction
- Update function code (runtime cannot change)updateFunctionCode
- Update function configuration (⚠️ when updating envVariables, must first query and merge with existing values to avoid overwriting)updateFunctionConfig
Logging:
- Get function log list (basic info)getFunctionLogs
- Get detailed log content by RequestIdgetFunctionLogDetail
(Plan B) - UsecallCloudApi
andGetFunctionLogs
actions if direct tools unavailableGetFunctionLogDetail
HTTP Access:
- Create HTTP access for functioncreateFunctionHTTPAccess
(Plan B) - UsecallCloudApi
action if direct tool unavailableCreateCloudBaseGWAPI
Triggers:
- Create or delete function triggersmanageFunctionTriggers
Console Management
Function Console URLs:
- Function List:
https://tcb.cloud.tencent.com/dev?envId=${envId}#/scf - Function Detail:
https://tcb.cloud.tencent.com/dev?envId=${envId}#/scf/detail?id=${functionName}&NameSpace=${envId}
Console Features:
- View function code and configuration
- Monitor function invocations and performance
- Manage environment variables
- Configure triggers
- View logs and execution history
Common Patterns
Error Handling
exports.main = async (event, context) => { try { // Function logic return { code: 0, message: "Success", data: result }; } catch (error) { return { code: -1, message: error.message, data: null }; } };
Environment Variable Usage
exports.main = async (event, context) => { const apiKey = process.env.API_KEY; const dbUrl = process.env.DATABASE_URL; // Use environment variables };
Database Operations
const cloudbase = require("@cloudbase/node-sdk"); const app = cloudbase.init({ env: process.env.ENV_ID }); exports.main = async (event, context) => { const db = app.database(); const result = await db.collection("users").get(); return result; };
Best Practices
- Runtime Selection: Always specify runtime explicitly, use
for new projectsNodejs18.15 - Code Organization: Keep functions focused and single-purpose
- Error Handling: Always implement proper error handling
- Environment Variables: Use env vars for configuration, never hardcode secrets
- Logging: Add meaningful logs for debugging
- Testing: Test functions locally when possible before deployment
- Security: Implement authentication/authorization for HTTP access
- Performance: Optimize cold start time, use connection pooling for databases
- Monitoring: Regularly check logs and monitor function performance
- Documentation: Document function parameters and return values
Related Skills
- For multi-language backend servicescloudrun-development
- For HTTP API invocation patternshttp-api
- For general CloudBase platform knowledgecloudbase-platform