agentfootprint 1.0.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/AGENTS.md +297 -0
- package/CLAUDE.md +297 -0
- package/LICENSE +21 -0
- package/README.md +339 -0
- package/ai-instructions/claude-code/SKILL.md +597 -0
- package/ai-instructions/clinerules +85 -0
- package/ai-instructions/copilot-instructions.md +109 -0
- package/ai-instructions/cursor/agentfootprint.md +101 -0
- package/ai-instructions/kiro/agentfootprint.md +101 -0
- package/ai-instructions/setup.sh +140 -0
- package/ai-instructions/windsurfrules +85 -0
- package/dist/adapters/a2a/a2aRunner.js +36 -0
- package/dist/adapters/a2a/a2aRunner.js.map +1 -0
- package/dist/adapters/anthropic/AnthropicAdapter.js +293 -0
- package/dist/adapters/anthropic/AnthropicAdapter.js.map +1 -0
- package/dist/adapters/bedrock/BedrockAdapter.js +313 -0
- package/dist/adapters/bedrock/BedrockAdapter.js.map +1 -0
- package/dist/adapters/browser/BrowserAnthropicAdapter.js +349 -0
- package/dist/adapters/browser/BrowserAnthropicAdapter.js.map +1 -0
- package/dist/adapters/browser/BrowserOpenAIAdapter.js +303 -0
- package/dist/adapters/browser/BrowserOpenAIAdapter.js.map +1 -0
- package/dist/adapters/browser/index.js +8 -0
- package/dist/adapters/browser/index.js.map +1 -0
- package/dist/adapters/createAdapterSubflow.js +46 -0
- package/dist/adapters/createAdapterSubflow.js.map +1 -0
- package/dist/adapters/createProvider.js +107 -0
- package/dist/adapters/createProvider.js.map +1 -0
- package/dist/adapters/fallbackProvider.js +94 -0
- package/dist/adapters/fallbackProvider.js.map +1 -0
- package/dist/adapters/index.js +47 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/mcp/mcpToolProvider.js +44 -0
- package/dist/adapters/mcp/mcpToolProvider.js.map +1 -0
- package/dist/adapters/memory/inMemory.js +38 -0
- package/dist/adapters/memory/inMemory.js.map +1 -0
- package/dist/adapters/memory/index.js +6 -0
- package/dist/adapters/memory/index.js.map +1 -0
- package/dist/adapters/memory/stores.js +137 -0
- package/dist/adapters/memory/stores.js.map +1 -0
- package/dist/adapters/memory/types.js +14 -0
- package/dist/adapters/memory/types.js.map +1 -0
- package/dist/adapters/mock/MockAdapter.js +66 -0
- package/dist/adapters/mock/MockAdapter.js.map +1 -0
- package/dist/adapters/mock/MockRetriever.js +61 -0
- package/dist/adapters/mock/MockRetriever.js.map +1 -0
- package/dist/adapters/openai/OpenAIAdapter.js +276 -0
- package/dist/adapters/openai/OpenAIAdapter.js.map +1 -0
- package/dist/adapters/resilientProvider.js +93 -0
- package/dist/adapters/resilientProvider.js.map +1 -0
- package/dist/compositions/index.js +17 -0
- package/dist/compositions/index.js.map +1 -0
- package/dist/compositions/withCircuitBreaker.js +84 -0
- package/dist/compositions/withCircuitBreaker.js.map +1 -0
- package/dist/compositions/withFallback.js +33 -0
- package/dist/compositions/withFallback.js.map +1 -0
- package/dist/compositions/withRetry.js +59 -0
- package/dist/compositions/withRetry.js.map +1 -0
- package/dist/concepts/FlowChart.js +205 -0
- package/dist/concepts/FlowChart.js.map +1 -0
- package/dist/concepts/LLMCall.js +160 -0
- package/dist/concepts/LLMCall.js.map +1 -0
- package/dist/concepts/Parallel.js +254 -0
- package/dist/concepts/Parallel.js.map +1 -0
- package/dist/concepts/RAG.js +198 -0
- package/dist/concepts/RAG.js.map +1 -0
- package/dist/concepts/Swarm.js +270 -0
- package/dist/concepts/Swarm.js.map +1 -0
- package/dist/concepts/index.js +23 -0
- package/dist/concepts/index.js.map +1 -0
- package/dist/concepts/specIcons.js +48 -0
- package/dist/concepts/specIcons.js.map +1 -0
- package/dist/core/config.js +7 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/index.js +14 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/providers.js +19 -0
- package/dist/core/providers.js.map +1 -0
- package/dist/core/recorders.js +7 -0
- package/dist/core/recorders.js.map +1 -0
- package/dist/esm/adapters/a2a/a2aRunner.js +32 -0
- package/dist/esm/adapters/a2a/a2aRunner.js.map +1 -0
- package/dist/esm/adapters/anthropic/AnthropicAdapter.js +289 -0
- package/dist/esm/adapters/anthropic/AnthropicAdapter.js.map +1 -0
- package/dist/esm/adapters/bedrock/BedrockAdapter.js +309 -0
- package/dist/esm/adapters/bedrock/BedrockAdapter.js.map +1 -0
- package/dist/esm/adapters/browser/BrowserAnthropicAdapter.js +345 -0
- package/dist/esm/adapters/browser/BrowserAnthropicAdapter.js.map +1 -0
- package/dist/esm/adapters/browser/BrowserOpenAIAdapter.js +299 -0
- package/dist/esm/adapters/browser/BrowserOpenAIAdapter.js.map +1 -0
- package/dist/esm/adapters/browser/index.js +3 -0
- package/dist/esm/adapters/browser/index.js.map +1 -0
- package/dist/esm/adapters/createAdapterSubflow.js +42 -0
- package/dist/esm/adapters/createAdapterSubflow.js.map +1 -0
- package/dist/esm/adapters/createProvider.js +101 -0
- package/dist/esm/adapters/createProvider.js.map +1 -0
- package/dist/esm/adapters/fallbackProvider.js +90 -0
- package/dist/esm/adapters/fallbackProvider.js.map +1 -0
- package/dist/esm/adapters/index.js +23 -0
- package/dist/esm/adapters/index.js.map +1 -0
- package/dist/esm/adapters/mcp/mcpToolProvider.js +40 -0
- package/dist/esm/adapters/mcp/mcpToolProvider.js.map +1 -0
- package/dist/esm/adapters/memory/inMemory.js +34 -0
- package/dist/esm/adapters/memory/inMemory.js.map +1 -0
- package/dist/esm/adapters/memory/index.js +2 -0
- package/dist/esm/adapters/memory/index.js.map +1 -0
- package/dist/esm/adapters/memory/stores.js +131 -0
- package/dist/esm/adapters/memory/stores.js.map +1 -0
- package/dist/esm/adapters/memory/types.js +13 -0
- package/dist/esm/adapters/memory/types.js.map +1 -0
- package/dist/esm/adapters/mock/MockAdapter.js +61 -0
- package/dist/esm/adapters/mock/MockAdapter.js.map +1 -0
- package/dist/esm/adapters/mock/MockRetriever.js +56 -0
- package/dist/esm/adapters/mock/MockRetriever.js.map +1 -0
- package/dist/esm/adapters/openai/OpenAIAdapter.js +272 -0
- package/dist/esm/adapters/openai/OpenAIAdapter.js.map +1 -0
- package/dist/esm/adapters/resilientProvider.js +89 -0
- package/dist/esm/adapters/resilientProvider.js.map +1 -0
- package/dist/esm/compositions/index.js +10 -0
- package/dist/esm/compositions/index.js.map +1 -0
- package/dist/esm/compositions/withCircuitBreaker.js +79 -0
- package/dist/esm/compositions/withCircuitBreaker.js.map +1 -0
- package/dist/esm/compositions/withFallback.js +29 -0
- package/dist/esm/compositions/withFallback.js.map +1 -0
- package/dist/esm/compositions/withRetry.js +55 -0
- package/dist/esm/compositions/withRetry.js.map +1 -0
- package/dist/esm/concepts/FlowChart.js +200 -0
- package/dist/esm/concepts/FlowChart.js.map +1 -0
- package/dist/esm/concepts/LLMCall.js +155 -0
- package/dist/esm/concepts/LLMCall.js.map +1 -0
- package/dist/esm/concepts/Parallel.js +249 -0
- package/dist/esm/concepts/Parallel.js.map +1 -0
- package/dist/esm/concepts/RAG.js +193 -0
- package/dist/esm/concepts/RAG.js.map +1 -0
- package/dist/esm/concepts/Swarm.js +265 -0
- package/dist/esm/concepts/Swarm.js.map +1 -0
- package/dist/esm/concepts/index.js +8 -0
- package/dist/esm/concepts/index.js.map +1 -0
- package/dist/esm/concepts/specIcons.js +44 -0
- package/dist/esm/concepts/specIcons.js.map +1 -0
- package/dist/esm/core/config.js +6 -0
- package/dist/esm/core/config.js.map +1 -0
- package/dist/esm/core/index.js +13 -0
- package/dist/esm/core/index.js.map +1 -0
- package/dist/esm/core/providers.js +18 -0
- package/dist/esm/core/providers.js.map +1 -0
- package/dist/esm/core/recorders.js +6 -0
- package/dist/esm/core/recorders.js.map +1 -0
- package/dist/esm/executor/agentLoop.js +150 -0
- package/dist/esm/executor/agentLoop.js.map +1 -0
- package/dist/esm/executor/index.js +5 -0
- package/dist/esm/executor/index.js.map +1 -0
- package/dist/esm/explain.barrel.js +19 -0
- package/dist/esm/explain.barrel.js.map +1 -0
- package/dist/esm/index.js +29 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/instructions.barrel.js +22 -0
- package/dist/esm/instructions.barrel.js.map +1 -0
- package/dist/esm/lib/call/callLLMStage.js +64 -0
- package/dist/esm/lib/call/callLLMStage.js.map +1 -0
- package/dist/esm/lib/call/handleResponseStage.js +49 -0
- package/dist/esm/lib/call/handleResponseStage.js.map +1 -0
- package/dist/esm/lib/call/helpers.js +164 -0
- package/dist/esm/lib/call/helpers.js.map +1 -0
- package/dist/esm/lib/call/index.js +7 -0
- package/dist/esm/lib/call/index.js.map +1 -0
- package/dist/esm/lib/call/parseResponseStage.js +48 -0
- package/dist/esm/lib/call/parseResponseStage.js.map +1 -0
- package/dist/esm/lib/call/streamingCallLLMStage.js +103 -0
- package/dist/esm/lib/call/streamingCallLLMStage.js.map +1 -0
- package/dist/esm/lib/call/toolExecutionSubflow.js +87 -0
- package/dist/esm/lib/call/toolExecutionSubflow.js.map +1 -0
- package/dist/esm/lib/call/types.js +10 -0
- package/dist/esm/lib/call/types.js.map +1 -0
- package/dist/esm/lib/concepts/Agent.js +7 -0
- package/dist/esm/lib/concepts/Agent.js.map +1 -0
- package/dist/esm/lib/concepts/AgentBuilder.js +224 -0
- package/dist/esm/lib/concepts/AgentBuilder.js.map +1 -0
- package/dist/esm/lib/concepts/AgentRunner.js +337 -0
- package/dist/esm/lib/concepts/AgentRunner.js.map +1 -0
- package/dist/esm/lib/concepts/index.js +2 -0
- package/dist/esm/lib/concepts/index.js.map +1 -0
- package/dist/esm/lib/instructions/InstructionRecorder.js +121 -0
- package/dist/esm/lib/instructions/InstructionRecorder.js.map +1 -0
- package/dist/esm/lib/instructions/agentInstruction.js +139 -0
- package/dist/esm/lib/instructions/agentInstruction.js.map +1 -0
- package/dist/esm/lib/instructions/buildInstructionsToLLMSubflow.js +83 -0
- package/dist/esm/lib/instructions/buildInstructionsToLLMSubflow.js.map +1 -0
- package/dist/esm/lib/instructions/evaluator.js +196 -0
- package/dist/esm/lib/instructions/evaluator.js.map +1 -0
- package/dist/esm/lib/instructions/index.js +10 -0
- package/dist/esm/lib/instructions/index.js.map +1 -0
- package/dist/esm/lib/instructions/inject.js +55 -0
- package/dist/esm/lib/instructions/inject.js.map +1 -0
- package/dist/esm/lib/instructions/preview.js +88 -0
- package/dist/esm/lib/instructions/preview.js.map +1 -0
- package/dist/esm/lib/instructions/strictFollowUp.js +125 -0
- package/dist/esm/lib/instructions/strictFollowUp.js.map +1 -0
- package/dist/esm/lib/instructions/template.js +82 -0
- package/dist/esm/lib/instructions/template.js.map +1 -0
- package/dist/esm/lib/instructions/types.js +83 -0
- package/dist/esm/lib/instructions/types.js.map +1 -0
- package/dist/esm/lib/loop/buildAgentLoop.js +401 -0
- package/dist/esm/lib/loop/buildAgentLoop.js.map +1 -0
- package/dist/esm/lib/loop/index.js +3 -0
- package/dist/esm/lib/loop/index.js.map +1 -0
- package/dist/esm/lib/loop/types.js +71 -0
- package/dist/esm/lib/loop/types.js.map +1 -0
- package/dist/esm/lib/narrative/agentRenderer.js +293 -0
- package/dist/esm/lib/narrative/agentRenderer.js.map +1 -0
- package/dist/esm/lib/narrative/groundingHelpers.js +136 -0
- package/dist/esm/lib/narrative/groundingHelpers.js.map +1 -0
- package/dist/esm/lib/narrative/index.js +3 -0
- package/dist/esm/lib/narrative/index.js.map +1 -0
- package/dist/esm/lib/slots/helpers.js +23 -0
- package/dist/esm/lib/slots/helpers.js.map +1 -0
- package/dist/esm/lib/slots/index.js +4 -0
- package/dist/esm/lib/slots/index.js.map +1 -0
- package/dist/esm/lib/slots/messages/buildMessagesSubflow.js +108 -0
- package/dist/esm/lib/slots/messages/buildMessagesSubflow.js.map +1 -0
- package/dist/esm/lib/slots/messages/index.js +2 -0
- package/dist/esm/lib/slots/messages/index.js.map +1 -0
- package/dist/esm/lib/slots/messages/types.js +10 -0
- package/dist/esm/lib/slots/messages/types.js.map +1 -0
- package/dist/esm/lib/slots/system-prompt/buildSystemPromptSubflow.js +64 -0
- package/dist/esm/lib/slots/system-prompt/buildSystemPromptSubflow.js.map +1 -0
- package/dist/esm/lib/slots/system-prompt/index.js +2 -0
- package/dist/esm/lib/slots/system-prompt/index.js.map +1 -0
- package/dist/esm/lib/slots/system-prompt/types.js +9 -0
- package/dist/esm/lib/slots/system-prompt/types.js.map +1 -0
- package/dist/esm/lib/slots/tools/buildToolsSubflow.js +67 -0
- package/dist/esm/lib/slots/tools/buildToolsSubflow.js.map +1 -0
- package/dist/esm/lib/slots/tools/index.js +2 -0
- package/dist/esm/lib/slots/tools/index.js.map +1 -0
- package/dist/esm/lib/slots/tools/types.js +11 -0
- package/dist/esm/lib/slots/tools/types.js.map +1 -0
- package/dist/esm/lib/swarm/buildSwarmRouting.js +207 -0
- package/dist/esm/lib/swarm/buildSwarmRouting.js.map +1 -0
- package/dist/esm/lib/swarm/index.js +2 -0
- package/dist/esm/lib/swarm/index.js.map +1 -0
- package/dist/esm/memory/conversationHelpers.js +56 -0
- package/dist/esm/memory/conversationHelpers.js.map +1 -0
- package/dist/esm/memory/index.js +2 -0
- package/dist/esm/memory/index.js.map +1 -0
- package/dist/esm/models/index.js +3 -0
- package/dist/esm/models/index.js.map +1 -0
- package/dist/esm/models/pricing.js +23 -0
- package/dist/esm/models/pricing.js.map +1 -0
- package/dist/esm/models/providers.js +42 -0
- package/dist/esm/models/providers.js.map +1 -0
- package/dist/esm/models/types.js +6 -0
- package/dist/esm/models/types.js.map +1 -0
- package/dist/esm/observe.barrel.js +18 -0
- package/dist/esm/observe.barrel.js.map +1 -0
- package/dist/esm/providers/index.js +12 -0
- package/dist/esm/providers/index.js.map +1 -0
- package/dist/esm/providers/messages/charBudget.js +39 -0
- package/dist/esm/providers/messages/charBudget.js.map +1 -0
- package/dist/esm/providers/messages/compositeMessages.js +33 -0
- package/dist/esm/providers/messages/compositeMessages.js.map +1 -0
- package/dist/esm/providers/messages/fullHistory.js +15 -0
- package/dist/esm/providers/messages/fullHistory.js.map +1 -0
- package/dist/esm/providers/messages/index.js +11 -0
- package/dist/esm/providers/messages/index.js.map +1 -0
- package/dist/esm/providers/messages/persistentHistory.js +40 -0
- package/dist/esm/providers/messages/persistentHistory.js.map +1 -0
- package/dist/esm/providers/messages/slidingWindow.js +24 -0
- package/dist/esm/providers/messages/slidingWindow.js.map +1 -0
- package/dist/esm/providers/messages/summaryStrategy.js +41 -0
- package/dist/esm/providers/messages/summaryStrategy.js.map +1 -0
- package/dist/esm/providers/messages/withToolPairSafety.js +76 -0
- package/dist/esm/providers/messages/withToolPairSafety.js.map +1 -0
- package/dist/esm/providers/prompt/compositePrompt.js +28 -0
- package/dist/esm/providers/prompt/compositePrompt.js.map +1 -0
- package/dist/esm/providers/prompt/index.js +8 -0
- package/dist/esm/providers/prompt/index.js.map +1 -0
- package/dist/esm/providers/prompt/skillBasedPrompt.js +37 -0
- package/dist/esm/providers/prompt/skillBasedPrompt.js.map +1 -0
- package/dist/esm/providers/prompt/static.js +9 -0
- package/dist/esm/providers/prompt/static.js.map +1 -0
- package/dist/esm/providers/prompt/template.js +20 -0
- package/dist/esm/providers/prompt/template.js.map +1 -0
- package/dist/esm/providers/tools/PermissionPolicy.js +100 -0
- package/dist/esm/providers/tools/PermissionPolicy.js.map +1 -0
- package/dist/esm/providers/tools/agentAsTool.js +47 -0
- package/dist/esm/providers/tools/agentAsTool.js.map +1 -0
- package/dist/esm/providers/tools/compositeTools.js +49 -0
- package/dist/esm/providers/tools/compositeTools.js.map +1 -0
- package/dist/esm/providers/tools/dynamicTools.js +41 -0
- package/dist/esm/providers/tools/dynamicTools.js.map +1 -0
- package/dist/esm/providers/tools/gatedTools.js +90 -0
- package/dist/esm/providers/tools/gatedTools.js.map +1 -0
- package/dist/esm/providers/tools/index.js +11 -0
- package/dist/esm/providers/tools/index.js.map +1 -0
- package/dist/esm/providers/tools/noTools.js +9 -0
- package/dist/esm/providers/tools/noTools.js.map +1 -0
- package/dist/esm/providers/tools/staticTools.js +25 -0
- package/dist/esm/providers/tools/staticTools.js.map +1 -0
- package/dist/esm/providers.barrel.js +32 -0
- package/dist/esm/providers.barrel.js.map +1 -0
- package/dist/esm/recorders/index.js +5 -0
- package/dist/esm/recorders/index.js.map +1 -0
- package/dist/esm/recorders/v2/CompositeRecorder.js +65 -0
- package/dist/esm/recorders/v2/CompositeRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/CostRecorder.js +47 -0
- package/dist/esm/recorders/v2/CostRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/ExplainRecorder.js +93 -0
- package/dist/esm/recorders/v2/ExplainRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/GuardrailRecorder.js +58 -0
- package/dist/esm/recorders/v2/GuardrailRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/OTelRecorder.js +79 -0
- package/dist/esm/recorders/v2/OTelRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/PermissionRecorder.js +86 -0
- package/dist/esm/recorders/v2/PermissionRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/QualityRecorder.js +48 -0
- package/dist/esm/recorders/v2/QualityRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/RecorderBridge.js +85 -0
- package/dist/esm/recorders/v2/RecorderBridge.js.map +1 -0
- package/dist/esm/recorders/v2/TokenRecorder.js +72 -0
- package/dist/esm/recorders/v2/TokenRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/ToolUsageRecorder.js +54 -0
- package/dist/esm/recorders/v2/ToolUsageRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/TurnRecorder.js +83 -0
- package/dist/esm/recorders/v2/TurnRecorder.js.map +1 -0
- package/dist/esm/recorders/v2/agentObservability.js +62 -0
- package/dist/esm/recorders/v2/agentObservability.js.map +1 -0
- package/dist/esm/recorders/v2/index.js +13 -0
- package/dist/esm/recorders/v2/index.js.map +1 -0
- package/dist/esm/resilience.barrel.js +16 -0
- package/dist/esm/resilience.barrel.js.map +1 -0
- package/dist/esm/scope/AgentScope.js +153 -0
- package/dist/esm/scope/AgentScope.js.map +1 -0
- package/dist/esm/scope/index.js +2 -0
- package/dist/esm/scope/index.js.map +1 -0
- package/dist/esm/scope/types.js +37 -0
- package/dist/esm/scope/types.js.map +1 -0
- package/dist/esm/security.barrel.js +17 -0
- package/dist/esm/security.barrel.js.map +1 -0
- package/dist/esm/stages/augmentPrompt.js +28 -0
- package/dist/esm/stages/augmentPrompt.js.map +1 -0
- package/dist/esm/stages/callLLM.js +15 -0
- package/dist/esm/stages/callLLM.js.map +1 -0
- package/dist/esm/stages/commitMemory.js +94 -0
- package/dist/esm/stages/commitMemory.js.map +1 -0
- package/dist/esm/stages/finalize.js +12 -0
- package/dist/esm/stages/finalize.js.map +1 -0
- package/dist/esm/stages/helpers.js +58 -0
- package/dist/esm/stages/helpers.js.map +1 -0
- package/dist/esm/stages/index.js +9 -0
- package/dist/esm/stages/index.js.map +1 -0
- package/dist/esm/stages/parseResponse.js +25 -0
- package/dist/esm/stages/parseResponse.js.map +1 -0
- package/dist/esm/stages/retrieve.js +18 -0
- package/dist/esm/stages/retrieve.js.map +1 -0
- package/dist/esm/stages/runnerAsStage.js +66 -0
- package/dist/esm/stages/runnerAsStage.js.map +1 -0
- package/dist/esm/stream.barrel.js +18 -0
- package/dist/esm/stream.barrel.js.map +1 -0
- package/dist/esm/streaming/StreamEmitter.js +43 -0
- package/dist/esm/streaming/StreamEmitter.js.map +1 -0
- package/dist/esm/streaming/index.js +2 -0
- package/dist/esm/streaming/index.js.map +1 -0
- package/dist/esm/subflows/index.js +2 -0
- package/dist/esm/subflows/index.js.map +1 -0
- package/dist/esm/subflows/prepareMemory.js +83 -0
- package/dist/esm/subflows/prepareMemory.js.map +1 -0
- package/dist/esm/tools/ToolRegistry.js +84 -0
- package/dist/esm/tools/ToolRegistry.js.map +1 -0
- package/dist/esm/tools/askHuman.js +63 -0
- package/dist/esm/tools/askHuman.js.map +1 -0
- package/dist/esm/tools/index.js +3 -0
- package/dist/esm/tools/index.js.map +1 -0
- package/dist/esm/tools/validateInput.js +56 -0
- package/dist/esm/tools/validateInput.js.map +1 -0
- package/dist/esm/tools/zodToJsonSchema.js +65 -0
- package/dist/esm/tools/zodToJsonSchema.js.map +1 -0
- package/dist/esm/types/adapter.js +11 -0
- package/dist/esm/types/adapter.js.map +1 -0
- package/dist/esm/types/agent.js +5 -0
- package/dist/esm/types/agent.js.map +1 -0
- package/dist/esm/types/content.js +82 -0
- package/dist/esm/types/content.js.map +1 -0
- package/dist/esm/types/errors.js +74 -0
- package/dist/esm/types/errors.js.map +1 -0
- package/dist/esm/types/index.js +5 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/llm.js +6 -0
- package/dist/esm/types/llm.js.map +1 -0
- package/dist/esm/types/messages.js +24 -0
- package/dist/esm/types/messages.js.map +1 -0
- package/dist/esm/types/multiAgent.js +5 -0
- package/dist/esm/types/multiAgent.js.map +1 -0
- package/dist/esm/types/retriever.js +6 -0
- package/dist/esm/types/retriever.js.map +1 -0
- package/dist/esm/types/tools.js +5 -0
- package/dist/esm/types/tools.js.map +1 -0
- package/dist/executor/agentLoop.js +154 -0
- package/dist/executor/agentLoop.js.map +1 -0
- package/dist/executor/index.js +9 -0
- package/dist/executor/index.js.map +1 -0
- package/dist/explain.barrel.js +27 -0
- package/dist/explain.barrel.js.map +1 -0
- package/dist/index.js +74 -0
- package/dist/index.js.map +1 -0
- package/dist/instructions.barrel.js +30 -0
- package/dist/instructions.barrel.js.map +1 -0
- package/dist/lib/call/callLLMStage.js +68 -0
- package/dist/lib/call/callLLMStage.js.map +1 -0
- package/dist/lib/call/handleResponseStage.js +53 -0
- package/dist/lib/call/handleResponseStage.js.map +1 -0
- package/dist/lib/call/helpers.js +169 -0
- package/dist/lib/call/helpers.js.map +1 -0
- package/dist/lib/call/index.js +17 -0
- package/dist/lib/call/index.js.map +1 -0
- package/dist/lib/call/parseResponseStage.js +52 -0
- package/dist/lib/call/parseResponseStage.js.map +1 -0
- package/dist/lib/call/streamingCallLLMStage.js +107 -0
- package/dist/lib/call/streamingCallLLMStage.js.map +1 -0
- package/dist/lib/call/toolExecutionSubflow.js +91 -0
- package/dist/lib/call/toolExecutionSubflow.js.map +1 -0
- package/dist/lib/call/types.js +11 -0
- package/dist/lib/call/types.js.map +1 -0
- package/dist/lib/concepts/Agent.js +12 -0
- package/dist/lib/concepts/Agent.js.map +1 -0
- package/dist/lib/concepts/AgentBuilder.js +228 -0
- package/dist/lib/concepts/AgentBuilder.js.map +1 -0
- package/dist/lib/concepts/AgentRunner.js +341 -0
- package/dist/lib/concepts/AgentRunner.js.map +1 -0
- package/dist/lib/concepts/index.js +7 -0
- package/dist/lib/concepts/index.js.map +1 -0
- package/dist/lib/instructions/InstructionRecorder.js +125 -0
- package/dist/lib/instructions/InstructionRecorder.js.map +1 -0
- package/dist/lib/instructions/agentInstruction.js +144 -0
- package/dist/lib/instructions/agentInstruction.js.map +1 -0
- package/dist/lib/instructions/buildInstructionsToLLMSubflow.js +87 -0
- package/dist/lib/instructions/buildInstructionsToLLMSubflow.js.map +1 -0
- package/dist/lib/instructions/evaluator.js +202 -0
- package/dist/lib/instructions/evaluator.js.map +1 -0
- package/dist/lib/instructions/index.js +27 -0
- package/dist/lib/instructions/index.js.map +1 -0
- package/dist/lib/instructions/inject.js +59 -0
- package/dist/lib/instructions/inject.js.map +1 -0
- package/dist/lib/instructions/preview.js +92 -0
- package/dist/lib/instructions/preview.js.map +1 -0
- package/dist/lib/instructions/strictFollowUp.js +130 -0
- package/dist/lib/instructions/strictFollowUp.js.map +1 -0
- package/dist/lib/instructions/template.js +86 -0
- package/dist/lib/instructions/template.js.map +1 -0
- package/dist/lib/instructions/types.js +88 -0
- package/dist/lib/instructions/types.js.map +1 -0
- package/dist/lib/loop/buildAgentLoop.js +405 -0
- package/dist/lib/loop/buildAgentLoop.js.map +1 -0
- package/dist/lib/loop/index.js +9 -0
- package/dist/lib/loop/index.js.map +1 -0
- package/dist/lib/loop/types.js +74 -0
- package/dist/lib/loop/types.js.map +1 -0
- package/dist/lib/narrative/agentRenderer.js +297 -0
- package/dist/lib/narrative/agentRenderer.js.map +1 -0
- package/dist/lib/narrative/groundingHelpers.js +142 -0
- package/dist/lib/narrative/groundingHelpers.js.map +1 -0
- package/dist/lib/narrative/index.js +10 -0
- package/dist/lib/narrative/index.js.map +1 -0
- package/dist/lib/slots/helpers.js +28 -0
- package/dist/lib/slots/helpers.js.map +1 -0
- package/dist/lib/slots/index.js +10 -0
- package/dist/lib/slots/index.js.map +1 -0
- package/dist/lib/slots/messages/buildMessagesSubflow.js +112 -0
- package/dist/lib/slots/messages/buildMessagesSubflow.js.map +1 -0
- package/dist/lib/slots/messages/index.js +6 -0
- package/dist/lib/slots/messages/index.js.map +1 -0
- package/dist/lib/slots/messages/types.js +11 -0
- package/dist/lib/slots/messages/types.js.map +1 -0
- package/dist/lib/slots/system-prompt/buildSystemPromptSubflow.js +68 -0
- package/dist/lib/slots/system-prompt/buildSystemPromptSubflow.js.map +1 -0
- package/dist/lib/slots/system-prompt/index.js +6 -0
- package/dist/lib/slots/system-prompt/index.js.map +1 -0
- package/dist/lib/slots/system-prompt/types.js +10 -0
- package/dist/lib/slots/system-prompt/types.js.map +1 -0
- package/dist/lib/slots/tools/buildToolsSubflow.js +71 -0
- package/dist/lib/slots/tools/buildToolsSubflow.js.map +1 -0
- package/dist/lib/slots/tools/index.js +6 -0
- package/dist/lib/slots/tools/index.js.map +1 -0
- package/dist/lib/slots/tools/types.js +12 -0
- package/dist/lib/slots/tools/types.js.map +1 -0
- package/dist/lib/swarm/buildSwarmRouting.js +211 -0
- package/dist/lib/swarm/buildSwarmRouting.js.map +1 -0
- package/dist/lib/swarm/index.js +6 -0
- package/dist/lib/swarm/index.js.map +1 -0
- package/dist/memory/conversationHelpers.js +66 -0
- package/dist/memory/conversationHelpers.js.map +1 -0
- package/dist/memory/index.js +12 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/models/index.js +12 -0
- package/dist/models/index.js.map +1 -0
- package/dist/models/pricing.js +27 -0
- package/dist/models/pricing.js.map +1 -0
- package/dist/models/providers.js +49 -0
- package/dist/models/providers.js.map +1 -0
- package/dist/models/types.js +7 -0
- package/dist/models/types.js.map +1 -0
- package/dist/observe.barrel.js +31 -0
- package/dist/observe.barrel.js.map +1 -0
- package/dist/providers/index.js +34 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/messages/charBudget.js +43 -0
- package/dist/providers/messages/charBudget.js.map +1 -0
- package/dist/providers/messages/compositeMessages.js +37 -0
- package/dist/providers/messages/compositeMessages.js.map +1 -0
- package/dist/providers/messages/fullHistory.js +19 -0
- package/dist/providers/messages/fullHistory.js.map +1 -0
- package/dist/providers/messages/index.js +22 -0
- package/dist/providers/messages/index.js.map +1 -0
- package/dist/providers/messages/persistentHistory.js +45 -0
- package/dist/providers/messages/persistentHistory.js.map +1 -0
- package/dist/providers/messages/slidingWindow.js +28 -0
- package/dist/providers/messages/slidingWindow.js.map +1 -0
- package/dist/providers/messages/summaryStrategy.js +45 -0
- package/dist/providers/messages/summaryStrategy.js.map +1 -0
- package/dist/providers/messages/withToolPairSafety.js +80 -0
- package/dist/providers/messages/withToolPairSafety.js.map +1 -0
- package/dist/providers/prompt/compositePrompt.js +32 -0
- package/dist/providers/prompt/compositePrompt.js.map +1 -0
- package/dist/providers/prompt/index.js +15 -0
- package/dist/providers/prompt/index.js.map +1 -0
- package/dist/providers/prompt/skillBasedPrompt.js +41 -0
- package/dist/providers/prompt/skillBasedPrompt.js.map +1 -0
- package/dist/providers/prompt/static.js +13 -0
- package/dist/providers/prompt/static.js.map +1 -0
- package/dist/providers/prompt/template.js +24 -0
- package/dist/providers/prompt/template.js.map +1 -0
- package/dist/providers/tools/PermissionPolicy.js +104 -0
- package/dist/providers/tools/PermissionPolicy.js.map +1 -0
- package/dist/providers/tools/agentAsTool.js +51 -0
- package/dist/providers/tools/agentAsTool.js.map +1 -0
- package/dist/providers/tools/compositeTools.js +53 -0
- package/dist/providers/tools/compositeTools.js.map +1 -0
- package/dist/providers/tools/dynamicTools.js +45 -0
- package/dist/providers/tools/dynamicTools.js.map +1 -0
- package/dist/providers/tools/gatedTools.js +94 -0
- package/dist/providers/tools/gatedTools.js.map +1 -0
- package/dist/providers/tools/index.js +21 -0
- package/dist/providers/tools/index.js.map +1 -0
- package/dist/providers/tools/noTools.js +13 -0
- package/dist/providers/tools/noTools.js.map +1 -0
- package/dist/providers/tools/staticTools.js +29 -0
- package/dist/providers/tools/staticTools.js.map +1 -0
- package/dist/providers.barrel.js +61 -0
- package/dist/providers.barrel.js.map +1 -0
- package/dist/recorders/index.js +17 -0
- package/dist/recorders/index.js.map +1 -0
- package/dist/recorders/v2/CompositeRecorder.js +69 -0
- package/dist/recorders/v2/CompositeRecorder.js.map +1 -0
- package/dist/recorders/v2/CostRecorder.js +51 -0
- package/dist/recorders/v2/CostRecorder.js.map +1 -0
- package/dist/recorders/v2/ExplainRecorder.js +97 -0
- package/dist/recorders/v2/ExplainRecorder.js.map +1 -0
- package/dist/recorders/v2/GuardrailRecorder.js +62 -0
- package/dist/recorders/v2/GuardrailRecorder.js.map +1 -0
- package/dist/recorders/v2/OTelRecorder.js +83 -0
- package/dist/recorders/v2/OTelRecorder.js.map +1 -0
- package/dist/recorders/v2/PermissionRecorder.js +90 -0
- package/dist/recorders/v2/PermissionRecorder.js.map +1 -0
- package/dist/recorders/v2/QualityRecorder.js +52 -0
- package/dist/recorders/v2/QualityRecorder.js.map +1 -0
- package/dist/recorders/v2/RecorderBridge.js +89 -0
- package/dist/recorders/v2/RecorderBridge.js.map +1 -0
- package/dist/recorders/v2/TokenRecorder.js +76 -0
- package/dist/recorders/v2/TokenRecorder.js.map +1 -0
- package/dist/recorders/v2/ToolUsageRecorder.js +58 -0
- package/dist/recorders/v2/ToolUsageRecorder.js.map +1 -0
- package/dist/recorders/v2/TurnRecorder.js +87 -0
- package/dist/recorders/v2/TurnRecorder.js.map +1 -0
- package/dist/recorders/v2/agentObservability.js +66 -0
- package/dist/recorders/v2/agentObservability.js.map +1 -0
- package/dist/recorders/v2/index.js +25 -0
- package/dist/recorders/v2/index.js.map +1 -0
- package/dist/resilience.barrel.js +25 -0
- package/dist/resilience.barrel.js.map +1 -0
- package/dist/scope/AgentScope.js +156 -0
- package/dist/scope/AgentScope.js.map +1 -0
- package/dist/scope/index.js +10 -0
- package/dist/scope/index.js.map +1 -0
- package/dist/scope/types.js +40 -0
- package/dist/scope/types.js.map +1 -0
- package/dist/security.barrel.js +22 -0
- package/dist/security.barrel.js.map +1 -0
- package/dist/stages/augmentPrompt.js +32 -0
- package/dist/stages/augmentPrompt.js.map +1 -0
- package/dist/stages/callLLM.js +19 -0
- package/dist/stages/callLLM.js.map +1 -0
- package/dist/stages/commitMemory.js +98 -0
- package/dist/stages/commitMemory.js.map +1 -0
- package/dist/stages/finalize.js +16 -0
- package/dist/stages/finalize.js.map +1 -0
- package/dist/stages/helpers.js +63 -0
- package/dist/stages/helpers.js.map +1 -0
- package/dist/stages/index.js +21 -0
- package/dist/stages/index.js.map +1 -0
- package/dist/stages/parseResponse.js +29 -0
- package/dist/stages/parseResponse.js.map +1 -0
- package/dist/stages/retrieve.js +22 -0
- package/dist/stages/retrieve.js.map +1 -0
- package/dist/stages/runnerAsStage.js +70 -0
- package/dist/stages/runnerAsStage.js.map +1 -0
- package/dist/stream.barrel.js +23 -0
- package/dist/stream.barrel.js.map +1 -0
- package/dist/streaming/StreamEmitter.js +48 -0
- package/dist/streaming/StreamEmitter.js.map +1 -0
- package/dist/streaming/index.js +7 -0
- package/dist/streaming/index.js.map +1 -0
- package/dist/subflows/index.js +6 -0
- package/dist/subflows/index.js.map +1 -0
- package/dist/subflows/prepareMemory.js +87 -0
- package/dist/subflows/prepareMemory.js.map +1 -0
- package/dist/tools/ToolRegistry.js +89 -0
- package/dist/tools/ToolRegistry.js.map +1 -0
- package/dist/tools/askHuman.js +68 -0
- package/dist/tools/askHuman.js.map +1 -0
- package/dist/tools/index.js +9 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/validateInput.js +61 -0
- package/dist/tools/validateInput.js.map +1 -0
- package/dist/tools/zodToJsonSchema.js +70 -0
- package/dist/tools/zodToJsonSchema.js.map +1 -0
- package/dist/types/adapter.js +14 -0
- package/dist/types/adapter.js.map +1 -0
- package/dist/types/adapters/a2a/a2aRunner.d.ts +40 -0
- package/dist/types/adapters/a2a/a2aRunner.d.ts.map +1 -0
- package/dist/types/adapters/anthropic/AnthropicAdapter.d.ts +37 -0
- package/dist/types/adapters/anthropic/AnthropicAdapter.d.ts.map +1 -0
- package/dist/types/adapters/bedrock/BedrockAdapter.d.ts +44 -0
- package/dist/types/adapters/bedrock/BedrockAdapter.d.ts.map +1 -0
- package/dist/types/adapters/browser/BrowserAnthropicAdapter.d.ts +40 -0
- package/dist/types/adapters/browser/BrowserAnthropicAdapter.d.ts.map +1 -0
- package/dist/types/adapters/browser/BrowserOpenAIAdapter.d.ts +46 -0
- package/dist/types/adapters/browser/BrowserOpenAIAdapter.d.ts.map +1 -0
- package/dist/types/adapters/browser/index.d.ts +5 -0
- package/dist/types/adapters/browser/index.d.ts.map +1 -0
- package/dist/types/adapters/createAdapterSubflow.d.ts +36 -0
- package/dist/types/adapters/createAdapterSubflow.d.ts.map +1 -0
- package/dist/types/adapters/createProvider.d.ts +47 -0
- package/dist/types/adapters/createProvider.d.ts.map +1 -0
- package/dist/types/adapters/fallbackProvider.d.ts +45 -0
- package/dist/types/adapters/fallbackProvider.d.ts.map +1 -0
- package/dist/types/adapters/index.d.ts +30 -0
- package/dist/types/adapters/index.d.ts.map +1 -0
- package/dist/types/adapters/mcp/mcpToolProvider.d.ts +41 -0
- package/dist/types/adapters/mcp/mcpToolProvider.d.ts.map +1 -0
- package/dist/types/adapters/memory/inMemory.d.ts +22 -0
- package/dist/types/adapters/memory/inMemory.d.ts.map +1 -0
- package/dist/types/adapters/memory/index.d.ts +3 -0
- package/dist/types/adapters/memory/index.d.ts.map +1 -0
- package/dist/types/adapters/memory/stores.d.ts +92 -0
- package/dist/types/adapters/memory/stores.d.ts.map +1 -0
- package/dist/types/adapters/memory/types.d.ts +74 -0
- package/dist/types/adapters/memory/types.d.ts.map +1 -0
- package/dist/types/adapters/mock/MockAdapter.d.ts +51 -0
- package/dist/types/adapters/mock/MockAdapter.d.ts.map +1 -0
- package/dist/types/adapters/mock/MockRetriever.d.ts +43 -0
- package/dist/types/adapters/mock/MockRetriever.d.ts.map +1 -0
- package/dist/types/adapters/openai/OpenAIAdapter.d.ts +47 -0
- package/dist/types/adapters/openai/OpenAIAdapter.d.ts.map +1 -0
- package/dist/types/adapters/resilientProvider.d.ts +33 -0
- package/dist/types/adapters/resilientProvider.d.ts.map +1 -0
- package/dist/types/agent.js +6 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/compositions/index.d.ts +13 -0
- package/dist/types/compositions/index.d.ts.map +1 -0
- package/dist/types/compositions/withCircuitBreaker.d.ts +43 -0
- package/dist/types/compositions/withCircuitBreaker.d.ts.map +1 -0
- package/dist/types/compositions/withFallback.d.ts +17 -0
- package/dist/types/compositions/withFallback.d.ts.map +1 -0
- package/dist/types/compositions/withRetry.d.ts +27 -0
- package/dist/types/compositions/withRetry.d.ts.map +1 -0
- package/dist/types/concepts/FlowChart.d.ts +52 -0
- package/dist/types/concepts/FlowChart.d.ts.map +1 -0
- package/dist/types/concepts/LLMCall.d.ts +56 -0
- package/dist/types/concepts/LLMCall.d.ts.map +1 -0
- package/dist/types/concepts/Parallel.d.ts +110 -0
- package/dist/types/concepts/Parallel.d.ts.map +1 -0
- package/dist/types/concepts/RAG.d.ts +71 -0
- package/dist/types/concepts/RAG.d.ts.map +1 -0
- package/dist/types/concepts/Swarm.d.ts +98 -0
- package/dist/types/concepts/Swarm.d.ts.map +1 -0
- package/dist/types/concepts/index.d.ts +12 -0
- package/dist/types/concepts/index.d.ts.map +1 -0
- package/dist/types/concepts/specIcons.d.ts +14 -0
- package/dist/types/concepts/specIcons.d.ts.map +1 -0
- package/dist/types/content.js +97 -0
- package/dist/types/content.js.map +1 -0
- package/dist/types/core/config.d.ts +24 -0
- package/dist/types/core/config.d.ts.map +1 -0
- package/dist/types/core/index.d.ts +15 -0
- package/dist/types/core/index.d.ts.map +1 -0
- package/dist/types/core/providers.d.ts +160 -0
- package/dist/types/core/providers.d.ts.map +1 -0
- package/dist/types/core/recorders.d.ts +54 -0
- package/dist/types/core/recorders.d.ts.map +1 -0
- package/dist/types/errors.js +80 -0
- package/dist/types/errors.js.map +1 -0
- package/dist/types/executor/agentLoop.d.ts +37 -0
- package/dist/types/executor/agentLoop.d.ts.map +1 -0
- package/dist/types/executor/index.d.ts +6 -0
- package/dist/types/executor/index.d.ts.map +1 -0
- package/dist/types/explain.barrel.d.ts +20 -0
- package/dist/types/explain.barrel.d.ts.map +1 -0
- package/dist/types/index.d.ts +31 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +29 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/instructions.barrel.d.ts +24 -0
- package/dist/types/instructions.barrel.d.ts.map +1 -0
- package/dist/types/lib/call/callLLMStage.d.ts +29 -0
- package/dist/types/lib/call/callLLMStage.d.ts.map +1 -0
- package/dist/types/lib/call/handleResponseStage.d.ts +35 -0
- package/dist/types/lib/call/handleResponseStage.d.ts.map +1 -0
- package/dist/types/lib/call/helpers.d.ts +64 -0
- package/dist/types/lib/call/helpers.d.ts.map +1 -0
- package/dist/types/lib/call/index.d.ts +10 -0
- package/dist/types/lib/call/index.d.ts.map +1 -0
- package/dist/types/lib/call/parseResponseStage.d.ts +21 -0
- package/dist/types/lib/call/parseResponseStage.d.ts.map +1 -0
- package/dist/types/lib/call/streamingCallLLMStage.d.ts +23 -0
- package/dist/types/lib/call/streamingCallLLMStage.d.ts.map +1 -0
- package/dist/types/lib/call/toolExecutionSubflow.d.ts +70 -0
- package/dist/types/lib/call/toolExecutionSubflow.d.ts.map +1 -0
- package/dist/types/lib/call/types.d.ts +17 -0
- package/dist/types/lib/call/types.d.ts.map +1 -0
- package/dist/types/lib/concepts/Agent.d.ts +9 -0
- package/dist/types/lib/concepts/Agent.d.ts.map +1 -0
- package/dist/types/lib/concepts/AgentBuilder.d.ts +152 -0
- package/dist/types/lib/concepts/AgentBuilder.d.ts.map +1 -0
- package/dist/types/lib/concepts/AgentRunner.d.ts +100 -0
- package/dist/types/lib/concepts/AgentRunner.d.ts.map +1 -0
- package/dist/types/lib/concepts/index.d.ts +3 -0
- package/dist/types/lib/concepts/index.d.ts.map +1 -0
- package/dist/types/lib/instructions/InstructionRecorder.d.ts +85 -0
- package/dist/types/lib/instructions/InstructionRecorder.d.ts.map +1 -0
- package/dist/types/lib/instructions/agentInstruction.d.ts +150 -0
- package/dist/types/lib/instructions/agentInstruction.d.ts.map +1 -0
- package/dist/types/lib/instructions/buildInstructionsToLLMSubflow.d.ts +56 -0
- package/dist/types/lib/instructions/buildInstructionsToLLMSubflow.d.ts.map +1 -0
- package/dist/types/lib/instructions/evaluator.d.ts +99 -0
- package/dist/types/lib/instructions/evaluator.d.ts.map +1 -0
- package/dist/types/lib/instructions/index.d.ts +18 -0
- package/dist/types/lib/instructions/index.d.ts.map +1 -0
- package/dist/types/lib/instructions/inject.d.ts +54 -0
- package/dist/types/lib/instructions/inject.d.ts.map +1 -0
- package/dist/types/lib/instructions/preview.d.ts +85 -0
- package/dist/types/lib/instructions/preview.d.ts.map +1 -0
- package/dist/types/lib/instructions/strictFollowUp.d.ts +88 -0
- package/dist/types/lib/instructions/strictFollowUp.d.ts.map +1 -0
- package/dist/types/lib/instructions/template.d.ts +52 -0
- package/dist/types/lib/instructions/template.d.ts.map +1 -0
- package/dist/types/lib/instructions/types.d.ts +394 -0
- package/dist/types/lib/instructions/types.d.ts.map +1 -0
- package/dist/types/lib/loop/buildAgentLoop.d.ts +67 -0
- package/dist/types/lib/loop/buildAgentLoop.d.ts.map +1 -0
- package/dist/types/lib/loop/index.d.ts +5 -0
- package/dist/types/lib/loop/index.d.ts.map +1 -0
- package/dist/types/lib/loop/types.d.ts +248 -0
- package/dist/types/lib/loop/types.d.ts.map +1 -0
- package/dist/types/lib/narrative/agentRenderer.d.ts +51 -0
- package/dist/types/lib/narrative/agentRenderer.d.ts.map +1 -0
- package/dist/types/lib/narrative/groundingHelpers.d.ts +94 -0
- package/dist/types/lib/narrative/groundingHelpers.d.ts.map +1 -0
- package/dist/types/lib/narrative/index.d.ts +5 -0
- package/dist/types/lib/narrative/index.d.ts.map +1 -0
- package/dist/types/lib/slots/helpers.d.ts +16 -0
- package/dist/types/lib/slots/helpers.d.ts.map +1 -0
- package/dist/types/lib/slots/index.d.ts +7 -0
- package/dist/types/lib/slots/index.d.ts.map +1 -0
- package/dist/types/lib/slots/messages/buildMessagesSubflow.d.ts +40 -0
- package/dist/types/lib/slots/messages/buildMessagesSubflow.d.ts.map +1 -0
- package/dist/types/lib/slots/messages/index.d.ts +3 -0
- package/dist/types/lib/slots/messages/index.d.ts.map +1 -0
- package/dist/types/lib/slots/messages/types.d.ts +26 -0
- package/dist/types/lib/slots/messages/types.d.ts.map +1 -0
- package/dist/types/lib/slots/system-prompt/buildSystemPromptSubflow.d.ts +27 -0
- package/dist/types/lib/slots/system-prompt/buildSystemPromptSubflow.d.ts.map +1 -0
- package/dist/types/lib/slots/system-prompt/index.d.ts +3 -0
- package/dist/types/lib/slots/system-prompt/index.d.ts.map +1 -0
- package/dist/types/lib/slots/system-prompt/types.d.ts +17 -0
- package/dist/types/lib/slots/system-prompt/types.d.ts.map +1 -0
- package/dist/types/lib/slots/tools/buildToolsSubflow.d.ts +23 -0
- package/dist/types/lib/slots/tools/buildToolsSubflow.d.ts.map +1 -0
- package/dist/types/lib/slots/tools/index.d.ts +3 -0
- package/dist/types/lib/slots/tools/index.d.ts.map +1 -0
- package/dist/types/lib/slots/tools/types.d.ts +18 -0
- package/dist/types/lib/slots/tools/types.d.ts.map +1 -0
- package/dist/types/lib/swarm/buildSwarmRouting.d.ts +36 -0
- package/dist/types/lib/swarm/buildSwarmRouting.d.ts.map +1 -0
- package/dist/types/lib/swarm/index.d.ts +3 -0
- package/dist/types/lib/swarm/index.d.ts.map +1 -0
- package/dist/types/llm.js +7 -0
- package/dist/types/llm.js.map +1 -0
- package/dist/types/memory/conversationHelpers.d.ts +23 -0
- package/dist/types/memory/conversationHelpers.d.ts.map +1 -0
- package/dist/types/memory/index.d.ts +2 -0
- package/dist/types/memory/index.d.ts.map +1 -0
- package/dist/types/messages.js +32 -0
- package/dist/types/messages.js.map +1 -0
- package/dist/types/models/index.d.ts +4 -0
- package/dist/types/models/index.d.ts.map +1 -0
- package/dist/types/models/pricing.d.ts +8 -0
- package/dist/types/models/pricing.d.ts.map +1 -0
- package/dist/types/models/providers.d.ts +23 -0
- package/dist/types/models/providers.d.ts.map +1 -0
- package/dist/types/models/types.d.ts +25 -0
- package/dist/types/models/types.d.ts.map +1 -0
- package/dist/types/multiAgent.js +6 -0
- package/dist/types/multiAgent.js.map +1 -0
- package/dist/types/observe.barrel.d.ts +21 -0
- package/dist/types/observe.barrel.d.ts.map +1 -0
- package/dist/types/providers/index.d.ts +15 -0
- package/dist/types/providers/index.d.ts.map +1 -0
- package/dist/types/providers/messages/charBudget.d.ts +19 -0
- package/dist/types/providers/messages/charBudget.d.ts.map +1 -0
- package/dist/types/providers/messages/compositeMessages.d.ts +16 -0
- package/dist/types/providers/messages/compositeMessages.d.ts.map +1 -0
- package/dist/types/providers/messages/fullHistory.d.ts +12 -0
- package/dist/types/providers/messages/fullHistory.d.ts.map +1 -0
- package/dist/types/providers/messages/index.d.ts +15 -0
- package/dist/types/providers/messages/index.d.ts.map +1 -0
- package/dist/types/providers/messages/persistentHistory.d.ts +32 -0
- package/dist/types/providers/messages/persistentHistory.d.ts.map +1 -0
- package/dist/types/providers/messages/slidingWindow.d.ts +16 -0
- package/dist/types/providers/messages/slidingWindow.d.ts.map +1 -0
- package/dist/types/providers/messages/summaryStrategy.d.ts +29 -0
- package/dist/types/providers/messages/summaryStrategy.d.ts.map +1 -0
- package/dist/types/providers/messages/withToolPairSafety.d.ts +19 -0
- package/dist/types/providers/messages/withToolPairSafety.d.ts.map +1 -0
- package/dist/types/providers/prompt/compositePrompt.d.ts +20 -0
- package/dist/types/providers/prompt/compositePrompt.d.ts.map +1 -0
- package/dist/types/providers/prompt/index.d.ts +10 -0
- package/dist/types/providers/prompt/index.d.ts.map +1 -0
- package/dist/types/providers/prompt/skillBasedPrompt.d.ts +33 -0
- package/dist/types/providers/prompt/skillBasedPrompt.d.ts.map +1 -0
- package/dist/types/providers/prompt/static.d.ts +6 -0
- package/dist/types/providers/prompt/static.d.ts.map +1 -0
- package/dist/types/providers/prompt/template.d.ts +6 -0
- package/dist/types/providers/prompt/template.d.ts.map +1 -0
- package/dist/types/providers/tools/PermissionPolicy.d.ts +76 -0
- package/dist/types/providers/tools/PermissionPolicy.d.ts.map +1 -0
- package/dist/types/providers/tools/agentAsTool.d.ts +40 -0
- package/dist/types/providers/tools/agentAsTool.d.ts.map +1 -0
- package/dist/types/providers/tools/compositeTools.d.ts +18 -0
- package/dist/types/providers/tools/compositeTools.d.ts.map +1 -0
- package/dist/types/providers/tools/dynamicTools.d.ts +27 -0
- package/dist/types/providers/tools/dynamicTools.d.ts.map +1 -0
- package/dist/types/providers/tools/gatedTools.d.ts +52 -0
- package/dist/types/providers/tools/gatedTools.d.ts.map +1 -0
- package/dist/types/providers/tools/index.d.ts +15 -0
- package/dist/types/providers/tools/index.d.ts.map +1 -0
- package/dist/types/providers/tools/noTools.d.ts +6 -0
- package/dist/types/providers/tools/noTools.d.ts.map +1 -0
- package/dist/types/providers/tools/staticTools.d.ts +7 -0
- package/dist/types/providers/tools/staticTools.d.ts.map +1 -0
- package/dist/types/providers.barrel.d.ts +34 -0
- package/dist/types/providers.barrel.d.ts.map +1 -0
- package/dist/types/recorders/index.d.ts +6 -0
- package/dist/types/recorders/index.d.ts.map +1 -0
- package/dist/types/recorders/v2/CompositeRecorder.d.ts +30 -0
- package/dist/types/recorders/v2/CompositeRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/CostRecorder.d.ts +43 -0
- package/dist/types/recorders/v2/CostRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/ExplainRecorder.d.ts +67 -0
- package/dist/types/recorders/v2/ExplainRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/GuardrailRecorder.d.ts +45 -0
- package/dist/types/recorders/v2/GuardrailRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/OTelRecorder.d.ts +50 -0
- package/dist/types/recorders/v2/OTelRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/PermissionRecorder.d.ts +66 -0
- package/dist/types/recorders/v2/PermissionRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/QualityRecorder.d.ts +37 -0
- package/dist/types/recorders/v2/QualityRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/RecorderBridge.d.ts +38 -0
- package/dist/types/recorders/v2/RecorderBridge.d.ts.map +1 -0
- package/dist/types/recorders/v2/TokenRecorder.d.ts +54 -0
- package/dist/types/recorders/v2/TokenRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/ToolUsageRecorder.d.ts +34 -0
- package/dist/types/recorders/v2/ToolUsageRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/TurnRecorder.d.ts +36 -0
- package/dist/types/recorders/v2/TurnRecorder.d.ts.map +1 -0
- package/dist/types/recorders/v2/agentObservability.d.ts +68 -0
- package/dist/types/recorders/v2/agentObservability.d.ts.map +1 -0
- package/dist/types/recorders/v2/index.d.ts +21 -0
- package/dist/types/recorders/v2/index.d.ts.map +1 -0
- package/dist/types/resilience.barrel.d.ts +18 -0
- package/dist/types/resilience.barrel.d.ts.map +1 -0
- package/dist/types/retriever.js +7 -0
- package/dist/types/retriever.js.map +1 -0
- package/dist/types/scope/AgentScope.d.ts +87 -0
- package/dist/types/scope/AgentScope.d.ts.map +1 -0
- package/dist/types/scope/index.d.ts +3 -0
- package/dist/types/scope/index.d.ts.map +1 -0
- package/dist/types/scope/types.d.ts +151 -0
- package/dist/types/scope/types.d.ts.map +1 -0
- package/dist/types/security.barrel.d.ts +17 -0
- package/dist/types/security.barrel.d.ts.map +1 -0
- package/dist/types/stages/augmentPrompt.d.ts +7 -0
- package/dist/types/stages/augmentPrompt.d.ts.map +1 -0
- package/dist/types/stages/callLLM.d.ts +8 -0
- package/dist/types/stages/callLLM.d.ts.map +1 -0
- package/dist/types/stages/commitMemory.d.ts +51 -0
- package/dist/types/stages/commitMemory.d.ts.map +1 -0
- package/dist/types/stages/finalize.d.ts +7 -0
- package/dist/types/stages/finalize.d.ts.map +1 -0
- package/dist/types/stages/helpers.d.ts +17 -0
- package/dist/types/stages/helpers.d.ts.map +1 -0
- package/dist/types/stages/index.d.ts +10 -0
- package/dist/types/stages/index.d.ts.map +1 -0
- package/dist/types/stages/parseResponse.d.ts +8 -0
- package/dist/types/stages/parseResponse.d.ts.map +1 -0
- package/dist/types/stages/retrieve.d.ts +8 -0
- package/dist/types/stages/retrieve.d.ts.map +1 -0
- package/dist/types/stages/runnerAsStage.d.ts +18 -0
- package/dist/types/stages/runnerAsStage.d.ts.map +1 -0
- package/dist/types/stream.barrel.d.ts +19 -0
- package/dist/types/stream.barrel.d.ts.map +1 -0
- package/dist/types/streaming/StreamEmitter.d.ts +93 -0
- package/dist/types/streaming/StreamEmitter.d.ts.map +1 -0
- package/dist/types/streaming/index.d.ts +3 -0
- package/dist/types/streaming/index.d.ts.map +1 -0
- package/dist/types/subflows/index.d.ts +3 -0
- package/dist/types/subflows/index.d.ts.map +1 -0
- package/dist/types/subflows/prepareMemory.d.ts +60 -0
- package/dist/types/subflows/prepareMemory.d.ts.map +1 -0
- package/dist/types/tools/ToolRegistry.d.ts +47 -0
- package/dist/types/tools/ToolRegistry.d.ts.map +1 -0
- package/dist/types/tools/askHuman.d.ts +39 -0
- package/dist/types/tools/askHuman.d.ts.map +1 -0
- package/dist/types/tools/index.d.ts +3 -0
- package/dist/types/tools/index.d.ts.map +1 -0
- package/dist/types/tools/validateInput.d.ts +29 -0
- package/dist/types/tools/validateInput.d.ts.map +1 -0
- package/dist/types/tools/zodToJsonSchema.d.ts +9 -0
- package/dist/types/tools/zodToJsonSchema.d.ts.map +1 -0
- package/dist/types/tools.js +6 -0
- package/dist/types/tools.js.map +1 -0
- package/dist/types/types/adapter.d.ts +36 -0
- package/dist/types/types/adapter.d.ts.map +1 -0
- package/dist/types/types/agent.d.ts +37 -0
- package/dist/types/types/agent.d.ts.map +1 -0
- package/dist/types/types/content.d.ts +104 -0
- package/dist/types/types/content.d.ts.map +1 -0
- package/dist/types/types/errors.d.ts +27 -0
- package/dist/types/types/errors.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +14 -0
- package/dist/types/types/index.d.ts.map +1 -0
- package/dist/types/types/llm.d.ts +78 -0
- package/dist/types/types/llm.d.ts.map +1 -0
- package/dist/types/types/messages.d.ts +40 -0
- package/dist/types/types/messages.d.ts.map +1 -0
- package/dist/types/types/multiAgent.d.ts +57 -0
- package/dist/types/types/multiAgent.d.ts.map +1 -0
- package/dist/types/types/retriever.d.ts +41 -0
- package/dist/types/types/retriever.d.ts.map +1 -0
- package/dist/types/types/tools.d.ts +19 -0
- package/dist/types/types/tools.d.ts.map +1 -0
- package/package.json +178 -0
|
@@ -0,0 +1,597 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: agentfootprint
|
|
3
|
+
description: Use when building AI agents with agentfootprint — LLM calls, ReAct agents, RAG pipelines, multi-agent flowcharts, swarm orchestration, tools, recorders, providers, adapters, and testing. Also use when someone asks how agentfootprint works or wants to understand the framework.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# agentfootprint — The Explainable Agent Framework
|
|
7
|
+
|
|
8
|
+
agentfootprint builds AI agents you can explain, audit, and trust. Every agent is a footprintjs flowchart — every LLM call, tool use, and decision auto-generates a causal trace.
|
|
9
|
+
|
|
10
|
+
**Core principle:** Every concept is a flowchart. Collect during traversal, never post-process.
|
|
11
|
+
|
|
12
|
+
```bash
|
|
13
|
+
npm install agentfootprint footprintjs
|
|
14
|
+
```
|
|
15
|
+
|
|
16
|
+
---
|
|
17
|
+
|
|
18
|
+
## 5 Concepts — The Concept Ladder
|
|
19
|
+
|
|
20
|
+
Each concept builds on footprintjs flowcharts. Each has a builder (`.create()`) and a runner (`.build()`).
|
|
21
|
+
|
|
22
|
+
### 1. LLMCall — Single LLM Call (No Tools, No Loop)
|
|
23
|
+
|
|
24
|
+
Flowchart: `SeedScope → CallLLM → ParseResponse → Finalize`
|
|
25
|
+
|
|
26
|
+
```typescript
|
|
27
|
+
import { LLMCall, mock } from 'agentfootprint';
|
|
28
|
+
|
|
29
|
+
const caller = LLMCall.create({ provider: mock([{ content: 'Hello!' }]) })
|
|
30
|
+
.system('You are helpful.')
|
|
31
|
+
.build();
|
|
32
|
+
|
|
33
|
+
const result = await caller.run('Hi');
|
|
34
|
+
// result.content === 'Hello!'
|
|
35
|
+
// result.messages — full message history
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
**Builder API:**
|
|
39
|
+
- `LLMCall.create({ provider })` — create with an LLM provider
|
|
40
|
+
- `.system(prompt)` — set system prompt
|
|
41
|
+
- `.recorder(rec)` — attach an AgentRecorder
|
|
42
|
+
- `.build()` — returns `LLMCallRunner`
|
|
43
|
+
|
|
44
|
+
**Runner API:**
|
|
45
|
+
- `runner.run(message, { signal?, timeoutMs? })` — execute
|
|
46
|
+
- `runner.getNarrative()` — causal trace from last run
|
|
47
|
+
- `runner.getSnapshot()` — full memory state
|
|
48
|
+
- `runner.getSpec()` — flowchart spec for visualization
|
|
49
|
+
- `runner.toFlowChart()` — expose for subflow composition
|
|
50
|
+
|
|
51
|
+
### 2. Agent — ReAct Agent (Tools + Loop)
|
|
52
|
+
|
|
53
|
+
Flowchart: `SeedScope → PromptAssembly → CallLLM → ParseResponse → HandleResponse → loopTo('call-llm')`
|
|
54
|
+
|
|
55
|
+
```typescript
|
|
56
|
+
import { Agent, defineTool, mock } from 'agentfootprint';
|
|
57
|
+
|
|
58
|
+
const searchTool = defineTool({
|
|
59
|
+
id: 'search',
|
|
60
|
+
description: 'Search the web',
|
|
61
|
+
inputSchema: { type: 'object', properties: { query: { type: 'string' } }, required: ['query'] },
|
|
62
|
+
handler: async (args) => `Results for: ${args.query}`,
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
const agent = Agent.create({ provider: mock([
|
|
66
|
+
{ content: '', toolCalls: [{ id: 'tc1', name: 'search', args: { query: 'AI' } }] },
|
|
67
|
+
{ content: 'AI is artificial intelligence.' },
|
|
68
|
+
]), name: 'researcher' })
|
|
69
|
+
.system('You are a research assistant.')
|
|
70
|
+
.tool(searchTool)
|
|
71
|
+
.maxIterations(5)
|
|
72
|
+
.build();
|
|
73
|
+
|
|
74
|
+
const result = await agent.run('What is AI?');
|
|
75
|
+
// result.content — final answer
|
|
76
|
+
// result.messages — full conversation
|
|
77
|
+
// result.iterations — number of ReAct loops
|
|
78
|
+
```
|
|
79
|
+
|
|
80
|
+
**Builder API:**
|
|
81
|
+
- `Agent.create({ provider, name? })` — create with LLM provider
|
|
82
|
+
- `.system(prompt)` — set system prompt
|
|
83
|
+
- `.tool(toolDef)` — register a single tool
|
|
84
|
+
- `.tools(toolDefs)` — register multiple tools
|
|
85
|
+
- `.maxIterations(n)` — set max ReAct loop iterations (default: 10)
|
|
86
|
+
- `.recorder(rec)` — attach an AgentRecorder
|
|
87
|
+
- `.build()` — returns `AgentRunner`
|
|
88
|
+
|
|
89
|
+
**Runner API:**
|
|
90
|
+
- `runner.run(message, { signal?, timeoutMs? })` — execute
|
|
91
|
+
- `runner.getNarrative()` / `runner.getNarrativeEntries()` — causal trace
|
|
92
|
+
- `runner.getSnapshot()` — full memory state
|
|
93
|
+
- `runner.getSpec()` — flowchart spec
|
|
94
|
+
- `runner.toFlowChart()` — expose for subflow composition
|
|
95
|
+
- `runner.getMessages()` — conversation history
|
|
96
|
+
- `runner.resetConversation()` — clear conversation state
|
|
97
|
+
|
|
98
|
+
### 3. RAG — Retrieve-Augment-Generate
|
|
99
|
+
|
|
100
|
+
Flowchart: `SeedScope → Retrieve → AugmentPrompt → CallLLM → ParseResponse → Finalize`
|
|
101
|
+
|
|
102
|
+
```typescript
|
|
103
|
+
import { RAG, mock, mockRetriever } from 'agentfootprint';
|
|
104
|
+
|
|
105
|
+
const rag = RAG.create({
|
|
106
|
+
provider: mock([{ content: 'Based on the documents...' }]),
|
|
107
|
+
retriever: mockRetriever([
|
|
108
|
+
{ chunks: [{ content: 'AI was invented...', score: 0.95, metadata: {} }] },
|
|
109
|
+
]),
|
|
110
|
+
})
|
|
111
|
+
.system('Answer based on provided context only.')
|
|
112
|
+
.topK(5)
|
|
113
|
+
.minScore(0.7)
|
|
114
|
+
.build();
|
|
115
|
+
|
|
116
|
+
const result = await rag.run('What is AI?');
|
|
117
|
+
// result.content — generated answer
|
|
118
|
+
// result.chunks — retrieved chunks
|
|
119
|
+
// result.query — the query used for retrieval
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
**Builder API:**
|
|
123
|
+
- `RAG.create({ provider, retriever })` — create with LLM + retriever
|
|
124
|
+
- `.system(prompt)` — set system prompt
|
|
125
|
+
- `.topK(n)` — number of chunks to retrieve
|
|
126
|
+
- `.minScore(score)` — minimum relevance threshold
|
|
127
|
+
- `.recorder(rec)` — attach an AgentRecorder
|
|
128
|
+
- `.build()` — returns `RAGRunner`
|
|
129
|
+
|
|
130
|
+
### 4. FlowChart — Sequential Multi-Agent Composition
|
|
131
|
+
|
|
132
|
+
Run agents in order, each feeding into the next. Agents with `toFlowChart()` are mounted as subflows (enables UI drill-down).
|
|
133
|
+
|
|
134
|
+
```typescript
|
|
135
|
+
import { FlowChart, Agent, mock, CostRecorder } from 'agentfootprint';
|
|
136
|
+
|
|
137
|
+
const researcher = Agent.create({ provider: mock([{ content: 'Research findings...' }]), name: 'researcher' })
|
|
138
|
+
.system('You are a researcher.')
|
|
139
|
+
.build();
|
|
140
|
+
|
|
141
|
+
const writer = Agent.create({ provider: mock([{ content: 'Final article...' }]), name: 'writer' })
|
|
142
|
+
.system('You are a writer.')
|
|
143
|
+
.build();
|
|
144
|
+
|
|
145
|
+
const costRecorder = new CostRecorder();
|
|
146
|
+
|
|
147
|
+
const pipeline = FlowChart.create()
|
|
148
|
+
.agent('researcher', 'Research', researcher)
|
|
149
|
+
.agent('writer', 'Write', writer)
|
|
150
|
+
.recorder(costRecorder)
|
|
151
|
+
.build();
|
|
152
|
+
|
|
153
|
+
const result = await pipeline.run('Write about AI');
|
|
154
|
+
// result.content — final output
|
|
155
|
+
// result.agents — per-agent results [{ id, name, content, latencyMs }]
|
|
156
|
+
// result.totalLatencyMs — end-to-end timing
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
**Builder API:**
|
|
160
|
+
- `FlowChart.create()` — create empty pipeline
|
|
161
|
+
- `.agent(id, name, runner, { inputMapper?, outputMapper? }?)` — add a runner
|
|
162
|
+
- `.recorder(rec)` — attach an AgentRecorder
|
|
163
|
+
- `.build()` — returns `FlowChartRunner`
|
|
164
|
+
|
|
165
|
+
### 5. Swarm — LLM-Routed Multi-Agent
|
|
166
|
+
|
|
167
|
+
An orchestrator agent delegates to specialist agents as tools. The LLM decides routing dynamically.
|
|
168
|
+
|
|
169
|
+
```typescript
|
|
170
|
+
import { Swarm, Agent, mock } from 'agentfootprint';
|
|
171
|
+
|
|
172
|
+
const researcher = Agent.create({ provider: mock([{ content: 'Research done.' }]), name: 'researcher' })
|
|
173
|
+
.system('You research topics.')
|
|
174
|
+
.build();
|
|
175
|
+
|
|
176
|
+
const writer = Agent.create({ provider: mock([{ content: 'Article written.' }]), name: 'writer' })
|
|
177
|
+
.system('You write articles.')
|
|
178
|
+
.build();
|
|
179
|
+
|
|
180
|
+
const swarm = Swarm.create({ provider: mock([
|
|
181
|
+
{ content: '', toolCalls: [{ id: 'tc1', name: 'research', args: { message: 'AI' } }] },
|
|
182
|
+
{ content: 'Here is the article about AI.' },
|
|
183
|
+
]) })
|
|
184
|
+
.system('You are a router. Delegate to the right specialist.')
|
|
185
|
+
.specialist('research', 'Research a topic in depth.', researcher)
|
|
186
|
+
.specialist('write', 'Write polished content.', writer)
|
|
187
|
+
.maxIterations(10)
|
|
188
|
+
.build();
|
|
189
|
+
|
|
190
|
+
const result = await swarm.run('Write about AI');
|
|
191
|
+
// result.content — orchestrator's final response
|
|
192
|
+
// result.agents — which specialists were invoked
|
|
193
|
+
// result.totalLatencyMs
|
|
194
|
+
```
|
|
195
|
+
|
|
196
|
+
**Builder API:**
|
|
197
|
+
- `Swarm.create({ provider, name? })` — create with orchestrator LLM
|
|
198
|
+
- `.system(prompt)` — orchestrator system prompt
|
|
199
|
+
- `.specialist(id, description, runner, { inputMapper? }?)` — register specialist
|
|
200
|
+
- `.tool(toolDef)` — register non-agent tool for orchestrator
|
|
201
|
+
- `.maxIterations(n)` — max ReAct iterations
|
|
202
|
+
- `.recorder(rec)` — attach an AgentRecorder
|
|
203
|
+
- `.build()` — returns `SwarmRunner`
|
|
204
|
+
|
|
205
|
+
---
|
|
206
|
+
|
|
207
|
+
## Tools — `defineTool()`
|
|
208
|
+
|
|
209
|
+
```typescript
|
|
210
|
+
import { defineTool } from 'agentfootprint';
|
|
211
|
+
|
|
212
|
+
const calculator = defineTool({
|
|
213
|
+
id: 'calculate',
|
|
214
|
+
description: 'Evaluate a math expression',
|
|
215
|
+
inputSchema: {
|
|
216
|
+
type: 'object',
|
|
217
|
+
properties: { expression: { type: 'string' } },
|
|
218
|
+
required: ['expression'],
|
|
219
|
+
},
|
|
220
|
+
handler: async (args) => {
|
|
221
|
+
return String(eval(args.expression));
|
|
222
|
+
},
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
// Register with agent
|
|
226
|
+
agent.tool(calculator);
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
**Fields:** `id` (unique), `description` (sent to LLM), `inputSchema` (JSON Schema), `handler` (async function returning string).
|
|
230
|
+
|
|
231
|
+
---
|
|
232
|
+
|
|
233
|
+
## Recorder System — Observe Without Changing Behavior
|
|
234
|
+
|
|
235
|
+
All recorders implement the `AgentRecorder` interface with optional hooks:
|
|
236
|
+
`onTurnStart`, `onLLMCall`, `onToolCall`, `onTurnComplete`, `onError`, `clear`.
|
|
237
|
+
|
|
238
|
+
### Built-in Recorders
|
|
239
|
+
|
|
240
|
+
```typescript
|
|
241
|
+
import {
|
|
242
|
+
TokenRecorder,
|
|
243
|
+
CostRecorder,
|
|
244
|
+
TurnRecorder,
|
|
245
|
+
ToolUsageRecorder,
|
|
246
|
+
QualityRecorder,
|
|
247
|
+
GuardrailRecorder,
|
|
248
|
+
CompositeRecorder,
|
|
249
|
+
} from 'agentfootprint';
|
|
250
|
+
|
|
251
|
+
// Token tracking
|
|
252
|
+
const tokens = new TokenRecorder();
|
|
253
|
+
|
|
254
|
+
// Cost tracking (needs model pricing)
|
|
255
|
+
const cost = new CostRecorder();
|
|
256
|
+
|
|
257
|
+
// Turn-by-turn history
|
|
258
|
+
const turns = new TurnRecorder();
|
|
259
|
+
|
|
260
|
+
// Tool usage statistics
|
|
261
|
+
const toolUsage = new ToolUsageRecorder();
|
|
262
|
+
|
|
263
|
+
// Quality evaluation (with custom judge)
|
|
264
|
+
const quality = new QualityRecorder(async (content) => ({
|
|
265
|
+
score: 0.9,
|
|
266
|
+
dimension: 'relevance',
|
|
267
|
+
}));
|
|
268
|
+
|
|
269
|
+
// Guardrail checks
|
|
270
|
+
const guardrail = new GuardrailRecorder([
|
|
271
|
+
async (content) => ({ passed: true, checkName: 'no-pii' }),
|
|
272
|
+
]);
|
|
273
|
+
|
|
274
|
+
// Compose multiple recorders into one
|
|
275
|
+
const composite = new CompositeRecorder([tokens, cost, turns]);
|
|
276
|
+
```
|
|
277
|
+
|
|
278
|
+
### Attach to Any Concept
|
|
279
|
+
|
|
280
|
+
```typescript
|
|
281
|
+
// On builders
|
|
282
|
+
const agent = Agent.create({ provider })
|
|
283
|
+
.system('...')
|
|
284
|
+
.recorder(tokens)
|
|
285
|
+
.recorder(cost)
|
|
286
|
+
.build();
|
|
287
|
+
|
|
288
|
+
// Or use CompositeRecorder
|
|
289
|
+
const agent = Agent.create({ provider })
|
|
290
|
+
.recorder(new CompositeRecorder([tokens, cost, turns]))
|
|
291
|
+
.build();
|
|
292
|
+
```
|
|
293
|
+
|
|
294
|
+
### Read Results After Execution
|
|
295
|
+
|
|
296
|
+
```typescript
|
|
297
|
+
await agent.run('Hello');
|
|
298
|
+
|
|
299
|
+
tokens.getStats(); // { totalInput: 50, totalOutput: 30, ... }
|
|
300
|
+
cost.getEntries(); // [{ model, inputTokens, outputTokens, cost }]
|
|
301
|
+
cost.getTotalCost(); // 0.0042
|
|
302
|
+
turns.getEntries(); // [{ message, content, messageCount, ... }]
|
|
303
|
+
toolUsage.getStats(); // { totalCalls: 3, tools: { search: { calls: 2, ... } } }
|
|
304
|
+
```
|
|
305
|
+
|
|
306
|
+
### Custom Recorder
|
|
307
|
+
|
|
308
|
+
```typescript
|
|
309
|
+
import type { AgentRecorder } from 'agentfootprint';
|
|
310
|
+
|
|
311
|
+
const myRecorder: AgentRecorder = {
|
|
312
|
+
id: 'my-recorder',
|
|
313
|
+
onLLMCall(event) {
|
|
314
|
+
console.log(`Model: ${event.model}, tokens: ${event.usage?.totalTokens}`);
|
|
315
|
+
},
|
|
316
|
+
onToolCall(event) {
|
|
317
|
+
console.log(`Tool: ${event.toolName}, latency: ${event.latencyMs}ms`);
|
|
318
|
+
},
|
|
319
|
+
clear() { /* reset state */ },
|
|
320
|
+
};
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
---
|
|
324
|
+
|
|
325
|
+
## Providers & Adapters
|
|
326
|
+
|
|
327
|
+
### Mock Provider (Testing)
|
|
328
|
+
|
|
329
|
+
```typescript
|
|
330
|
+
import { mock, mockRetriever } from 'agentfootprint';
|
|
331
|
+
|
|
332
|
+
// Mock LLM responses (consumed in order)
|
|
333
|
+
const provider = mock([
|
|
334
|
+
{ content: 'First response' },
|
|
335
|
+
{ content: '', toolCalls: [{ id: 'tc1', name: 'search', args: { query: 'AI' } }] },
|
|
336
|
+
{ content: 'Final answer' },
|
|
337
|
+
]);
|
|
338
|
+
|
|
339
|
+
// Mock retriever
|
|
340
|
+
const retriever = mockRetriever([
|
|
341
|
+
{ chunks: [{ content: 'doc text', score: 0.9, metadata: {} }] },
|
|
342
|
+
]);
|
|
343
|
+
```
|
|
344
|
+
|
|
345
|
+
### Real Providers
|
|
346
|
+
|
|
347
|
+
```typescript
|
|
348
|
+
import { createProvider, anthropic, openai, bedrock } from 'agentfootprint';
|
|
349
|
+
|
|
350
|
+
// Anthropic Claude
|
|
351
|
+
const claude = createProvider(anthropic({
|
|
352
|
+
modelId: 'claude-sonnet-4-20250514',
|
|
353
|
+
apiKey: process.env.ANTHROPIC_API_KEY,
|
|
354
|
+
}));
|
|
355
|
+
|
|
356
|
+
// OpenAI
|
|
357
|
+
const gpt = createProvider(openai({
|
|
358
|
+
modelId: 'gpt-4o',
|
|
359
|
+
apiKey: process.env.OPENAI_API_KEY,
|
|
360
|
+
}));
|
|
361
|
+
|
|
362
|
+
// AWS Bedrock
|
|
363
|
+
const bedrockLLM = createProvider(bedrock({
|
|
364
|
+
modelId: 'anthropic.claude-3-sonnet',
|
|
365
|
+
region: 'us-east-1',
|
|
366
|
+
}));
|
|
367
|
+
```
|
|
368
|
+
|
|
369
|
+
### Protocol Adapters
|
|
370
|
+
|
|
371
|
+
```typescript
|
|
372
|
+
import { mcpToolProvider, a2aRunner } from 'agentfootprint';
|
|
373
|
+
|
|
374
|
+
// MCP — connect to external tool servers
|
|
375
|
+
const mcpTools = mcpToolProvider({ client: mcpClient });
|
|
376
|
+
|
|
377
|
+
// A2A — call remote agents
|
|
378
|
+
const remoteAgent = a2aRunner({ client: a2aClient, agentId: 'remote-1' });
|
|
379
|
+
```
|
|
380
|
+
|
|
381
|
+
---
|
|
382
|
+
|
|
383
|
+
## Prompt Providers
|
|
384
|
+
|
|
385
|
+
```typescript
|
|
386
|
+
import { staticPrompt, templatePrompt, skillBasedPrompt, compositePrompt } from 'agentfootprint';
|
|
387
|
+
|
|
388
|
+
// Static string
|
|
389
|
+
const p1 = staticPrompt('You are helpful.');
|
|
390
|
+
|
|
391
|
+
// Template with variables
|
|
392
|
+
const p2 = templatePrompt('You are a {role} assistant.');
|
|
393
|
+
|
|
394
|
+
// Skill-based (select instructions by context)
|
|
395
|
+
const p3 = skillBasedPrompt({
|
|
396
|
+
skills: [
|
|
397
|
+
{ id: 'search', instruction: 'Use search tool for factual queries.' },
|
|
398
|
+
{ id: 'math', instruction: 'Use calculator for math questions.' },
|
|
399
|
+
],
|
|
400
|
+
selector: (ctx) => ctx.message.includes('calculate') ? ['math'] : ['search'],
|
|
401
|
+
});
|
|
402
|
+
|
|
403
|
+
// Compose providers
|
|
404
|
+
const p4 = compositePrompt({ providers: [p1, p3] });
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
---
|
|
408
|
+
|
|
409
|
+
## Tool Providers
|
|
410
|
+
|
|
411
|
+
```typescript
|
|
412
|
+
import { agentAsTool, compositeTools, defineTool } from 'agentfootprint';
|
|
413
|
+
|
|
414
|
+
// Wrap an agent as a tool (for Swarm pattern)
|
|
415
|
+
const agentTool = agentAsTool({
|
|
416
|
+
id: 'researcher',
|
|
417
|
+
description: 'Research a topic',
|
|
418
|
+
runner: researchAgent,
|
|
419
|
+
});
|
|
420
|
+
|
|
421
|
+
// Combine tool sets
|
|
422
|
+
const allTools = compositeTools([staticTools, mcpTools]);
|
|
423
|
+
```
|
|
424
|
+
|
|
425
|
+
---
|
|
426
|
+
|
|
427
|
+
## Compositions (Resilience)
|
|
428
|
+
|
|
429
|
+
```typescript
|
|
430
|
+
import { withRetry, withFallback, withCircuitBreaker } from 'agentfootprint';
|
|
431
|
+
|
|
432
|
+
// Retry with exponential backoff
|
|
433
|
+
const resilient = withRetry(agent, { maxRetries: 3, delayMs: 1000 });
|
|
434
|
+
|
|
435
|
+
// Fallback to cheaper model
|
|
436
|
+
const withFb = withFallback(primaryAgent, fallbackAgent);
|
|
437
|
+
|
|
438
|
+
// Circuit breaker
|
|
439
|
+
const breaker = withCircuitBreaker(agent, {
|
|
440
|
+
failureThreshold: 5,
|
|
441
|
+
resetTimeMs: 30000,
|
|
442
|
+
});
|
|
443
|
+
```
|
|
444
|
+
|
|
445
|
+
---
|
|
446
|
+
|
|
447
|
+
## Streaming
|
|
448
|
+
|
|
449
|
+
```typescript
|
|
450
|
+
import { StreamEmitter, SSEFormatter } from 'agentfootprint';
|
|
451
|
+
|
|
452
|
+
const emitter = new StreamEmitter();
|
|
453
|
+
emitter.on('chunk', (chunk) => process.stdout.write(chunk.text));
|
|
454
|
+
|
|
455
|
+
const formatter = new SSEFormatter();
|
|
456
|
+
// Convert stream events to SSE format for HTTP responses
|
|
457
|
+
```
|
|
458
|
+
|
|
459
|
+
---
|
|
460
|
+
|
|
461
|
+
## Testing Patterns
|
|
462
|
+
|
|
463
|
+
Every concept uses `mock([...])` for deterministic testing — no API keys needed.
|
|
464
|
+
|
|
465
|
+
```typescript
|
|
466
|
+
import { Agent, defineTool, mock, TokenRecorder, CostRecorder } from 'agentfootprint';
|
|
467
|
+
|
|
468
|
+
// 1. Define tools
|
|
469
|
+
const searchTool = defineTool({
|
|
470
|
+
id: 'search',
|
|
471
|
+
description: 'Search',
|
|
472
|
+
inputSchema: { type: 'object', properties: { q: { type: 'string' } }, required: ['q'] },
|
|
473
|
+
handler: async (args) => `Found: ${args.q}`,
|
|
474
|
+
});
|
|
475
|
+
|
|
476
|
+
// 2. Mock provider with scripted responses
|
|
477
|
+
const provider = mock([
|
|
478
|
+
{ content: '', toolCalls: [{ id: 'tc1', name: 'search', args: { q: 'test' } }] },
|
|
479
|
+
{ content: 'The answer is 42.' },
|
|
480
|
+
]);
|
|
481
|
+
|
|
482
|
+
// 3. Build with recorders
|
|
483
|
+
const tokens = new TokenRecorder();
|
|
484
|
+
const cost = new CostRecorder();
|
|
485
|
+
|
|
486
|
+
const agent = Agent.create({ provider, name: 'test-agent' })
|
|
487
|
+
.system('You are helpful.')
|
|
488
|
+
.tool(searchTool)
|
|
489
|
+
.recorder(tokens)
|
|
490
|
+
.recorder(cost)
|
|
491
|
+
.build();
|
|
492
|
+
|
|
493
|
+
// 4. Run and assert
|
|
494
|
+
const result = await agent.run('What is the answer?');
|
|
495
|
+
expect(result.content).toBe('The answer is 42.');
|
|
496
|
+
expect(result.iterations).toBe(2);
|
|
497
|
+
|
|
498
|
+
// 5. Inspect narrative (causal trace)
|
|
499
|
+
const narrative = agent.getNarrative();
|
|
500
|
+
// Verify the execution path
|
|
501
|
+
expect(narrative.some(line => line.includes('CallLLM'))).toBe(true);
|
|
502
|
+
```
|
|
503
|
+
|
|
504
|
+
---
|
|
505
|
+
|
|
506
|
+
## Architecture
|
|
507
|
+
|
|
508
|
+
```
|
|
509
|
+
src/
|
|
510
|
+
├── types/ → Content blocks, messages, LLM types, tool types, agent types
|
|
511
|
+
├── models/ → Model configs (anthropic, openai, ollama, bedrock)
|
|
512
|
+
├── adapters/ → Mock, Anthropic, OpenAI, Bedrock, MCP, A2A, createProvider
|
|
513
|
+
├── tools/ → ToolRegistry, defineTool
|
|
514
|
+
├── memory/ → Message helpers (appendMessage, slidingWindow, truncate)
|
|
515
|
+
├── scope/ → AgentScope (typed paths into footprintjs ScopeFacade)
|
|
516
|
+
├── stages/ → Reusable stage functions (seedScope, callLLM, parseResponse, etc.)
|
|
517
|
+
├── core/ → AgentRecorder, PromptProvider, ToolProvider, AgentLoopConfig
|
|
518
|
+
├── concepts/ → LLMCall, Agent, RAG, FlowChart, Swarm (builders + runners)
|
|
519
|
+
├── recorders/ → Scope-level + AgentRecorder implementations
|
|
520
|
+
│ └── v2/ → TokenRecorder, CostRecorder, TurnRecorder, ToolUsageRecorder, etc.
|
|
521
|
+
├── providers/ → Prompt providers, tool providers (agentAsTool, compositeTools)
|
|
522
|
+
├── compositions/ → withRetry, withFallback, withCircuitBreaker
|
|
523
|
+
├── streaming/ → StreamEmitter, SSEFormatter
|
|
524
|
+
└── executor/ → agentLoop (low-level loop runner)
|
|
525
|
+
```
|
|
526
|
+
|
|
527
|
+
Single entry point: `import { ... } from 'agentfootprint'`
|
|
528
|
+
|
|
529
|
+
---
|
|
530
|
+
|
|
531
|
+
## Anti-Patterns to Avoid
|
|
532
|
+
|
|
533
|
+
1. **Never use `CostRecorderV2`** — it's deprecated. Use `CostRecorder`.
|
|
534
|
+
2. **Never post-process the flowchart** — use recorders to collect data during traversal.
|
|
535
|
+
3. **Never build agents without `mock()`** in tests — no API keys in test suites.
|
|
536
|
+
4. **Don't skip `.recorder(rec)`** — always attach recorders to observe execution.
|
|
537
|
+
5. **Don't use raw footprintjs stages** for agent logic — use concept builders (`Agent.create()`, `LLMCall.create()`, etc.).
|
|
538
|
+
6. **Don't create flat stages for multi-agent** — use `FlowChart.create().agent(...)` or `Swarm.create().specialist(...)` so the UI gets drill-down.
|
|
539
|
+
7. **Don't manually call `agentLoop()`** unless building a custom concept — use the 5 concept builders.
|
|
540
|
+
8. **Don't mix `mock()` and real providers** in the same builder — pick one.
|
|
541
|
+
|
|
542
|
+
---
|
|
543
|
+
|
|
544
|
+
## Concept Ladder Summary
|
|
545
|
+
|
|
546
|
+
| Concept | Pattern | Tools | Loop | Multi-Agent |
|
|
547
|
+
|---------|---------|-------|------|-------------|
|
|
548
|
+
| `LLMCall` | Single call | No | No | No |
|
|
549
|
+
| `Agent` | ReAct | Yes | Yes | No |
|
|
550
|
+
| `RAG` | Retrieve + Generate | No | No | No |
|
|
551
|
+
| `FlowChart` | Sequential pipeline | Via agents | Via agents | Yes |
|
|
552
|
+
| `Swarm` | LLM-routed handoff | Yes + agents | Yes | Yes |
|
|
553
|
+
|
|
554
|
+
---
|
|
555
|
+
|
|
556
|
+
## Common Patterns
|
|
557
|
+
|
|
558
|
+
### Agent with tools and cost tracking
|
|
559
|
+
|
|
560
|
+
```typescript
|
|
561
|
+
const cost = new CostRecorder();
|
|
562
|
+
const agent = Agent.create({ provider: createProvider(anthropic({ modelId: 'claude-sonnet-4-20250514' })) })
|
|
563
|
+
.system('You are a helpful assistant.')
|
|
564
|
+
.tool(searchTool)
|
|
565
|
+
.tool(calculatorTool)
|
|
566
|
+
.recorder(cost)
|
|
567
|
+
.build();
|
|
568
|
+
|
|
569
|
+
await agent.run('Calculate 2+2 and search for AI');
|
|
570
|
+
console.log(`Total cost: $${cost.getTotalCost()}`);
|
|
571
|
+
```
|
|
572
|
+
|
|
573
|
+
### Multi-agent pipeline with narrative
|
|
574
|
+
|
|
575
|
+
```typescript
|
|
576
|
+
const pipeline = FlowChart.create()
|
|
577
|
+
.agent('planner', 'Plan', plannerAgent)
|
|
578
|
+
.agent('executor', 'Execute', executorAgent)
|
|
579
|
+
.agent('reviewer', 'Review', reviewerAgent)
|
|
580
|
+
.build();
|
|
581
|
+
|
|
582
|
+
const result = await pipeline.run('Build a website');
|
|
583
|
+
console.log(pipeline.getNarrative()); // Full causal trace across all agents
|
|
584
|
+
```
|
|
585
|
+
|
|
586
|
+
### Swarm with specialist routing
|
|
587
|
+
|
|
588
|
+
```typescript
|
|
589
|
+
const swarm = Swarm.create({ provider })
|
|
590
|
+
.system('Route to the best specialist for the task.')
|
|
591
|
+
.specialist('coder', 'Write and debug code.', coderAgent)
|
|
592
|
+
.specialist('writer', 'Write documentation and articles.', writerAgent)
|
|
593
|
+
.specialist('analyst', 'Analyze data and produce reports.', analystAgent)
|
|
594
|
+
.build();
|
|
595
|
+
|
|
596
|
+
await swarm.run('Write unit tests for the auth module');
|
|
597
|
+
```
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
# agentfootprint — Cline Rules
|
|
2
|
+
|
|
3
|
+
The explainable agent framework. Every agent is a footprintjs flowchart with auto-generated causal traces.
|
|
4
|
+
|
|
5
|
+
## Core Principle
|
|
6
|
+
|
|
7
|
+
**Every concept is a flowchart. Collect during traversal, never post-process.**
|
|
8
|
+
|
|
9
|
+
## 5 Concepts
|
|
10
|
+
|
|
11
|
+
```typescript
|
|
12
|
+
// 1. LLMCall — single call, no tools, no loop
|
|
13
|
+
LLMCall.create({ provider }).system('...').recorder(rec).build()
|
|
14
|
+
|
|
15
|
+
// 2. Agent — ReAct agent with tools + loop
|
|
16
|
+
Agent.create({ provider, name? }).system('...').tool(t).maxIterations(n).recorder(rec).build()
|
|
17
|
+
|
|
18
|
+
// 3. RAG — retrieve-augment-generate
|
|
19
|
+
RAG.create({ provider, retriever }).system('...').topK(5).recorder(rec).build()
|
|
20
|
+
|
|
21
|
+
// 4. FlowChart — sequential multi-agent
|
|
22
|
+
FlowChart.create().agent('id', 'name', runner).recorder(rec).build()
|
|
23
|
+
|
|
24
|
+
// 5. Swarm — LLM-routed multi-agent
|
|
25
|
+
Swarm.create({ provider }).specialist('id', 'desc', runner).recorder(rec).build()
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
## Tools
|
|
29
|
+
|
|
30
|
+
```typescript
|
|
31
|
+
import { defineTool } from 'agentfootprint';
|
|
32
|
+
defineTool({ id, description, inputSchema, handler })
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
## Recorders
|
|
36
|
+
|
|
37
|
+
```typescript
|
|
38
|
+
import { TokenRecorder, CostRecorder, TurnRecorder, ToolUsageRecorder,
|
|
39
|
+
QualityRecorder, GuardrailRecorder, CompositeRecorder } from 'agentfootprint';
|
|
40
|
+
// Attach via .recorder(rec) on any builder
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## Providers
|
|
44
|
+
|
|
45
|
+
```typescript
|
|
46
|
+
import { mock, mockRetriever, createProvider, anthropic, openai } from 'agentfootprint';
|
|
47
|
+
|
|
48
|
+
// Testing
|
|
49
|
+
mock([{ content: 'Hi' }])
|
|
50
|
+
mockRetriever([{ chunks: [{ content: '...', score: 0.9, metadata: {} }] }])
|
|
51
|
+
|
|
52
|
+
// Production
|
|
53
|
+
createProvider(anthropic({ modelId: 'claude-sonnet-4-20250514', apiKey: '...' }))
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
## Prompt & Tool Providers
|
|
57
|
+
|
|
58
|
+
```typescript
|
|
59
|
+
import { staticPrompt, templatePrompt, skillBasedPrompt, compositePrompt } from 'agentfootprint';
|
|
60
|
+
import { agentAsTool, compositeTools, mcpToolProvider, a2aRunner } from 'agentfootprint';
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
## Compositions
|
|
64
|
+
|
|
65
|
+
```typescript
|
|
66
|
+
import { withRetry, withFallback, withCircuitBreaker } from 'agentfootprint';
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## Runner API (all concepts)
|
|
70
|
+
|
|
71
|
+
```typescript
|
|
72
|
+
runner.run(message, { signal?, timeoutMs? })
|
|
73
|
+
runner.getNarrative() // causal trace
|
|
74
|
+
runner.getSnapshot() // memory state
|
|
75
|
+
runner.getSpec() // flowchart spec
|
|
76
|
+
runner.toFlowChart() // for subflow composition
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
## Rules
|
|
80
|
+
|
|
81
|
+
- Use `CostRecorder` (not `CostRecorderV2`)
|
|
82
|
+
- Never post-process — use recorders
|
|
83
|
+
- Use `mock([...])` in tests
|
|
84
|
+
- Use concept builders, not raw stages
|
|
85
|
+
- Use `FlowChart`/`Swarm` for multi-agent
|