@ouro.bot/cli 0.1.0-alpha.35 → 0.1.0-alpha.351
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 +188 -187
- 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 +2098 -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 +463 -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 +53 -21
- package/dist/heart/core.js +744 -252
- package/dist/heart/cross-chat-delivery.js +131 -0
- package/dist/heart/daemon/agent-config-check.js +561 -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 +170 -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 +591 -0
- package/dist/heart/daemon/cli-exec.js +2633 -0
- package/dist/heart/daemon/cli-help.js +306 -0
- package/dist/heart/daemon/cli-parse.js +913 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +512 -0
- package/dist/heart/daemon/cli-types.js +8 -0
- package/dist/heart/daemon/daemon-cli.js +30 -1171
- package/dist/heart/daemon/daemon-entry.js +358 -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 +751 -58
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +465 -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 +91 -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 +105 -0
- package/dist/heart/daemon/pulse.js +463 -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 +52 -120
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +3 -3
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +10 -7
- package/dist/heart/{daemon → hatch}/specialist-tools.js +56 -10
- 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 +127 -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 +194 -0
- package/dist/heart/outlook/readers/agent-machine.js +355 -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 +231 -0
- package/dist/heart/outlook/readers/shared.js +111 -0
- package/dist/heart/progress-story.js +42 -0
- package/dist/heart/provider-attempt.js +133 -0
- package/dist/heart/provider-binding-resolver.js +240 -0
- package/dist/heart/provider-credential-pool.js +395 -0
- package/dist/heart/provider-failover.js +135 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +258 -0
- package/dist/heart/provider-state.js +208 -0
- package/dist/heart/providers/anthropic-token.js +163 -0
- package/dist/heart/providers/anthropic.js +171 -50
- package/dist/heart/providers/azure.js +97 -11
- package/dist/heart/providers/error-classification.js +63 -0
- package/dist/heart/providers/github-copilot.js +135 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +23 -6
- package/dist/heart/providers/openai-codex.js +33 -23
- package/dist/heart/session-activity.js +190 -0
- package/dist/heart/session-events.js +727 -0
- package/dist/heart/session-transcript.js +162 -0
- package/dist/heart/start-of-turn-packet.js +341 -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 +358 -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 +296 -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 +140 -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.js +1001 -112
- 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 +319 -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 +527 -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 +316 -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 +110 -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/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} +225 -9
- package/dist/senses/bluebubbles/entry.js +13 -0
- package/dist/senses/bluebubbles/inbound-log.js +113 -0
- package/dist/senses/bluebubbles/index.js +1616 -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 +603 -246
- package/dist/senses/commands.js +65 -1
- 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 +633 -86
- package/dist/senses/pipeline.js +567 -0
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +199 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams.js +690 -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 +81 -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 -548
- package/dist/senses/debug-activity.js +0 -127
- package/subagents/README.md +0 -73
- 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
package/dist/repertoire/tools.js
CHANGED
|
@@ -1,56 +1,52 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
3
|
+
exports.surfaceToolDef = exports.restTool = exports.ponderTool = exports.observeTool = exports.settleTool = exports.tools = void 0;
|
|
4
|
+
exports.resetMcpDefinitions = resetMcpDefinitions;
|
|
4
5
|
exports.getToolsForChannel = getToolsForChannel;
|
|
5
|
-
exports.isConfirmationRequired = isConfirmationRequired;
|
|
6
6
|
exports.execTool = execTool;
|
|
7
7
|
exports.summarizeArgs = summarizeArgs;
|
|
8
|
+
exports.buildToolResultSummary = buildToolResultSummary;
|
|
8
9
|
const tools_base_1 = require("./tools-base");
|
|
9
10
|
const tools_teams_1 = require("./tools-teams");
|
|
10
11
|
const tools_bluebubbles_1 = require("./tools-bluebubbles");
|
|
11
12
|
const ado_semantic_1 = require("./ado-semantic");
|
|
12
13
|
const tools_github_1 = require("./tools-github");
|
|
14
|
+
const tools_bundle_1 = require("./tools-bundle");
|
|
13
15
|
const runtime_1 = require("../nerves/runtime");
|
|
16
|
+
const guardrails_1 = require("./guardrails");
|
|
17
|
+
const identity_1 = require("../heart/identity");
|
|
18
|
+
const tools_surface_1 = require("./tools-surface");
|
|
19
|
+
const mcp_tools_1 = require("./mcp-tools");
|
|
20
|
+
function safeGetAgentRoot() {
|
|
21
|
+
try {
|
|
22
|
+
return (0, identity_1.getAgentRoot)();
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
return undefined;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
14
28
|
// Re-export types and constants used by the rest of the codebase
|
|
15
29
|
var tools_base_2 = require("./tools-base");
|
|
16
30
|
Object.defineProperty(exports, "tools", { enumerable: true, get: function () { return tools_base_2.tools; } });
|
|
17
|
-
Object.defineProperty(exports, "
|
|
18
|
-
|
|
19
|
-
Object.defineProperty(exports, "
|
|
31
|
+
Object.defineProperty(exports, "settleTool", { enumerable: true, get: function () { return tools_base_2.settleTool; } });
|
|
32
|
+
Object.defineProperty(exports, "observeTool", { enumerable: true, get: function () { return tools_base_2.observeTool; } });
|
|
33
|
+
Object.defineProperty(exports, "ponderTool", { enumerable: true, get: function () { return tools_base_2.ponderTool; } });
|
|
34
|
+
Object.defineProperty(exports, "restTool", { enumerable: true, get: function () { return tools_base_2.restTool; } });
|
|
35
|
+
// Re-export surface tool schema for consumers (e.g. heart/core.ts)
|
|
36
|
+
var tools_surface_2 = require("./tools-surface");
|
|
37
|
+
Object.defineProperty(exports, "surfaceToolDef", { enumerable: true, get: function () { return tools_surface_2.surfaceToolDef; } });
|
|
20
38
|
// All tool definitions in a single registry
|
|
21
|
-
const allDefinitions = [
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
];
|
|
28
|
-
const REMOTE_BLOCKED_LOCAL_TOOLS = new Set(["shell", "read_file", "write_file", "git_commit", "gh_cli"]);
|
|
29
|
-
function isRemoteChannel(capabilities) {
|
|
30
|
-
return capabilities?.channel === "teams" || capabilities?.channel === "bluebubbles";
|
|
31
|
-
}
|
|
32
|
-
function isSharedRemoteContext(friend) {
|
|
33
|
-
const externalIds = friend.externalIds ?? [];
|
|
34
|
-
return externalIds.some((externalId) => externalId.externalId.startsWith("group:") || externalId.provider === "teams-conversation");
|
|
39
|
+
const allDefinitions = [...tools_base_1.baseToolDefinitions, ...tools_bluebubbles_1.bluebubblesToolDefinitions, ...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions, ...tools_bundle_1.bundleToolDefinitions, tools_surface_1.surfaceToolDefinition];
|
|
40
|
+
// MCP tool definitions — populated each time getToolsForChannel() is called with an mcpManager.
|
|
41
|
+
// Kept separate from allDefinitions so execTool can find them.
|
|
42
|
+
let mcpDefinitions = [];
|
|
43
|
+
/** Exported for testing — reset the MCP definitions cache. */
|
|
44
|
+
function resetMcpDefinitions() {
|
|
45
|
+
mcpDefinitions = [];
|
|
35
46
|
}
|
|
36
|
-
function
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const trustLevel = context.friend.trustLevel ?? "stranger";
|
|
40
|
-
return trustLevel !== "stranger" && !isSharedRemoteContext(context.friend);
|
|
41
|
-
}
|
|
42
|
-
function shouldBlockLocalTools(capabilities, context) {
|
|
43
|
-
if (!isRemoteChannel(capabilities))
|
|
44
|
-
return false;
|
|
45
|
-
return !isTrustedRemoteContext(context);
|
|
46
|
-
}
|
|
47
|
-
function blockedLocalToolMessage() {
|
|
48
|
-
return "I can't do that from here because I'm talking to multiple people in a shared remote channel, and local shell/file/git/gh operations could let conversations interfere with each other. Ask me for a remote-safe alternative (Graph/ADO/web), or run that operation from CLI.";
|
|
49
|
-
}
|
|
50
|
-
function baseToolsForCapabilities(capabilities, context) {
|
|
51
|
-
if (!shouldBlockLocalTools(capabilities, context))
|
|
52
|
-
return tools_base_1.tools;
|
|
53
|
-
return tools_base_1.tools.filter((tool) => !REMOTE_BLOCKED_LOCAL_TOOLS.has(tool.function.name));
|
|
47
|
+
function baseToolsForCapabilities() {
|
|
48
|
+
// Use baseToolDefinitions at call time so dynamically-added tools are included
|
|
49
|
+
return tools_base_1.baseToolDefinitions.map((d) => d.tool);
|
|
54
50
|
}
|
|
55
51
|
// Apply a single tool preference to a tool schema, returning a new object.
|
|
56
52
|
function applyPreference(tool, pref) {
|
|
@@ -62,53 +58,79 @@ function applyPreference(tool, pref) {
|
|
|
62
58
|
},
|
|
63
59
|
};
|
|
64
60
|
}
|
|
61
|
+
// Filter out tools whose requiredCapability is not in the provider's capability set.
|
|
62
|
+
// Uses baseToolDefinitions at call time so dynamically-added tools are included.
|
|
63
|
+
// Only base tools can have requiredCapability (integration tools do not).
|
|
64
|
+
function filterByCapability(toolList, providerCapabilities) {
|
|
65
|
+
return toolList.filter((tool) => {
|
|
66
|
+
const def = tools_base_1.baseToolDefinitions.find((d) => d.tool.function.name === tool.function.name);
|
|
67
|
+
if (!def?.requiredCapability)
|
|
68
|
+
return true;
|
|
69
|
+
return providerCapabilities?.has(def.requiredCapability) === true;
|
|
70
|
+
});
|
|
71
|
+
}
|
|
65
72
|
// Return the appropriate tools list based on channel capabilities.
|
|
66
73
|
// Base tools (no integration) are always included.
|
|
67
74
|
// Teams/integration tools are included only if their integration is in availableIntegrations.
|
|
68
75
|
// When toolPreferences is provided, matching preferences are appended to tool descriptions.
|
|
69
|
-
|
|
70
|
-
|
|
76
|
+
// When providerCapabilities is provided, tools with requiredCapability are filtered.
|
|
77
|
+
function getToolsForChannel(capabilities, toolPreferences, _context, providerCapabilities, mcpManager, _chatModel) {
|
|
78
|
+
const baseTools = baseToolsForCapabilities();
|
|
71
79
|
const bluebubblesTools = capabilities?.channel === "bluebubbles"
|
|
72
80
|
? tools_bluebubbles_1.bluebubblesToolDefinitions.map((d) => d.tool)
|
|
73
81
|
: [];
|
|
82
|
+
let result;
|
|
74
83
|
if (!capabilities || capabilities.availableIntegrations.length === 0) {
|
|
75
|
-
|
|
84
|
+
result = [...baseTools, ...bluebubblesTools];
|
|
76
85
|
}
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
86
|
+
else {
|
|
87
|
+
const available = new Set(capabilities.availableIntegrations);
|
|
88
|
+
const channelDefs = [...tools_teams_1.teamsToolDefinitions, ...ado_semantic_1.adoSemanticToolDefinitions, ...tools_github_1.githubToolDefinitions];
|
|
89
|
+
// Include tools whose integration is available, plus channel tools with no integration gate (e.g. teams_send_message)
|
|
90
|
+
const integrationDefs = channelDefs.filter((d) => d.integration ? available.has(d.integration) : capabilities.channel === "teams");
|
|
91
|
+
if (!toolPreferences || Object.keys(toolPreferences).length === 0) {
|
|
92
|
+
result = [...baseTools, ...bluebubblesTools, ...integrationDefs.map((d) => d.tool)];
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
// Build a map of integration -> preference text for fast lookup
|
|
96
|
+
const prefMap = new Map();
|
|
97
|
+
for (const [key, value] of Object.entries(toolPreferences)) {
|
|
98
|
+
prefMap.set(key, value);
|
|
99
|
+
}
|
|
100
|
+
// Apply preferences to matching integration tools (new objects, no mutation)
|
|
101
|
+
// d.integration is guaranteed truthy -- integrationDefs are pre-filtered above
|
|
102
|
+
const enrichedIntegrationTools = integrationDefs.map((d) => {
|
|
103
|
+
const pref = prefMap.get(d.integration);
|
|
104
|
+
return pref ? applyPreference(d.tool, pref) : d.tool;
|
|
105
|
+
});
|
|
106
|
+
result = [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
|
|
107
|
+
}
|
|
83
108
|
}
|
|
84
|
-
//
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
109
|
+
// Append first-class MCP tools when mcpManager is provided
|
|
110
|
+
if (mcpManager) {
|
|
111
|
+
mcpDefinitions = (0, mcp_tools_1.mcpToolsAsDefinitions)(mcpManager);
|
|
112
|
+
const mcpSchemas = mcpDefinitions.map((d) => d.tool);
|
|
113
|
+
result = [...result, ...mcpSchemas];
|
|
88
114
|
}
|
|
89
|
-
|
|
90
|
-
// d.integration is guaranteed truthy -- integrationDefs are pre-filtered above
|
|
91
|
-
const enrichedIntegrationTools = integrationDefs.map((d) => {
|
|
92
|
-
const pref = prefMap.get(d.integration);
|
|
93
|
-
return pref ? applyPreference(d.tool, pref) : d.tool;
|
|
94
|
-
});
|
|
95
|
-
return [...baseTools, ...bluebubblesTools, ...enrichedIntegrationTools];
|
|
115
|
+
return filterByCapability(result, providerCapabilities);
|
|
96
116
|
}
|
|
97
|
-
//
|
|
98
|
-
|
|
99
|
-
function
|
|
100
|
-
|
|
101
|
-
|
|
117
|
+
// Look up a tool definition from the combined registry (native + MCP).
|
|
118
|
+
function findDefinition(toolName) {
|
|
119
|
+
return allDefinitions.find((d) => d.tool.function.name === toolName)
|
|
120
|
+
?? mcpDefinitions.find((d) => d.tool.function.name === toolName);
|
|
121
|
+
}
|
|
122
|
+
function normalizeGuardArgs(_name, args) {
|
|
123
|
+
return args;
|
|
102
124
|
}
|
|
103
125
|
async function execTool(name, args, ctx) {
|
|
104
126
|
(0, runtime_1.emitNervesEvent)({
|
|
105
127
|
event: "tool.start",
|
|
106
128
|
component: "tools",
|
|
107
129
|
message: "tool execution started",
|
|
108
|
-
meta: { name },
|
|
130
|
+
meta: { name, ...(name === "shell" && args.command ? { command: args.command } : {}) },
|
|
109
131
|
});
|
|
110
|
-
// Look up from combined registry
|
|
111
|
-
const def =
|
|
132
|
+
// Look up from combined registry (native + MCP)
|
|
133
|
+
const def = findDefinition(name);
|
|
112
134
|
if (!def) {
|
|
113
135
|
(0, runtime_1.emitNervesEvent)({
|
|
114
136
|
level: "error",
|
|
@@ -119,16 +141,26 @@ async function execTool(name, args, ctx) {
|
|
|
119
141
|
});
|
|
120
142
|
return `unknown: ${name}`;
|
|
121
143
|
}
|
|
122
|
-
|
|
123
|
-
|
|
144
|
+
// Guardrail check: structural + trust-level
|
|
145
|
+
const mcpDef = mcpDefinitions.find((d) => d.tool.function.name === name);
|
|
146
|
+
const guardContext = {
|
|
147
|
+
readPaths: tools_base_1.editFileReadTracker,
|
|
148
|
+
trustLevel: ctx?.context?.friend?.trustLevel,
|
|
149
|
+
agentRoot: safeGetAgentRoot(),
|
|
150
|
+
...(mcpDef?.mcpServer ? { mcpServerName: mcpDef.mcpServer } : {}),
|
|
151
|
+
...(ctx?.context?.isGroupChat !== undefined ? { isGroupChat: (ctx?.context).isGroupChat } : {}),
|
|
152
|
+
};
|
|
153
|
+
const guardArgs = normalizeGuardArgs(name, args);
|
|
154
|
+
const guardResult = (0, guardrails_1.guardInvocation)(name, guardArgs, guardContext);
|
|
155
|
+
if (!guardResult.allowed) {
|
|
124
156
|
(0, runtime_1.emitNervesEvent)({
|
|
125
157
|
level: "warn",
|
|
126
|
-
event: "tool.
|
|
158
|
+
event: "tool.guardrail_block",
|
|
127
159
|
component: "tools",
|
|
128
|
-
message: "blocked
|
|
129
|
-
meta: { name,
|
|
160
|
+
message: "guardrail blocked tool execution",
|
|
161
|
+
meta: { name, reason: guardResult.reason },
|
|
130
162
|
});
|
|
131
|
-
return
|
|
163
|
+
return guardResult.reason;
|
|
132
164
|
}
|
|
133
165
|
try {
|
|
134
166
|
const result = await def.handler(args, ctx);
|
|
@@ -172,73 +204,47 @@ function summarizeUnknownArgs(args) {
|
|
|
172
204
|
return summarizeKeyValues(args, keys);
|
|
173
205
|
}
|
|
174
206
|
function summarizeArgs(name, args) {
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
return teamsSummary;
|
|
179
|
-
// Check github tools
|
|
180
|
-
const githubSummary = (0, tools_github_1.summarizeGithubArgs)(name, args);
|
|
181
|
-
if (githubSummary !== undefined)
|
|
182
|
-
return githubSummary;
|
|
183
|
-
// Base tools
|
|
184
|
-
if (name === "read_file" || name === "write_file")
|
|
185
|
-
return summarizeKeyValues(args, ["path"]);
|
|
186
|
-
if (name === "shell")
|
|
187
|
-
return summarizeKeyValues(args, ["command"]);
|
|
188
|
-
if (name === "list_directory")
|
|
189
|
-
return summarizeKeyValues(args, ["path"]);
|
|
190
|
-
if (name === "git_commit")
|
|
191
|
-
return summarizeKeyValues(args, ["message"]);
|
|
192
|
-
if (name === "gh_cli")
|
|
193
|
-
return summarizeKeyValues(args, ["command"]);
|
|
194
|
-
if (name === "load_skill")
|
|
195
|
-
return summarizeKeyValues(args, ["name"]);
|
|
196
|
-
if (name === "task_create")
|
|
197
|
-
return summarizeKeyValues(args, ["title", "type", "category", "scheduledAt", "cadence"]);
|
|
198
|
-
if (name === "schedule_reminder")
|
|
199
|
-
return summarizeKeyValues(args, ["title", "scheduledAt", "cadence"]);
|
|
200
|
-
if (name === "task_update_status")
|
|
201
|
-
return summarizeKeyValues(args, ["name", "status"]);
|
|
202
|
-
if (name === "task_board_status")
|
|
203
|
-
return summarizeKeyValues(args, ["status"]);
|
|
204
|
-
if (name === "task_board_action")
|
|
205
|
-
return summarizeKeyValues(args, ["scope"]);
|
|
206
|
-
if (name === "task_board" || name === "task_board_deps" || name === "task_board_sessions")
|
|
207
|
-
return "";
|
|
208
|
-
if (name === "coding_spawn")
|
|
209
|
-
return summarizeKeyValues(args, ["runner", "workdir", "taskRef"]);
|
|
210
|
-
if (name === "coding_status")
|
|
211
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
212
|
-
if (name === "coding_tail")
|
|
213
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
214
|
-
if (name === "coding_send_input")
|
|
215
|
-
return summarizeKeyValues(args, ["sessionId", "input"]);
|
|
216
|
-
if (name === "coding_kill")
|
|
217
|
-
return summarizeKeyValues(args, ["sessionId"]);
|
|
218
|
-
if (name === "bluebubbles_set_reply_target")
|
|
219
|
-
return summarizeKeyValues(args, ["target", "threadOriginatorGuid"]);
|
|
220
|
-
if (name === "claude")
|
|
221
|
-
return summarizeKeyValues(args, ["prompt"]);
|
|
222
|
-
if (name === "web_search")
|
|
223
|
-
return summarizeKeyValues(args, ["query"]);
|
|
224
|
-
if (name === "memory_search")
|
|
225
|
-
return summarizeKeyValues(args, ["query"]);
|
|
226
|
-
if (name === "memory_save")
|
|
227
|
-
return summarizeKeyValues(args, ["text", "about"]);
|
|
228
|
-
if (name === "get_friend_note")
|
|
229
|
-
return summarizeKeyValues(args, ["friendId"]);
|
|
230
|
-
if (name === "save_friend_note") {
|
|
231
|
-
return summarizeKeyValues(args, ["type", "key", "content"]);
|
|
207
|
+
const def = findDefinition(name);
|
|
208
|
+
if (def && def.summaryKeys !== undefined) {
|
|
209
|
+
return summarizeKeyValues(args, def.summaryKeys);
|
|
232
210
|
}
|
|
233
|
-
if (name === "ado_backlog_list")
|
|
234
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
235
|
-
if (name === "ado_batch_update")
|
|
236
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
237
|
-
if (name === "ado_create_epic" || name === "ado_create_issue")
|
|
238
|
-
return summarizeKeyValues(args, ["organization", "project", "title"]);
|
|
239
|
-
if (name === "ado_move_items")
|
|
240
|
-
return summarizeKeyValues(args, ["organization", "project", "workItemIds"]);
|
|
241
|
-
if (name === "ado_restructure_backlog")
|
|
242
|
-
return summarizeKeyValues(args, ["organization", "project"]);
|
|
243
211
|
return summarizeUnknownArgs(args);
|
|
244
212
|
}
|
|
213
|
+
/**
|
|
214
|
+
* Build an enriched tool result summary for display on remote channels.
|
|
215
|
+
* For recognized tools, includes result-derived info (diff stats, exit codes, etc.).
|
|
216
|
+
* Falls back to arg-based summary for unrecognized tools.
|
|
217
|
+
*/
|
|
218
|
+
function buildToolResultSummary(name, args, _result, success) {
|
|
219
|
+
/* v8 ignore start -- branches: ?? fallbacks and ternaries in tool summary formatting @preserve */
|
|
220
|
+
switch (name) {
|
|
221
|
+
case "edit_file": {
|
|
222
|
+
if (!success)
|
|
223
|
+
return summarizeArgs(name, args);
|
|
224
|
+
const addedLines = (args.new_string ?? "").split("\n").length;
|
|
225
|
+
const removedLines = (args.old_string ?? "").split("\n").length;
|
|
226
|
+
return `+${addedLines} -${removedLines} lines in ${args.path ?? "unknown"}`;
|
|
227
|
+
}
|
|
228
|
+
case "shell": {
|
|
229
|
+
const cmd = args.command ?? "?";
|
|
230
|
+
const exitCode = success ? 0 : 1;
|
|
231
|
+
return `$ ${cmd} (exit ${exitCode})`;
|
|
232
|
+
}
|
|
233
|
+
case "read_file":
|
|
234
|
+
return `path=${args.path ?? "unknown"}`;
|
|
235
|
+
case "write_file":
|
|
236
|
+
return `path=${args.path ?? "unknown"}`;
|
|
237
|
+
case "glob":
|
|
238
|
+
return `pattern=${args.pattern ?? "?"} ${args.cwd ? `cwd=${args.cwd}` : ""}`.trim();
|
|
239
|
+
case "grep":
|
|
240
|
+
return `pattern=${args.pattern ?? "?"} ${args.path ? `path=${args.path}` : ""}`.trim();
|
|
241
|
+
case "coding_spawn": {
|
|
242
|
+
const taskRef = args.taskRef ?? "unknown";
|
|
243
|
+
const status = success ? "spawned" : "failed";
|
|
244
|
+
return `${taskRef} -> ${status}`;
|
|
245
|
+
}
|
|
246
|
+
default:
|
|
247
|
+
return summarizeArgs(name, args);
|
|
248
|
+
}
|
|
249
|
+
/* v8 ignore stop */
|
|
250
|
+
}
|