create-apppaaaul 2.0.46 → 2.0.48

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 (215) hide show
  1. package/dist/templates/nextjs-ts-clean/project/.agents/skills/api-design-principles/SKILL.md +528 -0
  2. package/dist/templates/nextjs-ts-clean/project/.agents/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  3. package/dist/templates/nextjs-ts-clean/project/.agents/skills/api-design-principles/assets/rest-api-template.py +182 -0
  4. package/dist/templates/nextjs-ts-clean/project/.agents/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  5. package/dist/templates/nextjs-ts-clean/project/.agents/skills/api-design-principles/references/rest-best-practices.md +408 -0
  6. package/dist/templates/nextjs-ts-clean/project/.agents/skills/better-auth-best-practices/SKILL.md +166 -0
  7. package/dist/templates/nextjs-ts-clean/project/.agents/skills/brainstorming/SKILL.md +96 -0
  8. package/dist/templates/nextjs-ts-clean/project/.agents/skills/changelog-generator/SKILL.md +104 -0
  9. package/dist/templates/nextjs-ts-clean/project/.agents/skills/error-handling-patterns/SKILL.md +641 -0
  10. package/dist/templates/nextjs-ts-clean/project/.agents/skills/interface-design/SKILL.md +391 -0
  11. package/dist/templates/nextjs-ts-clean/project/.agents/skills/interface-design/references/critique.md +67 -0
  12. package/dist/templates/nextjs-ts-clean/project/.agents/skills/interface-design/references/example.md +86 -0
  13. package/dist/templates/nextjs-ts-clean/project/.agents/skills/interface-design/references/principles.md +235 -0
  14. package/dist/templates/nextjs-ts-clean/project/.agents/skills/interface-design/references/validation.md +48 -0
  15. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/SKILL.md +153 -0
  16. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/async-patterns.md +87 -0
  17. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/bundling.md +180 -0
  18. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/data-patterns.md +297 -0
  19. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/debug-tricks.md +105 -0
  20. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/directives.md +73 -0
  21. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/error-handling.md +227 -0
  22. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/file-conventions.md +140 -0
  23. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/font.md +245 -0
  24. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/functions.md +108 -0
  25. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/hydration-error.md +91 -0
  26. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/image.md +173 -0
  27. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/metadata.md +301 -0
  28. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/parallel-routes.md +287 -0
  29. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/route-handlers.md +146 -0
  30. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/rsc-boundaries.md +159 -0
  31. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/runtime-selection.md +39 -0
  32. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/scripts.md +141 -0
  33. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/self-hosting.md +371 -0
  34. package/dist/templates/nextjs-ts-clean/project/.agents/skills/next-best-practices/suspense-boundaries.md +67 -0
  35. package/dist/templates/nextjs-ts-clean/project/.agents/skills/postgresql-table-design/SKILL.md +202 -0
  36. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/SKILL.md +480 -0
  37. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  38. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/assets/prompt-template-library.md +264 -0
  39. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/references/chain-of-thought.md +412 -0
  40. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/references/few-shot-learning.md +386 -0
  41. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/references/prompt-optimization.md +428 -0
  42. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/references/prompt-templates.md +484 -0
  43. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/references/system-prompts.md +195 -0
  44. package/dist/templates/nextjs-ts-clean/project/.agents/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  45. package/dist/templates/nextjs-ts-clean/project/.agents/skills/seo-audit/SKILL.md +410 -0
  46. package/dist/templates/nextjs-ts-clean/project/.agents/skills/seo-audit/references/aeo-geo-patterns.md +285 -0
  47. package/dist/templates/nextjs-ts-clean/project/.agents/skills/seo-audit/references/ai-writing-detection.md +200 -0
  48. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/AGENTS.md +2934 -0
  49. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/SKILL.md +136 -0
  50. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  51. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
  52. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
  53. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
  54. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
  55. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
  56. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
  57. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  58. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
  59. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
  60. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
  61. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  62. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
  63. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
  64. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
  65. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  66. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  67. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
  68. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  69. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  70. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
  71. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  72. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  73. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  74. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  75. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
  76. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  77. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  78. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  79. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  80. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  81. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
  82. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  83. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  84. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  85. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  86. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  87. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  88. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  89. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  90. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  91. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  92. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
  93. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  94. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  95. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  96. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  97. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  98. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  99. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  100. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  101. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
  102. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  103. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  104. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
  105. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  106. package/dist/templates/nextjs-ts-clean/project/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
  107. package/dist/templates/nextjs-ts-clean/project/package.json +1 -1
  108. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/api-design-principles/SKILL.md +528 -0
  109. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  110. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/api-design-principles/assets/rest-api-template.py +182 -0
  111. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  112. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/api-design-principles/references/rest-best-practices.md +408 -0
  113. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/better-auth-best-practices/SKILL.md +166 -0
  114. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/brainstorming/SKILL.md +96 -0
  115. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/changelog-generator/SKILL.md +104 -0
  116. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/error-handling-patterns/SKILL.md +641 -0
  117. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/interface-design/SKILL.md +391 -0
  118. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/interface-design/references/critique.md +67 -0
  119. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/interface-design/references/example.md +86 -0
  120. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/interface-design/references/principles.md +235 -0
  121. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/interface-design/references/validation.md +48 -0
  122. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/SKILL.md +153 -0
  123. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/async-patterns.md +87 -0
  124. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/bundling.md +180 -0
  125. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/data-patterns.md +297 -0
  126. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/debug-tricks.md +105 -0
  127. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/directives.md +73 -0
  128. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/error-handling.md +227 -0
  129. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/file-conventions.md +140 -0
  130. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/font.md +245 -0
  131. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/functions.md +108 -0
  132. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/hydration-error.md +91 -0
  133. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/image.md +173 -0
  134. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/metadata.md +301 -0
  135. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/parallel-routes.md +287 -0
  136. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/route-handlers.md +146 -0
  137. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/rsc-boundaries.md +159 -0
  138. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/runtime-selection.md +39 -0
  139. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/scripts.md +141 -0
  140. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/self-hosting.md +371 -0
  141. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/next-best-practices/suspense-boundaries.md +67 -0
  142. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/postgresql-table-design/SKILL.md +202 -0
  143. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/SKILL.md +480 -0
  144. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  145. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/assets/prompt-template-library.md +264 -0
  146. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/references/chain-of-thought.md +412 -0
  147. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/references/few-shot-learning.md +386 -0
  148. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/references/prompt-optimization.md +428 -0
  149. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/references/prompt-templates.md +484 -0
  150. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/references/system-prompts.md +195 -0
  151. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  152. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/seo-audit/SKILL.md +410 -0
  153. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/seo-audit/references/aeo-geo-patterns.md +285 -0
  154. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/seo-audit/references/ai-writing-detection.md +200 -0
  155. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/AGENTS.md +2934 -0
  156. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/SKILL.md +136 -0
  157. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  158. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/advanced-init-once.md +42 -0
  159. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/advanced-use-latest.md +39 -0
  160. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/async-api-routes.md +38 -0
  161. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
  162. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/async-dependencies.md +51 -0
  163. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/async-parallel.md +28 -0
  164. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  165. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
  166. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/bundle-conditional.md +31 -0
  167. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +49 -0
  168. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +35 -0
  169. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/bundle-preload.md +50 -0
  170. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/client-event-listeners.md +74 -0
  171. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +71 -0
  172. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  173. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  174. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +107 -0
  175. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  176. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  177. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-cache-storage.md +70 -0
  178. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  179. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  180. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  181. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  182. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-length-check-first.md +49 -0
  183. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  184. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  185. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  186. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  187. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +47 -0
  188. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +40 -0
  189. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  190. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +46 -0
  191. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +82 -0
  192. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-hydration-suppress-warning.md +30 -0
  193. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  194. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rendering-usetransition-loading.md +75 -0
  195. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  196. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  197. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state-no-effect.md +40 -0
  198. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  199. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +74 -0
  200. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +58 -0
  201. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-memo-with-default-value.md +38 -0
  202. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  203. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-move-effect-to-event.md +45 -0
  204. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-simple-expression-in-memo.md +35 -0
  205. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  206. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/rerender-use-ref-transient-values.md +73 -0
  207. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  208. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-auth-actions.md +96 -0
  209. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  210. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  211. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-dedup-props.md +65 -0
  212. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  213. package/dist/templates/nextjs-ts-landing-prisma/project/.agents/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
  214. package/dist/templates/nextjs-ts-landing-prisma/project/package.json +1 -1
  215. package/package.json +1 -1
@@ -0,0 +1,528 @@
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
+ ## When to Use This Skill
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
+ ## Core Concepts
21
+
22
+ ### 1. RESTful Design Principles
23
+
24
+ **Resource-Oriented Architecture**
25
+
26
+ - Resources are nouns (users, orders, products), not verbs
27
+ - Use HTTP methods for actions (GET, POST, PUT, PATCH, DELETE)
28
+ - URLs represent resource hierarchies
29
+ - Consistent naming conventions
30
+
31
+ **HTTP Methods Semantics:**
32
+
33
+ - `GET`: Retrieve resources (idempotent, safe)
34
+ - `POST`: Create new resources
35
+ - `PUT`: Replace entire resource (idempotent)
36
+ - `PATCH`: Partial resource updates
37
+ - `DELETE`: Remove resources (idempotent)
38
+
39
+ ### 2. GraphQL Design Principles
40
+
41
+ **Schema-First Development**
42
+
43
+ - Types define your domain model
44
+ - Queries for reading data
45
+ - Mutations for modifying data
46
+ - Subscriptions for real-time updates
47
+
48
+ **Query Structure:**
49
+
50
+ - Clients request exactly what they need
51
+ - Single endpoint, multiple operations
52
+ - Strongly typed schema
53
+ - Introspection built-in
54
+
55
+ ### 3. API Versioning Strategies
56
+
57
+ **URL Versioning:**
58
+
59
+ ```
60
+ /api/v1/users
61
+ /api/v2/users
62
+ ```
63
+
64
+ **Header Versioning:**
65
+
66
+ ```
67
+ Accept: application/vnd.api+json; version=1
68
+ ```
69
+
70
+ **Query Parameter Versioning:**
71
+
72
+ ```
73
+ /api/users?version=1
74
+ ```
75
+
76
+ ## REST API Design Patterns
77
+
78
+ ### Pattern 1: Resource Collection Design
79
+
80
+ ```python
81
+ # Good: Resource-oriented endpoints
82
+ GET /api/users # List users (with pagination)
83
+ POST /api/users # Create user
84
+ GET /api/users/{id} # Get specific user
85
+ PUT /api/users/{id} # Replace user
86
+ PATCH /api/users/{id} # Update user fields
87
+ DELETE /api/users/{id} # Delete user
88
+
89
+ # Nested resources
90
+ GET /api/users/{id}/orders # Get user's orders
91
+ POST /api/users/{id}/orders # Create order for user
92
+
93
+ # Bad: Action-oriented endpoints (avoid)
94
+ POST /api/createUser
95
+ POST /api/getUserById
96
+ POST /api/deleteUser
97
+ ```
98
+
99
+ ### Pattern 2: Pagination and Filtering
100
+
101
+ ```python
102
+ from typing import List, Optional
103
+ from pydantic import BaseModel, Field
104
+
105
+ class PaginationParams(BaseModel):
106
+ page: int = Field(1, ge=1, description="Page number")
107
+ page_size: int = Field(20, ge=1, le=100, description="Items per page")
108
+
109
+ class FilterParams(BaseModel):
110
+ status: Optional[str] = None
111
+ created_after: Optional[str] = None
112
+ search: Optional[str] = None
113
+
114
+ class PaginatedResponse(BaseModel):
115
+ items: List[dict]
116
+ total: int
117
+ page: int
118
+ page_size: int
119
+ pages: int
120
+
121
+ @property
122
+ def has_next(self) -> bool:
123
+ return self.page < self.pages
124
+
125
+ @property
126
+ def has_prev(self) -> bool:
127
+ return self.page > 1
128
+
129
+ # FastAPI endpoint example
130
+ from fastapi import FastAPI, Query, Depends
131
+
132
+ app = FastAPI()
133
+
134
+ @app.get("/api/users", response_model=PaginatedResponse)
135
+ async def list_users(
136
+ page: int = Query(1, ge=1),
137
+ page_size: int = Query(20, ge=1, le=100),
138
+ status: Optional[str] = Query(None),
139
+ search: Optional[str] = Query(None)
140
+ ):
141
+ # Apply filters
142
+ query = build_query(status=status, search=search)
143
+
144
+ # Count total
145
+ total = await count_users(query)
146
+
147
+ # Fetch page
148
+ offset = (page - 1) * page_size
149
+ users = await fetch_users(query, limit=page_size, offset=offset)
150
+
151
+ return PaginatedResponse(
152
+ items=users,
153
+ total=total,
154
+ page=page,
155
+ page_size=page_size,
156
+ pages=(total + page_size - 1) // page_size
157
+ )
158
+ ```
159
+
160
+ ### Pattern 3: Error Handling and Status Codes
161
+
162
+ ```python
163
+ from fastapi import HTTPException, status
164
+ from pydantic import BaseModel
165
+
166
+ class ErrorResponse(BaseModel):
167
+ error: str
168
+ message: str
169
+ details: Optional[dict] = None
170
+ timestamp: str
171
+ path: str
172
+
173
+ class ValidationErrorDetail(BaseModel):
174
+ field: str
175
+ message: str
176
+ value: Any
177
+
178
+ # Consistent error responses
179
+ STATUS_CODES = {
180
+ "success": 200,
181
+ "created": 201,
182
+ "no_content": 204,
183
+ "bad_request": 400,
184
+ "unauthorized": 401,
185
+ "forbidden": 403,
186
+ "not_found": 404,
187
+ "conflict": 409,
188
+ "unprocessable": 422,
189
+ "internal_error": 500
190
+ }
191
+
192
+ def raise_not_found(resource: str, id: str):
193
+ raise HTTPException(
194
+ status_code=status.HTTP_404_NOT_FOUND,
195
+ detail={
196
+ "error": "NotFound",
197
+ "message": f"{resource} not found",
198
+ "details": {"id": id}
199
+ }
200
+ )
201
+
202
+ def raise_validation_error(errors: List[ValidationErrorDetail]):
203
+ raise HTTPException(
204
+ status_code=status.HTTP_422_UNPROCESSABLE_ENTITY,
205
+ detail={
206
+ "error": "ValidationError",
207
+ "message": "Request validation failed",
208
+ "details": {"errors": [e.dict() for e in errors]}
209
+ }
210
+ )
211
+
212
+ # Example usage
213
+ @app.get("/api/users/{user_id}")
214
+ async def get_user(user_id: str):
215
+ user = await fetch_user(user_id)
216
+ if not user:
217
+ raise_not_found("User", user_id)
218
+ return user
219
+ ```
220
+
221
+ ### Pattern 4: HATEOAS (Hypermedia as the Engine of Application State)
222
+
223
+ ```python
224
+ class UserResponse(BaseModel):
225
+ id: str
226
+ name: str
227
+ email: str
228
+ _links: dict
229
+
230
+ @classmethod
231
+ def from_user(cls, user: User, base_url: str):
232
+ return cls(
233
+ id=user.id,
234
+ name=user.name,
235
+ email=user.email,
236
+ _links={
237
+ "self": {"href": f"{base_url}/api/users/{user.id}"},
238
+ "orders": {"href": f"{base_url}/api/users/{user.id}/orders"},
239
+ "update": {
240
+ "href": f"{base_url}/api/users/{user.id}",
241
+ "method": "PATCH"
242
+ },
243
+ "delete": {
244
+ "href": f"{base_url}/api/users/{user.id}",
245
+ "method": "DELETE"
246
+ }
247
+ }
248
+ )
249
+ ```
250
+
251
+ ## GraphQL Design Patterns
252
+
253
+ ### Pattern 1: Schema Design
254
+
255
+ ```graphql
256
+ # schema.graphql
257
+
258
+ # Clear type definitions
259
+ type User {
260
+ id: ID!
261
+ email: String!
262
+ name: String!
263
+ createdAt: DateTime!
264
+
265
+ # Relationships
266
+ orders(first: Int = 20, after: String, status: OrderStatus): OrderConnection!
267
+
268
+ profile: UserProfile
269
+ }
270
+
271
+ type Order {
272
+ id: ID!
273
+ status: OrderStatus!
274
+ total: Money!
275
+ items: [OrderItem!]!
276
+ createdAt: DateTime!
277
+
278
+ # Back-reference
279
+ user: User!
280
+ }
281
+
282
+ # Pagination pattern (Relay-style)
283
+ type OrderConnection {
284
+ edges: [OrderEdge!]!
285
+ pageInfo: PageInfo!
286
+ totalCount: Int!
287
+ }
288
+
289
+ type OrderEdge {
290
+ node: Order!
291
+ cursor: String!
292
+ }
293
+
294
+ type PageInfo {
295
+ hasNextPage: Boolean!
296
+ hasPreviousPage: Boolean!
297
+ startCursor: String
298
+ endCursor: String
299
+ }
300
+
301
+ # Enums for type safety
302
+ enum OrderStatus {
303
+ PENDING
304
+ CONFIRMED
305
+ SHIPPED
306
+ DELIVERED
307
+ CANCELLED
308
+ }
309
+
310
+ # Custom scalars
311
+ scalar DateTime
312
+ scalar Money
313
+
314
+ # Query root
315
+ type Query {
316
+ user(id: ID!): User
317
+ users(first: Int = 20, after: String, search: String): UserConnection!
318
+
319
+ order(id: ID!): Order
320
+ }
321
+
322
+ # Mutation root
323
+ type Mutation {
324
+ createUser(input: CreateUserInput!): CreateUserPayload!
325
+ updateUser(input: UpdateUserInput!): UpdateUserPayload!
326
+ deleteUser(id: ID!): DeleteUserPayload!
327
+
328
+ createOrder(input: CreateOrderInput!): CreateOrderPayload!
329
+ }
330
+
331
+ # Input types for mutations
332
+ input CreateUserInput {
333
+ email: String!
334
+ name: String!
335
+ password: String!
336
+ }
337
+
338
+ # Payload types for mutations
339
+ type CreateUserPayload {
340
+ user: User
341
+ errors: [Error!]
342
+ }
343
+
344
+ type Error {
345
+ field: String
346
+ message: String!
347
+ }
348
+ ```
349
+
350
+ ### Pattern 2: Resolver Design
351
+
352
+ ```python
353
+ from typing import Optional, List
354
+ from ariadne import QueryType, MutationType, ObjectType
355
+ from dataclasses import dataclass
356
+
357
+ query = QueryType()
358
+ mutation = MutationType()
359
+ user_type = ObjectType("User")
360
+
361
+ @query.field("user")
362
+ async def resolve_user(obj, info, id: str) -> Optional[dict]:
363
+ """Resolve single user by ID."""
364
+ return await fetch_user_by_id(id)
365
+
366
+ @query.field("users")
367
+ async def resolve_users(
368
+ obj,
369
+ info,
370
+ first: int = 20,
371
+ after: Optional[str] = None,
372
+ search: Optional[str] = None
373
+ ) -> dict:
374
+ """Resolve paginated user list."""
375
+ # Decode cursor
376
+ offset = decode_cursor(after) if after else 0
377
+
378
+ # Fetch users
379
+ users = await fetch_users(
380
+ limit=first + 1, # Fetch one extra to check hasNextPage
381
+ offset=offset,
382
+ search=search
383
+ )
384
+
385
+ # Pagination
386
+ has_next = len(users) > first
387
+ if has_next:
388
+ users = users[:first]
389
+
390
+ edges = [
391
+ {
392
+ "node": user,
393
+ "cursor": encode_cursor(offset + i)
394
+ }
395
+ for i, user in enumerate(users)
396
+ ]
397
+
398
+ return {
399
+ "edges": edges,
400
+ "pageInfo": {
401
+ "hasNextPage": has_next,
402
+ "hasPreviousPage": offset > 0,
403
+ "startCursor": edges[0]["cursor"] if edges else None,
404
+ "endCursor": edges[-1]["cursor"] if edges else None
405
+ },
406
+ "totalCount": await count_users(search=search)
407
+ }
408
+
409
+ @user_type.field("orders")
410
+ async def resolve_user_orders(user: dict, info, first: int = 20) -> dict:
411
+ """Resolve user's orders (N+1 prevention with DataLoader)."""
412
+ # Use DataLoader to batch requests
413
+ loader = info.context["loaders"]["orders_by_user"]
414
+ orders = await loader.load(user["id"])
415
+
416
+ return paginate_orders(orders, first)
417
+
418
+ @mutation.field("createUser")
419
+ async def resolve_create_user(obj, info, input: dict) -> dict:
420
+ """Create new user."""
421
+ try:
422
+ # Validate input
423
+ validate_user_input(input)
424
+
425
+ # Create user
426
+ user = await create_user(
427
+ email=input["email"],
428
+ name=input["name"],
429
+ password=hash_password(input["password"])
430
+ )
431
+
432
+ return {
433
+ "user": user,
434
+ "errors": []
435
+ }
436
+ except ValidationError as e:
437
+ return {
438
+ "user": None,
439
+ "errors": [{"field": e.field, "message": e.message}]
440
+ }
441
+ ```
442
+
443
+ ### Pattern 3: DataLoader (N+1 Problem Prevention)
444
+
445
+ ```python
446
+ from aiodataloader import DataLoader
447
+ from typing import List, Optional
448
+
449
+ class UserLoader(DataLoader):
450
+ """Batch load users by ID."""
451
+
452
+ async def batch_load_fn(self, user_ids: List[str]) -> List[Optional[dict]]:
453
+ """Load multiple users in single query."""
454
+ users = await fetch_users_by_ids(user_ids)
455
+
456
+ # Map results back to input order
457
+ user_map = {user["id"]: user for user in users}
458
+ return [user_map.get(user_id) for user_id in user_ids]
459
+
460
+ class OrdersByUserLoader(DataLoader):
461
+ """Batch load orders by user ID."""
462
+
463
+ async def batch_load_fn(self, user_ids: List[str]) -> List[List[dict]]:
464
+ """Load orders for multiple users in single query."""
465
+ orders = await fetch_orders_by_user_ids(user_ids)
466
+
467
+ # Group orders by user_id
468
+ orders_by_user = {}
469
+ for order in orders:
470
+ user_id = order["user_id"]
471
+ if user_id not in orders_by_user:
472
+ orders_by_user[user_id] = []
473
+ orders_by_user[user_id].append(order)
474
+
475
+ # Return in input order
476
+ return [orders_by_user.get(user_id, []) for user_id in user_ids]
477
+
478
+ # Context setup
479
+ def create_context():
480
+ return {
481
+ "loaders": {
482
+ "user": UserLoader(),
483
+ "orders_by_user": OrdersByUserLoader()
484
+ }
485
+ }
486
+ ```
487
+
488
+ ## Best Practices
489
+
490
+ ### REST APIs
491
+
492
+ 1. **Consistent Naming**: Use plural nouns for collections (`/users`, not `/user`)
493
+ 2. **Stateless**: Each request contains all necessary information
494
+ 3. **Use HTTP Status Codes Correctly**: 2xx success, 4xx client errors, 5xx server errors
495
+ 4. **Version Your API**: Plan for breaking changes from day one
496
+ 5. **Pagination**: Always paginate large collections
497
+ 6. **Rate Limiting**: Protect your API with rate limits
498
+ 7. **Documentation**: Use OpenAPI/Swagger for interactive docs
499
+
500
+ ### GraphQL APIs
501
+
502
+ 1. **Schema First**: Design schema before writing resolvers
503
+ 2. **Avoid N+1**: Use DataLoaders for efficient data fetching
504
+ 3. **Input Validation**: Validate at schema and resolver levels
505
+ 4. **Error Handling**: Return structured errors in mutation payloads
506
+ 5. **Pagination**: Use cursor-based pagination (Relay spec)
507
+ 6. **Deprecation**: Use `@deprecated` directive for gradual migration
508
+ 7. **Monitoring**: Track query complexity and execution time
509
+
510
+ ## Common Pitfalls
511
+
512
+ - **Over-fetching/Under-fetching (REST)**: Fixed in GraphQL but requires DataLoaders
513
+ - **Breaking Changes**: Version APIs or use deprecation strategies
514
+ - **Inconsistent Error Formats**: Standardize error responses
515
+ - **Missing Rate Limits**: APIs without limits are vulnerable to abuse
516
+ - **Poor Documentation**: Undocumented APIs frustrate developers
517
+ - **Ignoring HTTP Semantics**: POST for idempotent operations breaks expectations
518
+ - **Tight Coupling**: API structure shouldn't mirror database schema
519
+
520
+ ## Resources
521
+
522
+ - **references/rest-best-practices.md**: Comprehensive REST API design guide
523
+ - **references/graphql-schema-design.md**: GraphQL schema patterns and anti-patterns
524
+ - **references/api-versioning-strategies.md**: Versioning approaches and migration paths
525
+ - **assets/rest-api-template.py**: FastAPI REST API template
526
+ - **assets/graphql-schema-template.graphql**: Complete GraphQL schema example
527
+ - **assets/api-design-checklist.md**: Pre-implementation review checklist
528
+ - **scripts/openapi-generator.py**: Generate OpenAPI specs from code
@@ -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