@illuma-ai/agents 1.4.0-alpha.6 → 1.5.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 +62 -0
- package/dist/cjs/agents/AgentContext.cjs +274 -67
- package/dist/cjs/agents/AgentContext.cjs.map +1 -1
- package/dist/cjs/common/enum.cjs +44 -13
- package/dist/cjs/common/enum.cjs.map +1 -1
- package/dist/cjs/graphs/Graph.cjs +182 -5
- package/dist/cjs/graphs/Graph.cjs.map +1 -1
- package/dist/cjs/graphs/MultiAgentGraph.cjs +152 -1167
- package/dist/cjs/graphs/MultiAgentGraph.cjs.map +1 -1
- package/dist/cjs/hooks/HookRegistry.cjs +162 -0
- package/dist/cjs/hooks/HookRegistry.cjs.map +1 -0
- package/dist/cjs/hooks/executeHooks.cjs +276 -0
- package/dist/cjs/hooks/executeHooks.cjs.map +1 -0
- package/dist/cjs/hooks/matchers.cjs +256 -0
- package/dist/cjs/hooks/matchers.cjs.map +1 -0
- package/dist/cjs/hooks/types.cjs +27 -0
- package/dist/cjs/hooks/types.cjs.map +1 -0
- package/dist/cjs/langchain/google-common.cjs +3 -0
- package/dist/cjs/langchain/google-common.cjs.map +1 -0
- package/dist/cjs/langchain/index.cjs +86 -0
- package/dist/cjs/langchain/index.cjs.map +1 -0
- package/dist/cjs/langchain/language_models/chat_models.cjs +3 -0
- package/dist/cjs/langchain/language_models/chat_models.cjs.map +1 -0
- package/dist/cjs/langchain/messages/tool.cjs +3 -0
- package/dist/cjs/langchain/messages/tool.cjs.map +1 -0
- package/dist/cjs/langchain/messages.cjs +51 -0
- package/dist/cjs/langchain/messages.cjs.map +1 -0
- package/dist/cjs/langchain/openai.cjs +3 -0
- package/dist/cjs/langchain/openai.cjs.map +1 -0
- package/dist/cjs/langchain/prompts.cjs +11 -0
- package/dist/cjs/langchain/prompts.cjs.map +1 -0
- package/dist/cjs/langchain/runnables.cjs +19 -0
- package/dist/cjs/langchain/runnables.cjs.map +1 -0
- package/dist/cjs/langchain/tools.cjs +23 -0
- package/dist/cjs/langchain/tools.cjs.map +1 -0
- package/dist/cjs/langchain/utils/env.cjs +11 -0
- package/dist/cjs/langchain/utils/env.cjs.map +1 -0
- package/dist/cjs/llm/anthropic/utils/message_inputs.cjs +5 -1
- package/dist/cjs/llm/anthropic/utils/message_inputs.cjs.map +1 -1
- package/dist/cjs/llm/bedrock/cacheSupport.cjs +55 -0
- package/dist/cjs/llm/bedrock/cacheSupport.cjs.map +1 -0
- package/dist/cjs/llm/bedrock/index.cjs +61 -33
- package/dist/cjs/llm/bedrock/index.cjs.map +1 -1
- package/dist/cjs/llm/openai/index.cjs +0 -3
- package/dist/cjs/llm/openai/index.cjs.map +1 -1
- package/dist/cjs/llm/openai/utils/index.cjs +27 -10
- package/dist/cjs/llm/openai/utils/index.cjs.map +1 -1
- package/dist/cjs/main.cjs +178 -127
- package/dist/cjs/main.cjs.map +1 -1
- package/dist/cjs/messages/cache.cjs +89 -0
- package/dist/cjs/messages/cache.cjs.map +1 -1
- package/dist/cjs/messages/contextPruning.cjs +156 -0
- package/dist/cjs/messages/contextPruning.cjs.map +1 -0
- package/dist/cjs/messages/contextPruningSettings.cjs +53 -0
- package/dist/cjs/messages/contextPruningSettings.cjs.map +1 -0
- package/dist/cjs/messages/format.cjs +144 -20
- package/dist/cjs/messages/format.cjs.map +1 -1
- package/dist/cjs/messages/prune.cjs +505 -4
- package/dist/cjs/messages/prune.cjs.map +1 -1
- package/dist/cjs/run.cjs +141 -1
- package/dist/cjs/run.cjs.map +1 -1
- package/dist/cjs/tools/BashExecutor.cjs +235 -0
- package/dist/cjs/tools/BashExecutor.cjs.map +1 -0
- package/dist/cjs/tools/BashProgrammaticToolCalling.cjs +297 -0
- package/dist/cjs/tools/BashProgrammaticToolCalling.cjs.map +1 -0
- package/dist/cjs/tools/CodeExecutor.cjs +44 -47
- package/dist/cjs/tools/CodeExecutor.cjs.map +1 -1
- package/dist/cjs/tools/ProgrammaticToolCalling.cjs +16 -11
- package/dist/cjs/tools/ProgrammaticToolCalling.cjs.map +1 -1
- package/dist/cjs/tools/ReadFile.cjs +44 -0
- package/dist/cjs/tools/ReadFile.cjs.map +1 -0
- package/dist/cjs/tools/SkillTool.cjs +51 -0
- package/dist/cjs/tools/SkillTool.cjs.map +1 -0
- package/dist/cjs/tools/SubagentTool.cjs +93 -0
- package/dist/cjs/tools/SubagentTool.cjs.map +1 -0
- package/dist/cjs/tools/ToolNode.cjs +450 -24
- package/dist/cjs/tools/ToolNode.cjs.map +1 -1
- package/dist/cjs/tools/search/search.cjs +11 -3
- package/dist/cjs/tools/search/search.cjs.map +1 -1
- package/dist/cjs/tools/search/tavily-scraper.cjs +189 -0
- package/dist/cjs/tools/search/tavily-scraper.cjs.map +1 -0
- package/dist/cjs/tools/search/tavily-search.cjs +372 -0
- package/dist/cjs/tools/search/tavily-search.cjs.map +1 -0
- package/dist/cjs/tools/search/tool.cjs +28 -4
- package/dist/cjs/tools/search/tool.cjs.map +1 -1
- package/dist/cjs/tools/search/utils.cjs +10 -3
- package/dist/cjs/tools/search/utils.cjs.map +1 -1
- package/dist/cjs/tools/skillCatalog.cjs +84 -0
- package/dist/cjs/tools/skillCatalog.cjs.map +1 -0
- package/dist/cjs/tools/subagent/SubagentExecutor.cjs +512 -0
- package/dist/cjs/tools/subagent/SubagentExecutor.cjs.map +1 -0
- package/dist/cjs/tools/toolOutputReferences.cjs +670 -0
- package/dist/cjs/tools/toolOutputReferences.cjs.map +1 -0
- package/dist/cjs/types/agent-cache.cjs +53 -0
- package/dist/cjs/types/agent-cache.cjs.map +1 -0
- package/dist/cjs/types/graph.cjs.map +1 -1
- package/dist/cjs/utils/truncation.cjs +135 -0
- package/dist/cjs/utils/truncation.cjs.map +1 -0
- package/dist/esm/agents/AgentContext.mjs +274 -67
- package/dist/esm/agents/AgentContext.mjs.map +1 -1
- package/dist/esm/common/enum.mjs +44 -12
- package/dist/esm/common/enum.mjs.map +1 -1
- package/dist/esm/graphs/Graph.mjs +182 -5
- package/dist/esm/graphs/Graph.mjs.map +1 -1
- package/dist/esm/graphs/MultiAgentGraph.mjs +155 -1170
- package/dist/esm/graphs/MultiAgentGraph.mjs.map +1 -1
- package/dist/esm/hooks/HookRegistry.mjs +160 -0
- package/dist/esm/hooks/HookRegistry.mjs.map +1 -0
- package/dist/esm/hooks/executeHooks.mjs +273 -0
- package/dist/esm/hooks/executeHooks.mjs.map +1 -0
- package/dist/esm/hooks/matchers.mjs +251 -0
- package/dist/esm/hooks/matchers.mjs.map +1 -0
- package/dist/esm/hooks/types.mjs +25 -0
- package/dist/esm/hooks/types.mjs.map +1 -0
- package/dist/esm/langchain/google-common.mjs +2 -0
- package/dist/esm/langchain/google-common.mjs.map +1 -0
- package/dist/esm/langchain/index.mjs +5 -0
- package/dist/esm/langchain/language_models/chat_models.mjs +2 -0
- package/dist/esm/langchain/language_models/chat_models.mjs.map +1 -0
- package/dist/esm/langchain/messages/tool.mjs +2 -0
- package/dist/esm/langchain/messages/tool.mjs.map +1 -0
- package/dist/esm/langchain/messages.mjs +2 -0
- package/dist/esm/langchain/messages.mjs.map +1 -0
- package/dist/esm/langchain/openai.mjs +2 -0
- package/dist/esm/langchain/openai.mjs.map +1 -0
- package/dist/esm/langchain/prompts.mjs +2 -0
- package/dist/esm/langchain/prompts.mjs.map +1 -0
- package/dist/esm/langchain/runnables.mjs +2 -0
- package/dist/esm/langchain/runnables.mjs.map +1 -0
- package/dist/esm/langchain/tools.mjs +2 -0
- package/dist/esm/langchain/tools.mjs.map +1 -0
- package/dist/esm/langchain/utils/env.mjs +2 -0
- package/dist/esm/langchain/utils/env.mjs.map +1 -0
- package/dist/esm/llm/anthropic/utils/message_inputs.mjs +5 -1
- package/dist/esm/llm/anthropic/utils/message_inputs.mjs.map +1 -1
- package/dist/esm/llm/bedrock/cacheSupport.mjs +52 -0
- package/dist/esm/llm/bedrock/cacheSupport.mjs.map +1 -0
- package/dist/esm/llm/bedrock/index.mjs +61 -34
- package/dist/esm/llm/bedrock/index.mjs.map +1 -1
- package/dist/esm/llm/openai/index.mjs +0 -3
- package/dist/esm/llm/openai/index.mjs.map +1 -1
- package/dist/esm/llm/openai/utils/index.mjs +27 -10
- package/dist/esm/llm/openai/utils/index.mjs.map +1 -1
- package/dist/esm/main.mjs +21 -27
- package/dist/esm/main.mjs.map +1 -1
- package/dist/esm/messages/cache.mjs +89 -0
- package/dist/esm/messages/cache.mjs.map +1 -1
- package/dist/esm/messages/contextPruning.mjs +154 -0
- package/dist/esm/messages/contextPruning.mjs.map +1 -0
- package/dist/esm/messages/contextPruningSettings.mjs +50 -0
- package/dist/esm/messages/contextPruningSettings.mjs.map +1 -0
- package/dist/esm/messages/format.mjs +136 -12
- package/dist/esm/messages/format.mjs.map +1 -1
- package/dist/esm/messages/prune.mjs +504 -7
- package/dist/esm/messages/prune.mjs.map +1 -1
- package/dist/esm/run.mjs +141 -1
- package/dist/esm/run.mjs.map +1 -1
- package/dist/esm/tools/BashExecutor.mjs +227 -0
- package/dist/esm/tools/BashExecutor.mjs.map +1 -0
- package/dist/esm/tools/BashProgrammaticToolCalling.mjs +288 -0
- package/dist/esm/tools/BashProgrammaticToolCalling.mjs.map +1 -0
- package/dist/esm/tools/CodeExecutor.mjs +44 -48
- package/dist/esm/tools/CodeExecutor.mjs.map +1 -1
- package/dist/esm/tools/ProgrammaticToolCalling.mjs +17 -12
- package/dist/esm/tools/ProgrammaticToolCalling.mjs.map +1 -1
- package/dist/esm/tools/ReadFile.mjs +39 -0
- package/dist/esm/tools/ReadFile.mjs.map +1 -0
- package/dist/esm/tools/SkillTool.mjs +46 -0
- package/dist/esm/tools/SkillTool.mjs.map +1 -0
- package/dist/esm/tools/SubagentTool.mjs +86 -0
- package/dist/esm/tools/SubagentTool.mjs.map +1 -0
- package/dist/esm/tools/ToolNode.mjs +452 -26
- package/dist/esm/tools/ToolNode.mjs.map +1 -1
- package/dist/esm/tools/search/search.mjs +11 -3
- package/dist/esm/tools/search/search.mjs.map +1 -1
- package/dist/esm/tools/search/tavily-scraper.mjs +186 -0
- package/dist/esm/tools/search/tavily-scraper.mjs.map +1 -0
- package/dist/esm/tools/search/tavily-search.mjs +370 -0
- package/dist/esm/tools/search/tavily-search.mjs.map +1 -0
- package/dist/esm/tools/search/tool.mjs +28 -4
- package/dist/esm/tools/search/tool.mjs.map +1 -1
- package/dist/esm/tools/search/utils.mjs +10 -3
- package/dist/esm/tools/search/utils.mjs.map +1 -1
- package/dist/esm/tools/skillCatalog.mjs +82 -0
- package/dist/esm/tools/skillCatalog.mjs.map +1 -0
- package/dist/esm/tools/subagent/SubagentExecutor.mjs +506 -0
- package/dist/esm/tools/subagent/SubagentExecutor.mjs.map +1 -0
- package/dist/esm/tools/toolOutputReferences.mjs +662 -0
- package/dist/esm/tools/toolOutputReferences.mjs.map +1 -0
- package/dist/esm/types/agent-cache.mjs +51 -0
- package/dist/esm/types/agent-cache.mjs.map +1 -0
- package/dist/esm/types/graph.mjs.map +1 -1
- package/dist/esm/utils/truncation.mjs +128 -0
- package/dist/esm/utils/truncation.mjs.map +1 -0
- package/dist/types/agents/AgentContext.d.ts +101 -8
- package/dist/types/common/enum.d.ts +39 -12
- package/dist/types/common/index.d.ts +0 -1
- package/dist/types/graphs/Graph.d.ts +43 -0
- package/dist/types/graphs/MultiAgentGraph.d.ts +26 -150
- package/dist/types/graphs/index.d.ts +0 -1
- package/dist/types/hooks/HookRegistry.d.ts +56 -0
- package/dist/types/hooks/executeHooks.d.ts +79 -0
- package/dist/types/hooks/index.d.ts +6 -0
- package/dist/types/hooks/matchers.d.ts +95 -0
- package/dist/types/hooks/types.d.ts +320 -0
- package/dist/types/index.d.ts +9 -9
- package/dist/types/langchain/google-common.d.ts +1 -0
- package/dist/types/langchain/index.d.ts +8 -0
- package/dist/types/langchain/language_models/chat_models.d.ts +1 -0
- package/dist/types/langchain/messages/tool.d.ts +1 -0
- package/dist/types/langchain/messages.d.ts +2 -0
- package/dist/types/langchain/openai.d.ts +1 -0
- package/dist/types/langchain/prompts.d.ts +1 -0
- package/dist/types/langchain/runnables.d.ts +2 -0
- package/dist/types/langchain/tools.d.ts +2 -0
- package/dist/types/langchain/utils/env.d.ts +1 -0
- package/dist/types/llm/bedrock/cacheSupport.d.ts +35 -0
- package/dist/types/llm/bedrock/index.d.ts +54 -1
- package/dist/types/messages/contextPruning.d.ts +42 -0
- package/dist/types/messages/contextPruningSettings.d.ts +44 -0
- package/dist/types/messages/format.d.ts +9 -1
- package/dist/types/messages/index.d.ts +2 -0
- package/dist/types/messages/prune.d.ts +91 -1
- package/dist/types/run.d.ts +2 -0
- package/dist/types/tools/BashExecutor.d.ts +76 -0
- package/dist/types/tools/BashProgrammaticToolCalling.d.ts +72 -0
- package/dist/types/tools/CodeExecutor.d.ts +8 -26
- package/dist/types/tools/ReadFile.d.ts +28 -0
- package/dist/types/tools/SkillTool.d.ts +40 -0
- package/dist/types/tools/SubagentTool.d.ts +36 -0
- package/dist/types/tools/ToolNode.d.ts +77 -5
- package/dist/types/tools/search/tavily-scraper.d.ts +19 -0
- package/dist/types/tools/search/tavily-search.d.ts +4 -0
- package/dist/types/tools/search/types.d.ts +99 -5
- package/dist/types/tools/search/utils.d.ts +2 -2
- package/dist/types/tools/skillCatalog.d.ts +19 -0
- package/dist/types/tools/subagent/SubagentExecutor.d.ts +137 -0
- package/dist/types/tools/subagent/index.d.ts +2 -0
- package/dist/types/tools/subagent/types.d.ts +84 -0
- package/dist/types/tools/toolOutputReferences.d.ts +236 -0
- package/dist/types/types/agent-cache.d.ts +70 -0
- package/dist/types/types/graph.d.ts +162 -22
- package/dist/types/types/index.d.ts +3 -0
- package/dist/types/types/messages.d.ts +26 -0
- package/dist/types/types/run.d.ts +22 -0
- package/dist/types/types/skill.d.ts +9 -0
- package/dist/types/types/tools.d.ts +111 -0
- package/dist/types/utils/index.d.ts +1 -3
- package/dist/types/utils/truncation.d.ts +70 -0
- package/package.json +57 -17
- package/src/agents/AgentContext.js.map +1 -0
- package/src/agents/AgentContext.test.js.map +1 -0
- package/src/agents/AgentContext.ts +321 -78
- package/src/agents/__tests__/AgentContext.cacheTtl.live.test.ts +259 -0
- package/src/agents/__tests__/AgentContext.crossAgentTier1.live.test.ts +264 -0
- package/src/agents/__tests__/AgentContext.crossUserCache.live.test.ts +342 -0
- package/src/agents/__tests__/AgentContext.test.js.map +1 -0
- package/src/agents/__tests__/AgentContext.test.ts +632 -0
- package/src/agents/__tests__/resolveStructuredOutputMode.test.js.map +1 -0
- package/src/common/__tests__/enum.test.ts +7 -17
- package/src/common/enum.js.map +1 -0
- package/src/common/enum.ts +43 -12
- package/src/common/index.js.map +1 -0
- package/src/common/index.ts +0 -1
- package/src/events.js.map +1 -0
- package/src/graphs/Graph.js.map +1 -0
- package/src/graphs/Graph.ts +222 -2
- package/src/graphs/MultiAgentGraph.js.map +1 -0
- package/src/graphs/MultiAgentGraph.ts +154 -1466
- package/src/graphs/__tests__/MultiAgentGraph.test.ts +91 -0
- package/src/graphs/__tests__/structured-output.integration.test.js.map +1 -0
- package/src/graphs/__tests__/structured-output.test.js.map +1 -0
- package/src/graphs/contextManagement.e2e.test.js.map +1 -0
- package/src/graphs/contextManagement.test.js.map +1 -0
- package/src/graphs/handoffValidation.test.js.map +1 -0
- package/src/graphs/index.js.map +1 -0
- package/src/graphs/index.ts +0 -1
- package/src/hooks/HookRegistry.ts +208 -0
- package/src/hooks/__tests__/HookRegistry.test.ts +190 -0
- package/src/hooks/__tests__/compactHooks.test.ts +214 -0
- package/src/hooks/__tests__/executeHooks.test.ts +1013 -0
- package/src/hooks/__tests__/integration.test.ts +337 -0
- package/src/hooks/__tests__/matchers.test.ts +238 -0
- package/src/hooks/__tests__/toolHooks.test.ts +665 -0
- package/src/hooks/executeHooks.ts +375 -0
- package/src/hooks/index.ts +57 -0
- package/src/hooks/matchers.ts +280 -0
- package/src/hooks/types.ts +404 -0
- package/src/index.js.map +1 -0
- package/src/index.ts +15 -24
- package/src/instrumentation.js.map +1 -0
- package/src/langchain/google-common.ts +1 -0
- package/src/langchain/index.ts +8 -0
- package/src/langchain/language_models/chat_models.ts +1 -0
- package/src/langchain/messages/tool.ts +5 -0
- package/src/langchain/messages.ts +21 -0
- package/src/langchain/openai.ts +1 -0
- package/src/langchain/prompts.ts +1 -0
- package/src/langchain/runnables.ts +7 -0
- package/src/langchain/tools.ts +8 -0
- package/src/langchain/utils/env.ts +1 -0
- package/src/llm/anthropic/index.js.map +1 -0
- package/src/llm/anthropic/types.js.map +1 -0
- package/src/llm/anthropic/utils/message_inputs.js.map +1 -0
- package/src/llm/anthropic/utils/message_inputs.ts +10 -1
- package/src/llm/anthropic/utils/message_outputs.js.map +1 -0
- package/src/llm/anthropic/utils/output_parsers.js.map +1 -0
- package/src/llm/anthropic/utils/server-tool-inputs.test.ts +436 -0
- package/src/llm/anthropic/utils/tools.js.map +1 -0
- package/src/llm/bedrock/__tests__/bedrock-caching.test.js.map +1 -0
- package/src/llm/bedrock/__tests__/bedrock-caching.test.ts +166 -18
- package/src/llm/bedrock/cacheSupport.test.ts +99 -0
- package/src/llm/bedrock/cacheSupport.ts +53 -0
- package/src/llm/bedrock/index.js.map +1 -0
- package/src/llm/bedrock/index.ts +116 -41
- package/src/llm/bedrock/types.js.map +1 -0
- package/src/llm/bedrock/utils/index.js.map +1 -0
- package/src/llm/bedrock/utils/message_inputs.js.map +1 -0
- package/src/llm/bedrock/utils/message_outputs.js.map +1 -0
- package/src/llm/fake.js.map +1 -0
- package/src/llm/google/index.js.map +1 -0
- package/src/llm/google/types.js.map +1 -0
- package/src/llm/google/utils/common.js.map +1 -0
- package/src/llm/google/utils/tools.js.map +1 -0
- package/src/llm/google/utils/zod_to_genai_parameters.js.map +1 -0
- package/src/llm/openai/index.js.map +1 -0
- package/src/llm/openai/types.js.map +1 -0
- package/src/llm/openai/utils/index.js.map +1 -0
- package/src/llm/openai/utils/index.ts +31 -14
- package/src/llm/openai/utils/isReasoningModel.test.js.map +1 -0
- package/src/llm/openrouter/index.js.map +1 -0
- package/src/llm/openrouter/reasoning.test.js.map +1 -0
- package/src/llm/providers.js.map +1 -0
- package/src/llm/text.js.map +1 -0
- package/src/llm/vertexai/index.js.map +1 -0
- package/src/messages/__tests__/contextPruning.test.ts +228 -0
- package/src/messages/__tests__/tools.test.js.map +1 -0
- package/src/messages/cache.js.map +1 -0
- package/src/messages/cache.test.js.map +1 -0
- package/src/messages/cache.test.ts +62 -24
- package/src/messages/cache.ts +112 -0
- package/src/messages/content.js.map +1 -0
- package/src/messages/content.test.js.map +1 -0
- package/src/messages/contextPruning.ts +191 -0
- package/src/messages/contextPruningSettings.ts +90 -0
- package/src/messages/core.js.map +1 -0
- package/src/messages/ensureThinkingBlock.test.js.map +1 -0
- package/src/messages/format.js.map +1 -0
- package/src/messages/format.ts +164 -12
- package/src/messages/formatAgentMessages.skills.test.ts +413 -0
- package/src/messages/formatAgentMessages.test.js.map +1 -0
- package/src/messages/formatAgentMessages.tools.test.js.map +1 -0
- package/src/messages/formatMessage.test.js.map +1 -0
- package/src/messages/ids.js.map +1 -0
- package/src/messages/index.js.map +1 -0
- package/src/messages/index.ts +2 -0
- package/src/messages/labelContentByAgent.test.js.map +1 -0
- package/src/messages/prune.js.map +1 -0
- package/src/messages/prune.ts +661 -4
- package/src/messages/reducer.js.map +1 -0
- package/src/messages/shiftIndexTokenCountMap.test.js.map +1 -0
- package/src/messages/summarize.js.map +1 -0
- package/src/messages/summarize.test.js.map +1 -0
- package/src/messages/tools.js.map +1 -0
- package/src/mockStream.js.map +1 -0
- package/src/prompts/collab.js.map +1 -0
- package/src/prompts/index.js.map +1 -0
- package/src/prompts/taskmanager.js.map +1 -0
- package/src/run.js.map +1 -0
- package/src/run.ts +155 -1
- package/src/schemas/index.js.map +1 -0
- package/src/schemas/schema-preparation.test.js.map +1 -0
- package/src/schemas/validate.js.map +1 -0
- package/src/schemas/validate.test.js.map +1 -0
- package/src/scripts/abort.js.map +1 -0
- package/src/scripts/ant_web_search.js.map +1 -0
- package/src/scripts/ant_web_search_edge_case.js.map +1 -0
- package/src/scripts/ant_web_search_error_edge_case.js.map +1 -0
- package/src/scripts/args.js.map +1 -0
- package/src/scripts/bedrock-cache-debug.js.map +1 -0
- package/src/scripts/bedrock-content-aggregation-test.js.map +1 -0
- package/src/scripts/bedrock-merge-test.js.map +1 -0
- package/src/scripts/bedrock-parallel-tools-test.js.map +1 -0
- package/src/scripts/caching.js.map +1 -0
- package/src/scripts/cli.js.map +1 -0
- package/src/scripts/cli2.js.map +1 -0
- package/src/scripts/cli3.js.map +1 -0
- package/src/scripts/cli4.js.map +1 -0
- package/src/scripts/cli5.js.map +1 -0
- package/src/scripts/code_exec.js.map +1 -0
- package/src/scripts/code_exec_files.js.map +1 -0
- package/src/scripts/code_exec_multi_session.js.map +1 -0
- package/src/scripts/code_exec_ptc.js.map +1 -0
- package/src/scripts/code_exec_session.js.map +1 -0
- package/src/scripts/code_exec_simple.js.map +1 -0
- package/src/scripts/content.js.map +1 -0
- package/src/scripts/empty_input.js.map +1 -0
- package/src/scripts/handoff-test.js.map +1 -0
- package/src/scripts/image.js.map +1 -0
- package/src/scripts/memory.js.map +1 -0
- package/src/scripts/multi-agent-chain.js.map +1 -0
- package/src/scripts/multi-agent-chain.ts +2 -2
- package/src/scripts/multi-agent-conditional.js.map +1 -0
- package/src/scripts/multi-agent-document-review-chain.js.map +1 -0
- package/src/scripts/multi-agent-document-review-chain.ts +2 -2
- package/src/scripts/multi-agent-hybrid-flow.js.map +1 -0
- package/src/scripts/multi-agent-hybrid-flow.ts +4 -4
- package/src/scripts/multi-agent-parallel-start.js.map +1 -0
- package/src/scripts/multi-agent-parallel.js.map +1 -0
- package/src/scripts/multi-agent-parallel.ts +3 -3
- package/src/scripts/multi-agent-sequence.js.map +1 -0
- package/src/scripts/multi-agent-sequence.ts +3 -3
- package/src/scripts/multi-agent-subagent.ts +246 -0
- package/src/scripts/multi-agent-supervisor.js.map +1 -0
- package/src/scripts/multi-agent-supervisor.ts +5 -5
- package/src/scripts/multi-agent-test.js.map +1 -0
- package/src/scripts/parallel-asymmetric-tools-test.js.map +1 -0
- package/src/scripts/parallel-full-metadata-test.js.map +1 -0
- package/src/scripts/parallel-tools-test.js.map +1 -0
- package/src/scripts/poc-multi-agent-comprehensive.ts +8 -8
- package/src/scripts/programmatic_exec.js.map +1 -0
- package/src/scripts/programmatic_exec_agent.js.map +1 -0
- package/src/scripts/search.js.map +1 -0
- package/src/scripts/sequential-full-metadata-test.js.map +1 -0
- package/src/scripts/sequential-full-metadata-test.ts +2 -2
- package/src/scripts/simple.js.map +1 -0
- package/src/scripts/single-agent-metadata-test.js.map +1 -0
- package/src/scripts/stream.js.map +1 -0
- package/src/scripts/subagent-event-driven-debug.ts +190 -0
- package/src/scripts/subagent-tools-debug.ts +160 -0
- package/src/scripts/test-custom-prompt-key.js.map +1 -0
- package/src/scripts/test-custom-prompt-key.ts +3 -3
- package/src/scripts/test-handoff-input.js.map +1 -0
- package/src/scripts/test-handoff-input.ts +1 -1
- package/src/scripts/test-handoff-preamble.js.map +1 -0
- package/src/scripts/test-handoff-steering.js.map +1 -0
- package/src/scripts/test-handoff-steering.ts +3 -3
- package/src/scripts/test-multi-agent-list-handoff.js.map +1 -0
- package/src/scripts/test-multi-agent-list-handoff.ts +1 -1
- package/src/scripts/test-parallel-agent-labeling.js.map +1 -0
- package/src/scripts/test-parallel-agent-labeling.ts +3 -3
- package/src/scripts/test-parallel-handoffs.js.map +1 -0
- package/src/scripts/test-parallel-handoffs.ts +2 -2
- package/src/scripts/test-thinking-handoff-bedrock.js.map +1 -0
- package/src/scripts/test-thinking-handoff-bedrock.ts +1 -1
- package/src/scripts/test-thinking-handoff.js.map +1 -0
- package/src/scripts/test-thinking-handoff.ts +1 -1
- package/src/scripts/test-thinking-to-thinking-handoff-bedrock.js.map +1 -0
- package/src/scripts/test-thinking-to-thinking-handoff-bedrock.ts +1 -1
- package/src/scripts/test-tool-before-handoff-role-order.js.map +1 -0
- package/src/scripts/test-tool-before-handoff-role-order.ts +1 -1
- package/src/scripts/test-tools-before-handoff.js.map +1 -0
- package/src/scripts/test-tools-before-handoff.ts +1 -1
- package/src/scripts/test_code_api.js.map +1 -0
- package/src/scripts/thinking-bedrock.js.map +1 -0
- package/src/scripts/thinking-vertexai.js.map +1 -0
- package/src/scripts/thinking.js.map +1 -0
- package/src/scripts/tool_search.js.map +1 -0
- package/src/scripts/tools.js.map +1 -0
- package/src/specs/agent-handoffs-bedrock.integration.test.js.map +1 -0
- package/src/specs/agent-handoffs.test.js.map +1 -0
- package/src/specs/agent-handoffs.test.ts +26 -483
- package/src/specs/anthropic.simple.test.js.map +1 -0
- package/src/specs/anthropic.simple.test.ts +61 -0
- package/src/specs/azure.simple.test.js.map +1 -0
- package/src/specs/cache.simple.test.js.map +1 -0
- package/src/specs/custom-event-await.test.js.map +1 -0
- package/src/specs/deepseek.simple.test.js.map +1 -0
- package/src/specs/emergency-prune.test.js.map +1 -0
- package/src/specs/moonshot.simple.test.js.map +1 -0
- package/src/specs/multi-agent-summarization.test.ts +396 -0
- package/src/specs/observability.integration.test.js.map +1 -0
- package/src/specs/openai.simple.test.js.map +1 -0
- package/src/specs/openrouter.simple.test.js.map +1 -0
- package/src/specs/prune.orphans.test.ts +248 -0
- package/src/specs/prune.test.js.map +1 -0
- package/src/specs/prune.test.ts +104 -16
- package/src/specs/reasoning.test.js.map +1 -0
- package/src/specs/spec.utils.js.map +1 -0
- package/src/specs/thinking-handoff.test.js.map +1 -0
- package/src/specs/thinking-handoff.test.ts +19 -19
- package/src/specs/thinking-prune.test.js.map +1 -0
- package/src/specs/token-distribution-edge-case.test.js.map +1 -0
- package/src/specs/token-memoization.test.js.map +1 -0
- package/src/specs/tokens.test.js.map +1 -0
- package/src/specs/tool-error.test.js.map +1 -0
- package/src/splitStream.js.map +1 -0
- package/src/splitStream.test.js.map +1 -0
- package/src/stream.js.map +1 -0
- package/src/stream.test.js.map +1 -0
- package/src/test/mockTools.js.map +1 -0
- package/src/tools/BashExecutor.ts +281 -0
- package/src/tools/BashProgrammaticToolCalling.ts +397 -0
- package/src/tools/BrowserTools.js.map +1 -0
- package/src/tools/Calculator.js.map +1 -0
- package/src/tools/Calculator.test.js.map +1 -0
- package/src/tools/CodeExecutor.js.map +1 -0
- package/src/tools/CodeExecutor.ts +62 -54
- package/src/tools/ProgrammaticToolCalling.js.map +1 -0
- package/src/tools/ProgrammaticToolCalling.ts +29 -14
- package/src/tools/ReadFile.ts +39 -0
- package/src/tools/SkillTool.ts +46 -0
- package/src/tools/StreamingToolCallBuffer.js.map +1 -0
- package/src/tools/SubagentTool.ts +100 -0
- package/src/tools/ToolNode.js.map +1 -0
- package/src/tools/ToolNode.ts +548 -26
- package/src/tools/ToolSearch.js.map +1 -0
- package/src/tools/__tests__/BashExecutor.test.ts +49 -0
- package/src/tools/__tests__/BrowserTools.test.js.map +1 -0
- package/src/tools/__tests__/CodeExecutor.test.ts +37 -36
- package/src/tools/__tests__/ProgrammaticToolCalling.integration.test.js.map +1 -0
- package/src/tools/__tests__/ProgrammaticToolCalling.test.js.map +1 -0
- package/src/tools/__tests__/ProgrammaticToolCalling.test.ts +60 -0
- package/src/tools/__tests__/ReadFile.test.ts +44 -0
- package/src/tools/__tests__/SkillTool.test.ts +442 -0
- package/src/tools/__tests__/StreamingToolCallBuffer.test.js.map +1 -0
- package/src/tools/__tests__/SubagentExecutor.test.ts +1148 -0
- package/src/tools/__tests__/SubagentTool.test.ts +149 -0
- package/src/tools/__tests__/ToolApproval.test.js.map +1 -0
- package/src/tools/__tests__/ToolNode.outputReferences.test.ts +1438 -0
- package/src/tools/__tests__/ToolNode.recovery.test.js.map +1 -0
- package/src/tools/__tests__/ToolNode.session.test.js.map +1 -0
- package/src/tools/__tests__/ToolSearch.integration.test.js.map +1 -0
- package/src/tools/__tests__/ToolSearch.test.js.map +1 -0
- package/src/tools/__tests__/annotateMessagesForLLM.test.ts +479 -0
- package/src/tools/__tests__/handlers.test.js.map +1 -0
- package/src/tools/__tests__/skillCatalog.test.ts +161 -0
- package/src/tools/__tests__/subagentHooks.test.ts +210 -0
- package/src/tools/__tests__/toolOutputReferences.test.ts +415 -0
- package/src/tools/__tests__/truncation-recovery.integration.test.js.map +1 -0
- package/src/tools/handlers.js.map +1 -0
- package/src/tools/schema.js.map +1 -0
- package/src/tools/search/anthropic.js.map +1 -0
- package/src/tools/search/content.js.map +1 -0
- package/src/tools/search/content.test.js.map +1 -0
- package/src/tools/search/firecrawl.js.map +1 -0
- package/src/tools/search/format.js.map +1 -0
- package/src/tools/search/highlights.js.map +1 -0
- package/src/tools/search/index.js.map +1 -0
- package/src/tools/search/jina-reranker.test.js.map +1 -0
- package/src/tools/search/rerankers.js.map +1 -0
- package/src/tools/search/schema.js.map +1 -0
- package/src/tools/search/search.js.map +1 -0
- package/src/tools/search/search.ts +12 -2
- package/src/tools/search/serper-scraper.js.map +1 -0
- package/src/tools/search/tavily-scraper.ts +235 -0
- package/src/tools/search/tavily-search.ts +424 -0
- package/src/tools/search/tavily.test.ts +965 -0
- package/src/tools/search/test.js.map +1 -0
- package/src/tools/search/tool.js.map +1 -0
- package/src/tools/search/tool.ts +36 -2
- package/src/tools/search/types.js.map +1 -0
- package/src/tools/search/types.ts +133 -8
- package/src/tools/search/utils.js.map +1 -0
- package/src/tools/search/utils.ts +13 -5
- package/src/tools/skillCatalog.ts +126 -0
- package/src/tools/subagent/SubagentExecutor.ts +676 -0
- package/src/tools/subagent/index.ts +13 -0
- package/src/tools/subagent/types.test.ts +70 -0
- package/src/tools/subagent/types.ts +115 -0
- package/src/tools/toolOutputReferences.ts +825 -0
- package/src/types/agent-cache.ts +73 -0
- package/src/types/graph.js.map +1 -0
- package/src/types/graph.test.js.map +1 -0
- package/src/types/graph.ts +171 -20
- package/src/types/index.js.map +1 -0
- package/src/types/index.ts +3 -0
- package/src/types/llm.js.map +1 -0
- package/src/types/messages.js.map +1 -0
- package/src/types/messages.ts +27 -0
- package/src/types/run.js.map +1 -0
- package/src/types/run.ts +22 -0
- package/src/types/skill.ts +11 -0
- package/src/types/stream.js.map +1 -0
- package/src/types/tools.js.map +1 -0
- package/src/types/tools.ts +118 -0
- package/src/utils/__tests__/truncation.test.ts +66 -0
- package/src/utils/contextAnalytics.js.map +1 -0
- package/src/utils/contextAnalytics.test.js.map +1 -0
- package/src/utils/events.js.map +1 -0
- package/src/utils/graph.js.map +1 -0
- package/src/utils/handlers.js.map +1 -0
- package/src/utils/index.js.map +1 -0
- package/src/utils/index.ts +1 -3
- package/src/utils/llm.js.map +1 -0
- package/src/utils/llmConfig.js.map +1 -0
- package/src/utils/logging.js.map +1 -0
- package/src/utils/misc.js.map +1 -0
- package/src/utils/run.js.map +1 -0
- package/src/utils/schema.js.map +1 -0
- package/src/utils/title.js.map +1 -0
- package/src/utils/tokens.js.map +1 -0
- package/src/utils/toonFormat.js.map +1 -0
- package/src/utils/truncation.ts +154 -0
- package/dist/cjs/common/spawnPath.cjs +0 -104
- package/dist/cjs/common/spawnPath.cjs.map +0 -1
- package/dist/cjs/content/ArtifactStore.cjs +0 -579
- package/dist/cjs/content/ArtifactStore.cjs.map +0 -1
- package/dist/cjs/content/ContentStore.cjs +0 -638
- package/dist/cjs/content/ContentStore.cjs.map +0 -1
- package/dist/cjs/content/contentAnalyzer.cjs +0 -91
- package/dist/cjs/content/contentAnalyzer.cjs.map +0 -1
- package/dist/cjs/content/index.cjs +0 -20
- package/dist/cjs/content/index.cjs.map +0 -1
- package/dist/cjs/content/mcpAutoCache.cjs +0 -115
- package/dist/cjs/content/mcpAutoCache.cjs.map +0 -1
- package/dist/cjs/graphs/HandoffRegistry.cjs +0 -143
- package/dist/cjs/graphs/HandoffRegistry.cjs.map +0 -1
- package/dist/cjs/providers/a2a/A2ACapabilityProvider.cjs +0 -288
- package/dist/cjs/providers/a2a/A2ACapabilityProvider.cjs.map +0 -1
- package/dist/cjs/providers/a2a/client.cjs +0 -92
- package/dist/cjs/providers/a2a/client.cjs.map +0 -1
- package/dist/cjs/providers/a2a/config.cjs +0 -38
- package/dist/cjs/providers/a2a/config.cjs.map +0 -1
- package/dist/cjs/providers/capabilityNaming.cjs +0 -43
- package/dist/cjs/providers/capabilityNaming.cjs.map +0 -1
- package/dist/cjs/providers/mcp/MCPCapabilityProvider.cjs +0 -244
- package/dist/cjs/providers/mcp/MCPCapabilityProvider.cjs.map +0 -1
- package/dist/cjs/providers/mcp/config.cjs +0 -42
- package/dist/cjs/providers/mcp/config.cjs.map +0 -1
- package/dist/cjs/providers/mcp/transport.cjs +0 -65
- package/dist/cjs/providers/mcp/transport.cjs.map +0 -1
- package/dist/cjs/providers/tools-server/ToolsServerCapabilityProvider.cjs +0 -128
- package/dist/cjs/providers/tools-server/ToolsServerCapabilityProvider.cjs.map +0 -1
- package/dist/cjs/providers/types.cjs +0 -51
- package/dist/cjs/providers/types.cjs.map +0 -1
- package/dist/cjs/tools/artifacts/schema.cjs +0 -86
- package/dist/cjs/tools/artifacts/schema.cjs.map +0 -1
- package/dist/cjs/tools/artifacts/tool.cjs +0 -219
- package/dist/cjs/tools/artifacts/tool.cjs.map +0 -1
- package/dist/cjs/tools/fileSearch/formatter.cjs +0 -93
- package/dist/cjs/tools/fileSearch/formatter.cjs.map +0 -1
- package/dist/cjs/tools/fileSearch/ragClient.cjs +0 -102
- package/dist/cjs/tools/fileSearch/ragClient.cjs.map +0 -1
- package/dist/cjs/tools/fileSearch/schema.cjs +0 -18
- package/dist/cjs/tools/fileSearch/schema.cjs.map +0 -1
- package/dist/cjs/tools/fileSearch/tool.cjs +0 -155
- package/dist/cjs/tools/fileSearch/tool.cjs.map +0 -1
- package/dist/cjs/tools/proxyTool.cjs +0 -102
- package/dist/cjs/tools/proxyTool.cjs.map +0 -1
- package/dist/cjs/utils/childAgentContext.cjs +0 -242
- package/dist/cjs/utils/childAgentContext.cjs.map +0 -1
- package/dist/cjs/utils/credentials.cjs +0 -142
- package/dist/cjs/utils/credentials.cjs.map +0 -1
- package/dist/cjs/utils/httpClient.cjs +0 -74
- package/dist/cjs/utils/httpClient.cjs.map +0 -1
- package/dist/cjs/utils/toolManifest.cjs +0 -100
- package/dist/cjs/utils/toolManifest.cjs.map +0 -1
- package/dist/esm/common/spawnPath.mjs +0 -95
- package/dist/esm/common/spawnPath.mjs.map +0 -1
- package/dist/esm/content/ArtifactStore.mjs +0 -576
- package/dist/esm/content/ArtifactStore.mjs.map +0 -1
- package/dist/esm/content/ContentStore.mjs +0 -635
- package/dist/esm/content/ContentStore.mjs.map +0 -1
- package/dist/esm/content/contentAnalyzer.mjs +0 -87
- package/dist/esm/content/contentAnalyzer.mjs.map +0 -1
- package/dist/esm/content/index.mjs +0 -5
- package/dist/esm/content/mcpAutoCache.mjs +0 -111
- package/dist/esm/content/mcpAutoCache.mjs.map +0 -1
- package/dist/esm/graphs/HandoffRegistry.mjs +0 -141
- package/dist/esm/graphs/HandoffRegistry.mjs.map +0 -1
- package/dist/esm/providers/a2a/A2ACapabilityProvider.mjs +0 -281
- package/dist/esm/providers/a2a/A2ACapabilityProvider.mjs.map +0 -1
- package/dist/esm/providers/a2a/client.mjs +0 -88
- package/dist/esm/providers/a2a/client.mjs.map +0 -1
- package/dist/esm/providers/a2a/config.mjs +0 -35
- package/dist/esm/providers/a2a/config.mjs.map +0 -1
- package/dist/esm/providers/capabilityNaming.mjs +0 -39
- package/dist/esm/providers/capabilityNaming.mjs.map +0 -1
- package/dist/esm/providers/mcp/MCPCapabilityProvider.mjs +0 -240
- package/dist/esm/providers/mcp/MCPCapabilityProvider.mjs.map +0 -1
- package/dist/esm/providers/mcp/config.mjs +0 -39
- package/dist/esm/providers/mcp/config.mjs.map +0 -1
- package/dist/esm/providers/mcp/transport.mjs +0 -63
- package/dist/esm/providers/mcp/transport.mjs.map +0 -1
- package/dist/esm/providers/tools-server/ToolsServerCapabilityProvider.mjs +0 -126
- package/dist/esm/providers/tools-server/ToolsServerCapabilityProvider.mjs.map +0 -1
- package/dist/esm/providers/types.mjs +0 -51
- package/dist/esm/providers/types.mjs.map +0 -1
- package/dist/esm/tools/artifacts/schema.mjs +0 -79
- package/dist/esm/tools/artifacts/schema.mjs.map +0 -1
- package/dist/esm/tools/artifacts/tool.mjs +0 -213
- package/dist/esm/tools/artifacts/tool.mjs.map +0 -1
- package/dist/esm/tools/fileSearch/formatter.mjs +0 -90
- package/dist/esm/tools/fileSearch/formatter.mjs.map +0 -1
- package/dist/esm/tools/fileSearch/ragClient.mjs +0 -98
- package/dist/esm/tools/fileSearch/ragClient.mjs.map +0 -1
- package/dist/esm/tools/fileSearch/schema.mjs +0 -15
- package/dist/esm/tools/fileSearch/schema.mjs.map +0 -1
- package/dist/esm/tools/fileSearch/tool.mjs +0 -152
- package/dist/esm/tools/fileSearch/tool.mjs.map +0 -1
- package/dist/esm/tools/proxyTool.mjs +0 -100
- package/dist/esm/tools/proxyTool.mjs.map +0 -1
- package/dist/esm/utils/childAgentContext.mjs +0 -237
- package/dist/esm/utils/childAgentContext.mjs.map +0 -1
- package/dist/esm/utils/credentials.mjs +0 -135
- package/dist/esm/utils/credentials.mjs.map +0 -1
- package/dist/esm/utils/httpClient.mjs +0 -70
- package/dist/esm/utils/httpClient.mjs.map +0 -1
- package/dist/esm/utils/toolManifest.mjs +0 -96
- package/dist/esm/utils/toolManifest.mjs.map +0 -1
- package/dist/types/common/spawnPath.d.ts +0 -59
- package/dist/types/content/ArtifactStore.d.ts +0 -223
- package/dist/types/content/ContentStore.d.ts +0 -140
- package/dist/types/content/contentAnalyzer.d.ts +0 -38
- package/dist/types/content/index.d.ts +0 -24
- package/dist/types/content/mcpAutoCache.d.ts +0 -89
- package/dist/types/content/types.d.ts +0 -75
- package/dist/types/graphs/HandoffRegistry.d.ts +0 -97
- package/dist/types/providers/a2a/A2ACapabilityProvider.d.ts +0 -89
- package/dist/types/providers/a2a/client.d.ts +0 -47
- package/dist/types/providers/a2a/config.d.ts +0 -18
- package/dist/types/providers/a2a/index.d.ts +0 -6
- package/dist/types/providers/a2a/types.d.ts +0 -173
- package/dist/types/providers/capabilityNaming.d.ts +0 -25
- package/dist/types/providers/index.d.ts +0 -12
- package/dist/types/providers/mcp/MCPCapabilityProvider.d.ts +0 -54
- package/dist/types/providers/mcp/config.d.ts +0 -20
- package/dist/types/providers/mcp/index.d.ts +0 -5
- package/dist/types/providers/mcp/transport.d.ts +0 -18
- package/dist/types/providers/mcp/types.d.ts +0 -112
- package/dist/types/providers/tools-server/ToolsServerCapabilityProvider.d.ts +0 -59
- package/dist/types/providers/tools-server/index.d.ts +0 -1
- package/dist/types/providers/types.d.ts +0 -184
- package/dist/types/tools/artifacts/index.d.ts +0 -3
- package/dist/types/tools/artifacts/schema.d.ts +0 -63
- package/dist/types/tools/artifacts/tool.d.ts +0 -16
- package/dist/types/tools/artifacts/types.d.ts +0 -127
- package/dist/types/tools/fileSearch/formatter.d.ts +0 -25
- package/dist/types/tools/fileSearch/index.d.ts +0 -5
- package/dist/types/tools/fileSearch/ragClient.d.ts +0 -32
- package/dist/types/tools/fileSearch/schema.d.ts +0 -13
- package/dist/types/tools/fileSearch/tool.d.ts +0 -18
- package/dist/types/tools/fileSearch/types.d.ts +0 -139
- package/dist/types/tools/proxyTool.d.ts +0 -62
- package/dist/types/utils/childAgentContext.d.ts +0 -99
- package/dist/types/utils/credentials.d.ts +0 -77
- package/dist/types/utils/httpClient.d.ts +0 -46
- package/dist/types/utils/toolManifest.d.ts +0 -49
- package/src/common/__tests__/spawnPath.test.ts +0 -110
- package/src/common/spawnPath.ts +0 -101
- package/src/content/ArtifactStore.ts +0 -782
- package/src/content/ContentStore.ts +0 -753
- package/src/content/contentAnalyzer.ts +0 -105
- package/src/content/index.ts +0 -51
- package/src/content/mcpAutoCache.ts +0 -185
- package/src/content/types.ts +0 -82
- package/src/graphs/HandoffRegistry.ts +0 -199
- package/src/graphs/__tests__/HandoffRegistry.test.ts +0 -410
- package/src/graphs/__tests__/multi-agent-delegate.test.ts +0 -458
- package/src/graphs/__tests__/multi-agent-edges.test.ts +0 -276
- package/src/graphs/__tests__/multi-agent-nested-subgraph.test.ts +0 -221
- package/src/graphs/handoffValidation.test.ts +0 -353
- package/src/providers/__tests__/ToolsServerCapabilityProvider.integration.spec.ts +0 -79
- package/src/providers/__tests__/ToolsServerCapabilityProvider.test.ts +0 -271
- package/src/providers/__tests__/types.test.ts +0 -64
- package/src/providers/a2a/A2ACapabilityProvider.ts +0 -384
- package/src/providers/a2a/__tests__/A2ACapabilityProvider.integration.spec.ts +0 -345
- package/src/providers/a2a/__tests__/A2ACapabilityProvider.test.ts +0 -460
- package/src/providers/a2a/client.ts +0 -115
- package/src/providers/a2a/config.ts +0 -40
- package/src/providers/a2a/index.ts +0 -29
- package/src/providers/a2a/types.ts +0 -191
- package/src/providers/capabilityNaming.ts +0 -42
- package/src/providers/index.ts +0 -68
- package/src/providers/mcp/MCPCapabilityProvider.ts +0 -345
- package/src/providers/mcp/__tests__/MCPCapabilityProvider.integration.spec.ts +0 -386
- package/src/providers/mcp/__tests__/MCPCapabilityProvider.test.ts +0 -371
- package/src/providers/mcp/config.ts +0 -45
- package/src/providers/mcp/index.ts +0 -21
- package/src/providers/mcp/transport.ts +0 -76
- package/src/providers/mcp/types.ts +0 -139
- package/src/providers/tools-server/ToolsServerCapabilityProvider.ts +0 -249
- package/src/providers/tools-server/index.ts +0 -1
- package/src/providers/types.ts +0 -204
- package/src/scripts/test-bedrock-handoff-autonomous.ts +0 -267
- package/src/scripts/test-handoff-preamble.ts +0 -278
- package/src/specs/agent-handoffs-bedrock.integration.test.ts +0 -415
- package/src/tools/artifacts/__tests__/tool.test.ts +0 -259
- package/src/tools/artifacts/index.ts +0 -33
- package/src/tools/artifacts/schema.ts +0 -99
- package/src/tools/artifacts/tool.ts +0 -289
- package/src/tools/artifacts/types.ts +0 -162
- package/src/tools/fileSearch/__tests__/tool.test.ts +0 -261
- package/src/tools/fileSearch/formatter.ts +0 -129
- package/src/tools/fileSearch/index.ts +0 -23
- package/src/tools/fileSearch/ragClient.ts +0 -137
- package/src/tools/fileSearch/schema.ts +0 -19
- package/src/tools/fileSearch/tool.ts +0 -207
- package/src/tools/fileSearch/types.ts +0 -149
- package/src/tools/proxyTool.ts +0 -166
- package/src/utils/__tests__/childAgentContext.test.ts +0 -217
- package/src/utils/__tests__/credentials.test.ts +0 -130
- package/src/utils/__tests__/httpClient.test.ts +0 -75
- package/src/utils/__tests__/toolManifest.test.ts +0 -116
- package/src/utils/childAgentContext.ts +0 -259
- package/src/utils/credentials.ts +0 -157
- package/src/utils/httpClient.ts +0 -92
- package/src/utils/toolManifest.ts +0 -109
- /package/dist/esm/{content → langchain}/index.mjs.map +0 -0
|
@@ -1,638 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
var crypto = require('node:crypto');
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Default 3-minute TTL for ephemeral content entries. Resets on every
|
|
7
|
-
* access. Kept short to reduce cache-backing memory pressure — callers
|
|
8
|
-
* that persist to durable storage (see {@link ArtifactStore}) rely on
|
|
9
|
-
* lazy restore from the durable backend on cache miss.
|
|
10
|
-
*
|
|
11
|
-
* Exported so consumers can construct their injected {@link Keyv}
|
|
12
|
-
* instance with a matching TTL without hard-coding the number.
|
|
13
|
-
*/
|
|
14
|
-
const CONTENT_TTL_MS = 180_000;
|
|
15
|
-
/** Default number of lines returned by readLines(). */
|
|
16
|
-
const DEFAULT_READ_LINES = 200;
|
|
17
|
-
/** Maximum lines that can be read in a single call. */
|
|
18
|
-
const MAX_READ_LINES = 500;
|
|
19
|
-
/** Maximum search results returned per call. */
|
|
20
|
-
const MAX_SEARCH_RESULTS = 50;
|
|
21
|
-
/** Lines of context to show around a failed edit match for diagnostics. */
|
|
22
|
-
const ERROR_CONTEXT_LINES = 5;
|
|
23
|
-
/**
|
|
24
|
-
* Normalize line endings: CRLF → LF, stray CR → LF.
|
|
25
|
-
* Prevents invisible mismatches when content originates from Windows/Office tools.
|
|
26
|
-
*/
|
|
27
|
-
function normalizeNewlines(text) {
|
|
28
|
-
return text.replace(/\r\n/g, '\n').replace(/\r/g, '\n');
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Trim trailing whitespace from each line — used as a fallback when
|
|
32
|
-
* exact matching fails due to invisible trailing spaces.
|
|
33
|
-
*/
|
|
34
|
-
function trimTrailingPerLine(text) {
|
|
35
|
-
return text
|
|
36
|
-
.split('\n')
|
|
37
|
-
.map((l) => l.trimEnd())
|
|
38
|
-
.join('\n');
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Fuzzy indentation-normalized matching. Compares line content after stripping
|
|
42
|
-
* all leading whitespace, then maps back to the real line range in the content.
|
|
43
|
-
* Returns `{ start, end }` character offsets in `content` if a unique match is found,
|
|
44
|
-
* or `null` if no match or ambiguous (multiple matches).
|
|
45
|
-
*/
|
|
46
|
-
function findIndentationNormalizedMatch(content, oldStr) {
|
|
47
|
-
const contentLines = content.split('\n');
|
|
48
|
-
const oldLines = oldStr.split('\n');
|
|
49
|
-
// Strip leading whitespace for comparison — keep non-empty lines only for matching key
|
|
50
|
-
const oldTrimmed = oldLines.map((l) => l.trimStart());
|
|
51
|
-
// Need at least 1 non-empty line to match on
|
|
52
|
-
const nonEmptyOldLines = oldTrimmed.filter((l) => l.length > 0);
|
|
53
|
-
if (nonEmptyOldLines.length === 0)
|
|
54
|
-
return null;
|
|
55
|
-
const matches = [];
|
|
56
|
-
// Slide a window of oldLines.length across contentLines
|
|
57
|
-
for (let i = 0; i <= contentLines.length - oldLines.length; i++) {
|
|
58
|
-
let matched = true;
|
|
59
|
-
for (let j = 0; j < oldLines.length; j++) {
|
|
60
|
-
const contentTrimmed = contentLines[i + j].trimStart();
|
|
61
|
-
if (contentTrimmed !== oldTrimmed[j]) {
|
|
62
|
-
matched = false;
|
|
63
|
-
break;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
if (matched) {
|
|
67
|
-
// Calculate character offsets for the matched region
|
|
68
|
-
let charStart = 0;
|
|
69
|
-
for (let k = 0; k < i; k++) {
|
|
70
|
-
charStart += contentLines[k].length + 1; // +1 for \n
|
|
71
|
-
}
|
|
72
|
-
let charEnd = charStart;
|
|
73
|
-
for (let k = 0; k < oldLines.length; k++) {
|
|
74
|
-
charEnd +=
|
|
75
|
-
contentLines[i + k].length + (k < oldLines.length - 1 ? 1 : 0);
|
|
76
|
-
}
|
|
77
|
-
matches.push({ start: charStart, end: charEnd });
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
// Only return if exactly one match (unambiguous)
|
|
81
|
-
return matches.length === 1 ? matches[0] : null;
|
|
82
|
-
}
|
|
83
|
-
/** Minimum fraction of lines that must match for partial fuzzy matching. */
|
|
84
|
-
const FUZZY_MATCH_THRESHOLD = 0.6;
|
|
85
|
-
/**
|
|
86
|
-
* Partial fuzzy matching — tolerates some lines being slightly different.
|
|
87
|
-
* LLMs often reconstruct code from memory with subtle differences on a few lines
|
|
88
|
-
* (e.g., changed variable name, missing semicolon). This layer finds the best-scoring
|
|
89
|
-
* region where at least FUZZY_MATCH_THRESHOLD of lines match after trimming.
|
|
90
|
-
*
|
|
91
|
-
* Returns `{ start, end }` character offsets if a single high-confidence region is found.
|
|
92
|
-
*/
|
|
93
|
-
function findPartialFuzzyMatch(content, oldStr) {
|
|
94
|
-
const contentLines = content.split('\n');
|
|
95
|
-
const oldLines = oldStr.split('\n');
|
|
96
|
-
// Need at least 3 lines for fuzzy matching to be meaningful
|
|
97
|
-
if (oldLines.length < 3)
|
|
98
|
-
return null;
|
|
99
|
-
const oldTrimmed = oldLines.map((l) => l.trim());
|
|
100
|
-
const minScore = Math.ceil(oldLines.length * FUZZY_MATCH_THRESHOLD);
|
|
101
|
-
let bestScore = 0;
|
|
102
|
-
let bestIdx = -1;
|
|
103
|
-
let secondBestScore = 0;
|
|
104
|
-
for (let i = 0; i <= contentLines.length - oldLines.length; i++) {
|
|
105
|
-
let score = 0;
|
|
106
|
-
for (let j = 0; j < oldLines.length; j++) {
|
|
107
|
-
const contentTrimmed = contentLines[i + j].trim();
|
|
108
|
-
// Exact match after trimming all whitespace
|
|
109
|
-
if (contentTrimmed === oldTrimmed[j]) {
|
|
110
|
-
score++;
|
|
111
|
-
}
|
|
112
|
-
else if (
|
|
113
|
-
// Substring match — one contains the other (handles minor edits)
|
|
114
|
-
contentTrimmed.length > 0 &&
|
|
115
|
-
oldTrimmed[j].length > 0 &&
|
|
116
|
-
(contentTrimmed.includes(oldTrimmed[j]) ||
|
|
117
|
-
oldTrimmed[j].includes(contentTrimmed))) {
|
|
118
|
-
score += 0.5;
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
if (score > bestScore) {
|
|
122
|
-
secondBestScore = bestScore;
|
|
123
|
-
bestScore = score;
|
|
124
|
-
bestIdx = i;
|
|
125
|
-
}
|
|
126
|
-
else if (score > secondBestScore) {
|
|
127
|
-
secondBestScore = score;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
// Require: meets threshold AND is clearly better than second-best (unique match)
|
|
131
|
-
if (bestIdx < 0 ||
|
|
132
|
-
bestScore < minScore ||
|
|
133
|
-
secondBestScore >= bestScore * 0.9) {
|
|
134
|
-
return null;
|
|
135
|
-
}
|
|
136
|
-
// Calculate character offsets
|
|
137
|
-
let charStart = 0;
|
|
138
|
-
for (let k = 0; k < bestIdx; k++) {
|
|
139
|
-
charStart += contentLines[k].length + 1;
|
|
140
|
-
}
|
|
141
|
-
let charEnd = charStart;
|
|
142
|
-
for (let k = 0; k < oldLines.length; k++) {
|
|
143
|
-
charEnd +=
|
|
144
|
-
contentLines[bestIdx + k].length + (k < oldLines.length - 1 ? 1 : 0);
|
|
145
|
-
}
|
|
146
|
-
return { start: charStart, end: charEnd };
|
|
147
|
-
}
|
|
148
|
-
/**
|
|
149
|
-
* Find the best approximate match location for `needle` in `haystack` using
|
|
150
|
-
* overlapping line content. Returns the 1-based line number of the best match
|
|
151
|
-
* region, or 0 if no reasonable overlap is found.
|
|
152
|
-
*/
|
|
153
|
-
function findApproximateLocation(haystack, needle) {
|
|
154
|
-
const needleLines = needle
|
|
155
|
-
.split('\n')
|
|
156
|
-
.map((l) => l.trim())
|
|
157
|
-
.filter(Boolean);
|
|
158
|
-
if (needleLines.length === 0)
|
|
159
|
-
return 0;
|
|
160
|
-
const haystackLines = haystack.split('\n');
|
|
161
|
-
let bestScore = 0;
|
|
162
|
-
let bestLine = 0;
|
|
163
|
-
for (let i = 0; i < haystackLines.length; i++) {
|
|
164
|
-
let score = 0;
|
|
165
|
-
for (let j = 0; j < needleLines.length && i + j < haystackLines.length; j++) {
|
|
166
|
-
if (haystackLines[i + j].trim().includes(needleLines[j]) ||
|
|
167
|
-
needleLines[j].includes(haystackLines[i + j].trim())) {
|
|
168
|
-
score++;
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
if (score > bestScore) {
|
|
172
|
-
bestScore = score;
|
|
173
|
-
bestLine = i + 1; // 1-based
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
// Require at least 1 matching line to report a location
|
|
177
|
-
return bestScore >= 1 ? bestLine : 0;
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* Build a diagnostic error message showing nearby content when an edit match fails.
|
|
181
|
-
*/
|
|
182
|
-
function buildEditDiagnostic(content, oldStr) {
|
|
183
|
-
const approxLine = findApproximateLocation(content, oldStr);
|
|
184
|
-
const lines = content.split('\n');
|
|
185
|
-
let contextSnippet = '';
|
|
186
|
-
if (approxLine > 0) {
|
|
187
|
-
const start = Math.max(0, approxLine - 1 - Math.floor(ERROR_CONTEXT_LINES / 2));
|
|
188
|
-
const end = Math.min(lines.length, start + ERROR_CONTEXT_LINES);
|
|
189
|
-
const padWidth = String(end).length;
|
|
190
|
-
const snippet = lines
|
|
191
|
-
.slice(start, end)
|
|
192
|
-
.map((l, i) => `${String(start + i + 1).padStart(padWidth, ' ')} | ${l}`)
|
|
193
|
-
.join('\n');
|
|
194
|
-
contextSnippet = `\nNearest content (around line ${approxLine}):\n${snippet}`;
|
|
195
|
-
}
|
|
196
|
-
return `old_str not found in content. Re-read the file with content_tool read before retrying.${contextSnippet}`;
|
|
197
|
-
}
|
|
198
|
-
/**
|
|
199
|
-
* Strip line-number prefixes (" N | ") that readLines() adds.
|
|
200
|
-
* Agents may copy these when constructing old_str for edits.
|
|
201
|
-
*/
|
|
202
|
-
function stripLineNumberPrefixes(text) {
|
|
203
|
-
return text
|
|
204
|
-
.split('\n')
|
|
205
|
-
.map((line) => {
|
|
206
|
-
const match = line.match(/^\s*\d+\s*\|\s?(.*)/);
|
|
207
|
-
return match ? match[1] : line;
|
|
208
|
-
})
|
|
209
|
-
.join('\n');
|
|
210
|
-
}
|
|
211
|
-
/**
|
|
212
|
-
* Generates a short, URL-safe random ID.
|
|
213
|
-
* @param length - Number of random bytes (output is hex, so 2x chars). Default 5 → 10 hex chars.
|
|
214
|
-
*/
|
|
215
|
-
function generateId(length = 5) {
|
|
216
|
-
return crypto.randomBytes(length).toString('hex');
|
|
217
|
-
}
|
|
218
|
-
/**
|
|
219
|
-
* Per-conversation content store backed by a caller-provided {@link Keyv}
|
|
220
|
-
* cache (typically Keyv + @keyv/redis, with in-memory fallback).
|
|
221
|
-
*
|
|
222
|
-
* Stores large content (MCP results, artifacts, agent-generated text)
|
|
223
|
-
* outside the LLM context window. Entries inherit the TTL configured on
|
|
224
|
-
* the injected {@link Keyv} instance — {@link CONTENT_TTL_MS} is the
|
|
225
|
-
* recommended default.
|
|
226
|
-
*
|
|
227
|
-
* The caller is responsible for namespacing the Keyv instance per
|
|
228
|
-
* conversation so content_ids don't collide across threads.
|
|
229
|
-
*
|
|
230
|
-
* @example
|
|
231
|
-
* ```ts
|
|
232
|
-
* import Keyv from 'keyv';
|
|
233
|
-
* const cache = new Keyv({ namespace: `content-store::${conversationId}`, ttl: CONTENT_TTL_MS });
|
|
234
|
-
* const store = new ContentStore(cache);
|
|
235
|
-
* const id = await store.store({ name: 'report.csv', type: 'text/plain', content: csv, source: 'mcp:sharepoint' });
|
|
236
|
-
* const result = await store.readLines(id, 1, 50);
|
|
237
|
-
* ```
|
|
238
|
-
*/
|
|
239
|
-
class ContentStore {
|
|
240
|
-
cache;
|
|
241
|
-
indexKey = '_index';
|
|
242
|
-
/**
|
|
243
|
-
* @param cache - A pre-namespaced {@link Keyv} instance. The store
|
|
244
|
-
* writes both content entries and a per-store `_index` key, so
|
|
245
|
-
* callers MUST namespace the Keyv per conversation to avoid
|
|
246
|
-
* cross-thread collisions.
|
|
247
|
-
*/
|
|
248
|
-
constructor(cache) {
|
|
249
|
-
this.cache = cache;
|
|
250
|
-
}
|
|
251
|
-
/**
|
|
252
|
-
* Store new content and return a content ID.
|
|
253
|
-
* @param entry - The content to store with metadata.
|
|
254
|
-
* @returns The generated content ID.
|
|
255
|
-
*/
|
|
256
|
-
async store(entry) {
|
|
257
|
-
const id = generateId();
|
|
258
|
-
const lines = entry.content.split('\n');
|
|
259
|
-
const metadata = {
|
|
260
|
-
id,
|
|
261
|
-
name: entry.name,
|
|
262
|
-
type: entry.type,
|
|
263
|
-
source: entry.source,
|
|
264
|
-
totalLines: lines.length,
|
|
265
|
-
totalChars: entry.content.length,
|
|
266
|
-
createdAt: Date.now(),
|
|
267
|
-
};
|
|
268
|
-
const stored = { content: entry.content, metadata };
|
|
269
|
-
await this.cache.set(id, JSON.stringify(stored));
|
|
270
|
-
// Update the index
|
|
271
|
-
const index = await this.getIndex();
|
|
272
|
-
index[id] = metadata;
|
|
273
|
-
await this.cache.set(this.indexKey, JSON.stringify(index));
|
|
274
|
-
return id;
|
|
275
|
-
}
|
|
276
|
-
/**
|
|
277
|
-
* Get metadata for a content entry without loading the full content.
|
|
278
|
-
* @param contentId - The content entry ID.
|
|
279
|
-
* @returns Metadata or null if not found.
|
|
280
|
-
*/
|
|
281
|
-
async info(contentId) {
|
|
282
|
-
const stored = await this.getStored(contentId);
|
|
283
|
-
if (!stored) {
|
|
284
|
-
return null;
|
|
285
|
-
}
|
|
286
|
-
// Touch both content entry and index to reset TTL
|
|
287
|
-
await this.touchEntry(contentId, stored);
|
|
288
|
-
return stored.metadata;
|
|
289
|
-
}
|
|
290
|
-
/**
|
|
291
|
-
* Read lines from a content entry with optional range.
|
|
292
|
-
* Lines are 1-based and inclusive. Returns formatted content with line numbers.
|
|
293
|
-
*
|
|
294
|
-
* @param contentId - The content entry ID.
|
|
295
|
-
* @param startLine - First line to read (1-based, default 1).
|
|
296
|
-
* @param endLine - Last line to read (inclusive, default startLine + DEFAULT_READ_LINES - 1).
|
|
297
|
-
* @returns Read result with formatted content and range info, or null if not found.
|
|
298
|
-
*/
|
|
299
|
-
async readLines(contentId, startLine, endLine) {
|
|
300
|
-
const stored = await this.getStored(contentId);
|
|
301
|
-
if (!stored) {
|
|
302
|
-
return null;
|
|
303
|
-
}
|
|
304
|
-
const lines = stored.content.split('\n');
|
|
305
|
-
const totalLines = lines.length;
|
|
306
|
-
// Clamp start to valid range
|
|
307
|
-
const start = Math.max(1, startLine ?? 1);
|
|
308
|
-
// Clamp end: default to start + DEFAULT_READ_LINES - 1, cap at totalLines and start + MAX_READ_LINES - 1
|
|
309
|
-
let end = endLine ?? start + DEFAULT_READ_LINES - 1;
|
|
310
|
-
end = Math.min(end, totalLines, start + MAX_READ_LINES - 1);
|
|
311
|
-
// Slice is 0-based, our line numbers are 1-based
|
|
312
|
-
const slice = lines.slice(start - 1, end);
|
|
313
|
-
// Format with line numbers (padded for alignment)
|
|
314
|
-
const padWidth = String(end).length;
|
|
315
|
-
const formatted = slice
|
|
316
|
-
.map((line, i) => {
|
|
317
|
-
const lineNum = String(start + i).padStart(padWidth, ' ');
|
|
318
|
-
return `${lineNum} | ${line}`;
|
|
319
|
-
})
|
|
320
|
-
.join('\n');
|
|
321
|
-
// Touch both content entry and index to reset TTL
|
|
322
|
-
await this.touchEntry(contentId, stored);
|
|
323
|
-
return {
|
|
324
|
-
content: formatted,
|
|
325
|
-
startLine: start,
|
|
326
|
-
endLine: end,
|
|
327
|
-
totalLines,
|
|
328
|
-
totalChars: stored.content.length,
|
|
329
|
-
truncated: end < totalLines,
|
|
330
|
-
};
|
|
331
|
-
}
|
|
332
|
-
/**
|
|
333
|
-
* Read the full content of an entry without line-number formatting or line caps.
|
|
334
|
-
* Used by API endpoints that serve complete content to the frontend (e.g., CodeViz).
|
|
335
|
-
* Unlike readLines(), this has no MAX_READ_LINES cap and returns raw content.
|
|
336
|
-
*
|
|
337
|
-
* @param contentId - The content entry ID.
|
|
338
|
-
* @returns Raw content with total line/char counts, or null if not found.
|
|
339
|
-
*/
|
|
340
|
-
async readAll(contentId) {
|
|
341
|
-
const stored = await this.getStored(contentId);
|
|
342
|
-
if (!stored) {
|
|
343
|
-
return null;
|
|
344
|
-
}
|
|
345
|
-
// Touch both content entry and index to reset TTL
|
|
346
|
-
await this.touchEntry(contentId, stored);
|
|
347
|
-
return {
|
|
348
|
-
content: stored.content,
|
|
349
|
-
totalLines: stored.content.split('\n').length,
|
|
350
|
-
totalChars: stored.content.length,
|
|
351
|
-
};
|
|
352
|
-
}
|
|
353
|
-
/**
|
|
354
|
-
* Search for a pattern within a content entry.
|
|
355
|
-
* Supports plain text matching and regex patterns.
|
|
356
|
-
*
|
|
357
|
-
* @param contentId - The content entry ID.
|
|
358
|
-
* @param pattern - Text or regex pattern to match.
|
|
359
|
-
* @param maxResults - Maximum matches to return (default MAX_SEARCH_RESULTS).
|
|
360
|
-
* @returns Array of matches with line numbers, or null if content not found.
|
|
361
|
-
*/
|
|
362
|
-
async search(contentId, pattern, maxResults = MAX_SEARCH_RESULTS) {
|
|
363
|
-
const stored = await this.getStored(contentId);
|
|
364
|
-
if (!stored) {
|
|
365
|
-
return null;
|
|
366
|
-
}
|
|
367
|
-
const lines = stored.content.split('\n');
|
|
368
|
-
const matches = [];
|
|
369
|
-
// Try regex first, fall back to plain string match
|
|
370
|
-
let regex = null;
|
|
371
|
-
try {
|
|
372
|
-
regex = new RegExp(pattern, 'i');
|
|
373
|
-
}
|
|
374
|
-
catch {
|
|
375
|
-
// Invalid regex — use plain string matching below
|
|
376
|
-
}
|
|
377
|
-
for (let i = 0; i < lines.length && matches.length < maxResults; i++) {
|
|
378
|
-
const line = lines[i];
|
|
379
|
-
const isMatch = regex ? regex.test(line) : line.includes(pattern);
|
|
380
|
-
if (isMatch) {
|
|
381
|
-
matches.push({ lineNumber: i + 1, content: line });
|
|
382
|
-
}
|
|
383
|
-
}
|
|
384
|
-
// Touch both content entry and index to reset TTL
|
|
385
|
-
await this.touchEntry(contentId, stored);
|
|
386
|
-
return matches;
|
|
387
|
-
}
|
|
388
|
-
/**
|
|
389
|
-
* Surgical string replacement within a content entry.
|
|
390
|
-
* Fails if old_str is not found or appears more than once (ambiguous).
|
|
391
|
-
*
|
|
392
|
-
* Uses layered matching: exact → line-number-stripped → CRLF-normalized → trailing-whitespace-trimmed.
|
|
393
|
-
* On failure, returns diagnostic context showing nearby content to help the agent self-correct.
|
|
394
|
-
*
|
|
395
|
-
* @param contentId - The content entry ID.
|
|
396
|
-
* @param oldStr - Exact string to find.
|
|
397
|
-
* @param newStr - Replacement string.
|
|
398
|
-
* @returns Edit result with diff and affected line info.
|
|
399
|
-
*/
|
|
400
|
-
async strReplace(contentId, oldStr, newStr) {
|
|
401
|
-
const stored = await this.getStored(contentId);
|
|
402
|
-
if (!stored) {
|
|
403
|
-
return {
|
|
404
|
-
success: false,
|
|
405
|
-
diff: '',
|
|
406
|
-
lineNumber: 0,
|
|
407
|
-
linesAffected: 0,
|
|
408
|
-
error: `Content "${contentId}" not found`,
|
|
409
|
-
};
|
|
410
|
-
}
|
|
411
|
-
const content = stored.content;
|
|
412
|
-
let effectiveOldStr = oldStr;
|
|
413
|
-
let firstIdx = content.indexOf(effectiveOldStr);
|
|
414
|
-
// Layer 1: Strip line-number prefixes that readLines() adds.
|
|
415
|
-
// Agents often copy formatted output (e.g., " 1 | import React") into old_str.
|
|
416
|
-
if (firstIdx === -1) {
|
|
417
|
-
const stripped = stripLineNumberPrefixes(oldStr);
|
|
418
|
-
if (stripped !== oldStr) {
|
|
419
|
-
firstIdx = content.indexOf(stripped);
|
|
420
|
-
if (firstIdx !== -1) {
|
|
421
|
-
effectiveOldStr = stripped;
|
|
422
|
-
}
|
|
423
|
-
}
|
|
424
|
-
}
|
|
425
|
-
// Layer 2: Normalize CRLF → LF (content from Windows/Office/MCP tools may have \r\n)
|
|
426
|
-
if (firstIdx === -1) {
|
|
427
|
-
const normContent = normalizeNewlines(content);
|
|
428
|
-
const normOld = normalizeNewlines(effectiveOldStr);
|
|
429
|
-
if (normContent !== content || normOld !== effectiveOldStr) {
|
|
430
|
-
const normIdx = normContent.indexOf(normOld);
|
|
431
|
-
if (normIdx !== -1) {
|
|
432
|
-
// Normalize stored content permanently so future edits don't hit this again
|
|
433
|
-
stored.content = normContent;
|
|
434
|
-
effectiveOldStr = normOld;
|
|
435
|
-
firstIdx = normIdx;
|
|
436
|
-
}
|
|
437
|
-
}
|
|
438
|
-
}
|
|
439
|
-
// Layer 3: Trim trailing whitespace per line (invisible trailing spaces cause mismatches)
|
|
440
|
-
if (firstIdx === -1) {
|
|
441
|
-
const trimmedContent = trimTrailingPerLine(stored.content);
|
|
442
|
-
const trimmedOld = trimTrailingPerLine(effectiveOldStr);
|
|
443
|
-
if (trimmedContent !== stored.content || trimmedOld !== effectiveOldStr) {
|
|
444
|
-
const trimIdx = trimmedContent.indexOf(trimmedOld);
|
|
445
|
-
if (trimIdx !== -1) {
|
|
446
|
-
// Use trimmed content for matching; map back to actual content position
|
|
447
|
-
// by finding the equivalent position in the original
|
|
448
|
-
stored.content = trimmedContent;
|
|
449
|
-
effectiveOldStr = trimmedOld;
|
|
450
|
-
firstIdx = trimIdx;
|
|
451
|
-
}
|
|
452
|
-
}
|
|
453
|
-
}
|
|
454
|
-
// Layer 4: Indentation-normalized line-by-line matching.
|
|
455
|
-
// Agent often gets the right code but with different indentation (e.g., 2 vs 4 spaces).
|
|
456
|
-
// Match lines by trimmed content, then replace the actual content range.
|
|
457
|
-
let rangeMatch = null;
|
|
458
|
-
if (firstIdx === -1) {
|
|
459
|
-
rangeMatch = findIndentationNormalizedMatch(stored.content, effectiveOldStr);
|
|
460
|
-
if (rangeMatch) {
|
|
461
|
-
effectiveOldStr = stored.content.substring(rangeMatch.start, rangeMatch.end);
|
|
462
|
-
firstIdx = rangeMatch.start;
|
|
463
|
-
}
|
|
464
|
-
}
|
|
465
|
-
// Layer 5: Partial fuzzy matching — tolerates some lines being slightly different.
|
|
466
|
-
// LLMs reconstruct code from memory and often get 80-90% of lines right but miss a few.
|
|
467
|
-
// This layer finds the best-scoring unique region above a match threshold.
|
|
468
|
-
if (firstIdx === -1) {
|
|
469
|
-
rangeMatch = findPartialFuzzyMatch(stored.content, effectiveOldStr);
|
|
470
|
-
if (rangeMatch) {
|
|
471
|
-
effectiveOldStr = stored.content.substring(rangeMatch.start, rangeMatch.end);
|
|
472
|
-
firstIdx = rangeMatch.start;
|
|
473
|
-
}
|
|
474
|
-
}
|
|
475
|
-
if (firstIdx === -1) {
|
|
476
|
-
const diagnostic = buildEditDiagnostic(stored.content, oldStr);
|
|
477
|
-
return {
|
|
478
|
-
success: false,
|
|
479
|
-
diff: '',
|
|
480
|
-
lineNumber: 0,
|
|
481
|
-
linesAffected: 0,
|
|
482
|
-
error: diagnostic,
|
|
483
|
-
};
|
|
484
|
-
}
|
|
485
|
-
// For range-matched edits (layers 4/5), skip the ambiguity check (already verified unique)
|
|
486
|
-
const lastIdx = rangeMatch
|
|
487
|
-
? firstIdx
|
|
488
|
-
: stored.content.lastIndexOf(effectiveOldStr);
|
|
489
|
-
if (firstIdx !== lastIdx) {
|
|
490
|
-
return {
|
|
491
|
-
success: false,
|
|
492
|
-
diff: '',
|
|
493
|
-
lineNumber: 0,
|
|
494
|
-
linesAffected: 0,
|
|
495
|
-
error: 'old_str appears multiple times — make it more specific',
|
|
496
|
-
};
|
|
497
|
-
}
|
|
498
|
-
// Find the line number where the match starts
|
|
499
|
-
const currentContent = stored.content;
|
|
500
|
-
const beforeMatch = currentContent.substring(0, firstIdx);
|
|
501
|
-
const lineNumber = beforeMatch.split('\n').length;
|
|
502
|
-
// Perform replacement
|
|
503
|
-
const newContent = currentContent.substring(0, firstIdx) +
|
|
504
|
-
newStr +
|
|
505
|
-
currentContent.substring(firstIdx + effectiveOldStr.length);
|
|
506
|
-
// Build a simple diff
|
|
507
|
-
const oldLines = effectiveOldStr.split('\n');
|
|
508
|
-
const newLines = newStr.split('\n');
|
|
509
|
-
let diff = '';
|
|
510
|
-
for (const line of oldLines) {
|
|
511
|
-
diff += `- ${line}\n`;
|
|
512
|
-
}
|
|
513
|
-
for (const line of newLines) {
|
|
514
|
-
diff += `+ ${line}\n`;
|
|
515
|
-
}
|
|
516
|
-
const linesAffected = Math.max(oldLines.length, newLines.length);
|
|
517
|
-
// Update stored content and metadata
|
|
518
|
-
stored.content = newContent;
|
|
519
|
-
stored.metadata.totalLines = newContent.split('\n').length;
|
|
520
|
-
stored.metadata.totalChars = newContent.length;
|
|
521
|
-
await this.cache.set(contentId, JSON.stringify(stored));
|
|
522
|
-
// Update index metadata
|
|
523
|
-
const index = await this.getIndex();
|
|
524
|
-
if (index[contentId]) {
|
|
525
|
-
index[contentId] = stored.metadata;
|
|
526
|
-
await this.cache.set(this.indexKey, JSON.stringify(index));
|
|
527
|
-
}
|
|
528
|
-
return { success: true, diff: diff.trimEnd(), lineNumber, linesAffected };
|
|
529
|
-
}
|
|
530
|
-
/**
|
|
531
|
-
* Overwrite content for an existing entry, preserving its name/source/type.
|
|
532
|
-
* @param contentId - The content entry ID.
|
|
533
|
-
* @param content - New content to write.
|
|
534
|
-
* @throws If content ID is not found.
|
|
535
|
-
*/
|
|
536
|
-
async write(contentId, content) {
|
|
537
|
-
const stored = await this.getStored(contentId);
|
|
538
|
-
if (!stored) {
|
|
539
|
-
throw new Error(`Content "${contentId}" not found`);
|
|
540
|
-
}
|
|
541
|
-
stored.content = content;
|
|
542
|
-
stored.metadata.totalLines = content.split('\n').length;
|
|
543
|
-
stored.metadata.totalChars = content.length;
|
|
544
|
-
await this.cache.set(contentId, JSON.stringify(stored));
|
|
545
|
-
// Update index metadata
|
|
546
|
-
const index = await this.getIndex();
|
|
547
|
-
if (index[contentId]) {
|
|
548
|
-
index[contentId] = stored.metadata;
|
|
549
|
-
await this.cache.set(this.indexKey, JSON.stringify(index));
|
|
550
|
-
}
|
|
551
|
-
}
|
|
552
|
-
/**
|
|
553
|
-
* List all content entries in this conversation's store.
|
|
554
|
-
* @returns Array of metadata for all entries.
|
|
555
|
-
*/
|
|
556
|
-
async list() {
|
|
557
|
-
const index = await this.getIndex();
|
|
558
|
-
// Touch index to reset TTL on access
|
|
559
|
-
if (Object.keys(index).length > 0) {
|
|
560
|
-
await this.cache.set(this.indexKey, JSON.stringify(index));
|
|
561
|
-
}
|
|
562
|
-
return Object.values(index);
|
|
563
|
-
}
|
|
564
|
-
/**
|
|
565
|
-
* Get the raw content string for a content entry, without line-number formatting.
|
|
566
|
-
* Resets TTL on access. Used by code edit wrapper to retrieve stored code for execution.
|
|
567
|
-
*
|
|
568
|
-
* @param contentId - The content entry ID.
|
|
569
|
-
* @returns Raw content string, or null if not found/expired.
|
|
570
|
-
*/
|
|
571
|
-
async getRawContent(contentId) {
|
|
572
|
-
const stored = await this.getStored(contentId);
|
|
573
|
-
if (!stored) {
|
|
574
|
-
return null;
|
|
575
|
-
}
|
|
576
|
-
await this.touchEntry(contentId, stored);
|
|
577
|
-
return stored.content;
|
|
578
|
-
}
|
|
579
|
-
/**
|
|
580
|
-
* Delete a content entry.
|
|
581
|
-
* @param contentId - The content entry ID.
|
|
582
|
-
*/
|
|
583
|
-
async delete(contentId) {
|
|
584
|
-
await this.cache.delete(contentId);
|
|
585
|
-
const index = await this.getIndex();
|
|
586
|
-
delete index[contentId];
|
|
587
|
-
await this.cache.set(this.indexKey, JSON.stringify(index));
|
|
588
|
-
}
|
|
589
|
-
/**
|
|
590
|
-
* Reset TTL on both a content entry and the index.
|
|
591
|
-
* Called on every access to keep active content alive.
|
|
592
|
-
* @param contentId - The content entry ID.
|
|
593
|
-
* @param stored - The stored entry to re-set (resets TTL via Keyv).
|
|
594
|
-
*/
|
|
595
|
-
async touchEntry(contentId, stored) {
|
|
596
|
-
await this.cache.set(contentId, JSON.stringify(stored));
|
|
597
|
-
const index = await this.getIndex();
|
|
598
|
-
if (Object.keys(index).length > 0) {
|
|
599
|
-
await this.cache.set(this.indexKey, JSON.stringify(index));
|
|
600
|
-
}
|
|
601
|
-
}
|
|
602
|
-
/**
|
|
603
|
-
* Retrieve the full stored entry (content + metadata) from Redis.
|
|
604
|
-
* Returns null if the entry has expired or doesn't exist.
|
|
605
|
-
*/
|
|
606
|
-
async getStored(contentId) {
|
|
607
|
-
const raw = (await this.cache.get(contentId));
|
|
608
|
-
if (!raw) {
|
|
609
|
-
return null;
|
|
610
|
-
}
|
|
611
|
-
try {
|
|
612
|
-
return JSON.parse(raw);
|
|
613
|
-
}
|
|
614
|
-
catch {
|
|
615
|
-
return null;
|
|
616
|
-
}
|
|
617
|
-
}
|
|
618
|
-
/**
|
|
619
|
-
* Retrieve the conversation's content index from Redis.
|
|
620
|
-
* The index maps content IDs to their metadata.
|
|
621
|
-
*/
|
|
622
|
-
async getIndex() {
|
|
623
|
-
const raw = (await this.cache.get(this.indexKey));
|
|
624
|
-
if (!raw) {
|
|
625
|
-
return {};
|
|
626
|
-
}
|
|
627
|
-
try {
|
|
628
|
-
return JSON.parse(raw);
|
|
629
|
-
}
|
|
630
|
-
catch {
|
|
631
|
-
return {};
|
|
632
|
-
}
|
|
633
|
-
}
|
|
634
|
-
}
|
|
635
|
-
|
|
636
|
-
exports.CONTENT_TTL_MS = CONTENT_TTL_MS;
|
|
637
|
-
exports.ContentStore = ContentStore;
|
|
638
|
-
//# sourceMappingURL=ContentStore.cjs.map
|