agent-sdk-rs
agent-sdk-rs is a lightweight Rust agent framework inspired by browser-use's SDK design.
It is intentionally minimal:
- small surface area
- explicit control flow
- simple tool integration
- easy embedding into Rust binaries
This project is expected to stay lightweight by default. New features should preserve that core philosophy.
What It Is
A Rust SDK for tool-using agents with:
- an
Agentloop query+query_stream- provider adapter boundary
- tool execution + dependency injection
- explicit completion semantics via
done
Coverage (v0.1.0 alpha)
Implemented:
- Anthropic provider adapter (
anthropic-ai-sdk) - Google Gemini provider adapter (Google Generative Language API)
- xAI Grok provider adapter (xAI Chat Completions API)
Agent+ builder APIqueryandquery_stream- event stream model (
MessageStart,StepStart,ToolCall,ToolResult,FinalResponse, etc.) - tool registration with JSON schema
- dependency map + dependency overrides
- translated Claude-code-style tool set:
bash,read,write,editglob_search,greptodo_read,todo_writedone
- optional
claude_codebinary target
Out of scope right now:
- Laminar integration
Roadmap
Near-term:
- Keep xAI/Anthropic/Google adapter trait behavior consistent
- Keep adapter trait stable across providers
- Improve docs/examples while keeping core small
Non-goal:
- turning this into a heavy orchestration framework
Documentation Status (Alpha)
- We currently focus docs on the core API surface (
Agent, query APIs, provider adapters, tool primitives). - If you enable
missing_docslinting globally, you will see many warnings on secondary/public-for-now items. - This crate is still alpha; some currently
pubitems exist for development convenience and may become private or reshaped before1.0.
Install
[]
= "0.1.0"
Quick Usage
1. Basic agent query
use ;
let model = from_env?;
let mut agent = builder.model.build?;
let answer = agent.query.await?;
println!;
# Ok::
2. Google Gemini query
use ;
let model = from_env?;
let mut agent = builder.model.build?;
let answer = agent.query.await?;
println!;
# Ok::
3. Streaming events
use ;
use StreamExt;
let model = from_env?;
let mut agent = builder.model.build?;
let stream = agent.query_stream;
pin_mut!;
while let Some = stream.next.await
# Ok::
4. xAI Grok query
use ;
let model = from_env?;
let mut agent = builder.model.build?;
let answer = agent.query.await?;
println!;
# Ok::
5. Claude-code tool pack
use ;
use ;
let model = from_env?;
let sandbox = ?;
let mut agent = builder
.model
.tools
.dependency
.require_done_tool
.build?;
# Ok::
Optional Binary
Run the fun Claude-code-like binary:
Environment:
ANTHROPIC_API_KEYrequiredANTHROPIC_MODELoptional (default set in binary)GOOGLE_API_KEYorGEMINI_API_KEYrequired for GeminiXAI_API_KEY(orGROK_API_KEY) required for GrokCLAUDE_CODE_SANDBOXoptional
Examples
Releases (release-plz)
Releases are automated via GitHub Actions + release-plz.
- Workflow:
.github/workflows/release-plz.yml - Config:
release-plz.toml - Required secret:
CARGO_REGISTRY_TOKEN
Behavior:
feat:,fix:,perf:,refactor:,revert:,build:commits onmaincan trigger/update a release PR.docs:andchore:do not trigger a release PR by default.
Flow:
- Merge releasable commits to
main. - release-plz opens/updates a release PR.
- Merge that release PR.
- release-plz publishes crates, creates tags, and creates GitHub releases.
License
MIT. See LICENSE.