codymaster 4.8.0 → 7.0.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 (416) hide show
  1. package/CHANGELOG.md +331 -7
  2. package/README.md +226 -296
  3. package/dist/advisory-handoff.js +89 -0
  4. package/dist/advisory-report.js +105 -0
  5. package/dist/agent/antigravity.js +152 -0
  6. package/dist/agent/backend.js +2 -0
  7. package/dist/agent/claude.js +196 -0
  8. package/dist/agent/codex.js +204 -0
  9. package/dist/agent/copilot.js +284 -0
  10. package/dist/agent/cursor.js +211 -0
  11. package/dist/agent/factory.js +30 -0
  12. package/dist/agent/gemini.js +142 -0
  13. package/dist/agent/opencode.js +205 -0
  14. package/dist/agent/spawn-helper.js +237 -0
  15. package/dist/agent/version.js +25 -0
  16. package/dist/browse/adapter-factory.js +69 -0
  17. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  18. package/dist/browse/adapters/playwright-adapter.js +309 -0
  19. package/dist/browse/adapters/types.js +6 -0
  20. package/dist/browse/error-collector.js +132 -0
  21. package/dist/browse/event-log.js +109 -0
  22. package/dist/browse/index.js +17 -0
  23. package/dist/browse-server.js +204 -120
  24. package/dist/cli/command-registry.js +20 -0
  25. package/dist/cli/commands/bench.js +69 -0
  26. package/dist/cli/commands/brain.js +108 -0
  27. package/dist/cli/commands/dashboard.js +76 -2
  28. package/dist/cli/commands/engineering.js +326 -4
  29. package/dist/cli/commands/evolve.js +123 -0
  30. package/dist/cli/commands/install.js +160 -0
  31. package/dist/cli/commands/learn.js +181 -0
  32. package/dist/cli/commands/mcp-serve.js +104 -0
  33. package/dist/cli/commands/parallel.js +138 -0
  34. package/dist/cli/commands/quality.js +105 -0
  35. package/dist/cli/commands/stack.js +49 -0
  36. package/dist/cli/commands/update.js +159 -0
  37. package/dist/cli/update-check.js +94 -10
  38. package/dist/cm-config.js +0 -18
  39. package/dist/codybench/judges/automated.js +31 -0
  40. package/dist/codybench/runners/claude-code.js +32 -0
  41. package/dist/codybench/suites/memory-retention.js +85 -0
  42. package/dist/codybench/suites/tdd-regression.js +35 -0
  43. package/dist/codybench/suites/token-efficiency.js +55 -0
  44. package/dist/codybench/types.js +2 -0
  45. package/dist/context-db.js +157 -0
  46. package/dist/continuity.js +5 -7
  47. package/dist/dashboard.js +47 -6
  48. package/dist/data.js +35 -0
  49. package/dist/execution/tdd-gate.js +113 -0
  50. package/dist/execution-analyzer.js +138 -0
  51. package/dist/executor/cancel.js +34 -0
  52. package/dist/executor/gc.js +74 -0
  53. package/dist/executor/index.js +14 -0
  54. package/dist/executor/runner.js +70 -0
  55. package/dist/executor/workdir.js +31 -0
  56. package/dist/handoff/contracts.js +22 -0
  57. package/dist/handoff/index.js +18 -0
  58. package/dist/handoff/io.js +121 -0
  59. package/dist/index.js +7 -3
  60. package/dist/indexer/skills-lib.js +533 -0
  61. package/dist/indexer/skills-map.js +1374 -0
  62. package/dist/indexer/skills.js +16 -0
  63. package/dist/indexer/stack-detect.js +219 -0
  64. package/dist/install/copy.js +98 -0
  65. package/dist/install/engine.js +42 -0
  66. package/dist/install/paths.js +70 -0
  67. package/dist/install/platforms/_simple.js +85 -0
  68. package/dist/install/platforms/antigravity.js +91 -0
  69. package/dist/install/platforms/claude-code.js +107 -0
  70. package/dist/install/platforms/cursor.js +77 -0
  71. package/dist/install/platforms/index.js +27 -0
  72. package/dist/install/platforms/simple.js +163 -0
  73. package/dist/install/profiles.js +75 -0
  74. package/dist/install/types.js +2 -0
  75. package/dist/learning-promoter.js +246 -0
  76. package/dist/learnings.js +208 -0
  77. package/dist/mcp-context-server.js +230 -1
  78. package/dist/middleware/metrics.js +30 -0
  79. package/dist/middleware/security-headers.js +14 -0
  80. package/dist/realtime/event-bus.js +29 -0
  81. package/dist/realtime/ws-hub.js +91 -0
  82. package/dist/schemas/task-schema.js +48 -0
  83. package/dist/schemas/validate.js +18 -0
  84. package/dist/skill-chain.js +63 -1
  85. package/dist/skill-evolver.js +456 -0
  86. package/dist/skill-execution-cache.js +254 -0
  87. package/dist/skills-lock.js +96 -0
  88. package/dist/smart-brain-router.js +184 -0
  89. package/dist/sprint-pipeline.js +26 -0
  90. package/dist/storage/index.js +21 -0
  91. package/dist/storage/repos/activity-repo.js +46 -0
  92. package/dist/storage/repos/message-repo.js +39 -0
  93. package/dist/storage/repos/project-repo.js +56 -0
  94. package/dist/storage/repos/task-repo.js +142 -0
  95. package/dist/storage/services/project-service.js +49 -0
  96. package/dist/storage/services/task-service.js +97 -0
  97. package/dist/storage/sqlite.js +113 -0
  98. package/dist/storage-backend.js +10 -8
  99. package/dist/tier-classify.js +131 -0
  100. package/dist/token-budget.js +88 -0
  101. package/dist/ui/onboarding.js +51 -15
  102. package/dist/utils/cli-utils.js +7 -2
  103. package/dist/utils/design-taste.js +108 -0
  104. package/dist/utils/output-compress.js +143 -0
  105. package/dist/vibecoding-index.js +126 -0
  106. package/package.json +20 -6
  107. package/public/dashboard/app.js +52 -1
  108. package/scripts/build-skills-lock.mjs +88 -0
  109. package/scripts/build-skills.mjs +187 -28
  110. package/scripts/compress-skill.mjs +73 -0
  111. package/scripts/deprecate-skill.mjs +72 -0
  112. package/scripts/install.sh +170 -0
  113. package/scripts/mcp-bridge.js +2 -2
  114. package/scripts/postinstall.js +53 -335
  115. package/scripts/update-changelog.sh +88 -0
  116. package/scripts/validate-skills.mjs +101 -4
  117. package/skills/CLAUDE.md +0 -5
  118. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  119. package/skills/_shared/helpers.md +2 -8
  120. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  121. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  122. package/skills/cm-browse/SKILL.md +6 -0
  123. package/skills/cm-clean-code/SKILL.md +20 -0
  124. package/skills/cm-code-review/SKILL.md +21 -0
  125. package/skills/cm-codeintell/SKILL.md +9 -0
  126. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  127. package/skills/cm-conductor-worktrees/SKILL.md +20 -18
  128. package/skills/cm-continuity/SKILL.md +41 -33
  129. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  130. package/skills/cm-dashboard/SKILL.md +20 -9
  131. package/skills/cm-dashboard/ui/app.js +9 -1
  132. package/skills/cm-debugging/SKILL.md +9 -0
  133. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  134. package/skills/cm-design-studio/SKILL.md +20 -24
  135. package/skills/cm-design-system/SKILL.md +1 -0
  136. package/skills/cm-ecosystem-roadmap/SKILL.md +4 -0
  137. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  138. package/skills/cm-engineering-meta/SKILL.md +19 -62
  139. package/skills/cm-execution/SKILL.md +98 -0
  140. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  141. package/skills/cm-git-worktrees/SKILL.md +15 -146
  142. package/skills/cm-guardian-runtime/SKILL.md +5 -1
  143. package/skills/cm-identity-guard/SKILL.md +8 -0
  144. package/skills/cm-mcp-engineering/SKILL.md +4 -0
  145. package/skills/cm-planning/SKILL.md +63 -92
  146. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  147. package/skills/cm-post-deploy-canary/SKILL.md +20 -12
  148. package/skills/cm-project-bootstrap/SKILL.md +11 -0
  149. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  150. package/skills/cm-qa-visual-cli/SKILL.md +19 -11
  151. package/skills/cm-quality-gate/SKILL.md +38 -0
  152. package/skills/cm-retro-cli/SKILL.md +4 -0
  153. package/skills/cm-safe-deploy/SKILL.md +9 -0
  154. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  155. package/skills/cm-second-opinion-cli/SKILL.md +20 -13
  156. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  157. package/skills/cm-secret-shield/SKILL.md +15 -569
  158. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  159. package/skills/cm-security-gate/SKILL.md +16 -228
  160. package/skills/cm-skill-chain/SKILL.md +25 -4
  161. package/skills/cm-skill-evolution/SKILL.md +83 -0
  162. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  163. package/skills/cm-skill-health/SKILL.md +26 -0
  164. package/skills/cm-skill-index/SKILL.md +19 -3
  165. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  166. package/skills/cm-skill-mastery/SKILL.md +16 -146
  167. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  168. package/skills/cm-skill-search/SKILL.md +26 -0
  169. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  170. package/skills/cm-skill-share/SKILL.md +26 -0
  171. package/skills/cm-sprint-bus/SKILL.md +13 -0
  172. package/skills/cm-start/SKILL.md +17 -10
  173. package/skills/cm-tdd/SKILL.md +21 -2
  174. package/skills/cm-terminal/SKILL.md +15 -0
  175. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  176. package/skills/cm-test-gate/SKILL.md +15 -234
  177. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  178. package/skills/cm-ui-preview/SKILL.md +16 -143
  179. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  180. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  181. package/skills/cm-ux-master/mcp/server.py +2 -2
  182. package/skills/profiles/design.txt +1 -1
  183. package/skills/profiles/full.txt +4 -10
  184. package/skills/profiles/growth.txt +8 -8
  185. package/skills/profiles/knowledge.txt +1 -1
  186. package/skills/profiles/top35.json +41 -0
  187. package/adapters/antigravity.js +0 -15
  188. package/adapters/claude-code.js +0 -17
  189. package/adapters/cursor.js +0 -16
  190. package/install.sh +0 -1125
  191. package/scripts/viking-demo.ts +0 -105
  192. package/skills/cm-ads-tracker/SKILL.md +0 -401
  193. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  194. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  195. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  196. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  197. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  198. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  199. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  200. package/skills/cm-auto-publisher/SKILL.md +0 -81
  201. package/skills/cm-booking-calendar/SKILL.md +0 -521
  202. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  203. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  204. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  205. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  206. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  207. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  208. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  209. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  210. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  211. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  219. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  229. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  230. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  231. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  232. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  233. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  234. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  235. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  236. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  237. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  238. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  239. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  240. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  241. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  242. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  243. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  244. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  245. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  246. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  247. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  248. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  249. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  250. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  251. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  252. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  253. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  254. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  255. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  256. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  257. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  258. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  259. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  260. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  261. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  262. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  263. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  264. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  265. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  266. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  267. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  268. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  269. package/skills/cm-content-factory/AGENTS.md +0 -61
  270. package/skills/cm-content-factory/CLAUDE.md +0 -63
  271. package/skills/cm-content-factory/CURSOR.md +0 -43
  272. package/skills/cm-content-factory/Content Factory.zip +0 -0
  273. package/skills/cm-content-factory/SKILL.md +0 -416
  274. package/skills/cm-content-factory/cf +0 -313
  275. package/skills/cm-content-factory/config.schema.json +0 -397
  276. package/skills/cm-content-factory/dashboard/app.js +0 -556
  277. package/skills/cm-content-factory/dashboard/index.html +0 -397
  278. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  279. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  280. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  281. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  282. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  283. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  284. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  285. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  286. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  287. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  288. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  289. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  290. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  291. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  292. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  293. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  294. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  295. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  296. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  297. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  298. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  299. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  300. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  301. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  302. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  303. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  304. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  305. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  306. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  307. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  308. package/skills/cm-content-factory/landing/docs/content/openviking.md +0 -33
  309. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  310. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  311. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  312. package/skills/cm-content-factory/landing/index.html +0 -680
  313. package/skills/cm-content-factory/landing/script.js +0 -143
  314. package/skills/cm-content-factory/landing/style.css +0 -1216
  315. package/skills/cm-content-factory/landing/translations.js +0 -508
  316. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  317. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  318. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  319. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  320. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  321. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  322. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  323. package/skills/cm-content-factory/scripts/audit.py +0 -106
  324. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  325. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  326. package/skills/cm-content-factory/scripts/extract.py +0 -132
  327. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  328. package/skills/cm-content-factory/scripts/memory.py +0 -521
  329. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  330. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  331. package/skills/cm-content-factory/scripts/plan.py +0 -163
  332. package/skills/cm-content-factory/scripts/publish.py +0 -145
  333. package/skills/cm-content-factory/scripts/research.py +0 -337
  334. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  335. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  336. package/skills/cm-content-factory/scripts/seo.py +0 -90
  337. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  338. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  339. package/skills/cm-content-factory/scripts/validate.py +0 -221
  340. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  341. package/skills/cm-content-factory/scripts/write.py +0 -93
  342. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  343. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  344. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  345. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  346. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  347. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  348. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  349. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  350. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  351. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  352. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  353. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  354. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  355. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  356. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  357. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  358. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  359. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  360. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  361. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  362. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  363. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  364. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  365. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  366. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  367. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  368. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  369. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  370. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  371. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  372. package/skills/cm-content-factory/tests/conftest.py +0 -66
  373. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  374. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  375. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  376. package/skills/cm-content-factory/tests/test_research.py +0 -56
  377. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  378. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  379. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  380. package/skills/cm-cro-methodology/SKILL.md +0 -290
  381. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  382. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  383. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  384. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  385. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  386. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  387. package/skills/cm-google-form/SKILL.md +0 -266
  388. package/skills/cm-google-form/templates/apps-script.js +0 -55
  389. package/skills/cm-google-form/templates/form-markup.html +0 -110
  390. package/skills/cm-google-form/templates/form-submit.js +0 -201
  391. package/skills/cm-google-form/templates/toast.css +0 -152
  392. package/skills/cm-growth-hacking/SKILL.md +0 -282
  393. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  394. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  395. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  396. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  397. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  398. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  399. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  400. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  401. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  402. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  403. package/skills/cm-jtbd/SKILL.md +0 -98
  404. package/skills/cm-notebooklm/SKILL.md +0 -156
  405. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  406. package/skills/cm-notebooklm/references/workflows.md +0 -60
  407. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  408. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  409. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  410. package/skills/cm-readit/SKILL.md +0 -289
  411. package/skills/cm-readit/audio-player.md +0 -206
  412. package/skills/cm-readit/examples/blog-reader.js +0 -352
  413. package/skills/cm-readit/examples/voice-cro.js +0 -390
  414. package/skills/cm-readit/tts-engine.md +0 -262
  415. package/skills/cm-readit/ui-patterns.md +0 -362
  416. package/skills/cm-readit/voice-cro.md +0 -223
@@ -3,7 +3,7 @@
3
3
  /**
4
4
  * CodyMaster MCP Context Server
5
5
  *
6
- * Exposes 13 tools over JSON-RPC 2.0 / stdio (Content-Length framing):
6
+ * Exposes 18 tools over JSON-RPC 2.0 / stdio (Content-Length framing):
7
7
  * cm_query — FTS5 search across learnings + decisions
8
8
  * cm_resolve — resolve a cm:// URI at L0/L1/L2
9
9
  * cm_bus_read — read context bus state
@@ -11,6 +11,7 @@
11
11
  * cm_budget_check — check token budget for a category
12
12
  * cm_memory_decay — TTL cleanup for learnings
13
13
  * cm_index_refresh — regenerate L0 indexes
14
+ * cm_advisory_report / cm_advisory_metrics / cm_advisory_handoff — advisory loop JSON surfaces
14
15
  * cm_plan / cm_review / cm_qa / cm_deploy / cm_search / cm_memory_query — engineering kit bridge
15
16
  *
16
17
  * Usage (stdio MCP):
@@ -39,6 +40,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
39
40
  return (mod && mod.__esModule) ? mod : { "default": mod };
40
41
  };
41
42
  Object.defineProperty(exports, "__esModule", { value: true });
43
+ exports.cmAdvisoryReport = cmAdvisoryReport;
44
+ exports.cmAdvisoryMetrics = cmAdvisoryMetrics;
45
+ exports.cmAdvisoryHandoff = cmAdvisoryHandoff;
42
46
  const path_1 = __importDefault(require("path"));
43
47
  const context_db_1 = require("./context-db");
44
48
  const uri_resolver_1 = require("./uri-resolver");
@@ -46,6 +50,9 @@ const context_bus_1 = require("./context-bus");
46
50
  const token_budget_1 = require("./token-budget");
47
51
  const l0_indexer_1 = require("./l0-indexer");
48
52
  const mcp_skills_tools_1 = require("./mcp-skills-tools");
53
+ const storage_backend_1 = require("./storage-backend");
54
+ const advisory_report_1 = require("./advisory-report");
55
+ const advisory_handoff_1 = require("./advisory-handoff");
49
56
  // ─── Config ──────────────────────────────────────────────────────────────────
50
57
  const SERVER_NAME = 'cm-context';
51
58
  const SERVER_VERSION = '1.0.0';
@@ -132,6 +139,84 @@ function cmBudgetCheck(args) {
132
139
  suggestion: check.suggestion,
133
140
  };
134
141
  }
142
+ function autoDetectCategory(content) {
143
+ const c = content.toLowerCase();
144
+ if (/\b(decided|architecture|we chose|design decision|chose to)\b/.test(c))
145
+ return 'arch_decision';
146
+ if (/\b(bug|fixed|caused by|root cause|crash)\b/.test(c))
147
+ return 'bug_fix';
148
+ if (/\b(prefer|always use|never use|avoid|convention|standard)\b/.test(c))
149
+ return 'user_pref';
150
+ if (/\b(function|pattern|approach|method|implementation)\b/.test(c))
151
+ return 'code_pattern';
152
+ return 'context';
153
+ }
154
+ function cmMemoryWrite(args) {
155
+ var _a;
156
+ const { content, scope = 'project', category, ttl_days, importance = 'medium' } = args;
157
+ if (!(content === null || content === void 0 ? void 0 : content.trim()))
158
+ throw new Error('content is required');
159
+ const detectedCategory = category || autoDetectCategory(content);
160
+ const defaultTtl = { session: 30, project: 90, global: 365 };
161
+ const ttl = (_a = ttl_days !== null && ttl_days !== void 0 ? ttl_days : defaultTtl[scope]) !== null && _a !== void 0 ? _a : 90;
162
+ const now = new Date().toISOString();
163
+ const id = `nli-${Date.now()}-${Math.random().toString(36).slice(2, 7)}`;
164
+ const dbPath = (0, context_db_1.getDbPath)(PROJECT_PATH);
165
+ (0, context_db_1.insertLearning)(dbPath, {
166
+ id,
167
+ what_failed: content,
168
+ why_failed: detectedCategory,
169
+ how_to_prevent: `importance:${importance}`,
170
+ scope,
171
+ ttl,
172
+ reinforce_count: 0,
173
+ status: 'active',
174
+ created_at: now,
175
+ updated_at: now,
176
+ agent: 'cm_natural',
177
+ });
178
+ return { ok: true, id, content, category: detectedCategory, scope, ttl_days: ttl, importance };
179
+ }
180
+ const NLI_PATTERNS = [
181
+ { pattern: /\b(remember|save|note)\s+that\s+/i, action: 'write', scope: 'project' },
182
+ { pattern: /\b(remember|save)\s+this[:\s]/i, action: 'write', scope: 'project' },
183
+ { pattern: /\bimportant[:\s]+/i, action: 'write', scope: 'project', importance: 'high' },
184
+ { pattern: /\b(forget|remove|ignore)\s+(about\s+)?/i, action: 'decay' },
185
+ { pattern: /\bwhat\s+did\s+we\s+(learn|know)\b/i, action: 'query' },
186
+ { pattern: /\bwhat\s+do\s+we\s+know\b/i, action: 'query' },
187
+ { pattern: /\blessons?\s+learned\b/i, action: 'query' },
188
+ { pattern: /\b(search|find|look\s+up)\b/i, action: 'query' },
189
+ ];
190
+ function cmNatural(args) {
191
+ var _a, _b, _c;
192
+ const { text } = args;
193
+ if (!(text === null || text === void 0 ? void 0 : text.trim()))
194
+ throw new Error('text is required');
195
+ for (const rule of NLI_PATTERNS) {
196
+ const match = text.match(rule.pattern);
197
+ if (!match)
198
+ continue;
199
+ const extracted = text.slice(((_a = match.index) !== null && _a !== void 0 ? _a : 0) + match[0].length).trim();
200
+ if (rule.action === 'write') {
201
+ const result = cmMemoryWrite({
202
+ content: extracted || text,
203
+ scope: (_b = rule.scope) !== null && _b !== void 0 ? _b : 'project',
204
+ importance: (_c = rule.importance) !== null && _c !== void 0 ? _c : 'medium',
205
+ });
206
+ return Object.assign(Object.assign({}, result), { matched_pattern: rule.pattern.source, routed_to: 'cm_memory_write' });
207
+ }
208
+ if (rule.action === 'decay') {
209
+ const result = cmMemoryDecay({ dry_run: false });
210
+ return Object.assign(Object.assign({}, result), { matched_pattern: rule.pattern.source, routed_to: 'cm_memory_decay' });
211
+ }
212
+ // query / search
213
+ const result = cmQuery({ query: extracted || text, scope: 'all', limit: 10 });
214
+ return Object.assign(Object.assign({}, result), { matched_pattern: rule.pattern.source, routed_to: 'cm_query' });
215
+ }
216
+ // No pattern matched — default to search
217
+ const result = cmQuery({ query: text, scope: 'all', limit: 10 });
218
+ return Object.assign(Object.assign({}, result), { matched_pattern: null, routed_to: 'cm_query (default)' });
219
+ }
135
220
  function cmMemoryDecay(args) {
136
221
  const { dry_run = false } = args;
137
222
  const dbPath = (0, context_db_1.getDbPath)(PROJECT_PATH);
@@ -188,6 +273,55 @@ function cmIndexRefresh(args) {
188
273
  }
189
274
  throw new Error(`Unknown target: ${target}. Valid: learnings, skeleton, all`);
190
275
  }
276
+ function cmAdvisoryReport(args) {
277
+ var _a;
278
+ const backend = (0, storage_backend_1.getBackend)(PROJECT_PATH);
279
+ backend.initialize();
280
+ try {
281
+ const limit = Math.max(1, (_a = args.limit) !== null && _a !== void 0 ? _a : 10);
282
+ const analyses = (0, advisory_report_1.buildAdvisoryReportData)(backend, { limit });
283
+ return {
284
+ count: analyses.length,
285
+ analyses,
286
+ generated_at: new Date().toISOString(),
287
+ };
288
+ }
289
+ finally {
290
+ backend.close();
291
+ }
292
+ }
293
+ function cmAdvisoryMetrics(args) {
294
+ var _a;
295
+ const backend = (0, storage_backend_1.getBackend)(PROJECT_PATH);
296
+ backend.initialize();
297
+ try {
298
+ const limit = Math.max(1, (_a = args.limit) !== null && _a !== void 0 ? _a : 10);
299
+ const metrics = (0, advisory_report_1.buildAdvisoryMetricsData)(backend, { limit });
300
+ return {
301
+ count: metrics.length,
302
+ metrics,
303
+ generated_at: new Date().toISOString(),
304
+ };
305
+ }
306
+ finally {
307
+ backend.close();
308
+ }
309
+ }
310
+ function cmAdvisoryHandoff(args) {
311
+ const backend = (0, storage_backend_1.getBackend)(PROJECT_PATH);
312
+ backend.initialize();
313
+ try {
314
+ return (0, advisory_handoff_1.buildAdvisoryHandoff)(backend, {
315
+ consumer: args.consumer,
316
+ analysisId: args.analysis_id,
317
+ skill: args.skill,
318
+ searchLimit: args.limit,
319
+ });
320
+ }
321
+ finally {
322
+ backend.close();
323
+ }
324
+ }
191
325
  // ─── Tool Registry ─────────────────────────────────────────────────────────────
192
326
  const TOOLS = [
193
327
  {
@@ -297,6 +431,53 @@ const TOOLS = [
297
431
  },
298
432
  },
299
433
  },
434
+ {
435
+ name: 'cm_advisory_report',
436
+ description: 'Return recent advisory analyses as structured JSON for agent consumption.',
437
+ inputSchema: {
438
+ type: 'object',
439
+ properties: {
440
+ limit: { type: 'number', description: 'Max analyses to return (default: 10)' },
441
+ },
442
+ },
443
+ },
444
+ {
445
+ name: 'cm_advisory_metrics',
446
+ description: 'Return aggregated skill metrics and quality weights as structured JSON.',
447
+ inputSchema: {
448
+ type: 'object',
449
+ properties: {
450
+ limit: { type: 'number', description: 'Max skills to return (default: 10)' },
451
+ },
452
+ },
453
+ },
454
+ {
455
+ name: 'cm_advisory_handoff',
456
+ description: 'Build a structured advisory handoff for cm-skill-health or cm-skill-evolution.',
457
+ inputSchema: {
458
+ type: 'object',
459
+ properties: {
460
+ consumer: {
461
+ type: 'string',
462
+ enum: ['cm-skill-health', 'cm-skill-evolution'],
463
+ description: 'Which self-healing skill should consume the handoff',
464
+ },
465
+ analysis_id: {
466
+ type: 'string',
467
+ description: 'Optional analysis id prefix (defaults to latest advisory analysis)',
468
+ },
469
+ skill: {
470
+ type: 'string',
471
+ description: 'Optional skill override when the target skill should be forced',
472
+ },
473
+ limit: {
474
+ type: 'number',
475
+ description: 'How many recent analyses to search while resolving analysis_id (default: 50)',
476
+ },
477
+ },
478
+ required: ['consumer'],
479
+ },
480
+ },
300
481
  {
301
482
  name: 'cm_plan',
302
483
  description: 'Sprint + context bus snapshot: pipeline state, next skill hint, artifact paths.',
@@ -342,6 +523,44 @@ const TOOLS = [
342
523
  required: ['query'],
343
524
  },
344
525
  },
526
+ {
527
+ name: 'cm_memory_write',
528
+ description: 'Write a new memory/learning to persistent storage. Use to save knowledge, decisions, preferences, or patterns for future sessions.',
529
+ inputSchema: {
530
+ type: 'object',
531
+ properties: {
532
+ content: { type: 'string', description: 'What to remember (the memory content)' },
533
+ scope: {
534
+ type: 'string',
535
+ enum: ['session', 'project', 'global'],
536
+ description: 'Memory scope: session=30d, project=90d, global=365d (default: project)',
537
+ },
538
+ category: {
539
+ type: 'string',
540
+ enum: ['code_pattern', 'arch_decision', 'bug_fix', 'user_pref', 'context'],
541
+ description: 'Category (auto-detected from content if omitted)',
542
+ },
543
+ ttl_days: { type: 'number', description: 'Override TTL in days' },
544
+ importance: {
545
+ type: 'string',
546
+ enum: ['low', 'medium', 'high'],
547
+ description: 'Importance level (default: medium)',
548
+ },
549
+ },
550
+ required: ['content'],
551
+ },
552
+ },
553
+ {
554
+ name: 'cm_natural',
555
+ description: 'Natural language memory interface. Understands "remember that...", "forget about...", "what did we learn about...", "find...". Routes to appropriate memory operation automatically.',
556
+ inputSchema: {
557
+ type: 'object',
558
+ properties: {
559
+ text: { type: 'string', description: 'Freeform natural language instruction or question' },
560
+ },
561
+ required: ['text'],
562
+ },
563
+ },
345
564
  ];
346
565
  // ─── MCP stdio protocol (JSON-RPC 2.0, Content-Length framing) ───────────────
347
566
  function sendMessage(msg) {
@@ -391,6 +610,12 @@ function handleRequest(msg) {
391
610
  result = cmMemoryDecay(a);
392
611
  else if (name === 'cm_index_refresh')
393
612
  result = cmIndexRefresh(a);
613
+ else if (name === 'cm_advisory_report')
614
+ result = cmAdvisoryReport(a);
615
+ else if (name === 'cm_advisory_metrics')
616
+ result = cmAdvisoryMetrics(a);
617
+ else if (name === 'cm_advisory_handoff')
618
+ result = cmAdvisoryHandoff(a);
394
619
  else if (name === 'cm_plan')
395
620
  result = (0, mcp_skills_tools_1.cmPlanTool)(PROJECT_PATH);
396
621
  else if (name === 'cm_review')
@@ -403,6 +628,10 @@ function handleRequest(msg) {
403
628
  result = (0, mcp_skills_tools_1.cmSearchTool)(PROJECT_PATH, a);
404
629
  else if (name === 'cm_memory_query')
405
630
  result = (0, mcp_skills_tools_1.cmMemoryQueryTool)(PROJECT_PATH, a);
631
+ else if (name === 'cm_memory_write')
632
+ result = cmMemoryWrite(a);
633
+ else if (name === 'cm_natural')
634
+ result = cmNatural(a);
406
635
  else
407
636
  throw new Error(`Unknown tool: ${name}`);
408
637
  respond(id, {
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.incMetric = incMetric;
4
+ exports.setMetric = setMetric;
5
+ exports.metricsHandler = metricsHandler;
6
+ const metrics = {
7
+ cm_tasks_running: 0,
8
+ cm_dispatch_total: 0,
9
+ cm_dispatch_duration_seconds_sum: 0,
10
+ cm_dispatch_duration_seconds_count: 0,
11
+ cm_backend_errors_total: 0,
12
+ cm_requests_total: 0,
13
+ };
14
+ function incMetric(name, value = 1) {
15
+ if (name in metrics) {
16
+ metrics[name] += value;
17
+ }
18
+ }
19
+ function setMetric(name, value) {
20
+ metrics[name] = value;
21
+ }
22
+ function metricsHandler(_req, res) {
23
+ let output = '';
24
+ for (const [key, value] of Object.entries(metrics)) {
25
+ output += `# TYPE ${key} counter\n`;
26
+ output += `${key} ${value}\n`;
27
+ }
28
+ res.setHeader('Content-Type', 'text/plain; version=0.0.4');
29
+ res.send(output);
30
+ }
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.securityHeaders = securityHeaders;
4
+ function securityHeaders() {
5
+ return (_req, res, next) => {
6
+ res.setHeader('X-Content-Type-Options', 'nosniff');
7
+ res.setHeader('X-Frame-Options', 'DENY');
8
+ res.setHeader('X-XSS-Protection', '1; mode=block');
9
+ res.setHeader('Referrer-Policy', 'strict-origin-when-cross-origin');
10
+ res.setHeader('Permissions-Policy', 'camera=(), microphone=(), geolocation=()');
11
+ res.setHeader('Content-Security-Policy', "default-src 'self'; script-src 'self' 'unsafe-inline'; style-src 'self' 'unsafe-inline'; img-src 'self' data:; font-src 'self';");
12
+ next();
13
+ };
14
+ }
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.eventBus = exports.EventBus = void 0;
4
+ const events_1 = require("events");
5
+ class EventBus extends events_1.EventEmitter {
6
+ emit(event, data) {
7
+ return super.emit(event, data);
8
+ }
9
+ on(event, listener) {
10
+ return super.on(event, listener);
11
+ }
12
+ off(event, listener) {
13
+ return super.off(event, listener);
14
+ }
15
+ emitTask(event) {
16
+ this.emit('task', event);
17
+ this.emit(event.type, event);
18
+ }
19
+ emitActivity(event) {
20
+ this.emit('activity', event);
21
+ this.emit(event.type, event);
22
+ }
23
+ emitAgent(event) {
24
+ this.emit('agent', event);
25
+ this.emit(event.type, event);
26
+ }
27
+ }
28
+ exports.EventBus = EventBus;
29
+ exports.eventBus = new EventBus();
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.broadcastToProject = broadcastToProject;
4
+ exports.broadcastAll = broadcastAll;
5
+ exports.initWsHub = initWsHub;
6
+ const ws_1 = require("ws");
7
+ const event_bus_1 = require("./event-bus");
8
+ const HEARTBEAT_INTERVAL = 15000;
9
+ const MAX_BUFFER = 100;
10
+ const clients = new Set();
11
+ function send(client, event) {
12
+ if (client.ws.readyState !== ws_1.WebSocket.OPEN)
13
+ return;
14
+ client.buffer.push(event);
15
+ if (client.buffer.length > MAX_BUFFER) {
16
+ client.buffer.shift();
17
+ }
18
+ client.ws.send(JSON.stringify(event));
19
+ }
20
+ function broadcastToProject(projectId, event) {
21
+ for (const client of clients) {
22
+ if (client.projectId === projectId) {
23
+ send(client, event);
24
+ }
25
+ }
26
+ }
27
+ function broadcastAll(event) {
28
+ for (const client of clients) {
29
+ send(client, event);
30
+ }
31
+ }
32
+ function initWsHub(server) {
33
+ const wss = new ws_1.WebSocketServer({ server, path: '/ws' });
34
+ wss.on('connection', (ws) => {
35
+ const client = { ws, buffer: [], alive: true };
36
+ clients.add(client);
37
+ ws.on('message', (raw) => {
38
+ let msg;
39
+ try {
40
+ msg = JSON.parse(raw.toString());
41
+ }
42
+ catch (_a) {
43
+ return;
44
+ }
45
+ if (msg.action === 'subscribe' && msg.projectId) {
46
+ client.projectId = msg.projectId;
47
+ ws.send(JSON.stringify({ type: 'subscribed', projectId: msg.projectId }));
48
+ }
49
+ else if (msg.action === 'unsubscribe') {
50
+ client.projectId = undefined;
51
+ ws.send(JSON.stringify({ type: 'unsubscribed' }));
52
+ }
53
+ });
54
+ ws.on('pong', () => {
55
+ client.alive = true;
56
+ });
57
+ ws.on('close', () => {
58
+ clients.delete(client);
59
+ });
60
+ ws.on('error', () => {
61
+ clients.delete(client);
62
+ });
63
+ });
64
+ const heartbeat = setInterval(() => {
65
+ for (const client of clients) {
66
+ if (!client.alive) {
67
+ client.ws.terminate();
68
+ clients.delete(client);
69
+ continue;
70
+ }
71
+ client.alive = false;
72
+ client.ws.ping();
73
+ }
74
+ }, HEARTBEAT_INTERVAL);
75
+ wss.on('close', () => {
76
+ clearInterval(heartbeat);
77
+ });
78
+ event_bus_1.eventBus.on('task', (event) => {
79
+ if ('projectId' in event) {
80
+ broadcastToProject(event.projectId, event);
81
+ }
82
+ });
83
+ event_bus_1.eventBus.on('activity', (event) => {
84
+ if ('activity' in event && event.activity.projectId) {
85
+ broadcastToProject(event.activity.projectId, event);
86
+ }
87
+ });
88
+ event_bus_1.eventBus.on('agent', (event) => {
89
+ broadcastAll(event);
90
+ });
91
+ }
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createProjectSchema = exports.autoSyncSchema = exports.updateTaskSchema = exports.createTaskSchema = void 0;
4
+ exports.createTaskSchema = {
5
+ type: 'object',
6
+ required: ['projectId', 'title'],
7
+ properties: {
8
+ projectId: { type: 'string', minLength: 1 },
9
+ title: { type: 'string', minLength: 1 },
10
+ description: { type: 'string' },
11
+ column: { type: 'string', enum: ['backlog', 'in-progress', 'review', 'done'] },
12
+ priority: { type: 'string', enum: ['low', 'medium', 'high', 'urgent'] },
13
+ agent: { type: 'string' },
14
+ skill: { type: 'string' },
15
+ },
16
+ additionalProperties: false,
17
+ };
18
+ exports.updateTaskSchema = {
19
+ type: 'object',
20
+ properties: {
21
+ title: { type: 'string', minLength: 1 },
22
+ description: { type: 'string' },
23
+ priority: { type: 'string', enum: ['low', 'medium', 'high', 'urgent'] },
24
+ },
25
+ additionalProperties: false,
26
+ minProperties: 1,
27
+ };
28
+ exports.autoSyncSchema = {
29
+ type: 'object',
30
+ required: ['conversationId', 'title'],
31
+ properties: {
32
+ conversationId: { type: 'string', minLength: 1 },
33
+ title: { type: 'string', minLength: 1 },
34
+ status: { type: 'string' },
35
+ column: { type: 'string', enum: ['backlog', 'in-progress', 'review', 'done'] },
36
+ },
37
+ additionalProperties: true,
38
+ };
39
+ exports.createProjectSchema = {
40
+ type: 'object',
41
+ required: ['name'],
42
+ properties: {
43
+ name: { type: 'string', minLength: 1 },
44
+ path: { type: 'string' },
45
+ agents: { type: 'array', items: { type: 'string' } },
46
+ },
47
+ additionalProperties: false,
48
+ };
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.validateBody = validateBody;
7
+ const ajv_1 = __importDefault(require("ajv"));
8
+ const ajv = new ajv_1.default();
9
+ function validateBody(schema) {
10
+ const validate = ajv.compile(schema);
11
+ return (req, res, next) => {
12
+ if (!validate(req.body)) {
13
+ res.status(400).json({ error: 'Validation failed', details: validate.errors });
14
+ return;
15
+ }
16
+ next();
17
+ };
18
+ }
@@ -4,6 +4,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.matchChain = matchChain;
7
+ exports.scoreStepRelevance = scoreStepRelevance;
8
+ exports.selectTopSkills = selectTopSkills;
7
9
  exports.listChains = listChains;
8
10
  exports.findChain = findChain;
9
11
  exports.createChainExecution = createChainExecution;
@@ -17,6 +19,8 @@ exports.getCurrentSkill = getCurrentSkill;
17
19
  const crypto_1 = __importDefault(require("crypto"));
18
20
  const builtin_1 = require("./chains/builtin");
19
21
  const context_bus_1 = require("./context-bus");
22
+ const execution_analyzer_1 = require("./execution-analyzer");
23
+ const storage_backend_1 = require("./storage-backend");
20
24
  // ─── Chain Matching ─────────────────────────────────────────────────────────
21
25
  // TRIZ #10: Preliminary Action — analyze task BEFORE dispatching
22
26
  /**
@@ -43,6 +47,53 @@ function matchChain(taskTitle) {
43
47
  }
44
48
  return bestMatch;
45
49
  }
50
+ // ─── Intelligent Skill Selection (SkillsBench: 2-3 skills = +18.6pp) ────────
51
+ // TRIZ #1: Segmentation — select only relevant sub-components
52
+ /**
53
+ * Score a single chain step's relevance to the given task title.
54
+ * Mandatory steps (optional=false, condition='always') receive a +100 base bonus
55
+ * to ensure they are always prioritised over optional ones.
56
+ */
57
+ function scoreStepRelevance(taskTitle, step) {
58
+ const taskTokens = new Set(taskTitle.toLowerCase().split(/\W+/).filter(t => t.length > 2));
59
+ const descTokens = step.description.toLowerCase().split(/\W+/).filter(t => t.length > 2);
60
+ const overlap = descTokens.filter(t => taskTokens.has(t)).length;
61
+ const mandatoryBonus = (!step.optional && step.condition === 'always') ? 100 : 0;
62
+ return overlap + mandatoryBonus;
63
+ }
64
+ /**
65
+ * Select the most relevant skills for a task, capped at maxSkills.
66
+ *
67
+ * Rules:
68
+ * - Mandatory steps (optional=false AND condition='always') are ALWAYS included,
69
+ * even if their count exceeds maxSkills (safety > optimisation).
70
+ * - Remaining slots are filled with the highest-scoring optional steps.
71
+ * - If mandatory count > maxSkills, a performance warning is emitted.
72
+ */
73
+ function selectTopSkills(taskTitle, chain, maxSkills = 3, options = {}) {
74
+ const mandatory = chain.steps.filter(s => !s.optional && s.condition === 'always');
75
+ const optional = chain.steps.filter(s => s.optional || s.condition !== 'always');
76
+ if (mandatory.length > maxSkills) {
77
+ process.stderr.write(`[CodyMaster] Chain "${chain.name}" has ${mandatory.length} mandatory steps (>${maxSkills}). ` +
78
+ `Consider splitting this chain. (SkillsBench: 2-3 skills = +18.6pp)\n`);
79
+ return mandatory; // include all mandatory — cannot safely drop them
80
+ }
81
+ const remaining = maxSkills - mandatory.length;
82
+ const scoredOptional = optional
83
+ .map(step => {
84
+ var _a, _b;
85
+ const relevance = scoreStepRelevance(taskTitle, step);
86
+ const metric = (_b = (_a = options.getSkillMetric) === null || _a === void 0 ? void 0 : _a.call(options, step.skill)) !== null && _b !== void 0 ? _b : null;
87
+ const quality = (0, execution_analyzer_1.qualityWeight)(metric);
88
+ return { step, score: relevance + quality, relevance, quality };
89
+ })
90
+ .sort((a, b) => b.score - a.score)
91
+ .slice(0, remaining)
92
+ .map(({ step }) => step);
93
+ // Preserve original chain order
94
+ const selected = new Set([...mandatory, ...scoredOptional]);
95
+ return chain.steps.filter(s => selected.has(s));
96
+ }
46
97
  /**
47
98
  * List all available chains (built-in + user-defined in the future).
48
99
  */
@@ -62,7 +113,18 @@ function findChain(chainId) {
62
113
  */
63
114
  function createChainExecution(chain, projectId, taskTitle, agent, projectPath) {
64
115
  const now = new Date().toISOString();
65
- const steps = chain.steps.map((step, index) => ({
116
+ const backend = projectPath ? (0, storage_backend_1.getBackend)(projectPath) : undefined;
117
+ let selectedSteps;
118
+ backend === null || backend === void 0 ? void 0 : backend.initialize();
119
+ try {
120
+ selectedSteps = selectTopSkills(taskTitle, chain, 3, {
121
+ getSkillMetric: backend ? (skill) => backend.getSkillMetric(skill) : undefined,
122
+ });
123
+ }
124
+ finally {
125
+ backend === null || backend === void 0 ? void 0 : backend.close();
126
+ }
127
+ const steps = selectedSteps.map((step, index) => ({
66
128
  index,
67
129
  skill: step.skill,
68
130
  description: step.description,