A lightweight, extensible framework for building LLM agents with Model Context Protocol (MCP) support
Project description
Pocket-Agent
A lightweight, extensible framework for building LLM agents with Model Context Protocol (MCP) support
Table of Contents
Why Pocket Agent?
Most agent frameworks are severely over-bloated. The reason for this is that they are trying to support too many things at once and make every possible agent implementation "simple". In the end, you might find yourself using 5-10% of the framework's code for your use case, meaning 90-95% is noise when you encounter a bug. This makes adding features and debugging unnecessarily complex.
Pocket Agent takes the opposite approach by implementing the basic functionalities of an Agent as an abstraction one layer above the MCP Client with useful features to provide first-class support for customization. This makes Pocket Agent extremely lightweight. In fact, so lightweight that the entire core framework and documentation can easily fit into most LLM context windows (see the built-in utility for this here). The minimal nature also means that you will use 90-95% of the framework's code for every agent you create.
Despite the minimal code, Pocket Agent is extremely powerful, even out-of-the-box with no custom extensions. By default, Pocket Agent enables users to:
- Use any remote or local MCP server(s) to integrate any amount of custom tools
- Run a typical agent loop (generate message, execute tool calls, handle tool results until the LLM does not call any tools)
- Allow tools to be run in parallel, minimizing execution bottlenecks
- Build multi-agent systems using built-in features to facilitate interaction
- View agents' behavior in a minimal built-in CLI frontend
- Use any local or remote LLM and enforce tpm/rpm limits for parallel LLM generations (Thanks to LiteLLM)
Design Principles
🚀 Lightweight & Simple
- Clean abstractions that separate agent logic from MCP client details
- Core functionality is only 2 files
- Only implements the core, non-case-specific features of an LLM agent
💡 Extensible
- Easily integrate a custom frontend using the built-in event system
- Easily implement fully custom agent behaviors
- Easily develop multi-agent systems
Installation
Install with uv (Recommended):
uv add pocket-agent
Install with pip:
pip install pocket-agent
Quick Start (For LLMs)
LLMs are excellent at building with Pocket Agent. Mostly, because the entirety of the core framework is minimal enough to easily fit into most LLM context windows.
Pocket Agent provides a simple command-line utility for this exact use case: pocket-dump
📄 Using pocket-dump
After installation, use pocket-dump to generate complete documentation with source code:
# Generate complete documentation + source code as pocket-agent-source.md
pocket-dump
# Custom filename
pocket-dump my-pocket-agent-reference.md
# Only include documentation
pocket-dump --docs-only
# Only include source code
pocket-dump --source-only
The generated file contains everything an LLM needs to understand and build with Pocket Agent - no need to piece together multiple documentation sources or guess at implementation details.
Quick Start (For Humans)
You can use PocketAgent out of the box in 3 steps:
-
Configure the agent:
from pocket_agent import AgentConfig # Configure and run config = AgentConfig( llm_model="gpt-4", system_prompt="You are a helpful assistant." )
-
Define the mcp servers the agent can access:
servers = { "mcpServers": { "weather_tools": { "transport": "stdio", "command": "python", "args": ["server.py"], "cwd": "path/to/server.py" } } }
-
Initialize and run the agent:
import asyncio from pocket_agent import PocketAgent agent = PocketAgent(agent_config=config, mcp_config=servers) agent_final_answer = await agent.run("What's the weather fo London?")
In the above example, the run method will add the input as a user message, and then run in a loop generating new messages and running any tools called by the configured LLM until the configured LLM generates a response which does not have any tool calls. All of the messages to and from the agent are neatly formatted in the console by default.
Pocket Agents are meant to be extended far beyond this behavior. Refer to the sections below for implementation examples and full documentation
🧑🍳 Cookbook
Find example implementations of Pocket Agents and their extensions in the Cookbook
📖 Documentation
For comprehensive documentation on all features and advanced usage, see the documentation folder:
- Getting Started - Detailed quick start guide and examples
- Core Concepts - PocketAgent base class, step method, message management
- Hooks and Events - Customizing agent behavior and frontend integration
- Multi-Model Support - Working with different LLM providers
- PocketAgentClient - MCP client wrapper and advanced features
- Multi-Agent Systems - Building complex agent architectures
- Agent-as-a-Server - Using agents as MCP servers
- Testing - Test suite and coverage
Feature Roadmap
Core Features
| Feature | Status | Priority | Description |
|---|---|---|---|
| Agent Abstraction | ✅ Implemented | - | Basic agent abstraction with PocketAgent base class |
| MCP Protocol Support | ✅ Implemented | - | Full integration with Model Context Protocol via fastmcp |
| Multi-Model Support | ✅ Implemented | - | Support for any LiteLLM compatible model/endpoint |
| Tool Execution | ✅ Implemented | - | Automatic parallel tool calling and results handling |
| Hook System | ✅ Implemented | - | Allow configurable hooks to inject functionality during agent execution |
| Logging Integration | ✅ Implemented | - | Built-in logging with custom logger support |
| Multi-Agent Integration | ✅ Implemented | - | Allow a PocketAgent to accept other PocketAgents as Sub Agents and automatically set up Sub Agents as tools for the Agent to use |
| function-as-a-tool support | 📋 Planned | Medium | Allow python functions to be passed to PocketAgent to act as tools |
| **Define Defaults for standard MCP Client handlers | 📋 Planned | Medium | Standard MCP client methods (i.e. sampling, progress, etc) may benefit from default implementations if custom behavior is not often needed |
| Streaming Responses | 📋 Planned | Medium | Real-time response streaming support |
| **Define Defaults for standard MCP Client handlers | 📋 Planned | Medium | Standard MCP client methods (i.e. sampling, progress, etc) may benefit from default implementations if custom behavior is not often needed |
| Resources Integration | 📋 Planned | Medium | Automatically set up mcp read_resource functionality as a tool (resources are not very commonly used today so this may not be necessary) |
Modality support
| Modality | Status | Priority | Description |
|---|---|---|---|
| Text | ✅ Implemented | - | Multi-modal input support for vision models |
| Images | ✅ Implemented | - | Multi-modal input support for VLMs with option to enable/disable |
| Audio | 📋 Planned | Low | Multi-modal input support for LLMs which allow audio inputs |
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pocket_agent-0.2.3.tar.gz.
File metadata
- Download URL: pocket_agent-0.2.3.tar.gz
- Upload date:
- Size: 5.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0152e44c310e340755ae49ef7cd8fc8dea5de697b527dc1ddae89bc08d8462d8
|
|
| MD5 |
d73655be021223bfa53e0f4a8eb01a05
|
|
| BLAKE2b-256 |
0ba421738ad520cdfac889083b5040a65b6d7ebfd0202ce4321d23234455f2b0
|
File details
Details for the file pocket_agent-0.2.3-py3-none-any.whl.
File metadata
- Download URL: pocket_agent-0.2.3-py3-none-any.whl
- Upload date:
- Size: 33.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cf6a88dff405625b7757e4d7465593c4680a39a3963899f03ebe99194a4be423
|
|
| MD5 |
52f47d7258fea9de3b8efbb2bfce2137
|
|
| BLAKE2b-256 |
2b81ebe8dc6738f6ce946f8a5efc0a1b2a3881d2af75cf606e8ec659ccd17cae
|