@ouro.bot/cli 0.1.0-alpha.4 → 0.1.0-alpha.400
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 +208 -184
- package/SerpentGuide.ouro/agent.json +82 -0
- package/SerpentGuide.ouro/psyche/SOUL.md +25 -0
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +2 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/assets/ouroboros.png +0 -0
- package/changelog.json +2610 -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 +832 -0
- 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 +417 -0
- package/dist/heart/bridges/manager.js +358 -0
- package/dist/heart/bridges/state-machine.js +135 -0
- package/dist/heart/bridges/store.js +123 -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 +176 -130
- package/dist/heart/core.js +872 -255
- package/dist/heart/cross-chat-delivery.js +131 -0
- package/dist/heart/daemon/agent-config-check.js +397 -0
- package/dist/heart/daemon/agent-discovery.js +157 -0
- package/dist/heart/daemon/agent-service.js +360 -0
- package/dist/heart/daemon/agentic-repair.js +213 -0
- package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
- package/dist/heart/daemon/cadence.js +70 -0
- package/dist/heart/daemon/cli-defaults.js +599 -0
- package/dist/heart/daemon/cli-exec.js +3616 -0
- package/dist/heart/daemon/cli-help.js +396 -0
- package/dist/heart/daemon/cli-parse.js +1118 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +560 -0
- package/dist/heart/daemon/cli-types.js +8 -0
- package/dist/heart/daemon/daemon-cli.js +29 -673
- package/dist/heart/daemon/daemon-entry.js +370 -8
- package/dist/heart/daemon/daemon-health.js +141 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +235 -0
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +813 -19
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +419 -0
- package/dist/heart/daemon/health-monitor.js +79 -1
- package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
- package/dist/heart/daemon/hooks/bundle-meta.js +206 -0
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/inner-status.js +89 -0
- package/dist/heart/daemon/interactive-repair.js +209 -0
- package/dist/heart/daemon/launchd.js +171 -0
- package/dist/heart/daemon/log-tailer.js +82 -12
- package/dist/heart/daemon/logs-prune.js +105 -0
- package/dist/heart/daemon/message-router.js +17 -8
- package/dist/heart/daemon/os-cron-deps.js +134 -0
- 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 +202 -1
- package/dist/heart/daemon/provider-discovery.js +137 -0
- package/dist/heart/daemon/pulse.js +475 -0
- package/dist/heart/daemon/readiness-repair.js +216 -0
- package/dist/heart/daemon/run-hooks.js +39 -0
- package/dist/heart/daemon/runtime-logging.js +67 -16
- package/dist/heart/daemon/runtime-metadata.js +191 -0
- package/dist/heart/daemon/runtime-mode.js +67 -0
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +355 -0
- 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 +307 -0
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +237 -0
- package/dist/heart/daemon/task-scheduler.js +3 -25
- package/dist/heart/daemon/thoughts.js +510 -0
- package/dist/heart/daemon/up-progress.js +135 -0
- package/dist/heart/delegation.js +62 -0
- package/dist/heart/habits/habit-migration.js +181 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-scheduler.js +371 -0
- package/dist/heart/hatch/hatch-animation.js +35 -0
- package/dist/heart/{daemon → hatch}/hatch-flow.js +55 -135
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
- package/dist/heart/hatch/specialist-orchestrator.js +129 -0
- package/dist/heart/hatch/specialist-prompt.js +102 -0
- package/dist/heart/hatch/specialist-tools.js +304 -0
- package/dist/heart/identity.js +246 -58
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +2 -20
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mcp/mcp-server.js +653 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +59 -0
- package/dist/heart/outlook/outlook-http-hooks.js +64 -0
- package/dist/heart/outlook/outlook-http-response.js +7 -0
- package/dist/heart/outlook/outlook-http-routes.js +232 -0
- package/dist/heart/outlook/outlook-http-static.js +99 -0
- package/dist/heart/outlook/outlook-http-transport.js +116 -0
- package/dist/heart/outlook/outlook-http.js +99 -0
- package/dist/heart/outlook/outlook-read.js +28 -0
- package/dist/heart/outlook/outlook-types.js +27 -0
- package/dist/heart/outlook/outlook-view.js +195 -0
- package/dist/heart/outlook/readers/agent-machine.js +359 -0
- package/dist/heart/outlook/readers/continuity-readers.js +332 -0
- package/dist/heart/outlook/readers/runtime-readers.js +660 -0
- package/dist/heart/outlook/readers/sessions.js +232 -0
- package/dist/heart/outlook/readers/shared.js +111 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/progress-story.js +42 -0
- package/dist/heart/provider-attempt.js +133 -0
- package/dist/heart/provider-binding-resolver.js +239 -0
- package/dist/heart/provider-credentials.js +383 -0
- package/dist/heart/provider-failover.js +266 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +237 -0
- package/dist/heart/provider-state.js +216 -0
- package/dist/heart/provider-visibility.js +186 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +202 -50
- package/dist/heart/providers/azure.js +103 -12
- package/dist/heart/providers/error-classification.js +63 -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 +29 -7
- package/dist/heart/providers/openai-codex.js +39 -29
- package/dist/heart/runtime-credentials.js +181 -0
- package/dist/heart/sense-truth.js +61 -0
- package/dist/heart/session-activity.js +190 -0
- package/dist/heart/session-events.js +855 -0
- package/dist/heart/session-transcript.js +167 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +117 -33
- package/dist/heart/sync.js +332 -0
- package/dist/heart/target-resolution.js +127 -0
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/tool-activity-callbacks.js +36 -0
- package/dist/heart/tool-description.js +135 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +351 -0
- package/dist/heart/turn-coordinator.js +28 -0
- package/dist/heart/versioning/ouro-bot-global-installer.js +128 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +301 -0
- package/dist/heart/{daemon → versioning}/ouro-uti.js +11 -2
- package/dist/heart/versioning/ouro-version-manager.js +295 -0
- package/dist/heart/versioning/staged-restart.js +146 -0
- package/dist/heart/versioning/update-checker.js +113 -0
- package/dist/heart/versioning/update-hooks.js +142 -0
- package/dist/heart/versioning/wrapper-publish-guard.js +86 -0
- package/dist/mind/bundle-manifest.js +77 -1
- package/dist/mind/context.js +141 -94
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +84 -96
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/first-impressions.js +16 -2
- package/dist/mind/friends/channel.js +64 -0
- package/dist/mind/friends/group-context.js +144 -0
- package/dist/mind/friends/resolver.js +38 -1
- package/dist/mind/friends/store-file.js +58 -3
- package/dist/mind/friends/trust-explanation.js +74 -0
- package/dist/mind/friends/types.js +10 -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 +76 -9
- package/dist/mind/phrases.js +1 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1111 -117
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/mind/token-estimate.js +8 -12
- package/dist/nerves/cli-logging.js +22 -3
- 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 +83 -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/runtime.js +5 -1
- package/dist/outlook-ui/assets/index-BAcU08c-.css +1 -0
- package/dist/outlook-ui/assets/index-D7l3l4vY.js +61 -0
- package/dist/outlook-ui/index.html +15 -0
- package/dist/repertoire/ado-client.js +17 -56
- package/dist/repertoire/ado-semantic.js +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +461 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +79 -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 +301 -0
- package/dist/repertoire/coding/index.js +4 -1
- package/dist/repertoire/coding/manager.js +220 -13
- package/dist/repertoire/coding/spawner.js +58 -12
- package/dist/repertoire/coding/tools.js +209 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +107 -0
- package/dist/repertoire/data/ado-endpoints.json +188 -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 +371 -0
- package/dist/repertoire/mcp-client.js +255 -0
- package/dist/repertoire/mcp-manager.js +305 -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 +43 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +28 -10
- 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 -79
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-base.js +45 -707
- package/dist/repertoire/tools-bluebubbles.js +94 -0
- package/dist/repertoire/tools-bridge.js +141 -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 +182 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +105 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-notes.js +376 -0
- package/dist/repertoire/tools-session.js +739 -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 +64 -61
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools.js +149 -98
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +118 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +382 -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/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/bluebubbles/client.js +685 -0
- package/dist/senses/bluebubbles/entry.js +70 -0
- package/dist/senses/bluebubbles/inbound-log.js +113 -0
- package/dist/senses/bluebubbles/index.js +1620 -0
- package/dist/senses/bluebubbles/media.js +389 -0
- package/dist/senses/bluebubbles/model.js +282 -0
- package/dist/senses/bluebubbles/mutation-log.js +116 -0
- package/dist/senses/bluebubbles/replay.js +129 -0
- package/dist/senses/bluebubbles/runtime-state.js +109 -0
- package/dist/senses/bluebubbles/session-cleanup.js +72 -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 +605 -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 +83 -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 +768 -264
- package/dist/senses/commands.js +66 -3
- package/dist/senses/continuity.js +94 -0
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +112 -19
- package/dist/senses/inner-dialog.js +636 -86
- package/dist/senses/pipeline.js +602 -0
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +205 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +844 -197
- package/dist/senses/trust-gate.js +112 -2
- package/package.json +38 -6
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +110 -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 +134 -0
- package/AdoptionSpecialist.ouro/agent.json +0 -20
- package/AdoptionSpecialist.ouro/psyche/SOUL.md +0 -22
- package/dist/heart/daemon/subagent-installer.js +0 -125
- package/dist/inner-worker-entry.js +0 -4
- package/dist/mind/associative-recall.js +0 -197
- package/subagents/README.md +0 -73
- package/subagents/work-doer.md +0 -233
- package/subagents/work-merger.md +0 -624
- package/subagents/work-planner.md +0 -373
- /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/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/identity.js
CHANGED
|
@@ -33,20 +33,40 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = void 0;
|
|
36
|
+
exports.HARNESS_CANONICAL_REPO_URL = exports.DEFAULT_AGENT_SENSES = exports.DEFAULT_VAULT_SERVER_URL = exports.DEFAULT_AGENT_PHRASES = exports.DEFAULT_AGENT_CONTEXT = exports.PROVIDER_CREDENTIALS = void 0;
|
|
37
|
+
exports.defaultStableVaultEmail = defaultStableVaultEmail;
|
|
38
|
+
exports.resolveVaultConfig = resolveVaultConfig;
|
|
39
|
+
exports.normalizeSenses = normalizeSenses;
|
|
37
40
|
exports.buildDefaultAgentTemplate = buildDefaultAgentTemplate;
|
|
38
41
|
exports.getAgentName = getAgentName;
|
|
39
42
|
exports.getRepoRoot = getRepoRoot;
|
|
40
43
|
exports.getAgentBundlesRoot = getAgentBundlesRoot;
|
|
41
44
|
exports.getAgentRoot = getAgentRoot;
|
|
42
|
-
exports.
|
|
45
|
+
exports.getAgentStateRoot = getAgentStateRoot;
|
|
46
|
+
exports.getAgentRepoWorkspacesRoot = getAgentRepoWorkspacesRoot;
|
|
47
|
+
exports.getAgentDaemonStateRoot = getAgentDaemonStateRoot;
|
|
48
|
+
exports.getAgentDaemonLogsDir = getAgentDaemonLogsDir;
|
|
49
|
+
exports.getAgentDaemonLoggingConfigPath = getAgentDaemonLoggingConfigPath;
|
|
50
|
+
exports.getAgentMessagesRoot = getAgentMessagesRoot;
|
|
51
|
+
exports.getAgentToolsRoot = getAgentToolsRoot;
|
|
43
52
|
exports.loadAgentConfig = loadAgentConfig;
|
|
44
53
|
exports.setAgentName = setAgentName;
|
|
54
|
+
exports.setAgentConfigOverride = setAgentConfigOverride;
|
|
55
|
+
exports.resetAgentConfigCache = resetAgentConfigCache;
|
|
45
56
|
exports.resetIdentity = resetIdentity;
|
|
46
57
|
const fs = __importStar(require("fs"));
|
|
47
58
|
const os = __importStar(require("os"));
|
|
48
59
|
const path = __importStar(require("path"));
|
|
49
60
|
const runtime_1 = require("../nerves/runtime");
|
|
61
|
+
const migrate_config_1 = require("./migrate-config");
|
|
62
|
+
/** Single source of truth for per-provider credential field names, env var mappings, and prompt labels. */
|
|
63
|
+
exports.PROVIDER_CREDENTIALS = {
|
|
64
|
+
anthropic: { required: ["setupToken"], envVars: { ANTHROPIC_API_KEY: "setupToken" }, promptLabels: { setupToken: "Anthropic setup-token" } },
|
|
65
|
+
"openai-codex": { required: ["oauthAccessToken"], envVars: { OPENAI_API_KEY: "oauthAccessToken" }, promptLabels: { oauthAccessToken: "OpenAI Codex OAuth token" } },
|
|
66
|
+
azure: { required: ["apiKey", "endpoint", "deployment"], envVars: { AZURE_OPENAI_API_KEY: "apiKey", AZURE_OPENAI_KEY: "apiKey", AZURE_OPENAI_ENDPOINT: "endpoint", AZURE_OPENAI_DEPLOYMENT: "deployment" }, promptLabels: { apiKey: "Azure API key", endpoint: "Azure endpoint", deployment: "Azure deployment" } },
|
|
67
|
+
minimax: { required: ["apiKey"], envVars: { MINIMAX_API_KEY: "apiKey" }, promptLabels: { apiKey: "MiniMax API key" } },
|
|
68
|
+
"github-copilot": { required: ["githubToken", "baseUrl"], envVars: { GH_TOKEN: "githubToken", GITHUB_TOKEN: "githubToken" }, promptLabels: { githubToken: "GitHub token" } },
|
|
69
|
+
};
|
|
50
70
|
exports.DEFAULT_AGENT_CONTEXT = {
|
|
51
71
|
maxTokens: 80000,
|
|
52
72
|
contextMargin: 20,
|
|
@@ -56,12 +76,92 @@ exports.DEFAULT_AGENT_PHRASES = {
|
|
|
56
76
|
tool: ["running tool"],
|
|
57
77
|
followup: ["processing"],
|
|
58
78
|
};
|
|
79
|
+
exports.DEFAULT_VAULT_SERVER_URL = "https://vault.ouroboros.bot";
|
|
80
|
+
function defaultStableVaultEmail(agentName) {
|
|
81
|
+
const local = agentName
|
|
82
|
+
.toLowerCase()
|
|
83
|
+
.replace(/[^a-z0-9._-]+/g, "-")
|
|
84
|
+
.replace(/^-+|-+$/g, "") || "agent";
|
|
85
|
+
return `${local}@ouro.bot`;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Resolve the vault config for an agent, applying defaults.
|
|
89
|
+
* If vault is not configured in agent.json, returns default values.
|
|
90
|
+
*/
|
|
91
|
+
function resolveVaultConfig(agentName, config) {
|
|
92
|
+
return {
|
|
93
|
+
email: config?.email ?? defaultStableVaultEmail(agentName),
|
|
94
|
+
serverUrl: config?.serverUrl ?? exports.DEFAULT_VAULT_SERVER_URL,
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
exports.DEFAULT_AGENT_SENSES = {
|
|
98
|
+
cli: { enabled: true },
|
|
99
|
+
teams: { enabled: false },
|
|
100
|
+
bluebubbles: { enabled: false },
|
|
101
|
+
};
|
|
102
|
+
function normalizeSenses(value, configFile) {
|
|
103
|
+
const defaults = {
|
|
104
|
+
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
105
|
+
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
106
|
+
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
107
|
+
};
|
|
108
|
+
if (value === undefined) {
|
|
109
|
+
return defaults;
|
|
110
|
+
}
|
|
111
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) {
|
|
112
|
+
(0, runtime_1.emitNervesEvent)({
|
|
113
|
+
level: "error",
|
|
114
|
+
event: "config_identity.error",
|
|
115
|
+
component: "config/identity",
|
|
116
|
+
message: "agent config has invalid senses block",
|
|
117
|
+
meta: { path: configFile },
|
|
118
|
+
});
|
|
119
|
+
throw new Error(`agent.json at ${configFile} must include senses as an object when present.`);
|
|
120
|
+
}
|
|
121
|
+
const raw = value;
|
|
122
|
+
const senseNames = ["cli", "teams", "bluebubbles"];
|
|
123
|
+
for (const senseName of senseNames) {
|
|
124
|
+
const rawSense = raw[senseName];
|
|
125
|
+
if (rawSense === undefined) {
|
|
126
|
+
continue;
|
|
127
|
+
}
|
|
128
|
+
if (!rawSense || typeof rawSense !== "object" || Array.isArray(rawSense)) {
|
|
129
|
+
(0, runtime_1.emitNervesEvent)({
|
|
130
|
+
level: "error",
|
|
131
|
+
event: "config_identity.error",
|
|
132
|
+
component: "config/identity",
|
|
133
|
+
message: "agent config has invalid sense config",
|
|
134
|
+
meta: { path: configFile, sense: senseName },
|
|
135
|
+
});
|
|
136
|
+
throw new Error(`agent.json at ${configFile} has invalid senses.${senseName} config.`);
|
|
137
|
+
}
|
|
138
|
+
const enabled = rawSense.enabled;
|
|
139
|
+
if (typeof enabled !== "boolean") {
|
|
140
|
+
(0, runtime_1.emitNervesEvent)({
|
|
141
|
+
level: "error",
|
|
142
|
+
event: "config_identity.error",
|
|
143
|
+
component: "config/identity",
|
|
144
|
+
message: "agent config has invalid sense enabled flag",
|
|
145
|
+
meta: { path: configFile, sense: senseName, enabled: enabled ?? null },
|
|
146
|
+
});
|
|
147
|
+
throw new Error(`agent.json at ${configFile} must include senses.${senseName}.enabled as boolean.`);
|
|
148
|
+
}
|
|
149
|
+
defaults[senseName] = { enabled };
|
|
150
|
+
}
|
|
151
|
+
return defaults;
|
|
152
|
+
}
|
|
59
153
|
function buildDefaultAgentTemplate(_agentName) {
|
|
60
154
|
return {
|
|
61
|
-
version:
|
|
155
|
+
version: 2,
|
|
62
156
|
enabled: true,
|
|
63
|
-
provider: "anthropic",
|
|
157
|
+
humanFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
158
|
+
agentFacing: { provider: "anthropic", model: "claude-opus-4-6" },
|
|
64
159
|
context: { ...exports.DEFAULT_AGENT_CONTEXT },
|
|
160
|
+
senses: {
|
|
161
|
+
cli: { ...exports.DEFAULT_AGENT_SENSES.cli },
|
|
162
|
+
teams: { ...exports.DEFAULT_AGENT_SENSES.teams },
|
|
163
|
+
bluebubbles: { ...exports.DEFAULT_AGENT_SENSES.bluebubbles },
|
|
164
|
+
},
|
|
65
165
|
phrases: {
|
|
66
166
|
thinking: [...exports.DEFAULT_AGENT_PHRASES.thinking],
|
|
67
167
|
tool: [...exports.DEFAULT_AGENT_PHRASES.tool],
|
|
@@ -70,7 +170,7 @@ function buildDefaultAgentTemplate(_agentName) {
|
|
|
70
170
|
};
|
|
71
171
|
}
|
|
72
172
|
let _cachedAgentName = null;
|
|
73
|
-
let
|
|
173
|
+
let _agentConfigOverride = null;
|
|
74
174
|
/**
|
|
75
175
|
* Parse `--agent <name>` from process.argv.
|
|
76
176
|
* Caches the result after first parse.
|
|
@@ -111,37 +211,55 @@ function getRepoRoot() {
|
|
|
111
211
|
* Returns the shared bundle root directory: `~/AgentBundles/`
|
|
112
212
|
*/
|
|
113
213
|
function getAgentBundlesRoot() {
|
|
114
|
-
|
|
214
|
+
const homeBase = process.env.WEBSITE_SITE_NAME ? "/home" : os.homedir();
|
|
215
|
+
return path.join(homeBase, "AgentBundles");
|
|
115
216
|
}
|
|
116
217
|
/**
|
|
117
218
|
* Returns the agent-specific bundle directory: `~/AgentBundles/<agentName>.ouro/`
|
|
118
219
|
*/
|
|
119
|
-
function getAgentRoot() {
|
|
120
|
-
return path.join(getAgentBundlesRoot(), `${
|
|
220
|
+
function getAgentRoot(agentName = getAgentName()) {
|
|
221
|
+
return path.join(getAgentBundlesRoot(), `${agentName}.ouro`);
|
|
121
222
|
}
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
223
|
+
function resolveOptionalAgentName(agentName) {
|
|
224
|
+
if (agentName && agentName.trim().length > 0)
|
|
225
|
+
return agentName.trim();
|
|
226
|
+
try {
|
|
227
|
+
return getAgentName();
|
|
228
|
+
}
|
|
229
|
+
catch {
|
|
230
|
+
return "slugger";
|
|
231
|
+
}
|
|
127
232
|
}
|
|
128
233
|
/**
|
|
129
|
-
*
|
|
130
|
-
* Caches the result after first load.
|
|
131
|
-
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
234
|
+
* Returns the bundle-local runtime state directory: `~/AgentBundles/<agentName>.ouro/state/`
|
|
132
235
|
*/
|
|
133
|
-
function
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
236
|
+
function getAgentStateRoot(agentName) {
|
|
237
|
+
return path.join(getAgentRoot(resolveOptionalAgentName(agentName)), "state");
|
|
238
|
+
}
|
|
239
|
+
exports.HARNESS_CANONICAL_REPO_URL = "https://github.com/ouroborosbot/ouroboros.git";
|
|
240
|
+
function getAgentRepoWorkspacesRoot(agentName) {
|
|
241
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "workspaces");
|
|
242
|
+
}
|
|
243
|
+
function getAgentDaemonStateRoot(agentName) {
|
|
244
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "daemon");
|
|
245
|
+
}
|
|
246
|
+
function getAgentDaemonLogsDir(agentName) {
|
|
247
|
+
return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logs");
|
|
248
|
+
}
|
|
249
|
+
function getAgentDaemonLoggingConfigPath(agentName) {
|
|
250
|
+
return path.join(getAgentDaemonStateRoot(resolveOptionalAgentName(agentName)), "logging.json");
|
|
251
|
+
}
|
|
252
|
+
function getAgentMessagesRoot(agentName) {
|
|
253
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "messages");
|
|
254
|
+
}
|
|
255
|
+
function getAgentToolsRoot(agentName) {
|
|
256
|
+
return path.join(getAgentStateRoot(resolveOptionalAgentName(agentName)), "tools");
|
|
257
|
+
}
|
|
258
|
+
const VALID_PROVIDERS = ["azure", "minimax", "anthropic", "openai-codex", "github-copilot"];
|
|
259
|
+
function isValidProvider(value) {
|
|
260
|
+
return typeof value === "string" && VALID_PROVIDERS.includes(value);
|
|
261
|
+
}
|
|
262
|
+
function readAndParseAgentJson(configFile) {
|
|
145
263
|
let raw;
|
|
146
264
|
try {
|
|
147
265
|
raw = fs.readFileSync(configFile, "utf-8");
|
|
@@ -159,9 +277,8 @@ function loadAgentConfig() {
|
|
|
159
277
|
});
|
|
160
278
|
throw new Error(`Cannot read agent.json at ${configFile}. Does the agent directory exist?`);
|
|
161
279
|
}
|
|
162
|
-
let parsed;
|
|
163
280
|
try {
|
|
164
|
-
|
|
281
|
+
return JSON.parse(raw);
|
|
165
282
|
}
|
|
166
283
|
catch (error) {
|
|
167
284
|
(0, runtime_1.emitNervesEvent)({
|
|
@@ -176,6 +293,62 @@ function loadAgentConfig() {
|
|
|
176
293
|
});
|
|
177
294
|
throw new Error(`Invalid JSON in agent.json at ${configFile}. Check syntax.`);
|
|
178
295
|
}
|
|
296
|
+
}
|
|
297
|
+
function validateFacingConfig(parsed, facingName, configFile) {
|
|
298
|
+
const raw = parsed[facingName];
|
|
299
|
+
if (!raw || typeof raw !== "object" || Array.isArray(raw)) {
|
|
300
|
+
(0, runtime_1.emitNervesEvent)({
|
|
301
|
+
level: "error",
|
|
302
|
+
event: "config_identity.error",
|
|
303
|
+
component: "config/identity",
|
|
304
|
+
message: `agent config missing or invalid ${facingName}`,
|
|
305
|
+
meta: { path: configFile, [facingName]: raw ?? null },
|
|
306
|
+
});
|
|
307
|
+
throw new Error(`agent.json at ${configFile} must include ${facingName} as { provider, model }.`);
|
|
308
|
+
}
|
|
309
|
+
const facing = raw;
|
|
310
|
+
if (!isValidProvider(facing.provider)) {
|
|
311
|
+
(0, runtime_1.emitNervesEvent)({
|
|
312
|
+
level: "error",
|
|
313
|
+
event: "config_identity.error",
|
|
314
|
+
component: "config/identity",
|
|
315
|
+
message: `agent config has invalid provider in ${facingName}`,
|
|
316
|
+
meta: { path: configFile, provider: facing.provider ?? null },
|
|
317
|
+
});
|
|
318
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.provider must be one of: ${VALID_PROVIDERS.join(", ")}.`);
|
|
319
|
+
}
|
|
320
|
+
if (typeof facing.model !== "string") {
|
|
321
|
+
(0, runtime_1.emitNervesEvent)({
|
|
322
|
+
level: "error",
|
|
323
|
+
event: "config_identity.error",
|
|
324
|
+
component: "config/identity",
|
|
325
|
+
message: `agent config has invalid model in ${facingName}`,
|
|
326
|
+
meta: { path: configFile, model: facing.model ?? null },
|
|
327
|
+
});
|
|
328
|
+
throw new Error(`agent.json at ${configFile} ${facingName}.model must be a string.`);
|
|
329
|
+
}
|
|
330
|
+
return { provider: facing.provider, model: facing.model };
|
|
331
|
+
}
|
|
332
|
+
/**
|
|
333
|
+
* Load and parse `<agentRoot>/agent.json`.
|
|
334
|
+
* Reads the file fresh on each call unless an override is set.
|
|
335
|
+
* If the config is v1, auto-migrates to v2 via migrateAgentConfigV1ToV2 and re-reads.
|
|
336
|
+
* Throws descriptive error if file is missing or contains invalid JSON.
|
|
337
|
+
*/
|
|
338
|
+
function loadAgentConfig() {
|
|
339
|
+
if (_agentConfigOverride) {
|
|
340
|
+
return _agentConfigOverride;
|
|
341
|
+
}
|
|
342
|
+
const agentRoot = getAgentRoot();
|
|
343
|
+
const configFile = path.join(agentRoot, "agent.json");
|
|
344
|
+
let parsed = readAndParseAgentJson(configFile);
|
|
345
|
+
// Inline migration: v1 -> v2
|
|
346
|
+
const rawVersion = parsed.version;
|
|
347
|
+
const initialVersion = typeof rawVersion === "number" ? rawVersion : 1;
|
|
348
|
+
if (initialVersion < 2) {
|
|
349
|
+
(0, migrate_config_1.migrateAgentConfigV1ToV2)(agentRoot);
|
|
350
|
+
parsed = readAndParseAgentJson(configFile);
|
|
351
|
+
}
|
|
179
352
|
const existingPhrases = parsed.phrases;
|
|
180
353
|
const needsFill = !existingPhrases ||
|
|
181
354
|
!existingPhrases.thinking ||
|
|
@@ -197,27 +370,11 @@ function loadAgentConfig() {
|
|
|
197
370
|
});
|
|
198
371
|
fs.writeFileSync(configFile, JSON.stringify(parsed, null, 2) + "\n", "utf-8");
|
|
199
372
|
}
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
(0, runtime_1.emitNervesEvent)({
|
|
206
|
-
level: "error",
|
|
207
|
-
event: "config_identity.error",
|
|
208
|
-
component: "config/identity",
|
|
209
|
-
message: "agent config missing or invalid provider",
|
|
210
|
-
meta: {
|
|
211
|
-
path: configFile,
|
|
212
|
-
provider: rawProvider,
|
|
213
|
-
},
|
|
214
|
-
});
|
|
215
|
-
throw new Error(`agent.json at ${configFile} must include provider: "azure", "minimax", "anthropic", or "openai-codex".`);
|
|
216
|
-
}
|
|
217
|
-
const rawVersion = parsed.version;
|
|
218
|
-
const version = rawVersion === undefined ? 1 : rawVersion;
|
|
219
|
-
if (typeof version !== "number" ||
|
|
220
|
-
!Number.isInteger(version) ||
|
|
373
|
+
// Validate v2 facing configs
|
|
374
|
+
const humanFacing = validateFacingConfig(parsed, "humanFacing", configFile);
|
|
375
|
+
const agentFacing = validateFacingConfig(parsed, "agentFacing", configFile);
|
|
376
|
+
const version = typeof parsed.version === "number" ? parsed.version : 1;
|
|
377
|
+
if (!Number.isInteger(version) ||
|
|
221
378
|
version < 1) {
|
|
222
379
|
(0, runtime_1.emitNervesEvent)({
|
|
223
380
|
level: "error",
|
|
@@ -226,7 +383,7 @@ function loadAgentConfig() {
|
|
|
226
383
|
message: "agent config missing or invalid version",
|
|
227
384
|
meta: {
|
|
228
385
|
path: configFile,
|
|
229
|
-
version:
|
|
386
|
+
version: parsed.version,
|
|
230
387
|
},
|
|
231
388
|
});
|
|
232
389
|
throw new Error(`agent.json at ${configFile} must include version as integer >= 1.`);
|
|
@@ -246,21 +403,37 @@ function loadAgentConfig() {
|
|
|
246
403
|
});
|
|
247
404
|
throw new Error(`agent.json at ${configFile} must include enabled as boolean.`);
|
|
248
405
|
}
|
|
249
|
-
|
|
406
|
+
// Tolerate deprecated provider field for backward compatibility
|
|
407
|
+
const rawProvider = parsed.provider;
|
|
408
|
+
const provider = isValidProvider(rawProvider) ? rawProvider : undefined;
|
|
409
|
+
// Spread parsed first so any field present in AgentConfig is carried
|
|
410
|
+
// through by default, then explicitly override the fields that need
|
|
411
|
+
// validation or normalization. This eliminates the field-drop bug class
|
|
412
|
+
// that caused the `sync` block (and previously `shell`) to be silently
|
|
413
|
+
// omitted from the returned config. Regression-guarded by the
|
|
414
|
+
// Required<AgentConfig> contract test in identity-contract.test.ts.
|
|
415
|
+
const config = {
|
|
416
|
+
...parsed,
|
|
250
417
|
version,
|
|
251
418
|
enabled,
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
419
|
+
humanFacing,
|
|
420
|
+
agentFacing,
|
|
421
|
+
senses: normalizeSenses(parsed.senses, configFile),
|
|
255
422
|
phrases: parsed.phrases,
|
|
256
423
|
};
|
|
424
|
+
if (provider !== undefined) {
|
|
425
|
+
config.provider = provider;
|
|
426
|
+
}
|
|
427
|
+
else {
|
|
428
|
+
delete config.provider;
|
|
429
|
+
}
|
|
257
430
|
(0, runtime_1.emitNervesEvent)({
|
|
258
431
|
event: "identity.resolve",
|
|
259
432
|
component: "config/identity",
|
|
260
433
|
message: "loaded agent config from disk",
|
|
261
434
|
meta: { source: "disk" },
|
|
262
435
|
});
|
|
263
|
-
return
|
|
436
|
+
return config;
|
|
264
437
|
}
|
|
265
438
|
/**
|
|
266
439
|
* Prime the agent name cache explicitly.
|
|
@@ -271,11 +444,26 @@ function loadAgentConfig() {
|
|
|
271
444
|
function setAgentName(name) {
|
|
272
445
|
_cachedAgentName = name;
|
|
273
446
|
}
|
|
447
|
+
/**
|
|
448
|
+
* Override the agent config returned by loadAgentConfig().
|
|
449
|
+
* When set to a non-null AgentConfig, loadAgentConfig() returns the override
|
|
450
|
+
* instead of reading from disk. When set to null, normal disk-based loading resumes.
|
|
451
|
+
*/
|
|
452
|
+
function setAgentConfigOverride(config) {
|
|
453
|
+
_agentConfigOverride = config;
|
|
454
|
+
}
|
|
455
|
+
/**
|
|
456
|
+
* Preserve the compatibility hook for callers that previously cleared cached
|
|
457
|
+
* disk-backed agent config. Agent config is now read fresh on every call.
|
|
458
|
+
*/
|
|
459
|
+
function resetAgentConfigCache() {
|
|
460
|
+
// No-op: disk-backed agent config is no longer memoized in-process.
|
|
461
|
+
}
|
|
274
462
|
/**
|
|
275
463
|
* Clear all cached identity state.
|
|
276
464
|
* Used in tests and when switching agent context.
|
|
277
465
|
*/
|
|
278
466
|
function resetIdentity() {
|
|
279
467
|
_cachedAgentName = null;
|
|
280
|
-
|
|
468
|
+
_agentConfigOverride = null;
|
|
281
469
|
}
|