cfsa-antigravity 1.0.0

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.
Files changed (378) hide show
  1. package/bin/cli.mjs +324 -0
  2. package/package.json +34 -0
  3. package/template/.agent/instructions/commands.md +48 -0
  4. package/template/.agent/instructions/patterns.md +61 -0
  5. package/template/.agent/instructions/structure.md +29 -0
  6. package/template/.agent/instructions/tech-stack.md +43 -0
  7. package/template/.agent/instructions/workflow.md +41 -0
  8. package/template/.agent/kit-sync.md +15 -0
  9. package/template/.agent/rules/boundary-not-placeholder.md +146 -0
  10. package/template/.agent/rules/completion-checklist.md +48 -0
  11. package/template/.agent/rules/decision-classification.md +103 -0
  12. package/template/.agent/rules/extensibility.md +47 -0
  13. package/template/.agent/rules/question-vs-command.md +81 -0
  14. package/template/.agent/rules/security-first.md +43 -0
  15. package/template/.agent/rules/specificity-standards.md +54 -0
  16. package/template/.agent/rules/tdd-contract-first.md +57 -0
  17. package/template/.agent/rules/vertical-slices.md +42 -0
  18. package/template/.agent/skill-library/MANIFEST.md +480 -0
  19. package/template/.agent/skill-library/README.md +38 -0
  20. package/template/.agent/skill-library/meta/brand-guidelines/SKILL.md +73 -0
  21. package/template/.agent/skill-library/meta/claude-code/README.md +9 -0
  22. package/template/.agent/skill-library/meta/claude-code/agent-development/SKILL.md +415 -0
  23. package/template/.agent/skill-library/meta/claude-code/hook-development/SKILL.md +712 -0
  24. package/template/.agent/skill-library/meta/claude-code/plugin-structure/SKILL.md +476 -0
  25. package/template/.agent/skill-library/meta/git-advanced/SKILL.md +972 -0
  26. package/template/.agent/skill-library/meta/mcp-builder/SKILL.md +236 -0
  27. package/template/.agent/skill-library/meta/product-marketing-context/SKILL.md +241 -0
  28. package/template/.agent/skill-library/meta/regex-patterns/SKILL.md +751 -0
  29. package/template/.agent/skill-library/meta/tmux-processes/SKILL.md +210 -0
  30. package/template/.agent/skill-library/meta/using-tmux-for-interactive-commands/SKILL.md +178 -0
  31. package/template/.agent/skill-library/stack/3d/threejs-pro/SKILL.md +300 -0
  32. package/template/.agent/skill-library/stack/ai/ai-sdk/SKILL.md +77 -0
  33. package/template/.agent/skill-library/stack/ai/langchain/SKILL.md +530 -0
  34. package/template/.agent/skill-library/stack/ai/ollama/SKILL.md +321 -0
  35. package/template/.agent/skill-library/stack/ai/openai-sdk/SKILL.md +549 -0
  36. package/template/.agent/skill-library/stack/analytics/google-analytics/SKILL.md +153 -0
  37. package/template/.agent/skill-library/stack/api/graphql/SKILL.md +1061 -0
  38. package/template/.agent/skill-library/stack/api/trpc/SKILL.md +576 -0
  39. package/template/.agent/skill-library/stack/auth/authjs/SKILL.md +569 -0
  40. package/template/.agent/skill-library/stack/auth/clerk/SKILL.md +590 -0
  41. package/template/.agent/skill-library/stack/auth/firebase-auth/SKILL.md +734 -0
  42. package/template/.agent/skill-library/stack/cms/payload-cms/SKILL.md +573 -0
  43. package/template/.agent/skill-library/stack/cms/shopify/SKILL.md +1193 -0
  44. package/template/.agent/skill-library/stack/cms/wordpress/SKILL.md +1104 -0
  45. package/template/.agent/skill-library/stack/css/sass-scss/SKILL.md +1121 -0
  46. package/template/.agent/skill-library/stack/css/tailwind-css-patterns/SKILL.md +863 -0
  47. package/template/.agent/skill-library/stack/css/tailwind-design-system/SKILL.md +490 -0
  48. package/template/.agent/skill-library/stack/css/vanilla-css/SKILL.md +1078 -0
  49. package/template/.agent/skill-library/stack/databases/clickhouse/SKILL.md +311 -0
  50. package/template/.agent/skill-library/stack/databases/influxdb/SKILL.md +280 -0
  51. package/template/.agent/skill-library/stack/databases/lancedb/SKILL.md +415 -0
  52. package/template/.agent/skill-library/stack/databases/mongodb/SKILL.md +1169 -0
  53. package/template/.agent/skill-library/stack/databases/neo4j/SKILL.md +839 -0
  54. package/template/.agent/skill-library/stack/databases/pgvector/SKILL.md +241 -0
  55. package/template/.agent/skill-library/stack/databases/pinecone/SKILL.md +212 -0
  56. package/template/.agent/skill-library/stack/databases/postgresql/SKILL.md +658 -0
  57. package/template/.agent/skill-library/stack/databases/qdrant/SKILL.md +312 -0
  58. package/template/.agent/skill-library/stack/databases/redis/SKILL.md +1079 -0
  59. package/template/.agent/skill-library/stack/databases/spacetimedb/SKILL.md +532 -0
  60. package/template/.agent/skill-library/stack/databases/sqlite/SKILL.md +1132 -0
  61. package/template/.agent/skill-library/stack/databases/supabase/SKILL.md +640 -0
  62. package/template/.agent/skill-library/stack/databases/surrealdb-expert/SKILL.md +945 -0
  63. package/template/.agent/skill-library/stack/databases/timescaledb/SKILL.md +745 -0
  64. package/template/.agent/skill-library/stack/databases/weaviate/SKILL.md +218 -0
  65. package/template/.agent/skill-library/stack/devops/github-actions/SKILL.md +554 -0
  66. package/template/.agent/skill-library/stack/devops/kubernetes/SKILL.md +950 -0
  67. package/template/.agent/skill-library/stack/devops/nginx/SKILL.md +841 -0
  68. package/template/.agent/skill-library/stack/devops/terraform/SKILL.md +860 -0
  69. package/template/.agent/skill-library/stack/email/resend/SKILL.md +391 -0
  70. package/template/.agent/skill-library/stack/engines/godot/SKILL.md +488 -0
  71. package/template/.agent/skill-library/stack/extensions/chrome-extension/SKILL.md +375 -0
  72. package/template/.agent/skill-library/stack/extensions/vscode-extension/SKILL.md +453 -0
  73. package/template/.agent/skill-library/stack/frameworks/astro-framework/SKILL.md +162 -0
  74. package/template/.agent/skill-library/stack/frameworks/electron/SKILL.md +1286 -0
  75. package/template/.agent/skill-library/stack/frameworks/fastapi/SKILL.md +650 -0
  76. package/template/.agent/skill-library/stack/frameworks/hono/SKILL.md +90 -0
  77. package/template/.agent/skill-library/stack/frameworks/nestjs/SKILL.md +878 -0
  78. package/template/.agent/skill-library/stack/frameworks/nextjs/SKILL.md +635 -0
  79. package/template/.agent/skill-library/stack/frameworks/nuxt/SKILL.md +564 -0
  80. package/template/.agent/skill-library/stack/frameworks/sveltekit/SKILL.md +614 -0
  81. package/template/.agent/skill-library/stack/frameworks/tauri/SKILL.md +920 -0
  82. package/template/.agent/skill-library/stack/gamedev/godot/SKILL.md +1032 -0
  83. package/template/.agent/skill-library/stack/gamedev/unity/SKILL.md +1175 -0
  84. package/template/.agent/skill-library/stack/hosting/aws/SKILL.md +467 -0
  85. package/template/.agent/skill-library/stack/hosting/cloudflare/SKILL.md +201 -0
  86. package/template/.agent/skill-library/stack/hosting/docker-expert/SKILL.md +409 -0
  87. package/template/.agent/skill-library/stack/hosting/vercel/SKILL.md +484 -0
  88. package/template/.agent/skill-library/stack/languages/bash-scripting/SKILL.md +773 -0
  89. package/template/.agent/skill-library/stack/languages/c-cpp/SKILL.md +712 -0
  90. package/template/.agent/skill-library/stack/languages/gdscript/SKILL.md +789 -0
  91. package/template/.agent/skill-library/stack/languages/go/SKILL.md +664 -0
  92. package/template/.agent/skill-library/stack/languages/java/SKILL.md +778 -0
  93. package/template/.agent/skill-library/stack/languages/kotlin/SKILL.md +665 -0
  94. package/template/.agent/skill-library/stack/languages/python/SKILL.md +678 -0
  95. package/template/.agent/skill-library/stack/languages/rust/SKILL.md +673 -0
  96. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/SKILL.md +141 -0
  97. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/advanced-generics.md +90 -0
  98. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/branded-types.md +57 -0
  99. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/builder-pattern.md +71 -0
  100. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/common-pitfalls.md +135 -0
  101. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/conditional-types.md +27 -0
  102. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/decorators.md +98 -0
  103. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/discriminated-unions.md +62 -0
  104. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/mapped-types.md +53 -0
  105. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/performance-best-practices.md +104 -0
  106. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/template-literal-types.md +49 -0
  107. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/testing-types.md +112 -0
  108. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/type-guards.md +70 -0
  109. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/type-inference.md +101 -0
  110. package/template/.agent/skill-library/stack/languages/typescript-advanced-patterns/references/utility-types.md +98 -0
  111. package/template/.agent/skill-library/stack/languages/vanilla-javascript/SKILL.md +803 -0
  112. package/template/.agent/skill-library/stack/messaging/kafka/SKILL.md +235 -0
  113. package/template/.agent/skill-library/stack/mobile/expo-react-native/SKILL.md +665 -0
  114. package/template/.agent/skill-library/stack/mobile/flutter/SKILL.md +316 -0
  115. package/template/.agent/skill-library/stack/mobile/react-native/SKILL.md +337 -0
  116. package/template/.agent/skill-library/stack/monitoring/posthog/SKILL.md +396 -0
  117. package/template/.agent/skill-library/stack/monitoring/sentry/SKILL.md +509 -0
  118. package/template/.agent/skill-library/stack/observability/datadog/SKILL.md +179 -0
  119. package/template/.agent/skill-library/stack/observability/distributed-tracing/SKILL.md +140 -0
  120. package/template/.agent/skill-library/stack/observability/logging-best-practices/SKILL.md +168 -0
  121. package/template/.agent/skill-library/stack/observability/opentelemetry/SKILL.md +164 -0
  122. package/template/.agent/skill-library/stack/observability/prometheus-grafana/SKILL.md +246 -0
  123. package/template/.agent/skill-library/stack/observability/python-observability/SKILL.md +158 -0
  124. package/template/.agent/skill-library/stack/orm/drizzle-orm/SKILL.md +613 -0
  125. package/template/.agent/skill-library/stack/orm/prisma/SKILL.md +744 -0
  126. package/template/.agent/skill-library/stack/payments/lemonsqueezy/SKILL.md +393 -0
  127. package/template/.agent/skill-library/stack/payments/stripe-integration/SKILL.md +457 -0
  128. package/template/.agent/skill-library/stack/queue/bullmq/SKILL.md +385 -0
  129. package/template/.agent/skill-library/stack/queue/inngest/SKILL.md +438 -0
  130. package/template/.agent/skill-library/stack/realtime/socketio/SKILL.md +595 -0
  131. package/template/.agent/skill-library/stack/search/elasticsearch/SKILL.md +248 -0
  132. package/template/.agent/skill-library/stack/search/meilisearch/SKILL.md +385 -0
  133. package/template/.agent/skill-library/stack/security/crypto-patterns/SKILL.md +437 -0
  134. package/template/.agent/skill-library/stack/security/csp-cors-headers/SKILL.md +588 -0
  135. package/template/.agent/skill-library/stack/security/dependency-auditing/SKILL.md +560 -0
  136. package/template/.agent/skill-library/stack/security/input-sanitization/SKILL.md +430 -0
  137. package/template/.agent/skill-library/stack/security/owasp-web-security/SKILL.md +421 -0
  138. package/template/.agent/skill-library/stack/state/tanstack-query/SKILL.md +637 -0
  139. package/template/.agent/skill-library/stack/state/zustand/SKILL.md +483 -0
  140. package/template/.agent/skill-library/stack/storage/aws-s3/SKILL.md +415 -0
  141. package/template/.agent/skill-library/stack/testing/playwright/SKILL.md +641 -0
  142. package/template/.agent/skill-library/stack/testing/storybook/SKILL.md +923 -0
  143. package/template/.agent/skill-library/stack/testing/testing-library/SKILL.md +872 -0
  144. package/template/.agent/skill-library/stack/testing/vitest/SKILL.md +714 -0
  145. package/template/.agent/skill-library/stack/ui/react-best-practices/SKILL.md +877 -0
  146. package/template/.agent/skill-library/stack/ui/react-composition-patterns/SKILL.md +1107 -0
  147. package/template/.agent/skill-library/stack/ui/react-flow/SKILL.md +425 -0
  148. package/template/.agent/skill-library/stack/ui/shadcn-ui/SKILL.md +703 -0
  149. package/template/.agent/skill-library/surface/api/api-caching/SKILL.md +458 -0
  150. package/template/.agent/skill-library/surface/api/api-documentation-openapi/SKILL.md +697 -0
  151. package/template/.agent/skill-library/surface/api/api-error-handling/SKILL.md +478 -0
  152. package/template/.agent/skill-library/surface/api/api-security-checklist/SKILL.md +147 -0
  153. package/template/.agent/skill-library/surface/api/api-versioning/SKILL.md +420 -0
  154. package/template/.agent/skill-library/surface/api/email-best-practices/SKILL.md +59 -0
  155. package/template/.agent/skill-library/surface/api/rate-limiting-abuse-protection/SKILL.md +147 -0
  156. package/template/.agent/skill-library/surface/api/rest-api-design/SKILL.md +478 -0
  157. package/template/.agent/skill-library/surface/api/webhook-design/SKILL.md +752 -0
  158. package/template/.agent/skill-library/surface/cli/cli-configuration-management/SKILL.md +445 -0
  159. package/template/.agent/skill-library/surface/cli/cli-error-diagnostics/SKILL.md +515 -0
  160. package/template/.agent/skill-library/surface/cli/cli-shell-integration/SKILL.md +479 -0
  161. package/template/.agent/skill-library/surface/cli/cli-ux-design/SKILL.md +477 -0
  162. package/template/.agent/skill-library/surface/desktop/desktop-app-distribution/SKILL.md +416 -0
  163. package/template/.agent/skill-library/surface/desktop/desktop-security-sandboxing/SKILL.md +407 -0
  164. package/template/.agent/skill-library/surface/desktop/desktop-ux-conventions/SKILL.md +361 -0
  165. package/template/.agent/skill-library/surface/desktop/native-os-integration/SKILL.md +563 -0
  166. package/template/.agent/skill-library/surface/extension/browser-extension-patterns/SKILL.md +482 -0
  167. package/template/.agent/skill-library/surface/extension/plugin-architecture-design/SKILL.md +632 -0
  168. package/template/.agent/skill-library/surface/extension/vscode-extension-development/SKILL.md +728 -0
  169. package/template/.agent/skill-library/surface/mobile/app-store-submission/SKILL.md +304 -0
  170. package/template/.agent/skill-library/surface/mobile/mobile-offline-sync/SKILL.md +443 -0
  171. package/template/.agent/skill-library/surface/mobile/mobile-responsive-patterns/SKILL.md +432 -0
  172. package/template/.agent/skill-library/surface/mobile/push-notifications/SKILL.md +495 -0
  173. package/template/.agent/skill-library/surface/web/accessibility-compliance/SKILL.md +827 -0
  174. package/template/.agent/skill-library/surface/web/ai-seo/SKILL.md +398 -0
  175. package/template/.agent/skill-library/surface/web/ai-seo/references/content-patterns.md +285 -0
  176. package/template/.agent/skill-library/surface/web/ai-seo/references/platform-ranking-factors.md +152 -0
  177. package/template/.agent/skill-library/surface/web/analytics-tracking/SKILL.md +309 -0
  178. package/template/.agent/skill-library/surface/web/analytics-tracking/references/event-library.md +260 -0
  179. package/template/.agent/skill-library/surface/web/analytics-tracking/references/ga4-implementation.md +300 -0
  180. package/template/.agent/skill-library/surface/web/analytics-tracking/references/gtm-implementation.md +390 -0
  181. package/template/.agent/skill-library/surface/web/authentication-ui-flows/SKILL.md +530 -0
  182. package/template/.agent/skill-library/surface/web/dark-mode-theming/SKILL.md +516 -0
  183. package/template/.agent/skill-library/surface/web/design-reference-data/SKILL.md +105 -0
  184. package/template/.agent/skill-library/surface/web/design-reference-data/data/charts.csv +26 -0
  185. package/template/.agent/skill-library/surface/web/design-reference-data/data/colors.csv +97 -0
  186. package/template/.agent/skill-library/surface/web/design-reference-data/data/landing.csv +31 -0
  187. package/template/.agent/skill-library/surface/web/design-reference-data/data/styles.csv +59 -0
  188. package/template/.agent/skill-library/surface/web/design-reference-data/data/typography.csv +58 -0
  189. package/template/.agent/skill-library/surface/web/design-reference-data/data/ux-guidelines.csv +100 -0
  190. package/template/.agent/skill-library/surface/web/design-reference-data/scripts/core.py +258 -0
  191. package/template/.agent/skill-library/surface/web/design-reference-data/scripts/design_system.py +1067 -0
  192. package/template/.agent/skill-library/surface/web/design-reference-data/scripts/search.py +106 -0
  193. package/template/.agent/skill-library/surface/web/form-handling-validation/SKILL.md +675 -0
  194. package/template/.agent/skill-library/surface/web/frontend-design/SKILL.md +1393 -0
  195. package/template/.agent/skill-library/surface/web/frontend-design/templates/cppn-hero.tsx +299 -0
  196. package/template/.agent/skill-library/surface/web/frontend-design/templates/wave-hero.tsx +875 -0
  197. package/template/.agent/skill-library/surface/web/frontend-verification/SKILL.md +111 -0
  198. package/template/.agent/skill-library/surface/web/frontend-verification/scripts/ux_audit.py +739 -0
  199. package/template/.agent/skill-library/surface/web/i18n-localization/SKILL.md +154 -0
  200. package/template/.agent/skill-library/surface/web/offline-first-pwa/SKILL.md +657 -0
  201. package/template/.agent/skill-library/surface/web/page-cro/SKILL.md +182 -0
  202. package/template/.agent/skill-library/surface/web/page-cro/references/experiments.md +248 -0
  203. package/template/.agent/skill-library/surface/web/programmatic-seo/SKILL.md +238 -0
  204. package/template/.agent/skill-library/surface/web/programmatic-seo/references/playbooks.md +308 -0
  205. package/template/.agent/skill-library/surface/web/schema-markup/SKILL.md +179 -0
  206. package/template/.agent/skill-library/surface/web/schema-markup/references/schema-examples.md +398 -0
  207. package/template/.agent/skill-library/surface/web/seo-audit/SKILL.md +394 -0
  208. package/template/.agent/skill-library/surface/web/seo-audit/references/ai-writing-detection.md +200 -0
  209. package/template/.agent/skill-library/surface/web/web-performance-optimization/SKILL.md +646 -0
  210. package/template/.agent/skill-library/surface/web/web-scraping/SKILL.md +58 -0
  211. package/template/.agent/skills/accessibility/SKILL.md +522 -0
  212. package/template/.agent/skills/accessibility/references/WCAG.md +162 -0
  213. package/template/.agent/skills/adversarial-review/SKILL.md +90 -0
  214. package/template/.agent/skills/antigravity-workflows/SKILL.md +81 -0
  215. package/template/.agent/skills/antigravity-workflows/resources/implementation-playbook.md +36 -0
  216. package/template/.agent/skills/api-design-principles/SKILL.md +37 -0
  217. package/template/.agent/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  218. package/template/.agent/skills/api-design-principles/assets/rest-api-template.py +182 -0
  219. package/template/.agent/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  220. package/template/.agent/skills/api-design-principles/references/rest-best-practices.md +408 -0
  221. package/template/.agent/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  222. package/template/.agent/skills/api-versioning/SKILL.md +420 -0
  223. package/template/.agent/skills/architecture-mapping/SKILL.md +219 -0
  224. package/template/.agent/skills/bootstrap-agents/SKILL.md +259 -0
  225. package/template/.agent/skills/brainstorming/SKILL.md +236 -0
  226. package/template/.agent/skills/brand-guidelines/SKILL.md +44 -0
  227. package/template/.agent/skills/clean-code/SKILL.md +94 -0
  228. package/template/.agent/skills/code-review-pro/SKILL.md +152 -0
  229. package/template/.agent/skills/concise-planning/SKILL.md +68 -0
  230. package/template/.agent/skills/cross-layer-consistency/SKILL.md +117 -0
  231. package/template/.agent/skills/database-schema-design/SKILL.md +429 -0
  232. package/template/.agent/skills/deployment-procedures/SKILL.md +241 -0
  233. package/template/.agent/skills/design-anti-cliche/SKILL.md +159 -0
  234. package/template/.agent/skills/design-direction/SKILL.md +45 -0
  235. package/template/.agent/skills/error-handling-patterns/SKILL.md +721 -0
  236. package/template/.agent/skills/find-skills/SKILL.md +145 -0
  237. package/template/.agent/skills/git-advanced/SKILL.md +972 -0
  238. package/template/.agent/skills/git-workflow/SKILL.md +420 -0
  239. package/template/.agent/skills/idea-extraction/SKILL.md +271 -0
  240. package/template/.agent/skills/logging-best-practices/SKILL.md +851 -0
  241. package/template/.agent/skills/migration-management/SKILL.md +384 -0
  242. package/template/.agent/skills/minimalist-surgical-development/SKILL.md +69 -0
  243. package/template/.agent/skills/parallel-agents/SKILL.md +165 -0
  244. package/template/.agent/skills/parallel-debugging/SKILL.md +135 -0
  245. package/template/.agent/skills/parallel-feature-development/SKILL.md +166 -0
  246. package/template/.agent/skills/performance-budgeting/SKILL.md +144 -0
  247. package/template/.agent/skills/pipeline-rubrics/SKILL.md +51 -0
  248. package/template/.agent/skills/pipeline-rubrics/references/architecture-rubric.md +19 -0
  249. package/template/.agent/skills/pipeline-rubrics/references/be-rubric.md +21 -0
  250. package/template/.agent/skills/pipeline-rubrics/references/fe-rubric.md +20 -0
  251. package/template/.agent/skills/pipeline-rubrics/references/ia-rubric.md +19 -0
  252. package/template/.agent/skills/pipeline-rubrics/references/scoring.md +28 -0
  253. package/template/.agent/skills/pipeline-rubrics/references/vision-rubric.md +11 -0
  254. package/template/.agent/skills/prd-templates/SKILL.md +88 -0
  255. package/template/.agent/skills/prd-templates/references/architecture-design-template.md +88 -0
  256. package/template/.agent/skills/prd-templates/references/be-spec-template.md +101 -0
  257. package/template/.agent/skills/prd-templates/references/data-placement-template.md +74 -0
  258. package/template/.agent/skills/prd-templates/references/decomposition-templates.md +211 -0
  259. package/template/.agent/skills/prd-templates/references/design-system-decisions.md +198 -0
  260. package/template/.agent/skills/prd-templates/references/engineering-standards-template.md +124 -0
  261. package/template/.agent/skills/prd-templates/references/fe-classification-procedures.md +47 -0
  262. package/template/.agent/skills/prd-templates/references/fe-spec-template.md +84 -0
  263. package/template/.agent/skills/prd-templates/references/infrastructure-report-template.md +71 -0
  264. package/template/.agent/skills/prd-templates/references/operational-templates.md +116 -0
  265. package/template/.agent/skills/prd-templates/references/placeholder-guard-template.md +21 -0
  266. package/template/.agent/skills/prd-templates/references/surface-model.md +61 -0
  267. package/template/.agent/skills/prd-templates/references/vision-template.md +66 -0
  268. package/template/.agent/skills/prompt-engineer/README.md +659 -0
  269. package/template/.agent/skills/prompt-engineer/SKILL.md +249 -0
  270. package/template/.agent/skills/regex-patterns/SKILL.md +751 -0
  271. package/template/.agent/skills/resolve-ambiguity/SKILL.md +278 -0
  272. package/template/.agent/skills/rest-api-design/SKILL.md +478 -0
  273. package/template/.agent/skills/security-scanning-security-hardening/SKILL.md +231 -0
  274. package/template/.agent/skills/session-continuity/SKILL.md +730 -0
  275. package/template/.agent/skills/session-continuity/protocols/01-session-resumption.md +38 -0
  276. package/template/.agent/skills/session-continuity/protocols/02-progress-generation.md +85 -0
  277. package/template/.agent/skills/session-continuity/protocols/03-progress-update.md +70 -0
  278. package/template/.agent/skills/session-continuity/protocols/04-pattern-extraction.md +60 -0
  279. package/template/.agent/skills/session-continuity/protocols/05-session-close.md +37 -0
  280. package/template/.agent/skills/session-continuity/protocols/06-decision-analysis.md +84 -0
  281. package/template/.agent/skills/session-continuity/protocols/07-spec-pipeline-generation.md +48 -0
  282. package/template/.agent/skills/session-continuity/protocols/08-spec-pipeline-update.md +43 -0
  283. package/template/.agent/skills/session-continuity/protocols/09-parallel-claim.md +122 -0
  284. package/template/.agent/skills/session-continuity/protocols/10-placeholder-verification-gate.md +104 -0
  285. package/template/.agent/skills/session-continuity/protocols/ambiguity-gates.md +48 -0
  286. package/template/.agent/skills/skill-creator/LICENSE.txt +202 -0
  287. package/template/.agent/skills/skill-creator/README.md +270 -0
  288. package/template/.agent/skills/skill-creator/SKILL.md +590 -0
  289. package/template/.agent/skills/skill-creator/references/output-patterns.md +82 -0
  290. package/template/.agent/skills/skill-creator/references/workflows.md +28 -0
  291. package/template/.agent/skills/skill-creator/scripts/init_skill.py +303 -0
  292. package/template/.agent/skills/skill-creator/scripts/package_skill.py +110 -0
  293. package/template/.agent/skills/skill-creator/scripts/quick_validate.py +95 -0
  294. package/template/.agent/skills/spec-writing/SKILL.md +110 -0
  295. package/template/.agent/skills/systematic-debugging/CREATION-LOG.md +119 -0
  296. package/template/.agent/skills/systematic-debugging/SKILL.md +297 -0
  297. package/template/.agent/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
  298. package/template/.agent/skills/systematic-debugging/condition-based-waiting.md +115 -0
  299. package/template/.agent/skills/systematic-debugging/defense-in-depth.md +122 -0
  300. package/template/.agent/skills/systematic-debugging/find-polluter.sh +63 -0
  301. package/template/.agent/skills/systematic-debugging/root-cause-tracing.md +169 -0
  302. package/template/.agent/skills/systematic-debugging/test-academic.md +14 -0
  303. package/template/.agent/skills/systematic-debugging/test-pressure-1.md +58 -0
  304. package/template/.agent/skills/systematic-debugging/test-pressure-2.md +68 -0
  305. package/template/.agent/skills/systematic-debugging/test-pressure-3.md +69 -0
  306. package/template/.agent/skills/tdd-workflow/SKILL.md +409 -0
  307. package/template/.agent/skills/tech-stack-catalog/SKILL.md +49 -0
  308. package/template/.agent/skills/tech-stack-catalog/references/constraint-questions.md +21 -0
  309. package/template/.agent/skills/tech-stack-catalog/references/dev-tooling-decisions.md +37 -0
  310. package/template/.agent/skills/tech-stack-catalog/references/surface-decision-tables.md +69 -0
  311. package/template/.agent/skills/technical-writer/SKILL.md +242 -0
  312. package/template/.agent/skills/testing-strategist/SKILL.md +932 -0
  313. package/template/.agent/skills/verification-before-completion/SKILL.md +145 -0
  314. package/template/.agent/skills/workflow-automation/SKILL.md +73 -0
  315. package/template/.agent/workflows/audit-ambiguity-execute.md +165 -0
  316. package/template/.agent/workflows/audit-ambiguity-rubrics.md +83 -0
  317. package/template/.agent/workflows/audit-ambiguity.md +64 -0
  318. package/template/.agent/workflows/bootstrap-agents-fill.md +201 -0
  319. package/template/.agent/workflows/bootstrap-agents-provision.md +197 -0
  320. package/template/.agent/workflows/bootstrap-agents.md +66 -0
  321. package/template/.agent/workflows/create-prd-architecture.md +119 -0
  322. package/template/.agent/workflows/create-prd-compile.md +138 -0
  323. package/template/.agent/workflows/create-prd-design-system.md +135 -0
  324. package/template/.agent/workflows/create-prd-security.md +113 -0
  325. package/template/.agent/workflows/create-prd-stack.md +91 -0
  326. package/template/.agent/workflows/create-prd.md +168 -0
  327. package/template/.agent/workflows/decompose-architecture-structure.md +82 -0
  328. package/template/.agent/workflows/decompose-architecture-validate.md +119 -0
  329. package/template/.agent/workflows/decompose-architecture.md +111 -0
  330. package/template/.agent/workflows/evolve-contract.md +98 -0
  331. package/template/.agent/workflows/evolve-feature-cascade.md +140 -0
  332. package/template/.agent/workflows/evolve-feature-classify.md +116 -0
  333. package/template/.agent/workflows/evolve-feature.md +56 -0
  334. package/template/.agent/workflows/ideate-discover.md +144 -0
  335. package/template/.agent/workflows/ideate-extract.md +129 -0
  336. package/template/.agent/workflows/ideate-validate.md +117 -0
  337. package/template/.agent/workflows/ideate.md +113 -0
  338. package/template/.agent/workflows/implement-slice-setup.md +113 -0
  339. package/template/.agent/workflows/implement-slice-tdd.md +198 -0
  340. package/template/.agent/workflows/implement-slice.md +50 -0
  341. package/template/.agent/workflows/plan-phase.md +202 -0
  342. package/template/.agent/workflows/propagate-decision-apply.md +135 -0
  343. package/template/.agent/workflows/propagate-decision-scan.md +147 -0
  344. package/template/.agent/workflows/propagate-decision.md +56 -0
  345. package/template/.agent/workflows/remediate-pipeline-assess.md +138 -0
  346. package/template/.agent/workflows/remediate-pipeline-execute.md +135 -0
  347. package/template/.agent/workflows/remediate-pipeline.md +55 -0
  348. package/template/.agent/workflows/resolve-ambiguity.md +82 -0
  349. package/template/.agent/workflows/sync-kit.md +209 -0
  350. package/template/.agent/workflows/update-architecture-map.md +74 -0
  351. package/template/.agent/workflows/validate-phase.md +219 -0
  352. package/template/.agent/workflows/verify-infrastructure.md +207 -0
  353. package/template/.agent/workflows/write-architecture-spec-deepen.md +139 -0
  354. package/template/.agent/workflows/write-architecture-spec-design.md +202 -0
  355. package/template/.agent/workflows/write-architecture-spec.md +63 -0
  356. package/template/.agent/workflows/write-be-spec-classify.md +165 -0
  357. package/template/.agent/workflows/write-be-spec-write.md +98 -0
  358. package/template/.agent/workflows/write-be-spec.md +76 -0
  359. package/template/.agent/workflows/write-fe-spec-classify.md +170 -0
  360. package/template/.agent/workflows/write-fe-spec-write.md +94 -0
  361. package/template/.agent/workflows/write-fe-spec.md +71 -0
  362. package/template/AGENTS.md +176 -0
  363. package/template/GEMINI.md +177 -0
  364. package/template/docs/README.md +187 -0
  365. package/template/docs/audits/.gitkeep +0 -0
  366. package/template/docs/audits/README.md +10 -0
  367. package/template/docs/plans/.gitkeep +0 -0
  368. package/template/docs/plans/README.md +21 -0
  369. package/template/docs/plans/be/.gitkeep +0 -0
  370. package/template/docs/plans/be/README.md +11 -0
  371. package/template/docs/plans/fe/.gitkeep +0 -0
  372. package/template/docs/plans/fe/README.md +11 -0
  373. package/template/docs/plans/ia/.gitkeep +0 -0
  374. package/template/docs/plans/ia/README.md +17 -0
  375. package/template/docs/plans/ia/deep-dives/.gitkeep +0 -0
  376. package/template/docs/plans/ia/deep-dives/README.md +5 -0
  377. package/template/docs/plans/phases/.gitkeep +0 -0
  378. package/template/docs/plans/phases/README.md +11 -0
@@ -0,0 +1,420 @@
1
+ ---
2
+ name: api-versioning
3
+ description: "Manage API versioning and evolution with URL/header/query strategies, deprecation workflows, breaking change classification, sunset headers, and consumer-driven contract testing. Use when designing versioning strategy, deprecating endpoints, or evolving API contracts."
4
+ version: 1.0.0
5
+ ---
6
+
7
+ # API Versioning & Evolution
8
+
9
+ APIs are contracts with consumers. Breaking that contract destroys trust. This skill covers how to version, evolve, and deprecate APIs without breaking clients.
10
+
11
+ ## Versioning Strategies
12
+
13
+ ### Strategy Comparison
14
+
15
+ | Strategy | Example | Pros | Cons |
16
+ |----------|---------|------|------|
17
+ | **URL path** | `/api/v2/models` | Obvious, cacheable, easy routing | URL represents resource not version; copies endpoints |
18
+ | **Header** | `API-Version: 2` | Clean URLs, content negotiation | Hidden from browser, harder to test |
19
+ | **Query param** | `/api/models?version=2` | Easy to test, no routing changes | Pollutes query string, cache key complexity |
20
+ | **Accept header** | `Accept: application/vnd.api.v2+json` | Proper content negotiation | Verbose, often misunderstood |
21
+
22
+ ### Recommendation
23
+
24
+ Use **URL path versioning** for public APIs (simplicity and discoverability). Use **header versioning** for internal/partner APIs (cleaner resource model).
25
+
26
+ ### URL Path Versioning
27
+
28
+ ```typescript
29
+ // src/pages/api/v1/models/[id].ts
30
+ export async function GET({ params }: APIContext) {
31
+ // V1 response shape
32
+ return new Response(JSON.stringify({
33
+ id: params.id,
34
+ name: model.name,
35
+ provider: model.provider,
36
+ // V1 had a flat pricing field
37
+ price_per_token: model.pricePerToken,
38
+ }));
39
+ }
40
+
41
+ // src/pages/api/v2/models/[id].ts
42
+ export async function GET({ params }: APIContext) {
43
+ // V2 response shape (nested pricing)
44
+ return new Response(JSON.stringify({
45
+ id: params.id,
46
+ name: model.name,
47
+ provider: model.provider,
48
+ // V2 has structured pricing
49
+ pricing: {
50
+ input: model.inputPrice,
51
+ output: model.outputPrice,
52
+ currency: 'USD',
53
+ unit: 'per_million_tokens',
54
+ },
55
+ }));
56
+ }
57
+ ```
58
+
59
+ ### Header Versioning
60
+
61
+ ```typescript
62
+ // Version routing middleware
63
+ function versionRouter(handlers: Record<string, Handler>): Handler {
64
+ return async (context) => {
65
+ const version = context.request.headers.get('API-Version')
66
+ ?? context.url.searchParams.get('version')
67
+ ?? DEFAULT_VERSION;
68
+
69
+ const handler = handlers[version];
70
+ if (!handler) {
71
+ return new Response(JSON.stringify({
72
+ type: 'https://api.example.com/problems/unsupported-version',
73
+ title: 'Unsupported API Version',
74
+ status: 400,
75
+ detail: `API version '${version}' is not supported. Supported versions: ${Object.keys(handlers).join(', ')}`,
76
+ }), { status: 400, headers: { 'Content-Type': 'application/problem+json' } });
77
+ }
78
+
79
+ const response = await handler(context);
80
+ response.headers.set('API-Version', version);
81
+ return response;
82
+ };
83
+ }
84
+
85
+ // Usage
86
+ export const GET = versionRouter({
87
+ '1': handleV1,
88
+ '2': handleV2,
89
+ });
90
+ ```
91
+
92
+ ---
93
+
94
+ ## Default Version Behavior
95
+
96
+ When a client does not specify a version, the API must behave predictably.
97
+
98
+ | Strategy | Behavior | When to Use |
99
+ |----------|----------|-------------|
100
+ | **Default to latest** | Unversioned requests get the newest version | Internal APIs with controlled consumers |
101
+ | **Default to oldest supported** | Unversioned requests get V1 | Public APIs (avoid surprise breakage) |
102
+ | **Require explicit version** | Return 400 if no version specified | Strict APIs where ambiguity is unacceptable |
103
+
104
+ ```typescript
105
+ const DEFAULT_VERSION = '1'; // Conservative default for public APIs
106
+
107
+ function resolveVersion(request: Request): string {
108
+ return request.headers.get('API-Version')
109
+ ?? request.url.searchParams.get('version')
110
+ ?? DEFAULT_VERSION;
111
+ }
112
+ ```
113
+
114
+ ---
115
+
116
+ ## Breaking vs Non-Breaking Changes
117
+
118
+ ### Non-Breaking (Safe to Ship)
119
+
120
+ | Change | Example | Why It Is Safe |
121
+ |--------|---------|---------------|
122
+ | Add optional field to response | `"avatar_url": "..."` added to user response | Clients ignore unknown fields |
123
+ | Add optional query parameter | `?sort=name` now supported | Existing queries still work |
124
+ | Add new endpoint | `POST /api/v1/webhooks` | Does not affect existing endpoints |
125
+ | Widen accepted input types | Field accepts `string \| number` instead of just `string` | Existing valid inputs remain valid |
126
+ | Add optional request field | `"metadata": {}` now accepted | Existing requests without it still work |
127
+ | Relax validation | Max length changed from 100 to 200 | Previously valid inputs still valid |
128
+
129
+ ### Breaking (Requires New Version)
130
+
131
+ | Change | Example | Why It Breaks |
132
+ |--------|---------|---------------|
133
+ | Remove field from response | `price_per_token` removed | Clients reading this field break |
134
+ | Rename field | `price_per_token` renamed to `pricing` | Clients reading old name break |
135
+ | Change field type | `price` from number to object | Parsing breaks |
136
+ | Remove endpoint | `DELETE /api/v1/legacy` | Clients calling it get 404 |
137
+ | Add required request field | `"region"` now required | Existing requests missing it fail |
138
+ | Tighten validation | Max length changed from 200 to 100 | Previously valid inputs now rejected |
139
+ | Change error response format | Different error shape | Client error handling breaks |
140
+ | Change authentication scheme | Bearer token to API key | Auth headers break |
141
+
142
+ ---
143
+
144
+ ## Additive-Only API Policy
145
+
146
+ The safest evolution strategy: never remove or rename, only add.
147
+
148
+ ```typescript
149
+ // V1 response (original)
150
+ interface ModelV1 {
151
+ id: string;
152
+ name: string;
153
+ price_per_token: number; // original flat field
154
+ }
155
+
156
+ // V1.1 response (additive evolution --- no new version needed)
157
+ interface ModelV1_1 {
158
+ id: string;
159
+ name: string;
160
+ price_per_token: number; // KEPT for backward compatibility
161
+ pricing: { // ADDED new structured field
162
+ input: number;
163
+ output: number;
164
+ currency: string;
165
+ unit: string;
166
+ };
167
+ }
168
+ // Clients reading price_per_token still work.
169
+ // New clients use pricing object.
170
+ // Remove price_per_token only in V2.
171
+ ```
172
+
173
+ ---
174
+
175
+ ## Sunset Headers and Deprecation Workflow
176
+
177
+ ### Sunset Header (RFC 8594)
178
+
179
+ ```typescript
180
+ function addDeprecationHeaders(response: Response, sunsetDate: string, docUrl: string): Response {
181
+ response.headers.set('Deprecation', 'true');
182
+ response.headers.set('Sunset', sunsetDate); // HTTP date format
183
+ response.headers.set('Link', `<${docUrl}>; rel="sunset"`);
184
+ return response;
185
+ }
186
+
187
+ // Usage
188
+ const response = await handleV1Request(context);
189
+ addDeprecationHeaders(
190
+ response,
191
+ 'Sat, 01 Mar 2026 00:00:00 GMT',
192
+ 'https://docs.example.com/migration/v1-to-v2'
193
+ );
194
+ ```
195
+
196
+ ### Deprecation Timeline
197
+
198
+ | Phase | Duration | Actions |
199
+ |-------|----------|---------|
200
+ | **Announce** | T-6 months | Add `Deprecation: true` header, publish migration guide |
201
+ | **Warn** | T-3 months | Add `Sunset` header with date, send email to consumers |
202
+ | **Monitor** | T-1 month | Track usage, notify active consumers directly |
203
+ | **Sunset** | T-0 | Return 410 Gone with migration link |
204
+ | **Remove** | T+3 months | Remove code (keep tests to prevent regression) |
205
+
206
+ ### Sunset Response
207
+
208
+ ```typescript
209
+ function sunsetResponse(migrationUrl: string): Response {
210
+ return new Response(JSON.stringify({
211
+ type: 'https://api.example.com/problems/gone',
212
+ title: 'API Version Removed',
213
+ status: 410,
214
+ detail: `This API version has been sunset. Please migrate to the latest version.`,
215
+ migrationGuide: migrationUrl,
216
+ }), {
217
+ status: 410,
218
+ headers: {
219
+ 'Content-Type': 'application/problem+json',
220
+ 'Link': `<${migrationUrl}>; rel="successor-version"`,
221
+ },
222
+ });
223
+ }
224
+ ```
225
+
226
+ ---
227
+
228
+ ## Consumer-Driven Contract Testing
229
+
230
+ Consumers define the contract they depend on. The provider runs these contracts in CI to ensure backward compatibility.
231
+
232
+ ```typescript
233
+ // consumer-contracts/model-service.contract.test.ts
234
+ import { describe, it, expect } from 'vitest';
235
+
236
+ describe('Model API Contract (Consumer: Dashboard)', () => {
237
+ it('GET /api/v1/models/:id returns expected shape', async () => {
238
+ const response = await fetch(`${API_URL}/api/v1/models/gpt-4`);
239
+ const data = await response.json();
240
+
241
+ // Consumer only depends on these fields --- adding fields is fine
242
+ expect(data).toMatchObject({
243
+ id: expect.any(String),
244
+ name: expect.any(String),
245
+ provider: expect.any(String),
246
+ });
247
+
248
+ // These fields must exist with these types
249
+ expect(typeof data.id).toBe('string');
250
+ expect(typeof data.name).toBe('string');
251
+ });
252
+
253
+ it('returns 404 for unknown model', async () => {
254
+ const response = await fetch(`${API_URL}/api/v1/models/nonexistent`);
255
+ expect(response.status).toBe(404);
256
+ });
257
+ });
258
+ ```
259
+
260
+ **Provider CI pipeline runs all consumer contracts before deploy:**
261
+ ```yaml
262
+ # .github/workflows/api-deploy.yml
263
+ jobs:
264
+ contract-tests:
265
+ runs-on: ubuntu-latest
266
+ steps:
267
+ - name: Run consumer contracts
268
+ run: pnpm test:contracts
269
+ # Deploy only if contracts pass
270
+ deploy:
271
+ needs: contract-tests
272
+ # ...
273
+ ```
274
+
275
+ ---
276
+
277
+ ## Changelog Automation
278
+
279
+ ### Conventional Commits for API Changes
280
+
281
+ ```
282
+ feat(api): add /api/v1/webhooks endpoint
283
+ fix(api): correct pagination cursor encoding in /api/v1/models
284
+ deprecate(api): mark /api/v1/legacy/search as deprecated
285
+ breaking(api): remove price_per_token field from /api/v2/models response
286
+ ```
287
+
288
+ ### Generated Changelog
289
+
290
+ ```markdown
291
+ ## API Changelog
292
+
293
+ ### v2.3.0 (2026-02-15)
294
+
295
+ #### Added
296
+ - `GET /api/v1/webhooks` - List registered webhooks
297
+ - `POST /api/v1/webhooks` - Register a new webhook
298
+
299
+ #### Deprecated
300
+ - `GET /api/v1/legacy/search` - Use `GET /api/v1/search` instead. Sunset: 2026-08-01.
301
+
302
+ #### Fixed
303
+ - Pagination cursor encoding now handles special characters correctly
304
+
305
+ ### v2.0.0 (2026-01-01)
306
+
307
+ #### Breaking Changes
308
+ - Removed `price_per_token` field from model responses. Use `pricing` object instead.
309
+ - See [migration guide](https://docs.example.com/migration/v1-to-v2).
310
+ ```
311
+
312
+ ---
313
+
314
+ ## Migration Guides
315
+
316
+ Every version bump must include a migration guide that covers:
317
+
318
+ ```markdown
319
+ # Migrating from API v1 to v2
320
+
321
+ ## Timeline
322
+ - **v1 deprecated:** January 1, 2026
323
+ - **v1 sunset:** July 1, 2026
324
+ - **v1 removed:** October 1, 2026
325
+
326
+ ## Breaking Changes
327
+
328
+ ### Model pricing field restructured
329
+
330
+ **Before (v1):**
331
+ ```json
332
+ { "price_per_token": 0.00003 }
333
+ ```
334
+
335
+ **After (v2):**
336
+ ```json
337
+ { "pricing": { "input": 0.00001, "output": 0.00003, "currency": "USD", "unit": "per_million_tokens" } }
338
+ ```
339
+
340
+ **Migration steps:**
341
+ 1. Update your response type definitions
342
+ 2. Replace `model.price_per_token` with `model.pricing.output`
343
+ 3. Test with v2 endpoint
344
+ 4. Update API-Version header to `2`
345
+ ```
346
+
347
+ ---
348
+
349
+ ## Version Routing Middleware
350
+
351
+ ```typescript
352
+ // src/middleware/api-version.ts
353
+ type VersionedHandlers = Record<string, Handler>;
354
+
355
+ export function createVersionedRoute(
356
+ handlers: VersionedHandlers,
357
+ options: {
358
+ defaultVersion?: string;
359
+ deprecated?: Record<string, { sunset: string; migrationUrl: string }>;
360
+ } = {}
361
+ ): Handler {
362
+ const { defaultVersion, deprecated = {} } = options;
363
+
364
+ return async (context) => {
365
+ const version = resolveVersion(context.request) ?? defaultVersion;
366
+
367
+ if (!version) {
368
+ return problemResponse({
369
+ type: 'https://api.example.com/problems/version-required',
370
+ title: 'API Version Required',
371
+ status: 400,
372
+ detail: 'Please specify an API version via the API-Version header.',
373
+ });
374
+ }
375
+
376
+ if (!(version in handlers)) {
377
+ return problemResponse({
378
+ type: 'https://api.example.com/problems/unsupported-version',
379
+ title: 'Unsupported API Version',
380
+ status: 400,
381
+ detail: `Version '${version}' is not supported.`,
382
+ });
383
+ }
384
+
385
+ const response = await handlers[version](context);
386
+ response.headers.set('API-Version', version);
387
+
388
+ // Add deprecation headers if applicable
389
+ if (version in deprecated) {
390
+ const { sunset, migrationUrl } = deprecated[version];
391
+ response.headers.set('Deprecation', 'true');
392
+ response.headers.set('Sunset', sunset);
393
+ response.headers.set('Link', `<${migrationUrl}>; rel="sunset"`);
394
+ }
395
+
396
+ return response;
397
+ };
398
+ }
399
+ ```
400
+
401
+ ---
402
+
403
+ ## Anti-Patterns
404
+
405
+ | Anti-Pattern | Correct Approach |
406
+ |-------------|------------------|
407
+ | Increment version for every change | Version only on breaking changes |
408
+ | Remove old version without notice | Follow deprecation timeline (6+ months) |
409
+ | Different versioning per endpoint | Consistent strategy across the entire API |
410
+ | Version in the response body only | Use URL path or headers --- visible and consistent |
411
+ | No default version behavior | Define and document the default |
412
+ | Breaking change without migration guide | Every breaking change needs a guide |
413
+ | No consumer notification | Email, changelog, and headers all used together |
414
+
415
+ ## References
416
+
417
+ - [RFC 8594: Sunset Header](https://tools.ietf.org/html/rfc8594)
418
+ - [Stripe API Versioning](https://stripe.com/docs/api/versioning)
419
+ - [Microsoft REST API Guidelines: Versioning](https://github.com/microsoft/api-guidelines)
420
+ - [Pact Contract Testing](https://docs.pact.io/)
@@ -0,0 +1,219 @@
1
+ ---
2
+ name: architecture-mapping
3
+ description: Analyzes codebase structure, data flow, module relationships, and key patterns to generate and maintain a living architecture document (ARCHITECTURE.md).
4
+ ---
5
+
6
+ # Architecture Mapping Skill
7
+
8
+ You are an expert software architect acting as a cartographer for the codebase. Your job is to analyze the current state of a repository and produce a "living map" of its architecture.
9
+
10
+ ## Core Responsibilities
11
+
12
+ When invoked, you must:
13
+
14
+ 1. **Analyze structural layout at a granular level:** Identify exactly where specific functionality lives, listing out key files (e.g., `src/api/worker.ts`, specific domain schemas, core components). **Do not just list directories; list the critical files within them**.
15
+ 2. **Trace data flow explicitly:** Determine how information moves through the system down to the exact environment bindings, database connections (e.g., SurrealDB KV bindings, Worker `Env` interfaces), and request interceptors.
16
+ 3. **Map relationships & contracts:** Detail the actual Zod schemas and API routes present in the codebase. If an API worker exists, document its exposed routes, rate limiting, and exact CORS configurations.
17
+ 4. **Extract key patterns:** Identify the architectural decisions and conventions in use, providing exact file references where these patterns are implemented (e.g., CFPA, React Islands).
18
+ 5. **Generate/Update Document:** Write these highly granular findings into a structured `docs/ARCHITECTURE.md` file. Avoid generic boilerplate; if the project only has 3 files, document precisely what those 3 files do.
19
+
20
+ ## Execution Strategy
21
+
22
+ Follow these strictly granular steps to perform an architecture mapping:
23
+
24
+ ### Step 1: Deep Codebase Reconnaissance
25
+ - **Do not just list directories.** Use your file exploration tools (`list_dir`, `view_file_outline`, `grep_search`) to survey the repository, but immediately follow up by reading the *contents* of key files (`view_file`).
26
+ - Identify exact entry points (`src/api/worker.ts`, `src/pages/index.astro`), configuration files (`astro.config.mjs`, `wrangler.toml`), and trace their imports.
27
+ - Locate exact schemas (Zod or TypeScript interfaces) defining the data models.
28
+
29
+ ### Step 2: Component & Contract Analysis
30
+ - Group files logically, but identify the specific files governing these components.
31
+ - For each component, trace its exact Zod schemas, API routes, or React props.
32
+ - Document exact environment variables and secrets expected by the code.
33
+
34
+ ### Step 3: Granular Dependency Tracing
35
+ - Trace exactly how components interact (e.g., "The `login` Astro page fetches data directly from SurrealDB using the `surrealdb.js` client in `src/lib/db.ts`").
36
+ - Explicitly catalog external integrations down to the binding name (e.g., "KVNamespace RATE_LIMITS").
37
+
38
+ ### Step 4: Pattern Extraction
39
+ - Read the implementation details of representative files to prove use of architectural patterns.
40
+ - If the project uses CFPA, locate the schema, the test, and the implementation file as proof.
41
+
42
+ ## 5. Document Generation
43
+ Create or update `docs/ARCHITECTURE.md` using the following structure:
44
+
45
+ ```markdown
46
+ # [Project Name] - Living Architecture Map
47
+
48
+ **Last Updated:** [Current Date]
49
+ **Purpose:** Deep, granular code context, environmental bindings, and exact architectural tracing.
50
+
51
+ ---
52
+
53
+ ## 1. Codebase Topography & Critical Files
54
+
55
+ ### Directory Tree
56
+ (You MUST include a full, comprehensive file/folder tree of the `src/` directory and any other relevant project directories. Do not summarize this; show the actual files.)
57
+ ```text
58
+ /
59
+ ├── src/
60
+ │ ├── api/
61
+ │ │ └── worker.ts
62
+ │ └── ...
63
+ ```
64
+
65
+ ### Critical Files
66
+ (Identify exactly where specific functionality lives, listing out key files defined in the tree above. Do not just list directories; explain what the critical files within them do.)
67
+
68
+ ## 2. Infrastructure & Explicit Data Flow
69
+ (Determine how information moves through the system down to the exact environment bindings, database connections, and request interceptors.)
70
+
71
+ ## 3. Module Relationships & Contracts
72
+ (Detail the actual Zod schemas and API routes present. Document exposed routes, rate limiting, and exact CORS configurations.)
73
+
74
+ ## 4. Key Patterns & Implementation Evidence
75
+ (Identify architectural decisions, providing exact file references where these patterns are implemented.)
76
+ ```
77
+
78
+ ## Best Practices
79
+
80
+ * **Granularity is Mandatory:** Do not describe the system abstractly. Use exact file paths, exact schema names, and exact environment binding names.
81
+ * **Trace the Code:** Never guess architectural boundaries. Use `grep_search` and `view_file` to trace imports and confirm how modules interact before documenting them.
82
+ * **Be Explicit:** Avoid boilerplate. If an API has 3 endpoints, list the 3 endpoints and their exact Zod validation schemas.
83
+ * **Living Document:** If updating an *existing* `ARCHITECTURE.md`, do not simply append. Integrate new, granular findings holistically into the existing structure. Update the "Last Updated" date.
84
+
85
+ ## Domain Boundary Protocol
86
+
87
+ ### Purpose
88
+
89
+ Run this protocol before proposing domain boundaries. Uses a domain inventory record to evaluate every candidate domain.
90
+
91
+ ### Domain Inventory Record Format
92
+
93
+ For each candidate domain, build a record in the following format:
94
+
95
+ ```
96
+ Domain: [name]
97
+ Architecture description: [one-line summary from architecture design]
98
+ Ideation sub-features:
99
+ 1. [Actor] can [goal] → primary data: [entity/table]
100
+ 2. [Actor] can [goal] → primary data: [entity/table]
101
+ ...
102
+ Split trigger: [none | review | mandatory-split]
103
+ ```
104
+
105
+ Read `docs/plans/ideation.md` and the architecture design to build each record.
106
+
107
+ ### Split Trigger Rules
108
+
109
+ Apply all three rules to every domain:
110
+
111
+ 1. **80-line proxy** — If the `ideation.md` section for this domain exceeds ~80 lines of content (features, user stories, acceptance criteria combined), flag as `mandatory-split`.
112
+
113
+ 2. **3-table rule** — If the domain's sub-features touch ≥3 independent database tables with no shared queries, flag as `mandatory-split`.
114
+
115
+ 3. **No-shared-query test** — If two sub-feature groups within a domain could each be assigned to a different developer without coordination (no shared API endpoints, no shared data mutations), flag as `review`.
116
+
117
+ ### Domain Boundary Table Template
118
+
119
+ | # | Domain | Features Included | Sub-feature Count | Complexity | Split Candidate? | Needs Deep Dive? |
120
+ |---|--------|-------------------|-------------------|------------|-----------------|------------------|
121
+ | 00 | Cross-cutting | Auth, API conventions, error handling | — | Medium | — | No |
122
+ | 01 | [Domain] | [Features] | [N] | [Low/Med/High] | [Yes/No — reason] | [Yes/No] |
123
+
124
+ ### User Approval Protocol
125
+
126
+ Present split candidates to the user before finalising the domain boundary table. For each candidate show:
127
+
128
+ - Domain name
129
+ - Sub-feature list
130
+ - Proposed split boundary
131
+ - Rationale
132
+
133
+ User must approve or reject each split before the table is locked.
134
+
135
+ ### Shard Numbering Convention
136
+
137
+ - `00-*` for cross-cutting concerns (may be multiple)
138
+ - `01-*` through `NN-*` for feature domains ordered by dependency (dependencies first)
139
+
140
+ ## Sub-Feature Reconciliation Protocol
141
+
142
+ ### Purpose
143
+
144
+ Run this protocol when beginning any architecture spec shard. `ideation.md` is the primary source of truth for sub-features — the architecture design is secondary context.
145
+
146
+ ### Sources to Read
147
+
148
+ 1. `docs/plans/ideation.md` — the section corresponding to this shard's domain
149
+ 2. The shard's `## Features` section
150
+ 3. `docs/plans/vision.md` Must Have features for this domain
151
+
152
+ ### Reconciliation Table
153
+
154
+ | Sub-feature | ideation.md | Shard ## Features | Must Have? | Decision |
155
+ |-------------|-------------|-------------------|------------|----------|
156
+ | [name] | ✅ Listed | ✅ Listed | Yes/No | Keep |
157
+ | [name] | ✅ Listed | ❌ Missing | Yes | **Add to shard immediately** |
158
+ | [name] | ✅ Listed | ❌ Missing | No | Add to shard — ideation is authoritative |
159
+ | [name] | ❌ Not listed | ✅ Listed | — | `[Architecture-only — not in ideation.md]` — keep but audit |
160
+
161
+ ### Mismatch Handling Rules
162
+
163
+ 1. If a sub-feature appears in `ideation.md` but not in the shard's `## Features` → **add it to the shard's `## Features` section immediately** before proceeding. Do not wait for user confirmation to add ideation-sourced sub-features.
164
+
165
+ 2. If a sub-feature appears in the shard's `## Features` but not in `ideation.md` → **keep it** but mark it with `[Architecture-only — not in ideation.md]` as an audit trail. These items need explicit user confirmation.
166
+
167
+ ### Scope Confirmation Presentation Format
168
+
169
+ Present the reconciled scope to the user in the following format:
170
+
171
+ > **Reconciled features for [Shard NN — Domain Name]:**
172
+ >
173
+ > [bullet list of all sub-features, with `[Architecture-only]` markers where applicable]
174
+ >
175
+ > **[N] sub-features added from ideation.md** that were missing from the shard skeleton.
176
+ > **[M] sub-features marked `[Architecture-only]`** — not found in ideation.md, added during decomposition.
177
+ >
178
+ > "Does this feature list match your intent for this domain? Any sub-features to add, remove, or re-scope?"
179
+
180
+ Wait for explicit user confirmation before proceeding. If the user modifies the list, update the shard file immediately.
181
+
182
+ ## Sub-Feature Complexity Split Protocol
183
+
184
+ ### Purpose
185
+
186
+ Run this protocol after reconciliation when the confirmed sub-feature count is **≥ 10**. This threshold indicates the shard is too complex for a single spec pass and must be split before writing proceeds.
187
+
188
+ ### Counting Rule
189
+
190
+ Count every bullet or named item under the confirmed feature list, excluding group headers. Use the same counting rule as `/decompose-architecture-validate` Step 12.
191
+
192
+ ### Split Proposal Format
193
+
194
+ Present to the user:
195
+
196
+ ```
197
+ Shard [NN] — [domain name] has [N] sub-features (threshold: ≥10 → mandatory split)
198
+
199
+ Current sub-features:
200
+ 1. [sub-feature]
201
+ 2. [sub-feature]
202
+ ...
203
+
204
+ Proposed split:
205
+ [NN]a — [new domain name] → file: docs/plans/ia/[NN]a-[domain].md
206
+ Sub-features: 1, 3, 5
207
+ [NN]b — [new domain name] → file: docs/plans/ia/[NN]b-[domain].md
208
+ Sub-features: 2, 4, 6
209
+
210
+ Split rationale: [why these groups are independent]
211
+
212
+ Does this split make sense, or would you prefer a different boundary?
213
+ ```
214
+
215
+ ### Approval Gate
216
+
217
+ **Wait for explicit user approval of the split before proceeding.** Do NOT continue spec writing with an oversized shard.
218
+
219
+ If the user approves: stop the current workflow and run `/decompose-architecture-validate` to formally register the new shards (it will re-run the Must Have coverage gate and update the decomposition plan). Then restart the spec workflow for each new shard individually.