@macpaw/cctk 1.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/License +21 -0
- package/README.md +142 -0
- package/bin/index.js +5 -0
- package/dist/index.js +1 -0
- package/package.json +65 -0
- package/templates/claude/agents/brainstormer.md +113 -0
- package/templates/claude/agents/code-reviewer.md +157 -0
- package/templates/claude/agents/copywriter.md +110 -0
- package/templates/claude/agents/database-admin.md +92 -0
- package/templates/claude/agents/debugger.md +137 -0
- package/templates/claude/agents/docs-manager.md +208 -0
- package/templates/claude/agents/fullstack-developer.md +95 -0
- package/templates/claude/agents/git-manager.md +394 -0
- package/templates/claude/agents/journal-writer.md +113 -0
- package/templates/claude/agents/mcp-manager.md +89 -0
- package/templates/claude/agents/planner.md +108 -0
- package/templates/claude/agents/project-manager.md +125 -0
- package/templates/claude/agents/registry.json +304 -0
- package/templates/claude/agents/researcher.md +37 -0
- package/templates/claude/agents/scout-external.md +140 -0
- package/templates/claude/agents/scout.md +106 -0
- package/templates/claude/agents/tester.md +105 -0
- package/templates/claude/agents/ui-ux-designer.md +208 -0
- package/templates/claude/commands/ask.md +56 -0
- package/templates/claude/commands/bootstrap/auto/fast.md +106 -0
- package/templates/claude/commands/bootstrap/auto/parallel.md +64 -0
- package/templates/claude/commands/bootstrap/auto.md +110 -0
- package/templates/claude/commands/bootstrap.md +130 -0
- package/templates/claude/commands/brainstorm.md +75 -0
- package/templates/claude/commands/code/auto.md +198 -0
- package/templates/claude/commands/code/no-test.md +172 -0
- package/templates/claude/commands/code/parallel.md +100 -0
- package/templates/claude/commands/code.md +197 -0
- package/templates/claude/commands/coding-level.md +37 -0
- package/templates/claude/commands/content/cro.md +41 -0
- package/templates/claude/commands/content/enhance.md +12 -0
- package/templates/claude/commands/content/fast.md +11 -0
- package/templates/claude/commands/content/good.md +14 -0
- package/templates/claude/commands/cook/auto/fast.md +26 -0
- package/templates/claude/commands/cook/auto/parallel.md +49 -0
- package/templates/claude/commands/cook/auto.md +15 -0
- package/templates/claude/commands/cook.md +101 -0
- package/templates/claude/commands/debug.md +13 -0
- package/templates/claude/commands/docs/init.md +37 -0
- package/templates/claude/commands/docs/summarize.md +22 -0
- package/templates/claude/commands/docs/update.md +78 -0
- package/templates/claude/commands/fix/ci.md +17 -0
- package/templates/claude/commands/fix/fast.md +18 -0
- package/templates/claude/commands/fix/hard.md +35 -0
- package/templates/claude/commands/fix/logs.md +26 -0
- package/templates/claude/commands/fix/parallel.md +54 -0
- package/templates/claude/commands/fix/test.md +20 -0
- package/templates/claude/commands/fix/types.md +9 -0
- package/templates/claude/commands/fix/ui.md +33 -0
- package/templates/claude/commands/fix.md +43 -0
- package/templates/claude/commands/git/cm.md +5 -0
- package/templates/claude/commands/git/cp.md +4 -0
- package/templates/claude/commands/git/merge.md +40 -0
- package/templates/claude/commands/git/pr.md +50 -0
- package/templates/claude/commands/journal.md +7 -0
- package/templates/claude/commands/kanban.md +99 -0
- package/templates/claude/commands/plan/archive.md +57 -0
- package/templates/claude/commands/plan/ci.md +33 -0
- package/templates/claude/commands/plan/cro.md +67 -0
- package/templates/claude/commands/plan/fast.md +66 -0
- package/templates/claude/commands/plan/hard.md +92 -0
- package/templates/claude/commands/plan/parallel.md +129 -0
- package/templates/claude/commands/plan/two.md +45 -0
- package/templates/claude/commands/plan/validate.md +117 -0
- package/templates/claude/commands/plan.md +30 -0
- package/templates/claude/commands/preview.md +87 -0
- package/templates/claude/commands/registry.json +313 -0
- package/templates/claude/commands/review/codebase/parallel.md +122 -0
- package/templates/claude/commands/review/codebase.md +47 -0
- package/templates/claude/commands/scout/ext.md +35 -0
- package/templates/claude/commands/scout.md +28 -0
- package/templates/claude/commands/skill/add.md +36 -0
- package/templates/claude/commands/skill/create.md +29 -0
- package/templates/claude/commands/skill/fix-logs.md +22 -0
- package/templates/claude/commands/skill/optimize/auto.md +25 -0
- package/templates/claude/commands/skill/optimize.md +34 -0
- package/templates/claude/commands/skill/plan.md +45 -0
- package/templates/claude/commands/test/ui.md +91 -0
- package/templates/claude/commands/test.md +8 -0
- package/templates/claude/commands/use-mcp.md +34 -0
- package/templates/claude/commands/watzup.md +8 -0
- package/templates/claude/commands/worktree.md +126 -0
- package/templates/claude/hooks/dev-rules-reminder.cjs +258 -0
- package/templates/claude/hooks/docs/README.md +42 -0
- package/templates/claude/hooks/lib/cctk-config-utils.cjs +751 -0
- package/templates/claude/hooks/lib/cctk-paths.cjs +106 -0
- package/templates/claude/hooks/lib/context-tracker.cjs +346 -0
- package/templates/claude/hooks/privacy-block.cjs +289 -0
- package/templates/claude/hooks/registry.json +77 -0
- package/templates/claude/hooks/scout-block/broad-pattern-detector.cjs +293 -0
- package/templates/claude/hooks/scout-block/error-formatter.cjs +156 -0
- package/templates/claude/hooks/scout-block/path-extractor.cjs +359 -0
- package/templates/claude/hooks/scout-block/pattern-matcher.cjs +184 -0
- package/templates/claude/hooks/scout-block/vendor/ignore.js +626 -0
- package/templates/claude/hooks/scout-block.cjs +167 -0
- package/templates/claude/hooks/session-end.cjs +35 -0
- package/templates/claude/hooks/session-init.cjs +214 -0
- package/templates/claude/hooks/subagent-init.cjs +161 -0
- package/templates/claude/hooks/write-compact-marker.cjs +153 -0
- package/templates/claude/output-styles/coding-level-1.md +148 -0
- package/templates/claude/output-styles/coding-level-2.md +159 -0
- package/templates/claude/output-styles/coding-level-3.md +91 -0
- package/templates/claude/scripts/README.md +33 -0
- package/templates/claude/scripts/generate-catalogs.cjs +318 -0
- package/templates/claude/scripts/registry.json +48 -0
- package/templates/claude/scripts/set-active-plan.cjs +45 -0
- package/templates/claude/scripts/validate-docs.cjs +447 -0
- package/templates/claude/scripts/worktree.cjs +658 -0
- package/templates/claude/skills/README.md +112 -0
- package/templates/claude/skills/ai-artist/SKILL.md +75 -0
- package/templates/claude/skills/ai-artist/references/advanced-techniques.md +184 -0
- package/templates/claude/skills/ai-artist/references/domain-code.md +66 -0
- package/templates/claude/skills/ai-artist/references/domain-data.md +72 -0
- package/templates/claude/skills/ai-artist/references/domain-marketing.md +66 -0
- package/templates/claude/skills/ai-artist/references/domain-patterns.md +33 -0
- package/templates/claude/skills/ai-artist/references/domain-writing.md +68 -0
- package/templates/claude/skills/ai-artist/references/image-prompting.md +141 -0
- package/templates/claude/skills/ai-artist/references/llm-prompting.md +165 -0
- package/templates/claude/skills/ai-artist/references/nano-banana.md +59 -0
- package/templates/claude/skills/ai-artist/references/reasoning-techniques.md +201 -0
- package/templates/claude/skills/backend-development/SKILL.md +95 -0
- package/templates/claude/skills/backend-development/references/backend-api-design.md +495 -0
- package/templates/claude/skills/backend-development/references/backend-architecture.md +454 -0
- package/templates/claude/skills/backend-development/references/backend-authentication.md +338 -0
- package/templates/claude/skills/backend-development/references/backend-code-quality.md +659 -0
- package/templates/claude/skills/backend-development/references/backend-debugging.md +904 -0
- package/templates/claude/skills/backend-development/references/backend-devops.md +494 -0
- package/templates/claude/skills/backend-development/references/backend-mindset.md +387 -0
- package/templates/claude/skills/backend-development/references/backend-performance.md +397 -0
- package/templates/claude/skills/backend-development/references/backend-security.md +290 -0
- package/templates/claude/skills/backend-development/references/backend-technologies.md +256 -0
- package/templates/claude/skills/backend-development/references/backend-testing.md +429 -0
- package/templates/claude/skills/better-auth/SKILL.md +204 -0
- package/templates/claude/skills/better-auth/references/advanced-features.md +553 -0
- package/templates/claude/skills/better-auth/references/database-integration.md +577 -0
- package/templates/claude/skills/better-auth/references/email-password-auth.md +416 -0
- package/templates/claude/skills/better-auth/references/oauth-providers.md +430 -0
- package/templates/claude/skills/better-auth/scripts/better_auth_init.py +521 -0
- package/templates/claude/skills/chrome-devtools/SKILL.md +473 -0
- package/templates/claude/skills/chrome-devtools/references/cdp-domains.md +694 -0
- package/templates/claude/skills/chrome-devtools/references/performance-guide.md +940 -0
- package/templates/claude/skills/chrome-devtools/references/puppeteer-reference.md +953 -0
- package/templates/claude/skills/chrome-devtools/scripts/README.md +288 -0
- package/templates/claude/skills/chrome-devtools/scripts/aria-snapshot.js +368 -0
- package/templates/claude/skills/chrome-devtools/scripts/click.js +92 -0
- package/templates/claude/skills/chrome-devtools/scripts/console.js +85 -0
- package/templates/claude/skills/chrome-devtools/scripts/evaluate.js +59 -0
- package/templates/claude/skills/chrome-devtools/scripts/fill.js +84 -0
- package/templates/claude/skills/chrome-devtools/scripts/inject-auth.js +247 -0
- package/templates/claude/skills/chrome-devtools/scripts/install-deps.sh +11 -0
- package/templates/claude/skills/chrome-devtools/scripts/install.sh +36 -0
- package/templates/claude/skills/chrome-devtools/scripts/lib/browser.js +335 -0
- package/templates/claude/skills/chrome-devtools/scripts/lib/selector.js +183 -0
- package/templates/claude/skills/chrome-devtools/scripts/navigate.js +60 -0
- package/templates/claude/skills/chrome-devtools/scripts/network.js +113 -0
- package/templates/claude/skills/chrome-devtools/scripts/package.json +16 -0
- package/templates/claude/skills/chrome-devtools/scripts/performance.js +159 -0
- package/templates/claude/skills/chrome-devtools/scripts/screenshot.js +212 -0
- package/templates/claude/skills/chrome-devtools/scripts/select-ref.js +151 -0
- package/templates/claude/skills/chrome-devtools/scripts/snapshot.js +143 -0
- package/templates/claude/skills/chrome-devtools/scripts/ws-debug.js +47 -0
- package/templates/claude/skills/chrome-devtools/scripts/ws-full-debug.js +115 -0
- package/templates/claude/skills/claude-code/references/advanced-features.md +399 -0
- package/templates/claude/skills/claude-code/references/agent-skills.md +399 -0
- package/templates/claude/skills/claude-code/references/api-reference.md +498 -0
- package/templates/claude/skills/claude-code/references/best-practices.md +447 -0
- package/templates/claude/skills/claude-code/references/cicd-integration.md +428 -0
- package/templates/claude/skills/claude-code/references/common-workflows.md +107 -0
- package/templates/claude/skills/claude-code/references/configuration.md +480 -0
- package/templates/claude/skills/claude-code/references/enterprise-features.md +472 -0
- package/templates/claude/skills/claude-code/references/getting-started.md +244 -0
- package/templates/claude/skills/claude-code/references/hooks-and-plugins.md +444 -0
- package/templates/claude/skills/claude-code/references/hooks-comprehensive.md +622 -0
- package/templates/claude/skills/claude-code/references/ide-integration.md +316 -0
- package/templates/claude/skills/claude-code/references/mcp-integration.md +386 -0
- package/templates/claude/skills/claude-code/references/slash-commands.md +460 -0
- package/templates/claude/skills/claude-code/references/troubleshooting.md +455 -0
- package/templates/claude/skills/claude-code/skill.md +60 -0
- package/templates/claude/skills/code-review/SKILL.md +143 -0
- package/templates/claude/skills/code-review/references/code-review-reception.md +209 -0
- package/templates/claude/skills/code-review/references/requesting-code-review.md +105 -0
- package/templates/claude/skills/code-review/references/verification-before-completion.md +139 -0
- package/templates/claude/skills/context-engineering/SKILL.md +86 -0
- package/templates/claude/skills/context-engineering/references/context-compression.md +84 -0
- package/templates/claude/skills/context-engineering/references/context-degradation.md +93 -0
- package/templates/claude/skills/context-engineering/references/context-fundamentals.md +75 -0
- package/templates/claude/skills/context-engineering/references/context-optimization.md +82 -0
- package/templates/claude/skills/context-engineering/references/evaluation.md +89 -0
- package/templates/claude/skills/context-engineering/references/memory-systems.md +88 -0
- package/templates/claude/skills/context-engineering/references/multi-agent-patterns.md +90 -0
- package/templates/claude/skills/context-engineering/references/project-development.md +97 -0
- package/templates/claude/skills/context-engineering/references/tool-design.md +86 -0
- package/templates/claude/skills/context-engineering/scripts/compression_evaluator.py +329 -0
- package/templates/claude/skills/context-engineering/scripts/context_analyzer.py +294 -0
- package/templates/claude/skills/databases/SKILL.md +232 -0
- package/templates/claude/skills/databases/references/mongodb-aggregation.md +447 -0
- package/templates/claude/skills/databases/references/mongodb-atlas.md +465 -0
- package/templates/claude/skills/databases/references/mongodb-crud.md +408 -0
- package/templates/claude/skills/databases/references/mongodb-indexing.md +442 -0
- package/templates/claude/skills/databases/references/postgresql-administration.md +594 -0
- package/templates/claude/skills/databases/references/postgresql-performance.md +527 -0
- package/templates/claude/skills/databases/references/postgresql-psql-cli.md +467 -0
- package/templates/claude/skills/databases/references/postgresql-queries.md +475 -0
- package/templates/claude/skills/databases/scripts/db_backup.py +502 -0
- package/templates/claude/skills/databases/scripts/db_migrate.py +414 -0
- package/templates/claude/skills/databases/scripts/db_performance_check.py +445 -0
- package/templates/claude/skills/debugging/SKILL.md +84 -0
- package/templates/claude/skills/debugging/references/defense-in-depth.md +124 -0
- package/templates/claude/skills/debugging/references/root-cause-tracing.md +122 -0
- package/templates/claude/skills/debugging/references/systematic-debugging.md +102 -0
- package/templates/claude/skills/debugging/references/verification.md +123 -0
- package/templates/claude/skills/debugging/scripts/find-polluter.sh +63 -0
- package/templates/claude/skills/debugging/scripts/find-polluter.test.md +102 -0
- package/templates/claude/skills/devops/SKILL.md +293 -0
- package/templates/claude/skills/devops/references/browser-rendering.md +305 -0
- package/templates/claude/skills/devops/references/cloudflare-d1-kv.md +123 -0
- package/templates/claude/skills/devops/references/cloudflare-platform.md +271 -0
- package/templates/claude/skills/devops/references/cloudflare-r2-storage.md +280 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-advanced.md +312 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-apis.md +309 -0
- package/templates/claude/skills/devops/references/cloudflare-workers-basics.md +418 -0
- package/templates/claude/skills/devops/references/docker-basics.md +297 -0
- package/templates/claude/skills/devops/references/docker-compose.md +292 -0
- package/templates/claude/skills/devops/references/gcloud-platform.md +307 -0
- package/templates/claude/skills/devops/references/gcloud-services.md +304 -0
- package/templates/claude/skills/devops/scripts/cloudflare_deploy.py +269 -0
- package/templates/claude/skills/devops/scripts/docker_optimize.py +320 -0
- package/templates/claude/skills/docs-seeker/SKILL.md +95 -0
- package/templates/claude/skills/docs-seeker/package.json +24 -0
- package/templates/claude/skills/docs-seeker/references/advanced.md +78 -0
- package/templates/claude/skills/docs-seeker/references/context7-patterns.md +68 -0
- package/templates/claude/skills/docs-seeker/references/errors.md +68 -0
- package/templates/claude/skills/docs-seeker/scripts/analyze-llms-txt.js +245 -0
- package/templates/claude/skills/docs-seeker/scripts/detect-topic.js +172 -0
- package/templates/claude/skills/docs-seeker/scripts/fetch-docs.js +212 -0
- package/templates/claude/skills/docs-seeker/workflows/library-search.md +87 -0
- package/templates/claude/skills/docs-seeker/workflows/repo-analysis.md +91 -0
- package/templates/claude/skills/docs-seeker/workflows/topic-search.md +77 -0
- package/templates/claude/skills/frontend-design/SKILL.md +85 -0
- package/templates/claude/skills/frontend-design/references/analysis-best-practices.md +80 -0
- package/templates/claude/skills/frontend-design/references/analysis-prompts.md +141 -0
- package/templates/claude/skills/frontend-design/references/analysis-techniques.md +118 -0
- package/templates/claude/skills/frontend-design/references/animejs.md +396 -0
- package/templates/claude/skills/frontend-design/references/design-extraction-overview.md +71 -0
- package/templates/claude/skills/frontend-design/references/extraction-best-practices.md +141 -0
- package/templates/claude/skills/frontend-design/references/extraction-output-templates.md +162 -0
- package/templates/claude/skills/frontend-design/references/extraction-prompts.md +127 -0
- package/templates/claude/skills/frontend-design/references/technical-accessibility.md +119 -0
- package/templates/claude/skills/frontend-design/references/technical-best-practices.md +97 -0
- package/templates/claude/skills/frontend-design/references/technical-optimization.md +44 -0
- package/templates/claude/skills/frontend-design/references/technical-overview.md +90 -0
- package/templates/claude/skills/frontend-design/references/technical-workflows.md +150 -0
- package/templates/claude/skills/frontend-design/references/visual-analysis-overview.md +95 -0
- package/templates/claude/skills/frontend-development/SKILL.md +399 -0
- package/templates/claude/skills/frontend-development/resources/common-patterns.md +331 -0
- package/templates/claude/skills/frontend-development/resources/complete-examples.md +872 -0
- package/templates/claude/skills/frontend-development/resources/component-patterns.md +502 -0
- package/templates/claude/skills/frontend-development/resources/data-fetching.md +767 -0
- package/templates/claude/skills/frontend-development/resources/file-organization.md +502 -0
- package/templates/claude/skills/frontend-development/resources/loading-and-error-states.md +501 -0
- package/templates/claude/skills/frontend-development/resources/performance.md +406 -0
- package/templates/claude/skills/frontend-development/resources/routing-guide.md +364 -0
- package/templates/claude/skills/frontend-development/resources/styling-guide.md +428 -0
- package/templates/claude/skills/frontend-development/resources/typescript-standards.md +418 -0
- package/templates/claude/skills/markdown-novel-viewer/SKILL.md +272 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/directory-browser.css +215 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/favicon.png +0 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/novel-theme.css +872 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/reader.js +378 -0
- package/templates/claude/skills/markdown-novel-viewer/assets/template.html +85 -0
- package/templates/claude/skills/markdown-novel-viewer/package.json +15 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/http-server.cjs +434 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/markdown-renderer.cjs +335 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/plan-navigator.cjs +509 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/port-finder.cjs +49 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/lib/process-mgr.cjs +150 -0
- package/templates/claude/skills/markdown-novel-viewer/scripts/server.cjs +398 -0
- package/templates/claude/skills/mcp-builder/SKILL.md +328 -0
- package/templates/claude/skills/mcp-builder/reference/evaluation.md +602 -0
- package/templates/claude/skills/mcp-builder/reference/mcp_best_practices.md +915 -0
- package/templates/claude/skills/mcp-builder/reference/node_mcp_server.md +916 -0
- package/templates/claude/skills/mcp-builder/reference/python_mcp_server.md +752 -0
- package/templates/claude/skills/mcp-builder/scripts/connections.py +151 -0
- package/templates/claude/skills/mcp-builder/scripts/evaluation.py +381 -0
- package/templates/claude/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
- package/templates/claude/skills/mcp-builder/scripts/requirements.txt +2 -0
- package/templates/claude/skills/mcp-management/README.md +219 -0
- package/templates/claude/skills/mcp-management/SKILL.md +209 -0
- package/templates/claude/skills/mcp-management/assets/tools.json +3146 -0
- package/templates/claude/skills/mcp-management/references/configuration.md +114 -0
- package/templates/claude/skills/mcp-management/references/gemini-cli-integration.md +209 -0
- package/templates/claude/skills/mcp-management/references/mcp-protocol.md +116 -0
- package/templates/claude/skills/mcp-management/scripts/.env.example +10 -0
- package/templates/claude/skills/mcp-management/scripts/cli.ts +202 -0
- package/templates/claude/skills/mcp-management/scripts/mcp-client.ts +247 -0
- package/templates/claude/skills/mcp-management/scripts/package.json +20 -0
- package/templates/claude/skills/mcp-management/scripts/tsconfig.json +15 -0
- package/templates/claude/skills/media-processing/SKILL.md +91 -0
- package/templates/claude/skills/media-processing/references/common-workflows.md +132 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-encoding.md +358 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-filters.md +503 -0
- package/templates/claude/skills/media-processing/references/ffmpeg-streaming.md +395 -0
- package/templates/claude/skills/media-processing/references/format-compatibility.md +375 -0
- package/templates/claude/skills/media-processing/references/imagemagick-batch.md +612 -0
- package/templates/claude/skills/media-processing/references/imagemagick-editing.md +623 -0
- package/templates/claude/skills/media-processing/references/rmbg-background-removal.md +66 -0
- package/templates/claude/skills/media-processing/references/troubleshooting.md +109 -0
- package/templates/claude/skills/media-processing/scripts/README.md +102 -0
- package/templates/claude/skills/media-processing/scripts/batch-remove-background.sh +124 -0
- package/templates/claude/skills/media-processing/scripts/batch_resize.py +342 -0
- package/templates/claude/skills/media-processing/scripts/media_convert.py +311 -0
- package/templates/claude/skills/media-processing/scripts/remove-background.sh +96 -0
- package/templates/claude/skills/media-processing/scripts/remove-bg-node.js +181 -0
- package/templates/claude/skills/mermaidjs-v11/SKILL.md +115 -0
- package/templates/claude/skills/mermaidjs-v11/references/cli-usage.md +228 -0
- package/templates/claude/skills/mermaidjs-v11/references/configuration.md +232 -0
- package/templates/claude/skills/mermaidjs-v11/references/diagram-types.md +315 -0
- package/templates/claude/skills/mermaidjs-v11/references/examples.md +344 -0
- package/templates/claude/skills/mermaidjs-v11/references/integration.md +310 -0
- package/templates/claude/skills/planning/SKILL.md +115 -0
- package/templates/claude/skills/planning/references/codebase-understanding.md +62 -0
- package/templates/claude/skills/planning/references/output-standards.md +127 -0
- package/templates/claude/skills/planning/references/plan-organization.md +150 -0
- package/templates/claude/skills/planning/references/research-phase.md +49 -0
- package/templates/claude/skills/planning/references/solution-design.md +63 -0
- package/templates/claude/skills/plans-kanban/SKILL.md +157 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard-template.html +119 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard.css +1594 -0
- package/templates/claude/skills/plans-kanban/assets/dashboard.js +659 -0
- package/templates/claude/skills/plans-kanban/assets/favicon.png +0 -0
- package/templates/claude/skills/plans-kanban/package.json +13 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/dashboard-renderer.cjs +941 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/http-server.cjs +310 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-metadata-extractor.cjs +489 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-parser.cjs +194 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/plan-scanner.cjs +277 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/port-finder.cjs +49 -0
- package/templates/claude/skills/plans-kanban/scripts/lib/process-mgr.cjs +128 -0
- package/templates/claude/skills/plans-kanban/scripts/server.cjs +249 -0
- package/templates/claude/skills/problem-solving/SKILL.md +96 -0
- package/templates/claude/skills/problem-solving/references/attribution.md +69 -0
- package/templates/claude/skills/problem-solving/references/collision-zone-thinking.md +79 -0
- package/templates/claude/skills/problem-solving/references/inversion-exercise.md +91 -0
- package/templates/claude/skills/problem-solving/references/meta-pattern-recognition.md +87 -0
- package/templates/claude/skills/problem-solving/references/scale-game.md +95 -0
- package/templates/claude/skills/problem-solving/references/simplification-cascades.md +80 -0
- package/templates/claude/skills/problem-solving/references/when-stuck.md +72 -0
- package/templates/claude/skills/registry.json +258 -0
- package/templates/claude/skills/repomix/SKILL.md +247 -0
- package/templates/claude/skills/repomix/references/configuration.md +211 -0
- package/templates/claude/skills/repomix/references/usage-patterns.md +232 -0
- package/templates/claude/skills/repomix/scripts/README.md +179 -0
- package/templates/claude/skills/repomix/scripts/repomix_batch.py +455 -0
- package/templates/claude/skills/repomix/scripts/repos.example.json +15 -0
- package/templates/claude/skills/research/SKILL.md +168 -0
- package/templates/claude/skills/sequential-thinking/.env.example +8 -0
- package/templates/claude/skills/sequential-thinking/README.md +183 -0
- package/templates/claude/skills/sequential-thinking/SKILL.md +94 -0
- package/templates/claude/skills/sequential-thinking/package.json +31 -0
- package/templates/claude/skills/sequential-thinking/references/advanced-strategies.md +79 -0
- package/templates/claude/skills/sequential-thinking/references/advanced-techniques.md +76 -0
- package/templates/claude/skills/sequential-thinking/references/core-patterns.md +95 -0
- package/templates/claude/skills/sequential-thinking/references/examples-api.md +88 -0
- package/templates/claude/skills/sequential-thinking/references/examples-architecture.md +94 -0
- package/templates/claude/skills/sequential-thinking/references/examples-debug.md +90 -0
- package/templates/claude/skills/sequential-thinking/scripts/format-thought.js +182 -0
- package/templates/claude/skills/sequential-thinking/scripts/process-thought.js +252 -0
- package/templates/claude/skills/skill-creator/LICENSE.txt +202 -0
- package/templates/claude/skills/skill-creator/SKILL.md +266 -0
- package/templates/claude/skills/skill-creator/references/agent-skills-spec.md +51 -0
- package/templates/claude/skills/skill-creator/scripts/encoding_utils.py +21 -0
- package/templates/claude/skills/skill-creator/scripts/init_skill.py +304 -0
- package/templates/claude/skills/skill-creator/scripts/package_skill.py +110 -0
- package/templates/claude/skills/skill-creator/scripts/quick_validate.py +66 -0
- package/templates/claude/skills/template-skill/SKILL.md +6 -0
- package/templates/claude/skills/vitest/SKILL.md +595 -0
- package/templates/claude/skills/vitest/references/async-patterns.md +82 -0
- package/templates/claude/skills/vitest/references/mock-patterns.md +78 -0
- package/templates/claude/skills/vitest/references/monorepo-setup.md +185 -0
- package/templates/claude/skills/vitest/references/turborepo-setup.md +332 -0
- package/templates/claude/skills/web-frameworks/SKILL.md +324 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-app-router.md +465 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-data-fetching.md +459 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-optimization.md +511 -0
- package/templates/claude/skills/web-frameworks/references/nextjs-server-components.md +495 -0
- package/templates/claude/skills/web-frameworks/references/remix-icon-integration.md +603 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-caching.md +551 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-pipelines.md +517 -0
- package/templates/claude/skills/web-frameworks/references/turborepo-setup.md +542 -0
- package/templates/claude/skills/web-frameworks/scripts/nextjs_init.py +547 -0
- package/templates/claude/skills/web-frameworks/scripts/turborepo_migrate.py +394 -0
- package/templates/claude/workflows/development-rules.md +40 -0
- package/templates/claude/workflows/documentation-management.md +121 -0
- package/templates/claude/workflows/orchestration-protocol.md +16 -0
- package/templates/claude/workflows/primary-workflow.md +45 -0
- package/templates/claude/workflows/registry.json +37 -0
- package/templates/common/.cct.json +41 -0
- package/templates/common/.cctkignore +22 -0
- package/templates/common/.env.example +39 -0
- package/templates/common/.mcp.json.example +16 -0
- package/templates/common/metadata.json +15 -0
- package/templates/common/settings.json +79 -0
- package/templates/common/statusline.cjs +271 -0
- package/templates/config/.repomixignore +22 -0
- package/templates/config/AGENTS.md +55 -0
- package/templates/config/CLAUDE.md +87 -0
- package/templates/plans/bug-fix-template.md +69 -0
- package/templates/plans/feature-implementation-template.md +84 -0
- package/templates/plans/refactor-template.md +82 -0
- package/templates/plans/template-usage-guide.md +58 -0
|
@@ -0,0 +1,312 @@
|
|
|
1
|
+
# Cloudflare Workers Advanced Patterns
|
|
2
|
+
|
|
3
|
+
Advanced techniques for optimization, performance, and complex workflows.
|
|
4
|
+
|
|
5
|
+
## Session Reuse and Connection Pooling
|
|
6
|
+
|
|
7
|
+
### Durable Objects for Persistent Sessions
|
|
8
|
+
```typescript
|
|
9
|
+
export class Browser {
|
|
10
|
+
state: DurableObjectState;
|
|
11
|
+
browser: any;
|
|
12
|
+
lastUsed: number;
|
|
13
|
+
|
|
14
|
+
constructor(state: DurableObjectState, env: Env) {
|
|
15
|
+
this.state = state;
|
|
16
|
+
this.lastUsed = Date.now();
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
async fetch(request: Request, env: Env) {
|
|
20
|
+
if (!this.browser) {
|
|
21
|
+
this.browser = await puppeteer.launch(env.MYBROWSER);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
this.lastUsed = Date.now();
|
|
25
|
+
await this.state.storage.setAlarm(Date.now() + 10000);
|
|
26
|
+
|
|
27
|
+
const page = await this.browser.newPage();
|
|
28
|
+
await page.goto(new URL(request.url).searchParams.get('url'));
|
|
29
|
+
const screenshot = await page.screenshot();
|
|
30
|
+
await page.close();
|
|
31
|
+
|
|
32
|
+
return new Response(screenshot);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
async alarm() {
|
|
36
|
+
if (Date.now() - this.lastUsed > 60000) {
|
|
37
|
+
await this.browser?.close();
|
|
38
|
+
this.browser = null;
|
|
39
|
+
} else {
|
|
40
|
+
await this.state.storage.setAlarm(Date.now() + 10000);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
## Multi-Tier Caching Strategy
|
|
47
|
+
|
|
48
|
+
```typescript
|
|
49
|
+
const CACHE_TTL = 3600;
|
|
50
|
+
|
|
51
|
+
export default {
|
|
52
|
+
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
|
|
53
|
+
const cache = caches.default;
|
|
54
|
+
const cacheKey = new Request(request.url);
|
|
55
|
+
|
|
56
|
+
// 1. Check edge cache
|
|
57
|
+
let response = await cache.match(cacheKey);
|
|
58
|
+
if (response) return response;
|
|
59
|
+
|
|
60
|
+
// 2. Check KV cache
|
|
61
|
+
const kvCached = await env.MY_KV.get(request.url);
|
|
62
|
+
if (kvCached) {
|
|
63
|
+
response = new Response(kvCached);
|
|
64
|
+
ctx.waitUntil(cache.put(cacheKey, response.clone()));
|
|
65
|
+
return response;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
// 3. Fetch from origin
|
|
69
|
+
response = await fetch(request);
|
|
70
|
+
|
|
71
|
+
// 4. Store in both caches
|
|
72
|
+
ctx.waitUntil(Promise.all([
|
|
73
|
+
cache.put(cacheKey, response.clone()),
|
|
74
|
+
env.MY_KV.put(request.url, await response.clone().text(), {
|
|
75
|
+
expirationTtl: CACHE_TTL
|
|
76
|
+
})
|
|
77
|
+
]));
|
|
78
|
+
|
|
79
|
+
return response;
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
## WebSocket with Durable Objects
|
|
85
|
+
|
|
86
|
+
```typescript
|
|
87
|
+
export class ChatRoom {
|
|
88
|
+
state: DurableObjectState;
|
|
89
|
+
sessions: Set<WebSocket>;
|
|
90
|
+
|
|
91
|
+
constructor(state: DurableObjectState) {
|
|
92
|
+
this.state = state;
|
|
93
|
+
this.sessions = new Set();
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
async fetch(request: Request) {
|
|
97
|
+
const pair = new WebSocketPair();
|
|
98
|
+
const [client, server] = Object.values(pair);
|
|
99
|
+
|
|
100
|
+
this.state.acceptWebSocket(server);
|
|
101
|
+
this.sessions.add(server);
|
|
102
|
+
|
|
103
|
+
return new Response(null, { status: 101, webSocket: client });
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
async webSocketMessage(ws: WebSocket, message: string) {
|
|
107
|
+
// Broadcast to all connected clients
|
|
108
|
+
for (const session of this.sessions) {
|
|
109
|
+
session.send(message);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
async webSocketClose(ws: WebSocket) {
|
|
114
|
+
this.sessions.delete(ws);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
## Queue-Based Crawler
|
|
120
|
+
|
|
121
|
+
```typescript
|
|
122
|
+
export default {
|
|
123
|
+
async queue(batch: MessageBatch<any>, env: Env): Promise<void> {
|
|
124
|
+
const browser = await puppeteer.launch(env.MYBROWSER);
|
|
125
|
+
|
|
126
|
+
for (const message of batch.messages) {
|
|
127
|
+
const page = await browser.newPage();
|
|
128
|
+
await page.goto(message.body.url);
|
|
129
|
+
|
|
130
|
+
// Extract links
|
|
131
|
+
const links = await page.evaluate(() => {
|
|
132
|
+
return Array.from(document.querySelectorAll('a'))
|
|
133
|
+
.map(a => a.href);
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
// Queue new links
|
|
137
|
+
for (const link of links) {
|
|
138
|
+
await env.QUEUE.send({ url: link });
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
await page.close();
|
|
142
|
+
message.ack();
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
await browser.close();
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
```
|
|
149
|
+
|
|
150
|
+
## Authentication Pattern
|
|
151
|
+
|
|
152
|
+
```typescript
|
|
153
|
+
import { sign, verify } from 'hono/jwt';
|
|
154
|
+
|
|
155
|
+
async function authenticate(request: Request, env: Env): Promise<any> {
|
|
156
|
+
const authHeader = request.headers.get('Authorization');
|
|
157
|
+
|
|
158
|
+
if (!authHeader?.startsWith('Bearer ')) {
|
|
159
|
+
throw new Error('Missing token');
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
const token = authHeader.substring(7);
|
|
163
|
+
const payload = await verify(token, env.JWT_SECRET);
|
|
164
|
+
|
|
165
|
+
return payload;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
export default {
|
|
169
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
170
|
+
try {
|
|
171
|
+
const user = await authenticate(request, env);
|
|
172
|
+
return new Response(`Hello ${user.name}`);
|
|
173
|
+
} catch (error) {
|
|
174
|
+
return new Response('Unauthorized', { status: 401 });
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
## Code Splitting
|
|
181
|
+
|
|
182
|
+
```typescript
|
|
183
|
+
// Lazy load large dependencies
|
|
184
|
+
export default {
|
|
185
|
+
async fetch(request: Request): Promise<Response> {
|
|
186
|
+
const url = new URL(request.url);
|
|
187
|
+
|
|
188
|
+
if (url.pathname === '/heavy') {
|
|
189
|
+
const { processHeavy } = await import('./heavy');
|
|
190
|
+
return processHeavy(request);
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
return new Response('OK');
|
|
194
|
+
}
|
|
195
|
+
};
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
## Batch Operations with D1
|
|
199
|
+
|
|
200
|
+
```typescript
|
|
201
|
+
// Efficient bulk inserts
|
|
202
|
+
const statements = users.map(user =>
|
|
203
|
+
env.DB.prepare('INSERT INTO users (name, email) VALUES (?, ?)')
|
|
204
|
+
.bind(user.name, user.email)
|
|
205
|
+
);
|
|
206
|
+
|
|
207
|
+
await env.DB.batch(statements);
|
|
208
|
+
```
|
|
209
|
+
|
|
210
|
+
## Stream Processing
|
|
211
|
+
|
|
212
|
+
```typescript
|
|
213
|
+
const { readable, writable } = new TransformStream({
|
|
214
|
+
transform(chunk, controller) {
|
|
215
|
+
// Process chunk
|
|
216
|
+
controller.enqueue(chunk);
|
|
217
|
+
}
|
|
218
|
+
});
|
|
219
|
+
|
|
220
|
+
response.body.pipeTo(writable);
|
|
221
|
+
return new Response(readable);
|
|
222
|
+
```
|
|
223
|
+
|
|
224
|
+
## AI-Powered Web Scraper
|
|
225
|
+
|
|
226
|
+
```typescript
|
|
227
|
+
import { Ai } from '@cloudflare/ai';
|
|
228
|
+
|
|
229
|
+
export default {
|
|
230
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
231
|
+
// Render page
|
|
232
|
+
const browser = await puppeteer.launch(env.MYBROWSER);
|
|
233
|
+
const page = await browser.newPage();
|
|
234
|
+
await page.goto('https://news.ycombinator.com');
|
|
235
|
+
const content = await page.content();
|
|
236
|
+
await browser.close();
|
|
237
|
+
|
|
238
|
+
// Extract with AI
|
|
239
|
+
const ai = new Ai(env.AI);
|
|
240
|
+
const response = await ai.run('@cf/meta/llama-3-8b-instruct', {
|
|
241
|
+
messages: [
|
|
242
|
+
{
|
|
243
|
+
role: 'system',
|
|
244
|
+
content: 'Extract top 5 article titles and URLs as JSON array'
|
|
245
|
+
},
|
|
246
|
+
{ role: 'user', content: content }
|
|
247
|
+
]
|
|
248
|
+
});
|
|
249
|
+
|
|
250
|
+
return Response.json(response);
|
|
251
|
+
}
|
|
252
|
+
};
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
## Performance Optimization
|
|
256
|
+
|
|
257
|
+
### Bundle Size
|
|
258
|
+
- Keep Workers <1MB bundled
|
|
259
|
+
- Remove unused dependencies
|
|
260
|
+
- Use code splitting
|
|
261
|
+
- Check with: `wrangler deploy --dry-run --outdir=dist`
|
|
262
|
+
|
|
263
|
+
### Cold Starts
|
|
264
|
+
- Minimize initialization code
|
|
265
|
+
- Use bindings over fetch
|
|
266
|
+
- Avoid large imports at top level
|
|
267
|
+
|
|
268
|
+
### Memory Management
|
|
269
|
+
- Close pages when done: `await page.close()`
|
|
270
|
+
- Disconnect browsers: `await browser.disconnect()`
|
|
271
|
+
- Implement cleanup alarms in Durable Objects
|
|
272
|
+
|
|
273
|
+
### Request Optimization
|
|
274
|
+
- Use server-side filtering with `--filter`
|
|
275
|
+
- Batch operations with D1 `.batch()`
|
|
276
|
+
- Stream large responses
|
|
277
|
+
- Implement proper caching
|
|
278
|
+
|
|
279
|
+
## Monitoring & Debugging
|
|
280
|
+
|
|
281
|
+
```bash
|
|
282
|
+
# Real-time logs
|
|
283
|
+
wrangler tail --format pretty
|
|
284
|
+
|
|
285
|
+
# Filter by status
|
|
286
|
+
wrangler tail --status error
|
|
287
|
+
|
|
288
|
+
# Check deployments
|
|
289
|
+
wrangler deployments list
|
|
290
|
+
|
|
291
|
+
# Rollback
|
|
292
|
+
wrangler rollback [version-id]
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
## Production Checklist
|
|
296
|
+
|
|
297
|
+
- [ ] Multi-stage error handling implemented
|
|
298
|
+
- [ ] Rate limiting configured
|
|
299
|
+
- [ ] Caching strategy in place
|
|
300
|
+
- [ ] Secrets managed with `wrangler secret`
|
|
301
|
+
- [ ] Health checks implemented
|
|
302
|
+
- [ ] Monitoring alerts configured
|
|
303
|
+
- [ ] Session reuse for browser rendering
|
|
304
|
+
- [ ] Resource cleanup (pages, browsers)
|
|
305
|
+
- [ ] Proper timeout configurations
|
|
306
|
+
- [ ] CI/CD pipeline set up
|
|
307
|
+
|
|
308
|
+
## Resources
|
|
309
|
+
|
|
310
|
+
- Advanced Patterns: https://developers.cloudflare.com/workers/examples/
|
|
311
|
+
- Durable Objects: https://developers.cloudflare.com/workers/runtime-apis/durable-objects/
|
|
312
|
+
- Performance: https://developers.cloudflare.com/workers/platform/limits/
|
|
@@ -0,0 +1,309 @@
|
|
|
1
|
+
# Cloudflare Workers Runtime APIs
|
|
2
|
+
|
|
3
|
+
Key runtime APIs for Workers development.
|
|
4
|
+
|
|
5
|
+
## Fetch API
|
|
6
|
+
|
|
7
|
+
```typescript
|
|
8
|
+
// Subrequest
|
|
9
|
+
const response = await fetch('https://api.example.com/data', {
|
|
10
|
+
method: 'POST',
|
|
11
|
+
headers: { 'Content-Type': 'application/json' },
|
|
12
|
+
body: JSON.stringify({ key: 'value' }),
|
|
13
|
+
cf: {
|
|
14
|
+
cacheTtl: 3600,
|
|
15
|
+
cacheEverything: true
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
const data = await response.json();
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## Headers API
|
|
23
|
+
|
|
24
|
+
```typescript
|
|
25
|
+
// Read headers
|
|
26
|
+
const userAgent = request.headers.get('User-Agent');
|
|
27
|
+
|
|
28
|
+
// Cloudflare-specific
|
|
29
|
+
const country = request.cf?.country;
|
|
30
|
+
const colo = request.cf?.colo;
|
|
31
|
+
const clientIP = request.headers.get('CF-Connecting-IP');
|
|
32
|
+
|
|
33
|
+
// Set headers
|
|
34
|
+
const headers = new Headers();
|
|
35
|
+
headers.set('Content-Type', 'application/json');
|
|
36
|
+
headers.append('X-Custom-Header', 'value');
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
## HTMLRewriter
|
|
40
|
+
|
|
41
|
+
```typescript
|
|
42
|
+
export default {
|
|
43
|
+
async fetch(request: Request): Promise<Response> {
|
|
44
|
+
const response = await fetch(request);
|
|
45
|
+
|
|
46
|
+
return new HTMLRewriter()
|
|
47
|
+
.on('title', {
|
|
48
|
+
element(element) {
|
|
49
|
+
element.setInnerContent('New Title');
|
|
50
|
+
}
|
|
51
|
+
})
|
|
52
|
+
.on('a[href]', {
|
|
53
|
+
element(element) {
|
|
54
|
+
const href = element.getAttribute('href');
|
|
55
|
+
element.setAttribute('href', href.replace('http://', 'https://'));
|
|
56
|
+
}
|
|
57
|
+
})
|
|
58
|
+
.transform(response);
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## WebSockets
|
|
64
|
+
|
|
65
|
+
```typescript
|
|
66
|
+
export default {
|
|
67
|
+
async fetch(request: Request): Promise<Response> {
|
|
68
|
+
const upgradeHeader = request.headers.get('Upgrade');
|
|
69
|
+
if (upgradeHeader !== 'websocket') {
|
|
70
|
+
return new Response('Expected WebSocket', { status: 426 });
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const pair = new WebSocketPair();
|
|
74
|
+
const [client, server] = Object.values(pair);
|
|
75
|
+
|
|
76
|
+
server.accept();
|
|
77
|
+
|
|
78
|
+
server.addEventListener('message', (event) => {
|
|
79
|
+
server.send(`Echo: ${event.data}`);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
return new Response(null, {
|
|
83
|
+
status: 101,
|
|
84
|
+
webSocket: client
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
## Streams API
|
|
91
|
+
|
|
92
|
+
```typescript
|
|
93
|
+
const { readable, writable } = new TransformStream();
|
|
94
|
+
|
|
95
|
+
const writer = writable.getWriter();
|
|
96
|
+
writer.write(new TextEncoder().encode('chunk 1'));
|
|
97
|
+
writer.write(new TextEncoder().encode('chunk 2'));
|
|
98
|
+
writer.close();
|
|
99
|
+
|
|
100
|
+
return new Response(readable, {
|
|
101
|
+
headers: { 'Content-Type': 'text/plain' }
|
|
102
|
+
});
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
## Web Crypto API
|
|
106
|
+
|
|
107
|
+
```typescript
|
|
108
|
+
// Generate hash
|
|
109
|
+
const data = new TextEncoder().encode('message');
|
|
110
|
+
const hashBuffer = await crypto.subtle.digest('SHA-256', data);
|
|
111
|
+
const hashArray = Array.from(new Uint8Array(hashBuffer));
|
|
112
|
+
const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('');
|
|
113
|
+
|
|
114
|
+
// HMAC signature
|
|
115
|
+
const key = await crypto.subtle.importKey(
|
|
116
|
+
'raw',
|
|
117
|
+
new TextEncoder().encode('secret'),
|
|
118
|
+
{ name: 'HMAC', hash: 'SHA-256' },
|
|
119
|
+
false,
|
|
120
|
+
['sign', 'verify']
|
|
121
|
+
);
|
|
122
|
+
|
|
123
|
+
const signature = await crypto.subtle.sign('HMAC', key, data);
|
|
124
|
+
const valid = await crypto.subtle.verify('HMAC', key, signature, data);
|
|
125
|
+
|
|
126
|
+
// Random values
|
|
127
|
+
const randomBytes = crypto.getRandomValues(new Uint8Array(32));
|
|
128
|
+
const uuid = crypto.randomUUID();
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
## Encoding APIs
|
|
132
|
+
|
|
133
|
+
```typescript
|
|
134
|
+
// TextEncoder
|
|
135
|
+
const encoder = new TextEncoder();
|
|
136
|
+
const bytes = encoder.encode('Hello');
|
|
137
|
+
|
|
138
|
+
// TextDecoder
|
|
139
|
+
const decoder = new TextDecoder();
|
|
140
|
+
const text = decoder.decode(bytes);
|
|
141
|
+
|
|
142
|
+
// Base64
|
|
143
|
+
const base64 = btoa('Hello');
|
|
144
|
+
const decoded = atob(base64);
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
## URL API
|
|
148
|
+
|
|
149
|
+
```typescript
|
|
150
|
+
const url = new URL(request.url);
|
|
151
|
+
const hostname = url.hostname;
|
|
152
|
+
const pathname = url.pathname;
|
|
153
|
+
const search = url.search;
|
|
154
|
+
|
|
155
|
+
// Query parameters
|
|
156
|
+
const name = url.searchParams.get('name');
|
|
157
|
+
url.searchParams.set('page', '2');
|
|
158
|
+
url.searchParams.delete('old');
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
## FormData API
|
|
162
|
+
|
|
163
|
+
```typescript
|
|
164
|
+
// Parse form data
|
|
165
|
+
const formData = await request.formData();
|
|
166
|
+
const name = formData.get('name');
|
|
167
|
+
const file = formData.get('file');
|
|
168
|
+
|
|
169
|
+
// Create form data
|
|
170
|
+
const form = new FormData();
|
|
171
|
+
form.append('name', 'value');
|
|
172
|
+
form.append('file', blob, 'filename.txt');
|
|
173
|
+
```
|
|
174
|
+
|
|
175
|
+
## Response Types
|
|
176
|
+
|
|
177
|
+
```typescript
|
|
178
|
+
// Text
|
|
179
|
+
return new Response('Hello');
|
|
180
|
+
|
|
181
|
+
// JSON
|
|
182
|
+
return Response.json({ message: 'Hello' });
|
|
183
|
+
|
|
184
|
+
// Stream
|
|
185
|
+
return new Response(readable);
|
|
186
|
+
|
|
187
|
+
// Redirect
|
|
188
|
+
return Response.redirect('https://example.com', 302);
|
|
189
|
+
|
|
190
|
+
// Error
|
|
191
|
+
return new Response('Not Found', { status: 404 });
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
## Request Cloning
|
|
195
|
+
|
|
196
|
+
```typescript
|
|
197
|
+
// Clone for multiple reads
|
|
198
|
+
const clone = request.clone();
|
|
199
|
+
const body1 = await request.json();
|
|
200
|
+
const body2 = await clone.json();
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
## AbortController
|
|
204
|
+
|
|
205
|
+
```typescript
|
|
206
|
+
const controller = new AbortController();
|
|
207
|
+
const { signal } = controller;
|
|
208
|
+
|
|
209
|
+
setTimeout(() => controller.abort(), 5000);
|
|
210
|
+
|
|
211
|
+
try {
|
|
212
|
+
const response = await fetch('https://slow-api.com', { signal });
|
|
213
|
+
} catch (error) {
|
|
214
|
+
if (error.name === 'AbortError') {
|
|
215
|
+
console.log('Request timed out');
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
## Scheduling APIs
|
|
221
|
+
|
|
222
|
+
```typescript
|
|
223
|
+
// setTimeout
|
|
224
|
+
const timeoutId = setTimeout(() => {
|
|
225
|
+
console.log('Delayed');
|
|
226
|
+
}, 1000);
|
|
227
|
+
|
|
228
|
+
// setInterval
|
|
229
|
+
const intervalId = setInterval(() => {
|
|
230
|
+
console.log('Repeated');
|
|
231
|
+
}, 1000);
|
|
232
|
+
|
|
233
|
+
// Clear
|
|
234
|
+
clearTimeout(timeoutId);
|
|
235
|
+
clearInterval(intervalId);
|
|
236
|
+
```
|
|
237
|
+
|
|
238
|
+
## Console API
|
|
239
|
+
|
|
240
|
+
```typescript
|
|
241
|
+
console.log('Info message');
|
|
242
|
+
console.error('Error message');
|
|
243
|
+
console.warn('Warning message');
|
|
244
|
+
console.debug('Debug message');
|
|
245
|
+
|
|
246
|
+
// Structured logging
|
|
247
|
+
console.log(JSON.stringify({
|
|
248
|
+
level: 'info',
|
|
249
|
+
message: 'Request processed',
|
|
250
|
+
url: request.url,
|
|
251
|
+
timestamp: new Date().toISOString()
|
|
252
|
+
}));
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
## Performance API
|
|
256
|
+
|
|
257
|
+
```typescript
|
|
258
|
+
const start = performance.now();
|
|
259
|
+
await processRequest();
|
|
260
|
+
const duration = performance.now() - start;
|
|
261
|
+
console.log(`Processed in ${duration}ms`);
|
|
262
|
+
```
|
|
263
|
+
|
|
264
|
+
## Bindings Reference
|
|
265
|
+
|
|
266
|
+
### KV Operations
|
|
267
|
+
```typescript
|
|
268
|
+
await env.KV.put(key, value, { expirationTtl: 3600, metadata: { userId: '123' } });
|
|
269
|
+
const value = await env.KV.get(key, 'json');
|
|
270
|
+
const { value, metadata } = await env.KV.getWithMetadata(key);
|
|
271
|
+
await env.KV.delete(key);
|
|
272
|
+
const list = await env.KV.list({ prefix: 'user:' });
|
|
273
|
+
```
|
|
274
|
+
|
|
275
|
+
### D1 Operations
|
|
276
|
+
```typescript
|
|
277
|
+
const result = await env.DB.prepare('SELECT * FROM users WHERE id = ?').bind(userId).first();
|
|
278
|
+
const { results } = await env.DB.prepare('SELECT * FROM users').all();
|
|
279
|
+
await env.DB.prepare('INSERT INTO users (name) VALUES (?)').bind(name).run();
|
|
280
|
+
await env.DB.batch([stmt1, stmt2, stmt3]);
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
### R2 Operations
|
|
284
|
+
```typescript
|
|
285
|
+
await env.R2.put(key, value, { httpMetadata: { contentType: 'image/jpeg' } });
|
|
286
|
+
const object = await env.R2.get(key);
|
|
287
|
+
await env.R2.delete(key);
|
|
288
|
+
const list = await env.R2.list({ prefix: 'uploads/' });
|
|
289
|
+
const multipart = await env.R2.createMultipartUpload(key);
|
|
290
|
+
```
|
|
291
|
+
|
|
292
|
+
### Queue Operations
|
|
293
|
+
```typescript
|
|
294
|
+
await env.QUEUE.send({ type: 'email', to: 'user@example.com' });
|
|
295
|
+
await env.QUEUE.sendBatch([{ body: msg1 }, { body: msg2 }]);
|
|
296
|
+
```
|
|
297
|
+
|
|
298
|
+
### Workers AI
|
|
299
|
+
```typescript
|
|
300
|
+
const response = await env.AI.run('@cf/meta/llama-3-8b-instruct', {
|
|
301
|
+
messages: [{ role: 'user', content: 'What is edge computing?' }]
|
|
302
|
+
});
|
|
303
|
+
```
|
|
304
|
+
|
|
305
|
+
## Resources
|
|
306
|
+
|
|
307
|
+
- Runtime APIs: https://developers.cloudflare.com/workers/runtime-apis/
|
|
308
|
+
- Web Standards: https://developers.cloudflare.com/workers/runtime-apis/web-standards/
|
|
309
|
+
- Bindings: https://developers.cloudflare.com/workers/runtime-apis/bindings/
|