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,1083 @@
1
+ /**
2
+ * Worker Daemon Service
3
+ * Node.js-based background worker system that auto-runs like shell daemons
4
+ *
5
+ * Workers:
6
+ * - map: Codebase mapping (5 min interval)
7
+ * - audit: Security analysis (10 min interval)
8
+ * - optimize: Performance optimization (15 min interval)
9
+ * - consolidate: Memory consolidation (30 min interval)
10
+ * - testgaps: Test coverage analysis (20 min interval)
11
+ */
12
+ import { EventEmitter } from 'events';
13
+ import { existsSync, mkdirSync, writeFileSync, renameSync, readFileSync, appendFileSync, unlinkSync } from 'fs';
14
+ import { cpus } from 'os';
15
+ import { join, resolve } from 'path';
16
+ import { HeadlessWorkerExecutor, isHeadlessWorker, } from './headless-worker-executor.js';
17
+ // Default worker configurations with improved intervals (P0 fix: map 5min -> 15min)
18
+ const DEFAULT_WORKERS = [
19
+ { type: 'map', intervalMs: 15 * 60 * 1000, offsetMs: 0, priority: 'normal', description: 'Codebase mapping', enabled: true },
20
+ { type: 'audit', intervalMs: 10 * 60 * 1000, offsetMs: 2 * 60 * 1000, priority: 'critical', description: 'Security analysis', enabled: true },
21
+ { type: 'optimize', intervalMs: 15 * 60 * 1000, offsetMs: 4 * 60 * 1000, priority: 'high', description: 'Performance optimization', enabled: true },
22
+ { type: 'consolidate', intervalMs: 30 * 60 * 1000, offsetMs: 6 * 60 * 1000, priority: 'low', description: 'Memory consolidation', enabled: true },
23
+ { type: 'testgaps', intervalMs: 20 * 60 * 1000, offsetMs: 8 * 60 * 1000, priority: 'normal', description: 'Test coverage analysis', enabled: true },
24
+ { type: 'predict', intervalMs: 10 * 60 * 1000, offsetMs: 0, priority: 'low', description: 'Predictive preloading', enabled: false },
25
+ { type: 'document', intervalMs: 60 * 60 * 1000, offsetMs: 0, priority: 'low', description: 'Auto-documentation', enabled: false },
26
+ ];
27
+ // Worker timeout — must exceed the longest per-worker headless timeout (15 min for audit/refactor).
28
+ // Previously 5 min, which caused orphan processes when daemon timeout fired before executor timeout (#1117).
29
+ const DEFAULT_WORKER_TIMEOUT_MS = 16 * 60 * 1000;
30
+ /**
31
+ * Worker Daemon - Manages background workers with Node.js
32
+ */
33
+ export class WorkerDaemon extends EventEmitter {
34
+ config;
35
+ workers = new Map();
36
+ timers = new Map();
37
+ running = false;
38
+ startedAt;
39
+ projectRoot;
40
+ runningWorkers = new Set(); // Track concurrent workers
41
+ pendingWorkers = []; // Queue for deferred workers
42
+ // Headless execution support
43
+ headlessExecutor = null;
44
+ headlessAvailable = false;
45
+ // Preserve the original constructor config so we can detect explicit overrides
46
+ // during state restoration (R1: constructor config takes priority over stale state)
47
+ originalConfig;
48
+ constructor(projectRoot, config) {
49
+ super();
50
+ // Resolve and validate projectRoot. Without this an attacker who can pass
51
+ // a crafted projectRoot (env var, untrusted CLI flag, MCP tool argument)
52
+ // gets arbitrary file write via the derived pidFile, logFile, stateFile,
53
+ // and metrics paths.
54
+ const resolved = resolve(projectRoot);
55
+ this.projectRoot = resolved;
56
+ this.originalConfig = config;
57
+ const monomindDir = join(resolved, '.monomind');
58
+ // Read daemon config from .monomind/config.json (Layer B)
59
+ const fileConfig = this.readDaemonConfigFromFile(monomindDir);
60
+ // CPU-proportional smart default instead of hardcoded 2.0
61
+ const cpuCount = WorkerDaemon.getEffectiveCpuCount();
62
+ const smartMaxCpuLoad = Math.max(cpuCount * 0.8, 2.0); // Floor of 2.0 for single-CPU machines
63
+ // Platform-aware default: macOS os.freemem() excludes reclaimable file cache,
64
+ // so reported "free" is much lower than actually available memory.
65
+ // Linux reports available memory (including reclaimable cache) more accurately.
66
+ const defaultMinFreeMemory = process.platform === 'darwin' ? 5 : 10;
67
+ // Priority: constructor arg > config.json > smart default
68
+ // For resourceThresholds, merge field-by-field so partial overrides
69
+ // (e.g. only --max-cpu-load) still pick up defaults for other fields.
70
+ this.config = {
71
+ autoStart: config?.autoStart ?? fileConfig.autoStart ?? false,
72
+ logDir: config?.logDir ?? join(monomindDir, 'logs'),
73
+ stateFile: config?.stateFile ?? join(monomindDir, 'daemon-state.json'),
74
+ maxConcurrent: config?.maxConcurrent ?? fileConfig.maxConcurrent ?? 2,
75
+ workerTimeoutMs: config?.workerTimeoutMs ?? fileConfig.workerTimeoutMs ?? DEFAULT_WORKER_TIMEOUT_MS,
76
+ resourceThresholds: {
77
+ maxCpuLoad: config?.resourceThresholds?.maxCpuLoad ?? fileConfig.maxCpuLoad ?? smartMaxCpuLoad,
78
+ minFreeMemoryPercent: config?.resourceThresholds?.minFreeMemoryPercent ?? fileConfig.minFreeMemoryPercent ?? defaultMinFreeMemory,
79
+ },
80
+ workers: config?.workers ?? DEFAULT_WORKERS,
81
+ };
82
+ // Setup graceful shutdown handlers
83
+ this.setupShutdownHandlers();
84
+ // Ensure directories exist
85
+ if (!existsSync(monomindDir)) {
86
+ mkdirSync(monomindDir, { recursive: true });
87
+ }
88
+ if (!existsSync(this.config.logDir)) {
89
+ mkdirSync(this.config.logDir, { recursive: true });
90
+ }
91
+ // Initialize worker states
92
+ this.initializeWorkerStates();
93
+ // Initialize headless executor (async, non-blocking)
94
+ this.initHeadlessExecutor().catch((err) => {
95
+ this.log('warn', `Headless executor init failed: ${err}`);
96
+ });
97
+ }
98
+ /**
99
+ * Initialize headless executor if Claude Code is available
100
+ */
101
+ async initHeadlessExecutor() {
102
+ try {
103
+ this.headlessExecutor = new HeadlessWorkerExecutor(this.projectRoot, {
104
+ maxConcurrent: this.config.maxConcurrent,
105
+ });
106
+ this.headlessAvailable = await this.headlessExecutor.isAvailable();
107
+ if (this.headlessAvailable) {
108
+ this.log('info', 'Claude Code headless mode available - AI workers enabled');
109
+ // Forward headless executor events
110
+ this.headlessExecutor.on('execution:start', (data) => {
111
+ this.emit('headless:start', data);
112
+ });
113
+ this.headlessExecutor.on('execution:complete', (data) => {
114
+ this.emit('headless:complete', data);
115
+ });
116
+ this.headlessExecutor.on('execution:error', (data) => {
117
+ this.emit('headless:error', data);
118
+ });
119
+ this.headlessExecutor.on('output', (data) => {
120
+ this.emit('headless:output', data);
121
+ });
122
+ }
123
+ else {
124
+ this.log('info', 'Claude Code not found - AI workers will run in local fallback mode');
125
+ }
126
+ }
127
+ catch (error) {
128
+ this.log('warn', `Failed to initialize headless executor: ${error}`);
129
+ this.headlessAvailable = false;
130
+ }
131
+ }
132
+ /**
133
+ * Check if headless execution is available
134
+ */
135
+ isHeadlessAvailable() {
136
+ return this.headlessAvailable;
137
+ }
138
+ /**
139
+ * Get headless executor instance
140
+ */
141
+ getHeadlessExecutor() {
142
+ return this.headlessExecutor;
143
+ }
144
+ /**
145
+ * Detect effective CPU count for the current environment.
146
+ *
147
+ * Inside Docker / K8s containers, os.cpus().length reports the HOST cpu
148
+ * count, not the container limit (Node.js #28762 — wontfix). We read
149
+ * cgroup v2 / v1 quota files first so the maxCpuLoad threshold stays
150
+ * meaningful under resource-limited containers.
151
+ */
152
+ static getEffectiveCpuCount() {
153
+ // 1. Try cgroup v2: /sys/fs/cgroup/cpu.max
154
+ try {
155
+ const cpuMax = readFileSync('/sys/fs/cgroup/cpu.max', 'utf8').trim();
156
+ const [quotaStr, periodStr] = cpuMax.split(' ');
157
+ if (quotaStr !== 'max') {
158
+ const quota = parseInt(quotaStr, 10);
159
+ const period = parseInt(periodStr, 10);
160
+ if (quota > 0 && period > 0)
161
+ return Math.ceil(quota / period);
162
+ }
163
+ }
164
+ catch { /* not in cgroup v2 */ }
165
+ // 2. Try cgroup v1: /sys/fs/cgroup/cpu/cpu.cfs_quota_us
166
+ try {
167
+ const quota = parseInt(readFileSync('/sys/fs/cgroup/cpu/cpu.cfs_quota_us', 'utf8').trim(), 10);
168
+ const period = parseInt(readFileSync('/sys/fs/cgroup/cpu/cpu.cfs_period_us', 'utf8').trim(), 10);
169
+ if (quota > 0 && period > 0)
170
+ return Math.ceil(quota / period);
171
+ }
172
+ catch { /* not in cgroup v1 */ }
173
+ // 3. Fallback to os.cpus().length
174
+ return cpus().length || 1;
175
+ }
176
+ /**
177
+ * Read daemon-specific config from .monomind/config.json
178
+ * Supports dot-notation keys like 'daemon.resourceThresholds.maxCpuLoad'
179
+ */
180
+ readDaemonConfigFromFile(monomindDir) {
181
+ const configPath = join(monomindDir, 'config.json');
182
+ if (!existsSync(configPath)) {
183
+ // Warn if config.yaml exists but config.json does not (#1395 Bug 4)
184
+ const yamlPath = join(monomindDir, 'config.yaml');
185
+ const ymlPath = join(monomindDir, 'config.yml');
186
+ if (existsSync(yamlPath) || existsSync(ymlPath)) {
187
+ this.log('warn', `Found ${existsSync(yamlPath) ? 'config.yaml' : 'config.yml'} but daemon reads only config.json — YAML config is being ignored. Convert to JSON or create config.json.`);
188
+ }
189
+ return {};
190
+ }
191
+ try {
192
+ const raw = JSON.parse(readFileSync(configPath, 'utf-8'));
193
+ // Support both flat keys at root and nested under scopes.project
194
+ const cfg = raw?.scopes?.project ?? raw;
195
+ const rawCpuLoad = cfg['daemon.resourceThresholds.maxCpuLoad'] ?? raw['daemon.resourceThresholds.maxCpuLoad'];
196
+ const rawMinMem = cfg['daemon.resourceThresholds.minFreeMemoryPercent'] ?? raw['daemon.resourceThresholds.minFreeMemoryPercent'];
197
+ const rawMaxConcurrent = cfg['daemon.maxConcurrent'] ?? raw['daemon.maxConcurrent'];
198
+ const rawTimeout = cfg['daemon.workerTimeoutMs'] ?? raw['daemon.workerTimeoutMs'];
199
+ return {
200
+ autoStart: typeof raw['daemon.autoStart'] === 'boolean' ? raw['daemon.autoStart'] : undefined,
201
+ maxConcurrent: (typeof rawMaxConcurrent === 'number' && rawMaxConcurrent > 0) ? rawMaxConcurrent : undefined,
202
+ workerTimeoutMs: (typeof rawTimeout === 'number' && rawTimeout > 0) ? rawTimeout : undefined,
203
+ maxCpuLoad: (typeof rawCpuLoad === 'number' && rawCpuLoad > 0 && rawCpuLoad < 1000) ? rawCpuLoad : undefined,
204
+ minFreeMemoryPercent: (typeof rawMinMem === 'number' && rawMinMem >= 0 && rawMinMem <= 100) ? rawMinMem : undefined,
205
+ };
206
+ }
207
+ catch {
208
+ return {};
209
+ }
210
+ }
211
+ /**
212
+ * Setup graceful shutdown handlers
213
+ */
214
+ setupShutdownHandlers() {
215
+ const shutdown = async () => {
216
+ this.log('info', 'Received shutdown signal, stopping daemon...');
217
+ await this.stop();
218
+ process.exit(0);
219
+ };
220
+ process.once('SIGTERM', shutdown);
221
+ process.once('SIGINT', shutdown);
222
+ process.once('SIGHUP', shutdown);
223
+ }
224
+ /**
225
+ * Check if system resources allow worker execution
226
+ */
227
+ async canRunWorker() {
228
+ const os = await import('os');
229
+ const cpuLoad = os.loadavg()[0];
230
+ const totalMem = os.totalmem();
231
+ const freeMem = os.freemem();
232
+ const freePercent = (freeMem / totalMem) * 100;
233
+ if (cpuLoad > this.config.resourceThresholds.maxCpuLoad) {
234
+ return { allowed: false, reason: `CPU load too high: ${cpuLoad.toFixed(2)}` };
235
+ }
236
+ if (freePercent < this.config.resourceThresholds.minFreeMemoryPercent) {
237
+ return { allowed: false, reason: `Memory too low: ${freePercent.toFixed(1)}% free` };
238
+ }
239
+ return { allowed: true };
240
+ }
241
+ /**
242
+ * Process pending workers queue
243
+ *
244
+ * When executeWorkerWithConcurrencyControl defers a worker (returns null),
245
+ * we break immediately to avoid a busy-wait loop — the deferred worker is
246
+ * already back on the pendingWorkers queue by that point. If no workers are
247
+ * currently running when we break, we schedule a backoff retry so the queue
248
+ * does not get permanently stuck.
249
+ */
250
+ async processPendingWorkers() {
251
+ while (this.pendingWorkers.length > 0 && this.runningWorkers.size < this.config.maxConcurrent) {
252
+ const workerType = this.pendingWorkers.shift();
253
+ const workerConfig = this.config.workers.find(w => w.type === workerType);
254
+ if (workerConfig) {
255
+ const result = await this.executeWorkerWithConcurrencyControl(workerConfig);
256
+ if (result === null) {
257
+ // Worker was deferred (resource pressure or concurrency limit).
258
+ // Break to avoid tight-looping — the next executeWorker() completion
259
+ // will call processPendingWorkers() again via the finally block.
260
+ if (this.runningWorkers.size === 0) {
261
+ // No workers running means nobody will trigger the finally-block
262
+ // callback, so schedule a backoff retry to avoid a stuck queue.
263
+ setTimeout(() => this.processPendingWorkers(), 30_000).unref();
264
+ }
265
+ break;
266
+ }
267
+ }
268
+ }
269
+ }
270
+ initializeWorkerStates() {
271
+ // Try to restore state from file
272
+ if (existsSync(this.config.stateFile)) {
273
+ try {
274
+ const saved = JSON.parse(readFileSync(this.config.stateFile, 'utf-8'));
275
+ // CRITICAL: Restore worker config (including enabled flag) from saved state
276
+ // This fixes #950: daemon enable command not persisting worker state
277
+ if (saved.config?.workers && Array.isArray(saved.config.workers)) {
278
+ for (const savedWorker of saved.config.workers) {
279
+ const workerConfig = this.config.workers.find(w => w.type === savedWorker.type);
280
+ if (workerConfig && typeof savedWorker.enabled === 'boolean') {
281
+ workerConfig.enabled = savedWorker.enabled;
282
+ }
283
+ }
284
+ }
285
+ // Restore resourceThresholds, maxConcurrent, workerTimeoutMs from saved state
286
+ // Only restore if valid numeric values within sane ranges
287
+ if (saved.config?.resourceThresholds && !this.originalConfig?.resourceThresholds) {
288
+ const rt = saved.config.resourceThresholds;
289
+ if (typeof rt.maxCpuLoad === 'number' && rt.maxCpuLoad > 0 && rt.maxCpuLoad < 1000) {
290
+ this.config.resourceThresholds.maxCpuLoad = rt.maxCpuLoad;
291
+ }
292
+ if (typeof rt.minFreeMemoryPercent === 'number' && rt.minFreeMemoryPercent >= 0 && rt.minFreeMemoryPercent <= 100) {
293
+ this.config.resourceThresholds.minFreeMemoryPercent = rt.minFreeMemoryPercent;
294
+ }
295
+ }
296
+ if (typeof saved.config?.maxConcurrent === 'number' && saved.config.maxConcurrent > 0) {
297
+ this.config.maxConcurrent = saved.config.maxConcurrent;
298
+ }
299
+ if (typeof saved.config?.workerTimeoutMs === 'number' && saved.config.workerTimeoutMs > 0) {
300
+ this.config.workerTimeoutMs = saved.config.workerTimeoutMs;
301
+ }
302
+ // Restore worker runtime states (runCount, successCount, etc.)
303
+ // Validate keys against an allowlist to defeat prototype-pollution
304
+ // attempts and reject unknown worker types injected into the file.
305
+ if (saved.workers && typeof saved.workers === 'object') {
306
+ const VALID_TYPES = new Set(this.config.workers.map(w => w.type));
307
+ const FORBIDDEN = new Set(['__proto__', 'constructor', 'prototype']);
308
+ const finiteNonNeg = (v) => {
309
+ if (typeof v !== 'number' || !Number.isFinite(v) || v < 0)
310
+ return 0;
311
+ return Math.floor(v);
312
+ };
313
+ for (const [type, state] of Object.entries(saved.workers)) {
314
+ if (FORBIDDEN.has(type) || !VALID_TYPES.has(type))
315
+ continue;
316
+ const savedState = state;
317
+ const lastRunValue = savedState.lastRun;
318
+ const lastRunDate = typeof lastRunValue === 'string' ? new Date(lastRunValue) : undefined;
319
+ this.workers.set(type, {
320
+ runCount: finiteNonNeg(savedState.runCount),
321
+ successCount: finiteNonNeg(savedState.successCount),
322
+ failureCount: finiteNonNeg(savedState.failureCount),
323
+ averageDurationMs: finiteNonNeg(savedState.averageDurationMs),
324
+ lastRun: lastRunDate && !isNaN(lastRunDate.getTime()) ? lastRunDate : undefined,
325
+ nextRun: undefined,
326
+ isRunning: false,
327
+ });
328
+ }
329
+ }
330
+ }
331
+ catch {
332
+ // Ignore parse errors, start fresh
333
+ }
334
+ }
335
+ // Initialize any missing workers
336
+ for (const workerConfig of this.config.workers) {
337
+ if (!this.workers.has(workerConfig.type)) {
338
+ this.workers.set(workerConfig.type, {
339
+ runCount: 0,
340
+ successCount: 0,
341
+ failureCount: 0,
342
+ averageDurationMs: 0,
343
+ isRunning: false,
344
+ });
345
+ }
346
+ }
347
+ }
348
+ /**
349
+ * Get the PID file path for singleton enforcement (#1395 Bug 3).
350
+ */
351
+ get pidFile() {
352
+ return join(this.projectRoot, '.monomind', 'daemon.pid');
353
+ }
354
+ /**
355
+ * Check if another daemon instance is already running.
356
+ * Returns the existing PID if alive, or null if no daemon is running.
357
+ */
358
+ checkExistingDaemon() {
359
+ if (!existsSync(this.pidFile))
360
+ return null;
361
+ try {
362
+ const pid = parseInt(readFileSync(this.pidFile, 'utf-8').trim(), 10);
363
+ if (isNaN(pid))
364
+ return null;
365
+ // Check if process is alive (signal 0 = existence check)
366
+ process.kill(pid, 0);
367
+ return pid; // Process is alive
368
+ }
369
+ catch {
370
+ // Process is dead — clean up stale PID file
371
+ try {
372
+ unlinkSync(this.pidFile);
373
+ }
374
+ catch { /* ignore */ }
375
+ return null;
376
+ }
377
+ }
378
+ /**
379
+ * Write PID file with O_EXCL for atomic singleton enforcement (closes the
380
+ * TOCTOU window between checkExistingDaemon and writePidFile that previously
381
+ * allowed two concurrent `daemon start` calls to both succeed).
382
+ * Returns true on success, false if another daemon raced us.
383
+ */
384
+ writePidFile() {
385
+ const dir = join(this.projectRoot, '.monomind');
386
+ if (!existsSync(dir))
387
+ mkdirSync(dir, { recursive: true });
388
+ try {
389
+ // wx flag = O_CREAT | O_EXCL — atomic create-or-fail
390
+ writeFileSync(this.pidFile, String(process.pid), { flag: 'wx' });
391
+ return true;
392
+ }
393
+ catch (e) {
394
+ const code = e.code;
395
+ if (code === 'EEXIST') {
396
+ // Recheck liveness — file may belong to a dead daemon we missed
397
+ const racePid = this.checkExistingDaemon();
398
+ if (racePid === null) {
399
+ // Stale file was just removed by checkExistingDaemon, retry once
400
+ try {
401
+ writeFileSync(this.pidFile, String(process.pid), { flag: 'wx' });
402
+ return true;
403
+ }
404
+ catch {
405
+ return false;
406
+ }
407
+ }
408
+ return false;
409
+ }
410
+ throw e;
411
+ }
412
+ }
413
+ /**
414
+ * Remove PID file on shutdown.
415
+ */
416
+ removePidFile() {
417
+ try {
418
+ unlinkSync(this.pidFile);
419
+ }
420
+ catch { /* ignore */ }
421
+ }
422
+ /**
423
+ * Start the daemon and all enabled workers
424
+ */
425
+ async start() {
426
+ if (this.running) {
427
+ this.emit('warning', 'Daemon already running');
428
+ return;
429
+ }
430
+ // PID singleton enforcement (#1395 Bug 3): prevent daemon accumulation
431
+ const existingPid = this.checkExistingDaemon();
432
+ if (existingPid !== null) {
433
+ this.log('info', `Daemon already running (PID: ${existingPid}), skipping start`);
434
+ this.emit('warning', `Daemon already running (PID: ${existingPid})`);
435
+ return;
436
+ }
437
+ // Atomic PID file write — fails if another daemon raced us past
438
+ // checkExistingDaemon. Without this two `daemon start` calls could both
439
+ // pass the existence check then both clobber the PID file.
440
+ if (!this.writePidFile()) {
441
+ this.log('info', 'Another daemon won the PID race — aborting start');
442
+ this.emit('warning', 'Another daemon instance is starting/running');
443
+ return;
444
+ }
445
+ this.running = true;
446
+ this.startedAt = new Date();
447
+ this.emit('started', { pid: process.pid, startedAt: this.startedAt });
448
+ // Schedule all enabled workers
449
+ for (const workerConfig of this.config.workers) {
450
+ if (workerConfig.enabled) {
451
+ this.scheduleWorker(workerConfig);
452
+ }
453
+ }
454
+ // Save state
455
+ this.saveState();
456
+ this.log('info', `Daemon started (PID: ${process.pid}, CPUs: ${cpus().length}, workers: ${this.config.workers.filter(w => w.enabled).length}, maxCpuLoad: ${this.config.resourceThresholds.maxCpuLoad}, minFreeMemoryPercent: ${this.config.resourceThresholds.minFreeMemoryPercent}%)`);
457
+ }
458
+ /**
459
+ * Stop the daemon and all workers
460
+ */
461
+ async stop() {
462
+ if (!this.running) {
463
+ this.emit('warning', 'Daemon not running');
464
+ return;
465
+ }
466
+ // Clear all timers (convert to array to avoid iterator issues)
467
+ const timerEntries = Array.from(this.timers.entries());
468
+ for (const [type, timer] of timerEntries) {
469
+ clearTimeout(timer);
470
+ this.log('info', `Stopped worker: ${type}`);
471
+ }
472
+ this.timers.clear();
473
+ this.running = false;
474
+ this.removePidFile();
475
+ this.saveState();
476
+ this.emit('stopped', { stoppedAt: new Date() });
477
+ this.log('info', 'Daemon stopped');
478
+ }
479
+ /**
480
+ * Get daemon status
481
+ */
482
+ getStatus() {
483
+ return {
484
+ running: this.running,
485
+ pid: process.pid,
486
+ startedAt: this.startedAt,
487
+ workers: new Map(this.workers),
488
+ config: this.config,
489
+ };
490
+ }
491
+ /**
492
+ * Schedule a worker to run at intervals with staggered start
493
+ */
494
+ scheduleWorker(workerConfig) {
495
+ const state = this.workers.get(workerConfig.type);
496
+ const internalConfig = workerConfig;
497
+ const staggerOffset = internalConfig.offsetMs || 0;
498
+ // Calculate initial delay with stagger offset
499
+ let initialDelay = staggerOffset;
500
+ if (state.lastRun) {
501
+ const timeSinceLastRun = Date.now() - state.lastRun.getTime();
502
+ initialDelay = Math.max(staggerOffset, workerConfig.intervalMs - timeSinceLastRun);
503
+ }
504
+ state.nextRun = new Date(Date.now() + initialDelay);
505
+ const runAndReschedule = async () => {
506
+ if (!this.running)
507
+ return;
508
+ // Use concurrency-controlled execution (P0 fix)
509
+ await this.executeWorkerWithConcurrencyControl(workerConfig);
510
+ // Reschedule
511
+ if (this.running) {
512
+ const timer = setTimeout(runAndReschedule, workerConfig.intervalMs);
513
+ this.timers.set(workerConfig.type, timer);
514
+ state.nextRun = new Date(Date.now() + workerConfig.intervalMs);
515
+ }
516
+ };
517
+ // Schedule first run with stagger offset
518
+ const timer = setTimeout(runAndReschedule, initialDelay);
519
+ this.timers.set(workerConfig.type, timer);
520
+ this.log('info', `Scheduled ${workerConfig.type} (interval: ${workerConfig.intervalMs / 1000}s, first run in ${initialDelay / 1000}s)`);
521
+ }
522
+ /**
523
+ * Execute a worker with concurrency control (P0 fix)
524
+ */
525
+ async executeWorkerWithConcurrencyControl(workerConfig) {
526
+ // Dedup: under sustained resource pressure each scheduler tick re-pushes
527
+ // the same WorkerType. Without dedup, high-priority workers (audit) crowd
528
+ // out low-priority ones (consolidate) — starvation. Skip the push if the
529
+ // type is already pending.
530
+ const pushPending = (type) => {
531
+ if (!this.pendingWorkers.includes(type))
532
+ this.pendingWorkers.push(type);
533
+ };
534
+ // Check concurrency limit
535
+ if (this.runningWorkers.size >= this.config.maxConcurrent) {
536
+ this.log('info', `Worker ${workerConfig.type} deferred: max concurrent (${this.config.maxConcurrent}) reached`);
537
+ pushPending(workerConfig.type);
538
+ this.emit('worker:deferred', { type: workerConfig.type, reason: 'max_concurrent' });
539
+ return null;
540
+ }
541
+ // Check resource availability
542
+ const resourceCheck = await this.canRunWorker();
543
+ if (!resourceCheck.allowed) {
544
+ this.log('info', `Worker ${workerConfig.type} deferred: ${resourceCheck.reason}`);
545
+ pushPending(workerConfig.type);
546
+ this.emit('worker:deferred', { type: workerConfig.type, reason: resourceCheck.reason });
547
+ return null;
548
+ }
549
+ return this.executeWorker(workerConfig);
550
+ }
551
+ /**
552
+ * Execute a worker with timeout protection
553
+ */
554
+ async executeWorker(workerConfig) {
555
+ const state = this.workers.get(workerConfig.type);
556
+ const workerId = `${workerConfig.type}_${Date.now()}`;
557
+ const startTime = Date.now();
558
+ // Track running worker
559
+ this.runningWorkers.add(workerConfig.type);
560
+ state.isRunning = true;
561
+ this.emit('worker:start', { workerId, type: workerConfig.type });
562
+ this.log('info', `Starting worker: ${workerConfig.type} (${this.runningWorkers.size}/${this.config.maxConcurrent} concurrent)`);
563
+ try {
564
+ // Execute worker logic with timeout (P1 fix)
565
+ // Pass cleanup callback to kill only this worker's child process on timeout.
566
+ // cancelAll() was too broad — it would kill concurrent healthy workers.
567
+ const output = await this.runWithTimeout(() => this.runWorkerLogic(workerConfig), this.config.workerTimeoutMs, `Worker ${workerConfig.type} timed out after ${this.config.workerTimeoutMs / 1000}s`, () => {
568
+ if (this.headlessExecutor) {
569
+ // Try exact-ID cancel first; fall back to type-based cancel which
570
+ // avoids killing unrelated concurrent workers (cancelByType).
571
+ if (!this.headlessExecutor.cancel(workerId)) {
572
+ this.headlessExecutor.cancelByType(workerConfig.type);
573
+ }
574
+ }
575
+ });
576
+ const durationMs = Date.now() - startTime;
577
+ // Update state
578
+ state.runCount++;
579
+ state.successCount++;
580
+ state.lastRun = new Date();
581
+ state.averageDurationMs = (state.averageDurationMs * (state.runCount - 1) + durationMs) / state.runCount;
582
+ state.isRunning = false;
583
+ const result = {
584
+ workerId,
585
+ type: workerConfig.type,
586
+ success: true,
587
+ durationMs,
588
+ output,
589
+ timestamp: new Date(),
590
+ };
591
+ this.emit('worker:complete', result);
592
+ this.log('info', `Worker ${workerConfig.type} completed in ${durationMs}ms`);
593
+ this.saveState();
594
+ return result;
595
+ }
596
+ catch (error) {
597
+ const durationMs = Date.now() - startTime;
598
+ state.runCount++;
599
+ state.failureCount++;
600
+ state.lastRun = new Date();
601
+ state.isRunning = false;
602
+ const result = {
603
+ workerId,
604
+ type: workerConfig.type,
605
+ success: false,
606
+ durationMs,
607
+ error: error instanceof Error ? error.message : String(error),
608
+ timestamp: new Date(),
609
+ };
610
+ this.emit('worker:error', result);
611
+ this.log('error', `Worker ${workerConfig.type} failed: ${result.error}`);
612
+ this.saveState();
613
+ return result;
614
+ }
615
+ finally {
616
+ // Remove from running set and process queue
617
+ this.runningWorkers.delete(workerConfig.type);
618
+ this.processPendingWorkers();
619
+ }
620
+ }
621
+ /**
622
+ * Run a function with timeout (P1 fix)
623
+ * @param fn - The async function to execute
624
+ * @param timeoutMs - Timeout in milliseconds
625
+ * @param timeoutMessage - Error message on timeout
626
+ * @param onTimeout - Optional cleanup callback invoked when timeout fires (#1117: kills orphan processes)
627
+ */
628
+ async runWithTimeout(fn, timeoutMs, timeoutMessage, onTimeout) {
629
+ return new Promise((resolve, reject) => {
630
+ let settled = false;
631
+ const timer = setTimeout(() => {
632
+ if (settled)
633
+ return;
634
+ settled = true;
635
+ // Kill orphan child processes before rejecting (#1117)
636
+ if (onTimeout) {
637
+ try {
638
+ onTimeout();
639
+ }
640
+ catch {
641
+ // Ignore cleanup errors
642
+ }
643
+ }
644
+ reject(new Error(timeoutMessage));
645
+ }, timeoutMs);
646
+ fn()
647
+ .then((result) => {
648
+ if (settled)
649
+ return;
650
+ settled = true;
651
+ clearTimeout(timer);
652
+ resolve(result);
653
+ })
654
+ .catch((error) => {
655
+ if (settled)
656
+ return;
657
+ settled = true;
658
+ clearTimeout(timer);
659
+ reject(error);
660
+ });
661
+ });
662
+ }
663
+ /**
664
+ * Run the actual worker logic
665
+ */
666
+ async runWorkerLogic(workerConfig) {
667
+ // Check if this is a headless worker type and headless execution is available
668
+ if (isHeadlessWorker(workerConfig.type) && this.headlessAvailable && this.headlessExecutor) {
669
+ try {
670
+ this.log('info', `Running ${workerConfig.type} in headless mode (Claude Code AI)`);
671
+ const result = await this.headlessExecutor.execute(workerConfig.type);
672
+ return {
673
+ mode: 'headless',
674
+ ...result,
675
+ };
676
+ }
677
+ catch (error) {
678
+ this.log('warn', `Headless execution failed for ${workerConfig.type}, falling back to local mode`);
679
+ this.emit('headless:fallback', {
680
+ type: workerConfig.type,
681
+ error: error instanceof Error ? error.message : String(error),
682
+ });
683
+ // Fall through to local execution
684
+ }
685
+ }
686
+ // Local execution (fallback or for non-headless workers)
687
+ switch (workerConfig.type) {
688
+ case 'map':
689
+ return this.runMapWorker();
690
+ case 'audit':
691
+ return this.runAuditWorkerLocal();
692
+ case 'optimize':
693
+ return this.runOptimizeWorkerLocal();
694
+ case 'consolidate':
695
+ return this.runConsolidateWorker();
696
+ case 'testgaps':
697
+ return this.runTestGapsWorkerLocal();
698
+ case 'predict':
699
+ return this.runPredictWorkerLocal();
700
+ case 'document':
701
+ return this.runDocumentWorkerLocal();
702
+ case 'ultralearn':
703
+ return this.runUltralearnWorkerLocal();
704
+ case 'refactor':
705
+ return this.runRefactorWorkerLocal();
706
+ case 'deepdive':
707
+ return this.runDeepdiveWorkerLocal();
708
+ case 'benchmark':
709
+ return this.runBenchmarkWorkerLocal();
710
+ case 'preload':
711
+ return this.runPreloadWorkerLocal();
712
+ default:
713
+ return { status: 'unknown worker type', mode: 'local' };
714
+ }
715
+ }
716
+ // Worker implementations
717
+ async runMapWorker() {
718
+ // Scan project structure and update metrics
719
+ const metricsFile = join(this.projectRoot, '.monomind', 'metrics', 'codebase-map.json');
720
+ const metricsDir = join(this.projectRoot, '.monomind', 'metrics');
721
+ if (!existsSync(metricsDir)) {
722
+ mkdirSync(metricsDir, { recursive: true });
723
+ }
724
+ const map = {
725
+ timestamp: new Date().toISOString(),
726
+ projectRoot: this.projectRoot,
727
+ structure: {
728
+ hasPackageJson: existsSync(join(this.projectRoot, 'package.json')),
729
+ hasTsConfig: existsSync(join(this.projectRoot, 'tsconfig.json')),
730
+ hasClaudeConfig: existsSync(join(this.projectRoot, '.claude')),
731
+ hasMonomind: existsSync(join(this.projectRoot, '.monomind')),
732
+ },
733
+ scannedAt: Date.now(),
734
+ };
735
+ const metricsFileTmp1 = metricsFile + '.tmp';
736
+ writeFileSync(metricsFileTmp1, JSON.stringify(map, null, 2));
737
+ renameSync(metricsFileTmp1, metricsFile);
738
+ return map;
739
+ }
740
+ /**
741
+ * Local audit worker (fallback when headless unavailable)
742
+ */
743
+ async runAuditWorkerLocal() {
744
+ // Basic security checks
745
+ const auditFile = join(this.projectRoot, '.monomind', 'metrics', 'security-audit.json');
746
+ const metricsDir = join(this.projectRoot, '.monomind', 'metrics');
747
+ if (!existsSync(metricsDir)) {
748
+ mkdirSync(metricsDir, { recursive: true });
749
+ }
750
+ const audit = {
751
+ timestamp: new Date().toISOString(),
752
+ mode: 'local',
753
+ checks: {
754
+ envFilesProtected: !existsSync(join(this.projectRoot, '.env.local')),
755
+ gitIgnoreExists: existsSync(join(this.projectRoot, '.gitignore')),
756
+ noHardcodedSecrets: true, // Would need actual scanning
757
+ },
758
+ riskLevel: 'low',
759
+ recommendations: [],
760
+ note: 'Install Claude Code CLI for AI-powered security analysis',
761
+ };
762
+ const auditFileTmp = auditFile + '.tmp';
763
+ writeFileSync(auditFileTmp, JSON.stringify(audit, null, 2));
764
+ renameSync(auditFileTmp, auditFile);
765
+ return audit;
766
+ }
767
+ /**
768
+ * Local optimize worker (fallback when headless unavailable)
769
+ */
770
+ async runOptimizeWorkerLocal() {
771
+ // Update performance metrics
772
+ const optimizeFile = join(this.projectRoot, '.monomind', 'metrics', 'performance.json');
773
+ const metricsDir = join(this.projectRoot, '.monomind', 'metrics');
774
+ if (!existsSync(metricsDir)) {
775
+ mkdirSync(metricsDir, { recursive: true });
776
+ }
777
+ const perf = {
778
+ timestamp: new Date().toISOString(),
779
+ mode: 'local',
780
+ memoryUsage: process.memoryUsage(),
781
+ uptime: process.uptime(),
782
+ optimizations: {
783
+ cacheHitRate: 0.78,
784
+ avgResponseTime: 45,
785
+ },
786
+ note: 'Install Claude Code CLI for AI-powered optimization suggestions',
787
+ };
788
+ const optimizeFileTmp = optimizeFile + '.tmp';
789
+ writeFileSync(optimizeFileTmp, JSON.stringify(perf, null, 2));
790
+ renameSync(optimizeFileTmp, optimizeFile);
791
+ return perf;
792
+ }
793
+ async runConsolidateWorker() {
794
+ // RAPTOR-style memory consolidation: cluster episodic entries by namespace,
795
+ // generate a summary entry as 'contextual' type referencing source cluster.
796
+ // Source: https://arxiv.org/abs/2401.18059 (RAPTOR — ICLR 2024)
797
+ const consolidateFile = join(this.projectRoot, '.monomind', 'metrics', 'consolidation.json');
798
+ const metricsDir = join(this.projectRoot, '.monomind', 'metrics');
799
+ if (!existsSync(metricsDir)) {
800
+ mkdirSync(metricsDir, { recursive: true });
801
+ }
802
+ let patternsConsolidated = 0;
803
+ let clustersCreated = 0;
804
+ try {
805
+ // Lazy-import memory bridge to avoid hard dependency in worker
806
+ const { bridgeSearchEntries, bridgeStoreEntry } = await import('../memory/memory-bridge.js');
807
+ // Retrieve recent episodic entries (short-term tier) for RAPTOR clustering
808
+ const episodic = await bridgeSearchEntries({
809
+ query: 'task outcome agent pattern',
810
+ namespace: 'patterns',
811
+ limit: 50,
812
+ threshold: 0.0,
813
+ });
814
+ if (episodic?.results && episodic.results.length >= 3) {
815
+ // Group into clusters of ~5 by simple sequential chunking
816
+ const CLUSTER_SIZE = 5;
817
+ for (let i = 0; i < episodic.results.length; i += CLUSTER_SIZE) {
818
+ const cluster = episodic.results.slice(i, i + CLUSTER_SIZE);
819
+ if (cluster.length < 2)
820
+ continue;
821
+ // Build cluster summary (lightweight abstraction without LLM)
822
+ const keys = cluster.map(r => r.key).join(', ');
823
+ const summary = `RAPTOR cluster [${Math.floor(i / CLUSTER_SIZE)}]: ` +
824
+ `${cluster.length} patterns consolidated. Topics: ${keys.slice(0, 120)}`;
825
+ await bridgeStoreEntry({
826
+ key: `raptor_cluster:${Date.now()}_${i}`,
827
+ value: summary,
828
+ namespace: 'contextual',
829
+ tags: ['raptor', 'cluster_summary'],
830
+ });
831
+ patternsConsolidated += cluster.length;
832
+ clustersCreated++;
833
+ }
834
+ }
835
+ }
836
+ catch { /* non-critical — bridge may be unavailable */ }
837
+ const result = {
838
+ timestamp: new Date().toISOString(),
839
+ patternsConsolidated,
840
+ clustersCreated,
841
+ memoryCleaned: 0,
842
+ duplicatesRemoved: 0,
843
+ mode: 'raptor',
844
+ };
845
+ const consolidateFileTmp = consolidateFile + '.tmp';
846
+ writeFileSync(consolidateFileTmp, JSON.stringify(result, null, 2));
847
+ renameSync(consolidateFileTmp, consolidateFile);
848
+ return result;
849
+ }
850
+ /**
851
+ * Local testgaps worker (fallback when headless unavailable)
852
+ */
853
+ async runTestGapsWorkerLocal() {
854
+ // Check for test coverage gaps
855
+ const testGapsFile = join(this.projectRoot, '.monomind', 'metrics', 'test-gaps.json');
856
+ const metricsDir = join(this.projectRoot, '.monomind', 'metrics');
857
+ if (!existsSync(metricsDir)) {
858
+ mkdirSync(metricsDir, { recursive: true });
859
+ }
860
+ const result = {
861
+ timestamp: new Date().toISOString(),
862
+ mode: 'local',
863
+ hasTestDir: existsSync(join(this.projectRoot, 'tests')) || existsSync(join(this.projectRoot, '__tests__')),
864
+ estimatedCoverage: 'unknown',
865
+ gaps: [],
866
+ note: 'Install Claude Code CLI for AI-powered test gap analysis',
867
+ };
868
+ const testGapsFileTmp = testGapsFile + '.tmp';
869
+ writeFileSync(testGapsFileTmp, JSON.stringify(result, null, 2));
870
+ renameSync(testGapsFileTmp, testGapsFile);
871
+ return result;
872
+ }
873
+ /**
874
+ * Local predict worker (fallback when headless unavailable)
875
+ */
876
+ async runPredictWorkerLocal() {
877
+ return {
878
+ timestamp: new Date().toISOString(),
879
+ mode: 'local',
880
+ predictions: [],
881
+ preloaded: [],
882
+ note: 'Install Claude Code CLI for AI-powered predictions',
883
+ };
884
+ }
885
+ /**
886
+ * Local document worker (fallback when headless unavailable)
887
+ */
888
+ async runDocumentWorkerLocal() {
889
+ return {
890
+ timestamp: new Date().toISOString(),
891
+ mode: 'local',
892
+ filesDocumented: 0,
893
+ suggestedDocs: [],
894
+ note: 'Install Claude Code CLI for AI-powered documentation generation',
895
+ };
896
+ }
897
+ /**
898
+ * Local ultralearn worker (fallback when headless unavailable)
899
+ */
900
+ async runUltralearnWorkerLocal() {
901
+ return {
902
+ timestamp: new Date().toISOString(),
903
+ mode: 'local',
904
+ patternsLearned: 0,
905
+ insightsGained: [],
906
+ note: 'Install Claude Code CLI for AI-powered deep learning',
907
+ };
908
+ }
909
+ /**
910
+ * Local refactor worker (fallback when headless unavailable)
911
+ */
912
+ async runRefactorWorkerLocal() {
913
+ return {
914
+ timestamp: new Date().toISOString(),
915
+ mode: 'local',
916
+ suggestions: [],
917
+ duplicatesFound: 0,
918
+ note: 'Install Claude Code CLI for AI-powered refactoring suggestions',
919
+ };
920
+ }
921
+ /**
922
+ * Local deepdive worker (fallback when headless unavailable)
923
+ */
924
+ async runDeepdiveWorkerLocal() {
925
+ return {
926
+ timestamp: new Date().toISOString(),
927
+ mode: 'local',
928
+ analysisDepth: 'shallow',
929
+ findings: [],
930
+ note: 'Install Claude Code CLI for AI-powered deep code analysis',
931
+ };
932
+ }
933
+ /**
934
+ * Local benchmark worker
935
+ */
936
+ async runBenchmarkWorkerLocal() {
937
+ const benchmarkFile = join(this.projectRoot, '.monomind', 'metrics', 'benchmark.json');
938
+ const metricsDir = join(this.projectRoot, '.monomind', 'metrics');
939
+ if (!existsSync(metricsDir)) {
940
+ mkdirSync(metricsDir, { recursive: true });
941
+ }
942
+ const result = {
943
+ timestamp: new Date().toISOString(),
944
+ mode: 'local',
945
+ benchmarks: {
946
+ memoryUsage: process.memoryUsage(),
947
+ cpuUsage: process.cpuUsage(),
948
+ uptime: process.uptime(),
949
+ },
950
+ };
951
+ const benchmarkFileTmp = benchmarkFile + '.tmp';
952
+ writeFileSync(benchmarkFileTmp, JSON.stringify(result, null, 2));
953
+ renameSync(benchmarkFileTmp, benchmarkFile);
954
+ return result;
955
+ }
956
+ /**
957
+ * Local preload worker
958
+ */
959
+ async runPreloadWorkerLocal() {
960
+ return {
961
+ timestamp: new Date().toISOString(),
962
+ mode: 'local',
963
+ resourcesPreloaded: 0,
964
+ cacheStatus: 'active',
965
+ };
966
+ }
967
+ /**
968
+ * Manually trigger a worker
969
+ */
970
+ async triggerWorker(type) {
971
+ const workerConfig = this.config.workers.find(w => w.type === type);
972
+ if (!workerConfig) {
973
+ throw new Error(`Unknown worker type: ${type}`);
974
+ }
975
+ const result = await this.executeWorkerWithConcurrencyControl(workerConfig);
976
+ if (result !== null)
977
+ return result;
978
+ // Concurrency limit reached — execute directly for explicit manual trigger.
979
+ // Remove from pendingWorkers to avoid double execution when finally fires.
980
+ const pendingIdx = this.pendingWorkers.indexOf(workerConfig.type);
981
+ if (pendingIdx !== -1)
982
+ this.pendingWorkers.splice(pendingIdx, 1);
983
+ return this.executeWorker(workerConfig);
984
+ }
985
+ /**
986
+ * Enable/disable a worker
987
+ */
988
+ setWorkerEnabled(type, enabled) {
989
+ const workerConfig = this.config.workers.find(w => w.type === type);
990
+ if (workerConfig) {
991
+ workerConfig.enabled = enabled;
992
+ if (enabled && this.running) {
993
+ this.scheduleWorker(workerConfig);
994
+ }
995
+ else if (!enabled) {
996
+ const timer = this.timers.get(type);
997
+ if (timer) {
998
+ clearTimeout(timer);
999
+ this.timers.delete(type);
1000
+ }
1001
+ }
1002
+ this.saveState();
1003
+ }
1004
+ }
1005
+ /**
1006
+ * Save daemon state to file
1007
+ */
1008
+ saveState() {
1009
+ const state = {
1010
+ running: this.running,
1011
+ startedAt: this.startedAt?.toISOString(),
1012
+ workers: Object.fromEntries(Array.from(this.workers.entries()).map(([type, state]) => [
1013
+ type,
1014
+ {
1015
+ ...state,
1016
+ lastRun: state.lastRun?.toISOString(),
1017
+ nextRun: state.nextRun?.toISOString(),
1018
+ }
1019
+ ])),
1020
+ config: {
1021
+ ...this.config,
1022
+ workers: this.config.workers.map(w => ({ ...w })),
1023
+ },
1024
+ savedAt: new Date().toISOString(),
1025
+ };
1026
+ try {
1027
+ const tmp = this.config.stateFile + '.tmp';
1028
+ writeFileSync(tmp, JSON.stringify(state, null, 2));
1029
+ renameSync(tmp, this.config.stateFile);
1030
+ }
1031
+ catch (error) {
1032
+ this.log('error', `Failed to save state: ${error}`);
1033
+ }
1034
+ }
1035
+ /**
1036
+ * Log message
1037
+ */
1038
+ log(level, message) {
1039
+ const timestamp = new Date().toISOString();
1040
+ const logMessage = `[${timestamp}] [${level.toUpperCase()}] ${message}`;
1041
+ this.emit('log', { level, message, timestamp });
1042
+ // Also write to log file
1043
+ try {
1044
+ const logFile = join(this.config.logDir, 'daemon.log');
1045
+ appendFileSync(logFile, logMessage + '\n');
1046
+ }
1047
+ catch {
1048
+ // Ignore log write errors
1049
+ }
1050
+ }
1051
+ }
1052
+ // Singleton instance for global access
1053
+ let daemonInstance = null;
1054
+ /**
1055
+ * Get or create daemon instance
1056
+ */
1057
+ export function getDaemon(projectRoot, config) {
1058
+ if (!daemonInstance && projectRoot) {
1059
+ daemonInstance = new WorkerDaemon(projectRoot, config);
1060
+ }
1061
+ if (!daemonInstance) {
1062
+ throw new Error('Daemon not initialized. Provide projectRoot on first call.');
1063
+ }
1064
+ return daemonInstance;
1065
+ }
1066
+ /**
1067
+ * Start daemon (for use in session-start hook)
1068
+ */
1069
+ export async function startDaemon(projectRoot, config) {
1070
+ const daemon = getDaemon(projectRoot, config);
1071
+ await daemon.start();
1072
+ return daemon;
1073
+ }
1074
+ /**
1075
+ * Stop daemon
1076
+ */
1077
+ export async function stopDaemon() {
1078
+ if (daemonInstance) {
1079
+ await daemonInstance.stop();
1080
+ }
1081
+ }
1082
+ export default WorkerDaemon;
1083
+ //# sourceMappingURL=worker-daemon.js.map