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,158 @@
1
+ # minimem Claude Code Plugin
2
+
3
+ A Claude Code plugin that provides memory capabilities via the minimem semantic search system.
4
+
5
+ ## Features
6
+
7
+ - **MCP Server**: Provides `memory_search` tool for semantic search across memories
8
+ - **Memory Skill**: Automatically invoked when storing or recalling information
9
+ - **Commands**:
10
+ - `/minimem:remember <text>` - Store information for later
11
+ - `/minimem:recall <query>` - Search for stored memories
12
+
13
+ ## Installation
14
+
15
+ ### Prerequisites
16
+
17
+ 1. Install minimem globally:
18
+ ```bash
19
+ npm install -g minimem
20
+ ```
21
+
22
+ 2. Initialize your global memory directory:
23
+ ```bash
24
+ minimem init --global
25
+ ```
26
+
27
+ 3. Set your embedding API key:
28
+ ```bash
29
+ export OPENAI_API_KEY=your-key
30
+ # or
31
+ export GOOGLE_API_KEY=your-key
32
+ ```
33
+
34
+ ### Install the Plugin
35
+
36
+ #### Option 1: Test locally during development
37
+
38
+ ```bash
39
+ claude --plugin-dir /path/to/minimem/claude-plugin
40
+ ```
41
+
42
+ #### Option 2: Install from a marketplace
43
+
44
+ If this plugin is published to a marketplace:
45
+
46
+ ```
47
+ /plugin install minimem
48
+ ```
49
+
50
+ ## Usage
51
+
52
+ ### Automatic Memory Skill
53
+
54
+ The memory skill is automatically invoked when you:
55
+ - Ask Claude to "remember" something
56
+ - Ask Claude to "recall" or "find" previous context
57
+ - Reference past decisions or notes
58
+
59
+ ### Manual Commands
60
+
61
+ ```
62
+ # Store a memory
63
+ /minimem:remember We decided to use PostgreSQL for the database
64
+
65
+ # Search memories
66
+ /minimem:recall database decisions
67
+ ```
68
+
69
+ ### Direct MCP Tool
70
+
71
+ The `memory_search` tool is available for direct use:
72
+
73
+ ```
74
+ memory_search("api design decisions", maxResults=5)
75
+ ```
76
+
77
+ ## Configuration
78
+
79
+ ### Default Behavior
80
+
81
+ By default, the plugin searches both:
82
+ - **Current directory** (`.`) - Project-specific memories
83
+ - **Global** (`~/.minimem`) - Shared memories across all projects
84
+
85
+ This means project context is available when working in a project, and global memories are always accessible.
86
+
87
+ ### Custom Memory Locations
88
+
89
+ To use only specific directories, modify `.mcp.json`:
90
+
91
+ ```json
92
+ {
93
+ "minimem": {
94
+ "command": "npx",
95
+ "args": ["minimem", "mcp", "--dir", "/path/to/work", "--dir", "/path/to/personal"]
96
+ }
97
+ }
98
+ ```
99
+
100
+ ### Global Only
101
+
102
+ To use only the global memory directory:
103
+
104
+ ```json
105
+ {
106
+ "minimem": {
107
+ "command": "npx",
108
+ "args": ["minimem", "mcp", "--global"]
109
+ }
110
+ }
111
+ ```
112
+
113
+ ## Plugin Structure
114
+
115
+ ```
116
+ claude-plugin/
117
+ ├── .claude-plugin/
118
+ │ └── plugin.json # Plugin manifest
119
+ ├── .mcp.json # MCP server definition
120
+ ├── skills/
121
+ │ └── memory/
122
+ │ └── SKILL.md # Memory skill (auto-invoked)
123
+ ├── commands/
124
+ │ ├── remember.md # /minimem:remember command
125
+ │ └── recall.md # /minimem:recall command
126
+ └── README.md # This file
127
+ ```
128
+
129
+ ## Troubleshooting
130
+
131
+ ### "minimem command not found"
132
+
133
+ Ensure minimem is installed globally:
134
+ ```bash
135
+ npm install -g minimem
136
+ ```
137
+
138
+ ### "No API key found"
139
+
140
+ Set your embedding provider API key:
141
+ ```bash
142
+ export OPENAI_API_KEY=sk-...
143
+ # or
144
+ export GOOGLE_API_KEY=...
145
+ ```
146
+
147
+ ### "Memory directory not initialized"
148
+
149
+ Initialize the memory directory:
150
+ ```bash
151
+ minimem init --global
152
+ # or
153
+ minimem init /path/to/directory
154
+ ```
155
+
156
+ ## License
157
+
158
+ MIT
@@ -0,0 +1,47 @@
1
+ ---
2
+ description: Search memories for relevant information
3
+ ---
4
+
5
+ # Recall Command
6
+
7
+ Search for memories matching: "$ARGUMENTS"
8
+
9
+ ## Instructions
10
+
11
+ 1. Use `memory_search` MCP tool with the user's query (compact mode by default)
12
+ 2. If results are found:
13
+ - Show the compact index (path, score, preview)
14
+ - Use `memory_get_details` to fetch full text for the top 2-3 most relevant results
15
+ - Summarize the key information
16
+ - Offer to fetch more details if needed
17
+ 3. If no results:
18
+ - Suggest alternative search terms
19
+ - Try filtering by type if the query implies a category (e.g., "decisions" → type: "decision")
20
+ - Offer to help store relevant information
21
+
22
+ ## Response Format
23
+
24
+ **When results found:**
25
+
26
+ Show results clearly with:
27
+ - Relevance score (percentage)
28
+ - Source file and line numbers
29
+ - Full text of the top results (fetched via memory_get_details)
30
+ - A brief summary synthesizing the findings
31
+
32
+ **When no results:**
33
+
34
+ "I couldn't find memories matching '[query]'. Try:
35
+ - [alternative search term 1]
36
+ - [alternative search term 2]
37
+ - Filtering by type: `decision`, `bugfix`, `feature`, `discovery`
38
+
39
+ Use `/minimem:remember` to store information for later."
40
+
41
+ ## Tips
42
+
43
+ - Use the two-phase workflow: compact search first, then fetch details
44
+ - If the query mentions decisions, bugs, or features, add the `type` filter
45
+ - If the query is vague, ask for clarification
46
+ - Try broader terms if initial search returns few results
47
+ - Mention the source files so the user can read more context
@@ -0,0 +1,41 @@
1
+ ---
2
+ description: Store information in memory for later recall
3
+ ---
4
+
5
+ # Remember Command
6
+
7
+ Store the following information in memory: "$ARGUMENTS"
8
+
9
+ ## Instructions
10
+
11
+ 1. Parse what the user wants to remember from the arguments
12
+ 2. Determine the appropriate file:
13
+ - General notes → `memory/YYYY-MM-DD.md` (today's date)
14
+ - Important decisions → `MEMORY.md`
15
+ - Topic-specific → `memory/<topic>.md`
16
+ 3. Infer the observation type from context:
17
+ - Architectural/design choices → `decision`
18
+ - Bug fixes, root causes → `bugfix`
19
+ - New feature details → `feature`
20
+ - Learned facts, TILs → `discovery`
21
+ - Setup notes, environment → `context`
22
+ - Everything else → `note`
23
+ 4. Format the entry with a timestamp and type:
24
+ ```markdown
25
+ ### YYYY-MM-DD HH:MM
26
+ <!-- type: decision -->
27
+ <content>
28
+ ```
29
+ 5. If content contains sensitive data (keys, passwords), wrap those parts in `<private>` tags
30
+ 6. Use the Write or Edit tool to update the content as a regular Markdown file
31
+ 7. Confirm what was stored and where
32
+
33
+ ## Response Format
34
+
35
+ After storing, confirm:
36
+ - What was remembered
37
+ - Which file it was stored in
38
+ - The observation type assigned
39
+ - How to find it later (suggest search terms and type filter)
40
+
41
+ Example: "I've stored your architecture decision in today's log (memory/2026-02-14.md) with type 'decision'. Search with `memory_search(query: 'rate limit', type: 'decision')` to find it later."
@@ -0,0 +1,272 @@
1
+ /**
2
+ * Tests for hook scripts config checking behavior.
3
+ *
4
+ * These tests verify that session-start and session-end hooks
5
+ * respect the hooks config (enabled/disabled). They run the actual
6
+ * shell scripts in temp directories with controlled configs.
7
+ *
8
+ * Run with: npx tsx --test claude-plugin/hooks/__tests__/hooks.test.ts
9
+ */
10
+
11
+ import { execSync } from "node:child_process";
12
+ import fs from "node:fs/promises";
13
+ import os from "node:os";
14
+ import path from "node:path";
15
+ import { after, afterEach, beforeEach, describe, it } from "node:test";
16
+ import assert from "node:assert";
17
+
18
+ const HOOKS_DIR = path.resolve(
19
+ import.meta.dirname,
20
+ "..",
21
+ );
22
+
23
+ describe("hook scripts config checks", () => {
24
+ let tempDir: string;
25
+ let originalHome: string;
26
+
27
+ beforeEach(async () => {
28
+ tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-hooks-test-"));
29
+ originalHome = process.env.HOME!;
30
+ // Use a fake HOME so global config doesn't interfere
31
+ process.env.HOME = tempDir;
32
+ });
33
+
34
+ afterEach(async () => {
35
+ process.env.HOME = originalHome;
36
+ await fs.rm(tempDir, { recursive: true, force: true });
37
+ });
38
+
39
+ /**
40
+ * Run a hook script in a given working directory.
41
+ * Returns exit code (0 = success/early-exit, non-zero = error).
42
+ * We pipe empty JSON as stdin since hooks expect input.
43
+ */
44
+ function runHook(
45
+ script: string,
46
+ cwd: string,
47
+ stdinData = "{}",
48
+ ): { exitCode: number; stdout: string; stderr: string } {
49
+ try {
50
+ const stdout = execSync(`echo '${stdinData}' | bash "${script}"`, {
51
+ cwd,
52
+ env: { ...process.env, HOME: tempDir },
53
+ timeout: 10_000,
54
+ encoding: "utf-8",
55
+ stdio: ["pipe", "pipe", "pipe"],
56
+ });
57
+ return { exitCode: 0, stdout: stdout.toString(), stderr: "" };
58
+ } catch (err: unknown) {
59
+ const e = err as { status?: number; stdout?: string; stderr?: string };
60
+ return {
61
+ exitCode: e.status ?? 1,
62
+ stdout: (e.stdout ?? "").toString(),
63
+ stderr: (e.stderr ?? "").toString(),
64
+ };
65
+ }
66
+ }
67
+
68
+ describe("session-start hook", () => {
69
+ const script = path.join(HOOKS_DIR, "session-start.sh");
70
+
71
+ it("should exit early when no .minimem directories exist", () => {
72
+ const result = runHook(script, tempDir);
73
+ assert.strictEqual(result.exitCode, 0);
74
+ assert.strictEqual(result.stdout.trim(), "");
75
+ });
76
+
77
+ it("should exit early when hooks.sessionStart is not set (defaults to false)", async () => {
78
+ // Create local .minimem with config but no hooks setting
79
+ const configDir = path.join(tempDir, ".minimem");
80
+ await fs.mkdir(configDir, { recursive: true });
81
+ await fs.writeFile(
82
+ path.join(configDir, "config.json"),
83
+ JSON.stringify({ embedding: { provider: "auto" } }),
84
+ );
85
+
86
+ const result = runHook(script, tempDir);
87
+ assert.strictEqual(result.exitCode, 0);
88
+ // Should produce no output (exited before search)
89
+ assert.strictEqual(result.stdout.trim(), "");
90
+ });
91
+
92
+ it("should exit early when hooks.sessionStart is false in local config", async () => {
93
+ const configDir = path.join(tempDir, ".minimem");
94
+ await fs.mkdir(configDir, { recursive: true });
95
+ await fs.writeFile(
96
+ path.join(configDir, "config.json"),
97
+ JSON.stringify({ hooks: { sessionStart: false } }),
98
+ );
99
+
100
+ const result = runHook(script, tempDir);
101
+ assert.strictEqual(result.exitCode, 0);
102
+ assert.strictEqual(result.stdout.trim(), "");
103
+ });
104
+
105
+ it("should exit early when hooks.sessionStart is false in global config", async () => {
106
+ // Create global config at $HOME/.minimem/.minimem/config.json
107
+ const globalConfigDir = path.join(tempDir, ".minimem", ".minimem");
108
+ await fs.mkdir(globalConfigDir, { recursive: true });
109
+ await fs.writeFile(
110
+ path.join(globalConfigDir, "config.json"),
111
+ JSON.stringify({ hooks: { sessionStart: false } }),
112
+ );
113
+
114
+ const result = runHook(script, tempDir);
115
+ assert.strictEqual(result.exitCode, 0);
116
+ assert.strictEqual(result.stdout.trim(), "");
117
+ });
118
+
119
+ it("should allow local config to override global config (local true, global false)", async () => {
120
+ // Global: disabled
121
+ const globalConfigDir = path.join(tempDir, ".minimem", ".minimem");
122
+ await fs.mkdir(globalConfigDir, { recursive: true });
123
+ await fs.writeFile(
124
+ path.join(globalConfigDir, "config.json"),
125
+ JSON.stringify({ hooks: { sessionStart: false } }),
126
+ );
127
+
128
+ // Local: enabled — script should proceed past config check
129
+ // (it will fail at npx minimem search, but that's expected)
130
+ const localConfigDir = path.join(tempDir, ".minimem");
131
+ await fs.writeFile(
132
+ path.join(localConfigDir, "config.json"),
133
+ JSON.stringify({ hooks: { sessionStart: true } }),
134
+ );
135
+
136
+ const result = runHook(script, tempDir);
137
+ // Script proceeds past config check. It will exit 0 because
138
+ // the npx search failure is caught with || true
139
+ assert.strictEqual(result.exitCode, 0);
140
+ });
141
+
142
+ it("should allow local config to override global config (local false, global true)", async () => {
143
+ // Global: enabled
144
+ const globalConfigDir = path.join(tempDir, ".minimem", ".minimem");
145
+ await fs.mkdir(globalConfigDir, { recursive: true });
146
+ await fs.writeFile(
147
+ path.join(globalConfigDir, "config.json"),
148
+ JSON.stringify({ hooks: { sessionStart: true } }),
149
+ );
150
+
151
+ // Local: disabled
152
+ const localConfigDir = path.join(tempDir, ".minimem");
153
+ await fs.writeFile(
154
+ path.join(localConfigDir, "config.json"),
155
+ JSON.stringify({ hooks: { sessionStart: false } }),
156
+ );
157
+
158
+ const result = runHook(script, tempDir);
159
+ assert.strictEqual(result.exitCode, 0);
160
+ // Should exit early — no search output
161
+ assert.strictEqual(result.stdout.trim(), "");
162
+ });
163
+ });
164
+
165
+ describe("session-end hook", () => {
166
+ const script = path.join(HOOKS_DIR, "session-end.sh");
167
+
168
+ it("should exit early when no .minimem directories exist", () => {
169
+ const result = runHook(script, tempDir);
170
+ assert.strictEqual(result.exitCode, 0);
171
+ assert.strictEqual(result.stdout.trim(), "");
172
+ });
173
+
174
+ it("should exit early when hooks.sessionEnd is not set (defaults to false)", async () => {
175
+ const configDir = path.join(tempDir, ".minimem");
176
+ await fs.mkdir(configDir, { recursive: true });
177
+ await fs.writeFile(
178
+ path.join(configDir, "config.json"),
179
+ JSON.stringify({ embedding: { provider: "auto" } }),
180
+ );
181
+
182
+ const result = runHook(script, tempDir);
183
+ assert.strictEqual(result.exitCode, 0);
184
+ assert.strictEqual(result.stdout.trim(), "");
185
+ });
186
+
187
+ it("should exit early when hooks.sessionEnd is false in local config", async () => {
188
+ const configDir = path.join(tempDir, ".minimem");
189
+ await fs.mkdir(configDir, { recursive: true });
190
+ await fs.writeFile(
191
+ path.join(configDir, "config.json"),
192
+ JSON.stringify({ hooks: { sessionEnd: false } }),
193
+ );
194
+
195
+ const result = runHook(script, tempDir);
196
+ assert.strictEqual(result.exitCode, 0);
197
+ assert.strictEqual(result.stdout.trim(), "");
198
+ });
199
+
200
+ it("should exit early when hooks.sessionEnd is false in global config", async () => {
201
+ const globalConfigDir = path.join(tempDir, ".minimem", ".minimem");
202
+ await fs.mkdir(globalConfigDir, { recursive: true });
203
+ await fs.writeFile(
204
+ path.join(globalConfigDir, "config.json"),
205
+ JSON.stringify({ hooks: { sessionEnd: false } }),
206
+ );
207
+
208
+ const result = runHook(script, tempDir);
209
+ assert.strictEqual(result.exitCode, 0);
210
+ assert.strictEqual(result.stdout.trim(), "");
211
+ });
212
+
213
+ it("should allow local config to override global config (local true, global false)", async () => {
214
+ // Global: disabled
215
+ const globalConfigDir = path.join(tempDir, ".minimem", ".minimem");
216
+ await fs.mkdir(globalConfigDir, { recursive: true });
217
+ await fs.writeFile(
218
+ path.join(globalConfigDir, "config.json"),
219
+ JSON.stringify({ hooks: { sessionEnd: false } }),
220
+ );
221
+
222
+ // Local: enabled
223
+ const localConfigDir = path.join(tempDir, ".minimem");
224
+ await fs.writeFile(
225
+ path.join(localConfigDir, "config.json"),
226
+ JSON.stringify({ hooks: { sessionEnd: true } }),
227
+ );
228
+
229
+ const result = runHook(script, tempDir);
230
+ // Script proceeds past config check — npx append will fail but is caught
231
+ assert.strictEqual(result.exitCode, 0);
232
+ });
233
+
234
+ it("should allow local config to override global config (local false, global true)", async () => {
235
+ // Global: enabled
236
+ const globalConfigDir = path.join(tempDir, ".minimem", ".minimem");
237
+ await fs.mkdir(globalConfigDir, { recursive: true });
238
+ await fs.writeFile(
239
+ path.join(globalConfigDir, "config.json"),
240
+ JSON.stringify({ hooks: { sessionEnd: true } }),
241
+ );
242
+
243
+ // Local: disabled
244
+ const localConfigDir = path.join(tempDir, ".minimem");
245
+ await fs.writeFile(
246
+ path.join(localConfigDir, "config.json"),
247
+ JSON.stringify({ hooks: { sessionEnd: false } }),
248
+ );
249
+
250
+ const result = runHook(script, tempDir);
251
+ assert.strictEqual(result.exitCode, 0);
252
+ assert.strictEqual(result.stdout.trim(), "");
253
+ });
254
+
255
+ it("should exit early when stop_hook_active is true", async () => {
256
+ const configDir = path.join(tempDir, ".minimem");
257
+ await fs.mkdir(configDir, { recursive: true });
258
+ await fs.writeFile(
259
+ path.join(configDir, "config.json"),
260
+ JSON.stringify({ hooks: { sessionEnd: true } }),
261
+ );
262
+
263
+ const result = runHook(
264
+ script,
265
+ tempDir,
266
+ JSON.stringify({ stop_hook_active: true }),
267
+ );
268
+ assert.strictEqual(result.exitCode, 0);
269
+ assert.strictEqual(result.stdout.trim(), "");
270
+ });
271
+ });
272
+ });
@@ -0,0 +1,27 @@
1
+ {
2
+ "hooks": {
3
+ "SessionStart": [
4
+ {
5
+ "matcher": "startup|resume",
6
+ "hooks": [
7
+ {
8
+ "type": "command",
9
+ "command": "${CLAUDE_PLUGIN_ROOT}/hooks/session-start.sh",
10
+ "timeout": 10
11
+ }
12
+ ]
13
+ }
14
+ ],
15
+ "Stop": [
16
+ {
17
+ "hooks": [
18
+ {
19
+ "type": "command",
20
+ "command": "${CLAUDE_PLUGIN_ROOT}/hooks/session-end.sh",
21
+ "timeout": 15
22
+ }
23
+ ]
24
+ }
25
+ ]
26
+ }
27
+ }
@@ -0,0 +1,86 @@
1
+ #!/bin/bash
2
+ # minimem SessionEnd (Stop) hook
3
+ # Auto-summarizes the session by appending a note to today's daily log.
4
+ # Uses the transcript path to determine what was worked on.
5
+
6
+ set -euo pipefail
7
+
8
+ # Read hook input from stdin
9
+ INPUT=$(cat)
10
+
11
+ # Prevent infinite loops: if stop hook is already active, exit
12
+ STOP_ACTIVE=$(echo "$INPUT" | node -e "
13
+ const d = JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8'));
14
+ console.log(d.stop_hook_active ? 'true' : 'false');
15
+ " 2>/dev/null) || echo "false"
16
+
17
+ if [ "$STOP_ACTIVE" = "true" ]; then
18
+ exit 0
19
+ fi
20
+
21
+ # Only proceed if minimem is initialized (local or global)
22
+ HAS_LOCAL=""
23
+ HAS_GLOBAL=""
24
+ if [ -d ".minimem" ]; then
25
+ HAS_LOCAL="1"
26
+ fi
27
+ if [ -d "$HOME/.minimem" ]; then
28
+ HAS_GLOBAL="1"
29
+ fi
30
+
31
+ if [ -z "$HAS_LOCAL" ] && [ -z "$HAS_GLOBAL" ]; then
32
+ exit 0
33
+ fi
34
+
35
+ # Check config to see if this hook is enabled (defaults to true)
36
+ HOOK_ENABLED=$(node -e "
37
+ const fs = require('fs');
38
+ const path = require('path');
39
+ const configs = [];
40
+ try { configs.push(JSON.parse(fs.readFileSync(path.join(process.env.HOME, '.minimem', '.minimem', 'config.json'), 'utf-8'))); } catch {}
41
+ try { configs.push(JSON.parse(fs.readFileSync('.minimem/config.json', 'utf-8'))); } catch {}
42
+ // Last config wins (local overrides global)
43
+ for (const c of configs.reverse()) {
44
+ if (c.hooks && typeof c.hooks.sessionEnd === 'boolean') {
45
+ console.log(c.hooks.sessionEnd ? 'true' : 'false');
46
+ process.exit(0);
47
+ }
48
+ }
49
+ console.log('false');
50
+ " 2>/dev/null) || echo "false"
51
+
52
+ if [ "$HOOK_ENABLED" = "false" ]; then
53
+ exit 0
54
+ fi
55
+
56
+ # Extract session info from hook input
57
+ SESSION_ID=$(echo "$INPUT" | node -e "
58
+ const d = JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8'));
59
+ console.log(d.session_id || 'unknown');
60
+ " 2>/dev/null) || echo "unknown"
61
+
62
+ CWD=$(echo "$INPUT" | node -e "
63
+ const d = JSON.parse(require('fs').readFileSync('/dev/stdin','utf-8'));
64
+ console.log(d.cwd || process.cwd());
65
+ " 2>/dev/null) || pwd
66
+
67
+ PROJECT_NAME=$(basename "$CWD")
68
+ TIMESTAMP=$(date +"%Y-%m-%d %H:%M")
69
+
70
+ # Build append args
71
+ APPEND_ARGS=("append")
72
+ if [ -n "$HAS_LOCAL" ]; then
73
+ APPEND_ARGS+=("--dir" ".")
74
+ elif [ -n "$HAS_GLOBAL" ]; then
75
+ APPEND_ARGS+=("--global")
76
+ fi
77
+
78
+ # Create a session end marker in memory
79
+ # The content is intentionally brief — Claude Code's transcript has the full details.
80
+ ENTRY="### ${TIMESTAMP} (session: ${SESSION_ID})
81
+ <!-- type: context -->
82
+ Session ended in project: ${PROJECT_NAME} (${CWD})"
83
+
84
+ npx --yes minimem "${APPEND_ARGS[@]}" "$ENTRY" 2>/dev/null || true
85
+
86
+ exit 0