Metadata-Version: 2.4
Name: agentr
Version: 0.1.4
Summary: Add your description here
Author-email: Manoj Bajaj <manojbajaj95@gmail.com>
Requires-Python: >=3.11
Requires-Dist: loguru>=0.7.3
Requires-Dist: mcp>=1.5.0
Requires-Dist: pyyaml>=6.0.2
Requires-Dist: typer>=0.15.2
Description-Content-Type: text/markdown

# AgentR

AgentR is a Python framework for building powerful agent applications with integrated third-party services. It provides a clean abstraction for incorporating various API services as "applications" into your agent workflow.

## 🌟 Features

- **Simplified API Integration**: Connect to services like GitHub, Google Calendar, Gmail, Reddit, Tavily, and more with minimal code
- **Authentication Handling**: Built-in support for API keys and OAuth-based authentication flows
- **Extensible Architecture**: Easily build and add new app integrations with minimal boilerplate
- **MCP (Model Context Protocol) Integration**: Seamlessly works with MCP server architecture
- **Credential Management**: Flexible storage options for API credentials with memory and environment-based implementations

## 🔧 Installation

Install AgentR using pip:

```bash
pip install agentr
```

## 🚀 Quick Start

### 1. Get an API Key
Before using AgentR with services that require authorization (like GitHub, Gmail, etc.), you'll need an AgentR API key:

Visit https://agentr.dev to create an account
Generate an API key from your dashboard
Set it as an environment variable or include it directly in your code:

```bash
export AGENTR_API_KEY="your_api_key_here"
```

### 2. Create a basic server

```bash
from agentr.server import TestServer

# Define your applications list
apps_list = [
    {
        "name": "tavily",
        "integration": {
            "name": "tavily_api_key",
            "type": "api_key",
            "store": {
                "type": "environment",
            }
        },        
    },
    {
        "name": "zenquotes",
        "integration": None
    },
    {
        "name": "github",
        "integration": {
            "name": "github",
            "type": "agentr",
        }
    }
]

# Create a server with these applications
server = TestServer(name="My Agent Server", description="A server for my agent apps", apps_list=apps_list)

# Run the server
if __name__ == "__main__":
    server.run()
```

## 🧩 Available Applications
AgentR comes with several pre-built applications:

| Application | Description | Authentication Type |
|-------------|-------------|---------------------|
| GitHub | Star repositories and more | OAuth (AgentR) |
| Google Calendar | Retrieve calendar events | OAuth (AgentR) |
| Gmail | Send emails | OAuth (AgentR) |
| Reddit | Access Reddit data | OAuth (AgentR) |
| Resend | Send emails via Resend API | API Key |
| Tavily | Web search capabilities | API Key |
| ZenQuotes | Get inspirational quotes | None |

> **Note**: More applications are coming soon! Stay tuned for updates to our application catalog.

## 🔐 Integration Types
AgentR supports two primary integration types:

### 1. API Key Integration
For services that authenticate via API keys:
```python
{
    "name": "service_name",
    "integration": {
        "name": "service_api_key",
        "type": "api_key",
        "store": {
            "type": "environment",  # or "memory"
        }
    }
}
```

### 2. OAuth Integration (via AgentR)
For services requiring OAuth flow:
```python
{
    "name": "service_name",
    "integration": {
        "name": "service_name",
        "type": "agentr"
    }
}
```
When using OAuth integrations, users will be directed to authenticate with the service provider through a secure flow managed by AgentR.

## 🤖 CLI Usage
AgentR includes a command-line interface for common operations:

```bash
# Get version information
agentr version

# Generate API client from OpenAPI schema
agentr generate --schema path/to/openapi.yaml

# Run the test server
agentr run

# Install AgentR for specific applications
agentr install claude
```

## 📋 Requirements

- Python 3.11+
- Dependencies (automatically installed):
  - loguru >= 0.7.3
  - mcp >= 1.5.0
  - pyyaml >= 6.0.2
  - typer >= 0.15.2


