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
@@ -1,521 +0,0 @@
1
- #!/usr/bin/env python3
2
- """
3
- Memory Engine โ€” 3-layer memory system for self-learning content factory.
4
-
5
- Architecture:
6
- 1. Semantic Memory โ€” Long-term patterns, rules, writing style (persistent)
7
- 2. Episodic Memory โ€” Per-session experiences with outcomes (time-bounded)
8
- 3. Working Memory โ€” Current session context (ephemeral)
9
-
10
- Usage:
11
- python3 memory.py --config content-factory.config.json --status
12
- python3 memory.py --config content-factory.config.json --learn
13
- python3 memory.py --config content-factory.config.json --test
14
- """
15
-
16
- import json
17
- import sys
18
- import os
19
- import argparse
20
- from pathlib import Path
21
- from datetime import datetime, timedelta
22
-
23
-
24
- MEMORY_SCHEMA = {
25
- "semantic": {
26
- "writing_patterns.json": {
27
- "description": "Accumulated writing style preferences",
28
- "patterns": {},
29
- "style_preferences": {
30
- "tone": [],
31
- "sentence_length": "medium",
32
- "paragraph_style": "concise",
33
- "heading_style": "question-based",
34
- "cta_style": "soft"
35
- },
36
- "updated_at": None
37
- },
38
- "seo_patterns.json": {
39
- "description": "SEO rules proven effective",
40
- "patterns": {},
41
- "effective_titles": [],
42
- "effective_descriptions": [],
43
- "keyword_strategies": [],
44
- "updated_at": None
45
- },
46
- "niche_knowledge.json": {
47
- "description": "Domain knowledge accumulated from research",
48
- "domains": {},
49
- "sources": [],
50
- "confidence_scores": {},
51
- "updated_at": None
52
- },
53
- "mistakes.json": {
54
- "description": "Anti-patterns learned from user corrections",
55
- "patterns": {},
56
- "common_errors": [],
57
- "deleted_content_reasons": [],
58
- "updated_at": None
59
- }
60
- },
61
- "episodic": {},
62
- "working": {
63
- "current_session.json": {
64
- "session_id": None,
65
- "started_at": None,
66
- "phase": None,
67
- "articles_processed": 0,
68
- "errors": [],
69
- "notes": []
70
- }
71
- }
72
- }
73
-
74
-
75
- class MemoryEngine:
76
- """Three-layer memory system for the content factory."""
77
-
78
- def __init__(self, config_path: str):
79
- with open(config_path, "r", encoding="utf-8") as f:
80
- self.config = json.load(f)
81
-
82
- self.project_root = Path(config_path).resolve().parent
83
- mem_cfg = self.config.get("memory", {})
84
- self.memory_dir = self.project_root / mem_cfg.get("memory_dir", "memory")
85
- self.auto_learn = mem_cfg.get("auto_learn", True)
86
- self.max_episodic_days = mem_cfg.get("max_episodic_days", 90)
87
-
88
- # Ensure directory structure
89
- self._init_dirs()
90
-
91
- def _init_dirs(self):
92
- """Create memory directory structure if not exists."""
93
- for subdir in ["semantic", "episodic", "working"]:
94
- (self.memory_dir / subdir).mkdir(parents=True, exist_ok=True)
95
-
96
- # Initialize semantic files if missing
97
- for filename, schema in MEMORY_SCHEMA["semantic"].items():
98
- filepath = self.memory_dir / "semantic" / filename
99
- if not filepath.exists():
100
- data = dict(schema)
101
- data["updated_at"] = datetime.now().isoformat()
102
- self._save_json(filepath, data)
103
-
104
- # Initialize working memory
105
- working_file = self.memory_dir / "working" / "current_session.json"
106
- if not working_file.exists():
107
- self._save_json(working_file, MEMORY_SCHEMA["working"]["current_session.json"])
108
-
109
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
110
- # SEMANTIC MEMORY โ€” Long-term patterns & rules
111
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
112
-
113
- def load_semantic(self, category: str) -> dict:
114
- """Load a semantic memory file."""
115
- filepath = self.memory_dir / "semantic" / f"{category}.json"
116
- if filepath.exists():
117
- return self._load_json(filepath)
118
- return {}
119
-
120
- def save_semantic(self, category: str, data: dict):
121
- """Save to semantic memory."""
122
- data["updated_at"] = datetime.now().isoformat()
123
- filepath = self.memory_dir / "semantic" / f"{category}.json"
124
- self._save_json(filepath, data)
125
-
126
- def add_writing_pattern(self, pattern_id: str, pattern: dict):
127
- """Add or update a writing pattern."""
128
- data = self.load_semantic("writing_patterns")
129
- patterns = data.get("patterns", {})
130
-
131
- if pattern_id in patterns:
132
- # Update confidence based on usage
133
- existing = patterns[pattern_id]
134
- existing["applications"] = existing.get("applications", 0) + 1
135
- existing["confidence"] = min(1.0, existing.get("confidence", 0.5) + 0.05)
136
- existing["last_used"] = datetime.now().isoformat()
137
- else:
138
- pattern.setdefault("confidence", 0.5)
139
- pattern.setdefault("applications", 1)
140
- pattern.setdefault("created", datetime.now().isoformat())
141
- pattern.setdefault("last_used", datetime.now().isoformat())
142
- patterns[pattern_id] = pattern
143
-
144
- data["patterns"] = patterns
145
- self.save_semantic("writing_patterns", data)
146
-
147
- def add_mistake(self, mistake: dict):
148
- """Record a mistake to avoid in future."""
149
- data = self.load_semantic("mistakes")
150
- patterns = data.get("patterns", {})
151
- mistakes_list = data.get("common_errors", [])
152
-
153
- mistake_id = mistake.get("id", f"err-{datetime.now().strftime('%Y%m%d-%H%M%S')}")
154
- mistake["recorded_at"] = datetime.now().isoformat()
155
- mistake.setdefault("severity", "medium")
156
- mistake.setdefault("occurrences", 1)
157
-
158
- if mistake_id in patterns:
159
- patterns[mistake_id]["occurrences"] = patterns[mistake_id].get("occurrences", 0) + 1
160
- patterns[mistake_id]["last_seen"] = datetime.now().isoformat()
161
- else:
162
- patterns[mistake_id] = mistake
163
-
164
- data["patterns"] = patterns
165
- data["common_errors"] = mistakes_list
166
- self.save_semantic("mistakes", data)
167
-
168
- def add_niche_knowledge(self, domain: str, knowledge: dict):
169
- """Add acquired domain knowledge from research."""
170
- data = self.load_semantic("niche_knowledge")
171
- domains = data.get("domains", {})
172
-
173
- if domain not in domains:
174
- domains[domain] = {
175
- "topics": {},
176
- "sources": [],
177
- "acquired_at": datetime.now().isoformat()
178
- }
179
-
180
- for key, value in knowledge.items():
181
- if key == "topics":
182
- domains[domain]["topics"].update(value)
183
- elif key == "sources":
184
- domains[domain]["sources"].extend(value)
185
- else:
186
- domains[domain][key] = value
187
-
188
- data["domains"] = domains
189
- self.save_semantic("niche_knowledge", data)
190
-
191
- def get_writing_context(self) -> dict:
192
- """Get accumulated writing context for content generation."""
193
- patterns = self.load_semantic("writing_patterns")
194
- mistakes = self.load_semantic("mistakes")
195
- seo = self.load_semantic("seo_patterns")
196
- knowledge = self.load_semantic("niche_knowledge")
197
-
198
- # Get top patterns by confidence
199
- top_patterns = sorted(
200
- patterns.get("patterns", {}).values(),
201
- key=lambda p: p.get("confidence", 0) * p.get("applications", 1),
202
- reverse=True
203
- )[:10]
204
-
205
- # Get recent mistakes to avoid
206
- recent_mistakes = sorted(
207
- mistakes.get("patterns", {}).values(),
208
- key=lambda m: m.get("occurrences", 0),
209
- reverse=True
210
- )[:5]
211
-
212
- return {
213
- "style": patterns.get("style_preferences", {}),
214
- "top_patterns": top_patterns,
215
- "avoid": [m.get("description", m.get("id", "")) for m in recent_mistakes],
216
- "seo_rules": seo.get("effective_titles", [])[:5],
217
- "domain_knowledge": list(knowledge.get("domains", {}).keys())
218
- }
219
-
220
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
221
- # EPISODIC MEMORY โ€” Per-session experiences
222
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
223
-
224
- def record_experience(self, phase: str, outcome: str, details: dict):
225
- """Record a pipeline experience."""
226
- now = datetime.now()
227
- year_dir = self.memory_dir / "episodic" / str(now.year)
228
- year_dir.mkdir(parents=True, exist_ok=True)
229
-
230
- episode = {
231
- "id": f"ep-{now.strftime('%Y%m%d-%H%M%S')}",
232
- "timestamp": now.isoformat(),
233
- "phase": phase,
234
- "outcome": outcome, # success, partial, failure
235
- "details": details,
236
- "niche": self.config.get("niche", "unknown"),
237
- "lessons": details.get("lessons", []),
238
- "user_feedback": details.get("user_feedback", None)
239
- }
240
-
241
- filename = f"{now.strftime('%m-%d')}-{phase}.json"
242
- filepath = year_dir / filename
243
-
244
- # Append to existing or create new
245
- if filepath.exists():
246
- episodes = self._load_json(filepath)
247
- if isinstance(episodes, list):
248
- episodes.append(episode)
249
- else:
250
- episodes = [episodes, episode]
251
- else:
252
- episodes = [episode]
253
-
254
- self._save_json(filepath, episodes)
255
- return episode["id"]
256
-
257
- def get_recent_experiences(self, days: int = 7, phase: str = None) -> list:
258
- """Retrieve recent episodic memories."""
259
- experiences = []
260
- now = datetime.now()
261
-
262
- for i in range(days):
263
- day = now - timedelta(days=i)
264
- year_dir = self.memory_dir / "episodic" / str(day.year)
265
- if not year_dir.exists():
266
- continue
267
-
268
- for f in year_dir.glob(f"{day.strftime('%m-%d')}-*.json"):
269
- data = self._load_json(f)
270
- if isinstance(data, list):
271
- experiences.extend(data)
272
- else:
273
- experiences.append(data)
274
-
275
- if phase:
276
- experiences = [e for e in experiences if e.get("phase") == phase]
277
-
278
- return sorted(experiences, key=lambda x: x.get("timestamp", ""), reverse=True)
279
-
280
- def cleanup_old_episodes(self):
281
- """Remove episodic memories older than max_episodic_days."""
282
- cutoff = datetime.now() - timedelta(days=self.max_episodic_days)
283
- removed = 0
284
-
285
- episodic_dir = self.memory_dir / "episodic"
286
- for year_dir in episodic_dir.iterdir():
287
- if not year_dir.is_dir():
288
- continue
289
- for f in year_dir.glob("*.json"):
290
- try:
291
- data = self._load_json(f)
292
- entries = data if isinstance(data, list) else [data]
293
- if entries and entries[0].get("timestamp", ""):
294
- ts = datetime.fromisoformat(entries[0]["timestamp"])
295
- if ts < cutoff:
296
- f.unlink()
297
- removed += 1
298
- except (ValueError, KeyError):
299
- pass
300
-
301
- return removed
302
-
303
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
304
- # WORKING MEMORY โ€” Current session
305
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
306
-
307
- def start_session(self, phase: str = None):
308
- """Initialize working memory for current session."""
309
- session = {
310
- "session_id": f"ses-{datetime.now().strftime('%Y%m%d-%H%M%S')}",
311
- "started_at": datetime.now().isoformat(),
312
- "phase": phase,
313
- "articles_processed": 0,
314
- "errors": [],
315
- "notes": []
316
- }
317
- self._save_json(self.memory_dir / "working" / "current_session.json", session)
318
- return session["session_id"]
319
-
320
- def update_session(self, updates: dict):
321
- """Update current working memory."""
322
- filepath = self.memory_dir / "working" / "current_session.json"
323
- session = self._load_json(filepath) if filepath.exists() else {}
324
- session.update(updates)
325
- self._save_json(filepath, session)
326
-
327
- def end_session(self, outcome: str = "complete"):
328
- """Finalize session and create episodic record."""
329
- filepath = self.memory_dir / "working" / "current_session.json"
330
- session = self._load_json(filepath) if filepath.exists() else {}
331
- session["ended_at"] = datetime.now().isoformat()
332
- session["outcome"] = outcome
333
-
334
- # Create episodic record from session
335
- if session.get("phase"):
336
- self.record_experience(
337
- phase=session["phase"],
338
- outcome=outcome,
339
- details={
340
- "articles_processed": session.get("articles_processed", 0),
341
- "errors": session.get("errors", []),
342
- "notes": session.get("notes", [])
343
- }
344
- )
345
-
346
- # Archive session
347
- self._save_json(
348
- self.memory_dir / "working" / "session_end.json", session
349
- )
350
-
351
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
352
- # PATTERN EXTRACTION โ€” Learn from experiences
353
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
354
-
355
- def extract_patterns(self):
356
- """Analyze episodic memories and extract semantic patterns."""
357
- experiences = self.get_recent_experiences(days=30)
358
- if not experiences:
359
- print(" โš ๏ธ No recent experiences to learn from")
360
- return 0
361
-
362
- patterns_added = 0
363
-
364
- # Group by phase
365
- phases = {}
366
- for exp in experiences:
367
- phase = exp.get("phase", "unknown")
368
- phases.setdefault(phase, []).append(exp)
369
-
370
- for phase, exps in phases.items():
371
- successes = [e for e in exps if e.get("outcome") == "success"]
372
- failures = [e for e in exps if e.get("outcome") == "failure"]
373
-
374
- # Extract success patterns
375
- if len(successes) >= 2:
376
- self.add_writing_pattern(f"success-{phase}", {
377
- "description": f"{phase} phase success pattern ({len(successes)} occurrences)",
378
- "source": "episodic_analysis",
379
- "category": phase,
380
- "success_count": len(successes)
381
- })
382
- patterns_added += 1
383
-
384
- # Extract failure patterns as mistakes
385
- for fail in failures:
386
- errors = fail.get("details", {}).get("errors", [])
387
- for error in errors[:3]:
388
- self.add_mistake({
389
- "id": f"err-{phase}-{hash(str(error)) % 10000}",
390
- "description": str(error)[:200],
391
- "phase": phase,
392
- "severity": "high" if "delete" in str(error).lower() else "medium"
393
- })
394
- patterns_added += 1
395
-
396
- print(f" ๐Ÿ“Š Extracted {patterns_added} patterns from {len(experiences)} experiences")
397
- return patterns_added
398
-
399
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
400
- # STATUS & UTILITIES
401
- # โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
402
-
403
- def get_status(self) -> dict:
404
- """Get memory system status."""
405
- status = {"layers": {}}
406
-
407
- # Semantic
408
- semantic_dir = self.memory_dir / "semantic"
409
- semantic_files = list(semantic_dir.glob("*.json")) if semantic_dir.exists() else []
410
- total_patterns = 0
411
- for f in semantic_files:
412
- data = self._load_json(f)
413
- total_patterns += len(data.get("patterns", {}))
414
-
415
- status["layers"]["semantic"] = {
416
- "files": len(semantic_files),
417
- "total_patterns": total_patterns
418
- }
419
-
420
- # Episodic
421
- episodic_dir = self.memory_dir / "episodic"
422
- episodic_files = list(episodic_dir.rglob("*.json")) if episodic_dir.exists() else []
423
- status["layers"]["episodic"] = {
424
- "files": len(episodic_files),
425
- "recent_7d": len(self.get_recent_experiences(7))
426
- }
427
-
428
- # Working
429
- working_file = self.memory_dir / "working" / "current_session.json"
430
- session = self._load_json(working_file) if working_file.exists() else {}
431
- status["layers"]["working"] = {
432
- "active_session": session.get("session_id"),
433
- "phase": session.get("phase")
434
- }
435
-
436
- return status
437
-
438
- def _load_json(self, filepath: Path) -> dict:
439
- with open(filepath, "r", encoding="utf-8") as f:
440
- return json.load(f)
441
-
442
- def _save_json(self, filepath: Path, data):
443
- filepath.parent.mkdir(parents=True, exist_ok=True)
444
- with open(filepath, "w", encoding="utf-8") as f:
445
- json.dump(data, f, ensure_ascii=False, indent=2)
446
-
447
-
448
- def main():
449
- parser = argparse.ArgumentParser(description="Memory Engine โ€” Self-learning system")
450
- parser.add_argument("--config", required=True, help="Path to config JSON")
451
- parser.add_argument("--status", action="store_true", help="Show memory status")
452
- parser.add_argument("--learn", action="store_true", help="Extract patterns from experiences")
453
- parser.add_argument("--cleanup", action="store_true", help="Remove old episodic memories")
454
- parser.add_argument("--context", action="store_true", help="Show writing context")
455
- parser.add_argument("--test", action="store_true", help="Run self-test")
456
- args = parser.parse_args()
457
-
458
- engine = MemoryEngine(args.config)
459
-
460
- if args.status:
461
- status = engine.get_status()
462
- print(f"\n{'โ•' * 50}")
463
- print(f" ๐Ÿง  Memory System Status")
464
- print(f"{'โ•' * 50}")
465
- for layer, info in status["layers"].items():
466
- print(f"\n ๐Ÿ“ฆ {layer.upper()}")
467
- for k, v in info.items():
468
- print(f" {k}: {v}")
469
- print(f"\n{'โ•' * 50}")
470
-
471
- elif args.learn:
472
- print("๐Ÿง  Learning from experiences...")
473
- count = engine.extract_patterns()
474
- print(f" โœ… {count} patterns extracted")
475
-
476
- elif args.cleanup:
477
- removed = engine.cleanup_old_episodes()
478
- print(f"๐Ÿงน Cleaned up {removed} old episodic memories")
479
-
480
- elif args.context:
481
- ctx = engine.get_writing_context()
482
- print(json.dumps(ctx, ensure_ascii=False, indent=2))
483
-
484
- elif args.test:
485
- print("๐Ÿงช Testing memory system...")
486
- # Test session lifecycle
487
- sid = engine.start_session("test")
488
- print(f" โœ… Session started: {sid}")
489
- engine.update_session({"articles_processed": 1, "notes": ["test note"]})
490
- print(f" โœ… Session updated")
491
- engine.end_session("success")
492
- print(f" โœ… Session ended โ†’ episodic record created")
493
-
494
- # Test pattern recording
495
- engine.add_writing_pattern("test-pattern", {
496
- "description": "Test writing pattern",
497
- "category": "test"
498
- })
499
- print(f" โœ… Writing pattern recorded")
500
-
501
- engine.add_mistake({
502
- "id": "test-mistake",
503
- "description": "Test mistake",
504
- "phase": "test"
505
- })
506
- print(f" โœ… Mistake recorded")
507
-
508
- # Test context
509
- ctx = engine.get_writing_context()
510
- print(f" โœ… Writing context generated ({len(ctx)} keys)")
511
-
512
- # Status
513
- status = engine.get_status()
514
- print(f" โœ… Status: {status['layers']['semantic']['total_patterns']} patterns")
515
- print(f"\n ๐ŸŽ‰ All memory tests passed!")
516
- else:
517
- parser.print_help()
518
-
519
-
520
- if __name__ == "__main__":
521
- main()