Skip to content

AgentConfig

type AgentConfig = {
model?: | Model<BaseModelConfig>
| string;
messages?: | Message[]
| MessageData[];
tools?: ToolList;
systemPrompt?: | SystemPrompt
| SystemPromptData;
appState?: Record<string, JSONValue>;
modelState?: Record<string, JSONValue>;
printer?: boolean;
conversationManager?: ConversationManager;
contextManager?: ContextManagerStrategy;
plugins?: Plugin[];
retryStrategy?: | RetryStrategy
| RetryStrategy[]
| null;
interventions?: InterventionHandler[];
structuredOutputSchema?: z.ZodSchema;
sessionManager?: SessionManager;
memoryManager?: | MemoryManager
| MemoryManagerConfig;
traceAttributes?: Record<string, AttributeValue>;
name?: string;
description?: string;
id?: string;
toolExecutor?: ToolExecutorStrategy;
sandbox?: Sandbox | false;
};

Defined in: src/agent/agent.ts:174

Configuration object for creating a new Agent.

optional model?:
| Model<BaseModelConfig>
| string;

Defined in: src/agent/agent.ts:197

The model instance that the agent will use to make decisions. Accepts either a Model instance or a string representing a Bedrock model ID. When a string is provided, it will be used to create a BedrockModel instance.

// Using a string model ID (creates BedrockModel)
const agent = new Agent({
model: 'global.anthropic.claude-sonnet-4-6'
})
// Using an explicit BedrockModel instance with configuration
const agent = new Agent({
model: new BedrockModel({
modelId: 'global.anthropic.claude-sonnet-4-6',
temperature: 0.7,
maxTokens: 2048
})
})

optional messages?:
| Message[]
| MessageData[];

Defined in: src/agent/agent.ts:199

An initial set of messages to seed the agent’s conversation history.


optional tools?: ToolList;

Defined in: src/agent/agent.ts:205

An initial set of tools to register with the agent. Accepts nested arrays of tools at any depth, which will be flattened automatically. Agent instances are automatically wrapped as tools via Agent.asTool.


optional systemPrompt?:
| SystemPrompt
| SystemPromptData;

Defined in: src/agent/agent.ts:209

A system prompt which guides model behavior.


optional appState?: Record<string, JSONValue>;

Defined in: src/agent/agent.ts:211

Optional initial state values for the agent.


optional modelState?: Record<string, JSONValue>;

Defined in: src/agent/agent.ts:216

Optional initial model-provider state (e.g., restoring responseId from a prior session). Typically only set when hydrating from a snapshot.


optional printer?: boolean;

Defined in: src/agent/agent.ts:222

Enable automatic printing of agent output to console. When true, prints text generation, reasoning, and tool usage as they occur. Defaults to true.


optional conversationManager?: ConversationManager;

Defined in: src/agent/agent.ts:227

Conversation manager for handling message history and context overflow. Defaults to SlidingWindowConversationManager with windowSize of 40.


optional contextManager?: ContextManagerStrategy;

Defined in: src/agent/agent.ts:241

Context management strategy.

  • "auto": SummarizingConversationManager with proactive compression + ContextOffloader.
  • "agentic": Lets the model drive context management via injected tools.

If conversationManager is also provided, the user’s conversation manager is used instead. Defaults to undefined (SlidingWindowConversationManager, no offloader).

The offloader uses in-memory storage that does not persist across process restarts. For agents using sessionManager, provide an explicit ContextOffloader with durable storage via the plugins parameter.


optional plugins?: Plugin[];

Defined in: src/agent/agent.ts:245

Plugins to register with the agent.


optional retryStrategy?:
| RetryStrategy
| RetryStrategy[]
| null;

Defined in: src/agent/agent.ts:256

Retry strategy (or strategies) for failed model/tool calls.

  • Omitted: a sensible default DefaultModelRetryStrategy with exponential backoff is used.
  • Single strategy: the given strategy is used.
  • Array of strategies: all are registered, in the given order. Passing two instances of the same concrete class logs a warning — they will collide on plugin.name when the plugin registry initializes.
  • null or []: retries are explicitly disabled; failures propagate to the caller.

optional interventions?: InterventionHandler[];

Defined in: src/agent/agent.ts:260

Intervention handlers evaluated in registration order at each lifecycle point.


optional structuredOutputSchema?: z.ZodSchema;

Defined in: src/agent/agent.ts:264

Zod schema for structured output validation.


optional sessionManager?: SessionManager;

Defined in: src/agent/agent.ts:268

Session manager for saving and restoring agent sessions


optional memoryManager?:
| MemoryManager
| MemoryManagerConfig;

Defined in: src/agent/agent.ts:274

Memory manager for cross-session memory retrieval and storage. Manages one or more memory stores and exposes search/add tools. Accepts a MemoryManager instance or a MemoryManagerConfig object (auto-wrapped).


optional traceAttributes?: Record<string, AttributeValue>;

Defined in: src/agent/agent.ts:280

Custom trace attributes to include in all spans. These attributes are merged with standard attributes in telemetry spans. Telemetry must be enabled globally via telemetry.setupTracer() for these to take effect.


optional name?: string;

Defined in: src/agent/agent.ts:284

Optional name for the agent. Defaults to “Strands Agent”.


optional description?: string;

Defined in: src/agent/agent.ts:288

Optional description of what the agent does.


optional id?: string;

Defined in: src/agent/agent.ts:292

Optional unique identifier for the agent. Defaults to “agent”.


optional toolExecutor?: ToolExecutorStrategy;

Defined in: src/agent/agent.ts:297

Strategy for executing tool calls from a single assistant turn. Defaults to 'concurrent'. See ToolExecutorStrategy for details.


optional sandbox?: Sandbox | false;

Defined in: src/agent/agent.ts:311

Execution environment for running commands, code, and file operations. When provided, sandbox-aware tools route operations through it.

Two distinct intents, even though they resolve to the same host execution in Node today:

  • Omitted: use the environment’s default sandbox (host execution in Node). This default is the slot reserved for richer behavior later.
  • false: explicitly opt out of a managed sandbox and run on the host.

Keep false distinct from omitting so the opt-out stays stable even if the default changes.