@ouro.bot/cli 0.1.0-alpha.45 → 0.1.0-alpha.450
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 -19
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -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 +2853 -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 +426 -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 +110 -128
- package/dist/heart/core.js +745 -227
- package/dist/heart/cross-chat-delivery.js +131 -0
- package/dist/heart/daemon/agent-config-check.js +490 -0
- package/dist/heart/daemon/agent-discovery.js +79 -3
- package/dist/heart/daemon/agent-service.js +360 -0
- package/dist/heart/daemon/agentic-repair.js +216 -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 +631 -0
- package/dist/heart/daemon/cli-exec.js +5805 -0
- package/dist/heart/daemon/cli-help.js +428 -0
- package/dist/heart/daemon/cli-parse.js +1156 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +561 -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 -1617
- package/dist/heart/daemon/daemon-entry.js +356 -3
- package/dist/heart/daemon/daemon-health.js +141 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +190 -12
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +684 -58
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +427 -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 +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 +25 -5
- 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 +2 -2
- 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 +214 -0
- 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 +73 -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 +123 -34
- 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 +264 -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 +510 -0
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/delegation.js +62 -0
- 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 +3 -3
- 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 +197 -65
- 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/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 +644 -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 +134 -0
- package/dist/heart/provider-binding-resolver.js +255 -0
- package/dist/heart/provider-credentials.js +424 -0
- package/dist/heart/provider-failover.js +266 -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 +193 -55
- 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 +62 -38
- package/dist/heart/runtime-capability-check.js +170 -0
- package/dist/heart/runtime-credentials.js +260 -0
- package/dist/heart/sense-truth.js +3 -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 +36 -27
- 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/{daemon → versioning}/ouro-bot-global-installer.js +1 -1
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +425 -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 +5 -1
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- package/dist/mind/bundle-manifest.js +7 -1
- package/dist/mind/context.js +132 -93
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +74 -93
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +21 -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 +39 -3
- package/dist/mind/friends/trust-explanation.js +74 -0
- package/dist/mind/friends/types.js +1 -1
- 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 +66 -7
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +947 -165
- 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 +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 +15 -56
- package/dist/repertoire/ado-semantic.js +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +774 -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 +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 +37 -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 +42 -690
- package/dist/repertoire/tools-bluebubbles.js +1 -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 +361 -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 +9 -39
- 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 +144 -113
- 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/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 +73 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +7 -3
- package/dist/senses/bluebubbles/index.js +1620 -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/replay.js +129 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +2 -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 +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 +516 -211
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +102 -19
- package/dist/senses/inner-dialog.js +597 -95
- package/dist/senses/pipeline.js +533 -72
- 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 +413 -163
- package/dist/senses/trust-gate.js +5 -5
- package/package.json +32 -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/mind/associative-recall.js +0 -209
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1028
- package/dist/senses/debug-activity.js +0 -127
- 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
|
@@ -33,7 +33,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
33
33
|
};
|
|
34
34
|
})();
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
-
exports.
|
|
36
|
+
exports.storeHatchlingProviderCredentials = storeHatchlingProviderCredentials;
|
|
37
37
|
exports.runHatchFlow = runHatchFlow;
|
|
38
38
|
const fs = __importStar(require("fs"));
|
|
39
39
|
const os = __importStar(require("os"));
|
|
@@ -41,15 +41,15 @@ const path = __importStar(require("path"));
|
|
|
41
41
|
const identity_1 = require("../identity");
|
|
42
42
|
const config_1 = require("../config");
|
|
43
43
|
const runtime_1 = require("../../nerves/runtime");
|
|
44
|
+
const auth_flow_1 = require("../auth/auth-flow");
|
|
45
|
+
const provider_models_1 = require("../provider-models");
|
|
46
|
+
const habit_parser_1 = require("../habits/habit-parser");
|
|
47
|
+
const machine_identity_1 = require("../machine-identity");
|
|
48
|
+
const provider_credentials_1 = require("../provider-credentials");
|
|
49
|
+
const provider_state_1 = require("../provider-state");
|
|
44
50
|
const hatch_specialist_1 = require("./hatch-specialist");
|
|
45
51
|
function requiredCredentialKeys(provider) {
|
|
46
|
-
|
|
47
|
-
return ["setupToken"];
|
|
48
|
-
if (provider === "openai-codex")
|
|
49
|
-
return ["oauthAccessToken"];
|
|
50
|
-
if (provider === "minimax")
|
|
51
|
-
return ["apiKey"];
|
|
52
|
-
return ["apiKey", "endpoint", "deployment"];
|
|
52
|
+
return identity_1.PROVIDER_CREDENTIALS[provider].required;
|
|
53
53
|
}
|
|
54
54
|
function validateCredentials(provider, credentials) {
|
|
55
55
|
const missing = requiredCredentialKeys(provider).filter((key) => {
|
|
@@ -67,70 +67,8 @@ function validateCredentials(provider, credentials) {
|
|
|
67
67
|
throw new Error(`Missing required credentials for ${provider}: ${missing.join(", ")}`);
|
|
68
68
|
}
|
|
69
69
|
}
|
|
70
|
-
function
|
|
71
|
-
return
|
|
72
|
-
providers: {
|
|
73
|
-
azure: {
|
|
74
|
-
modelName: "gpt-4o-mini",
|
|
75
|
-
apiKey: "",
|
|
76
|
-
endpoint: "",
|
|
77
|
-
deployment: "",
|
|
78
|
-
apiVersion: "2025-04-01-preview",
|
|
79
|
-
},
|
|
80
|
-
minimax: {
|
|
81
|
-
model: "minimax-text-01",
|
|
82
|
-
apiKey: "",
|
|
83
|
-
},
|
|
84
|
-
anthropic: {
|
|
85
|
-
model: "claude-opus-4-6",
|
|
86
|
-
setupToken: "",
|
|
87
|
-
},
|
|
88
|
-
"openai-codex": {
|
|
89
|
-
model: "gpt-5.4",
|
|
90
|
-
oauthAccessToken: "",
|
|
91
|
-
},
|
|
92
|
-
},
|
|
93
|
-
teams: {
|
|
94
|
-
clientId: "",
|
|
95
|
-
clientSecret: "",
|
|
96
|
-
tenantId: "",
|
|
97
|
-
},
|
|
98
|
-
oauth: {
|
|
99
|
-
graphConnectionName: "graph",
|
|
100
|
-
adoConnectionName: "ado",
|
|
101
|
-
githubConnectionName: "",
|
|
102
|
-
},
|
|
103
|
-
teamsChannel: {
|
|
104
|
-
skipConfirmation: true,
|
|
105
|
-
port: 3978,
|
|
106
|
-
},
|
|
107
|
-
integrations: {
|
|
108
|
-
perplexityApiKey: "",
|
|
109
|
-
openaiEmbeddingsApiKey: "",
|
|
110
|
-
},
|
|
111
|
-
};
|
|
112
|
-
}
|
|
113
|
-
function writeSecretsFile(agentName, provider, credentials, secretsRoot) {
|
|
114
|
-
const secrets = buildSecretsTemplate();
|
|
115
|
-
if (provider === "anthropic") {
|
|
116
|
-
secrets.providers.anthropic.setupToken = credentials.setupToken.trim();
|
|
117
|
-
}
|
|
118
|
-
else if (provider === "openai-codex") {
|
|
119
|
-
secrets.providers["openai-codex"].oauthAccessToken = credentials.oauthAccessToken.trim();
|
|
120
|
-
}
|
|
121
|
-
else if (provider === "minimax") {
|
|
122
|
-
secrets.providers.minimax.apiKey = credentials.apiKey.trim();
|
|
123
|
-
}
|
|
124
|
-
else {
|
|
125
|
-
secrets.providers.azure.apiKey = credentials.apiKey.trim();
|
|
126
|
-
secrets.providers.azure.endpoint = credentials.endpoint.trim();
|
|
127
|
-
secrets.providers.azure.deployment = credentials.deployment.trim();
|
|
128
|
-
}
|
|
129
|
-
const secretsDir = path.join(secretsRoot, agentName);
|
|
130
|
-
fs.mkdirSync(secretsDir, { recursive: true });
|
|
131
|
-
const secretsPath = path.join(secretsDir, "secrets.json");
|
|
132
|
-
fs.writeFileSync(secretsPath, `${JSON.stringify(secrets, null, 2)}\n`, "utf-8");
|
|
133
|
-
return secretsPath;
|
|
70
|
+
async function storeHatchlingProviderCredentials(agentName, provider, credentials) {
|
|
71
|
+
return (await (0, auth_flow_1.storeProviderCredentials)(agentName, provider, credentials)).credentialPath;
|
|
134
72
|
}
|
|
135
73
|
function writeReadme(dir, purpose) {
|
|
136
74
|
fs.mkdirSync(dir, { recursive: true });
|
|
@@ -139,36 +77,16 @@ function writeReadme(dir, purpose) {
|
|
|
139
77
|
fs.writeFileSync(readmePath, `# ${path.basename(dir)}\n\n${purpose}\n`, "utf-8");
|
|
140
78
|
}
|
|
141
79
|
}
|
|
142
|
-
function
|
|
143
|
-
|
|
144
|
-
}
|
|
145
|
-
function formatTaskStem(now) {
|
|
146
|
-
return `${now.getFullYear()}-${pad(now.getMonth() + 1)}-${pad(now.getDate())}-${pad(now.getHours())}${pad(now.getMinutes())}`;
|
|
147
|
-
}
|
|
148
|
-
function writeHeartbeatTask(bundleRoot, now) {
|
|
149
|
-
const habitsDir = path.join(bundleRoot, "tasks", "habits");
|
|
80
|
+
function writeHeartbeatHabit(bundleRoot, now) {
|
|
81
|
+
const habitsDir = path.join(bundleRoot, "habits");
|
|
150
82
|
fs.mkdirSync(habitsDir, { recursive: true });
|
|
151
|
-
const
|
|
152
|
-
const
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
"
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
"title: Heartbeat check-in",
|
|
159
|
-
"status: processing",
|
|
160
|
-
`created: ${iso}`,
|
|
161
|
-
`updated: ${iso}`,
|
|
162
|
-
"requester: system",
|
|
163
|
-
"validator: null",
|
|
164
|
-
"cadence: \"30m\"",
|
|
165
|
-
"scheduledAt: null",
|
|
166
|
-
"lastRun: null",
|
|
167
|
-
"---",
|
|
168
|
-
"",
|
|
169
|
-
"Run a lightweight heartbeat cycle. Review task board and inbox.",
|
|
170
|
-
"",
|
|
171
|
-
].join("\n");
|
|
83
|
+
const filePath = path.join(habitsDir, "heartbeat.md");
|
|
84
|
+
const content = (0, habit_parser_1.renderHabitFile)({
|
|
85
|
+
title: "Heartbeat check-in",
|
|
86
|
+
cadence: "30m",
|
|
87
|
+
status: "active",
|
|
88
|
+
created: now.toISOString(),
|
|
89
|
+
}, "Run a lightweight heartbeat cycle. Review task board and inbox.\nCheck on pending obligations. Journal anything important.");
|
|
172
90
|
fs.writeFileSync(filePath, content, "utf-8");
|
|
173
91
|
}
|
|
174
92
|
function writeFriendImprint(bundleRoot, humanName, now) {
|
|
@@ -176,7 +94,7 @@ function writeFriendImprint(bundleRoot, humanName, now) {
|
|
|
176
94
|
fs.mkdirSync(friendsDir, { recursive: true });
|
|
177
95
|
const nowIso = now.toISOString();
|
|
178
96
|
const id = `friend-${(0, config_1.slugify)(humanName) || "friend"}`;
|
|
179
|
-
const localExternalId =
|
|
97
|
+
const localExternalId = os.userInfo().username;
|
|
180
98
|
const record = {
|
|
181
99
|
id,
|
|
182
100
|
name: humanName,
|
|
@@ -200,19 +118,38 @@ function writeFriendImprint(bundleRoot, humanName, now) {
|
|
|
200
118
|
};
|
|
201
119
|
fs.writeFileSync(path.join(friendsDir, `${id}.json`), `${JSON.stringify(record, null, 2)}\n`, "utf-8");
|
|
202
120
|
}
|
|
203
|
-
function
|
|
204
|
-
const
|
|
205
|
-
fs.mkdirSync(path.join(
|
|
206
|
-
fs.mkdirSync(path.join(
|
|
207
|
-
fs.writeFileSync(path.join(
|
|
208
|
-
fs.writeFileSync(path.join(
|
|
121
|
+
function writeDiaryScaffold(bundleRoot) {
|
|
122
|
+
const diaryRoot = path.join(bundleRoot, "diary");
|
|
123
|
+
fs.mkdirSync(path.join(diaryRoot, "daily"), { recursive: true });
|
|
124
|
+
fs.mkdirSync(path.join(diaryRoot, "archive"), { recursive: true });
|
|
125
|
+
fs.writeFileSync(path.join(diaryRoot, "facts.jsonl"), "", "utf-8");
|
|
126
|
+
fs.writeFileSync(path.join(diaryRoot, "entities.json"), "{}\n", "utf-8");
|
|
209
127
|
}
|
|
210
128
|
function writeHatchlingAgentConfig(bundleRoot, input) {
|
|
211
129
|
const template = (0, identity_1.buildDefaultAgentTemplate)(input.agentName);
|
|
130
|
+
const model = (0, provider_models_1.getDefaultModelForProvider)(input.provider);
|
|
212
131
|
template.provider = input.provider;
|
|
132
|
+
template.humanFacing = { provider: input.provider, model };
|
|
133
|
+
template.agentFacing = { provider: input.provider, model };
|
|
213
134
|
template.enabled = true;
|
|
214
135
|
fs.writeFileSync(path.join(bundleRoot, "agent.json"), `${JSON.stringify(template, null, 2)}\n`, "utf-8");
|
|
215
136
|
}
|
|
137
|
+
function writeHatchlingProviderState(bundleRoot, input, now) {
|
|
138
|
+
const model = (0, provider_models_1.getDefaultModelForProvider)(input.provider);
|
|
139
|
+
const machine = (0, machine_identity_1.loadOrCreateMachineIdentity)({
|
|
140
|
+
homeDir: (0, provider_credentials_1.providerCredentialMachineHomeDir)(),
|
|
141
|
+
now: () => now,
|
|
142
|
+
});
|
|
143
|
+
const state = (0, provider_state_1.bootstrapProviderStateFromAgentConfig)({
|
|
144
|
+
machineId: machine.machineId,
|
|
145
|
+
now,
|
|
146
|
+
agentConfig: {
|
|
147
|
+
humanFacing: { provider: input.provider, model },
|
|
148
|
+
agentFacing: { provider: input.provider, model },
|
|
149
|
+
},
|
|
150
|
+
});
|
|
151
|
+
(0, provider_state_1.writeProviderState)(bundleRoot, state);
|
|
152
|
+
}
|
|
216
153
|
async function runHatchFlow(input, deps = {}) {
|
|
217
154
|
(0, runtime_1.emitNervesEvent)({
|
|
218
155
|
component: "daemon",
|
|
@@ -222,7 +159,6 @@ async function runHatchFlow(input, deps = {}) {
|
|
|
222
159
|
});
|
|
223
160
|
validateCredentials(input.provider, input.credentials);
|
|
224
161
|
const bundlesRoot = deps.bundlesRoot ?? path.join(os.homedir(), "AgentBundles");
|
|
225
|
-
const secretsRoot = deps.secretsRoot ?? path.join(os.homedir(), ".agentsecrets");
|
|
226
162
|
const sourceIdentities = deps.specialistIdentitySourceDir ?? (0, hatch_specialist_1.getSpecialistIdentitySourceDir)();
|
|
227
163
|
const targetIdentities = deps.specialistIdentityTargetDir ?? (0, hatch_specialist_1.getRepoSpecialistIdentitiesDir)();
|
|
228
164
|
const now = deps.now ? deps.now() : new Date();
|
|
@@ -235,25 +171,25 @@ async function runHatchFlow(input, deps = {}) {
|
|
|
235
171
|
identitiesDir: targetIdentities,
|
|
236
172
|
random,
|
|
237
173
|
});
|
|
238
|
-
const specialistSecretsPath = writeSecretsFile("AdoptionSpecialist", input.provider, input.credentials, secretsRoot);
|
|
239
|
-
const hatchlingSecretsPath = writeSecretsFile(input.agentName, input.provider, input.credentials, secretsRoot);
|
|
240
174
|
const bundleRoot = path.join(bundlesRoot, `${input.agentName}.ouro`);
|
|
241
175
|
fs.mkdirSync(bundleRoot, { recursive: true });
|
|
242
176
|
writeReadme(bundleRoot, "Root of this agent bundle.");
|
|
243
177
|
writeReadme(path.join(bundleRoot, "psyche"), "Identity and behavior files.");
|
|
244
|
-
writeReadme(path.join(bundleRoot, "
|
|
178
|
+
writeReadme(path.join(bundleRoot, "diary"), "Persistent diary -- things I have learned and chosen to keep.");
|
|
245
179
|
writeReadme(path.join(bundleRoot, "friends"), "Known friend records.");
|
|
246
180
|
writeReadme(path.join(bundleRoot, "tasks"), "Task files.");
|
|
247
|
-
writeReadme(path.join(bundleRoot, "tasks", "habits"), "Recurring tasks.");
|
|
248
181
|
writeReadme(path.join(bundleRoot, "tasks", "one-shots"), "One-shot tasks.");
|
|
249
182
|
writeReadme(path.join(bundleRoot, "tasks", "ongoing"), "Ongoing tasks.");
|
|
183
|
+
writeReadme(path.join(bundleRoot, "habits"), "Recurring habits and autonomous rhythms.");
|
|
250
184
|
writeReadme(path.join(bundleRoot, "skills"), "Local skill files.");
|
|
251
185
|
writeReadme(path.join(bundleRoot, "senses"), "Sense-specific config.");
|
|
252
186
|
writeReadme(path.join(bundleRoot, "senses", "teams"), "Teams sense config.");
|
|
253
187
|
writeHatchlingAgentConfig(bundleRoot, input);
|
|
254
|
-
|
|
188
|
+
const credentialPath = await storeHatchlingProviderCredentials(input.agentName, input.provider, input.credentials);
|
|
189
|
+
writeHatchlingProviderState(bundleRoot, input, now);
|
|
190
|
+
writeDiaryScaffold(bundleRoot);
|
|
255
191
|
writeFriendImprint(bundleRoot, input.humanName, now);
|
|
256
|
-
|
|
192
|
+
writeHeartbeatHabit(bundleRoot, now);
|
|
257
193
|
(0, runtime_1.emitNervesEvent)({
|
|
258
194
|
component: "daemon",
|
|
259
195
|
event: "daemon.hatch_flow_end",
|
|
@@ -263,7 +199,6 @@ async function runHatchFlow(input, deps = {}) {
|
|
|
263
199
|
return {
|
|
264
200
|
bundleRoot,
|
|
265
201
|
selectedIdentity: selected.fileName,
|
|
266
|
-
|
|
267
|
-
hatchlingSecretsPath,
|
|
202
|
+
credentialPath,
|
|
268
203
|
};
|
|
269
204
|
}
|
|
@@ -43,14 +43,14 @@ const path = __importStar(require("path"));
|
|
|
43
43
|
const runtime_1 = require("../../nerves/runtime");
|
|
44
44
|
function getSpecialistIdentitySourceDir() {
|
|
45
45
|
// Prefer ~/AgentBundles/ if it exists (user may have customized identities)
|
|
46
|
-
const userSource = path.join(os.homedir(), "AgentBundles", "
|
|
46
|
+
const userSource = path.join(os.homedir(), "AgentBundles", "SerpentGuide.ouro", "psyche", "identities");
|
|
47
47
|
if (fs.existsSync(userSource))
|
|
48
48
|
return userSource;
|
|
49
49
|
// Fall back to the bundled copy shipped with the npm package
|
|
50
|
-
return path.join(__dirname, "..", "..", "..", "
|
|
50
|
+
return path.join(__dirname, "..", "..", "..", "SerpentGuide.ouro", "psyche", "identities");
|
|
51
51
|
}
|
|
52
52
|
function getRepoSpecialistIdentitiesDir() {
|
|
53
|
-
return path.join(process.cwd(), "
|
|
53
|
+
return path.join(process.cwd(), "SerpentGuide.ouro", "psyche", "identities");
|
|
54
54
|
}
|
|
55
55
|
function listMarkdownIdentityFiles(dir) {
|
|
56
56
|
let entries;
|
|
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.buildSpecialistSystemPrompt = buildSpecialistSystemPrompt;
|
|
4
4
|
const runtime_1 = require("../../nerves/runtime");
|
|
5
5
|
/**
|
|
6
|
-
* Build the
|
|
6
|
+
* Build the serpent guide's system prompt from its components.
|
|
7
7
|
* The prompt is written in first person (the specialist's own voice).
|
|
8
8
|
*/
|
|
9
9
|
function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, context) {
|
|
@@ -31,7 +31,7 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
31
31
|
"I am one of thirteen serpent guides who help humans hatch their first agent. The system randomly selected me for this session.",
|
|
32
32
|
"Most humans only go through this process once, so this is likely the only time they'll meet me.",
|
|
33
33
|
"I make this encounter count — warm, memorable, and uniquely mine.",
|
|
34
|
-
"IMPORTANT: I NEVER refer to myself
|
|
34
|
+
"IMPORTANT: I NEVER refer to myself by internal implementation labels — I introduce myself by my own name from my identity.",
|
|
35
35
|
"",
|
|
36
36
|
"## Voice rules",
|
|
37
37
|
"IMPORTANT: I keep every response to 1-3 short sentences. I sound like a friend texting, not a manual.",
|
|
@@ -44,7 +44,7 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
44
44
|
`Provider: ${context.provider}`,
|
|
45
45
|
`Temp directory: ${context.tempDir}`,
|
|
46
46
|
"Final home: ~/AgentBundles/<Name>.ouro/",
|
|
47
|
-
"
|
|
47
|
+
"Provider credentials: the hatch tool stores them in the agent's vault.",
|
|
48
48
|
].join("\n"));
|
|
49
49
|
sections.push([
|
|
50
50
|
"## Bundle creation guidelines",
|
|
@@ -59,8 +59,10 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
59
59
|
"It also needs an **agent.json** with at minimum:",
|
|
60
60
|
'```json',
|
|
61
61
|
'{',
|
|
62
|
+
' "version": 2,',
|
|
62
63
|
' "name": "AgentName",',
|
|
63
|
-
` "provider": "${context.provider}",`,
|
|
64
|
+
` "humanFacing": { "provider": "${context.provider}", "model": "${context.model}" },`,
|
|
65
|
+
` "agentFacing": { "provider": "${context.provider}", "model": "${context.model}" },`,
|
|
64
66
|
' "enabled": true',
|
|
65
67
|
'}',
|
|
66
68
|
'```',
|
|
@@ -82,18 +84,19 @@ function buildSpecialistSystemPrompt(soulText, identityText, existingBundles, co
|
|
|
82
84
|
"2. I write agent.json to the temp directory using write_file",
|
|
83
85
|
"3. I suggest a PascalCase name for the hatchling and confirm with the human",
|
|
84
86
|
"4. I call complete_adoption with the name and a warm handoff message",
|
|
85
|
-
"5. I call
|
|
87
|
+
"5. I call settle to end the session",
|
|
86
88
|
].join("\n"));
|
|
87
89
|
sections.push([
|
|
88
90
|
"## Tools",
|
|
89
91
|
"- `write_file`: Write a file to disk. Use this to write psyche files and agent.json to the temp directory.",
|
|
90
92
|
"- `read_file`: Read a file from disk. Useful for reviewing existing agent bundles or migration sources.",
|
|
91
93
|
"- `list_directory`: List directory contents. Useful for exploring existing agent bundles.",
|
|
92
|
-
"- I also have the normal local harness tools when useful here, including `shell`, `ouro task create`, `ouro reminder create`,
|
|
93
|
-
"- `complete_adoption`: Finalize the bundle. Validates, scaffolds structural dirs, moves to ~/AgentBundles/, writes secrets, plays hatch animation. I call this with `name` (PascalCase) and `handoff_message` (warm message for the human).",
|
|
94
|
-
"-
|
|
94
|
+
"- I also have the normal local harness tools when useful here, including `shell`, `ouro task create`, `ouro reminder create`, note tools, coding tools, and repo helpers.",
|
|
95
|
+
"- `complete_adoption`: Finalize the bundle. Validates, asks the harness to collect and confirm the hatchling vault unlock secret through hidden terminal prompts, scaffolds structural dirs, moves to ~/AgentBundles/, writes secrets, plays hatch animation. I call this with `name` (PascalCase) and `handoff_message` (warm message for the human).",
|
|
96
|
+
"- The complete_adoption tool triggers hidden terminal prompts for the hatchling vault unlock secret. I must never ask the human to type the vault unlock secret into chat, and I must never include it in tool arguments.",
|
|
97
|
+
"- `settle`: End the conversation with a final message. I call this after complete_adoption succeeds.",
|
|
95
98
|
"",
|
|
96
|
-
"I must call `
|
|
99
|
+
"I must call `settle` when I am done to end the session cleanly.",
|
|
97
100
|
].join("\n"));
|
|
98
101
|
return sections.join("\n\n");
|
|
99
102
|
}
|
|
@@ -35,19 +35,21 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
36
|
exports.getSpecialistTools = getSpecialistTools;
|
|
37
37
|
exports.createSpecialistExecTool = createSpecialistExecTool;
|
|
38
|
-
const crypto = __importStar(require("crypto"));
|
|
39
38
|
const fs = __importStar(require("fs"));
|
|
40
39
|
const path = __importStar(require("path"));
|
|
41
40
|
const tools_base_1 = require("../../repertoire/tools-base");
|
|
42
41
|
const hatch_flow_1 = require("./hatch-flow");
|
|
43
42
|
const hatch_animation_1 = require("./hatch-animation");
|
|
44
43
|
const bundle_manifest_1 = require("../../mind/bundle-manifest");
|
|
44
|
+
const identity_1 = require("../identity");
|
|
45
45
|
const runtime_1 = require("../../nerves/runtime");
|
|
46
|
+
const vault_setup_1 = require("../../repertoire/vault-setup");
|
|
47
|
+
const vault_unlock_1 = require("../../repertoire/vault-unlock");
|
|
46
48
|
const completeAdoptionTool = {
|
|
47
49
|
type: "function",
|
|
48
50
|
function: {
|
|
49
51
|
name: "complete_adoption",
|
|
50
|
-
description: "finalize the agent bundle and hatch the new agent. call this only when you have written all 5 psyche files and agent.json to the temp directory, and the human has approved the bundle.",
|
|
52
|
+
description: "finalize the agent bundle and hatch the new agent. call this only when you have written all 5 psyche files and agent.json to the temp directory, and the human has approved the bundle. tool execution asks the human for the hatchling vault unlock secret through a hidden terminal prompt; do not ask for or include vault unlock secrets in chat or tool args.",
|
|
51
53
|
parameters: {
|
|
52
54
|
type: "object",
|
|
53
55
|
properties: {
|
|
@@ -90,7 +92,7 @@ const listDirToolSchema = {
|
|
|
90
92
|
* Returns the specialist's tool schema array.
|
|
91
93
|
*/
|
|
92
94
|
function getSpecialistTools() {
|
|
93
|
-
return [completeAdoptionTool, tools_base_1.
|
|
95
|
+
return [completeAdoptionTool, tools_base_1.settleTool, readFileTool.tool, writeFileTool.tool, listDirToolSchema];
|
|
94
96
|
}
|
|
95
97
|
const PSYCHE_FILES = ["SOUL.md", "IDENTITY.md", "LORE.md", "TACIT.md", "ASPIRATIONS.md"];
|
|
96
98
|
function isPascalCase(name) {
|
|
@@ -105,21 +107,21 @@ function writeReadme(dir, purpose) {
|
|
|
105
107
|
}
|
|
106
108
|
}
|
|
107
109
|
function scaffoldBundle(bundleRoot) {
|
|
108
|
-
writeReadme(path.join(bundleRoot, "
|
|
109
|
-
writeReadme(path.join(bundleRoot, "
|
|
110
|
-
writeReadme(path.join(bundleRoot, "
|
|
110
|
+
writeReadme(path.join(bundleRoot, "notes"), "Persistent notes store.");
|
|
111
|
+
writeReadme(path.join(bundleRoot, "notes", "daily"), "Daily note entries.");
|
|
112
|
+
writeReadme(path.join(bundleRoot, "notes", "archive"), "Archived notes.");
|
|
111
113
|
writeReadme(path.join(bundleRoot, "friends"), "Known friend records.");
|
|
112
114
|
writeReadme(path.join(bundleRoot, "tasks"), "Task files.");
|
|
113
|
-
writeReadme(path.join(bundleRoot, "tasks", "habits"), "Recurring tasks.");
|
|
114
115
|
writeReadme(path.join(bundleRoot, "tasks", "one-shots"), "One-shot tasks.");
|
|
116
|
+
writeReadme(path.join(bundleRoot, "habits"), "Recurring habits and autonomous rhythms.");
|
|
115
117
|
writeReadme(path.join(bundleRoot, "tasks", "ongoing"), "Ongoing tasks.");
|
|
116
118
|
writeReadme(path.join(bundleRoot, "skills"), "Local skill files.");
|
|
117
119
|
writeReadme(path.join(bundleRoot, "senses"), "Sense-specific config.");
|
|
118
120
|
writeReadme(path.join(bundleRoot, "senses", "teams"), "Teams sense config.");
|
|
119
|
-
//
|
|
120
|
-
const
|
|
121
|
-
const factsPath = path.join(
|
|
122
|
-
const entitiesPath = path.join(
|
|
121
|
+
// Notes scaffold files
|
|
122
|
+
const notesRoot = path.join(bundleRoot, "notes");
|
|
123
|
+
const factsPath = path.join(notesRoot, "facts.jsonl");
|
|
124
|
+
const entitiesPath = path.join(notesRoot, "entities.json");
|
|
123
125
|
/* v8 ignore next -- defensive: guard against re-scaffold on existing bundle @preserve */
|
|
124
126
|
if (!fs.existsSync(factsPath))
|
|
125
127
|
fs.writeFileSync(factsPath, "", "utf-8");
|
|
@@ -166,13 +168,34 @@ async function execCompleteAdoption(args, deps) {
|
|
|
166
168
|
if (fs.existsSync(targetBundle)) {
|
|
167
169
|
return `error: bundle '${name}.ouro' already exists at ${deps.bundlesRoot}. choose a different name.`;
|
|
168
170
|
}
|
|
171
|
+
if (!deps.promptSecret) {
|
|
172
|
+
return "error: complete_adoption requires an interactive vault unlock secret prompt. Re-run `ouro hatch` in a terminal so the human can enter a hatchling vault unlock secret without echoing it.";
|
|
173
|
+
}
|
|
174
|
+
const vault = (0, identity_1.resolveVaultConfig)(name);
|
|
175
|
+
let vaultUnlockSecret;
|
|
176
|
+
try {
|
|
177
|
+
vaultUnlockSecret = await (0, vault_unlock_1.promptConfirmedVaultUnlockSecret)({
|
|
178
|
+
promptSecret: deps.promptSecret,
|
|
179
|
+
question: `Choose Ouro vault unlock secret for ${vault.email}: `,
|
|
180
|
+
confirmQuestion: `Confirm Ouro vault unlock secret for ${vault.email}: `,
|
|
181
|
+
emptyError: "hatchling vault creation requires an unlock secret. Re-run `ouro hatch` in an interactive terminal and enter a human-chosen unlock secret.",
|
|
182
|
+
});
|
|
183
|
+
}
|
|
184
|
+
catch (error) {
|
|
185
|
+
return `error: failed to read hatchling vault unlock secret: ${error instanceof Error ? error.message : /* v8 ignore next -- defensive: non-Error catch branch @preserve */ String(error)}`;
|
|
186
|
+
}
|
|
169
187
|
// Scaffold structural dirs into tempDir
|
|
170
188
|
scaffoldBundle(deps.tempDir);
|
|
171
189
|
// Move tempDir -> final bundle location
|
|
172
190
|
moveDir(deps.tempDir, targetBundle);
|
|
173
191
|
// Write secrets
|
|
174
192
|
try {
|
|
175
|
-
(0,
|
|
193
|
+
const vaultResult = await (0, vault_setup_1.createVaultAccount)(name, vault.serverUrl, vault.email, vaultUnlockSecret);
|
|
194
|
+
if (!vaultResult.success) {
|
|
195
|
+
throw new Error(`failed to create vault: ${vaultResult.error}`);
|
|
196
|
+
}
|
|
197
|
+
(0, vault_unlock_1.storeVaultUnlockSecret)({ agentName: name, email: vault.email, serverUrl: vault.serverUrl }, vaultUnlockSecret);
|
|
198
|
+
await (0, hatch_flow_1.storeHatchlingProviderCredentials)(name, deps.provider, deps.credentials);
|
|
176
199
|
}
|
|
177
200
|
catch (e) {
|
|
178
201
|
// Rollback: remove the moved bundle
|