@rubix0270/arboris 1.0.2 → 1.0.4

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 (451) hide show
  1. package/package.json +25 -37
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -383
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,73 +0,0 @@
1
- ---
2
- name: data-throughput-accelerator
3
- description: Use when large data ingestion, backfill, export, ETL, warehouse loading, manifest catch-up, or table synchronization needs to become much faster while preserving data correctness.
4
- metadata:
5
- origin: ECC
6
- tools: Read, Write, Edit, Bash, Grep, Glob
7
- ---
8
-
9
- # Data Throughput Accelerator
10
-
11
- Use this skill when the bottleneck is moving, transforming, or saving lots of
12
- data. The goal is not just speed. The goal is faster correct data landing in the
13
- right place with proof.
14
-
15
- ## First Distinction
16
-
17
- Separate these before optimizing:
18
-
19
- - source extraction speed;
20
- - network transfer speed;
21
- - warehouse/load speed;
22
- - transform speed;
23
- - serving-table freshness;
24
- - live tail growth while the job runs.
25
-
26
- A pipeline can be "fast" and still appear behind if new data arrives faster
27
- than the final catch-up window.
28
-
29
- ## Fast Path Heuristics
30
-
31
- - Move compute to where the data already is.
32
- - Prefer warehouse-native scans, joins, and appends for large landed files.
33
- - Use manifests or checkpoints so completed files/partitions are skipped.
34
- - Use partitioning and clustering that match the read and append pattern.
35
- - Batch small files, requests, and writes.
36
- - Make writes idempotent through unique keys, manifests, or replaceable staging.
37
- - Keep raw, derived, and serving tables separately accountable.
38
-
39
- ## Workflow
40
-
41
- 1. Read the current source, target, and manifest contracts.
42
- 2. Measure backlog: external files, manifest rows, raw rows, derived rows,
43
- min/max timestamps, and unprocessed counts.
44
- 3. Run a safe catch-up or sample benchmark.
45
- 4. Compare variants: batch size, worker count, warehouse SQL, file grouping,
46
- staging shape, and manifest update method.
47
- 5. Promote only the fastest path that keeps counts and timestamps coherent.
48
- 6. Codify the path as a CLI, scheduled job, workflow, or runbook.
49
- 7. Rerun final accounting after the codified path executes.
50
-
51
- ## Accounting Output
52
-
53
- Use a hard accounting block:
54
-
55
- ```text
56
- Data throughput result:
57
- - Source files discovered: 294
58
- - Files processed this run: 294
59
- - Raw rows added: 9,683,598
60
- - Derived rows added: 8,917,585
61
- - Remaining tail: 24 files at readback time
62
- - Runtime: 38.7s
63
- - Correctness gate: manifest counts and table max timestamps match
64
- ```
65
-
66
- ## Guardrails
67
-
68
- - Do not delete raw data to make a metric look better.
69
- - Do not skip failed files silently.
70
- - Do not mix historical backfill status with live-tail freshness.
71
- - Do not call a pipeline complete until the target tables and manifest agree.
72
- - For finance, healthcare, regulated, or customer-impacting data, preserve
73
- replay evidence and approval gates.
@@ -1,430 +0,0 @@
1
- ---
2
- name: database-migrations
3
- description: Database migration best practices for schema changes, data migrations, rollbacks, and zero-downtime deployments across PostgreSQL, MySQL, and common ORMs (Prisma, Drizzle, Kysely, Django, TypeORM, golang-migrate).
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Database Migration Patterns
9
-
10
- Safe, reversible database schema changes for production systems.
11
-
12
- ## When to Activate
13
-
14
- - Creating or altering database tables
15
- - Adding/removing columns or indexes
16
- - Running data migrations (backfill, transform)
17
- - Planning zero-downtime schema changes
18
- - Setting up migration tooling for a new project
19
-
20
- ## Core Principles
21
-
22
- 1. **Every change is a migration** — never alter production databases manually
23
- 2. **Migrations are forward-only in production** — rollbacks use new forward migrations
24
- 3. **Schema and data migrations are separate** — never mix DDL and DML in one migration
25
- 4. **Test migrations against production-sized data** — a migration that works on 100 rows may lock on 10M
26
- 5. **Migrations are immutable once deployed** — never edit a migration that has run in production
27
-
28
- ## Migration Safety Checklist
29
-
30
- Before applying any migration:
31
-
32
- - [ ] Migration has both UP and DOWN (or is explicitly marked irreversible)
33
- - [ ] No full table locks on large tables (use concurrent operations)
34
- - [ ] New columns have defaults or are nullable (never add NOT NULL without default)
35
- - [ ] Indexes created concurrently (not inline with CREATE TABLE for existing tables)
36
- - [ ] Data backfill is a separate migration from schema change
37
- - [ ] Tested against a copy of production data
38
- - [ ] Rollback plan documented
39
-
40
- ## PostgreSQL Patterns
41
-
42
- ### Adding a Column Safely
43
-
44
- ```sql
45
- -- GOOD: Nullable column, no lock
46
- ALTER TABLE users ADD COLUMN avatar_url TEXT;
47
-
48
- -- GOOD: Column with default (Postgres 11+ is instant, no rewrite)
49
- ALTER TABLE users ADD COLUMN is_active BOOLEAN NOT NULL DEFAULT true;
50
-
51
- -- BAD: NOT NULL without default on existing table (requires full rewrite)
52
- ALTER TABLE users ADD COLUMN role TEXT NOT NULL;
53
- -- This locks the table and rewrites every row
54
- ```
55
-
56
- ### Adding an Index Without Downtime
57
-
58
- ```sql
59
- -- BAD: Blocks writes on large tables
60
- CREATE INDEX idx_users_email ON users (email);
61
-
62
- -- GOOD: Non-blocking, allows concurrent writes
63
- CREATE INDEX CONCURRENTLY idx_users_email ON users (email);
64
-
65
- -- Note: CONCURRENTLY cannot run inside a transaction block
66
- -- Most migration tools need special handling for this
67
- ```
68
-
69
- ### Renaming a Column (Zero-Downtime)
70
-
71
- Never rename directly in production. Use the expand-contract pattern:
72
-
73
- ```sql
74
- -- Step 1: Add new column (migration 001)
75
- ALTER TABLE users ADD COLUMN display_name TEXT;
76
-
77
- -- Step 2: Backfill data (migration 002, data migration)
78
- UPDATE users SET display_name = username WHERE display_name IS NULL;
79
-
80
- -- Step 3: Update application code to read/write both columns
81
- -- Deploy application changes
82
-
83
- -- Step 4: Stop writing to old column, drop it (migration 003)
84
- ALTER TABLE users DROP COLUMN username;
85
- ```
86
-
87
- ### Removing a Column Safely
88
-
89
- ```sql
90
- -- Step 1: Remove all application references to the column
91
- -- Step 2: Deploy application without the column reference
92
- -- Step 3: Drop column in next migration
93
- ALTER TABLE orders DROP COLUMN legacy_status;
94
-
95
- -- For Django: use SeparateDatabaseAndState to remove from model
96
- -- without generating DROP COLUMN (then drop in next migration)
97
- ```
98
-
99
- ### Large Data Migrations
100
-
101
- ```sql
102
- -- BAD: Updates all rows in one transaction (locks table)
103
- UPDATE users SET normalized_email = LOWER(email);
104
-
105
- -- GOOD: Batch update with progress
106
- DO $$
107
- DECLARE
108
- batch_size INT := 10000;
109
- rows_updated INT;
110
- BEGIN
111
- LOOP
112
- UPDATE users
113
- SET normalized_email = LOWER(email)
114
- WHERE id IN (
115
- SELECT id FROM users
116
- WHERE normalized_email IS NULL
117
- LIMIT batch_size
118
- FOR UPDATE SKIP LOCKED
119
- );
120
- GET DIAGNOSTICS rows_updated = ROW_COUNT;
121
- RAISE NOTICE 'Updated % rows', rows_updated;
122
- EXIT WHEN rows_updated = 0;
123
- COMMIT;
124
- END LOOP;
125
- END $$;
126
- ```
127
-
128
- ## Prisma (TypeScript/Node.js)
129
-
130
- ### Workflow
131
-
132
- ```bash
133
- # Create migration from schema changes
134
- npx prisma migrate dev --name add_user_avatar
135
-
136
- # Apply pending migrations in production
137
- npx prisma migrate deploy
138
-
139
- # Reset database (dev only)
140
- npx prisma migrate reset
141
-
142
- # Generate client after schema changes
143
- npx prisma generate
144
- ```
145
-
146
- ### Schema Example
147
-
148
- ```prisma
149
- model User {
150
- id String @id @default(cuid())
151
- email String @unique
152
- name String?
153
- avatarUrl String? @map("avatar_url")
154
- createdAt DateTime @default(now()) @map("created_at")
155
- updatedAt DateTime @updatedAt @map("updated_at")
156
- orders Order[]
157
-
158
- @@map("users")
159
- @@index([email])
160
- }
161
- ```
162
-
163
- ### Custom SQL Migration
164
-
165
- For operations Prisma cannot express (concurrent indexes, data backfills):
166
-
167
- ```bash
168
- # Create empty migration, then edit the SQL manually
169
- npx prisma migrate dev --create-only --name add_email_index
170
- ```
171
-
172
- ```sql
173
- -- migrations/20240115_add_email_index/migration.sql
174
- -- Prisma cannot generate CONCURRENTLY, so we write it manually
175
- CREATE INDEX CONCURRENTLY IF NOT EXISTS idx_users_email ON users (email);
176
- ```
177
-
178
- ## Drizzle (TypeScript/Node.js)
179
-
180
- ### Workflow
181
-
182
- ```bash
183
- # Generate migration from schema changes
184
- npx drizzle-kit generate
185
-
186
- # Apply migrations
187
- npx drizzle-kit migrate
188
-
189
- # Push schema directly (dev only, no migration file)
190
- npx drizzle-kit push
191
- ```
192
-
193
- ### Schema Example
194
-
195
- ```typescript
196
- import { pgTable, text, timestamp, uuid, boolean } from "drizzle-orm/pg-core";
197
-
198
- export const users = pgTable("users", {
199
- id: uuid("id").primaryKey().defaultRandom(),
200
- email: text("email").notNull().unique(),
201
- name: text("name"),
202
- isActive: boolean("is_active").notNull().default(true),
203
- createdAt: timestamp("created_at").notNull().defaultNow(),
204
- updatedAt: timestamp("updated_at").notNull().defaultNow(),
205
- });
206
- ```
207
-
208
- ## Kysely (TypeScript/Node.js)
209
-
210
- ### Workflow (kysely-ctl)
211
-
212
- ```bash
213
- # Initialize config file (kysely.config.ts)
214
- kysely init
215
-
216
- # Create a new migration file
217
- kysely migrate make add_user_avatar
218
-
219
- # Apply all pending migrations
220
- kysely migrate latest
221
-
222
- # Rollback last migration
223
- kysely migrate down
224
-
225
- # Show migration status
226
- kysely migrate list
227
- ```
228
-
229
- ### Migration File
230
-
231
- ```typescript
232
- // migrations/2024_01_15_001_create_user_profile.ts
233
- import { type Kysely, sql } from 'kysely'
234
-
235
- // IMPORTANT: Always use Kysely<any>, not your typed DB interface.
236
- // Migrations are frozen in time and must not depend on current schema types.
237
- export async function up(db: Kysely<any>): Promise<void> {
238
- await db.schema
239
- .createTable('user_profile')
240
- .addColumn('id', 'serial', (col) => col.primaryKey())
241
- .addColumn('email', 'varchar(255)', (col) => col.notNull().unique())
242
- .addColumn('avatar_url', 'text')
243
- .addColumn('created_at', 'timestamp', (col) =>
244
- col.defaultTo(sql`now()`).notNull()
245
- )
246
- .execute()
247
-
248
- await db.schema
249
- .createIndex('idx_user_profile_avatar')
250
- .on('user_profile')
251
- .column('avatar_url')
252
- .execute()
253
- }
254
-
255
- export async function down(db: Kysely<any>): Promise<void> {
256
- await db.schema.dropTable('user_profile').execute()
257
- }
258
- ```
259
-
260
- ### Programmatic Migrator
261
-
262
- ```typescript
263
- import { Migrator, FileMigrationProvider } from 'kysely'
264
- import { promises as fs } from 'fs'
265
- import * as path from 'path'
266
- // ESM only — CJS can use __dirname directly
267
- import { fileURLToPath } from 'url'
268
- const migrationFolder = path.join(
269
- path.dirname(fileURLToPath(import.meta.url)),
270
- './migrations',
271
- )
272
-
273
- // `db` is your Kysely<any> database instance
274
- const migrator = new Migrator({
275
- db,
276
- provider: new FileMigrationProvider({
277
- fs,
278
- path,
279
- migrationFolder,
280
- }),
281
- // WARNING: Only enable in development. Disables timestamp-ordering
282
- // validation, which can cause schema drift between environments.
283
- // allowUnorderedMigrations: true,
284
- })
285
-
286
- const { error, results } = await migrator.migrateToLatest()
287
-
288
- results?.forEach((it) => {
289
- if (it.status === 'Success') {
290
- console.log(`migration "${it.migrationName}" executed successfully`)
291
- } else if (it.status === 'Error') {
292
- console.error(`failed to execute migration "${it.migrationName}"`)
293
- }
294
- })
295
-
296
- if (error) {
297
- console.error('migration failed', error)
298
- process.exit(1)
299
- }
300
- ```
301
-
302
- ## Django (Python)
303
-
304
- ### Workflow
305
-
306
- ```bash
307
- # Generate migration from model changes
308
- python manage.py makemigrations
309
-
310
- # Apply migrations
311
- python manage.py migrate
312
-
313
- # Show migration status
314
- python manage.py showmigrations
315
-
316
- # Generate empty migration for custom SQL
317
- python manage.py makemigrations --empty app_name -n description
318
- ```
319
-
320
- ### Data Migration
321
-
322
- ```python
323
- from django.db import migrations
324
-
325
- def backfill_display_names(apps, schema_editor):
326
- User = apps.get_model("accounts", "User")
327
- batch_size = 5000
328
- users = User.objects.filter(display_name="")
329
- while users.exists():
330
- batch = list(users[:batch_size])
331
- for user in batch:
332
- user.display_name = user.username
333
- User.objects.bulk_update(batch, ["display_name"], batch_size=batch_size)
334
-
335
- def reverse_backfill(apps, schema_editor):
336
- pass # Data migration, no reverse needed
337
-
338
- class Migration(migrations.Migration):
339
- dependencies = [("accounts", "0015_add_display_name")]
340
-
341
- operations = [
342
- migrations.RunPython(backfill_display_names, reverse_backfill),
343
- ]
344
- ```
345
-
346
- ### SeparateDatabaseAndState
347
-
348
- Remove a column from the Django model without dropping it from the database immediately:
349
-
350
- ```python
351
- class Migration(migrations.Migration):
352
- operations = [
353
- migrations.SeparateDatabaseAndState(
354
- state_operations=[
355
- migrations.RemoveField(model_name="user", name="legacy_field"),
356
- ],
357
- database_operations=[], # Don't touch the DB yet
358
- ),
359
- ]
360
- ```
361
-
362
- ## golang-migrate (Go)
363
-
364
- ### Workflow
365
-
366
- ```bash
367
- # Create migration pair
368
- migrate create -ext sql -dir migrations -seq add_user_avatar
369
-
370
- # Apply all pending migrations
371
- migrate -path migrations -database "$DATABASE_URL" up
372
-
373
- # Rollback last migration
374
- migrate -path migrations -database "$DATABASE_URL" down 1
375
-
376
- # Force version (fix dirty state)
377
- migrate -path migrations -database "$DATABASE_URL" force VERSION
378
- ```
379
-
380
- ### Migration Files
381
-
382
- ```sql
383
- -- migrations/000003_add_user_avatar.up.sql
384
- ALTER TABLE users ADD COLUMN avatar_url TEXT;
385
- CREATE INDEX CONCURRENTLY idx_users_avatar ON users (avatar_url) WHERE avatar_url IS NOT NULL;
386
-
387
- -- migrations/000003_add_user_avatar.down.sql
388
- DROP INDEX IF EXISTS idx_users_avatar;
389
- ALTER TABLE users DROP COLUMN IF EXISTS avatar_url;
390
- ```
391
-
392
- ## Zero-Downtime Migration Strategy
393
-
394
- For critical production changes, follow the expand-contract pattern:
395
-
396
- ```
397
- Phase 1: EXPAND
398
- - Add new column/table (nullable or with default)
399
- - Deploy: app writes to BOTH old and new
400
- - Backfill existing data
401
-
402
- Phase 2: MIGRATE
403
- - Deploy: app reads from NEW, writes to BOTH
404
- - Verify data consistency
405
-
406
- Phase 3: CONTRACT
407
- - Deploy: app only uses NEW
408
- - Drop old column/table in separate migration
409
- ```
410
-
411
- ### Timeline Example
412
-
413
- ```
414
- Day 1: Migration adds new_status column (nullable)
415
- Day 1: Deploy app v2 — writes to both status and new_status
416
- Day 2: Run backfill migration for existing rows
417
- Day 3: Deploy app v3 — reads from new_status only
418
- Day 7: Migration drops old status column
419
- ```
420
-
421
- ## Anti-Patterns
422
-
423
- | Anti-Pattern | Why It Fails | Better Approach |
424
- |-------------|-------------|-----------------|
425
- | Manual SQL in production | No audit trail, unrepeatable | Always use migration files |
426
- | Editing deployed migrations | Causes drift between environments | Create new migration instead |
427
- | NOT NULL without default | Locks table, rewrites all rows | Add nullable, backfill, then add constraint |
428
- | Inline index on large table | Blocks writes during build | CREATE INDEX CONCURRENTLY |
429
- | Schema + data in one migration | Hard to rollback, long transactions | Separate migrations |
430
- | Dropping column before removing code | Application errors on missing column | Remove code first, drop column next deploy |
@@ -1,160 +0,0 @@
1
- ---
2
- name: deep-research
3
- description: Multi-source deep research using firecrawl and exa MCPs. Searches the web, synthesizes findings, and delivers cited reports with source attribution. Use when the user wants thorough research on any topic with evidence and citations.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Deep Research
9
-
10
- > **Drift-prone skill.** Firecrawl/Exa MCP tool names, quotas, and result
11
- > shapes change. Verify the configured MCP tools and current API docs before
12
- > promising coverage or quoting live source counts.
13
-
14
- Produce thorough, cited research reports from multiple web sources using firecrawl and exa MCP tools.
15
-
16
- ## When to Activate
17
-
18
- - User asks to research any topic in depth
19
- - Competitive analysis, technology evaluation, or market sizing
20
- - Due diligence on companies, investors, or technologies
21
- - Any question requiring synthesis from multiple sources
22
- - User says "research", "deep dive", "investigate", or "what's the current state of"
23
-
24
- ## MCP Requirements
25
-
26
- At least one of:
27
- - **firecrawl** — `firecrawl_search`, `firecrawl_scrape`, `firecrawl_crawl`
28
- - **exa** — `web_search_exa`, `web_search_advanced_exa`, `crawling_exa`
29
-
30
- Both together give the best coverage. Configure in `~/.claude.json` or `~/.codex/config.toml`.
31
-
32
- ## Workflow
33
-
34
- ### Step 1: Understand the Goal
35
-
36
- Ask 1-2 quick clarifying questions:
37
- - "What's your goal — learning, making a decision, or writing something?"
38
- - "Any specific angle or depth you want?"
39
-
40
- If the user says "just research it" — skip ahead with reasonable defaults.
41
-
42
- ### Step 2: Plan the Research
43
-
44
- Break the topic into 3-5 research sub-questions. Example:
45
- - Topic: "Impact of AI on healthcare"
46
- - What are the main AI applications in healthcare today?
47
- - What clinical outcomes have been measured?
48
- - What are the regulatory challenges?
49
- - What companies are leading this space?
50
- - What's the market size and growth trajectory?
51
-
52
- ### Step 3: Execute Multi-Source Search
53
-
54
- For EACH sub-question, search using available MCP tools:
55
-
56
- **With firecrawl:**
57
- ```
58
- firecrawl_search(query: "<sub-question keywords>", limit: 8)
59
- ```
60
-
61
- **With exa:**
62
- ```
63
- web_search_exa(query: "<sub-question keywords>", numResults: 8)
64
- web_search_advanced_exa(query: "<keywords>", numResults: 5, startPublishedDate: "2025-01-01")
65
- ```
66
-
67
- **Search strategy:**
68
- - Use 2-3 different keyword variations per sub-question
69
- - Mix general and news-focused queries
70
- - Aim for 15-30 unique sources total
71
- - Prioritize: academic, official, reputable news > blogs > forums
72
-
73
- ### Step 4: Deep-Read Key Sources
74
-
75
- For the most promising URLs, fetch full content:
76
-
77
- **With firecrawl:**
78
- ```
79
- firecrawl_scrape(url: "<url>")
80
- ```
81
-
82
- **With exa:**
83
- ```
84
- crawling_exa(url: "<url>", tokensNum: 5000)
85
- ```
86
-
87
- Read 3-5 key sources in full for depth. Do not rely only on search snippets.
88
-
89
- ### Step 5: Synthesize and Write Report
90
-
91
- Structure the report:
92
-
93
- ```markdown
94
- # [Topic]: Research Report
95
- *Generated: [date] | Sources: [N] | Confidence: [High/Medium/Low]*
96
-
97
- ## Executive Summary
98
- [3-5 sentence overview of key findings]
99
-
100
- ## 1. [First Major Theme]
101
- [Findings with inline citations]
102
- - Key point ([Source Name](url))
103
- - Supporting data ([Source Name](url))
104
-
105
- ## 2. [Second Major Theme]
106
- ...
107
-
108
- ## 3. [Third Major Theme]
109
- ...
110
-
111
- ## Key Takeaways
112
- - [Actionable insight 1]
113
- - [Actionable insight 2]
114
- - [Actionable insight 3]
115
-
116
- ## Sources
117
- 1. [Title](url) — [one-line summary]
118
- 2. ...
119
-
120
- ## Methodology
121
- Searched [N] queries across web and news. Analyzed [M] sources.
122
- Sub-questions investigated: [list]
123
- ```
124
-
125
- ### Step 6: Deliver
126
-
127
- - **Short topics**: Post the full report in chat
128
- - **Long reports**: Post the executive summary + key takeaways, save full report to a file
129
-
130
- ## Parallel Research with Subagents
131
-
132
- For broad topics, use Claude Code's Task tool to parallelize:
133
-
134
- ```
135
- Launch 3 research agents in parallel:
136
- 1. Agent 1: Research sub-questions 1-2
137
- 2. Agent 2: Research sub-questions 3-4
138
- 3. Agent 3: Research sub-question 5 + cross-cutting themes
139
- ```
140
-
141
- Each agent searches, reads sources, and returns findings. The main session synthesizes into the final report.
142
-
143
- ## Quality Rules
144
-
145
- 1. **Every claim needs a source.** No unsourced assertions.
146
- 2. **Cross-reference.** If only one source says it, flag it as unverified.
147
- 3. **Recency matters.** Prefer sources from the last 12 months.
148
- 4. **Acknowledge gaps.** If you couldn't find good info on a sub-question, say so.
149
- 5. **No hallucination.** If you don't know, say "insufficient data found."
150
- 6. **Separate fact from inference.** Label estimates, projections, and opinions clearly.
151
-
152
- ## Examples
153
-
154
- ```
155
- "Research the current state of nuclear fusion energy"
156
- "Deep dive into Rust vs Go for backend services in 2026"
157
- "Research the best strategies for bootstrapping a SaaS business"
158
- "What's happening with the US housing market right now?"
159
- "Investigate the competitive landscape for AI code editors"
160
- ```