This skill should be used when the user mentions "wrangler", "wrangler.toml", "wrangler.jsonc", "wrangler commands", "local development", "wrangler dev", "wrangler deploy", "wrangler publish", "secrets management", "wrangler tail", "wrangler d1", "wrangler kv", or discusses Cloudflare Workers CLI, configuration files, or deployment workflows.
/plugin marketplace add involvex/involvex-claude-marketplace/plugin install cloudflare-expert@involvex-claude-marketplaceThis skill inherits all available tools. When active, it can use any tool Claude has access to.
examples/wrangler-jsonc-template.jsoncreferences/wrangler-commands-cheatsheet.mdThis skill provides comprehensive guidance for using Wrangler, the Cloudflare Workers CLI tool. It covers common commands, configuration file management, local development workflows, secrets handling, and deployment processes. Use this skill when working with Wrangler CLI operations, configuring Workers projects, or managing Workers deployments.
Wrangler is the official CLI tool for Cloudflare Workers. It handles:
# Install globally via npm
npm install -g wrangler
# Or use npx (no install needed)
npx wrangler
# Verify installation
wrangler --version
# Login to Cloudflare account
wrangler login
# Or use API token
export CLOUDFLARE_API_TOKEN=your-token
wrangler whoami
Start local development server:
# Local mode (uses local resources when possible)
wrangler dev
# Remote mode (uses remote resources)
wrangler dev --remote
# Custom port
wrangler dev --port 3000
# With live reload
wrangler dev --live-reload
Tail logs (real-time):
# Production logs
wrangler tail
# With filters
wrangler tail --status error
wrangler tail --method POST
wrangler tail --search "user-id"
# Pretty print
wrangler tail --format pretty
Deploy to Cloudflare:
# Deploy to production
wrangler deploy
# Deploy to specific environment
wrangler deploy --env staging
wrangler deploy --env production
# Dry run (validate without deploying)
wrangler deploy --dry-run
# Legacy command (same as deploy)
wrangler publish
Manage deployments:
# List deployments
wrangler deployments list
# View deployment details
wrangler deployments view [deployment-id]
# Rollback to previous deployment
wrangler rollback [deployment-id]
KV Commands:
# Create KV namespace
wrangler kv:namespace create NAMESPACE_NAME
# List namespaces
wrangler kv:namespace list
# Put key-value
wrangler kv:key put KEY "value" --namespace-id=xxx
# Get value
wrangler kv:key get KEY --namespace-id=xxx
# Delete key
wrangler kv:key delete KEY --namespace-id=xxx
# List keys
wrangler kv:key list --namespace-id=xxx
# Bulk operations
wrangler kv:bulk put data.json --namespace-id=xxx
wrangler kv:bulk delete keys.json --namespace-id=xxx
D1 Commands:
# Create database
wrangler d1 create DATABASE_NAME
# List databases
wrangler d1 list
# Execute SQL
wrangler d1 execute DB_NAME --command="SELECT * FROM users"
wrangler d1 execute DB_NAME --file=query.sql
# Remote mode (production)
wrangler d1 execute DB_NAME --remote --command="SELECT * FROM users"
# Migrations
wrangler d1 migrations create DB_NAME migration_name
wrangler d1 migrations list DB_NAME
wrangler d1 migrations apply DB_NAME
wrangler d1 migrations apply DB_NAME --remote
R2 Commands:
# Create bucket
wrangler r2 bucket create BUCKET_NAME
# List buckets
wrangler r2 bucket list
# Upload object
wrangler r2 object put BUCKET_NAME/key.txt --file=local-file.txt
# Download object
wrangler r2 object get BUCKET_NAME/key.txt --file=output.txt
# Delete object
wrangler r2 object delete BUCKET_NAME/key.txt
# List objects
wrangler r2 object list BUCKET_NAME
# Add secret
wrangler secret put SECRET_NAME
# (prompts for value)
# List secrets
wrangler secret list
# Delete secret
wrangler secret delete SECRET_NAME
# Bulk secrets
wrangler secret bulk data.json
See references/wrangler-commands-cheatsheet.md for complete command reference.
Wrangler supports two configuration formats:
{
"name": "my-worker",
"main": "src/index.ts",
"compatibility_date": "2024-01-01",
// Environment variables
"vars": {
"ENVIRONMENT": "production"
},
// KV namespaces
"kv_namespaces": [
{
"binding": "MY_KV",
"id": "abc123..."
}
],
// D1 databases
"d1_databases": [
{
"binding": "DB",
"database_name": "my-db",
"database_id": "xyz789..."
}
],
// R2 buckets
"r2_buckets": [
{
"binding": "MY_BUCKET",
"bucket_name": "uploads"
}
],
// Workers AI
"ai": {
"binding": "AI"
}
}
{
"name": "my-worker",
"main": "src/index.ts",
"compatibility_date": "2024-01-01",
// Default (production) configuration
"vars": {
"ENVIRONMENT": "production"
},
"kv_namespaces": [
{
"binding": "CACHE",
"id": "prod-id"
}
],
// Environment-specific overrides
"env": {
"staging": {
"vars": {
"ENVIRONMENT": "staging"
},
"kv_namespaces": [
{
"binding": "CACHE",
"id": "staging-id"
}
]
},
"development": {
"vars": {
"ENVIRONMENT": "development"
},
"kv_namespaces": [
{
"binding": "CACHE",
"id": "dev-id"
}
]
}
}
}
Deploy to specific environment:
wrangler deploy --env staging
wrangler deploy --env development
See references/wrangler-config-options.md for all configuration options and examples/wrangler-jsonc-template.jsonc for annotated template.
# Create new project
npm create cloudflare@latest
# Or initialize in existing directory
npm init cloudflare
Create or update wrangler.jsonc with bindings, environment variables, and settings.
# Start dev server
wrangler dev
# Worker accessible at http://localhost:8787
# Local KV (simulated)
wrangler dev
# Remote resources (real KV, D1, etc.)
wrangler dev --remote
# Deploy to production
wrangler deploy
--remotewrangler dev
wrangler dev --remote
Important: Some bindings like Vectorize don't support local mode and always require --remote.
# Interactive (secure, recommended)
wrangler secret put API_KEY
# From file (be careful)
wrangler secret put DB_PASSWORD < password.txt
# Bulk from JSON
cat secrets.json | wrangler secret bulk
| Feature | Secrets | Environment Variables |
|---|---|---|
| Storage | Encrypted, not in config | Plain text in wrangler.jsonc |
| Use case | API keys, passwords | Non-sensitive config |
| Deployment | Set via CLI | Committed to git |
| Access | Same as env vars in code | Same as secrets in code |
Rule: Never commit secrets to version control. Use wrangler secret put for sensitive data.
# Tail production logs
wrangler tail
# Filter by status
wrangler tail --status error
wrangler tail --status ok
# Filter by method
wrangler tail --method POST
# Search logs
wrangler tail --search "user-123"
# Multiple filters
wrangler tail --status error --method POST
# Start with debugging
wrangler dev
# Console.log output visible in terminal
# Use Chrome DevTools for breakpoints
In Worker code:
console.log('Info message', { data: 'value' });
console.error('Error:', error);
console.warn('Warning');
Visible in:
wrangler dev terminal outputwrangler tail for productionWrangler automatically supports TypeScript:
// src/index.ts
export interface Env {
MY_KV: KVNamespace;
DB: D1Database;
API_KEY: string;
}
export default {
async fetch(
request: Request,
env: Env,
ctx: ExecutionContext
): Promise<Response> {
const value = await env.MY_KV.get('key');
return new Response(value);
}
};
Install types:
npm install -D @cloudflare/workers-types
Update tsconfig.json:
{
"compilerOptions": {
"target": "ES2022",
"module": "ES2022",
"lib": ["ES2022"],
"types": ["@cloudflare/workers-types"]
}
}
# 1. Create project
npm create cloudflare@latest my-worker
# 2. Navigate to project
cd my-worker
# 3. Install dependencies
npm install
# 4. Configure wrangler.jsonc
# (edit wrangler.jsonc)
# 5. Develop locally
wrangler dev
# 6. Deploy
wrangler deploy
# 1. Create database
wrangler d1 create my-database
# 2. Add to wrangler.jsonc
# "d1_databases": [{ "binding": "DB", "database_id": "..." }]
# 3. Create migrations
wrangler d1 migrations create my-database create_users_table
# 4. Write SQL in migrations/0001_create_users_table.sql
# 5. Apply migrations locally
wrangler d1 migrations apply my-database
# 6. Apply to production
wrangler d1 migrations apply my-database --remote
# Deploy to staging
wrangler deploy --env staging
# Tail staging logs
wrangler tail --env staging
# Execute on staging D1
wrangler d1 execute DB --env staging --remote --command="SELECT COUNT(*) FROM users"
# Deploy to production
wrangler deploy --env production
Issue: "Vectorize bindings not working in local dev"
wrangler dev --remote, Vectorize doesn't support local modeIssue: "Authentication failed"
wrangler login or set CLOUDFLARE_API_TOKENIssue: "Binding not found in env"
Issue: "D1 migrations not applying"
--remote flag for production: wrangler d1 migrations apply DB --remoteIssue: "Secrets not updating"
wrangler secret put KEY then wrangler deploy# General help
wrangler --help
# Command-specific help
wrangler dev --help
wrangler deploy --help
wrangler d1 --help
# Version info
wrangler --version
wrangler.jsonc for modern projects (JSON with comments)wrangler dev before deploying--remote when testing bindings that don't support local modewrangler deploy --dry-run to validate before deployingwrangler tail to debug production issueswrangler deployments list to track deployment historywrangler tail after deploymentwrangler secret put for sensitive dataFor detailed information, consult:
references/wrangler-commands-cheatsheet.md - Complete command reference with examplesreferences/wrangler-config-options.md - All configuration options for wrangler.jsoncWorking examples in examples/:
wrangler-jsonc-template.jsonc - Comprehensive annotated configuration templateFor the latest Wrangler documentation:
Use the cloudflare-docs-specialist agent to search documentation and fetch the latest Wrangler information.
This skill should be used when the user asks to "create a slash command", "add a command", "write a custom command", "define command arguments", "use command frontmatter", "organize commands", "create command with file references", "interactive command", "use AskUserQuestion in command", or needs guidance on slash command structure, YAML frontmatter fields, dynamic arguments, bash execution in commands, user interaction patterns, or command development best practices for Claude Code.
This skill should be used when the user asks to "create an agent", "add an agent", "write a subagent", "agent frontmatter", "when to use description", "agent examples", "agent tools", "agent colors", "autonomous agent", or needs guidance on agent structure, system prompts, triggering conditions, or agent development best practices for Claude Code plugins.
This skill should be used when the user asks to "create a hook", "add a PreToolUse/PostToolUse/Stop hook", "validate tool use", "implement prompt-based hooks", "use ${CLAUDE_PLUGIN_ROOT}", "set up event-driven automation", "block dangerous commands", or mentions hook events (PreToolUse, PostToolUse, Stop, SubagentStop, SessionStart, SessionEnd, UserPromptSubmit, PreCompact, Notification). Provides comprehensive guidance for creating and implementing Claude Code plugin hooks with focus on advanced prompt-based hooks API.