Skip to main content

A Python framework for building LLM-powered agents with modular state, tools, and MCP support.

Project description

Pygent

A Python framework for building LLM-powered agents with modular state management, composable operators, and LLM tool-calling integration (including MCP).

Features

  • Modular architecture — Agents, context, tools, memory, and plans as composable modules
  • State management — Consistent save/load and serialization via PygentOperator
  • LLM-native — Messages and tools align with OpenAI-style APIs
  • MCP support — Use Model Context Protocol (SSE and stdio) tools via ToolManager
  • Toolkits — Built-in toolkits such as RestrictedTerminal for safe shell access

Requirements

  • Python 3.11+

Installation

From the project root:

pip install -e .

Or with uv:

uv pip install -e .

Quick Start

from pygent.agent import BaseAgent
from pygent.context import BaseContext
from pygent.llm import AsyncOpenAIClient
from pygent.message import UserMessage
from pygent.module.tool import ToolManager
from pygent.toolkits import RestrictedTerminal

class MyAgent(BaseAgent):
    def __init__(self):
        super().__init__()
        self.llm = AsyncOpenAIClient(
            base_url="https://api.openai.com/v1",
            api_key="YOUR_API_KEY",
            model_name="gpt-4",
        )
        self.tool_manager = ToolManager()
        terminal = RestrictedTerminal(root_dir=".")
        self.tool_manager.add_module("terminal", terminal)
        self.tool_manager.register_tools(terminal.get_tools())

    async def run(self, user_input: str):
        context = BaseContext(system_prompt="You are a helpful assistant.")
        context.add_message(UserMessage(content=user_input))
        # ... tool loop and LLM calls (see examples/react_agent)
        return context

See examples/react_agent/react_agent.py for a full ReAct-style agent with tool calling.

Project Layout

  • pygent/ — Core package: agents, context, LLM client, messages, modules (tool, plan, memory, etc.), toolkits
  • examples/ — Example agents (e.g. ReAct agent)
  • MCPs/ — Example MCP servers (e.g. LocalMemoryMCP)
  • docs/Architecture and API documentation
  • tests/ — Pytest tests

Documentation

License

Apache-2.0. See LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pygent_ai-0.1.4.tar.gz (74.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pygent_ai-0.1.4-py3-none-any.whl (70.3 kB view details)

Uploaded Python 3

File details

Details for the file pygent_ai-0.1.4.tar.gz.

File metadata

  • Download URL: pygent_ai-0.1.4.tar.gz
  • Upload date:
  • Size: 74.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pygent_ai-0.1.4.tar.gz
Algorithm Hash digest
SHA256 2548772c72a522f8bfb0a29d8efe0241498f98881028e3b82b789c97edda7cba
MD5 2702f44463e1612ed168d378f767d30c
BLAKE2b-256 b28db3d45bb747f019a423d3acbbe17c82b9a02e3a8161f104c722a180b3f746

See more details on using hashes here.

Provenance

The following attestation bundles were made for pygent_ai-0.1.4.tar.gz:

Publisher: python-publish.yml on pygent-ai/pygent

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pygent_ai-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: pygent_ai-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 70.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pygent_ai-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 2c02f9e208412f3cb6e90fdc22d1fd173bfb6d9cb194c169f220d3c64d7c1734
MD5 3f35910c14926f996eb33d73d2940ac4
BLAKE2b-256 c43f4ede2ea50cf2d3e906ec4b7be0e01d36cadcac68f6b816d96614494b10ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for pygent_ai-0.1.4-py3-none-any.whl:

Publisher: python-publish.yml on pygent-ai/pygent

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page