Metadata-Version: 2.4
Name: macsdk
Version: 0.5.1
Summary: Multi-Agent Chatbot SDK - Build customizable multi-agent chatbots with ease
Project-URL: Homepage, https://github.com/juanje/macsdk
Project-URL: Documentation, https://github.com/juanje/macsdk#readme
Project-URL: Repository, https://github.com/juanje/macsdk
Author-email: Juanje Ojeda <juanje@redhat.com>
License: MIT
Keywords: ai,chatbot,langchain,langgraph,llm,multi-agent,sdk
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Requires-Python: >=3.12
Requires-Dist: aiofiles>=24.0.0
Requires-Dist: click>=8.0.0
Requires-Dist: fastapi>=0.115.0
Requires-Dist: httpx>=0.27.0
Requires-Dist: jinja2>=3.0.0
Requires-Dist: jsonpath-ng>=1.6.0
Requires-Dist: langchain-core>=1.0.0
Requires-Dist: langchain-google-genai>=2.0.0
Requires-Dist: langchain>=1.0.1
Requires-Dist: langgraph>=1.0.0
Requires-Dist: pydantic-settings>=2.0.0
Requires-Dist: pydantic>=2.0.0
Requires-Dist: pyyaml>=6.0.0
Requires-Dist: rich>=13.0.0
Requires-Dist: twine>=6.2.0
Requires-Dist: uvicorn>=0.32.0
Requires-Dist: websockets>=13.0
Provides-Extra: all
Requires-Dist: beautifulsoup4>=4.12.0; extra == 'all'
Requires-Dist: certifi>=2023.0.0; extra == 'all'
Requires-Dist: chromadb>=0.4.0; extra == 'all'
Requires-Dist: langchain-chroma>=0.1.0; extra == 'all'
Requires-Dist: langchain-community>=0.2.0; extra == 'all'
Requires-Dist: tiktoken>=0.5.0; extra == 'all'
Requires-Dist: tqdm>=4.66.0; extra == 'all'
Provides-Extra: rag
Requires-Dist: beautifulsoup4>=4.12.0; extra == 'rag'
Requires-Dist: certifi>=2023.0.0; extra == 'rag'
Requires-Dist: chromadb>=0.4.0; extra == 'rag'
Requires-Dist: langchain-chroma>=0.1.0; extra == 'rag'
Requires-Dist: langchain-community>=0.2.0; extra == 'rag'
Requires-Dist: tiktoken>=0.5.0; extra == 'rag'
Requires-Dist: tqdm>=4.66.0; extra == 'rag'
Description-Content-Type: text/markdown

# MACSDK - Multi-Agent Chatbot SDK

A comprehensive SDK for building customizable multi-agent chatbots with RAG support, web interfaces, and reusable API tools.

## What can it do?

- Create a **chatbot** with CLI and Web UI, ready to be used immediately.
- Create **agents** with a CLI chat (for testing purposes) ready to be used.
- **Register agents** into chatbots, so your chatbot can call any of the agents you add.

## How does it work?

The chatbot has a **"supervisor"** agent that knows about the registered agents and decides when to use one or another. It uses them as tools.

## Key Features

- **🏗️ Scaffolding CLI**: Generate chatbot and agent projects with a single command.
- **🤖 Intelligent Supervisor**: Automatic routing and orchestration of specialist agents.
- **📚 RAG Support**: Enable RAG when creating a chatbot to pull docs from URLs (HTML/Markdown) or local files.
- **🧠 Context Management**: Keeps user queries and final answers in context, auto-compressing messages if the history gets too large.
- **🌐 Web Interface**: Built-in FastAPI + WebSocket server with real-time streaming (compatible with other WebSocket UIs).
- **⏱️ Time Awareness**: Injects current time into prompts so agents are aware of the "now" (useful for logs/APIs).
- **🔧 Built-in Tools**: Ready-to-use tools for REST APIs (with JSONPath extraction) and file downloads.
- **🔄 Progress Tracking**: Shows real-time progress when an agent is selected and which tools are being used.

## Quick Start

### Installation

For detailed installation instructions, see the [Installation Guide](docs/getting-started/installation.md).

```bash
# Clone and install
git clone https://github.com/juanje/macsdk
cd macsdk
uv sync

# Or install via pip/uv (once published)
# uv add macsdk
```

### 1. Create a Chatbot

Learn more in the [Creating Chatbots Guide](docs/guides/creating-chatbots.md).

```bash
macsdk new chatbot my-chatbot --display-name "My First Chatbot"
cd my-chatbot
cp .env.example .env
# Edit .env and add your GOOGLE_API_KEY
uv sync
uv run my-chatbot
```
*It's ready to use immediately.*

### 2. Create an Agent

Learn more in the [Creating Agents Guide](docs/guides/creating-agents.md).

```bash
cd ..
macsdk new agent infra-agent --description "Monitors infrastructure services"
cd infra-agent
uv sync
uv run infra-agent chat
```
*It has its own chat for testing.*

### 3. Register the Agent to the Chatbot

```bash
cd ../my-chatbot/
macsdk add-agent . --path ../infra-agent
```

Now you'll be able to use the chat, which can delegate to the agent if needed.

```bash
uv run my-chatbot chat
# Or using the Web UI
uv run my-chatbot web
```

You can add as many agents as you want!

## Configuration

### Environment Variables (.env)

```bash
GOOGLE_API_KEY=your_key_here
```

### YAML Configuration (config.yml)

```yaml
# LLM settings
llm_model: gemini-2.5-flash
llm_temperature: 0.3

# RAG sources (if --with-rag)
rag:
  enabled: true
  sources:
    - name: "My Docs"
      url: "https://docs.example.com/"
      tags: ["docs", "api"]
```

## Examples

The `examples/` directory contains working examples:

- **api-agent**: REST API interactions with JSONPlaceholder.
- **devops-chatbot**: Multi-agent chatbot with RAG and API tools.

## Development

```bash
git clone https://github.com/juanje/macsdk
cd macsdk
uv sync

# Run tests
uv run pytest

# Type checking & linting
uv run mypy src/
uv run ruff check .
```

## License

MIT

## 🤖 AI Tools Disclaimer

This project was developed with the assistance of artificial intelligence tools:

**Tools used:**
- **Cursor**: Code editor with AI capabilities
- **Claude-4.5-Opus**: Anthropic's language model

**Division of responsibilities:**

**Human (Juanje Ojeda)**:
- 🎯 Specification of objectives and requirements
- 📋 Definition of project's architecture
- 🔍 Critical review of code and documentation
- 💬 Iterative feedback and solution refinement
- ✅ Final validation of concepts and approaches

**AI (Cursor + Claude-4.5-Opus)**:
- 🔧 Initial code prototyping
- 📝 Generation of examples and test cases
- 🐛 Assistance in debugging and error resolution
- 📚 Documentation and comments writing
- 💡 Technical implementation suggestions

**Collaboration philosophy**: AI tools served as a highly capable technical assistant, while all design decisions and project directions were defined and validated by the human.

---
- author: Juanje Ojeda
- email: juanje@redhat.com
