@ouro.bot/cli 0.1.0-alpha.62 → 0.1.0-alpha.637
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.
- package/README.md +127 -23
- package/RepairGuide.ouro/agent.json +5 -0
- package/RepairGuide.ouro/psyche/IDENTITY.md +19 -0
- package/RepairGuide.ouro/psyche/SOUL.md +55 -0
- package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
- package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
- package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
- package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/changelog.json +4087 -13
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +144 -0
- package/dist/arc/episodes.js +118 -0
- package/dist/arc/evolution.js +487 -0
- package/dist/arc/intentions.js +134 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +270 -0
- package/dist/arc/packets.js +288 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +57 -0
- package/dist/heart/active-work.js +860 -43
- package/dist/heart/agent-entry.js +69 -3
- package/dist/heart/attachments/image-normalize.js +194 -0
- package/dist/heart/attachments/materialize.js +97 -0
- package/dist/heart/attachments/originals.js +88 -0
- package/dist/heart/attachments/render.js +29 -0
- package/dist/heart/attachments/sources/bluebubbles.js +156 -0
- package/dist/heart/attachments/sources/cli-local-file.js +78 -0
- package/dist/heart/attachments/sources/index.js +16 -0
- package/dist/heart/attachments/store.js +103 -0
- package/dist/heart/attachments/types.js +93 -0
- package/dist/heart/auth/auth-flow.js +479 -0
- package/dist/heart/awaiting/await-alert.js +146 -0
- package/dist/heart/awaiting/await-expiry.js +108 -0
- package/dist/heart/awaiting/await-loader.js +91 -0
- package/dist/heart/awaiting/await-parser.js +141 -0
- package/dist/heart/awaiting/await-runtime-state.js +100 -0
- package/dist/heart/awaiting/await-scheduler.js +377 -0
- package/dist/heart/background-operations.js +281 -0
- package/dist/heart/bridges/manager.js +137 -17
- package/dist/heart/bridges/store.js +14 -2
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +135 -0
- package/dist/heart/config-registry.js +322 -0
- package/dist/heart/config.js +114 -119
- package/dist/heart/core.js +1028 -248
- package/dist/heart/cross-chat-delivery.js +3 -18
- package/dist/heart/daemon/agent-config-check.js +419 -0
- package/dist/heart/daemon/agent-discovery.js +102 -3
- package/dist/heart/daemon/agent-service.js +522 -0
- package/dist/heart/daemon/agentic-repair.js +547 -0
- package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
- package/dist/heart/daemon/boot-sync-probe.js +197 -0
- package/dist/heart/daemon/cadence.js +70 -0
- package/dist/heart/daemon/cli-defaults.js +776 -0
- package/dist/heart/daemon/cli-desk.js +322 -0
- package/dist/heart/daemon/cli-exec.js +7468 -0
- package/dist/heart/daemon/cli-help.js +505 -0
- package/dist/heart/daemon/cli-parse.js +1554 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +763 -0
- package/dist/heart/daemon/cli-types.js +8 -0
- package/dist/heart/daemon/connect-bay.js +323 -0
- package/dist/heart/daemon/daemon-cli.js +29 -1700
- package/dist/heart/daemon/daemon-entry.js +485 -2
- package/dist/heart/daemon/daemon-health.js +176 -0
- package/dist/heart/daemon/daemon-rollup.js +57 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +88 -13
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +906 -71
- package/dist/heart/daemon/dns-workflow.js +394 -0
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +873 -0
- package/dist/heart/daemon/health-monitor.js +122 -1
- package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
- package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/human-command-screens.js +234 -0
- package/dist/heart/daemon/human-readiness.js +114 -0
- package/dist/heart/daemon/inner-status.js +89 -0
- package/dist/heart/daemon/interactive-repair.js +394 -0
- package/dist/heart/daemon/launchd.js +37 -8
- package/dist/heart/daemon/log-tailer.js +79 -10
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/migrate-to-desk.js +848 -0
- package/dist/heart/daemon/os-cron-deps.js +135 -0
- package/dist/heart/daemon/os-cron.js +14 -12
- package/dist/heart/daemon/ouro-bot-entry.js +4 -2
- package/dist/heart/daemon/ouro-entry.js +3 -1
- package/dist/heart/daemon/plugin-cli.js +432 -0
- package/dist/heart/daemon/process-manager.js +501 -35
- package/dist/heart/daemon/provider-discovery.js +137 -0
- package/dist/heart/daemon/provider-ping-progress.js +83 -0
- package/dist/heart/daemon/pulse.js +475 -0
- package/dist/heart/daemon/readiness-repair.js +365 -0
- package/dist/heart/daemon/run-hooks.js +2 -0
- package/dist/heart/daemon/runtime-logging.js +11 -3
- package/dist/heart/daemon/runtime-metadata.js +2 -30
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +493 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +22 -9
- package/dist/heart/daemon/socket-client.js +158 -11
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +330 -0
- package/dist/heart/daemon/task-scheduler.js +117 -39
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +229 -17
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/daemon/vault-items.js +56 -0
- package/dist/heart/delegation.js +1 -4
- package/dist/heart/habits/habit-migration.js +189 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-runtime-state.js +100 -0
- package/dist/heart/habits/habit-scheduler.js +372 -0
- package/dist/heart/{daemon → hatch}/hatch-flow.js +32 -56
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
- package/dist/heart/{daemon → hatch}/specialist-tools.js +37 -14
- package/dist/heart/identity.js +168 -57
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +1 -1
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mail-import-discovery.js +353 -0
- package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
- package/dist/heart/mailbox/mailbox-http-static.js +103 -0
- package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
- package/dist/heart/mailbox/mailbox-http.js +99 -0
- package/dist/heart/mailbox/mailbox-read.js +31 -0
- package/dist/heart/mailbox/mailbox-types.js +27 -0
- package/dist/heart/mailbox/mailbox-view.js +197 -0
- package/dist/heart/mailbox/readers/agent-machine.js +418 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +319 -0
- package/dist/heart/mailbox/readers/mail.js +375 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +756 -0
- package/dist/heart/mailbox/readers/sessions.js +232 -0
- package/dist/heart/mailbox/readers/shared.js +111 -0
- package/dist/heart/mcp/mcp-server.js +692 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/orientation-frame.js +217 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +272 -0
- package/dist/heart/provider-credentials.js +425 -0
- package/dist/heart/provider-failover.js +301 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +262 -0
- package/dist/heart/provider-readiness-cache.js +40 -0
- package/dist/heart/provider-visibility.js +188 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +139 -52
- package/dist/heart/providers/azure.js +23 -11
- package/dist/heart/providers/error-classification.js +127 -0
- package/dist/heart/providers/github-copilot.js +145 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +26 -8
- package/dist/heart/providers/openai-codex.js +55 -40
- package/dist/heart/runtime-capability-check.js +170 -0
- package/dist/heart/runtime-credentials.js +367 -0
- package/dist/heart/runtime-cwd.js +87 -0
- package/dist/heart/sense-truth.js +13 -4
- package/dist/heart/session-activity.js +48 -24
- package/dist/heart/session-events.js +1163 -0
- package/dist/heart/session-playback-cli-main.js +5 -0
- package/dist/heart/session-playback-cli.js +36 -0
- package/dist/heart/session-playback.js +231 -0
- package/dist/heart/session-stats-cli-main.js +5 -0
- package/dist/heart/session-stats.js +182 -0
- package/dist/heart/session-transcript.js +133 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- package/dist/heart/structured-output.js +196 -0
- package/dist/heart/sync-classification.js +176 -0
- package/dist/heart/sync.js +449 -0
- package/dist/heart/target-resolution.js +9 -5
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/timeouts.js +101 -0
- package/dist/heart/tool-activity-callbacks.js +59 -0
- package/dist/heart/tool-description.js +143 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +389 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +426 -0
- package/dist/heart/versioning/ouro-version-manager.js +295 -0
- package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
- package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- package/dist/mailbox-ui/assets/index-9-AxCxuB.js +61 -0
- package/dist/mailbox-ui/assets/index-CWzt267f.css +1 -0
- package/dist/mailbox-ui/index.html +15 -0
- package/dist/mailroom/attention.js +167 -0
- package/dist/mailroom/autonomy.js +209 -0
- package/dist/mailroom/blob-store.js +715 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +788 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +568 -0
- package/dist/mailroom/mbox-import.js +393 -0
- package/dist/mailroom/migration.js +164 -0
- package/dist/mailroom/outbound.js +380 -0
- package/dist/mailroom/policy.js +263 -0
- package/dist/mailroom/reader.js +233 -0
- package/dist/mailroom/search-cache.js +334 -0
- package/dist/mailroom/search-relevance.js +319 -0
- package/dist/mailroom/smtp-ingress.js +176 -0
- package/dist/mailroom/source-state.js +176 -0
- package/dist/mailroom/thread.js +109 -0
- package/dist/mailroom/travel-extract.js +89 -0
- package/dist/mind/bundle-manifest.js +14 -1
- package/dist/mind/context.js +251 -101
- package/dist/mind/desk-section.js +310 -0
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +68 -76
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +39 -0
- package/dist/mind/friends/resolver.js +54 -2
- package/dist/mind/friends/store-file.js +48 -4
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +162 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +6 -1
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1075 -146
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/nerves/cli-logging.js +7 -1
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +139 -5
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +15 -56
- package/dist/repertoire/ado-semantic.js +16 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +1040 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +331 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +166 -10
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +219 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +178 -0
- package/dist/repertoire/desk/classifier.js +362 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +385 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +403 -0
- package/dist/repertoire/mcp-tools.js +83 -0
- package/dist/repertoire/plugin-mcp.js +175 -0
- package/dist/repertoire/plugins.js +253 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +48 -4
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-awaiting.js +372 -0
- package/dist/repertoire/tools-base.js +59 -1082
- package/dist/repertoire/tools-bluebubbles.js +2 -0
- package/dist/repertoire/tools-bridge.js +144 -0
- package/dist/repertoire/tools-bundle.js +993 -0
- package/dist/repertoire/tools-config.js +186 -0
- package/dist/repertoire/tools-continuity.js +252 -0
- package/dist/repertoire/tools-credential.js +383 -0
- package/dist/repertoire/tools-evolution.js +527 -0
- package/dist/repertoire/tools-files.js +344 -0
- package/dist/repertoire/tools-flight.js +227 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +3 -8
- package/dist/repertoire/tools-mail.js +1975 -0
- package/dist/repertoire/tools-notes.js +438 -0
- package/dist/repertoire/tools-obligations.js +143 -0
- package/dist/repertoire/tools-orientation.js +31 -0
- package/dist/repertoire/tools-record.js +464 -0
- package/dist/repertoire/tools-runtime.js +150 -0
- package/dist/repertoire/tools-session.js +766 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +182 -0
- package/dist/repertoire/tools-surface.js +344 -0
- package/dist/repertoire/tools-teams.js +12 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +982 -0
- package/dist/repertoire/tools-user-profile.js +146 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools-voice.js +145 -0
- package/dist/repertoire/tools.js +215 -103
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +594 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/attention-queue.js +186 -0
- package/dist/senses/await-turn-message.js +58 -0
- package/dist/senses/bluebubbles/active-turns.js +216 -0
- package/dist/senses/bluebubbles/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
- package/dist/senses/bluebubbles/index.js +2737 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -71
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
- package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
- package/dist/senses/bluebubbles-meta-guard.js +40 -0
- package/dist/senses/cli/bracketed-paste.js +82 -0
- package/dist/senses/cli/image-paste.js +287 -0
- package/dist/senses/cli/image-ref-navigation.js +75 -0
- package/dist/senses/cli/ink-app.js +156 -0
- package/dist/senses/cli/inline-diff.js +64 -0
- package/dist/senses/cli/input-keys.js +174 -0
- package/dist/senses/cli/kill-ring.js +86 -0
- package/dist/senses/cli/message-list.js +51 -0
- package/dist/senses/cli/ouro-tui.js +607 -0
- package/dist/senses/cli/spinner-imperative.js +135 -0
- package/dist/senses/cli/spinner.js +101 -0
- package/dist/senses/cli/status-line.js +60 -0
- package/dist/senses/cli/streaming-markdown.js +526 -0
- package/dist/senses/cli/tool-display.js +85 -0
- package/dist/senses/cli/tool-render.js +85 -0
- package/dist/senses/cli/tui-store.js +240 -0
- package/dist/senses/cli/virtual-list.js +35 -0
- package/dist/senses/cli-entry.js +60 -8
- package/dist/senses/cli-layout.js +100 -0
- package/dist/senses/cli.js +517 -204
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +254 -22
- package/dist/senses/inner-dialog.js +505 -40
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +666 -181
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +393 -0
- package/dist/senses/surface-tool.js +108 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +388 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/senses/voice/audio-playback.js +237 -0
- package/dist/senses/voice/audio-routing.js +119 -0
- package/dist/senses/voice/elevenlabs.js +202 -0
- package/dist/senses/voice/floor-control.js +431 -0
- package/dist/senses/voice/floor-controller.js +115 -0
- package/dist/senses/voice/golden-path.js +116 -0
- package/dist/senses/voice/index.js +29 -0
- package/dist/senses/voice/meeting.js +113 -0
- package/dist/senses/voice/outbound.js +190 -0
- package/dist/senses/voice/phone.js +33 -0
- package/dist/senses/voice/playback.js +139 -0
- package/dist/senses/voice/realtime-eval.js +496 -0
- package/dist/senses/voice/realtime-trace.js +531 -0
- package/dist/senses/voice/transcript.js +70 -0
- package/dist/senses/voice/turn.js +191 -0
- package/dist/senses/voice/twilio-phone-runtime.js +807 -0
- package/dist/senses/voice/twilio-phone.js +5079 -0
- package/dist/senses/voice/types.js +2 -0
- package/dist/senses/voice/whisper.js +161 -0
- package/dist/senses/voice-entry.js +81 -0
- package/dist/senses/voice-realtime-eval-command.js +99 -0
- package/dist/senses/voice-realtime-eval-entry.js +21 -0
- package/dist/senses/voice-twilio-entry.js +87 -0
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +265 -0
- package/dist/util/frontmatter.js +53 -0
- package/package.json +48 -8
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +99 -0
- package/skills/travel-planning.md +138 -0
- package/dist/heart/daemon/auth-flow.js +0 -351
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/safe-workspace.js +0 -228
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- package/dist/repertoire/tasks/board.js +0 -134
- package/dist/repertoire/tasks/index.js +0 -224
- package/dist/repertoire/tasks/lifecycle.js +0 -80
- package/dist/repertoire/tasks/middleware.js +0 -65
- package/dist/repertoire/tasks/parser.js +0 -173
- package/dist/repertoire/tasks/scanner.js +0 -132
- package/dist/repertoire/tasks/transitions.js +0 -144
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1177
- package/dist/senses/debug-activity.js +0 -148
- package/subagents/README.md +0 -7
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
- /package/dist/{repertoire/tasks/types.js → heart/attachments/sources/adapter.js} +0 -0
- /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
- /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
- /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
- /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
|
@@ -0,0 +1,367 @@
|
|
|
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.MACHINE_RUNTIME_CONFIG_ITEM_PREFIX = exports.RUNTIME_CONFIG_ITEM_NAME = void 0;
|
|
37
|
+
exports.machineRuntimeConfigItemName = machineRuntimeConfigItemName;
|
|
38
|
+
exports.readRuntimeCredentialConfig = readRuntimeCredentialConfig;
|
|
39
|
+
exports.readMachineRuntimeCredentialConfig = readMachineRuntimeCredentialConfig;
|
|
40
|
+
exports.cacheRuntimeCredentialConfig = cacheRuntimeCredentialConfig;
|
|
41
|
+
exports.cacheMachineRuntimeCredentialConfig = cacheMachineRuntimeCredentialConfig;
|
|
42
|
+
exports.applyRuntimeCredentialBootstrapMessage = applyRuntimeCredentialBootstrapMessage;
|
|
43
|
+
exports.waitForRuntimeCredentialBootstrap = waitForRuntimeCredentialBootstrap;
|
|
44
|
+
exports.refreshRuntimeCredentialConfig = refreshRuntimeCredentialConfig;
|
|
45
|
+
exports.refreshMachineRuntimeCredentialConfig = refreshMachineRuntimeCredentialConfig;
|
|
46
|
+
exports.upsertRuntimeCredentialConfig = upsertRuntimeCredentialConfig;
|
|
47
|
+
exports.upsertMachineRuntimeCredentialConfig = upsertMachineRuntimeCredentialConfig;
|
|
48
|
+
exports.resetRuntimeCredentialConfigCache = resetRuntimeCredentialConfigCache;
|
|
49
|
+
const crypto = __importStar(require("node:crypto"));
|
|
50
|
+
const runtime_1 = require("../nerves/runtime");
|
|
51
|
+
const credential_access_1 = require("../repertoire/credential-access");
|
|
52
|
+
const identity_1 = require("./identity");
|
|
53
|
+
const provider_credentials_1 = require("./provider-credentials");
|
|
54
|
+
exports.RUNTIME_CONFIG_ITEM_NAME = "runtime/config";
|
|
55
|
+
exports.MACHINE_RUNTIME_CONFIG_ITEM_PREFIX = "runtime/machines";
|
|
56
|
+
let cachedRuntimeConfigs = new Map();
|
|
57
|
+
let cachedMachineRuntimeConfigs = new Map();
|
|
58
|
+
function isRecord(value) {
|
|
59
|
+
return !!value && typeof value === "object" && !Array.isArray(value);
|
|
60
|
+
}
|
|
61
|
+
function isCredentialValue(value) {
|
|
62
|
+
return typeof value === "string" || typeof value === "number";
|
|
63
|
+
}
|
|
64
|
+
function isCredentialRecord(value) {
|
|
65
|
+
if (!isRecord(value))
|
|
66
|
+
return false;
|
|
67
|
+
return Object.values(value).every(isCredentialValue);
|
|
68
|
+
}
|
|
69
|
+
function isProviderCredentialRecord(value) {
|
|
70
|
+
if (!isRecord(value))
|
|
71
|
+
return false;
|
|
72
|
+
if (typeof value.provider !== "string")
|
|
73
|
+
return false;
|
|
74
|
+
if (typeof value.revision !== "string" || value.revision.trim().length === 0)
|
|
75
|
+
return false;
|
|
76
|
+
if (typeof value.updatedAt !== "string" || value.updatedAt.trim().length === 0)
|
|
77
|
+
return false;
|
|
78
|
+
if (!isCredentialRecord(value.credentials))
|
|
79
|
+
return false;
|
|
80
|
+
if (!isCredentialRecord(value.config))
|
|
81
|
+
return false;
|
|
82
|
+
const provenance = value.provenance;
|
|
83
|
+
if (!isRecord(provenance))
|
|
84
|
+
return false;
|
|
85
|
+
if (provenance.source !== "auth-flow" && provenance.source !== "manual")
|
|
86
|
+
return false;
|
|
87
|
+
if (typeof provenance.updatedAt !== "string" || provenance.updatedAt.trim().length === 0)
|
|
88
|
+
return false;
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
function stableJson(value) {
|
|
92
|
+
if (Array.isArray(value))
|
|
93
|
+
return `[${value.map(stableJson).join(",")}]`;
|
|
94
|
+
if (isRecord(value)) {
|
|
95
|
+
return `{${Object.keys(value).sort().map((key) => `${JSON.stringify(key)}:${stableJson(value[key])}`).join(",")}}`;
|
|
96
|
+
}
|
|
97
|
+
return JSON.stringify(value);
|
|
98
|
+
}
|
|
99
|
+
function runtimeConfigVaultPath(agentName, itemName = exports.RUNTIME_CONFIG_ITEM_NAME) {
|
|
100
|
+
return `vault:${agentName}:${itemName}`;
|
|
101
|
+
}
|
|
102
|
+
function machineRuntimeConfigItemName(machineId) {
|
|
103
|
+
const normalized = machineId.trim();
|
|
104
|
+
if (!normalized)
|
|
105
|
+
throw new Error("machineId must be non-empty");
|
|
106
|
+
return `${exports.MACHINE_RUNTIME_CONFIG_ITEM_PREFIX}/${normalized}/config`;
|
|
107
|
+
}
|
|
108
|
+
function runtimeConfigRevision(payload) {
|
|
109
|
+
return `runtime_${crypto
|
|
110
|
+
.createHash("sha256")
|
|
111
|
+
.update(stableJson(payload))
|
|
112
|
+
.digest("hex")
|
|
113
|
+
.slice(0, 16)}`;
|
|
114
|
+
}
|
|
115
|
+
function validateRuntimeCredentialPayload(value) {
|
|
116
|
+
if (!isRecord(value))
|
|
117
|
+
throw new Error("runtime credential payload must be an object");
|
|
118
|
+
if (value.schemaVersion !== 1)
|
|
119
|
+
throw new Error("runtime credential payload schemaVersion must be 1");
|
|
120
|
+
if (value.kind !== "runtime-config")
|
|
121
|
+
throw new Error("runtime credential payload kind must be runtime-config");
|
|
122
|
+
if (typeof value.updatedAt !== "string" || value.updatedAt.trim().length === 0) {
|
|
123
|
+
throw new Error("runtime credential payload updatedAt must be non-empty");
|
|
124
|
+
}
|
|
125
|
+
if (!isRecord(value.config))
|
|
126
|
+
throw new Error("runtime credential payload config must be an object");
|
|
127
|
+
return value;
|
|
128
|
+
}
|
|
129
|
+
function resultFromPayload(agentName, payload) {
|
|
130
|
+
return {
|
|
131
|
+
ok: true,
|
|
132
|
+
itemPath: runtimeConfigVaultPath(agentName),
|
|
133
|
+
config: { ...payload.config },
|
|
134
|
+
revision: runtimeConfigRevision(payload),
|
|
135
|
+
updatedAt: payload.updatedAt,
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
function resultFromPayloadForItem(agentName, itemName, payload) {
|
|
139
|
+
return {
|
|
140
|
+
ok: true,
|
|
141
|
+
itemPath: runtimeConfigVaultPath(agentName, itemName),
|
|
142
|
+
config: { ...payload.config },
|
|
143
|
+
revision: runtimeConfigRevision(payload),
|
|
144
|
+
updatedAt: payload.updatedAt,
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
function missingRuntimeConfig(agentName, itemName = exports.RUNTIME_CONFIG_ITEM_NAME) {
|
|
148
|
+
return {
|
|
149
|
+
ok: false,
|
|
150
|
+
reason: "missing",
|
|
151
|
+
itemPath: runtimeConfigVaultPath(agentName, itemName),
|
|
152
|
+
error: `no runtime credentials stored at ${runtimeConfigVaultPath(agentName, itemName)}`,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
function cacheResult(agentName, result) {
|
|
156
|
+
cachedRuntimeConfigs.set(agentName, result);
|
|
157
|
+
return result;
|
|
158
|
+
}
|
|
159
|
+
function cacheMachineResult(agentName, result) {
|
|
160
|
+
cachedMachineRuntimeConfigs.set(agentName, result);
|
|
161
|
+
return result;
|
|
162
|
+
}
|
|
163
|
+
function missingMachineRuntimeConfig(agentName) {
|
|
164
|
+
return {
|
|
165
|
+
ok: false,
|
|
166
|
+
reason: "missing",
|
|
167
|
+
itemPath: `vault:${agentName}:${exports.MACHINE_RUNTIME_CONFIG_ITEM_PREFIX}/<this-machine>/config`,
|
|
168
|
+
error: `no machine runtime credentials loaded for ${agentName}`,
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
function readRuntimeCredentialConfig(agentName = (0, identity_1.getAgentName)()) {
|
|
172
|
+
return cachedRuntimeConfigs.get(agentName) ?? missingRuntimeConfig(agentName);
|
|
173
|
+
}
|
|
174
|
+
function readMachineRuntimeCredentialConfig(agentName = (0, identity_1.getAgentName)()) {
|
|
175
|
+
return cachedMachineRuntimeConfigs.get(agentName) ?? missingMachineRuntimeConfig(agentName);
|
|
176
|
+
}
|
|
177
|
+
function cacheRuntimeCredentialConfig(agentName, config, now = new Date()) {
|
|
178
|
+
const payload = {
|
|
179
|
+
schemaVersion: 1,
|
|
180
|
+
kind: "runtime-config",
|
|
181
|
+
updatedAt: now.toISOString(),
|
|
182
|
+
config: { ...config },
|
|
183
|
+
};
|
|
184
|
+
return cacheResult(agentName, resultFromPayload(agentName, payload));
|
|
185
|
+
}
|
|
186
|
+
function cacheMachineRuntimeCredentialConfig(agentName, config, now = new Date(), machineId = "<this-machine>") {
|
|
187
|
+
const payload = {
|
|
188
|
+
schemaVersion: 1,
|
|
189
|
+
kind: "runtime-config",
|
|
190
|
+
updatedAt: now.toISOString(),
|
|
191
|
+
config: { ...config },
|
|
192
|
+
};
|
|
193
|
+
return cacheMachineResult(agentName, resultFromPayloadForItem(agentName, machineRuntimeConfigItemName(machineId), payload));
|
|
194
|
+
}
|
|
195
|
+
function isRuntimeCredentialBootstrapMessage(value) {
|
|
196
|
+
if (!value || typeof value !== "object" || Array.isArray(value))
|
|
197
|
+
return false;
|
|
198
|
+
const record = value;
|
|
199
|
+
if (record.type !== "ouro.runtimeCredentialBootstrap")
|
|
200
|
+
return false;
|
|
201
|
+
if (typeof record.agentName !== "string" || record.agentName.trim().length === 0)
|
|
202
|
+
return false;
|
|
203
|
+
if (record.runtimeConfig !== undefined && !isRecord(record.runtimeConfig))
|
|
204
|
+
return false;
|
|
205
|
+
if (record.machineRuntimeConfig !== undefined && !isRecord(record.machineRuntimeConfig))
|
|
206
|
+
return false;
|
|
207
|
+
if (record.machineId !== undefined && (typeof record.machineId !== "string" || record.machineId.trim().length === 0))
|
|
208
|
+
return false;
|
|
209
|
+
if (record.providerCredentialRecords !== undefined
|
|
210
|
+
&& (!Array.isArray(record.providerCredentialRecords)
|
|
211
|
+
|| !record.providerCredentialRecords.every(isProviderCredentialRecord)))
|
|
212
|
+
return false;
|
|
213
|
+
return true;
|
|
214
|
+
}
|
|
215
|
+
function applyRuntimeCredentialBootstrapMessage(message) {
|
|
216
|
+
if (!isRuntimeCredentialBootstrapMessage(message))
|
|
217
|
+
return false;
|
|
218
|
+
const agentName = message.agentName.trim();
|
|
219
|
+
const now = new Date();
|
|
220
|
+
if (message.runtimeConfig) {
|
|
221
|
+
cacheRuntimeCredentialConfig(agentName, message.runtimeConfig, now);
|
|
222
|
+
}
|
|
223
|
+
if (message.machineRuntimeConfig) {
|
|
224
|
+
cacheMachineRuntimeCredentialConfig(agentName, message.machineRuntimeConfig, now, message.machineId ?? "<this-machine>");
|
|
225
|
+
}
|
|
226
|
+
if (message.providerCredentialRecords && message.providerCredentialRecords.length > 0) {
|
|
227
|
+
(0, provider_credentials_1.cacheProviderCredentialRecords)(agentName, message.providerCredentialRecords, now);
|
|
228
|
+
}
|
|
229
|
+
(0, runtime_1.emitNervesEvent)({
|
|
230
|
+
component: "config/identity",
|
|
231
|
+
event: "config.runtime_credentials_bootstrapped",
|
|
232
|
+
message: "loaded runtime credentials from daemon bootstrap",
|
|
233
|
+
meta: {
|
|
234
|
+
agentName,
|
|
235
|
+
runtimeConfig: !!message.runtimeConfig,
|
|
236
|
+
machineRuntimeConfig: !!message.machineRuntimeConfig,
|
|
237
|
+
providerCredentialRecords: message.providerCredentialRecords?.length ?? 0,
|
|
238
|
+
},
|
|
239
|
+
});
|
|
240
|
+
return true;
|
|
241
|
+
}
|
|
242
|
+
function waitForRuntimeCredentialBootstrap(agentName, options = {}) {
|
|
243
|
+
const timeoutMs = options.timeoutMs ?? 1_500;
|
|
244
|
+
return new Promise((resolve) => {
|
|
245
|
+
let settled = false;
|
|
246
|
+
let timer = null;
|
|
247
|
+
const finish = (value) => {
|
|
248
|
+
/* v8 ignore next -- defensive: listener cleanup and timer cleanup prevent double settlement @preserve */
|
|
249
|
+
if (settled)
|
|
250
|
+
return;
|
|
251
|
+
settled = true;
|
|
252
|
+
/* v8 ignore next -- defensive: timer is assigned immediately after listener registration @preserve */
|
|
253
|
+
if (timer)
|
|
254
|
+
clearTimeout(timer);
|
|
255
|
+
process.off?.("message", onMessage);
|
|
256
|
+
resolve(value);
|
|
257
|
+
};
|
|
258
|
+
const onMessage = (message) => {
|
|
259
|
+
if (!isRuntimeCredentialBootstrapMessage(message))
|
|
260
|
+
return;
|
|
261
|
+
if (message.agentName.trim() !== agentName.trim())
|
|
262
|
+
return;
|
|
263
|
+
finish(applyRuntimeCredentialBootstrapMessage(message));
|
|
264
|
+
};
|
|
265
|
+
process.on?.("message", onMessage);
|
|
266
|
+
timer = setTimeout(() => finish(false), timeoutMs);
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
async function refreshRuntimeCredentialConfigItem(agentName, itemName, cache, options = {}) {
|
|
270
|
+
try {
|
|
271
|
+
const store = (0, credential_access_1.getCredentialStore)(agentName);
|
|
272
|
+
const raw = await store.getRawSecret(itemName, "password");
|
|
273
|
+
const payload = validateRuntimeCredentialPayload(JSON.parse(raw));
|
|
274
|
+
const result = resultFromPayloadForItem(agentName, itemName, payload);
|
|
275
|
+
(0, runtime_1.emitNervesEvent)({
|
|
276
|
+
component: "config/identity",
|
|
277
|
+
event: "config.runtime_credentials_loaded",
|
|
278
|
+
message: "loaded runtime credentials from vault",
|
|
279
|
+
meta: { agentName, itemPath: result.itemPath, revision: result.revision },
|
|
280
|
+
});
|
|
281
|
+
return cache(agentName, result);
|
|
282
|
+
}
|
|
283
|
+
catch (error) {
|
|
284
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
285
|
+
const existing = cache === cacheMachineResult
|
|
286
|
+
? cachedMachineRuntimeConfigs.get(agentName)
|
|
287
|
+
: cachedRuntimeConfigs.get(agentName);
|
|
288
|
+
const reason = message.includes(`no credential found for domain "${itemName}"`)
|
|
289
|
+
? "missing"
|
|
290
|
+
: message.includes("runtime credential payload")
|
|
291
|
+
? "invalid"
|
|
292
|
+
: "unavailable";
|
|
293
|
+
const result = {
|
|
294
|
+
ok: false,
|
|
295
|
+
reason,
|
|
296
|
+
itemPath: runtimeConfigVaultPath(agentName, itemName),
|
|
297
|
+
error: reason === "missing" ? `no runtime credentials stored at ${runtimeConfigVaultPath(agentName, itemName)}` : message,
|
|
298
|
+
};
|
|
299
|
+
(0, runtime_1.emitNervesEvent)({
|
|
300
|
+
level: reason === "missing" ? "warn" : "error",
|
|
301
|
+
component: "config/identity",
|
|
302
|
+
event: "config.runtime_credentials_unavailable",
|
|
303
|
+
message: "runtime credentials unavailable",
|
|
304
|
+
meta: { agentName, reason, itemPath: result.itemPath },
|
|
305
|
+
});
|
|
306
|
+
if (options.preserveCachedOnFailure && existing?.ok)
|
|
307
|
+
return existing;
|
|
308
|
+
return cache(agentName, result);
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
async function refreshRuntimeCredentialConfig(agentName, options = {}) {
|
|
312
|
+
return refreshRuntimeCredentialConfigItem(agentName, exports.RUNTIME_CONFIG_ITEM_NAME, cacheResult, options);
|
|
313
|
+
}
|
|
314
|
+
async function refreshMachineRuntimeCredentialConfig(agentName, machineId, options = {}) {
|
|
315
|
+
return refreshRuntimeCredentialConfigItem(agentName, machineRuntimeConfigItemName(machineId), cacheMachineResult, options);
|
|
316
|
+
}
|
|
317
|
+
async function upsertRuntimeCredentialConfig(agentName, config, now = new Date()) {
|
|
318
|
+
const payload = {
|
|
319
|
+
schemaVersion: 1,
|
|
320
|
+
kind: "runtime-config",
|
|
321
|
+
updatedAt: now.toISOString(),
|
|
322
|
+
config: { ...config },
|
|
323
|
+
};
|
|
324
|
+
const store = (0, credential_access_1.getCredentialStore)(agentName);
|
|
325
|
+
await store.store(exports.RUNTIME_CONFIG_ITEM_NAME, {
|
|
326
|
+
username: "runtime/config",
|
|
327
|
+
password: JSON.stringify(payload),
|
|
328
|
+
notes: "Ouro runtime credentials for senses and integrations. Provider credentials live in providers/* items.",
|
|
329
|
+
});
|
|
330
|
+
const result = resultFromPayload(agentName, payload);
|
|
331
|
+
(0, runtime_1.emitNervesEvent)({
|
|
332
|
+
component: "config/identity",
|
|
333
|
+
event: "config.runtime_credentials_upserted",
|
|
334
|
+
message: "upserted runtime credential config in vault",
|
|
335
|
+
meta: { agentName, itemPath: result.itemPath, revision: result.revision },
|
|
336
|
+
});
|
|
337
|
+
cacheResult(agentName, result);
|
|
338
|
+
return result;
|
|
339
|
+
}
|
|
340
|
+
async function upsertMachineRuntimeCredentialConfig(agentName, machineId, config, now = new Date()) {
|
|
341
|
+
const payload = {
|
|
342
|
+
schemaVersion: 1,
|
|
343
|
+
kind: "runtime-config",
|
|
344
|
+
updatedAt: now.toISOString(),
|
|
345
|
+
config: { ...config },
|
|
346
|
+
};
|
|
347
|
+
const itemName = machineRuntimeConfigItemName(machineId);
|
|
348
|
+
const store = (0, credential_access_1.getCredentialStore)(agentName);
|
|
349
|
+
await store.store(itemName, {
|
|
350
|
+
username: itemName,
|
|
351
|
+
password: JSON.stringify(payload),
|
|
352
|
+
notes: "Ouro machine-local runtime credentials for senses attached to one machine. Portable runtime credentials live in runtime/config.",
|
|
353
|
+
});
|
|
354
|
+
const result = resultFromPayloadForItem(agentName, itemName, payload);
|
|
355
|
+
(0, runtime_1.emitNervesEvent)({
|
|
356
|
+
component: "config/identity",
|
|
357
|
+
event: "config.runtime_credentials_upserted",
|
|
358
|
+
message: "upserted machine runtime credential config in vault",
|
|
359
|
+
meta: { agentName, itemPath: result.itemPath, revision: result.revision },
|
|
360
|
+
});
|
|
361
|
+
cacheMachineResult(agentName, result);
|
|
362
|
+
return result;
|
|
363
|
+
}
|
|
364
|
+
function resetRuntimeCredentialConfigCache() {
|
|
365
|
+
cachedRuntimeConfigs = new Map();
|
|
366
|
+
cachedMachineRuntimeConfigs = new Map();
|
|
367
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
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.recoverRuntimeCwd = recoverRuntimeCwd;
|
|
37
|
+
const fs = __importStar(require("node:fs"));
|
|
38
|
+
const path = __importStar(require("node:path"));
|
|
39
|
+
const runtime_1 = require("../nerves/runtime");
|
|
40
|
+
function defaultRuntimeRoot() {
|
|
41
|
+
return path.resolve(__dirname, "../..");
|
|
42
|
+
}
|
|
43
|
+
const defaultDeps = {
|
|
44
|
+
cwd: process.cwd.bind(process),
|
|
45
|
+
chdir: process.chdir.bind(process),
|
|
46
|
+
existsSync: fs.existsSync,
|
|
47
|
+
};
|
|
48
|
+
function recoverRuntimeCwd(fallback = defaultRuntimeRoot(), deps = defaultDeps) {
|
|
49
|
+
try {
|
|
50
|
+
return deps.cwd();
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
const reason = error instanceof Error ? error.message : String(error);
|
|
54
|
+
let recovered = false;
|
|
55
|
+
let resolved = fallback;
|
|
56
|
+
let repairReason;
|
|
57
|
+
try {
|
|
58
|
+
if (deps.existsSync(fallback)) {
|
|
59
|
+
deps.chdir(fallback);
|
|
60
|
+
resolved = deps.cwd();
|
|
61
|
+
recovered = true;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
repairReason = "fallback cwd does not exist";
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch (repairError) {
|
|
68
|
+
repairReason = repairError instanceof Error ? repairError.message : String(repairError);
|
|
69
|
+
}
|
|
70
|
+
(0, runtime_1.emitNervesEvent)({
|
|
71
|
+
level: recovered ? "warn" : "error",
|
|
72
|
+
component: "heart",
|
|
73
|
+
event: "heart.cwd_recovery",
|
|
74
|
+
message: recovered
|
|
75
|
+
? "recovered process cwd after the previous working directory disappeared"
|
|
76
|
+
: "process cwd disappeared and could not be repaired automatically",
|
|
77
|
+
meta: {
|
|
78
|
+
reason,
|
|
79
|
+
fallback,
|
|
80
|
+
resolved,
|
|
81
|
+
recovered,
|
|
82
|
+
...(repairReason ? { repairReason } : {}),
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
return resolved;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
@@ -7,12 +7,18 @@ const SENSES = [
|
|
|
7
7
|
{ sense: "cli", label: "CLI", daemonManaged: false },
|
|
8
8
|
{ sense: "teams", label: "Teams", daemonManaged: true },
|
|
9
9
|
{ sense: "bluebubbles", label: "BlueBubbles", daemonManaged: true },
|
|
10
|
+
{ sense: "mail", label: "Mail", daemonManaged: true },
|
|
11
|
+
{ sense: "voice", label: "Voice", daemonManaged: true },
|
|
10
12
|
];
|
|
11
13
|
function configuredSenses(senses) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
14
|
+
const configured = senses ?? {};
|
|
15
|
+
return {
|
|
16
|
+
...configured,
|
|
17
|
+
cli: configured.cli ?? { ...identity_1.DEFAULT_AGENT_SENSES.cli },
|
|
18
|
+
teams: configured.teams ?? { ...identity_1.DEFAULT_AGENT_SENSES.teams },
|
|
19
|
+
bluebubbles: configured.bluebubbles ?? { ...identity_1.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
20
|
+
mail: configured.mail ?? { ...identity_1.DEFAULT_AGENT_SENSES.mail },
|
|
21
|
+
voice: configured.voice ?? { ...identity_1.DEFAULT_AGENT_SENSES.voice },
|
|
16
22
|
};
|
|
17
23
|
}
|
|
18
24
|
function resolveStatus(enabled, daemonManaged, runtimeInfo) {
|
|
@@ -28,6 +34,9 @@ function resolveStatus(enabled, daemonManaged, runtimeInfo) {
|
|
|
28
34
|
if (runtimeInfo?.runtime === "running") {
|
|
29
35
|
return "running";
|
|
30
36
|
}
|
|
37
|
+
if (runtimeInfo?.configured === false && runtimeInfo.optional) {
|
|
38
|
+
return "not_attached";
|
|
39
|
+
}
|
|
31
40
|
if (runtimeInfo?.configured === false) {
|
|
32
41
|
return "needs_config";
|
|
33
42
|
}
|
|
@@ -38,6 +38,8 @@ exports.findFreshestFriendSession = findFreshestFriendSession;
|
|
|
38
38
|
const fs = __importStar(require("fs"));
|
|
39
39
|
const path = __importStar(require("path"));
|
|
40
40
|
const runtime_1 = require("../nerves/runtime");
|
|
41
|
+
const config_1 = require("./config");
|
|
42
|
+
const session_events_1 = require("./session-events");
|
|
41
43
|
const DEFAULT_ACTIVE_THRESHOLD_MS = 24 * 60 * 60 * 1000;
|
|
42
44
|
function activityPriority(source) {
|
|
43
45
|
return source === "friend-facing" ? 0 : 1;
|
|
@@ -54,7 +56,7 @@ function resolveFriendName(friendId, friendsDir, agentName) {
|
|
|
54
56
|
return friendId;
|
|
55
57
|
}
|
|
56
58
|
}
|
|
57
|
-
function parseFriendActivity(sessionPath) {
|
|
59
|
+
function parseFriendActivity(sessionPath, activeThresholdMs, nowMs) {
|
|
58
60
|
let mtimeMs;
|
|
59
61
|
try {
|
|
60
62
|
mtimeMs = fs.statSync(sessionPath).mtimeMs;
|
|
@@ -62,32 +64,49 @@ function parseFriendActivity(sessionPath) {
|
|
|
62
64
|
catch {
|
|
63
65
|
return null;
|
|
64
66
|
}
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
67
|
+
if (Number.isFinite(activeThresholdMs) && nowMs - mtimeMs > activeThresholdMs) {
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
const envelope = (0, session_events_1.loadSessionEnvelopeFile)(sessionPath);
|
|
71
|
+
const chronology = envelope ? (0, session_events_1.deriveSessionChronology)(envelope.events) : null;
|
|
72
|
+
const explicit = envelope?.state.lastFriendActivityAt;
|
|
73
|
+
if (typeof explicit === "string") {
|
|
74
|
+
const parsedMs = Date.parse(explicit);
|
|
75
|
+
if (Number.isFinite(parsedMs)) {
|
|
76
|
+
return {
|
|
77
|
+
lastActivityMs: parsedMs,
|
|
78
|
+
lastActivityAt: new Date(parsedMs).toISOString(),
|
|
79
|
+
activitySource: "friend-facing",
|
|
80
|
+
lastInboundAt: chronology?.lastInboundAt ?? null,
|
|
81
|
+
lastOutboundAt: chronology?.lastOutboundAt ?? null,
|
|
82
|
+
unansweredInboundCount: chronology?.unansweredInboundCount ?? 0,
|
|
83
|
+
};
|
|
78
84
|
}
|
|
79
85
|
}
|
|
80
|
-
|
|
81
|
-
|
|
86
|
+
if (chronology?.lastInboundAt) {
|
|
87
|
+
const parsedMs = Date.parse(chronology.lastInboundAt);
|
|
88
|
+
if (Number.isFinite(parsedMs)) {
|
|
89
|
+
return {
|
|
90
|
+
lastActivityMs: parsedMs,
|
|
91
|
+
lastActivityAt: new Date(parsedMs).toISOString(),
|
|
92
|
+
activitySource: "friend-facing",
|
|
93
|
+
lastInboundAt: chronology.lastInboundAt,
|
|
94
|
+
lastOutboundAt: chronology.lastOutboundAt,
|
|
95
|
+
unansweredInboundCount: chronology.unansweredInboundCount,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
82
98
|
}
|
|
83
99
|
return {
|
|
84
100
|
lastActivityMs: mtimeMs,
|
|
85
101
|
lastActivityAt: new Date(mtimeMs).toISOString(),
|
|
86
102
|
activitySource: "mtime-fallback",
|
|
103
|
+
lastInboundAt: chronology?.lastInboundAt ?? null,
|
|
104
|
+
lastOutboundAt: chronology?.lastOutboundAt ?? null,
|
|
105
|
+
unansweredInboundCount: chronology?.unansweredInboundCount ?? 0,
|
|
87
106
|
};
|
|
88
107
|
}
|
|
89
108
|
function listSessionActivity(query) {
|
|
90
|
-
const { sessionsDir, friendsDir, agentName, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, currentSession = null, } = query;
|
|
109
|
+
const { sessionsDir, friendsDir, agentName, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, nowMs = Date.now(), currentSession = null, } = query;
|
|
91
110
|
(0, runtime_1.emitNervesEvent)({
|
|
92
111
|
component: "daemon",
|
|
93
112
|
event: "daemon.session_activity_scan",
|
|
@@ -99,7 +118,6 @@ function listSessionActivity(query) {
|
|
|
99
118
|
});
|
|
100
119
|
if (!fs.existsSync(sessionsDir))
|
|
101
120
|
return [];
|
|
102
|
-
const now = Date.now();
|
|
103
121
|
const results = [];
|
|
104
122
|
let friendDirs;
|
|
105
123
|
try {
|
|
@@ -130,14 +148,17 @@ function listSessionActivity(query) {
|
|
|
130
148
|
if (!keyFile.endsWith(".json"))
|
|
131
149
|
continue;
|
|
132
150
|
const key = keyFile.replace(/\.json$/, "");
|
|
133
|
-
|
|
151
|
+
// Compare with sanitizeKey on both sides — session keys from the filesystem
|
|
152
|
+
// are already sanitized (colons → underscores), but the canonical key from
|
|
153
|
+
// the pipeline may still have colons (e.g. "chat:any" vs "chat_any").
|
|
154
|
+
if (currentSession && friendId === currentSession.friendId && channel === currentSession.channel && (0, config_1.sanitizeKey)(key) === (0, config_1.sanitizeKey)(currentSession.key)) {
|
|
134
155
|
continue;
|
|
135
156
|
}
|
|
136
157
|
const sessionPath = path.join(channelPath, keyFile);
|
|
137
|
-
const activity = parseFriendActivity(sessionPath);
|
|
158
|
+
const activity = parseFriendActivity(sessionPath, activeThresholdMs, nowMs);
|
|
138
159
|
if (!activity)
|
|
139
160
|
continue;
|
|
140
|
-
if (
|
|
161
|
+
if (nowMs - activity.lastActivityMs > activeThresholdMs)
|
|
141
162
|
continue;
|
|
142
163
|
results.push({
|
|
143
164
|
friendId,
|
|
@@ -148,6 +169,9 @@ function listSessionActivity(query) {
|
|
|
148
169
|
lastActivityAt: activity.lastActivityAt,
|
|
149
170
|
lastActivityMs: activity.lastActivityMs,
|
|
150
171
|
activitySource: activity.activitySource,
|
|
172
|
+
lastInboundAt: activity.lastInboundAt,
|
|
173
|
+
lastOutboundAt: activity.lastOutboundAt,
|
|
174
|
+
unansweredInboundCount: activity.unansweredInboundCount,
|
|
151
175
|
});
|
|
152
176
|
}
|
|
153
177
|
}
|
|
@@ -160,10 +184,10 @@ function listSessionActivity(query) {
|
|
|
160
184
|
});
|
|
161
185
|
}
|
|
162
186
|
function findFreshestFriendSession(query) {
|
|
163
|
-
const { activeOnly = false, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, ...rest } = query;
|
|
187
|
+
const { activeOnly = false, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, nowMs, ...rest } = query;
|
|
164
188
|
const currentSession = rest.currentSession ?? null;
|
|
165
189
|
const all = activeOnly
|
|
166
|
-
? listSessionActivity({ ...rest, activeThresholdMs, currentSession })
|
|
167
|
-
: listSessionActivity({ ...rest, activeThresholdMs: Number.MAX_SAFE_INTEGER, currentSession });
|
|
190
|
+
? listSessionActivity({ ...rest, activeThresholdMs, nowMs, currentSession })
|
|
191
|
+
: listSessionActivity({ ...rest, activeThresholdMs: Number.MAX_SAFE_INTEGER, nowMs, currentSession });
|
|
168
192
|
return all.find((entry) => entry.friendId === query.friendId) ?? null;
|
|
169
193
|
}
|