@ouro.bot/cli 0.1.0-alpha.56 → 0.1.0-alpha.560
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 +3596 -0
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +140 -0
- package/dist/arc/episodes.js +117 -0
- package/dist/arc/intentions.js +133 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +237 -0
- package/dist/arc/packets.js +193 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +65 -0
- package/dist/heart/active-work.js +837 -26
- package/dist/heart/agent-entry.js +58 -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/adapter.js +2 -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/background-operations.js +281 -0
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +111 -0
- package/dist/heart/config-registry.js +322 -0
- package/dist/heart/config.js +114 -118
- package/dist/heart/core.js +913 -246
- 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-exec.js +7457 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1592 -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 -1698
- package/dist/heart/daemon/daemon-entry.js +387 -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 +796 -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 +826 -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 +82 -12
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/message-router.js +2 -2
- 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/process-manager.js +375 -33
- 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 +67 -16
- package/dist/heart/daemon/runtime-metadata.js +3 -31
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +389 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +94 -0
- 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 +3 -25
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +162 -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 -1
- 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 +35 -12
- package/dist/heart/identity.js +203 -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 +195 -0
- package/dist/heart/mailbox/readers/agent-machine.js +382 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
- package/dist/heart/mailbox/readers/mail.js +362 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +651 -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 +683 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +267 -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 +97 -13
- 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 +43 -22
- package/dist/heart/session-events.js +1149 -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 +243 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- 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 +139 -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-B-461hes.js +61 -0
- package/dist/mailbox-ui/assets/index-BPr5vNuM.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 +674 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +720 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +430 -0
- package/dist/mailroom/mbox-import.js +383 -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 +256 -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 +7 -1
- package/dist/mind/context.js +165 -101
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +62 -75
- 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 +39 -3
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +161 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +4 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1011 -123
- 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 +129 -5
- package/dist/nerves/coverage/run-artifacts.js +1 -1
- 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 +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +963 -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 +330 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +158 -9
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +170 -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/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 +396 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +362 -0
- package/dist/repertoire/mcp-tools.js +63 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +15 -24
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tasks/board.js +31 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +16 -4
- package/dist/repertoire/tasks/lifecycle.js +2 -2
- package/dist/repertoire/tasks/parser.js +3 -2
- package/dist/repertoire/tasks/scanner.js +194 -37
- package/dist/repertoire/tasks/transitions.js +16 -78
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-base.js +47 -1075
- package/dist/repertoire/tools-bluebubbles.js +1 -0
- package/dist/repertoire/tools-bridge.js +142 -0
- package/dist/repertoire/tools-bundle.js +984 -0
- package/dist/repertoire/tools-config.js +185 -0
- package/dist/repertoire/tools-continuity.js +248 -0
- package/dist/repertoire/tools-credential.js +381 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-mail.js +1857 -0
- package/dist/repertoire/tools-notes.js +421 -0
- package/dist/repertoire/tools-session.js +750 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +180 -0
- package/dist/repertoire/tools-surface.js +243 -0
- package/dist/repertoire/tools-teams.js +9 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +604 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools.js +108 -100
- 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 +116 -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 +2305 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
- 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/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 +187 -0
- package/dist/senses/cli.js +520 -209
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +175 -21
- package/dist/senses/inner-dialog.js +330 -27
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +549 -181
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +248 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +387 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/senses/voice/elevenlabs.js +125 -0
- package/dist/senses/voice/index.js +22 -0
- package/dist/senses/voice/transcript.js +70 -0
- package/dist/senses/voice/turn.js +85 -0
- package/dist/senses/voice/types.js +2 -0
- package/dist/senses/voice/whisper.js +133 -0
- package/dist/senses/voice-entry.js +80 -0
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +146 -0
- package/package.json +38 -7
- 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 +101 -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/daemon/subagent-installer.js +0 -166
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- 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 -86
- package/subagents/work-doer.md +0 -237
- package/subagents/work-merger.md +0 -618
- package/subagents/work-planner.md +0 -390
- /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/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;
|
|
@@ -62,32 +64,46 @@ 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
|
+
const envelope = (0, session_events_1.loadSessionEnvelopeFile)(sessionPath);
|
|
68
|
+
const chronology = envelope ? (0, session_events_1.deriveSessionChronology)(envelope.events) : null;
|
|
69
|
+
const explicit = envelope?.state.lastFriendActivityAt;
|
|
70
|
+
if (typeof explicit === "string") {
|
|
71
|
+
const parsedMs = Date.parse(explicit);
|
|
72
|
+
if (Number.isFinite(parsedMs)) {
|
|
73
|
+
return {
|
|
74
|
+
lastActivityMs: parsedMs,
|
|
75
|
+
lastActivityAt: new Date(parsedMs).toISOString(),
|
|
76
|
+
activitySource: "friend-facing",
|
|
77
|
+
lastInboundAt: chronology?.lastInboundAt ?? null,
|
|
78
|
+
lastOutboundAt: chronology?.lastOutboundAt ?? null,
|
|
79
|
+
unansweredInboundCount: chronology?.unansweredInboundCount ?? 0,
|
|
80
|
+
};
|
|
78
81
|
}
|
|
79
82
|
}
|
|
80
|
-
|
|
81
|
-
|
|
83
|
+
if (chronology?.lastInboundAt) {
|
|
84
|
+
const parsedMs = Date.parse(chronology.lastInboundAt);
|
|
85
|
+
if (Number.isFinite(parsedMs)) {
|
|
86
|
+
return {
|
|
87
|
+
lastActivityMs: parsedMs,
|
|
88
|
+
lastActivityAt: new Date(parsedMs).toISOString(),
|
|
89
|
+
activitySource: "friend-facing",
|
|
90
|
+
lastInboundAt: chronology.lastInboundAt,
|
|
91
|
+
lastOutboundAt: chronology.lastOutboundAt,
|
|
92
|
+
unansweredInboundCount: chronology.unansweredInboundCount,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
82
95
|
}
|
|
83
96
|
return {
|
|
84
97
|
lastActivityMs: mtimeMs,
|
|
85
98
|
lastActivityAt: new Date(mtimeMs).toISOString(),
|
|
86
99
|
activitySource: "mtime-fallback",
|
|
100
|
+
lastInboundAt: chronology?.lastInboundAt ?? null,
|
|
101
|
+
lastOutboundAt: chronology?.lastOutboundAt ?? null,
|
|
102
|
+
unansweredInboundCount: chronology?.unansweredInboundCount ?? 0,
|
|
87
103
|
};
|
|
88
104
|
}
|
|
89
105
|
function listSessionActivity(query) {
|
|
90
|
-
const { sessionsDir, friendsDir, agentName, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, currentSession = null, } = query;
|
|
106
|
+
const { sessionsDir, friendsDir, agentName, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, nowMs = Date.now(), currentSession = null, } = query;
|
|
91
107
|
(0, runtime_1.emitNervesEvent)({
|
|
92
108
|
component: "daemon",
|
|
93
109
|
event: "daemon.session_activity_scan",
|
|
@@ -99,7 +115,6 @@ function listSessionActivity(query) {
|
|
|
99
115
|
});
|
|
100
116
|
if (!fs.existsSync(sessionsDir))
|
|
101
117
|
return [];
|
|
102
|
-
const now = Date.now();
|
|
103
118
|
const results = [];
|
|
104
119
|
let friendDirs;
|
|
105
120
|
try {
|
|
@@ -130,14 +145,17 @@ function listSessionActivity(query) {
|
|
|
130
145
|
if (!keyFile.endsWith(".json"))
|
|
131
146
|
continue;
|
|
132
147
|
const key = keyFile.replace(/\.json$/, "");
|
|
133
|
-
|
|
148
|
+
// Compare with sanitizeKey on both sides — session keys from the filesystem
|
|
149
|
+
// are already sanitized (colons → underscores), but the canonical key from
|
|
150
|
+
// the pipeline may still have colons (e.g. "chat:any" vs "chat_any").
|
|
151
|
+
if (currentSession && friendId === currentSession.friendId && channel === currentSession.channel && (0, config_1.sanitizeKey)(key) === (0, config_1.sanitizeKey)(currentSession.key)) {
|
|
134
152
|
continue;
|
|
135
153
|
}
|
|
136
154
|
const sessionPath = path.join(channelPath, keyFile);
|
|
137
155
|
const activity = parseFriendActivity(sessionPath);
|
|
138
156
|
if (!activity)
|
|
139
157
|
continue;
|
|
140
|
-
if (
|
|
158
|
+
if (nowMs - activity.lastActivityMs > activeThresholdMs)
|
|
141
159
|
continue;
|
|
142
160
|
results.push({
|
|
143
161
|
friendId,
|
|
@@ -148,6 +166,9 @@ function listSessionActivity(query) {
|
|
|
148
166
|
lastActivityAt: activity.lastActivityAt,
|
|
149
167
|
lastActivityMs: activity.lastActivityMs,
|
|
150
168
|
activitySource: activity.activitySource,
|
|
169
|
+
lastInboundAt: activity.lastInboundAt,
|
|
170
|
+
lastOutboundAt: activity.lastOutboundAt,
|
|
171
|
+
unansweredInboundCount: activity.unansweredInboundCount,
|
|
151
172
|
});
|
|
152
173
|
}
|
|
153
174
|
}
|
|
@@ -160,10 +181,10 @@ function listSessionActivity(query) {
|
|
|
160
181
|
});
|
|
161
182
|
}
|
|
162
183
|
function findFreshestFriendSession(query) {
|
|
163
|
-
const { activeOnly = false, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, ...rest } = query;
|
|
184
|
+
const { activeOnly = false, activeThresholdMs = DEFAULT_ACTIVE_THRESHOLD_MS, nowMs, ...rest } = query;
|
|
164
185
|
const currentSession = rest.currentSession ?? null;
|
|
165
186
|
const all = activeOnly
|
|
166
|
-
? listSessionActivity({ ...rest, activeThresholdMs, currentSession })
|
|
167
|
-
: listSessionActivity({ ...rest, activeThresholdMs: Number.MAX_SAFE_INTEGER, currentSession });
|
|
187
|
+
? listSessionActivity({ ...rest, activeThresholdMs, nowMs, currentSession })
|
|
188
|
+
: listSessionActivity({ ...rest, activeThresholdMs: Number.MAX_SAFE_INTEGER, nowMs, currentSession });
|
|
168
189
|
return all.find((entry) => entry.friendId === query.friendId) ?? null;
|
|
169
190
|
}
|