aigroup-workflow 2.1.2 → 2.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (916) hide show
  1. package/.codex/AGENTS.md +1 -1
  2. package/CLAUDE.md +1 -4
  3. package/README.md +333 -333
  4. package/cli/commands/init.mjs +20 -6
  5. package/cli/utils/scaffold.mjs +39 -9
  6. package/docs/red-flags.md +1 -1
  7. package/docs/rules/entropy.md +1 -1
  8. package/docs/rules/performance.md +1 -1
  9. package/docs/workflow-pipeline.md +8 -6
  10. package/manifests/install-modules.json +223 -133
  11. package/package.json +39 -39
  12. package/scripts/hooks/checks/orchestration-artifacts.cjs +28 -23
  13. package/scripts/hooks/checks/workflow-state.cjs +4 -5
  14. package/scripts/orchestration/lib/orchestrator.cjs +353 -92
  15. package/scripts/orchestration/lib/validate.cjs +145 -0
  16. package/scripts/orchestration/session.cjs +100 -33
  17. package/skills/ai-ml/fine-tuning-expert/SKILL.md +162 -0
  18. package/skills/ai-ml/fine-tuning-expert/references/dataset-preparation.md +540 -0
  19. package/skills/ai-ml/fine-tuning-expert/references/deployment-optimization.md +673 -0
  20. package/skills/ai-ml/fine-tuning-expert/references/evaluation-metrics.md +597 -0
  21. package/skills/ai-ml/fine-tuning-expert/references/hyperparameter-tuning.md +565 -0
  22. package/skills/ai-ml/fine-tuning-expert/references/lora-peft.md +347 -0
  23. package/skills/ai-ml/ml-pipeline/SKILL.md +159 -0
  24. package/skills/ai-ml/ml-pipeline/references/experiment-tracking.md +833 -0
  25. package/skills/ai-ml/ml-pipeline/references/feature-engineering.md +631 -0
  26. package/skills/ai-ml/ml-pipeline/references/model-validation.md +978 -0
  27. package/skills/ai-ml/ml-pipeline/references/pipeline-orchestration.md +907 -0
  28. package/skills/ai-ml/ml-pipeline/references/training-pipelines.md +782 -0
  29. package/skills/ai-ml/rag-architect/SKILL.md +194 -0
  30. package/skills/ai-ml/rag-architect/references/chunking-strategies.md +878 -0
  31. package/skills/ai-ml/rag-architect/references/embedding-models.md +561 -0
  32. package/skills/ai-ml/rag-architect/references/rag-evaluation.md +833 -0
  33. package/skills/ai-ml/rag-architect/references/retrieval-optimization.md +795 -0
  34. package/skills/ai-ml/rag-architect/references/vector-databases.md +589 -0
  35. package/skills/ai-ml/spark-engineer/SKILL.md +148 -0
  36. package/skills/ai-ml/spark-engineer/references/partitioning-caching.md +543 -0
  37. package/skills/ai-ml/spark-engineer/references/performance-tuning.md +544 -0
  38. package/skills/ai-ml/spark-engineer/references/rdd-operations.md +599 -0
  39. package/skills/ai-ml/spark-engineer/references/spark-sql-dataframes.md +474 -0
  40. package/skills/ai-ml/spark-engineer/references/streaming-patterns.md +786 -0
  41. package/skills/backend/api-designer/SKILL.md +217 -0
  42. package/skills/backend/api-designer/references/error-handling.md +541 -0
  43. package/skills/backend/api-designer/references/openapi.md +824 -0
  44. package/skills/backend/api-designer/references/pagination.md +494 -0
  45. package/skills/backend/api-designer/references/rest-patterns.md +335 -0
  46. package/skills/backend/api-designer/references/versioning.md +391 -0
  47. package/skills/backend/architecture-designer/SKILL.md +117 -0
  48. package/skills/backend/architecture-designer/references/adr-template.md +116 -0
  49. package/skills/backend/architecture-designer/references/architecture-patterns.md +111 -0
  50. package/skills/backend/architecture-designer/references/database-selection.md +102 -0
  51. package/skills/backend/architecture-designer/references/nfr-checklist.md +112 -0
  52. package/skills/backend/architecture-designer/references/system-design.md +100 -0
  53. package/skills/backend/code-documenter/SKILL.md +147 -0
  54. package/skills/backend/code-documenter/references/api-docs-fastapi-django.md +166 -0
  55. package/skills/backend/code-documenter/references/api-docs-nestjs-express.md +220 -0
  56. package/skills/backend/code-documenter/references/coverage-reports.md +125 -0
  57. package/skills/backend/code-documenter/references/documentation-systems.md +333 -0
  58. package/skills/backend/code-documenter/references/interactive-api-docs.md +531 -0
  59. package/skills/backend/code-documenter/references/python-docstrings.md +121 -0
  60. package/skills/backend/code-documenter/references/typescript-jsdoc.md +145 -0
  61. package/skills/backend/code-documenter/references/user-guides-tutorials.md +530 -0
  62. package/skills/backend/debugging-wizard/SKILL.md +105 -0
  63. package/skills/backend/debugging-wizard/references/common-patterns.md +132 -0
  64. package/skills/backend/debugging-wizard/references/debugging-tools.md +140 -0
  65. package/skills/backend/debugging-wizard/references/quick-fixes.md +177 -0
  66. package/skills/backend/debugging-wizard/references/strategies.md +142 -0
  67. package/skills/backend/debugging-wizard/references/systematic-debugging.md +367 -0
  68. package/skills/backend/feature-forge/SKILL.md +98 -0
  69. package/skills/backend/feature-forge/references/acceptance-criteria.md +104 -0
  70. package/skills/backend/feature-forge/references/ears-syntax.md +99 -0
  71. package/skills/backend/feature-forge/references/interview-questions.md +150 -0
  72. package/skills/backend/feature-forge/references/pre-discovery-subagents.md +54 -0
  73. package/skills/backend/feature-forge/references/specification-template.md +103 -0
  74. package/skills/backend/fullstack-guardian/SKILL.md +105 -0
  75. package/skills/backend/fullstack-guardian/references/api-design-standards.md +307 -0
  76. package/skills/backend/fullstack-guardian/references/architecture-decisions.md +350 -0
  77. package/skills/backend/fullstack-guardian/references/backend-patterns.md +237 -0
  78. package/skills/backend/fullstack-guardian/references/common-patterns.md +134 -0
  79. package/skills/backend/fullstack-guardian/references/deliverables-checklist.md +354 -0
  80. package/skills/backend/fullstack-guardian/references/design-template.md +91 -0
  81. package/skills/backend/fullstack-guardian/references/error-handling.md +135 -0
  82. package/skills/backend/fullstack-guardian/references/frontend-patterns.md +340 -0
  83. package/skills/backend/fullstack-guardian/references/integration-patterns.md +333 -0
  84. package/skills/backend/fullstack-guardian/references/security-checklist.md +106 -0
  85. package/skills/backend/graphql-architect/SKILL.md +146 -0
  86. package/skills/backend/graphql-architect/references/federation.md +418 -0
  87. package/skills/backend/graphql-architect/references/migration-from-rest.md +1141 -0
  88. package/skills/backend/graphql-architect/references/resolvers.md +425 -0
  89. package/skills/backend/graphql-architect/references/schema-design.md +393 -0
  90. package/skills/backend/graphql-architect/references/security.md +569 -0
  91. package/skills/backend/graphql-architect/references/subscriptions.md +510 -0
  92. package/skills/backend/legacy-modernizer/SKILL.md +137 -0
  93. package/skills/backend/legacy-modernizer/references/legacy-testing.md +381 -0
  94. package/skills/backend/legacy-modernizer/references/migration-strategies.md +423 -0
  95. package/skills/backend/legacy-modernizer/references/refactoring-patterns.md +395 -0
  96. package/skills/backend/legacy-modernizer/references/strangler-fig-pattern.md +281 -0
  97. package/skills/backend/legacy-modernizer/references/system-assessment.md +487 -0
  98. package/skills/backend/microservices-architect/SKILL.md +164 -0
  99. package/skills/backend/microservices-architect/references/communication.md +499 -0
  100. package/skills/backend/microservices-architect/references/data.md +721 -0
  101. package/skills/backend/microservices-architect/references/decomposition.md +344 -0
  102. package/skills/backend/microservices-architect/references/observability.md +805 -0
  103. package/skills/backend/microservices-architect/references/patterns.md +603 -0
  104. package/skills/database/database-optimizer/SKILL.md +147 -0
  105. package/skills/database/database-optimizer/references/index-strategies.md +331 -0
  106. package/skills/database/database-optimizer/references/monitoring-analysis.md +501 -0
  107. package/skills/database/database-optimizer/references/mysql-tuning.md +452 -0
  108. package/skills/database/database-optimizer/references/postgresql-tuning.md +413 -0
  109. package/skills/database/database-optimizer/references/query-optimization.md +251 -0
  110. package/skills/database/postgres-pro/SKILL.md +152 -0
  111. package/skills/database/postgres-pro/references/extensions.md +404 -0
  112. package/skills/database/postgres-pro/references/jsonb.md +321 -0
  113. package/skills/database/postgres-pro/references/maintenance.md +481 -0
  114. package/skills/database/postgres-pro/references/performance.md +265 -0
  115. package/skills/database/postgres-pro/references/replication.md +446 -0
  116. package/skills/database/sql-pro/SKILL.md +129 -0
  117. package/skills/database/sql-pro/references/database-design.md +402 -0
  118. package/skills/database/sql-pro/references/dialect-differences.md +419 -0
  119. package/skills/database/sql-pro/references/optimization.md +384 -0
  120. package/skills/database/sql-pro/references/query-patterns.md +285 -0
  121. package/skills/database/sql-pro/references/window-functions.md +328 -0
  122. package/skills/dotnet/csharp-developer/SKILL.md +125 -0
  123. package/skills/dotnet/csharp-developer/references/aspnet-core.md +394 -0
  124. package/skills/dotnet/csharp-developer/references/blazor.md +553 -0
  125. package/skills/dotnet/csharp-developer/references/entity-framework.md +409 -0
  126. package/skills/dotnet/csharp-developer/references/modern-csharp.md +248 -0
  127. package/skills/dotnet/csharp-developer/references/performance.md +498 -0
  128. package/skills/dotnet/dotnet-core-expert/SKILL.md +138 -0
  129. package/skills/dotnet/dotnet-core-expert/references/authentication.md +546 -0
  130. package/skills/dotnet/dotnet-core-expert/references/clean-architecture.md +455 -0
  131. package/skills/dotnet/dotnet-core-expert/references/cloud-native.md +548 -0
  132. package/skills/dotnet/dotnet-core-expert/references/entity-framework.md +440 -0
  133. package/skills/dotnet/dotnet-core-expert/references/minimal-apis.md +319 -0
  134. package/skills/frontend/angular-architect/SKILL.md +152 -0
  135. package/skills/frontend/angular-architect/references/components.md +297 -0
  136. package/skills/frontend/angular-architect/references/ngrx.md +401 -0
  137. package/skills/frontend/angular-architect/references/routing.md +361 -0
  138. package/skills/frontend/angular-architect/references/rxjs.md +319 -0
  139. package/skills/frontend/angular-architect/references/testing.md +405 -0
  140. package/skills/frontend/flutter-expert/SKILL.md +138 -0
  141. package/skills/frontend/flutter-expert/references/bloc-state.md +259 -0
  142. package/skills/frontend/flutter-expert/references/gorouter-navigation.md +119 -0
  143. package/skills/frontend/flutter-expert/references/performance.md +99 -0
  144. package/skills/frontend/flutter-expert/references/project-structure.md +118 -0
  145. package/skills/frontend/flutter-expert/references/riverpod-state.md +130 -0
  146. package/skills/frontend/flutter-expert/references/widget-patterns.md +123 -0
  147. package/skills/frontend/nextjs-developer/SKILL.md +143 -0
  148. package/skills/frontend/nextjs-developer/references/app-router.md +311 -0
  149. package/skills/frontend/nextjs-developer/references/data-fetching.md +482 -0
  150. package/skills/frontend/nextjs-developer/references/deployment.md +545 -0
  151. package/skills/frontend/nextjs-developer/references/server-actions.md +462 -0
  152. package/skills/frontend/nextjs-developer/references/server-components.md +384 -0
  153. package/skills/frontend/react-expert/SKILL.md +149 -0
  154. package/skills/frontend/react-expert/references/hooks-patterns.md +162 -0
  155. package/skills/frontend/react-expert/references/migration-class-to-modern.md +1119 -0
  156. package/skills/frontend/react-expert/references/performance.md +168 -0
  157. package/skills/frontend/react-expert/references/react-19-features.md +174 -0
  158. package/skills/frontend/react-expert/references/server-components.md +143 -0
  159. package/skills/frontend/react-expert/references/state-management.md +171 -0
  160. package/skills/frontend/react-expert/references/testing-react.md +174 -0
  161. package/skills/frontend/react-native-expert/SKILL.md +185 -0
  162. package/skills/frontend/react-native-expert/references/expo-router.md +187 -0
  163. package/skills/frontend/react-native-expert/references/list-optimization.md +204 -0
  164. package/skills/frontend/react-native-expert/references/platform-handling.md +188 -0
  165. package/skills/frontend/react-native-expert/references/project-structure.md +171 -0
  166. package/skills/frontend/react-native-expert/references/storage-hooks.md +173 -0
  167. package/skills/frontend/vue-expert/SKILL.md +98 -0
  168. package/skills/frontend/vue-expert/references/build-tooling.md +480 -0
  169. package/skills/frontend/vue-expert/references/components.md +448 -0
  170. package/skills/frontend/vue-expert/references/composition-api.md +299 -0
  171. package/skills/frontend/vue-expert/references/mobile-hybrid.md +636 -0
  172. package/skills/frontend/vue-expert/references/nuxt.md +669 -0
  173. package/skills/frontend/vue-expert/references/state-management.md +449 -0
  174. package/skills/frontend/vue-expert/references/typescript.md +584 -0
  175. package/skills/frontend/vue-expert-js/SKILL.md +167 -0
  176. package/skills/frontend/vue-expert-js/references/component-architecture.md +219 -0
  177. package/skills/frontend/vue-expert-js/references/composables-patterns.md +183 -0
  178. package/skills/frontend/vue-expert-js/references/jsdoc-typing.md +535 -0
  179. package/skills/frontend/vue-expert-js/references/state-management.md +249 -0
  180. package/skills/frontend/vue-expert-js/references/testing-patterns.md +237 -0
  181. package/skills/go-rust-cpp/cpp-pro/SKILL.md +115 -0
  182. package/skills/go-rust-cpp/cpp-pro/references/build-tooling.md +440 -0
  183. package/skills/go-rust-cpp/cpp-pro/references/concurrency.md +437 -0
  184. package/skills/go-rust-cpp/cpp-pro/references/memory-performance.md +397 -0
  185. package/skills/go-rust-cpp/cpp-pro/references/modern-cpp.md +304 -0
  186. package/skills/go-rust-cpp/cpp-pro/references/templates.md +357 -0
  187. package/skills/go-rust-cpp/golang-pro/SKILL.md +122 -0
  188. package/skills/go-rust-cpp/golang-pro/references/concurrency.md +329 -0
  189. package/skills/go-rust-cpp/golang-pro/references/generics.md +442 -0
  190. package/skills/go-rust-cpp/golang-pro/references/interfaces.md +432 -0
  191. package/skills/go-rust-cpp/golang-pro/references/project-structure.md +477 -0
  192. package/skills/go-rust-cpp/golang-pro/references/testing.md +451 -0
  193. package/skills/go-rust-cpp/rust-engineer/SKILL.md +167 -0
  194. package/skills/go-rust-cpp/rust-engineer/references/async.md +458 -0
  195. package/skills/go-rust-cpp/rust-engineer/references/error-handling.md +334 -0
  196. package/skills/go-rust-cpp/rust-engineer/references/ownership.md +278 -0
  197. package/skills/go-rust-cpp/rust-engineer/references/testing.md +470 -0
  198. package/skills/go-rust-cpp/rust-engineer/references/traits.md +413 -0
  199. package/skills/infra/cli-developer/SKILL.md +113 -0
  200. package/skills/infra/cli-developer/references/design-patterns.md +221 -0
  201. package/skills/infra/cli-developer/references/go-cli.md +540 -0
  202. package/skills/infra/cli-developer/references/node-cli.md +383 -0
  203. package/skills/infra/cli-developer/references/python-cli.md +422 -0
  204. package/skills/infra/cli-developer/references/ux-patterns.md +448 -0
  205. package/skills/infra/cloud-architect/SKILL.md +216 -0
  206. package/skills/infra/cloud-architect/references/aws.md +394 -0
  207. package/skills/infra/cloud-architect/references/azure.md +562 -0
  208. package/skills/infra/cloud-architect/references/cost.md +582 -0
  209. package/skills/infra/cloud-architect/references/gcp.md +633 -0
  210. package/skills/infra/cloud-architect/references/multi-cloud.md +483 -0
  211. package/skills/infra/devops-engineer/SKILL.md +144 -0
  212. package/skills/infra/devops-engineer/references/deployment-strategies.md +241 -0
  213. package/skills/infra/devops-engineer/references/docker-patterns.md +113 -0
  214. package/skills/infra/devops-engineer/references/github-actions.md +139 -0
  215. package/skills/infra/devops-engineer/references/incident-response.md +331 -0
  216. package/skills/infra/devops-engineer/references/kubernetes.md +154 -0
  217. package/skills/infra/devops-engineer/references/platform-engineering.md +417 -0
  218. package/skills/infra/devops-engineer/references/release-automation.md +527 -0
  219. package/skills/infra/devops-engineer/references/terraform-iac.md +141 -0
  220. package/skills/infra/kubernetes-specialist/SKILL.md +241 -0
  221. package/skills/infra/kubernetes-specialist/references/configuration.md +452 -0
  222. package/skills/infra/kubernetes-specialist/references/cost-optimization.md +458 -0
  223. package/skills/infra/kubernetes-specialist/references/custom-operators.md +563 -0
  224. package/skills/infra/kubernetes-specialist/references/gitops.md +530 -0
  225. package/skills/infra/kubernetes-specialist/references/helm-charts.md +912 -0
  226. package/skills/infra/kubernetes-specialist/references/multi-cluster.md +507 -0
  227. package/skills/infra/kubernetes-specialist/references/networking.md +447 -0
  228. package/skills/infra/kubernetes-specialist/references/service-mesh.md +459 -0
  229. package/skills/infra/kubernetes-specialist/references/storage.md +535 -0
  230. package/skills/infra/kubernetes-specialist/references/troubleshooting.md +414 -0
  231. package/skills/infra/kubernetes-specialist/references/workloads.md +377 -0
  232. package/skills/infra/mcp-developer/SKILL.md +143 -0
  233. package/skills/infra/mcp-developer/references/protocol.md +244 -0
  234. package/skills/infra/mcp-developer/references/python-sdk.md +367 -0
  235. package/skills/infra/mcp-developer/references/resources.md +554 -0
  236. package/skills/infra/mcp-developer/references/tools.md +480 -0
  237. package/skills/infra/mcp-developer/references/typescript-sdk.md +350 -0
  238. package/skills/infra/monitoring-expert/SKILL.md +176 -0
  239. package/skills/infra/monitoring-expert/references/alerting-rules.md +141 -0
  240. package/skills/infra/monitoring-expert/references/application-profiling.md +331 -0
  241. package/skills/infra/monitoring-expert/references/capacity-planning.md +344 -0
  242. package/skills/infra/monitoring-expert/references/dashboards.md +126 -0
  243. package/skills/infra/monitoring-expert/references/opentelemetry.md +123 -0
  244. package/skills/infra/monitoring-expert/references/performance-testing.md +269 -0
  245. package/skills/infra/monitoring-expert/references/prometheus-metrics.md +136 -0
  246. package/skills/infra/monitoring-expert/references/structured-logging.md +142 -0
  247. package/skills/infra/sre-engineer/SKILL.md +181 -0
  248. package/skills/infra/sre-engineer/references/automation-toil.md +492 -0
  249. package/skills/infra/sre-engineer/references/error-budget-policy.md +334 -0
  250. package/skills/infra/sre-engineer/references/incident-chaos.md +576 -0
  251. package/skills/infra/sre-engineer/references/monitoring-alerting.md +424 -0
  252. package/skills/infra/sre-engineer/references/slo-sli-management.md +238 -0
  253. package/skills/infra/terraform-engineer/SKILL.md +143 -0
  254. package/skills/infra/terraform-engineer/references/best-practices.md +583 -0
  255. package/skills/infra/terraform-engineer/references/module-patterns.md +297 -0
  256. package/skills/infra/terraform-engineer/references/providers.md +452 -0
  257. package/skills/infra/terraform-engineer/references/state-management.md +371 -0
  258. package/skills/infra/terraform-engineer/references/testing.md +486 -0
  259. package/skills/infra/websocket-engineer/SKILL.md +168 -0
  260. package/skills/infra/websocket-engineer/references/alternatives.md +391 -0
  261. package/skills/infra/websocket-engineer/references/patterns.md +400 -0
  262. package/skills/infra/websocket-engineer/references/protocol.md +195 -0
  263. package/skills/infra/websocket-engineer/references/scaling.md +333 -0
  264. package/skills/infra/websocket-engineer/references/security.md +474 -0
  265. package/skills/java/java-architect/SKILL.md +132 -0
  266. package/skills/java/java-architect/references/jpa-optimization.md +393 -0
  267. package/skills/java/java-architect/references/reactive-webflux.md +356 -0
  268. package/skills/java/java-architect/references/spring-boot-setup.md +269 -0
  269. package/skills/java/java-architect/references/spring-security.md +445 -0
  270. package/skills/java/java-architect/references/testing-patterns.md +500 -0
  271. package/skills/java/kotlin-specialist/SKILL.md +147 -0
  272. package/skills/java/kotlin-specialist/references/android-compose.md +419 -0
  273. package/skills/java/kotlin-specialist/references/coroutines-flow.md +276 -0
  274. package/skills/java/kotlin-specialist/references/dsl-idioms.md +421 -0
  275. package/skills/java/kotlin-specialist/references/ktor-server.md +426 -0
  276. package/skills/java/kotlin-specialist/references/multiplatform-kmp.md +380 -0
  277. package/skills/java/spring-boot-engineer/SKILL.md +195 -0
  278. package/skills/java/spring-boot-engineer/references/cloud.md +498 -0
  279. package/skills/java/spring-boot-engineer/references/data.md +381 -0
  280. package/skills/java/spring-boot-engineer/references/security.md +459 -0
  281. package/skills/java/spring-boot-engineer/references/testing.md +545 -0
  282. package/skills/java/spring-boot-engineer/references/web.md +295 -0
  283. package/skills/javascript/javascript-pro/SKILL.md +132 -0
  284. package/skills/javascript/javascript-pro/references/async-patterns.md +334 -0
  285. package/skills/javascript/javascript-pro/references/browser-apis.md +398 -0
  286. package/skills/javascript/javascript-pro/references/modern-syntax.md +272 -0
  287. package/skills/javascript/javascript-pro/references/modules.md +357 -0
  288. package/skills/javascript/javascript-pro/references/node-essentials.md +471 -0
  289. package/skills/javascript/nestjs-expert/SKILL.md +206 -0
  290. package/skills/javascript/nestjs-expert/references/authentication.md +166 -0
  291. package/skills/javascript/nestjs-expert/references/controllers-routing.md +111 -0
  292. package/skills/javascript/nestjs-expert/references/dtos-validation.md +153 -0
  293. package/skills/javascript/nestjs-expert/references/migration-from-express.md +1237 -0
  294. package/skills/javascript/nestjs-expert/references/services-di.md +140 -0
  295. package/skills/javascript/nestjs-expert/references/testing-patterns.md +186 -0
  296. package/skills/javascript/typescript-pro/SKILL.md +145 -0
  297. package/skills/javascript/typescript-pro/references/advanced-types.md +259 -0
  298. package/skills/javascript/typescript-pro/references/configuration.md +445 -0
  299. package/skills/javascript/typescript-pro/references/patterns.md +484 -0
  300. package/skills/javascript/typescript-pro/references/type-guards.md +352 -0
  301. package/skills/javascript/typescript-pro/references/utility-types.md +329 -0
  302. package/skills/php/laravel-specialist/SKILL.md +262 -0
  303. package/skills/php/laravel-specialist/references/eloquent.md +351 -0
  304. package/skills/php/laravel-specialist/references/livewire.md +512 -0
  305. package/skills/php/laravel-specialist/references/queues.md +423 -0
  306. package/skills/php/laravel-specialist/references/routing.md +362 -0
  307. package/skills/php/laravel-specialist/references/testing.md +522 -0
  308. package/skills/php/php-pro/SKILL.md +206 -0
  309. package/skills/php/php-pro/references/async-patterns.md +412 -0
  310. package/skills/php/php-pro/references/laravel-patterns.md +377 -0
  311. package/skills/php/php-pro/references/modern-php-features.md +323 -0
  312. package/skills/php/php-pro/references/symfony-patterns.md +466 -0
  313. package/skills/php/php-pro/references/testing-quality.md +466 -0
  314. package/skills/python/django-expert/SKILL.md +162 -0
  315. package/skills/python/django-expert/references/authentication.md +145 -0
  316. package/skills/python/django-expert/references/drf-serializers.md +148 -0
  317. package/skills/python/django-expert/references/models-orm.md +151 -0
  318. package/skills/python/django-expert/references/testing-django.md +204 -0
  319. package/skills/python/django-expert/references/viewsets-views.md +153 -0
  320. package/skills/python/fastapi-expert/SKILL.md +185 -0
  321. package/skills/python/fastapi-expert/references/async-sqlalchemy.md +146 -0
  322. package/skills/python/fastapi-expert/references/authentication.md +159 -0
  323. package/skills/python/fastapi-expert/references/endpoints-routing.md +142 -0
  324. package/skills/python/fastapi-expert/references/migration-from-django.md +997 -0
  325. package/skills/python/fastapi-expert/references/pydantic-v2.md +135 -0
  326. package/skills/python/fastapi-expert/references/testing-async.md +159 -0
  327. package/skills/python/pandas-pro/SKILL.md +178 -0
  328. package/skills/python/pandas-pro/references/aggregation-groupby.md +545 -0
  329. package/skills/python/pandas-pro/references/data-cleaning.md +500 -0
  330. package/skills/python/pandas-pro/references/dataframe-operations.md +420 -0
  331. package/skills/python/pandas-pro/references/merging-joining.md +596 -0
  332. package/skills/python/pandas-pro/references/performance-optimization.md +597 -0
  333. package/skills/python/python-pro/SKILL.md +177 -0
  334. package/skills/python/python-pro/references/async-patterns.md +356 -0
  335. package/skills/python/python-pro/references/packaging.md +460 -0
  336. package/skills/python/python-pro/references/standard-library.md +378 -0
  337. package/skills/python/python-pro/references/testing.md +404 -0
  338. package/skills/python/python-pro/references/type-system.md +290 -0
  339. package/skills/quality/chaos-engineer/SKILL.md +182 -0
  340. package/skills/quality/chaos-engineer/references/chaos-tools.md +511 -0
  341. package/skills/quality/chaos-engineer/references/experiment-design.md +229 -0
  342. package/skills/quality/chaos-engineer/references/game-days.md +434 -0
  343. package/skills/quality/chaos-engineer/references/infrastructure-chaos.md +348 -0
  344. package/skills/quality/chaos-engineer/references/kubernetes-chaos.md +432 -0
  345. package/skills/quality/code-reviewer/SKILL.md +119 -0
  346. package/skills/quality/code-reviewer/references/common-issues.md +142 -0
  347. package/skills/quality/code-reviewer/references/feedback-examples.md +144 -0
  348. package/skills/quality/code-reviewer/references/receiving-feedback.md +238 -0
  349. package/skills/quality/code-reviewer/references/report-template.md +109 -0
  350. package/skills/quality/code-reviewer/references/review-checklist.md +88 -0
  351. package/skills/quality/code-reviewer/references/spec-compliance-review.md +258 -0
  352. package/skills/quality/playwright-expert/SKILL.md +169 -0
  353. package/skills/quality/playwright-expert/references/api-mocking.md +140 -0
  354. package/skills/quality/playwright-expert/references/configuration.md +155 -0
  355. package/skills/quality/playwright-expert/references/debugging-flaky.md +150 -0
  356. package/skills/quality/playwright-expert/references/page-object-model.md +152 -0
  357. package/skills/quality/playwright-expert/references/selectors-locators.md +119 -0
  358. package/skills/quality/secure-code-guardian/SKILL.md +191 -0
  359. package/skills/quality/secure-code-guardian/references/authentication.md +136 -0
  360. package/skills/quality/secure-code-guardian/references/input-validation.md +146 -0
  361. package/skills/quality/secure-code-guardian/references/owasp-prevention.md +135 -0
  362. package/skills/quality/secure-code-guardian/references/security-headers.md +133 -0
  363. package/skills/quality/secure-code-guardian/references/xss-csrf.md +157 -0
  364. package/skills/quality/security-reviewer/SKILL.md +103 -0
  365. package/skills/quality/security-reviewer/references/infrastructure-security.md +268 -0
  366. package/skills/quality/security-reviewer/references/penetration-testing.md +268 -0
  367. package/skills/quality/security-reviewer/references/report-template.md +170 -0
  368. package/skills/quality/security-reviewer/references/sast-tools.md +117 -0
  369. package/skills/quality/security-reviewer/references/secret-scanning.md +125 -0
  370. package/skills/quality/security-reviewer/references/vulnerability-patterns.md +152 -0
  371. package/skills/quality/tdd-guide/assets/sample_coverage_report.lcov +0 -0
  372. package/skills/quality/test-master/SKILL.md +94 -0
  373. package/skills/quality/test-master/references/automation-frameworks.md +294 -0
  374. package/skills/quality/test-master/references/e2e-testing.md +128 -0
  375. package/skills/quality/test-master/references/integration-testing.md +120 -0
  376. package/skills/quality/test-master/references/performance-testing.md +118 -0
  377. package/skills/quality/test-master/references/qa-methodology.md +247 -0
  378. package/skills/quality/test-master/references/security-testing.md +127 -0
  379. package/skills/quality/test-master/references/tdd-iron-laws.md +174 -0
  380. package/skills/quality/test-master/references/test-reports.md +104 -0
  381. package/skills/quality/test-master/references/testing-anti-patterns.md +231 -0
  382. package/skills/quality/test-master/references/unit-testing.md +113 -0
  383. package/skills/ruby/rails-expert/SKILL.md +154 -0
  384. package/skills/ruby/rails-expert/references/active-record.md +244 -0
  385. package/skills/ruby/rails-expert/references/api-development.md +401 -0
  386. package/skills/ruby/rails-expert/references/background-jobs.md +272 -0
  387. package/skills/ruby/rails-expert/references/hotwire-turbo.md +228 -0
  388. package/skills/ruby/rails-expert/references/rspec-testing.md +367 -0
  389. package/skills/swift/swift-expert/SKILL.md +163 -0
  390. package/skills/swift/swift-expert/references/async-concurrency.md +360 -0
  391. package/skills/swift/swift-expert/references/memory-performance.md +377 -0
  392. package/skills/swift/swift-expert/references/protocol-oriented.md +354 -0
  393. package/skills/swift/swift-expert/references/swiftui-patterns.md +291 -0
  394. package/skills/swift/swift-expert/references/testing-patterns.md +399 -0
  395. package/skills/workflow/brainstorming/SKILL.md +164 -0
  396. package/skills/workflow/brainstorming/scripts/helper.js +88 -0
  397. package/skills/workflow/brainstorming/scripts/start-server.sh +148 -0
  398. package/skills/workflow/brainstorming/scripts/stop-server.sh +56 -0
  399. package/skills/workflow/brainstorming/spec-document-reviewer-prompt.md +49 -0
  400. package/skills/workflow/brainstorming/visual-companion.md +287 -0
  401. package/skills/workflow/documentation/SKILL.md +45 -0
  402. package/skills/workflow/entropy-management/SKILL.md +115 -0
  403. package/skills/workflow/executing-plans/SKILL.md +70 -0
  404. package/skills/workflow/finishing-a-development-branch/SKILL.md +200 -0
  405. package/skills/workflow/receiving-code-review/SKILL.md +213 -0
  406. package/skills/workflow/requesting-code-review/SKILL.md +105 -0
  407. package/skills/workflow/requesting-code-review/code-reviewer.md +146 -0
  408. package/skills/workflow/requirement-engineering/SKILL.md +111 -0
  409. package/skills/workflow/systematic-debugging/CREATION-LOG.md +119 -0
  410. package/skills/workflow/systematic-debugging/SKILL.md +296 -0
  411. package/skills/workflow/systematic-debugging/condition-based-waiting-example.ts +158 -0
  412. package/skills/workflow/systematic-debugging/condition-based-waiting.md +115 -0
  413. package/skills/workflow/systematic-debugging/defense-in-depth.md +122 -0
  414. package/skills/workflow/systematic-debugging/find-polluter.sh +63 -0
  415. package/skills/workflow/systematic-debugging/root-cause-tracing.md +169 -0
  416. package/skills/workflow/systematic-debugging/test-academic.md +14 -0
  417. package/skills/workflow/systematic-debugging/test-pressure-1.md +58 -0
  418. package/skills/workflow/systematic-debugging/test-pressure-2.md +68 -0
  419. package/skills/workflow/systematic-debugging/test-pressure-3.md +69 -0
  420. package/skills/workflow/using-git-worktrees/SKILL.md +218 -0
  421. package/skills/workflow/verification-before-completion/SKILL.md +139 -0
  422. package/skills/workflow/writing-plans/SKILL.md +151 -0
  423. package/skills/workflow/writing-plans/plan-document-reviewer-prompt.md +49 -0
  424. package/skills/workflow/writing-skills/SKILL.md +655 -0
  425. package/skills/workflow/writing-skills/anthropic-best-practices.md +1150 -0
  426. package/skills/workflow/writing-skills/examples/CLAUDE_MD_TESTING.md +189 -0
  427. package/skills/workflow/writing-skills/graphviz-conventions.dot +0 -0
  428. package/skills/workflow/writing-skills/persuasion-principles.md +187 -0
  429. package/skills/workflow/writing-skills/render-graphs.js +168 -0
  430. package/skills/workflow/writing-skills/testing-skills-with-subagents.md +384 -0
  431. package/skills/angular-architect/SKILL.md +0 -152
  432. package/skills/angular-architect/references/components.md +0 -297
  433. package/skills/angular-architect/references/ngrx.md +0 -401
  434. package/skills/angular-architect/references/routing.md +0 -361
  435. package/skills/angular-architect/references/rxjs.md +0 -319
  436. package/skills/angular-architect/references/testing.md +0 -405
  437. package/skills/api-designer/SKILL.md +0 -217
  438. package/skills/api-designer/references/error-handling.md +0 -541
  439. package/skills/api-designer/references/openapi.md +0 -824
  440. package/skills/api-designer/references/pagination.md +0 -494
  441. package/skills/api-designer/references/rest-patterns.md +0 -335
  442. package/skills/api-designer/references/versioning.md +0 -391
  443. package/skills/architecture-designer/SKILL.md +0 -117
  444. package/skills/architecture-designer/references/adr-template.md +0 -116
  445. package/skills/architecture-designer/references/architecture-patterns.md +0 -111
  446. package/skills/architecture-designer/references/database-selection.md +0 -102
  447. package/skills/architecture-designer/references/nfr-checklist.md +0 -112
  448. package/skills/architecture-designer/references/system-design.md +0 -100
  449. package/skills/brainstorming/SKILL.md +0 -164
  450. package/skills/brainstorming/scripts/helper.js +0 -88
  451. package/skills/brainstorming/scripts/start-server.sh +0 -148
  452. package/skills/brainstorming/scripts/stop-server.sh +0 -56
  453. package/skills/brainstorming/spec-document-reviewer-prompt.md +0 -49
  454. package/skills/brainstorming/visual-companion.md +0 -287
  455. package/skills/chaos-engineer/SKILL.md +0 -182
  456. package/skills/chaos-engineer/references/chaos-tools.md +0 -511
  457. package/skills/chaos-engineer/references/experiment-design.md +0 -229
  458. package/skills/chaos-engineer/references/game-days.md +0 -434
  459. package/skills/chaos-engineer/references/infrastructure-chaos.md +0 -348
  460. package/skills/chaos-engineer/references/kubernetes-chaos.md +0 -432
  461. package/skills/cli-developer/SKILL.md +0 -113
  462. package/skills/cli-developer/references/design-patterns.md +0 -221
  463. package/skills/cli-developer/references/go-cli.md +0 -540
  464. package/skills/cli-developer/references/node-cli.md +0 -383
  465. package/skills/cli-developer/references/python-cli.md +0 -422
  466. package/skills/cli-developer/references/ux-patterns.md +0 -448
  467. package/skills/cloud-architect/SKILL.md +0 -216
  468. package/skills/cloud-architect/references/aws.md +0 -394
  469. package/skills/cloud-architect/references/azure.md +0 -562
  470. package/skills/cloud-architect/references/cost.md +0 -582
  471. package/skills/cloud-architect/references/gcp.md +0 -633
  472. package/skills/cloud-architect/references/multi-cloud.md +0 -483
  473. package/skills/code-documenter/SKILL.md +0 -147
  474. package/skills/code-documenter/references/api-docs-fastapi-django.md +0 -166
  475. package/skills/code-documenter/references/api-docs-nestjs-express.md +0 -220
  476. package/skills/code-documenter/references/coverage-reports.md +0 -125
  477. package/skills/code-documenter/references/documentation-systems.md +0 -333
  478. package/skills/code-documenter/references/interactive-api-docs.md +0 -531
  479. package/skills/code-documenter/references/python-docstrings.md +0 -121
  480. package/skills/code-documenter/references/typescript-jsdoc.md +0 -145
  481. package/skills/code-documenter/references/user-guides-tutorials.md +0 -530
  482. package/skills/code-reviewer/SKILL.md +0 -119
  483. package/skills/code-reviewer/references/common-issues.md +0 -142
  484. package/skills/code-reviewer/references/feedback-examples.md +0 -144
  485. package/skills/code-reviewer/references/receiving-feedback.md +0 -238
  486. package/skills/code-reviewer/references/report-template.md +0 -109
  487. package/skills/code-reviewer/references/review-checklist.md +0 -88
  488. package/skills/code-reviewer/references/spec-compliance-review.md +0 -258
  489. package/skills/cpp-pro/SKILL.md +0 -115
  490. package/skills/cpp-pro/references/build-tooling.md +0 -440
  491. package/skills/cpp-pro/references/concurrency.md +0 -437
  492. package/skills/cpp-pro/references/memory-performance.md +0 -397
  493. package/skills/cpp-pro/references/modern-cpp.md +0 -304
  494. package/skills/cpp-pro/references/templates.md +0 -357
  495. package/skills/csharp-developer/SKILL.md +0 -125
  496. package/skills/csharp-developer/references/aspnet-core.md +0 -394
  497. package/skills/csharp-developer/references/blazor.md +0 -553
  498. package/skills/csharp-developer/references/entity-framework.md +0 -409
  499. package/skills/csharp-developer/references/modern-csharp.md +0 -248
  500. package/skills/csharp-developer/references/performance.md +0 -498
  501. package/skills/database-optimizer/SKILL.md +0 -147
  502. package/skills/database-optimizer/references/index-strategies.md +0 -331
  503. package/skills/database-optimizer/references/monitoring-analysis.md +0 -501
  504. package/skills/database-optimizer/references/mysql-tuning.md +0 -452
  505. package/skills/database-optimizer/references/postgresql-tuning.md +0 -413
  506. package/skills/database-optimizer/references/query-optimization.md +0 -251
  507. package/skills/debugging-wizard/SKILL.md +0 -105
  508. package/skills/debugging-wizard/references/common-patterns.md +0 -132
  509. package/skills/debugging-wizard/references/debugging-tools.md +0 -140
  510. package/skills/debugging-wizard/references/quick-fixes.md +0 -177
  511. package/skills/debugging-wizard/references/strategies.md +0 -142
  512. package/skills/debugging-wizard/references/systematic-debugging.md +0 -367
  513. package/skills/devops-engineer/SKILL.md +0 -144
  514. package/skills/devops-engineer/references/deployment-strategies.md +0 -241
  515. package/skills/devops-engineer/references/docker-patterns.md +0 -113
  516. package/skills/devops-engineer/references/github-actions.md +0 -139
  517. package/skills/devops-engineer/references/incident-response.md +0 -331
  518. package/skills/devops-engineer/references/kubernetes.md +0 -154
  519. package/skills/devops-engineer/references/platform-engineering.md +0 -417
  520. package/skills/devops-engineer/references/release-automation.md +0 -527
  521. package/skills/devops-engineer/references/terraform-iac.md +0 -141
  522. package/skills/django-expert/SKILL.md +0 -162
  523. package/skills/django-expert/references/authentication.md +0 -145
  524. package/skills/django-expert/references/drf-serializers.md +0 -148
  525. package/skills/django-expert/references/models-orm.md +0 -151
  526. package/skills/django-expert/references/testing-django.md +0 -204
  527. package/skills/django-expert/references/viewsets-views.md +0 -153
  528. package/skills/documentation/SKILL.md +0 -45
  529. package/skills/dotnet-core-expert/SKILL.md +0 -138
  530. package/skills/dotnet-core-expert/references/authentication.md +0 -546
  531. package/skills/dotnet-core-expert/references/clean-architecture.md +0 -455
  532. package/skills/dotnet-core-expert/references/cloud-native.md +0 -548
  533. package/skills/dotnet-core-expert/references/entity-framework.md +0 -440
  534. package/skills/dotnet-core-expert/references/minimal-apis.md +0 -319
  535. package/skills/entropy-management/SKILL.md +0 -115
  536. package/skills/executing-plans/SKILL.md +0 -70
  537. package/skills/fastapi-expert/SKILL.md +0 -185
  538. package/skills/fastapi-expert/references/async-sqlalchemy.md +0 -146
  539. package/skills/fastapi-expert/references/authentication.md +0 -159
  540. package/skills/fastapi-expert/references/endpoints-routing.md +0 -142
  541. package/skills/fastapi-expert/references/migration-from-django.md +0 -997
  542. package/skills/fastapi-expert/references/pydantic-v2.md +0 -135
  543. package/skills/fastapi-expert/references/testing-async.md +0 -159
  544. package/skills/feature-forge/SKILL.md +0 -98
  545. package/skills/feature-forge/references/acceptance-criteria.md +0 -104
  546. package/skills/feature-forge/references/ears-syntax.md +0 -99
  547. package/skills/feature-forge/references/interview-questions.md +0 -150
  548. package/skills/feature-forge/references/pre-discovery-subagents.md +0 -54
  549. package/skills/feature-forge/references/specification-template.md +0 -103
  550. package/skills/fine-tuning-expert/SKILL.md +0 -162
  551. package/skills/fine-tuning-expert/references/dataset-preparation.md +0 -540
  552. package/skills/fine-tuning-expert/references/deployment-optimization.md +0 -673
  553. package/skills/fine-tuning-expert/references/evaluation-metrics.md +0 -597
  554. package/skills/fine-tuning-expert/references/hyperparameter-tuning.md +0 -565
  555. package/skills/fine-tuning-expert/references/lora-peft.md +0 -347
  556. package/skills/finishing-a-development-branch/SKILL.md +0 -200
  557. package/skills/flutter-expert/SKILL.md +0 -138
  558. package/skills/flutter-expert/references/bloc-state.md +0 -259
  559. package/skills/flutter-expert/references/gorouter-navigation.md +0 -119
  560. package/skills/flutter-expert/references/performance.md +0 -99
  561. package/skills/flutter-expert/references/project-structure.md +0 -118
  562. package/skills/flutter-expert/references/riverpod-state.md +0 -130
  563. package/skills/flutter-expert/references/widget-patterns.md +0 -123
  564. package/skills/fullstack-guardian/SKILL.md +0 -105
  565. package/skills/fullstack-guardian/references/api-design-standards.md +0 -307
  566. package/skills/fullstack-guardian/references/architecture-decisions.md +0 -350
  567. package/skills/fullstack-guardian/references/backend-patterns.md +0 -237
  568. package/skills/fullstack-guardian/references/common-patterns.md +0 -134
  569. package/skills/fullstack-guardian/references/deliverables-checklist.md +0 -354
  570. package/skills/fullstack-guardian/references/design-template.md +0 -91
  571. package/skills/fullstack-guardian/references/error-handling.md +0 -135
  572. package/skills/fullstack-guardian/references/frontend-patterns.md +0 -340
  573. package/skills/fullstack-guardian/references/integration-patterns.md +0 -333
  574. package/skills/fullstack-guardian/references/security-checklist.md +0 -106
  575. package/skills/golang-pro/SKILL.md +0 -122
  576. package/skills/golang-pro/references/concurrency.md +0 -329
  577. package/skills/golang-pro/references/generics.md +0 -442
  578. package/skills/golang-pro/references/interfaces.md +0 -432
  579. package/skills/golang-pro/references/project-structure.md +0 -477
  580. package/skills/golang-pro/references/testing.md +0 -451
  581. package/skills/graphql-architect/SKILL.md +0 -146
  582. package/skills/graphql-architect/references/federation.md +0 -418
  583. package/skills/graphql-architect/references/migration-from-rest.md +0 -1141
  584. package/skills/graphql-architect/references/resolvers.md +0 -425
  585. package/skills/graphql-architect/references/schema-design.md +0 -393
  586. package/skills/graphql-architect/references/security.md +0 -569
  587. package/skills/graphql-architect/references/subscriptions.md +0 -510
  588. package/skills/java-architect/SKILL.md +0 -132
  589. package/skills/java-architect/references/jpa-optimization.md +0 -393
  590. package/skills/java-architect/references/reactive-webflux.md +0 -356
  591. package/skills/java-architect/references/spring-boot-setup.md +0 -269
  592. package/skills/java-architect/references/spring-security.md +0 -445
  593. package/skills/java-architect/references/testing-patterns.md +0 -500
  594. package/skills/javascript-pro/SKILL.md +0 -132
  595. package/skills/javascript-pro/references/async-patterns.md +0 -334
  596. package/skills/javascript-pro/references/browser-apis.md +0 -398
  597. package/skills/javascript-pro/references/modern-syntax.md +0 -272
  598. package/skills/javascript-pro/references/modules.md +0 -357
  599. package/skills/javascript-pro/references/node-essentials.md +0 -471
  600. package/skills/kotlin-specialist/SKILL.md +0 -147
  601. package/skills/kotlin-specialist/references/android-compose.md +0 -419
  602. package/skills/kotlin-specialist/references/coroutines-flow.md +0 -276
  603. package/skills/kotlin-specialist/references/dsl-idioms.md +0 -421
  604. package/skills/kotlin-specialist/references/ktor-server.md +0 -426
  605. package/skills/kotlin-specialist/references/multiplatform-kmp.md +0 -380
  606. package/skills/kubernetes-specialist/SKILL.md +0 -241
  607. package/skills/kubernetes-specialist/references/configuration.md +0 -452
  608. package/skills/kubernetes-specialist/references/cost-optimization.md +0 -458
  609. package/skills/kubernetes-specialist/references/custom-operators.md +0 -563
  610. package/skills/kubernetes-specialist/references/gitops.md +0 -530
  611. package/skills/kubernetes-specialist/references/helm-charts.md +0 -912
  612. package/skills/kubernetes-specialist/references/multi-cluster.md +0 -507
  613. package/skills/kubernetes-specialist/references/networking.md +0 -447
  614. package/skills/kubernetes-specialist/references/service-mesh.md +0 -459
  615. package/skills/kubernetes-specialist/references/storage.md +0 -535
  616. package/skills/kubernetes-specialist/references/troubleshooting.md +0 -414
  617. package/skills/kubernetes-specialist/references/workloads.md +0 -377
  618. package/skills/laravel-specialist/SKILL.md +0 -262
  619. package/skills/laravel-specialist/references/eloquent.md +0 -351
  620. package/skills/laravel-specialist/references/livewire.md +0 -512
  621. package/skills/laravel-specialist/references/queues.md +0 -423
  622. package/skills/laravel-specialist/references/routing.md +0 -362
  623. package/skills/laravel-specialist/references/testing.md +0 -522
  624. package/skills/legacy-modernizer/SKILL.md +0 -137
  625. package/skills/legacy-modernizer/references/legacy-testing.md +0 -381
  626. package/skills/legacy-modernizer/references/migration-strategies.md +0 -423
  627. package/skills/legacy-modernizer/references/refactoring-patterns.md +0 -395
  628. package/skills/legacy-modernizer/references/strangler-fig-pattern.md +0 -281
  629. package/skills/legacy-modernizer/references/system-assessment.md +0 -487
  630. package/skills/mcp-developer/SKILL.md +0 -143
  631. package/skills/mcp-developer/references/protocol.md +0 -244
  632. package/skills/mcp-developer/references/python-sdk.md +0 -367
  633. package/skills/mcp-developer/references/resources.md +0 -554
  634. package/skills/mcp-developer/references/tools.md +0 -480
  635. package/skills/mcp-developer/references/typescript-sdk.md +0 -350
  636. package/skills/microservices-architect/SKILL.md +0 -164
  637. package/skills/microservices-architect/references/communication.md +0 -499
  638. package/skills/microservices-architect/references/data.md +0 -721
  639. package/skills/microservices-architect/references/decomposition.md +0 -344
  640. package/skills/microservices-architect/references/observability.md +0 -805
  641. package/skills/microservices-architect/references/patterns.md +0 -603
  642. package/skills/ml-pipeline/SKILL.md +0 -159
  643. package/skills/ml-pipeline/references/experiment-tracking.md +0 -833
  644. package/skills/ml-pipeline/references/feature-engineering.md +0 -631
  645. package/skills/ml-pipeline/references/model-validation.md +0 -978
  646. package/skills/ml-pipeline/references/pipeline-orchestration.md +0 -907
  647. package/skills/ml-pipeline/references/training-pipelines.md +0 -782
  648. package/skills/monitoring-expert/SKILL.md +0 -176
  649. package/skills/monitoring-expert/references/alerting-rules.md +0 -141
  650. package/skills/monitoring-expert/references/application-profiling.md +0 -331
  651. package/skills/monitoring-expert/references/capacity-planning.md +0 -344
  652. package/skills/monitoring-expert/references/dashboards.md +0 -126
  653. package/skills/monitoring-expert/references/opentelemetry.md +0 -123
  654. package/skills/monitoring-expert/references/performance-testing.md +0 -269
  655. package/skills/monitoring-expert/references/prometheus-metrics.md +0 -136
  656. package/skills/monitoring-expert/references/structured-logging.md +0 -142
  657. package/skills/nestjs-expert/SKILL.md +0 -206
  658. package/skills/nestjs-expert/references/authentication.md +0 -166
  659. package/skills/nestjs-expert/references/controllers-routing.md +0 -111
  660. package/skills/nestjs-expert/references/dtos-validation.md +0 -153
  661. package/skills/nestjs-expert/references/migration-from-express.md +0 -1237
  662. package/skills/nestjs-expert/references/services-di.md +0 -140
  663. package/skills/nestjs-expert/references/testing-patterns.md +0 -186
  664. package/skills/nextjs-developer/SKILL.md +0 -143
  665. package/skills/nextjs-developer/references/app-router.md +0 -311
  666. package/skills/nextjs-developer/references/data-fetching.md +0 -482
  667. package/skills/nextjs-developer/references/deployment.md +0 -545
  668. package/skills/nextjs-developer/references/server-actions.md +0 -462
  669. package/skills/nextjs-developer/references/server-components.md +0 -384
  670. package/skills/pandas-pro/SKILL.md +0 -178
  671. package/skills/pandas-pro/references/aggregation-groupby.md +0 -545
  672. package/skills/pandas-pro/references/data-cleaning.md +0 -500
  673. package/skills/pandas-pro/references/dataframe-operations.md +0 -420
  674. package/skills/pandas-pro/references/merging-joining.md +0 -596
  675. package/skills/pandas-pro/references/performance-optimization.md +0 -597
  676. package/skills/php-pro/SKILL.md +0 -206
  677. package/skills/php-pro/references/async-patterns.md +0 -412
  678. package/skills/php-pro/references/laravel-patterns.md +0 -377
  679. package/skills/php-pro/references/modern-php-features.md +0 -323
  680. package/skills/php-pro/references/symfony-patterns.md +0 -466
  681. package/skills/php-pro/references/testing-quality.md +0 -466
  682. package/skills/playwright-expert/SKILL.md +0 -169
  683. package/skills/playwright-expert/references/api-mocking.md +0 -140
  684. package/skills/playwright-expert/references/configuration.md +0 -155
  685. package/skills/playwright-expert/references/debugging-flaky.md +0 -150
  686. package/skills/playwright-expert/references/page-object-model.md +0 -152
  687. package/skills/playwright-expert/references/selectors-locators.md +0 -119
  688. package/skills/postgres-pro/SKILL.md +0 -152
  689. package/skills/postgres-pro/references/extensions.md +0 -404
  690. package/skills/postgres-pro/references/jsonb.md +0 -321
  691. package/skills/postgres-pro/references/maintenance.md +0 -481
  692. package/skills/postgres-pro/references/performance.md +0 -265
  693. package/skills/postgres-pro/references/replication.md +0 -446
  694. package/skills/python-pro/SKILL.md +0 -177
  695. package/skills/python-pro/references/async-patterns.md +0 -356
  696. package/skills/python-pro/references/packaging.md +0 -460
  697. package/skills/python-pro/references/standard-library.md +0 -378
  698. package/skills/python-pro/references/testing.md +0 -404
  699. package/skills/python-pro/references/type-system.md +0 -290
  700. package/skills/rag-architect/SKILL.md +0 -194
  701. package/skills/rag-architect/references/chunking-strategies.md +0 -878
  702. package/skills/rag-architect/references/embedding-models.md +0 -561
  703. package/skills/rag-architect/references/rag-evaluation.md +0 -833
  704. package/skills/rag-architect/references/retrieval-optimization.md +0 -795
  705. package/skills/rag-architect/references/vector-databases.md +0 -589
  706. package/skills/rails-expert/SKILL.md +0 -154
  707. package/skills/rails-expert/references/active-record.md +0 -244
  708. package/skills/rails-expert/references/api-development.md +0 -401
  709. package/skills/rails-expert/references/background-jobs.md +0 -272
  710. package/skills/rails-expert/references/hotwire-turbo.md +0 -228
  711. package/skills/rails-expert/references/rspec-testing.md +0 -367
  712. package/skills/react-expert/SKILL.md +0 -149
  713. package/skills/react-expert/references/hooks-patterns.md +0 -162
  714. package/skills/react-expert/references/migration-class-to-modern.md +0 -1119
  715. package/skills/react-expert/references/performance.md +0 -168
  716. package/skills/react-expert/references/react-19-features.md +0 -174
  717. package/skills/react-expert/references/server-components.md +0 -143
  718. package/skills/react-expert/references/state-management.md +0 -171
  719. package/skills/react-expert/references/testing-react.md +0 -174
  720. package/skills/react-native-expert/SKILL.md +0 -185
  721. package/skills/react-native-expert/references/expo-router.md +0 -187
  722. package/skills/react-native-expert/references/list-optimization.md +0 -204
  723. package/skills/react-native-expert/references/platform-handling.md +0 -188
  724. package/skills/react-native-expert/references/project-structure.md +0 -171
  725. package/skills/react-native-expert/references/storage-hooks.md +0 -173
  726. package/skills/receiving-code-review/SKILL.md +0 -213
  727. package/skills/requesting-code-review/SKILL.md +0 -105
  728. package/skills/requesting-code-review/code-reviewer.md +0 -146
  729. package/skills/requirement-engineering/SKILL.md +0 -111
  730. package/skills/rust-engineer/SKILL.md +0 -167
  731. package/skills/rust-engineer/references/async.md +0 -458
  732. package/skills/rust-engineer/references/error-handling.md +0 -334
  733. package/skills/rust-engineer/references/ownership.md +0 -278
  734. package/skills/rust-engineer/references/testing.md +0 -470
  735. package/skills/rust-engineer/references/traits.md +0 -413
  736. package/skills/secure-code-guardian/SKILL.md +0 -191
  737. package/skills/secure-code-guardian/references/authentication.md +0 -136
  738. package/skills/secure-code-guardian/references/input-validation.md +0 -146
  739. package/skills/secure-code-guardian/references/owasp-prevention.md +0 -135
  740. package/skills/secure-code-guardian/references/security-headers.md +0 -133
  741. package/skills/secure-code-guardian/references/xss-csrf.md +0 -157
  742. package/skills/security-reviewer/SKILL.md +0 -103
  743. package/skills/security-reviewer/references/infrastructure-security.md +0 -268
  744. package/skills/security-reviewer/references/penetration-testing.md +0 -268
  745. package/skills/security-reviewer/references/report-template.md +0 -170
  746. package/skills/security-reviewer/references/sast-tools.md +0 -117
  747. package/skills/security-reviewer/references/secret-scanning.md +0 -125
  748. package/skills/security-reviewer/references/vulnerability-patterns.md +0 -152
  749. package/skills/spark-engineer/SKILL.md +0 -148
  750. package/skills/spark-engineer/references/partitioning-caching.md +0 -543
  751. package/skills/spark-engineer/references/performance-tuning.md +0 -544
  752. package/skills/spark-engineer/references/rdd-operations.md +0 -599
  753. package/skills/spark-engineer/references/spark-sql-dataframes.md +0 -474
  754. package/skills/spark-engineer/references/streaming-patterns.md +0 -786
  755. package/skills/spring-boot-engineer/SKILL.md +0 -195
  756. package/skills/spring-boot-engineer/references/cloud.md +0 -498
  757. package/skills/spring-boot-engineer/references/data.md +0 -381
  758. package/skills/spring-boot-engineer/references/security.md +0 -459
  759. package/skills/spring-boot-engineer/references/testing.md +0 -545
  760. package/skills/spring-boot-engineer/references/web.md +0 -295
  761. package/skills/sql-pro/SKILL.md +0 -129
  762. package/skills/sql-pro/references/database-design.md +0 -402
  763. package/skills/sql-pro/references/dialect-differences.md +0 -419
  764. package/skills/sql-pro/references/optimization.md +0 -384
  765. package/skills/sql-pro/references/query-patterns.md +0 -285
  766. package/skills/sql-pro/references/window-functions.md +0 -328
  767. package/skills/sre-engineer/SKILL.md +0 -181
  768. package/skills/sre-engineer/references/automation-toil.md +0 -492
  769. package/skills/sre-engineer/references/error-budget-policy.md +0 -334
  770. package/skills/sre-engineer/references/incident-chaos.md +0 -576
  771. package/skills/sre-engineer/references/monitoring-alerting.md +0 -424
  772. package/skills/sre-engineer/references/slo-sli-management.md +0 -238
  773. package/skills/swift-expert/SKILL.md +0 -163
  774. package/skills/swift-expert/references/async-concurrency.md +0 -360
  775. package/skills/swift-expert/references/memory-performance.md +0 -377
  776. package/skills/swift-expert/references/protocol-oriented.md +0 -354
  777. package/skills/swift-expert/references/swiftui-patterns.md +0 -291
  778. package/skills/swift-expert/references/testing-patterns.md +0 -399
  779. package/skills/systematic-debugging/CREATION-LOG.md +0 -119
  780. package/skills/systematic-debugging/SKILL.md +0 -296
  781. package/skills/systematic-debugging/condition-based-waiting-example.ts +0 -158
  782. package/skills/systematic-debugging/condition-based-waiting.md +0 -115
  783. package/skills/systematic-debugging/defense-in-depth.md +0 -122
  784. package/skills/systematic-debugging/find-polluter.sh +0 -63
  785. package/skills/systematic-debugging/root-cause-tracing.md +0 -169
  786. package/skills/systematic-debugging/test-academic.md +0 -14
  787. package/skills/systematic-debugging/test-pressure-1.md +0 -58
  788. package/skills/systematic-debugging/test-pressure-2.md +0 -68
  789. package/skills/systematic-debugging/test-pressure-3.md +0 -69
  790. package/skills/tdd-guide/assets/sample_coverage_report.lcov +0 -56
  791. package/skills/terraform-engineer/SKILL.md +0 -143
  792. package/skills/terraform-engineer/references/best-practices.md +0 -583
  793. package/skills/terraform-engineer/references/module-patterns.md +0 -297
  794. package/skills/terraform-engineer/references/providers.md +0 -452
  795. package/skills/terraform-engineer/references/state-management.md +0 -371
  796. package/skills/terraform-engineer/references/testing.md +0 -486
  797. package/skills/test-master/SKILL.md +0 -94
  798. package/skills/test-master/references/automation-frameworks.md +0 -294
  799. package/skills/test-master/references/e2e-testing.md +0 -128
  800. package/skills/test-master/references/integration-testing.md +0 -120
  801. package/skills/test-master/references/performance-testing.md +0 -118
  802. package/skills/test-master/references/qa-methodology.md +0 -247
  803. package/skills/test-master/references/security-testing.md +0 -127
  804. package/skills/test-master/references/tdd-iron-laws.md +0 -174
  805. package/skills/test-master/references/test-reports.md +0 -104
  806. package/skills/test-master/references/testing-anti-patterns.md +0 -231
  807. package/skills/test-master/references/unit-testing.md +0 -113
  808. package/skills/typescript-pro/SKILL.md +0 -145
  809. package/skills/typescript-pro/references/advanced-types.md +0 -259
  810. package/skills/typescript-pro/references/configuration.md +0 -445
  811. package/skills/typescript-pro/references/patterns.md +0 -484
  812. package/skills/typescript-pro/references/type-guards.md +0 -352
  813. package/skills/typescript-pro/references/utility-types.md +0 -329
  814. package/skills/using-git-worktrees/SKILL.md +0 -218
  815. package/skills/verification-before-completion/SKILL.md +0 -139
  816. package/skills/vue-expert/SKILL.md +0 -98
  817. package/skills/vue-expert/references/build-tooling.md +0 -480
  818. package/skills/vue-expert/references/components.md +0 -448
  819. package/skills/vue-expert/references/composition-api.md +0 -299
  820. package/skills/vue-expert/references/mobile-hybrid.md +0 -636
  821. package/skills/vue-expert/references/nuxt.md +0 -669
  822. package/skills/vue-expert/references/state-management.md +0 -449
  823. package/skills/vue-expert/references/typescript.md +0 -584
  824. package/skills/vue-expert-js/SKILL.md +0 -167
  825. package/skills/vue-expert-js/references/component-architecture.md +0 -219
  826. package/skills/vue-expert-js/references/composables-patterns.md +0 -183
  827. package/skills/vue-expert-js/references/jsdoc-typing.md +0 -535
  828. package/skills/vue-expert-js/references/state-management.md +0 -249
  829. package/skills/vue-expert-js/references/testing-patterns.md +0 -237
  830. package/skills/websocket-engineer/SKILL.md +0 -168
  831. package/skills/websocket-engineer/references/alternatives.md +0 -391
  832. package/skills/websocket-engineer/references/patterns.md +0 -400
  833. package/skills/websocket-engineer/references/protocol.md +0 -195
  834. package/skills/websocket-engineer/references/scaling.md +0 -333
  835. package/skills/websocket-engineer/references/security.md +0 -474
  836. package/skills/writing-plans/SKILL.md +0 -151
  837. package/skills/writing-plans/plan-document-reviewer-prompt.md +0 -49
  838. package/skills/writing-skills/SKILL.md +0 -655
  839. package/skills/writing-skills/anthropic-best-practices.md +0 -1150
  840. package/skills/writing-skills/examples/CLAUDE_MD_TESTING.md +0 -189
  841. package/skills/writing-skills/graphviz-conventions.dot +0 -172
  842. package/skills/writing-skills/persuasion-principles.md +0 -187
  843. package/skills/writing-skills/render-graphs.js +0 -168
  844. package/skills/writing-skills/testing-skills-with-subagents.md +0 -384
  845. /package/skills/{design-commands → frontend/design-commands}/design.md +0 -0
  846. /package/skills/{design-commands → frontend/design-commands}/handoff.md +0 -0
  847. /package/skills/{design-commands → frontend/design-commands}/prototype.md +0 -0
  848. /package/skills/{design-commands → frontend/design-commands}/spec.md +0 -0
  849. /package/skills/{design-commands → frontend/design-commands}/style.md +0 -0
  850. /package/skills/{senior-frontend → frontend/senior-frontend}/SKILL.md +0 -0
  851. /package/skills/{senior-frontend → frontend/senior-frontend}/references/frontend_best_practices.md +0 -0
  852. /package/skills/{senior-frontend → frontend/senior-frontend}/references/nextjs_optimization_guide.md +0 -0
  853. /package/skills/{senior-frontend → frontend/senior-frontend}/references/react_patterns.md +0 -0
  854. /package/skills/{senior-frontend → frontend/senior-frontend}/scripts/bundle_analyzer.py +0 -0
  855. /package/skills/{senior-frontend → frontend/senior-frontend}/scripts/component_generator.py +0 -0
  856. /package/skills/{senior-frontend → frontend/senior-frontend}/scripts/frontend_scaffolder.py +0 -0
  857. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/SKILL.md +0 -0
  858. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/charts.csv +0 -0
  859. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/colors.csv +0 -0
  860. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/icons.csv +0 -0
  861. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/landing.csv +0 -0
  862. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/products.csv +0 -0
  863. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/react-performance.csv +0 -0
  864. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/astro.csv +0 -0
  865. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/flutter.csv +0 -0
  866. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/html-tailwind.csv +0 -0
  867. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/jetpack-compose.csv +0 -0
  868. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/nextjs.csv +0 -0
  869. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/nuxt-ui.csv +0 -0
  870. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/nuxtjs.csv +0 -0
  871. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/react-native.csv +0 -0
  872. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/react.csv +0 -0
  873. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/shadcn.csv +0 -0
  874. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/svelte.csv +0 -0
  875. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/swiftui.csv +0 -0
  876. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/stacks/vue.csv +0 -0
  877. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/styles.csv +0 -0
  878. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/typography.csv +0 -0
  879. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/ui-reasoning.csv +0 -0
  880. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/ux-guidelines.csv +0 -0
  881. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/data/web-interface.csv +0 -0
  882. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/scripts/core.py +0 -0
  883. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/scripts/design_system.py +0 -0
  884. /package/skills/{ui-ux-pro-max → frontend/ui-ux-pro-max}/scripts/search.py +0 -0
  885. /package/skills/{competitive-analysis → product/competitive-analysis}/SKILL.md +0 -0
  886. /package/skills/{meeting-notes → product/meeting-notes}/SKILL.md +0 -0
  887. /package/skills/{prd-template → product/prd-template}/SKILL.md +0 -0
  888. /package/skills/{stakeholder-update → product/stakeholder-update}/SKILL.md +0 -0
  889. /package/skills/{user-research-synthesis → product/user-research-synthesis}/SKILL.md +0 -0
  890. /package/skills/{senior-qa → quality/senior-qa}/README.md +0 -0
  891. /package/skills/{senior-qa → quality/senior-qa}/SKILL.md +0 -0
  892. /package/skills/{senior-qa → quality/senior-qa}/references/qa_best_practices.md +0 -0
  893. /package/skills/{senior-qa → quality/senior-qa}/references/test_automation_patterns.md +0 -0
  894. /package/skills/{senior-qa → quality/senior-qa}/references/testing_strategies.md +0 -0
  895. /package/skills/{senior-qa → quality/senior-qa}/scripts/coverage_analyzer.py +0 -0
  896. /package/skills/{senior-qa → quality/senior-qa}/scripts/e2e_test_scaffolder.py +0 -0
  897. /package/skills/{senior-qa → quality/senior-qa}/scripts/test_suite_generator.py +0 -0
  898. /package/skills/{tdd-guide → quality/tdd-guide}/HOW_TO_USE.md +0 -0
  899. /package/skills/{tdd-guide → quality/tdd-guide}/README.md +0 -0
  900. /package/skills/{tdd-guide → quality/tdd-guide}/SKILL.md +0 -0
  901. /package/skills/{tdd-guide → quality/tdd-guide}/assets/expected_output.json +0 -0
  902. /package/skills/{tdd-guide → quality/tdd-guide}/assets/sample_input_python.json +0 -0
  903. /package/skills/{tdd-guide → quality/tdd-guide}/assets/sample_input_typescript.json +0 -0
  904. /package/skills/{tdd-guide → quality/tdd-guide}/references/ci-integration.md +0 -0
  905. /package/skills/{tdd-guide → quality/tdd-guide}/references/framework-guide.md +0 -0
  906. /package/skills/{tdd-guide → quality/tdd-guide}/references/tdd-best-practices.md +0 -0
  907. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/coverage_analyzer.py +0 -0
  908. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/fixture_generator.py +0 -0
  909. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/format_detector.py +0 -0
  910. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/framework_adapter.py +0 -0
  911. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/metrics_calculator.py +0 -0
  912. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/output_formatter.py +0 -0
  913. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/tdd_workflow.py +0 -0
  914. /package/skills/{tdd-guide → quality/tdd-guide}/scripts/test_generator.py +0 -0
  915. /package/skills/{brainstorming → workflow/brainstorming}/scripts/frame-template.html +0 -0
  916. /package/skills/{brainstorming → workflow/brainstorming}/scripts/server.cjs +0 -0
@@ -1,997 +0,0 @@
1
- # Django to FastAPI Migration Guide
2
-
3
- ---
4
-
5
- ## When to Use This Guide
6
-
7
- **Migrate to FastAPI when:**
8
- - Need async/await for I/O-bound operations
9
- - Require WebSocket or Server-Sent Events
10
- - Want automatic OpenAPI/Swagger documentation
11
- - Need better performance for API-heavy workloads
12
- - Desire modern Python type hints and editor support
13
- - Building microservices from Django monolith
14
- - Require lower resource consumption
15
-
16
- **DO NOT migrate when:**
17
- - Heavy use of Django admin interface
18
- - Extensive Django ORM model inheritance
19
- - Complex form handling and validation
20
- - Server-side template rendering required
21
- - Team lacks async Python experience
22
- - Django ecosystem plugins are critical
23
- - Migration cost exceeds business value
24
-
25
- ---
26
-
27
- ## Concept Mapping: Django/DRF → FastAPI
28
-
29
- | Django/DRF Concept | FastAPI Equivalent | Notes |
30
- |-------------------|-------------------|-------|
31
- | `models.Model` | Pydantic `BaseModel` + SQLAlchemy | Separate schema from ORM |
32
- | `serializers.Serializer` | Pydantic `BaseModel` | Type-safe validation |
33
- | `ModelSerializer` | Multiple Pydantic models | Create/Read/Update schemas |
34
- | `ViewSet` | `APIRouter` + path operations | More explicit routing |
35
- | `GenericAPIView` | Dependency injection | Function-based approach |
36
- | `@api_view` decorator | `@router.get/post` | Built-in HTTP methods |
37
- | `urls.py` | `APIRouter` + `app.include_router` | Nested routers |
38
- | `settings.py` | `pydantic-settings` | Environment-based config |
39
- | `middleware` | Middleware + dependencies | More granular control |
40
- | `permissions` | Dependencies | Composable auth |
41
- | `authentication` | OAuth2 + JWT dependencies | Standards-based |
42
- | `pagination` | Query parameters + dependencies | Manual implementation |
43
- | `filters` | Query parameters | Type-safe filtering |
44
- | `Django ORM` | SQLAlchemy 2.0+ | Async support |
45
- | `select_related` | `selectinload` | Eager loading |
46
- | `prefetch_related` | `joinedload` | Join strategies |
47
- | `pytest-django` | `pytest + httpx` | Async test client |
48
- | `admin.py` | External (SQLAdmin, etc.) | Not built-in |
49
-
50
- ---
51
-
52
- ## Serializer → Pydantic V2 Migration
53
-
54
- ### Django REST Framework Serializer
55
-
56
- ```python
57
- # Django DRF
58
- from rest_framework import serializers
59
- from .models import User, Post
60
-
61
- class UserSerializer(serializers.ModelSerializer):
62
- post_count = serializers.SerializerMethodField()
63
-
64
- class Meta:
65
- model = User
66
- fields = ['id', 'username', 'email', 'created_at', 'post_count']
67
- read_only_fields = ['id', 'created_at']
68
- extra_kwargs = {
69
- 'email': {'write_only': True}
70
- }
71
-
72
- def get_post_count(self, obj):
73
- return obj.posts.count()
74
-
75
- def validate_username(self, value):
76
- if len(value) < 3:
77
- raise serializers.ValidationError("Username too short")
78
- return value
79
-
80
- class PostSerializer(serializers.ModelSerializer):
81
- author = UserSerializer(read_only=True)
82
- tags = serializers.ListField(child=serializers.CharField())
83
-
84
- class Meta:
85
- model = Post
86
- fields = ['id', 'title', 'content', 'author', 'tags', 'published']
87
-
88
- def create(self, validated_data):
89
- tags = validated_data.pop('tags', [])
90
- post = Post.objects.create(**validated_data)
91
- post.tags.set(tags)
92
- return post
93
- ```
94
-
95
- ### FastAPI Pydantic V2 Schemas
96
-
97
- ```python
98
- # FastAPI with Pydantic V2
99
- from pydantic import BaseModel, EmailStr, Field, field_validator, computed_field
100
- from datetime import datetime
101
- from typing import Annotated
102
-
103
- # Base schemas
104
- class UserBase(BaseModel):
105
- username: Annotated[str, Field(min_length=3, max_length=50)]
106
- email: EmailStr
107
-
108
- # Create schema (input)
109
- class UserCreate(UserBase):
110
- password: Annotated[str, Field(min_length=8)]
111
-
112
- @field_validator('username')
113
- @classmethod
114
- def validate_username(cls, v: str) -> str:
115
- if len(v) < 3:
116
- raise ValueError("Username too short")
117
- return v
118
-
119
- # Update schema (partial)
120
- class UserUpdate(BaseModel):
121
- username: Annotated[str | None, Field(min_length=3, max_length=50)] = None
122
- email: EmailStr | None = None
123
-
124
- # Read schema (output) - analogous to read_only_fields
125
- class UserRead(UserBase):
126
- id: int
127
- created_at: datetime
128
-
129
- model_config = {
130
- "from_attributes": True # Pydantic V2: replaces orm_mode
131
- }
132
-
133
- # Read schema with relations - analogous to SerializerMethodField
134
- class UserReadWithStats(UserRead):
135
- post_count: int
136
-
137
- @computed_field # Pydantic V2 computed fields
138
- @property
139
- def display_name(self) -> str:
140
- return f"@{self.username}"
141
-
142
- # Nested schemas
143
- class PostBase(BaseModel):
144
- title: Annotated[str, Field(max_length=200)]
145
- content: str
146
- tags: list[str] = []
147
- published: bool = False
148
-
149
- class PostCreate(PostBase):
150
- pass
151
-
152
- class PostRead(PostBase):
153
- id: int
154
- author: UserRead # Nested serialization
155
- created_at: datetime
156
-
157
- model_config = {"from_attributes": True}
158
-
159
- # Embedding vs side-loading
160
- class PostReadMinimal(BaseModel):
161
- """Minimal post representation (just ID)"""
162
- id: int
163
- title: str
164
- author_id: int # Side-loaded reference
165
-
166
- model_config = {"from_attributes": True}
167
- ```
168
-
169
- ---
170
-
171
- ## ViewSet → APIRouter Migration
172
-
173
- ### Django REST Framework ViewSet
174
-
175
- ```python
176
- # Django DRF ViewSet
177
- from rest_framework import viewsets, status
178
- from rest_framework.decorators import action
179
- from rest_framework.response import Response
180
- from rest_framework.permissions import IsAuthenticated
181
- from django.shortcuts import get_object_or_404
182
-
183
- class PostViewSet(viewsets.ModelViewSet):
184
- queryset = Post.objects.all()
185
- serializer_class = PostSerializer
186
- permission_classes = [IsAuthenticated]
187
-
188
- def get_queryset(self):
189
- queryset = super().get_queryset()
190
- if self.request.user.is_authenticated:
191
- return queryset.filter(author=self.request.user)
192
- return queryset.none()
193
-
194
- def perform_create(self, serializer):
195
- serializer.save(author=self.request.user)
196
-
197
- @action(detail=True, methods=['post'])
198
- def publish(self, request, pk=None):
199
- post = self.get_object()
200
- post.published = True
201
- post.save()
202
- return Response({'status': 'published'})
203
-
204
- @action(detail=False, methods=['get'])
205
- def recent(self, request):
206
- recent_posts = self.get_queryset().order_by('-created_at')[:10]
207
- serializer = self.get_serializer(recent_posts, many=True)
208
- return Response(serializer.data)
209
- ```
210
-
211
- ### FastAPI APIRouter with Dependencies
212
-
213
- ```python
214
- # FastAPI APIRouter
215
- from fastapi import APIRouter, Depends, HTTPException, status, Query
216
- from sqlalchemy.ext.asyncio import AsyncSession
217
- from sqlalchemy import select
218
- from typing import Annotated
219
-
220
- from .database import get_db
221
- from .auth import get_current_user
222
- from .models import Post as PostModel, User as UserModel
223
- from .schemas import PostRead, PostCreate, PostUpdate, UserRead
224
-
225
- router = APIRouter(prefix="/posts", tags=["posts"])
226
-
227
- # Dependency for database session
228
- DbSession = Annotated[AsyncSession, Depends(get_db)]
229
- CurrentUser = Annotated[UserModel, Depends(get_current_user)]
230
-
231
- # List posts (GET /posts)
232
- @router.get("/", response_model=list[PostRead])
233
- async def list_posts(
234
- db: DbSession,
235
- current_user: CurrentUser,
236
- skip: int = Query(0, ge=0),
237
- limit: int = Query(100, le=100),
238
- ):
239
- """Analogous to ViewSet.list()"""
240
- result = await db.execute(
241
- select(PostModel)
242
- .where(PostModel.author_id == current_user.id)
243
- .offset(skip)
244
- .limit(limit)
245
- )
246
- posts = result.scalars().all()
247
- return posts
248
-
249
- # Create post (POST /posts)
250
- @router.post("/", response_model=PostRead, status_code=status.HTTP_201_CREATED)
251
- async def create_post(
252
- post_data: PostCreate,
253
- db: DbSession,
254
- current_user: CurrentUser,
255
- ):
256
- """Analogous to ViewSet.create()"""
257
- post = PostModel(**post_data.model_dump(), author_id=current_user.id)
258
- db.add(post)
259
- await db.commit()
260
- await db.refresh(post)
261
- return post
262
-
263
- # Retrieve single post (GET /posts/{post_id})
264
- @router.get("/{post_id}", response_model=PostRead)
265
- async def get_post(
266
- post_id: int,
267
- db: DbSession,
268
- current_user: CurrentUser,
269
- ):
270
- """Analogous to ViewSet.retrieve()"""
271
- result = await db.execute(
272
- select(PostModel).where(
273
- PostModel.id == post_id,
274
- PostModel.author_id == current_user.id
275
- )
276
- )
277
- post = result.scalar_one_or_none()
278
- if not post:
279
- raise HTTPException(status_code=404, detail="Post not found")
280
- return post
281
-
282
- # Update post (PUT /posts/{post_id})
283
- @router.put("/{post_id}", response_model=PostRead)
284
- async def update_post(
285
- post_id: int,
286
- post_data: PostUpdate,
287
- db: DbSession,
288
- current_user: CurrentUser,
289
- ):
290
- """Analogous to ViewSet.update()"""
291
- result = await db.execute(
292
- select(PostModel).where(
293
- PostModel.id == post_id,
294
- PostModel.author_id == current_user.id
295
- )
296
- )
297
- post = result.scalar_one_or_none()
298
- if not post:
299
- raise HTTPException(status_code=404, detail="Post not found")
300
-
301
- # Update only provided fields
302
- for field, value in post_data.model_dump(exclude_unset=True).items():
303
- setattr(post, field, value)
304
-
305
- await db.commit()
306
- await db.refresh(post)
307
- return post
308
-
309
- # Delete post (DELETE /posts/{post_id})
310
- @router.delete("/{post_id}", status_code=status.HTTP_204_NO_CONTENT)
311
- async def delete_post(
312
- post_id: int,
313
- db: DbSession,
314
- current_user: CurrentUser,
315
- ):
316
- """Analogous to ViewSet.destroy()"""
317
- result = await db.execute(
318
- select(PostModel).where(
319
- PostModel.id == post_id,
320
- PostModel.author_id == current_user.id
321
- )
322
- )
323
- post = result.scalar_one_or_none()
324
- if not post:
325
- raise HTTPException(status_code=404, detail="Post not found")
326
-
327
- await db.delete(post)
328
- await db.commit()
329
-
330
- # Custom action: Publish (POST /posts/{post_id}/publish)
331
- @router.post("/{post_id}/publish", response_model=dict)
332
- async def publish_post(
333
- post_id: int,
334
- db: DbSession,
335
- current_user: CurrentUser,
336
- ):
337
- """Analogous to @action(detail=True)"""
338
- result = await db.execute(
339
- select(PostModel).where(
340
- PostModel.id == post_id,
341
- PostModel.author_id == current_user.id
342
- )
343
- )
344
- post = result.scalar_one_or_none()
345
- if not post:
346
- raise HTTPException(status_code=404, detail="Post not found")
347
-
348
- post.published = True
349
- await db.commit()
350
- return {"status": "published"}
351
-
352
- # Custom collection action: Recent posts (GET /posts/recent)
353
- @router.get("/actions/recent", response_model=list[PostRead])
354
- async def recent_posts(
355
- db: DbSession,
356
- current_user: CurrentUser,
357
- limit: int = Query(10, le=50),
358
- ):
359
- """Analogous to @action(detail=False)"""
360
- result = await db.execute(
361
- select(PostModel)
362
- .where(PostModel.author_id == current_user.id)
363
- .order_by(PostModel.created_at.desc())
364
- .limit(limit)
365
- )
366
- posts = result.scalars().all()
367
- return posts
368
- ```
369
-
370
- ---
371
-
372
- ## Django ORM → Async SQLAlchemy
373
-
374
- ### Django ORM Models
375
-
376
- ```python
377
- # Django models
378
- from django.db import models
379
-
380
- class User(models.Model):
381
- username = models.CharField(max_length=50, unique=True)
382
- email = models.EmailField(unique=True)
383
- created_at = models.DateTimeField(auto_now_add=True)
384
-
385
- class Meta:
386
- db_table = 'users'
387
- indexes = [
388
- models.Index(fields=['username']),
389
- ]
390
-
391
- class Post(models.Model):
392
- title = models.CharField(max_length=200)
393
- content = models.TextField()
394
- author = models.ForeignKey(User, on_delete=models.CASCADE, related_name='posts')
395
- created_at = models.DateTimeField(auto_now_add=True)
396
- published = models.BooleanField(default=False)
397
-
398
- class Meta:
399
- db_table = 'posts'
400
- ordering = ['-created_at']
401
- ```
402
-
403
- ### SQLAlchemy 2.0 Async Models
404
-
405
- ```python
406
- # SQLAlchemy 2.0 models
407
- from sqlalchemy.orm import DeclarativeBase, Mapped, mapped_column, relationship
408
- from sqlalchemy import String, Text, Boolean, ForeignKey, Index
409
- from datetime import datetime
410
- from typing import List
411
-
412
- class Base(DeclarativeBase):
413
- pass
414
-
415
- class User(Base):
416
- __tablename__ = 'users'
417
-
418
- # Primary key
419
- id: Mapped[int] = mapped_column(primary_key=True)
420
-
421
- # Columns with type hints
422
- username: Mapped[str] = mapped_column(String(50), unique=True, index=True)
423
- email: Mapped[str] = mapped_column(String(255), unique=True)
424
- created_at: Mapped[datetime] = mapped_column(default=datetime.utcnow)
425
-
426
- # Relationships (analogous to related_name)
427
- posts: Mapped[List["Post"]] = relationship(back_populates="author")
428
-
429
- __table_args__ = (
430
- Index('ix_users_username', 'username'),
431
- )
432
-
433
- class Post(Base):
434
- __tablename__ = 'posts'
435
-
436
- id: Mapped[int] = mapped_column(primary_key=True)
437
- title: Mapped[str] = mapped_column(String(200))
438
- content: Mapped[str] = mapped_column(Text)
439
- author_id: Mapped[int] = mapped_column(ForeignKey('users.id', ondelete='CASCADE'))
440
- created_at: Mapped[datetime] = mapped_column(default=datetime.utcnow)
441
- published: Mapped[bool] = mapped_column(Boolean, default=False)
442
-
443
- # Relationship
444
- author: Mapped["User"] = relationship(back_populates="posts")
445
-
446
- __table_args__ = (
447
- Index('ix_posts_created_at', 'created_at'),
448
- )
449
- ```
450
-
451
- ### Query Patterns: Django ORM vs SQLAlchemy
452
-
453
- ```python
454
- # Django ORM queries
455
- from django.db.models import Count, Q
456
-
457
- # Simple filter
458
- posts = Post.objects.filter(published=True)
459
-
460
- # Select related (JOIN)
461
- posts = Post.objects.select_related('author').filter(published=True)
462
-
463
- # Prefetch related (separate query)
464
- users = User.objects.prefetch_related('posts').all()
465
-
466
- # Complex filtering
467
- posts = Post.objects.filter(
468
- Q(published=True) | Q(author__username='admin')
469
- ).order_by('-created_at')[:10]
470
-
471
- # Aggregation
472
- user_stats = User.objects.annotate(
473
- post_count=Count('posts')
474
- ).filter(post_count__gte=5)
475
- ```
476
-
477
- ```python
478
- # SQLAlchemy 2.0 async queries
479
- from sqlalchemy import select, func, or_
480
- from sqlalchemy.orm import selectinload, joinedload
481
-
482
- # Simple filter
483
- async def get_published_posts(db: AsyncSession):
484
- result = await db.execute(
485
- select(Post).where(Post.published == True)
486
- )
487
- return result.scalars().all()
488
-
489
- # Eager loading with JOIN (selectinload = separate query)
490
- async def get_posts_with_authors(db: AsyncSession):
491
- result = await db.execute(
492
- select(Post)
493
- .options(selectinload(Post.author))
494
- .where(Post.published == True)
495
- )
496
- return result.scalars().all()
497
-
498
- # Prefetch related (joinedload = single query with JOIN)
499
- async def get_users_with_posts(db: AsyncSession):
500
- result = await db.execute(
501
- select(User).options(joinedload(User.posts))
502
- )
503
- return result.unique().scalars().all()
504
-
505
- # Complex filtering
506
- async def get_complex_posts(db: AsyncSession):
507
- result = await db.execute(
508
- select(Post)
509
- .join(Post.author)
510
- .where(
511
- or_(
512
- Post.published == True,
513
- User.username == 'admin'
514
- )
515
- )
516
- .order_by(Post.created_at.desc())
517
- .limit(10)
518
- )
519
- return result.scalars().all()
520
-
521
- # Aggregation
522
- async def get_user_stats(db: AsyncSession):
523
- result = await db.execute(
524
- select(User, func.count(Post.id).label('post_count'))
525
- .join(Post)
526
- .group_by(User.id)
527
- .having(func.count(Post.id) >= 5)
528
- )
529
- return result.all()
530
- ```
531
-
532
- ---
533
-
534
- ## Authentication: SimpleJWT → FastAPI JWT
535
-
536
- ### Django SimpleJWT
537
-
538
- ```python
539
- # Django settings.py
540
- REST_FRAMEWORK = {
541
- 'DEFAULT_AUTHENTICATION_CLASSES': [
542
- 'rest_framework_simplejwt.authentication.JWTAuthentication',
543
- ],
544
- }
545
-
546
- # Views
547
- from rest_framework_simplejwt.views import TokenObtainPairView
548
-
549
- # Usage in ViewSet
550
- from rest_framework.permissions import IsAuthenticated
551
-
552
- class ProtectedViewSet(viewsets.ModelViewSet):
553
- permission_classes = [IsAuthenticated]
554
-
555
- def get_queryset(self):
556
- return Post.objects.filter(author=self.request.user)
557
- ```
558
-
559
- ### FastAPI JWT Authentication
560
-
561
- ```python
562
- # auth.py - FastAPI JWT implementation
563
- from fastapi import Depends, HTTPException, status
564
- from fastapi.security import OAuth2PasswordBearer, OAuth2PasswordRequestForm
565
- from jose import JWTError, jwt
566
- from passlib.context import CryptContext
567
- from datetime import datetime, timedelta
568
- from pydantic import BaseModel
569
- from typing import Annotated
570
-
571
- # Configuration
572
- SECRET_KEY = "your-secret-key" # Use environment variable
573
- ALGORITHM = "HS256"
574
- ACCESS_TOKEN_EXPIRE_MINUTES = 30
575
-
576
- # Password hashing
577
- pwd_context = CryptContext(schemes=["bcrypt"], deprecated="auto")
578
-
579
- # OAuth2 scheme
580
- oauth2_scheme = OAuth2PasswordBearer(tokenUrl="/auth/token")
581
-
582
- # Schemas
583
- class Token(BaseModel):
584
- access_token: str
585
- token_type: str
586
-
587
- class TokenData(BaseModel):
588
- username: str | None = None
589
-
590
- # Helper functions
591
- def verify_password(plain_password: str, hashed_password: str) -> bool:
592
- return pwd_context.verify(plain_password, hashed_password)
593
-
594
- def get_password_hash(password: str) -> str:
595
- return pwd_context.hash(password)
596
-
597
- def create_access_token(data: dict, expires_delta: timedelta | None = None):
598
- to_encode = data.copy()
599
- if expires_delta:
600
- expire = datetime.utcnow() + expires_delta
601
- else:
602
- expire = datetime.utcnow() + timedelta(minutes=15)
603
- to_encode.update({"exp": expire})
604
- encoded_jwt = jwt.encode(to_encode, SECRET_KEY, algorithm=ALGORITHM)
605
- return encoded_jwt
606
-
607
- # Dependency: Get current user from token
608
- async def get_current_user(
609
- token: Annotated[str, Depends(oauth2_scheme)],
610
- db: Annotated[AsyncSession, Depends(get_db)]
611
- ) -> UserModel:
612
- credentials_exception = HTTPException(
613
- status_code=status.HTTP_401_UNAUTHORIZED,
614
- detail="Could not validate credentials",
615
- headers={"WWW-Authenticate": "Bearer"},
616
- )
617
- try:
618
- payload = jwt.decode(token, SECRET_KEY, algorithms=[ALGORITHM])
619
- username: str = payload.get("sub")
620
- if username is None:
621
- raise credentials_exception
622
- token_data = TokenData(username=username)
623
- except JWTError:
624
- raise credentials_exception
625
-
626
- result = await db.execute(
627
- select(UserModel).where(UserModel.username == token_data.username)
628
- )
629
- user = result.scalar_one_or_none()
630
- if user is None:
631
- raise credentials_exception
632
- return user
633
-
634
- # Login endpoint
635
- auth_router = APIRouter(prefix="/auth", tags=["auth"])
636
-
637
- @auth_router.post("/token", response_model=Token)
638
- async def login(
639
- form_data: Annotated[OAuth2PasswordRequestForm, Depends()],
640
- db: Annotated[AsyncSession, Depends(get_db)]
641
- ):
642
- # Authenticate user
643
- result = await db.execute(
644
- select(UserModel).where(UserModel.username == form_data.username)
645
- )
646
- user = result.scalar_one_or_none()
647
-
648
- if not user or not verify_password(form_data.password, user.hashed_password):
649
- raise HTTPException(
650
- status_code=status.HTTP_401_UNAUTHORIZED,
651
- detail="Incorrect username or password",
652
- headers={"WWW-Authenticate": "Bearer"},
653
- )
654
-
655
- # Create access token
656
- access_token_expires = timedelta(minutes=ACCESS_TOKEN_EXPIRE_MINUTES)
657
- access_token = create_access_token(
658
- data={"sub": user.username}, expires_delta=access_token_expires
659
- )
660
- return {"access_token": access_token, "token_type": "bearer"}
661
-
662
- # Protected endpoint usage
663
- @router.get("/protected")
664
- async def protected_route(current_user: Annotated[UserModel, Depends(get_current_user)]):
665
- return {"message": f"Hello {current_user.username}"}
666
- ```
667
-
668
- ---
669
-
670
- ## Testing Migration
671
-
672
- ### Django/DRF Tests
673
-
674
- ```python
675
- # Django pytest
676
- import pytest
677
- from rest_framework.test import APIClient
678
- from django.contrib.auth.models import User
679
-
680
- @pytest.fixture
681
- def api_client():
682
- return APIClient()
683
-
684
- @pytest.fixture
685
- def user(db):
686
- return User.objects.create_user(username='test', password='test123')
687
-
688
- @pytest.mark.django_db
689
- def test_create_post(api_client, user):
690
- api_client.force_authenticate(user=user)
691
- response = api_client.post('/api/posts/', {
692
- 'title': 'Test Post',
693
- 'content': 'Test content'
694
- })
695
- assert response.status_code == 201
696
- assert response.data['title'] == 'Test Post'
697
- ```
698
-
699
- ### FastAPI Tests
700
-
701
- ```python
702
- # FastAPI pytest with httpx
703
- import pytest
704
- from httpx import AsyncClient, ASGITransport
705
- from sqlalchemy.ext.asyncio import create_async_engine, AsyncSession, async_sessionmaker
706
- from app.main import app
707
- from app.database import get_db, Base
708
- from app.models import User
709
-
710
- # Test database setup
711
- TEST_DATABASE_URL = "sqlite+aiosqlite:///:memory:"
712
-
713
- @pytest.fixture
714
- async def db_engine():
715
- engine = create_async_engine(TEST_DATABASE_URL, echo=False)
716
- async with engine.begin() as conn:
717
- await conn.run_sync(Base.metadata.create_all)
718
- yield engine
719
- await engine.dispose()
720
-
721
- @pytest.fixture
722
- async def db_session(db_engine):
723
- async_session = async_sessionmaker(
724
- db_engine, class_=AsyncSession, expire_on_commit=False
725
- )
726
- async with async_session() as session:
727
- yield session
728
-
729
- @pytest.fixture
730
- async def client(db_session):
731
- async def override_get_db():
732
- yield db_session
733
-
734
- app.dependency_overrides[get_db] = override_get_db
735
-
736
- async with AsyncClient(
737
- transport=ASGITransport(app=app),
738
- base_url="http://test"
739
- ) as ac:
740
- yield ac
741
-
742
- app.dependency_overrides.clear()
743
-
744
- @pytest.fixture
745
- async def auth_headers(client, db_session):
746
- # Create test user
747
- user = User(username="test", email="test@example.com")
748
- user.hashed_password = get_password_hash("test123")
749
- db_session.add(user)
750
- await db_session.commit()
751
-
752
- # Get token
753
- response = await client.post("/auth/token", data={
754
- "username": "test",
755
- "password": "test123"
756
- })
757
- token = response.json()["access_token"]
758
- return {"Authorization": f"Bearer {token}"}
759
-
760
- @pytest.mark.asyncio
761
- async def test_create_post(client, auth_headers):
762
- response = await client.post(
763
- "/posts/",
764
- json={"title": "Test Post", "content": "Test content"},
765
- headers=auth_headers
766
- )
767
- assert response.status_code == 201
768
- data = response.json()
769
- assert data["title"] == "Test Post"
770
-
771
- @pytest.mark.asyncio
772
- async def test_list_posts(client, auth_headers, db_session):
773
- # Create test data
774
- user = await db_session.execute(select(User).where(User.username == "test"))
775
- user = user.scalar_one()
776
-
777
- post = Post(title="Test", content="Content", author_id=user.id)
778
- db_session.add(post)
779
- await db_session.commit()
780
-
781
- # Test endpoint
782
- response = await client.get("/posts/", headers=auth_headers)
783
- assert response.status_code == 200
784
- assert len(response.json()) == 1
785
- ```
786
-
787
- ---
788
-
789
- ## Incremental Migration Strategy
790
-
791
- ### Phase 1: Parallel API (Strangler Pattern)
792
-
793
- Run Django and FastAPI side-by-side, migrating endpoints incrementally.
794
-
795
- ```python
796
- # Nginx routing config
797
- location /api/v2/ {
798
- proxy_pass http://fastapi:8000;
799
- }
800
-
801
- location /api/ {
802
- proxy_pass http://django:8001;
803
- }
804
- ```
805
-
806
- **Approach:**
807
- 1. Stand up FastAPI with shared database (read-only initially)
808
- 2. Migrate GET endpoints first (lowest risk)
809
- 3. Add write endpoints with dual-write to both systems
810
- 4. Validate data consistency
811
- 5. Switch traffic gradually (feature flags)
812
-
813
- ### Phase 2: Shared Database Migration
814
-
815
- ```python
816
- # FastAPI with existing Django database
817
- from sqlalchemy import MetaData
818
-
819
- # Reflect existing Django tables
820
- metadata = MetaData()
821
- metadata.reflect(bind=engine, only=['users', 'posts'])
822
-
823
- # Or define models matching Django schema
824
- class User(Base):
825
- __tablename__ = 'auth_user' # Django's user table
826
- # Map to Django's column names
827
- ```
828
-
829
- ### Phase 3: Database Schema Modernization
830
-
831
- After traffic migration, modernize schema:
832
- - Remove Django-specific fields (`content_type`, `permissions`)
833
- - Simplify table names (remove app prefixes)
834
- - Add database-level constraints
835
- - Optimize indexes for async queries
836
-
837
- ### Phase 4: Complete Cutover
838
-
839
- ```python
840
- # Decommission Django
841
- # 1. Archive Django admin usage
842
- # 2. Export management commands to FastAPI CLI
843
- # 3. Migrate background tasks to Celery/Dramatiq
844
- # 4. Remove Django dependency
845
- ```
846
-
847
- ---
848
-
849
- ## Common Pitfalls
850
-
851
- ### 1. Async/Await Mistakes
852
-
853
- **WRONG:**
854
- ```python
855
- # Blocking call in async function
856
- @router.get("/users")
857
- async def get_users(db: AsyncSession):
858
- users = db.execute(select(User)).scalars().all() # Missing await
859
- return users
860
- ```
861
-
862
- **CORRECT:**
863
- ```python
864
- @router.get("/users")
865
- async def get_users(db: AsyncSession):
866
- result = await db.execute(select(User)) # Await async operation
867
- users = result.scalars().all()
868
- return users
869
- ```
870
-
871
- ### 2. Missing `from_attributes` (orm_mode)
872
-
873
- **WRONG:**
874
- ```python
875
- class UserRead(BaseModel):
876
- id: int
877
- username: str
878
- # Missing config - won't work with SQLAlchemy models
879
- ```
880
-
881
- **CORRECT:**
882
- ```python
883
- class UserRead(BaseModel):
884
- id: int
885
- username: str
886
-
887
- model_config = {"from_attributes": True} # Pydantic V2
888
- ```
889
-
890
- ### 3. Session Management
891
-
892
- **WRONG:**
893
- ```python
894
- # Reusing session across requests
895
- db_session = async_sessionmaker(engine)()
896
-
897
- @router.get("/users")
898
- async def get_users():
899
- return await db_session.execute(select(User)) # Session leak
900
- ```
901
-
902
- **CORRECT:**
903
- ```python
904
- # Dependency injection per request
905
- async def get_db():
906
- async with async_sessionmaker(engine)() as session:
907
- yield session
908
- await session.commit()
909
-
910
- @router.get("/users")
911
- async def get_users(db: Annotated[AsyncSession, Depends(get_db)]):
912
- result = await db.execute(select(User))
913
- return result.scalars().all()
914
- ```
915
-
916
- ### 4. Relationship Loading
917
-
918
- **WRONG:**
919
- ```python
920
- # Lazy loading in async (causes errors)
921
- user = await db.get(User, user_id)
922
- posts = user.posts # Error: lazy loading not supported in async
923
- ```
924
-
925
- **CORRECT:**
926
- ```python
927
- # Eager loading with selectinload
928
- result = await db.execute(
929
- select(User).options(selectinload(User.posts)).where(User.id == user_id)
930
- )
931
- user = result.scalar_one()
932
- posts = user.posts # Already loaded
933
- ```
934
-
935
- ### 5. Transaction Handling
936
-
937
- **WRONG:**
938
- ```python
939
- # Auto-commit not configured
940
- @router.post("/users")
941
- async def create_user(user: UserCreate, db: AsyncSession):
942
- db_user = User(**user.dict())
943
- db.add(db_user)
944
- # Missing commit - changes lost
945
- return db_user
946
- ```
947
-
948
- **CORRECT:**
949
- ```python
950
- @router.post("/users")
951
- async def create_user(user: UserCreate, db: AsyncSession):
952
- db_user = User(**user.model_dump())
953
- db.add(db_user)
954
- await db.commit() # Explicit commit
955
- await db.refresh(db_user) # Refresh to get DB-generated fields
956
- return db_user
957
- ```
958
-
959
- ---
960
-
961
- ## Cross-Reference
962
-
963
- For comprehensive migration strategies and modernization patterns:
964
- - **Legacy Modernizer**: `/skills/legacy-modernizer/references/migration-strategies.md`
965
- - Strangler pattern implementation
966
- - Feature flag strategies
967
- - Rollback procedures
968
- - Data migration pipelines
969
-
970
- ---
971
-
972
- ## Migration Checklist
973
-
974
- **Pre-Migration:**
975
- - [ ] Async readiness assessment (I/O bound workload?)
976
- - [ ] Team async Python experience validated
977
- - [ ] Database compatibility verified (async drivers available)
978
- - [ ] Admin interface replacement identified
979
- - [ ] Migration timeline approved (6-12 months realistic)
980
-
981
- **During Migration:**
982
- - [ ] Parallel deployment configured
983
- - [ ] Monitoring and alerting set up
984
- - [ ] Load testing completed
985
- - [ ] Data consistency validation automated
986
- - [ ] Rollback procedure tested
987
-
988
- **Post-Migration:**
989
- - [ ] Django dependencies removed
990
- - [ ] Documentation updated
991
- - [ ] Team training completed
992
- - [ ] Performance gains measured
993
- - [ ] Cost savings validated
994
-
995
- ---
996
-
997
- **Key Takeaway:** Migrate incrementally. Start with read-heavy endpoints, validate thoroughly, then gradually move write operations. Always maintain rollback capability.