@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
|
@@ -3,24 +3,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
7
|
-
exports.summarizeTeamsArgs = summarizeTeamsArgs;
|
|
6
|
+
exports.teamsToolDefinitions = void 0;
|
|
8
7
|
const graph_client_1 = require("./graph-client");
|
|
9
8
|
const ado_client_1 = require("./ado-client");
|
|
10
9
|
const graph_endpoints_json_1 = __importDefault(require("./data/graph-endpoints.json"));
|
|
11
10
|
const ado_endpoints_json_1 = __importDefault(require("./data/ado-endpoints.json"));
|
|
12
11
|
const runtime_1 = require("../nerves/runtime");
|
|
13
12
|
const MUTATE_METHODS = ["POST", "PATCH", "DELETE"];
|
|
14
|
-
// Map HTTP method to authority action name for canWrite() checks
|
|
15
|
-
const METHOD_TO_ACTION = {
|
|
16
|
-
POST: "createWorkItem",
|
|
17
|
-
PATCH: "updateWorkItem",
|
|
18
|
-
DELETE: "deleteWorkItem",
|
|
19
|
-
};
|
|
20
|
-
// Check if a tool response indicates a 403 PERMISSION_DENIED (authority checker removed; this is now a no-op kept for call-site stability)
|
|
21
|
-
function checkAndRecord403(_result, _integration, _scope, _action, _ctx) {
|
|
22
|
-
// No-op: AuthorityChecker eliminated. 403 recording removed.
|
|
23
|
-
}
|
|
24
13
|
const DEFAULT_ADO_QUERY = "SELECT [System.Id], [System.Title], [System.State], [System.AssignedTo] FROM WorkItems WHERE [System.AssignedTo] = @Me AND [System.State] <> 'Closed' ORDER BY [System.ChangedDate] DESC";
|
|
25
14
|
exports.teamsToolDefinitions = [
|
|
26
15
|
// -- Generic Graph tools --
|
|
@@ -46,6 +35,7 @@ exports.teamsToolDefinitions = [
|
|
|
46
35
|
return (0, graph_client_1.graphRequest)(ctx.graphToken, "GET", args.path);
|
|
47
36
|
},
|
|
48
37
|
integration: "graph",
|
|
38
|
+
summaryKeys: ["path"],
|
|
49
39
|
},
|
|
50
40
|
{
|
|
51
41
|
tool: {
|
|
@@ -74,7 +64,7 @@ exports.teamsToolDefinitions = [
|
|
|
74
64
|
return (0, graph_client_1.graphRequest)(ctx.graphToken, args.method, args.path, args.body);
|
|
75
65
|
},
|
|
76
66
|
integration: "graph",
|
|
77
|
-
|
|
67
|
+
summaryKeys: ["method", "path"],
|
|
78
68
|
},
|
|
79
69
|
// -- Generic ADO tools --
|
|
80
70
|
{
|
|
@@ -82,7 +72,7 @@ exports.teamsToolDefinitions = [
|
|
|
82
72
|
type: "function",
|
|
83
73
|
function: {
|
|
84
74
|
name: "ado_query",
|
|
85
|
-
description: "GET or POST (for WIQL read queries) any Azure DevOps API endpoint. Use ado_docs first to look up the correct path.",
|
|
75
|
+
description: "GET or POST (for WIQL read queries) any Azure DevOps API endpoint. Use ado_docs first to look up the correct path and host.",
|
|
86
76
|
parameters: {
|
|
87
77
|
type: "object",
|
|
88
78
|
properties: {
|
|
@@ -90,6 +80,7 @@ exports.teamsToolDefinitions = [
|
|
|
90
80
|
path: { type: "string", description: "ADO API path after /{org}, e.g. /_apis/wit/wiql" },
|
|
91
81
|
method: { type: "string", enum: ["GET", "POST"], description: "HTTP method (defaults to GET)" },
|
|
92
82
|
body: { type: "string", description: "JSON request body (optional, used with POST for WIQL)" },
|
|
83
|
+
host: { type: "string", description: "API host override for non-standard APIs (e.g. 'vsapm.dev.azure.com' for entitlements, 'vssps.dev.azure.com' for users). Omit for standard dev.azure.com." },
|
|
93
84
|
},
|
|
94
85
|
required: ["organization", "path"],
|
|
95
86
|
},
|
|
@@ -100,18 +91,17 @@ exports.teamsToolDefinitions = [
|
|
|
100
91
|
return "AUTH_REQUIRED:ado -- I need access to Azure DevOps. Please sign in when prompted.";
|
|
101
92
|
}
|
|
102
93
|
const method = args.method || "GET";
|
|
103
|
-
|
|
104
|
-
checkAndRecord403(result, "ado", args.organization, method, ctx);
|
|
105
|
-
return result;
|
|
94
|
+
return (0, ado_client_1.adoRequest)(ctx.adoToken, method, args.organization, args.path, args.body, args.host);
|
|
106
95
|
},
|
|
107
96
|
integration: "ado",
|
|
97
|
+
summaryKeys: ["method", "organization", "path"],
|
|
108
98
|
},
|
|
109
99
|
{
|
|
110
100
|
tool: {
|
|
111
101
|
type: "function",
|
|
112
102
|
function: {
|
|
113
103
|
name: "ado_mutate",
|
|
114
|
-
description: "POST/PATCH/DELETE any Azure DevOps API endpoint for actual mutations. Use ado_docs first to look up the correct path.",
|
|
104
|
+
description: "POST/PATCH/DELETE any Azure DevOps API endpoint for actual mutations. Use ado_docs first to look up the correct path and host.",
|
|
115
105
|
parameters: {
|
|
116
106
|
type: "object",
|
|
117
107
|
properties: {
|
|
@@ -119,6 +109,7 @@ exports.teamsToolDefinitions = [
|
|
|
119
109
|
organization: { type: "string", description: "Azure DevOps organization name" },
|
|
120
110
|
path: { type: "string", description: "ADO API path after /{org}" },
|
|
121
111
|
body: { type: "string", description: "JSON request body (optional)" },
|
|
112
|
+
host: { type: "string", description: "API host override for non-standard APIs (e.g. 'vsapm.dev.azure.com' for entitlements, 'vssps.dev.azure.com' for users). Omit for standard dev.azure.com." },
|
|
122
113
|
},
|
|
123
114
|
required: ["method", "organization", "path"],
|
|
124
115
|
},
|
|
@@ -131,14 +122,10 @@ exports.teamsToolDefinitions = [
|
|
|
131
122
|
if (!MUTATE_METHODS.includes(args.method)) {
|
|
132
123
|
return `Invalid method "${args.method}". Must be one of: ${MUTATE_METHODS.join(", ")}`;
|
|
133
124
|
}
|
|
134
|
-
|
|
135
|
-
const action = METHOD_TO_ACTION[args.method] || args.method;
|
|
136
|
-
const result = await (0, ado_client_1.adoRequest)(ctx.adoToken, args.method, args.organization, args.path, args.body);
|
|
137
|
-
checkAndRecord403(result, "ado", args.organization, action, ctx);
|
|
138
|
-
return result;
|
|
125
|
+
return (0, ado_client_1.adoRequest)(ctx.adoToken, args.method, args.organization, args.path, args.body, args.host);
|
|
139
126
|
},
|
|
140
127
|
integration: "ado",
|
|
141
|
-
|
|
128
|
+
summaryKeys: ["method", "organization", "path"],
|
|
142
129
|
},
|
|
143
130
|
// -- Convenience aliases (backward compat) --
|
|
144
131
|
{
|
|
@@ -157,6 +144,7 @@ exports.teamsToolDefinitions = [
|
|
|
157
144
|
return (0, graph_client_1.getProfile)(ctx.graphToken);
|
|
158
145
|
},
|
|
159
146
|
integration: "graph",
|
|
147
|
+
summaryKeys: [],
|
|
160
148
|
},
|
|
161
149
|
{
|
|
162
150
|
tool: {
|
|
@@ -200,6 +188,54 @@ exports.teamsToolDefinitions = [
|
|
|
200
188
|
return (0, ado_client_1.queryWorkItems)(ctx.adoToken, org, query);
|
|
201
189
|
},
|
|
202
190
|
integration: "ado",
|
|
191
|
+
summaryKeys: ["organization", "query"],
|
|
192
|
+
},
|
|
193
|
+
// -- Proactive messaging --
|
|
194
|
+
{
|
|
195
|
+
tool: {
|
|
196
|
+
type: "function",
|
|
197
|
+
function: {
|
|
198
|
+
name: "teams_send_message",
|
|
199
|
+
description: "send a proactive 1:1 Teams message to a user. requires their AAD object ID (use graph_query /users to find it). the message appears as coming from the bot.",
|
|
200
|
+
parameters: {
|
|
201
|
+
type: "object",
|
|
202
|
+
properties: {
|
|
203
|
+
user_id: { type: "string", description: "AAD object ID of the user to message" },
|
|
204
|
+
user_name: { type: "string", description: "display name of the user (for logging)" },
|
|
205
|
+
message: { type: "string", description: "message text to send" },
|
|
206
|
+
tenant_id: { type: "string", description: "tenant ID (optional, defaults to current conversation tenant)" },
|
|
207
|
+
},
|
|
208
|
+
required: ["user_id", "message"],
|
|
209
|
+
},
|
|
210
|
+
},
|
|
211
|
+
},
|
|
212
|
+
/* v8 ignore start -- proactive messaging requires live Teams SDK conversation client @preserve */
|
|
213
|
+
handler: async (args, ctx) => {
|
|
214
|
+
if (!ctx?.botApi) {
|
|
215
|
+
return "proactive messaging is not available -- no bot API context (this tool only works in the Teams channel)";
|
|
216
|
+
}
|
|
217
|
+
try {
|
|
218
|
+
const tenantId = args.tenant_id || ctx.tenantId;
|
|
219
|
+
// Cast to the SDK's ConversationClient shape (kept as `unknown` in ToolContext to avoid type coupling)
|
|
220
|
+
const conversations = ctx.botApi.conversations;
|
|
221
|
+
const conversation = await conversations.create({
|
|
222
|
+
bot: { id: ctx.botApi.id },
|
|
223
|
+
members: [{ id: args.user_id, role: "user", name: args.user_name || args.user_id }],
|
|
224
|
+
tenantId,
|
|
225
|
+
isGroup: false,
|
|
226
|
+
});
|
|
227
|
+
await conversations.activities(conversation.id).create({
|
|
228
|
+
type: "message",
|
|
229
|
+
text: args.message,
|
|
230
|
+
});
|
|
231
|
+
return `message sent to ${args.user_name || args.user_id}`;
|
|
232
|
+
}
|
|
233
|
+
catch (e) {
|
|
234
|
+
return `failed to send proactive message: ${e instanceof Error ? e.message : String(e)}`;
|
|
235
|
+
}
|
|
236
|
+
},
|
|
237
|
+
/* v8 ignore stop */
|
|
238
|
+
summaryKeys: ["user_name", "user_id"],
|
|
203
239
|
},
|
|
204
240
|
// -- Documentation tools --
|
|
205
241
|
{
|
|
@@ -221,6 +257,7 @@ exports.teamsToolDefinitions = [
|
|
|
221
257
|
return searchEndpoints(graph_endpoints_json_1.default, args.query || "");
|
|
222
258
|
},
|
|
223
259
|
integration: "graph",
|
|
260
|
+
summaryKeys: ["query"],
|
|
224
261
|
},
|
|
225
262
|
{
|
|
226
263
|
tool: {
|
|
@@ -241,12 +278,9 @@ exports.teamsToolDefinitions = [
|
|
|
241
278
|
return searchEndpoints(ado_endpoints_json_1.default, args.query || "");
|
|
242
279
|
},
|
|
243
280
|
integration: "ado",
|
|
281
|
+
summaryKeys: ["query"],
|
|
244
282
|
},
|
|
245
283
|
];
|
|
246
|
-
// Backward-compat: extract just the OpenAI tool schemas
|
|
247
|
-
exports.teamsTools = exports.teamsToolDefinitions.map((d) => d.tool);
|
|
248
|
-
// Backward-compat: extract just the handlers by name
|
|
249
|
-
exports.teamsToolHandlers = Object.fromEntries(exports.teamsToolDefinitions.map((d) => [d.tool.function.name, d.handler]));
|
|
250
284
|
function searchEndpoints(entries, query) {
|
|
251
285
|
(0, runtime_1.emitNervesEvent)({
|
|
252
286
|
component: "repertoire",
|
|
@@ -268,41 +302,10 @@ function searchEndpoints(entries, query) {
|
|
|
268
302
|
` ${e.description}`,
|
|
269
303
|
` Params: ${e.params || "none"}`,
|
|
270
304
|
];
|
|
305
|
+
if (e.host)
|
|
306
|
+
lines.push(` Host: ${e.host}`);
|
|
271
307
|
if (e.scopes)
|
|
272
308
|
lines.push(` Scopes: ${e.scopes}`);
|
|
273
309
|
return lines.join("\n");
|
|
274
310
|
}).join("\n\n");
|
|
275
311
|
}
|
|
276
|
-
function summarizeTeamsArgs(name, args) {
|
|
277
|
-
function summarizeKeyValues(keys) {
|
|
278
|
-
const parts = [];
|
|
279
|
-
for (const key of keys) {
|
|
280
|
-
const raw = args[key];
|
|
281
|
-
if (raw === undefined || raw === null)
|
|
282
|
-
continue;
|
|
283
|
-
const compact = String(raw).replace(/\s+/g, " ").trim();
|
|
284
|
-
if (!compact)
|
|
285
|
-
continue;
|
|
286
|
-
const clipped = compact.length > 60 ? compact.slice(0, 60) + "..." : compact;
|
|
287
|
-
parts.push(`${key}=${clipped}`);
|
|
288
|
-
}
|
|
289
|
-
return parts.join(" ");
|
|
290
|
-
}
|
|
291
|
-
if (name === "graph_profile")
|
|
292
|
-
return "";
|
|
293
|
-
if (name === "ado_work_items")
|
|
294
|
-
return summarizeKeyValues(["organization", "query"]);
|
|
295
|
-
if (name === "graph_query")
|
|
296
|
-
return summarizeKeyValues(["path"]);
|
|
297
|
-
if (name === "graph_mutate")
|
|
298
|
-
return summarizeKeyValues(["method", "path"]);
|
|
299
|
-
if (name === "ado_query")
|
|
300
|
-
return summarizeKeyValues(["method", "organization", "path"]);
|
|
301
|
-
if (name === "ado_mutate")
|
|
302
|
-
return summarizeKeyValues(["method", "organization", "path"]);
|
|
303
|
-
if (name === "graph_docs")
|
|
304
|
-
return summarizeKeyValues(["query"]);
|
|
305
|
-
if (name === "ado_docs")
|
|
306
|
-
return summarizeKeyValues(["query"]);
|
|
307
|
-
return undefined;
|
|
308
|
-
}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.travelToolDefinitions = void 0;
|
|
4
|
+
const travel_api_client_1 = require("./travel-api-client");
|
|
5
|
+
const runtime_1 = require("../nerves/runtime");
|
|
6
|
+
exports.travelToolDefinitions = [
|
|
7
|
+
{
|
|
8
|
+
tool: {
|
|
9
|
+
type: "function",
|
|
10
|
+
function: {
|
|
11
|
+
name: "weather_lookup",
|
|
12
|
+
description: "Get current weather for a location. Provide either a city name or lat/lon coordinates.",
|
|
13
|
+
parameters: {
|
|
14
|
+
type: "object",
|
|
15
|
+
properties: {
|
|
16
|
+
city: { type: "string", description: "City name (e.g. 'London', 'New York')" },
|
|
17
|
+
lat: { type: "string", description: "Latitude (decimal)" },
|
|
18
|
+
lon: { type: "string", description: "Longitude (decimal)" },
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
handler: async (args) => {
|
|
24
|
+
(0, runtime_1.emitNervesEvent)({
|
|
25
|
+
component: "repertoire",
|
|
26
|
+
event: "repertoire.travel_tool_call",
|
|
27
|
+
message: "weather_lookup invoked",
|
|
28
|
+
meta: { tool: "weather_lookup" },
|
|
29
|
+
});
|
|
30
|
+
try {
|
|
31
|
+
if (args.city) {
|
|
32
|
+
const data = await (0, travel_api_client_1.getWeatherByCity)(args.city);
|
|
33
|
+
return JSON.stringify(data, null, 2);
|
|
34
|
+
}
|
|
35
|
+
if (args.lat && args.lon) {
|
|
36
|
+
const data = await (0, travel_api_client_1.getWeather)(parseFloat(args.lat), parseFloat(args.lon));
|
|
37
|
+
return JSON.stringify(data, null, 2);
|
|
38
|
+
}
|
|
39
|
+
return "Please provide either a city name or lat/lon coordinates.";
|
|
40
|
+
}
|
|
41
|
+
catch (err) {
|
|
42
|
+
/* v8 ignore next -- defensive: callers throw Error instances @preserve */
|
|
43
|
+
return `Weather lookup error: ${err instanceof Error ? err.message : String(err)}`;
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
summaryKeys: ["city", "lat", "lon"],
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
tool: {
|
|
50
|
+
type: "function",
|
|
51
|
+
function: {
|
|
52
|
+
name: "travel_advisory",
|
|
53
|
+
description: "Get US State Department travel advisory for a country. Returns advisory level (1-4) and description.",
|
|
54
|
+
parameters: {
|
|
55
|
+
type: "object",
|
|
56
|
+
properties: {
|
|
57
|
+
country_code: {
|
|
58
|
+
type: "string",
|
|
59
|
+
description: "ISO 3166 alpha-2 country code (e.g. 'US', 'GB', 'AF')",
|
|
60
|
+
},
|
|
61
|
+
},
|
|
62
|
+
required: ["country_code"],
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
handler: async (args) => {
|
|
67
|
+
(0, runtime_1.emitNervesEvent)({
|
|
68
|
+
component: "repertoire",
|
|
69
|
+
event: "repertoire.travel_tool_call",
|
|
70
|
+
message: "travel_advisory invoked",
|
|
71
|
+
meta: { tool: "travel_advisory" },
|
|
72
|
+
});
|
|
73
|
+
try {
|
|
74
|
+
const data = await (0, travel_api_client_1.getTravelAdvisory)(args.country_code.toUpperCase());
|
|
75
|
+
return JSON.stringify(data, null, 2);
|
|
76
|
+
}
|
|
77
|
+
catch (err) {
|
|
78
|
+
/* v8 ignore next -- defensive: callers throw Error instances @preserve */
|
|
79
|
+
return `Travel advisory error: ${err instanceof Error ? err.message : String(err)}`;
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
summaryKeys: ["country_code"],
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
tool: {
|
|
86
|
+
type: "function",
|
|
87
|
+
function: {
|
|
88
|
+
name: "geocode_search",
|
|
89
|
+
description: "Search for locations, addresses, or points of interest. Returns coordinates and display names.",
|
|
90
|
+
parameters: {
|
|
91
|
+
type: "object",
|
|
92
|
+
properties: {
|
|
93
|
+
query: { type: "string", description: "Search query (e.g. 'Eiffel Tower', '123 Main St')" },
|
|
94
|
+
near_lat: { type: "string", description: "Latitude to search near (for POI search)" },
|
|
95
|
+
near_lon: { type: "string", description: "Longitude to search near (for POI search)" },
|
|
96
|
+
radius_km: { type: "string", description: "Search radius in km (default 10)" },
|
|
97
|
+
},
|
|
98
|
+
required: ["query"],
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
},
|
|
102
|
+
handler: async (args) => {
|
|
103
|
+
(0, runtime_1.emitNervesEvent)({
|
|
104
|
+
component: "repertoire",
|
|
105
|
+
event: "repertoire.travel_tool_call",
|
|
106
|
+
message: "geocode_search invoked",
|
|
107
|
+
meta: { tool: "geocode_search" },
|
|
108
|
+
});
|
|
109
|
+
try {
|
|
110
|
+
if (args.near_lat && args.near_lon) {
|
|
111
|
+
const radiusKm = args.radius_km ? parseFloat(args.radius_km) : undefined;
|
|
112
|
+
const data = await (0, travel_api_client_1.searchPOI)(args.query, parseFloat(args.near_lat), parseFloat(args.near_lon), radiusKm);
|
|
113
|
+
return JSON.stringify(data, null, 2);
|
|
114
|
+
}
|
|
115
|
+
const data = await (0, travel_api_client_1.geocode)(args.query);
|
|
116
|
+
return JSON.stringify(data, null, 2);
|
|
117
|
+
}
|
|
118
|
+
catch (err) {
|
|
119
|
+
/* v8 ignore next -- defensive: callers throw Error instances @preserve */
|
|
120
|
+
return `Geocode error: ${err instanceof Error ? err.message : String(err)}`;
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
summaryKeys: ["query"],
|
|
124
|
+
},
|
|
125
|
+
];
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.userProfileToolDefinitions = void 0;
|
|
4
|
+
const user_profile_1 = require("./user-profile");
|
|
5
|
+
const credential_access_1 = require("./credential-access");
|
|
6
|
+
const runtime_1 = require("../nerves/runtime");
|
|
7
|
+
function requireFamilyContext(ctx) {
|
|
8
|
+
if (!ctx?.context?.friend?.id) {
|
|
9
|
+
return "no friend context — cannot access user profile.";
|
|
10
|
+
}
|
|
11
|
+
if (ctx.context.friend.trustLevel !== "family") {
|
|
12
|
+
return "user profile access requires family trust level.";
|
|
13
|
+
}
|
|
14
|
+
return { friendId: ctx.context.friend.id };
|
|
15
|
+
}
|
|
16
|
+
exports.userProfileToolDefinitions = [
|
|
17
|
+
{
|
|
18
|
+
tool: {
|
|
19
|
+
type: "function",
|
|
20
|
+
function: {
|
|
21
|
+
name: "user_profile_store",
|
|
22
|
+
description: "Store or update user profile fields (legal name, DOB, passport, etc.) in the agent's vault. Fields are merged with any existing profile. Requires family trust level.",
|
|
23
|
+
parameters: {
|
|
24
|
+
type: "object",
|
|
25
|
+
properties: {
|
|
26
|
+
fields: {
|
|
27
|
+
type: "string",
|
|
28
|
+
description: 'JSON object with profile fields to store/update. Keys: legalName, dateOfBirth, gender, nationality, passport, driverLicense, email, phone, addresses, loyaltyPrograms, preferences, emergencyContact.',
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
required: ["fields"],
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
handler: async (args, ctx) => {
|
|
36
|
+
(0, runtime_1.emitNervesEvent)({
|
|
37
|
+
component: "repertoire",
|
|
38
|
+
event: "repertoire.tool_user_profile_store",
|
|
39
|
+
message: "user_profile_store invoked",
|
|
40
|
+
meta: { tool: "user_profile_store" },
|
|
41
|
+
});
|
|
42
|
+
const guard = requireFamilyContext(ctx);
|
|
43
|
+
if (typeof guard === "string")
|
|
44
|
+
return guard;
|
|
45
|
+
let fields;
|
|
46
|
+
try {
|
|
47
|
+
fields = JSON.parse(args.fields);
|
|
48
|
+
}
|
|
49
|
+
catch {
|
|
50
|
+
return "invalid JSON in fields parameter.";
|
|
51
|
+
}
|
|
52
|
+
try {
|
|
53
|
+
const store = (0, credential_access_1.getCredentialStore)();
|
|
54
|
+
await (0, user_profile_1.updateUserProfileFields)(guard.friendId, fields, store);
|
|
55
|
+
return `profile fields stored for ${guard.friendId}.`;
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
/* v8 ignore next -- defensive: updateUserProfileFields errors are always Error instances @preserve */
|
|
59
|
+
return `failed to store profile: ${err instanceof Error ? err.message : String(err)}`;
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
summaryKeys: ["fields"],
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
tool: {
|
|
66
|
+
type: "function",
|
|
67
|
+
function: {
|
|
68
|
+
name: "user_profile_get",
|
|
69
|
+
description: "Retrieve a specific field from a user's profile. Only returns the requested field, never the full profile. Requires family trust level.",
|
|
70
|
+
parameters: {
|
|
71
|
+
type: "object",
|
|
72
|
+
properties: {
|
|
73
|
+
field: {
|
|
74
|
+
type: "string",
|
|
75
|
+
description: "The profile field to retrieve: legalName, dateOfBirth, gender, nationality, passport, driverLicense, email, phone, addresses, loyaltyPrograms, preferences, emergencyContact.",
|
|
76
|
+
},
|
|
77
|
+
},
|
|
78
|
+
required: ["field"],
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
},
|
|
82
|
+
handler: async (args, ctx) => {
|
|
83
|
+
(0, runtime_1.emitNervesEvent)({
|
|
84
|
+
component: "repertoire",
|
|
85
|
+
event: "repertoire.tool_user_profile_get",
|
|
86
|
+
message: "user_profile_get invoked",
|
|
87
|
+
meta: { tool: "user_profile_get", field: args.field },
|
|
88
|
+
});
|
|
89
|
+
const guard = requireFamilyContext(ctx);
|
|
90
|
+
if (typeof guard === "string")
|
|
91
|
+
return guard;
|
|
92
|
+
try {
|
|
93
|
+
const store = (0, credential_access_1.getCredentialStore)();
|
|
94
|
+
const value = await (0, user_profile_1.getUserProfileField)(guard.friendId, args.field, store);
|
|
95
|
+
if (value === undefined) {
|
|
96
|
+
return `field "${args.field}" is not set on the profile.`;
|
|
97
|
+
}
|
|
98
|
+
/* v8 ignore next -- platform-dependent v8 branch counting on ternary @preserve */
|
|
99
|
+
return typeof value === "string" ? value : JSON.stringify(value, null, 2);
|
|
100
|
+
}
|
|
101
|
+
catch (err) {
|
|
102
|
+
/* v8 ignore next -- defensive: getUserProfileField errors are always Error instances @preserve */
|
|
103
|
+
return `failed to get profile field: ${err instanceof Error ? err.message : String(err)}`;
|
|
104
|
+
}
|
|
105
|
+
},
|
|
106
|
+
summaryKeys: ["field"],
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
tool: {
|
|
110
|
+
type: "function",
|
|
111
|
+
function: {
|
|
112
|
+
name: "user_profile_delete",
|
|
113
|
+
description: "Delete a user's entire profile from the vault. This is irreversible. Requires family trust level.",
|
|
114
|
+
parameters: {
|
|
115
|
+
type: "object",
|
|
116
|
+
properties: {},
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
},
|
|
120
|
+
handler: async (_args, ctx) => {
|
|
121
|
+
(0, runtime_1.emitNervesEvent)({
|
|
122
|
+
component: "repertoire",
|
|
123
|
+
event: "repertoire.tool_user_profile_delete",
|
|
124
|
+
message: "user_profile_delete invoked",
|
|
125
|
+
meta: { tool: "user_profile_delete" },
|
|
126
|
+
});
|
|
127
|
+
const guard = requireFamilyContext(ctx);
|
|
128
|
+
if (typeof guard === "string")
|
|
129
|
+
return guard;
|
|
130
|
+
try {
|
|
131
|
+
const store = (0, credential_access_1.getCredentialStore)();
|
|
132
|
+
const deleted = await (0, user_profile_1.deleteUserProfile)(guard.friendId, store);
|
|
133
|
+
return deleted
|
|
134
|
+
? `profile deleted for ${guard.friendId}.`
|
|
135
|
+
: `no profile found for ${guard.friendId}.`;
|
|
136
|
+
}
|
|
137
|
+
catch (err) {
|
|
138
|
+
/* v8 ignore next -- defensive: deleteUserProfile errors are always Error instances @preserve */
|
|
139
|
+
return `failed to delete profile: ${err instanceof Error ? err.message : String(err)}`;
|
|
140
|
+
}
|
|
141
|
+
},
|
|
142
|
+
summaryKeys: [],
|
|
143
|
+
},
|
|
144
|
+
];
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.vaultToolDefinitions = void 0;
|
|
4
|
+
const identity_1 = require("../heart/identity");
|
|
5
|
+
const runtime_1 = require("../nerves/runtime");
|
|
6
|
+
exports.vaultToolDefinitions = [
|
|
7
|
+
{
|
|
8
|
+
tool: {
|
|
9
|
+
type: "function",
|
|
10
|
+
function: {
|
|
11
|
+
name: "vault_setup",
|
|
12
|
+
description: "Set up the agent's credential vault. Creates a Bitwarden account on the configured Vaultwarden server. One-time operation — idempotent if vault already exists.",
|
|
13
|
+
parameters: {
|
|
14
|
+
type: "object",
|
|
15
|
+
properties: {},
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
handler: async () => {
|
|
20
|
+
const agentName = (0, identity_1.getAgentName)();
|
|
21
|
+
(0, runtime_1.emitNervesEvent)({
|
|
22
|
+
component: "repertoire",
|
|
23
|
+
event: "repertoire.vault_tool_call",
|
|
24
|
+
message: "vault_setup invoked",
|
|
25
|
+
meta: { tool: "vault_setup", agentName },
|
|
26
|
+
});
|
|
27
|
+
return [
|
|
28
|
+
"Vault setup is human-required.",
|
|
29
|
+
"",
|
|
30
|
+
"Why I cannot do it here:",
|
|
31
|
+
" Creating or unlocking a vault requires secret entry that must stay out of agent context.",
|
|
32
|
+
"",
|
|
33
|
+
"Do this in a terminal:",
|
|
34
|
+
` ouro vault create --agent ${agentName}`,
|
|
35
|
+
` ouro vault unlock --agent ${agentName}`,
|
|
36
|
+
].join("\n");
|
|
37
|
+
},
|
|
38
|
+
summaryKeys: [],
|
|
39
|
+
},
|
|
40
|
+
];
|