codymaster 4.8.0 → 7.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (416) hide show
  1. package/CHANGELOG.md +331 -7
  2. package/README.md +226 -296
  3. package/dist/advisory-handoff.js +89 -0
  4. package/dist/advisory-report.js +105 -0
  5. package/dist/agent/antigravity.js +152 -0
  6. package/dist/agent/backend.js +2 -0
  7. package/dist/agent/claude.js +196 -0
  8. package/dist/agent/codex.js +204 -0
  9. package/dist/agent/copilot.js +284 -0
  10. package/dist/agent/cursor.js +211 -0
  11. package/dist/agent/factory.js +30 -0
  12. package/dist/agent/gemini.js +142 -0
  13. package/dist/agent/opencode.js +205 -0
  14. package/dist/agent/spawn-helper.js +237 -0
  15. package/dist/agent/version.js +25 -0
  16. package/dist/browse/adapter-factory.js +69 -0
  17. package/dist/browse/adapters/agent-browser-adapter.js +305 -0
  18. package/dist/browse/adapters/playwright-adapter.js +309 -0
  19. package/dist/browse/adapters/types.js +6 -0
  20. package/dist/browse/error-collector.js +132 -0
  21. package/dist/browse/event-log.js +109 -0
  22. package/dist/browse/index.js +17 -0
  23. package/dist/browse-server.js +204 -120
  24. package/dist/cli/command-registry.js +20 -0
  25. package/dist/cli/commands/bench.js +69 -0
  26. package/dist/cli/commands/brain.js +108 -0
  27. package/dist/cli/commands/dashboard.js +76 -2
  28. package/dist/cli/commands/engineering.js +326 -4
  29. package/dist/cli/commands/evolve.js +123 -0
  30. package/dist/cli/commands/install.js +160 -0
  31. package/dist/cli/commands/learn.js +181 -0
  32. package/dist/cli/commands/mcp-serve.js +104 -0
  33. package/dist/cli/commands/parallel.js +138 -0
  34. package/dist/cli/commands/quality.js +105 -0
  35. package/dist/cli/commands/stack.js +49 -0
  36. package/dist/cli/commands/update.js +159 -0
  37. package/dist/cli/update-check.js +94 -10
  38. package/dist/cm-config.js +0 -18
  39. package/dist/codybench/judges/automated.js +31 -0
  40. package/dist/codybench/runners/claude-code.js +32 -0
  41. package/dist/codybench/suites/memory-retention.js +85 -0
  42. package/dist/codybench/suites/tdd-regression.js +35 -0
  43. package/dist/codybench/suites/token-efficiency.js +55 -0
  44. package/dist/codybench/types.js +2 -0
  45. package/dist/context-db.js +157 -0
  46. package/dist/continuity.js +5 -7
  47. package/dist/dashboard.js +47 -6
  48. package/dist/data.js +35 -0
  49. package/dist/execution/tdd-gate.js +113 -0
  50. package/dist/execution-analyzer.js +138 -0
  51. package/dist/executor/cancel.js +34 -0
  52. package/dist/executor/gc.js +74 -0
  53. package/dist/executor/index.js +14 -0
  54. package/dist/executor/runner.js +70 -0
  55. package/dist/executor/workdir.js +31 -0
  56. package/dist/handoff/contracts.js +22 -0
  57. package/dist/handoff/index.js +18 -0
  58. package/dist/handoff/io.js +121 -0
  59. package/dist/index.js +7 -3
  60. package/dist/indexer/skills-lib.js +533 -0
  61. package/dist/indexer/skills-map.js +1374 -0
  62. package/dist/indexer/skills.js +16 -0
  63. package/dist/indexer/stack-detect.js +219 -0
  64. package/dist/install/copy.js +98 -0
  65. package/dist/install/engine.js +42 -0
  66. package/dist/install/paths.js +70 -0
  67. package/dist/install/platforms/_simple.js +85 -0
  68. package/dist/install/platforms/antigravity.js +91 -0
  69. package/dist/install/platforms/claude-code.js +107 -0
  70. package/dist/install/platforms/cursor.js +77 -0
  71. package/dist/install/platforms/index.js +27 -0
  72. package/dist/install/platforms/simple.js +163 -0
  73. package/dist/install/profiles.js +75 -0
  74. package/dist/install/types.js +2 -0
  75. package/dist/learning-promoter.js +246 -0
  76. package/dist/learnings.js +208 -0
  77. package/dist/mcp-context-server.js +230 -1
  78. package/dist/middleware/metrics.js +30 -0
  79. package/dist/middleware/security-headers.js +14 -0
  80. package/dist/realtime/event-bus.js +29 -0
  81. package/dist/realtime/ws-hub.js +91 -0
  82. package/dist/schemas/task-schema.js +48 -0
  83. package/dist/schemas/validate.js +18 -0
  84. package/dist/skill-chain.js +63 -1
  85. package/dist/skill-evolver.js +456 -0
  86. package/dist/skill-execution-cache.js +254 -0
  87. package/dist/skills-lock.js +96 -0
  88. package/dist/smart-brain-router.js +184 -0
  89. package/dist/sprint-pipeline.js +26 -0
  90. package/dist/storage/index.js +21 -0
  91. package/dist/storage/repos/activity-repo.js +46 -0
  92. package/dist/storage/repos/message-repo.js +39 -0
  93. package/dist/storage/repos/project-repo.js +56 -0
  94. package/dist/storage/repos/task-repo.js +142 -0
  95. package/dist/storage/services/project-service.js +49 -0
  96. package/dist/storage/services/task-service.js +97 -0
  97. package/dist/storage/sqlite.js +113 -0
  98. package/dist/storage-backend.js +10 -8
  99. package/dist/tier-classify.js +131 -0
  100. package/dist/token-budget.js +88 -0
  101. package/dist/ui/onboarding.js +51 -15
  102. package/dist/utils/cli-utils.js +7 -2
  103. package/dist/utils/design-taste.js +108 -0
  104. package/dist/utils/output-compress.js +143 -0
  105. package/dist/vibecoding-index.js +126 -0
  106. package/package.json +20 -6
  107. package/public/dashboard/app.js +52 -1
  108. package/scripts/build-skills-lock.mjs +88 -0
  109. package/scripts/build-skills.mjs +187 -28
  110. package/scripts/compress-skill.mjs +73 -0
  111. package/scripts/deprecate-skill.mjs +72 -0
  112. package/scripts/install.sh +170 -0
  113. package/scripts/mcp-bridge.js +2 -2
  114. package/scripts/postinstall.js +53 -335
  115. package/scripts/update-changelog.sh +88 -0
  116. package/scripts/validate-skills.mjs +101 -4
  117. package/skills/CLAUDE.md +0 -5
  118. package/skills/_shared/SKILL_TEMPLATE.md +62 -0
  119. package/skills/_shared/helpers.md +2 -8
  120. package/skills/cm-autopilot/scripts/autopilot.py +19 -2
  121. package/skills/cm-brainstorm-idea/SKILL.md +9 -0
  122. package/skills/cm-browse/SKILL.md +6 -0
  123. package/skills/cm-clean-code/SKILL.md +20 -0
  124. package/skills/cm-code-review/SKILL.md +21 -0
  125. package/skills/cm-codeintell/SKILL.md +9 -0
  126. package/skills/cm-conductor-worktrees/SKILL.archive.md +28 -0
  127. package/skills/cm-conductor-worktrees/SKILL.md +20 -18
  128. package/skills/cm-continuity/SKILL.md +41 -33
  129. package/skills/cm-dashboard/SKILL.archive.md +15 -0
  130. package/skills/cm-dashboard/SKILL.md +20 -9
  131. package/skills/cm-dashboard/ui/app.js +9 -1
  132. package/skills/cm-debugging/SKILL.md +9 -0
  133. package/skills/cm-design-studio/SKILL.archive.md +34 -0
  134. package/skills/cm-design-studio/SKILL.md +20 -24
  135. package/skills/cm-design-system/SKILL.md +1 -0
  136. package/skills/cm-ecosystem-roadmap/SKILL.md +4 -0
  137. package/skills/cm-engineering-meta/SKILL.archive.md +73 -0
  138. package/skills/cm-engineering-meta/SKILL.md +19 -62
  139. package/skills/cm-execution/SKILL.md +98 -0
  140. package/skills/cm-git-worktrees/SKILL.archive.md +157 -0
  141. package/skills/cm-git-worktrees/SKILL.md +15 -146
  142. package/skills/cm-guardian-runtime/SKILL.md +5 -1
  143. package/skills/cm-identity-guard/SKILL.md +8 -0
  144. package/skills/cm-mcp-engineering/SKILL.md +4 -0
  145. package/skills/cm-planning/SKILL.md +63 -92
  146. package/skills/cm-post-deploy-canary/SKILL.archive.md +22 -0
  147. package/skills/cm-post-deploy-canary/SKILL.md +20 -12
  148. package/skills/cm-project-bootstrap/SKILL.md +11 -0
  149. package/skills/cm-qa-visual-cli/SKILL.archive.md +22 -0
  150. package/skills/cm-qa-visual-cli/SKILL.md +19 -11
  151. package/skills/cm-quality-gate/SKILL.md +38 -0
  152. package/skills/cm-retro-cli/SKILL.md +4 -0
  153. package/skills/cm-safe-deploy/SKILL.md +9 -0
  154. package/skills/cm-second-opinion-cli/SKILL.archive.md +23 -0
  155. package/skills/cm-second-opinion-cli/SKILL.md +20 -13
  156. package/skills/cm-secret-shield/SKILL.archive.md +580 -0
  157. package/skills/cm-secret-shield/SKILL.md +15 -569
  158. package/skills/cm-security-gate/SKILL.archive.md +239 -0
  159. package/skills/cm-security-gate/SKILL.md +16 -228
  160. package/skills/cm-skill-chain/SKILL.md +25 -4
  161. package/skills/cm-skill-evolution/SKILL.md +83 -0
  162. package/skills/cm-skill-health/SKILL.archive.md +83 -0
  163. package/skills/cm-skill-health/SKILL.md +26 -0
  164. package/skills/cm-skill-index/SKILL.md +19 -3
  165. package/skills/cm-skill-mastery/SKILL.archive.md +156 -0
  166. package/skills/cm-skill-mastery/SKILL.md +16 -146
  167. package/skills/cm-skill-search/SKILL.archive.md +49 -0
  168. package/skills/cm-skill-search/SKILL.md +26 -0
  169. package/skills/cm-skill-share/SKILL.archive.md +58 -0
  170. package/skills/cm-skill-share/SKILL.md +26 -0
  171. package/skills/cm-sprint-bus/SKILL.md +13 -0
  172. package/skills/cm-start/SKILL.md +17 -10
  173. package/skills/cm-tdd/SKILL.md +21 -2
  174. package/skills/cm-terminal/SKILL.md +15 -0
  175. package/skills/cm-test-gate/SKILL.archive.md +245 -0
  176. package/skills/cm-test-gate/SKILL.md +15 -234
  177. package/skills/cm-ui-preview/SKILL.archive.md +153 -0
  178. package/skills/cm-ui-preview/SKILL.md +16 -143
  179. package/skills/cm-ux-master/cli/uxmaster/commands/mcp.py +1 -1
  180. package/skills/cm-ux-master/mcp/mcp-config.json +1 -1
  181. package/skills/cm-ux-master/mcp/server.py +2 -2
  182. package/skills/profiles/design.txt +1 -1
  183. package/skills/profiles/full.txt +4 -10
  184. package/skills/profiles/growth.txt +8 -8
  185. package/skills/profiles/knowledge.txt +1 -1
  186. package/skills/profiles/top35.json +41 -0
  187. package/adapters/antigravity.js +0 -15
  188. package/adapters/claude-code.js +0 -17
  189. package/adapters/cursor.js +0 -16
  190. package/install.sh +0 -1125
  191. package/scripts/viking-demo.ts +0 -105
  192. package/skills/cm-ads-tracker/SKILL.md +0 -401
  193. package/skills/cm-ads-tracker/evals/evals.json +0 -55
  194. package/skills/cm-ads-tracker/references/gtm-architecture.md +0 -321
  195. package/skills/cm-ads-tracker/references/industry-events.md +0 -294
  196. package/skills/cm-ads-tracker/references/platforms-api.md +0 -238
  197. package/skills/cm-ads-tracker/templates/capi-payload.md +0 -79
  198. package/skills/cm-ads-tracker/templates/datalayer-push.js +0 -104
  199. package/skills/cm-ads-tracker/templates/gtm-variables.js +0 -56
  200. package/skills/cm-auto-publisher/SKILL.md +0 -81
  201. package/skills/cm-booking-calendar/SKILL.md +0 -521
  202. package/skills/cm-booking-calendar/references/industry-patterns.md +0 -527
  203. package/skills/cm-booking-calendar/templates/booking-form.css +0 -626
  204. package/skills/cm-booking-calendar/templates/booking-form.html +0 -477
  205. package/skills/cm-booking-calendar/templates/calendar-engine.js +0 -419
  206. package/skills/cm-booking-calendar/templates/calendar-export.js +0 -395
  207. package/skills/cm-booking-calendar/templates/reminder-config.js +0 -629
  208. package/skills/cm-content-factory/.content-factory-state.json +0 -132
  209. package/skills/cm-content-factory/.git 2/logs/refs/heads/main +0 -1
  210. package/skills/cm-content-factory/.git 2/logs/refs/remotes/origin/main +0 -1
  211. package/skills/cm-content-factory/.git 2/objects/02/fb0956734b5f8ba3f918b7defd04a89cfe0076 +0 -0
  212. package/skills/cm-content-factory/.git 2/objects/08/1e129d75dc6feac6c02037272e6bd1a04e3324 +0 -0
  213. package/skills/cm-content-factory/.git 2/objects/0c/5393416f3c5e01c9a655a802bff0dd52f76f0a +0 -0
  214. package/skills/cm-content-factory/.git 2/objects/10/0b9be46978a946a77188f68be725098a122001 +0 -0
  215. package/skills/cm-content-factory/.git 2/objects/10/cf041167fc9843610eb3d90259ef3396315fdc +0 -0
  216. package/skills/cm-content-factory/.git 2/objects/12/5e19538dd6e1338ffe74f6c4c165b00435bf48 +0 -0
  217. package/skills/cm-content-factory/.git 2/objects/16/a9b9d0088d5c1347628b45a2620b479d8ad57c +0 -0
  218. package/skills/cm-content-factory/.git 2/objects/17/8c2a9ef93c33ae4eec9d58e82321f9229843a1 +0 -0
  219. package/skills/cm-content-factory/.git 2/objects/25/397ae41d09104d763bdcac2695209d85cdea89 +0 -0
  220. package/skills/cm-content-factory/.git 2/objects/2f/a836b7947f2d458e1f639788bf4bb0983a3305 +0 -0
  221. package/skills/cm-content-factory/.git 2/objects/3a/baaaf0a1c0909c0828335791557125fba911e0 +0 -0
  222. package/skills/cm-content-factory/.git 2/objects/42/2924221b81f5ce3c4e4daac9a64a24f9b01f9a +0 -0
  223. package/skills/cm-content-factory/.git 2/objects/42/ec0ce707447dc11446a34c9995fb8533801731 +0 -0
  224. package/skills/cm-content-factory/.git 2/objects/46/e43ce92866d56ce74b1d750db307cfe6154a15 +0 -0
  225. package/skills/cm-content-factory/.git 2/objects/48/5e41b633c63f55b8277bcc59f44f67681f671a +0 -0
  226. package/skills/cm-content-factory/.git 2/objects/49/49c596a3a89fa240642acd95dd3258e261eb09 +0 -0
  227. package/skills/cm-content-factory/.git 2/objects/50/9d42d8412ef8eaf7f7e138476bac2e4d10ce60 +0 -0
  228. package/skills/cm-content-factory/.git 2/objects/55/0c8c389d981b463ef849aeb792d8be3ccb6ec8 +0 -0
  229. package/skills/cm-content-factory/.git 2/objects/5d/82d3b18410cdda3ace3677436f0cb599dbe2d2 +0 -0
  230. package/skills/cm-content-factory/.git 2/objects/60/0617c58e871a38b33bf29e282d132bb3c381ad +0 -0
  231. package/skills/cm-content-factory/.git 2/objects/6a/8369a99c687b7245c92ffaf0e0f0dab9014504 +0 -0
  232. package/skills/cm-content-factory/.git 2/objects/79/bea435d40ab531c1aaf6be0432c6a5b7aaed21 +0 -0
  233. package/skills/cm-content-factory/.git 2/objects/7e/5ebd79251c2f14e4aceb86c74b6b6daae6b500 +0 -0
  234. package/skills/cm-content-factory/.git 2/objects/81/98a822a60178d6d5023ddb3e222cddf048742e +0 -0
  235. package/skills/cm-content-factory/.git 2/objects/86/0a0e1943dfe53411d2e499a1f16f46a96ef758 +0 -0
  236. package/skills/cm-content-factory/.git 2/objects/86/971fb55fdc081fdbae52376f0f13e57a4e9b04 +0 -0
  237. package/skills/cm-content-factory/.git 2/objects/88/b89dd609a0a03f8d4fe8bfde20d5b8fc1d326d +0 -0
  238. package/skills/cm-content-factory/.git 2/objects/90/8737edb6b7809e32cc01590b4e08ba42a9d40d +0 -0
  239. package/skills/cm-content-factory/.git 2/objects/93/d5a8a9a7d4fb7f11491cb596a6880528725118 +0 -0
  240. package/skills/cm-content-factory/.git 2/objects/98/46a2ab81d0c3b3eb00ef88fc56989aa7e9f316 +0 -0
  241. package/skills/cm-content-factory/.git 2/objects/9b/d8dd1e49cf274eaf9c555f3ab39dce7af5715e +0 -0
  242. package/skills/cm-content-factory/.git 2/objects/a1/13329fb0cec96ae78b222d33a24c3b5bc7fa1f +0 -0
  243. package/skills/cm-content-factory/.git 2/objects/a9/e6effe626e8a3aea3a8fc3364b492191c6e7d0 +0 -0
  244. package/skills/cm-content-factory/.git 2/objects/ad/6de7e48d9782cca9353d1ff0aa1aab7fe1df85 +0 -0
  245. package/skills/cm-content-factory/.git 2/objects/af/54ae316f771ff692e299ffcd8bf2f06b413b59 +0 -0
  246. package/skills/cm-content-factory/.git 2/objects/b0/4cb8b0b00dad633e731c1472161419e738d674 +0 -0
  247. package/skills/cm-content-factory/.git 2/objects/b3/094abb0b9ed46419b269e4a4e36a459690e3b0 +0 -0
  248. package/skills/cm-content-factory/.git 2/objects/b9/435c5d4baac2cfc5c83009ddd27b46b60db5f1 +0 -0
  249. package/skills/cm-content-factory/.git 2/objects/ba/5da17dbaec5ec2dcfdfd126aead518d1171d5c +0 -0
  250. package/skills/cm-content-factory/.git 2/objects/c0/bf58703aa258ba5dd63083bebaec8f223d844c +0 -0
  251. package/skills/cm-content-factory/.git 2/objects/c4/701a34edf1fc1bad58ccc57bd03f9426acb59a +0 -0
  252. package/skills/cm-content-factory/.git 2/objects/c7/5ccce9a4e5cc74d9b3174550cf6d993ca43638 +0 -0
  253. package/skills/cm-content-factory/.git 2/objects/c7/710d59b5a35b0f1f0a0399386643a0bd94c929 +0 -0
  254. package/skills/cm-content-factory/.git 2/objects/d1/fe58237112e953e5fec52da22cf38e08be3df9 +0 -5
  255. package/skills/cm-content-factory/.git 2/objects/d2/2bbe9fd2f74c95bc5583e803f5e435f1e2cd86 +0 -0
  256. package/skills/cm-content-factory/.git 2/objects/d7/e72852ea2bff74581dbf247d400120086229f4 +0 -0
  257. package/skills/cm-content-factory/.git 2/objects/d8/d4c3b5553e4fd72807e1d4b49ef07d9ef3ac35 +0 -0
  258. package/skills/cm-content-factory/.git 2/objects/dc/75050c2876f6a02ae2a53a3c886f395b622977 +0 -0
  259. package/skills/cm-content-factory/.git 2/objects/ee/e8546f95acec500187c08a28a8b9ee02db0dec +0 -0
  260. package/skills/cm-content-factory/.git 2/objects/ef/263c059208b416c2146434f10cb2b9fabcba16 +0 -0
  261. package/skills/cm-content-factory/.git 2/objects/f3/ae597e84d9a59b88acd21c99bde2eaf686d785 +0 -0
  262. package/skills/cm-content-factory/.git 2/objects/f3/f6f5673c821d3d8e76fa267a9e882e7a5387ea +0 -0
  263. package/skills/cm-content-factory/.git 2/objects/f9/6e6d0ad02624dd11d5848594d056caef7a5e8b +0 -0
  264. package/skills/cm-content-factory/.git 2/objects/ff/278988fc1edf0db3abcf18de795f4cc0b4f3e1 +0 -0
  265. package/skills/cm-content-factory/.git 2/refs/heads/main +0 -1
  266. package/skills/cm-content-factory/.git 2/refs/remotes/origin/main +0 -1
  267. package/skills/cm-content-factory/.pytest_cache 2/v/cache/nodeids +0 -76
  268. package/skills/cm-content-factory/.pytest_cache 2/v/cache/stepwise +0 -1
  269. package/skills/cm-content-factory/AGENTS.md +0 -61
  270. package/skills/cm-content-factory/CLAUDE.md +0 -63
  271. package/skills/cm-content-factory/CURSOR.md +0 -43
  272. package/skills/cm-content-factory/Content Factory.zip +0 -0
  273. package/skills/cm-content-factory/SKILL.md +0 -416
  274. package/skills/cm-content-factory/cf +0 -313
  275. package/skills/cm-content-factory/config.schema.json +0 -397
  276. package/skills/cm-content-factory/dashboard/app.js +0 -556
  277. package/skills/cm-content-factory/dashboard/index.html +0 -397
  278. package/skills/cm-content-factory/dashboard/style.css +0 -1211
  279. package/skills/cm-content-factory/examples/01-real-estate.config.json +0 -146
  280. package/skills/cm-content-factory/examples/02-personal-finance.config.json +0 -146
  281. package/skills/cm-content-factory/examples/03-health-wellness.config.json +0 -147
  282. package/skills/cm-content-factory/examples/04-saas-software.config.json +0 -147
  283. package/skills/cm-content-factory/examples/05-legal-services.config.json +0 -147
  284. package/skills/cm-content-factory/examples/06-insurance.config.json +0 -146
  285. package/skills/cm-content-factory/examples/07-ecommerce-dropship.config.json +0 -146
  286. package/skills/cm-content-factory/examples/08-online-education.config.json +0 -147
  287. package/skills/cm-content-factory/examples/09-crypto-defi.config.json +0 -147
  288. package/skills/cm-content-factory/examples/10-beauty-skincare.config.json +0 -147
  289. package/skills/cm-content-factory/examples/11-home-services.config.json +0 -146
  290. package/skills/cm-content-factory/examples/12-dental-clinic.config.json +0 -147
  291. package/skills/cm-content-factory/examples/13-pet-care.config.json +0 -147
  292. package/skills/cm-content-factory/examples/14-travel-hospitality.config.json +0 -147
  293. package/skills/cm-content-factory/examples/15-ai-automation.config.json +0 -147
  294. package/skills/cm-content-factory/examples/16-wedding-events.config.json +0 -147
  295. package/skills/cm-content-factory/examples/17-fitness-coaching.config.json +0 -148
  296. package/skills/cm-content-factory/examples/18-cybersecurity.config.json +0 -147
  297. package/skills/cm-content-factory/examples/19-food-restaurant.config.json +0 -148
  298. package/skills/cm-content-factory/examples/20-solar-energy.config.json +0 -147
  299. package/skills/cm-content-factory/examples/fitness-blog.config.json +0 -116
  300. package/skills/cm-content-factory/examples/tech-blog.config.json +0 -107
  301. package/skills/cm-content-factory/extensions/EXTENSION_GUIDE.md +0 -72
  302. package/skills/cm-content-factory/extensions/hooks.py +0 -126
  303. package/skills/cm-content-factory/extensions/openclaw_adapter.py +0 -132
  304. package/skills/cm-content-factory/landing/docs/content/changelog.md +0 -36
  305. package/skills/cm-content-factory/landing/docs/content/deployment.md +0 -46
  306. package/skills/cm-content-factory/landing/docs/content/execution-flow.md +0 -67
  307. package/skills/cm-content-factory/landing/docs/content/openspace.md +0 -27
  308. package/skills/cm-content-factory/landing/docs/content/openviking.md +0 -33
  309. package/skills/cm-content-factory/landing/docs/content/use-cases.md +0 -26
  310. package/skills/cm-content-factory/landing/docs/content/v5-intro.md +0 -28
  311. package/skills/cm-content-factory/landing/docs/index.html +0 -240
  312. package/skills/cm-content-factory/landing/index.html +0 -680
  313. package/skills/cm-content-factory/landing/script.js +0 -143
  314. package/skills/cm-content-factory/landing/style.css +0 -1216
  315. package/skills/cm-content-factory/landing/translations.js +0 -508
  316. package/skills/cm-content-factory/logs/events.jsonl +0 -11
  317. package/skills/cm-content-factory/profiles/_template.profile.json +0 -231
  318. package/skills/cm-content-factory/profiles/finance.profile.json +0 -278
  319. package/skills/cm-content-factory/profiles/legal.profile.json +0 -263
  320. package/skills/cm-content-factory/profiles/medical-research.profile.json +0 -321
  321. package/skills/cm-content-factory/profiles/technology.profile.json +0 -275
  322. package/skills/cm-content-factory/scripts/agent_dispatcher.py +0 -266
  323. package/skills/cm-content-factory/scripts/audit.py +0 -106
  324. package/skills/cm-content-factory/scripts/dashboard_server.py +0 -225
  325. package/skills/cm-content-factory/scripts/deploy.py +0 -146
  326. package/skills/cm-content-factory/scripts/extract.py +0 -132
  327. package/skills/cm-content-factory/scripts/landing_generator.py +0 -459
  328. package/skills/cm-content-factory/scripts/memory.py +0 -521
  329. package/skills/cm-content-factory/scripts/monetize.py +0 -239
  330. package/skills/cm-content-factory/scripts/pipeline.py +0 -357
  331. package/skills/cm-content-factory/scripts/plan.py +0 -163
  332. package/skills/cm-content-factory/scripts/publish.py +0 -145
  333. package/skills/cm-content-factory/scripts/research.py +0 -337
  334. package/skills/cm-content-factory/scripts/scaffold.py +0 -464
  335. package/skills/cm-content-factory/scripts/scoreboard.py +0 -336
  336. package/skills/cm-content-factory/scripts/seo.py +0 -90
  337. package/skills/cm-content-factory/scripts/state_manager.py +0 -320
  338. package/skills/cm-content-factory/scripts/token_manager.py +0 -268
  339. package/skills/cm-content-factory/scripts/validate.py +0 -221
  340. package/skills/cm-content-factory/scripts/wizard.py +0 -329
  341. package/skills/cm-content-factory/scripts/write.py +0 -93
  342. package/skills/cm-content-factory/sites/docs-site/src/assets/houston.webp +0 -0
  343. package/skills/cm-content-factory/sites/docs-site/src/content/docs/architecture.md +0 -90
  344. package/skills/cm-content-factory/sites/docs-site/src/content/docs/data-flow.md +0 -54
  345. package/skills/cm-content-factory/sites/docs-site/src/content/docs/deployment.md +0 -38
  346. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/index.md +0 -65
  347. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/lc-content-lifecycle.md +0 -48
  348. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/seq-write-mode.md +0 -39
  349. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/uj-first-batch.md +0 -42
  350. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-content-pipeline.md +0 -51
  351. package/skills/cm-content-factory/sites/docs-site/src/content/docs/flows/wf-learning-cycle.md +0 -52
  352. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/configuration.md +0 -86
  353. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/installation.md +0 -80
  354. package/skills/cm-content-factory/sites/docs-site/src/content/docs/getting-started/intro.md +0 -58
  355. package/skills/cm-content-factory/sites/docs-site/src/content/docs/index.md +0 -102
  356. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/index.md +0 -45
  357. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/optimize-seo.md +0 -29
  358. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/scale-content-production.md +0 -55
  359. package/skills/cm-content-factory/sites/docs-site/src/content/docs/jtbd/standardize-quality.md +0 -29
  360. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-cmo-huong.md +0 -41
  361. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/buyer-content-lead-khoa.md +0 -40
  362. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/index.md +0 -56
  363. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-content-manager-lan.md +0 -46
  364. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-seo-minh.md +0 -45
  365. package/skills/cm-content-factory/sites/docs-site/src/content/docs/personas/user-writer-tu.md +0 -45
  366. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/content-pipeline.md +0 -108
  367. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/index.md +0 -22
  368. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/memory-system.md +0 -52
  369. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/seo-optimization.md +0 -58
  370. package/skills/cm-content-factory/sites/docs-site/src/content/docs/sop/troubleshooting-guide.md +0 -92
  371. package/skills/cm-content-factory/sites/docs-site/src/styles/custom.css +0 -575
  372. package/skills/cm-content-factory/tests/conftest.py +0 -66
  373. package/skills/cm-content-factory/tests/test_agent_dispatcher.py +0 -125
  374. package/skills/cm-content-factory/tests/test_memory.py +0 -128
  375. package/skills/cm-content-factory/tests/test_pipeline.py +0 -107
  376. package/skills/cm-content-factory/tests/test_research.py +0 -56
  377. package/skills/cm-content-factory/tests/test_state_manager.py +0 -131
  378. package/skills/cm-content-factory/tests/test_token_manager.py +0 -110
  379. package/skills/cm-content-factory/tests/test_wizard.py +0 -121
  380. package/skills/cm-cro-methodology/SKILL.md +0 -290
  381. package/skills/cm-cro-methodology/references/COPYWRITING.md +0 -178
  382. package/skills/cm-cro-methodology/references/OBJECTIONS.md +0 -135
  383. package/skills/cm-cro-methodology/references/PERSUASION.md +0 -158
  384. package/skills/cm-cro-methodology/references/RESEARCH.md +0 -220
  385. package/skills/cm-cro-methodology/references/funnel-analysis.md +0 -365
  386. package/skills/cm-cro-methodology/references/testing-methodology.md +0 -330
  387. package/skills/cm-google-form/SKILL.md +0 -266
  388. package/skills/cm-google-form/templates/apps-script.js +0 -55
  389. package/skills/cm-google-form/templates/form-markup.html +0 -110
  390. package/skills/cm-google-form/templates/form-submit.js +0 -201
  391. package/skills/cm-google-form/templates/toast.css +0 -152
  392. package/skills/cm-growth-hacking/SKILL.md +0 -282
  393. package/skills/cm-growth-hacking/bottom-sheet-engine.md +0 -261
  394. package/skills/cm-growth-hacking/calendar-integration.md +0 -264
  395. package/skills/cm-growth-hacking/references/engagement-patterns.md +0 -346
  396. package/skills/cm-growth-hacking/templates/bottom-sheet.css +0 -528
  397. package/skills/cm-growth-hacking/templates/bottom-sheet.js +0 -269
  398. package/skills/cm-growth-hacking/templates/calendar-cta.js +0 -213
  399. package/skills/cm-growth-hacking/templates/tracking-events.js +0 -211
  400. package/skills/cm-growth-hacking/templates/trigger-manager.js +0 -254
  401. package/skills/cm-growth-hacking/tracking-events.md +0 -246
  402. package/skills/cm-growth-hacking/trigger-system.md +0 -342
  403. package/skills/cm-jtbd/SKILL.md +0 -98
  404. package/skills/cm-notebooklm/SKILL.md +0 -156
  405. package/skills/cm-notebooklm/references/command_reference.md +0 -94
  406. package/skills/cm-notebooklm/references/workflows.md +0 -60
  407. package/skills/cm-notebooklm/resources/knowledge_sources.md +0 -106
  408. package/skills/cm-notebooklm/scripts/brain-sync.sh +0 -453
  409. package/skills/cm-notebooklm/scripts/graduate_wisdom.py +0 -101
  410. package/skills/cm-readit/SKILL.md +0 -289
  411. package/skills/cm-readit/audio-player.md +0 -206
  412. package/skills/cm-readit/examples/blog-reader.js +0 -352
  413. package/skills/cm-readit/examples/voice-cro.js +0 -390
  414. package/skills/cm-readit/tts-engine.md +0 -262
  415. package/skills/cm-readit/ui-patterns.md +0 -362
  416. package/skills/cm-readit/voice-cro.md +0 -223
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ /**
3
+ * AdapterFactory — Auto-detect and select the best available browser adapter.
4
+ * Priority: agent-browser → Playwright (fallback).
5
+ */
6
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
7
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
8
+ return new (P || (P = Promise))(function (resolve, reject) {
9
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
10
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
11
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
12
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
13
+ });
14
+ };
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.createAdapter = createAdapter;
17
+ exports.checkEngines = checkEngines;
18
+ const agent_browser_adapter_1 = require("./adapters/agent-browser-adapter");
19
+ const playwright_adapter_1 = require("./adapters/playwright-adapter");
20
+ /**
21
+ * Create the best available adapter.
22
+ * @param preferred - 'auto' (default), 'agent-browser', or 'playwright'
23
+ */
24
+ function createAdapter() {
25
+ return __awaiter(this, arguments, void 0, function* (preferred = 'auto') {
26
+ // Explicit choice
27
+ if (preferred === 'playwright') {
28
+ const pw = new playwright_adapter_1.PlaywrightAdapter();
29
+ if (!(yield pw.isAvailable())) {
30
+ throw new Error('Playwright is not available. Run: npx playwright install chromium');
31
+ }
32
+ return { adapter: pw, engine: 'playwright', fallback: false };
33
+ }
34
+ if (preferred === 'agent-browser') {
35
+ const ab = new agent_browser_adapter_1.AgentBrowserAdapter();
36
+ if (!(yield ab.isAvailable())) {
37
+ throw new Error('agent-browser is not available. Run: npm i -g agent-browser && agent-browser install');
38
+ }
39
+ return { adapter: ab, engine: 'agent-browser', fallback: false };
40
+ }
41
+ // Auto: try agent-browser first, fallback to playwright
42
+ const ab = new agent_browser_adapter_1.AgentBrowserAdapter();
43
+ if (yield ab.isAvailable()) {
44
+ return { adapter: ab, engine: 'agent-browser', fallback: false };
45
+ }
46
+ const pw = new playwright_adapter_1.PlaywrightAdapter();
47
+ if (yield pw.isAvailable()) {
48
+ console.log('[cm-browse] agent-browser not found, falling back to Playwright');
49
+ return { adapter: pw, engine: 'playwright', fallback: true };
50
+ }
51
+ throw new Error('No browser engine available. Install one:\n' +
52
+ ' npm i -g agent-browser && agent-browser install\n' +
53
+ ' npx playwright install chromium');
54
+ });
55
+ }
56
+ /**
57
+ * Check which engines are available without creating adapters.
58
+ */
59
+ function checkEngines() {
60
+ return __awaiter(this, void 0, void 0, function* () {
61
+ const ab = new agent_browser_adapter_1.AgentBrowserAdapter();
62
+ const pw = new playwright_adapter_1.PlaywrightAdapter();
63
+ const [abAvail, pwAvail] = yield Promise.all([ab.isAvailable(), pw.isAvailable()]);
64
+ return {
65
+ 'agent-browser': abAvail,
66
+ playwright: pwAvail,
67
+ };
68
+ });
69
+ }
@@ -0,0 +1,305 @@
1
+ "use strict";
2
+ /**
3
+ * AgentBrowserAdapter — BrowserAdapter implementation using agent-browser CLI.
4
+ * Calls the Rust CLI via child_process, parses structured output.
5
+ */
6
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ var desc = Object.getOwnPropertyDescriptor(m, k);
9
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
+ desc = { enumerable: true, get: function() { return m[k]; } };
11
+ }
12
+ Object.defineProperty(o, k2, desc);
13
+ }) : (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ o[k2] = m[k];
16
+ }));
17
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
19
+ }) : function(o, v) {
20
+ o["default"] = v;
21
+ });
22
+ var __importStar = (this && this.__importStar) || (function () {
23
+ var ownKeys = function(o) {
24
+ ownKeys = Object.getOwnPropertyNames || function (o) {
25
+ var ar = [];
26
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
27
+ return ar;
28
+ };
29
+ return ownKeys(o);
30
+ };
31
+ return function (mod) {
32
+ if (mod && mod.__esModule) return mod;
33
+ var result = {};
34
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
35
+ __setModuleDefault(result, mod);
36
+ return result;
37
+ };
38
+ })();
39
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
40
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
41
+ return new (P || (P = Promise))(function (resolve, reject) {
42
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
43
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
44
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
45
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
46
+ });
47
+ };
48
+ Object.defineProperty(exports, "__esModule", { value: true });
49
+ exports.AgentBrowserAdapter = void 0;
50
+ const child_process_1 = require("child_process");
51
+ const util_1 = require("util");
52
+ const error_collector_1 = require("../error-collector");
53
+ const execFileAsync = (0, util_1.promisify)(child_process_1.execFile);
54
+ class AgentBrowserAdapter {
55
+ constructor() {
56
+ this.name = 'agent-browser';
57
+ this.errorCollector = new error_collector_1.ErrorCollector();
58
+ this.consoleLog = [];
59
+ this.networkLog = [];
60
+ this.sessionActive = false;
61
+ this.currentUrl = '';
62
+ }
63
+ isAvailable() {
64
+ return __awaiter(this, void 0, void 0, function* () {
65
+ try {
66
+ const { stdout } = yield execFileAsync('agent-browser', ['--version'], { timeout: 5000 });
67
+ return stdout.trim().length > 0;
68
+ }
69
+ catch (_a) {
70
+ return false;
71
+ }
72
+ });
73
+ }
74
+ startSession(opts) {
75
+ return __awaiter(this, void 0, void 0, function* () {
76
+ const args = ['open'];
77
+ if ((opts === null || opts === void 0 ? void 0 : opts.headless) === false)
78
+ args.push('--headed');
79
+ yield this.exec(args);
80
+ this.sessionActive = true;
81
+ });
82
+ }
83
+ navigate(url) {
84
+ return __awaiter(this, void 0, void 0, function* () {
85
+ yield this.exec(['navigate', url]);
86
+ this.currentUrl = url;
87
+ });
88
+ }
89
+ click(ref) {
90
+ return __awaiter(this, void 0, void 0, function* () {
91
+ const cleanRef = ref.startsWith('@') ? ref : `@${ref}`;
92
+ yield this.exec(['click', cleanRef]);
93
+ });
94
+ }
95
+ fill(ref, value) {
96
+ return __awaiter(this, void 0, void 0, function* () {
97
+ const cleanRef = ref.startsWith('@') ? ref : `@${ref}`;
98
+ yield this.exec(['fill', cleanRef, value]);
99
+ });
100
+ }
101
+ type(ref, text, opts) {
102
+ return __awaiter(this, void 0, void 0, function* () {
103
+ const cleanRef = ref.startsWith('@') ? ref : `@${ref}`;
104
+ const args = ['type', cleanRef, text];
105
+ if (opts === null || opts === void 0 ? void 0 : opts.delay)
106
+ args.push('--delay', String(opts.delay));
107
+ yield this.exec(args);
108
+ });
109
+ }
110
+ press(key) {
111
+ return __awaiter(this, void 0, void 0, function* () {
112
+ yield this.exec(['press', key]);
113
+ });
114
+ }
115
+ screenshot(opts) {
116
+ return __awaiter(this, void 0, void 0, function* () {
117
+ const args = ['screenshot'];
118
+ if (opts === null || opts === void 0 ? void 0 : opts.fullPage)
119
+ args.push('--full-page');
120
+ const { stdout } = yield this.exec(args);
121
+ // agent-browser outputs base64 or file path
122
+ if (stdout.startsWith('/')) {
123
+ const fs = yield Promise.resolve().then(() => __importStar(require('fs')));
124
+ return fs.readFileSync(stdout.trim());
125
+ }
126
+ return Buffer.from(stdout.trim(), 'base64');
127
+ });
128
+ }
129
+ getSnapshot() {
130
+ return __awaiter(this, void 0, void 0, function* () {
131
+ const { stdout } = yield this.exec(['snapshot']);
132
+ return this.parseSnapshot(stdout);
133
+ });
134
+ }
135
+ getConsole() {
136
+ return __awaiter(this, void 0, void 0, function* () {
137
+ try {
138
+ const { stdout } = yield this.exec(['console']);
139
+ const entries = JSON.parse(stdout);
140
+ this.consoleLog = entries.map((e) => {
141
+ var _a, _b, _c, _d, _e;
142
+ return ({
143
+ type: (_b = (_a = e.level) !== null && _a !== void 0 ? _a : e.type) !== null && _b !== void 0 ? _b : 'log',
144
+ text: (_d = (_c = e.text) !== null && _c !== void 0 ? _c : e.message) !== null && _d !== void 0 ? _d : '',
145
+ timestamp: (_e = e.timestamp) !== null && _e !== void 0 ? _e : new Date().toISOString(),
146
+ });
147
+ });
148
+ }
149
+ catch (_a) {
150
+ /* return cached */
151
+ }
152
+ return [...this.consoleLog];
153
+ });
154
+ }
155
+ getNetwork() {
156
+ return __awaiter(this, void 0, void 0, function* () {
157
+ try {
158
+ const { stdout } = yield this.exec(['network']);
159
+ const entries = JSON.parse(stdout);
160
+ this.networkLog = entries.map((e) => {
161
+ var _a, _b;
162
+ return ({
163
+ url: e.url,
164
+ method: (_a = e.method) !== null && _a !== void 0 ? _a : 'GET',
165
+ status: e.status,
166
+ timestamp: (_b = e.timestamp) !== null && _b !== void 0 ? _b : new Date().toISOString(),
167
+ });
168
+ });
169
+ }
170
+ catch (_a) {
171
+ /* return cached */
172
+ }
173
+ return [...this.networkLog];
174
+ });
175
+ }
176
+ getErrors() {
177
+ return __awaiter(this, void 0, void 0, function* () {
178
+ return this.errorCollector.getAll();
179
+ });
180
+ }
181
+ startRecording() {
182
+ return __awaiter(this, void 0, void 0, function* () {
183
+ yield this.exec(['record', 'start']);
184
+ });
185
+ }
186
+ stopRecording() {
187
+ return __awaiter(this, void 0, void 0, function* () {
188
+ const { stdout } = yield this.exec(['record', 'stop']);
189
+ return stdout.trim();
190
+ });
191
+ }
192
+ getEngineInfo() {
193
+ return {
194
+ name: 'agent-browser',
195
+ version: 'latest',
196
+ capabilities: {
197
+ a11ySnapshot: true,
198
+ videoRecording: true,
199
+ networkCapture: true,
200
+ consoleCapture: true,
201
+ },
202
+ };
203
+ }
204
+ closeSession() {
205
+ return __awaiter(this, void 0, void 0, function* () {
206
+ try {
207
+ yield this.exec(['close']);
208
+ }
209
+ catch (_a) {
210
+ /* ignore */
211
+ }
212
+ this.sessionActive = false;
213
+ this.consoleLog = [];
214
+ this.networkLog = [];
215
+ this.errorCollector.clear();
216
+ });
217
+ }
218
+ // ── Private helpers ─────────────────────────────────────────────────────────
219
+ exec(args) {
220
+ return __awaiter(this, void 0, void 0, function* () {
221
+ return new Promise((resolve, reject) => {
222
+ const proc = (0, child_process_1.spawn)('agent-browser', args, { timeout: 30000 });
223
+ let stdout = '';
224
+ let stderr = '';
225
+ proc.stdout.on('data', (data) => { stdout += data.toString(); });
226
+ proc.stderr.on('data', (data) => { stderr += data.toString(); });
227
+ proc.on('close', (code) => {
228
+ if (code === 0) {
229
+ resolve({ stdout, stderr });
230
+ }
231
+ else {
232
+ const err = new Error(`agent-browser exited ${code}: ${stderr}`);
233
+ this.errorCollector.add({
234
+ type: 'js-error',
235
+ source: 'agent-browser',
236
+ message: stderr || `exit code ${code}`,
237
+ });
238
+ reject(err);
239
+ }
240
+ });
241
+ proc.on('error', (err) => {
242
+ this.errorCollector.add({
243
+ type: 'js-error',
244
+ source: 'agent-browser',
245
+ message: err.message,
246
+ });
247
+ reject(err);
248
+ });
249
+ });
250
+ });
251
+ }
252
+ parseSnapshot(raw) {
253
+ var _a;
254
+ try {
255
+ // Try JSON format first
256
+ const parsed = JSON.parse(raw);
257
+ return {
258
+ root: this.normalizeA11yNode(parsed, 0),
259
+ refs: (_a = parsed.refs) !== null && _a !== void 0 ? _a : {},
260
+ timestamp: new Date().toISOString(),
261
+ };
262
+ }
263
+ catch (_b) {
264
+ // Fallback: parse text-based a11y tree
265
+ return this.parseTextSnapshot(raw);
266
+ }
267
+ }
268
+ normalizeA11yNode(node, depth) {
269
+ var _a, _b, _c;
270
+ if (!node)
271
+ return { role: 'unknown', name: '', ref: `@e${depth}` };
272
+ const result = {
273
+ role: (_a = node.role) !== null && _a !== void 0 ? _a : 'unknown',
274
+ name: (_b = node.name) !== null && _b !== void 0 ? _b : '',
275
+ ref: (_c = node.ref) !== null && _c !== void 0 ? _c : `@e${depth}`,
276
+ };
277
+ if (node.value)
278
+ result.value = String(node.value);
279
+ if (node.focused)
280
+ result.focused = true;
281
+ if (node.disabled)
282
+ result.disabled = true;
283
+ if (node.children && Array.isArray(node.children)) {
284
+ result.children = node.children.map((child, i) => this.normalizeA11yNode(child, depth * 10 + i + 1));
285
+ }
286
+ return result;
287
+ }
288
+ parseTextSnapshot(raw) {
289
+ const refs = {};
290
+ const lines = raw.split('\n').filter(l => l.trim());
291
+ // Parse lines like: " [button] Submit (@e1)"
292
+ const root = { role: 'WebArea', name: this.currentUrl, ref: '@e0', children: [] };
293
+ for (const line of lines) {
294
+ const match = line.match(/\[(\w+)\]\s*(.+?)\s*\(@e(\d+)\)/);
295
+ if (match) {
296
+ const [, role, name, num] = match;
297
+ const ref = `@e${num}`;
298
+ refs[ref] = `${role}: ${name}`;
299
+ root.children.push({ role, name, ref });
300
+ }
301
+ }
302
+ return { root, refs, timestamp: new Date().toISOString() };
303
+ }
304
+ }
305
+ exports.AgentBrowserAdapter = AgentBrowserAdapter;
@@ -0,0 +1,309 @@
1
+ "use strict";
2
+ /**
3
+ * PlaywrightAdapter — BrowserAdapter implementation using Playwright.
4
+ * Extracted from the original BrowseDaemon page operations.
5
+ */
6
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ var desc = Object.getOwnPropertyDescriptor(m, k);
9
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
+ desc = { enumerable: true, get: function() { return m[k]; } };
11
+ }
12
+ Object.defineProperty(o, k2, desc);
13
+ }) : (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ o[k2] = m[k];
16
+ }));
17
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
19
+ }) : function(o, v) {
20
+ o["default"] = v;
21
+ });
22
+ var __importStar = (this && this.__importStar) || (function () {
23
+ var ownKeys = function(o) {
24
+ ownKeys = Object.getOwnPropertyNames || function (o) {
25
+ var ar = [];
26
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
27
+ return ar;
28
+ };
29
+ return ownKeys(o);
30
+ };
31
+ return function (mod) {
32
+ if (mod && mod.__esModule) return mod;
33
+ var result = {};
34
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
35
+ __setModuleDefault(result, mod);
36
+ return result;
37
+ };
38
+ })();
39
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
40
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
41
+ return new (P || (P = Promise))(function (resolve, reject) {
42
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
43
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
44
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
45
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
46
+ });
47
+ };
48
+ Object.defineProperty(exports, "__esModule", { value: true });
49
+ exports.PlaywrightAdapter = void 0;
50
+ const error_collector_1 = require("../error-collector");
51
+ class PlaywrightAdapter {
52
+ constructor() {
53
+ this.name = 'playwright';
54
+ this.browser = null;
55
+ this.context = null;
56
+ this.page = null;
57
+ this.errorCollector = new error_collector_1.ErrorCollector();
58
+ this.consoleLog = [];
59
+ this.networkLog = [];
60
+ this.videoDir = null;
61
+ this.refMap = {};
62
+ }
63
+ isAvailable() {
64
+ return __awaiter(this, void 0, void 0, function* () {
65
+ try {
66
+ const pw = yield Promise.resolve().then(() => __importStar(require('playwright')));
67
+ return !!pw.chromium;
68
+ }
69
+ catch (_a) {
70
+ return false;
71
+ }
72
+ });
73
+ }
74
+ startSession(opts) {
75
+ return __awaiter(this, void 0, void 0, function* () {
76
+ var _a, _b;
77
+ const pw = yield Promise.resolve().then(() => __importStar(require('playwright')));
78
+ const headless = (_a = opts === null || opts === void 0 ? void 0 : opts.headless) !== null && _a !== void 0 ? _a : true;
79
+ this.browser = yield pw.chromium.launch({ headless });
80
+ const contextOpts = {};
81
+ if (opts === null || opts === void 0 ? void 0 : opts.viewport)
82
+ contextOpts.viewport = opts.viewport;
83
+ if (opts === null || opts === void 0 ? void 0 : opts.userAgent)
84
+ contextOpts.userAgent = opts.userAgent;
85
+ if (opts === null || opts === void 0 ? void 0 : opts.recordVideo) {
86
+ this.videoDir = (_b = opts.videoDir) !== null && _b !== void 0 ? _b : '/tmp/cm-browse-videos';
87
+ contextOpts.recordVideo = { dir: this.videoDir };
88
+ }
89
+ this.context = yield this.browser.newContext(contextOpts);
90
+ this.page = yield this.context.newPage();
91
+ // Wire console events
92
+ this.page.on('console', (msg) => {
93
+ const entry = {
94
+ type: msg.type(),
95
+ text: msg.text(),
96
+ timestamp: new Date().toISOString(),
97
+ };
98
+ this.consoleLog.push(entry);
99
+ // Feed error collector
100
+ if (msg.type() === 'error' || msg.type() === 'warning') {
101
+ this.errorCollector.addConsole(msg.type(), msg.text());
102
+ }
103
+ });
104
+ // Wire page errors (uncaught exceptions)
105
+ this.page.on('pageerror', (err) => {
106
+ this.errorCollector.add({
107
+ type: 'js-error',
108
+ source: 'page',
109
+ message: err.message,
110
+ stack: err.stack,
111
+ });
112
+ });
113
+ // Wire network events
114
+ if (this.context) {
115
+ this.context.on('response', (response) => {
116
+ try {
117
+ const entry = {
118
+ url: response.url(),
119
+ method: response.request().method(),
120
+ status: response.status(),
121
+ statusText: response.statusText(),
122
+ timestamp: new Date().toISOString(),
123
+ resourceType: response.request().resourceType(),
124
+ };
125
+ this.networkLog.push(entry);
126
+ // Capture failures
127
+ if (response.status() >= 400) {
128
+ this.errorCollector.addNetworkFailure(response.url(), response.request().method(), response.status());
129
+ }
130
+ }
131
+ catch (_a) {
132
+ /* ignore */
133
+ }
134
+ });
135
+ this.context.on('requestfailed', (request) => {
136
+ var _a;
137
+ this.errorCollector.addNetworkFailure(request.url(), request.method(), undefined, (_a = request.failure()) === null || _a === void 0 ? void 0 : _a.errorText);
138
+ });
139
+ }
140
+ });
141
+ }
142
+ navigate(url) {
143
+ return __awaiter(this, void 0, void 0, function* () {
144
+ if (!this.page)
145
+ throw new Error('No active session');
146
+ yield this.page.goto(url, { waitUntil: 'domcontentloaded', timeout: 60000 });
147
+ });
148
+ }
149
+ click(ref) {
150
+ return __awaiter(this, void 0, void 0, function* () {
151
+ if (!this.page)
152
+ throw new Error('No active session');
153
+ const cleanRef = ref.replace(/^@/, '');
154
+ yield this.page.click(`[data-cm-ref="${cleanRef}"]`, { timeout: 15000 });
155
+ });
156
+ }
157
+ fill(ref, value) {
158
+ return __awaiter(this, void 0, void 0, function* () {
159
+ if (!this.page)
160
+ throw new Error('No active session');
161
+ const cleanRef = ref.replace(/^@/, '');
162
+ yield this.page.fill(`[data-cm-ref="${cleanRef}"]`, value, { timeout: 15000 });
163
+ });
164
+ }
165
+ type(ref, text, opts) {
166
+ return __awaiter(this, void 0, void 0, function* () {
167
+ if (!this.page)
168
+ throw new Error('No active session');
169
+ const cleanRef = ref.replace(/^@/, '');
170
+ yield this.page.fill(`[data-cm-ref="${cleanRef}"]`, text, { timeout: 15000 });
171
+ });
172
+ }
173
+ press(key) {
174
+ return __awaiter(this, void 0, void 0, function* () {
175
+ if (!this.page)
176
+ throw new Error('No active session');
177
+ yield this.page.keyboard.press(key);
178
+ });
179
+ }
180
+ screenshot(opts) {
181
+ return __awaiter(this, void 0, void 0, function* () {
182
+ if (!this.page)
183
+ throw new Error('No active session');
184
+ return this.page.screenshot({ type: 'png', fullPage: opts === null || opts === void 0 ? void 0 : opts.fullPage });
185
+ });
186
+ }
187
+ getSnapshot() {
188
+ return __awaiter(this, void 0, void 0, function* () {
189
+ if (!this.page)
190
+ throw new Error('No active session');
191
+ // Use Playwright's accessibility snapshot
192
+ const pwSnapshot = yield this.page.accessibility.snapshot();
193
+ // Also tag interactive elements with data-cm-ref
194
+ const refMapping = yield this.page.evaluate(() => {
195
+ const sel = 'a[href],button,input,textarea,select,[role="button"],[onclick]';
196
+ const nodes = Array.from(document.querySelectorAll(sel));
197
+ const out = {};
198
+ nodes.forEach((el, i) => {
199
+ const id = `e${i + 1}`;
200
+ el.setAttribute('data-cm-ref', id);
201
+ const tag = el.tagName.toLowerCase();
202
+ const txt = (el.textContent || '').trim().slice(0, 80);
203
+ out[id] = `${tag}${txt ? `: ${txt}` : ''}`;
204
+ });
205
+ return out;
206
+ });
207
+ this.refMap = refMapping;
208
+ // Convert Playwright a11y tree to our format
209
+ const root = this.convertA11yNode(pwSnapshot, 0);
210
+ return {
211
+ root,
212
+ refs: refMapping,
213
+ timestamp: new Date().toISOString(),
214
+ };
215
+ });
216
+ }
217
+ getConsole() {
218
+ return __awaiter(this, void 0, void 0, function* () {
219
+ return [...this.consoleLog];
220
+ });
221
+ }
222
+ getNetwork() {
223
+ return __awaiter(this, void 0, void 0, function* () {
224
+ return [...this.networkLog];
225
+ });
226
+ }
227
+ getErrors() {
228
+ return __awaiter(this, void 0, void 0, function* () {
229
+ return this.errorCollector.getAll();
230
+ });
231
+ }
232
+ startRecording() {
233
+ return __awaiter(this, void 0, void 0, function* () {
234
+ // Video recording must be set at context creation time in Playwright
235
+ // This is a no-op if not started with recordVideo
236
+ if (!this.context)
237
+ throw new Error('No active session');
238
+ });
239
+ }
240
+ stopRecording() {
241
+ return __awaiter(this, void 0, void 0, function* () {
242
+ if (!this.page)
243
+ throw new Error('No active session');
244
+ // Playwright saves video on page close
245
+ const video = this.page.video();
246
+ if (video) {
247
+ const path = yield video.path();
248
+ return path;
249
+ }
250
+ return '';
251
+ });
252
+ }
253
+ getEngineInfo() {
254
+ return {
255
+ name: 'playwright',
256
+ version: '1.x',
257
+ capabilities: {
258
+ a11ySnapshot: true,
259
+ videoRecording: true,
260
+ networkCapture: true,
261
+ consoleCapture: true,
262
+ },
263
+ };
264
+ }
265
+ closeSession() {
266
+ return __awaiter(this, void 0, void 0, function* () {
267
+ if (this.page)
268
+ yield this.page.close().catch(() => { });
269
+ if (this.context)
270
+ yield this.context.close().catch(() => { });
271
+ if (this.browser)
272
+ yield this.browser.close().catch(() => { });
273
+ this.page = null;
274
+ this.context = null;
275
+ this.browser = null;
276
+ this.consoleLog = [];
277
+ this.networkLog = [];
278
+ this.errorCollector.clear();
279
+ this.refMap = {};
280
+ });
281
+ }
282
+ // ── Private helpers ─────────────────────────────────────────────────────────
283
+ convertA11yNode(node, depth) {
284
+ var _a, _b;
285
+ if (!node)
286
+ return { role: 'unknown', name: '', ref: `@e${depth}` };
287
+ const ref = `@e${depth}`;
288
+ const result = {
289
+ role: (_a = node.role) !== null && _a !== void 0 ? _a : 'unknown',
290
+ name: (_b = node.name) !== null && _b !== void 0 ? _b : '',
291
+ ref,
292
+ };
293
+ if (node.value !== undefined)
294
+ result.value = String(node.value);
295
+ if (node.focused)
296
+ result.focused = true;
297
+ if (node.disabled)
298
+ result.disabled = true;
299
+ if (node.expanded !== undefined)
300
+ result.expanded = node.expanded;
301
+ if (node.selected !== undefined)
302
+ result.selected = node.selected;
303
+ if (node.children && Array.isArray(node.children)) {
304
+ result.children = node.children.map((child, i) => this.convertA11yNode(child, depth * 10 + i + 1));
305
+ }
306
+ return result;
307
+ }
308
+ }
309
+ exports.PlaywrightAdapter = PlaywrightAdapter;
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ /**
3
+ * Browse Hybrid Bridge — Unified adapter interface and types.
4
+ * Both PlaywrightAdapter and AgentBrowserAdapter implement BrowserAdapter.
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });