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,90 @@
1
+ ---
2
+ name: adversarial-review
3
+ description: Structured methodology for adversarial thinking — generating attack scenarios, abuse cases, race conditions, and security edge cases against specs and implementations. Produces spec-level gap items, not code-level fixes.
4
+ ---
5
+
6
+ # Adversarial Review
7
+
8
+ This skill is invoked during spec deepening passes, ambiguity audits, and security review gates, and its output is always spec-level gap items — never code-level fixes.
9
+
10
+ ## When to Use
11
+
12
+ - During `write-architecture-spec-deepen` Pass 3
13
+ - During `audit-ambiguity-execute` Step 3c devil's advocate pass
14
+ - During `remediate-pipeline-execute` adversarial consistency check
15
+ - During `validate-phase` Step 8 security review
16
+ - Before any spec layer audit gate
17
+
18
+ ## Instructions
19
+
20
+ ### 1. Attack Surface Enumeration
21
+
22
+ Systematically enumerate each of the following categories for every feature or endpoint under review. For each category, apply the listed triggering question:
23
+
24
+ - **Authentication bypass**: "What happens if the request arrives with no token, an expired token, or a token for a different service?"
25
+ - **Privilege escalation**: "What happens if a user with role X calls an endpoint intended only for role Y — does the guard exist at the API layer, or only the UI layer?"
26
+ - **Insecure direct object reference (IDOR)**: "What happens if an authenticated user sends a request substituting another user's resource ID?"
27
+ - **Data exfiltration**: "Does any response field expose data about resources the caller did not request?"
28
+ - **Denial-of-service**: "Is this endpoint bounded — are there rate limits, payload size limits, and query result limits specified in the spec?"
29
+ - **Injection points**: "Is every user-supplied string that reaches a query, command, template, or file path validated and sanitized in the spec?"
30
+
31
+ For every category where the spec does not provide an explicit answer, write a `SPEC GAP` item (see Step 5).
32
+
33
+ ### 2. Abuse Scenario Generation Framework
34
+
35
+ For each feature or endpoint, generate all four scenario paths:
36
+
37
+ - **Happy path**: The intended use by a legitimate, competent user.
38
+ - **Malicious actor path**: A deliberate attempt to cause unauthorized access, data corruption, or system disruption.
39
+ - **Incompetent actor path**: An accidental misuse — duplicate submissions, wrong resource IDs, malformed payloads — and whether the spec handles the resulting state gracefully.
40
+ - **Concurrent execution path**: Two or more users executing the same operation simultaneously — does the spec describe the expected outcome, or does it silently assume serial execution?
41
+
42
+ Document the expected behavior for each path. Any path for which the spec does not define expected behavior is a `SPEC GAP`.
43
+
44
+ ### 3. Race Condition and Concurrency Identification
45
+
46
+ For every write operation in the spec, ask "what if two requests arrive simultaneously?" Specifically identify:
47
+
48
+ - Shared mutable state that is read then written in non-atomic operations.
49
+ - Read-modify-write sequences that do not specify a locking or optimistic-concurrency strategy.
50
+ - Time-of-check-to-time-of-use (TOCTOU) windows (e.g., permission check followed by action, not wrapped atomically).
51
+ - Distributed transaction boundaries where partial success is possible and the spec does not define a rollback or compensation behavior.
52
+
53
+ Each identified pattern that is not addressed in the spec is a `SPEC GAP`.
54
+
55
+ ### 4. Boundary Condition Stress-Testing
56
+
57
+ For every input in the spec, verify the spec defines behavior at:
58
+
59
+ - **Empty string / empty collection** (where at least one item is assumed by downstream logic).
60
+ - **Null and undefined** (for every optional field — what does the system do when the field is absent?).
61
+ - **Maximum field length** (what happens when a string hits the character limit?).
62
+ - **Integer overflow and underflow boundaries**.
63
+ - **Negative numbers** where only positives are semantically valid.
64
+ - **Unicode edge cases**: right-to-left characters, zero-width characters, emoji in identifiers.
65
+
66
+ Any boundary for which the spec does not define behavior is a `SPEC GAP`.
67
+
68
+ ### 5. Documenting Findings as Spec-Level Gap Items
69
+
70
+ All findings from Steps 1–4 must be written using this exact format:
71
+
72
+ ```
73
+ SPEC GAP: [layer] § [section] — [what is underspecified] — [attack scenario or failure mode] — [proposed resolution or question for user]
74
+ ```
75
+
76
+ - The **layer** field is one of: `IA`, `BE`, `FE`.
77
+ - The **section** field quotes the heading of the spec section under review.
78
+ - The **proposed resolution** is either a concrete suggestion (if the answer is determinable from `vision.md` or `architecture-design.md`) or a question for the user (if it is a product decision).
79
+
80
+ **Never** write the finding as a code change, a PR comment, or an implementation task.
81
+
82
+ ## Anti-Patterns
83
+
84
+ - **Implementation TODOs instead of spec gaps** — Documenting findings as implementation TODOs rather than spec gap items. The output of this skill is always a spec amendment, never a code fix.
85
+ - **Skipping the concurrent execution path** — Skipping the concurrent execution path because "the feature seems simple." Concurrency issues emerge precisely in features that appear trivial.
86
+ - **Stopping at the happy path** — The malicious, incompetent, and concurrent paths are not optional. All four scenario paths must be generated for every feature and endpoint.
87
+
88
+ ## Related Skills
89
+
90
+ - **`security-scanning-security-hardening`** — Use when transitioning from spec-level gap analysis to implementation-level security hardening. This skill identifies *what is underspecified* at the spec layer; `security-scanning-security-hardening` coordinates *multi-layer scanning and hardening* of the actual codebase and infrastructure after implementation.
@@ -0,0 +1,81 @@
1
+ ---
2
+ name: antigravity-workflows
3
+ description: "Orchestrate multiple Antigravity skills through guided workflows for SaaS MVP delivery, security audits, AI agent builds, and browser QA."
4
+ risk: none
5
+ source: self
6
+ date_added: "2026-02-27"
7
+ ---
8
+
9
+ # Antigravity Workflows
10
+
11
+ Use this skill to turn a complex objective into a guided sequence of skill invocations.
12
+
13
+ ## When to Use This Skill
14
+
15
+ Use this skill when:
16
+ - The user wants to combine several skills without manually selecting each one.
17
+ - The goal is multi-phase (for example: plan, build, test, ship).
18
+ - The user asks for best-practice execution for common scenarios like:
19
+ - Shipping a SaaS MVP
20
+ - Running a web security audit
21
+ - Building an AI agent system
22
+ - Implementing browser automation and E2E QA
23
+
24
+ ## Workflow Source of Truth
25
+
26
+ Read workflows in this order:
27
+ 1. `docs/WORKFLOWS.md` for human-readable playbooks.
28
+ 2. `data/workflows.json` for machine-readable workflow metadata.
29
+
30
+ ## How to Run This Skill
31
+
32
+ 1. Identify the user's concrete outcome.
33
+ 2. Propose the 1-2 best matching workflows.
34
+ 3. Ask the user to choose one.
35
+ 4. Execute step-by-step:
36
+ - Announce current step and expected artifact.
37
+ - Invoke recommended skills for that step.
38
+ - Verify completion criteria before moving to next step.
39
+ 5. At the end, provide:
40
+ - Completed artifacts
41
+ - Validation evidence
42
+ - Remaining risks and next actions
43
+
44
+ ## Default Workflow Routing
45
+
46
+ - Product delivery request -> `ship-saas-mvp`
47
+ - Security review request -> `security-audit-web-app`
48
+ - Agent/LLM product request -> `build-ai-agent-system`
49
+ - E2E/browser testing request -> `qa-browser-automation`
50
+
51
+ ## Copy-Paste Prompts
52
+
53
+ ```text
54
+ Use @antigravity-workflows to run the "Ship a SaaS MVP" workflow for my project idea.
55
+ ```
56
+
57
+ ```text
58
+ Use @antigravity-workflows and execute a full "Security Audit for a Web App" workflow.
59
+ ```
60
+
61
+ ```text
62
+ Use @antigravity-workflows to guide me through "Build an AI Agent System" with checkpoints.
63
+ ```
64
+
65
+ ```text
66
+ Use @antigravity-workflows to execute the "QA and Browser Automation" workflow and stabilize flaky tests.
67
+ ```
68
+
69
+ ## Limitations
70
+
71
+ - This skill orchestrates; it does not replace specialized skills.
72
+ - It depends on the local availability of referenced skills.
73
+ - It does not guarantee success without environment access, credentials, or required infrastructure.
74
+ - For stack-specific browser automation in Go, `go-playwright` may require the corresponding skill to be present in your local skills repository.
75
+
76
+ ## Related Skills
77
+
78
+ - `concise-planning`
79
+ - `brainstorming`
80
+ - `workflow-automation`
81
+ - `verification-before-completion`
@@ -0,0 +1,36 @@
1
+ # Antigravity Workflows Implementation Playbook
2
+
3
+ This document explains how an agent should execute workflow-based orchestration.
4
+
5
+ ## Execution Contract
6
+
7
+ For every workflow:
8
+
9
+ 1. Confirm objective and scope.
10
+ 2. Select the best-matching workflow.
11
+ 3. Execute workflow steps in order.
12
+ 4. Produce one concrete artifact per step.
13
+ 5. Validate before continuing.
14
+
15
+ ## Step Artifact Examples
16
+
17
+ - Plan step -> scope document or milestone checklist.
18
+ - Build step -> code changes and implementation notes.
19
+ - Test step -> test results and failure triage.
20
+ - Release step -> rollout checklist and risk log.
21
+
22
+ ## Safety Guardrails
23
+
24
+ - Never run destructive actions without explicit user approval.
25
+ - If a required skill is missing, state the gap and fallback to closest available skill.
26
+ - When security testing is involved, ensure authorization is explicit.
27
+
28
+ ## Suggested Completion Format
29
+
30
+ At workflow completion, return:
31
+
32
+ 1. Completed steps
33
+ 2. Artifacts produced
34
+ 3. Validation evidence
35
+ 4. Open risks
36
+ 5. Suggested next action
@@ -0,0 +1,37 @@
1
+ ---
2
+ name: api-design-principles
3
+ description: Master REST and GraphQL API design principles to build intuitive, scalable, and maintainable APIs that delight developers. Use when designing new APIs, reviewing API specifications, or establishing API design standards.
4
+ ---
5
+
6
+ # API Design Principles
7
+
8
+ Master REST and GraphQL API design principles to build intuitive, scalable, and maintainable APIs that delight developers and stand the test of time.
9
+
10
+ ## Use this skill when
11
+
12
+ - Designing new REST or GraphQL APIs
13
+ - Refactoring existing APIs for better usability
14
+ - Establishing API design standards for your team
15
+ - Reviewing API specifications before implementation
16
+ - Migrating between API paradigms (REST to GraphQL, etc.)
17
+ - Creating developer-friendly API documentation
18
+ - Optimizing APIs for specific use cases (mobile, third-party integrations)
19
+
20
+ ## Do not use this skill when
21
+
22
+ - You only need implementation guidance for a specific framework
23
+ - You are doing infrastructure-only work without API contracts
24
+ - You cannot change or version public interfaces
25
+
26
+ ## Instructions
27
+
28
+ 1. Define consumers, use cases, and constraints.
29
+ 2. Choose API style and model resources or types.
30
+ 3. Specify errors, versioning, pagination, and auth strategy.
31
+ 4. Validate with examples and review for consistency.
32
+
33
+ Refer to `resources/implementation-playbook.md` for detailed patterns, checklists, and templates.
34
+
35
+ ## Resources
36
+
37
+ - `resources/implementation-playbook.md` for detailed patterns, checklists, and templates.
@@ -0,0 +1,155 @@
1
+ # API Design Checklist
2
+
3
+ ## Pre-Implementation Review
4
+
5
+ ### Resource Design
6
+
7
+ - [ ] Resources are nouns, not verbs
8
+ - [ ] Plural names for collections
9
+ - [ ] Consistent naming across all endpoints
10
+ - [ ] Clear resource hierarchy (avoid deep nesting >2 levels)
11
+ - [ ] All CRUD operations properly mapped to HTTP methods
12
+
13
+ ### HTTP Methods
14
+
15
+ - [ ] GET for retrieval (safe, idempotent)
16
+ - [ ] POST for creation
17
+ - [ ] PUT for full replacement (idempotent)
18
+ - [ ] PATCH for partial updates
19
+ - [ ] DELETE for removal (idempotent)
20
+
21
+ ### Status Codes
22
+
23
+ - [ ] 200 OK for successful GET/PATCH/PUT
24
+ - [ ] 201 Created for POST
25
+ - [ ] 204 No Content for DELETE
26
+ - [ ] 400 Bad Request for malformed requests
27
+ - [ ] 401 Unauthorized for missing auth
28
+ - [ ] 403 Forbidden for insufficient permissions
29
+ - [ ] 404 Not Found for missing resources
30
+ - [ ] 422 Unprocessable Entity for validation errors
31
+ - [ ] 429 Too Many Requests for rate limiting
32
+ - [ ] 500 Internal Server Error for server issues
33
+
34
+ ### Pagination
35
+
36
+ - [ ] All collection endpoints paginated
37
+ - [ ] Default page size defined (e.g., 20)
38
+ - [ ] Maximum page size enforced (e.g., 100)
39
+ - [ ] Pagination metadata included (total, pages, etc.)
40
+ - [ ] Cursor-based or offset-based pattern chosen
41
+
42
+ ### Filtering & Sorting
43
+
44
+ - [ ] Query parameters for filtering
45
+ - [ ] Sort parameter supported
46
+ - [ ] Search parameter for full-text search
47
+ - [ ] Field selection supported (sparse fieldsets)
48
+
49
+ ### Versioning
50
+
51
+ - [ ] Versioning strategy defined (URL/header/query)
52
+ - [ ] Version included in all endpoints
53
+ - [ ] Deprecation policy documented
54
+
55
+ ### Error Handling
56
+
57
+ - [ ] Consistent error response format
58
+ - [ ] Detailed error messages
59
+ - [ ] Field-level validation errors
60
+ - [ ] Error codes for client handling
61
+ - [ ] Timestamps in error responses
62
+
63
+ ### Authentication & Authorization
64
+
65
+ - [ ] Authentication method defined (Bearer token, API key)
66
+ - [ ] Authorization checks on all endpoints
67
+ - [ ] 401 vs 403 used correctly
68
+ - [ ] Token expiration handled
69
+
70
+ ### Rate Limiting
71
+
72
+ - [ ] Rate limits defined per endpoint/user
73
+ - [ ] Rate limit headers included
74
+ - [ ] 429 status code for exceeded limits
75
+ - [ ] Retry-After header provided
76
+
77
+ ### Documentation
78
+
79
+ - [ ] OpenAPI/Swagger spec generated
80
+ - [ ] All endpoints documented
81
+ - [ ] Request/response examples provided
82
+ - [ ] Error responses documented
83
+ - [ ] Authentication flow documented
84
+
85
+ ### Testing
86
+
87
+ - [ ] Unit tests for business logic
88
+ - [ ] Integration tests for endpoints
89
+ - [ ] Error scenarios tested
90
+ - [ ] Edge cases covered
91
+ - [ ] Performance tests for heavy endpoints
92
+
93
+ ### Security
94
+
95
+ - [ ] Input validation on all fields
96
+ - [ ] SQL injection prevention
97
+ - [ ] XSS prevention
98
+ - [ ] CORS configured correctly
99
+ - [ ] HTTPS enforced
100
+ - [ ] Sensitive data not in URLs
101
+ - [ ] No secrets in responses
102
+
103
+ ### Performance
104
+
105
+ - [ ] Database queries optimized
106
+ - [ ] N+1 queries prevented
107
+ - [ ] Caching strategy defined
108
+ - [ ] Cache headers set appropriately
109
+ - [ ] Large responses paginated
110
+
111
+ ### Monitoring
112
+
113
+ - [ ] Logging implemented
114
+ - [ ] Error tracking configured
115
+ - [ ] Performance metrics collected
116
+ - [ ] Health check endpoint available
117
+ - [ ] Alerts configured for errors
118
+
119
+ ## GraphQL-Specific Checks
120
+
121
+ ### Schema Design
122
+
123
+ - [ ] Schema-first approach used
124
+ - [ ] Types properly defined
125
+ - [ ] Non-null vs nullable decided
126
+ - [ ] Interfaces/unions used appropriately
127
+ - [ ] Custom scalars defined
128
+
129
+ ### Queries
130
+
131
+ - [ ] Query depth limiting
132
+ - [ ] Query complexity analysis
133
+ - [ ] DataLoaders prevent N+1
134
+ - [ ] Pagination pattern chosen (Relay/offset)
135
+
136
+ ### Mutations
137
+
138
+ - [ ] Input types defined
139
+ - [ ] Payload types with errors
140
+ - [ ] Optimistic response support
141
+ - [ ] Idempotency considered
142
+
143
+ ### Performance
144
+
145
+ - [ ] DataLoader for all relationships
146
+ - [ ] Query batching enabled
147
+ - [ ] Persisted queries considered
148
+ - [ ] Response caching implemented
149
+
150
+ ### Documentation
151
+
152
+ - [ ] All fields documented
153
+ - [ ] Deprecations marked
154
+ - [ ] Examples provided
155
+ - [ ] Schema introspection enabled
@@ -0,0 +1,182 @@
1
+ """
2
+ Production-ready REST API template using FastAPI.
3
+ Includes pagination, filtering, error handling, and best practices.
4
+ """
5
+
6
+ from fastapi import FastAPI, HTTPException, Query, Path, Depends, status
7
+ from fastapi.middleware.cors import CORSMiddleware
8
+ from fastapi.middleware.trustedhost import TrustedHostMiddleware
9
+ from fastapi.responses import JSONResponse
10
+ from pydantic import BaseModel, Field, EmailStr, ConfigDict
11
+ from typing import Optional, List, Any
12
+ from datetime import datetime
13
+ from enum import Enum
14
+
15
+ app = FastAPI(
16
+ title="API Template",
17
+ version="1.0.0",
18
+ docs_url="/api/docs"
19
+ )
20
+
21
+ # Security Middleware
22
+ # Trusted Host: Prevents HTTP Host Header attacks
23
+ app.add_middleware(
24
+ TrustedHostMiddleware,
25
+ allowed_hosts=["*"] # TODO: Configure this in production, e.g. ["api.example.com"]
26
+ )
27
+
28
+ # CORS: Configures Cross-Origin Resource Sharing
29
+ app.add_middleware(
30
+ CORSMiddleware,
31
+ allow_origins=["*"], # TODO: Update this with specific origins in production
32
+ allow_credentials=False, # TODO: Set to True if you need cookies/auth headers, but restrict origins
33
+ allow_methods=["*"],
34
+ allow_headers=["*"],
35
+ )
36
+
37
+ # Models
38
+ class UserStatus(str, Enum):
39
+ ACTIVE = "active"
40
+ INACTIVE = "inactive"
41
+ SUSPENDED = "suspended"
42
+
43
+ class UserBase(BaseModel):
44
+ email: EmailStr
45
+ name: str = Field(..., min_length=1, max_length=100)
46
+ status: UserStatus = UserStatus.ACTIVE
47
+
48
+ class UserCreate(UserBase):
49
+ password: str = Field(..., min_length=8)
50
+
51
+ class UserUpdate(BaseModel):
52
+ email: Optional[EmailStr] = None
53
+ name: Optional[str] = Field(None, min_length=1, max_length=100)
54
+ status: Optional[UserStatus] = None
55
+
56
+ class User(UserBase):
57
+ id: str
58
+ created_at: datetime
59
+ updated_at: datetime
60
+
61
+ model_config = ConfigDict(from_attributes=True)
62
+
63
+ # Pagination
64
+ class PaginationParams(BaseModel):
65
+ page: int = Field(1, ge=1)
66
+ page_size: int = Field(20, ge=1, le=100)
67
+
68
+ class PaginatedResponse(BaseModel):
69
+ items: List[Any]
70
+ total: int
71
+ page: int
72
+ page_size: int
73
+ pages: int
74
+
75
+ # Error handling
76
+ class ErrorDetail(BaseModel):
77
+ field: Optional[str] = None
78
+ message: str
79
+ code: str
80
+
81
+ class ErrorResponse(BaseModel):
82
+ error: str
83
+ message: str
84
+ details: Optional[List[ErrorDetail]] = None
85
+
86
+ @app.exception_handler(HTTPException)
87
+ async def http_exception_handler(request, exc):
88
+ return JSONResponse(
89
+ status_code=exc.status_code,
90
+ content=ErrorResponse(
91
+ error=exc.__class__.__name__,
92
+ message=exc.detail if isinstance(exc.detail, str) else exc.detail.get("message", "Error"),
93
+ details=exc.detail.get("details") if isinstance(exc.detail, dict) else None
94
+ ).model_dump()
95
+ )
96
+
97
+ # Endpoints
98
+ @app.get("/api/users", response_model=PaginatedResponse, tags=["Users"])
99
+ async def list_users(
100
+ page: int = Query(1, ge=1),
101
+ page_size: int = Query(20, ge=1, le=100),
102
+ status: Optional[UserStatus] = Query(None),
103
+ search: Optional[str] = Query(None)
104
+ ):
105
+ """List users with pagination and filtering."""
106
+ # Mock implementation
107
+ total = 100
108
+ items = [
109
+ User(
110
+ id=str(i),
111
+ email=f"user{i}@example.com",
112
+ name=f"User {i}",
113
+ status=UserStatus.ACTIVE,
114
+ created_at=datetime.now(),
115
+ updated_at=datetime.now()
116
+ ).model_dump()
117
+ for i in range((page-1)*page_size, min(page*page_size, total))
118
+ ]
119
+
120
+ return PaginatedResponse(
121
+ items=items,
122
+ total=total,
123
+ page=page,
124
+ page_size=page_size,
125
+ pages=(total + page_size - 1) // page_size
126
+ )
127
+
128
+ @app.post("/api/users", response_model=User, status_code=status.HTTP_201_CREATED, tags=["Users"])
129
+ async def create_user(user: UserCreate):
130
+ """Create a new user."""
131
+ # Mock implementation
132
+ return User(
133
+ id="123",
134
+ email=user.email,
135
+ name=user.name,
136
+ status=user.status,
137
+ created_at=datetime.now(),
138
+ updated_at=datetime.now()
139
+ )
140
+
141
+ @app.get("/api/users/{user_id}", response_model=User, tags=["Users"])
142
+ async def get_user(user_id: str = Path(..., description="User ID")):
143
+ """Get user by ID."""
144
+ # Mock: Check if exists
145
+ if user_id == "999":
146
+ raise HTTPException(
147
+ status_code=status.HTTP_404_NOT_FOUND,
148
+ detail={"message": "User not found", "details": {"id": user_id}}
149
+ )
150
+
151
+ return User(
152
+ id=user_id,
153
+ email="user@example.com",
154
+ name="User Name",
155
+ status=UserStatus.ACTIVE,
156
+ created_at=datetime.now(),
157
+ updated_at=datetime.now()
158
+ )
159
+
160
+ @app.patch("/api/users/{user_id}", response_model=User, tags=["Users"])
161
+ async def update_user(user_id: str, update: UserUpdate):
162
+ """Partially update user."""
163
+ # Validate user exists
164
+ existing = await get_user(user_id)
165
+
166
+ # Apply updates
167
+ update_data = update.model_dump(exclude_unset=True)
168
+ for field, value in update_data.items():
169
+ setattr(existing, field, value)
170
+
171
+ existing.updated_at = datetime.now()
172
+ return existing
173
+
174
+ @app.delete("/api/users/{user_id}", status_code=status.HTTP_204_NO_CONTENT, tags=["Users"])
175
+ async def delete_user(user_id: str):
176
+ """Delete user."""
177
+ await get_user(user_id) # Verify exists
178
+ return None
179
+
180
+ if __name__ == "__main__":
181
+ import uvicorn
182
+ uvicorn.run(app, host="0.0.0.0", port=8000)