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
package/dist/dashboard.js CHANGED
@@ -4,21 +4,33 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.launchDashboard = launchDashboard;
7
+ /// <reference types="pino-http" />
7
8
  const express_1 = __importDefault(require("express"));
8
9
  const chalk_1 = __importDefault(require("chalk"));
9
10
  const path_1 = __importDefault(require("path"));
10
11
  const fs_1 = __importDefault(require("fs"));
11
12
  const crypto_1 = __importDefault(require("crypto"));
13
+ const pino_1 = __importDefault(require("pino"));
14
+ const pino_http_1 = __importDefault(require("pino-http"));
12
15
  const data_1 = require("./data");
13
16
  const agent_dispatch_1 = require("./agent-dispatch");
17
+ const event_bus_1 = require("./realtime/event-bus");
18
+ const ws_hub_1 = require("./realtime/ws-hub");
14
19
  const continuity_1 = require("./continuity");
15
20
  const judge_1 = require("./judge");
16
21
  const skill_chain_1 = require("./skill-chain");
22
+ const validate_1 = require("./schemas/validate");
23
+ const task_schema_1 = require("./schemas/task-schema");
24
+ const security_headers_1 = require("./middleware/security-headers");
17
25
  // ─── Dashboard Server ───────────────────────────────────────────────────────
18
26
  function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
19
27
  const app = (0, express_1.default)();
20
28
  app.disable('x-powered-by');
29
+ app.use((0, security_headers_1.securityHeaders)());
21
30
  app.use(express_1.default.json({ limit: '1mb' }));
31
+ const logger = (0, pino_1.default)({ level: 'info' });
32
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
33
+ app.use((0, pino_http_1.default)({ logger: logger }));
22
34
  const publicDir = path_1.default.join(__dirname, '..', 'public', 'dashboard');
23
35
  app.use(express_1.default.static(publicDir));
24
36
  // ─── Project API ────────────────────────────────────────────────────────
@@ -30,7 +42,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
30
42
  });
31
43
  res.json(enriched);
32
44
  });
33
- app.post('/api/projects', (req, res) => {
45
+ app.post('/api/projects', (0, validate_1.validateBody)(task_schema_1.createProjectSchema), (req, res) => {
34
46
  const data = (0, data_1.loadData)();
35
47
  const { name, path: pp, agents } = req.body;
36
48
  if (!name || typeof name !== 'string') {
@@ -82,7 +94,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
82
94
  tasks = tasks.filter(t => t.projectId === req.query.projectId);
83
95
  res.json(tasks);
84
96
  });
85
- app.post('/api/tasks', (req, res) => {
97
+ app.post('/api/tasks', (0, validate_1.validateBody)(task_schema_1.createTaskSchema), (req, res) => {
86
98
  const data = (0, data_1.loadData)();
87
99
  const { title, description, column, priority, projectId, agent, skill } = req.body;
88
100
  if (!title || typeof title !== 'string') {
@@ -113,6 +125,8 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
113
125
  }
114
126
  (0, data_1.logActivity)(data, 'task_created', `Task "${task.title}" created`, rpid, agent || '', { taskId: task.id, column: tc });
115
127
  (0, data_1.saveData)(data);
128
+ event_bus_1.eventBus.emitTask({ type: 'task.created', taskId: task.id, projectId: task.projectId, data: task });
129
+ event_bus_1.eventBus.emitActivity({ type: 'activity.added', activity: { id: crypto_1.default.randomUUID(), type: 'task_created', message: `Task "${task.title}" created`, projectId: rpid, taskId: task.id, actorId: agent || '', createdAt: new Date().toISOString() } });
116
130
  res.status(201).json(task);
117
131
  });
118
132
  app.post('/api/tasks/sync', (req, res) => {
@@ -141,12 +155,15 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
141
155
  }
142
156
  (0, data_1.logActivity)(data, 'task_created', `Synced ${created.length} tasks`, project.id, agent || '', { count: created.length });
143
157
  (0, data_1.saveData)(data);
158
+ for (const t of created) {
159
+ event_bus_1.eventBus.emitTask({ type: 'task.created', taskId: t.id, projectId: t.projectId, data: t });
160
+ }
144
161
  res.status(201).json({ project, tasks: created });
145
162
  });
146
163
  // ─── Auto-Sync (Conversation Lifecycle) ─────────────────────────────
147
164
  // Agents and webhooks call this to report conversation status.
148
165
  // Upserts by conversationId — creates task if missing, transitions if status changes.
149
- app.post('/api/tasks/auto-sync', (req, res) => {
166
+ app.post('/api/tasks/auto-sync', (0, validate_1.validateBody)(task_schema_1.autoSyncSchema), (req, res) => {
150
167
  const data = (0, data_1.loadData)();
151
168
  const { conversationId, title, status, agent, skill, projectId, projectName, priority } = req.body;
152
169
  if (!conversationId || !title) {
@@ -161,11 +178,12 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
161
178
  'started': 'in-progress',
162
179
  'active': 'in-progress',
163
180
  'in-progress': 'in-progress',
181
+ 'in_progress': 'in-progress',
164
182
  'idle': 'in-progress',
165
183
  'review': 'review',
166
184
  'completed': 'done',
167
185
  'done': 'done',
168
- 'cancelled': 'done',
186
+ 'cancelled': 'cancelled',
169
187
  };
170
188
  const column = STATUS_TO_COLUMN[status || 'active'] || 'in-progress';
171
189
  // Find project — try by ID, then by name, then use first project
@@ -204,8 +222,10 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
204
222
  data.tasks.filter(t => t.column === oldCol && t.projectId === task.projectId).sort((a, b) => a.order - b.order).forEach((t, i) => { t.order = i; });
205
223
  const actType = column === 'done' ? 'task_done' : 'task_transitioned';
206
224
  (0, data_1.logActivity)(data, actType, `Auto-sync: "${task.title}" ${oldCol} → ${column}`, task.projectId, agent || task.agent, { from: oldCol, to: column, conversationId });
225
+ event_bus_1.eventBus.emitTask({ type: 'task.transitioned', taskId: task.id, projectId: task.projectId, data: { from: oldCol, to: column } });
207
226
  }
208
227
  (0, data_1.saveData)(data);
228
+ event_bus_1.eventBus.emitTask({ type: 'task.updated', taskId: task.id, projectId: task.projectId, data: data.tasks[taskIdx] });
209
229
  res.json({ action: 'updated', task: data.tasks[taskIdx] });
210
230
  }
211
231
  else {
@@ -229,6 +249,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
229
249
  data.tasks.push(task);
230
250
  (0, data_1.logActivity)(data, 'task_created', `Auto-sync: "${task.title}" created in ${column}`, project.id, agent || '', { conversationId });
231
251
  (0, data_1.saveData)(data);
252
+ event_bus_1.eventBus.emitTask({ type: 'task.created', taskId: task.id, projectId: task.projectId, data: task });
232
253
  res.status(201).json({ action: 'created', task });
233
254
  }
234
255
  });
@@ -252,13 +273,14 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
252
273
  }
253
274
  res.json({ removed, remaining: data.tasks.length });
254
275
  });
255
- app.put('/api/tasks/:id', (req, res) => {
276
+ app.put('/api/tasks/:id', (0, validate_1.validateBody)(task_schema_1.updateTaskSchema), (req, res) => {
256
277
  const data = (0, data_1.loadData)();
257
278
  const idx = data.tasks.findIndex(t => t.id === req.params.id);
258
279
  if (idx === -1) {
259
280
  res.status(404).json({ error: 'Task not found' });
260
281
  return;
261
282
  }
283
+ req.log = req.log.child({ task_id: data.tasks[idx].id });
262
284
  const { title, description, priority, agent, skill } = req.body;
263
285
  if (title !== undefined)
264
286
  data.tasks[idx].title = String(title).trim();
@@ -274,6 +296,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
274
296
  data.tasks[idx].updatedAt = new Date().toISOString();
275
297
  (0, data_1.logActivity)(data, 'task_updated', `Task "${data.tasks[idx].title}" updated`, data.tasks[idx].projectId, agent || '');
276
298
  (0, data_1.saveData)(data);
299
+ event_bus_1.eventBus.emitTask({ type: 'task.updated', taskId: data.tasks[idx].id, projectId: data.tasks[idx].projectId, data: data.tasks[idx] });
277
300
  res.json(data.tasks[idx]);
278
301
  });
279
302
  app.put('/api/tasks/:id/move', (req, res) => {
@@ -283,6 +306,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
283
306
  res.status(404).json({ error: 'Task not found' });
284
307
  return;
285
308
  }
309
+ req.log = req.log.child({ task_id: data.tasks[idx].id });
286
310
  const { column, order } = req.body;
287
311
  const vc = ['backlog', 'in-progress', 'review', 'done'];
288
312
  if (!column || !vc.includes(column)) {
@@ -304,6 +328,12 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
304
328
  const actType = column === 'done' ? 'task_done' : 'task_moved';
305
329
  (0, data_1.logActivity)(data, actType, `Task "${task.title}" moved: ${oldCol} → ${column}`, task.projectId, task.agent, { from: oldCol, to: column });
306
330
  (0, data_1.saveData)(data);
331
+ if (oldCol !== column) {
332
+ event_bus_1.eventBus.emitTask({ type: 'task.transitioned', taskId: task.id, projectId: task.projectId, data: { from: oldCol, to: column } });
333
+ }
334
+ else {
335
+ event_bus_1.eventBus.emitTask({ type: 'task.updated', taskId: task.id, projectId: task.projectId, data: task });
336
+ }
307
337
  res.json(task);
308
338
  });
309
339
  // ─── Valid Transition Map ─────────────────────────────────────────────
@@ -320,6 +350,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
320
350
  res.status(404).json({ error: 'Task not found' });
321
351
  return;
322
352
  }
353
+ req.log = req.log.child({ task_id: data.tasks[idx].id });
323
354
  const { column, reason } = req.body;
324
355
  const vc = ['backlog', 'in-progress', 'review', 'done'];
325
356
  if (!column || !vc.includes(column)) {
@@ -358,6 +389,8 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
358
389
  : `Task "${task.title}" transitioned: ${oldCol} → ${column}`;
359
390
  (0, data_1.logActivity)(data, actType, msg, task.projectId, task.agent, { from: oldCol, to: column, reason: reason || '' });
360
391
  (0, data_1.saveData)(data);
392
+ event_bus_1.eventBus.emitTask({ type: 'task.transitioned', taskId: task.id, projectId: task.projectId, data: { from: oldCol, to: column } });
393
+ event_bus_1.eventBus.emitActivity({ type: 'activity.added', activity: { id: crypto_1.default.randomUUID(), type: actType, message: msg, projectId: task.projectId, taskId: task.id, actorId: task.agent, createdAt: new Date().toISOString() } });
361
394
  res.json(task);
362
395
  });
363
396
  app.post('/api/tasks/bulk-transition', (req, res) => {
@@ -429,10 +462,13 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
429
462
  res.status(404).json({ error: 'Task not found' });
430
463
  return;
431
464
  }
465
+ req.log = req.log.child({ task_id: data.tasks[idx].id });
432
466
  const [removed] = data.tasks.splice(idx, 1);
433
467
  data.tasks.filter(t => t.column === removed.column && t.projectId === removed.projectId).sort((a, b) => a.order - b.order).forEach((t, i) => { t.order = i; });
434
468
  (0, data_1.logActivity)(data, 'task_deleted', `Task "${removed.title}" deleted`, removed.projectId, removed.agent);
435
469
  (0, data_1.saveData)(data);
470
+ event_bus_1.eventBus.emitTask({ type: 'task.deleted', taskId: removed.id, projectId: removed.projectId, data: {} });
471
+ event_bus_1.eventBus.emitActivity({ type: 'activity.added', activity: { id: crypto_1.default.randomUUID(), type: 'task_deleted', message: `Task "${removed.title}" deleted`, projectId: removed.projectId, taskId: removed.id, actorId: removed.agent, createdAt: new Date().toISOString() } });
436
472
  res.status(204).send();
437
473
  });
438
474
  // ─── Task Dispatch API ──────────────────────────────────────────────────
@@ -443,6 +479,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
443
479
  res.status(404).json({ error: 'Task not found' });
444
480
  return;
445
481
  }
482
+ req.log = req.log.child({ task_id: task.id });
446
483
  const project = data.projects.find(p => p.id === task.projectId);
447
484
  const force = req.query.force === 'true';
448
485
  // Validate before dispatch
@@ -898,11 +935,14 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
898
935
  res.json(chain || { match: false });
899
936
  });
900
937
  // ─── Fallback ──────────────────────────────────────────────────────────
938
+ app.use('/api/{*path}', (_req, res) => {
939
+ res.status(404).json({ error: 'not found' });
940
+ });
901
941
  app.get('/{*path}', (_req, res) => {
902
942
  res.sendFile(path_1.default.join(publicDir, 'index.html'));
903
943
  });
904
944
  // ─── Start Server ─────────────────────────────────────────────────────
905
- const server = app.listen(port, () => {
945
+ const server = app.listen(port, '127.0.0.1', () => {
906
946
  try {
907
947
  fs_1.default.writeFileSync(data_1.PID_FILE, String(process.pid));
908
948
  }
@@ -917,6 +957,7 @@ function launchDashboard(port = data_1.DEFAULT_PORT, silent = false) {
917
957
  console.log(chalk_1.default.gray(` 📊 Dashboard auto-started → http://codymaster.localhost:${port}`));
918
958
  }
919
959
  });
960
+ (0, ws_hub_1.initWsHub)(server);
920
961
  const cleanup = () => { try {
921
962
  fs_1.default.unlinkSync(data_1.PID_FILE);
922
963
  }
package/dist/data.js CHANGED
@@ -1,4 +1,13 @@
1
1
  "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
2
11
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
13
  };
@@ -7,6 +16,8 @@ exports.DEFAULT_PORT = exports.PID_FILE = exports.DATA_FILE = exports.DATA_DIR =
7
16
  exports.ensureDataDir = ensureDataDir;
8
17
  exports.loadData = loadData;
9
18
  exports.saveData = saveData;
19
+ exports.loadDataSafe = loadDataSafe;
20
+ exports.saveDataSafe = saveDataSafe;
10
21
  exports.logActivity = logActivity;
11
22
  exports.findProjectByNameOrId = findProjectByNameOrId;
12
23
  exports.findTaskByIdPrefix = findTaskByIdPrefix;
@@ -15,6 +26,8 @@ const path_1 = __importDefault(require("path"));
15
26
  const fs_1 = __importDefault(require("fs"));
16
27
  const os_1 = __importDefault(require("os"));
17
28
  const crypto_1 = __importDefault(require("crypto"));
29
+ const async_mutex_1 = require("async-mutex");
30
+ const dataMutex = new async_mutex_1.Mutex();
18
31
  // ─── Constants ──────────────────────────────────────────────────────────────
19
32
  exports.DATA_DIR = path_1.default.join(os_1.default.homedir(), '.codymaster');
20
33
  exports.DATA_FILE = path_1.default.join(exports.DATA_DIR, 'kanban.json');
@@ -94,6 +107,28 @@ function saveData(data) {
94
107
  ensureDataDir();
95
108
  fs_1.default.writeFileSync(exports.DATA_FILE, JSON.stringify(data, null, 2));
96
109
  }
110
+ function loadDataSafe() {
111
+ return __awaiter(this, void 0, void 0, function* () {
112
+ const release = yield dataMutex.acquire();
113
+ try {
114
+ return loadData();
115
+ }
116
+ finally {
117
+ release();
118
+ }
119
+ });
120
+ }
121
+ function saveDataSafe(data) {
122
+ return __awaiter(this, void 0, void 0, function* () {
123
+ const release = yield dataMutex.acquire();
124
+ try {
125
+ fs_1.default.writeFileSync(exports.DATA_FILE, JSON.stringify(data, null, 2));
126
+ }
127
+ finally {
128
+ release();
129
+ }
130
+ });
131
+ }
97
132
  // ─── Activity Logger ────────────────────────────────────────────────────────
98
133
  function logActivity(data, type, message, projectId = '', agent = '', metadata = {}) {
99
134
  data.activities.unshift({
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+ /**
3
+ * TDD Enforcement Gate — blocks execution without tests.
4
+ *
5
+ * TRIZ Principle #10 (Prior Action):
6
+ * Pre-flight check scans for test files BEFORE execution starts.
7
+ *
8
+ * TRIZ Principle #3 (Local Quality):
9
+ * Each task must have its own test file before implementation.
10
+ */
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.findTestFile = findTestFile;
16
+ exports.suggestTestFile = suggestTestFile;
17
+ exports.runTests = runTests;
18
+ exports.enforceTDD = enforceTDD;
19
+ exports.hasTestFile = hasTestFile;
20
+ const fs_1 = __importDefault(require("fs"));
21
+ const child_process_1 = require("child_process");
22
+ /**
23
+ * Find test file for a given source file.
24
+ * Mapping: src/foo.ts → test/foo.test.ts
25
+ * src/bar/baz.ts → test/bar/baz.test.ts
26
+ */
27
+ function findTestFile(sourceFile) {
28
+ const testFile = sourceFile
29
+ .replace(/^src\//, 'test/')
30
+ .replace(/\.ts$/, '.test.ts')
31
+ .replace(/\.js$/, '.test.js');
32
+ return fs_1.default.existsSync(testFile) ? testFile : null;
33
+ }
34
+ /**
35
+ * Suggest test file path for a given source file.
36
+ */
37
+ function suggestTestFile(sourceFile) {
38
+ return sourceFile
39
+ .replace(/^src\//, 'test/')
40
+ .replace(/\.ts$/, '.test.ts')
41
+ .replace(/\.js$/, '.test.js');
42
+ }
43
+ /**
44
+ * Run tests for a specific test file and return failure count.
45
+ */
46
+ function runTests(testFile) {
47
+ try {
48
+ const output = (0, child_process_1.execSync)(`npx vitest run ${testFile} --reporter=verbose`, {
49
+ encoding: 'utf-8',
50
+ timeout: 30000,
51
+ stdio: ['pipe', 'pipe', 'pipe'],
52
+ });
53
+ return { failures: 0, output };
54
+ }
55
+ catch (error) {
56
+ // vitest exits with non-zero code when tests fail
57
+ const output = error.stdout || error.stderr || '';
58
+ const failMatch = output.match(/(\d+) failed/);
59
+ const failures = failMatch ? parseInt(failMatch[1], 10) : 1;
60
+ return { failures, output };
61
+ }
62
+ }
63
+ /**
64
+ * Enforce TDD: verify test file exists and has failing tests (RED phase).
65
+ *
66
+ * Rules:
67
+ * 1. Test file MUST exist for target source file
68
+ * 2. Tests MUST fail (RED phase) before implementation
69
+ * 3. If all tests pass, user must write a failing test first
70
+ */
71
+ function enforceTDD(targetFiles) {
72
+ for (const file of targetFiles) {
73
+ // Skip test files themselves
74
+ if (file.includes('.test.') || file.includes('.spec.')) {
75
+ continue;
76
+ }
77
+ // Skip non-source files
78
+ if (!file.startsWith('src/') && !file.startsWith('lib/')) {
79
+ continue;
80
+ }
81
+ const testFile = findTestFile(file);
82
+ if (!testFile) {
83
+ return {
84
+ passed: false,
85
+ testFile: null,
86
+ message: `TDD GATE: No test file found for ${file}. Write test first: ${suggestTestFile(file)}`,
87
+ };
88
+ }
89
+ const result = runTests(testFile);
90
+ if (result.failures === 0) {
91
+ return {
92
+ passed: false,
93
+ testFile,
94
+ message: `TDD GATE: All tests pass in ${testFile}. Write a failing test for new behavior first (RED phase).`,
95
+ };
96
+ }
97
+ }
98
+ return { passed: true, testFile: null, message: 'TDD GATE: OK — failing tests found (RED phase)' };
99
+ }
100
+ /**
101
+ * Quick check: does test file exist? (no execution, fast)
102
+ */
103
+ function hasTestFile(targetFiles) {
104
+ for (const file of targetFiles) {
105
+ if (file.includes('.test.') || file.includes('.spec.'))
106
+ continue;
107
+ if (!file.startsWith('src/') && !file.startsWith('lib/'))
108
+ continue;
109
+ if (!findTestFile(file))
110
+ return false;
111
+ }
112
+ return true;
113
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.cancelTask = cancelTask;
16
+ const child_process_1 = require("child_process");
17
+ const os_1 = __importDefault(require("os"));
18
+ function cancelTask(taskId, pgid) {
19
+ return __awaiter(this, void 0, void 0, function* () {
20
+ if (os_1.default.platform() === 'win32') {
21
+ (0, child_process_1.execFileSync)('taskkill', ['/PID', String(pgid), '/T', '/F'], { timeout: 10000 });
22
+ }
23
+ else {
24
+ process.kill(-pgid, 'SIGTERM');
25
+ yield new Promise(resolve => setTimeout(resolve, 5000));
26
+ try {
27
+ process.kill(-pgid, 'SIGKILL');
28
+ }
29
+ catch (_a) {
30
+ // already dead
31
+ }
32
+ }
33
+ });
34
+ }
@@ -0,0 +1,74 @@
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.startGcLoop = startGcLoop;
7
+ exports.gcPass = gcPass;
8
+ const fs_1 = __importDefault(require("fs"));
9
+ const path_1 = __importDefault(require("path"));
10
+ const os_1 = __importDefault(require("os"));
11
+ const WORKSPACES_ROOT = path_1.default.join(os_1.default.homedir(), '.cm', 'workspaces');
12
+ const DEFAULT_GC_TTL_MS = 24 * 60 * 60 * 1000; // 24h
13
+ const DEFAULT_GC_ORPHAN_TTL_MS = 72 * 60 * 60 * 1000; // 72h
14
+ const GC_INTERVAL_MS = 60 * 60 * 1000; // 1h
15
+ function startGcLoop() {
16
+ return setInterval(() => {
17
+ gcPass();
18
+ }, GC_INTERVAL_MS);
19
+ }
20
+ function gcPass() {
21
+ let removed = 0;
22
+ let errors = 0;
23
+ if (!fs_1.default.existsSync(WORKSPACES_ROOT)) {
24
+ return { removed, errors };
25
+ }
26
+ const now = Date.now();
27
+ try {
28
+ const projects = fs_1.default.readdirSync(WORKSPACES_ROOT);
29
+ for (const project of projects) {
30
+ const projectDir = path_1.default.join(WORKSPACES_ROOT, project);
31
+ if (!fs_1.default.statSync(projectDir).isDirectory())
32
+ continue;
33
+ try {
34
+ const tasks = fs_1.default.readdirSync(projectDir);
35
+ for (const task of tasks) {
36
+ const taskDir = path_1.default.join(projectDir, task);
37
+ if (!fs_1.default.statSync(taskDir).isDirectory())
38
+ continue;
39
+ const gcMetaPath = path_1.default.join(taskDir, '.gc_meta.json');
40
+ try {
41
+ if (fs_1.default.existsSync(gcMetaPath)) {
42
+ const meta = JSON.parse(fs_1.default.readFileSync(gcMetaPath, 'utf-8'));
43
+ if (meta.completedAt) {
44
+ const completedTime = new Date(meta.completedAt).getTime();
45
+ if (now - completedTime > DEFAULT_GC_TTL_MS) {
46
+ fs_1.default.rmSync(taskDir, { recursive: true, force: true });
47
+ removed++;
48
+ }
49
+ }
50
+ }
51
+ else {
52
+ const stat = fs_1.default.statSync(taskDir);
53
+ const age = now - stat.mtimeMs;
54
+ if (age > DEFAULT_GC_ORPHAN_TTL_MS) {
55
+ fs_1.default.rmSync(taskDir, { recursive: true, force: true });
56
+ removed++;
57
+ }
58
+ }
59
+ }
60
+ catch (_a) {
61
+ errors++;
62
+ }
63
+ }
64
+ }
65
+ catch (_b) {
66
+ errors++;
67
+ }
68
+ }
69
+ }
70
+ catch (_c) {
71
+ errors++;
72
+ }
73
+ return { removed, errors };
74
+ }
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.cancelTask = exports.runTask = exports.gcPass = exports.startGcLoop = exports.reuseWorkdir = exports.writeGcMeta = exports.prepareWorkdir = void 0;
4
+ var workdir_1 = require("./workdir");
5
+ Object.defineProperty(exports, "prepareWorkdir", { enumerable: true, get: function () { return workdir_1.prepareWorkdir; } });
6
+ Object.defineProperty(exports, "writeGcMeta", { enumerable: true, get: function () { return workdir_1.writeGcMeta; } });
7
+ Object.defineProperty(exports, "reuseWorkdir", { enumerable: true, get: function () { return workdir_1.reuseWorkdir; } });
8
+ var gc_1 = require("./gc");
9
+ Object.defineProperty(exports, "startGcLoop", { enumerable: true, get: function () { return gc_1.startGcLoop; } });
10
+ Object.defineProperty(exports, "gcPass", { enumerable: true, get: function () { return gc_1.gcPass; } });
11
+ var runner_1 = require("./runner");
12
+ Object.defineProperty(exports, "runTask", { enumerable: true, get: function () { return runner_1.runTask; } });
13
+ var cancel_1 = require("./cancel");
14
+ Object.defineProperty(exports, "cancelTask", { enumerable: true, get: function () { return cancel_1.cancelTask; } });
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __asyncValues = (this && this.__asyncValues) || function (o) {
12
+ if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
13
+ var m = o[Symbol.asyncIterator], i;
14
+ return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
15
+ function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
16
+ function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
17
+ };
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ exports.runTask = runTask;
20
+ const workdir_1 = require("./workdir");
21
+ function runTask(opts) {
22
+ return __awaiter(this, void 0, void 0, function* () {
23
+ const { backend, taskId, projectId, prompt, execOpts, eventBus, priorWorkdir, pinnedSessionId, } = opts;
24
+ const projectShort = projectId.slice(0, 8);
25
+ const taskShort = taskId.slice(0, 8);
26
+ const workdir = priorWorkdir !== null && priorWorkdir !== void 0 ? priorWorkdir : (0, workdir_1.prepareWorkdir)(projectShort, taskShort);
27
+ const resolvedOpts = Object.assign(Object.assign({}, execOpts), { cwd: workdir, resumeSessionId: pinnedSessionId !== null && pinnedSessionId !== void 0 ? pinnedSessionId : execOpts.resumeSessionId });
28
+ const session = yield backend.execute(prompt, resolvedOpts);
29
+ let lastSessionId = pinnedSessionId;
30
+ const messageLoop = (() => __awaiter(this, void 0, void 0, function* () {
31
+ var _a, e_1, _b, _c;
32
+ try {
33
+ for (var _d = true, _e = __asyncValues(session.messages), _f; _f = yield _e.next(), _a = _f.done, !_a; _d = true) {
34
+ _c = _f.value;
35
+ _d = false;
36
+ const msg = _c;
37
+ emitAgentMessage(eventBus, taskId, projectId, msg);
38
+ if (msg.type === 'text' && msg.sessionId) {
39
+ lastSessionId = msg.sessionId;
40
+ }
41
+ }
42
+ }
43
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
44
+ finally {
45
+ try {
46
+ if (!_d && !_a && (_b = _e.return)) yield _b.call(_e);
47
+ }
48
+ finally { if (e_1) throw e_1.error; }
49
+ }
50
+ }))();
51
+ const [result] = yield Promise.all([session.result, messageLoop]);
52
+ if (lastSessionId && !result.sessionId) {
53
+ result.sessionId = lastSessionId;
54
+ }
55
+ (0, workdir_1.writeGcMeta)(projectShort, taskShort, {
56
+ taskId,
57
+ projectId,
58
+ completedAt: new Date().toISOString(),
59
+ });
60
+ return result;
61
+ });
62
+ }
63
+ function emitAgentMessage(eventBus, taskId, projectId, msg) {
64
+ eventBus.emitTask({
65
+ type: 'task.message',
66
+ taskId,
67
+ projectId,
68
+ data: { message: msg },
69
+ });
70
+ }
@@ -0,0 +1,31 @@
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.prepareWorkdir = prepareWorkdir;
7
+ exports.writeGcMeta = writeGcMeta;
8
+ exports.reuseWorkdir = reuseWorkdir;
9
+ const fs_1 = __importDefault(require("fs"));
10
+ const path_1 = __importDefault(require("path"));
11
+ const os_1 = __importDefault(require("os"));
12
+ const WORKSPACES_ROOT = path_1.default.join(os_1.default.homedir(), '.cm', 'workspaces');
13
+ function prepareWorkdir(projectShort, taskShort) {
14
+ const workdir = path_1.default.join(WORKSPACES_ROOT, projectShort, taskShort, 'workdir');
15
+ fs_1.default.mkdirSync(workdir, { recursive: true });
16
+ const outputDir = path_1.default.join(WORKSPACES_ROOT, projectShort, taskShort, 'output');
17
+ const logsDir = path_1.default.join(WORKSPACES_ROOT, projectShort, taskShort, 'logs');
18
+ fs_1.default.mkdirSync(outputDir, { recursive: true });
19
+ fs_1.default.mkdirSync(logsDir, { recursive: true });
20
+ return workdir;
21
+ }
22
+ function writeGcMeta(projectShort, taskShort, meta) {
23
+ const metaPath = path_1.default.join(WORKSPACES_ROOT, projectShort, taskShort, '.gc_meta.json');
24
+ fs_1.default.writeFileSync(metaPath, JSON.stringify(meta, null, 2));
25
+ }
26
+ function reuseWorkdir(existingPath) {
27
+ if (!fs_1.default.existsSync(existingPath)) {
28
+ throw new Error(`Workdir not found: ${existingPath}`);
29
+ }
30
+ return existingPath;
31
+ }
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ /**
3
+ * Handoff JSON contracts for the sprint flow (v2.0).
4
+ *
5
+ * Each sprint phase emits a typed handoff JSON under `.cm/handoff/`.
6
+ * Downstream skills read the predecessor's handoff to pick up cold,
7
+ * eliminating re-derivation cost.
8
+ *
9
+ * Schema versioning: every contract has a `schema: "<name>@<n>"` field.
10
+ * Bump @n on breaking change; readers should reject unknown majors.
11
+ */
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ exports.HANDOFF_FILENAMES = void 0;
14
+ exports.HANDOFF_FILENAMES = {
15
+ 'intent@1': 'intent.json',
16
+ 'plan@1': 'plan.json',
17
+ 'exec@1': 'exec.json',
18
+ 'review@1': 'review.json',
19
+ 'quality@1': 'quality.json',
20
+ 'retro@1': 'retro.json',
21
+ 'party@1': 'party.json',
22
+ };
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./contracts.js"), exports);
18
+ __exportStar(require("./io.js"), exports);