Documentation ◆ Samples ◆ Tools ◆ Agent Builder ◆ MCP Server
Strands Agents is a simple yet powerful SDK that takes a model-driven approach to building and running AI agents. From simple conversational assistants to complex autonomous workflows, from local development to production deployment, Strands Agents scales with your needs.
This monorepo contains the Python SDK, TypeScript SDK, documentation site, and supporting packages:
| Directory | Description |
|---|---|
strands-py/ |
Python SDK: agent loop, model providers, tools (PyPI · releases) |
strands-ts/ |
TypeScript SDK: agent loop, model providers, tools (npm · releases) |
strands-wasm/ |
WebAssembly bindings for running Python tools from TypeScript agents |
strands-py-wasm/ |
Python host for WASM components (bridges WIT interfaces to Python) |
strandly/ |
Developer CLI for local builds, codegen, and workspace tooling |
site/ |
Source for the strandsagents.com documentation site (Astro/Starlight) |
designs/ |
Design proposals for significant features (RFC-style) |
Build an agent harness. Control it end-to-end.
- Build your way. Any model, any cloud. Context management, execution limits, and observability built in before you write a line of config. Swap backends when you scale; your code stays the same.
- Model agnostic. First-class support for Amazon Bedrock, Anthropic, OpenAI, and Gemini, plus many more providers and custom ones.
- Stay in control. The agent loop traces every decision by default. Hooks let you intercept any step to log it, validate it, or redirect it.
- Deliver outcomes that work. Guardrails catch mistakes before they run. Steering handlers let agents correct themselves instead of failing silently.
MCP, streaming, multi-agent patterns, and structured output are all built in.
Both SDKs default to the Amazon Bedrock model provider, so you'll need AWS credentials configured and model access enabled for Claude Sonnet. The Quickstart Guide covers configuring other providers (Anthropic, OpenAI, Gemini, Ollama, and more).
Requires Python 3.10+:
pip install strands-agents strands-agents-toolsfrom strands import Agent
from strands_tools import calculator
agent = Agent(tools=[calculator])
agent("What is the square root of 1764")The Python SDK README covers tools, model providers, MCP, and bidirectional streaming.
Requires Node.js 20+:
npm install @strands-agents/sdkimport { Agent } from '@strands-agents/sdk'
const agent = new Agent()
const result = await agent.invoke('What is the square root of 1764?')
console.log(result)More in the TypeScript SDK README, including Zod-typed tools, structured output, and multi-agent patterns.
For detailed guidance & examples, explore our documentation:
- User Guide
- Quick Start Guide
- Agent Loop
- Examples
- API Reference: Python · TypeScript
- Production & Deployment Guide
The docs themselves live in this monorepo under site/, and doc PRs are welcome alongside code changes.
Git operations (commits, branches, PRs) are done from the repo root. Each package has its own toolchain:
Python SDK (strands-py/):
cd strands-py
pip install hatch
hatch test # run unit tests
hatch fmt # format & lintTypeScript SDK (strands-ts/):
npm ci # install from repo root
npm run build # build
npm test # run unit testsDocumentation site (site/):
cd site
npm install
npm run dev # local dev server at http://localhost:4321/We welcome contributions! See our Contributing Guide for details on:
- Reporting bugs & features
- Development setup
- Contributing via Pull Requests
- Code of Conduct
- Reporting of security issues
Come meet the Strands team and other users on Discord
This project is licensed under the Apache License 2.0 - see the LICENSE.APACHE file for details.
See CONTRIBUTING for more information.