monomind 1.10.0 → 1.10.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 (597) hide show
  1. package/.claude/commands/monomind/understand.md +111 -70
  2. package/.claude/settings.local.json +1 -2
  3. package/package.json +1 -1
  4. package/packages/@monomind/cli/bundled-graph/dist/src/analyze.d.ts +32 -0
  5. package/packages/@monomind/cli/bundled-graph/dist/src/analyze.d.ts.map +1 -0
  6. package/packages/@monomind/cli/bundled-graph/dist/src/analyze.js +297 -0
  7. package/packages/@monomind/cli/bundled-graph/dist/src/analyze.js.map +1 -0
  8. package/packages/@monomind/cli/bundled-graph/dist/src/build.d.ts +8 -0
  9. package/packages/@monomind/cli/bundled-graph/dist/src/build.d.ts.map +1 -0
  10. package/packages/@monomind/cli/bundled-graph/dist/src/build.js +73 -0
  11. package/packages/@monomind/cli/bundled-graph/dist/src/build.js.map +1 -0
  12. package/packages/@monomind/cli/bundled-graph/dist/src/cache.d.ts +12 -0
  13. package/packages/@monomind/cli/bundled-graph/dist/src/cache.d.ts.map +1 -0
  14. package/packages/@monomind/cli/bundled-graph/dist/src/cache.js +43 -0
  15. package/packages/@monomind/cli/bundled-graph/dist/src/cache.js.map +1 -0
  16. package/packages/@monomind/cli/bundled-graph/dist/src/cluster.d.ts +5 -0
  17. package/packages/@monomind/cli/bundled-graph/dist/src/cluster.d.ts.map +1 -0
  18. package/packages/@monomind/cli/bundled-graph/dist/src/cluster.js +120 -0
  19. package/packages/@monomind/cli/bundled-graph/dist/src/cluster.js.map +1 -0
  20. package/packages/@monomind/cli/bundled-graph/dist/src/detect.d.ts +21 -0
  21. package/packages/@monomind/cli/bundled-graph/dist/src/detect.d.ts.map +1 -0
  22. package/packages/@monomind/cli/bundled-graph/dist/src/detect.js +195 -0
  23. package/packages/@monomind/cli/bundled-graph/dist/src/detect.js.map +1 -0
  24. package/packages/@monomind/cli/bundled-graph/dist/src/export.d.ts +21 -0
  25. package/packages/@monomind/cli/bundled-graph/dist/src/export.d.ts.map +1 -0
  26. package/packages/@monomind/cli/bundled-graph/dist/src/export.js +68 -0
  27. package/packages/@monomind/cli/bundled-graph/dist/src/export.js.map +1 -0
  28. package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.d.ts +20 -0
  29. package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.d.ts.map +1 -0
  30. package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.js +158 -0
  31. package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.js.map +1 -0
  32. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.d.ts +3 -0
  33. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.d.ts.map +1 -0
  34. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.js +88 -0
  35. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.js.map +1 -0
  36. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.d.ts +3 -0
  37. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.d.ts.map +1 -0
  38. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.js +121 -0
  39. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.js.map +1 -0
  40. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.d.ts +3 -0
  41. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.d.ts.map +1 -0
  42. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.js +121 -0
  43. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.js.map +1 -0
  44. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.d.ts +3 -0
  45. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.d.ts.map +1 -0
  46. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.js +181 -0
  47. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.js.map +1 -0
  48. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.d.ts +3 -0
  49. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.d.ts.map +1 -0
  50. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.js +117 -0
  51. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.js.map +1 -0
  52. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.d.ts +3 -0
  53. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.d.ts.map +1 -0
  54. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.js +112 -0
  55. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.js.map +1 -0
  56. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.d.ts +3 -0
  57. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.d.ts.map +1 -0
  58. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.js +130 -0
  59. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.js.map +1 -0
  60. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.d.ts +3 -0
  61. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.d.ts.map +1 -0
  62. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.js +230 -0
  63. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.js.map +1 -0
  64. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.d.ts +3 -0
  65. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.d.ts.map +1 -0
  66. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.js +120 -0
  67. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.js.map +1 -0
  68. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.d.ts +3 -0
  69. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.d.ts.map +1 -0
  70. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.js +195 -0
  71. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.js.map +1 -0
  72. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.d.ts +3 -0
  73. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.d.ts.map +1 -0
  74. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.js +110 -0
  75. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.js.map +1 -0
  76. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.d.ts +3 -0
  77. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.d.ts.map +1 -0
  78. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.js +122 -0
  79. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.js.map +1 -0
  80. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.d.ts +3 -0
  81. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.d.ts.map +1 -0
  82. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.js +295 -0
  83. package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.js.map +1 -0
  84. package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.d.ts +38 -0
  85. package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.d.ts.map +1 -0
  86. package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.js +242 -0
  87. package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.js.map +1 -0
  88. package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.d.ts +48 -0
  89. package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.d.ts.map +1 -0
  90. package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.js +137 -0
  91. package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.js.map +1 -0
  92. package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.d.ts +7 -0
  93. package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.d.ts.map +1 -0
  94. package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.js +2 -0
  95. package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.js.map +1 -0
  96. package/packages/@monomind/cli/bundled-graph/dist/src/index.d.ts +28 -0
  97. package/packages/@monomind/cli/bundled-graph/dist/src/index.d.ts.map +1 -0
  98. package/packages/@monomind/cli/bundled-graph/dist/src/index.js +26 -0
  99. package/packages/@monomind/cli/bundled-graph/dist/src/index.js.map +1 -0
  100. package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.d.ts +27 -0
  101. package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.d.ts.map +1 -0
  102. package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.js +269 -0
  103. package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.js.map +1 -0
  104. package/packages/@monomind/cli/bundled-graph/dist/src/report.d.ts +26 -0
  105. package/packages/@monomind/cli/bundled-graph/dist/src/report.d.ts.map +1 -0
  106. package/packages/@monomind/cli/bundled-graph/dist/src/report.js +214 -0
  107. package/packages/@monomind/cli/bundled-graph/dist/src/report.js.map +1 -0
  108. package/packages/@monomind/cli/bundled-graph/dist/src/types.d.ts +124 -0
  109. package/packages/@monomind/cli/bundled-graph/dist/src/types.d.ts.map +1 -0
  110. package/packages/@monomind/cli/bundled-graph/dist/src/types.js +2 -0
  111. package/packages/@monomind/cli/bundled-graph/dist/src/types.js.map +1 -0
  112. package/packages/@monomind/cli/bundled-graph/dist/src/visualize.d.ts +4 -0
  113. package/packages/@monomind/cli/bundled-graph/dist/src/visualize.d.ts.map +1 -0
  114. package/packages/@monomind/cli/bundled-graph/dist/src/visualize.js +574 -0
  115. package/packages/@monomind/cli/bundled-graph/dist/src/visualize.js.map +1 -0
  116. package/packages/@monomind/cli/dist/src/agents/halt-signal.d.ts +25 -0
  117. package/packages/@monomind/cli/dist/src/agents/halt-signal.js +76 -0
  118. package/packages/@monomind/cli/dist/src/agents/index.d.ts +18 -0
  119. package/packages/@monomind/cli/dist/src/agents/index.js +13 -0
  120. package/packages/@monomind/cli/dist/src/agents/managed-agent.d.ts +41 -0
  121. package/packages/@monomind/cli/dist/src/agents/managed-agent.js +69 -0
  122. package/packages/@monomind/cli/dist/src/agents/prompt-experiment.d.ts +23 -0
  123. package/packages/@monomind/cli/dist/src/agents/prompt-experiment.js +49 -0
  124. package/packages/@monomind/cli/dist/src/agents/prompt-version-manager.d.ts +22 -0
  125. package/packages/@monomind/cli/dist/src/agents/prompt-version-manager.js +80 -0
  126. package/packages/@monomind/cli/dist/src/agents/registry-builder.d.ts +36 -0
  127. package/packages/@monomind/cli/dist/src/agents/registry-builder.js +200 -0
  128. package/packages/@monomind/cli/dist/src/agents/registry-query.d.ts +71 -0
  129. package/packages/@monomind/cli/dist/src/agents/registry-query.js +125 -0
  130. package/packages/@monomind/cli/dist/src/agents/score-decay.d.ts +19 -0
  131. package/packages/@monomind/cli/dist/src/agents/score-decay.js +22 -0
  132. package/packages/@monomind/cli/dist/src/agents/shared-instructions-loader.d.ts +13 -0
  133. package/packages/@monomind/cli/dist/src/agents/shared-instructions-loader.js +40 -0
  134. package/packages/@monomind/cli/dist/src/agents/specialization-scorer.d.ts +54 -0
  135. package/packages/@monomind/cli/dist/src/agents/specialization-scorer.js +212 -0
  136. package/packages/@monomind/cli/dist/src/agents/termination-watcher.d.ts +30 -0
  137. package/packages/@monomind/cli/dist/src/agents/termination-watcher.js +84 -0
  138. package/packages/@monomind/cli/dist/src/agents/trigger-index.d.ts +20 -0
  139. package/packages/@monomind/cli/dist/src/agents/trigger-index.js +38 -0
  140. package/packages/@monomind/cli/dist/src/agents/trigger-scanner.d.ts +64 -0
  141. package/packages/@monomind/cli/dist/src/agents/trigger-scanner.js +308 -0
  142. package/packages/@monomind/cli/dist/src/agents/version-diff.d.ts +18 -0
  143. package/packages/@monomind/cli/dist/src/agents/version-diff.js +64 -0
  144. package/packages/@monomind/cli/dist/src/agents/version-store.d.ts +60 -0
  145. package/packages/@monomind/cli/dist/src/agents/version-store.js +235 -0
  146. package/packages/@monomind/cli/dist/src/autopilot-state.d.ts +77 -0
  147. package/packages/@monomind/cli/dist/src/autopilot-state.js +330 -0
  148. package/packages/@monomind/cli/dist/src/benchmarks/benchmark-runner.d.ts +87 -0
  149. package/packages/@monomind/cli/dist/src/benchmarks/benchmark-runner.js +273 -0
  150. package/packages/@monomind/cli/dist/src/benchmarks/metric-evaluators.d.ts +36 -0
  151. package/packages/@monomind/cli/dist/src/benchmarks/metric-evaluators.js +114 -0
  152. package/packages/@monomind/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
  153. package/packages/@monomind/cli/dist/src/benchmarks/pretrain/index.js +404 -0
  154. package/packages/@monomind/cli/dist/src/commands/agent-wasm.d.ts +14 -0
  155. package/packages/@monomind/cli/dist/src/commands/agent-wasm.js +333 -0
  156. package/packages/@monomind/cli/dist/src/commands/agent.d.ts +8 -0
  157. package/packages/@monomind/cli/dist/src/commands/agent.js +943 -0
  158. package/packages/@monomind/cli/dist/src/commands/analyze.d.ts +19 -0
  159. package/packages/@monomind/cli/dist/src/commands/analyze.js +2048 -0
  160. package/packages/@monomind/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
  161. package/packages/@monomind/cli/dist/src/commands/appliance-advanced.js +238 -0
  162. package/packages/@monomind/cli/dist/src/commands/appliance.d.ts +8 -0
  163. package/packages/@monomind/cli/dist/src/commands/appliance.js +406 -0
  164. package/packages/@monomind/cli/dist/src/commands/autopilot.d.ts +15 -0
  165. package/packages/@monomind/cli/dist/src/commands/autopilot.js +362 -0
  166. package/packages/@monomind/cli/dist/src/commands/benchmark.d.ts +10 -0
  167. package/packages/@monomind/cli/dist/src/commands/benchmark.js +571 -0
  168. package/packages/@monomind/cli/dist/src/commands/claims.d.ts +10 -0
  169. package/packages/@monomind/cli/dist/src/commands/claims.js +632 -0
  170. package/packages/@monomind/cli/dist/src/commands/cleanup.d.ts +13 -0
  171. package/packages/@monomind/cli/dist/src/commands/cleanup.js +218 -0
  172. package/packages/@monomind/cli/dist/src/commands/completions.d.ts +10 -0
  173. package/packages/@monomind/cli/dist/src/commands/completions.js +539 -0
  174. package/packages/@monomind/cli/dist/src/commands/config.d.ts +8 -0
  175. package/packages/@monomind/cli/dist/src/commands/config.js +460 -0
  176. package/packages/@monomind/cli/dist/src/commands/daemon.d.ts +8 -0
  177. package/packages/@monomind/cli/dist/src/commands/daemon.js +671 -0
  178. package/packages/@monomind/cli/dist/src/commands/deployment.d.ts +10 -0
  179. package/packages/@monomind/cli/dist/src/commands/deployment.js +691 -0
  180. package/packages/@monomind/cli/dist/src/commands/doctor.d.ts +10 -0
  181. package/packages/@monomind/cli/dist/src/commands/doctor.js +647 -0
  182. package/packages/@monomind/cli/dist/src/commands/embeddings.d.ts +18 -0
  183. package/packages/@monomind/cli/dist/src/commands/embeddings.js +1652 -0
  184. package/packages/@monomind/cli/dist/src/commands/guidance.d.ts +8 -0
  185. package/packages/@monomind/cli/dist/src/commands/guidance.js +560 -0
  186. package/packages/@monomind/cli/dist/src/commands/hive-mind.d.ts +11 -0
  187. package/packages/@monomind/cli/dist/src/commands/hive-mind.js +1238 -0
  188. package/packages/@monomind/cli/dist/src/commands/hooks.d.ts +8 -0
  189. package/packages/@monomind/cli/dist/src/commands/hooks.js +4446 -0
  190. package/packages/@monomind/cli/dist/src/commands/index.d.ts +119 -0
  191. package/packages/@monomind/cli/dist/src/commands/index.js +404 -0
  192. package/packages/@monomind/cli/dist/src/commands/init.d.ts +8 -0
  193. package/packages/@monomind/cli/dist/src/commands/init.js +853 -0
  194. package/packages/@monomind/cli/dist/src/commands/issues.d.ts +21 -0
  195. package/packages/@monomind/cli/dist/src/commands/issues.js +567 -0
  196. package/packages/@monomind/cli/dist/src/commands/mcp.d.ts +11 -0
  197. package/packages/@monomind/cli/dist/src/commands/mcp.js +705 -0
  198. package/packages/@monomind/cli/dist/src/commands/memory.d.ts +8 -0
  199. package/packages/@monomind/cli/dist/src/commands/memory.js +1596 -0
  200. package/packages/@monomind/cli/dist/src/commands/migrate.d.ts +8 -0
  201. package/packages/@monomind/cli/dist/src/commands/migrate.js +790 -0
  202. package/packages/@monomind/cli/dist/src/commands/monograph.d.ts +8 -0
  203. package/packages/@monomind/cli/dist/src/commands/monograph.js +526 -0
  204. package/packages/@monomind/cli/dist/src/commands/neural.d.ts +10 -0
  205. package/packages/@monomind/cli/dist/src/commands/neural.js +1494 -0
  206. package/packages/@monomind/cli/dist/src/commands/performance.d.ts +10 -0
  207. package/packages/@monomind/cli/dist/src/commands/performance.js +601 -0
  208. package/packages/@monomind/cli/dist/src/commands/plugins.d.ts +11 -0
  209. package/packages/@monomind/cli/dist/src/commands/plugins.js +796 -0
  210. package/packages/@monomind/cli/dist/src/commands/process.d.ts +10 -0
  211. package/packages/@monomind/cli/dist/src/commands/process.js +718 -0
  212. package/packages/@monomind/cli/dist/src/commands/progress.d.ts +11 -0
  213. package/packages/@monomind/cli/dist/src/commands/progress.js +259 -0
  214. package/packages/@monomind/cli/dist/src/commands/providers.d.ts +10 -0
  215. package/packages/@monomind/cli/dist/src/commands/providers.js +391 -0
  216. package/packages/@monomind/cli/dist/src/commands/replay.d.ts +8 -0
  217. package/packages/@monomind/cli/dist/src/commands/replay.js +60 -0
  218. package/packages/@monomind/cli/dist/src/commands/route.d.ts +16 -0
  219. package/packages/@monomind/cli/dist/src/commands/route.js +939 -0
  220. package/packages/@monomind/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
  221. package/packages/@monomind/cli/dist/src/commands/ruvector/backup.js +746 -0
  222. package/packages/@monomind/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
  223. package/packages/@monomind/cli/dist/src/commands/ruvector/benchmark.js +489 -0
  224. package/packages/@monomind/cli/dist/src/commands/ruvector/import.d.ts +18 -0
  225. package/packages/@monomind/cli/dist/src/commands/ruvector/import.js +359 -0
  226. package/packages/@monomind/cli/dist/src/commands/ruvector/index.d.ts +29 -0
  227. package/packages/@monomind/cli/dist/src/commands/ruvector/index.js +129 -0
  228. package/packages/@monomind/cli/dist/src/commands/ruvector/init.d.ts +11 -0
  229. package/packages/@monomind/cli/dist/src/commands/ruvector/init.js +481 -0
  230. package/packages/@monomind/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
  231. package/packages/@monomind/cli/dist/src/commands/ruvector/migrate.js +497 -0
  232. package/packages/@monomind/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
  233. package/packages/@monomind/cli/dist/src/commands/ruvector/optimize.js +504 -0
  234. package/packages/@monomind/cli/dist/src/commands/ruvector/setup.d.ts +18 -0
  235. package/packages/@monomind/cli/dist/src/commands/ruvector/setup.js +765 -0
  236. package/packages/@monomind/cli/dist/src/commands/ruvector/status.d.ts +11 -0
  237. package/packages/@monomind/cli/dist/src/commands/ruvector/status.js +491 -0
  238. package/packages/@monomind/cli/dist/src/commands/security.d.ts +10 -0
  239. package/packages/@monomind/cli/dist/src/commands/security.js +943 -0
  240. package/packages/@monomind/cli/dist/src/commands/session.d.ts +8 -0
  241. package/packages/@monomind/cli/dist/src/commands/session.js +793 -0
  242. package/packages/@monomind/cli/dist/src/commands/start.d.ts +8 -0
  243. package/packages/@monomind/cli/dist/src/commands/start.js +432 -0
  244. package/packages/@monomind/cli/dist/src/commands/status.d.ts +8 -0
  245. package/packages/@monomind/cli/dist/src/commands/status.js +591 -0
  246. package/packages/@monomind/cli/dist/src/commands/swarm.d.ts +8 -0
  247. package/packages/@monomind/cli/dist/src/commands/swarm.js +812 -0
  248. package/packages/@monomind/cli/dist/src/commands/task.d.ts +8 -0
  249. package/packages/@monomind/cli/dist/src/commands/task.js +671 -0
  250. package/packages/@monomind/cli/dist/src/commands/tokens.d.ts +8 -0
  251. package/packages/@monomind/cli/dist/src/commands/tokens.js +107 -0
  252. package/packages/@monomind/cli/dist/src/commands/transfer-store.d.ts +13 -0
  253. package/packages/@monomind/cli/dist/src/commands/transfer-store.js +428 -0
  254. package/packages/@monomind/cli/dist/src/commands/ui.js +68 -0
  255. package/packages/@monomind/cli/dist/src/commands/update.d.ts +8 -0
  256. package/packages/@monomind/cli/dist/src/commands/update.js +276 -0
  257. package/packages/@monomind/cli/dist/src/commands/workflow.d.ts +8 -0
  258. package/packages/@monomind/cli/dist/src/commands/workflow.js +644 -0
  259. package/packages/@monomind/cli/dist/src/config-adapter.d.ts +16 -0
  260. package/packages/@monomind/cli/dist/src/config-adapter.js +186 -0
  261. package/packages/@monomind/cli/dist/src/consensus/audit-writer.d.ts +50 -0
  262. package/packages/@monomind/cli/dist/src/consensus/audit-writer.js +142 -0
  263. package/packages/@monomind/cli/dist/src/consensus/index.d.ts +7 -0
  264. package/packages/@monomind/cli/dist/src/consensus/index.js +6 -0
  265. package/packages/@monomind/cli/dist/src/consensus/vote-signer.d.ts +36 -0
  266. package/packages/@monomind/cli/dist/src/consensus/vote-signer.js +71 -0
  267. package/packages/@monomind/cli/dist/src/context/context-provider.d.ts +44 -0
  268. package/packages/@monomind/cli/dist/src/context/context-provider.js +25 -0
  269. package/packages/@monomind/cli/dist/src/context/git-state-provider.d.ts +12 -0
  270. package/packages/@monomind/cli/dist/src/context/git-state-provider.js +34 -0
  271. package/packages/@monomind/cli/dist/src/context/index.d.ts +12 -0
  272. package/packages/@monomind/cli/dist/src/context/index.js +12 -0
  273. package/packages/@monomind/cli/dist/src/context/project-conventions-provider.d.ts +15 -0
  274. package/packages/@monomind/cli/dist/src/context/project-conventions-provider.js +19 -0
  275. package/packages/@monomind/cli/dist/src/context/prompt-assembler.d.ts +26 -0
  276. package/packages/@monomind/cli/dist/src/context/prompt-assembler.js +93 -0
  277. package/packages/@monomind/cli/dist/src/context/task-history-provider.d.ts +24 -0
  278. package/packages/@monomind/cli/dist/src/context/task-history-provider.js +32 -0
  279. package/packages/@monomind/cli/dist/src/context/user-preferences-provider.d.ts +14 -0
  280. package/packages/@monomind/cli/dist/src/context/user-preferences-provider.js +27 -0
  281. package/packages/@monomind/cli/dist/src/dlq/dlq-reader.d.ts +31 -0
  282. package/packages/@monomind/cli/dist/src/dlq/dlq-reader.js +81 -0
  283. package/packages/@monomind/cli/dist/src/dlq/dlq-replayer.d.ts +27 -0
  284. package/packages/@monomind/cli/dist/src/dlq/dlq-replayer.js +90 -0
  285. package/packages/@monomind/cli/dist/src/dlq/dlq-writer.d.ts +24 -0
  286. package/packages/@monomind/cli/dist/src/dlq/dlq-writer.js +65 -0
  287. package/packages/@monomind/cli/dist/src/dlq/index.d.ts +10 -0
  288. package/packages/@monomind/cli/dist/src/dlq/index.js +7 -0
  289. package/packages/@monomind/cli/dist/src/eval/dataset-manager.d.ts +33 -0
  290. package/packages/@monomind/cli/dist/src/eval/dataset-manager.js +107 -0
  291. package/packages/@monomind/cli/dist/src/eval/dataset-runner.d.ts +23 -0
  292. package/packages/@monomind/cli/dist/src/eval/dataset-runner.js +59 -0
  293. package/packages/@monomind/cli/dist/src/eval/index.d.ts +10 -0
  294. package/packages/@monomind/cli/dist/src/eval/index.js +7 -0
  295. package/packages/@monomind/cli/dist/src/eval/trace-collector.d.ts +40 -0
  296. package/packages/@monomind/cli/dist/src/eval/trace-collector.js +102 -0
  297. package/packages/@monomind/cli/dist/src/index.d.ts +82 -0
  298. package/packages/@monomind/cli/dist/src/index.js +580 -0
  299. package/packages/@monomind/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
  300. package/packages/@monomind/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
  301. package/packages/@monomind/cli/dist/src/init/claudemd-generator.d.ts +25 -0
  302. package/packages/@monomind/cli/dist/src/init/claudemd-generator.js +558 -0
  303. package/packages/@monomind/cli/dist/src/init/executor.d.ts +38 -0
  304. package/packages/@monomind/cli/dist/src/init/executor.js +2172 -0
  305. package/packages/@monomind/cli/dist/src/init/helpers-generator.d.ts +60 -0
  306. package/packages/@monomind/cli/dist/src/init/helpers-generator.js +1235 -0
  307. package/packages/@monomind/cli/dist/src/init/index.d.ts +13 -0
  308. package/packages/@monomind/cli/dist/src/init/index.js +15 -0
  309. package/packages/@monomind/cli/dist/src/init/mcp-generator.d.ts +26 -0
  310. package/packages/@monomind/cli/dist/src/init/mcp-generator.js +99 -0
  311. package/packages/@monomind/cli/dist/src/init/settings-generator.d.ts +14 -0
  312. package/packages/@monomind/cli/dist/src/init/settings-generator.js +417 -0
  313. package/packages/@monomind/cli/dist/src/init/shared-instructions-generator.d.ts +38 -0
  314. package/packages/@monomind/cli/dist/src/init/shared-instructions-generator.js +586 -0
  315. package/packages/@monomind/cli/dist/src/init/statusline-generator.d.ts +25 -0
  316. package/packages/@monomind/cli/dist/src/init/statusline-generator.js +1171 -0
  317. package/packages/@monomind/cli/dist/src/init/types.d.ts +315 -0
  318. package/packages/@monomind/cli/dist/src/init/types.js +254 -0
  319. package/packages/@monomind/cli/dist/src/interactive/interrupt.d.ts +22 -0
  320. package/packages/@monomind/cli/dist/src/interactive/interrupt.js +71 -0
  321. package/packages/@monomind/cli/dist/src/mcp/deprecation-injector.d.ts +25 -0
  322. package/packages/@monomind/cli/dist/src/mcp/deprecation-injector.js +48 -0
  323. package/packages/@monomind/cli/dist/src/mcp/tool-registry.d.ts +61 -0
  324. package/packages/@monomind/cli/dist/src/mcp/tool-registry.js +246 -0
  325. package/packages/@monomind/cli/dist/src/mcp-client.d.ts +92 -0
  326. package/packages/@monomind/cli/dist/src/mcp-client.js +270 -0
  327. package/packages/@monomind/cli/dist/src/mcp-server.d.ts +170 -0
  328. package/packages/@monomind/cli/dist/src/mcp-server.js +829 -0
  329. package/packages/@monomind/cli/dist/src/mcp-tools/a2a-tools.d.ts +14 -0
  330. package/packages/@monomind/cli/dist/src/mcp-tools/a2a-tools.js +244 -0
  331. package/packages/@monomind/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
  332. package/packages/@monomind/cli/dist/src/mcp-tools/agent-tools.js +607 -0
  333. package/packages/@monomind/cli/dist/src/mcp-tools/agentdb-tools.d.ts +30 -0
  334. package/packages/@monomind/cli/dist/src/mcp-tools/agentdb-tools.js +596 -0
  335. package/packages/@monomind/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
  336. package/packages/@monomind/cli/dist/src/mcp-tools/analyze-tools.js +326 -0
  337. package/packages/@monomind/cli/dist/src/mcp-tools/auto-install.d.ts +83 -0
  338. package/packages/@monomind/cli/dist/src/mcp-tools/auto-install.js +129 -0
  339. package/packages/@monomind/cli/dist/src/mcp-tools/autopilot-tools.d.ts +12 -0
  340. package/packages/@monomind/cli/dist/src/mcp-tools/autopilot-tools.js +237 -0
  341. package/packages/@monomind/cli/dist/src/mcp-tools/browser-tools.d.ts +13 -0
  342. package/packages/@monomind/cli/dist/src/mcp-tools/browser-tools.js +729 -0
  343. package/packages/@monomind/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
  344. package/packages/@monomind/cli/dist/src/mcp-tools/claims-tools.js +797 -0
  345. package/packages/@monomind/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
  346. package/packages/@monomind/cli/dist/src/mcp-tools/config-tools.js +381 -0
  347. package/packages/@monomind/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
  348. package/packages/@monomind/cli/dist/src/mcp-tools/coordination-tools.js +728 -0
  349. package/packages/@monomind/cli/dist/src/mcp-tools/daa-tools.d.ts +13 -0
  350. package/packages/@monomind/cli/dist/src/mcp-tools/daa-tools.js +509 -0
  351. package/packages/@monomind/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
  352. package/packages/@monomind/cli/dist/src/mcp-tools/embeddings-tools.js +823 -0
  353. package/packages/@monomind/cli/dist/src/mcp-tools/github-tools.d.ts +9 -0
  354. package/packages/@monomind/cli/dist/src/mcp-tools/github-tools.js +485 -0
  355. package/packages/@monomind/cli/dist/src/mcp-tools/graphify-tools.d.ts +10 -0
  356. package/packages/@monomind/cli/dist/src/mcp-tools/graphify-tools.js +49 -0
  357. package/packages/@monomind/cli/dist/src/mcp-tools/guidance-tools.d.ts +15 -0
  358. package/packages/@monomind/cli/dist/src/mcp-tools/guidance-tools.js +646 -0
  359. package/packages/@monomind/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
  360. package/packages/@monomind/cli/dist/src/mcp-tools/hive-mind-tools.js +957 -0
  361. package/packages/@monomind/cli/dist/src/mcp-tools/hooks-tools.d.ts +44 -0
  362. package/packages/@monomind/cli/dist/src/mcp-tools/hooks-tools.js +3440 -0
  363. package/packages/@monomind/cli/dist/src/mcp-tools/index.d.ts +39 -0
  364. package/packages/@monomind/cli/dist/src/mcp-tools/index.js +41 -0
  365. package/packages/@monomind/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
  366. package/packages/@monomind/cli/dist/src/mcp-tools/memory-tools.js +530 -0
  367. package/packages/@monomind/cli/dist/src/mcp-tools/monograph-tools.d.ts +9 -0
  368. package/packages/@monomind/cli/dist/src/mcp-tools/monograph-tools.js +6306 -0
  369. package/packages/@monomind/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
  370. package/packages/@monomind/cli/dist/src/mcp-tools/neural-tools.js +718 -0
  371. package/packages/@monomind/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
  372. package/packages/@monomind/cli/dist/src/mcp-tools/performance-tools.js +656 -0
  373. package/packages/@monomind/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
  374. package/packages/@monomind/cli/dist/src/mcp-tools/progress-tools.js +350 -0
  375. package/packages/@monomind/cli/dist/src/mcp-tools/request-tracker.d.ts +17 -0
  376. package/packages/@monomind/cli/dist/src/mcp-tools/request-tracker.js +30 -0
  377. package/packages/@monomind/cli/dist/src/mcp-tools/ruvllm-tools.d.ts +9 -0
  378. package/packages/@monomind/cli/dist/src/mcp-tools/ruvllm-tools.js +295 -0
  379. package/packages/@monomind/cli/dist/src/mcp-tools/security-tools.d.ts +18 -0
  380. package/packages/@monomind/cli/dist/src/mcp-tools/security-tools.js +434 -0
  381. package/packages/@monomind/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
  382. package/packages/@monomind/cli/dist/src/mcp-tools/session-tools.js +378 -0
  383. package/packages/@monomind/cli/dist/src/mcp-tools/swarm-tools.d.ts +9 -0
  384. package/packages/@monomind/cli/dist/src/mcp-tools/swarm-tools.js +317 -0
  385. package/packages/@monomind/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
  386. package/packages/@monomind/cli/dist/src/mcp-tools/system-tools.js +552 -0
  387. package/packages/@monomind/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
  388. package/packages/@monomind/cli/dist/src/mcp-tools/task-tools.js +446 -0
  389. package/packages/@monomind/cli/dist/src/mcp-tools/terminal-tools.d.ts +8 -0
  390. package/packages/@monomind/cli/dist/src/mcp-tools/terminal-tools.js +309 -0
  391. package/packages/@monomind/cli/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
  392. package/packages/@monomind/cli/dist/src/mcp-tools/transfer-tools.js +401 -0
  393. package/packages/@monomind/cli/dist/src/mcp-tools/types.d.ts +37 -0
  394. package/packages/@monomind/cli/dist/src/mcp-tools/types.js +14 -0
  395. package/packages/@monomind/cli/dist/src/mcp-tools/wasm-agent-tools.d.ts +9 -0
  396. package/packages/@monomind/cli/dist/src/mcp-tools/wasm-agent-tools.js +230 -0
  397. package/packages/@monomind/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
  398. package/packages/@monomind/cli/dist/src/mcp-tools/workflow-tools.js +631 -0
  399. package/packages/@monomind/cli/dist/src/memory/ewc-consolidation.d.ts +295 -0
  400. package/packages/@monomind/cli/dist/src/memory/ewc-consolidation.js +632 -0
  401. package/packages/@monomind/cli/dist/src/memory/intelligence.d.ts +338 -0
  402. package/packages/@monomind/cli/dist/src/memory/intelligence.js +1049 -0
  403. package/packages/@monomind/cli/dist/src/memory/memory-bridge.d.ts +410 -0
  404. package/packages/@monomind/cli/dist/src/memory/memory-bridge.js +1654 -0
  405. package/packages/@monomind/cli/dist/src/memory/memory-initializer.d.ts +414 -0
  406. package/packages/@monomind/cli/dist/src/memory/memory-initializer.js +2284 -0
  407. package/packages/@monomind/cli/dist/src/memory/sona-optimizer.d.ts +234 -0
  408. package/packages/@monomind/cli/dist/src/memory/sona-optimizer.js +650 -0
  409. package/packages/@monomind/cli/dist/src/model/complexity-scorer.d.ts +21 -0
  410. package/packages/@monomind/cli/dist/src/model/complexity-scorer.js +106 -0
  411. package/packages/@monomind/cli/dist/src/model/index.d.ts +4 -0
  412. package/packages/@monomind/cli/dist/src/model/index.js +4 -0
  413. package/packages/@monomind/cli/dist/src/model/model-settings.d.ts +22 -0
  414. package/packages/@monomind/cli/dist/src/model/model-settings.js +33 -0
  415. package/packages/@monomind/cli/dist/src/model/model-tier-resolver.d.ts +24 -0
  416. package/packages/@monomind/cli/dist/src/model/model-tier-resolver.js +65 -0
  417. package/packages/@monomind/cli/dist/src/observability/replay-reader.d.ts +40 -0
  418. package/packages/@monomind/cli/dist/src/observability/replay-reader.js +138 -0
  419. package/packages/@monomind/cli/dist/src/orchestration/index.d.ts +7 -0
  420. package/packages/@monomind/cli/dist/src/orchestration/index.js +6 -0
  421. package/packages/@monomind/cli/dist/src/orchestration/mode-dispatcher.d.ts +11 -0
  422. package/packages/@monomind/cli/dist/src/orchestration/mode-dispatcher.js +31 -0
  423. package/packages/@monomind/cli/dist/src/orchestration/routing-modes.d.ts +68 -0
  424. package/packages/@monomind/cli/dist/src/orchestration/routing-modes.js +180 -0
  425. package/packages/@monomind/cli/dist/src/output.d.ts +133 -0
  426. package/packages/@monomind/cli/dist/src/output.js +514 -0
  427. package/packages/@monomind/cli/dist/src/parser.d.ts +59 -0
  428. package/packages/@monomind/cli/dist/src/parser.js +459 -0
  429. package/packages/@monomind/cli/dist/src/plugins/manager.d.ts +133 -0
  430. package/packages/@monomind/cli/dist/src/plugins/manager.js +493 -0
  431. package/packages/@monomind/cli/dist/src/plugins/store/discovery.d.ts +88 -0
  432. package/packages/@monomind/cli/dist/src/plugins/store/discovery.js +859 -0
  433. package/packages/@monomind/cli/dist/src/plugins/store/index.d.ts +76 -0
  434. package/packages/@monomind/cli/dist/src/plugins/store/index.js +141 -0
  435. package/packages/@monomind/cli/dist/src/plugins/store/search.d.ts +46 -0
  436. package/packages/@monomind/cli/dist/src/plugins/store/search.js +230 -0
  437. package/packages/@monomind/cli/dist/src/plugins/store/types.d.ts +274 -0
  438. package/packages/@monomind/cli/dist/src/plugins/store/types.js +7 -0
  439. package/packages/@monomind/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
  440. package/packages/@monomind/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
  441. package/packages/@monomind/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
  442. package/packages/@monomind/cli/dist/src/plugins/tests/standalone-test.js +188 -0
  443. package/packages/@monomind/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
  444. package/packages/@monomind/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
  445. package/packages/@monomind/cli/dist/src/production/circuit-breaker.d.ts +101 -0
  446. package/packages/@monomind/cli/dist/src/production/circuit-breaker.js +248 -0
  447. package/packages/@monomind/cli/dist/src/production/error-handler.d.ts +94 -0
  448. package/packages/@monomind/cli/dist/src/production/error-handler.js +321 -0
  449. package/packages/@monomind/cli/dist/src/production/index.d.ts +23 -0
  450. package/packages/@monomind/cli/dist/src/production/index.js +18 -0
  451. package/packages/@monomind/cli/dist/src/production/monitoring.d.ts +161 -0
  452. package/packages/@monomind/cli/dist/src/production/monitoring.js +360 -0
  453. package/packages/@monomind/cli/dist/src/production/rate-limiter.d.ts +80 -0
  454. package/packages/@monomind/cli/dist/src/production/rate-limiter.js +209 -0
  455. package/packages/@monomind/cli/dist/src/production/retry.d.ts +48 -0
  456. package/packages/@monomind/cli/dist/src/production/retry.js +179 -0
  457. package/packages/@monomind/cli/dist/src/prompt.d.ts +44 -0
  458. package/packages/@monomind/cli/dist/src/prompt.js +501 -0
  459. package/packages/@monomind/cli/dist/src/runtime/headless.d.ts +60 -0
  460. package/packages/@monomind/cli/dist/src/runtime/headless.js +284 -0
  461. package/packages/@monomind/cli/dist/src/ruvector/agent-wasm.d.ts +182 -0
  462. package/packages/@monomind/cli/dist/src/ruvector/agent-wasm.js +316 -0
  463. package/packages/@monomind/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
  464. package/packages/@monomind/cli/dist/src/ruvector/ast-analyzer.js +277 -0
  465. package/packages/@monomind/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
  466. package/packages/@monomind/cli/dist/src/ruvector/coverage-router.js +539 -0
  467. package/packages/@monomind/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
  468. package/packages/@monomind/cli/dist/src/ruvector/coverage-tools.js +157 -0
  469. package/packages/@monomind/cli/dist/src/ruvector/diff-classifier.d.ts +176 -0
  470. package/packages/@monomind/cli/dist/src/ruvector/diff-classifier.js +718 -0
  471. package/packages/@monomind/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
  472. package/packages/@monomind/cli/dist/src/ruvector/enhanced-model-router.js +551 -0
  473. package/packages/@monomind/cli/dist/src/ruvector/flash-attention.d.ts +195 -0
  474. package/packages/@monomind/cli/dist/src/ruvector/flash-attention.js +643 -0
  475. package/packages/@monomind/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
  476. package/packages/@monomind/cli/dist/src/ruvector/graph-analyzer.js +929 -0
  477. package/packages/@monomind/cli/dist/src/ruvector/index.d.ts +39 -0
  478. package/packages/@monomind/cli/dist/src/ruvector/index.js +76 -0
  479. package/packages/@monomind/cli/dist/src/ruvector/lora-adapter.d.ts +218 -0
  480. package/packages/@monomind/cli/dist/src/ruvector/lora-adapter.js +455 -0
  481. package/packages/@monomind/cli/dist/src/ruvector/model-router.d.ts +222 -0
  482. package/packages/@monomind/cli/dist/src/ruvector/model-router.js +512 -0
  483. package/packages/@monomind/cli/dist/src/ruvector/moe-router.d.ts +213 -0
  484. package/packages/@monomind/cli/dist/src/ruvector/moe-router.js +649 -0
  485. package/packages/@monomind/cli/dist/src/ruvector/q-learning-router.d.ts +217 -0
  486. package/packages/@monomind/cli/dist/src/ruvector/q-learning-router.js +712 -0
  487. package/packages/@monomind/cli/dist/src/ruvector/ruvllm-wasm.d.ts +179 -0
  488. package/packages/@monomind/cli/dist/src/ruvector/ruvllm-wasm.js +363 -0
  489. package/packages/@monomind/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
  490. package/packages/@monomind/cli/dist/src/ruvector/semantic-router.js +178 -0
  491. package/packages/@monomind/cli/dist/src/ruvector/vector-db.d.ts +69 -0
  492. package/packages/@monomind/cli/dist/src/ruvector/vector-db.js +243 -0
  493. package/packages/@monomind/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
  494. package/packages/@monomind/cli/dist/src/services/agentic-flow-bridge.js +95 -0
  495. package/packages/@monomind/cli/dist/src/services/claim-service.d.ts +206 -0
  496. package/packages/@monomind/cli/dist/src/services/claim-service.js +849 -0
  497. package/packages/@monomind/cli/dist/src/services/config-file-manager.d.ts +51 -0
  498. package/packages/@monomind/cli/dist/src/services/config-file-manager.js +312 -0
  499. package/packages/@monomind/cli/dist/src/services/container-worker-pool.d.ts +197 -0
  500. package/packages/@monomind/cli/dist/src/services/container-worker-pool.js +623 -0
  501. package/packages/@monomind/cli/dist/src/services/headless-worker-executor.d.ts +311 -0
  502. package/packages/@monomind/cli/dist/src/services/headless-worker-executor.js +1167 -0
  503. package/packages/@monomind/cli/dist/src/services/index.d.ts +13 -0
  504. package/packages/@monomind/cli/dist/src/services/index.js +11 -0
  505. package/packages/@monomind/cli/dist/src/services/registry-api.d.ts +58 -0
  506. package/packages/@monomind/cli/dist/src/services/registry-api.js +199 -0
  507. package/packages/@monomind/cli/dist/src/services/ruvector-training.d.ts +222 -0
  508. package/packages/@monomind/cli/dist/src/services/ruvector-training.js +696 -0
  509. package/packages/@monomind/cli/dist/src/services/worker-daemon.d.ts +248 -0
  510. package/packages/@monomind/cli/dist/src/services/worker-daemon.js +1083 -0
  511. package/packages/@monomind/cli/dist/src/services/worker-queue.d.ts +201 -0
  512. package/packages/@monomind/cli/dist/src/services/worker-queue.js +594 -0
  513. package/packages/@monomind/cli/dist/src/suggest.d.ts +53 -0
  514. package/packages/@monomind/cli/dist/src/suggest.js +209 -0
  515. package/packages/@monomind/cli/dist/src/swarm/communication-graph.d.ts +25 -0
  516. package/packages/@monomind/cli/dist/src/swarm/communication-graph.js +77 -0
  517. package/packages/@monomind/cli/dist/src/swarm/flow-enforcer.d.ts +31 -0
  518. package/packages/@monomind/cli/dist/src/swarm/flow-enforcer.js +61 -0
  519. package/packages/@monomind/cli/dist/src/swarm/flow-visualizer.d.ts +19 -0
  520. package/packages/@monomind/cli/dist/src/swarm/flow-visualizer.js +68 -0
  521. package/packages/@monomind/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
  522. package/packages/@monomind/cli/dist/src/transfer/anonymization/index.js +177 -0
  523. package/packages/@monomind/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
  524. package/packages/@monomind/cli/dist/src/transfer/deploy-seraphine.js +205 -0
  525. package/packages/@monomind/cli/dist/src/transfer/export.d.ts +25 -0
  526. package/packages/@monomind/cli/dist/src/transfer/export.js +115 -0
  527. package/packages/@monomind/cli/dist/src/transfer/index.d.ts +12 -0
  528. package/packages/@monomind/cli/dist/src/transfer/index.js +31 -0
  529. package/packages/@monomind/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
  530. package/packages/@monomind/cli/dist/src/transfer/ipfs/client.js +384 -0
  531. package/packages/@monomind/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
  532. package/packages/@monomind/cli/dist/src/transfer/ipfs/upload.js +420 -0
  533. package/packages/@monomind/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
  534. package/packages/@monomind/cli/dist/src/transfer/models/seraphine.js +373 -0
  535. package/packages/@monomind/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
  536. package/packages/@monomind/cli/dist/src/transfer/serialization/cfp.js +183 -0
  537. package/packages/@monomind/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
  538. package/packages/@monomind/cli/dist/src/transfer/storage/gcs.js +281 -0
  539. package/packages/@monomind/cli/dist/src/transfer/storage/index.d.ts +6 -0
  540. package/packages/@monomind/cli/dist/src/transfer/storage/index.js +6 -0
  541. package/packages/@monomind/cli/dist/src/transfer/store/discovery.d.ts +91 -0
  542. package/packages/@monomind/cli/dist/src/transfer/store/discovery.js +437 -0
  543. package/packages/@monomind/cli/dist/src/transfer/store/download.d.ts +79 -0
  544. package/packages/@monomind/cli/dist/src/transfer/store/download.js +423 -0
  545. package/packages/@monomind/cli/dist/src/transfer/store/index.d.ts +84 -0
  546. package/packages/@monomind/cli/dist/src/transfer/store/index.js +153 -0
  547. package/packages/@monomind/cli/dist/src/transfer/store/publish.d.ts +76 -0
  548. package/packages/@monomind/cli/dist/src/transfer/store/publish.js +293 -0
  549. package/packages/@monomind/cli/dist/src/transfer/store/registry.d.ts +58 -0
  550. package/packages/@monomind/cli/dist/src/transfer/store/registry.js +301 -0
  551. package/packages/@monomind/cli/dist/src/transfer/store/search.d.ts +54 -0
  552. package/packages/@monomind/cli/dist/src/transfer/store/search.js +232 -0
  553. package/packages/@monomind/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
  554. package/packages/@monomind/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
  555. package/packages/@monomind/cli/dist/src/transfer/store/types.d.ts +193 -0
  556. package/packages/@monomind/cli/dist/src/transfer/store/types.js +6 -0
  557. package/packages/@monomind/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
  558. package/packages/@monomind/cli/dist/src/transfer/test-seraphine.js +105 -0
  559. package/packages/@monomind/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
  560. package/packages/@monomind/cli/dist/src/transfer/tests/test-store.js +214 -0
  561. package/packages/@monomind/cli/dist/src/transfer/types.d.ts +245 -0
  562. package/packages/@monomind/cli/dist/src/transfer/types.js +6 -0
  563. package/packages/@monomind/cli/dist/src/types.d.ts +198 -0
  564. package/packages/@monomind/cli/dist/src/types.js +38 -0
  565. package/packages/@monomind/cli/dist/src/update/checker.d.ts +34 -0
  566. package/packages/@monomind/cli/dist/src/update/checker.js +198 -0
  567. package/packages/@monomind/cli/dist/src/update/executor.d.ts +32 -0
  568. package/packages/@monomind/cli/dist/src/update/executor.js +186 -0
  569. package/packages/@monomind/cli/dist/src/update/index.d.ts +33 -0
  570. package/packages/@monomind/cli/dist/src/update/index.js +64 -0
  571. package/packages/@monomind/cli/dist/src/update/rate-limiter.d.ts +31 -0
  572. package/packages/@monomind/cli/dist/src/update/rate-limiter.js +116 -0
  573. package/packages/@monomind/cli/dist/src/update/validator.d.ts +17 -0
  574. package/packages/@monomind/cli/dist/src/update/validator.js +118 -0
  575. package/packages/@monomind/cli/dist/src/utils/parse-jsonl.d.ts +6 -0
  576. package/packages/@monomind/cli/dist/src/utils/parse-jsonl.js +22 -0
  577. package/packages/@monomind/cli/dist/src/workflow/condition-evaluator.d.ts +10 -0
  578. package/packages/@monomind/cli/dist/src/workflow/condition-evaluator.js +82 -0
  579. package/packages/@monomind/cli/dist/src/workflow/context-resolver.d.ts +12 -0
  580. package/packages/@monomind/cli/dist/src/workflow/context-resolver.js +23 -0
  581. package/packages/@monomind/cli/dist/src/workflow/dag-builder.d.ts +17 -0
  582. package/packages/@monomind/cli/dist/src/workflow/dag-builder.js +129 -0
  583. package/packages/@monomind/cli/dist/src/workflow/dag-executor.d.ts +9 -0
  584. package/packages/@monomind/cli/dist/src/workflow/dag-executor.js +116 -0
  585. package/packages/@monomind/cli/dist/src/workflow/dag-types.d.ts +41 -0
  586. package/packages/@monomind/cli/dist/src/workflow/dag-types.js +8 -0
  587. package/packages/@monomind/cli/dist/src/workflow/dsl-parser.d.ts +12 -0
  588. package/packages/@monomind/cli/dist/src/workflow/dsl-parser.js +20 -0
  589. package/packages/@monomind/cli/dist/src/workflow/dsl-schema.d.ts +165 -0
  590. package/packages/@monomind/cli/dist/src/workflow/dsl-schema.js +82 -0
  591. package/packages/@monomind/cli/dist/src/workflow/index.d.ts +13 -0
  592. package/packages/@monomind/cli/dist/src/workflow/index.js +11 -0
  593. package/packages/@monomind/cli/dist/src/workflow/template-engine.d.ts +11 -0
  594. package/packages/@monomind/cli/dist/src/workflow/template-engine.js +40 -0
  595. package/packages/@monomind/cli/dist/src/workflow/workflow-executor.d.ts +29 -0
  596. package/packages/@monomind/cli/dist/src/workflow/workflow-executor.js +227 -0
  597. package/packages/@monomind/cli/package.json +2 -1
@@ -0,0 +1,797 @@
1
+ /**
2
+ * Claims MCP Tools for CLI
3
+ *
4
+ * Implements MCP tools for ADR-016: Collaborative Issue Claims
5
+ * Provides programmatic access to claim operations for MCP clients.
6
+ *
7
+ * @module @monomind/cli/mcp-tools/claims
8
+ */
9
+ // File-based persistence
10
+ import { existsSync, readFileSync, writeFileSync, renameSync, mkdirSync } from 'fs';
11
+ import { join, resolve } from 'path';
12
+ const CLAIMS_DIR = '.monomind/claims';
13
+ const CLAIMS_FILE = 'claims.json';
14
+ function getClaimsPath() {
15
+ return resolve(join(CLAIMS_DIR, CLAIMS_FILE));
16
+ }
17
+ function ensureClaimsDir() {
18
+ const dir = resolve(CLAIMS_DIR);
19
+ if (!existsSync(dir)) {
20
+ mkdirSync(dir, { recursive: true });
21
+ }
22
+ }
23
+ function loadClaims() {
24
+ try {
25
+ const path = getClaimsPath();
26
+ if (existsSync(path)) {
27
+ return JSON.parse(readFileSync(path, 'utf-8'));
28
+ }
29
+ }
30
+ catch {
31
+ // Return empty store on error
32
+ }
33
+ return { claims: {}, stealable: {}, contests: {} };
34
+ }
35
+ function saveClaims(store) {
36
+ ensureClaimsDir();
37
+ const dest = getClaimsPath();
38
+ const tmp = `${dest}.${process.pid}.${Date.now()}.tmp`;
39
+ writeFileSync(tmp, JSON.stringify(store, null, 2), 'utf-8');
40
+ renameSync(tmp, dest);
41
+ }
42
+ function formatClaimant(claimant) {
43
+ return claimant.type === 'human'
44
+ ? `human:${claimant.userId}:${claimant.name}`
45
+ : `agent:${claimant.agentId}:${claimant.agentType}`;
46
+ }
47
+ function parseClaimant(str) {
48
+ const parts = str.split(':');
49
+ if (parts[0] === 'human' && parts.length >= 3) {
50
+ return { type: 'human', userId: parts[1], name: parts.slice(2).join(':') };
51
+ }
52
+ else if (parts[0] === 'agent' && parts.length >= 3) {
53
+ return { type: 'agent', agentId: parts[1], agentType: parts[2] };
54
+ }
55
+ return null;
56
+ }
57
+ export const claimsTools = [
58
+ {
59
+ name: 'claims_claim',
60
+ description: 'Claim an issue for work (human or agent)',
61
+ category: 'claims',
62
+ inputSchema: {
63
+ type: 'object',
64
+ properties: {
65
+ issueId: {
66
+ type: 'string',
67
+ description: 'Issue ID or GitHub issue number',
68
+ },
69
+ claimant: {
70
+ type: 'string',
71
+ description: 'Claimant identifier (e.g., "human:user-1:Alice" or "agent:coder-1:coder")',
72
+ },
73
+ context: {
74
+ type: 'string',
75
+ description: 'Optional context about the work approach',
76
+ },
77
+ },
78
+ required: ['issueId', 'claimant'],
79
+ },
80
+ handler: async (input) => {
81
+ const issueId = input.issueId;
82
+ const claimantStr = input.claimant;
83
+ const context = input.context;
84
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
85
+ if (!issueId || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
86
+ return { success: false, error: 'Invalid issueId' };
87
+ }
88
+ const claimant = parseClaimant(claimantStr);
89
+ if (!claimant) {
90
+ return { success: false, error: 'Invalid claimant format. Use "human:userId:name" or "agent:agentId:agentType"' };
91
+ }
92
+ const store = loadClaims();
93
+ const MAX_CLAIMS = 10000;
94
+ if (Object.keys(store.claims).length >= MAX_CLAIMS) {
95
+ return { success: false, error: 'Claims store at capacity' };
96
+ }
97
+ // Check if already claimed (Object.hasOwn defends against bracket access
98
+ // resolving to inherited Object.prototype methods like `toString`)
99
+ if (Object.hasOwn(store.claims, issueId)) {
100
+ const existing = store.claims[issueId];
101
+ return {
102
+ success: false,
103
+ error: `Issue already claimed by ${formatClaimant(existing.claimant)}`,
104
+ existingClaim: existing,
105
+ };
106
+ }
107
+ const now = new Date().toISOString();
108
+ const claim = {
109
+ issueId,
110
+ claimant,
111
+ claimedAt: now,
112
+ status: 'active',
113
+ statusChangedAt: now,
114
+ progress: 0,
115
+ context,
116
+ };
117
+ store.claims[issueId] = claim;
118
+ saveClaims(store);
119
+ return {
120
+ success: true,
121
+ claim,
122
+ message: `Issue ${issueId} claimed by ${formatClaimant(claimant)}`,
123
+ };
124
+ },
125
+ },
126
+ {
127
+ name: 'claims_release',
128
+ description: 'Release a claim on an issue',
129
+ category: 'claims',
130
+ inputSchema: {
131
+ type: 'object',
132
+ properties: {
133
+ issueId: {
134
+ type: 'string',
135
+ description: 'Issue ID to release',
136
+ },
137
+ claimant: {
138
+ type: 'string',
139
+ description: 'Claimant identifier (must match current owner)',
140
+ },
141
+ reason: {
142
+ type: 'string',
143
+ description: 'Reason for releasing',
144
+ },
145
+ },
146
+ required: ['issueId', 'claimant'],
147
+ },
148
+ handler: async (input) => {
149
+ const issueId = input.issueId;
150
+ const claimantStr = input.claimant;
151
+ const reason = input.reason;
152
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
153
+ if (!issueId || typeof issueId !== 'string' || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
154
+ return { success: false, error: 'Invalid issueId' };
155
+ }
156
+ const claimant = parseClaimant(claimantStr);
157
+ if (!claimant) {
158
+ return { success: false, error: 'Invalid claimant format' };
159
+ }
160
+ const store = loadClaims();
161
+ if (!Object.hasOwn(store.claims, issueId)) {
162
+ return { success: false, error: 'Issue is not claimed' };
163
+ }
164
+ const claim = store.claims[issueId];
165
+ // Verify ownership
166
+ if (formatClaimant(claim.claimant) !== formatClaimant(claimant)) {
167
+ return { success: false, error: 'Only the current claimant can release' };
168
+ }
169
+ delete store.claims[issueId];
170
+ delete store.stealable[issueId];
171
+ saveClaims(store);
172
+ return {
173
+ success: true,
174
+ message: `Issue ${issueId} released`,
175
+ reason,
176
+ previousClaim: claim,
177
+ };
178
+ },
179
+ },
180
+ {
181
+ name: 'claims_handoff',
182
+ description: 'Request handoff of an issue to another claimant',
183
+ category: 'claims',
184
+ inputSchema: {
185
+ type: 'object',
186
+ properties: {
187
+ issueId: {
188
+ type: 'string',
189
+ description: 'Issue ID to handoff',
190
+ },
191
+ from: {
192
+ type: 'string',
193
+ description: 'Current claimant identifier',
194
+ },
195
+ to: {
196
+ type: 'string',
197
+ description: 'Target claimant identifier',
198
+ },
199
+ reason: {
200
+ type: 'string',
201
+ description: 'Reason for handoff',
202
+ },
203
+ progress: {
204
+ type: 'number',
205
+ description: 'Current progress percentage (0-100)',
206
+ },
207
+ },
208
+ required: ['issueId', 'from', 'to'],
209
+ },
210
+ handler: async (input) => {
211
+ const issueId = input.issueId;
212
+ const fromStr = input.from;
213
+ const toStr = input.to;
214
+ const reason = input.reason;
215
+ const progress = input.progress || 0;
216
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
217
+ if (!issueId || typeof issueId !== 'string' || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
218
+ return { success: false, error: 'Invalid issueId' };
219
+ }
220
+ const from = parseClaimant(fromStr);
221
+ const to = parseClaimant(toStr);
222
+ if (!from || !to) {
223
+ return { success: false, error: 'Invalid claimant format' };
224
+ }
225
+ const store = loadClaims();
226
+ if (!Object.hasOwn(store.claims, issueId)) {
227
+ return { success: false, error: 'Issue is not claimed' };
228
+ }
229
+ const claim = store.claims[issueId];
230
+ if (formatClaimant(claim.claimant) !== formatClaimant(from)) {
231
+ return { success: false, error: 'Only the current claimant can request handoff' };
232
+ }
233
+ const now = new Date().toISOString();
234
+ claim.status = 'handoff-pending';
235
+ claim.statusChangedAt = now;
236
+ claim.handoffTo = to;
237
+ claim.handoffReason = reason;
238
+ claim.progress = progress;
239
+ store.claims[issueId] = claim;
240
+ saveClaims(store);
241
+ return {
242
+ success: true,
243
+ claim,
244
+ message: `Handoff requested from ${formatClaimant(from)} to ${formatClaimant(to)}`,
245
+ };
246
+ },
247
+ },
248
+ {
249
+ name: 'claims_accept-handoff',
250
+ description: 'Accept a pending handoff',
251
+ category: 'claims',
252
+ inputSchema: {
253
+ type: 'object',
254
+ properties: {
255
+ issueId: {
256
+ type: 'string',
257
+ description: 'Issue ID with pending handoff',
258
+ },
259
+ claimant: {
260
+ type: 'string',
261
+ description: 'Claimant accepting the handoff',
262
+ },
263
+ },
264
+ required: ['issueId', 'claimant'],
265
+ },
266
+ handler: async (input) => {
267
+ const issueId = input.issueId;
268
+ const claimantStr = input.claimant;
269
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
270
+ if (!issueId || typeof issueId !== 'string' || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
271
+ return { success: false, error: 'Invalid issueId' };
272
+ }
273
+ const claimant = parseClaimant(claimantStr);
274
+ if (!claimant) {
275
+ return { success: false, error: 'Invalid claimant format' };
276
+ }
277
+ const store = loadClaims();
278
+ if (!Object.hasOwn(store.claims, issueId)) {
279
+ return { success: false, error: 'Issue is not claimed' };
280
+ }
281
+ const claim = store.claims[issueId];
282
+ if (claim.status !== 'handoff-pending') {
283
+ return { success: false, error: 'No pending handoff for this issue' };
284
+ }
285
+ if (!claim.handoffTo || formatClaimant(claim.handoffTo) !== formatClaimant(claimant)) {
286
+ return { success: false, error: 'You are not the target of this handoff' };
287
+ }
288
+ const previousOwner = claim.claimant;
289
+ const now = new Date().toISOString();
290
+ claim.claimant = claimant;
291
+ claim.status = 'active';
292
+ claim.statusChangedAt = now;
293
+ claim.handoffTo = undefined;
294
+ claim.handoffReason = undefined;
295
+ store.claims[issueId] = claim;
296
+ saveClaims(store);
297
+ return {
298
+ success: true,
299
+ claim,
300
+ previousOwner,
301
+ message: `Handoff accepted. ${formatClaimant(claimant)} now owns issue ${issueId}`,
302
+ };
303
+ },
304
+ },
305
+ {
306
+ name: 'claims_status',
307
+ description: 'Update claim status',
308
+ category: 'claims',
309
+ inputSchema: {
310
+ type: 'object',
311
+ properties: {
312
+ issueId: {
313
+ type: 'string',
314
+ description: 'Issue ID',
315
+ },
316
+ status: {
317
+ type: 'string',
318
+ description: 'New status',
319
+ enum: ['active', 'paused', 'blocked', 'review-requested', 'completed'],
320
+ },
321
+ claimant: {
322
+ type: 'string',
323
+ description: 'Claimant identifier (must match current owner)',
324
+ },
325
+ note: {
326
+ type: 'string',
327
+ description: 'Status note or reason',
328
+ },
329
+ progress: {
330
+ type: 'number',
331
+ description: 'Current progress percentage',
332
+ },
333
+ },
334
+ required: ['issueId', 'status'],
335
+ },
336
+ handler: async (input) => {
337
+ const issueId = input.issueId;
338
+ const status = input.status;
339
+ const claimantStr = input.claimant;
340
+ const note = input.note;
341
+ const progress = input.progress;
342
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
343
+ if (!issueId || typeof issueId !== 'string' || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
344
+ return { success: false, error: 'Invalid issueId' };
345
+ }
346
+ const store = loadClaims();
347
+ if (!Object.hasOwn(store.claims, issueId)) {
348
+ return { success: false, error: 'Issue is not claimed' };
349
+ }
350
+ const claim = store.claims[issueId];
351
+ if (claimantStr) {
352
+ const claimant = parseClaimant(claimantStr);
353
+ if (!claimant) {
354
+ return { success: false, error: 'Invalid claimant format' };
355
+ }
356
+ if (formatClaimant(claim.claimant) !== formatClaimant(claimant)) {
357
+ return { success: false, error: 'Only the current claimant can update status' };
358
+ }
359
+ }
360
+ const now = new Date().toISOString();
361
+ claim.status = status;
362
+ claim.statusChangedAt = now;
363
+ if (status === 'blocked') {
364
+ claim.blockReason = note;
365
+ }
366
+ if (progress !== undefined) {
367
+ claim.progress = Math.min(100, Math.max(0, progress));
368
+ }
369
+ store.claims[issueId] = claim;
370
+ saveClaims(store);
371
+ return {
372
+ success: true,
373
+ claim,
374
+ message: `Issue ${issueId} status updated to ${status}`,
375
+ };
376
+ },
377
+ },
378
+ {
379
+ name: 'claims_list',
380
+ description: 'List all claims or filter by criteria',
381
+ category: 'claims',
382
+ inputSchema: {
383
+ type: 'object',
384
+ properties: {
385
+ status: {
386
+ type: 'string',
387
+ description: 'Filter by status',
388
+ enum: ['active', 'paused', 'blocked', 'stealable', 'completed', 'all'],
389
+ },
390
+ claimant: {
391
+ type: 'string',
392
+ description: 'Filter by claimant',
393
+ },
394
+ agentType: {
395
+ type: 'string',
396
+ description: 'Filter by agent type',
397
+ },
398
+ },
399
+ },
400
+ handler: async (input) => {
401
+ const status = input.status;
402
+ const claimantFilter = input.claimant;
403
+ const agentType = input.agentType;
404
+ const store = loadClaims();
405
+ let claims = Object.values(store.claims);
406
+ if (status && status !== 'all') {
407
+ claims = claims.filter(c => c.status === status);
408
+ }
409
+ if (claimantFilter) {
410
+ claims = claims.filter(c => formatClaimant(c.claimant).includes(claimantFilter));
411
+ }
412
+ if (agentType) {
413
+ claims = claims.filter(c => c.claimant.type === 'agent' && c.claimant.agentType === agentType);
414
+ }
415
+ return {
416
+ success: true,
417
+ claims,
418
+ count: claims.length,
419
+ stealableCount: Object.keys(store.stealable).length,
420
+ };
421
+ },
422
+ },
423
+ {
424
+ name: 'claims_mark-stealable',
425
+ description: 'Mark an issue as stealable by other agents',
426
+ category: 'claims',
427
+ inputSchema: {
428
+ type: 'object',
429
+ properties: {
430
+ issueId: {
431
+ type: 'string',
432
+ description: 'Issue ID to mark stealable',
433
+ },
434
+ reason: {
435
+ type: 'string',
436
+ description: 'Reason for marking stealable',
437
+ enum: ['overloaded', 'stale', 'blocked-timeout', 'voluntary'],
438
+ },
439
+ preferredTypes: {
440
+ type: 'array',
441
+ description: 'Preferred agent types to steal',
442
+ items: { type: 'string' },
443
+ },
444
+ context: {
445
+ type: 'string',
446
+ description: 'Handoff context for the stealer',
447
+ },
448
+ },
449
+ required: ['issueId', 'reason'],
450
+ },
451
+ handler: async (input) => {
452
+ const issueId = input.issueId;
453
+ const reason = input.reason;
454
+ const preferredTypes = input.preferredTypes;
455
+ const context = input.context;
456
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
457
+ if (!issueId || typeof issueId !== 'string' || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
458
+ return { success: false, error: 'Invalid issueId' };
459
+ }
460
+ const store = loadClaims();
461
+ if (!Object.hasOwn(store.claims, issueId)) {
462
+ return { success: false, error: 'Issue is not claimed' };
463
+ }
464
+ const claim = store.claims[issueId];
465
+ const now = new Date().toISOString();
466
+ claim.status = 'stealable';
467
+ claim.statusChangedAt = now;
468
+ store.stealable[issueId] = {
469
+ reason,
470
+ stealableAt: now,
471
+ preferredTypes,
472
+ progress: claim.progress,
473
+ context,
474
+ };
475
+ store.claims[issueId] = claim;
476
+ saveClaims(store);
477
+ return {
478
+ success: true,
479
+ claim,
480
+ stealableInfo: store.stealable[issueId],
481
+ message: `Issue ${issueId} marked as stealable (${reason})`,
482
+ };
483
+ },
484
+ },
485
+ {
486
+ name: 'claims_steal',
487
+ description: 'Steal a stealable issue',
488
+ category: 'claims',
489
+ inputSchema: {
490
+ type: 'object',
491
+ properties: {
492
+ issueId: {
493
+ type: 'string',
494
+ description: 'Issue ID to steal',
495
+ },
496
+ stealer: {
497
+ type: 'string',
498
+ description: 'Claimant stealing the issue',
499
+ },
500
+ },
501
+ required: ['issueId', 'stealer'],
502
+ },
503
+ handler: async (input) => {
504
+ const issueId = input.issueId;
505
+ const stealerStr = input.stealer;
506
+ const RESERVED_KEYS = new Set(['__proto__', 'constructor', 'prototype']);
507
+ if (!issueId || typeof issueId !== 'string' || issueId.length > 256 || RESERVED_KEYS.has(issueId)) {
508
+ return { success: false, error: 'Invalid issueId' };
509
+ }
510
+ const stealer = parseClaimant(stealerStr);
511
+ if (!stealer) {
512
+ return { success: false, error: 'Invalid claimant format' };
513
+ }
514
+ const store = loadClaims();
515
+ if (!Object.hasOwn(store.claims, issueId)) {
516
+ return { success: false, error: 'Issue is not claimed' };
517
+ }
518
+ const claim = store.claims[issueId];
519
+ const stealableInfo = Object.hasOwn(store.stealable, issueId) ? store.stealable[issueId] : undefined;
520
+ if (!stealableInfo) {
521
+ return { success: false, error: 'Issue is not stealable' };
522
+ }
523
+ // Check preferred types
524
+ if (stealableInfo.preferredTypes && stealableInfo.preferredTypes.length > 0) {
525
+ if (stealer.type === 'agent' && !stealableInfo.preferredTypes.includes(stealer.agentType)) {
526
+ return {
527
+ success: false,
528
+ error: `Issue prefers agent types: ${stealableInfo.preferredTypes.join(', ')}`,
529
+ };
530
+ }
531
+ }
532
+ const previousOwner = claim.claimant;
533
+ const now = new Date().toISOString();
534
+ claim.claimant = stealer;
535
+ claim.status = 'active';
536
+ claim.statusChangedAt = now;
537
+ claim.context = stealableInfo.context;
538
+ delete store.stealable[issueId];
539
+ store.claims[issueId] = claim;
540
+ saveClaims(store);
541
+ return {
542
+ success: true,
543
+ claim,
544
+ previousOwner,
545
+ stealableInfo,
546
+ message: `Issue ${issueId} stolen by ${formatClaimant(stealer)}`,
547
+ };
548
+ },
549
+ },
550
+ {
551
+ name: 'claims_stealable',
552
+ description: 'List all stealable issues',
553
+ category: 'claims',
554
+ inputSchema: {
555
+ type: 'object',
556
+ properties: {
557
+ agentType: {
558
+ type: 'string',
559
+ description: 'Filter by preferred agent type',
560
+ },
561
+ },
562
+ },
563
+ handler: async (input) => {
564
+ const agentType = input.agentType;
565
+ const store = loadClaims();
566
+ let stealableIssues = Object.entries(store.stealable).map(([issueId, info]) => ({
567
+ issueId,
568
+ ...info,
569
+ claim: store.claims[issueId],
570
+ }));
571
+ if (agentType) {
572
+ stealableIssues = stealableIssues.filter(s => !s.preferredTypes || s.preferredTypes.length === 0 || s.preferredTypes.includes(agentType));
573
+ }
574
+ return {
575
+ success: true,
576
+ stealable: stealableIssues,
577
+ count: stealableIssues.length,
578
+ };
579
+ },
580
+ },
581
+ {
582
+ name: 'claims_load',
583
+ description: 'Get agent load information',
584
+ category: 'claims',
585
+ inputSchema: {
586
+ type: 'object',
587
+ properties: {
588
+ agentId: {
589
+ type: 'string',
590
+ description: 'Specific agent ID (optional)',
591
+ },
592
+ agentType: {
593
+ type: 'string',
594
+ description: 'Filter by agent type',
595
+ },
596
+ },
597
+ },
598
+ handler: async (input) => {
599
+ const agentId = input.agentId;
600
+ const agentType = input.agentType;
601
+ const store = loadClaims();
602
+ const claims = Object.values(store.claims);
603
+ // Group claims by agent
604
+ const agentLoads = new Map();
605
+ for (const claim of claims) {
606
+ if (claim.claimant.type !== 'agent')
607
+ continue;
608
+ const key = claim.claimant.agentId;
609
+ if (!agentLoads.has(key)) {
610
+ agentLoads.set(key, {
611
+ agentId: key,
612
+ agentType: claim.claimant.agentType,
613
+ claims: [],
614
+ blockedCount: 0,
615
+ });
616
+ }
617
+ const load = agentLoads.get(key);
618
+ load.claims.push(claim);
619
+ if (claim.status === 'blocked') {
620
+ load.blockedCount++;
621
+ }
622
+ }
623
+ let loads = Array.from(agentLoads.values());
624
+ if (agentId) {
625
+ loads = loads.filter(l => l.agentId === agentId);
626
+ }
627
+ if (agentType) {
628
+ loads = loads.filter(l => l.agentType === agentType);
629
+ }
630
+ const result = loads.map(l => ({
631
+ agentId: l.agentId,
632
+ agentType: l.agentType,
633
+ claimCount: l.claims.length,
634
+ maxClaims: 5, // Default max
635
+ utilization: l.claims.length / 5,
636
+ blockedCount: l.blockedCount,
637
+ claims: l.claims.map(c => ({
638
+ issueId: c.issueId,
639
+ status: c.status,
640
+ progress: c.progress,
641
+ })),
642
+ }));
643
+ return {
644
+ success: true,
645
+ loads: result,
646
+ totalAgents: result.length,
647
+ totalClaims: claims.filter(c => c.claimant.type === 'agent').length,
648
+ avgUtilization: result.length > 0
649
+ ? result.reduce((sum, l) => sum + l.utilization, 0) / result.length
650
+ : 0,
651
+ };
652
+ },
653
+ },
654
+ {
655
+ name: 'claims_board',
656
+ description: 'Get a visual board view of all claims',
657
+ category: 'claims',
658
+ inputSchema: {
659
+ type: 'object',
660
+ properties: {},
661
+ },
662
+ handler: async () => {
663
+ const store = loadClaims();
664
+ const claims = Object.values(store.claims);
665
+ const byStatus = {
666
+ active: [],
667
+ paused: [],
668
+ blocked: [],
669
+ 'handoff-pending': [],
670
+ 'review-requested': [],
671
+ stealable: [],
672
+ completed: [],
673
+ };
674
+ for (const claim of claims) {
675
+ if (byStatus[claim.status]) {
676
+ byStatus[claim.status].push(claim);
677
+ }
678
+ }
679
+ const humanClaims = claims.filter(c => c.claimant.type === 'human');
680
+ const agentClaims = claims.filter(c => c.claimant.type === 'agent');
681
+ return {
682
+ success: true,
683
+ board: {
684
+ active: byStatus.active.map(c => ({ issueId: c.issueId, claimant: formatClaimant(c.claimant), progress: c.progress })),
685
+ paused: byStatus.paused.map(c => ({ issueId: c.issueId, claimant: formatClaimant(c.claimant) })),
686
+ blocked: byStatus.blocked.map(c => ({ issueId: c.issueId, claimant: formatClaimant(c.claimant), reason: c.blockReason })),
687
+ 'handoff-pending': byStatus['handoff-pending'].map(c => ({ issueId: c.issueId, from: formatClaimant(c.claimant), to: c.handoffTo ? formatClaimant(c.handoffTo) : null })),
688
+ 'review-requested': byStatus['review-requested'].map(c => ({ issueId: c.issueId, claimant: formatClaimant(c.claimant) })),
689
+ stealable: byStatus.stealable.map(c => ({ issueId: c.issueId, claimant: formatClaimant(c.claimant) })),
690
+ completed: byStatus.completed.map(c => ({ issueId: c.issueId, claimant: formatClaimant(c.claimant) })),
691
+ },
692
+ summary: {
693
+ total: claims.length,
694
+ active: byStatus.active.length,
695
+ blocked: byStatus.blocked.length,
696
+ stealable: byStatus.stealable.length,
697
+ humanClaims: humanClaims.length,
698
+ agentClaims: agentClaims.length,
699
+ },
700
+ };
701
+ },
702
+ },
703
+ {
704
+ name: 'claims_rebalance',
705
+ description: 'Suggest or apply load rebalancing across agents',
706
+ category: 'claims',
707
+ inputSchema: {
708
+ type: 'object',
709
+ properties: {
710
+ dryRun: {
711
+ type: 'boolean',
712
+ description: 'Preview rebalancing without applying',
713
+ default: true,
714
+ },
715
+ targetUtilization: {
716
+ type: 'number',
717
+ description: 'Target utilization (0-1)',
718
+ default: 0.7,
719
+ },
720
+ },
721
+ },
722
+ handler: async (input) => {
723
+ const dryRun = input.dryRun !== false;
724
+ const targetUtilization = input.targetUtilization || 0.7;
725
+ const store = loadClaims();
726
+ const claims = Object.values(store.claims);
727
+ // Group by agent
728
+ const agentLoads = new Map();
729
+ for (const claim of claims) {
730
+ if (claim.claimant.type !== 'agent')
731
+ continue;
732
+ const key = claim.claimant.agentId;
733
+ if (!agentLoads.has(key)) {
734
+ agentLoads.set(key, { agentId: key, agentType: claim.claimant.agentType, claims: [] });
735
+ }
736
+ agentLoads.get(key).claims.push(claim);
737
+ }
738
+ const loads = Array.from(agentLoads.values());
739
+ const maxClaims = 5;
740
+ const avgLoad = loads.length > 0
741
+ ? loads.reduce((sum, l) => sum + l.claims.length, 0) / loads.length
742
+ : 0;
743
+ const overloaded = loads.filter(l => l.claims.length > maxClaims * targetUtilization * 1.5);
744
+ const underloaded = loads.filter(l => l.claims.length < maxClaims * targetUtilization * 0.5);
745
+ const suggestions = [];
746
+ for (const over of overloaded) {
747
+ // Find low-progress claims to redistribute
748
+ const movable = over.claims
749
+ .filter(c => c.progress < 25 && c.status === 'active')
750
+ .slice(0, over.claims.length - Math.ceil(maxClaims * targetUtilization));
751
+ for (const claim of movable) {
752
+ const target = underloaded.find(u => u.agentType === over.agentType && u.claims.length < maxClaims);
753
+ if (target) {
754
+ suggestions.push({
755
+ issueId: claim.issueId,
756
+ from: `agent:${over.agentId}:${over.agentType}`,
757
+ to: `agent:${target.agentId}:${target.agentType}`,
758
+ reason: 'Load balancing',
759
+ });
760
+ }
761
+ }
762
+ }
763
+ // When not a dry run, execute the suggested moves
764
+ if (!dryRun) {
765
+ for (const suggestion of suggestions) {
766
+ const claim = store.claims[suggestion.issueId];
767
+ if (claim) {
768
+ const newOwner = parseClaimant(suggestion.to);
769
+ if (newOwner) {
770
+ claim.claimant = newOwner;
771
+ claim.statusChangedAt = new Date().toISOString();
772
+ store.claims[suggestion.issueId] = claim;
773
+ }
774
+ }
775
+ }
776
+ saveClaims(store);
777
+ }
778
+ return {
779
+ success: true,
780
+ dryRun,
781
+ suggestions,
782
+ metrics: {
783
+ totalAgents: loads.length,
784
+ avgLoad,
785
+ overloadedCount: overloaded.length,
786
+ underloadedCount: underloaded.length,
787
+ targetUtilization,
788
+ },
789
+ message: dryRun
790
+ ? `Found ${suggestions.length} rebalancing opportunities (dry run)`
791
+ : `Applied ${suggestions.length} rebalancing moves`,
792
+ };
793
+ },
794
+ },
795
+ ];
796
+ export default claimsTools;
797
+ //# sourceMappingURL=claims-tools.js.map