mixdog 0.7.1

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 (404) hide show
  1. package/.claude-plugin/marketplace.json +31 -0
  2. package/.claude-plugin/plugin.json +20 -0
  3. package/.gitattributes +34 -0
  4. package/.mcp.json +14 -0
  5. package/ARCHITECTURE.md +77 -0
  6. package/CHANGELOG.md +7 -0
  7. package/CONTRIBUTING.md +45 -0
  8. package/DATA-FLOW.md +79 -0
  9. package/LICENSE +21 -0
  10. package/README.md +389 -0
  11. package/SECURITY.md +138 -0
  12. package/UNINSTALL.md +112 -0
  13. package/agents/maintenance.md +5 -0
  14. package/agents/memory-classification.md +30 -0
  15. package/agents/scheduler-task.md +18 -0
  16. package/agents/webhook-handler.md +27 -0
  17. package/agents/worker.md +24 -0
  18. package/bin/bridge +133 -0
  19. package/bin/statusline-launcher.mjs +78 -0
  20. package/bin/statusline-lib.mjs +550 -0
  21. package/bin/statusline.mjs +607 -0
  22. package/bun.lock +802 -0
  23. package/commands/config.md +16 -0
  24. package/commands/doctor.md +13 -0
  25. package/commands/setup.md +17 -0
  26. package/defaults/cycle3-review-prompt.md +90 -0
  27. package/defaults/hidden-roles.json +65 -0
  28. package/defaults/memory-chunk-prompt.md +63 -0
  29. package/defaults/memory-promote-prompt.md +135 -0
  30. package/defaults/mixdog-config.template.json +27 -0
  31. package/defaults/user-workflow.json +8 -0
  32. package/defaults/user-workflow.md +12 -0
  33. package/hooks/hooks.json +73 -0
  34. package/hooks/lib/active-instance.cjs +77 -0
  35. package/hooks/lib/permission-evaluator.cjs +411 -0
  36. package/hooks/lib/permission-route.cjs +63 -0
  37. package/hooks/lib/permission-rules.cjs +170 -0
  38. package/hooks/lib/settings-loader.cjs +116 -0
  39. package/hooks/post-tool-use.cjs +84 -0
  40. package/hooks/pre-mcp-sandbox.cjs +158 -0
  41. package/hooks/pre-tool-subagent.cjs +253 -0
  42. package/hooks/session-start.cjs +1372 -0
  43. package/hooks/turn-timer.cjs +82 -0
  44. package/lib/claude-md-writer.cjs +386 -0
  45. package/lib/config-cjs.cjs +61 -0
  46. package/lib/hook-pipe-path.cjs +10 -0
  47. package/lib/keychain-cjs.cjs +263 -0
  48. package/lib/plugin-paths.cjs +61 -0
  49. package/lib/rules-builder.cjs +241 -0
  50. package/lib/text-utils.cjs +61 -0
  51. package/native/README.md +117 -0
  52. package/native/prebuilt/linux-aarch64/mixdog-shim +0 -0
  53. package/native/prebuilt/linux-x86_64/mixdog-shim +0 -0
  54. package/native/prebuilt/macos-aarch64/mixdog-shim +0 -0
  55. package/native/prebuilt/macos-x86_64/mixdog-shim +0 -0
  56. package/native/prebuilt/windows-x86_64/mixdog-shim.exe +0 -0
  57. package/package.json +107 -0
  58. package/prompts/code-review.txt +16 -0
  59. package/prompts/security-audit.txt +17 -0
  60. package/rules/bridge/00-common.md +39 -0
  61. package/rules/bridge/20-skip-protocol.md +18 -0
  62. package/rules/bridge/30-explorer.md +33 -0
  63. package/rules/bridge/40-cycle1-agent.md +52 -0
  64. package/rules/bridge/41-cycle2-agent.md +62 -0
  65. package/rules/bridge/42-cycle3-agent.md +44 -0
  66. package/rules/lead/00-tool-lead.md +61 -0
  67. package/rules/lead/01-general.md +23 -0
  68. package/rules/lead/02-channels.md +49 -0
  69. package/rules/lead/03-team.md +27 -0
  70. package/rules/lead/04-workflow.md +20 -0
  71. package/rules/shared/00-language.md +14 -0
  72. package/rules/shared/01-tool.md +138 -0
  73. package/scripts/bootstrap.mjs +184 -0
  74. package/scripts/bridge-unify-smoke.mjs +308 -0
  75. package/scripts/build-runtime-linux.sh +348 -0
  76. package/scripts/build-runtime-macos.sh +217 -0
  77. package/scripts/build-runtime-windows.ps1 +242 -0
  78. package/scripts/builtin-utils-smoke.mjs +392 -0
  79. package/scripts/check-json.mjs +45 -0
  80. package/scripts/check-syntax-changed.mjs +102 -0
  81. package/scripts/check-syntax.mjs +58 -0
  82. package/scripts/code-graph-batch.test.mjs +33 -0
  83. package/scripts/config-preserve-smoke.mjs +180 -0
  84. package/scripts/doctor.mjs +484 -0
  85. package/scripts/edit-normalize-fuzz.mjs +130 -0
  86. package/scripts/edit-normalize-smoke.mjs +401 -0
  87. package/scripts/edit-operation-smoke.mjs +369 -0
  88. package/scripts/edit2-smoke.mjs +63 -0
  89. package/scripts/fuzzy-e2e.mjs +28 -0
  90. package/scripts/fuzzy-smoke.mjs +26 -0
  91. package/scripts/generate-runtime-manifest.mjs +166 -0
  92. package/scripts/guard-smoke.mjs +66 -0
  93. package/scripts/hidden-role-schema-smoke.mjs +162 -0
  94. package/scripts/hook-routing-smoke.mjs +29 -0
  95. package/scripts/inject-input.ps1 +204 -0
  96. package/scripts/io-complex-smoke.mjs +667 -0
  97. package/scripts/io-explore-bench.mjs +424 -0
  98. package/scripts/io-guardrails-smoke.mjs +205 -0
  99. package/scripts/io-mini-bench-baseline.json +11 -0
  100. package/scripts/io-mini-bench.mjs +216 -0
  101. package/scripts/io-route-harness.mjs +933 -0
  102. package/scripts/io-telemetry-report.mjs +691 -0
  103. package/scripts/mutation-bench.mjs +564 -0
  104. package/scripts/mutation-io-smoke.mjs +1081 -0
  105. package/scripts/native-patch-bridge-smoke.mjs +288 -0
  106. package/scripts/native-patch-smoke.mjs +304 -0
  107. package/scripts/patch-interior-context-smoke.mjs +49 -0
  108. package/scripts/patch-newline-utf8-smoke.mjs +157 -0
  109. package/scripts/perf-hook-smoke.mjs +71 -0
  110. package/scripts/permission-eval-smoke.mjs +426 -0
  111. package/scripts/prep-patch.mjs +53 -0
  112. package/scripts/prep-shim.mjs +96 -0
  113. package/scripts/provider-cache-smoke.mjs +687 -0
  114. package/scripts/report-runtime-health.mjs +132 -0
  115. package/scripts/run-mcp.mjs +1547 -0
  116. package/scripts/salvage-v4a-shatter.test.mjs +58 -0
  117. package/scripts/scoped-cache-io-smoke.mjs +103 -0
  118. package/scripts/shell-policy-round3-smoke.mjs +46 -0
  119. package/scripts/smoke-runtime-negative.ps1 +100 -0
  120. package/scripts/smoke-runtime-negative.sh +95 -0
  121. package/scripts/stall-policy-smoke.mjs +50 -0
  122. package/scripts/start-memory-worker.mjs +23 -0
  123. package/scripts/statusline-launcher-smoke.mjs +82 -0
  124. package/scripts/stress-atomic-write.mjs +1028 -0
  125. package/scripts/test-config-rmw-restore.mjs +122 -0
  126. package/scripts/test-fault-inject.mjs +164 -0
  127. package/scripts/test-large-file.mjs +174 -0
  128. package/scripts/tool-edge-smoke.mjs +209 -0
  129. package/scripts/uninstall.mjs +201 -0
  130. package/scripts/webhook-selfheal-smoke.mjs +29 -0
  131. package/scripts/write-overwrite-guard-smoke.mjs +56 -0
  132. package/server-main.mjs +3055 -0
  133. package/server.mjs +468 -0
  134. package/setup/config-merge.mjs +254 -0
  135. package/setup/install.mjs +120 -0
  136. package/setup/launch-core.mjs +507 -0
  137. package/setup/launch.mjs +101 -0
  138. package/setup/setup-server.mjs +3206 -0
  139. package/setup/setup.html +3693 -0
  140. package/skills/retro-skill-proposer/SKILL.md +92 -0
  141. package/skills/schedule-add/SKILL.md +77 -0
  142. package/skills/setup/SKILL.md +346 -0
  143. package/skills/webhook-add/SKILL.md +81 -0
  144. package/src/agent/bridge-stall-watchdog.mjs +337 -0
  145. package/src/agent/index.mjs +2138 -0
  146. package/src/agent/orchestrator/activity-bus.mjs +38 -0
  147. package/src/agent/orchestrator/ai-wrapped-dispatch.mjs +1010 -0
  148. package/src/agent/orchestrator/bridge-retry.mjs +220 -0
  149. package/src/agent/orchestrator/bridge-trace.mjs +583 -0
  150. package/src/agent/orchestrator/cache-mtime.mjs +58 -0
  151. package/src/agent/orchestrator/config.mjs +358 -0
  152. package/src/agent/orchestrator/context/collect.mjs +651 -0
  153. package/src/agent/orchestrator/dispatch-persist.mjs +549 -0
  154. package/src/agent/orchestrator/drain-registry.mjs +50 -0
  155. package/src/agent/orchestrator/explore-validator.mjs +8 -0
  156. package/src/agent/orchestrator/internal-roles.mjs +118 -0
  157. package/src/agent/orchestrator/internal-tools.mjs +88 -0
  158. package/src/agent/orchestrator/jobs.mjs +116 -0
  159. package/src/agent/orchestrator/mcp/client.mjs +364 -0
  160. package/src/agent/orchestrator/providers/anthropic-betas.mjs +21 -0
  161. package/src/agent/orchestrator/providers/anthropic-oauth.mjs +1745 -0
  162. package/src/agent/orchestrator/providers/anthropic.mjs +437 -0
  163. package/src/agent/orchestrator/providers/gemini.mjs +1175 -0
  164. package/src/agent/orchestrator/providers/grok-oauth.mjs +782 -0
  165. package/src/agent/orchestrator/providers/model-catalog.mjs +241 -0
  166. package/src/agent/orchestrator/providers/openai-compat.mjs +1467 -0
  167. package/src/agent/orchestrator/providers/openai-oauth-ws.mjs +1890 -0
  168. package/src/agent/orchestrator/providers/openai-oauth.mjs +1307 -0
  169. package/src/agent/orchestrator/providers/openai-ws.mjs +104 -0
  170. package/src/agent/orchestrator/providers/registry.mjs +192 -0
  171. package/src/agent/orchestrator/providers/retry-classifier.mjs +325 -0
  172. package/src/agent/orchestrator/session/abort-lookup.mjs +13 -0
  173. package/src/agent/orchestrator/session/cache/post-edit-marks.mjs +42 -0
  174. package/src/agent/orchestrator/session/cache/prefetch-cache.mjs +142 -0
  175. package/src/agent/orchestrator/session/cache/read-cache.mjs +319 -0
  176. package/src/agent/orchestrator/session/cache/scoped-cache-outcome.mjs +11 -0
  177. package/src/agent/orchestrator/session/cache/scoped-cache.mjs +361 -0
  178. package/src/agent/orchestrator/session/cache/util.mjs +49 -0
  179. package/src/agent/orchestrator/session/loop.mjs +1478 -0
  180. package/src/agent/orchestrator/session/manager.mjs +1975 -0
  181. package/src/agent/orchestrator/session/read-dedup.mjs +6 -0
  182. package/src/agent/orchestrator/session/result-classification.mjs +65 -0
  183. package/src/agent/orchestrator/session/save-session-worker.mjs +18 -0
  184. package/src/agent/orchestrator/session/store.mjs +624 -0
  185. package/src/agent/orchestrator/session/stream-watchdog.mjs +130 -0
  186. package/src/agent/orchestrator/session/tool-result-offload.mjs +166 -0
  187. package/src/agent/orchestrator/session/trim.mjs +491 -0
  188. package/src/agent/orchestrator/smart-bridge/CACHE-SHARD.md +115 -0
  189. package/src/agent/orchestrator/smart-bridge/bridge-llm.mjs +327 -0
  190. package/src/agent/orchestrator/smart-bridge/cache-obs.mjs +150 -0
  191. package/src/agent/orchestrator/smart-bridge/cache-strategy.mjs +228 -0
  192. package/src/agent/orchestrator/smart-bridge/index.mjs +215 -0
  193. package/src/agent/orchestrator/smart-bridge/profiles.mjs +37 -0
  194. package/src/agent/orchestrator/smart-bridge/registry.mjs +348 -0
  195. package/src/agent/orchestrator/smart-bridge/session-builder.mjs +116 -0
  196. package/src/agent/orchestrator/stall-policy.mjs +195 -0
  197. package/src/agent/orchestrator/tool-loop-guard.mjs +75 -0
  198. package/src/agent/orchestrator/tools/bash-policy-scan.mjs +77 -0
  199. package/src/agent/orchestrator/tools/bash-session.mjs +721 -0
  200. package/src/agent/orchestrator/tools/builtin/advisory-lock.mjs +171 -0
  201. package/src/agent/orchestrator/tools/builtin/arg-guard.mjs +455 -0
  202. package/src/agent/orchestrator/tools/builtin/atomic-write.mjs +236 -0
  203. package/src/agent/orchestrator/tools/builtin/bash-tool.mjs +480 -0
  204. package/src/agent/orchestrator/tools/builtin/binary-file.mjs +76 -0
  205. package/src/agent/orchestrator/tools/builtin/builtin-tools.mjs +256 -0
  206. package/src/agent/orchestrator/tools/builtin/cache-layers.mjs +386 -0
  207. package/src/agent/orchestrator/tools/builtin/cwd-utils.mjs +37 -0
  208. package/src/agent/orchestrator/tools/builtin/device-paths.mjs +154 -0
  209. package/src/agent/orchestrator/tools/builtin/diagnostics-tool.mjs +292 -0
  210. package/src/agent/orchestrator/tools/builtin/diff-utils.mjs +109 -0
  211. package/src/agent/orchestrator/tools/builtin/edit-base-guard.mjs +58 -0
  212. package/src/agent/orchestrator/tools/builtin/edit-byte-plan.mjs +240 -0
  213. package/src/agent/orchestrator/tools/builtin/edit-byte-utils.mjs +113 -0
  214. package/src/agent/orchestrator/tools/builtin/edit-commit.mjs +74 -0
  215. package/src/agent/orchestrator/tools/builtin/edit-context-utils.mjs +242 -0
  216. package/src/agent/orchestrator/tools/builtin/edit-diagnostics.mjs +211 -0
  217. package/src/agent/orchestrator/tools/builtin/edit-engine.mjs +1364 -0
  218. package/src/agent/orchestrator/tools/builtin/edit-failure-context.mjs +126 -0
  219. package/src/agent/orchestrator/tools/builtin/edit-hint.mjs +141 -0
  220. package/src/agent/orchestrator/tools/builtin/edit-match-utils.mjs +194 -0
  221. package/src/agent/orchestrator/tools/builtin/edit-partial-write.mjs +60 -0
  222. package/src/agent/orchestrator/tools/builtin/edit-stale-refresh.mjs +168 -0
  223. package/src/agent/orchestrator/tools/builtin/edit-tool.mjs +173 -0
  224. package/src/agent/orchestrator/tools/builtin/edit-utf8-guard.mjs +48 -0
  225. package/src/agent/orchestrator/tools/builtin/fs-reachability.mjs +48 -0
  226. package/src/agent/orchestrator/tools/builtin/fuzzy-match.mjs +99 -0
  227. package/src/agent/orchestrator/tools/builtin/glob-walk.mjs +170 -0
  228. package/src/agent/orchestrator/tools/builtin/grep-formatting.mjs +113 -0
  229. package/src/agent/orchestrator/tools/builtin/hash-utils.mjs +6 -0
  230. package/src/agent/orchestrator/tools/builtin/list-formatting.mjs +7 -0
  231. package/src/agent/orchestrator/tools/builtin/list-tool.mjs +593 -0
  232. package/src/agent/orchestrator/tools/builtin/native-edit-runner.mjs +89 -0
  233. package/src/agent/orchestrator/tools/builtin/notebook-edit-tool.mjs +300 -0
  234. package/src/agent/orchestrator/tools/builtin/open-config-tool.mjs +26 -0
  235. package/src/agent/orchestrator/tools/builtin/path-diagnostics.mjs +152 -0
  236. package/src/agent/orchestrator/tools/builtin/path-locks.mjs +35 -0
  237. package/src/agent/orchestrator/tools/builtin/path-utils.mjs +201 -0
  238. package/src/agent/orchestrator/tools/builtin/read-args.mjs +103 -0
  239. package/src/agent/orchestrator/tools/builtin/read-batch.mjs +172 -0
  240. package/src/agent/orchestrator/tools/builtin/read-constants.mjs +40 -0
  241. package/src/agent/orchestrator/tools/builtin/read-formatting.mjs +118 -0
  242. package/src/agent/orchestrator/tools/builtin/read-image-resize.mjs +189 -0
  243. package/src/agent/orchestrator/tools/builtin/read-image.mjs +88 -0
  244. package/src/agent/orchestrator/tools/builtin/read-lines.mjs +12 -0
  245. package/src/agent/orchestrator/tools/builtin/read-mode-tool.mjs +455 -0
  246. package/src/agent/orchestrator/tools/builtin/read-open.mjs +190 -0
  247. package/src/agent/orchestrator/tools/builtin/read-range-index.mjs +271 -0
  248. package/src/agent/orchestrator/tools/builtin/read-ranges.mjs +26 -0
  249. package/src/agent/orchestrator/tools/builtin/read-single-tool.mjs +728 -0
  250. package/src/agent/orchestrator/tools/builtin/read-snapshot-runtime.mjs +173 -0
  251. package/src/agent/orchestrator/tools/builtin/read-special-files.mjs +268 -0
  252. package/src/agent/orchestrator/tools/builtin/read-streaming.mjs +602 -0
  253. package/src/agent/orchestrator/tools/builtin/read-tool.mjs +530 -0
  254. package/src/agent/orchestrator/tools/builtin/read-windows.mjs +107 -0
  255. package/src/agent/orchestrator/tools/builtin/rename-tool.mjs +196 -0
  256. package/src/agent/orchestrator/tools/builtin/rg-runner.mjs +422 -0
  257. package/src/agent/orchestrator/tools/builtin/search-builders.mjs +158 -0
  258. package/src/agent/orchestrator/tools/builtin/search-tool.mjs +869 -0
  259. package/src/agent/orchestrator/tools/builtin/shell-analysis.mjs +653 -0
  260. package/src/agent/orchestrator/tools/builtin/shell-jobs.mjs +936 -0
  261. package/src/agent/orchestrator/tools/builtin/shell-output.mjs +36 -0
  262. package/src/agent/orchestrator/tools/builtin/shell-runtime.mjs +214 -0
  263. package/src/agent/orchestrator/tools/builtin/snapshot-helpers.mjs +143 -0
  264. package/src/agent/orchestrator/tools/builtin/snapshot-store.mjs +206 -0
  265. package/src/agent/orchestrator/tools/builtin/snapshot-validation.mjs +98 -0
  266. package/src/agent/orchestrator/tools/builtin/text-stats.mjs +69 -0
  267. package/src/agent/orchestrator/tools/builtin/windows-roots.mjs +23 -0
  268. package/src/agent/orchestrator/tools/builtin/write-tool.mjs +401 -0
  269. package/src/agent/orchestrator/tools/builtin.mjs +500 -0
  270. package/src/agent/orchestrator/tools/code-graph-prewarm-worker.mjs +39 -0
  271. package/src/agent/orchestrator/tools/code-graph-tool-defs.mjs +24 -0
  272. package/src/agent/orchestrator/tools/code-graph.mjs +4095 -0
  273. package/src/agent/orchestrator/tools/cwd-tool.mjs +298 -0
  274. package/src/agent/orchestrator/tools/destructive-warning.mjs +323 -0
  275. package/src/agent/orchestrator/tools/edit-normalize.mjs +603 -0
  276. package/src/agent/orchestrator/tools/env-scrub.mjs +100 -0
  277. package/src/agent/orchestrator/tools/graph-binary-fetcher.mjs +144 -0
  278. package/src/agent/orchestrator/tools/graph-manifest.json +26 -0
  279. package/src/agent/orchestrator/tools/host-input.mjs +204 -0
  280. package/src/agent/orchestrator/tools/mutation-content-cache.mjs +67 -0
  281. package/src/agent/orchestrator/tools/mutation-planner.mjs +75 -0
  282. package/src/agent/orchestrator/tools/next-call-utils.mjs +48 -0
  283. package/src/agent/orchestrator/tools/patch-binary-fetcher.mjs +133 -0
  284. package/src/agent/orchestrator/tools/patch-manifest.json +26 -0
  285. package/src/agent/orchestrator/tools/patch-tool-defs.mjs +20 -0
  286. package/src/agent/orchestrator/tools/patch.mjs +2754 -0
  287. package/src/agent/orchestrator/tools/progress-message.mjs +118 -0
  288. package/src/agent/orchestrator/tools/result-compression.mjs +279 -0
  289. package/src/agent/orchestrator/tools/shell-command.mjs +865 -0
  290. package/src/agent/orchestrator/tools/shell-exec-policy.mjs +89 -0
  291. package/src/agent/orchestrator/tools/shell-policy-danger-target.mjs +27 -0
  292. package/src/agent/orchestrator/tools/shell-policy-imports.mjs +7 -0
  293. package/src/agent/orchestrator/tools/shell-policy.mjs +345 -0
  294. package/src/agent/orchestrator/tools/shell-snapshot.mjs +313 -0
  295. package/src/agent/orchestrator/workflow-store.mjs +93 -0
  296. package/src/agent/tool-defs.mjs +103 -0
  297. package/src/channels/backends/discord.mjs +784 -0
  298. package/src/channels/data/voice-runtime-manifest.json +138 -0
  299. package/src/channels/index.mjs +3229 -0
  300. package/src/channels/lib/cli-worker-host.mjs +12 -0
  301. package/src/channels/lib/config-lock.mjs +13 -0
  302. package/src/channels/lib/config.mjs +292 -0
  303. package/src/channels/lib/drop-trace.mjs +71 -0
  304. package/src/channels/lib/event-pipeline.mjs +81 -0
  305. package/src/channels/lib/event-queue.mjs +345 -0
  306. package/src/channels/lib/executor.mjs +168 -0
  307. package/src/channels/lib/format.mjs +188 -0
  308. package/src/channels/lib/holidays.mjs +138 -0
  309. package/src/channels/lib/hook-pipe-server.mjs +802 -0
  310. package/src/channels/lib/interaction-workflows.mjs +184 -0
  311. package/src/channels/lib/memory-client.mjs +149 -0
  312. package/src/channels/lib/output-forwarder.mjs +765 -0
  313. package/src/channels/lib/runtime-paths.mjs +479 -0
  314. package/src/channels/lib/scheduler.mjs +723 -0
  315. package/src/channels/lib/session-control.mjs +36 -0
  316. package/src/channels/lib/session-discovery.mjs +103 -0
  317. package/src/channels/lib/settings.mjs +11 -0
  318. package/src/channels/lib/state-file.mjs +68 -0
  319. package/src/channels/lib/status-snapshot.mjs +219 -0
  320. package/src/channels/lib/tool-format.mjs +140 -0
  321. package/src/channels/lib/transcript-discovery.mjs +195 -0
  322. package/src/channels/lib/voice-runtime-fetcher.mjs +734 -0
  323. package/src/channels/lib/webhook.mjs +1179 -0
  324. package/src/channels/lib/whisper-server.mjs +477 -0
  325. package/src/channels/tool-defs.mjs +170 -0
  326. package/src/daemon/host.mjs +118 -0
  327. package/src/daemon/mcp-transport.mjs +47 -0
  328. package/src/daemon/session.mjs +100 -0
  329. package/src/daemon/thin-client.mjs +71 -0
  330. package/src/daemon/transport.mjs +163 -0
  331. package/src/memory/data/runtime-manifest.json +40 -0
  332. package/src/memory/index.mjs +3305 -0
  333. package/src/memory/lib/agent-ipc.mjs +93 -0
  334. package/src/memory/lib/bridge-trace-queries.mjs +120 -0
  335. package/src/memory/lib/core-memory-store.mjs +330 -0
  336. package/src/memory/lib/embedding-provider.mjs +269 -0
  337. package/src/memory/lib/embedding-worker.mjs +323 -0
  338. package/src/memory/lib/llm-worker-host.mjs +17 -0
  339. package/src/memory/lib/memory-cycle.mjs +11 -0
  340. package/src/memory/lib/memory-cycle1.mjs +641 -0
  341. package/src/memory/lib/memory-cycle2.mjs +1284 -0
  342. package/src/memory/lib/memory-cycle3.mjs +540 -0
  343. package/src/memory/lib/memory-embed.mjs +299 -0
  344. package/src/memory/lib/memory-extraction.mjs +5 -0
  345. package/src/memory/lib/memory-maintenance-store.mjs +32 -0
  346. package/src/memory/lib/memory-ops-policy.mjs +190 -0
  347. package/src/memory/lib/memory-recall-id-patch.mjs +15 -0
  348. package/src/memory/lib/memory-recall-read-query.mjs +7 -0
  349. package/src/memory/lib/memory-recall-scope-filter.mjs +63 -0
  350. package/src/memory/lib/memory-recall-store.mjs +621 -0
  351. package/src/memory/lib/memory-retrievers.mjs +112 -0
  352. package/src/memory/lib/memory-score.mjs +71 -0
  353. package/src/memory/lib/memory-text-utils.mjs +58 -0
  354. package/src/memory/lib/memory.mjs +412 -0
  355. package/src/memory/lib/model-profile.mjs +85 -0
  356. package/src/memory/lib/pg/adapter.mjs +308 -0
  357. package/src/memory/lib/pg/process.mjs +360 -0
  358. package/src/memory/lib/pg/supervisor.mjs +396 -0
  359. package/src/memory/lib/project-id-resolver.mjs +86 -0
  360. package/src/memory/lib/runtime-fetcher.mjs +442 -0
  361. package/src/memory/lib/trace-store.mjs +728 -0
  362. package/src/memory/tool-defs.mjs +79 -0
  363. package/src/search/index.mjs +1173 -0
  364. package/src/search/lib/backends/anthropic-oauth.mjs +98 -0
  365. package/src/search/lib/backends/exa.mjs +50 -0
  366. package/src/search/lib/backends/firecrawl.mjs +61 -0
  367. package/src/search/lib/backends/gemini-api.mjs +83 -0
  368. package/src/search/lib/backends/grok-oauth.mjs +86 -0
  369. package/src/search/lib/backends/index.mjs +150 -0
  370. package/src/search/lib/backends/openai-api.mjs +144 -0
  371. package/src/search/lib/backends/openai-oauth.mjs +98 -0
  372. package/src/search/lib/backends/openai-web-search.mjs +76 -0
  373. package/src/search/lib/backends/tavily.mjs +55 -0
  374. package/src/search/lib/backends/xai-api.mjs +113 -0
  375. package/src/search/lib/cache.mjs +131 -0
  376. package/src/search/lib/config.mjs +192 -0
  377. package/src/search/lib/formatter.mjs +115 -0
  378. package/src/search/lib/provider-usage.mjs +67 -0
  379. package/src/search/lib/providers.mjs +47 -0
  380. package/src/search/lib/search-intent.mjs +109 -0
  381. package/src/search/lib/setup-handler.mjs +261 -0
  382. package/src/search/lib/state.mjs +201 -0
  383. package/src/search/lib/web-tools.mjs +1207 -0
  384. package/src/search/tool-defs.mjs +83 -0
  385. package/src/setup/defender-exclusion.mjs +183 -0
  386. package/src/shared/abort-controller.mjs +15 -0
  387. package/src/shared/atomic-file.mjs +420 -0
  388. package/src/shared/config.mjs +350 -0
  389. package/src/shared/daemon-recycle.mjs +108 -0
  390. package/src/shared/disable-claude-builtins.mjs +88 -0
  391. package/src/shared/err-text.mjs +12 -0
  392. package/src/shared/llm/cost.mjs +66 -0
  393. package/src/shared/llm/http-agent.mjs +123 -0
  394. package/src/shared/llm/index.mjs +41 -0
  395. package/src/shared/llm/pid-cleanup.mjs +27 -0
  396. package/src/shared/llm/usage-log.mjs +47 -0
  397. package/src/shared/plugin-paths.mjs +58 -0
  398. package/src/shared/schedules-store.mjs +70 -0
  399. package/src/shared/seed.mjs +119 -0
  400. package/src/shared/user-cwd.mjs +213 -0
  401. package/src/shared/user-data-guard.mjs +238 -0
  402. package/src/status/aggregator.mjs +584 -0
  403. package/src/status/server.mjs +413 -0
  404. package/tools.json +1653 -0
@@ -0,0 +1,85 @@
1
+ /**
2
+ * model-profile.mjs — Lightweight ONNX model profiling.
3
+ *
4
+ * Writes one JSONL line per measurement point to
5
+ * `history/model-profile.jsonl` (mirrors `retrieval-trace.jsonl`). Meant for
6
+ * the embedding provider. Fire-and-forget: any I/O error is swallowed so
7
+ * instrumentation never breaks a live bridge or memory-cycle call.
8
+ *
9
+ * Schema:
10
+ * {
11
+ * ts, phase, model, device, dtype,
12
+ * rssBytes, externalBytes, heapUsedBytes,
13
+ * cpuUserUs, cpuSystemUs, wallMs,
14
+ * docsScored?, note?
15
+ * }
16
+ *
17
+ * `phase` values used by the providers:
18
+ * - 'baseline' (pre-load RSS / CPU snapshot)
19
+ * - 'load' (after pipeline/model load resolves)
20
+ * - 'warmup' (after the first forward pass)
21
+ * - 'steady' (sampled steady-state per-query)
22
+ * - 'post-idle' (after the idle dispose fires)
23
+ *
24
+ * No behaviour change when nobody reads the JSONL — this is telemetry only.
25
+ */
26
+
27
+ import { appendFile, mkdir } from 'node:fs/promises';
28
+ import { join, dirname } from 'node:path';
29
+ import { resolvePluginData } from '../../shared/plugin-paths.mjs';
30
+
31
+ const DATA_DIR = resolvePluginData();
32
+
33
+ const PROFILE_PATH = join(DATA_DIR, 'history', 'model-profile.jsonl');
34
+
35
+ let _mkdirPromise = null;
36
+ async function ensureDir() {
37
+ if (!_mkdirPromise) {
38
+ _mkdirPromise = mkdir(dirname(PROFILE_PATH), { recursive: true }).catch(() => {});
39
+ }
40
+ return _mkdirPromise;
41
+ }
42
+
43
+ /**
44
+ * Collect the current RSS + CPU snapshot plus caller metadata. Fire-and-forget
45
+ * writer; errors are swallowed. Callers should pass `wallMs` measured with
46
+ * `performance.now()` around the operation being profiled.
47
+ *
48
+ * @param {object} record
49
+ * @param {string} record.phase — 'baseline' | 'load' | 'warmup' | 'steady' | 'post-idle' | ...
50
+ * @param {string} record.model — model id (e.g. 'Xenova/bge-m3')
51
+ * @param {string} [record.device] — 'cpu' | 'dml' | 'webgpu' | …
52
+ * @param {string} [record.dtype]
53
+ * @param {number} [record.wallMs]
54
+ * @param {number} [record.docsScored]
55
+ * @param {string} [record.note]
56
+ */
57
+ export function writeProfilePoint(record) {
58
+ try {
59
+ const mem = process.memoryUsage();
60
+ const cpu = process.resourceUsage();
61
+ const line = JSON.stringify({
62
+ ts: new Date().toISOString(),
63
+ phase: record.phase,
64
+ model: record.model,
65
+ device: record.device ?? null,
66
+ dtype: record.dtype ?? null,
67
+ rssBytes: mem.rss,
68
+ externalBytes: mem.external,
69
+ heapUsedBytes: mem.heapUsed,
70
+ arrayBufferBytes: mem.arrayBuffers,
71
+ cpuUserUs: cpu.userCPUTime,
72
+ cpuSystemUs: cpu.systemCPUTime,
73
+ wallMs: typeof record.wallMs === 'number' ? record.wallMs : null,
74
+ docsScored: typeof record.docsScored === 'number' ? record.docsScored : undefined,
75
+ note: record.note ?? undefined,
76
+ });
77
+ // Fire-and-forget: any error is swallowed so instrumentation never
78
+ // breaks a live call path.
79
+ ensureDir()
80
+ .then(() => appendFile(PROFILE_PATH, line + '\n'))
81
+ .catch(() => {});
82
+ } catch {
83
+ // never throw from instrumentation
84
+ }
85
+ }
@@ -0,0 +1,308 @@
1
+ // pg-adapter.mjs — PG connection manager for mixdog 0.4.0
2
+ // Single owner: supervisor-pg.ensurePgInstance(dataDir) starts PG.
3
+ // pg-adapter calls supervisor-pg — never pg-process directly.
4
+ //
5
+ // Public API:
6
+ // ensurePgInstance(dataDir, { schema? }) → { db, pool, host, port, runtimeDir, pgdataDir }
7
+ // closePgInstance(dataDir) → void
8
+ //
9
+ // The returned `db` exposes the native PG query surface:
10
+ // db.query(sql, params?) → { rows, rowCount }
11
+ // db.exec(sql) → multi-statement; resolves on completion
12
+ // db.transaction(async tx => …) → auto BEGIN/COMMIT, ROLLBACK on throw
13
+
14
+ import { resolve } from 'path'
15
+ import { ensurePgInstance as supervisorEnsure } from './supervisor.mjs'
16
+
17
+ // ---------------------------------------------------------------------------
18
+ // One-shot bootstrap guard — keyed by resolved dataDir (cluster-level, not schema)
19
+ // ---------------------------------------------------------------------------
20
+
21
+ const _bootstrapped = new Set()
22
+
23
+ // ---------------------------------------------------------------------------
24
+ // Cross-process advisory-lock keys (two-int4 form: classid + objid).
25
+ //
26
+ // pg advisory locks are CLUSTER-global regardless of which database the session
27
+ // is connected to, so a single shared classid namespaces all mixdog first-boot
28
+ // locks; distinct objids separate the CREATE DATABASE race from the per-cluster
29
+ // extension/schema DDL race. Fixed app-specific keys → concurrent first-boot
30
+ // workers serialize on the exact same lock rather than racing the DDL path.
31
+ // ---------------------------------------------------------------------------
32
+
33
+ const ADVISORY_LOCK_CLASSID = 0x6d696478 // "midx" — mixdog bootstrap namespace
34
+ const ADVISORY_OBJID_CREATE_DB = 1 // CREATE DATABASE mixdog
35
+ export const ADVISORY_OBJID_SCHEMA_BOOTSTRAP = 2 // extensions + schema DDL
36
+
37
+ // ---------------------------------------------------------------------------
38
+ // In-process cache
39
+ // ---------------------------------------------------------------------------
40
+
41
+ const instances = new Map() // `${dataDir}|${schema}` → instance handle
42
+ const opening = new Map() // same key → Promise (dedupe concurrent calls)
43
+
44
+ // ---------------------------------------------------------------------------
45
+ // Per-connection init — WeakSet-guarded so settings run exactly once per client
46
+ // ---------------------------------------------------------------------------
47
+
48
+ const _clientInited = new WeakSet()
49
+
50
+ async function _initClient(client, schema) {
51
+ if (_clientInited.has(client)) return
52
+ // Set search_path so unqualified table names resolve to the correct schema.
53
+ //
54
+ // CROSS-SCHEMA QUERY RULE: search_path is per-connection and biases every
55
+ // unqualified table reference toward the connection's primary schema. Any
56
+ // query that intentionally touches the OTHER schema (e.g. orphan sweep on
57
+ // memory.entries from a trace-schema connection, or recall × trace JOIN
58
+ // analytics) MUST use fully-qualified names (memory.entries / trace.trace_events).
59
+ // Relying on search_path silently in cross-schema code = bug magnet.
60
+ const sp = schema === 'trace' ? 'trace, public' : 'memory, public'
61
+ await client.query(`SET search_path = ${sp}`)
62
+ // pg_trgm similarity threshold: session-local, must be set per connection.
63
+ await client.query(`SELECT set_limit(0.10)`)
64
+ await client.query(`SET default_transaction_isolation TO 'read committed'`)
65
+ // Mark seen only after all init statements succeed; failure leaves client
66
+ // unmarked so the next checkout retries init.
67
+ _clientInited.add(client)
68
+ }
69
+
70
+ // Wrapper around pool.connect() that runs per-client init before returning.
71
+ // Exported so external callers (e.g. trace-store.insertBridgeCalls) can obtain
72
+ // a connection with search_path already set; raw _pool.connect() leaves it at
73
+ // the PG default and unqualified table lookups resolve in the wrong schema.
74
+ export async function checkedConnect(pgPool, schema) {
75
+ const client = await pgPool.connect()
76
+ try {
77
+ await _initClient(client, schema)
78
+ } catch (e) {
79
+ client.release()
80
+ throw e
81
+ }
82
+ return client
83
+ }
84
+ const _checkedConnect = checkedConnect
85
+
86
+ // ---------------------------------------------------------------------------
87
+ // native PG db shim
88
+ // ---------------------------------------------------------------------------
89
+
90
+ function makeCompatDb(pgPool, schema) {
91
+ const db = {
92
+ // query: use pool directly for single-statement queries
93
+ query: async (sql, params) => {
94
+ const client = await _checkedConnect(pgPool, schema)
95
+ try {
96
+ return await client.query(sql, params)
97
+ } finally {
98
+ client.release()
99
+ }
100
+ },
101
+
102
+ // exec: multi-statement SQL (semicolon-separated); single client for session state
103
+ exec: async (sql) => {
104
+ const client = await _checkedConnect(pgPool, schema)
105
+ try {
106
+ await client.query(sql)
107
+ } finally {
108
+ client.release()
109
+ }
110
+ },
111
+
112
+ // transaction: check out one client, BEGIN, run callback(tx), COMMIT or ROLLBACK
113
+ transaction: async (fn) => {
114
+ const client = await _checkedConnect(pgPool, schema)
115
+ try {
116
+ await client.query('BEGIN')
117
+ const tx = {
118
+ query: (sql, params) => client.query(sql, params),
119
+ exec: (sql) => client.query(sql),
120
+ }
121
+ const result = await fn(tx)
122
+ await client.query('COMMIT')
123
+ return result
124
+ } catch (err) {
125
+ try { await client.query('ROLLBACK') } catch {}
126
+ throw err
127
+ } finally {
128
+ client.release()
129
+ }
130
+ },
131
+
132
+ // close: drain pool
133
+ close: () => pgPool.end(),
134
+
135
+ // Internal access for callers that need raw pool
136
+ _pool: pgPool,
137
+ }
138
+ return db
139
+ }
140
+
141
+ // ---------------------------------------------------------------------------
142
+ // Instance bootstrap — extensions + schemas (idempotent)
143
+ // ---------------------------------------------------------------------------
144
+
145
+ // Run `fn` while holding the cluster-global schema-bootstrap advisory lock on a
146
+ // dedicated client. Concurrent first-boot workers across processes serialize on
147
+ // the fixed key so the CREATE TYPE / CREATE EXTENSION / schema DDL path is never
148
+ // raced. The lock is session-scoped (held by this client) and released in
149
+ // finally; `fn`'s own DDL may run on other pool connections — the lock only has
150
+ // to provide cross-process mutual exclusion, not cover the same session.
151
+ export async function withSchemaBootstrapLock(pgPool, fn) {
152
+ const client = await pgPool.connect()
153
+ // Tracks whether the advisory lock is provably released. Stays false until a
154
+ // successful pg_advisory_unlock; any failure/uncertainty keeps it false so we
155
+ // never return a still-locked session to the pool.
156
+ let unlockErr = new Error('schema-bootstrap advisory lock release not attempted')
157
+ try {
158
+ await client.query(`SELECT pg_advisory_lock($1, $2)`, [
159
+ ADVISORY_LOCK_CLASSID, ADVISORY_OBJID_SCHEMA_BOOTSTRAP,
160
+ ])
161
+ try {
162
+ return await fn()
163
+ } finally {
164
+ try {
165
+ await client.query(`SELECT pg_advisory_unlock($1, $2)`, [
166
+ ADVISORY_LOCK_CLASSID, ADVISORY_OBJID_SCHEMA_BOOTSTRAP,
167
+ ])
168
+ unlockErr = null // lock provably released → client is clean to reuse
169
+ } catch (err) {
170
+ unlockErr = err instanceof Error ? err : new Error(String(err))
171
+ }
172
+ }
173
+ } finally {
174
+ // A client whose advisory-lock state is uncertain must never be reused:
175
+ // release(truthy) makes node-pg destroy it instead of pooling it.
176
+ client.release(unlockErr || undefined)
177
+ }
178
+ }
179
+
180
+ async function bootstrapInstance(pgPool, dataDirKey) {
181
+ if (_bootstrapped.has(dataDirKey)) return
182
+ // Serialize the cluster-level DDL across concurrent first-boot processes.
183
+ await withSchemaBootstrapLock(pgPool, async () => {
184
+ // Use a raw client bypassing per-client schema settings (bootstrap targets
185
+ // the cluster level, not a specific schema).
186
+ const client = await pgPool.connect()
187
+ try {
188
+ await client.query(`CREATE EXTENSION IF NOT EXISTS vector WITH SCHEMA public`)
189
+ await client.query(`CREATE EXTENSION IF NOT EXISTS pg_trgm WITH SCHEMA public`)
190
+ await client.query(`CREATE SCHEMA IF NOT EXISTS memory`)
191
+ await client.query(`CREATE SCHEMA IF NOT EXISTS trace`)
192
+ } finally {
193
+ client.release()
194
+ }
195
+ })
196
+ _bootstrapped.add(dataDirKey)
197
+ }
198
+
199
+ // ---------------------------------------------------------------------------
200
+ // ensurePgInstance — public API
201
+ // ---------------------------------------------------------------------------
202
+
203
+ /**
204
+ * Ensure a live PG instance and return a native PG db handle.
205
+ *
206
+ * @param {string} dataDir Plugin data directory.
207
+ * @param {{ schema?: 'memory' | 'trace' }} [opts]
208
+ * @returns {Promise<{ db, pool, host, port, runtimeDir, pgdataDir }>}
209
+ */
210
+ export async function ensurePgInstance(dataDir, opts = {}) {
211
+ const schema = opts.schema ?? 'memory'
212
+ const key = `${resolve(dataDir)}|${schema}`
213
+
214
+ if (instances.has(key)) return instances.get(key)
215
+ if (opening.has(key)) return opening.get(key)
216
+
217
+ const promise = (async () => {
218
+ // 1. Let supervisor-pg own PG startup and health-checking.
219
+ // Returns { host, port, runtimeDir, pgdataDir }.
220
+ const { host, port, runtimeDir, pgdataDir } = await supervisorEnsure(dataDir)
221
+
222
+ // 2. Connect via node-postgres; auto-create the mixdog database if absent.
223
+ const { default: pg } = await import('pg')
224
+
225
+ const PG_USER = 'postgres'
226
+ const PG_DB = 'mixdog'
227
+
228
+ const adminPool = new pg.Pool({
229
+ host, port, user: PG_USER, database: 'postgres',
230
+ password: '', max: 1, idleTimeoutMillis: 5_000,
231
+ })
232
+ try {
233
+ // CREATE DATABASE cannot run inside a transaction, so guard the
234
+ // check-then-create with a session-level advisory lock held on a single
235
+ // dedicated client. Concurrent first-boot workers block on the same
236
+ // cluster-global key here and only one issues the CREATE; the rest see
237
+ // the row present after the holder releases. Released in finally.
238
+ const adminClient = await adminPool.connect()
239
+ // Same invariant as withSchemaBootstrapLock: only reuse the client if the
240
+ // advisory lock is provably released.
241
+ let unlockErr = new Error('create-db advisory lock release not attempted')
242
+ try {
243
+ await adminClient.query(`SELECT pg_advisory_lock($1, $2)`, [
244
+ ADVISORY_LOCK_CLASSID, ADVISORY_OBJID_CREATE_DB,
245
+ ])
246
+ try {
247
+ const r = await adminClient.query(`SELECT 1 FROM pg_database WHERE datname = $1`, [PG_DB])
248
+ if (r.rows.length === 0) {
249
+ await adminClient.query(`CREATE DATABASE ${PG_DB}`)
250
+ process.stderr.write(`[pg-adapter] created database ${PG_DB}\n`)
251
+ }
252
+ } finally {
253
+ try {
254
+ await adminClient.query(`SELECT pg_advisory_unlock($1, $2)`, [
255
+ ADVISORY_LOCK_CLASSID, ADVISORY_OBJID_CREATE_DB,
256
+ ])
257
+ unlockErr = null // lock provably released → client is clean to reuse
258
+ } catch (err) {
259
+ unlockErr = err instanceof Error ? err : new Error(String(err))
260
+ }
261
+ }
262
+ } finally {
263
+ // Uncertain advisory-lock state → destroy the client (truthy release arg)
264
+ // so a still-locked session never re-enters the admin pool.
265
+ adminClient.release(unlockErr || undefined)
266
+ }
267
+ } finally {
268
+ await adminPool.end()
269
+ }
270
+
271
+ // 3. Production pool.
272
+ const pgPool = new pg.Pool({
273
+ host, port, user: PG_USER, database: PG_DB,
274
+ password: '', max: 5, idleTimeoutMillis: 30_000,
275
+ connectionTimeoutMillis: 10_000,
276
+ })
277
+
278
+ // 4. Bootstrap extensions + schemas once (idempotent).
279
+ await bootstrapInstance(pgPool, resolve(dataDir))
280
+
281
+ // 5. Build the compat db shim.
282
+ const db = makeCompatDb(pgPool, schema)
283
+
284
+ const result = { db, pool: pgPool, host, port, runtimeDir, pgdataDir }
285
+ instances.set(key, result)
286
+ return result
287
+ })()
288
+
289
+ opening.set(key, promise)
290
+ try {
291
+ return await promise
292
+ } finally {
293
+ opening.delete(key)
294
+ }
295
+ }
296
+
297
+ // ---------------------------------------------------------------------------
298
+ // closePgInstance — drain pool
299
+ // ---------------------------------------------------------------------------
300
+
301
+ export async function closePgInstance(dataDir, opts = {}) {
302
+ const schema = opts.schema ?? 'memory'
303
+ const key = `${resolve(dataDir)}|${schema}`
304
+ const inst = instances.get(key)
305
+ if (!inst) return
306
+ try { await inst.pool.end() } catch {}
307
+ instances.delete(key)
308
+ }