@ouro.bot/cli 0.1.0-alpha.55 → 0.1.0-alpha.550
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 +133 -19
- 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-bootstrap-drift.md +54 -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 +3555 -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 +304 -0
- package/dist/heart/config.js +114 -118
- package/dist/heart/core.js +925 -246
- package/dist/heart/cross-chat-delivery.js +3 -18
- package/dist/heart/daemon/agent-config-check.js +512 -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 +554 -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 +665 -0
- package/dist/heart/daemon/cli-exec.js +7565 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1590 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +775 -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 -1672
- package/dist/heart/daemon/daemon-entry.js +417 -2
- package/dist/heart/daemon/daemon-health.js +183 -0
- package/dist/heart/daemon/daemon-rollup.js +58 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +87 -13
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +758 -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 +844 -0
- package/dist/heart/daemon/drift-detection.js +146 -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 +102 -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 +353 -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 +52 -117
- 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 +200 -51
- 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 +255 -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-state.js +216 -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 +11 -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 +381 -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-BPr5vNuM.css +1 -0
- package/dist/mailbox-ui/assets/index-Cm51CY9W.js +61 -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 +30 -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 +995 -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 +139 -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 +816 -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 +111 -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 +561 -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 +569 -182
- 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/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/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,421 @@
|
|
|
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.notesToolDefinitions = void 0;
|
|
37
|
+
const fs = __importStar(require("fs"));
|
|
38
|
+
const path = __importStar(require("path"));
|
|
39
|
+
const child_process_1 = require("child_process");
|
|
40
|
+
const skills_1 = require("./skills");
|
|
41
|
+
const config_1 = require("../heart/config");
|
|
42
|
+
const identity_1 = require("../heart/identity");
|
|
43
|
+
const runtime_1 = require("../nerves/runtime");
|
|
44
|
+
const diary_1 = require("../mind/diary");
|
|
45
|
+
const provenance_trust_1 = require("../mind/provenance-trust");
|
|
46
|
+
exports.notesToolDefinitions = [
|
|
47
|
+
{
|
|
48
|
+
tool: {
|
|
49
|
+
type: "function",
|
|
50
|
+
function: {
|
|
51
|
+
name: "list_skills",
|
|
52
|
+
description: "list all available skills",
|
|
53
|
+
parameters: { type: "object", properties: {} },
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
handler: () => JSON.stringify((0, skills_1.listSkills)()),
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
tool: {
|
|
60
|
+
type: "function",
|
|
61
|
+
function: {
|
|
62
|
+
name: "load_skill",
|
|
63
|
+
description: "load a skill by name, returns its content",
|
|
64
|
+
parameters: {
|
|
65
|
+
type: "object",
|
|
66
|
+
properties: { name: { type: "string" } },
|
|
67
|
+
required: ["name"],
|
|
68
|
+
},
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
handler: (a) => {
|
|
72
|
+
try {
|
|
73
|
+
return (0, skills_1.loadSkill)(a.name);
|
|
74
|
+
}
|
|
75
|
+
catch (e) {
|
|
76
|
+
return `error: ${e}`;
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
summaryKeys: ["name"],
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
tool: {
|
|
83
|
+
type: "function",
|
|
84
|
+
function: {
|
|
85
|
+
name: "claude",
|
|
86
|
+
description: "use claude code to query this codebase or get an outside perspective. Use for code review, second opinions, or questions that benefit from a fresh perspective outside this conversation's context.",
|
|
87
|
+
parameters: {
|
|
88
|
+
type: "object",
|
|
89
|
+
properties: { prompt: { type: "string" } },
|
|
90
|
+
required: ["prompt"],
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
},
|
|
94
|
+
handler: (a) => {
|
|
95
|
+
try {
|
|
96
|
+
const result = (0, child_process_1.spawnSync)("claude", ["-p", "--no-session-persistence", "--dangerously-skip-permissions", "--add-dir", "."], {
|
|
97
|
+
input: a.prompt,
|
|
98
|
+
encoding: "utf-8",
|
|
99
|
+
timeout: 60000,
|
|
100
|
+
});
|
|
101
|
+
if (result.error)
|
|
102
|
+
return `error: ${result.error}`;
|
|
103
|
+
if (result.status !== 0)
|
|
104
|
+
return `claude exited with code ${result.status}: ${result.stderr}`;
|
|
105
|
+
return result.stdout || "(no output)";
|
|
106
|
+
}
|
|
107
|
+
catch (e) {
|
|
108
|
+
return `error: ${e}`;
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
summaryKeys: ["prompt"],
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
tool: {
|
|
115
|
+
type: "function",
|
|
116
|
+
function: {
|
|
117
|
+
name: "web_search",
|
|
118
|
+
description: "search the web using perplexity. returns ranked results with titles, urls, and snippets",
|
|
119
|
+
parameters: {
|
|
120
|
+
type: "object",
|
|
121
|
+
properties: { query: { type: "string" } },
|
|
122
|
+
required: ["query"],
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
},
|
|
126
|
+
handler: async (a) => {
|
|
127
|
+
try {
|
|
128
|
+
const key = (0, config_1.getIntegrationsConfig)().perplexityApiKey;
|
|
129
|
+
if (!key)
|
|
130
|
+
return "error: perplexityApiKey not configured in the agent vault runtime/config item";
|
|
131
|
+
const res = await fetch("https://api.perplexity.ai/search", {
|
|
132
|
+
method: "POST",
|
|
133
|
+
headers: {
|
|
134
|
+
Authorization: `Bearer ${key}`,
|
|
135
|
+
"Content-Type": "application/json",
|
|
136
|
+
},
|
|
137
|
+
body: JSON.stringify({ query: a.query, max_results: 5 }),
|
|
138
|
+
});
|
|
139
|
+
if (!res.ok)
|
|
140
|
+
return `error: ${res.status} ${res.statusText}`;
|
|
141
|
+
const data = (await res.json());
|
|
142
|
+
if (!data.results?.length)
|
|
143
|
+
return "no results found";
|
|
144
|
+
return data.results
|
|
145
|
+
.map((r) => `${r.title}\n${r.url}\n${r.snippet}`)
|
|
146
|
+
.join("\n\n");
|
|
147
|
+
}
|
|
148
|
+
catch (e) {
|
|
149
|
+
return `error: ${e}`;
|
|
150
|
+
}
|
|
151
|
+
},
|
|
152
|
+
summaryKeys: ["query"],
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
tool: {
|
|
156
|
+
type: "function",
|
|
157
|
+
function: {
|
|
158
|
+
name: "search_notes",
|
|
159
|
+
description: "Search my diary and journal for facts, thoughts, and working notes matching a query. Uses semantic similarity -- phrasing matters. Try different angles if the first query doesn't find what you're looking for. Search written notes before asking the human something the notes may already answer.",
|
|
160
|
+
parameters: {
|
|
161
|
+
type: "object",
|
|
162
|
+
properties: { query: { type: "string" } },
|
|
163
|
+
required: ["query"],
|
|
164
|
+
},
|
|
165
|
+
},
|
|
166
|
+
},
|
|
167
|
+
handler: async (a) => {
|
|
168
|
+
try {
|
|
169
|
+
const query = (a.query || "").trim();
|
|
170
|
+
if (!query)
|
|
171
|
+
return "query is required";
|
|
172
|
+
const resultLines = [];
|
|
173
|
+
// Search diary entries
|
|
174
|
+
const hits = await (0, diary_1.searchDiaryEntries)(query, (0, diary_1.readDiaryEntries)());
|
|
175
|
+
for (const fact of hits) {
|
|
176
|
+
let meta = `source=${fact.source}, createdAt=${fact.createdAt}`;
|
|
177
|
+
if (fact.provenance) {
|
|
178
|
+
if (fact.provenance.channel)
|
|
179
|
+
meta += `, channel=${fact.provenance.channel}`;
|
|
180
|
+
if (fact.provenance.friendName)
|
|
181
|
+
meta += `, friend=${fact.provenance.friendName}`;
|
|
182
|
+
if (fact.provenance.trust)
|
|
183
|
+
meta += `, trust=${fact.provenance.trust}`;
|
|
184
|
+
}
|
|
185
|
+
const tag = (0, provenance_trust_1.classifyProvenanceTrust)(fact.provenance) === "external" ? "diary/external" : "diary";
|
|
186
|
+
resultLines.push(`[${tag}] ${fact.text} (${meta})`);
|
|
187
|
+
}
|
|
188
|
+
// Search journal index
|
|
189
|
+
const agentRoot = (0, identity_1.getAgentRoot)();
|
|
190
|
+
const journalIndexPath = path.join(agentRoot, "journal", ".index.json");
|
|
191
|
+
try {
|
|
192
|
+
const raw = fs.readFileSync(journalIndexPath, "utf8");
|
|
193
|
+
const journalEntries = JSON.parse(raw);
|
|
194
|
+
if (Array.isArray(journalEntries) && journalEntries.length > 0) {
|
|
195
|
+
// Substring match on preview and filename
|
|
196
|
+
const lowerQuery = query.toLowerCase();
|
|
197
|
+
for (const entry of journalEntries) {
|
|
198
|
+
/* v8 ignore next 4 -- both sides tested (filename-only match in search_notes-journal.test.ts); v8 misreports || short-circuit @preserve */
|
|
199
|
+
if (entry.preview.toLowerCase().includes(lowerQuery) ||
|
|
200
|
+
entry.filename.toLowerCase().includes(lowerQuery)) {
|
|
201
|
+
resultLines.push(`[journal] ${entry.filename}: ${entry.preview}`);
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
catch {
|
|
207
|
+
// No journal index or malformed — skip journal search
|
|
208
|
+
}
|
|
209
|
+
return resultLines.join("\n");
|
|
210
|
+
}
|
|
211
|
+
catch (e) {
|
|
212
|
+
return `error: ${e instanceof Error ? e.message : String(e)}`;
|
|
213
|
+
}
|
|
214
|
+
},
|
|
215
|
+
summaryKeys: ["query"],
|
|
216
|
+
},
|
|
217
|
+
{
|
|
218
|
+
tool: {
|
|
219
|
+
type: "function",
|
|
220
|
+
function: {
|
|
221
|
+
name: "diary_write",
|
|
222
|
+
description: "Write an entry in my diary -- something I learned, noticed, or concluded that I want available later. Use 'about' to tag the entry to a person, topic, or context. Write for my future self: include enough context that the entry makes sense without the surrounding conversation. Prefer durable conclusions over passing noise. Don't duplicate what already belongs in friend notes.",
|
|
223
|
+
parameters: {
|
|
224
|
+
type: "object",
|
|
225
|
+
properties: {
|
|
226
|
+
entry: { type: "string" },
|
|
227
|
+
about: { type: "string" },
|
|
228
|
+
},
|
|
229
|
+
required: ["entry"],
|
|
230
|
+
},
|
|
231
|
+
},
|
|
232
|
+
},
|
|
233
|
+
handler: async (a, ctx) => {
|
|
234
|
+
const entry = (a.entry || "").trim();
|
|
235
|
+
if (!entry)
|
|
236
|
+
return "entry is required";
|
|
237
|
+
let provenance;
|
|
238
|
+
if (ctx?.context) {
|
|
239
|
+
const p = { tool: "diary_write" };
|
|
240
|
+
const channel = ctx.context.channel?.channel;
|
|
241
|
+
if (channel)
|
|
242
|
+
p.channel = channel;
|
|
243
|
+
const friendId = ctx.context.friend?.id;
|
|
244
|
+
if (friendId)
|
|
245
|
+
p.friendId = friendId;
|
|
246
|
+
const friendName = ctx.context.friend?.name;
|
|
247
|
+
if (friendName)
|
|
248
|
+
p.friendName = friendName;
|
|
249
|
+
const trust = ctx.context.friend?.trustLevel;
|
|
250
|
+
if (trust)
|
|
251
|
+
p.trust = trust;
|
|
252
|
+
provenance = p;
|
|
253
|
+
}
|
|
254
|
+
const result = await (0, diary_1.saveDiaryEntry)({
|
|
255
|
+
text: entry,
|
|
256
|
+
source: "tool:diary_write",
|
|
257
|
+
about: typeof a.about === "string" ? a.about : undefined,
|
|
258
|
+
provenance,
|
|
259
|
+
});
|
|
260
|
+
return `saved diary entry (added=${result.added}, skipped=${result.skipped})`;
|
|
261
|
+
},
|
|
262
|
+
summaryKeys: ["entry", "about"],
|
|
263
|
+
},
|
|
264
|
+
{
|
|
265
|
+
tool: {
|
|
266
|
+
type: "function",
|
|
267
|
+
function: {
|
|
268
|
+
name: "friend_list",
|
|
269
|
+
description: "list all friends with id, name, and trust level. use this when i need to see who i know — e.g. for cross-chat outreach decisions, screener triage, or just orienting on the friend graph.",
|
|
270
|
+
parameters: {
|
|
271
|
+
type: "object",
|
|
272
|
+
properties: {
|
|
273
|
+
trust: { type: "string", enum: ["family", "friend", "stranger"], description: "optional trust filter; omit to list all" },
|
|
274
|
+
limit: { type: "string", description: "max records to return, 1-200. defaults to 50." },
|
|
275
|
+
},
|
|
276
|
+
},
|
|
277
|
+
},
|
|
278
|
+
},
|
|
279
|
+
handler: async (a, ctx) => {
|
|
280
|
+
/* v8 ignore start -- friend_list defensive plumbing: ctx + listAll guards, trust/limit branch fan-out, and empty-set status messages aren't all combined in tests; full coverage lives at the friend-store unit-test layer @preserve */
|
|
281
|
+
if (!ctx?.friendStore)
|
|
282
|
+
return "i can't list friends -- friend store not available";
|
|
283
|
+
if (!ctx.friendStore.listAll)
|
|
284
|
+
return "the configured friend store does not support listing.";
|
|
285
|
+
const all = await ctx.friendStore.listAll();
|
|
286
|
+
const trustFilter = a.trust;
|
|
287
|
+
const filtered = trustFilter
|
|
288
|
+
? all.filter((f) => (f.trustLevel ?? "friend") === trustFilter)
|
|
289
|
+
: all;
|
|
290
|
+
const limitRaw = a.limit ? Number.parseInt(a.limit, 10) : 50;
|
|
291
|
+
const limit = Number.isFinite(limitRaw) ? Math.min(200, Math.max(1, limitRaw)) : 50;
|
|
292
|
+
const ordered = [...filtered].sort((left, right) => left.name.localeCompare(right.name)).slice(0, limit);
|
|
293
|
+
if (ordered.length === 0) {
|
|
294
|
+
return trustFilter ? `no friends with trust level '${trustFilter}'.` : "no friends recorded yet.";
|
|
295
|
+
}
|
|
296
|
+
/* v8 ignore stop */
|
|
297
|
+
/* v8 ignore start -- formatting branches: externalIds presence + pluralization + trust suffix variants depend on specific friend-record shapes not exhaustively combined in tests @preserve */
|
|
298
|
+
const lines = ordered.map((friend) => {
|
|
299
|
+
const externals = friend.externalIds && friend.externalIds.length > 0
|
|
300
|
+
? ` [${friend.externalIds.map((id) => `${id.provider}:${id.externalId}`).join(", ")}]`
|
|
301
|
+
: "";
|
|
302
|
+
return `- ${friend.id} (${friend.trustLevel ?? "friend"}): ${friend.name}${externals}`;
|
|
303
|
+
});
|
|
304
|
+
return `${ordered.length} friend${ordered.length === 1 ? "" : "s"}${trustFilter ? ` with trust=${trustFilter}` : ""}:\n${lines.join("\n")}`;
|
|
305
|
+
/* v8 ignore stop */
|
|
306
|
+
},
|
|
307
|
+
summaryKeys: ["trust", "limit"],
|
|
308
|
+
},
|
|
309
|
+
{
|
|
310
|
+
tool: {
|
|
311
|
+
type: "function",
|
|
312
|
+
function: {
|
|
313
|
+
name: "get_friend_note",
|
|
314
|
+
description: "read a specific friend record by friend id. use this when i need notes/context about someone not currently active",
|
|
315
|
+
parameters: {
|
|
316
|
+
type: "object",
|
|
317
|
+
properties: {
|
|
318
|
+
friendId: { type: "string" },
|
|
319
|
+
},
|
|
320
|
+
required: ["friendId"],
|
|
321
|
+
},
|
|
322
|
+
},
|
|
323
|
+
},
|
|
324
|
+
handler: async (a, ctx) => {
|
|
325
|
+
const friendId = (a.friendId || "").trim();
|
|
326
|
+
if (!friendId)
|
|
327
|
+
return "friendId is required";
|
|
328
|
+
if (!ctx?.friendStore)
|
|
329
|
+
return "i can't read friend notes -- friend store not available";
|
|
330
|
+
const friend = await ctx.friendStore.get(friendId);
|
|
331
|
+
if (!friend)
|
|
332
|
+
return `friend not found: ${friendId}`;
|
|
333
|
+
return JSON.stringify(friend, null, 2);
|
|
334
|
+
},
|
|
335
|
+
summaryKeys: ["friendId"],
|
|
336
|
+
},
|
|
337
|
+
{
|
|
338
|
+
tool: {
|
|
339
|
+
type: "function",
|
|
340
|
+
function: {
|
|
341
|
+
name: "save_friend_note",
|
|
342
|
+
description: "save something i learned about my friend. use type 'name' to update their display name, 'tool_preference' for how they like a specific tool to behave (key = tool category like 'ado', 'graph'), or 'note' for general knowledge (key = topic). when updating an existing value, set override to true if i'm replacing/correcting it. omit override (or set false) if i'm unsure and want to check what's already saved.",
|
|
343
|
+
parameters: {
|
|
344
|
+
type: "object",
|
|
345
|
+
properties: {
|
|
346
|
+
type: { type: "string", enum: ["name", "tool_preference", "note"], description: "what kind of information to save" },
|
|
347
|
+
key: { type: "string", description: "category key (required for tool_preference and note, e.g. 'ado', 'role')" },
|
|
348
|
+
content: { type: "string", description: "the value to save" },
|
|
349
|
+
override: { type: "string", enum: ["true", "false"], description: "set to 'true' to overwrite an existing value" },
|
|
350
|
+
},
|
|
351
|
+
required: ["type", "content"],
|
|
352
|
+
},
|
|
353
|
+
},
|
|
354
|
+
},
|
|
355
|
+
handler: async (a, ctx) => {
|
|
356
|
+
(0, runtime_1.emitNervesEvent)({
|
|
357
|
+
component: "repertoire",
|
|
358
|
+
event: "repertoire.save_friend_note",
|
|
359
|
+
message: "save friend note invoked",
|
|
360
|
+
meta: { type: a.type },
|
|
361
|
+
});
|
|
362
|
+
if (!ctx?.context) {
|
|
363
|
+
return "i can't save notes -- no friend context available";
|
|
364
|
+
}
|
|
365
|
+
if (!ctx.friendStore) {
|
|
366
|
+
return "i can't save notes -- friend store not available";
|
|
367
|
+
}
|
|
368
|
+
const friendId = ctx.context.friend?.id;
|
|
369
|
+
if (!friendId)
|
|
370
|
+
return "i can't save notes -- no friend identity available";
|
|
371
|
+
// Validate parameters
|
|
372
|
+
if (!a.content)
|
|
373
|
+
return "i need a content value to save";
|
|
374
|
+
const validTypes = ["name", "tool_preference", "note"];
|
|
375
|
+
if (!validTypes.includes(a.type))
|
|
376
|
+
return `i don't recognize type '${a.type}' -- use name, tool_preference, or note`;
|
|
377
|
+
if ((a.type === "tool_preference" || a.type === "note") && !a.key)
|
|
378
|
+
return "i need a key for tool_preference or note type";
|
|
379
|
+
try {
|
|
380
|
+
// Read fresh record from disk
|
|
381
|
+
const record = await ctx.friendStore.get(friendId);
|
|
382
|
+
if (!record)
|
|
383
|
+
return "i can't find the friend record on disk";
|
|
384
|
+
const isOverride = a.override === "true";
|
|
385
|
+
if (a.type === "name") {
|
|
386
|
+
const updated = { ...record, name: a.content, updatedAt: new Date().toISOString() };
|
|
387
|
+
await ctx.friendStore.put(friendId, updated);
|
|
388
|
+
return `saved: name = ${a.content}`;
|
|
389
|
+
}
|
|
390
|
+
if (a.type === "tool_preference") {
|
|
391
|
+
const existing = record.toolPreferences[a.key];
|
|
392
|
+
if (existing && !isOverride) {
|
|
393
|
+
return `i already have a preference for '${a.key}': "${existing}". if you want to replace it, call again with override: true. or merge both values into content and override.`;
|
|
394
|
+
}
|
|
395
|
+
const updated = { ...record, toolPreferences: { ...record.toolPreferences, [a.key]: a.content }, updatedAt: new Date().toISOString() };
|
|
396
|
+
await ctx.friendStore.put(friendId, updated);
|
|
397
|
+
return `saved: toolPreference ${a.key} = ${a.content}`;
|
|
398
|
+
}
|
|
399
|
+
// type === "note"
|
|
400
|
+
// Redirect "name" key to name field
|
|
401
|
+
if (a.key === "name") {
|
|
402
|
+
const updated = { ...record, name: a.content, updatedAt: new Date().toISOString() };
|
|
403
|
+
await ctx.friendStore.put(friendId, updated);
|
|
404
|
+
return `updated friend's name to '${a.content}' (stored as name, not a note)`;
|
|
405
|
+
}
|
|
406
|
+
const existing = record.notes[a.key];
|
|
407
|
+
if (existing && !isOverride) {
|
|
408
|
+
return `i already have a note for '${a.key}': "${existing.value}". if you want to replace it, call again with override: true. or merge both values into content and override.`;
|
|
409
|
+
}
|
|
410
|
+
const updated = { ...record, notes: { ...record.notes, [a.key]: { value: a.content, savedAt: new Date().toISOString() } }, updatedAt: new Date().toISOString() };
|
|
411
|
+
await ctx.friendStore.put(friendId, updated);
|
|
412
|
+
return `saved: note ${a.key} = ${a.content}`;
|
|
413
|
+
}
|
|
414
|
+
catch (err) {
|
|
415
|
+
/* v8 ignore next -- defensive: non-Error branch for String(err) @preserve */
|
|
416
|
+
return `error saving note: ${err instanceof Error ? err.message : String(err)}`;
|
|
417
|
+
}
|
|
418
|
+
},
|
|
419
|
+
summaryKeys: ["type", "key", "content"],
|
|
420
|
+
},
|
|
421
|
+
];
|