codymaster 5.2.0 → 7.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (378) 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/middleware/metrics.js +30 -0
  59. package/dist/middleware/security-headers.js +14 -0
  60. package/dist/realtime/event-bus.js +29 -0
  61. package/dist/realtime/ws-hub.js +91 -0
  62. package/dist/schemas/task-schema.js +48 -0
  63. package/dist/schemas/validate.js +18 -0
  64. package/dist/skills-lock.js +96 -0
  65. package/dist/sprint-pipeline.js +26 -0
  66. package/dist/storage/index.js +21 -0
  67. package/dist/storage/repos/activity-repo.js +46 -0
  68. package/dist/storage/repos/message-repo.js +39 -0
  69. package/dist/storage/repos/project-repo.js +56 -0
  70. package/dist/storage/repos/task-repo.js +142 -0
  71. package/dist/storage/services/project-service.js +49 -0
  72. package/dist/storage/services/task-service.js +97 -0
  73. package/dist/storage/sqlite.js +113 -0
  74. package/dist/tier-classify.js +131 -0
  75. package/dist/ui/onboarding.js +51 -15
  76. package/dist/utils/cli-utils.js +7 -2
  77. package/dist/utils/design-taste.js +108 -0
  78. package/dist/utils/output-compress.js +143 -0
  79. package/dist/vibecoding-index.js +126 -0
  80. package/package.json +19 -4
  81. package/public/dashboard/app.js +52 -1
  82. package/scripts/build-skills-lock.mjs +88 -0
  83. package/scripts/build-skills.mjs +187 -28
  84. package/scripts/compress-skill.mjs +73 -0
  85. package/scripts/deprecate-skill.mjs +72 -0
  86. package/scripts/install.sh +170 -0
  87. package/scripts/mcp-bridge.js +2 -2
  88. package/scripts/postinstall.js +54 -287
  89. package/scripts/update-changelog.sh +88 -0
  90. package/scripts/validate-skills.mjs +101 -4
  91. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  92. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  93. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  94. package/skills/cm-clean-code/SKILL.md +20 -0
  95. package/skills/cm-code-review/SKILL.md +21 -0
  96. package/skills/cm-codeintell/SKILL.md +9 -0
  97. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  98. package/skills/cm-conductor-worktrees/SKILL.md +17 -19
  99. package/skills/cm-continuity/SKILL.md +9 -0
  100. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  101. package/skills/cm-dashboard/SKILL.md +20 -9
  102. package/skills/cm-dashboard/ui/app.js +9 -1
  103. package/skills/cm-debugging/SKILL.md +9 -0
  104. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  105. package/skills/cm-design-studio/SKILL.md +17 -25
  106. package/skills/cm-design-system/SKILL.md +1 -0
  107. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  108. package/skills/cm-engineering-meta/SKILL.md +16 -63
  109. package/skills/cm-execution/SKILL.md +98 -0
  110. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  111. package/skills/cm-git-worktrees/SKILL.md +15 -146
  112. package/skills/cm-identity-guard/SKILL.md +8 -0
  113. package/skills/cm-planning/SKILL.md +63 -92
  114. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  115. package/skills/cm-post-deploy-canary/SKILL.md +17 -13
  116. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  117. package/skills/cm-qa-visual-cli/SKILL.md +16 -12
  118. package/skills/cm-quality-gate/SKILL.md +38 -0
  119. package/skills/cm-safe-deploy/SKILL.md +9 -0
  120. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  121. package/skills/cm-second-opinion-cli/SKILL.md +17 -14
  122. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  123. package/skills/cm-secret-shield/SKILL.md +15 -569
  124. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  125. package/skills/cm-security-gate/SKILL.md +15 -228
  126. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  127. package/skills/cm-skill-health/SKILL.md +16 -73
  128. package/skills/cm-skill-index/SKILL.md +8 -0
  129. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  130. package/skills/cm-skill-mastery/SKILL.md +16 -146
  131. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  132. package/skills/cm-skill-search/SKILL.md +17 -40
  133. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  134. package/skills/cm-skill-share/SKILL.md +17 -49
  135. package/skills/cm-sprint-bus/SKILL.md +9 -0
  136. package/skills/cm-start/SKILL.md +17 -0
  137. package/skills/cm-tdd/SKILL.md +19 -0
  138. package/skills/cm-terminal/SKILL.md +15 -0
  139. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  140. package/skills/cm-test-gate/SKILL.md +15 -234
  141. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  142. package/skills/cm-ui-preview/SKILL.md +16 -143
  143. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  144. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  145. package/skills/cm-ux-master/mcp/server.py +2 -2
  146. package/skills/profiles/design.txt +1 -1
  147. package/skills/profiles/full.txt +0 -10
  148. package/skills/profiles/growth.txt +8 -8
  149. package/skills/profiles/knowledge.txt +1 -1
  150. package/skills/profiles/top35.json +41 -0
  151. package/adapters/antigravity.js +0 -15
  152. package/adapters/claude-code.js +0 -17
  153. package/adapters/cursor.js +0 -16
  154. package/skills/cm-ads-tracker/SKILL.md +0 -401
  155. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  156. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  157. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  158. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  159. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  160. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  161. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  162. package/skills/cm-auto-publisher/SKILL.md +0 -81
  163. package/skills/cm-booking-calendar/SKILL.md +0 -521
  164. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  165. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  166. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  167. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  168. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  169. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  170. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  171. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  172. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  173. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  174. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  175. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  176. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  177. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  178. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  179. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  180. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  181. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  182. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  183. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  184. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  185. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  186. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  187. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  188. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  189. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  190. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  191. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  192. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  193. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  194. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  195. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  196. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  197. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  198. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  199. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  200. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  201. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  202. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  203. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  204. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  205. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  206. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  207. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  208. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  209. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  210. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  211. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  217. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  219. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  227. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  228. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  229. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  230. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  231. package/skills/cm-content-factory/AGENTS.md +0 -61
  232. package/skills/cm-content-factory/CLAUDE.md +0 -63
  233. package/skills/cm-content-factory/CURSOR.md +0 -43
  234. package/skills/cm-content-factory/Content Factory.zip +0 -0
  235. package/skills/cm-content-factory/SKILL.md +0 -416
  236. package/skills/cm-content-factory/cf +0 -313
  237. package/skills/cm-content-factory/config.schema.json +0 -397
  238. package/skills/cm-content-factory/dashboard/app.js +0 -556
  239. package/skills/cm-content-factory/dashboard/index.html +0 -397
  240. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  241. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  242. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  243. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  244. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  245. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  246. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  247. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  248. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  249. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  250. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  251. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  252. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  253. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  254. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  255. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  256. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  257. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  258. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  259. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  260. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  261. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  262. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  263. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  264. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  265. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  266. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  267. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  268. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  269. package/skills/cm-content-factory/landing/docs/content/memory-system.md +0 -38
  270. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  271. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  272. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  273. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  274. package/skills/cm-content-factory/landing/index.html +0 -680
  275. package/skills/cm-content-factory/landing/script.js +0 -143
  276. package/skills/cm-content-factory/landing/style.css +0 -1216
  277. package/skills/cm-content-factory/landing/translations.js +0 -508
  278. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  279. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  280. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  281. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  282. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  283. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  284. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  285. package/skills/cm-content-factory/scripts/audit.py +0 -106
  286. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  287. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  288. package/skills/cm-content-factory/scripts/extract.py +0 -132
  289. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  290. package/skills/cm-content-factory/scripts/memory.py +0 -521
  291. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  292. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  293. package/skills/cm-content-factory/scripts/plan.py +0 -163
  294. package/skills/cm-content-factory/scripts/publish.py +0 -145
  295. package/skills/cm-content-factory/scripts/research.py +0 -337
  296. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  297. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  298. package/skills/cm-content-factory/scripts/seo.py +0 -90
  299. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  300. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  301. package/skills/cm-content-factory/scripts/validate.py +0 -221
  302. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  303. package/skills/cm-content-factory/scripts/write.py +0 -93
  304. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  305. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  306. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  307. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  308. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  309. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  310. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  311. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  312. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  313. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  314. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  315. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  316. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  317. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  318. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  319. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  320. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  321. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  322. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  323. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  324. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  325. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  326. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  327. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  328. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  329. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  330. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  331. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  332. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  333. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  334. package/skills/cm-content-factory/tests/conftest.py +0 -66
  335. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  336. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  337. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  338. package/skills/cm-content-factory/tests/test_research.py +0 -56
  339. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  340. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  341. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  342. package/skills/cm-cro-methodology/SKILL.md +0 -290
  343. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  344. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  345. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  346. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  347. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  348. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  349. package/skills/cm-google-form/SKILL.md +0 -266
  350. package/skills/cm-google-form/templates/apps-script.js +0 -55
  351. package/skills/cm-google-form/templates/form-markup.html +0 -110
  352. package/skills/cm-google-form/templates/form-submit.js +0 -201
  353. package/skills/cm-google-form/templates/toast.css +0 -152
  354. package/skills/cm-growth-hacking/SKILL.md +0 -282
  355. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  356. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  357. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  358. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  359. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  360. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  361. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  362. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  363. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  364. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  365. package/skills/cm-jtbd/SKILL.md +0 -98
  366. package/skills/cm-notebooklm/SKILL.md +0 -156
  367. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  368. package/skills/cm-notebooklm/references/workflows.md +0 -60
  369. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  370. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  371. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  372. package/skills/cm-readit/SKILL.md +0 -289
  373. package/skills/cm-readit/audio-player.md +0 -206
  374. package/skills/cm-readit/examples/blog-reader.js +0 -352
  375. package/skills/cm-readit/examples/voice-cro.js +0 -390
  376. package/skills/cm-readit/tts-engine.md +0 -262
  377. package/skills/cm-readit/ui-patterns.md +0 -362
  378. 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);