Skip to main content

AI Agents framework with Pydantic AI support and LLM Gateway integration

Project description

Rakam Systems Agent

The agent package of Rakam Systems providing AI agent implementations powered by Pydantic AI.

Overview

rakam-systems-agent provides flexible AI agents with tool integration, chat history, and LLM gateway abstractions. This package depends on rakam-systems-core.

Features

  • Configuration-First Design: Change agents without code changes — just update YAML files
  • Async/Sync Support: Full support for both synchronous and asynchronous agent operations
  • Tool Integration: Easy tool definition and integration using the Tool.from_schema pattern
  • Model Settings: Control model behavior including parallel tool calls, temperature, and max tokens
  • Pydantic AI Powered: Built on top of Pydantic AI library
  • Streaming Support: Both sync and async streaming interfaces
  • Chat History: Multiple backends (JSON, SQLite, PostgreSQL)
  • LLM Gateway: Unified interface for OpenAI and Mistral AI

Installation

pip install rakam-systems-agent

Available extras:

Extra What it adds
llm-providers openai, mistralai, tiktoken
all Everything above
pip install rakam-systems-agent[all]

Quick Start

import asyncio
from rakam_systems_agent import BaseAgent
from rakam_systems_core.ai_core.interfaces import ModelSettings
from rakam_systems_core.ai_core.interfaces.tool import ToolComponent as Tool

async def get_weather(city: str) -> dict:
    """Get weather information for a city"""
    return {"city": city, "temperature": 72, "condition": "sunny"}

agent = BaseAgent(
    name="weather_agent",
    model="openai:gpt-4o",
    system_prompt="You are a helpful weather assistant.",
    tools=[
        Tool.from_schema(
            function=get_weather,
            name='get_weather',
            description='Get weather information for a city',
            json_schema={
                'type': 'object',
                'properties': {
                    'city': {'type': 'string', 'description': 'The city name'},
                },
                'required': ['city'],
                'additionalProperties': False,
            },
            takes_ctx=False,
        ),
    ],
)

async def main():
    result = await agent.arun(
        "What's the weather in San Francisco?",
        model_settings=ModelSettings(parallel_tool_calls=True),
    )
    print(result.output_text)

asyncio.run(main())

Core Components

  • BaseAgent — Primary agent implementation powered by Pydantic AI, with tool support and streaming
  • Tool — Wrapper for tool functions using Tool.from_schema pattern
  • ModelSettings — Configure parallel tool calls, temperature, max tokens
  • LLM Gateway — Provider-agnostic interface for OpenAI and Mistral (details)
  • Chat History — JSON, SQLite, and PostgreSQL backends
  • MCP Server — Message-based component registry for agent tools (details)

Package Structure

rakam-systems-agent/
├── src/rakam_systems_agent/
│   ├── components/
│   │   ├── base_agent.py         # BaseAgent (Pydantic AI-powered)
│   │   ├── llm_gateway/          # LLM provider gateways
│   │   ├── chat_history/         # Chat history backends
│   │   ├── tools/                # Built-in tools
│   │   └── __init__.py           # Exports
│   └── server/                   # MCP server
└── pyproject.toml

Documentation

For API reference, advanced usage (dependencies, streaming, YAML config), and troubleshooting, see the official documentation.

Contributing

When adding new agent types:

  1. Inherit from BaseAgent
  2. Implement ainfer() for async or infer() for sync
  3. Add tests in tests/

License

See main project LICENSE file.

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

rakam_systems_agent-0.1.2rc2.tar.gz (36.4 kB view details)

Uploaded Source

Built Distribution

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

rakam_systems_agent-0.1.2rc2-py3-none-any.whl (53.6 kB view details)

Uploaded Python 3

File details

Details for the file rakam_systems_agent-0.1.2rc2.tar.gz.

File metadata

File hashes

Hashes for rakam_systems_agent-0.1.2rc2.tar.gz
Algorithm Hash digest
SHA256 2f2fd5fbe3e7cefc864e0a0ae1591ed5d0ebc3501458119d1da04173b4f1668b
MD5 b60366dbc5193523f5c15e60b3b9feb5
BLAKE2b-256 dc07484050c83059cb4a0a32348bc48f62bbc0dcc6e38abce8b050b22b8877d1

See more details on using hashes here.

File details

Details for the file rakam_systems_agent-0.1.2rc2-py3-none-any.whl.

File metadata

File hashes

Hashes for rakam_systems_agent-0.1.2rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 0c1c8ad0e86f08081d4f535ffc3eeb36534a242d45ebad35e20ec82607e431a6
MD5 125a5afd383e26f8b4a86f78ab80f994
BLAKE2b-256 40de1baf14a09f57ab6374f423690d017795377c901a400971a3582f4679742a

See more details on using hashes here.

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