codymaster 5.2.0 → 7.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (380) hide show
  1. package/CHANGELOG.md +276 -0
  2. package/README.md +216 -333
  3. package/dist/agent/antigravity.js +152 -0
  4. package/dist/agent/backend.js +2 -0
  5. package/dist/agent/claude.js +196 -0
  6. package/dist/agent/codex.js +204 -0
  7. package/dist/agent/copilot.js +284 -0
  8. package/dist/agent/cursor.js +211 -0
  9. package/dist/agent/factory.js +30 -0
  10. package/dist/agent/gemini.js +142 -0
  11. package/dist/agent/opencode.js +205 -0
  12. package/dist/agent/spawn-helper.js +237 -0
  13. package/dist/agent/version.js +25 -0
  14. package/dist/browse/adapter-factory.js +69 -0
  15. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  16. package/dist/browse/adapters/playwright-adapter.js +309 -0
  17. package/dist/browse/adapters/types.js +6 -0
  18. package/dist/browse/error-collector.js +132 -0
  19. package/dist/browse/event-log.js +109 -0
  20. package/dist/browse/index.js +17 -0
  21. package/dist/browse-server.js +204 -120
  22. package/dist/cli/command-registry.js +12 -0
  23. package/dist/cli/commands/dashboard.js +76 -2
  24. package/dist/cli/commands/engineering.js +218 -4
  25. package/dist/cli/commands/install.js +160 -0
  26. package/dist/cli/commands/learn.js +181 -0
  27. package/dist/cli/commands/parallel.js +138 -0
  28. package/dist/cli/commands/quality.js +105 -0
  29. package/dist/cli/commands/stack.js +49 -0
  30. package/dist/cli/commands/update.js +159 -0
  31. package/dist/cli/update-check.js +94 -10
  32. package/dist/continuity.js +3 -1
  33. package/dist/dashboard.js +47 -6
  34. package/dist/data.js +35 -0
  35. package/dist/execution/tdd-gate.js +113 -0
  36. package/dist/executor/cancel.js +34 -0
  37. package/dist/executor/gc.js +74 -0
  38. package/dist/executor/index.js +14 -0
  39. package/dist/executor/runner.js +70 -0
  40. package/dist/executor/workdir.js +31 -0
  41. package/dist/handoff/contracts.js +22 -0
  42. package/dist/handoff/index.js +18 -0
  43. package/dist/handoff/io.js +121 -0
  44. package/dist/index.js +7 -3
  45. package/dist/indexer/stack-detect.js +219 -0
  46. package/dist/install/copy.js +98 -0
  47. package/dist/install/engine.js +42 -0
  48. package/dist/install/paths.js +70 -0
  49. package/dist/install/platforms/_simple.js +85 -0
  50. package/dist/install/platforms/antigravity.js +91 -0
  51. package/dist/install/platforms/claude-code.js +107 -0
  52. package/dist/install/platforms/cursor.js +77 -0
  53. package/dist/install/platforms/index.js +27 -0
  54. package/dist/install/platforms/simple.js +163 -0
  55. package/dist/install/profiles.js +75 -0
  56. package/dist/install/types.js +2 -0
  57. package/dist/learnings.js +208 -0
  58. package/dist/mcp-context-server.js +1 -1
  59. package/dist/middleware/metrics.js +30 -0
  60. package/dist/middleware/security-headers.js +14 -0
  61. package/dist/realtime/event-bus.js +29 -0
  62. package/dist/realtime/ws-hub.js +91 -0
  63. package/dist/schemas/task-schema.js +48 -0
  64. package/dist/schemas/validate.js +18 -0
  65. package/dist/skills-lock.js +96 -0
  66. package/dist/sprint-pipeline.js +26 -0
  67. package/dist/storage/index.js +21 -0
  68. package/dist/storage/repos/activity-repo.js +46 -0
  69. package/dist/storage/repos/message-repo.js +39 -0
  70. package/dist/storage/repos/project-repo.js +56 -0
  71. package/dist/storage/repos/task-repo.js +142 -0
  72. package/dist/storage/services/project-service.js +49 -0
  73. package/dist/storage/services/task-service.js +97 -0
  74. package/dist/storage/sqlite.js +113 -0
  75. package/dist/tier-classify.js +131 -0
  76. package/dist/ui/onboarding.js +51 -15
  77. package/dist/utils/cli-utils.js +7 -2
  78. package/dist/utils/design-taste.js +108 -0
  79. package/dist/utils/output-compress.js +143 -0
  80. package/dist/vibecoding-index.js +126 -0
  81. package/package.json +27 -4
  82. package/public/dashboard/app.js +52 -1
  83. package/scripts/build-skills-lock.mjs +88 -0
  84. package/scripts/build-skills.mjs +187 -28
  85. package/scripts/compress-skill.mjs +73 -0
  86. package/scripts/deprecate-skill.mjs +72 -0
  87. package/scripts/install.sh +170 -0
  88. package/scripts/mcp-bridge.js +2 -2
  89. package/scripts/postinstall.js +54 -287
  90. package/scripts/release.sh +126 -0
  91. package/scripts/update-changelog.sh +88 -0
  92. package/scripts/validate-skills.mjs +101 -4
  93. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  94. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  95. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  96. package/skills/cm-clean-code/SKILL.md +20 -0
  97. package/skills/cm-code-review/SKILL.md +21 -0
  98. package/skills/cm-codeintell/SKILL.md +9 -0
  99. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  100. package/skills/cm-conductor-worktrees/SKILL.md +17 -19
  101. package/skills/cm-continuity/SKILL.md +9 -0
  102. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  103. package/skills/cm-dashboard/SKILL.md +20 -9
  104. package/skills/cm-dashboard/ui/app.js +9 -1
  105. package/skills/cm-debugging/SKILL.md +9 -0
  106. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  107. package/skills/cm-design-studio/SKILL.md +17 -25
  108. package/skills/cm-design-system/SKILL.md +1 -0
  109. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  110. package/skills/cm-engineering-meta/SKILL.md +16 -63
  111. package/skills/cm-execution/SKILL.md +98 -0
  112. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  113. package/skills/cm-git-worktrees/SKILL.md +15 -146
  114. package/skills/cm-identity-guard/SKILL.md +8 -0
  115. package/skills/cm-planning/SKILL.md +63 -92
  116. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  117. package/skills/cm-post-deploy-canary/SKILL.md +17 -13
  118. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  119. package/skills/cm-qa-visual-cli/SKILL.md +16 -12
  120. package/skills/cm-quality-gate/SKILL.md +38 -0
  121. package/skills/cm-safe-deploy/SKILL.md +9 -0
  122. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  123. package/skills/cm-second-opinion-cli/SKILL.md +17 -14
  124. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  125. package/skills/cm-secret-shield/SKILL.md +15 -569
  126. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  127. package/skills/cm-security-gate/SKILL.md +15 -228
  128. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  129. package/skills/cm-skill-health/SKILL.md +16 -73
  130. package/skills/cm-skill-index/SKILL.md +8 -0
  131. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  132. package/skills/cm-skill-mastery/SKILL.md +16 -146
  133. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  134. package/skills/cm-skill-search/SKILL.md +17 -40
  135. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  136. package/skills/cm-skill-share/SKILL.md +17 -49
  137. package/skills/cm-sprint-bus/SKILL.md +9 -0
  138. package/skills/cm-start/SKILL.md +17 -0
  139. package/skills/cm-tdd/SKILL.md +19 -0
  140. package/skills/cm-terminal/SKILL.md +15 -0
  141. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  142. package/skills/cm-test-gate/SKILL.md +15 -234
  143. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  144. package/skills/cm-ui-preview/SKILL.md +16 -143
  145. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  146. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  147. package/skills/cm-ux-master/mcp/server.py +2 -2
  148. package/skills/profiles/design.txt +1 -1
  149. package/skills/profiles/full.txt +0 -10
  150. package/skills/profiles/growth.txt +8 -8
  151. package/skills/profiles/knowledge.txt +1 -1
  152. package/skills/profiles/top35.json +41 -0
  153. package/adapters/antigravity.js +0 -15
  154. package/adapters/claude-code.js +0 -17
  155. package/adapters/cursor.js +0 -16
  156. package/skills/cm-ads-tracker/SKILL.md +0 -401
  157. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  158. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  159. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  160. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  161. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  162. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  163. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  164. package/skills/cm-auto-publisher/SKILL.md +0 -81
  165. package/skills/cm-booking-calendar/SKILL.md +0 -521
  166. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  167. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  168. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  169. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  170. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  171. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  172. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  173. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  174. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  175. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  176. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  177. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  178. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  179. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  180. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  181. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  182. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  183. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  184. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  185. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  186. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  187. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  188. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  189. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  190. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  191. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  192. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  193. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  194. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  195. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  196. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  197. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  198. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  199. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  200. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  201. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  202. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  203. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  204. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  205. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  206. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  207. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  208. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  209. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  210. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  211. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  219. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  229. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  230. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  231. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  232. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  233. package/skills/cm-content-factory/AGENTS.md +0 -61
  234. package/skills/cm-content-factory/CLAUDE.md +0 -63
  235. package/skills/cm-content-factory/CURSOR.md +0 -43
  236. package/skills/cm-content-factory/Content Factory.zip +0 -0
  237. package/skills/cm-content-factory/SKILL.md +0 -416
  238. package/skills/cm-content-factory/cf +0 -313
  239. package/skills/cm-content-factory/config.schema.json +0 -397
  240. package/skills/cm-content-factory/dashboard/app.js +0 -556
  241. package/skills/cm-content-factory/dashboard/index.html +0 -397
  242. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  243. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  244. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  245. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  246. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  247. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  248. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  249. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  250. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  251. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  252. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  253. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  254. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  255. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  256. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  257. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  258. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  259. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  260. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  261. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  262. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  263. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  264. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  265. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  266. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  267. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  268. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  269. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  270. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  271. package/skills/cm-content-factory/landing/docs/content/memory-system.md +0 -38
  272. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  273. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  274. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  275. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  276. package/skills/cm-content-factory/landing/index.html +0 -680
  277. package/skills/cm-content-factory/landing/script.js +0 -143
  278. package/skills/cm-content-factory/landing/style.css +0 -1216
  279. package/skills/cm-content-factory/landing/translations.js +0 -508
  280. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  281. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  282. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  283. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  284. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  285. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  286. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  287. package/skills/cm-content-factory/scripts/audit.py +0 -106
  288. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  289. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  290. package/skills/cm-content-factory/scripts/extract.py +0 -132
  291. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  292. package/skills/cm-content-factory/scripts/memory.py +0 -521
  293. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  294. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  295. package/skills/cm-content-factory/scripts/plan.py +0 -163
  296. package/skills/cm-content-factory/scripts/publish.py +0 -145
  297. package/skills/cm-content-factory/scripts/research.py +0 -337
  298. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  299. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  300. package/skills/cm-content-factory/scripts/seo.py +0 -90
  301. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  302. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  303. package/skills/cm-content-factory/scripts/validate.py +0 -221
  304. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  305. package/skills/cm-content-factory/scripts/write.py +0 -93
  306. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  307. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  308. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  309. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  310. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  311. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  312. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  313. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  314. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  315. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  316. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  317. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  318. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  319. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  320. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  321. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  322. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  323. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  324. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  325. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  326. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  327. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  328. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  329. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  330. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  331. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  332. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  333. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  334. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  335. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  336. package/skills/cm-content-factory/tests/conftest.py +0 -66
  337. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  338. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  339. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  340. package/skills/cm-content-factory/tests/test_research.py +0 -56
  341. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  342. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  343. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  344. package/skills/cm-cro-methodology/SKILL.md +0 -290
  345. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  346. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  347. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  348. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  349. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  350. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  351. package/skills/cm-google-form/SKILL.md +0 -266
  352. package/skills/cm-google-form/templates/apps-script.js +0 -55
  353. package/skills/cm-google-form/templates/form-markup.html +0 -110
  354. package/skills/cm-google-form/templates/form-submit.js +0 -201
  355. package/skills/cm-google-form/templates/toast.css +0 -152
  356. package/skills/cm-growth-hacking/SKILL.md +0 -282
  357. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  358. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  359. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  360. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  361. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  362. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  363. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  364. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  365. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  366. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  367. package/skills/cm-jtbd/SKILL.md +0 -98
  368. package/skills/cm-notebooklm/SKILL.md +0 -156
  369. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  370. package/skills/cm-notebooklm/references/workflows.md +0 -60
  371. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  372. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  373. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  374. package/skills/cm-readit/SKILL.md +0 -289
  375. package/skills/cm-readit/audio-player.md +0 -206
  376. package/skills/cm-readit/examples/blog-reader.js +0 -352
  377. package/skills/cm-readit/examples/voice-cro.js +0 -390
  378. package/skills/cm-readit/tts-engine.md +0 -262
  379. package/skills/cm-readit/ui-patterns.md +0 -362
  380. package/skills/cm-readit/voice-cro.md +0 -223
@@ -0,0 +1,208 @@
1
+ "use strict";
2
+ /**
3
+ * Per-project learnings — append-only JSONL log under `.cm/learnings.jsonl`.
4
+ *
5
+ * Each learning is a small structured note that future sessions read at start
6
+ * (via cm-continuity) so the agent doesn't repeat past pitfalls or forget
7
+ * preferences. Inspired by gstack `/learn` but simpler — no sync required.
8
+ *
9
+ * Format (one JSON object per line):
10
+ * { "ts": "2026-05-07T12:00:00Z",
11
+ * "type": "pitfall" | "preference" | "pattern" | "fact",
12
+ * "scope": "deploy" | "ui" | "test" | ...,
13
+ * "note": "human readable note",
14
+ * "source": "cm-retro-cli" | "manual" | ... }
15
+ */
16
+ var __importDefault = (this && this.__importDefault) || function (mod) {
17
+ return (mod && mod.__esModule) ? mod : { "default": mod };
18
+ };
19
+ Object.defineProperty(exports, "__esModule", { value: true });
20
+ exports.LearningError = void 0;
21
+ exports.learningsPath = learningsPath;
22
+ exports.addLearning = addLearning;
23
+ exports.listLearnings = listLearnings;
24
+ exports.pruneLearnings = pruneLearnings;
25
+ exports.anonymize = anonymize;
26
+ exports.learningKey = learningKey;
27
+ exports.mergeLearnings = mergeLearnings;
28
+ exports.readLearningsFile = readLearningsFile;
29
+ exports.writeLearningsFile = writeLearningsFile;
30
+ exports.renderLearningsForContinuity = renderLearningsForContinuity;
31
+ const fs_1 = __importDefault(require("fs"));
32
+ const path_1 = __importDefault(require("path"));
33
+ const LEARNING_TYPES = new Set(['pitfall', 'preference', 'pattern', 'fact']);
34
+ function learningsPath(projectPath) {
35
+ return path_1.default.join(projectPath, '.cm', 'learnings.jsonl');
36
+ }
37
+ function ensureDir(file) {
38
+ const d = path_1.default.dirname(file);
39
+ if (!fs_1.default.existsSync(d))
40
+ fs_1.default.mkdirSync(d, { recursive: true });
41
+ }
42
+ class LearningError extends Error {
43
+ }
44
+ exports.LearningError = LearningError;
45
+ function validate(input) {
46
+ if (!LEARNING_TYPES.has(input.type)) {
47
+ throw new LearningError(`invalid learning type: ${input.type}`);
48
+ }
49
+ if (!input.scope || typeof input.scope !== 'string') {
50
+ throw new LearningError('learning.scope is required (string)');
51
+ }
52
+ if (!input.note || typeof input.note !== 'string') {
53
+ throw new LearningError('learning.note is required (string)');
54
+ }
55
+ if (input.note.length > 500) {
56
+ throw new LearningError(`learning.note too long (${input.note.length} > 500)`);
57
+ }
58
+ }
59
+ function addLearning(projectPath, input) {
60
+ var _a;
61
+ validate(input);
62
+ const learning = Object.assign({ ts: (_a = input.ts) !== null && _a !== void 0 ? _a : new Date().toISOString(), type: input.type, scope: input.scope, note: input.note }, (input.source ? { source: input.source } : {}));
63
+ const file = learningsPath(projectPath);
64
+ ensureDir(file);
65
+ fs_1.default.appendFileSync(file, JSON.stringify(learning) + '\n', 'utf8');
66
+ return learning;
67
+ }
68
+ function listLearnings(projectPath, query = {}) {
69
+ const file = learningsPath(projectPath);
70
+ if (!fs_1.default.existsSync(file))
71
+ return [];
72
+ const raw = fs_1.default.readFileSync(file, 'utf8');
73
+ const out = [];
74
+ for (const line of raw.split('\n')) {
75
+ if (!line.trim())
76
+ continue;
77
+ let parsed;
78
+ try {
79
+ parsed = JSON.parse(line);
80
+ }
81
+ catch (_a) {
82
+ continue; // skip malformed lines
83
+ }
84
+ if (query.type && parsed.type !== query.type)
85
+ continue;
86
+ if (query.scope && parsed.scope !== query.scope)
87
+ continue;
88
+ if (query.since && parsed.ts < query.since)
89
+ continue;
90
+ out.push(parsed);
91
+ }
92
+ // Newest first.
93
+ out.reverse();
94
+ if (query.limit && out.length > query.limit)
95
+ return out.slice(0, query.limit);
96
+ return out;
97
+ }
98
+ /**
99
+ * Remove learnings older than `maxAgeDays` (default 180).
100
+ * Returns the number of pruned entries.
101
+ */
102
+ function pruneLearnings(projectPath, maxAgeDays = 180) {
103
+ const file = learningsPath(projectPath);
104
+ if (!fs_1.default.existsSync(file))
105
+ return 0;
106
+ const cutoff = new Date(Date.now() - maxAgeDays * 24 * 60 * 60 * 1000).toISOString();
107
+ const raw = fs_1.default.readFileSync(file, 'utf8');
108
+ const kept = [];
109
+ let pruned = 0;
110
+ for (const line of raw.split('\n')) {
111
+ if (!line.trim())
112
+ continue;
113
+ try {
114
+ const parsed = JSON.parse(line);
115
+ if (parsed.ts >= cutoff) {
116
+ kept.push(line);
117
+ }
118
+ else {
119
+ pruned++;
120
+ }
121
+ }
122
+ catch (_a) {
123
+ kept.push(line); // keep malformed lines as-is
124
+ }
125
+ }
126
+ fs_1.default.writeFileSync(file, kept.join('\n') + (kept.length ? '\n' : ''), 'utf8');
127
+ return pruned;
128
+ }
129
+ /**
130
+ * Strip user-identifying / token-looking material from a learning before it
131
+ * leaves the project. Used by `cm learn sync` to push to a shared remote
132
+ * without leaking absolute paths, emails, or long credentials.
133
+ */
134
+ function anonymize(l) {
135
+ const stripPath = (s) => s
136
+ .replace(/\/Users\/[^/\s"']+/g, '~')
137
+ .replace(/\/home\/[^/\s"']+/g, '~')
138
+ .replace(/[A-Za-z]:\\Users\\[^\\\s"']+/g, '~');
139
+ const stripEmail = (s) => s.replace(/[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}/g, '<email>');
140
+ const stripToken = (s) =>
141
+ // Long opaque tokens — runs of 24+ url-safe chars without spaces.
142
+ s.replace(/[A-Za-z0-9_\-]{24,}/g, '<token>');
143
+ const clean = (s) => stripToken(stripEmail(stripPath(s)));
144
+ return Object.assign({ ts: l.ts, type: l.type, scope: clean(l.scope), note: clean(l.note) }, (l.source ? { source: clean(l.source) } : {}));
145
+ }
146
+ /**
147
+ * Stable identity hash for dedup across machines. Excludes `ts` so the same
148
+ * note appearing on two days collapses to one entry.
149
+ */
150
+ function learningKey(l) {
151
+ return `${l.type}|${l.scope}|${l.note}`;
152
+ }
153
+ /**
154
+ * Merge two learning lists, dropping duplicates by `learningKey`. The earliest
155
+ * timestamp wins (we treat the original observation as canonical).
156
+ */
157
+ function mergeLearnings(a, b) {
158
+ const map = new Map();
159
+ for (const l of [...a, ...b]) {
160
+ const k = learningKey(l);
161
+ const prev = map.get(k);
162
+ if (!prev || l.ts < prev.ts)
163
+ map.set(k, l);
164
+ }
165
+ return Array.from(map.values()).sort((x, y) => (x.ts < y.ts ? -1 : 1));
166
+ }
167
+ /**
168
+ * Read the JSONL file at an arbitrary path (used by sync to read the remote
169
+ * mirror copy). Returns [] if the file is missing.
170
+ */
171
+ function readLearningsFile(file) {
172
+ if (!fs_1.default.existsSync(file))
173
+ return [];
174
+ const out = [];
175
+ for (const line of fs_1.default.readFileSync(file, 'utf8').split('\n')) {
176
+ if (!line.trim())
177
+ continue;
178
+ try {
179
+ out.push(JSON.parse(line));
180
+ }
181
+ catch (_a) {
182
+ // skip malformed
183
+ }
184
+ }
185
+ return out;
186
+ }
187
+ function writeLearningsFile(file, list) {
188
+ const dir = path_1.default.dirname(file);
189
+ if (!fs_1.default.existsSync(dir))
190
+ fs_1.default.mkdirSync(dir, { recursive: true });
191
+ const body = list.map(l => JSON.stringify(l)).join('\n');
192
+ fs_1.default.writeFileSync(file, list.length ? body + '\n' : '', 'utf8');
193
+ }
194
+ /**
195
+ * Render the most recent N learnings as a compact Markdown block, suitable
196
+ * for injection into CONTINUITY.md by cm-continuity at session start.
197
+ */
198
+ function renderLearningsForContinuity(projectPath, limit = 10) {
199
+ const recent = listLearnings(projectPath, { limit });
200
+ if (recent.length === 0)
201
+ return '';
202
+ const lines = ['## Recent Learnings (auto-loaded)'];
203
+ for (const l of recent) {
204
+ const date = l.ts.slice(0, 10);
205
+ lines.push(`- [${date}] **${l.type}/${l.scope}**: ${l.note}`);
206
+ }
207
+ return lines.join('\n') + '\n';
208
+ }
@@ -55,7 +55,7 @@ const advisory_report_1 = require("./advisory-report");
55
55
  const advisory_handoff_1 = require("./advisory-handoff");
56
56
  // ─── Config ──────────────────────────────────────────────────────────────────
57
57
  const SERVER_NAME = 'cm-context';
58
- const SERVER_VERSION = '1.0.0';
58
+ const SERVER_VERSION = JSON.parse(require('fs').readFileSync(require('path').join(__dirname, '..', 'package.json'), 'utf-8')).version;
59
59
  function getProjectPath() {
60
60
  const args = process.argv.slice(2);
61
61
  const idx = args.indexOf('--project');
@@ -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
+ }
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ /**
3
+ * Skills-Lock — record canonical hashes for every active skill.
4
+ *
5
+ * Stored as `skills-lock.json` at the package root. Each entry records the
6
+ * version (frontmatter), a sha256 of the SKILL.md content, and a generated
7
+ * timestamp. The postinstall verifier compares the current SKILL.md hashes
8
+ * against the lock and warns on drift.
9
+ */
10
+ var __importDefault = (this && this.__importDefault) || function (mod) {
11
+ return (mod && mod.__esModule) ? mod : { "default": mod };
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.buildSkillsLock = buildSkillsLock;
15
+ exports.writeSkillsLock = writeSkillsLock;
16
+ exports.verifySkillsLock = verifySkillsLock;
17
+ const fs_1 = __importDefault(require("fs"));
18
+ const path_1 = __importDefault(require("path"));
19
+ const crypto_1 = __importDefault(require("crypto"));
20
+ function sha256OfFile(file) {
21
+ const buf = fs_1.default.readFileSync(file);
22
+ return crypto_1.default.createHash('sha256').update(buf).digest('hex');
23
+ }
24
+ function parseFrontmatter(text) {
25
+ const m = text.match(/^---\n([\s\S]*?)\n---/);
26
+ if (!m)
27
+ return {};
28
+ const out = {};
29
+ const v = m[1].match(/^version:\s*['"]?([\w.\-+]+)['"]?\s*$/m);
30
+ if (v)
31
+ out.version = v[1];
32
+ const d = m[1].match(/^deprecated:\s*(true|false)\s*$/m);
33
+ if (d)
34
+ out.deprecated = d[1] === 'true';
35
+ return out;
36
+ }
37
+ function buildSkillsLock(packageRoot) {
38
+ const skillsDir = path_1.default.join(packageRoot, 'skills');
39
+ const skills = {};
40
+ if (fs_1.default.existsSync(skillsDir)) {
41
+ for (const entry of fs_1.default.readdirSync(skillsDir, { withFileTypes: true })) {
42
+ if (!entry.isDirectory() || !entry.name.startsWith('cm-'))
43
+ continue;
44
+ const skillFile = path_1.default.join(skillsDir, entry.name, 'SKILL.md');
45
+ if (!fs_1.default.existsSync(skillFile))
46
+ continue;
47
+ const text = fs_1.default.readFileSync(skillFile, 'utf8');
48
+ const fm = parseFrontmatter(text);
49
+ skills[entry.name] = Object.assign(Object.assign({ sha256: sha256OfFile(skillFile) }, (fm.version ? { version: fm.version } : {})), (fm.deprecated ? { deprecated: true } : {}));
50
+ }
51
+ }
52
+ return {
53
+ version: 2,
54
+ generated_at: new Date().toISOString(),
55
+ skills,
56
+ };
57
+ }
58
+ function writeSkillsLock(packageRoot) {
59
+ const lock = buildSkillsLock(packageRoot);
60
+ const file = path_1.default.join(packageRoot, 'skills-lock.json');
61
+ fs_1.default.writeFileSync(file, JSON.stringify(lock, null, 2) + '\n', 'utf8');
62
+ return file;
63
+ }
64
+ function verifySkillsLock(packageRoot) {
65
+ var _a, _b;
66
+ const lockPath = path_1.default.join(packageRoot, 'skills-lock.json');
67
+ const result = { ok: true, missing: [], drifted: [], unlocked: [] };
68
+ if (!fs_1.default.existsSync(lockPath)) {
69
+ result.ok = false;
70
+ return result;
71
+ }
72
+ let lock;
73
+ try {
74
+ lock = JSON.parse(fs_1.default.readFileSync(lockPath, 'utf8'));
75
+ }
76
+ catch (_c) {
77
+ result.ok = false;
78
+ return result;
79
+ }
80
+ const current = buildSkillsLock(packageRoot);
81
+ for (const [name, entry] of Object.entries((_a = lock.skills) !== null && _a !== void 0 ? _a : {})) {
82
+ const cur = current.skills[name];
83
+ if (!cur) {
84
+ result.missing.push(name);
85
+ continue;
86
+ }
87
+ if (cur.sha256 !== entry.sha256)
88
+ result.drifted.push(name);
89
+ }
90
+ for (const name of Object.keys(current.skills)) {
91
+ if (!((_b = lock.skills) !== null && _b !== void 0 ? _b : {})[name])
92
+ result.unlocked.push(name);
93
+ }
94
+ result.ok = result.missing.length === 0 && result.drifted.length === 0;
95
+ return result;
96
+ }
@@ -2,6 +2,10 @@
2
2
  /**
3
3
  * Opinionated sprint pipeline + Context Bus files under `.cm/sprint/`.
4
4
  * Complements root `context-bus.json` with step artifacts (ADR 002).
5
+ *
6
+ * v2.0: optional structured handoff JSON via `src/handoff/`. Sprint skills
7
+ * may call `completeSprintStepWithHandoff()` to emit a typed handoff file
8
+ * alongside the Markdown artifact.
5
9
  */
6
10
  var __importDefault = (this && this.__importDefault) || function (mod) {
7
11
  return (mod && mod.__esModule) ? mod : { "default": mod };
@@ -12,6 +16,7 @@ exports.readSprintState = readSprintState;
12
16
  exports.writeSprintState = writeSprintState;
13
17
  exports.initSprint = initSprint;
14
18
  exports.completeSprintStep = completeSprintStep;
19
+ exports.completeSprintStepWithHandoff = completeSprintStepWithHandoff;
15
20
  exports.skipSprintStep = skipSprintStep;
16
21
  exports.resetSprint = resetSprint;
17
22
  exports.sprintDryRun = sprintDryRun;
@@ -19,6 +24,7 @@ exports.sprintArtifactPreviewFromDisk = sprintArtifactPreviewFromDisk;
19
24
  exports.skillMappingForStep = skillMappingForStep;
20
25
  const fs_1 = __importDefault(require("fs"));
21
26
  const path_1 = __importDefault(require("path"));
27
+ const handoff_1 = require("./handoff");
22
28
  exports.SPRINT_STEPS = [
23
29
  'brainstorm',
24
30
  'plan',
@@ -109,6 +115,26 @@ function completeSprintStep(projectPath, step, artifactBody) {
109
115
  appendEvent(projectPath, { type: 'complete', step, at: state.updated_at });
110
116
  return state;
111
117
  }
118
+ /**
119
+ * Complete a sprint step AND emit a typed handoff JSON under `.cm/handoff/`.
120
+ *
121
+ * Use this from sprint skills (cm-planning, cm-execution, cm-code-review,
122
+ * cm-quality-gate, cm-brainstorm-idea, cm-retro-cli) to make their output
123
+ * machine-readable for the next phase.
124
+ *
125
+ * The Markdown artifact is still written; handoff is additive.
126
+ */
127
+ function completeSprintStepWithHandoff(projectPath, step, artifactBody, handoff) {
128
+ const state = completeSprintStep(projectPath, step, artifactBody);
129
+ const handoffFile = (0, handoff_1.writeHandoff)(projectPath, handoff);
130
+ appendEvent(projectPath, {
131
+ type: 'handoff',
132
+ step,
133
+ schema: handoff.schema,
134
+ at: state.updated_at,
135
+ });
136
+ return { state, handoffFile };
137
+ }
112
138
  const SKIP_STUB = (step, at) => `# ${step}\n\n_Skipped via \`cm sprint skip\` at ${at}._\n`;
113
139
  function skipSprintStep(projectPath, step) {
114
140
  let state = readSprintState(projectPath);
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTaskService = exports.createProjectService = exports.createMessageRepo = exports.createActivityRepo = exports.isValidTransition = exports.createTaskRepo = exports.createProjectRepo = exports.DASHBOARD_DB_PATH = exports.runMigrations = exports.closeDashboardDb = exports.getDashboardDb = void 0;
4
+ var sqlite_1 = require("./sqlite");
5
+ Object.defineProperty(exports, "getDashboardDb", { enumerable: true, get: function () { return sqlite_1.getDashboardDb; } });
6
+ Object.defineProperty(exports, "closeDashboardDb", { enumerable: true, get: function () { return sqlite_1.closeDashboardDb; } });
7
+ Object.defineProperty(exports, "runMigrations", { enumerable: true, get: function () { return sqlite_1.runMigrations; } });
8
+ Object.defineProperty(exports, "DASHBOARD_DB_PATH", { enumerable: true, get: function () { return sqlite_1.DASHBOARD_DB_PATH; } });
9
+ var project_repo_1 = require("./repos/project-repo");
10
+ Object.defineProperty(exports, "createProjectRepo", { enumerable: true, get: function () { return project_repo_1.createProjectRepo; } });
11
+ var task_repo_1 = require("./repos/task-repo");
12
+ Object.defineProperty(exports, "createTaskRepo", { enumerable: true, get: function () { return task_repo_1.createTaskRepo; } });
13
+ Object.defineProperty(exports, "isValidTransition", { enumerable: true, get: function () { return task_repo_1.isValidTransition; } });
14
+ var activity_repo_1 = require("./repos/activity-repo");
15
+ Object.defineProperty(exports, "createActivityRepo", { enumerable: true, get: function () { return activity_repo_1.createActivityRepo; } });
16
+ var message_repo_1 = require("./repos/message-repo");
17
+ Object.defineProperty(exports, "createMessageRepo", { enumerable: true, get: function () { return message_repo_1.createMessageRepo; } });
18
+ var project_service_1 = require("./services/project-service");
19
+ Object.defineProperty(exports, "createProjectService", { enumerable: true, get: function () { return project_service_1.createProjectService; } });
20
+ var task_service_1 = require("./services/task-service");
21
+ Object.defineProperty(exports, "createTaskService", { enumerable: true, get: function () { return task_service_1.createTaskService; } });
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createActivityRepo = createActivityRepo;
4
+ // ─── Repo ───────────────────────────────────────────────────────────────────
5
+ function createActivityRepo(db) {
6
+ const insert = db.prepare(`
7
+ INSERT INTO activities (id, type, message, project_id, task_id, actor_type, actor_id, meta, created_at)
8
+ VALUES (@id, @type, @message, @project_id, @task_id, @actor_type, @actor_id, @meta, @created_at)
9
+ `);
10
+ const getById = db.prepare('SELECT * FROM activities WHERE id = ?');
11
+ const getByProject = db.prepare('SELECT * FROM activities WHERE project_id = ? ORDER BY created_at DESC LIMIT ?');
12
+ const getByTask = db.prepare('SELECT * FROM activities WHERE task_id = ? ORDER BY created_at DESC LIMIT ?');
13
+ const getRecent = db.prepare('SELECT * FROM activities ORDER BY created_at DESC LIMIT ?');
14
+ return {
15
+ create(input) {
16
+ var _a, _b, _c, _d;
17
+ const now = new Date().toISOString();
18
+ const row = {
19
+ id: input.id,
20
+ type: input.type,
21
+ message: input.message,
22
+ project_id: (_a = input.project_id) !== null && _a !== void 0 ? _a : null,
23
+ task_id: (_b = input.task_id) !== null && _b !== void 0 ? _b : null,
24
+ actor_type: (_c = input.actor_type) !== null && _c !== void 0 ? _c : null,
25
+ actor_id: (_d = input.actor_id) !== null && _d !== void 0 ? _d : null,
26
+ meta: input.meta ? JSON.stringify(input.meta) : null,
27
+ created_at: now,
28
+ };
29
+ insert.run(row);
30
+ return row;
31
+ },
32
+ getById(id) {
33
+ var _a;
34
+ return (_a = getById.get(id)) !== null && _a !== void 0 ? _a : null;
35
+ },
36
+ getByProject(projectId, limit = 50) {
37
+ return getByProject.all(projectId, limit);
38
+ },
39
+ getByTask(taskId, limit = 50) {
40
+ return getByTask.all(taskId, limit);
41
+ },
42
+ getRecent(limit = 50) {
43
+ return getRecent.all(limit);
44
+ },
45
+ };
46
+ }