codymaster 5.2.0 โ†’ 7.0.0

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