claudecode-omc 5.5.2 → 5.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (433) hide show
  1. package/README.md +63 -0
  2. package/bundled/manifest.json +3 -2
  3. package/bundled/upstream/ecc/.omc-source/bundle.json +23 -0
  4. package/bundled/upstream/ecc/.omc-source/last-plan-apply.json +439 -0
  5. package/bundled/upstream/ecc/.omc-source/manifests/.claude-plugin/marketplace.json +47 -0
  6. package/bundled/upstream/ecc/agents/a11y-architect.md +141 -0
  7. package/bundled/upstream/ecc/agents/architect.md +211 -0
  8. package/bundled/upstream/ecc/agents/build-error-resolver.md +114 -0
  9. package/bundled/upstream/ecc/agents/chief-of-staff.md +151 -0
  10. package/bundled/upstream/ecc/agents/code-architect.md +71 -0
  11. package/bundled/upstream/ecc/agents/code-explorer.md +69 -0
  12. package/bundled/upstream/ecc/agents/code-reviewer.md +237 -0
  13. package/bundled/upstream/ecc/agents/code-simplifier.md +47 -0
  14. package/bundled/upstream/ecc/agents/comment-analyzer.md +45 -0
  15. package/bundled/upstream/ecc/agents/conversation-analyzer.md +52 -0
  16. package/bundled/upstream/ecc/agents/cpp-build-resolver.md +90 -0
  17. package/bundled/upstream/ecc/agents/cpp-reviewer.md +72 -0
  18. package/bundled/upstream/ecc/agents/csharp-reviewer.md +101 -0
  19. package/bundled/upstream/ecc/agents/dart-build-resolver.md +201 -0
  20. package/bundled/upstream/ecc/agents/database-reviewer.md +91 -0
  21. package/bundled/upstream/ecc/agents/doc-updater.md +107 -0
  22. package/bundled/upstream/ecc/agents/docs-lookup.md +68 -0
  23. package/bundled/upstream/ecc/agents/e2e-runner.md +107 -0
  24. package/bundled/upstream/ecc/agents/flutter-reviewer.md +243 -0
  25. package/bundled/upstream/ecc/agents/gan-evaluator.md +209 -0
  26. package/bundled/upstream/ecc/agents/gan-generator.md +131 -0
  27. package/bundled/upstream/ecc/agents/gan-planner.md +99 -0
  28. package/bundled/upstream/ecc/agents/go-build-resolver.md +94 -0
  29. package/bundled/upstream/ecc/agents/go-reviewer.md +76 -0
  30. package/bundled/upstream/ecc/agents/harness-optimizer.md +35 -0
  31. package/bundled/upstream/ecc/agents/healthcare-reviewer.md +83 -0
  32. package/bundled/upstream/ecc/agents/java-build-resolver.md +153 -0
  33. package/bundled/upstream/ecc/agents/java-reviewer.md +92 -0
  34. package/bundled/upstream/ecc/agents/kotlin-build-resolver.md +118 -0
  35. package/bundled/upstream/ecc/agents/kotlin-reviewer.md +159 -0
  36. package/bundled/upstream/ecc/agents/loop-operator.md +36 -0
  37. package/bundled/upstream/ecc/agents/opensource-forker.md +198 -0
  38. package/bundled/upstream/ecc/agents/opensource-packager.md +249 -0
  39. package/bundled/upstream/ecc/agents/opensource-sanitizer.md +188 -0
  40. package/bundled/upstream/ecc/agents/performance-optimizer.md +446 -0
  41. package/bundled/upstream/ecc/agents/planner.md +212 -0
  42. package/bundled/upstream/ecc/agents/pr-test-analyzer.md +45 -0
  43. package/bundled/upstream/ecc/agents/python-reviewer.md +98 -0
  44. package/bundled/upstream/ecc/agents/pytorch-build-resolver.md +120 -0
  45. package/bundled/upstream/ecc/agents/refactor-cleaner.md +85 -0
  46. package/bundled/upstream/ecc/agents/rust-build-resolver.md +148 -0
  47. package/bundled/upstream/ecc/agents/rust-reviewer.md +94 -0
  48. package/bundled/upstream/ecc/agents/security-reviewer.md +108 -0
  49. package/bundled/upstream/ecc/agents/seo-specialist.md +62 -0
  50. package/bundled/upstream/ecc/agents/silent-failure-hunter.md +50 -0
  51. package/bundled/upstream/ecc/agents/tdd-guide.md +91 -0
  52. package/bundled/upstream/ecc/agents/type-design-analyzer.md +41 -0
  53. package/bundled/upstream/ecc/agents/typescript-reviewer.md +112 -0
  54. package/bundled/upstream/ecc/commands/agent-sort.md +23 -0
  55. package/bundled/upstream/ecc/commands/aside.md +164 -0
  56. package/bundled/upstream/ecc/commands/build-fix.md +62 -0
  57. package/bundled/upstream/ecc/commands/checkpoint.md +74 -0
  58. package/bundled/upstream/ecc/commands/claw.md +23 -0
  59. package/bundled/upstream/ecc/commands/code-review.md +289 -0
  60. package/bundled/upstream/ecc/commands/context-budget.md +23 -0
  61. package/bundled/upstream/ecc/commands/cpp-build.md +173 -0
  62. package/bundled/upstream/ecc/commands/cpp-review.md +132 -0
  63. package/bundled/upstream/ecc/commands/cpp-test.md +251 -0
  64. package/bundled/upstream/ecc/commands/devfleet.md +23 -0
  65. package/bundled/upstream/ecc/commands/docs.md +23 -0
  66. package/bundled/upstream/ecc/commands/e2e.md +268 -0
  67. package/bundled/upstream/ecc/commands/eval.md +23 -0
  68. package/bundled/upstream/ecc/commands/evolve.md +178 -0
  69. package/bundled/upstream/ecc/commands/feature-dev.md +49 -0
  70. package/bundled/upstream/ecc/commands/flutter-build.md +164 -0
  71. package/bundled/upstream/ecc/commands/flutter-review.md +116 -0
  72. package/bundled/upstream/ecc/commands/flutter-test.md +144 -0
  73. package/bundled/upstream/ecc/commands/gan-build.md +99 -0
  74. package/bundled/upstream/ecc/commands/gan-design.md +35 -0
  75. package/bundled/upstream/ecc/commands/go-build.md +183 -0
  76. package/bundled/upstream/ecc/commands/go-review.md +148 -0
  77. package/bundled/upstream/ecc/commands/go-test.md +268 -0
  78. package/bundled/upstream/ecc/commands/gradle-build.md +70 -0
  79. package/bundled/upstream/ecc/commands/harness-audit.md +73 -0
  80. package/bundled/upstream/ecc/commands/hookify-configure.md +14 -0
  81. package/bundled/upstream/ecc/commands/hookify-help.md +46 -0
  82. package/bundled/upstream/ecc/commands/hookify-list.md +21 -0
  83. package/bundled/upstream/ecc/commands/hookify.md +50 -0
  84. package/bundled/upstream/ecc/commands/instinct-export.md +66 -0
  85. package/bundled/upstream/ecc/commands/instinct-import.md +114 -0
  86. package/bundled/upstream/ecc/commands/instinct-status.md +59 -0
  87. package/bundled/upstream/ecc/commands/jira.md +106 -0
  88. package/bundled/upstream/ecc/commands/kotlin-build.md +174 -0
  89. package/bundled/upstream/ecc/commands/kotlin-review.md +140 -0
  90. package/bundled/upstream/ecc/commands/kotlin-test.md +312 -0
  91. package/bundled/upstream/ecc/commands/learn-eval.md +116 -0
  92. package/bundled/upstream/ecc/commands/learn.md +70 -0
  93. package/bundled/upstream/ecc/commands/loop-start.md +32 -0
  94. package/bundled/upstream/ecc/commands/loop-status.md +24 -0
  95. package/bundled/upstream/ecc/commands/model-route.md +26 -0
  96. package/bundled/upstream/ecc/commands/multi-backend.md +158 -0
  97. package/bundled/upstream/ecc/commands/multi-execute.md +315 -0
  98. package/bundled/upstream/ecc/commands/multi-frontend.md +158 -0
  99. package/bundled/upstream/ecc/commands/multi-plan.md +268 -0
  100. package/bundled/upstream/ecc/commands/multi-workflow.md +191 -0
  101. package/bundled/upstream/ecc/commands/orchestrate.md +135 -0
  102. package/bundled/upstream/ecc/commands/plan.md +117 -0
  103. package/bundled/upstream/ecc/commands/pm2.md +272 -0
  104. package/bundled/upstream/ecc/commands/projects.md +39 -0
  105. package/bundled/upstream/ecc/commands/promote.md +41 -0
  106. package/bundled/upstream/ecc/commands/prompt-optimize.md +23 -0
  107. package/bundled/upstream/ecc/commands/prp-commit.md +112 -0
  108. package/bundled/upstream/ecc/commands/prp-implement.md +385 -0
  109. package/bundled/upstream/ecc/commands/prp-plan.md +502 -0
  110. package/bundled/upstream/ecc/commands/prp-pr.md +184 -0
  111. package/bundled/upstream/ecc/commands/prp-prd.md +447 -0
  112. package/bundled/upstream/ecc/commands/prune.md +31 -0
  113. package/bundled/upstream/ecc/commands/python-review.md +297 -0
  114. package/bundled/upstream/ecc/commands/quality-gate.md +29 -0
  115. package/bundled/upstream/ecc/commands/refactor-clean.md +80 -0
  116. package/bundled/upstream/ecc/commands/resume-session.md +156 -0
  117. package/bundled/upstream/ecc/commands/review-pr.md +37 -0
  118. package/bundled/upstream/ecc/commands/rules-distill.md +20 -0
  119. package/bundled/upstream/ecc/commands/rust-build.md +187 -0
  120. package/bundled/upstream/ecc/commands/rust-review.md +142 -0
  121. package/bundled/upstream/ecc/commands/rust-test.md +308 -0
  122. package/bundled/upstream/ecc/commands/santa-loop.md +175 -0
  123. package/bundled/upstream/ecc/commands/save-session.md +275 -0
  124. package/bundled/upstream/ecc/commands/sessions.md +339 -0
  125. package/bundled/upstream/ecc/commands/setup-pm.md +80 -0
  126. package/bundled/upstream/ecc/commands/skill-create.md +174 -0
  127. package/bundled/upstream/ecc/commands/skill-health.md +54 -0
  128. package/bundled/upstream/ecc/commands/tdd.md +231 -0
  129. package/bundled/upstream/ecc/commands/test-coverage.md +69 -0
  130. package/bundled/upstream/ecc/commands/update-codemaps.md +72 -0
  131. package/bundled/upstream/ecc/commands/update-docs.md +84 -0
  132. package/bundled/upstream/ecc/commands/verify.md +23 -0
  133. package/bundled/upstream/ecc/hooks/README.md +237 -0
  134. package/bundled/upstream/ecc/hooks/hooks.json +330 -0
  135. package/bundled/upstream/ecc/skills/accessibility/SKILL.md +146 -0
  136. package/bundled/upstream/ecc/skills/agent-eval/SKILL.md +145 -0
  137. package/bundled/upstream/ecc/skills/agent-harness-construction/SKILL.md +73 -0
  138. package/bundled/upstream/ecc/skills/agent-introspection-debugging/SKILL.md +153 -0
  139. package/bundled/upstream/ecc/skills/agent-payment-x402/SKILL.md +178 -0
  140. package/bundled/upstream/ecc/skills/agent-sort/SKILL.md +215 -0
  141. package/bundled/upstream/ecc/skills/agentic-engineering/SKILL.md +63 -0
  142. package/bundled/upstream/ecc/skills/ai-first-engineering/SKILL.md +51 -0
  143. package/bundled/upstream/ecc/skills/ai-regression-testing/SKILL.md +385 -0
  144. package/bundled/upstream/ecc/skills/android-clean-architecture/SKILL.md +339 -0
  145. package/bundled/upstream/ecc/skills/api-connector-builder/SKILL.md +120 -0
  146. package/bundled/upstream/ecc/skills/api-design/SKILL.md +523 -0
  147. package/bundled/upstream/ecc/skills/architecture-decision-records/SKILL.md +179 -0
  148. package/bundled/upstream/ecc/skills/article-writing/SKILL.md +79 -0
  149. package/bundled/upstream/ecc/skills/automation-audit-ops/SKILL.md +142 -0
  150. package/bundled/upstream/ecc/skills/autonomous-agent-harness/SKILL.md +267 -0
  151. package/bundled/upstream/ecc/skills/autonomous-loops/SKILL.md +610 -0
  152. package/bundled/upstream/ecc/skills/backend-patterns/SKILL.md +598 -0
  153. package/bundled/upstream/ecc/skills/benchmark/SKILL.md +93 -0
  154. package/bundled/upstream/ecc/skills/blueprint/SKILL.md +105 -0
  155. package/bundled/upstream/ecc/skills/brand-voice/SKILL.md +97 -0
  156. package/bundled/upstream/ecc/skills/brand-voice/references/voice-profile-schema.md +55 -0
  157. package/bundled/upstream/ecc/skills/browser-qa/SKILL.md +87 -0
  158. package/bundled/upstream/ecc/skills/bun-runtime/SKILL.md +84 -0
  159. package/bundled/upstream/ecc/skills/canary-watch/SKILL.md +99 -0
  160. package/bundled/upstream/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
  161. package/bundled/upstream/ecc/skills/ck/SKILL.md +147 -0
  162. package/bundled/upstream/ecc/skills/ck/commands/forget.mjs +44 -0
  163. package/bundled/upstream/ecc/skills/ck/commands/info.mjs +24 -0
  164. package/bundled/upstream/ecc/skills/ck/commands/init.mjs +143 -0
  165. package/bundled/upstream/ecc/skills/ck/commands/list.mjs +40 -0
  166. package/bundled/upstream/ecc/skills/ck/commands/migrate.mjs +202 -0
  167. package/bundled/upstream/ecc/skills/ck/commands/resume.mjs +36 -0
  168. package/bundled/upstream/ecc/skills/ck/commands/save.mjs +210 -0
  169. package/bundled/upstream/ecc/skills/ck/commands/shared.mjs +387 -0
  170. package/bundled/upstream/ecc/skills/ck/hooks/session-start.mjs +224 -0
  171. package/bundled/upstream/ecc/skills/claude-api/SKILL.md +337 -0
  172. package/bundled/upstream/ecc/skills/claude-devfleet/SKILL.md +103 -0
  173. package/bundled/upstream/ecc/skills/click-path-audit/SKILL.md +244 -0
  174. package/bundled/upstream/ecc/skills/clickhouse-io/SKILL.md +439 -0
  175. package/bundled/upstream/ecc/skills/code-tour/SKILL.md +236 -0
  176. package/bundled/upstream/ecc/skills/codebase-onboarding/SKILL.md +233 -0
  177. package/bundled/upstream/ecc/skills/coding-standards/SKILL.md +549 -0
  178. package/bundled/upstream/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  179. package/bundled/upstream/ecc/skills/configure-ecc/SKILL.md +367 -0
  180. package/bundled/upstream/ecc/skills/connections-optimizer/SKILL.md +189 -0
  181. package/bundled/upstream/ecc/skills/content-engine/SKILL.md +131 -0
  182. package/bundled/upstream/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
  183. package/bundled/upstream/ecc/skills/context-budget/SKILL.md +135 -0
  184. package/bundled/upstream/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
  185. package/bundled/upstream/ecc/skills/continuous-learning/SKILL.md +123 -0
  186. package/bundled/upstream/ecc/skills/continuous-learning/config.json +18 -0
  187. package/bundled/upstream/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
  188. package/bundled/upstream/ecc/skills/continuous-learning-v2/SKILL.md +346 -0
  189. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +282 -0
  190. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
  191. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  192. package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  193. package/bundled/upstream/ecc/skills/continuous-learning-v2/config.json +8 -0
  194. package/bundled/upstream/ecc/skills/continuous-learning-v2/hooks/observe.sh +460 -0
  195. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +243 -0
  196. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  197. package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +984 -0
  198. package/bundled/upstream/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  199. package/bundled/upstream/ecc/skills/council/SKILL.md +203 -0
  200. package/bundled/upstream/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
  201. package/bundled/upstream/ecc/skills/cpp-testing/SKILL.md +324 -0
  202. package/bundled/upstream/ecc/skills/crosspost/SKILL.md +111 -0
  203. package/bundled/upstream/ecc/skills/csharp-testing/SKILL.md +321 -0
  204. package/bundled/upstream/ecc/skills/customer-billing-ops/SKILL.md +140 -0
  205. package/bundled/upstream/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
  206. package/bundled/upstream/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
  207. package/bundled/upstream/ecc/skills/dashboard-builder/SKILL.md +108 -0
  208. package/bundled/upstream/ecc/skills/data-scraper-agent/SKILL.md +764 -0
  209. package/bundled/upstream/ecc/skills/database-migrations/SKILL.md +429 -0
  210. package/bundled/upstream/ecc/skills/deep-research/SKILL.md +155 -0
  211. package/bundled/upstream/ecc/skills/defi-amm-security/SKILL.md +160 -0
  212. package/bundled/upstream/ecc/skills/deployment-patterns/SKILL.md +427 -0
  213. package/bundled/upstream/ecc/skills/design-system/SKILL.md +82 -0
  214. package/bundled/upstream/ecc/skills/django-patterns/SKILL.md +734 -0
  215. package/bundled/upstream/ecc/skills/django-security/SKILL.md +593 -0
  216. package/bundled/upstream/ecc/skills/django-tdd/SKILL.md +729 -0
  217. package/bundled/upstream/ecc/skills/django-verification/SKILL.md +469 -0
  218. package/bundled/upstream/ecc/skills/dmux-workflows/SKILL.md +191 -0
  219. package/bundled/upstream/ecc/skills/docker-patterns/SKILL.md +364 -0
  220. package/bundled/upstream/ecc/skills/documentation-lookup/SKILL.md +90 -0
  221. package/bundled/upstream/ecc/skills/dotnet-patterns/SKILL.md +321 -0
  222. package/bundled/upstream/ecc/skills/e2e-testing/SKILL.md +326 -0
  223. package/bundled/upstream/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
  224. package/bundled/upstream/ecc/skills/email-ops/SKILL.md +121 -0
  225. package/bundled/upstream/ecc/skills/energy-procurement/SKILL.md +228 -0
  226. package/bundled/upstream/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
  227. package/bundled/upstream/ecc/skills/eval-harness/SKILL.md +270 -0
  228. package/bundled/upstream/ecc/skills/evm-token-decimals/SKILL.md +130 -0
  229. package/bundled/upstream/ecc/skills/exa-search/SKILL.md +103 -0
  230. package/bundled/upstream/ecc/skills/fal-ai-media/SKILL.md +284 -0
  231. package/bundled/upstream/ecc/skills/finance-billing-ops/SKILL.md +127 -0
  232. package/bundled/upstream/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
  233. package/bundled/upstream/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
  234. package/bundled/upstream/ecc/skills/frontend-design/SKILL.md +145 -0
  235. package/bundled/upstream/ecc/skills/frontend-patterns/SKILL.md +642 -0
  236. package/bundled/upstream/ecc/skills/frontend-slides/SKILL.md +184 -0
  237. package/bundled/upstream/ecc/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  238. package/bundled/upstream/ecc/skills/gan-style-harness/SKILL.md +278 -0
  239. package/bundled/upstream/ecc/skills/gateguard/SKILL.md +121 -0
  240. package/bundled/upstream/ecc/skills/git-workflow/SKILL.md +715 -0
  241. package/bundled/upstream/ecc/skills/github-ops/SKILL.md +144 -0
  242. package/bundled/upstream/ecc/skills/golang-patterns/SKILL.md +674 -0
  243. package/bundled/upstream/ecc/skills/golang-testing/SKILL.md +720 -0
  244. package/bundled/upstream/ecc/skills/google-workspace-ops/SKILL.md +95 -0
  245. package/bundled/upstream/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  246. package/bundled/upstream/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
  247. package/bundled/upstream/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
  248. package/bundled/upstream/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
  249. package/bundled/upstream/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
  250. package/bundled/upstream/ecc/skills/hipaa-compliance/SKILL.md +78 -0
  251. package/bundled/upstream/ecc/skills/hookify-rules/SKILL.md +128 -0
  252. package/bundled/upstream/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
  253. package/bundled/upstream/ecc/skills/investor-materials/SKILL.md +96 -0
  254. package/bundled/upstream/ecc/skills/investor-outreach/SKILL.md +91 -0
  255. package/bundled/upstream/ecc/skills/iterative-retrieval/SKILL.md +211 -0
  256. package/bundled/upstream/ecc/skills/java-coding-standards/SKILL.md +147 -0
  257. package/bundled/upstream/ecc/skills/jira-integration/SKILL.md +293 -0
  258. package/bundled/upstream/ecc/skills/jpa-patterns/SKILL.md +151 -0
  259. package/bundled/upstream/ecc/skills/knowledge-ops/SKILL.md +154 -0
  260. package/bundled/upstream/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  261. package/bundled/upstream/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  262. package/bundled/upstream/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  263. package/bundled/upstream/ecc/skills/kotlin-patterns/SKILL.md +711 -0
  264. package/bundled/upstream/ecc/skills/kotlin-testing/SKILL.md +824 -0
  265. package/bundled/upstream/ecc/skills/laravel-patterns/SKILL.md +415 -0
  266. package/bundled/upstream/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
  267. package/bundled/upstream/ecc/skills/laravel-security/SKILL.md +285 -0
  268. package/bundled/upstream/ecc/skills/laravel-tdd/SKILL.md +283 -0
  269. package/bundled/upstream/ecc/skills/laravel-verification/SKILL.md +179 -0
  270. package/bundled/upstream/ecc/skills/lead-intelligence/SKILL.md +321 -0
  271. package/bundled/upstream/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  272. package/bundled/upstream/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  273. package/bundled/upstream/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  274. package/bundled/upstream/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  275. package/bundled/upstream/ecc/skills/liquid-glass-design/SKILL.md +279 -0
  276. package/bundled/upstream/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
  277. package/bundled/upstream/ecc/skills/logistics-exception-management/SKILL.md +222 -0
  278. package/bundled/upstream/ecc/skills/manim-video/SKILL.md +89 -0
  279. package/bundled/upstream/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
  280. package/bundled/upstream/ecc/skills/market-research/SKILL.md +75 -0
  281. package/bundled/upstream/ecc/skills/mcp-server-patterns/SKILL.md +69 -0
  282. package/bundled/upstream/ecc/skills/messages-ops/SKILL.md +104 -0
  283. package/bundled/upstream/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
  284. package/bundled/upstream/ecc/skills/nestjs-patterns/SKILL.md +230 -0
  285. package/bundled/upstream/ecc/skills/nextjs-turbopack/SKILL.md +44 -0
  286. package/bundled/upstream/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
  287. package/bundled/upstream/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
  288. package/bundled/upstream/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
  289. package/bundled/upstream/ecc/skills/openclaw-persona-forge/SKILL.md +296 -0
  290. package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
  291. package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
  292. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  293. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  294. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  295. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  296. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  297. package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
  298. package/bundled/upstream/ecc/skills/opensource-pipeline/SKILL.md +255 -0
  299. package/bundled/upstream/ecc/skills/perl-patterns/SKILL.md +504 -0
  300. package/bundled/upstream/ecc/skills/perl-security/SKILL.md +503 -0
  301. package/bundled/upstream/ecc/skills/perl-testing/SKILL.md +475 -0
  302. package/bundled/upstream/ecc/skills/plankton-code-quality/SKILL.md +236 -0
  303. package/bundled/upstream/ecc/skills/postgres-patterns/SKILL.md +147 -0
  304. package/bundled/upstream/ecc/skills/product-capability/SKILL.md +141 -0
  305. package/bundled/upstream/ecc/skills/product-lens/SKILL.md +92 -0
  306. package/bundled/upstream/ecc/skills/production-scheduling/SKILL.md +238 -0
  307. package/bundled/upstream/ecc/skills/project-flow-ops/SKILL.md +111 -0
  308. package/bundled/upstream/ecc/skills/prompt-optimizer/SKILL.md +397 -0
  309. package/bundled/upstream/ecc/skills/python-patterns/SKILL.md +750 -0
  310. package/bundled/upstream/ecc/skills/python-testing/SKILL.md +816 -0
  311. package/bundled/upstream/ecc/skills/pytorch-patterns/SKILL.md +396 -0
  312. package/bundled/upstream/ecc/skills/quality-nonconformance/SKILL.md +260 -0
  313. package/bundled/upstream/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  314. package/bundled/upstream/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  315. package/bundled/upstream/ecc/skills/remotion-video-creation/SKILL.md +43 -0
  316. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
  317. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
  318. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  319. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  320. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  321. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
  322. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
  323. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  324. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
  325. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
  326. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
  327. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
  328. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  329. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
  330. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  331. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  332. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  333. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
  334. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/images.md +130 -0
  335. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  336. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
  337. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  338. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  339. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
  340. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
  341. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
  342. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
  343. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  344. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
  345. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
  346. package/bundled/upstream/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
  347. package/bundled/upstream/ecc/skills/repo-scan/SKILL.md +78 -0
  348. package/bundled/upstream/ecc/skills/research-ops/SKILL.md +112 -0
  349. package/bundled/upstream/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
  350. package/bundled/upstream/ecc/skills/rules-distill/SKILL.md +264 -0
  351. package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
  352. package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
  353. package/bundled/upstream/ecc/skills/rust-patterns/SKILL.md +499 -0
  354. package/bundled/upstream/ecc/skills/rust-testing/SKILL.md +500 -0
  355. package/bundled/upstream/ecc/skills/safety-guard/SKILL.md +75 -0
  356. package/bundled/upstream/ecc/skills/santa-method/SKILL.md +306 -0
  357. package/bundled/upstream/ecc/skills/search-first/SKILL.md +161 -0
  358. package/bundled/upstream/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
  359. package/bundled/upstream/ecc/skills/security-review/SKILL.md +495 -0
  360. package/bundled/upstream/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
  361. package/bundled/upstream/ecc/skills/security-scan/SKILL.md +165 -0
  362. package/bundled/upstream/ecc/skills/seo/SKILL.md +154 -0
  363. package/bundled/upstream/ecc/skills/skill-comply/SKILL.md +58 -0
  364. package/bundled/upstream/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  365. package/bundled/upstream/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  366. package/bundled/upstream/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  367. package/bundled/upstream/ecc/skills/skill-comply/prompts/classifier.md +24 -0
  368. package/bundled/upstream/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
  369. package/bundled/upstream/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
  370. package/bundled/upstream/ecc/skills/skill-comply/pyproject.toml +15 -0
  371. package/bundled/upstream/ecc/skills/skill-comply/scripts/__init__.py +0 -0
  372. package/bundled/upstream/ecc/skills/skill-comply/scripts/classifier.py +85 -0
  373. package/bundled/upstream/ecc/skills/skill-comply/scripts/grader.py +124 -0
  374. package/bundled/upstream/ecc/skills/skill-comply/scripts/parser.py +107 -0
  375. package/bundled/upstream/ecc/skills/skill-comply/scripts/report.py +170 -0
  376. package/bundled/upstream/ecc/skills/skill-comply/scripts/run.py +127 -0
  377. package/bundled/upstream/ecc/skills/skill-comply/scripts/runner.py +161 -0
  378. package/bundled/upstream/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
  379. package/bundled/upstream/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
  380. package/bundled/upstream/ecc/skills/skill-comply/scripts/utils.py +13 -0
  381. package/bundled/upstream/ecc/skills/skill-comply/tests/test_grader.py +197 -0
  382. package/bundled/upstream/ecc/skills/skill-comply/tests/test_parser.py +90 -0
  383. package/bundled/upstream/ecc/skills/skill-stocktake/SKILL.md +193 -0
  384. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  385. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
  386. package/bundled/upstream/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
  387. package/bundled/upstream/ecc/skills/social-graph-ranker/SKILL.md +154 -0
  388. package/bundled/upstream/ecc/skills/springboot-patterns/SKILL.md +314 -0
  389. package/bundled/upstream/ecc/skills/springboot-security/SKILL.md +272 -0
  390. package/bundled/upstream/ecc/skills/springboot-tdd/SKILL.md +158 -0
  391. package/bundled/upstream/ecc/skills/springboot-verification/SKILL.md +231 -0
  392. package/bundled/upstream/ecc/skills/strategic-compact/SKILL.md +131 -0
  393. package/bundled/upstream/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
  394. package/bundled/upstream/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
  395. package/bundled/upstream/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
  396. package/bundled/upstream/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
  397. package/bundled/upstream/ecc/skills/swiftui-patterns/SKILL.md +259 -0
  398. package/bundled/upstream/ecc/skills/tdd-workflow/SKILL.md +463 -0
  399. package/bundled/upstream/ecc/skills/team-builder/SKILL.md +168 -0
  400. package/bundled/upstream/ecc/skills/terminal-ops/SKILL.md +109 -0
  401. package/bundled/upstream/ecc/skills/token-budget-advisor/SKILL.md +133 -0
  402. package/bundled/upstream/ecc/skills/ui-demo/SKILL.md +465 -0
  403. package/bundled/upstream/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
  404. package/bundled/upstream/ecc/skills/verification-loop/SKILL.md +126 -0
  405. package/bundled/upstream/ecc/skills/video-editing/SKILL.md +310 -0
  406. package/bundled/upstream/ecc/skills/videodb/SKILL.md +374 -0
  407. package/bundled/upstream/ecc/skills/videodb/reference/api-reference.md +550 -0
  408. package/bundled/upstream/ecc/skills/videodb/reference/capture-reference.md +407 -0
  409. package/bundled/upstream/ecc/skills/videodb/reference/capture.md +101 -0
  410. package/bundled/upstream/ecc/skills/videodb/reference/editor.md +443 -0
  411. package/bundled/upstream/ecc/skills/videodb/reference/generative.md +331 -0
  412. package/bundled/upstream/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
  413. package/bundled/upstream/ecc/skills/videodb/reference/rtstream.md +65 -0
  414. package/bundled/upstream/ecc/skills/videodb/reference/search.md +230 -0
  415. package/bundled/upstream/ecc/skills/videodb/reference/streaming.md +406 -0
  416. package/bundled/upstream/ecc/skills/videodb/reference/use-cases.md +118 -0
  417. package/bundled/upstream/ecc/skills/videodb/scripts/ws_listener.py +282 -0
  418. package/bundled/upstream/ecc/skills/visa-doc-translate/README.md +86 -0
  419. package/bundled/upstream/ecc/skills/visa-doc-translate/SKILL.md +117 -0
  420. package/bundled/upstream/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
  421. package/bundled/upstream/ecc/skills/x-api/SKILL.md +230 -0
  422. package/bundled/upstream/superpowers/.omc-source/last-plan-apply.json +22 -0
  423. package/package.json +3 -1
  424. package/src/catalog/source-catalog.js +391 -0
  425. package/src/cli/artifact.js +3 -2
  426. package/src/cli/doctor.js +25 -4
  427. package/src/cli/index.js +19 -0
  428. package/src/cli/plan.js +220 -0
  429. package/src/cli/setup.js +209 -12
  430. package/src/cli/source.js +110 -3
  431. package/src/config/paths.js +31 -0
  432. package/src/config/sources.js +103 -10
  433. package/src/merge/hook-merger.js +1 -0
@@ -0,0 +1,439 @@
1
+ ---
2
+ name: clickhouse-io
3
+ description: ClickHouse database patterns, query optimization, analytics, and data engineering best practices for high-performance analytical workloads.
4
+ origin: ECC
5
+ ---
6
+
7
+ # ClickHouse Analytics Patterns
8
+
9
+ ClickHouse-specific patterns for high-performance analytics and data engineering.
10
+
11
+ ## When to Activate
12
+
13
+ - Designing ClickHouse table schemas (MergeTree engine selection)
14
+ - Writing analytical queries (aggregations, window functions, joins)
15
+ - Optimizing query performance (partition pruning, projections, materialized views)
16
+ - Ingesting large volumes of data (batch inserts, Kafka integration)
17
+ - Migrating from PostgreSQL/MySQL to ClickHouse for analytics
18
+ - Implementing real-time dashboards or time-series analytics
19
+
20
+ ## Overview
21
+
22
+ ClickHouse is a column-oriented database management system (DBMS) for online analytical processing (OLAP). It's optimized for fast analytical queries on large datasets.
23
+
24
+ **Key Features:**
25
+ - Column-oriented storage
26
+ - Data compression
27
+ - Parallel query execution
28
+ - Distributed queries
29
+ - Real-time analytics
30
+
31
+ ## Table Design Patterns
32
+
33
+ ### MergeTree Engine (Most Common)
34
+
35
+ ```sql
36
+ CREATE TABLE markets_analytics (
37
+ date Date,
38
+ market_id String,
39
+ market_name String,
40
+ volume UInt64,
41
+ trades UInt32,
42
+ unique_traders UInt32,
43
+ avg_trade_size Float64,
44
+ created_at DateTime
45
+ ) ENGINE = MergeTree()
46
+ PARTITION BY toYYYYMM(date)
47
+ ORDER BY (date, market_id)
48
+ SETTINGS index_granularity = 8192;
49
+ ```
50
+
51
+ ### ReplacingMergeTree (Deduplication)
52
+
53
+ ```sql
54
+ -- For data that may have duplicates (e.g., from multiple sources)
55
+ CREATE TABLE user_events (
56
+ event_id String,
57
+ user_id String,
58
+ event_type String,
59
+ timestamp DateTime,
60
+ properties String
61
+ ) ENGINE = ReplacingMergeTree()
62
+ PARTITION BY toYYYYMM(timestamp)
63
+ ORDER BY (user_id, event_id, timestamp)
64
+ PRIMARY KEY (user_id, event_id);
65
+ ```
66
+
67
+ ### AggregatingMergeTree (Pre-aggregation)
68
+
69
+ ```sql
70
+ -- For maintaining aggregated metrics
71
+ CREATE TABLE market_stats_hourly (
72
+ hour DateTime,
73
+ market_id String,
74
+ total_volume AggregateFunction(sum, UInt64),
75
+ total_trades AggregateFunction(count, UInt32),
76
+ unique_users AggregateFunction(uniq, String)
77
+ ) ENGINE = AggregatingMergeTree()
78
+ PARTITION BY toYYYYMM(hour)
79
+ ORDER BY (hour, market_id);
80
+
81
+ -- Query aggregated data
82
+ SELECT
83
+ hour,
84
+ market_id,
85
+ sumMerge(total_volume) AS volume,
86
+ countMerge(total_trades) AS trades,
87
+ uniqMerge(unique_users) AS users
88
+ FROM market_stats_hourly
89
+ WHERE hour >= toStartOfHour(now() - INTERVAL 24 HOUR)
90
+ GROUP BY hour, market_id
91
+ ORDER BY hour DESC;
92
+ ```
93
+
94
+ ## Query Optimization Patterns
95
+
96
+ ### Efficient Filtering
97
+
98
+ ```sql
99
+ -- PASS: GOOD: Use indexed columns first
100
+ SELECT *
101
+ FROM markets_analytics
102
+ WHERE date >= '2025-01-01'
103
+ AND market_id = 'market-123'
104
+ AND volume > 1000
105
+ ORDER BY date DESC
106
+ LIMIT 100;
107
+
108
+ -- FAIL: BAD: Filter on non-indexed columns first
109
+ SELECT *
110
+ FROM markets_analytics
111
+ WHERE volume > 1000
112
+ AND market_name LIKE '%election%'
113
+ AND date >= '2025-01-01';
114
+ ```
115
+
116
+ ### Aggregations
117
+
118
+ ```sql
119
+ -- PASS: GOOD: Use ClickHouse-specific aggregation functions
120
+ SELECT
121
+ toStartOfDay(created_at) AS day,
122
+ market_id,
123
+ sum(volume) AS total_volume,
124
+ count() AS total_trades,
125
+ uniq(trader_id) AS unique_traders,
126
+ avg(trade_size) AS avg_size
127
+ FROM trades
128
+ WHERE created_at >= today() - INTERVAL 7 DAY
129
+ GROUP BY day, market_id
130
+ ORDER BY day DESC, total_volume DESC;
131
+
132
+ -- PASS: Use quantile for percentiles (more efficient than percentile)
133
+ SELECT
134
+ quantile(0.50)(trade_size) AS median,
135
+ quantile(0.95)(trade_size) AS p95,
136
+ quantile(0.99)(trade_size) AS p99
137
+ FROM trades
138
+ WHERE created_at >= now() - INTERVAL 1 HOUR;
139
+ ```
140
+
141
+ ### Window Functions
142
+
143
+ ```sql
144
+ -- Calculate running totals
145
+ SELECT
146
+ date,
147
+ market_id,
148
+ volume,
149
+ sum(volume) OVER (
150
+ PARTITION BY market_id
151
+ ORDER BY date
152
+ ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
153
+ ) AS cumulative_volume
154
+ FROM markets_analytics
155
+ WHERE date >= today() - INTERVAL 30 DAY
156
+ ORDER BY market_id, date;
157
+ ```
158
+
159
+ ## Data Insertion Patterns
160
+
161
+ ### Bulk Insert (Recommended)
162
+
163
+ ```typescript
164
+ import { ClickHouse } from 'clickhouse'
165
+
166
+ const clickhouse = new ClickHouse({
167
+ url: process.env.CLICKHOUSE_URL,
168
+ port: 8123,
169
+ basicAuth: {
170
+ username: process.env.CLICKHOUSE_USER,
171
+ password: process.env.CLICKHOUSE_PASSWORD
172
+ }
173
+ })
174
+
175
+ // PASS: Batch insert (efficient)
176
+ async function bulkInsertTrades(trades: Trade[]) {
177
+ const values = trades.map(trade => `(
178
+ '${trade.id}',
179
+ '${trade.market_id}',
180
+ '${trade.user_id}',
181
+ ${trade.amount},
182
+ '${trade.timestamp.toISOString()}'
183
+ )`).join(',')
184
+
185
+ await clickhouse.query(`
186
+ INSERT INTO trades (id, market_id, user_id, amount, timestamp)
187
+ VALUES ${values}
188
+ `).toPromise()
189
+ }
190
+
191
+ // FAIL: Individual inserts (slow)
192
+ async function insertTrade(trade: Trade) {
193
+ // Don't do this in a loop!
194
+ await clickhouse.query(`
195
+ INSERT INTO trades VALUES ('${trade.id}', ...)
196
+ `).toPromise()
197
+ }
198
+ ```
199
+
200
+ ### Streaming Insert
201
+
202
+ ```typescript
203
+ // For continuous data ingestion
204
+ import { createWriteStream } from 'fs'
205
+ import { pipeline } from 'stream/promises'
206
+
207
+ async function streamInserts() {
208
+ const stream = clickhouse.insert('trades').stream()
209
+
210
+ for await (const batch of dataSource) {
211
+ stream.write(batch)
212
+ }
213
+
214
+ await stream.end()
215
+ }
216
+ ```
217
+
218
+ ## Materialized Views
219
+
220
+ ### Real-time Aggregations
221
+
222
+ ```sql
223
+ -- Create materialized view for hourly stats
224
+ CREATE MATERIALIZED VIEW market_stats_hourly_mv
225
+ TO market_stats_hourly
226
+ AS SELECT
227
+ toStartOfHour(timestamp) AS hour,
228
+ market_id,
229
+ sumState(amount) AS total_volume,
230
+ countState() AS total_trades,
231
+ uniqState(user_id) AS unique_users
232
+ FROM trades
233
+ GROUP BY hour, market_id;
234
+
235
+ -- Query the materialized view
236
+ SELECT
237
+ hour,
238
+ market_id,
239
+ sumMerge(total_volume) AS volume,
240
+ countMerge(total_trades) AS trades,
241
+ uniqMerge(unique_users) AS users
242
+ FROM market_stats_hourly
243
+ WHERE hour >= now() - INTERVAL 24 HOUR
244
+ GROUP BY hour, market_id;
245
+ ```
246
+
247
+ ## Performance Monitoring
248
+
249
+ ### Query Performance
250
+
251
+ ```sql
252
+ -- Check slow queries
253
+ SELECT
254
+ query_id,
255
+ user,
256
+ query,
257
+ query_duration_ms,
258
+ read_rows,
259
+ read_bytes,
260
+ memory_usage
261
+ FROM system.query_log
262
+ WHERE type = 'QueryFinish'
263
+ AND query_duration_ms > 1000
264
+ AND event_time >= now() - INTERVAL 1 HOUR
265
+ ORDER BY query_duration_ms DESC
266
+ LIMIT 10;
267
+ ```
268
+
269
+ ### Table Statistics
270
+
271
+ ```sql
272
+ -- Check table sizes
273
+ SELECT
274
+ database,
275
+ table,
276
+ formatReadableSize(sum(bytes)) AS size,
277
+ sum(rows) AS rows,
278
+ max(modification_time) AS latest_modification
279
+ FROM system.parts
280
+ WHERE active
281
+ GROUP BY database, table
282
+ ORDER BY sum(bytes) DESC;
283
+ ```
284
+
285
+ ## Common Analytics Queries
286
+
287
+ ### Time Series Analysis
288
+
289
+ ```sql
290
+ -- Daily active users
291
+ SELECT
292
+ toDate(timestamp) AS date,
293
+ uniq(user_id) AS daily_active_users
294
+ FROM events
295
+ WHERE timestamp >= today() - INTERVAL 30 DAY
296
+ GROUP BY date
297
+ ORDER BY date;
298
+
299
+ -- Retention analysis
300
+ SELECT
301
+ signup_date,
302
+ countIf(days_since_signup = 0) AS day_0,
303
+ countIf(days_since_signup = 1) AS day_1,
304
+ countIf(days_since_signup = 7) AS day_7,
305
+ countIf(days_since_signup = 30) AS day_30
306
+ FROM (
307
+ SELECT
308
+ user_id,
309
+ min(toDate(timestamp)) AS signup_date,
310
+ toDate(timestamp) AS activity_date,
311
+ dateDiff('day', signup_date, activity_date) AS days_since_signup
312
+ FROM events
313
+ GROUP BY user_id, activity_date
314
+ )
315
+ GROUP BY signup_date
316
+ ORDER BY signup_date DESC;
317
+ ```
318
+
319
+ ### Funnel Analysis
320
+
321
+ ```sql
322
+ -- Conversion funnel
323
+ SELECT
324
+ countIf(step = 'viewed_market') AS viewed,
325
+ countIf(step = 'clicked_trade') AS clicked,
326
+ countIf(step = 'completed_trade') AS completed,
327
+ round(clicked / viewed * 100, 2) AS view_to_click_rate,
328
+ round(completed / clicked * 100, 2) AS click_to_completion_rate
329
+ FROM (
330
+ SELECT
331
+ user_id,
332
+ session_id,
333
+ event_type AS step
334
+ FROM events
335
+ WHERE event_date = today()
336
+ )
337
+ GROUP BY session_id;
338
+ ```
339
+
340
+ ### Cohort Analysis
341
+
342
+ ```sql
343
+ -- User cohorts by signup month
344
+ SELECT
345
+ toStartOfMonth(signup_date) AS cohort,
346
+ toStartOfMonth(activity_date) AS month,
347
+ dateDiff('month', cohort, month) AS months_since_signup,
348
+ count(DISTINCT user_id) AS active_users
349
+ FROM (
350
+ SELECT
351
+ user_id,
352
+ min(toDate(timestamp)) OVER (PARTITION BY user_id) AS signup_date,
353
+ toDate(timestamp) AS activity_date
354
+ FROM events
355
+ )
356
+ GROUP BY cohort, month, months_since_signup
357
+ ORDER BY cohort, months_since_signup;
358
+ ```
359
+
360
+ ## Data Pipeline Patterns
361
+
362
+ ### ETL Pattern
363
+
364
+ ```typescript
365
+ // Extract, Transform, Load
366
+ async function etlPipeline() {
367
+ // 1. Extract from source
368
+ const rawData = await extractFromPostgres()
369
+
370
+ // 2. Transform
371
+ const transformed = rawData.map(row => ({
372
+ date: new Date(row.created_at).toISOString().split('T')[0],
373
+ market_id: row.market_slug,
374
+ volume: parseFloat(row.total_volume),
375
+ trades: parseInt(row.trade_count)
376
+ }))
377
+
378
+ // 3. Load to ClickHouse
379
+ await bulkInsertToClickHouse(transformed)
380
+ }
381
+
382
+ // Run periodically
383
+ setInterval(etlPipeline, 60 * 60 * 1000) // Every hour
384
+ ```
385
+
386
+ ### Change Data Capture (CDC)
387
+
388
+ ```typescript
389
+ // Listen to PostgreSQL changes and sync to ClickHouse
390
+ import { Client } from 'pg'
391
+
392
+ const pgClient = new Client({ connectionString: process.env.DATABASE_URL })
393
+
394
+ pgClient.query('LISTEN market_updates')
395
+
396
+ pgClient.on('notification', async (msg) => {
397
+ const update = JSON.parse(msg.payload)
398
+
399
+ await clickhouse.insert('market_updates', [
400
+ {
401
+ market_id: update.id,
402
+ event_type: update.operation, // INSERT, UPDATE, DELETE
403
+ timestamp: new Date(),
404
+ data: JSON.stringify(update.new_data)
405
+ }
406
+ ])
407
+ })
408
+ ```
409
+
410
+ ## Best Practices
411
+
412
+ ### 1. Partitioning Strategy
413
+ - Partition by time (usually month or day)
414
+ - Avoid too many partitions (performance impact)
415
+ - Use DATE type for partition key
416
+
417
+ ### 2. Ordering Key
418
+ - Put most frequently filtered columns first
419
+ - Consider cardinality (high cardinality first)
420
+ - Order impacts compression
421
+
422
+ ### 3. Data Types
423
+ - Use smallest appropriate type (UInt32 vs UInt64)
424
+ - Use LowCardinality for repeated strings
425
+ - Use Enum for categorical data
426
+
427
+ ### 4. Avoid
428
+ - SELECT * (specify columns)
429
+ - FINAL (merge data before query instead)
430
+ - Too many JOINs (denormalize for analytics)
431
+ - Small frequent inserts (batch instead)
432
+
433
+ ### 5. Monitoring
434
+ - Track query performance
435
+ - Monitor disk usage
436
+ - Check merge operations
437
+ - Review slow query log
438
+
439
+ **Remember**: ClickHouse excels at analytical workloads. Design tables for your query patterns, batch inserts, and leverage materialized views for real-time aggregations.
@@ -0,0 +1,236 @@
1
+ ---
2
+ name: code-tour
3
+ description: Create CodeTour `.tour` files — persona-targeted, step-by-step walkthroughs with real file and line anchors. Use for onboarding tours, architecture walkthroughs, PR tours, RCA tours, and structured "explain how this works" requests.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Code Tour
8
+
9
+ Create **CodeTour** `.tour` files for codebase walkthroughs that open directly to real files and line ranges. Tours live in `.tours/` and are meant for the CodeTour format, not ad hoc Markdown notes.
10
+
11
+ A good tour is a narrative for a specific reader:
12
+ - what they are looking at
13
+ - why it matters
14
+ - what path they should follow next
15
+
16
+ Only create `.tour` JSON files. Do not modify source code as part of this skill.
17
+
18
+ ## When to Use
19
+
20
+ Use this skill when:
21
+ - the user asks for a code tour, onboarding tour, architecture walkthrough, or PR tour
22
+ - the user says "explain how X works" and wants a reusable guided artifact
23
+ - the user wants a ramp-up path for a new engineer or reviewer
24
+ - the task is better served by a guided sequence than a flat summary
25
+
26
+ Examples:
27
+ - onboarding a new maintainer
28
+ - architecture tour for one service or package
29
+ - PR-review walk-through anchored to changed files
30
+ - RCA tour showing the failure path
31
+ - security review tour of trust boundaries and key checks
32
+
33
+ ## When NOT to Use
34
+
35
+ | Instead of code-tour | Use |
36
+ | --- | --- |
37
+ | A one-off explanation in chat is enough | answer directly |
38
+ | The user wants prose docs, not a `.tour` artifact | `documentation-lookup` or repo docs editing |
39
+ | The task is implementation or refactoring | do the implementation work |
40
+ | The task is broad codebase onboarding without a tour artifact | `codebase-onboarding` |
41
+
42
+ ## Workflow
43
+
44
+ ### 1. Discover
45
+
46
+ Explore the repo before writing anything:
47
+ - README and package/app entry points
48
+ - folder structure
49
+ - relevant config files
50
+ - the changed files if the tour is PR-focused
51
+
52
+ Do not start writing steps before you understand the shape of the code.
53
+
54
+ ### 2. Infer the reader
55
+
56
+ Decide the persona and depth from the request.
57
+
58
+ | Request shape | Persona | Suggested depth |
59
+ | --- | --- | --- |
60
+ | "onboarding", "new joiner" | `new-joiner` | 9-13 steps |
61
+ | "quick tour", "vibe check" | `vibecoder` | 5-8 steps |
62
+ | "architecture" | `architect` | 14-18 steps |
63
+ | "tour this PR" | `pr-reviewer` | 7-11 steps |
64
+ | "why did this break" | `rca-investigator` | 7-11 steps |
65
+ | "security review" | `security-reviewer` | 7-11 steps |
66
+ | "explain how this feature works" | `feature-explainer` | 7-11 steps |
67
+ | "debug this path" | `bug-fixer` | 7-11 steps |
68
+
69
+ ### 3. Read and verify anchors
70
+
71
+ Every file path and line anchor must be real:
72
+ - confirm the file exists
73
+ - confirm the line numbers are in range
74
+ - if using a selection, verify the exact block
75
+ - if the file is volatile, prefer a pattern-based anchor
76
+
77
+ Never guess line numbers.
78
+
79
+ ### 4. Write the `.tour`
80
+
81
+ Write to:
82
+
83
+ ```text
84
+ .tours/<persona>-<focus>.tour
85
+ ```
86
+
87
+ Keep the path deterministic and readable.
88
+
89
+ ### 5. Validate
90
+
91
+ Before finishing:
92
+ - every referenced path exists
93
+ - every line or selection is valid
94
+ - the first step is anchored to a real file or directory
95
+ - the tour tells a coherent story rather than listing files
96
+
97
+ ## Step Types
98
+
99
+ ### Content
100
+
101
+ Use sparingly, usually only for a closing step:
102
+
103
+ ```json
104
+ { "title": "Next Steps", "description": "You can now trace the request path end to end." }
105
+ ```
106
+
107
+ Do not make the first step content-only.
108
+
109
+ ### Directory
110
+
111
+ Use to orient the reader to a module:
112
+
113
+ ```json
114
+ { "directory": "src/services", "title": "Service Layer", "description": "The core orchestration logic lives here." }
115
+ ```
116
+
117
+ ### File + line
118
+
119
+ This is the default step type:
120
+
121
+ ```json
122
+ { "file": "src/auth/middleware.ts", "line": 42, "title": "Auth Gate", "description": "Every protected request passes here first." }
123
+ ```
124
+
125
+ ### Selection
126
+
127
+ Use when one code block matters more than the whole file:
128
+
129
+ ```json
130
+ {
131
+ "file": "src/core/pipeline.ts",
132
+ "selection": {
133
+ "start": { "line": 15, "character": 0 },
134
+ "end": { "line": 34, "character": 0 }
135
+ },
136
+ "title": "Request Pipeline",
137
+ "description": "This block wires validation, auth, and downstream execution."
138
+ }
139
+ ```
140
+
141
+ ### Pattern
142
+
143
+ Use when exact lines may drift:
144
+
145
+ ```json
146
+ { "file": "src/app.ts", "pattern": "export default class App", "title": "Application Entry" }
147
+ ```
148
+
149
+ ### URI
150
+
151
+ Use for PRs, issues, or docs when helpful:
152
+
153
+ ```json
154
+ { "uri": "https://github.com/org/repo/pull/456", "title": "The PR" }
155
+ ```
156
+
157
+ ## Writing Rule: SMIG
158
+
159
+ Each description should answer:
160
+ - **Situation**: what the reader is looking at
161
+ - **Mechanism**: how it works
162
+ - **Implication**: why it matters for this persona
163
+ - **Gotcha**: what a smart reader might miss
164
+
165
+ Keep descriptions compact, specific, and grounded in the actual code.
166
+
167
+ ## Narrative Shape
168
+
169
+ Use this arc unless the task clearly needs something different:
170
+ 1. orientation
171
+ 2. module map
172
+ 3. core execution path
173
+ 4. edge case or gotcha
174
+ 5. closing / next move
175
+
176
+ The tour should feel like a path, not an inventory.
177
+
178
+ ## Example
179
+
180
+ ```json
181
+ {
182
+ "$schema": "https://aka.ms/codetour-schema",
183
+ "title": "API Service Tour",
184
+ "description": "Walkthrough of the request path for the payments service.",
185
+ "ref": "main",
186
+ "steps": [
187
+ {
188
+ "directory": "src",
189
+ "title": "Source Root",
190
+ "description": "All runtime code for the service starts here."
191
+ },
192
+ {
193
+ "file": "src/server.ts",
194
+ "line": 12,
195
+ "title": "Entry Point",
196
+ "description": "The server boots here and wires middleware before any route is reached."
197
+ },
198
+ {
199
+ "file": "src/routes/payments.ts",
200
+ "line": 8,
201
+ "title": "Payment Routes",
202
+ "description": "Every payments request enters through this router before hitting service logic."
203
+ },
204
+ {
205
+ "title": "Next Steps",
206
+ "description": "You can now follow any payment request end to end with the main anchors in place."
207
+ }
208
+ ]
209
+ }
210
+ ```
211
+
212
+ ## Anti-Patterns
213
+
214
+ | Anti-pattern | Fix |
215
+ | --- | --- |
216
+ | Flat file listing | Tell a story with dependency between steps |
217
+ | Generic descriptions | Name the concrete code path or pattern |
218
+ | Guessed anchors | Verify every file and line first |
219
+ | Too many steps for a quick tour | Cut aggressively |
220
+ | First step is content-only | Anchor the first step to a real file or directory |
221
+ | Persona mismatch | Write for the actual reader, not a generic engineer |
222
+
223
+ ## Best Practices
224
+
225
+ - keep step count proportional to repo size and persona depth
226
+ - use directory steps for orientation, file steps for substance
227
+ - for PR tours, cover changed files first
228
+ - for monorepos, scope to the relevant packages instead of touring everything
229
+ - close with what the reader can now do, not a recap
230
+
231
+ ## Related Skills
232
+
233
+ - `codebase-onboarding`
234
+ - `coding-standards`
235
+ - `council`
236
+ - official upstream format: `microsoft/codetour`