@ouro.bot/cli 0.1.0-alpha.37 → 0.1.0-alpha.371
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 +106 -14
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +3 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +1 -1
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/changelog.json +2230 -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 +37 -2
- 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 +378 -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 +107 -61
- package/dist/heart/core.js +803 -259
- package/dist/heart/cross-chat-delivery.js +131 -0
- package/dist/heart/daemon/agent-config-check.js +382 -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 +205 -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 +538 -0
- package/dist/heart/daemon/cli-exec.js +3114 -0
- package/dist/heart/daemon/cli-help.js +312 -0
- package/dist/heart/daemon/cli-parse.js +1023 -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 -1171
- 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 +157 -12
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +757 -58
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +445 -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/inner-status.js +89 -0
- package/dist/heart/daemon/interactive-repair.js +148 -0
- package/dist/heart/daemon/launchd.js +46 -9
- 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 +1 -1
- package/dist/heart/daemon/process-manager.js +201 -0
- package/dist/heart/daemon/provider-discovery.js +113 -0
- package/dist/heart/daemon/pulse.js +475 -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 +101 -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 +72 -3
- 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/{daemon → hatch}/hatch-flow.js +55 -126
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +11 -8
- package/dist/heart/{daemon → hatch}/specialist-tools.js +77 -11
- package/dist/heart/identity.js +154 -59
- 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 +379 -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 +180 -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 +39 -29
- 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 +362 -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 +301 -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 +12 -2
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- package/dist/mind/bundle-manifest.js +7 -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 +14 -1
- package/dist/mind/friends/channel.js +56 -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 +9 -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 +74 -7
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +1030 -118
- 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 +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/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-LwChZTgL.css +1 -0
- package/dist/outlook-ui/assets/index-xTdv64BV.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 +365 -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 +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 +107 -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 +375 -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 -771
- 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 +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 +12 -62
- 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 -138
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +118 -0
- package/dist/repertoire/vault-setup.js +241 -0
- package/dist/repertoire/vault-unlock.js +359 -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} +260 -9
- package/dist/senses/bluebubbles/entry.js +13 -0
- package/dist/senses/bluebubbles/inbound-log.js +113 -0
- 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} +43 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +46 -6
- package/dist/senses/bluebubbles/replay.js +129 -0
- package/dist/senses/bluebubbles/runtime-state.js +109 -0
- 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 +1 -1
- package/dist/senses/cli-layout.js +187 -0
- package/dist/senses/cli.js +588 -250
- 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.js +693 -160
- package/dist/senses/trust-gate.js +112 -2
- package/package.json +29 -7
- 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 +138 -0
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/daemon/subagent-installer.js +0 -134
- package/dist/mind/associative-recall.js +0 -197
- package/dist/senses/bluebubbles-entry.js +0 -11
- package/dist/senses/bluebubbles.js +0 -558
- package/dist/senses/debug-activity.js +0 -127
- package/subagents/README.md +0 -60
- package/subagents/work-doer.md +0 -235
- package/subagents/work-merger.md +0 -618
- package/subagents/work-planner.md +0 -382
- /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
|
@@ -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
|
{
|
|
@@ -101,11 +91,10 @@ exports.teamsToolDefinitions = [
|
|
|
101
91
|
return "AUTH_REQUIRED:ado -- I need access to Azure DevOps. Please sign in when prompted.";
|
|
102
92
|
}
|
|
103
93
|
const method = args.method || "GET";
|
|
104
|
-
|
|
105
|
-
checkAndRecord403(result, "ado", args.organization, method, ctx);
|
|
106
|
-
return result;
|
|
94
|
+
return (0, ado_client_1.adoRequest)(ctx.adoToken, method, args.organization, args.path, args.body, args.host);
|
|
107
95
|
},
|
|
108
96
|
integration: "ado",
|
|
97
|
+
summaryKeys: ["method", "organization", "path"],
|
|
109
98
|
},
|
|
110
99
|
{
|
|
111
100
|
tool: {
|
|
@@ -133,14 +122,10 @@ exports.teamsToolDefinitions = [
|
|
|
133
122
|
if (!MUTATE_METHODS.includes(args.method)) {
|
|
134
123
|
return `Invalid method "${args.method}". Must be one of: ${MUTATE_METHODS.join(", ")}`;
|
|
135
124
|
}
|
|
136
|
-
|
|
137
|
-
const action = METHOD_TO_ACTION[args.method] || args.method;
|
|
138
|
-
const result = await (0, ado_client_1.adoRequest)(ctx.adoToken, args.method, args.organization, args.path, args.body, args.host);
|
|
139
|
-
checkAndRecord403(result, "ado", args.organization, action, ctx);
|
|
140
|
-
return result;
|
|
125
|
+
return (0, ado_client_1.adoRequest)(ctx.adoToken, args.method, args.organization, args.path, args.body, args.host);
|
|
141
126
|
},
|
|
142
127
|
integration: "ado",
|
|
143
|
-
|
|
128
|
+
summaryKeys: ["method", "organization", "path"],
|
|
144
129
|
},
|
|
145
130
|
// -- Convenience aliases (backward compat) --
|
|
146
131
|
{
|
|
@@ -159,6 +144,7 @@ exports.teamsToolDefinitions = [
|
|
|
159
144
|
return (0, graph_client_1.getProfile)(ctx.graphToken);
|
|
160
145
|
},
|
|
161
146
|
integration: "graph",
|
|
147
|
+
summaryKeys: [],
|
|
162
148
|
},
|
|
163
149
|
{
|
|
164
150
|
tool: {
|
|
@@ -202,6 +188,7 @@ exports.teamsToolDefinitions = [
|
|
|
202
188
|
return (0, ado_client_1.queryWorkItems)(ctx.adoToken, org, query);
|
|
203
189
|
},
|
|
204
190
|
integration: "ado",
|
|
191
|
+
summaryKeys: ["organization", "query"],
|
|
205
192
|
},
|
|
206
193
|
// -- Proactive messaging --
|
|
207
194
|
{
|
|
@@ -248,7 +235,7 @@ exports.teamsToolDefinitions = [
|
|
|
248
235
|
}
|
|
249
236
|
},
|
|
250
237
|
/* v8 ignore stop */
|
|
251
|
-
|
|
238
|
+
summaryKeys: ["user_name", "user_id"],
|
|
252
239
|
},
|
|
253
240
|
// -- Documentation tools --
|
|
254
241
|
{
|
|
@@ -270,6 +257,7 @@ exports.teamsToolDefinitions = [
|
|
|
270
257
|
return searchEndpoints(graph_endpoints_json_1.default, args.query || "");
|
|
271
258
|
},
|
|
272
259
|
integration: "graph",
|
|
260
|
+
summaryKeys: ["query"],
|
|
273
261
|
},
|
|
274
262
|
{
|
|
275
263
|
tool: {
|
|
@@ -290,12 +278,9 @@ exports.teamsToolDefinitions = [
|
|
|
290
278
|
return searchEndpoints(ado_endpoints_json_1.default, args.query || "");
|
|
291
279
|
},
|
|
292
280
|
integration: "ado",
|
|
281
|
+
summaryKeys: ["query"],
|
|
293
282
|
},
|
|
294
283
|
];
|
|
295
|
-
// Backward-compat: extract just the OpenAI tool schemas
|
|
296
|
-
exports.teamsTools = exports.teamsToolDefinitions.map((d) => d.tool);
|
|
297
|
-
// Backward-compat: extract just the handlers by name
|
|
298
|
-
exports.teamsToolHandlers = Object.fromEntries(exports.teamsToolDefinitions.map((d) => [d.tool.function.name, d.handler]));
|
|
299
284
|
function searchEndpoints(entries, query) {
|
|
300
285
|
(0, runtime_1.emitNervesEvent)({
|
|
301
286
|
component: "repertoire",
|
|
@@ -324,38 +309,3 @@ function searchEndpoints(entries, query) {
|
|
|
324
309
|
return lines.join("\n");
|
|
325
310
|
}).join("\n\n");
|
|
326
311
|
}
|
|
327
|
-
function summarizeTeamsArgs(name, args) {
|
|
328
|
-
function summarizeKeyValues(keys) {
|
|
329
|
-
const parts = [];
|
|
330
|
-
for (const key of keys) {
|
|
331
|
-
const raw = args[key];
|
|
332
|
-
if (raw === undefined || raw === null)
|
|
333
|
-
continue;
|
|
334
|
-
const compact = String(raw).replace(/\s+/g, " ").trim();
|
|
335
|
-
if (!compact)
|
|
336
|
-
continue;
|
|
337
|
-
const clipped = compact.length > 60 ? compact.slice(0, 60) + "..." : compact;
|
|
338
|
-
parts.push(`${key}=${clipped}`);
|
|
339
|
-
}
|
|
340
|
-
return parts.join(" ");
|
|
341
|
-
}
|
|
342
|
-
if (name === "graph_profile")
|
|
343
|
-
return "";
|
|
344
|
-
if (name === "ado_work_items")
|
|
345
|
-
return summarizeKeyValues(["organization", "query"]);
|
|
346
|
-
if (name === "graph_query")
|
|
347
|
-
return summarizeKeyValues(["path"]);
|
|
348
|
-
if (name === "graph_mutate")
|
|
349
|
-
return summarizeKeyValues(["method", "path"]);
|
|
350
|
-
if (name === "ado_query")
|
|
351
|
-
return summarizeKeyValues(["method", "organization", "path"]);
|
|
352
|
-
if (name === "ado_mutate")
|
|
353
|
-
return summarizeKeyValues(["method", "organization", "path"]);
|
|
354
|
-
if (name === "graph_docs")
|
|
355
|
-
return summarizeKeyValues(["query"]);
|
|
356
|
-
if (name === "ado_docs")
|
|
357
|
-
return summarizeKeyValues(["query"]);
|
|
358
|
-
if (name === "teams_send_message")
|
|
359
|
-
return summarizeKeyValues(["user_name", "user_id"]);
|
|
360
|
-
return undefined;
|
|
361
|
-
}
|
|
@@ -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
|
+
];
|