@agent-native/core 0.52.0 → 0.53.0
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 +41 -95
- package/blueprints/action/crud.md +98 -0
- package/blueprints/channel/discord.md +74 -0
- package/blueprints/provider/stripe.md +87 -0
- package/blueprints/sandbox/docker.md +78 -0
- package/dist/action.d.ts +24 -0
- package/dist/action.d.ts.map +1 -1
- package/dist/action.js +4 -0
- package/dist/action.js.map +1 -1
- package/dist/agent/observational-memory/compactor.d.ts +43 -0
- package/dist/agent/observational-memory/compactor.d.ts.map +1 -0
- package/dist/agent/observational-memory/compactor.js +50 -0
- package/dist/agent/observational-memory/compactor.js.map +1 -0
- package/dist/agent/observational-memory/config.d.ts +37 -0
- package/dist/agent/observational-memory/config.d.ts.map +1 -0
- package/dist/agent/observational-memory/config.js +48 -0
- package/dist/agent/observational-memory/config.js.map +1 -0
- package/dist/agent/observational-memory/index.d.ts +26 -0
- package/dist/agent/observational-memory/index.d.ts.map +1 -0
- package/dist/agent/observational-memory/index.js +25 -0
- package/dist/agent/observational-memory/index.js.map +1 -0
- package/dist/agent/observational-memory/internal-run.d.ts +37 -0
- package/dist/agent/observational-memory/internal-run.d.ts.map +1 -0
- package/dist/agent/observational-memory/internal-run.js +59 -0
- package/dist/agent/observational-memory/internal-run.js.map +1 -0
- package/dist/agent/observational-memory/message-text.d.ts +13 -0
- package/dist/agent/observational-memory/message-text.d.ts.map +1 -0
- package/dist/agent/observational-memory/message-text.js +46 -0
- package/dist/agent/observational-memory/message-text.js.map +1 -0
- package/dist/agent/observational-memory/migrations.d.ts +13 -0
- package/dist/agent/observational-memory/migrations.d.ts.map +1 -0
- package/dist/agent/observational-memory/migrations.js +43 -0
- package/dist/agent/observational-memory/migrations.js.map +1 -0
- package/dist/agent/observational-memory/observer.d.ts +37 -0
- package/dist/agent/observational-memory/observer.d.ts.map +1 -0
- package/dist/agent/observational-memory/observer.js +82 -0
- package/dist/agent/observational-memory/observer.js.map +1 -0
- package/dist/agent/observational-memory/plugin.d.ts +16 -0
- package/dist/agent/observational-memory/plugin.d.ts.map +1 -0
- package/dist/agent/observational-memory/plugin.js +26 -0
- package/dist/agent/observational-memory/plugin.js.map +1 -0
- package/dist/agent/observational-memory/prompts.d.ts +27 -0
- package/dist/agent/observational-memory/prompts.d.ts.map +1 -0
- package/dist/agent/observational-memory/prompts.js +42 -0
- package/dist/agent/observational-memory/prompts.js.map +1 -0
- package/dist/agent/observational-memory/read.d.ts +47 -0
- package/dist/agent/observational-memory/read.d.ts.map +1 -0
- package/dist/agent/observational-memory/read.js +99 -0
- package/dist/agent/observational-memory/read.js.map +1 -0
- package/dist/agent/observational-memory/reflector.d.ts +31 -0
- package/dist/agent/observational-memory/reflector.d.ts.map +1 -0
- package/dist/agent/observational-memory/reflector.js +76 -0
- package/dist/agent/observational-memory/reflector.js.map +1 -0
- package/dist/agent/observational-memory/schema.d.ts +267 -0
- package/dist/agent/observational-memory/schema.d.ts.map +1 -0
- package/dist/agent/observational-memory/schema.js +48 -0
- package/dist/agent/observational-memory/schema.js.map +1 -0
- package/dist/agent/observational-memory/store.d.ts +52 -0
- package/dist/agent/observational-memory/store.d.ts.map +1 -0
- package/dist/agent/observational-memory/store.js +197 -0
- package/dist/agent/observational-memory/store.js.map +1 -0
- package/dist/agent/observational-memory/types.d.ts +61 -0
- package/dist/agent/observational-memory/types.d.ts.map +1 -0
- package/dist/agent/observational-memory/types.js +9 -0
- package/dist/agent/observational-memory/types.js.map +1 -0
- package/dist/agent/production-agent.d.ts +15 -0
- package/dist/agent/production-agent.d.ts.map +1 -1
- package/dist/agent/production-agent.js +240 -1
- package/dist/agent/production-agent.js.map +1 -1
- package/dist/agent/run-loop-with-resume.d.ts.map +1 -1
- package/dist/agent/run-loop-with-resume.js +49 -0
- package/dist/agent/run-loop-with-resume.js.map +1 -1
- package/dist/agent/run-store.d.ts +17 -0
- package/dist/agent/run-store.d.ts.map +1 -1
- package/dist/agent/run-store.js +55 -0
- package/dist/agent/run-store.js.map +1 -1
- package/dist/agent/runtime-context.d.ts +30 -0
- package/dist/agent/runtime-context.d.ts.map +1 -1
- package/dist/agent/runtime-context.js +54 -1
- package/dist/agent/runtime-context.js.map +1 -1
- package/dist/agent/tool-call-journal.d.ts +101 -0
- package/dist/agent/tool-call-journal.d.ts.map +1 -0
- package/dist/agent/tool-call-journal.js +214 -0
- package/dist/agent/tool-call-journal.js.map +1 -0
- package/dist/agent/types.d.ts +24 -0
- package/dist/agent/types.d.ts.map +1 -1
- package/dist/agent/types.js.map +1 -1
- package/dist/cli/add.d.ts +109 -0
- package/dist/cli/add.d.ts.map +1 -0
- package/dist/cli/add.js +352 -0
- package/dist/cli/add.js.map +1 -0
- package/dist/cli/connect.d.ts +2 -2
- package/dist/cli/connect.d.ts.map +1 -1
- package/dist/cli/connect.js +92 -24
- package/dist/cli/connect.js.map +1 -1
- package/dist/cli/eval.d.ts +17 -0
- package/dist/cli/eval.d.ts.map +1 -0
- package/dist/cli/eval.js +121 -0
- package/dist/cli/eval.js.map +1 -0
- package/dist/cli/index.js +44 -3
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/mcp.d.ts.map +1 -1
- package/dist/cli/mcp.js +11 -5
- package/dist/cli/mcp.js.map +1 -1
- package/dist/cli/plan-local.d.ts +66 -5
- package/dist/cli/plan-local.d.ts.map +1 -1
- package/dist/cli/plan-local.js +495 -19
- package/dist/cli/plan-local.js.map +1 -1
- package/dist/cli/skills.d.ts +2 -2
- package/dist/cli/skills.d.ts.map +1 -1
- package/dist/cli/skills.js +70 -59
- package/dist/cli/skills.js.map +1 -1
- package/dist/client/AssistantChat.d.ts.map +1 -1
- package/dist/client/AssistantChat.js +118 -92
- package/dist/client/AssistantChat.js.map +1 -1
- package/dist/client/agent-chat-adapter.d.ts.map +1 -1
- package/dist/client/agent-chat-adapter.js +16 -0
- package/dist/client/agent-chat-adapter.js.map +1 -1
- package/dist/client/chat/tool-call-display.d.ts +20 -1
- package/dist/client/chat/tool-call-display.d.ts.map +1 -1
- package/dist/client/chat/tool-call-display.js +32 -7
- package/dist/client/chat/tool-call-display.js.map +1 -1
- package/dist/client/sse-event-processor.d.ts +13 -0
- package/dist/client/sse-event-processor.d.ts.map +1 -1
- package/dist/client/sse-event-processor.js +21 -0
- package/dist/client/sse-event-processor.js.map +1 -1
- package/dist/db/client.d.ts +4 -2
- package/dist/db/client.d.ts.map +1 -1
- package/dist/db/client.js +6 -4
- package/dist/db/client.js.map +1 -1
- package/dist/deploy/route-discovery.d.ts.map +1 -1
- package/dist/deploy/route-discovery.js +1 -0
- package/dist/deploy/route-discovery.js.map +1 -1
- package/dist/eval/agent-runner.d.ts +63 -0
- package/dist/eval/agent-runner.d.ts.map +1 -0
- package/dist/eval/agent-runner.js +142 -0
- package/dist/eval/agent-runner.js.map +1 -0
- package/dist/eval/define-eval.d.ts +29 -0
- package/dist/eval/define-eval.d.ts.map +1 -0
- package/dist/eval/define-eval.js +43 -0
- package/dist/eval/define-eval.js.map +1 -0
- package/dist/eval/index.d.ts +18 -0
- package/dist/eval/index.d.ts.map +1 -0
- package/dist/eval/index.js +17 -0
- package/dist/eval/index.js.map +1 -0
- package/dist/eval/report.d.ts +8 -0
- package/dist/eval/report.d.ts.map +1 -0
- package/dist/eval/report.js +44 -0
- package/dist/eval/report.js.map +1 -0
- package/dist/eval/runner.d.ts +67 -0
- package/dist/eval/runner.d.ts.map +1 -0
- package/dist/eval/runner.js +256 -0
- package/dist/eval/runner.js.map +1 -0
- package/dist/eval/scorer.d.ts +83 -0
- package/dist/eval/scorer.d.ts.map +1 -0
- package/dist/eval/scorer.js +195 -0
- package/dist/eval/scorer.js.map +1 -0
- package/dist/eval/types.d.ts +162 -0
- package/dist/eval/types.d.ts.map +1 -0
- package/dist/eval/types.js +20 -0
- package/dist/eval/types.js.map +1 -0
- package/dist/observability/traces.d.ts.map +1 -1
- package/dist/observability/traces.js +100 -1
- package/dist/observability/traces.js.map +1 -1
- package/dist/observability/tracing.d.ts +73 -0
- package/dist/observability/tracing.d.ts.map +1 -0
- package/dist/observability/tracing.js +126 -0
- package/dist/observability/tracing.js.map +1 -0
- package/dist/onboarding/default-steps.d.ts.map +1 -1
- package/dist/onboarding/default-steps.js +4 -1
- package/dist/onboarding/default-steps.js.map +1 -1
- package/dist/provider-api/actions/query-staged-dataset.d.ts +1 -1
- package/dist/scripts/agent-engines/list-agent-engines.d.ts.map +1 -1
- package/dist/scripts/agent-engines/list-agent-engines.js +10 -3
- package/dist/scripts/agent-engines/list-agent-engines.js.map +1 -1
- package/dist/server/action-discovery.d.ts.map +1 -1
- package/dist/server/action-discovery.js +4 -0
- package/dist/server/action-discovery.js.map +1 -1
- package/dist/server/agent-chat-plugin.d.ts +9 -0
- package/dist/server/agent-chat-plugin.d.ts.map +1 -1
- package/dist/server/agent-chat-plugin.js +118 -110
- package/dist/server/agent-chat-plugin.js.map +1 -1
- package/dist/server/agent-teams.d.ts +62 -0
- package/dist/server/agent-teams.d.ts.map +1 -1
- package/dist/server/agent-teams.js +99 -2
- package/dist/server/agent-teams.js.map +1 -1
- package/dist/server/core-routes-plugin.d.ts.map +1 -1
- package/dist/server/core-routes-plugin.js +7 -4
- package/dist/server/core-routes-plugin.js.map +1 -1
- package/dist/server/credential-provider.d.ts.map +1 -1
- package/dist/server/credential-provider.js +2 -0
- package/dist/server/credential-provider.js.map +1 -1
- package/dist/server/framework-request-handler.d.ts.map +1 -1
- package/dist/server/framework-request-handler.js +33 -1
- package/dist/server/framework-request-handler.js.map +1 -1
- package/dist/server/index.d.ts +1 -0
- package/dist/server/index.d.ts.map +1 -1
- package/dist/server/index.js +1 -0
- package/dist/server/index.js.map +1 -1
- package/dist/templates/workspace-core/.agents/skills/external-agents/SKILL.md +10 -0
- package/dist/templates/workspace-core/.agents/skills/harness-agents/SKILL.md +20 -0
- package/dist/templates/workspace-core/.agents/skills/observability/SKILL.md +20 -0
- package/docs/content/agent-teams.md +32 -0
- package/docs/content/blueprint-installer.md +73 -0
- package/docs/content/evals.md +141 -0
- package/docs/content/pr-visual-recap.md +7 -4
- package/docs/content/sandbox-adapters.md +134 -0
- package/docs/content/template-plan.md +20 -8
- package/package.json +5 -1
- package/src/templates/workspace-core/.agents/skills/external-agents/SKILL.md +10 -0
- package/src/templates/workspace-core/.agents/skills/harness-agents/SKILL.md +20 -0
- package/src/templates/workspace-core/.agents/skills/observability/SKILL.md +20 -0
|
@@ -21,7 +21,7 @@ import { resourceList, resourceListAccessible, resourceGet, resourceGetByPath, e
|
|
|
21
21
|
import { getFrontmatterValue, getSkillNameFromPath, parseFrontmatter, } from "../resources/metadata.js";
|
|
22
22
|
import nodePath from "node:path";
|
|
23
23
|
import { readBody } from "./h3-helpers.js";
|
|
24
|
-
import { AGENT_TEAM_PROCESS_RUN_PATH, processAgentTeamRun, reconcileAgentTeamRunsForOwner, } from "./agent-teams.js";
|
|
24
|
+
import { AGENT_TEAM_PROCESS_RUN_PATH, getCurrentDelegationDepth, processAgentTeamRun, reconcileAgentTeamRunsForOwner, } from "./agent-teams.js";
|
|
25
25
|
import { setProgressPreListHook } from "../progress/store.js";
|
|
26
26
|
import { verifyInternalToken, extractBearerToken, } from "../integrations/internal-token.js";
|
|
27
27
|
import { hasConfiguredA2ASecret, isA2AProductionRuntime, } from "../a2a/auth-policy.js";
|
|
@@ -3280,116 +3280,118 @@ export function createAgentChatPlugin(options) {
|
|
|
3280
3280
|
: DEV_FRAMEWORK_PROMPT) + devActionsPrompt;
|
|
3281
3281
|
// Keep legacy names for the composition below
|
|
3282
3282
|
const basePrompt = prodPrompt;
|
|
3283
|
-
|
|
3284
|
-
|
|
3285
|
-
|
|
3286
|
-
|
|
3287
|
-
|
|
3288
|
-
|
|
3289
|
-
|
|
3290
|
-
|
|
3291
|
-
|
|
3292
|
-
|
|
3293
|
-
|
|
3294
|
-
|
|
3295
|
-
|
|
3296
|
-
|
|
3297
|
-
|
|
3298
|
-
|
|
3299
|
-
|
|
3300
|
-
|
|
3301
|
-
|
|
3302
|
-
|
|
3303
|
-
|
|
3304
|
-
|
|
3305
|
-
});
|
|
3306
|
-
const mcpModelCandidate = options?.model ??
|
|
3307
|
-
(await getStoredModelForEngine(mcpEngine, {
|
|
3283
|
+
if (options?.disableMcp !== true) {
|
|
3284
|
+
// Mount MCP remote server — same action registry as A2A + agent chat
|
|
3285
|
+
const { mountMCP } = await import("../mcp/server.js");
|
|
3286
|
+
mountMCP(nitroApp, {
|
|
3287
|
+
name: options?.appId
|
|
3288
|
+
? options.appId.charAt(0).toUpperCase() + options.appId.slice(1)
|
|
3289
|
+
: "Agent",
|
|
3290
|
+
title: options?.mcpServerInfo?.title,
|
|
3291
|
+
appId: options?.appId,
|
|
3292
|
+
description: options?.mcpServerInfo?.description ??
|
|
3293
|
+
`Agent-native ${options?.appId ?? "app"} agent`,
|
|
3294
|
+
websiteUrl: options?.mcpServerInfo?.websiteUrl,
|
|
3295
|
+
icons: options?.mcpServerInfo?.icons,
|
|
3296
|
+
actions: allScripts,
|
|
3297
|
+
productionActions: mcpFullActions,
|
|
3298
|
+
...(options?.connectorCatalog
|
|
3299
|
+
? { connectorCatalog: options.connectorCatalog }
|
|
3300
|
+
: {}),
|
|
3301
|
+
askAgent: async (message) => {
|
|
3302
|
+
const mcpEngine = await resolveEngine({
|
|
3303
|
+
engineOption: options?.engine,
|
|
3304
|
+
apiKey: options?.apiKey,
|
|
3308
3305
|
appId: options?.appId,
|
|
3309
|
-
})) ??
|
|
3310
|
-
mcpEngine.defaultModel;
|
|
3311
|
-
const model = normalizeModelForEngine(mcpEngine, mcpModelCandidate);
|
|
3312
|
-
// Same actions as A2A — without call-agent to prevent loops.
|
|
3313
|
-
// In dev mode, template actions go through bash, not native tools.
|
|
3314
|
-
const devActiveMcp = isDevMode();
|
|
3315
|
-
const mcpActions = attachToolSearch(devActiveMcp
|
|
3316
|
-
? {
|
|
3317
|
-
...resourceScripts,
|
|
3318
|
-
...docsScripts,
|
|
3319
|
-
...(lazyContext ? frameworkContextTool : {}),
|
|
3320
|
-
...urlTools,
|
|
3321
|
-
...chatScripts,
|
|
3322
|
-
...fetchTool,
|
|
3323
|
-
...webSearchTool,
|
|
3324
|
-
...workspaceFilesTool,
|
|
3325
|
-
...toolActions,
|
|
3326
|
-
...mcpActionEntries,
|
|
3327
|
-
...devScriptsForA2A,
|
|
3328
|
-
...devRunCodeTool,
|
|
3329
|
-
}
|
|
3330
|
-
: {
|
|
3331
|
-
...templateScripts,
|
|
3332
|
-
...resourceScripts,
|
|
3333
|
-
...docsScripts,
|
|
3334
|
-
...dbScripts,
|
|
3335
|
-
...refreshScreenTool,
|
|
3336
|
-
...(lazyContext ? frameworkContextTool : {}),
|
|
3337
|
-
...urlTools,
|
|
3338
|
-
...chatScripts,
|
|
3339
|
-
...fetchTool,
|
|
3340
|
-
...webSearchTool,
|
|
3341
|
-
...workspaceFilesTool,
|
|
3342
|
-
...toolActions,
|
|
3343
|
-
...mcpActionEntries,
|
|
3344
|
-
...(resolvedProdCodeExec !== "off" ? runCodeTool : {}),
|
|
3345
|
-
...prodCodingTools,
|
|
3346
3306
|
});
|
|
3347
|
-
|
|
3348
|
-
|
|
3349
|
-
|
|
3350
|
-
|
|
3351
|
-
|
|
3352
|
-
|
|
3353
|
-
|
|
3354
|
-
|
|
3355
|
-
|
|
3356
|
-
|
|
3357
|
-
|
|
3358
|
-
|
|
3359
|
-
|
|
3360
|
-
|
|
3361
|
-
|
|
3362
|
-
|
|
3363
|
-
|
|
3364
|
-
|
|
3365
|
-
|
|
3366
|
-
|
|
3367
|
-
|
|
3368
|
-
|
|
3369
|
-
|
|
3370
|
-
|
|
3371
|
-
|
|
3372
|
-
|
|
3373
|
-
|
|
3374
|
-
|
|
3375
|
-
|
|
3376
|
-
|
|
3377
|
-
|
|
3378
|
-
|
|
3379
|
-
|
|
3380
|
-
|
|
3381
|
-
|
|
3382
|
-
|
|
3383
|
-
|
|
3384
|
-
|
|
3385
|
-
|
|
3386
|
-
|
|
3387
|
-
|
|
3388
|
-
|
|
3389
|
-
|
|
3390
|
-
|
|
3391
|
-
|
|
3392
|
-
|
|
3307
|
+
const mcpModelCandidate = options?.model ??
|
|
3308
|
+
(await getStoredModelForEngine(mcpEngine, {
|
|
3309
|
+
appId: options?.appId,
|
|
3310
|
+
})) ??
|
|
3311
|
+
mcpEngine.defaultModel;
|
|
3312
|
+
const model = normalizeModelForEngine(mcpEngine, mcpModelCandidate);
|
|
3313
|
+
// Same actions as A2A — without call-agent to prevent loops.
|
|
3314
|
+
// In dev mode, template actions go through bash, not native tools.
|
|
3315
|
+
const devActiveMcp = isDevMode();
|
|
3316
|
+
const mcpActions = attachToolSearch(devActiveMcp
|
|
3317
|
+
? {
|
|
3318
|
+
...resourceScripts,
|
|
3319
|
+
...docsScripts,
|
|
3320
|
+
...(lazyContext ? frameworkContextTool : {}),
|
|
3321
|
+
...urlTools,
|
|
3322
|
+
...chatScripts,
|
|
3323
|
+
...fetchTool,
|
|
3324
|
+
...webSearchTool,
|
|
3325
|
+
...workspaceFilesTool,
|
|
3326
|
+
...toolActions,
|
|
3327
|
+
...mcpActionEntries,
|
|
3328
|
+
...devScriptsForA2A,
|
|
3329
|
+
...devRunCodeTool,
|
|
3330
|
+
}
|
|
3331
|
+
: {
|
|
3332
|
+
...templateScripts,
|
|
3333
|
+
...resourceScripts,
|
|
3334
|
+
...docsScripts,
|
|
3335
|
+
...dbScripts,
|
|
3336
|
+
...refreshScreenTool,
|
|
3337
|
+
...(lazyContext ? frameworkContextTool : {}),
|
|
3338
|
+
...urlTools,
|
|
3339
|
+
...chatScripts,
|
|
3340
|
+
...fetchTool,
|
|
3341
|
+
...webSearchTool,
|
|
3342
|
+
...workspaceFilesTool,
|
|
3343
|
+
...toolActions,
|
|
3344
|
+
...mcpActionEntries,
|
|
3345
|
+
...(resolvedProdCodeExec !== "off" ? runCodeTool : {}),
|
|
3346
|
+
...prodCodingTools,
|
|
3347
|
+
});
|
|
3348
|
+
const mcpTools = actionsToEngineTools(mcpActions);
|
|
3349
|
+
const resources = await loadResourcesForPrompt(SHARED_OWNER, lazyContext, options?.appId);
|
|
3350
|
+
const schemaBlock = lazyContext
|
|
3351
|
+
? ""
|
|
3352
|
+
: await buildSchemaBlock(SHARED_OWNER, devActiveMcp);
|
|
3353
|
+
// Build the MCP handler's own prompt — always use the bash-based
|
|
3354
|
+
// dev prompt in dev mode because mcpActions routes template actions
|
|
3355
|
+
// through bash (`devScriptsForA2A`), regardless of `nativeActionsInDev`.
|
|
3356
|
+
const mcpDevPrompt = (options?.devSystemPrompt
|
|
3357
|
+
? options.devSystemPrompt +
|
|
3358
|
+
(options?.systemPrompt ??
|
|
3359
|
+
(lazyContext
|
|
3360
|
+
? PROD_FRAMEWORK_PROMPT_COMPACT
|
|
3361
|
+
: PROD_FRAMEWORK_PROMPT))
|
|
3362
|
+
: lazyContext
|
|
3363
|
+
? DEV_FRAMEWORK_PROMPT_COMPACT
|
|
3364
|
+
: DEV_FRAMEWORK_PROMPT) + devActionsPrompt;
|
|
3365
|
+
const systemPrompt = devActiveMcp
|
|
3366
|
+
? mcpDevPrompt +
|
|
3367
|
+
buildRuntimeContextPrompt() +
|
|
3368
|
+
resources +
|
|
3369
|
+
schemaBlock
|
|
3370
|
+
: basePrompt +
|
|
3371
|
+
buildRuntimeContextPrompt() +
|
|
3372
|
+
resources +
|
|
3373
|
+
schemaBlock;
|
|
3374
|
+
let accumulatedText = "";
|
|
3375
|
+
const controller = new AbortController();
|
|
3376
|
+
await runAgentLoopDirectWithSoftTimeout({
|
|
3377
|
+
engine: mcpEngine,
|
|
3378
|
+
model,
|
|
3379
|
+
systemPrompt,
|
|
3380
|
+
tools: mcpTools,
|
|
3381
|
+
messages: [
|
|
3382
|
+
{ role: "user", content: [{ type: "text", text: message }] },
|
|
3383
|
+
],
|
|
3384
|
+
actions: mcpActions,
|
|
3385
|
+
send: (event) => {
|
|
3386
|
+
if (event.type === "text")
|
|
3387
|
+
accumulatedText += event.text;
|
|
3388
|
+
},
|
|
3389
|
+
signal: controller.signal,
|
|
3390
|
+
}, options?.runSoftTimeoutMs);
|
|
3391
|
+
return accumulatedText || "(no response)";
|
|
3392
|
+
},
|
|
3393
|
+
});
|
|
3394
|
+
}
|
|
3393
3395
|
const OWNER_CONTEXT_KEY = "__agentNativeOwnerContext";
|
|
3394
3396
|
// Resolve owner from the H3 event's session, with an optional
|
|
3395
3397
|
// template-provided anonymous owner for public read-only surfaces.
|
|
@@ -3889,7 +3891,13 @@ export function createAgentChatPlugin(options) {
|
|
|
3889
3891
|
tzRaw.trim().length < 64
|
|
3890
3892
|
? tzRaw.trim()
|
|
3891
3893
|
: undefined;
|
|
3892
|
-
|
|
3894
|
+
// Thread the ambient sub-agent delegation depth so a sub-agent running
|
|
3895
|
+
// at the depth cap is told in its runtime context that it cannot
|
|
3896
|
+
// delegate further. The depth-guard already enforces the cap
|
|
3897
|
+
// server-side (`evaluateSubagentDepth`); this only surfaces it to the
|
|
3898
|
+
// model. 0 (the top-level chat) emits no delegation line.
|
|
3899
|
+
const delegationDepth = getCurrentDelegationDepth();
|
|
3900
|
+
return buildRuntimeContextPrompt({ timezone, delegationDepth });
|
|
3893
3901
|
};
|
|
3894
3902
|
// The app-rendered sidebar must never edit the app's source code
|
|
3895
3903
|
// directly. Source-file edits can trigger HMR or full reloads of the
|