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
@@ -1,4 +1,37 @@
1
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
2
35
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
36
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
37
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -32,13 +65,14 @@ function projectPath(opt) {
32
65
  return path_1.default.resolve(opt || process.cwd());
33
66
  }
34
67
  function registerEngineeringCommands(program) {
35
- const browse = program.command('browse').description('Playwright browse daemon (local QA / screenshots)');
68
+ const browse = program.command('browse').description('Browse daemon (Hybrid Bridge: agent-browser + Playwright)');
36
69
  browse
37
70
  .command('start')
38
71
  .option('-p, --port <n>', 'port (default: .cm/config.yaml browse.port or 17395)')
39
72
  .option('-H, --host <h>', 'bind host (default: config or 127.0.0.1)')
40
73
  .option('--token <t>', 'bearer token (or env CM_BROWSE_TOKEN or config browse.token)')
41
74
  .option('--headed', 'headed browser', false)
75
+ .option('--engine <e>', 'browser engine: auto (default), agent-browser, playwright', 'auto')
42
76
  .action((opts) => __awaiter(this, void 0, void 0, function* () {
43
77
  var _a, _b, _c, _d, _e, _f, _g;
44
78
  const root = process.cwd();
@@ -54,16 +88,168 @@ function registerEngineeringCommands(program) {
54
88
  port,
55
89
  token,
56
90
  headless: !opts.headed,
91
+ engine: opts.engine,
57
92
  });
58
93
  yield daemon.listen();
59
94
  console.log(chalk_1.default.green(`cm-browse listening http://${host}:${port}`));
60
95
  console.log(chalk_1.default.dim(`Authorization: Bearer ${token.slice(0, 8)}…`));
61
- console.log(chalk_1.default.dim('POST /session/start, /navigate, /refs/refresh, /click, /fill, GET /screenshot'));
96
+ console.log(chalk_1.default.dim(`Engine: ${opts.engine}`));
97
+ console.log(chalk_1.default.dim('Endpoints: POST /session/start, /navigate, /refs/refresh, /click, /fill'));
98
+ console.log(chalk_1.default.dim(' GET /screenshot, /console, /network, /errors, /a11y-snapshot, /engine'));
99
+ console.log(chalk_1.default.dim(' POST /record/start, /record/stop'));
62
100
  process.on('SIGINT', () => __awaiter(this, void 0, void 0, function* () {
63
101
  yield daemon.close();
64
102
  process.exit(0);
65
103
  }));
66
104
  }));
105
+ browse
106
+ .command('doctor')
107
+ .description('Check browser engine availability')
108
+ .action(() => __awaiter(this, void 0, void 0, function* () {
109
+ const { checkEngines } = yield Promise.resolve().then(() => __importStar(require('../../browse/adapter-factory')));
110
+ const engines = yield checkEngines();
111
+ console.log(chalk_1.default.bold('Browser engine status:'));
112
+ console.log(` agent-browser: ${engines['agent-browser'] ? chalk_1.default.green('available') : chalk_1.default.red('not found')}`);
113
+ console.log(` playwright: ${engines.playwright ? chalk_1.default.green('available') : chalk_1.default.red('not found')}`);
114
+ if (!engines['agent-browser'] && !engines.playwright) {
115
+ console.log(chalk_1.default.yellow('\nInstall one:'));
116
+ console.log(' npm i -g agent-browser && agent-browser install');
117
+ console.log(' npx playwright install chromium');
118
+ }
119
+ else if (!engines['agent-browser']) {
120
+ console.log(chalk_1.default.dim('\nTip: Install agent-browser for better performance + a11y tree:'));
121
+ console.log(' npm i -g agent-browser && agent-browser install');
122
+ }
123
+ }));
124
+ browse
125
+ .command('errors')
126
+ .description('List collected browser errors')
127
+ .option('--port <n>', 'browse daemon port (default: config or 17395)')
128
+ .option('--token <t>', 'or env CM_BROWSE_TOKEN or config browse.token')
129
+ .option('--type <t>', 'filter by type: js-error, network-fail, console-error, timeout, crash')
130
+ .option('--severity <s>', 'filter by severity: critical, error, warning, info')
131
+ .action((opts) => __awaiter(this, void 0, void 0, function* () {
132
+ var _a, _b, _c, _d;
133
+ const cfg = (0, cm_config_1.loadCmConfig)(process.cwd());
134
+ const token = opts.token || process.env.CM_BROWSE_TOKEN || ((_a = cfg.browse) === null || _a === void 0 ? void 0 : _a.token) || 'dev-token-change-me';
135
+ const port = parseInt(String((_d = (_b = opts.port) !== null && _b !== void 0 ? _b : (_c = cfg.browse) === null || _c === void 0 ? void 0 : _c.port) !== null && _d !== void 0 ? _d : 17395), 10);
136
+ const auth = `Bearer ${token}`;
137
+ try {
138
+ let path = '/errors';
139
+ const params = new URLSearchParams();
140
+ if (opts.type)
141
+ params.set('type', opts.type);
142
+ if (opts.severity)
143
+ params.set('severity', opts.severity);
144
+ if (params.toString())
145
+ path += `?${params.toString()}`;
146
+ const raw = yield browseRaw(port, path, auth);
147
+ const data = JSON.parse(raw);
148
+ if (data.errors.length === 0) {
149
+ console.log(chalk_1.default.green('No errors collected'));
150
+ }
151
+ else {
152
+ console.log(chalk_1.default.bold(`Found ${data.errors.length} errors (total: ${data.total}):`));
153
+ for (const e of data.errors) {
154
+ const icon = e.severity === 'critical' ? '🔴' : e.severity === 'error' ? '🟠' : '🟡';
155
+ console.log(` ${icon} [${e.type}] ${e.message.slice(0, 120)}`);
156
+ }
157
+ }
158
+ }
159
+ catch (e) {
160
+ console.error(chalk_1.default.red(e.message));
161
+ process.exit(1);
162
+ }
163
+ }));
164
+ browse
165
+ .command('snapshot')
166
+ .description('Get a11y tree snapshot with @eN refs')
167
+ .option('--port <n>', 'browse daemon port')
168
+ .option('--token <t>', 'or env CM_BROWSE_TOKEN or config')
169
+ .action((opts) => __awaiter(this, void 0, void 0, function* () {
170
+ var _a, _b, _c, _d;
171
+ const cfg = (0, cm_config_1.loadCmConfig)(process.cwd());
172
+ const token = opts.token || process.env.CM_BROWSE_TOKEN || ((_a = cfg.browse) === null || _a === void 0 ? void 0 : _a.token) || 'dev-token-change-me';
173
+ const port = parseInt(String((_d = (_b = opts.port) !== null && _b !== void 0 ? _b : (_c = cfg.browse) === null || _c === void 0 ? void 0 : _c.port) !== null && _d !== void 0 ? _d : 17395), 10);
174
+ const auth = `Bearer ${token}`;
175
+ try {
176
+ const raw = yield browseRaw(port, '/a11y-snapshot', auth);
177
+ const snap = JSON.parse(raw);
178
+ console.log(chalk_1.default.bold('A11y Snapshot:'));
179
+ console.log(chalk_1.default.dim(` Timestamp: ${snap.timestamp}`));
180
+ console.log(chalk_1.default.dim(` Refs: ${Object.keys(snap.refs).length} elements`));
181
+ for (const [ref, desc] of Object.entries(snap.refs)) {
182
+ console.log(` @${ref}: ${desc}`);
183
+ }
184
+ }
185
+ catch (e) {
186
+ console.error(chalk_1.default.red(e.message));
187
+ process.exit(1);
188
+ }
189
+ }));
190
+ browse
191
+ .command('engine')
192
+ .description('Show current browser engine info')
193
+ .option('--port <n>', 'browse daemon port')
194
+ .option('--token <t>', 'or env CM_BROWSE_TOKEN or config')
195
+ .action((opts) => __awaiter(this, void 0, void 0, function* () {
196
+ var _a, _b, _c, _d;
197
+ const cfg = (0, cm_config_1.loadCmConfig)(process.cwd());
198
+ const token = opts.token || process.env.CM_BROWSE_TOKEN || ((_a = cfg.browse) === null || _a === void 0 ? void 0 : _a.token) || 'dev-token-change-me';
199
+ const port = parseInt(String((_d = (_b = opts.port) !== null && _b !== void 0 ? _b : (_c = cfg.browse) === null || _c === void 0 ? void 0 : _c.port) !== null && _d !== void 0 ? _d : 17395), 10);
200
+ const auth = `Bearer ${token}`;
201
+ try {
202
+ const raw = yield browseRaw(port, '/engine', auth);
203
+ const info = JSON.parse(raw);
204
+ console.log(chalk_1.default.bold('Engine:'), info.name);
205
+ console.log(chalk_1.default.dim(` Version: ${info.version}`));
206
+ console.log(chalk_1.default.dim(` Active: ${info.active}`));
207
+ if (info.capabilities) {
208
+ console.log(chalk_1.default.dim(' Capabilities:'));
209
+ for (const [k, v] of Object.entries(info.capabilities)) {
210
+ console.log(` ${k}: ${v ? '✅' : '❌'}`);
211
+ }
212
+ }
213
+ }
214
+ catch (e) {
215
+ console.error(chalk_1.default.red(e.message));
216
+ process.exit(1);
217
+ }
218
+ }));
219
+ browse
220
+ .command('record')
221
+ .description('Video recording control')
222
+ .argument('<action>', 'start or stop')
223
+ .option('--port <n>', 'browse daemon port')
224
+ .option('--token <t>', 'or env CM_BROWSE_TOKEN or config')
225
+ .action((action, opts) => __awaiter(this, void 0, void 0, function* () {
226
+ var _a, _b, _c, _d;
227
+ const cfg = (0, cm_config_1.loadCmConfig)(process.cwd());
228
+ const token = opts.token || process.env.CM_BROWSE_TOKEN || ((_a = cfg.browse) === null || _a === void 0 ? void 0 : _a.token) || 'dev-token-change-me';
229
+ const port = parseInt(String((_d = (_b = opts.port) !== null && _b !== void 0 ? _b : (_c = cfg.browse) === null || _c === void 0 ? void 0 : _c.port) !== null && _d !== void 0 ? _d : 17395), 10);
230
+ const auth = `Bearer ${token}`;
231
+ try {
232
+ if (action === 'start') {
233
+ yield browseRequest(port, '/record/start', 'POST', auth, {});
234
+ console.log(chalk_1.default.green('Recording started'));
235
+ }
236
+ else if (action === 'stop') {
237
+ const raw = yield browseRequestRaw(port, '/record/stop', 'POST', auth);
238
+ const data = JSON.parse(raw);
239
+ console.log(chalk_1.default.green('Recording stopped'));
240
+ if (data.path)
241
+ console.log(chalk_1.default.dim(` Video: ${data.path}`));
242
+ }
243
+ else {
244
+ console.error(chalk_1.default.red('Usage: cm browse record <start|stop>'));
245
+ process.exit(1);
246
+ }
247
+ }
248
+ catch (e) {
249
+ console.error(chalk_1.default.red(e.message));
250
+ process.exit(1);
251
+ }
252
+ }));
67
253
  const guardian = program.command('guardian').description('Runtime safety: destructive command patterns + path freeze');
68
254
  guardian
69
255
  .command('check')
@@ -413,14 +599,14 @@ function registerEngineeringCommands(program) {
413
599
  .requiredOption('--branch <b>', 'branch name')
414
600
  .option('--base <b>', 'start from branch', 'main')
415
601
  .action((opts) => {
416
- (0, child_process_1.execSync)(`git worktree add -b ${opts.branch} ${opts.at} ${opts.base}`, {
602
+ (0, child_process_1.execFileSync)('git', ['worktree', 'add', '-b', opts.branch, opts.at, opts.base], {
417
603
  stdio: 'inherit',
418
604
  cwd: process.cwd(),
419
605
  });
420
606
  console.log(chalk_1.default.green('Worktree created'));
421
607
  });
422
608
  conductor.command('list').action(() => {
423
- (0, child_process_1.execSync)('git worktree list', { stdio: 'inherit', cwd: process.cwd() });
609
+ (0, child_process_1.execFileSync)('git', ['worktree', 'list'], { stdio: 'inherit', cwd: process.cwd() });
424
610
  });
425
611
  const retro = program
426
612
  .command('retro')
@@ -585,6 +771,34 @@ function browseRaw(port, pathname, auth) {
585
771
  }).on('error', reject);
586
772
  });
587
773
  }
774
+ function browseRequestRaw(port, pathname, method, auth, body = {}) {
775
+ return new Promise((resolve, reject) => {
776
+ const data = Buffer.from(JSON.stringify(body));
777
+ const req = http_1.default.request({
778
+ hostname: '127.0.0.1',
779
+ port,
780
+ path: pathname,
781
+ method,
782
+ headers: {
783
+ 'Content-Type': 'application/json',
784
+ 'Content-Length': data.length,
785
+ Authorization: auth,
786
+ },
787
+ }, (res) => {
788
+ let s = '';
789
+ res.on('data', (c) => (s += c));
790
+ res.on('end', () => {
791
+ if (res.statusCode && res.statusCode >= 400)
792
+ reject(new Error(`HTTP ${res.statusCode}: ${s}`));
793
+ else
794
+ resolve(s);
795
+ });
796
+ });
797
+ req.on('error', reject);
798
+ req.write(data);
799
+ req.end();
800
+ });
801
+ }
588
802
  function httpProbeUrl(url) {
589
803
  return __awaiter(this, void 0, void 0, function* () {
590
804
  const t0 = performance.now();
@@ -0,0 +1,160 @@
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.registerInstallCommands = registerInstallCommands;
16
+ const chalk_1 = __importDefault(require("chalk"));
17
+ const child_process_1 = require("child_process");
18
+ const path_1 = __importDefault(require("path"));
19
+ const fs_1 = __importDefault(require("fs"));
20
+ const engine_1 = require("../../install/engine");
21
+ const profiles_1 = require("../../install/profiles");
22
+ const repoRoot = path_1.default.join(__dirname, '..', '..', '..');
23
+ function registerInstallCommands(program) {
24
+ program
25
+ .command('install [platform]')
26
+ .description('Install CodyMaster skills to an AI coding platform')
27
+ .option('-p, --profile <name>', 'Skill profile: core | growth | design | knowledge | full', 'full')
28
+ .option('-s, --scope <scope>', 'Install scope for platforms that support it: user | project', 'user')
29
+ .option('--all', 'Install to every detected platform')
30
+ .option('--list', 'List supported platforms and exit')
31
+ .option('--sync', 'Sync skills to all platforms after install')
32
+ .option('--dry-run', 'Show what would change without writing any files')
33
+ .action((platform, opts) => __awaiter(this, void 0, void 0, function* () {
34
+ if (opts.list)
35
+ return printPlatforms();
36
+ const profile = String(opts.profile);
37
+ if (!(0, profiles_1.isValidProfile)(profile)) {
38
+ console.error(chalk_1.default.red(`Invalid profile: ${profile}`));
39
+ console.error(chalk_1.default.dim('Valid: core, growth, design, knowledge, full'));
40
+ process.exit(1);
41
+ }
42
+ if (opts.scope !== 'user' && opts.scope !== 'project') {
43
+ console.error(chalk_1.default.red(`Invalid scope: ${opts.scope} (expected user|project)`));
44
+ process.exit(1);
45
+ }
46
+ const installOpts = {
47
+ profile: profile,
48
+ scope: opts.scope,
49
+ dryRun: !!opts.dryRun,
50
+ };
51
+ let targets;
52
+ if (opts.all) {
53
+ targets = (0, engine_1.detectPlatforms)()
54
+ .filter((p) => p.installed)
55
+ .map((p) => p.platform.id);
56
+ if (targets.length === 0) {
57
+ console.error(chalk_1.default.red('No installed AI platforms detected.'));
58
+ console.error(chalk_1.default.dim("Pass a platform id explicitly: cm install claude-code"));
59
+ process.exit(1);
60
+ }
61
+ }
62
+ else if (platform) {
63
+ targets = [platform];
64
+ }
65
+ else {
66
+ printPlatforms();
67
+ console.log(chalk_1.default.dim('\nUsage: cm install <platform> [--profile core] [--scope user|project]'));
68
+ return;
69
+ }
70
+ console.log(chalk_1.default.bold(`\nInstalling profile=${profile} scope=${opts.scope}${opts.dryRun ? ' (dry-run)' : ''}`));
71
+ const results = yield (0, engine_1.installToMany)(targets, installOpts);
72
+ for (const r of results) {
73
+ console.log('');
74
+ console.log(chalk_1.default.bold.magenta(` ${r.platform}`));
75
+ console.log(chalk_1.default.dim(` → ${r.targetPath}`));
76
+ console.log(chalk_1.default.green(` ✓ ${r.installed.length} skills installed`) + chalk_1.default.dim(` (${r.skipped.length} skipped)`));
77
+ for (const h of r.postInstallHints)
78
+ console.log(chalk_1.default.cyan(` ℹ ${h}`));
79
+ }
80
+ // Auto-sync if --sync flag or --all flag
81
+ if ((opts.sync || opts.all) && !opts.dryRun) {
82
+ console.log(chalk_1.default.bold('\n Syncing skills to all platforms...'));
83
+ try {
84
+ (0, child_process_1.execSync)('node scripts/build-skills.mjs --all-platforms', {
85
+ stdio: 'inherit',
86
+ cwd: repoRoot,
87
+ timeout: 60000,
88
+ });
89
+ console.log(chalk_1.default.green(' ✅ Skills synced to all platforms'));
90
+ }
91
+ catch (error) {
92
+ console.log(chalk_1.default.yellow(' ⚠️ Sync failed (run `cm update --sync` manually)'));
93
+ }
94
+ }
95
+ console.log('');
96
+ }));
97
+ // ─── Doctor Command ─────────────────────────────────────────
98
+ program
99
+ .command('doctor')
100
+ .description('Check which AI platforms are installed and which have CodyMaster skills')
101
+ .option('--sync-check', 'Check skill sync status across platforms')
102
+ .action((opts) => {
103
+ console.log(chalk_1.default.bold('\nDetected platforms:\n'));
104
+ for (const d of (0, engine_1.detectPlatforms)()) {
105
+ const mark = d.installed ? chalk_1.default.green('●') : chalk_1.default.dim('○');
106
+ const detail = d.detail ? chalk_1.default.dim(` (${d.detail})`) : '';
107
+ console.log(` ${mark} ${d.platform.emoji} ${d.platform.name}${detail}`);
108
+ }
109
+ // Sync check
110
+ if (opts.syncCheck) {
111
+ console.log(chalk_1.default.bold('\n Sync Status:\n'));
112
+ checkSyncStatus();
113
+ }
114
+ console.log('');
115
+ });
116
+ }
117
+ function checkSyncStatus() {
118
+ const platforms = [
119
+ { name: 'claude-code', dir: '.claude/skills' },
120
+ { name: 'claude-desktop', dir: '.claude-desktop/skills' },
121
+ { name: 'cursor', dir: '.cursor-plugin/skills' },
122
+ { name: 'windsurf', dir: '.windsurf/skills' },
123
+ { name: 'antigravity', dir: '.gemini/skills' },
124
+ { name: 'codex', dir: '.codex/skills' },
125
+ { name: 'opencode', dir: '.opencode/skills' },
126
+ { name: 'cline', dir: '.cline/skills' },
127
+ { name: 'kiro', dir: '.kiro/skills' },
128
+ { name: 'copilot', dir: '.copilot/skills' },
129
+ { name: 'aider', dir: '.aider/skills' },
130
+ { name: 'continue', dir: '.continue/skills' },
131
+ { name: 'amazon-q', dir: '.amazonq/skills' },
132
+ { name: 'amp', dir: '.amp/skills' },
133
+ ];
134
+ let synced = 0;
135
+ let missing = 0;
136
+ for (const p of platforms) {
137
+ const fullPath = path_1.default.join(repoRoot, p.dir);
138
+ const hasShared = fs_1.default.existsSync(path_1.default.join(fullPath, '_shared', 'helpers.md'));
139
+ if (hasShared) {
140
+ synced++;
141
+ }
142
+ else {
143
+ missing++;
144
+ console.log(chalk_1.default.yellow(` ⚠ ${p.name}: _shared/helpers.md missing`));
145
+ }
146
+ }
147
+ if (missing === 0) {
148
+ console.log(chalk_1.default.green(` ✅ All ${synced} platforms synced`));
149
+ }
150
+ else {
151
+ console.log(chalk_1.default.dim(` ${synced} synced, ${missing} missing`));
152
+ console.log(chalk_1.default.dim(' Run `cm update --sync` to fix.'));
153
+ }
154
+ }
155
+ function printPlatforms() {
156
+ console.log(chalk_1.default.bold('\nSupported platforms:\n'));
157
+ for (const p of (0, engine_1.listPlatforms)()) {
158
+ console.log(` ${p.emoji} ${chalk_1.default.cyan(p.id.padEnd(16))} ${chalk_1.default.dim(p.name)}`);
159
+ }
160
+ }
@@ -0,0 +1,181 @@
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.syncLearnings = syncLearnings;
7
+ exports.registerLearnCommands = registerLearnCommands;
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ const path_1 = __importDefault(require("path"));
10
+ const os_1 = __importDefault(require("os"));
11
+ const fs_1 = __importDefault(require("fs"));
12
+ const child_process_1 = require("child_process");
13
+ const learnings_1 = require("../../learnings");
14
+ const VALID_TYPES = ['pitfall', 'preference', 'pattern', 'fact'];
15
+ function resolveProject(opts) {
16
+ var _a;
17
+ return path_1.default.resolve((_a = opts.project) !== null && _a !== void 0 ? _a : process.cwd());
18
+ }
19
+ function git(cwd, args) {
20
+ return (0, child_process_1.execFileSync)('git', args, { cwd, encoding: 'utf8', stdio: ['ignore', 'pipe', 'pipe'] });
21
+ }
22
+ function syncLearnings(projectPath, opts) {
23
+ var _a;
24
+ const syncDir = (_a = opts.syncDir) !== null && _a !== void 0 ? _a : path_1.default.join(os_1.default.homedir(), '.cm', 'learnings-sync');
25
+ const remoteFile = path_1.default.join(syncDir, 'learnings.jsonl');
26
+ if (!fs_1.default.existsSync(path_1.default.join(syncDir, '.git'))) {
27
+ fs_1.default.mkdirSync(path_1.default.dirname(syncDir), { recursive: true });
28
+ if (fs_1.default.existsSync(syncDir)) {
29
+ // Existing non-git dir — abort rather than wipe.
30
+ throw new Error(`${syncDir} exists but is not a git checkout`);
31
+ }
32
+ git(path_1.default.dirname(syncDir), ['clone', opts.remote, path_1.default.basename(syncDir)]);
33
+ // Ensure a local identity exists so commits succeed even when the host
34
+ // has no global git config (CI runners, fresh containers).
35
+ try {
36
+ git(syncDir, ['config', 'user.email', 'cm-learn-sync@codymaster.local']);
37
+ }
38
+ catch (_b) { }
39
+ try {
40
+ git(syncDir, ['config', 'user.name', 'cm-learn-sync']);
41
+ }
42
+ catch (_c) { }
43
+ }
44
+ else {
45
+ // Make sure we point at the requested remote, then refresh.
46
+ try {
47
+ git(syncDir, ['remote', 'set-url', 'origin', opts.remote]);
48
+ }
49
+ catch (_d) {
50
+ git(syncDir, ['remote', 'add', 'origin', opts.remote]);
51
+ }
52
+ try {
53
+ git(syncDir, ['pull', '--ff-only', 'origin', 'HEAD']);
54
+ }
55
+ catch (_e) {
56
+ // Empty repo / unborn HEAD — ignore; nothing to pull.
57
+ }
58
+ }
59
+ const localFile = (0, learnings_1.learningsPath)(projectPath);
60
+ const localBefore = (0, learnings_1.readLearningsFile)(localFile);
61
+ const remoteBefore = (0, learnings_1.readLearningsFile)(remoteFile);
62
+ const merged = (0, learnings_1.mergeLearnings)(localBefore, remoteBefore);
63
+ // Local: write merged set verbatim (keeps full fidelity for the user).
64
+ (0, learnings_1.writeLearningsFile)(localFile, merged);
65
+ const pulled = merged.length - localBefore.length;
66
+ if (opts.pullOnly) {
67
+ return { pulled, pushed: 0, localTotal: merged.length };
68
+ }
69
+ // Remote: write anonymized merge.
70
+ const anonMerged = (0, learnings_1.mergeLearnings)(remoteBefore, localBefore.map(learnings_1.anonymize));
71
+ (0, learnings_1.writeLearningsFile)(remoteFile, anonMerged);
72
+ const pushed = anonMerged.length - remoteBefore.length;
73
+ if (pushed > 0) {
74
+ git(syncDir, ['add', 'learnings.jsonl']);
75
+ try {
76
+ git(syncDir, ['commit', '-m', `learn: +${pushed} from ${path_1.default.basename(projectPath)}`]);
77
+ git(syncDir, ['push', 'origin', 'HEAD']);
78
+ }
79
+ catch (e) {
80
+ // Bubble up so the caller can decide; non-zero pushes left in local mirror are fine.
81
+ throw new Error(`git push failed: ${e.message}`);
82
+ }
83
+ }
84
+ return { pulled, pushed, localTotal: merged.length };
85
+ }
86
+ function registerLearnCommands(program) {
87
+ program
88
+ .command('learn <cmd> [args...]')
89
+ .description('Per-project learnings log (.cm/learnings.jsonl) — gstack-style notes')
90
+ .option('-p, --project <path>', 'Project path (default: cwd)')
91
+ .option('-t, --type <type>', 'pitfall | preference | pattern | fact', 'fact')
92
+ .option('-s, --scope <scope>', 'Scope tag (deploy, ui, test, ...)', 'general')
93
+ .option('--source <source>', 'Origin label (e.g. cm-retro-cli)', 'manual')
94
+ .option('--days <n>', 'For prune: max age in days', '180')
95
+ .option('--limit <n>', 'For list: max rows', '20')
96
+ .option('--filter-type <type>', 'For list: filter by type')
97
+ .option('--filter-scope <scope>', 'For list: filter by scope')
98
+ .option('--remote <url>', 'For sync: git remote URL of the shared learnings repo')
99
+ .option('--pull-only', 'For sync: pull + merge only, do not push back')
100
+ .option('--sync-dir <path>', 'For sync: working dir (default: ~/.cm/learnings-sync)')
101
+ .action((cmd, args, opts) => {
102
+ const project = resolveProject(opts);
103
+ switch (cmd) {
104
+ case 'add': {
105
+ const note = args.join(' ').trim();
106
+ if (!note) {
107
+ console.error(chalk_1.default.red('Usage: cm learn add "<note>" [--type ... --scope ...]'));
108
+ process.exitCode = 1;
109
+ return;
110
+ }
111
+ if (!VALID_TYPES.includes(opts.type)) {
112
+ console.error(chalk_1.default.red(`Invalid --type. Use one of: ${VALID_TYPES.join(', ')}`));
113
+ process.exitCode = 1;
114
+ return;
115
+ }
116
+ try {
117
+ const l = (0, learnings_1.addLearning)(project, {
118
+ type: opts.type,
119
+ scope: opts.scope,
120
+ note,
121
+ source: opts.source,
122
+ });
123
+ console.log(chalk_1.default.green(`✓ Learned [${l.type}/${l.scope}]: ${l.note}`));
124
+ }
125
+ catch (e) {
126
+ console.error(chalk_1.default.red(`✗ ${e.message}`));
127
+ process.exitCode = 1;
128
+ }
129
+ return;
130
+ }
131
+ case 'list':
132
+ case 'ls': {
133
+ const items = (0, learnings_1.listLearnings)(project, {
134
+ limit: parseInt(opts.limit, 10),
135
+ type: opts.filterType,
136
+ scope: opts.filterScope,
137
+ });
138
+ if (items.length === 0) {
139
+ console.log(chalk_1.default.dim('(no learnings yet)'));
140
+ return;
141
+ }
142
+ for (const l of items) {
143
+ const date = l.ts.slice(0, 10);
144
+ console.log(`${chalk_1.default.gray(date)} ${chalk_1.default.cyan(l.type.padEnd(10))} ${chalk_1.default.yellow(l.scope.padEnd(12))} ${l.note}`);
145
+ }
146
+ console.log(chalk_1.default.dim(`\n${items.length} learning(s)`));
147
+ return;
148
+ }
149
+ case 'prune': {
150
+ const days = parseInt(opts.days, 10);
151
+ const n = (0, learnings_1.pruneLearnings)(project, days);
152
+ console.log(chalk_1.default.green(`✓ Pruned ${n} learning(s) older than ${days} days`));
153
+ return;
154
+ }
155
+ case 'sync': {
156
+ if (!opts.remote) {
157
+ console.error(chalk_1.default.red('Usage: cm learn sync --remote <git-url> [--pull-only]'));
158
+ process.exitCode = 1;
159
+ return;
160
+ }
161
+ try {
162
+ const result = syncLearnings(project, {
163
+ remote: opts.remote,
164
+ pullOnly: !!opts.pullOnly,
165
+ syncDir: opts.syncDir,
166
+ });
167
+ console.log(chalk_1.default.green(`✓ sync ok — pulled=${result.pulled} pushed=${result.pushed} local=${result.localTotal}`));
168
+ }
169
+ catch (e) {
170
+ console.error(chalk_1.default.red(`✗ sync failed: ${e.message}`));
171
+ process.exitCode = 1;
172
+ }
173
+ return;
174
+ }
175
+ default:
176
+ console.error(chalk_1.default.red(`Unknown subcommand: ${cmd}`));
177
+ console.log(chalk_1.default.dim('Available: add, list, prune, sync'));
178
+ process.exitCode = 1;
179
+ }
180
+ });
181
+ }