arboris-cli 1.0.0 → 1.1.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 (451) hide show
  1. package/dist/cli.mjs +420 -0
  2. package/manifest.json +602 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,73 @@
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.
@@ -0,0 +1,430 @@
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 |
@@ -0,0 +1,160 @@
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
+ ```