macro-agent 0.1.1 → 0.1.2

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 (406) hide show
  1. package/.sudocode/issues.jsonl +28 -0
  2. package/.sudocode/specs.jsonl +4 -0
  3. package/CLAUDE.md +9 -3
  4. package/dist/agent/agent-manager.d.ts.map +1 -1
  5. package/dist/agent/agent-manager.js +111 -48
  6. package/dist/agent/agent-manager.js.map +1 -1
  7. package/dist/agent/types.d.ts +7 -0
  8. package/dist/agent/types.d.ts.map +1 -1
  9. package/dist/agent/types.js.map +1 -1
  10. package/dist/api/server.d.ts +5 -1
  11. package/dist/api/server.d.ts.map +1 -1
  12. package/dist/api/server.js +100 -3
  13. package/dist/api/server.js.map +1 -1
  14. package/dist/api/types.d.ts +1 -1
  15. package/dist/api/types.d.ts.map +1 -1
  16. package/dist/cli/acp.d.ts.map +1 -1
  17. package/dist/cli/acp.js +71 -1
  18. package/dist/cli/acp.js.map +1 -1
  19. package/dist/cli/index.js +5 -1
  20. package/dist/cli/index.js.map +1 -1
  21. package/dist/cli/mcp.js +27 -8
  22. package/dist/cli/mcp.js.map +1 -1
  23. package/dist/config/project-config.d.ts +13 -2
  24. package/dist/config/project-config.d.ts.map +1 -1
  25. package/dist/config/project-config.js +12 -2
  26. package/dist/config/project-config.js.map +1 -1
  27. package/dist/index.d.ts +1 -0
  28. package/dist/index.d.ts.map +1 -1
  29. package/dist/index.js +2 -0
  30. package/dist/index.js.map +1 -1
  31. package/dist/lifecycle/handlers/index.d.ts +7 -3
  32. package/dist/lifecycle/handlers/index.d.ts.map +1 -1
  33. package/dist/lifecycle/handlers/index.js +25 -8
  34. package/dist/lifecycle/handlers/index.js.map +1 -1
  35. package/dist/lifecycle/types.d.ts +2 -0
  36. package/dist/lifecycle/types.d.ts.map +1 -1
  37. package/dist/lifecycle/types.js.map +1 -1
  38. package/dist/map/adapter/extensions/index.d.ts +4 -1
  39. package/dist/map/adapter/extensions/index.d.ts.map +1 -1
  40. package/dist/map/adapter/extensions/index.js +27 -0
  41. package/dist/map/adapter/extensions/index.js.map +1 -1
  42. package/dist/map/adapter/extensions/streams.d.ts +95 -0
  43. package/dist/map/adapter/extensions/streams.d.ts.map +1 -0
  44. package/dist/map/adapter/extensions/streams.js +515 -0
  45. package/dist/map/adapter/extensions/streams.js.map +1 -0
  46. package/dist/map/adapter/index.d.ts +1 -1
  47. package/dist/map/adapter/index.d.ts.map +1 -1
  48. package/dist/map/adapter/index.js +3 -1
  49. package/dist/map/adapter/index.js.map +1 -1
  50. package/dist/map/adapter/types.d.ts +1 -1
  51. package/dist/map/adapter/types.d.ts.map +1 -1
  52. package/dist/mcp/mcp-server.d.ts +2 -0
  53. package/dist/mcp/mcp-server.d.ts.map +1 -1
  54. package/dist/mcp/mcp-server.js +12 -3
  55. package/dist/mcp/mcp-server.js.map +1 -1
  56. package/dist/mcp/tools/done.d.ts.map +1 -1
  57. package/dist/mcp/tools/done.js +18 -0
  58. package/dist/mcp/tools/done.js.map +1 -1
  59. package/dist/roles/builtin/coordinator.d.ts.map +1 -1
  60. package/dist/roles/builtin/coordinator.js +2 -1
  61. package/dist/roles/builtin/coordinator.js.map +1 -1
  62. package/dist/roles/builtin/integrator.d.ts.map +1 -1
  63. package/dist/roles/builtin/integrator.js +2 -1
  64. package/dist/roles/builtin/integrator.js.map +1 -1
  65. package/dist/roles/builtin/worker.d.ts.map +1 -1
  66. package/dist/roles/builtin/worker.js +3 -1
  67. package/dist/roles/builtin/worker.js.map +1 -1
  68. package/dist/roles/capabilities.d.ts +6 -0
  69. package/dist/roles/capabilities.d.ts.map +1 -1
  70. package/dist/roles/capabilities.js +10 -0
  71. package/dist/roles/capabilities.js.map +1 -1
  72. package/dist/roles/config-loader.d.ts +1 -1
  73. package/dist/roles/config-loader.d.ts.map +1 -1
  74. package/dist/roles/config-loader.js +3 -2
  75. package/dist/roles/config-loader.js.map +1 -1
  76. package/dist/roles/types.d.ts +3 -1
  77. package/dist/roles/types.d.ts.map +1 -1
  78. package/dist/server/combined-server.d.ts +8 -1
  79. package/dist/server/combined-server.d.ts.map +1 -1
  80. package/dist/server/combined-server.js +6 -2
  81. package/dist/server/combined-server.js.map +1 -1
  82. package/dist/store/event-store.d.ts.map +1 -1
  83. package/dist/store/event-store.js +12 -5
  84. package/dist/store/event-store.js.map +1 -1
  85. package/dist/store/instance.d.ts +1 -1
  86. package/dist/store/instance.d.ts.map +1 -1
  87. package/dist/store/instance.js +2 -2
  88. package/dist/store/instance.js.map +1 -1
  89. package/dist/store/types/agents.d.ts +5 -0
  90. package/dist/store/types/agents.d.ts.map +1 -1
  91. package/dist/task/backend/opentasks/daemon-manager.d.ts.map +1 -1
  92. package/dist/task/backend/opentasks/daemon-manager.js +1 -1
  93. package/dist/task/backend/opentasks/daemon-manager.js.map +1 -1
  94. package/dist/teams/index.d.ts +3 -1
  95. package/dist/teams/index.d.ts.map +1 -1
  96. package/dist/teams/index.js +2 -0
  97. package/dist/teams/index.js.map +1 -1
  98. package/dist/teams/seed-defaults.d.ts +20 -0
  99. package/dist/teams/seed-defaults.d.ts.map +1 -0
  100. package/dist/teams/seed-defaults.js +71 -0
  101. package/dist/teams/seed-defaults.js.map +1 -0
  102. package/dist/teams/team-loader.d.ts +6 -2
  103. package/dist/teams/team-loader.d.ts.map +1 -1
  104. package/dist/teams/team-loader.js +154 -162
  105. package/dist/teams/team-loader.js.map +1 -1
  106. package/dist/teams/team-manager.d.ts +112 -0
  107. package/dist/teams/team-manager.d.ts.map +1 -0
  108. package/dist/teams/team-manager.js +305 -0
  109. package/dist/teams/team-manager.js.map +1 -0
  110. package/dist/teams/team-runtime.d.ts +125 -19
  111. package/dist/teams/team-runtime.d.ts.map +1 -1
  112. package/dist/teams/team-runtime.js +527 -119
  113. package/dist/teams/team-runtime.js.map +1 -1
  114. package/dist/teams/types.d.ts +41 -151
  115. package/dist/teams/types.d.ts.map +1 -1
  116. package/dist/teams/types.js +2 -3
  117. package/dist/teams/types.js.map +1 -1
  118. package/docs/teams.md +73 -0
  119. package/package.json +2 -1
  120. package/references/minimem/.claude/settings.json +7 -0
  121. package/references/minimem/.sudocode/issues.jsonl +18 -0
  122. package/references/minimem/.sudocode/specs.jsonl +1 -0
  123. package/references/minimem/CLAUDE.md +310 -0
  124. package/references/minimem/README.md +562 -0
  125. package/references/minimem/claude-plugin/.claude-plugin/plugin.json +10 -0
  126. package/references/minimem/claude-plugin/.mcp.json +7 -0
  127. package/references/minimem/claude-plugin/README.md +158 -0
  128. package/references/minimem/claude-plugin/commands/recall.md +47 -0
  129. package/references/minimem/claude-plugin/commands/remember.md +41 -0
  130. package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +272 -0
  131. package/references/minimem/claude-plugin/hooks/hooks.json +27 -0
  132. package/references/minimem/claude-plugin/hooks/session-end.sh +86 -0
  133. package/references/minimem/claude-plugin/hooks/session-start.sh +85 -0
  134. package/references/minimem/claude-plugin/skills/memory/SKILL.md +108 -0
  135. package/references/minimem/media/banner.png +0 -0
  136. package/references/minimem/package-lock.json +5373 -0
  137. package/references/minimem/package.json +72 -0
  138. package/references/minimem/scripts/postbuild.js +35 -0
  139. package/references/minimem/src/__tests__/edge-cases.test.ts +371 -0
  140. package/references/minimem/src/__tests__/errors.test.ts +265 -0
  141. package/references/minimem/src/__tests__/helpers.ts +199 -0
  142. package/references/minimem/src/__tests__/internal.test.ts +407 -0
  143. package/references/minimem/src/__tests__/knowledge.test.ts +287 -0
  144. package/references/minimem/src/__tests__/minimem.integration.test.ts +1127 -0
  145. package/references/minimem/src/__tests__/session.test.ts +190 -0
  146. package/references/minimem/src/cli/__tests__/commands.test.ts +759 -0
  147. package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +141 -0
  148. package/references/minimem/src/cli/commands/append.ts +76 -0
  149. package/references/minimem/src/cli/commands/config.ts +262 -0
  150. package/references/minimem/src/cli/commands/conflicts.ts +413 -0
  151. package/references/minimem/src/cli/commands/daemon.ts +169 -0
  152. package/references/minimem/src/cli/commands/index.ts +12 -0
  153. package/references/minimem/src/cli/commands/init.ts +88 -0
  154. package/references/minimem/src/cli/commands/mcp.ts +177 -0
  155. package/references/minimem/src/cli/commands/push-pull.ts +213 -0
  156. package/references/minimem/src/cli/commands/search.ts +158 -0
  157. package/references/minimem/src/cli/commands/status.ts +84 -0
  158. package/references/minimem/src/cli/commands/sync-init.ts +290 -0
  159. package/references/minimem/src/cli/commands/sync.ts +70 -0
  160. package/references/minimem/src/cli/commands/upsert.ts +197 -0
  161. package/references/minimem/src/cli/config.ts +584 -0
  162. package/references/minimem/src/cli/index.ts +264 -0
  163. package/references/minimem/src/cli/shared.ts +161 -0
  164. package/references/minimem/src/cli/sync/__tests__/central.test.ts +152 -0
  165. package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +209 -0
  166. package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +118 -0
  167. package/references/minimem/src/cli/sync/__tests__/detection.test.ts +207 -0
  168. package/references/minimem/src/cli/sync/__tests__/integration.test.ts +476 -0
  169. package/references/minimem/src/cli/sync/__tests__/registry.test.ts +363 -0
  170. package/references/minimem/src/cli/sync/__tests__/state.test.ts +255 -0
  171. package/references/minimem/src/cli/sync/__tests__/validation.test.ts +193 -0
  172. package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +178 -0
  173. package/references/minimem/src/cli/sync/central.ts +292 -0
  174. package/references/minimem/src/cli/sync/conflicts.ts +204 -0
  175. package/references/minimem/src/cli/sync/daemon.ts +407 -0
  176. package/references/minimem/src/cli/sync/detection.ts +138 -0
  177. package/references/minimem/src/cli/sync/index.ts +107 -0
  178. package/references/minimem/src/cli/sync/operations.ts +373 -0
  179. package/references/minimem/src/cli/sync/registry.ts +279 -0
  180. package/references/minimem/src/cli/sync/state.ts +355 -0
  181. package/references/minimem/src/cli/sync/validation.ts +206 -0
  182. package/references/minimem/src/cli/sync/watcher.ts +234 -0
  183. package/references/minimem/src/cli/version.ts +34 -0
  184. package/references/minimem/src/core/index.ts +9 -0
  185. package/references/minimem/src/core/indexer.ts +628 -0
  186. package/references/minimem/src/core/searcher.ts +221 -0
  187. package/references/minimem/src/db/schema.ts +183 -0
  188. package/references/minimem/src/db/sqlite-vec.ts +24 -0
  189. package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +431 -0
  190. package/references/minimem/src/embeddings/batch-gemini.ts +392 -0
  191. package/references/minimem/src/embeddings/batch-openai.ts +409 -0
  192. package/references/minimem/src/embeddings/embeddings.ts +434 -0
  193. package/references/minimem/src/index.ts +109 -0
  194. package/references/minimem/src/internal.ts +299 -0
  195. package/references/minimem/src/minimem.ts +1276 -0
  196. package/references/minimem/src/search/__tests__/hybrid.test.ts +247 -0
  197. package/references/minimem/src/search/graph.ts +234 -0
  198. package/references/minimem/src/search/hybrid.ts +151 -0
  199. package/references/minimem/src/search/search.ts +256 -0
  200. package/references/minimem/src/server/__tests__/mcp.test.ts +341 -0
  201. package/references/minimem/src/server/__tests__/tools.test.ts +364 -0
  202. package/references/minimem/src/server/mcp.ts +326 -0
  203. package/references/minimem/src/server/tools.ts +720 -0
  204. package/references/minimem/src/session.ts +460 -0
  205. package/references/minimem/tsconfig.json +19 -0
  206. package/references/minimem/tsup.config.ts +26 -0
  207. package/references/minimem/vitest.config.ts +24 -0
  208. package/references/openteams/.claude/settings.json +6 -0
  209. package/references/openteams/README.md +1 -0
  210. package/references/openteams/SKILL.md +341 -0
  211. package/references/openteams/design.md +411 -0
  212. package/references/openteams/examples/bmad-method/prompts/analyst/ROLE.md +16 -0
  213. package/references/openteams/examples/bmad-method/prompts/analyst/SOUL.md +5 -0
  214. package/references/openteams/examples/bmad-method/prompts/architect/ROLE.md +24 -0
  215. package/references/openteams/examples/bmad-method/prompts/architect/SOUL.md +5 -0
  216. package/references/openteams/examples/bmad-method/prompts/developer/ROLE.md +25 -0
  217. package/references/openteams/examples/bmad-method/prompts/developer/SOUL.md +5 -0
  218. package/references/openteams/examples/bmad-method/prompts/master/ROLE.md +21 -0
  219. package/references/openteams/examples/bmad-method/prompts/master/SOUL.md +5 -0
  220. package/references/openteams/examples/bmad-method/prompts/pm/ROLE.md +20 -0
  221. package/references/openteams/examples/bmad-method/prompts/pm/SOUL.md +5 -0
  222. package/references/openteams/examples/bmad-method/prompts/qa/ROLE.md +17 -0
  223. package/references/openteams/examples/bmad-method/prompts/qa/SOUL.md +5 -0
  224. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/ROLE.md +23 -0
  225. package/references/openteams/examples/bmad-method/prompts/quick-flow-dev/SOUL.md +5 -0
  226. package/references/openteams/examples/bmad-method/prompts/scrum-master/ROLE.md +27 -0
  227. package/references/openteams/examples/bmad-method/prompts/scrum-master/SOUL.md +5 -0
  228. package/references/openteams/examples/bmad-method/prompts/tech-writer/ROLE.md +21 -0
  229. package/references/openteams/examples/bmad-method/prompts/tech-writer/SOUL.md +5 -0
  230. package/references/openteams/examples/bmad-method/prompts/ux-designer/ROLE.md +16 -0
  231. package/references/openteams/examples/bmad-method/prompts/ux-designer/SOUL.md +5 -0
  232. package/references/openteams/examples/bmad-method/roles/analyst.yaml +9 -0
  233. package/references/openteams/examples/bmad-method/roles/architect.yaml +9 -0
  234. package/references/openteams/examples/bmad-method/roles/developer.yaml +8 -0
  235. package/references/openteams/examples/bmad-method/roles/master.yaml +8 -0
  236. package/references/openteams/examples/bmad-method/roles/pm.yaml +9 -0
  237. package/references/openteams/examples/bmad-method/roles/qa.yaml +8 -0
  238. package/references/openteams/examples/bmad-method/roles/quick-flow-dev.yaml +8 -0
  239. package/references/openteams/examples/bmad-method/roles/scrum-master.yaml +9 -0
  240. package/references/openteams/examples/bmad-method/roles/tech-writer.yaml +8 -0
  241. package/references/openteams/examples/bmad-method/roles/ux-designer.yaml +8 -0
  242. package/references/openteams/examples/bmad-method/team.yaml +161 -0
  243. package/references/openteams/examples/get-shit-done/prompts/codebase-mapper/ROLE.md +17 -0
  244. package/references/openteams/examples/get-shit-done/prompts/codebase-mapper/SOUL.md +5 -0
  245. package/references/openteams/examples/get-shit-done/prompts/debugger/ROLE.md +25 -0
  246. package/references/openteams/examples/get-shit-done/prompts/debugger/SOUL.md +5 -0
  247. package/references/openteams/examples/get-shit-done/prompts/executor/ROLE.md +34 -0
  248. package/references/openteams/examples/get-shit-done/prompts/executor/SOUL.md +5 -0
  249. package/references/openteams/examples/get-shit-done/prompts/integration-checker/ROLE.md +18 -0
  250. package/references/openteams/examples/get-shit-done/prompts/integration-checker/SOUL.md +3 -0
  251. package/references/openteams/examples/get-shit-done/prompts/orchestrator/ROLE.md +42 -0
  252. package/references/openteams/examples/get-shit-done/prompts/orchestrator/SOUL.md +5 -0
  253. package/references/openteams/examples/get-shit-done/prompts/phase-researcher/ROLE.md +15 -0
  254. package/references/openteams/examples/get-shit-done/prompts/phase-researcher/SOUL.md +3 -0
  255. package/references/openteams/examples/get-shit-done/prompts/plan-checker/ROLE.md +17 -0
  256. package/references/openteams/examples/get-shit-done/prompts/plan-checker/SOUL.md +3 -0
  257. package/references/openteams/examples/get-shit-done/prompts/planner/ROLE.md +28 -0
  258. package/references/openteams/examples/get-shit-done/prompts/planner/SOUL.md +5 -0
  259. package/references/openteams/examples/get-shit-done/prompts/project-researcher/ROLE.md +16 -0
  260. package/references/openteams/examples/get-shit-done/prompts/project-researcher/SOUL.md +3 -0
  261. package/references/openteams/examples/get-shit-done/prompts/research-synthesizer/ROLE.md +13 -0
  262. package/references/openteams/examples/get-shit-done/prompts/research-synthesizer/SOUL.md +3 -0
  263. package/references/openteams/examples/get-shit-done/prompts/roadmapper/ROLE.md +14 -0
  264. package/references/openteams/examples/get-shit-done/prompts/roadmapper/SOUL.md +3 -0
  265. package/references/openteams/examples/get-shit-done/prompts/verifier/ROLE.md +19 -0
  266. package/references/openteams/examples/get-shit-done/prompts/verifier/SOUL.md +5 -0
  267. package/references/openteams/examples/get-shit-done/roles/codebase-mapper.yaml +8 -0
  268. package/references/openteams/examples/get-shit-done/roles/debugger.yaml +8 -0
  269. package/references/openteams/examples/get-shit-done/roles/executor.yaml +8 -0
  270. package/references/openteams/examples/get-shit-done/roles/integration-checker.yaml +8 -0
  271. package/references/openteams/examples/get-shit-done/roles/orchestrator.yaml +9 -0
  272. package/references/openteams/examples/get-shit-done/roles/phase-researcher.yaml +7 -0
  273. package/references/openteams/examples/get-shit-done/roles/plan-checker.yaml +8 -0
  274. package/references/openteams/examples/get-shit-done/roles/planner.yaml +8 -0
  275. package/references/openteams/examples/get-shit-done/roles/project-researcher.yaml +8 -0
  276. package/references/openteams/examples/get-shit-done/roles/research-synthesizer.yaml +7 -0
  277. package/references/openteams/examples/get-shit-done/roles/roadmapper.yaml +7 -0
  278. package/references/openteams/examples/get-shit-done/roles/verifier.yaml +8 -0
  279. package/references/openteams/examples/get-shit-done/team.yaml +154 -0
  280. package/references/openteams/package-lock.json +2181 -0
  281. package/references/openteams/package.json +48 -0
  282. package/references/openteams/schema/role.schema.json +125 -0
  283. package/references/openteams/schema/team.schema.json +284 -0
  284. package/references/openteams/src/cli/agent.ts +104 -0
  285. package/references/openteams/src/cli/cli.test.ts +381 -0
  286. package/references/openteams/src/cli/generate.ts +220 -0
  287. package/references/openteams/src/cli/message.ts +241 -0
  288. package/references/openteams/src/cli/task.ts +154 -0
  289. package/references/openteams/src/cli/team.ts +104 -0
  290. package/references/openteams/src/cli/template.ts +207 -0
  291. package/references/openteams/src/cli.ts +45 -0
  292. package/references/openteams/src/db/database.test.ts +185 -0
  293. package/references/openteams/src/db/database.ts +240 -0
  294. package/references/openteams/src/generators/agent-prompt-generator.test.ts +332 -0
  295. package/references/openteams/src/generators/agent-prompt-generator.ts +521 -0
  296. package/references/openteams/src/generators/package-generator.test.ts +129 -0
  297. package/references/openteams/src/generators/package-generator.ts +102 -0
  298. package/references/openteams/src/generators/skill-generator.test.ts +246 -0
  299. package/references/openteams/src/generators/skill-generator.ts +374 -0
  300. package/references/openteams/src/index.ts +104 -0
  301. package/references/openteams/src/services/agent-service.test.ts +158 -0
  302. package/references/openteams/src/services/agent-service.ts +84 -0
  303. package/references/openteams/src/services/communication-service.test.ts +455 -0
  304. package/references/openteams/src/services/communication-service.ts +371 -0
  305. package/references/openteams/src/services/message-service.test.ts +342 -0
  306. package/references/openteams/src/services/message-service.ts +203 -0
  307. package/references/openteams/src/services/task-service.test.ts +434 -0
  308. package/references/openteams/src/services/task-service.ts +239 -0
  309. package/references/openteams/src/services/team-service.test.ts +181 -0
  310. package/references/openteams/src/services/team-service.ts +139 -0
  311. package/references/openteams/src/services/template-service.test.ts +306 -0
  312. package/references/openteams/src/services/template-service.ts +182 -0
  313. package/references/openteams/src/spawner/acp-factory.ts +96 -0
  314. package/references/openteams/src/spawner/interface.ts +31 -0
  315. package/references/openteams/src/spawner/mock.test.ts +93 -0
  316. package/references/openteams/src/spawner/mock.ts +59 -0
  317. package/references/openteams/src/template/loader.test.ts +1319 -0
  318. package/references/openteams/src/template/loader.ts +698 -0
  319. package/references/openteams/src/template/types.ts +200 -0
  320. package/references/openteams/src/types.ts +205 -0
  321. package/references/openteams/tsconfig.json +18 -0
  322. package/references/openteams/vitest.config.ts +9 -0
  323. package/references/skill-tree/.claude/settings.json +6 -0
  324. package/references/skill-tree/.sudocode/issues.jsonl +11 -0
  325. package/references/skill-tree/.sudocode/specs.jsonl +1 -0
  326. package/references/skill-tree/CLAUDE.md +150 -0
  327. package/references/skill-tree/README.md +324 -0
  328. package/references/skill-tree/docs/GAPS_v1.md +221 -0
  329. package/references/skill-tree/docs/INTEGRATION_PLAN.md +467 -0
  330. package/references/skill-tree/docs/TODOS.md +91 -0
  331. package/references/skill-tree/docs/anthropic_skill_guide.md +1364 -0
  332. package/references/skill-tree/docs/design/federated-skill-trees.md +524 -0
  333. package/references/skill-tree/docs/design/multi-agent-sync.md +759 -0
  334. package/references/skill-tree/docs/scraper/BRAINSTORM.md +583 -0
  335. package/references/skill-tree/docs/scraper/POC_PLAN.md +420 -0
  336. package/references/skill-tree/docs/scraper/README.md +170 -0
  337. package/references/skill-tree/examples/basic-usage.ts +190 -0
  338. package/references/skill-tree/package-lock.json +1509 -0
  339. package/references/skill-tree/package.json +66 -0
  340. package/references/skill-tree/scraper/README.md +123 -0
  341. package/references/skill-tree/scraper/docs/DESIGN.md +683 -0
  342. package/references/skill-tree/scraper/docs/PLAN.md +336 -0
  343. package/references/skill-tree/scraper/drizzle.config.ts +10 -0
  344. package/references/skill-tree/scraper/package-lock.json +6329 -0
  345. package/references/skill-tree/scraper/package.json +68 -0
  346. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +7 -0
  347. package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +7 -0
  348. package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +27 -0
  349. package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +21 -0
  350. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +54 -0
  351. package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +24 -0
  352. package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +93 -0
  353. package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +22 -0
  354. package/references/skill-tree/scraper/tsup.config.ts +14 -0
  355. package/references/skill-tree/scraper/vitest.config.ts +17 -0
  356. package/references/skill-tree/scripts/convert-to-vitest.ts +166 -0
  357. package/references/skill-tree/skills/skill-writer/SKILL.md +339 -0
  358. package/references/skill-tree/skills/skill-writer/references/examples.md +326 -0
  359. package/references/skill-tree/skills/skill-writer/references/patterns.md +210 -0
  360. package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +123 -0
  361. package/references/skill-tree/test/run-all.ts +106 -0
  362. package/references/skill-tree/test/utils.ts +128 -0
  363. package/references/skill-tree/vitest.config.ts +16 -0
  364. package/src/agent/agent-manager.ts +143 -72
  365. package/src/agent/types.ts +9 -0
  366. package/src/api/__tests__/server.test.ts +203 -4
  367. package/src/api/server.ts +130 -5
  368. package/src/api/types.ts +3 -1
  369. package/src/cli/acp.ts +68 -1
  370. package/src/cli/index.ts +5 -1
  371. package/src/cli/mcp.ts +27 -13
  372. package/src/config/project-config.ts +27 -3
  373. package/src/index.ts +3 -0
  374. package/src/lifecycle/__tests__/handlers.test.ts +53 -0
  375. package/src/lifecycle/handlers/index.ts +25 -8
  376. package/src/lifecycle/types.ts +3 -0
  377. package/src/map/adapter/__tests__/stream-extensions.test.ts +494 -0
  378. package/src/map/adapter/extensions/index.ts +36 -0
  379. package/src/map/adapter/extensions/streams.ts +839 -0
  380. package/src/map/adapter/index.ts +5 -0
  381. package/src/map/adapter/types.ts +8 -1
  382. package/src/mcp/mcp-server.ts +14 -3
  383. package/src/mcp/tools/done.ts +19 -0
  384. package/src/roles/builtin/coordinator.ts +2 -0
  385. package/src/roles/builtin/integrator.ts +2 -0
  386. package/src/roles/builtin/worker.ts +3 -0
  387. package/src/roles/capabilities.ts +11 -0
  388. package/src/roles/config-loader.ts +3 -2
  389. package/src/roles/types.ts +7 -0
  390. package/src/server/combined-server.ts +15 -1
  391. package/src/store/__tests__/event-store-oob.test.ts +109 -0
  392. package/src/store/event-store.ts +13 -3
  393. package/src/store/instance.ts +2 -2
  394. package/src/store/types/agents.ts +5 -0
  395. package/src/task/backend/__tests__/memory-pull-mode.test.ts +153 -0
  396. package/src/task/backend/opentasks/daemon-manager.ts +4 -1
  397. package/src/teams/CLAUDE.md +180 -0
  398. package/src/teams/__tests__/e2e/workspace-isolation.e2e.test.ts +1263 -0
  399. package/src/teams/__tests__/team-manager.test.ts +814 -0
  400. package/src/teams/__tests__/team-system.test.ts +1291 -8
  401. package/src/teams/index.ts +21 -3
  402. package/src/teams/seed-defaults.ts +79 -0
  403. package/src/teams/team-loader.ts +200 -234
  404. package/src/teams/team-manager.ts +387 -0
  405. package/src/teams/team-runtime.ts +590 -121
  406. package/src/teams/types.ts +99 -200
@@ -0,0 +1,413 @@
1
+ /**
2
+ * minimem sync:conflicts - Conflict management commands
3
+ */
4
+
5
+ import fs from "node:fs/promises";
6
+ import path from "node:path";
7
+ import { spawn } from "node:child_process";
8
+
9
+ import {
10
+ resolveMemoryDir,
11
+ isInitialized,
12
+ formatPath,
13
+ getSyncConfig,
14
+ exitWithError,
15
+ warn,
16
+ } from "../config.js";
17
+ import {
18
+ listQuarantinedConflicts,
19
+ getConflictsDir,
20
+ getShadowsDir,
21
+ } from "../sync/conflicts.js";
22
+ import { getSyncStatePath, loadSyncState } from "../sync/state.js";
23
+
24
+ export type ConflictsOptions = {
25
+ dir?: string;
26
+ global?: boolean;
27
+ json?: boolean;
28
+ };
29
+
30
+ /**
31
+ * List all quarantined conflicts
32
+ */
33
+ export async function conflictsCommand(options: ConflictsOptions): Promise<void> {
34
+ const memoryDir = resolveMemoryDir({
35
+ dir: options.dir,
36
+ global: options.global,
37
+ });
38
+
39
+ if (!(await isInitialized(memoryDir))) {
40
+ exitWithError(`${formatPath(memoryDir)} is not initialized.`);
41
+ }
42
+
43
+ try {
44
+ const conflicts = await listQuarantinedConflicts(memoryDir);
45
+
46
+ if (options.json) {
47
+ console.log(JSON.stringify(conflicts, null, 2));
48
+ return;
49
+ }
50
+
51
+ if (conflicts.length === 0) {
52
+ console.log("No quarantined conflicts.");
53
+ return;
54
+ }
55
+
56
+ console.log(`Quarantined conflicts in ${formatPath(memoryDir)}`);
57
+ console.log("-".repeat(50));
58
+
59
+ for (const conflict of conflicts) {
60
+ console.log(`\n${conflict.timestamp}:`);
61
+ for (const file of conflict.files) {
62
+ console.log(` - ${file}`);
63
+ }
64
+ }
65
+
66
+ console.log(`\nTotal: ${conflicts.length} conflict set(s)`);
67
+ console.log("\nUse 'minimem sync:resolve <timestamp>' to resolve a conflict.");
68
+ } catch (error) {
69
+ const message = error instanceof Error ? error.message : String(error);
70
+ exitWithError(message);
71
+ }
72
+ }
73
+
74
+ export type ResolveOptions = {
75
+ dir?: string;
76
+ global?: boolean;
77
+ tool?: string;
78
+ };
79
+
80
+ /**
81
+ * Resolve a quarantined conflict
82
+ */
83
+ export async function resolveCommand(
84
+ timestamp: string,
85
+ options: ResolveOptions
86
+ ): Promise<void> {
87
+ const memoryDir = resolveMemoryDir({
88
+ dir: options.dir,
89
+ global: options.global,
90
+ });
91
+
92
+ if (!(await isInitialized(memoryDir))) {
93
+ exitWithError(`${formatPath(memoryDir)} is not initialized.`);
94
+ }
95
+
96
+ const conflictDir = path.join(getConflictsDir(memoryDir), timestamp);
97
+
98
+ try {
99
+ await fs.access(conflictDir);
100
+ } catch {
101
+ exitWithError(
102
+ `Conflict '${timestamp}' not found.`,
103
+ "Use 'minimem sync:conflicts' to list available conflicts."
104
+ );
105
+ }
106
+
107
+ try {
108
+ const files = await fs.readdir(conflictDir);
109
+
110
+ // Group files by base name
111
+ const fileGroups = new Map<string, { local?: string; remote?: string; base?: string }>();
112
+ for (const file of files) {
113
+ const match = file.match(/^(.+)\.(local|remote|base)$/);
114
+ if (match) {
115
+ const [, baseName, type] = match;
116
+ if (!fileGroups.has(baseName)) {
117
+ fileGroups.set(baseName, {});
118
+ }
119
+ const group = fileGroups.get(baseName)!;
120
+ group[type as "local" | "remote" | "base"] = path.join(conflictDir, file);
121
+ }
122
+ }
123
+
124
+ if (fileGroups.size === 0) {
125
+ exitWithError("No conflict files found in this directory.");
126
+ }
127
+
128
+ // Determine merge tool
129
+ const mergeTool = options.tool || process.env.MERGE_TOOL || await detectMergeTool();
130
+
131
+ if (!mergeTool) {
132
+ console.log("No merge tool detected. Available conflict files:");
133
+ for (const [baseName, group] of fileGroups) {
134
+ console.log(`\n${baseName.replace(/_/g, "/")}:`);
135
+ if (group.local) console.log(` Local: ${group.local}`);
136
+ if (group.remote) console.log(` Remote: ${group.remote}`);
137
+ if (group.base) console.log(` Base: ${group.base}`);
138
+ }
139
+ console.log("\nManually edit the files or set MERGE_TOOL environment variable.");
140
+ return;
141
+ }
142
+
143
+ console.log(`Using merge tool: ${mergeTool}`);
144
+
145
+ for (const [baseName, group] of fileGroups) {
146
+ const fileName = baseName.replace(/_/g, "/");
147
+ console.log(`\nResolving: ${fileName}`);
148
+
149
+ if (group.local && group.remote) {
150
+ // Launch merge tool
151
+ const args = group.base
152
+ ? [group.local, group.base, group.remote]
153
+ : [group.local, group.remote];
154
+
155
+ const child = spawn(mergeTool, args, { stdio: "inherit" });
156
+
157
+ await new Promise<void>((resolve, reject) => {
158
+ child.on("close", (code) => {
159
+ if (code === 0) {
160
+ resolve();
161
+ } else {
162
+ reject(new Error(`Merge tool exited with code ${code}`));
163
+ }
164
+ });
165
+ child.on("error", reject);
166
+ });
167
+ }
168
+ }
169
+
170
+ console.log("\nMerge complete. Remove conflict directory when satisfied:");
171
+ console.log(` rm -rf "${conflictDir}"`);
172
+ } catch (error) {
173
+ const message = error instanceof Error ? error.message : String(error);
174
+ exitWithError(message);
175
+ }
176
+ }
177
+
178
+ /**
179
+ * Detect available merge tool
180
+ */
181
+ async function detectMergeTool(): Promise<string | null> {
182
+ const tools = ["code", "meld", "kdiff3", "vimdiff", "opendiff"];
183
+
184
+ for (const tool of tools) {
185
+ try {
186
+ const { execSync } = await import("node:child_process");
187
+ execSync(`which ${tool}`, { stdio: "ignore" });
188
+ return tool;
189
+ } catch {
190
+ continue;
191
+ }
192
+ }
193
+
194
+ return null;
195
+ }
196
+
197
+ export type CleanupOptions = {
198
+ dir?: string;
199
+ global?: boolean;
200
+ days?: number;
201
+ dryRun?: boolean;
202
+ };
203
+
204
+ /**
205
+ * Clean up old quarantined conflicts
206
+ */
207
+ export async function cleanupCommand(options: CleanupOptions): Promise<void> {
208
+ const memoryDir = resolveMemoryDir({
209
+ dir: options.dir,
210
+ global: options.global,
211
+ });
212
+
213
+ if (!(await isInitialized(memoryDir))) {
214
+ exitWithError(`${formatPath(memoryDir)} is not initialized.`);
215
+ }
216
+
217
+ const maxAgeDays = options.days ?? 30;
218
+ const cutoffDate = new Date(Date.now() - maxAgeDays * 24 * 60 * 60 * 1000);
219
+
220
+ try {
221
+ const conflictsDir = getConflictsDir(memoryDir);
222
+ let entries: string[] = [];
223
+
224
+ try {
225
+ entries = await fs.readdir(conflictsDir);
226
+ } catch {
227
+ console.log("No conflicts directory found.");
228
+ return;
229
+ }
230
+
231
+ let cleaned = 0;
232
+ let kept = 0;
233
+
234
+ for (const entry of entries) {
235
+ // Timestamps are in ISO format with : and . replaced with -
236
+ // e.g., 2026-02-03T07-20-56-704Z
237
+ const timestamp = entry.replace(/-(\d{2})-(\d{2})-(\d{3})Z$/, ":$1:$2.$3Z");
238
+ const entryDate = new Date(timestamp);
239
+
240
+ if (isNaN(entryDate.getTime())) {
241
+ console.log(` Skipping invalid timestamp: ${entry}`);
242
+ continue;
243
+ }
244
+
245
+ const entryPath = path.join(conflictsDir, entry);
246
+
247
+ if (entryDate < cutoffDate) {
248
+ if (options.dryRun) {
249
+ console.log(` Would remove: ${entry}`);
250
+ } else {
251
+ await fs.rm(entryPath, { recursive: true, force: true });
252
+ console.log(` Removed: ${entry}`);
253
+ }
254
+ cleaned++;
255
+ } else {
256
+ kept++;
257
+ }
258
+ }
259
+
260
+ if (options.dryRun) {
261
+ console.log(`\nWould remove ${cleaned} conflict(s), keep ${kept}`);
262
+ } else {
263
+ console.log(`\nRemoved ${cleaned} conflict(s), kept ${kept}`);
264
+ }
265
+ } catch (error) {
266
+ const message = error instanceof Error ? error.message : String(error);
267
+ exitWithError(message);
268
+ }
269
+ }
270
+
271
+ /**
272
+ * Sync logging
273
+ */
274
+ const SYNC_LOG_FILE = "sync.log";
275
+ const MAX_LOG_ENTRIES = 1000;
276
+
277
+ export type SyncLogEntry = {
278
+ timestamp: string;
279
+ operation: "push" | "pull" | "sync";
280
+ result: "success" | "partial" | "failure";
281
+ pushed?: number;
282
+ pulled?: number;
283
+ conflicts?: number;
284
+ errors?: string[];
285
+ };
286
+
287
+ /**
288
+ * Get sync log path
289
+ */
290
+ export function getSyncLogPath(memoryDir: string): string {
291
+ return path.join(memoryDir, ".minimem", SYNC_LOG_FILE);
292
+ }
293
+
294
+ /**
295
+ * Append to sync log
296
+ */
297
+ export async function appendSyncLog(
298
+ memoryDir: string,
299
+ entry: SyncLogEntry
300
+ ): Promise<void> {
301
+ const logPath = getSyncLogPath(memoryDir);
302
+
303
+ try {
304
+ await fs.mkdir(path.dirname(logPath), { recursive: true });
305
+
306
+ // Read existing log
307
+ let entries: SyncLogEntry[] = [];
308
+ try {
309
+ const content = await fs.readFile(logPath, "utf-8");
310
+ entries = content
311
+ .split("\n")
312
+ .filter(Boolean)
313
+ .map((line) => JSON.parse(line));
314
+ } catch {
315
+ // No existing log
316
+ }
317
+
318
+ // Add new entry and trim if needed
319
+ entries.push(entry);
320
+ if (entries.length > MAX_LOG_ENTRIES) {
321
+ entries = entries.slice(-MAX_LOG_ENTRIES);
322
+ }
323
+
324
+ // Write back
325
+ const content = entries.map((e) => JSON.stringify(e)).join("\n") + "\n";
326
+ await fs.writeFile(logPath, content);
327
+ } catch (error) {
328
+ // Log failures are non-fatal
329
+ const message = error instanceof Error ? error.message : String(error);
330
+ warn(`Failed to write sync log: ${message}`);
331
+ }
332
+ }
333
+
334
+ /**
335
+ * Read sync log
336
+ */
337
+ export async function readSyncLog(memoryDir: string): Promise<SyncLogEntry[]> {
338
+ const logPath = getSyncLogPath(memoryDir);
339
+
340
+ try {
341
+ const content = await fs.readFile(logPath, "utf-8");
342
+ return content
343
+ .split("\n")
344
+ .filter(Boolean)
345
+ .map((line) => JSON.parse(line));
346
+ } catch {
347
+ return [];
348
+ }
349
+ }
350
+
351
+ export type LogOptions = {
352
+ dir?: string;
353
+ global?: boolean;
354
+ limit?: number;
355
+ json?: boolean;
356
+ };
357
+
358
+ /**
359
+ * Show sync log
360
+ */
361
+ export async function logCommand(options: LogOptions): Promise<void> {
362
+ const memoryDir = resolveMemoryDir({
363
+ dir: options.dir,
364
+ global: options.global,
365
+ });
366
+
367
+ if (!(await isInitialized(memoryDir))) {
368
+ exitWithError(`${formatPath(memoryDir)} is not initialized.`);
369
+ }
370
+
371
+ try {
372
+ let entries = await readSyncLog(memoryDir);
373
+
374
+ const limit = options.limit ?? 20;
375
+ entries = entries.slice(-limit);
376
+
377
+ if (options.json) {
378
+ console.log(JSON.stringify(entries, null, 2));
379
+ return;
380
+ }
381
+
382
+ if (entries.length === 0) {
383
+ console.log("No sync history.");
384
+ return;
385
+ }
386
+
387
+ console.log(`Sync history for ${formatPath(memoryDir)}`);
388
+ console.log("-".repeat(60));
389
+
390
+ for (const entry of entries) {
391
+ const time = new Date(entry.timestamp).toLocaleString();
392
+ const status =
393
+ entry.result === "success" ? "OK" :
394
+ entry.result === "partial" ? "PARTIAL" : "FAILED";
395
+
396
+ let details = "";
397
+ if (entry.pushed) details += ` +${entry.pushed}`;
398
+ if (entry.pulled) details += ` -${entry.pulled}`;
399
+ if (entry.conflicts) details += ` !${entry.conflicts}`;
400
+
401
+ console.log(`${time} ${entry.operation.padEnd(6)} ${status.padEnd(8)}${details}`);
402
+
403
+ if (entry.errors && entry.errors.length > 0) {
404
+ for (const error of entry.errors.slice(0, 3)) {
405
+ console.log(` Error: ${error}`);
406
+ }
407
+ }
408
+ }
409
+ } catch (error) {
410
+ const message = error instanceof Error ? error.message : String(error);
411
+ exitWithError(message);
412
+ }
413
+ }
@@ -0,0 +1,169 @@
1
+ /**
2
+ * minimem daemon - Background sync daemon commands
3
+ */
4
+
5
+ import fs from "node:fs/promises";
6
+
7
+ import {
8
+ startDaemon,
9
+ startDaemonBackground,
10
+ stopDaemon,
11
+ getDaemonStatus,
12
+ isDaemonRunning,
13
+ getDaemonLogPath,
14
+ } from "../sync/daemon.js";
15
+ import { exitWithError } from "../config.js";
16
+
17
+ export type DaemonOptions = {
18
+ background?: boolean;
19
+ foreground?: boolean;
20
+ };
21
+
22
+ /**
23
+ * Start the daemon
24
+ */
25
+ export async function daemonCommand(options: DaemonOptions): Promise<void> {
26
+ // If --foreground is specified, run in foreground (used by background spawn)
27
+ if (options.foreground) {
28
+ console.log("Starting daemon in foreground...");
29
+ try {
30
+ await startDaemon();
31
+ } catch (error) {
32
+ const message = error instanceof Error ? error.message : String(error);
33
+ exitWithError(`Daemon: ${message}`);
34
+ }
35
+ return;
36
+ }
37
+
38
+ // Check if already running
39
+ if (await isDaemonRunning()) {
40
+ console.log("Daemon is already running.");
41
+ console.log("Use 'minimem daemon:stop' to stop it.");
42
+ return;
43
+ }
44
+
45
+ if (options.background) {
46
+ console.log("Starting daemon in background...");
47
+ try {
48
+ const pid = await startDaemonBackground();
49
+ console.log(`Daemon started with PID ${pid}`);
50
+ console.log(`Log file: ${getDaemonLogPath()}`);
51
+ } catch (error) {
52
+ const message = error instanceof Error ? error.message : String(error);
53
+ exitWithError(`Failed to start daemon: ${message}`);
54
+ }
55
+ } else {
56
+ console.log("Starting daemon in foreground...");
57
+ console.log("Press Ctrl+C to stop.");
58
+ console.log("");
59
+ try {
60
+ await startDaemon();
61
+ } catch (error) {
62
+ const message = error instanceof Error ? error.message : String(error);
63
+ exitWithError(`Daemon: ${message}`);
64
+ }
65
+ }
66
+ }
67
+
68
+ /**
69
+ * Stop the daemon
70
+ */
71
+ export async function daemonStopCommand(): Promise<void> {
72
+ const status = await getDaemonStatus();
73
+
74
+ if (!status.running) {
75
+ console.log("Daemon is not running.");
76
+ return;
77
+ }
78
+
79
+ console.log(`Stopping daemon (PID ${status.pid})...`);
80
+
81
+ const stopped = await stopDaemon();
82
+
83
+ if (stopped) {
84
+ console.log("Daemon stopped.");
85
+ } else {
86
+ exitWithError("Failed to stop daemon.");
87
+ }
88
+ }
89
+
90
+ /**
91
+ * Show daemon status
92
+ */
93
+ export async function daemonStatusCommand(): Promise<void> {
94
+ const status = await getDaemonStatus();
95
+
96
+ if (status.running) {
97
+ console.log("Daemon status: running");
98
+ console.log(` PID: ${status.pid}`);
99
+ console.log(` Log: ${getDaemonLogPath()}`);
100
+ } else {
101
+ console.log("Daemon status: stopped");
102
+ }
103
+ }
104
+
105
+ export type LogOptions = {
106
+ lines?: number;
107
+ follow?: boolean;
108
+ };
109
+
110
+ /**
111
+ * Show daemon logs
112
+ */
113
+ export async function daemonLogsCommand(options: LogOptions): Promise<void> {
114
+ const logPath = getDaemonLogPath();
115
+
116
+ try {
117
+ const content = await fs.readFile(logPath, "utf-8");
118
+ const lines = content.split("\n").filter(Boolean);
119
+
120
+ const numLines = options.lines ?? 50;
121
+ const displayLines = lines.slice(-numLines);
122
+
123
+ for (const line of displayLines) {
124
+ console.log(line);
125
+ }
126
+
127
+ if (options.follow) {
128
+ console.log("\n--- Following log (Ctrl+C to stop) ---\n");
129
+
130
+ // Simple follow implementation using polling
131
+ let lastSize = (await fs.stat(logPath)).size;
132
+
133
+ const poll = async () => {
134
+ try {
135
+ const stats = await fs.stat(logPath);
136
+ if (stats.size > lastSize) {
137
+ const fd = await fs.open(logPath, "r");
138
+ const buffer = Buffer.alloc(stats.size - lastSize);
139
+ await fd.read(buffer, 0, buffer.length, lastSize);
140
+ await fd.close();
141
+
142
+ process.stdout.write(buffer.toString());
143
+ lastSize = stats.size;
144
+ }
145
+ } catch {
146
+ // File may have been rotated
147
+ lastSize = 0;
148
+ }
149
+ };
150
+
151
+ const interval = setInterval(poll, 1000);
152
+
153
+ process.on("SIGINT", () => {
154
+ clearInterval(interval);
155
+ process.exit(0);
156
+ });
157
+
158
+ // Keep running
159
+ await new Promise(() => {});
160
+ }
161
+ } catch (error) {
162
+ if ((error as NodeJS.ErrnoException).code === "ENOENT") {
163
+ console.log("No daemon log found.");
164
+ } else {
165
+ const message = error instanceof Error ? error.message : String(error);
166
+ exitWithError(`Error reading log: ${message}`);
167
+ }
168
+ }
169
+ }
@@ -0,0 +1,12 @@
1
+ /**
2
+ * CLI Commands
3
+ */
4
+
5
+ export { init, type InitOptions } from "./init.js";
6
+ export { search, type SearchOptions } from "./search.js";
7
+ export { sync, type SyncOptions } from "./sync.js";
8
+ export { status, type StatusOptions } from "./status.js";
9
+ export { append, type AppendOptions } from "./append.js";
10
+ export { upsert, type UpsertOptions } from "./upsert.js";
11
+ export { mcp, type McpOptions } from "./mcp.js";
12
+ export { config, type ConfigOptions } from "./config.js";
@@ -0,0 +1,88 @@
1
+ /**
2
+ * minimem init - Initialize memory directory
3
+ */
4
+
5
+ import fs from "node:fs/promises";
6
+ import path from "node:path";
7
+
8
+ import {
9
+ resolveMemoryDir,
10
+ saveConfig,
11
+ getInitConfig,
12
+ isInitialized,
13
+ formatPath,
14
+ } from "../config.js";
15
+
16
+ const MEMORY_TEMPLATE = `# Memory
17
+
18
+ This is your memory file. Add notes, decisions, and context here.
19
+
20
+ ## Quick Start
21
+
22
+ - Add daily logs in the \`memory/\` directory (e.g., \`memory/2024-01-15.md\`)
23
+ - Use \`minimem search <query>\` to find relevant memories
24
+ - Use \`minimem append <text>\` to quickly add to today's log
25
+
26
+ ## Notes
27
+
28
+ `;
29
+
30
+ export type InitOptions = {
31
+ global?: boolean;
32
+ force?: boolean;
33
+ };
34
+
35
+ export async function init(
36
+ dir: string | undefined,
37
+ options: InitOptions,
38
+ ): Promise<void> {
39
+ const memoryDir = resolveMemoryDir({ dir, global: options.global });
40
+ const displayPath = formatPath(memoryDir);
41
+
42
+ // Check if already initialized
43
+ if (!options.force && (await isInitialized(memoryDir))) {
44
+ console.log(`Already initialized: ${displayPath}`);
45
+ console.log("Use --force to reinitialize");
46
+ return;
47
+ }
48
+
49
+ console.log(`Initializing minimem in ${displayPath}...`);
50
+
51
+ // Create directories
52
+ await fs.mkdir(memoryDir, { recursive: true });
53
+ await fs.mkdir(path.join(memoryDir, "memory"), { recursive: true });
54
+ await fs.mkdir(path.join(memoryDir, ".minimem"), { recursive: true });
55
+
56
+ // Create MEMORY.md if it doesn't exist
57
+ const memoryFilePath = path.join(memoryDir, "MEMORY.md");
58
+ try {
59
+ await fs.access(memoryFilePath);
60
+ console.log(" MEMORY.md already exists, skipping");
61
+ } catch {
62
+ await fs.writeFile(memoryFilePath, MEMORY_TEMPLATE, "utf-8");
63
+ console.log(" Created MEMORY.md");
64
+ }
65
+
66
+ // Create config
67
+ const config = getInitConfig();
68
+ await saveConfig(memoryDir, config);
69
+ console.log(" Created .minimem/config.json");
70
+
71
+ // Create .gitignore for .minimem directory
72
+ const gitignorePath = path.join(memoryDir, ".minimem", ".gitignore");
73
+ await fs.writeFile(gitignorePath, "index.db\nindex.db-*\n", "utf-8");
74
+ console.log(" Created .minimem/.gitignore");
75
+
76
+ console.log();
77
+ console.log("Done! Your memory directory is ready.");
78
+ console.log();
79
+ console.log("Next steps:");
80
+ console.log(` 1. Set your embedding API key:`);
81
+ console.log(` export OPENAI_API_KEY=your-key`);
82
+ console.log(` # or: export GOOGLE_API_KEY=your-key`);
83
+ console.log();
84
+ console.log(` 2. Add some memories to MEMORY.md or memory/*.md`);
85
+ console.log();
86
+ console.log(` 3. Search your memories:`);
87
+ console.log(` minimem search "your query"${dir ? ` --dir ${dir}` : ""}`);
88
+ }