@ouro.bot/cli 0.1.0-alpha.5 → 0.1.0-alpha.500

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 (380) hide show
  1. package/README.md +226 -183
  2. package/SerpentGuide.ouro/agent.json +82 -0
  3. package/SerpentGuide.ouro/psyche/SOUL.md +25 -0
  4. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +2 -2
  5. package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
  6. package/assets/ouroboros.png +0 -0
  7. package/changelog.json +3418 -0
  8. package/dist/arc/attention-types.js +8 -0
  9. package/dist/arc/cares.js +140 -0
  10. package/dist/arc/episodes.js +117 -0
  11. package/dist/arc/intentions.js +133 -0
  12. package/dist/arc/json-store.js +117 -0
  13. package/dist/arc/obligations.js +237 -0
  14. package/dist/arc/packets.js +193 -0
  15. package/dist/arc/presence.js +185 -0
  16. package/dist/arc/task-lifecycle.js +65 -0
  17. package/dist/heart/active-work.js +989 -0
  18. package/dist/heart/agent-entry.js +58 -3
  19. package/dist/heart/attachments/image-normalize.js +194 -0
  20. package/dist/heart/attachments/materialize.js +97 -0
  21. package/dist/heart/attachments/originals.js +88 -0
  22. package/dist/heart/attachments/render.js +29 -0
  23. package/dist/heart/attachments/sources/adapter.js +2 -0
  24. package/dist/heart/attachments/sources/bluebubbles.js +156 -0
  25. package/dist/heart/attachments/sources/cli-local-file.js +78 -0
  26. package/dist/heart/attachments/sources/index.js +16 -0
  27. package/dist/heart/attachments/store.js +103 -0
  28. package/dist/heart/attachments/types.js +93 -0
  29. package/dist/heart/auth/auth-flow.js +426 -0
  30. package/dist/heart/background-operations.js +281 -0
  31. package/dist/heart/bridges/manager.js +358 -0
  32. package/dist/heart/bridges/state-machine.js +135 -0
  33. package/dist/heart/bridges/store.js +123 -0
  34. package/dist/heart/bundle-state.js +168 -0
  35. package/dist/heart/commitments.js +111 -0
  36. package/dist/heart/config-registry.js +304 -0
  37. package/dist/heart/config.js +193 -130
  38. package/dist/heart/core.js +1010 -261
  39. package/dist/heart/cross-chat-delivery.js +131 -0
  40. package/dist/heart/daemon/agent-config-check.js +490 -0
  41. package/dist/heart/daemon/agent-discovery.js +157 -0
  42. package/dist/heart/daemon/agent-service.js +360 -0
  43. package/dist/heart/daemon/agentic-repair.js +216 -0
  44. package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
  45. package/dist/heart/daemon/cadence.js +70 -0
  46. package/dist/heart/daemon/cli-defaults.js +640 -0
  47. package/dist/heart/daemon/cli-exec.js +7239 -0
  48. package/dist/heart/daemon/cli-help.js +493 -0
  49. package/dist/heart/daemon/cli-parse.js +1533 -0
  50. package/dist/heart/daemon/cli-render-doctor.js +57 -0
  51. package/dist/heart/daemon/cli-render.js +561 -0
  52. package/dist/heart/daemon/cli-types.js +8 -0
  53. package/dist/heart/daemon/connect-bay.js +323 -0
  54. package/dist/heart/daemon/daemon-cli.js +30 -697
  55. package/dist/heart/daemon/daemon-entry.js +359 -8
  56. package/dist/heart/daemon/daemon-health.js +141 -0
  57. package/dist/heart/daemon/daemon-runtime-sync.js +268 -0
  58. package/dist/heart/daemon/daemon-tombstone.js +236 -0
  59. package/dist/heart/daemon/daemon.js +813 -19
  60. package/dist/heart/daemon/dns-workflow.js +394 -0
  61. package/dist/heart/daemon/doctor-types.js +8 -0
  62. package/dist/heart/daemon/doctor.js +615 -0
  63. package/dist/heart/daemon/health-monitor.js +92 -1
  64. package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
  65. package/dist/heart/daemon/hooks/bundle-meta.js +206 -0
  66. package/dist/heart/daemon/http-health-probe.js +80 -0
  67. package/dist/heart/daemon/human-command-screens.js +234 -0
  68. package/dist/heart/daemon/human-readiness.js +114 -0
  69. package/dist/heart/daemon/inner-status.js +89 -0
  70. package/dist/heart/daemon/interactive-repair.js +394 -0
  71. package/dist/heart/daemon/launchd.js +171 -0
  72. package/dist/heart/daemon/log-tailer.js +82 -12
  73. package/dist/heart/daemon/logs-prune.js +110 -0
  74. package/dist/heart/daemon/message-router.js +17 -8
  75. package/dist/heart/daemon/os-cron-deps.js +134 -0
  76. package/dist/heart/daemon/ouro-bot-entry.js +4 -2
  77. package/dist/heart/daemon/ouro-entry.js +3 -1
  78. package/dist/heart/daemon/process-manager.js +215 -1
  79. package/dist/heart/daemon/provider-discovery.js +137 -0
  80. package/dist/heart/daemon/provider-ping-progress.js +83 -0
  81. package/dist/heart/daemon/pulse.js +475 -0
  82. package/dist/heart/daemon/readiness-repair.js +365 -0
  83. package/dist/heart/daemon/run-hooks.js +39 -0
  84. package/dist/heart/daemon/runtime-logging.js +67 -16
  85. package/dist/heart/daemon/runtime-metadata.js +191 -0
  86. package/dist/heart/daemon/runtime-mode.js +67 -0
  87. package/dist/heart/daemon/safe-mode.js +161 -0
  88. package/dist/heart/daemon/sense-manager.js +431 -0
  89. package/dist/heart/daemon/session-id-resolver.js +131 -0
  90. package/dist/heart/daemon/skill-management-installer.js +94 -0
  91. package/dist/heart/daemon/socket-client.js +307 -0
  92. package/dist/heart/daemon/stale-bundle-prune.js +96 -0
  93. package/dist/heart/daemon/startup-tui.js +264 -0
  94. package/dist/heart/daemon/task-scheduler.js +3 -25
  95. package/dist/heart/daemon/terminal-ui.js +499 -0
  96. package/dist/heart/daemon/thoughts.js +524 -0
  97. package/dist/heart/daemon/up-progress.js +366 -0
  98. package/dist/heart/daemon/vault-items.js +56 -0
  99. package/dist/heart/delegation.js +62 -0
  100. package/dist/heart/habits/habit-migration.js +189 -0
  101. package/dist/heart/habits/habit-parser.js +140 -0
  102. package/dist/heart/habits/habit-runtime-state.js +100 -0
  103. package/dist/heart/habits/habit-scheduler.js +372 -0
  104. package/dist/heart/{daemon → hatch}/hatch-animation.js +10 -3
  105. package/dist/heart/{daemon → hatch}/hatch-flow.js +54 -136
  106. package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
  107. package/dist/heart/hatch/specialist-orchestrator.js +129 -0
  108. package/dist/heart/hatch/specialist-prompt.js +102 -0
  109. package/dist/heart/hatch/specialist-tools.js +306 -0
  110. package/dist/heart/identity.js +274 -61
  111. package/dist/heart/kept-notes.js +357 -0
  112. package/dist/heart/kicks.js +2 -20
  113. package/dist/heart/machine-identity.js +161 -0
  114. package/dist/heart/mail-import-discovery.js +353 -0
  115. package/dist/heart/mcp/mcp-server.js +653 -0
  116. package/dist/heart/migrate-config.js +100 -0
  117. package/dist/heart/model-capabilities.js +59 -0
  118. package/dist/heart/outlook/outlook-http-hooks.js +66 -0
  119. package/dist/heart/outlook/outlook-http-response.js +7 -0
  120. package/dist/heart/outlook/outlook-http-routes.js +244 -0
  121. package/dist/heart/outlook/outlook-http-static.js +103 -0
  122. package/dist/heart/outlook/outlook-http-transport.js +116 -0
  123. package/dist/heart/outlook/outlook-http.js +99 -0
  124. package/dist/heart/outlook/outlook-read.js +31 -0
  125. package/dist/heart/outlook/outlook-types.js +27 -0
  126. package/dist/heart/outlook/outlook-view.js +195 -0
  127. package/dist/heart/outlook/readers/agent-machine.js +382 -0
  128. package/dist/heart/outlook/readers/continuity-readers.js +336 -0
  129. package/dist/heart/outlook/readers/mail.js +362 -0
  130. package/dist/heart/outlook/readers/runtime-readers.js +644 -0
  131. package/dist/heart/outlook/readers/sessions.js +232 -0
  132. package/dist/heart/outlook/readers/shared.js +111 -0
  133. package/dist/heart/platform.js +81 -0
  134. package/dist/heart/progress-story.js +42 -0
  135. package/dist/heart/provider-attempt.js +134 -0
  136. package/dist/heart/provider-binding-resolver.js +255 -0
  137. package/dist/heart/provider-credentials.js +424 -0
  138. package/dist/heart/provider-failover.js +301 -0
  139. package/dist/heart/provider-models.js +81 -0
  140. package/dist/heart/provider-ping.js +262 -0
  141. package/dist/heart/provider-state.js +216 -0
  142. package/dist/heart/provider-visibility.js +188 -0
  143. package/dist/heart/providers/anthropic-token.js +131 -0
  144. package/dist/heart/providers/anthropic.js +202 -50
  145. package/dist/heart/providers/azure.js +104 -13
  146. package/dist/heart/providers/error-classification.js +63 -0
  147. package/dist/heart/providers/github-copilot.js +145 -0
  148. package/dist/heart/providers/minimax-vlm.js +189 -0
  149. package/dist/heart/providers/minimax.js +29 -7
  150. package/dist/heart/providers/openai-codex.js +63 -39
  151. package/dist/heart/runtime-capability-check.js +170 -0
  152. package/dist/heart/runtime-credentials.js +260 -0
  153. package/dist/heart/sense-truth.js +68 -0
  154. package/dist/heart/session-activity.js +190 -0
  155. package/dist/heart/session-events.js +1089 -0
  156. package/dist/heart/session-playback-cli-main.js +5 -0
  157. package/dist/heart/session-playback-cli.js +36 -0
  158. package/dist/heart/session-playback.js +231 -0
  159. package/dist/heart/session-transcript.js +167 -0
  160. package/dist/heart/start-of-turn-packet.js +345 -0
  161. package/dist/heart/streaming.js +129 -34
  162. package/dist/heart/sync.js +332 -0
  163. package/dist/heart/target-resolution.js +127 -0
  164. package/dist/heart/tempo.js +93 -0
  165. package/dist/heart/temporal-view.js +41 -0
  166. package/dist/heart/tool-activity-callbacks.js +36 -0
  167. package/dist/heart/tool-description.js +135 -0
  168. package/dist/heart/tool-friction.js +55 -0
  169. package/dist/heart/tool-loop.js +200 -0
  170. package/dist/heart/turn-context.js +372 -0
  171. package/dist/heart/turn-coordinator.js +28 -0
  172. package/dist/heart/versioning/ouro-bot-global-installer.js +128 -0
  173. package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
  174. package/dist/heart/versioning/ouro-path-installer.js +425 -0
  175. package/dist/heart/{daemon → versioning}/ouro-uti.js +11 -2
  176. package/dist/heart/versioning/ouro-version-manager.js +295 -0
  177. package/dist/heart/versioning/staged-restart.js +146 -0
  178. package/dist/heart/versioning/update-checker.js +115 -0
  179. package/dist/heart/versioning/update-hooks.js +142 -0
  180. package/dist/heart/versioning/wrapper-publish-guard.js +86 -0
  181. package/dist/mailroom/attention.js +167 -0
  182. package/dist/mailroom/autonomy.js +209 -0
  183. package/dist/mailroom/blob-store.js +606 -0
  184. package/dist/mailroom/core.js +672 -0
  185. package/dist/mailroom/entry.js +160 -0
  186. package/dist/mailroom/file-store.js +426 -0
  187. package/dist/mailroom/mbox-import.js +382 -0
  188. package/dist/mailroom/outbound.js +380 -0
  189. package/dist/mailroom/policy.js +263 -0
  190. package/dist/mailroom/reader.js +219 -0
  191. package/dist/mailroom/search-cache.js +182 -0
  192. package/dist/mailroom/search-relevance.js +319 -0
  193. package/dist/mailroom/smtp-ingress.js +176 -0
  194. package/dist/mailroom/source-state.js +176 -0
  195. package/dist/mailroom/thread.js +109 -0
  196. package/dist/mailroom/travel-extract.js +89 -0
  197. package/dist/mind/bundle-manifest.js +77 -1
  198. package/dist/mind/context.js +173 -94
  199. package/dist/mind/diary-integrity.js +60 -0
  200. package/dist/mind/{memory.js → diary.js} +84 -96
  201. package/dist/mind/embedding-provider.js +60 -0
  202. package/dist/mind/file-state.js +179 -0
  203. package/dist/mind/first-impressions.js +16 -2
  204. package/dist/mind/friends/channel.js +73 -0
  205. package/dist/mind/friends/group-context.js +144 -0
  206. package/dist/mind/friends/resolver.js +54 -2
  207. package/dist/mind/friends/store-file.js +58 -3
  208. package/dist/mind/friends/trust-explanation.js +74 -0
  209. package/dist/mind/friends/types.js +10 -2
  210. package/dist/mind/journal-index.js +161 -0
  211. package/dist/mind/note-search.js +268 -0
  212. package/dist/mind/obligation-steering.js +221 -0
  213. package/dist/mind/pending.js +76 -9
  214. package/dist/mind/phrases.js +1 -0
  215. package/dist/mind/prompt-refresh.js +3 -2
  216. package/dist/mind/prompt.js +1144 -117
  217. package/dist/mind/provenance-trust.js +26 -0
  218. package/dist/mind/scrutiny.js +173 -0
  219. package/dist/mind/token-estimate.js +8 -12
  220. package/dist/nerves/cli-logging.js +22 -3
  221. package/dist/nerves/coverage/audit-rules.js +15 -6
  222. package/dist/nerves/coverage/audit.js +28 -2
  223. package/dist/nerves/coverage/cli.js +1 -1
  224. package/dist/nerves/coverage/contract.js +5 -5
  225. package/dist/nerves/coverage/file-completeness.js +101 -5
  226. package/dist/nerves/coverage/run-artifacts.js +1 -1
  227. package/dist/nerves/event-buffer.js +111 -0
  228. package/dist/nerves/index.js +224 -4
  229. package/dist/nerves/observation.js +20 -0
  230. package/dist/nerves/redact.js +79 -0
  231. package/dist/nerves/runtime.js +5 -1
  232. package/dist/outlook-ui/assets/index-BPr5vNuM.css +1 -0
  233. package/dist/outlook-ui/assets/index-Cm51CY9W.js +61 -0
  234. package/dist/outlook-ui/index.html +15 -0
  235. package/dist/repertoire/ado-client.js +17 -56
  236. package/dist/repertoire/ado-semantic.js +11 -10
  237. package/dist/repertoire/api-client.js +97 -0
  238. package/dist/repertoire/bitwarden-store.js +774 -0
  239. package/dist/repertoire/bundle-templates.js +72 -0
  240. package/dist/repertoire/bw-installer.js +180 -0
  241. package/dist/repertoire/coding/codex-jsonl.js +64 -0
  242. package/dist/repertoire/coding/context-pack.js +330 -0
  243. package/dist/repertoire/coding/feedback.js +301 -0
  244. package/dist/repertoire/coding/index.js +4 -1
  245. package/dist/repertoire/coding/manager.js +220 -13
  246. package/dist/repertoire/coding/spawner.js +58 -12
  247. package/dist/repertoire/coding/tools.js +209 -7
  248. package/dist/repertoire/commerce-errors.js +109 -0
  249. package/dist/repertoire/commerce-self-test.js +156 -0
  250. package/dist/repertoire/credential-access.js +111 -0
  251. package/dist/repertoire/data/ado-endpoints.json +188 -0
  252. package/dist/repertoire/duffel-client.js +185 -0
  253. package/dist/repertoire/github-client.js +14 -55
  254. package/dist/repertoire/graph-client.js +11 -52
  255. package/dist/repertoire/guardrails.js +396 -0
  256. package/dist/repertoire/mcp-client.js +255 -0
  257. package/dist/repertoire/mcp-manager.js +305 -0
  258. package/dist/repertoire/mcp-tools.js +63 -0
  259. package/dist/repertoire/shell-sessions.js +133 -0
  260. package/dist/repertoire/skills.js +15 -24
  261. package/dist/repertoire/stripe-client.js +131 -0
  262. package/dist/repertoire/tasks/board.js +43 -5
  263. package/dist/repertoire/tasks/fix.js +182 -0
  264. package/dist/repertoire/tasks/index.js +39 -13
  265. package/dist/repertoire/tasks/lifecycle.js +2 -2
  266. package/dist/repertoire/tasks/parser.js +3 -2
  267. package/dist/repertoire/tasks/scanner.js +194 -37
  268. package/dist/repertoire/tasks/transitions.js +16 -79
  269. package/dist/repertoire/tool-results.js +29 -0
  270. package/dist/repertoire/tools-attachments.js +317 -0
  271. package/dist/repertoire/tools-base.js +49 -707
  272. package/dist/repertoire/tools-bluebubbles.js +94 -0
  273. package/dist/repertoire/tools-bridge.js +141 -0
  274. package/dist/repertoire/tools-bundle.js +984 -0
  275. package/dist/repertoire/tools-config.js +185 -0
  276. package/dist/repertoire/tools-continuity.js +248 -0
  277. package/dist/repertoire/tools-credential.js +381 -0
  278. package/dist/repertoire/tools-files.js +342 -0
  279. package/dist/repertoire/tools-flight.js +224 -0
  280. package/dist/repertoire/tools-flow.js +105 -0
  281. package/dist/repertoire/tools-github.js +1 -7
  282. package/dist/repertoire/tools-mail.js +1377 -0
  283. package/dist/repertoire/tools-notes.js +376 -0
  284. package/dist/repertoire/tools-session.js +749 -0
  285. package/dist/repertoire/tools-shell.js +120 -0
  286. package/dist/repertoire/tools-stripe.js +180 -0
  287. package/dist/repertoire/tools-surface.js +243 -0
  288. package/dist/repertoire/tools-teams.js +64 -61
  289. package/dist/repertoire/tools-travel.js +125 -0
  290. package/dist/repertoire/tools-trip.js +356 -0
  291. package/dist/repertoire/tools-user-profile.js +144 -0
  292. package/dist/repertoire/tools-vault.js +40 -0
  293. package/dist/repertoire/tools.js +149 -98
  294. package/dist/repertoire/travel-api-client.js +360 -0
  295. package/dist/repertoire/user-profile.js +131 -0
  296. package/dist/repertoire/vault-setup.js +246 -0
  297. package/dist/repertoire/vault-unlock.js +561 -0
  298. package/dist/scripts/claude-code-hook.js +41 -0
  299. package/dist/scripts/claude-code-stop-hook.js +47 -0
  300. package/dist/senses/attention-queue.js +116 -0
  301. package/dist/senses/bluebubbles/attachment-cache.js +53 -0
  302. package/dist/senses/bluebubbles/attachment-download.js +137 -0
  303. package/dist/senses/bluebubbles/client.js +685 -0
  304. package/dist/senses/bluebubbles/entry.js +73 -0
  305. package/dist/senses/bluebubbles/inbound-log.js +126 -0
  306. package/dist/senses/bluebubbles/index.js +1881 -0
  307. package/dist/senses/bluebubbles/media.js +389 -0
  308. package/dist/senses/bluebubbles/model.js +282 -0
  309. package/dist/senses/bluebubbles/mutation-log.js +116 -0
  310. package/dist/senses/bluebubbles/processed-log.js +111 -0
  311. package/dist/senses/bluebubbles/replay.js +129 -0
  312. package/dist/senses/bluebubbles/runtime-state.js +109 -0
  313. package/dist/senses/bluebubbles/session-cleanup.js +72 -0
  314. package/dist/senses/cli/bracketed-paste.js +82 -0
  315. package/dist/senses/cli/image-paste.js +287 -0
  316. package/dist/senses/cli/image-ref-navigation.js +75 -0
  317. package/dist/senses/cli/ink-app.js +156 -0
  318. package/dist/senses/cli/inline-diff.js +64 -0
  319. package/dist/senses/cli/input-keys.js +174 -0
  320. package/dist/senses/cli/kill-ring.js +86 -0
  321. package/dist/senses/cli/message-list.js +51 -0
  322. package/dist/senses/cli/ouro-tui.js +605 -0
  323. package/dist/senses/cli/spinner-imperative.js +135 -0
  324. package/dist/senses/cli/spinner.js +101 -0
  325. package/dist/senses/cli/status-line.js +60 -0
  326. package/dist/senses/cli/streaming-markdown.js +526 -0
  327. package/dist/senses/cli/tool-display.js +83 -0
  328. package/dist/senses/cli/tool-render.js +85 -0
  329. package/dist/senses/cli/tui-store.js +240 -0
  330. package/dist/senses/cli/virtual-list.js +35 -0
  331. package/dist/senses/cli-entry.js +60 -8
  332. package/dist/senses/cli-layout.js +187 -0
  333. package/dist/senses/cli.js +768 -264
  334. package/dist/senses/commands.js +66 -3
  335. package/dist/senses/continuity.js +94 -0
  336. package/dist/senses/habit-turn-message.js +108 -0
  337. package/dist/senses/inner-dialog-worker.js +199 -16
  338. package/dist/senses/inner-dialog.js +640 -91
  339. package/dist/senses/mail-entry.js +66 -0
  340. package/dist/senses/mail.js +379 -0
  341. package/dist/senses/pipeline.js +665 -0
  342. package/dist/senses/proactive-content-guard.js +51 -0
  343. package/dist/senses/shared-turn.js +248 -0
  344. package/dist/senses/surface-tool.js +68 -0
  345. package/dist/senses/teams-entry.js +60 -8
  346. package/dist/senses/teams.js +844 -197
  347. package/dist/senses/trust-gate.js +207 -2
  348. package/dist/trips/core.js +138 -0
  349. package/dist/trips/store.js +146 -0
  350. package/package.json +47 -6
  351. package/skills/agent-commerce.md +106 -0
  352. package/skills/browser-navigation.md +117 -0
  353. package/skills/commerce-setup-guide.md +116 -0
  354. package/skills/commerce-setup.md +84 -0
  355. package/skills/configure-dev-tools.md +101 -0
  356. package/skills/travel-planning.md +138 -0
  357. package/AdoptionSpecialist.ouro/agent.json +0 -20
  358. package/AdoptionSpecialist.ouro/psyche/SOUL.md +0 -22
  359. package/dist/heart/daemon/specialist-orchestrator.js +0 -160
  360. package/dist/heart/daemon/specialist-prompt.js +0 -40
  361. package/dist/heart/daemon/specialist-session.js +0 -142
  362. package/dist/heart/daemon/specialist-tools.js +0 -128
  363. package/dist/heart/daemon/subagent-installer.js +0 -125
  364. package/dist/inner-worker-entry.js +0 -4
  365. package/dist/mind/associative-recall.js +0 -197
  366. package/subagents/README.md +0 -73
  367. package/subagents/work-doer.md +0 -233
  368. package/subagents/work-merger.md +0 -624
  369. package/subagents/work-planner.md +0 -373
  370. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
  371. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
  372. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
  373. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
  374. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
  375. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
  376. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
  377. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
  378. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
  379. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
  380. /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
@@ -0,0 +1,281 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.readBackgroundOperation = readBackgroundOperation;
37
+ exports.listBackgroundOperations = listBackgroundOperations;
38
+ exports.startBackgroundOperation = startBackgroundOperation;
39
+ exports.markBackgroundOperationRunning = markBackgroundOperationRunning;
40
+ exports.updateBackgroundOperation = updateBackgroundOperation;
41
+ exports.completeBackgroundOperation = completeBackgroundOperation;
42
+ exports.failBackgroundOperation = failBackgroundOperation;
43
+ const fs = __importStar(require("node:fs"));
44
+ const path = __importStar(require("node:path"));
45
+ const runtime_1 = require("../nerves/runtime");
46
+ const identity_1 = require("./identity");
47
+ function operationsDir(agentName, agentRoot = (0, identity_1.getAgentRoot)(agentName)) {
48
+ return path.join(agentRoot, "state", "background-operations");
49
+ }
50
+ function operationPath(locator) {
51
+ return path.join(operationsDir(locator.agentName, locator.agentRoot), `${locator.id}.json`);
52
+ }
53
+ function normalizeProgress(progress) {
54
+ if (!progress)
55
+ return undefined;
56
+ const normalized = {};
57
+ if (typeof progress.current === "number" && Number.isFinite(progress.current))
58
+ normalized.current = progress.current;
59
+ if (typeof progress.total === "number" && Number.isFinite(progress.total))
60
+ normalized.total = progress.total;
61
+ if (typeof progress.unit === "string" && progress.unit.trim().length > 0)
62
+ normalized.unit = progress.unit.trim();
63
+ return Object.keys(normalized).length > 0 ? normalized : undefined;
64
+ }
65
+ function normalizeRecord(record) {
66
+ if (record.schemaVersion !== 1)
67
+ return null;
68
+ if (typeof record.id !== "string" || record.id.trim().length === 0)
69
+ return null;
70
+ if (typeof record.agentName !== "string" || record.agentName.trim().length === 0)
71
+ return null;
72
+ if (typeof record.kind !== "string" || record.kind.trim().length === 0)
73
+ return null;
74
+ if (typeof record.title !== "string" || record.title.trim().length === 0)
75
+ return null;
76
+ if (typeof record.summary !== "string" || record.summary.trim().length === 0)
77
+ return null;
78
+ if (typeof record.createdAt !== "string" || record.createdAt.trim().length === 0)
79
+ return null;
80
+ if (typeof record.updatedAt !== "string" || record.updatedAt.trim().length === 0)
81
+ return null;
82
+ if (record.status !== "queued"
83
+ && record.status !== "running"
84
+ && record.status !== "succeeded"
85
+ && record.status !== "failed") {
86
+ return null;
87
+ }
88
+ const normalized = {
89
+ schemaVersion: 1,
90
+ id: record.id,
91
+ agentName: record.agentName,
92
+ kind: record.kind,
93
+ title: record.title,
94
+ status: record.status,
95
+ summary: record.summary,
96
+ createdAt: record.createdAt,
97
+ updatedAt: record.updatedAt,
98
+ };
99
+ if (typeof record.detail === "string" && record.detail.trim().length > 0)
100
+ normalized.detail = record.detail.trim();
101
+ if (typeof record.startedAt === "string" && record.startedAt.trim().length > 0)
102
+ normalized.startedAt = record.startedAt;
103
+ if (typeof record.finishedAt === "string" && record.finishedAt.trim().length > 0)
104
+ normalized.finishedAt = record.finishedAt;
105
+ const progress = normalizeProgress(record.progress);
106
+ if (progress)
107
+ normalized.progress = progress;
108
+ if (record.spec && typeof record.spec === "object" && !Array.isArray(record.spec))
109
+ normalized.spec = { ...record.spec };
110
+ if (record.result && typeof record.result === "object" && !Array.isArray(record.result))
111
+ normalized.result = { ...record.result };
112
+ if (record.error && typeof record.error.message === "string" && record.error.message.trim().length > 0) {
113
+ normalized.error = { message: record.error.message.trim() };
114
+ }
115
+ if (record.failure && typeof record.failure === "object" && !Array.isArray(record.failure)) {
116
+ const failureClass = typeof record.failure.class === "string" ? record.failure.class.trim() : "";
117
+ const retryDisposition = record.failure.retryDisposition;
118
+ const hint = typeof record.failure.hint === "string" ? record.failure.hint.trim() : "";
119
+ if (failureClass) {
120
+ normalized.failure = {
121
+ class: failureClass,
122
+ ...(retryDisposition === "retry-safe" || retryDisposition === "fix-before-retry" || retryDisposition === "investigate-first"
123
+ ? { retryDisposition }
124
+ : {}),
125
+ ...(hint ? { hint } : {}),
126
+ };
127
+ }
128
+ }
129
+ if (Array.isArray(record.remediation)) {
130
+ const remediation = record.remediation.filter((entry) => typeof entry === "string" && entry.trim().length > 0);
131
+ if (remediation.length > 0)
132
+ normalized.remediation = remediation;
133
+ }
134
+ return normalized;
135
+ }
136
+ function readRecord(filePath) {
137
+ try {
138
+ const parsed = JSON.parse(fs.readFileSync(filePath, "utf-8"));
139
+ return normalizeRecord(parsed);
140
+ }
141
+ catch {
142
+ return null;
143
+ }
144
+ }
145
+ function specText(spec, key) {
146
+ const value = spec?.[key];
147
+ return typeof value === "string" ? value.trim() : "";
148
+ }
149
+ function visibleOperationKey(record) {
150
+ if (record.kind !== "mail.import-mbox")
151
+ return null;
152
+ const filePath = specText(record.spec, "filePath");
153
+ if (!filePath)
154
+ return null;
155
+ const ownerEmail = specText(record.spec, "ownerEmail").toLowerCase();
156
+ const source = specText(record.spec, "source").toLowerCase();
157
+ return `${record.agentName.toLowerCase()}|${record.kind}|${filePath}|${ownerEmail}|${source}`;
158
+ }
159
+ function writeRecord(locator, record) {
160
+ const normalized = normalizeRecord(record);
161
+ if (!normalized) {
162
+ throw new Error(`invalid background operation record: ${locator.id}`);
163
+ }
164
+ fs.mkdirSync(operationsDir(locator.agentName, locator.agentRoot), { recursive: true });
165
+ fs.writeFileSync(operationPath(locator), `${JSON.stringify(normalized, null, 2)}\n`, "utf-8");
166
+ (0, runtime_1.emitNervesEvent)({
167
+ component: "engine",
168
+ event: "engine.background_operation_written",
169
+ message: "background operation state written",
170
+ meta: { agentName: locator.agentName, id: locator.id, kind: normalized.kind, status: normalized.status },
171
+ });
172
+ return normalized;
173
+ }
174
+ function requireRecord(locator) {
175
+ const record = readBackgroundOperation(locator);
176
+ if (!record) {
177
+ throw new Error(`background operation not found: ${locator.id}`);
178
+ }
179
+ return record;
180
+ }
181
+ function readBackgroundOperation(locator) {
182
+ return readRecord(operationPath(locator));
183
+ }
184
+ function listBackgroundOperations(input) {
185
+ const dir = operationsDir(input.agentName, input.agentRoot);
186
+ if (!fs.existsSync(dir))
187
+ return [];
188
+ let entries;
189
+ try {
190
+ entries = fs.readdirSync(dir);
191
+ }
192
+ catch {
193
+ return [];
194
+ }
195
+ const records = entries
196
+ .filter((entry) => entry.endsWith(".json"))
197
+ .map((entry) => readRecord(path.join(dir, entry)))
198
+ .filter((entry) => entry !== null)
199
+ .sort((left, right) => Date.parse(right.updatedAt) - Date.parse(left.updatedAt));
200
+ const visibleKeys = new Set();
201
+ const visible = records.filter((record) => {
202
+ const key = visibleOperationKey(record);
203
+ if (!key)
204
+ return true;
205
+ if (visibleKeys.has(key))
206
+ return false;
207
+ visibleKeys.add(key);
208
+ return true;
209
+ });
210
+ return visible.slice(0, input.limit ?? 10);
211
+ }
212
+ function startBackgroundOperation(input) {
213
+ return writeRecord(input, {
214
+ schemaVersion: 1,
215
+ id: input.id,
216
+ agentName: input.agentName,
217
+ kind: input.kind,
218
+ title: input.title,
219
+ status: "queued",
220
+ summary: input.summary,
221
+ createdAt: input.createdAt,
222
+ updatedAt: input.createdAt,
223
+ ...(input.spec ? { spec: input.spec } : {}),
224
+ });
225
+ }
226
+ function markBackgroundOperationRunning(input) {
227
+ const current = requireRecord(input);
228
+ const updatedAt = input.updatedAt ?? input.startedAt;
229
+ return writeRecord(input, {
230
+ ...current,
231
+ status: "running",
232
+ summary: input.summary ?? current.summary,
233
+ ...(input.detail ? { detail: input.detail } : {}),
234
+ ...(normalizeProgress(input.progress) ? { progress: normalizeProgress(input.progress) } : {}),
235
+ startedAt: input.startedAt,
236
+ updatedAt,
237
+ ...(current.finishedAt ? { finishedAt: current.finishedAt } : {}),
238
+ });
239
+ }
240
+ function updateBackgroundOperation(input) {
241
+ const current = requireRecord(input);
242
+ return writeRecord(input, {
243
+ ...current,
244
+ summary: input.summary ?? current.summary,
245
+ ...(input.detail ? { detail: input.detail } : {}),
246
+ ...(normalizeProgress(input.progress) ? { progress: normalizeProgress(input.progress) } : {}),
247
+ ...(input.spec ? { spec: input.spec } : {}),
248
+ updatedAt: input.updatedAt ?? current.updatedAt,
249
+ });
250
+ }
251
+ function completeBackgroundOperation(input) {
252
+ const current = requireRecord(input);
253
+ return writeRecord(input, {
254
+ ...current,
255
+ status: "succeeded",
256
+ summary: input.summary ?? current.summary,
257
+ ...(input.detail ? { detail: input.detail } : {}),
258
+ ...(normalizeProgress(input.progress) ? { progress: normalizeProgress(input.progress) } : {}),
259
+ ...(input.result ? { result: input.result } : {}),
260
+ error: undefined,
261
+ remediation: undefined,
262
+ failure: undefined,
263
+ finishedAt: input.finishedAt,
264
+ updatedAt: input.updatedAt ?? input.finishedAt,
265
+ });
266
+ }
267
+ function failBackgroundOperation(input) {
268
+ const current = requireRecord(input);
269
+ return writeRecord(input, {
270
+ ...current,
271
+ status: "failed",
272
+ summary: input.summary ?? current.summary,
273
+ ...(input.detail ? { detail: input.detail } : {}),
274
+ ...(normalizeProgress(input.progress) ? { progress: normalizeProgress(input.progress) } : {}),
275
+ error: { message: input.error },
276
+ ...(input.failure ? { failure: input.failure } : {}),
277
+ ...(input.remediation && input.remediation.length > 0 ? { remediation: input.remediation } : {}),
278
+ finishedAt: input.finishedAt,
279
+ updatedAt: input.updatedAt ?? input.finishedAt,
280
+ });
281
+ }
@@ -0,0 +1,358 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.formatBridgeStatus = formatBridgeStatus;
4
+ exports.formatBridgeContext = formatBridgeContext;
5
+ exports.createBridgeManager = createBridgeManager;
6
+ const runtime_1 = require("../../nerves/runtime");
7
+ const state_machine_1 = require("./state-machine");
8
+ const store_1 = require("./store");
9
+ const turn_coordinator_1 = require("../turn-coordinator");
10
+ const tasks_1 = require("../../repertoire/tasks");
11
+ function defaultIdFactory() {
12
+ return `bridge-${Date.now().toString(36)}`;
13
+ }
14
+ function sessionIdentityKey(session) {
15
+ return `${session.friendId}/${session.channel}/${session.key}`;
16
+ }
17
+ function assertBridgeMutable(bridge, action) {
18
+ if (bridge.lifecycle === "completed" || bridge.lifecycle === "cancelled") {
19
+ throw new Error(`cannot ${action} a terminal bridge`);
20
+ }
21
+ }
22
+ function defaultTaskBody(bridge) {
23
+ const lines = [
24
+ "## scope",
25
+ bridge.objective,
26
+ "",
27
+ "## bridge",
28
+ `id: ${bridge.id}`,
29
+ ];
30
+ if (bridge.attachedSessions.length > 0) {
31
+ lines.push("sessions:");
32
+ for (const session of bridge.attachedSessions) {
33
+ lines.push(`- ${sessionIdentityKey(session)}`);
34
+ }
35
+ }
36
+ return lines.join("\n");
37
+ }
38
+ function formatBridgeStatus(bridge) {
39
+ const summary = typeof bridge.summary === "string" ? bridge.summary.trim() : "";
40
+ const lines = [
41
+ `bridge: ${bridge.id}`,
42
+ `objective: ${bridge.objective}`,
43
+ `state: ${(0, state_machine_1.bridgeStateLabel)(bridge)}`,
44
+ `sessions: ${bridge.attachedSessions.length}`,
45
+ `task: ${bridge.task?.taskName ?? "none"}`,
46
+ ];
47
+ if (summary) {
48
+ lines.push(`summary: ${summary}`);
49
+ }
50
+ return lines.join("\n");
51
+ }
52
+ function formatBridgeContext(bridges) {
53
+ if (bridges.length === 0)
54
+ return "";
55
+ const lines = ["## active bridge work"];
56
+ for (const bridge of bridges) {
57
+ const task = bridge.task?.taskName ? ` (task: ${bridge.task.taskName})` : "";
58
+ const label = typeof bridge.summary === "string" && bridge.summary.trim().length > 0 ? bridge.summary.trim() : bridge.objective;
59
+ lines.push(`- ${bridge.id}: ${label} [${(0, state_machine_1.bridgeStateLabel)(bridge)}]${task}`);
60
+ }
61
+ return lines.join("\n");
62
+ }
63
+ function ensureRunnable(bridge, now, store) {
64
+ if (bridge.lifecycle === "forming" || bridge.lifecycle === "suspended") {
65
+ const activated = {
66
+ ...bridge,
67
+ ...(0, state_machine_1.activateBridge)(bridge),
68
+ updatedAt: now(),
69
+ };
70
+ return store.save(activated);
71
+ }
72
+ if (bridge.lifecycle === "completed" || bridge.lifecycle === "cancelled") {
73
+ throw new Error(`bridge is terminal: ${bridge.id}`);
74
+ }
75
+ return bridge;
76
+ }
77
+ function sessionMatches(left, right) {
78
+ return left.friendId === right.friendId && left.channel === right.channel && left.key === right.key;
79
+ }
80
+ function hasAttachedSessionActivity(bridge, sessionActivity) {
81
+ return sessionActivity.some((activity) => activity.channel !== "inner"
82
+ && bridge.attachedSessions.some((session) => sessionMatches(activity, session)));
83
+ }
84
+ function hasLiveTaskStatus(bridge, taskBoard) {
85
+ const taskName = bridge.task?.taskName;
86
+ if (!taskName)
87
+ return false;
88
+ return (taskBoard.byStatus.processing.includes(taskName)
89
+ || taskBoard.byStatus.collaborating.includes(taskName)
90
+ || taskBoard.byStatus.validating.includes(taskName));
91
+ }
92
+ function isCurrentSessionAttached(bridge, currentSession) {
93
+ if (!currentSession)
94
+ return false;
95
+ return bridge.attachedSessions.some((session) => sessionMatches(session, currentSession));
96
+ }
97
+ function createBridgeManager(options = {}) {
98
+ const store = options.store ?? (0, store_1.createBridgeStore)();
99
+ const now = options.now ?? (() => new Date().toISOString());
100
+ const idFactory = options.idFactory ?? defaultIdFactory;
101
+ function requireBridge(bridgeId) {
102
+ const bridge = store.get(bridgeId);
103
+ if (!bridge) {
104
+ throw new Error(`bridge not found: ${bridgeId}`);
105
+ }
106
+ return bridge;
107
+ }
108
+ function save(bridge) {
109
+ return store.save(bridge);
110
+ }
111
+ return {
112
+ beginBridge(input) {
113
+ const timestamp = now();
114
+ const state = (0, state_machine_1.activateBridge)((0, state_machine_1.createBridgeState)());
115
+ const bridge = {
116
+ id: idFactory(),
117
+ objective: input.objective,
118
+ summary: input.summary,
119
+ lifecycle: state.lifecycle,
120
+ runtime: state.runtime,
121
+ createdAt: timestamp,
122
+ updatedAt: timestamp,
123
+ attachedSessions: [input.session],
124
+ task: null,
125
+ };
126
+ (0, runtime_1.emitNervesEvent)({
127
+ component: "engine",
128
+ event: "engine.bridge_begin",
129
+ message: "created bridge",
130
+ meta: {
131
+ bridgeId: bridge.id,
132
+ session: sessionIdentityKey(input.session),
133
+ },
134
+ });
135
+ return save(bridge);
136
+ },
137
+ attachSession(bridgeId, session) {
138
+ const bridge = requireBridge(bridgeId);
139
+ assertBridgeMutable(bridge, "attach session to");
140
+ const existing = bridge.attachedSessions.some((candidate) => sessionIdentityKey(candidate) === sessionIdentityKey(session));
141
+ if (existing)
142
+ return bridge;
143
+ const updated = {
144
+ ...bridge,
145
+ attachedSessions: [...bridge.attachedSessions, session],
146
+ updatedAt: now(),
147
+ };
148
+ (0, runtime_1.emitNervesEvent)({
149
+ component: "engine",
150
+ event: "engine.bridge_attach_session",
151
+ message: "attached canonical session to bridge",
152
+ meta: {
153
+ bridgeId,
154
+ session: sessionIdentityKey(session),
155
+ },
156
+ });
157
+ return save(updated);
158
+ },
159
+ detachSession(bridgeId, session) {
160
+ const bridge = requireBridge(bridgeId);
161
+ assertBridgeMutable(bridge, "detach session from");
162
+ const updated = {
163
+ ...bridge,
164
+ attachedSessions: bridge.attachedSessions.filter((candidate) => sessionIdentityKey(candidate) !== sessionIdentityKey(session)),
165
+ updatedAt: now(),
166
+ };
167
+ (0, runtime_1.emitNervesEvent)({
168
+ component: "engine",
169
+ event: "engine.bridge_detach_session",
170
+ message: "detached canonical session from bridge",
171
+ meta: {
172
+ bridgeId,
173
+ session: sessionIdentityKey(session),
174
+ },
175
+ });
176
+ return save(updated);
177
+ },
178
+ getBridge(bridgeId) {
179
+ return store.get(bridgeId);
180
+ },
181
+ listBridges() {
182
+ return store.list();
183
+ },
184
+ findBridgesForSession(session) {
185
+ return store.findBySession(session)
186
+ .filter((bridge) => bridge.lifecycle !== "completed" && bridge.lifecycle !== "cancelled");
187
+ },
188
+ reconcileLifecycles(input) {
189
+ return store.list().map((bridge) => {
190
+ const nextState = (0, state_machine_1.reconcileBridgeState)(bridge, {
191
+ hasAttachedSessionActivity: hasAttachedSessionActivity(bridge, input.sessionActivity),
192
+ hasLiveTask: hasLiveTaskStatus(bridge, input.taskBoard),
193
+ currentSessionAttached: isCurrentSessionAttached(bridge, input.currentSession),
194
+ });
195
+ if (nextState.lifecycle === bridge.lifecycle && nextState.runtime === bridge.runtime) {
196
+ return bridge;
197
+ }
198
+ return save({
199
+ ...bridge,
200
+ ...nextState,
201
+ updatedAt: now(),
202
+ });
203
+ });
204
+ },
205
+ promoteBridgeToTask(bridgeId, input = {}) {
206
+ const bridge = requireBridge(bridgeId);
207
+ assertBridgeMutable(bridge, "promote");
208
+ if (bridge.task)
209
+ return bridge;
210
+ const taskPath = (0, tasks_1.getTaskModule)().createTask({
211
+ title: input.title?.trim() || bridge.objective,
212
+ type: "ongoing",
213
+ category: input.category?.trim() || "coordination",
214
+ status: "processing",
215
+ body: input.body?.trim() || defaultTaskBody(bridge),
216
+ activeBridge: bridge.id,
217
+ bridgeSessions: bridge.attachedSessions.map((session) => sessionIdentityKey(session)),
218
+ });
219
+ const taskName = taskPath.replace(/^.*\//, "").replace(/\.md$/, "");
220
+ const updated = save({
221
+ ...bridge,
222
+ task: {
223
+ taskName,
224
+ path: taskPath,
225
+ mode: "promoted",
226
+ boundAt: now(),
227
+ },
228
+ updatedAt: now(),
229
+ });
230
+ (0, runtime_1.emitNervesEvent)({
231
+ component: "engine",
232
+ event: "engine.bridge_promote_task",
233
+ message: "promoted bridge to task-backed work",
234
+ meta: {
235
+ bridgeId,
236
+ taskName,
237
+ },
238
+ });
239
+ return updated;
240
+ },
241
+ completeBridge(bridgeId) {
242
+ const bridge = requireBridge(bridgeId);
243
+ const updated = save({
244
+ ...bridge,
245
+ ...(0, state_machine_1.completeBridge)(bridge),
246
+ updatedAt: now(),
247
+ });
248
+ (0, runtime_1.emitNervesEvent)({
249
+ component: "engine",
250
+ event: "engine.bridge_complete",
251
+ message: "completed bridge",
252
+ meta: {
253
+ bridgeId,
254
+ },
255
+ });
256
+ return updated;
257
+ },
258
+ cancelBridge(bridgeId) {
259
+ const bridge = requireBridge(bridgeId);
260
+ const updated = save({
261
+ ...bridge,
262
+ ...(0, state_machine_1.cancelBridge)(bridge),
263
+ updatedAt: now(),
264
+ });
265
+ (0, runtime_1.emitNervesEvent)({
266
+ component: "engine",
267
+ event: "engine.bridge_cancel",
268
+ message: "cancelled bridge",
269
+ meta: {
270
+ bridgeId,
271
+ },
272
+ });
273
+ return updated;
274
+ },
275
+ async runBridgeTurn(bridgeId, fn) {
276
+ if (!(0, turn_coordinator_1.tryBeginSharedTurn)("bridge", bridgeId)) {
277
+ const bridge = requireBridge(bridgeId);
278
+ const queued = bridge.runtime === "awaiting-follow-up"
279
+ ? bridge
280
+ : save({
281
+ ...bridge,
282
+ ...(0, state_machine_1.queueBridgeFollowUp)(bridge),
283
+ updatedAt: now(),
284
+ });
285
+ (0, turn_coordinator_1.enqueueSharedFollowUp)("bridge", bridgeId, {
286
+ conversationId: bridgeId,
287
+ text: "bridge follow-up",
288
+ receivedAt: Date.now(),
289
+ effect: "none",
290
+ });
291
+ (0, runtime_1.emitNervesEvent)({
292
+ component: "engine",
293
+ event: "engine.bridge_turn_queued",
294
+ message: "queued follow-up bridge turn",
295
+ meta: {
296
+ bridgeId,
297
+ },
298
+ });
299
+ return {
300
+ queued: true,
301
+ bridge: queued,
302
+ };
303
+ }
304
+ try {
305
+ let current = ensureRunnable(requireBridge(bridgeId), now, store);
306
+ current = save({
307
+ ...current,
308
+ ...(0, state_machine_1.beginBridgeProcessing)(current),
309
+ updatedAt: now(),
310
+ });
311
+ while (true) {
312
+ (0, runtime_1.emitNervesEvent)({
313
+ component: "engine",
314
+ event: "engine.bridge_turn_start",
315
+ message: "running bridge turn",
316
+ meta: {
317
+ bridgeId,
318
+ },
319
+ });
320
+ await fn();
321
+ let next = requireBridge(bridgeId);
322
+ const bufferedFollowUps = (0, turn_coordinator_1.drainSharedFollowUps)("bridge", bridgeId);
323
+ if (bufferedFollowUps.length > 0 && next.runtime !== "awaiting-follow-up") {
324
+ next = save({
325
+ ...next,
326
+ ...(0, state_machine_1.queueBridgeFollowUp)(next),
327
+ updatedAt: now(),
328
+ });
329
+ }
330
+ const advanced = save({
331
+ ...next,
332
+ ...(0, state_machine_1.advanceBridgeAfterTurn)(next),
333
+ updatedAt: now(),
334
+ });
335
+ if (advanced.runtime === "processing") {
336
+ current = advanced;
337
+ continue;
338
+ }
339
+ (0, runtime_1.emitNervesEvent)({
340
+ component: "engine",
341
+ event: "engine.bridge_turn_end",
342
+ message: "bridge turn finished",
343
+ meta: {
344
+ bridgeId,
345
+ },
346
+ });
347
+ return {
348
+ queued: false,
349
+ bridge: current = advanced,
350
+ };
351
+ }
352
+ }
353
+ finally {
354
+ (0, turn_coordinator_1.endSharedTurn)("bridge", bridgeId);
355
+ }
356
+ },
357
+ };
358
+ }