codymaster 5.2.0 → 7.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (380) hide show
  1. package/CHANGELOG.md +276 -0
  2. package/README.md +216 -333
  3. package/dist/agent/antigravity.js +152 -0
  4. package/dist/agent/backend.js +2 -0
  5. package/dist/agent/claude.js +196 -0
  6. package/dist/agent/codex.js +204 -0
  7. package/dist/agent/copilot.js +284 -0
  8. package/dist/agent/cursor.js +211 -0
  9. package/dist/agent/factory.js +30 -0
  10. package/dist/agent/gemini.js +142 -0
  11. package/dist/agent/opencode.js +205 -0
  12. package/dist/agent/spawn-helper.js +237 -0
  13. package/dist/agent/version.js +25 -0
  14. package/dist/browse/adapter-factory.js +69 -0
  15. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  16. package/dist/browse/adapters/playwright-adapter.js +309 -0
  17. package/dist/browse/adapters/types.js +6 -0
  18. package/dist/browse/error-collector.js +132 -0
  19. package/dist/browse/event-log.js +109 -0
  20. package/dist/browse/index.js +17 -0
  21. package/dist/browse-server.js +204 -120
  22. package/dist/cli/command-registry.js +12 -0
  23. package/dist/cli/commands/dashboard.js +76 -2
  24. package/dist/cli/commands/engineering.js +218 -4
  25. package/dist/cli/commands/install.js +160 -0
  26. package/dist/cli/commands/learn.js +181 -0
  27. package/dist/cli/commands/parallel.js +138 -0
  28. package/dist/cli/commands/quality.js +105 -0
  29. package/dist/cli/commands/stack.js +49 -0
  30. package/dist/cli/commands/update.js +159 -0
  31. package/dist/cli/update-check.js +94 -10
  32. package/dist/continuity.js +3 -1
  33. package/dist/dashboard.js +47 -6
  34. package/dist/data.js +35 -0
  35. package/dist/execution/tdd-gate.js +113 -0
  36. package/dist/executor/cancel.js +34 -0
  37. package/dist/executor/gc.js +74 -0
  38. package/dist/executor/index.js +14 -0
  39. package/dist/executor/runner.js +70 -0
  40. package/dist/executor/workdir.js +31 -0
  41. package/dist/handoff/contracts.js +22 -0
  42. package/dist/handoff/index.js +18 -0
  43. package/dist/handoff/io.js +121 -0
  44. package/dist/index.js +7 -3
  45. package/dist/indexer/stack-detect.js +219 -0
  46. package/dist/install/copy.js +98 -0
  47. package/dist/install/engine.js +42 -0
  48. package/dist/install/paths.js +70 -0
  49. package/dist/install/platforms/_simple.js +85 -0
  50. package/dist/install/platforms/antigravity.js +91 -0
  51. package/dist/install/platforms/claude-code.js +107 -0
  52. package/dist/install/platforms/cursor.js +77 -0
  53. package/dist/install/platforms/index.js +27 -0
  54. package/dist/install/platforms/simple.js +163 -0
  55. package/dist/install/profiles.js +75 -0
  56. package/dist/install/types.js +2 -0
  57. package/dist/learnings.js +208 -0
  58. package/dist/mcp-context-server.js +1 -1
  59. package/dist/middleware/metrics.js +30 -0
  60. package/dist/middleware/security-headers.js +14 -0
  61. package/dist/realtime/event-bus.js +29 -0
  62. package/dist/realtime/ws-hub.js +91 -0
  63. package/dist/schemas/task-schema.js +48 -0
  64. package/dist/schemas/validate.js +18 -0
  65. package/dist/skills-lock.js +96 -0
  66. package/dist/sprint-pipeline.js +26 -0
  67. package/dist/storage/index.js +21 -0
  68. package/dist/storage/repos/activity-repo.js +46 -0
  69. package/dist/storage/repos/message-repo.js +39 -0
  70. package/dist/storage/repos/project-repo.js +56 -0
  71. package/dist/storage/repos/task-repo.js +142 -0
  72. package/dist/storage/services/project-service.js +49 -0
  73. package/dist/storage/services/task-service.js +97 -0
  74. package/dist/storage/sqlite.js +113 -0
  75. package/dist/tier-classify.js +131 -0
  76. package/dist/ui/onboarding.js +51 -15
  77. package/dist/utils/cli-utils.js +7 -2
  78. package/dist/utils/design-taste.js +108 -0
  79. package/dist/utils/output-compress.js +143 -0
  80. package/dist/vibecoding-index.js +126 -0
  81. package/package.json +27 -4
  82. package/public/dashboard/app.js +52 -1
  83. package/scripts/build-skills-lock.mjs +88 -0
  84. package/scripts/build-skills.mjs +187 -28
  85. package/scripts/compress-skill.mjs +73 -0
  86. package/scripts/deprecate-skill.mjs +72 -0
  87. package/scripts/install.sh +170 -0
  88. package/scripts/mcp-bridge.js +2 -2
  89. package/scripts/postinstall.js +54 -287
  90. package/scripts/release.sh +126 -0
  91. package/scripts/update-changelog.sh +88 -0
  92. package/scripts/validate-skills.mjs +101 -4
  93. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  94. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  95. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  96. package/skills/cm-clean-code/SKILL.md +20 -0
  97. package/skills/cm-code-review/SKILL.md +21 -0
  98. package/skills/cm-codeintell/SKILL.md +9 -0
  99. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  100. package/skills/cm-conductor-worktrees/SKILL.md +17 -19
  101. package/skills/cm-continuity/SKILL.md +9 -0
  102. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  103. package/skills/cm-dashboard/SKILL.md +20 -9
  104. package/skills/cm-dashboard/ui/app.js +9 -1
  105. package/skills/cm-debugging/SKILL.md +9 -0
  106. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  107. package/skills/cm-design-studio/SKILL.md +17 -25
  108. package/skills/cm-design-system/SKILL.md +1 -0
  109. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  110. package/skills/cm-engineering-meta/SKILL.md +16 -63
  111. package/skills/cm-execution/SKILL.md +98 -0
  112. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  113. package/skills/cm-git-worktrees/SKILL.md +15 -146
  114. package/skills/cm-identity-guard/SKILL.md +8 -0
  115. package/skills/cm-planning/SKILL.md +63 -92
  116. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  117. package/skills/cm-post-deploy-canary/SKILL.md +17 -13
  118. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  119. package/skills/cm-qa-visual-cli/SKILL.md +16 -12
  120. package/skills/cm-quality-gate/SKILL.md +38 -0
  121. package/skills/cm-safe-deploy/SKILL.md +9 -0
  122. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  123. package/skills/cm-second-opinion-cli/SKILL.md +17 -14
  124. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  125. package/skills/cm-secret-shield/SKILL.md +15 -569
  126. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  127. package/skills/cm-security-gate/SKILL.md +15 -228
  128. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  129. package/skills/cm-skill-health/SKILL.md +16 -73
  130. package/skills/cm-skill-index/SKILL.md +8 -0
  131. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  132. package/skills/cm-skill-mastery/SKILL.md +16 -146
  133. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  134. package/skills/cm-skill-search/SKILL.md +17 -40
  135. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  136. package/skills/cm-skill-share/SKILL.md +17 -49
  137. package/skills/cm-sprint-bus/SKILL.md +9 -0
  138. package/skills/cm-start/SKILL.md +17 -0
  139. package/skills/cm-tdd/SKILL.md +19 -0
  140. package/skills/cm-terminal/SKILL.md +15 -0
  141. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  142. package/skills/cm-test-gate/SKILL.md +15 -234
  143. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  144. package/skills/cm-ui-preview/SKILL.md +16 -143
  145. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  146. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  147. package/skills/cm-ux-master/mcp/server.py +2 -2
  148. package/skills/profiles/design.txt +1 -1
  149. package/skills/profiles/full.txt +0 -10
  150. package/skills/profiles/growth.txt +8 -8
  151. package/skills/profiles/knowledge.txt +1 -1
  152. package/skills/profiles/top35.json +41 -0
  153. package/adapters/antigravity.js +0 -15
  154. package/adapters/claude-code.js +0 -17
  155. package/adapters/cursor.js +0 -16
  156. package/skills/cm-ads-tracker/SKILL.md +0 -401
  157. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  158. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  159. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  160. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  161. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  162. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  163. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  164. package/skills/cm-auto-publisher/SKILL.md +0 -81
  165. package/skills/cm-booking-calendar/SKILL.md +0 -521
  166. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  167. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  168. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  169. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  170. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  171. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  172. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  173. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  174. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  175. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  176. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  177. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  178. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  179. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  180. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  181. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  182. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  183. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  184. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  185. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  186. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  187. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  188. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  189. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  190. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  191. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  192. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  193. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  194. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  195. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  196. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  197. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  198. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  199. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  200. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  201. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  202. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  203. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  204. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  205. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  206. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  207. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  208. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  209. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  210. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  211. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  219. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  229. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  230. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  231. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  232. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  233. package/skills/cm-content-factory/AGENTS.md +0 -61
  234. package/skills/cm-content-factory/CLAUDE.md +0 -63
  235. package/skills/cm-content-factory/CURSOR.md +0 -43
  236. package/skills/cm-content-factory/Content Factory.zip +0 -0
  237. package/skills/cm-content-factory/SKILL.md +0 -416
  238. package/skills/cm-content-factory/cf +0 -313
  239. package/skills/cm-content-factory/config.schema.json +0 -397
  240. package/skills/cm-content-factory/dashboard/app.js +0 -556
  241. package/skills/cm-content-factory/dashboard/index.html +0 -397
  242. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  243. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  244. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  245. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  246. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  247. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  248. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  249. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  250. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  251. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  252. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  253. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  254. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  255. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  256. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  257. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  258. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  259. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  260. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  261. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  262. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  263. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  264. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  265. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  266. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  267. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  268. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  269. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  270. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  271. package/skills/cm-content-factory/landing/docs/content/memory-system.md +0 -38
  272. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  273. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  274. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  275. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  276. package/skills/cm-content-factory/landing/index.html +0 -680
  277. package/skills/cm-content-factory/landing/script.js +0 -143
  278. package/skills/cm-content-factory/landing/style.css +0 -1216
  279. package/skills/cm-content-factory/landing/translations.js +0 -508
  280. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  281. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  282. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  283. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  284. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  285. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  286. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  287. package/skills/cm-content-factory/scripts/audit.py +0 -106
  288. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  289. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  290. package/skills/cm-content-factory/scripts/extract.py +0 -132
  291. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  292. package/skills/cm-content-factory/scripts/memory.py +0 -521
  293. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  294. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  295. package/skills/cm-content-factory/scripts/plan.py +0 -163
  296. package/skills/cm-content-factory/scripts/publish.py +0 -145
  297. package/skills/cm-content-factory/scripts/research.py +0 -337
  298. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  299. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  300. package/skills/cm-content-factory/scripts/seo.py +0 -90
  301. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  302. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  303. package/skills/cm-content-factory/scripts/validate.py +0 -221
  304. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  305. package/skills/cm-content-factory/scripts/write.py +0 -93
  306. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  307. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  308. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  309. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  310. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  311. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  312. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  313. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  314. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  315. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  316. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  317. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  318. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  319. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  320. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  321. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  322. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  323. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  324. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  325. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  326. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  327. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  328. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  329. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  330. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  331. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  332. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  333. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  334. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  335. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  336. package/skills/cm-content-factory/tests/conftest.py +0 -66
  337. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  338. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  339. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  340. package/skills/cm-content-factory/tests/test_research.py +0 -56
  341. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  342. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  343. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  344. package/skills/cm-cro-methodology/SKILL.md +0 -290
  345. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  346. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  347. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  348. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  349. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  350. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  351. package/skills/cm-google-form/SKILL.md +0 -266
  352. package/skills/cm-google-form/templates/apps-script.js +0 -55
  353. package/skills/cm-google-form/templates/form-markup.html +0 -110
  354. package/skills/cm-google-form/templates/form-submit.js +0 -201
  355. package/skills/cm-google-form/templates/toast.css +0 -152
  356. package/skills/cm-growth-hacking/SKILL.md +0 -282
  357. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  358. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  359. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  360. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  361. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  362. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  363. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  364. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  365. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  366. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  367. package/skills/cm-jtbd/SKILL.md +0 -98
  368. package/skills/cm-notebooklm/SKILL.md +0 -156
  369. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  370. package/skills/cm-notebooklm/references/workflows.md +0 -60
  371. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  372. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  373. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  374. package/skills/cm-readit/SKILL.md +0 -289
  375. package/skills/cm-readit/audio-player.md +0 -206
  376. package/skills/cm-readit/examples/blog-reader.js +0 -352
  377. package/skills/cm-readit/examples/voice-cro.js +0 -390
  378. package/skills/cm-readit/tts-engine.md +0 -262
  379. package/skills/cm-readit/ui-patterns.md +0 -362
  380. package/skills/cm-readit/voice-cro.md +0 -223
@@ -0,0 +1,88 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Build/refresh skills-lock.json with sha256 + version for every skill.
4
+ *
5
+ * Usage:
6
+ * node scripts/build-skills-lock.mjs → rewrite skills-lock.json
7
+ * node scripts/build-skills-lock.mjs --check → exit 1 on drift, no write
8
+ */
9
+ import fs from 'fs';
10
+ import path from 'path';
11
+ import crypto from 'crypto';
12
+ import { fileURLToPath } from 'url';
13
+
14
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
15
+ const ROOT = path.resolve(__dirname, '..');
16
+ const SKILLS = path.join(ROOT, 'skills');
17
+ const LOCK = path.join(ROOT, 'skills-lock.json');
18
+
19
+ const args = new Set(process.argv.slice(2));
20
+ const checkOnly = args.has('--check');
21
+
22
+ function sha256(file) {
23
+ return crypto.createHash('sha256').update(fs.readFileSync(file)).digest('hex');
24
+ }
25
+
26
+ function parseFrontmatter(text) {
27
+ const m = text.match(/^---\n([\s\S]*?)\n---/);
28
+ if (!m) return {};
29
+ const out = {};
30
+ const v = m[1].match(/^version:\s*['"]?([\w.\-+]+)['"]?\s*$/m);
31
+ if (v) out.version = v[1];
32
+ const d = m[1].match(/^deprecated:\s*(true|false)\s*$/m);
33
+ if (d) out.deprecated = d[1] === 'true';
34
+ return out;
35
+ }
36
+
37
+ function buildLock() {
38
+ const skills = {};
39
+ if (fs.existsSync(SKILLS)) {
40
+ for (const name of fs.readdirSync(SKILLS).sort()) {
41
+ if (!name.startsWith('cm-')) continue;
42
+ const skillFile = path.join(SKILLS, name, 'SKILL.md');
43
+ if (!fs.existsSync(skillFile)) continue;
44
+ const text = fs.readFileSync(skillFile, 'utf8');
45
+ const fm = parseFrontmatter(text);
46
+ skills[name] = {
47
+ sha256: sha256(skillFile),
48
+ ...(fm.version ? { version: fm.version } : {}),
49
+ ...(fm.deprecated ? { deprecated: true } : {}),
50
+ };
51
+ }
52
+ }
53
+ return {
54
+ version: 2,
55
+ generated_at: new Date().toISOString(),
56
+ skills,
57
+ };
58
+ }
59
+
60
+ const next = buildLock();
61
+
62
+ if (checkOnly) {
63
+ if (!fs.existsSync(LOCK)) {
64
+ console.error('✗ skills-lock.json missing');
65
+ process.exit(1);
66
+ }
67
+ const prev = JSON.parse(fs.readFileSync(LOCK, 'utf8'));
68
+ const drift = [];
69
+ for (const [name, entry] of Object.entries(next.skills)) {
70
+ const before = prev.skills?.[name];
71
+ if (!before) drift.push(`+ ${name} (new)`);
72
+ else if (before.sha256 !== entry.sha256) drift.push(`Δ ${name} (hash drift)`);
73
+ }
74
+ for (const name of Object.keys(prev.skills ?? {})) {
75
+ if (!next.skills[name]) drift.push(`- ${name} (removed)`);
76
+ }
77
+ if (drift.length) {
78
+ console.error('✗ skills-lock drift:');
79
+ for (const line of drift) console.error(' ' + line);
80
+ console.error('Run `node scripts/build-skills-lock.mjs` to refresh.');
81
+ process.exit(1);
82
+ }
83
+ console.log(`✓ skills-lock OK (${Object.keys(next.skills).length} skills)`);
84
+ process.exit(0);
85
+ }
86
+
87
+ fs.writeFileSync(LOCK, JSON.stringify(next, null, 2) + '\n', 'utf8');
88
+ console.log(`✓ wrote skills-lock.json (${Object.keys(next.skills).length} skills)`);
@@ -1,46 +1,157 @@
1
1
  #!/usr/bin/env node
2
2
  /**
3
- * Generate SKILL.md from SKILL.md.tmpl + meta.json when present.
4
- * Usage: node scripts/build-skills.mjs [--check]
3
+ * Build / sync skills.
4
+ *
5
+ * Modes:
6
+ * 1. Template render — reads skills/<name>/SKILL.md.tmpl + meta.json,
7
+ * writes SKILL.md. Always runs.
8
+ * 2. Multi-platform sync — when --platforms is passed (or --all-platforms),
9
+ * mirrors ALL cm-* skill folders + _shared/ into per-platform install dirs.
10
+ *
11
+ * Usage:
12
+ * node scripts/build-skills.mjs # template only
13
+ * node scripts/build-skills.mjs --check # template + (when --platforms) drift check
14
+ * node scripts/build-skills.mjs --platforms cursor,codex,opencode
15
+ * node scripts/build-skills.mjs --all-platforms
5
16
  */
6
17
  import fs from 'fs';
7
18
  import path from 'path';
19
+ import crypto from 'crypto';
8
20
  import { fileURLToPath } from 'url';
9
21
 
10
22
  const __dirname = path.dirname(fileURLToPath(import.meta.url));
11
- const skillsRoot = path.join(__dirname, '..', 'skills');
12
- const check = process.argv.includes('--check');
23
+ const repoRoot = path.join(__dirname, '..');
24
+ const skillsRoot = path.join(repoRoot, 'skills');
25
+ const args = process.argv.slice(2);
26
+ const check = args.includes('--check');
27
+
28
+ function getFlag(name) {
29
+ const i = args.indexOf(`--${name}`);
30
+ if (i === -1) return null;
31
+ return args[i + 1] ?? '';
32
+ }
33
+
34
+ const platformsArg = getFlag('platforms');
35
+ const allPlatforms = args.includes('--all-platforms');
36
+
37
+ // All 14 supported platforms
38
+ const PLATFORM_DIRS = {
39
+ 'claude-code': path.join(repoRoot, '.claude', 'skills'),
40
+ 'claude-desktop': path.join(repoRoot, '.claude-desktop', 'skills'),
41
+ cursor: path.join(repoRoot, '.cursor-plugin', 'skills'),
42
+ windsurf: path.join(repoRoot, '.windsurf', 'skills'),
43
+ antigravity: path.join(repoRoot, '.gemini', 'skills'),
44
+ codex: path.join(repoRoot, '.codex', 'skills'),
45
+ opencode: path.join(repoRoot, '.opencode', 'skills'),
46
+ cline: path.join(repoRoot, '.cline', 'skills'),
47
+ kiro: path.join(repoRoot, '.kiro', 'skills'),
48
+ copilot: path.join(repoRoot, '.copilot', 'skills'),
49
+ aider: path.join(repoRoot, '.aider', 'skills'),
50
+ continue: path.join(repoRoot, '.continue', 'skills'),
51
+ 'amazon-q': path.join(repoRoot, '.amazonq', 'skills'),
52
+ amp: path.join(repoRoot, '.amp', 'skills'),
53
+ };
13
54
 
14
55
  function render(tmpl, vars) {
15
56
  return tmpl.replace(/\{\{(\w+)\}\}/g, (_, k) => (vars[k] != null ? String(vars[k]) : `{{${k}}}`));
16
57
  }
17
58
 
18
- let tmplCount = 0;
19
- if (!fs.existsSync(skillsRoot)) process.exit(0);
20
-
21
- for (const dir of fs.readdirSync(skillsRoot, { withFileTypes: true })) {
22
- if (!dir.isDirectory()) continue;
23
- const folder = path.join(skillsRoot, dir.name);
24
- const tmplPath = path.join(folder, 'SKILL.md.tmpl');
25
- const metaPath = path.join(folder, 'meta.json');
26
- const outPath = path.join(folder, 'SKILL.md');
27
- if (!fs.existsSync(tmplPath)) continue;
28
-
29
- tmplCount++;
30
- const tmpl = fs.readFileSync(tmplPath, 'utf8');
31
- let meta = {};
32
- if (fs.existsSync(metaPath)) {
33
- meta = JSON.parse(fs.readFileSync(metaPath, 'utf8'));
59
+ function sha256(buf) {
60
+ return crypto.createHash('sha256').update(buf).digest('hex');
61
+ }
62
+
63
+ function ensureDir(p) {
64
+ fs.mkdirSync(p, { recursive: true });
65
+ }
66
+
67
+ function copyFileIdempotent(src, dst) {
68
+ const srcBuf = fs.readFileSync(src);
69
+ if (fs.existsSync(dst)) {
70
+ const dstBuf = fs.readFileSync(dst);
71
+ if (sha256(srcBuf) === sha256(dstBuf)) return 'skipped';
34
72
  }
35
- const out = render(tmpl, meta);
36
- if (check) {
37
- const cur = fs.existsSync(outPath) ? fs.readFileSync(outPath, 'utf8') : '';
38
- if (cur !== out) {
39
- console.error(`check failed: ${outPath} out of date (run npm run build:skills)`);
40
- process.exit(2);
73
+ if (check) return 'drift';
74
+ ensureDir(path.dirname(dst));
75
+ fs.writeFileSync(dst, srcBuf);
76
+ return 'synced';
77
+ }
78
+
79
+ function copyDirShallow(srcDir, dstDir) {
80
+ const result = { synced: 0, skipped: 0, drift: 0 };
81
+ if (!fs.existsSync(srcDir)) return result;
82
+ ensureDir(dstDir);
83
+
84
+ const skillFile = path.join(srcDir, 'SKILL.md');
85
+ if (fs.existsSync(skillFile)) {
86
+ result[copyFileIdempotent(skillFile, path.join(dstDir, 'SKILL.md'))]++;
87
+ }
88
+
89
+ const refDir = path.join(srcDir, 'references');
90
+ if (fs.existsSync(refDir) && fs.statSync(refDir).isDirectory()) {
91
+ for (const entry of fs.readdirSync(refDir)) {
92
+ const s = path.join(refDir, entry);
93
+ if (fs.statSync(s).isFile()) {
94
+ result[copyFileIdempotent(s, path.join(dstDir, 'references', entry))]++;
95
+ }
96
+ }
97
+ }
98
+ return result;
99
+ }
100
+
101
+ // Copy _shared/ directory recursively
102
+ function copySharedHelpers(srcRoot, dstRoot) {
103
+ const sharedSrc = path.join(srcRoot, '_shared');
104
+ const sharedDst = path.join(dstRoot, '_shared');
105
+ if (!fs.existsSync(sharedSrc)) return { synced: 0, skipped: 0, drift: 0 };
106
+
107
+ const result = { synced: 0, skipped: 0, drift: 0 };
108
+ ensureDir(sharedDst);
109
+
110
+ for (const entry of fs.readdirSync(sharedSrc)) {
111
+ const srcFile = path.join(sharedSrc, entry);
112
+ const dstFile = path.join(sharedDst, entry);
113
+ if (fs.statSync(srcFile).isFile()) {
114
+ result[copyFileIdempotent(srcFile, dstFile)]++;
115
+ }
116
+ }
117
+ return result;
118
+ }
119
+
120
+ // Get ALL cm-* skills from skills/ directory
121
+ function getAllCmSkills() {
122
+ if (!fs.existsSync(skillsRoot)) return [];
123
+ return fs.readdirSync(skillsRoot, { withFileTypes: true })
124
+ .filter(d => d.isDirectory() && d.name.startsWith('cm-'))
125
+ .map(d => d.name);
126
+ }
127
+
128
+ // --- Mode 1: template render ---
129
+ let tmplCount = 0;
130
+ if (fs.existsSync(skillsRoot)) {
131
+ for (const dir of fs.readdirSync(skillsRoot, { withFileTypes: true })) {
132
+ if (!dir.isDirectory()) continue;
133
+ const folder = path.join(skillsRoot, dir.name);
134
+ const tmplPath = path.join(folder, 'SKILL.md.tmpl');
135
+ const metaPath = path.join(folder, 'meta.json');
136
+ const outPath = path.join(folder, 'SKILL.md');
137
+ if (!fs.existsSync(tmplPath)) continue;
138
+
139
+ tmplCount++;
140
+ const tmpl = fs.readFileSync(tmplPath, 'utf8');
141
+ let meta = {};
142
+ if (fs.existsSync(metaPath)) {
143
+ meta = JSON.parse(fs.readFileSync(metaPath, 'utf8'));
144
+ }
145
+ const out = render(tmpl, meta);
146
+ if (check) {
147
+ const cur = fs.existsSync(outPath) ? fs.readFileSync(outPath, 'utf8') : '';
148
+ if (cur !== out) {
149
+ console.error(`check failed: ${outPath} out of date (run npm run build:skills)`);
150
+ process.exit(2);
151
+ }
152
+ } else {
153
+ fs.writeFileSync(outPath, out, 'utf8');
41
154
  }
42
- } else {
43
- fs.writeFileSync(outPath, out, 'utf8');
44
155
  }
45
156
  }
46
157
 
@@ -49,3 +160,51 @@ if (tmplCount === 0) {
49
160
  } else {
50
161
  console.log(check ? `build-skills: --check OK (${tmplCount})` : `build-skills: wrote ${tmplCount} skill(s)`);
51
162
  }
163
+
164
+ // --- Mode 2: multi-platform sync ---
165
+ let platforms = [];
166
+ if (allPlatforms) platforms = Object.keys(PLATFORM_DIRS);
167
+ else if (platformsArg) {
168
+ platforms = platformsArg.split(',').map(s => s.trim()).filter(Boolean);
169
+ }
170
+
171
+ if (platforms.length > 0) {
172
+ // Get ALL cm-* skills (not just top 35)
173
+ const list = getAllCmSkills();
174
+ console.log(`build-skills: found ${list.length} cm-* skills to sync`);
175
+
176
+ for (const platform of platforms) {
177
+ const dst = PLATFORM_DIRS[platform];
178
+ if (!dst) {
179
+ console.error(`build-skills: unknown platform '${platform}' (valid: ${Object.keys(PLATFORM_DIRS).join(',')})`);
180
+ process.exit(2);
181
+ }
182
+
183
+ let synced = 0, skipped = 0, drift = 0, missing = 0;
184
+
185
+ // Sync _shared/ helpers
186
+ const sharedResult = copySharedHelpers(skillsRoot, dst);
187
+ synced += sharedResult.synced;
188
+ skipped += sharedResult.skipped;
189
+ drift += sharedResult.drift;
190
+
191
+ // Sync ALL cm-* skills
192
+ for (const name of list) {
193
+ const srcDir = path.join(skillsRoot, name);
194
+ if (!fs.existsSync(srcDir)) {
195
+ missing++;
196
+ console.warn(` ! ${platform}: skill '${name}' not found in skills/`);
197
+ continue;
198
+ }
199
+ const r = copyDirShallow(srcDir, path.join(dst, name));
200
+ synced += r.synced; skipped += r.skipped; drift += r.drift;
201
+ }
202
+
203
+ if (check && drift > 0) {
204
+ console.error(`build-skills: --check FAILED for ${platform} (drift=${drift})`);
205
+ process.exit(2);
206
+ }
207
+ const tag = check ? 'check' : 'sync';
208
+ console.log(`build-skills[${platform}] ${tag}: synced=${synced} skipped=${skipped} drift=${drift} missing=${missing} total=${list.length + 1}`);
209
+ }
210
+ }
@@ -0,0 +1,73 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Migrate a skill to v2 compressed format.
4
+ *
5
+ * - Adds frontmatter: `token_budget: <N>`, `compressed: true`, `deprecated: false`
6
+ * - Inserts `## TL;DR` block after the H1 if not present
7
+ * - Preserves the rest of the body verbatim
8
+ *
9
+ * Usage:
10
+ * node scripts/compress-skill.mjs <skill-name> <token_budget> "<tldr-line-1>" "<tldr-line-2>" ...
11
+ *
12
+ * Idempotent: skips skills already marked `compressed: true`.
13
+ */
14
+ import fs from 'fs';
15
+ import path from 'path';
16
+ import { fileURLToPath } from 'url';
17
+
18
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
19
+
20
+ const [, , name, budgetArg, ...tldrLines] = process.argv;
21
+ if (!name || !budgetArg || tldrLines.length === 0) {
22
+ console.error('Usage: compress-skill.mjs <skill-name> <token_budget> "<tldr-1>" ["<tldr-2>" ...]');
23
+ process.exit(1);
24
+ }
25
+ const budget = parseInt(budgetArg, 10);
26
+ if (Number.isNaN(budget) || budget < 100 || budget > 6000) {
27
+ console.error(`token_budget must be int 100..6000, got: ${budgetArg}`);
28
+ process.exit(1);
29
+ }
30
+
31
+ const file = path.join(__dirname, '..', 'skills', name, 'SKILL.md');
32
+ if (!fs.existsSync(file)) {
33
+ console.error(`✗ ${name}: SKILL.md not found`);
34
+ process.exit(1);
35
+ }
36
+
37
+ const original = fs.readFileSync(file, 'utf8');
38
+ if (/^compressed:\s*true/m.test(original)) {
39
+ console.log(`• ${name}: already compressed, skipping`);
40
+ process.exit(0);
41
+ }
42
+
43
+ const fmMatch = original.match(/^---\n([\s\S]*?)\n---\n([\s\S]*)$/);
44
+ if (!fmMatch) {
45
+ console.error(`✗ ${name}: missing YAML frontmatter`);
46
+ process.exit(1);
47
+ }
48
+ let fmText = fmMatch[1];
49
+ const body = fmMatch[2];
50
+
51
+ // Append fields if missing.
52
+ if (!/^token_budget:/m.test(fmText)) fmText += `\ntoken_budget: ${budget}`;
53
+ if (!/^compressed:/m.test(fmText)) fmText += `\ncompressed: true`;
54
+ if (!/^deprecated:/m.test(fmText)) fmText += `\ndeprecated: false`;
55
+
56
+ // Insert ## TL;DR after the H1 if absent.
57
+ let newBody = body;
58
+ if (!/^##\s+TL;DR\b/m.test(body)) {
59
+ const h1 = body.match(/^(#\s+[^\n]+\n)/m);
60
+ if (!h1) {
61
+ console.error(`✗ ${name}: missing H1`);
62
+ process.exit(1);
63
+ }
64
+ const tldrBlock =
65
+ `\n## TL;DR\n` +
66
+ tldrLines.map((l) => `- ${l}`).join('\n') +
67
+ `\n`;
68
+ newBody = body.replace(h1[0], h1[0] + tldrBlock);
69
+ }
70
+
71
+ const out = `---\n${fmText}\n---\n${newBody}`;
72
+ fs.writeFileSync(file, out, 'utf8');
73
+ console.log(`✓ ${name}: compressed (budget=${budget})`);
@@ -0,0 +1,72 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * Deprecate a skill: archives original SKILL.md to SKILL.archive.md
4
+ * and replaces SKILL.md with a small redirect stub.
5
+ *
6
+ * Usage:
7
+ * node scripts/deprecate-skill.mjs <skill-name> <merged-into> [reason]
8
+ *
9
+ * Idempotent: skips if SKILL.md already has `deprecated: true`.
10
+ */
11
+ import fs from 'fs';
12
+ import path from 'path';
13
+ import { fileURLToPath } from 'url';
14
+
15
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
16
+
17
+ const [, , name, mergedInto, ...reasonParts] = process.argv;
18
+ if (!name || !mergedInto) {
19
+ console.error('Usage: deprecate-skill.mjs <skill-name> <merged-into> [reason]');
20
+ process.exit(1);
21
+ }
22
+ const reason = reasonParts.join(' ') || `consolidated into ${mergedInto}`;
23
+
24
+ const dir = path.join(__dirname, '..', 'skills', name);
25
+ const file = path.join(dir, 'SKILL.md');
26
+ const archive = path.join(dir, 'SKILL.archive.md');
27
+
28
+ if (!fs.existsSync(file)) {
29
+ console.error(`✗ ${name}: SKILL.md not found`);
30
+ process.exit(1);
31
+ }
32
+
33
+ const original = fs.readFileSync(file, 'utf8');
34
+ if (/^deprecated:\s*true/m.test(original)) {
35
+ console.log(`• ${name}: already deprecated, skipping`);
36
+ process.exit(0);
37
+ }
38
+
39
+ if (!fs.existsSync(archive)) {
40
+ fs.writeFileSync(archive, original, 'utf8');
41
+ }
42
+
43
+ const stub = `---
44
+ name: ${name}
45
+ description: "[Deprecated] ${reason}. Use \`${mergedInto}\` instead."
46
+ deprecated: true
47
+ merged_into: ${mergedInto}
48
+ ---
49
+
50
+ # ${name} — Deprecated
51
+
52
+ > ⚠️ This skill is deprecated as of CodyMaster v6.0.0 and will be removed in v6.1.0.
53
+ >
54
+ > **Use \`${mergedInto}\` instead.** ${reason}.
55
+ >
56
+ > See [docs/migration-v2.md](../../docs/migration-v2.md) for the full mapping.
57
+
58
+ The original content is preserved at [SKILL.archive.md](SKILL.archive.md) for reference.
59
+
60
+ ## Migration
61
+
62
+ \`\`\`bash
63
+ # Old: cm <use this skill>
64
+ # New (v6.0+): cm ${mergedInto.replace(/^cm-/, '')} <equivalent action>
65
+ \`\`\`
66
+
67
+ If you depend on a capability that didn't carry over, please file an issue:
68
+ https://github.com/tody-agent/codymaster/issues
69
+ `;
70
+
71
+ fs.writeFileSync(file, stub, 'utf8');
72
+ console.log(`✓ ${name} → deprecated, redirects to ${mergedInto}`);
@@ -0,0 +1,170 @@
1
+ #!/bin/bash
2
+ # CodyMaster CLI Installer
3
+ # Usage: curl -fsSL https://raw.githubusercontent.com/todyle/codymaster/main/scripts/install.sh | bash
4
+ #
5
+ # Detects platform, checks prerequisites, installs globally via npm.
6
+
7
+ set -e
8
+
9
+ CM_VERSION="${CM_VERSION:-latest}"
10
+ PACKAGE_NAME="codymaster"
11
+
12
+ # Colors
13
+ RED='\033[0;31m'
14
+ GREEN='\033[0;32m'
15
+ YELLOW='\033[1;33m'
16
+ BLUE='\033[0;34m'
17
+ BOLD='\033[1m'
18
+ RESET='\033[0m'
19
+
20
+ info() { echo -e "${BLUE} ℹ ${RESET}$1"; }
21
+ ok() { echo -e "${GREEN} ✅ ${RESET}$1"; }
22
+ warn() { echo -e "${YELLOW} ⚠️ ${RESET}$1"; }
23
+ err() { echo -e "${RED} ❌ ${RESET}$1"; }
24
+
25
+ echo ""
26
+ echo -e "${BOLD} 🐹 CodyMaster Installer${RESET}"
27
+ echo -e " The Hamster-Powered AI Agent Framework"
28
+ echo ""
29
+
30
+ # ─── Detect Platform ──────────────────────────────────────────────
31
+ detect_platform() {
32
+ local os arch
33
+
34
+ case "$(uname -s)" in
35
+ Darwin*) os="macos" ;;
36
+ Linux*) os="linux" ;;
37
+ MINGW*|MSYS*|CYGWIN*) os="windows" ;;
38
+ *) os="unknown" ;;
39
+ esac
40
+
41
+ case "$(uname -m)" in
42
+ x86_64|amd64) arch="x64" ;;
43
+ arm64|aarch64) arch="arm64" ;;
44
+ *) arch="$(uname -m)" ;;
45
+ esac
46
+
47
+ echo "${os}-${arch}"
48
+ }
49
+
50
+ PLATFORM=$(detect_platform)
51
+ info "Platform: ${PLATFORM}"
52
+
53
+ # ─── Check Node.js ────────────────────────────────────────────────
54
+ check_node() {
55
+ if command -v node &>/dev/null; then
56
+ local node_version
57
+ node_version=$(node --version 2>/dev/null | sed 's/v//')
58
+ local major
59
+ major=$(echo "$node_version" | cut -d. -f1)
60
+
61
+ if [ "$major" -ge 18 ]; then
62
+ ok "Node.js v${node_version} found"
63
+ return 0
64
+ else
65
+ err "Node.js v${node_version} found but v18+ required"
66
+ return 1
67
+ fi
68
+ else
69
+ err "Node.js not found"
70
+ return 1
71
+ fi
72
+ }
73
+
74
+ # ─── Check npm ────────────────────────────────────────────────────
75
+ check_npm() {
76
+ if command -v npm &>/dev/null; then
77
+ local npm_version
78
+ npm_version=$(npm --version 2>/dev/null)
79
+ ok "npm v${npm_version} found"
80
+ return 0
81
+ else
82
+ err "npm not found"
83
+ return 1
84
+ fi
85
+ }
86
+
87
+ # ─── Install Node.js if missing ───────────────────────────────────
88
+ install_node() {
89
+ info "Installing Node.js via nvm..."
90
+
91
+ if command -v nvm &>/dev/null; then
92
+ nvm install --lts
93
+ nvm use --lts
94
+ elif [ -f "$HOME/.nvm/nvm.sh" ]; then
95
+ # shellcheck source=/dev/null
96
+ source "$HOME/.nvm/nvm.sh"
97
+ nvm install --lts
98
+ nvm use --lts
99
+ else
100
+ # Install nvm
101
+ info "Installing nvm..."
102
+ curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.3/install.sh | bash
103
+
104
+ export NVM_DIR="$HOME/.nvm"
105
+ # shellcheck source=/dev/null
106
+ [ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"
107
+ nvm install --lts
108
+ nvm use --lts
109
+ fi
110
+
111
+ if check_node; then
112
+ ok "Node.js installed successfully"
113
+ else
114
+ err "Node.js installation failed. Please install manually: https://nodejs.org"
115
+ exit 1
116
+ fi
117
+ }
118
+
119
+ # ─── Main Install Flow ───────────────────────────────────────────
120
+ main() {
121
+ # Check/install Node.js
122
+ if ! check_node; then
123
+ install_node
124
+ fi
125
+
126
+ # Check npm
127
+ if ! check_npm; then
128
+ err "npm is required but not found. Please install Node.js from https://nodejs.org"
129
+ exit 1
130
+ fi
131
+
132
+ # Install codymaster
133
+ echo ""
134
+ info "Installing codymaster..."
135
+
136
+ if [ "$CM_VERSION" = "latest" ]; then
137
+ npm install -g "$PACKAGE_NAME@latest"
138
+ else
139
+ npm install -g "$PACKAGE_NAME@${CM_VERSION}"
140
+ fi
141
+
142
+ # Verify installation
143
+ echo ""
144
+ if command -v cm &>/dev/null; then
145
+ local installed_version
146
+ installed_version=$(cm --version 2>/dev/null || echo "unknown")
147
+ ok "CodyMaster installed successfully!"
148
+ echo ""
149
+ echo -e " ${BOLD}Version:${RESET} v${installed_version}"
150
+ echo -e " ${BOLD}Command:${RESET} cm --help"
151
+ echo -e " ${BOLD}Docs:${RESET} https://github.com/todyle/codymaster"
152
+ echo ""
153
+ echo -e " ${BOLD}Quick start:${RESET}"
154
+ echo -e " cm status Show project summary"
155
+ echo -e " cm task add \"...\" Create a task"
156
+ echo -e " cm dashboard Start dashboard"
157
+ echo ""
158
+ else
159
+ warn "cm command not found in PATH. You may need to restart your shell:"
160
+ echo ""
161
+ echo " # For bash/zsh:"
162
+ echo " source ~/.bashrc # or source ~/.zshrc"
163
+ echo ""
164
+ echo " # Or add npm global bin to PATH:"
165
+ echo " export PATH=\"\$(npm config get prefix)/bin:\$PATH\""
166
+ echo ""
167
+ fi
168
+ }
169
+
170
+ main
@@ -89,7 +89,7 @@ async function cmSyncTodos({ todos, projectName, sessionId }) {
89
89
  dashboardRequest('POST', '/api/tasks/auto-sync', {
90
90
  conversationId: `${sid}:${todo.id}`,
91
91
  title: todo.content,
92
- status: STATUS_TO_COLUMN[todo.status] || 'backlog',
92
+ status: todo.status || 'pending', // Send original status, not mapped column
93
93
  agent: 'claude-code',
94
94
  priority: todo.priority || 'medium',
95
95
  projectName: project,
@@ -124,7 +124,7 @@ async function cmUpdateTask({ conversationId, status, title, projectName }) {
124
124
  const result = await dashboardRequest('POST', '/api/tasks/auto-sync', {
125
125
  conversationId: conversationId || `mcp-${Date.now()}:manual`,
126
126
  title: title || conversationId,
127
- status: STATUS_TO_COLUMN[status] || 'in-progress',
127
+ status: status || 'in_progress', // Send original status, not mapped column
128
128
  agent: 'claude-code',
129
129
  projectName: projectName || 'Claude Desktop',
130
130
  });