@bcelep/capint 0.4.2 → 0.6.5
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/AGENT.md +11 -1
- package/CHANGELOG.md +101 -0
- package/README.md +38 -10
- package/bin/capint.js +13 -1
- package/docs/PRD-v0.5-agent-capability-activation.md +430 -0
- package/docs/conventions/cli-scripting.md +60 -0
- package/docs/conventions/daily-use.md +132 -0
- package/docs/conventions/task-to-capability-cheatsheet.md +29 -0
- package/docs/execution-intent-contract.md +31 -3
- package/docs/kullanim-kilavuzu.md +374 -0
- package/docs/maintainer-dogfood.md +90 -0
- package/package.json +11 -2
- package/projections/session-start.md +14 -6
- package/registry.json +117 -4
- package/schemas/explanation.v1.json +48 -0
- package/scripts/capint-task.ps1 +38 -0
- package/scripts/capint-task.sh +40 -0
- package/scripts/release-check.mjs +14 -1
- package/scripts/validate-registry.mjs +44 -0
- package/skill-routing-matrix.json +50 -4
- package/skills/agent-browser/LICENSE +201 -0
- package/skills/agent-browser/SKILL.md +522 -0
- package/skills/agent-browser/agents/verdent.yaml +7 -0
- package/skills/agent-browser/assets/icon-dark.png +0 -0
- package/skills/agent-browser/assets/icon-light.png +0 -0
- package/skills/agent-browser/references/authentication.md +202 -0
- package/skills/agent-browser/references/commands.md +263 -0
- package/skills/agent-browser/references/profiling.md +120 -0
- package/skills/agent-browser/references/proxy-support.md +194 -0
- package/skills/agent-browser/references/session-management.md +193 -0
- package/skills/agent-browser/references/snapshot-refs.md +194 -0
- package/skills/agent-browser/references/video-recording.md +173 -0
- package/skills/agent-browser/templates/authenticated-session.sh +105 -0
- package/skills/agent-browser/templates/capture-workflow.sh +69 -0
- package/skills/agent-browser/templates/form-automation.sh +62 -0
- package/skills/algorithmic-art/LICENSE.txt +202 -0
- package/skills/algorithmic-art/SKILL.md +410 -0
- package/skills/algorithmic-art/agents/verdent.yaml +11 -0
- package/skills/algorithmic-art/assets/icon-dark.png +0 -0
- package/skills/algorithmic-art/assets/icon-light.png +0 -0
- package/skills/algorithmic-art/templates/generator_template.js +223 -0
- package/skills/algorithmic-art/templates/viewer.html +599 -0
- package/skills/api-and-interface-design/SKILL.md +294 -0
- package/skills/aspnet-core/LICENSE.txt +202 -0
- package/skills/aspnet-core/SKILL.md +67 -0
- package/skills/aspnet-core/agents/verdent.yaml +11 -0
- package/skills/aspnet-core/assets/dotnet-logo.png +0 -0
- package/skills/aspnet-core/assets/icon-dark.png +0 -0
- package/skills/aspnet-core/assets/icon-light.png +0 -0
- package/skills/aspnet-core/references/_sections.md +40 -0
- package/skills/aspnet-core/references/apis-minimal-and-controllers.md +81 -0
- package/skills/aspnet-core/references/data-state-and-services.md +69 -0
- package/skills/aspnet-core/references/program-and-pipeline.md +103 -0
- package/skills/aspnet-core/references/realtime-grpc-and-background-work.md +58 -0
- package/skills/aspnet-core/references/security-and-identity.md +75 -0
- package/skills/aspnet-core/references/source-map.md +43 -0
- package/skills/aspnet-core/references/stack-selection.md +63 -0
- package/skills/aspnet-core/references/testing-performance-and-operations.md +92 -0
- package/skills/aspnet-core/references/ui-blazor.md +53 -0
- package/skills/aspnet-core/references/ui-mvc.md +56 -0
- package/skills/aspnet-core/references/ui-razor-pages.md +55 -0
- package/skills/aspnet-core/references/versioning-and-upgrades.md +51 -0
- package/skills/auth-patterns/SKILL.md +549 -0
- package/skills/best-practices/SKILL.md +641 -0
- package/skills/better-auth-best-practices/SKILL.md +180 -0
- package/skills/better-auth-best-practices/agents/verdent.yaml +11 -0
- package/skills/better-auth-best-practices/assets/icon-dark.png +0 -0
- package/skills/better-auth-best-practices/assets/icon-light.png +0 -0
- package/skills/brainstorming/SKILL.md +164 -0
- package/skills/brainstorming/spec-document-reviewer-prompt.md +49 -0
- package/skills/brainstorming/visual-companion.md +287 -0
- package/skills/canvas-design/LICENSE.txt +202 -0
- package/skills/canvas-design/SKILL.md +135 -0
- package/skills/canvas-design/agents/verdent.yaml +11 -0
- package/skills/canvas-design/assets/icon-dark.png +0 -0
- package/skills/canvas-design/assets/icon-light.png +0 -0
- package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
- package/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
- package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
- package/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
- package/skills/ci-cd-and-automation/SKILL.md +390 -0
- package/skills/cloudflare/SKILL.md +233 -0
- package/skills/cloudflare/agents/verdent.yaml +12 -0
- package/skills/cloudflare/assets/icon-dark.png +0 -0
- package/skills/cloudflare/assets/icon-light.png +0 -0
- package/skills/cloudflare/references/agents-sdk/README.md +89 -0
- package/skills/cloudflare/references/agents-sdk/api.md +190 -0
- package/skills/cloudflare/references/agents-sdk/configuration.md +182 -0
- package/skills/cloudflare/references/agents-sdk/gotchas.md +158 -0
- package/skills/cloudflare/references/agents-sdk/patterns.md +192 -0
- package/skills/cloudflare/references/ai-gateway/README.md +175 -0
- package/skills/cloudflare/references/ai-gateway/configuration.md +111 -0
- package/skills/cloudflare/references/ai-gateway/dynamic-routing.md +82 -0
- package/skills/cloudflare/references/ai-gateway/features.md +96 -0
- package/skills/cloudflare/references/ai-gateway/sdk-integration.md +114 -0
- package/skills/cloudflare/references/ai-gateway/troubleshooting.md +88 -0
- package/skills/cloudflare/references/ai-search/README.md +138 -0
- package/skills/cloudflare/references/ai-search/api.md +87 -0
- package/skills/cloudflare/references/ai-search/configuration.md +88 -0
- package/skills/cloudflare/references/ai-search/gotchas.md +81 -0
- package/skills/cloudflare/references/ai-search/patterns.md +85 -0
- package/skills/cloudflare/references/analytics-engine/README.md +94 -0
- package/skills/cloudflare/references/analytics-engine/api.md +112 -0
- package/skills/cloudflare/references/analytics-engine/configuration.md +112 -0
- package/skills/cloudflare/references/analytics-engine/gotchas.md +85 -0
- package/skills/cloudflare/references/analytics-engine/patterns.md +83 -0
- package/skills/cloudflare/references/api/README.md +66 -0
- package/skills/cloudflare/references/api/api.md +204 -0
- package/skills/cloudflare/references/api/configuration.md +160 -0
- package/skills/cloudflare/references/api/gotchas.md +225 -0
- package/skills/cloudflare/references/api/patterns.md +204 -0
- package/skills/cloudflare/references/api-shield/README.md +44 -0
- package/skills/cloudflare/references/api-shield/api.md +141 -0
- package/skills/cloudflare/references/api-shield/configuration.md +192 -0
- package/skills/cloudflare/references/api-shield/gotchas.md +125 -0
- package/skills/cloudflare/references/api-shield/patterns.md +180 -0
- package/skills/cloudflare/references/argo-smart-routing/README.md +90 -0
- package/skills/cloudflare/references/argo-smart-routing/api.md +240 -0
- package/skills/cloudflare/references/argo-smart-routing/configuration.md +197 -0
- package/skills/cloudflare/references/argo-smart-routing/gotchas.md +111 -0
- package/skills/cloudflare/references/argo-smart-routing/patterns.md +104 -0
- package/skills/cloudflare/references/bindings/README.md +122 -0
- package/skills/cloudflare/references/bindings/api.md +203 -0
- package/skills/cloudflare/references/bindings/configuration.md +188 -0
- package/skills/cloudflare/references/bindings/gotchas.md +208 -0
- package/skills/cloudflare/references/bindings/patterns.md +200 -0
- package/skills/cloudflare/references/bot-management/README.md +94 -0
- package/skills/cloudflare/references/bot-management/api.md +169 -0
- package/skills/cloudflare/references/bot-management/configuration.md +163 -0
- package/skills/cloudflare/references/bot-management/gotchas.md +114 -0
- package/skills/cloudflare/references/bot-management/patterns.md +182 -0
- package/skills/cloudflare/references/browser-rendering/README.md +78 -0
- package/skills/cloudflare/references/browser-rendering/api.md +108 -0
- package/skills/cloudflare/references/browser-rendering/configuration.md +78 -0
- package/skills/cloudflare/references/browser-rendering/gotchas.md +88 -0
- package/skills/cloudflare/references/browser-rendering/patterns.md +91 -0
- package/skills/cloudflare/references/c3/README.md +111 -0
- package/skills/cloudflare/references/c3/api.md +71 -0
- package/skills/cloudflare/references/c3/configuration.md +81 -0
- package/skills/cloudflare/references/c3/gotchas.md +92 -0
- package/skills/cloudflare/references/c3/patterns.md +82 -0
- package/skills/cloudflare/references/cache-reserve/README.md +147 -0
- package/skills/cloudflare/references/cache-reserve/api.md +194 -0
- package/skills/cloudflare/references/cache-reserve/configuration.md +169 -0
- package/skills/cloudflare/references/cache-reserve/gotchas.md +132 -0
- package/skills/cloudflare/references/cache-reserve/patterns.md +197 -0
- package/skills/cloudflare/references/containers/README.md +85 -0
- package/skills/cloudflare/references/containers/api.md +187 -0
- package/skills/cloudflare/references/containers/configuration.md +188 -0
- package/skills/cloudflare/references/containers/gotchas.md +178 -0
- package/skills/cloudflare/references/containers/patterns.md +202 -0
- package/skills/cloudflare/references/cron-triggers/README.md +99 -0
- package/skills/cloudflare/references/cron-triggers/api.md +196 -0
- package/skills/cloudflare/references/cron-triggers/configuration.md +180 -0
- package/skills/cloudflare/references/cron-triggers/gotchas.md +199 -0
- package/skills/cloudflare/references/cron-triggers/patterns.md +190 -0
- package/skills/cloudflare/references/d1/README.md +133 -0
- package/skills/cloudflare/references/d1/api.md +196 -0
- package/skills/cloudflare/references/d1/configuration.md +188 -0
- package/skills/cloudflare/references/d1/gotchas.md +98 -0
- package/skills/cloudflare/references/d1/patterns.md +189 -0
- package/skills/cloudflare/references/ddos/README.md +41 -0
- package/skills/cloudflare/references/ddos/api.md +164 -0
- package/skills/cloudflare/references/ddos/configuration.md +93 -0
- package/skills/cloudflare/references/ddos/gotchas.md +107 -0
- package/skills/cloudflare/references/ddos/patterns.md +174 -0
- package/skills/cloudflare/references/do-storage/README.md +75 -0
- package/skills/cloudflare/references/do-storage/api.md +102 -0
- package/skills/cloudflare/references/do-storage/configuration.md +112 -0
- package/skills/cloudflare/references/do-storage/gotchas.md +150 -0
- package/skills/cloudflare/references/do-storage/patterns.md +194 -0
- package/skills/cloudflare/references/do-storage/testing.md +183 -0
- package/skills/cloudflare/references/durable-objects/README.md +185 -0
- package/skills/cloudflare/references/durable-objects/api.md +187 -0
- package/skills/cloudflare/references/durable-objects/configuration.md +160 -0
- package/skills/cloudflare/references/durable-objects/gotchas.md +197 -0
- package/skills/cloudflare/references/durable-objects/patterns.md +201 -0
- package/skills/cloudflare/references/email-routing/README.md +89 -0
- package/skills/cloudflare/references/email-routing/api.md +195 -0
- package/skills/cloudflare/references/email-routing/configuration.md +186 -0
- package/skills/cloudflare/references/email-routing/gotchas.md +196 -0
- package/skills/cloudflare/references/email-routing/patterns.md +229 -0
- package/skills/cloudflare/references/email-workers/README.md +151 -0
- package/skills/cloudflare/references/email-workers/api.md +237 -0
- package/skills/cloudflare/references/email-workers/configuration.md +112 -0
- package/skills/cloudflare/references/email-workers/gotchas.md +125 -0
- package/skills/cloudflare/references/email-workers/patterns.md +102 -0
- package/skills/cloudflare/references/graphql-api/README.md +147 -0
- package/skills/cloudflare/references/graphql-api/api.md +175 -0
- package/skills/cloudflare/references/graphql-api/configuration.md +118 -0
- package/skills/cloudflare/references/graphql-api/gotchas.md +110 -0
- package/skills/cloudflare/references/graphql-api/patterns.md +225 -0
- package/skills/cloudflare/references/hyperdrive/README.md +82 -0
- package/skills/cloudflare/references/hyperdrive/api.md +143 -0
- package/skills/cloudflare/references/hyperdrive/configuration.md +159 -0
- package/skills/cloudflare/references/hyperdrive/gotchas.md +77 -0
- package/skills/cloudflare/references/hyperdrive/patterns.md +190 -0
- package/skills/cloudflare/references/images/README.md +61 -0
- package/skills/cloudflare/references/images/api.md +96 -0
- package/skills/cloudflare/references/images/configuration.md +211 -0
- package/skills/cloudflare/references/images/gotchas.md +99 -0
- package/skills/cloudflare/references/images/patterns.md +115 -0
- package/skills/cloudflare/references/kv/README.md +89 -0
- package/skills/cloudflare/references/kv/api.md +160 -0
- package/skills/cloudflare/references/kv/configuration.md +144 -0
- package/skills/cloudflare/references/kv/gotchas.md +131 -0
- package/skills/cloudflare/references/kv/patterns.md +196 -0
- package/skills/cloudflare/references/miniflare/README.md +105 -0
- package/skills/cloudflare/references/miniflare/api.md +187 -0
- package/skills/cloudflare/references/miniflare/configuration.md +173 -0
- package/skills/cloudflare/references/miniflare/gotchas.md +160 -0
- package/skills/cloudflare/references/miniflare/patterns.md +181 -0
- package/skills/cloudflare/references/network-interconnect/README.md +99 -0
- package/skills/cloudflare/references/network-interconnect/api.md +199 -0
- package/skills/cloudflare/references/network-interconnect/configuration.md +114 -0
- package/skills/cloudflare/references/network-interconnect/gotchas.md +165 -0
- package/skills/cloudflare/references/network-interconnect/patterns.md +166 -0
- package/skills/cloudflare/references/observability/README.md +88 -0
- package/skills/cloudflare/references/observability/api.md +164 -0
- package/skills/cloudflare/references/observability/configuration.md +169 -0
- package/skills/cloudflare/references/observability/gotchas.md +115 -0
- package/skills/cloudflare/references/observability/patterns.md +105 -0
- package/skills/cloudflare/references/pages/README.md +88 -0
- package/skills/cloudflare/references/pages/api.md +204 -0
- package/skills/cloudflare/references/pages/configuration.md +201 -0
- package/skills/cloudflare/references/pages/gotchas.md +203 -0
- package/skills/cloudflare/references/pages/patterns.md +204 -0
- package/skills/cloudflare/references/pages-functions/README.md +98 -0
- package/skills/cloudflare/references/pages-functions/api.md +143 -0
- package/skills/cloudflare/references/pages-functions/configuration.md +122 -0
- package/skills/cloudflare/references/pages-functions/gotchas.md +94 -0
- package/skills/cloudflare/references/pages-functions/patterns.md +137 -0
- package/skills/cloudflare/references/pipelines/README.md +105 -0
- package/skills/cloudflare/references/pipelines/api.md +208 -0
- package/skills/cloudflare/references/pipelines/configuration.md +98 -0
- package/skills/cloudflare/references/pipelines/gotchas.md +80 -0
- package/skills/cloudflare/references/pipelines/patterns.md +87 -0
- package/skills/cloudflare/references/pulumi/README.md +100 -0
- package/skills/cloudflare/references/pulumi/api.md +200 -0
- package/skills/cloudflare/references/pulumi/configuration.md +198 -0
- package/skills/cloudflare/references/pulumi/gotchas.md +181 -0
- package/skills/cloudflare/references/pulumi/patterns.md +191 -0
- package/skills/cloudflare/references/queues/README.md +96 -0
- package/skills/cloudflare/references/queues/api.md +206 -0
- package/skills/cloudflare/references/queues/configuration.md +144 -0
- package/skills/cloudflare/references/queues/gotchas.md +206 -0
- package/skills/cloudflare/references/queues/patterns.md +220 -0
- package/skills/cloudflare/references/r2/README.md +95 -0
- package/skills/cloudflare/references/r2/api.md +200 -0
- package/skills/cloudflare/references/r2/configuration.md +165 -0
- package/skills/cloudflare/references/r2/gotchas.md +190 -0
- package/skills/cloudflare/references/r2/patterns.md +193 -0
- package/skills/cloudflare/references/r2-data-catalog/README.md +149 -0
- package/skills/cloudflare/references/r2-data-catalog/api.md +199 -0
- package/skills/cloudflare/references/r2-data-catalog/configuration.md +198 -0
- package/skills/cloudflare/references/r2-data-catalog/gotchas.md +170 -0
- package/skills/cloudflare/references/r2-data-catalog/patterns.md +191 -0
- package/skills/cloudflare/references/r2-sql/README.md +128 -0
- package/skills/cloudflare/references/r2-sql/SKILL.md.backup +512 -0
- package/skills/cloudflare/references/r2-sql/api.md +158 -0
- package/skills/cloudflare/references/r2-sql/configuration.md +147 -0
- package/skills/cloudflare/references/r2-sql/gotchas.md +212 -0
- package/skills/cloudflare/references/r2-sql/patterns.md +222 -0
- package/skills/cloudflare/references/realtime-sfu/README.md +65 -0
- package/skills/cloudflare/references/realtime-sfu/api.md +158 -0
- package/skills/cloudflare/references/realtime-sfu/configuration.md +137 -0
- package/skills/cloudflare/references/realtime-sfu/gotchas.md +133 -0
- package/skills/cloudflare/references/realtime-sfu/patterns.md +174 -0
- package/skills/cloudflare/references/realtimekit/README.md +113 -0
- package/skills/cloudflare/references/realtimekit/api.md +212 -0
- package/skills/cloudflare/references/realtimekit/configuration.md +203 -0
- package/skills/cloudflare/references/realtimekit/gotchas.md +169 -0
- package/skills/cloudflare/references/realtimekit/patterns.md +223 -0
- package/skills/cloudflare/references/sandbox/README.md +96 -0
- package/skills/cloudflare/references/sandbox/api.md +198 -0
- package/skills/cloudflare/references/sandbox/configuration.md +143 -0
- package/skills/cloudflare/references/sandbox/gotchas.md +194 -0
- package/skills/cloudflare/references/sandbox/patterns.md +201 -0
- package/skills/cloudflare/references/secrets-store/README.md +74 -0
- package/skills/cloudflare/references/secrets-store/api.md +200 -0
- package/skills/cloudflare/references/secrets-store/configuration.md +185 -0
- package/skills/cloudflare/references/secrets-store/gotchas.md +97 -0
- package/skills/cloudflare/references/secrets-store/patterns.md +207 -0
- package/skills/cloudflare/references/smart-placement/README.md +138 -0
- package/skills/cloudflare/references/smart-placement/api.md +183 -0
- package/skills/cloudflare/references/smart-placement/configuration.md +196 -0
- package/skills/cloudflare/references/smart-placement/gotchas.md +174 -0
- package/skills/cloudflare/references/smart-placement/patterns.md +183 -0
- package/skills/cloudflare/references/snippets/README.md +68 -0
- package/skills/cloudflare/references/snippets/api.md +198 -0
- package/skills/cloudflare/references/snippets/configuration.md +227 -0
- package/skills/cloudflare/references/snippets/gotchas.md +86 -0
- package/skills/cloudflare/references/snippets/patterns.md +135 -0
- package/skills/cloudflare/references/spectrum/README.md +52 -0
- package/skills/cloudflare/references/spectrum/api.md +181 -0
- package/skills/cloudflare/references/spectrum/configuration.md +194 -0
- package/skills/cloudflare/references/spectrum/gotchas.md +145 -0
- package/skills/cloudflare/references/spectrum/patterns.md +196 -0
- package/skills/cloudflare/references/static-assets/README.md +65 -0
- package/skills/cloudflare/references/static-assets/api.md +199 -0
- package/skills/cloudflare/references/static-assets/configuration.md +186 -0
- package/skills/cloudflare/references/static-assets/gotchas.md +162 -0
- package/skills/cloudflare/references/static-assets/patterns.md +189 -0
- package/skills/cloudflare/references/stream/README.md +114 -0
- package/skills/cloudflare/references/stream/api-live.md +195 -0
- package/skills/cloudflare/references/stream/api.md +199 -0
- package/skills/cloudflare/references/stream/configuration.md +141 -0
- package/skills/cloudflare/references/stream/gotchas.md +130 -0
- package/skills/cloudflare/references/stream/patterns.md +184 -0
- package/skills/cloudflare/references/tail-workers/README.md +89 -0
- package/skills/cloudflare/references/tail-workers/api.md +200 -0
- package/skills/cloudflare/references/tail-workers/configuration.md +176 -0
- package/skills/cloudflare/references/tail-workers/gotchas.md +192 -0
- package/skills/cloudflare/references/tail-workers/patterns.md +180 -0
- package/skills/cloudflare/references/terraform/README.md +102 -0
- package/skills/cloudflare/references/terraform/api.md +178 -0
- package/skills/cloudflare/references/terraform/configuration.md +197 -0
- package/skills/cloudflare/references/terraform/gotchas.md +150 -0
- package/skills/cloudflare/references/terraform/patterns.md +174 -0
- package/skills/cloudflare/references/tunnel/README.md +129 -0
- package/skills/cloudflare/references/tunnel/api.md +193 -0
- package/skills/cloudflare/references/tunnel/configuration.md +157 -0
- package/skills/cloudflare/references/tunnel/gotchas.md +147 -0
- package/skills/cloudflare/references/tunnel/networking.md +168 -0
- package/skills/cloudflare/references/tunnel/patterns.md +192 -0
- package/skills/cloudflare/references/turn/README.md +82 -0
- package/skills/cloudflare/references/turn/api.md +239 -0
- package/skills/cloudflare/references/turn/configuration.md +179 -0
- package/skills/cloudflare/references/turn/gotchas.md +231 -0
- package/skills/cloudflare/references/turn/patterns.md +213 -0
- package/skills/cloudflare/references/turnstile/README.md +99 -0
- package/skills/cloudflare/references/turnstile/api.md +240 -0
- package/skills/cloudflare/references/turnstile/configuration.md +222 -0
- package/skills/cloudflare/references/turnstile/gotchas.md +218 -0
- package/skills/cloudflare/references/turnstile/patterns.md +193 -0
- package/skills/cloudflare/references/vectorize/README.md +133 -0
- package/skills/cloudflare/references/vectorize/api.md +88 -0
- package/skills/cloudflare/references/vectorize/configuration.md +88 -0
- package/skills/cloudflare/references/vectorize/gotchas.md +76 -0
- package/skills/cloudflare/references/vectorize/patterns.md +90 -0
- package/skills/cloudflare/references/waf/README.md +113 -0
- package/skills/cloudflare/references/waf/api.md +202 -0
- package/skills/cloudflare/references/waf/configuration.md +203 -0
- package/skills/cloudflare/references/waf/gotchas.md +204 -0
- package/skills/cloudflare/references/waf/patterns.md +197 -0
- package/skills/cloudflare/references/web-analytics/README.md +141 -0
- package/skills/cloudflare/references/web-analytics/configuration.md +76 -0
- package/skills/cloudflare/references/web-analytics/gotchas.md +82 -0
- package/skills/cloudflare/references/web-analytics/integration.md +60 -0
- package/skills/cloudflare/references/web-analytics/patterns.md +91 -0
- package/skills/cloudflare/references/workerd/README.md +78 -0
- package/skills/cloudflare/references/workerd/api.md +185 -0
- package/skills/cloudflare/references/workerd/configuration.md +183 -0
- package/skills/cloudflare/references/workerd/gotchas.md +139 -0
- package/skills/cloudflare/references/workerd/patterns.md +192 -0
- package/skills/cloudflare/references/workers/README.md +108 -0
- package/skills/cloudflare/references/workers/api.md +195 -0
- package/skills/cloudflare/references/workers/configuration.md +185 -0
- package/skills/cloudflare/references/workers/frameworks.md +197 -0
- package/skills/cloudflare/references/workers/gotchas.md +136 -0
- package/skills/cloudflare/references/workers/patterns.md +198 -0
- package/skills/cloudflare/references/workers-ai/README.md +197 -0
- package/skills/cloudflare/references/workers-ai/api.md +112 -0
- package/skills/cloudflare/references/workers-ai/configuration.md +97 -0
- package/skills/cloudflare/references/workers-ai/gotchas.md +114 -0
- package/skills/cloudflare/references/workers-ai/patterns.md +120 -0
- package/skills/cloudflare/references/workers-for-platforms/README.md +89 -0
- package/skills/cloudflare/references/workers-for-platforms/api.md +196 -0
- package/skills/cloudflare/references/workers-for-platforms/configuration.md +167 -0
- package/skills/cloudflare/references/workers-for-platforms/gotchas.md +134 -0
- package/skills/cloudflare/references/workers-for-platforms/patterns.md +188 -0
- package/skills/cloudflare/references/workers-playground/README.md +127 -0
- package/skills/cloudflare/references/workers-playground/api.md +101 -0
- package/skills/cloudflare/references/workers-playground/configuration.md +163 -0
- package/skills/cloudflare/references/workers-playground/gotchas.md +88 -0
- package/skills/cloudflare/references/workers-playground/patterns.md +132 -0
- package/skills/cloudflare/references/workers-vpc/README.md +127 -0
- package/skills/cloudflare/references/workers-vpc/api.md +202 -0
- package/skills/cloudflare/references/workers-vpc/configuration.md +147 -0
- package/skills/cloudflare/references/workers-vpc/gotchas.md +167 -0
- package/skills/cloudflare/references/workers-vpc/patterns.md +209 -0
- package/skills/cloudflare/references/workflows/README.md +69 -0
- package/skills/cloudflare/references/workflows/api.md +185 -0
- package/skills/cloudflare/references/workflows/configuration.md +151 -0
- package/skills/cloudflare/references/workflows/gotchas.md +97 -0
- package/skills/cloudflare/references/workflows/patterns.md +175 -0
- package/skills/cloudflare/references/wrangler/README.md +135 -0
- package/skills/cloudflare/references/wrangler/api.md +188 -0
- package/skills/cloudflare/references/wrangler/configuration.md +197 -0
- package/skills/cloudflare/references/wrangler/gotchas.md +197 -0
- package/skills/cloudflare/references/wrangler/patterns.md +209 -0
- package/skills/cloudflare/references/zaraz/IMPLEMENTATION_SUMMARY.md +121 -0
- package/skills/cloudflare/references/zaraz/README.md +111 -0
- package/skills/cloudflare/references/zaraz/api.md +112 -0
- package/skills/cloudflare/references/zaraz/configuration.md +90 -0
- package/skills/cloudflare/references/zaraz/gotchas.md +81 -0
- package/skills/cloudflare/references/zaraz/patterns.md +74 -0
- package/skills/code-reviewer/SKILL.md +347 -0
- package/skills/code-simplifier/SKILL.md +124 -0
- package/skills/code-simplifier/agents/verdent.yaml +11 -0
- package/skills/code-simplifier/assets/icon-dark.png +0 -0
- package/skills/code-simplifier/assets/icon-light.png +0 -0
- package/skills/concept-modeler/SKILL.md +178 -0
- package/skills/context-engineering/SKILL.md +289 -0
- package/skills/copywriting/SKILL.md +252 -0
- package/skills/copywriting/evals/evals.json +111 -0
- package/skills/copywriting/references/copy-frameworks.md +344 -0
- package/skills/copywriting/references/natural-transitions.md +272 -0
- package/skills/core-web-vitals/SKILL.md +483 -0
- package/skills/core-web-vitals/references/LCP.md +208 -0
- package/skills/craft-authoring/SKILL.md +123 -0
- package/skills/create-design-system-rules/SKILL.md +530 -0
- package/skills/create-design-system-rules/agents/verdent.yaml +11 -0
- package/skills/create-design-system-rules/assets/icon-dark.png +0 -0
- package/skills/create-design-system-rules/assets/icon-light.png +0 -0
- package/skills/database-and-data-modeling/SKILL.md +515 -0
- package/skills/database-blueprints/SKILL.md +60 -0
- package/skills/database-blueprints/agents/verdent.yaml +13 -0
- package/skills/database-blueprints/assets/icon-dark.png +0 -0
- package/skills/database-blueprints/assets/icon-light.png +0 -0
- package/skills/database-blueprints/references/core-schema.md +68 -0
- package/skills/database-blueprints/references/migration-safety.md +55 -0
- package/skills/database-blueprints/references/mysql.md +50 -0
- package/skills/database-blueprints/references/prisma.md +47 -0
- package/skills/database-blueprints/references/supabase-postgres.md +63 -0
- package/skills/delivery-acceptance/SKILL.md +60 -0
- package/skills/delivery-acceptance/agents/verdent.yaml +12 -0
- package/skills/delivery-acceptance/assets/icon-dark.png +0 -0
- package/skills/delivery-acceptance/assets/icon-light.png +0 -0
- package/skills/delivery-acceptance/references/acceptance-checklist.md +44 -0
- package/skills/delivery-acceptance/references/mobile-print-file.md +19 -0
- package/skills/delivery-acceptance/references/playwright-smoke.md +35 -0
- package/skills/dependency-audit/SKILL.md +97 -0
- package/skills/deprecation-and-migration/SKILL.md +206 -0
- package/skills/design-reviewer/SKILL.md +189 -0
- package/skills/develop-web-game/LICENSE.txt +201 -0
- package/skills/develop-web-game/SKILL.md +154 -0
- package/skills/develop-web-game/agents/verdent.yaml +12 -0
- package/skills/develop-web-game/assets/game-small.svg +4 -0
- package/skills/develop-web-game/assets/game.png +0 -0
- package/skills/develop-web-game/assets/icon-dark.png +0 -0
- package/skills/develop-web-game/assets/icon-light.png +0 -0
- package/skills/develop-web-game/references/action_payloads.json +7 -0
- package/skills/develop-web-game/scripts/web_game_playwright_client.js +356 -0
- package/skills/dignified-python/SKILL.md +175 -0
- package/skills/dignified-python/agents/verdent.yaml +11 -0
- package/skills/dignified-python/assets/icon-dark.png +0 -0
- package/skills/dignified-python/assets/icon-light.png +0 -0
- package/skills/dignified-python/cli-patterns.md +156 -0
- package/skills/dignified-python/dignified-python-core.md +345 -0
- package/skills/dignified-python/references/README.md +319 -0
- package/skills/dignified-python/references/advanced/api-design.md +230 -0
- package/skills/dignified-python/references/advanced/exception-handling.md +185 -0
- package/skills/dignified-python/references/advanced/interfaces.md +183 -0
- package/skills/dignified-python/references/advanced/typing-advanced.md +158 -0
- package/skills/dignified-python/references/checklists.md +134 -0
- package/skills/dignified-python/references/module-design.md +214 -0
- package/skills/dignified-python/subprocess.md +99 -0
- package/skills/dignified-python/versions/python-3.10.md +520 -0
- package/skills/dignified-python/versions/python-3.11.md +538 -0
- package/skills/dignified-python/versions/python-3.12.md +664 -0
- package/skills/dignified-python/versions/python-3.13.md +657 -0
- package/skills/dispatching-parallel-agents/SKILL.md +182 -0
- package/skills/documentation-and-adrs/SKILL.md +278 -0
- package/skills/documentation-sync/SKILL.md +76 -0
- package/skills/documentation-writer/SKILL.md +50 -0
- package/skills/documentation-writer/agents/verdent.yaml +10 -0
- package/skills/documentation-writer/assets/icon-dark.png +0 -0
- package/skills/documentation-writer/assets/icon-light.png +0 -0
- package/skills/docx/SKILL.md +186 -0
- package/skills/docx/agents/verdent.yaml +9 -0
- package/skills/docx/assets/docx.png +0 -0
- package/skills/docx/assets/icon-dark.png +0 -0
- package/skills/docx/assets/icon-light.png +0 -0
- package/skills/docx/references/creation-guide.md +309 -0
- package/skills/docx/references/xml-editing-guide.md +237 -0
- package/skills/docx/scripts/docx_tool.py +164 -0
- package/skills/docx/scripts/fixtures/comments.xml +3 -0
- package/skills/docx/scripts/fixtures/commentsExtended.xml +3 -0
- package/skills/docx/scripts/fixtures/commentsExtensible.xml +3 -0
- package/skills/docx/scripts/fixtures/commentsIds.xml +3 -0
- package/skills/docx/scripts/fixtures/people.xml +3 -0
- package/skills/docx/scripts/internals/__init__.py +0 -0
- package/skills/docx/scripts/internals/content.py +307 -0
- package/skills/docx/scripts/internals/integrity/__init__.py +0 -0
- package/skills/docx/scripts/internals/integrity/foundation.py +559 -0
- package/skills/docx/scripts/internals/integrity/orchestrator.py +66 -0
- package/skills/docx/scripts/internals/integrity/revision_checker.py +181 -0
- package/skills/docx/scripts/internals/integrity/schema_checker.py +294 -0
- package/skills/docx/scripts/internals/packaging.py +193 -0
- package/skills/docx/scripts/internals/preprocessing/__init__.py +0 -0
- package/skills/docx/scripts/internals/preprocessing/revision_merger.py +193 -0
- package/skills/docx/scripts/internals/preprocessing/run_consolidator.py +179 -0
- package/skills/docx/scripts/internals/runtime/__init__.py +0 -0
- package/skills/docx/scripts/internals/runtime/converter.py +184 -0
- package/skills/docx/scripts/internals/runtime/renderer.py +60 -0
- package/skills/docx/scripts/internals/runtime/revision_acceptor.py +122 -0
- package/skills/docx/scripts/render_docx.py +296 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
- package/skills/docx/scripts/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
- package/skills/docx/scripts/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
- package/skills/docx/scripts/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
- package/skills/docx/scripts/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
- package/skills/docx/scripts/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
- package/skills/docx/scripts/schemas/mce/mc.xsd +75 -0
- package/skills/docx/scripts/schemas/microsoft/wml-2010.xsd +560 -0
- package/skills/docx/scripts/schemas/microsoft/wml-2012.xsd +67 -0
- package/skills/docx/scripts/schemas/microsoft/wml-2018.xsd +14 -0
- package/skills/docx/scripts/schemas/microsoft/wml-cex-2018.xsd +20 -0
- package/skills/docx/scripts/schemas/microsoft/wml-cid-2016.xsd +13 -0
- package/skills/docx/scripts/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
- package/skills/docx/scripts/schemas/microsoft/wml-symex-2015.xsd +8 -0
- package/skills/doubt-driven-development/SKILL.md +243 -0
- package/skills/e2e-testing-guide/SKILL.md +204 -0
- package/skills/emil-design-eng/SKILL.md +679 -0
- package/skills/environment-and-config/SKILL.md +849 -0
- package/skills/error-handling/SKILL.md +757 -0
- package/skills/excalidraw-diagram-generator/SKILL.md +618 -0
- package/skills/excalidraw-diagram-generator/agents/verdent.yaml +11 -0
- package/skills/excalidraw-diagram-generator/assets/icon-dark.png +0 -0
- package/skills/excalidraw-diagram-generator/assets/icon-light.png +0 -0
- package/skills/excalidraw-diagram-generator/references/element-types.md +497 -0
- package/skills/excalidraw-diagram-generator/references/excalidraw-schema.md +350 -0
- package/skills/excalidraw-diagram-generator/scripts/README.md +193 -0
- package/skills/excalidraw-diagram-generator/scripts/add-arrow.py +312 -0
- package/skills/excalidraw-diagram-generator/scripts/add-icon-to-diagram.py +404 -0
- package/skills/excalidraw-diagram-generator/scripts/split-excalidraw-library.py +183 -0
- package/skills/excalidraw-diagram-generator/templates/business-flow-swimlane-template.excalidraw +334 -0
- package/skills/excalidraw-diagram-generator/templates/class-diagram-template.excalidraw +558 -0
- package/skills/excalidraw-diagram-generator/templates/data-flow-diagram-template.excalidraw +279 -0
- package/skills/excalidraw-diagram-generator/templates/er-diagram-template.excalidraw +662 -0
- package/skills/excalidraw-diagram-generator/templates/flowchart-template.excalidraw +179 -0
- package/skills/excalidraw-diagram-generator/templates/mindmap-template.excalidraw +244 -0
- package/skills/excalidraw-diagram-generator/templates/relationship-template.excalidraw +145 -0
- package/skills/excalidraw-diagram-generator/templates/sequence-diagram-template.excalidraw +509 -0
- package/skills/executing-plans/SKILL.md +245 -0
- package/skills/figma/LICENSE.txt +202 -0
- package/skills/figma/SKILL.md +53 -0
- package/skills/figma/agents/verdent.yaml +7 -0
- package/skills/figma/assets/figma.png +0 -0
- package/skills/figma/assets/icon-dark.png +0 -0
- package/skills/figma/assets/icon-light.png +0 -0
- package/skills/figma/assets/icon.svg +28 -0
- package/skills/figma/references/figma-mcp-config.md +49 -0
- package/skills/figma/references/figma-tools-and-prompts.md +39 -0
- package/skills/figma-implement-design/LICENSE.txt +202 -0
- package/skills/figma-implement-design/SKILL.md +265 -0
- package/skills/figma-implement-design/agents/verdent.yaml +7 -0
- package/skills/figma-implement-design/assets/figma.png +0 -0
- package/skills/figma-implement-design/assets/icon-dark.png +0 -0
- package/skills/figma-implement-design/assets/icon-light.png +0 -0
- package/skills/figma-implement-design/assets/icon.svg +28 -0
- package/skills/find-docs/SKILL.md +164 -0
- package/skills/find-docs/agents/verdent.yaml +11 -0
- package/skills/find-docs/assets/icon-dark.png +0 -0
- package/skills/find-docs/assets/icon-light.png +0 -0
- package/skills/find-skills/SKILL.md +142 -0
- package/skills/firecrawl/SKILL.md +131 -0
- package/skills/firecrawl/agents/verdent.yaml +11 -0
- package/skills/firecrawl/assets/icon-dark.png +0 -0
- package/skills/firecrawl/assets/icon-light.png +0 -0
- package/skills/firecrawl/rules/install.md +63 -0
- package/skills/firecrawl/rules/security.md +26 -0
- package/skills/flutter-architecting-apps/SKILL.md +164 -0
- package/skills/flutter-architecting-apps/agents/verdent.yaml +11 -0
- package/skills/flutter-architecting-apps/assets/icon-dark.png +0 -0
- package/skills/flutter-architecting-apps/assets/icon-light.png +0 -0
- package/skills/frontend-design-pro/SKILL.md +328 -0
- package/skills/frontend-slides/LICENSE +21 -0
- package/skills/frontend-slides/SKILL.md +1169 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +561 -0
- package/skills/frontend-slides/agents/verdent.yaml +7 -0
- package/skills/frontend-slides/assets/icon-dark.png +0 -0
- package/skills/frontend-slides/assets/icon-light.png +0 -0
- package/skills/gh-cli/SKILL.md +2192 -0
- package/skills/gh-cli/agents/verdent.yaml +12 -0
- package/skills/gh-cli/assets/icon-dark.png +0 -0
- package/skills/gh-cli/assets/icon-light.png +0 -0
- package/skills/git-commit/SKILL.md +129 -0
- package/skills/git-commit/agents/verdent.yaml +11 -0
- package/skills/git-commit/assets/icon-dark.png +0 -0
- package/skills/git-commit/assets/icon-light.png +0 -0
- package/skills/git-workflow-and-versioning/SKILL.md +300 -0
- package/skills/graphql-operations/SKILL.md +247 -0
- package/skills/graphql-operations/agents/verdent.yaml +11 -0
- package/skills/graphql-operations/assets/icon-dark.png +0 -0
- package/skills/graphql-operations/assets/icon-light.png +0 -0
- package/skills/graphql-operations/references/fragments.md +536 -0
- package/skills/graphql-operations/references/mutations.md +435 -0
- package/skills/graphql-operations/references/queries.md +504 -0
- package/skills/graphql-operations/references/tooling.md +404 -0
- package/skills/graphql-operations/references/variables.md +440 -0
- package/skills/graphql-schema/SKILL.md +175 -0
- package/skills/graphql-schema/agents/verdent.yaml +11 -0
- package/skills/graphql-schema/assets/icon-dark.png +0 -0
- package/skills/graphql-schema/assets/icon-light.png +0 -0
- package/skills/graphql-schema/references/errors.md +388 -0
- package/skills/graphql-schema/references/naming.md +400 -0
- package/skills/graphql-schema/references/pagination.md +396 -0
- package/skills/graphql-schema/references/security.md +484 -0
- package/skills/graphql-schema/references/types.md +445 -0
- package/skills/hugging-face-model-trainer/SKILL.md +722 -0
- package/skills/hugging-face-model-trainer/agents/verdent.yaml +12 -0
- package/skills/hugging-face-model-trainer/assets/icon-dark.png +0 -0
- package/skills/hugging-face-model-trainer/assets/icon-light.png +0 -0
- package/skills/hugging-face-model-trainer/references/gguf_conversion.md +296 -0
- package/skills/hugging-face-model-trainer/references/hardware_guide.md +283 -0
- package/skills/hugging-face-model-trainer/references/hub_saving.md +364 -0
- package/skills/hugging-face-model-trainer/references/local_training_macos.md +231 -0
- package/skills/hugging-face-model-trainer/references/reliability_principles.md +371 -0
- package/skills/hugging-face-model-trainer/references/trackio_guide.md +189 -0
- package/skills/hugging-face-model-trainer/references/training_methods.md +150 -0
- package/skills/hugging-face-model-trainer/references/training_patterns.md +203 -0
- package/skills/hugging-face-model-trainer/references/troubleshooting.md +282 -0
- package/skills/hugging-face-model-trainer/references/unsloth.md +313 -0
- package/skills/hugging-face-model-trainer/scripts/convert_to_gguf.py +424 -0
- package/skills/hugging-face-model-trainer/scripts/dataset_inspector.py +417 -0
- package/skills/hugging-face-model-trainer/scripts/estimate_cost.py +150 -0
- package/skills/hugging-face-model-trainer/scripts/train_dpo_example.py +106 -0
- package/skills/hugging-face-model-trainer/scripts/train_grpo_example.py +89 -0
- package/skills/hugging-face-model-trainer/scripts/train_sft_example.py +122 -0
- package/skills/hugging-face-model-trainer/scripts/unsloth_sft_example.py +512 -0
- package/skills/imagegen/LICENSE.txt +201 -0
- package/skills/imagegen/SKILL.md +180 -0
- package/skills/imagegen/agents/verdent.yaml +11 -0
- package/skills/imagegen/assets/icon-dark.png +0 -0
- package/skills/imagegen/assets/icon-light.png +0 -0
- package/skills/imagegen/assets/imagegen-small.svg +5 -0
- package/skills/imagegen/assets/imagegen.png +0 -0
- package/skills/imagegen/references/cli.md +132 -0
- package/skills/imagegen/references/image-api.md +36 -0
- package/skills/imagegen/references/network-notes.md +28 -0
- package/skills/imagegen/references/prompting.md +81 -0
- package/skills/imagegen/references/sample-prompts.md +384 -0
- package/skills/imagegen/scripts/image_gen.py +876 -0
- package/skills/impeccable/SKILL.md +450 -0
- package/skills/impeccable/reference/adapt.md +190 -0
- package/skills/impeccable/reference/animate.md +175 -0
- package/skills/impeccable/reference/audit.md +133 -0
- package/skills/impeccable/reference/bolder.md +113 -0
- package/skills/impeccable/reference/brand.md +114 -0
- package/skills/impeccable/reference/clarify.md +174 -0
- package/skills/impeccable/reference/cognitive-load.md +106 -0
- package/skills/impeccable/reference/color-and-contrast.md +105 -0
- package/skills/impeccable/reference/colorize.md +154 -0
- package/skills/impeccable/reference/craft.md +193 -0
- package/skills/impeccable/reference/critique.md +213 -0
- package/skills/impeccable/reference/delight.md +302 -0
- package/skills/impeccable/reference/distill.md +111 -0
- package/skills/impeccable/reference/document.md +427 -0
- package/skills/impeccable/reference/extract.md +69 -0
- package/skills/impeccable/reference/harden.md +347 -0
- package/skills/impeccable/reference/heuristics-scoring.md +234 -0
- package/skills/impeccable/reference/interaction-design.md +195 -0
- package/skills/impeccable/reference/layout.md +141 -0
- package/skills/impeccable/reference/live.md +622 -0
- package/skills/impeccable/reference/motion-design.md +109 -0
- package/skills/impeccable/reference/onboard.md +234 -0
- package/skills/impeccable/reference/optimize.md +258 -0
- package/skills/impeccable/reference/overdrive.md +130 -0
- package/skills/impeccable/reference/personas.md +179 -0
- package/skills/impeccable/reference/polish.md +233 -0
- package/skills/impeccable/reference/product.md +62 -0
- package/skills/impeccable/reference/quieter.md +99 -0
- package/skills/impeccable/reference/responsive-design.md +114 -0
- package/skills/impeccable/reference/shape.md +151 -0
- package/skills/impeccable/reference/spatial-design.md +100 -0
- package/skills/impeccable/reference/teach.md +156 -0
- package/skills/impeccable/reference/typeset.md +124 -0
- package/skills/impeccable/reference/typography.md +159 -0
- package/skills/impeccable/reference/ux-writing.md +107 -0
- package/skills/impeccable/references/A11Y-PATTERNS.md +233 -0
- package/skills/impeccable/references/WCAG.md +191 -0
- package/skills/impeccable/scripts/cleanup-deprecated.mjs +284 -0
- package/skills/impeccable/scripts/command-metadata.json +94 -0
- package/skills/impeccable/scripts/design-parser.mjs +820 -0
- package/skills/impeccable/scripts/detect-csp.mjs +198 -0
- package/skills/impeccable/scripts/impeccable-paths.mjs +105 -0
- package/skills/impeccable/scripts/is-generated.mjs +69 -0
- package/skills/impeccable/scripts/live-accept.mjs +595 -0
- package/skills/impeccable/scripts/live-browser-session.js +123 -0
- package/skills/impeccable/scripts/live-browser.js +4860 -0
- package/skills/impeccable/scripts/live-complete.mjs +75 -0
- package/skills/impeccable/scripts/live-completion.mjs +18 -0
- package/skills/impeccable/scripts/live-inject.mjs +446 -0
- package/skills/impeccable/scripts/live-poll.mjs +200 -0
- package/skills/impeccable/scripts/live-resume.mjs +48 -0
- package/skills/impeccable/scripts/live-server.mjs +836 -0
- package/skills/impeccable/scripts/live-session-store.mjs +254 -0
- package/skills/impeccable/scripts/live-status.mjs +47 -0
- package/skills/impeccable/scripts/live-wrap.mjs +632 -0
- package/skills/impeccable/scripts/live.mjs +247 -0
- package/skills/impeccable/scripts/load-context.mjs +141 -0
- package/skills/impeccable/scripts/modern-screenshot.umd.js +14 -0
- package/skills/impeccable/scripts/pin.mjs +214 -0
- package/skills/improve-codebase-architecture/DEEPENING.md +37 -0
- package/skills/improve-codebase-architecture/INTERFACE-DESIGN.md +44 -0
- package/skills/improve-codebase-architecture/LANGUAGE.md +53 -0
- package/skills/improve-codebase-architecture/SKILL.md +331 -0
- package/skills/incident-response/SKILL.md +97 -0
- package/skills/interview-me/SKILL.md +221 -0
- package/skills/knowledge-base-update/SKILL.md +90 -0
- package/skills/langchain-rag/SKILL.md +522 -0
- package/skills/langchain-rag/agents/verdent.yaml +12 -0
- package/skills/langchain-rag/assets/icon-dark.png +0 -0
- package/skills/langchain-rag/assets/icon-light.png +0 -0
- package/skills/linear/LICENSE.txt +202 -0
- package/skills/linear/SKILL.md +102 -0
- package/skills/linear/agents/verdent.yaml +7 -0
- package/skills/linear/assets/icon-dark.png +0 -0
- package/skills/linear/assets/icon-light.png +0 -0
- package/skills/linear/assets/linear.png +0 -0
- package/skills/localization-hub/ai-batch.md +23 -0
- package/skills/localization-hub/key-naming.md +15 -0
- package/skills/localization-hub/route-slugs.md +14 -0
- package/skills/mcp-builder/LICENSE.txt +202 -0
- package/skills/mcp-builder/SKILL.md +260 -0
- package/skills/mcp-builder/agents/verdent.yaml +7 -0
- package/skills/mcp-builder/assets/icon-dark.png +0 -0
- package/skills/mcp-builder/assets/icon-light.png +0 -0
- package/skills/mcp-builder/reference/mcp_best_practices.md +269 -0
- package/skills/mcp-builder/reference/node_mcp_server.md +980 -0
- package/skills/mcp-builder/reference/python_mcp_server.md +737 -0
- package/skills/mcp-builder/scripts/connections.py +151 -0
- package/skills/netlify-deploy/LICENSE.txt +201 -0
- package/skills/netlify-deploy/SKILL.md +261 -0
- package/skills/netlify-deploy/agents/verdent.yaml +7 -0
- package/skills/netlify-deploy/assets/icon-dark.png +0 -0
- package/skills/netlify-deploy/assets/icon-light.png +0 -0
- package/skills/netlify-deploy/assets/netlify.png +0 -0
- package/skills/netlify-deploy/references/cli-commands.md +162 -0
- package/skills/netlify-deploy/references/deployment-patterns.md +319 -0
- package/skills/netlify-deploy/references/netlify-toml.md +259 -0
- package/skills/nexus-mapper/SKILL.md +314 -0
- package/skills/nexus-mapper/references/language-customization.md +164 -0
- package/skills/nexus-mapper/references/output-schema.md +298 -0
- package/skills/nexus-mapper/references/probe-protocol.md +246 -0
- package/skills/nexus-mapper/scripts/extract_ast.py +705 -0
- package/skills/nexus-mapper/scripts/git_detective.py +194 -0
- package/skills/nexus-mapper/scripts/languages.json +127 -0
- package/skills/nexus-mapper/scripts/query_graph.py +556 -0
- package/skills/nexus-mapper/scripts/requirements.txt +6 -0
- package/skills/notion-spec-to-implementation/LICENSE.txt +7 -0
- package/skills/notion-spec-to-implementation/SKILL.md +67 -0
- package/skills/notion-spec-to-implementation/agents/verdent.yaml +7 -0
- package/skills/notion-spec-to-implementation/assets/icon-dark.png +0 -0
- package/skills/notion-spec-to-implementation/assets/icon-light.png +0 -0
- package/skills/notion-spec-to-implementation/assets/notion.png +0 -0
- package/skills/notion-spec-to-implementation/evaluations/README.md +130 -0
- package/skills/notion-spec-to-implementation/evaluations/basic-spec-implementation.json +31 -0
- package/skills/notion-spec-to-implementation/evaluations/spec-to-tasks.json +34 -0
- package/skills/notion-spec-to-implementation/examples/api-feature.md +511 -0
- package/skills/notion-spec-to-implementation/examples/database-migration.md +89 -0
- package/skills/notion-spec-to-implementation/examples/ui-component.md +78 -0
- package/skills/notion-spec-to-implementation/reference/milestone-summary-template.md +31 -0
- package/skills/notion-spec-to-implementation/reference/progress-tracking.md +507 -0
- package/skills/notion-spec-to-implementation/reference/progress-update-template.md +29 -0
- package/skills/notion-spec-to-implementation/reference/quick-implementation-plan.md +30 -0
- package/skills/notion-spec-to-implementation/reference/spec-parsing.md +406 -0
- package/skills/notion-spec-to-implementation/reference/standard-implementation-plan.md +170 -0
- package/skills/notion-spec-to-implementation/reference/task-creation-template.md +40 -0
- package/skills/notion-spec-to-implementation/reference/task-creation.md +467 -0
- package/skills/pdf/LICENSE.txt +201 -0
- package/skills/pdf/SKILL.md +715 -0
- package/skills/pdf/agents/verdent.yaml +9 -0
- package/skills/pdf/assets/icon-dark.png +0 -0
- package/skills/pdf/assets/icon-light.png +0 -0
- package/skills/pdf/assets/pdf.png +0 -0
- package/skills/pdf/reference.md +221 -0
- package/skills/performance/SKILL.md +400 -0
- package/skills/playwright/LICENSE.txt +201 -0
- package/skills/playwright/NOTICE.txt +14 -0
- package/skills/playwright/SKILL.md +151 -0
- package/skills/playwright/agents/verdent.yaml +7 -0
- package/skills/playwright/assets/icon-dark.png +0 -0
- package/skills/playwright/assets/icon-light.png +0 -0
- package/skills/playwright/assets/playwright.png +0 -0
- package/skills/playwright/references/cli.md +116 -0
- package/skills/playwright/references/workflows.md +95 -0
- package/skills/playwright/scripts/playwright_cli.sh +25 -0
- package/skills/playwriter/SKILL.md +69 -0
- package/skills/playwriter/agents/verdent.yaml +7 -0
- package/skills/playwriter/assets/icon-dark.png +0 -0
- package/skills/playwriter/assets/icon-light.png +0 -0
- package/skills/pptx/SKILL.md +302 -0
- package/skills/pptx/agents/verdent.yaml +9 -0
- package/skills/pptx/assets/icon-dark.png +0 -0
- package/skills/pptx/assets/icon-light.png +0 -0
- package/skills/pptx/references/generate-with-js.md +412 -0
- package/skills/pptx/references/modify-workflow.md +157 -0
- package/skills/pptx/references/python-charts.md +91 -0
- package/skills/pptx/scripts/check_env.py +207 -0
- package/skills/pptx/scripts/deck.py +161 -0
- package/skills/pptx/scripts/internals/__init__.py +0 -0
- package/skills/pptx/scripts/internals/cleanup.py +194 -0
- package/skills/pptx/scripts/internals/content.py +62 -0
- package/skills/pptx/scripts/internals/create.py +122 -0
- package/skills/pptx/scripts/internals/gridshot.py +181 -0
- package/skills/pptx/scripts/internals/imaging.py +77 -0
- package/skills/pptx/scripts/internals/integrity/__init__.py +0 -0
- package/skills/pptx/scripts/internals/integrity/checks.py +318 -0
- package/skills/pptx/scripts/internals/packaging.py +127 -0
- package/skills/pptx/scripts/internals/runtime/__init__.py +0 -0
- package/skills/pptx/scripts/internals/runtime/converter.py +154 -0
- package/skills/pptx/scripts/internals/structure.py +162 -0
- package/skills/pr-creator/SKILL.md +98 -0
- package/skills/pr-creator/agents/verdent.yaml +11 -0
- package/skills/pr-creator/assets/icon-dark.png +0 -0
- package/skills/pr-creator/assets/icon-light.png +0 -0
- package/skills/prd/SKILL.md +148 -0
- package/skills/prd/agents/verdent.yaml +11 -0
- package/skills/prd/assets/icon-dark.png +0 -0
- package/skills/prd/assets/icon-light.png +0 -0
- package/skills/prismx-skill-gateway/SKILL.md +179 -0
- package/skills/prismx-skill-gateway/references/installed-skills.md +38 -0
- package/skills/prismx-skills-catalog/SKILL.md +51 -0
- package/skills/prismx-skills-catalog/references/inventory.json +1092 -0
- package/skills/prompt-enhancer/SKILL.md +90 -0
- package/skills/react-native-best-practices/SKILL.md +241 -0
- package/skills/react-native-best-practices/agents/verdent.yaml +11 -0
- package/skills/react-native-best-practices/assets/icon-dark.png +0 -0
- package/skills/react-native-best-practices/assets/icon-light.png +0 -0
- package/skills/react-native-best-practices/references/bundle-analyze-app.md +211 -0
- package/skills/react-native-best-practices/references/bundle-analyze-js.md +262 -0
- package/skills/react-native-best-practices/references/bundle-barrel-exports.md +248 -0
- package/skills/react-native-best-practices/references/bundle-code-splitting.md +224 -0
- package/skills/react-native-best-practices/references/bundle-hermes-mmap.md +167 -0
- package/skills/react-native-best-practices/references/bundle-library-size.md +177 -0
- package/skills/react-native-best-practices/references/bundle-native-assets.md +214 -0
- package/skills/react-native-best-practices/references/bundle-r8-android.md +225 -0
- package/skills/react-native-best-practices/references/bundle-tree-shaking.md +214 -0
- package/skills/react-native-best-practices/references/images/bundle-treemap-source-map-explorer.png +0 -0
- package/skills/react-native-best-practices/references/images/controlled-textinput-pingpong.png +0 -0
- package/skills/react-native-best-practices/references/images/devtools-flamegraph.png +0 -0
- package/skills/react-native-best-practices/references/images/emerge-xray-ios.png +0 -0
- package/skills/react-native-best-practices/references/images/expo-atlas-treemap.png +0 -0
- package/skills/react-native-best-practices/references/images/flashlight-flatlist-vs-flashlist.png +0 -0
- package/skills/react-native-best-practices/references/images/fps-drop-graph.png +0 -0
- package/skills/react-native-best-practices/references/images/memory-heap-snapshot.png +0 -0
- package/skills/react-native-best-practices/references/images/tti-warm-start-diagram.png +0 -0
- package/skills/react-native-best-practices/references/images/view-hierarchy-flattening.png +0 -0
- package/skills/react-native-best-practices/references/images/xcode-instruments-templates.png +0 -0
- package/skills/react-native-best-practices/references/images/xcode-thread-view.png +0 -0
- package/skills/react-native-best-practices/references/js-animations-reanimated.md +254 -0
- package/skills/react-native-best-practices/references/js-atomic-state.md +245 -0
- package/skills/react-native-best-practices/references/js-concurrent-react.md +236 -0
- package/skills/react-native-best-practices/references/js-lists-flatlist-flashlist.md +236 -0
- package/skills/react-native-best-practices/references/js-measure-fps.md +180 -0
- package/skills/react-native-best-practices/references/js-memory-leaks.md +205 -0
- package/skills/react-native-best-practices/references/js-profile-react.md +161 -0
- package/skills/react-native-best-practices/references/js-react-compiler.md +368 -0
- package/skills/react-native-best-practices/references/js-uncontrolled-components.md +216 -0
- package/skills/react-native-best-practices/references/native-android-16kb-alignment.md +113 -0
- package/skills/react-native-best-practices/references/native-measure-tti.md +262 -0
- package/skills/react-native-best-practices/references/native-memory-leaks.md +240 -0
- package/skills/react-native-best-practices/references/native-memory-patterns.md +274 -0
- package/skills/react-native-best-practices/references/native-platform-setup.md +110 -0
- package/skills/react-native-best-practices/references/native-profiling.md +176 -0
- package/skills/react-native-best-practices/references/native-sdks-over-polyfills.md +183 -0
- package/skills/react-native-best-practices/references/native-threading-model.md +234 -0
- package/skills/react-native-best-practices/references/native-turbo-modules.md +292 -0
- package/skills/react-native-best-practices/references/native-view-flattening.md +201 -0
- package/skills/redis-development/FULL_GUIDE.md +2216 -0
- package/skills/redis-development/SKILL.md +124 -0
- package/skills/redis-development/agents/verdent.yaml +12 -0
- package/skills/redis-development/assets/icon-dark.png +0 -0
- package/skills/redis-development/assets/icon-light.png +0 -0
- package/skills/redis-development/assets/logo.png +0 -0
- package/skills/redis-development/rules/_contributing.md +97 -0
- package/skills/redis-development/rules/_sections.md +50 -0
- package/skills/redis-development/rules/_template.md +52 -0
- package/skills/redis-development/rules/cluster-hash-tags.md +78 -0
- package/skills/redis-development/rules/cluster-read-replicas.md +55 -0
- package/skills/redis-development/rules/conn-blocking.md +75 -0
- package/skills/redis-development/rules/conn-client-cache.md +70 -0
- package/skills/redis-development/rules/conn-pipelining.md +58 -0
- package/skills/redis-development/rules/conn-pooling.md +71 -0
- package/skills/redis-development/rules/conn-timeouts.md +41 -0
- package/skills/redis-development/rules/data-choose-structure.md +76 -0
- package/skills/redis-development/rules/data-hash-field-expiry.md +62 -0
- package/skills/redis-development/rules/data-incr.md +76 -0
- package/skills/redis-development/rules/data-key-naming.md +62 -0
- package/skills/redis-development/rules/data-transactions.md +74 -0
- package/skills/redis-development/rules/json-partial-updates.md +49 -0
- package/skills/redis-development/rules/json-vs-hash.md +105 -0
- package/skills/redis-development/rules/observe-commands.md +53 -0
- package/skills/redis-development/rules/observe-metrics.md +39 -0
- package/skills/redis-development/rules/ram-limits.md +42 -0
- package/skills/redis-development/rules/ram-ttl.md +55 -0
- package/skills/redis-development/rules/rqe-dialect.md +47 -0
- package/skills/redis-development/rules/rqe-field-types.md +81 -0
- package/skills/redis-development/rules/rqe-index-creation.md +73 -0
- package/skills/redis-development/rules/rqe-index-management.md +49 -0
- package/skills/redis-development/rules/rqe-query-optimization.md +49 -0
- package/skills/redis-development/rules/rqe-skip-initial-scan.md +82 -0
- package/skills/redis-development/rules/security-acls.md +41 -0
- package/skills/redis-development/rules/security-auth.md +78 -0
- package/skills/redis-development/rules/security-network.md +52 -0
- package/skills/redis-development/rules/semantic-cache-best-practices.md +72 -0
- package/skills/redis-development/rules/semantic-cache-langcache-usage.md +86 -0
- package/skills/redis-development/rules/stream-choosing-pattern.md +44 -0
- package/skills/redis-development/rules/vector-algorithm-choice.md +60 -0
- package/skills/redis-development/rules/vector-hybrid-search.md +49 -0
- package/skills/redis-development/rules/vector-index-creation.md +83 -0
- package/skills/redis-development/rules/vector-rag-pattern.md +51 -0
- package/skills/refactor/agents/verdent.yaml +11 -0
- package/skills/refactor/assets/icon-dark.png +0 -0
- package/skills/refactor/assets/icon-light.png +0 -0
- package/skills/runtime-inspector/SKILL.md +99 -0
- package/skills/schema-markup/SKILL.md +179 -0
- package/skills/schema-markup/evals/evals.json +87 -0
- package/skills/schema-markup/references/schema-examples.md +398 -0
- package/skills/screenshot/LICENSE.txt +201 -0
- package/skills/screenshot/SKILL.md +271 -0
- package/skills/screenshot/agents/verdent.yaml +7 -0
- package/skills/screenshot/assets/icon-dark.png +0 -0
- package/skills/screenshot/assets/icon-light.png +0 -0
- package/skills/screenshot/assets/screenshot.png +0 -0
- package/skills/screenshot/scripts/ensure_macos_permissions.sh +54 -0
- package/skills/screenshot/scripts/macos_display_info.swift +22 -0
- package/skills/screenshot/scripts/macos_permissions.swift +40 -0
- package/skills/screenshot/scripts/macos_window_info.swift +126 -0
- package/skills/screenshot/scripts/take_screenshot.ps1 +163 -0
- package/skills/screenshot/scripts/take_screenshot.py +585 -0
- package/skills/security-and-hardening/SKILL.md +349 -0
- package/skills/security-best-practices/LICENSE.txt +201 -0
- package/skills/security-best-practices/SKILL.md +91 -0
- package/skills/security-best-practices/agents/verdent.yaml +7 -0
- package/skills/security-best-practices/assets/icon-dark.png +0 -0
- package/skills/security-best-practices/assets/icon-light.png +0 -0
- package/skills/security-best-practices/references/golang-general-backend-security.md +988 -0
- package/skills/security-best-practices/references/javascript-express-web-server-security.md +1151 -0
- package/skills/security-best-practices/references/javascript-general-web-frontend-security.md +725 -0
- package/skills/security-best-practices/references/javascript-jquery-web-frontend-security.md +672 -0
- package/skills/security-best-practices/references/javascript-typescript-nextjs-web-server-security.md +1138 -0
- package/skills/security-best-practices/references/javascript-typescript-react-web-frontend-security.md +975 -0
- package/skills/security-best-practices/references/javascript-typescript-vue-web-frontend-security.md +789 -0
- package/skills/security-best-practices/references/python-django-web-server-security.md +880 -0
- package/skills/security-best-practices/references/python-fastapi-web-server-security.md +1030 -0
- package/skills/security-best-practices/references/python-flask-web-server-security.md +835 -0
- package/skills/security-ownership-map/LICENSE.txt +201 -0
- package/skills/security-ownership-map/SKILL.md +212 -0
- package/skills/security-ownership-map/agents/verdent.yaml +12 -0
- package/skills/security-ownership-map/assets/icon-dark.png +0 -0
- package/skills/security-ownership-map/assets/icon-light.png +0 -0
- package/skills/security-ownership-map/references/neo4j-import.md +60 -0
- package/skills/security-ownership-map/scripts/build_ownership_map.py +956 -0
- package/skills/security-ownership-map/scripts/community_maintainers.py +544 -0
- package/skills/security-ownership-map/scripts/query_ownership.py +483 -0
- package/skills/security-ownership-map/scripts/run_ownership_map.py +200 -0
- package/skills/security-threat-model/LICENSE.txt +201 -0
- package/skills/security-threat-model/SKILL.md +94 -0
- package/skills/security-threat-model/agents/verdent.yaml +7 -0
- package/skills/security-threat-model/assets/icon-dark.png +0 -0
- package/skills/security-threat-model/assets/icon-light.png +0 -0
- package/skills/security-threat-model/references/prompt-template.md +254 -0
- package/skills/security-threat-model/references/security-controls-and-assets.md +35 -0
- package/skills/seo-audit/SKILL.md +527 -0
- package/skills/seo-audit/evals/evals.json +136 -0
- package/skills/seo-audit/references/ai-writing-detection.md +200 -0
- package/skills/seo-audit/references/international-seo.md +230 -0
- package/skills/sequential-thinking/SKILL.md +224 -0
- package/skills/session-context-primer/SKILL.md +69 -0
- package/skills/shipping-and-launch/SKILL.md +309 -0
- package/skills/source-driven-development/SKILL.md +194 -0
- package/skills/spec-writer/SKILL.md +200 -0
- package/skills/speech/LICENSE.txt +201 -0
- package/skills/speech/SKILL.md +150 -0
- package/skills/speech/agents/verdent.yaml +12 -0
- package/skills/speech/assets/icon-dark.png +0 -0
- package/skills/speech/assets/icon-light.png +0 -0
- package/skills/speech/assets/speech-small.svg +3 -0
- package/skills/speech/assets/speech.png +0 -0
- package/skills/speech/references/accessibility.md +32 -0
- package/skills/speech/references/audio-api.md +31 -0
- package/skills/speech/references/cli.md +99 -0
- package/skills/speech/references/ivr.md +32 -0
- package/skills/speech/references/narration.md +31 -0
- package/skills/speech/references/network-notes.md +28 -0
- package/skills/speech/references/prompting.md +38 -0
- package/skills/speech/references/sample-prompts.md +44 -0
- package/skills/speech/references/voice-directions.md +80 -0
- package/skills/speech/references/voiceover.md +31 -0
- package/skills/speech/scripts/text_to_speech.py +528 -0
- package/skills/system-architect/SKILL.md +677 -0
- package/skills/system-designer/SKILL.md +601 -0
- package/skills/systematic-debugging/CREATION-LOG.md +119 -0
- package/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
- package/skills/systematic-debugging/condition-based-waiting.md +115 -0
- package/skills/systematic-debugging/defense-in-depth.md +122 -0
- package/skills/systematic-debugging/find-polluter.sh +63 -0
- package/skills/systematic-debugging/root-cause-tracing.md +169 -0
- package/skills/systematic-debugging/test-academic.md +14 -0
- package/skills/systematic-debugging/test-pressure-1.md +58 -0
- package/skills/systematic-debugging/test-pressure-2.md +68 -0
- package/skills/systematic-debugging/test-pressure-3.md +69 -0
- package/skills/task-planner/SKILL.md +699 -0
- package/skills/task-reviewer/SKILL.md +387 -0
- package/skills/task-skill-router/SKILL.md +105 -0
- package/skills/tech-evaluator/SKILL.md +181 -0
- package/skills/tech-evaluator/references/ADR_TEMPLATE.md +80 -0
- package/skills/tech-evaluator/scripts/evaluate_matrix.py +190 -0
- package/skills/test-driven-development/SKILL.md +383 -0
- package/skills/test-driven-development/testing-anti-patterns.md +299 -0
- package/skills/theme-factory/LICENSE.txt +202 -0
- package/skills/theme-factory/SKILL.md +64 -0
- package/skills/theme-factory/agents/verdent.yaml +11 -0
- package/skills/theme-factory/assets/icon-dark.png +0 -0
- package/skills/theme-factory/assets/icon-light.png +0 -0
- package/skills/theme-factory/theme-showcase.pdf +0 -0
- package/skills/theme-factory/themes/arctic-frost.md +19 -0
- package/skills/theme-factory/themes/botanical-garden.md +19 -0
- package/skills/theme-factory/themes/desert-rose.md +19 -0
- package/skills/theme-factory/themes/forest-canopy.md +19 -0
- package/skills/theme-factory/themes/golden-hour.md +19 -0
- package/skills/theme-factory/themes/midnight-galaxy.md +19 -0
- package/skills/theme-factory/themes/modern-minimalist.md +19 -0
- package/skills/theme-factory/themes/ocean-depths.md +19 -0
- package/skills/theme-factory/themes/sunset-boulevard.md +19 -0
- package/skills/theme-factory/themes/tech-innovation.md +19 -0
- package/skills/transcribe/LICENSE.txt +201 -0
- package/skills/transcribe/SKILL.md +86 -0
- package/skills/transcribe/agents/verdent.yaml +12 -0
- package/skills/transcribe/assets/icon-dark.png +0 -0
- package/skills/transcribe/assets/icon-light.png +0 -0
- package/skills/transcribe/assets/transcribe-small.svg +3 -0
- package/skills/transcribe/assets/transcribe.png +0 -0
- package/skills/transcribe/references/api.md +8 -0
- package/skills/transcribe/scripts/transcribe_diarize.py +276 -0
- package/skills/vercel-composition-patterns/FULL_GUIDE.md +946 -0
- package/skills/vercel-composition-patterns/SKILL.md +92 -0
- package/skills/vercel-composition-patterns/agents/verdent.yaml +12 -0
- package/skills/vercel-composition-patterns/assets/icon-dark.png +0 -0
- package/skills/vercel-composition-patterns/assets/icon-light.png +0 -0
- package/skills/vercel-composition-patterns/rules/_sections.md +29 -0
- package/skills/vercel-composition-patterns/rules/_template.md +24 -0
- package/skills/vercel-composition-patterns/rules/architecture-avoid-boolean-props.md +100 -0
- package/skills/vercel-composition-patterns/rules/architecture-compound-components.md +112 -0
- package/skills/vercel-composition-patterns/rules/patterns-children-over-render-props.md +87 -0
- package/skills/vercel-composition-patterns/rules/patterns-explicit-variants.md +100 -0
- package/skills/vercel-composition-patterns/rules/react19-no-forwardref.md +42 -0
- package/skills/vercel-composition-patterns/rules/state-context-interface.md +191 -0
- package/skills/vercel-composition-patterns/rules/state-decouple-implementation.md +113 -0
- package/skills/vercel-composition-patterns/rules/state-lift-state.md +125 -0
- package/skills/vercel-deploy/LICENSE.txt +21 -0
- package/skills/vercel-deploy/SKILL.md +75 -0
- package/skills/vercel-deploy/agents/verdent.yaml +7 -0
- package/skills/vercel-deploy/assets/icon-dark.png +0 -0
- package/skills/vercel-deploy/assets/icon-light.png +0 -0
- package/skills/vercel-deploy/assets/vercel.png +0 -0
- package/skills/vercel-deploy/scripts/deploy.sh +301 -0
- package/skills/vercel-react-best-practices/FULL_GUIDE.md +3254 -0
- package/skills/vercel-react-best-practices/SKILL.md +144 -0
- package/skills/vercel-react-best-practices/agents/verdent.yaml +12 -0
- package/skills/vercel-react-best-practices/assets/icon-dark.png +0 -0
- package/skills/vercel-react-best-practices/assets/icon-light.png +0 -0
- package/skills/vercel-react-best-practices/rules/_sections.md +46 -0
- package/skills/vercel-react-best-practices/rules/_template.md +28 -0
- package/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
- package/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
- package/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
- package/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
- package/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
- package/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
- package/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
- package/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
- package/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
- package/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
- package/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
- package/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
- package/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
- package/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
- package/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
- package/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
- package/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
- package/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
- package/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
- package/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
- package/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
- package/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
- package/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
- package/skills/vercel-react-best-practices/rules/js-flatmap-filter.md +60 -0
- package/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
- package/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
- package/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
- package/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
- package/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
- package/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
- package/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
- package/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
- package/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
- package/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
- package/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
- package/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
- package/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
- package/skills/vercel-react-best-practices/rules/rendering-resource-hints.md +85 -0
- package/skills/vercel-react-best-practices/rules/rendering-script-defer-async.md +68 -0
- package/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
- package/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
- package/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
- package/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
- package/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
- package/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
- package/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
- package/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
- package/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
- package/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
- package/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
- package/skills/vercel-react-best-practices/rules/rerender-no-inline-components.md +82 -0
- package/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
- package/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
- package/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
- package/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
- package/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
- package/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
- package/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
- package/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
- package/skills/vercel-react-best-practices/rules/server-hoist-static-io.md +142 -0
- package/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
- package/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
- package/skills/verdent-image-cli/SKILL.md +218 -0
- package/skills/verdent-image-cli/agents/verdent.yaml +11 -0
- package/skills/verdent-image-cli/assets/icon-dark.png +0 -0
- package/skills/verdent-image-cli/assets/icon-light.png +0 -0
- package/skills/verdent-skills-catalog/SKILL.md +72 -0
- package/skills/verdent-skills-catalog/references/categories.json +158 -0
- package/skills/verdent-skills-catalog/references/inventory.json +493 -0
- package/skills/verification-before-completion/SKILL.md +139 -0
- package/skills/web-quality-audit/SKILL.md +172 -0
- package/skills/web-quality-audit/scripts/analyze.sh +113 -0
- package/skills/webapp-testing/LICENSE.txt +202 -0
- package/skills/webapp-testing/SKILL.md +302 -0
- package/skills/webapp-testing/examples/console_logging.py +35 -0
- package/skills/webapp-testing/examples/element_discovery.py +40 -0
- package/skills/webapp-testing/examples/static_html_automation.py +33 -0
- package/skills/webapp-testing/scripts/with_server.py +110 -0
- package/skills/workers-best-practices/SKILL.md +132 -0
- package/skills/workers-best-practices/agents/verdent.yaml +11 -0
- package/skills/workers-best-practices/assets/icon-dark.png +0 -0
- package/skills/workers-best-practices/assets/icon-light.png +0 -0
- package/skills/workers-best-practices/references/review.md +174 -0
- package/skills/workers-best-practices/references/rules.md +463 -0
- package/skills/xlsx/SKILL.md +318 -0
- package/skills/xlsx/agents/verdent.yaml +9 -0
- package/skills/xlsx/assets/icon-dark.png +0 -0
- package/skills/xlsx/assets/icon-light.png +0 -0
- package/skills/xlsx/assets/spreadsheet.png +0 -0
- package/skills/xlsx/references/advanced-analysis.md +272 -0
- package/skills/xlsx/references/examples/openpyxl/create_basic_spreadsheet.py +51 -0
- package/skills/xlsx/references/examples/openpyxl/create_spreadsheet_with_styling.py +96 -0
- package/skills/xlsx/references/examples/openpyxl/read_existing_spreadsheet.py +59 -0
- package/skills/xlsx/references/examples/openpyxl/styling_spreadsheet.py +79 -0
- package/skills/xlsx/scripts/formula_engine.py +219 -0
- package/skills/xlsx/scripts/profile.py +62 -0
- package/src/commands/init.js +27 -3
- package/src/commands/pipeline.js +31 -0
- package/src/commands/recover.js +62 -0
- package/src/commands/route.js +7 -0
- package/src/commands/scaffold.js +7 -1
- package/src/commands/skill.js +114 -0
- package/src/commands/ui.js +50 -0
- package/src/commands/upgrade.js +2 -2
- package/src/lib/capability-router.js +4 -3
- package/src/lib/contract.js +49 -0
- package/src/lib/disabled-skills.js +86 -0
- package/src/lib/doctor.js +32 -1
- package/src/lib/env-flags.js +35 -0
- package/src/lib/execution-policy.js +78 -4
- package/src/lib/explanation.js +159 -0
- package/src/lib/ide-sync.js +4 -3
- package/src/lib/pipeline.js +68 -0
- package/src/lib/recover.js +93 -0
- package/src/lib/registry.js +79 -0
- package/src/lib/route-engine.js +21 -1
- package/src/lib/scaffold/index.js +23 -7
- package/src/lib/scaffold/presets.js +200 -31
- package/src/lib/ui-server.js +139 -0
- package/src/lib/upgrade-matrix.js +16 -1
- package/src/lib/workspace-boundary.js +60 -0
- package/templates/minimal/AGENT.md +10 -1
- package/templates/minimal/GUNLUK.md +12 -0
- package/templates/minimal/docs/conventions/daily-use.md +130 -0
- package/templates/minimal/docs/conventions/task-to-capability-cheatsheet.md +29 -0
- package/templates/minimal/docs/kullanim-kilavuzu.md +374 -0
- package/ui/app.js +167 -0
- package/ui/index.html +75 -0
- package/ui/styles.css +227 -0
- package/workflows/audit.md +143 -0
- package/workflows/blueprint.md +374 -0
- package/workflows/challenge.md +322 -0
- package/workflows/change.md +162 -0
- package/workflows/craft.md +135 -0
- package/workflows/design-system.md +248 -0
- package/workflows/explore.md +226 -0
- package/workflows/forge.md +570 -34
- package/workflows/genesis.md +307 -0
- package/workflows/ingest.md +145 -0
- package/workflows/init.md +216 -0
- package/workflows/probe.md +181 -0
- package/workflows/query-to-page.md +134 -0
- package/workflows/quickstart.md +111 -0
- package/workflows/retro.md +78 -0
- package/workflows/upgrade.md +146 -0
- package/workflows/wiki-lint.md +159 -0
- package/templates/bundle/skills/capability-router/SKILL.md +0 -12
- package/templates/bundle/skills/context-memory-bridge/SKILL.md +0 -17
- package/templates/bundle/skills/localization-hub/SKILL.md +0 -17
- package/templates/bundle/skills/refactor/SKILL.md +0 -17
- package/templates/bundle/skills/systematic-debugging/SKILL.md +0 -19
- package/templates/bundle/workflows/forge.md +0 -51
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
# Code Review — Workers
|
|
2
|
+
|
|
3
|
+
How to review Workers code for type correctness, API usage, config validity, and best practices. This is self-contained — do not assume access to other skills.
|
|
4
|
+
|
|
5
|
+
## Retrieval
|
|
6
|
+
|
|
7
|
+
Prefer retrieval over pre-training. Types, config schemas, and APIs change with compatibility dates and new bindings.
|
|
8
|
+
|
|
9
|
+
### Workers types
|
|
10
|
+
|
|
11
|
+
Fetch the latest `@cloudflare/workers-types` before reviewing. The project may have an older version installed.
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
mkdir -p /tmp/workers-types-latest && \
|
|
15
|
+
npm pack @cloudflare/workers-types --pack-destination /tmp/workers-types-latest && \
|
|
16
|
+
tar -xzf /tmp/workers-types-latest/cloudflare-workers-types-*.tgz -C /tmp/workers-types-latest
|
|
17
|
+
# Types are at /tmp/workers-types-latest/package/index.d.ts
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
Search this file for the specific type, class, or interface under review. Do not guess type names.
|
|
21
|
+
|
|
22
|
+
Alternative: `npx wrangler types` generates a typed `Env` interface from the local wrangler config.
|
|
23
|
+
|
|
24
|
+
Fallback: read `node_modules/@cloudflare/workers-types/index.d.ts`. Note the installed version.
|
|
25
|
+
|
|
26
|
+
### Wrangler config schema
|
|
27
|
+
|
|
28
|
+
The authoritative schema is bundled with wrangler as `config-schema.json` (JSON Schema draft-07).
|
|
29
|
+
|
|
30
|
+
```bash
|
|
31
|
+
# Read from local node_modules
|
|
32
|
+
cat node_modules/wrangler/config-schema.json
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
Do not guess field names or structures — look them up.
|
|
36
|
+
|
|
37
|
+
### Cloudflare docs
|
|
38
|
+
|
|
39
|
+
Use the Cloudflare docs search tool if available, or fetch from `https://developers.cloudflare.com/workers/`. The best practices page lives at `/workers/best-practices/workers-best-practices/`.
|
|
40
|
+
|
|
41
|
+
---
|
|
42
|
+
|
|
43
|
+
## Type Validation
|
|
44
|
+
|
|
45
|
+
### Env interface
|
|
46
|
+
|
|
47
|
+
- Every binding must have a specific type. Flag `any`, `unknown`, `object`, or `Record<string, unknown>` on bindings.
|
|
48
|
+
- Binding types that accept generic parameters (Durable Object namespaces, Queues, Service bindings for RPC) must include them. Read the type definition to confirm which types are generic.
|
|
49
|
+
- Binding names must match the wrangler config exactly.
|
|
50
|
+
- Prefer generated types from `wrangler types` over hand-written interfaces.
|
|
51
|
+
|
|
52
|
+
### Handler and class signatures
|
|
53
|
+
|
|
54
|
+
Verify against current type definitions — do not assume signatures are stable.
|
|
55
|
+
|
|
56
|
+
- Correct import path (most Workers platform classes import from `"cloudflare:workers"`)
|
|
57
|
+
- Generic type parameter on base classes (e.g., `DurableObject<Env>`)
|
|
58
|
+
- Binding access pattern: `env.X` in module export handlers, `this.env.X` in classes extending platform base classes
|
|
59
|
+
- `ExecutionContext` as the third param in module export handlers (needed for `ctx.waitUntil()`)
|
|
60
|
+
- `fetch()` handlers must return `Promise<Response>`
|
|
61
|
+
|
|
62
|
+
### Binding access — the most common error
|
|
63
|
+
|
|
64
|
+
- **Module export handlers** (`fetch`, `scheduled`, `queue`, `email`): bindings via `env.X` parameter
|
|
65
|
+
- **Platform base classes** (`WorkerEntrypoint`, `DurableObject`, `Workflow`, `Agent`): bindings via `this.env.X`
|
|
66
|
+
|
|
67
|
+
Flag `env.X` inside a class extending a platform base class. Flag `this.env.X` inside a module export handler.
|
|
68
|
+
|
|
69
|
+
### Type integrity rules
|
|
70
|
+
|
|
71
|
+
| Rule | Detail |
|
|
72
|
+
|------|--------|
|
|
73
|
+
| No `any` | Never on binding types, handler params, or API responses |
|
|
74
|
+
| No double-casting | `as unknown as T` hides real incompatibilities — fix the underlying design |
|
|
75
|
+
| Justify suppressions | `@ts-ignore`/`@ts-expect-error` must include a comment explaining why |
|
|
76
|
+
| Prefer `satisfies` | Use `satisfies ExportedHandler<Env>` over `as` — validates without widening |
|
|
77
|
+
| Validate, do not assert | Schema or type guard for untyped data (JSON, parsed bodies), not `as` |
|
|
78
|
+
|
|
79
|
+
### Stale class patterns
|
|
80
|
+
|
|
81
|
+
Old patterns survive in codebases long after APIs change.
|
|
82
|
+
|
|
83
|
+
- **`extends` vs `implements`**: platform classes use `extends`, not `implements`. The `implements` pattern is legacy and loses `this.ctx`, `this.env`.
|
|
84
|
+
- **Import paths**: verify module specifiers match what types actually export. Common mistake: wrong path for `"cloudflare:workers"` vs `"cloudflare:workflows"`.
|
|
85
|
+
- **Renamed properties**: e.g., `this.state` to `this.ctx` in Durable Objects. Search types to confirm.
|
|
86
|
+
- **Constructor signatures**: base class constructors change. Verify expected parameters.
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## Config Validation
|
|
91
|
+
|
|
92
|
+
### Required fields
|
|
93
|
+
|
|
94
|
+
For executable examples, verify: `name`, `compatibility_date`, `main`. Check the schema for current required fields.
|
|
95
|
+
|
|
96
|
+
### Config format
|
|
97
|
+
|
|
98
|
+
- **JSONC** (`wrangler.jsonc`) — preferred for new projects
|
|
99
|
+
- **JSON** (`wrangler.json`) — valid but no comments
|
|
100
|
+
- **TOML** (`wrangler.toml`) — legacy; acceptable in existing content, flag in new projects
|
|
101
|
+
|
|
102
|
+
### Binding-code consistency
|
|
103
|
+
|
|
104
|
+
1. Every `env.X` reference in code has a corresponding binding declaration in config
|
|
105
|
+
2. Every binding in config is referenced in code (warn on unused)
|
|
106
|
+
3. Names match exactly (case-sensitive)
|
|
107
|
+
4. For Durable Objects: `class_name` matches the exported class name
|
|
108
|
+
|
|
109
|
+
### Common config mistakes
|
|
110
|
+
|
|
111
|
+
| Check | What to look for |
|
|
112
|
+
|-------|-----------------|
|
|
113
|
+
| Stale `compatibility_date` | Should be recent; use `$today` placeholder in docs |
|
|
114
|
+
| Missing DO migrations | Every new DO class needs a migration entry |
|
|
115
|
+
| Binding name mismatch | Config `binding`/`name` must match `env.X` in code |
|
|
116
|
+
| Secrets in config | Never in `vars` — use `wrangler secret put` |
|
|
117
|
+
| Wrong binding key | Verify top-level key name against the schema |
|
|
118
|
+
| Missing entrypoint | `main` required for executable Workers |
|
|
119
|
+
|
|
120
|
+
---
|
|
121
|
+
|
|
122
|
+
## Anti-Patterns to Flag
|
|
123
|
+
|
|
124
|
+
See the full anti-patterns table in `SKILL.md`. The type-specific ones to watch for during review:
|
|
125
|
+
|
|
126
|
+
- **`any` on `Env` or handler params** — defeats type safety for all downstream binding access
|
|
127
|
+
- **`as unknown as T`** — hides real type incompatibilities; fix the underlying design
|
|
128
|
+
- **`@ts-ignore`/`@ts-expect-error` without explanation** — masks errors silently; require a justifying comment
|
|
129
|
+
- **`implements` instead of `extends` on platform base classes** — legacy pattern; loses `this.ctx`, `this.env`
|
|
130
|
+
- **`env.X` inside class body** — should be `this.env.X` in platform base classes
|
|
131
|
+
- **`this.env.X` in module export handler** — should be `env.X` parameter
|
|
132
|
+
- **Non-serializable values across boundaries** — `Response`, `Error` in step/queue compiles but fails at runtime
|
|
133
|
+
|
|
134
|
+
---
|
|
135
|
+
|
|
136
|
+
## Serialization Boundaries
|
|
137
|
+
|
|
138
|
+
Data crossing these boundaries must be structured-clone serializable:
|
|
139
|
+
|
|
140
|
+
- **Queue messages**: body passed to `.send()` or `.sendBatch()`
|
|
141
|
+
- **Workflow step return values**: persisted to durable storage
|
|
142
|
+
- **DO storage**: values in `storage.put()` or SQL
|
|
143
|
+
- **`postMessage()`**: WebSocket messages
|
|
144
|
+
|
|
145
|
+
Non-serializable types to flag: `Response`, `Request`, `Error`, functions, class instances with methods, `Map`/`Set`, `Symbol`.
|
|
146
|
+
|
|
147
|
+
Valid: plain objects, arrays, strings, numbers, booleans, null, `ArrayBuffer`, `Date`.
|
|
148
|
+
|
|
149
|
+
---
|
|
150
|
+
|
|
151
|
+
## Review Process
|
|
152
|
+
|
|
153
|
+
1. **Retrieve** — fetch latest workers types, wrangler schema, and best practices page
|
|
154
|
+
2. **Read full files** — not just diffs; context matters for binding access patterns
|
|
155
|
+
3. **Categorize code** — determines what to check:
|
|
156
|
+
- **Illustrative** (concept demo, comments for most logic): verify correct API names and realistic signatures
|
|
157
|
+
- **Demonstrative** (functional snippet, would work in context): verify syntax, correct APIs, correct binding access
|
|
158
|
+
- **Executable** (standalone, runs without modification): verify compiles, runs, includes imports and config
|
|
159
|
+
4. **Check types** — binding access pattern, handler signatures, no `any`, no unsafe casts
|
|
160
|
+
5. **Check config** — compatibility_date, nodejs_compat, observability, secrets, binding-code consistency
|
|
161
|
+
6. **Check patterns** — streaming, floating promises, global state, serialization boundaries
|
|
162
|
+
7. **Check security** — crypto usage, secret handling, timing-safe comparisons, error handling
|
|
163
|
+
8. **Validate with tools** — `npx tsc --noEmit`, lint for `no-floating-promises`
|
|
164
|
+
9. **Assess risk** — HIGH (auth, crypto, bindings), MEDIUM (business logic, config), LOW (style, comments)
|
|
165
|
+
|
|
166
|
+
### Output format
|
|
167
|
+
|
|
168
|
+
```
|
|
169
|
+
**[SEVERITY]** Brief description
|
|
170
|
+
`file.ts:42` — explanation with evidence
|
|
171
|
+
Suggested fix: `code`
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
Severity: **CRITICAL** (security, data loss, crash) | **HIGH** (type error, wrong API, broken config) | **MEDIUM** (missing validation, edge case) | **LOW** (style, minor improvement)
|
|
@@ -0,0 +1,463 @@
|
|
|
1
|
+
# Workers Best Practices — Rules
|
|
2
|
+
|
|
3
|
+
Each rule has an imperative summary, what to check, the correct pattern, and an anti-pattern where applicable. Code examples are plain TypeScript — no MDX components.
|
|
4
|
+
|
|
5
|
+
When a rule involves config fields or API signatures that may evolve, a **Retrieve** callout reminds you to check the latest docs or types before flagging. All doc paths are relative to `https://developers.cloudflare.com`.
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Configuration
|
|
10
|
+
|
|
11
|
+
### Keep compatibility_date current
|
|
12
|
+
|
|
13
|
+
Set `compatibility_date` to today on new projects. Update periodically on existing ones to access new APIs and fixes.
|
|
14
|
+
|
|
15
|
+
**Check**: `compatibility_date` exists. Flag if older than 6 months.
|
|
16
|
+
|
|
17
|
+
```jsonc
|
|
18
|
+
// wrangler.jsonc
|
|
19
|
+
{
|
|
20
|
+
"compatibility_date": "$today", // Replace with today's date (YYYY-MM-DD)
|
|
21
|
+
"compatibility_flags": ["nodejs_compat"]
|
|
22
|
+
}
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
**Retrieve**: current compatibility dates at `/workers/configuration/compatibility-dates/`.
|
|
26
|
+
|
|
27
|
+
### Enable nodejs_compat
|
|
28
|
+
|
|
29
|
+
The `nodejs_compat` flag enables Node.js built-in modules (`node:crypto`, `node:buffer`, `node:stream`). Many libraries require it. Missing this flag causes cryptic import errors at runtime.
|
|
30
|
+
|
|
31
|
+
**Check**: `compatibility_flags` includes `"nodejs_compat"`.
|
|
32
|
+
|
|
33
|
+
```jsonc
|
|
34
|
+
{
|
|
35
|
+
"compatibility_flags": ["nodejs_compat"]
|
|
36
|
+
}
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### Generate binding types with wrangler types
|
|
40
|
+
|
|
41
|
+
Never hand-write the `Env` interface. Run `wrangler types` to generate it from the wrangler config. Re-run after adding or renaming any binding.
|
|
42
|
+
|
|
43
|
+
**Check**: no manually defined `Env` or `interface Env` that duplicates wrangler config bindings. Look for `satisfies ExportedHandler<Env>` pattern on the default export.
|
|
44
|
+
|
|
45
|
+
```ts
|
|
46
|
+
// Generated by wrangler types — always matches actual config
|
|
47
|
+
export default {
|
|
48
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
49
|
+
const value = await env.MY_KV.get("key");
|
|
50
|
+
return new Response(value);
|
|
51
|
+
},
|
|
52
|
+
} satisfies ExportedHandler<Env>;
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
Anti-pattern:
|
|
56
|
+
```ts
|
|
57
|
+
// Hand-written Env that drifts from actual bindings
|
|
58
|
+
interface Env {
|
|
59
|
+
MY_KV: KVNamespace; // What if the binding name changed?
|
|
60
|
+
}
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
### Store secrets with wrangler secret
|
|
64
|
+
|
|
65
|
+
Secrets must never appear in wrangler config or source code. Use `wrangler secret put` and access via `env` at runtime. Non-secret config goes in `vars`.
|
|
66
|
+
|
|
67
|
+
**Check**: no string literals that look like API keys, tokens, or credentials. Verify `.env` is in `.gitignore` for local dev.
|
|
68
|
+
|
|
69
|
+
```jsonc
|
|
70
|
+
{
|
|
71
|
+
"vars": {
|
|
72
|
+
"API_BASE_URL": "https://api.example.com" // Non-secret: OK in config
|
|
73
|
+
}
|
|
74
|
+
// Secrets set via: wrangler secret put API_KEY
|
|
75
|
+
}
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
Anti-pattern:
|
|
79
|
+
```jsonc
|
|
80
|
+
{
|
|
81
|
+
"vars": {
|
|
82
|
+
"API_KEY": "sk-live-abc123..." // Secret in version control
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### Use wrangler.jsonc for config
|
|
88
|
+
|
|
89
|
+
Prefer `wrangler.jsonc` over `wrangler.toml`. Newer features are JSON-only. JSONC supports comments for documenting config decisions.
|
|
90
|
+
|
|
91
|
+
**Check**: project uses `wrangler.jsonc` (or `wrangler.json`). Flag `wrangler.toml` in new projects.
|
|
92
|
+
|
|
93
|
+
---
|
|
94
|
+
|
|
95
|
+
## Request & Response Handling
|
|
96
|
+
|
|
97
|
+
### Stream request and response bodies
|
|
98
|
+
|
|
99
|
+
Workers have a 128 MB memory limit. Buffering entire bodies with `await response.text()` or `await request.arrayBuffer()` crashes on large payloads. Stream data through using `TransformStream` or pass `response.body` directly.
|
|
100
|
+
|
|
101
|
+
**Check**: any `await response.text()`, `await response.json()`, or `await response.arrayBuffer()` on data that could be large or unbounded. Small, bounded payloads (known-size JSON, config files) are fine to buffer.
|
|
102
|
+
|
|
103
|
+
Correct — stream through:
|
|
104
|
+
```ts
|
|
105
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
106
|
+
const response = await fetch("https://api.example.com/large-dataset");
|
|
107
|
+
return new Response(response.body, response);
|
|
108
|
+
}
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
Correct — concatenate multiple streams:
|
|
112
|
+
```ts
|
|
113
|
+
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
|
|
114
|
+
const urls = ["https://api.example.com/part-1", "https://api.example.com/part-2"];
|
|
115
|
+
const { readable, writable } = new TransformStream();
|
|
116
|
+
|
|
117
|
+
// Track the pipeline promise — don't let it float
|
|
118
|
+
ctx.waitUntil((async () => {
|
|
119
|
+
for (const url of urls) {
|
|
120
|
+
const response = await fetch(url);
|
|
121
|
+
if (response.body) {
|
|
122
|
+
await response.body.pipeTo(writable, { preventClose: true });
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
await writable.close();
|
|
126
|
+
})());
|
|
127
|
+
|
|
128
|
+
return new Response(readable, {
|
|
129
|
+
headers: { "Content-Type": "application/octet-stream" },
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
Anti-pattern:
|
|
135
|
+
```ts
|
|
136
|
+
// Buffers entire body — crashes on large payloads
|
|
137
|
+
const response = await fetch("https://api.example.com/large-dataset");
|
|
138
|
+
const text = await response.text();
|
|
139
|
+
return new Response(text);
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
**Retrieve**: streaming APIs at `/workers/runtime-apis/streams/`.
|
|
143
|
+
|
|
144
|
+
### Use waitUntil for work after the response
|
|
145
|
+
|
|
146
|
+
`ctx.waitUntil()` performs background work (analytics, cache writes, webhooks) after the response is sent. Keeps response fast. 30-second time limit after response.
|
|
147
|
+
|
|
148
|
+
**Check**: background work uses `ctx.waitUntil()`, not inline `await`. Do not destructure `ctx` — it loses the `this` binding and throws "Illegal invocation".
|
|
149
|
+
|
|
150
|
+
```ts
|
|
151
|
+
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
|
|
152
|
+
const data = await processRequest(request);
|
|
153
|
+
|
|
154
|
+
ctx.waitUntil(logToAnalytics(env, data));
|
|
155
|
+
ctx.waitUntil(updateCache(env, data));
|
|
156
|
+
|
|
157
|
+
return Response.json(data);
|
|
158
|
+
}
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
Anti-pattern:
|
|
162
|
+
```ts
|
|
163
|
+
// Destructuring ctx loses the this binding
|
|
164
|
+
const { waitUntil } = ctx; // "Illegal invocation" at runtime
|
|
165
|
+
waitUntil(somePromise);
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
---
|
|
169
|
+
|
|
170
|
+
## Architecture
|
|
171
|
+
|
|
172
|
+
### Use bindings for Cloudflare services, not REST APIs
|
|
173
|
+
|
|
174
|
+
Bindings (KV, R2, D1, Queues, Workflows) are direct, in-process references — no network hop, no authentication, no extra latency. Using the Cloudflare REST API from a Worker wastes time and adds complexity.
|
|
175
|
+
|
|
176
|
+
**Check**: no `fetch("https://api.cloudflare.com/client/v4/...")` calls for services available as bindings.
|
|
177
|
+
|
|
178
|
+
```ts
|
|
179
|
+
// Binding — direct, zero-cost
|
|
180
|
+
const object = await env.MY_BUCKET.get("my-file");
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
Anti-pattern:
|
|
184
|
+
```ts
|
|
185
|
+
// REST API from inside a Worker — unnecessary overhead
|
|
186
|
+
const response = await fetch(
|
|
187
|
+
"https://api.cloudflare.com/client/v4/accounts/.../r2/buckets/.../objects/my-file",
|
|
188
|
+
{ headers: { Authorization: `Bearer ${env.CF_API_TOKEN}` } }
|
|
189
|
+
);
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
### Use Queues and Workflows for async and background work
|
|
193
|
+
|
|
194
|
+
Long-running, retriable, or non-urgent tasks should not block a request.
|
|
195
|
+
|
|
196
|
+
- **Queues**: decouple producer from consumer. Fan-out, buffering/batching, simple single-step background jobs. At-least-once delivery.
|
|
197
|
+
- **Workflows**: multi-step durable execution. Each step's return value is persisted; only failed steps retry. Can run for hours/days/weeks.
|
|
198
|
+
- **Both together**: Queue buffers high-throughput entry, consumer creates Workflow instances for complex processing.
|
|
199
|
+
|
|
200
|
+
**Check**: long-running work (email sends, webhooks, multi-step processes) is offloaded to Queues or Workflows, not done inline in the fetch handler.
|
|
201
|
+
|
|
202
|
+
```ts
|
|
203
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
204
|
+
const order = await request.json<{ id: string; type: string }>();
|
|
205
|
+
|
|
206
|
+
if (order.type === "simple") {
|
|
207
|
+
await env.ORDER_QUEUE.send({ orderId: order.id, action: "send-email" });
|
|
208
|
+
} else {
|
|
209
|
+
await env.FULFILLMENT_WORKFLOW.create({ params: { orderId: order.id } });
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
return Response.json({ status: "accepted" }, { status: 202 });
|
|
213
|
+
}
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
**Retrieve**: `/queues/` and `/workflows/` for current APIs. For Workflow-specific rules, see [Rules of Workflows](https://developers.cloudflare.com/workflows/build/rules-of-workflows/).
|
|
217
|
+
|
|
218
|
+
### Use service bindings for Worker-to-Worker communication
|
|
219
|
+
|
|
220
|
+
Service bindings are zero-cost, bypass the public internet, and support type-safe RPC. Do not call another Worker via its public URL.
|
|
221
|
+
|
|
222
|
+
**Check**: Worker-to-Worker calls use `env.SERVICE_NAME.method()` (RPC) or `env.SERVICE_NAME.fetch()`, not `fetch("https://my-other-worker.example.com/...")`.
|
|
223
|
+
|
|
224
|
+
```ts
|
|
225
|
+
import { WorkerEntrypoint } from "cloudflare:workers";
|
|
226
|
+
|
|
227
|
+
export class AuthService extends WorkerEntrypoint {
|
|
228
|
+
async verifyToken(token: string): Promise<{ userId: string; valid: boolean }> {
|
|
229
|
+
return { userId: "user-123", valid: true };
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
// Caller Worker
|
|
234
|
+
const auth = await env.AUTH_SERVICE.verifyToken(token);
|
|
235
|
+
```
|
|
236
|
+
|
|
237
|
+
**Retrieve**: verify `WorkerEntrypoint` import path and signature against latest `@cloudflare/workers-types`.
|
|
238
|
+
|
|
239
|
+
### Use Hyperdrive for external database connections
|
|
240
|
+
|
|
241
|
+
Hyperdrive maintains a regional connection pool, eliminating per-request TCP + TLS + auth cost (often 300-500ms). Create a new `Client` per request — Hyperdrive manages the underlying pool. Requires `nodejs_compat`.
|
|
242
|
+
|
|
243
|
+
**Check**: any `new Client()` or database connection that uses a direct connection string instead of `env.HYPERDRIVE.connectionString`.
|
|
244
|
+
|
|
245
|
+
```jsonc
|
|
246
|
+
{
|
|
247
|
+
"hyperdrive": [{ "binding": "HYPERDRIVE", "id": "<YOUR_HYPERDRIVE_ID>" }]
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
```ts
|
|
252
|
+
import { Client } from "pg";
|
|
253
|
+
|
|
254
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
255
|
+
const client = new Client({ connectionString: env.HYPERDRIVE.connectionString });
|
|
256
|
+
await client.connect();
|
|
257
|
+
const result = await client.query("SELECT id, name FROM users LIMIT 10");
|
|
258
|
+
return Response.json(result.rows);
|
|
259
|
+
}
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
**Retrieve**: `/hyperdrive/` for current configuration and supported databases.
|
|
263
|
+
|
|
264
|
+
---
|
|
265
|
+
|
|
266
|
+
## Observability
|
|
267
|
+
|
|
268
|
+
### Enable Workers Logs and Traces
|
|
269
|
+
|
|
270
|
+
Enable `observability` in wrangler config before deploying to production. Use `head_sampling_rate` to control volume and cost. Use structured JSON logging — `console.log(JSON.stringify({...}))` — so logs are searchable. Use `console.error` for errors (appears at error severity in the dashboard).
|
|
271
|
+
|
|
272
|
+
**Check**: `observability.enabled` is `true` in config. Logging uses structured JSON, not string concatenation.
|
|
273
|
+
|
|
274
|
+
```jsonc
|
|
275
|
+
{
|
|
276
|
+
"observability": {
|
|
277
|
+
"enabled": true,
|
|
278
|
+
"logs": { "head_sampling_rate": 1 },
|
|
279
|
+
"traces": { "enabled": true, "head_sampling_rate": 0.01 }
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
```
|
|
283
|
+
|
|
284
|
+
```ts
|
|
285
|
+
// Structured JSON — searchable and filterable
|
|
286
|
+
console.log(JSON.stringify({ message: "incoming request", method: request.method, path: url.pathname }));
|
|
287
|
+
|
|
288
|
+
// Error severity
|
|
289
|
+
console.error(JSON.stringify({ message: "request failed", error: e instanceof Error ? e.message : String(e) }));
|
|
290
|
+
```
|
|
291
|
+
|
|
292
|
+
Anti-pattern:
|
|
293
|
+
```ts
|
|
294
|
+
// Unstructured string logs — hard to query
|
|
295
|
+
console.log("Got a request to " + url.pathname);
|
|
296
|
+
```
|
|
297
|
+
|
|
298
|
+
**Retrieve**: `/workers/observability/logs/workers-logs/` and `/workers/observability/traces/` for current config options.
|
|
299
|
+
|
|
300
|
+
---
|
|
301
|
+
|
|
302
|
+
## Code Patterns
|
|
303
|
+
|
|
304
|
+
### Do not store request-scoped state in global scope
|
|
305
|
+
|
|
306
|
+
Workers reuse isolates across requests. Module-level mutable variables cause cross-request data leaks, stale state, and "Cannot perform I/O on behalf of a different request" errors.
|
|
307
|
+
|
|
308
|
+
**Check**: no mutable `let`/`var` at module scope that gets assigned inside a handler. Pass state through function arguments.
|
|
309
|
+
|
|
310
|
+
```ts
|
|
311
|
+
export default {
|
|
312
|
+
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
|
|
313
|
+
const userId = request.headers.get("X-User-Id");
|
|
314
|
+
const result = await handleRequest(userId, env);
|
|
315
|
+
return Response.json(result);
|
|
316
|
+
},
|
|
317
|
+
} satisfies ExportedHandler<Env>;
|
|
318
|
+
```
|
|
319
|
+
|
|
320
|
+
Anti-pattern:
|
|
321
|
+
```ts
|
|
322
|
+
// Module-level mutable state — leaks between requests
|
|
323
|
+
let currentUser: string | null = null;
|
|
324
|
+
|
|
325
|
+
export default {
|
|
326
|
+
async fetch(request: Request, env: Env): Promise<Response> {
|
|
327
|
+
currentUser = request.headers.get("X-User-Id"); // Visible to next request
|
|
328
|
+
// ...
|
|
329
|
+
},
|
|
330
|
+
};
|
|
331
|
+
```
|
|
332
|
+
|
|
333
|
+
### Always await or waitUntil Promises
|
|
334
|
+
|
|
335
|
+
A Promise that is not `await`ed, `return`ed, or passed to `ctx.waitUntil()` is a floating promise. Causes: dropped results, swallowed errors, unfinished work. The runtime may terminate the isolate before it completes.
|
|
336
|
+
|
|
337
|
+
**Check**: every `fetch()`, `env.*.put()`, `env.*.send()`, and any other async call is handled. Enable `no-floating-promises` lint rule.
|
|
338
|
+
|
|
339
|
+
```bash
|
|
340
|
+
# ESLint
|
|
341
|
+
npx eslint --rule '{"@typescript-eslint/no-floating-promises": "error"}' src/
|
|
342
|
+
|
|
343
|
+
# oxlint
|
|
344
|
+
npx oxlint --deny typescript/no-floating-promises src/
|
|
345
|
+
```
|
|
346
|
+
|
|
347
|
+
```ts
|
|
348
|
+
// Correct: await when you need the result
|
|
349
|
+
const response = await fetch("https://api.example.com/process", { method: "POST", body: JSON.stringify(data) });
|
|
350
|
+
|
|
351
|
+
// Correct: waitUntil when you don't need the result before responding
|
|
352
|
+
ctx.waitUntil(fetch("https://api.example.com/webhook", { method: "POST", body: JSON.stringify(data) }));
|
|
353
|
+
```
|
|
354
|
+
|
|
355
|
+
Anti-pattern:
|
|
356
|
+
```ts
|
|
357
|
+
// Floating promise — result dropped, error swallowed
|
|
358
|
+
fetch("https://api.example.com/webhook", { method: "POST", body: JSON.stringify(data) });
|
|
359
|
+
```
|
|
360
|
+
|
|
361
|
+
### Be aware of platform limits
|
|
362
|
+
|
|
363
|
+
Workers have a 10ms CPU time limit (Bundled) or 30s (Standard/Unbound). Heavy synchronous work — tight loops, large JSON parsing, compute-intensive crypto — can hit the CPU limit and terminate the request.
|
|
364
|
+
|
|
365
|
+
**Check**: compute-heavy operations that run synchronously. Consider breaking work into smaller chunks, offloading to Queues/Workflows, or using WebAssembly for CPU-intensive tasks.
|
|
366
|
+
|
|
367
|
+
**Retrieve**: current limits at `/workers/platform/limits/`.
|
|
368
|
+
|
|
369
|
+
---
|
|
370
|
+
|
|
371
|
+
## Security
|
|
372
|
+
|
|
373
|
+
### Use Web Crypto for secure token generation
|
|
374
|
+
|
|
375
|
+
Use `crypto.randomUUID()` for unique IDs and `crypto.getRandomValues()` for random bytes. `Math.random()` is not cryptographically secure.
|
|
376
|
+
|
|
377
|
+
For comparing secrets (API keys, HMAC signatures), use `crypto.subtle.timingSafeEqual()`. Hash both values to a fixed size first — do not short-circuit on length mismatch (leaks length via timing).
|
|
378
|
+
|
|
379
|
+
**Check**: no `Math.random()` for security-sensitive values. Secret comparisons use `timingSafeEqual` with fixed-size hashing.
|
|
380
|
+
|
|
381
|
+
```ts
|
|
382
|
+
// Secure random UUID
|
|
383
|
+
const sessionId = crypto.randomUUID();
|
|
384
|
+
|
|
385
|
+
// Secure random bytes
|
|
386
|
+
const tokenBytes = new Uint8Array(32);
|
|
387
|
+
crypto.getRandomValues(tokenBytes);
|
|
388
|
+
const token = Array.from(tokenBytes).map((b) => b.toString(16).padStart(2, "0")).join("");
|
|
389
|
+
```
|
|
390
|
+
|
|
391
|
+
```ts
|
|
392
|
+
// Constant-time comparison — hash first to avoid length leak
|
|
393
|
+
async function verifyToken(provided: string, expected: string): Promise<boolean> {
|
|
394
|
+
const encoder = new TextEncoder();
|
|
395
|
+
const [providedHash, expectedHash] = await Promise.all([
|
|
396
|
+
crypto.subtle.digest("SHA-256", encoder.encode(provided)),
|
|
397
|
+
crypto.subtle.digest("SHA-256", encoder.encode(expected)),
|
|
398
|
+
]);
|
|
399
|
+
return crypto.subtle.timingSafeEqual(providedHash, expectedHash);
|
|
400
|
+
}
|
|
401
|
+
```
|
|
402
|
+
|
|
403
|
+
Anti-pattern:
|
|
404
|
+
```ts
|
|
405
|
+
// Predictable — not cryptographically secure
|
|
406
|
+
const token = Math.random().toString(36).substring(2);
|
|
407
|
+
|
|
408
|
+
// Timing side-channel — leaks information about the expected value
|
|
409
|
+
return provided === expected;
|
|
410
|
+
```
|
|
411
|
+
|
|
412
|
+
**Retrieve**: `/workers/runtime-apis/web-crypto/` for current API surface.
|
|
413
|
+
|
|
414
|
+
### Explicit error handling over passThroughOnException
|
|
415
|
+
|
|
416
|
+
`passThroughOnException()` is a fail-open mechanism that sends requests to the origin when the Worker throws. It hides bugs and makes debugging difficult. Use explicit try/catch with structured error responses.
|
|
417
|
+
|
|
418
|
+
**Check**: no `ctx.passThroughOnException()` calls. Error handling uses try/catch with structured JSON error responses and `console.error`.
|
|
419
|
+
|
|
420
|
+
```ts
|
|
421
|
+
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
|
|
422
|
+
try {
|
|
423
|
+
const result = await handleRequest(request, env);
|
|
424
|
+
return Response.json(result);
|
|
425
|
+
} catch (error) {
|
|
426
|
+
const message = error instanceof Error ? error.message : "Unknown error";
|
|
427
|
+
console.error(JSON.stringify({ message: "unhandled error", error: message, path: new URL(request.url).pathname }));
|
|
428
|
+
return Response.json({ error: "Internal server error" }, { status: 500 });
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
```
|
|
432
|
+
|
|
433
|
+
---
|
|
434
|
+
|
|
435
|
+
## Development & Testing
|
|
436
|
+
|
|
437
|
+
### Test with @cloudflare/vitest-pool-workers
|
|
438
|
+
|
|
439
|
+
Runs tests inside the Workers runtime with real bindings. Catches issues that Node.js-based tests miss.
|
|
440
|
+
|
|
441
|
+
**Known pitfall**: the Vitest pool auto-injects `nodejs_compat`, so tests pass even if your wrangler config is missing the flag. Always confirm your `wrangler.jsonc` includes `nodejs_compat` if your code depends on Node.js built-ins.
|
|
442
|
+
|
|
443
|
+
**Check**: test setup uses `@cloudflare/vitest-pool-workers`. Tests cover nullable returns (e.g., KV `.get()` returning `null`).
|
|
444
|
+
|
|
445
|
+
```ts
|
|
446
|
+
import { describe, it, expect } from "vitest";
|
|
447
|
+
import { env } from "cloudflare:test";
|
|
448
|
+
|
|
449
|
+
describe("KV operations", () => {
|
|
450
|
+
it("should store and retrieve a value", async () => {
|
|
451
|
+
await env.MY_KV.put("key", "value");
|
|
452
|
+
const result = await env.MY_KV.get("key");
|
|
453
|
+
expect(result).toBe("value");
|
|
454
|
+
});
|
|
455
|
+
|
|
456
|
+
it("should return null for missing keys", async () => {
|
|
457
|
+
const result = await env.MY_KV.get("nonexistent");
|
|
458
|
+
expect(result).toBeNull();
|
|
459
|
+
});
|
|
460
|
+
});
|
|
461
|
+
```
|
|
462
|
+
|
|
463
|
+
**Retrieve**: `/workers/testing/vitest-integration/` for current setup and configuration.
|