Skip to content

Latest commit

 

History

History
708 lines (542 loc) · 19.6 KB

File metadata and controls

708 lines (542 loc) · 19.6 KB

Developer Guide

This guide covers everything you need to know to develop with the Aden Agent Framework.

Table of Contents

  1. Repository Overview
  2. Initial Setup
  3. Project Structure
  4. Building Agents
  5. Testing Agents
  6. Code Style & Conventions
  7. Git Workflow
  8. Common Tasks
  9. Troubleshooting

Repository Overview

Aden Agent Framework is a Python-based system for building goal-driven, self-improving AI agents.

Package Directory Description Tech Stack
framework /core Core runtime, graph executor, protocols Python 3.11+
tools /tools MCP tools for agent capabilities Python 3.11+
exports /exports Agent packages (user-created, gitignored) Python 3.11+
skills .claude, .agents, .agent Shared skills for Claude/Codex/other coding agents Markdown
codex .codex Codex CLI project configuration (MCP servers) TOML

Key Principles

  • Goal-Driven Development: Define objectives, framework generates agent graphs
  • Self-Improving: Agents adapt and evolve based on failures
  • SDK-Wrapped Nodes: Built-in memory, monitoring, and tool access
  • Human-in-the-Loop: Intervention points for human oversight
  • Production-Ready: Evaluation, testing, and deployment infrastructure

Initial Setup

Prerequisites

Ensure you have installed:

  • Python 3.11+ - Download (3.12 or 3.13 recommended)
  • uv - Python package manager (Install)
  • git - Version control
  • Claude Code - Install (optional)
  • Codex CLI - Install (optional)

Verify installation:

python --version    # Should be 3.11+
uv --version        # Should be latest
git --version       # Any recent version

Step-by-Step Setup

# 1. Clone the repository
git clone https://github.com/adenhq/hive.git
cd hive

# 2. Run automated setup
./quickstart.sh

The setup script performs these actions:

  1. Checks Python version (3.11+)
  2. Installs framework package from /core (editable mode)
  3. Installs aden_tools package from /tools (editable mode)
  4. Fixes package compatibility (upgrades openai for litellm)
  5. Verifies all installations

API Keys (Optional)

For running agents with real LLMs:

# Add to your shell profile (~/.bashrc, ~/.zshrc, etc.)
export ANTHROPIC_API_KEY="your-key-here"
export OPENAI_API_KEY="your-key-here"        # Optional
export BRAVE_SEARCH_API_KEY="your-key-here"  # Optional, for web search tool

Get API keys:

Install Claude Code Skills

# Install building-agents and testing-agent skills
./quickstart.sh

This installs agent-related Claude Code skills:

  • /hive - Complete workflow for building agents
  • /hive-create - Step-by-step agent building
  • /hive-concepts - Fundamental agent concepts
  • /hive-patterns - Best practices and design patterns
  • /hive-test - Test and validate agents

Cursor IDE Support

Skills are also available in Cursor. To enable:

  1. Open Command Palette (Cmd+Shift+P / Ctrl+Shift+P)
  2. Run MCP: Enable to enable MCP servers
  3. Restart Cursor to load the MCP servers from .cursor/mcp.json
  4. Type / in Agent chat and search for skills (e.g., /hive-create)

Codex CLI Support

Hive supports OpenAI Codex CLI (v0.101.0+).

Configuration files are tracked in git:

  • .codex/config.toml — MCP server config (agent-builder)
  • .agents/skills/ — Symlinks to Hive skills

To use Codex with Hive:

  1. Run codex in the repo root
  2. Type use hive to start the agent workflow

Example:

codex> use hive

Opencode Support

To enable Opencode integration:

  1. Create/Ensure .opencode/ directory exists
  2. Configure MCP servers in .opencode/mcp.json
  3. Restart Opencode to load the MCP servers
  4. Switch to the Hive agent
  • Tools: Accesses agent-builder and standard tools via standard MCP protocols over stdio.

Verify Setup

# Verify package imports
uv run python -c "import framework; print('✓ framework OK')"
uv run python -c "import aden_tools; print('✓ aden_tools OK')"
uv run python -c "import litellm; print('✓ litellm OK')"

# Run an agent (after building one via /hive-create)
PYTHONPATH=exports uv run python -m your_agent_name validate

Project Structure

hive/                                    # Repository root
│
├── .github/                             # GitHub configuration
│   ├── workflows/
│   │   ├── ci.yml                       # Lint, test, validate on every PR
│   │   ├── release.yml                  # Runs on tags
│   │   ├── pr-requirements.yml          # PR requirement checks
│   │   ├── pr-check-command.yml         # PR check commands
│   │   ├── claude-issue-triage.yml      # Automated issue triage
│   │   └── auto-close-duplicates.yml    # Close duplicate issues
│   ├── ISSUE_TEMPLATE/                  # Bug report & feature request templates
│   ├── PULL_REQUEST_TEMPLATE.md         # PR description template
│   └── CODEOWNERS                       # Auto-assign reviewers
│
├── .claude/                             # Claude Code Skills
│   └── skills/                          # Skills for building
│       ├── hive/                        # Complete workflow
│       ├── hive-create/                 # Step-by-step build guide
│       ├── hive-concepts/               # Fundamental concepts
│       ├── hive-patterns/               # Best practices
│       └── hive-test/                   # Test and validate agents
├── .codex/                              # Codex CLI project config
│   └── config.toml                      # Codex MCP server definitions
├── .agents/                             # Shared skill mountpoint
│   └── skills/                          # Symlinks to Hive skills
│
├── core/                                # CORE FRAMEWORK PACKAGE
│   ├── framework/                       # Main package code
│   │   ├── builder/                     # Agent builder utilities
│   │   ├── credentials/                 # Credential management
│   │   ├── graph/                       # GraphExecutor - executes node graphs
│   │   ├── llm/                         # LLM provider integrations (Anthropic, OpenAI, etc.)
│   │   ├── mcp/                         # MCP server integration
│   │   ├── runner/                      # AgentRunner - loads and runs agents
|   |   ├── observability/               # Structured logging - human-readable and machine-parseable tracing
│   │   ├── runtime/                     # Runtime environment
│   │   ├── schemas/                     # Data schemas
│   │   ├── storage/                     # File-based persistence
│   │   ├── testing/                     # Testing utilities
│   │   ├── tui/                         # Terminal UI dashboard
│   │   └── __init__.py
│   ├── pyproject.toml                   # Package metadata and dependencies
│   ├── README.md                        # Framework documentation
│   ├── MCP_INTEGRATION_GUIDE.md         # MCP server integration guide
│   └── docs/                            # Protocol documentation
│
├── tools/                               # TOOLS PACKAGE (MCP tools)
│   ├── src/
│   │   └── aden_tools/
│   │       ├── tools/                   # Individual tool implementations
│   │       │   ├── web_search_tool/
│   │       │   ├── web_scrape_tool/
│   │       │   ├── file_system_toolkits/
│   │       │   └── ...                  # Additional tools
│   │       ├── mcp_server.py            # HTTP MCP server
│   │       └── __init__.py
│   ├── pyproject.toml                   # Package metadata
│   └── README.md                        # Tools documentation
│
├── exports/                             # AGENT PACKAGES (user-created, gitignored)
│   └── your_agent_name/                 # Created via /hive-create
│
├── examples/                            # Example agents
│   └── templates/                       # Pre-built template agents
│
├── docs/                                # Documentation
│   ├── getting-started.md               # Quick start guide
│   ├── configuration.md                 # Configuration reference
│   ├── architecture/                    # System architecture
│   ├── articles/                        # Technical articles
│   ├── quizzes/                         # Developer quizzes
│   └── i18n/                            # Translations
│
├── scripts/                             # Utility scripts
│   └── auto-close-duplicates.ts         # GitHub duplicate issue closer
│
├── .agent/                        # Antigravity IDE: mcp_config.json + skills (symlinks)
├── quickstart.sh                        # Interactive setup wizard
├── README.md                            # Project overview
├── CONTRIBUTING.md                      # Contribution guidelines
├── LICENSE                              # Apache 2.0 License
├── docs/CODE_OF_CONDUCT.md              # Community guidelines
└── SECURITY.md                          # Security policy

Building Agents

Using Claude Code Skills

The fastest way to build agents is using the Claude Code skills:

# Install skills (one-time)
./quickstart.sh

# Build a new agent
claude> /hive

# Test the agent
claude> /hive-test

Agent Development Workflow

  1. Define Your Goal

    claude> /hive
    Enter goal: "Build an agent that processes customer support tickets"
    
  2. Design the Workflow

    • The skill guides you through defining nodes
    • Each node is a unit of work (LLM call with event_loop)
    • Edges define how execution flows
  3. Generate the Agent

    • The skill generates a complete Python package in exports/
    • Includes: agent.json, tools.py, README.md
  4. Validate the Agent

    PYTHONPATH=exports uv run python -m your_agent_name validate
  5. Test the Agent

    claude> /hive-test
    

Manual Agent Development

If you prefer to build agents manually:

# exports/my_agent/agent.json
{
  "goal": {
    "goal_id": "support_ticket",
    "name": "Support Ticket Handler",
    "description": "Process customer support tickets",
    "success_criteria": "Ticket is categorized, prioritized, and routed correctly"
  },
  "nodes": [
    {
      "node_id": "analyze",
      "name": "Analyze Ticket",
      "node_type": "event_loop",
      "system_prompt": "Analyze this support ticket...",
      "input_keys": ["ticket_content"],
      "output_keys": ["category", "priority"]
    }
  ],
  "edges": [
    {
      "edge_id": "start_to_analyze",
      "source": "START",
      "target": "analyze",
      "condition": "on_success"
    }
  ]
}

Running Agents

# Browse and run agents interactively (Recommended)
hive tui

# Run a specific agent
hive run exports/my_agent --input '{"ticket_content": "My login is broken", "customer_id": "CUST-123"}'

# Run with TUI dashboard
hive run exports/my_agent --tui

Using Python directly: PYTHONPATH=exports uv run python -m agent_name run --input '{...}'


Testing Agents

Using the Testing Agent Skill

# Run tests for an agent
claude> /hive-test

This generates and runs:

  • Constraint tests - Verify agent respects constraints
  • Success tests - Verify agent achieves success criteria
  • Integration tests - End-to-end workflows

Manual Testing

# Run all tests for an agent
PYTHONPATH=exports uv run python -m agent_name test

# Run specific test type
PYTHONPATH=exports uv run python -m agent_name test --type constraint
PYTHONPATH=exports uv run python -m agent_name test --type success

# Run with parallel execution
PYTHONPATH=exports uv run python -m agent_name test --parallel 4

# Fail fast (stop on first failure)
PYTHONPATH=exports uv run python -m agent_name test --fail-fast

Writing Custom Tests

# exports/my_agent/tests/test_custom.py
import pytest
from framework.runner import AgentRunner

def test_ticket_categorization():
    """Test that tickets are categorized correctly"""
    runner = AgentRunner.from_file("exports/my_agent/agent.json")

    result = runner.run({
        "ticket_content": "I can't log in to my account"
    })

    assert result["category"] == "authentication"
    assert result["priority"] in ["high", "medium", "low"]

Code Style & Conventions

Python Code Style

  • PEP 8 - Follow Python style guide
  • Type hints - Use for function signatures and class attributes
  • Docstrings - Document classes and public functions
  • Ruff - Linter and formatter (run with make check)
# Good
from typing import Optional, Dict, Any

def process_ticket(
    ticket_content: str,
    customer_id: str,
    priority: Optional[str] = None
) -> Dict[str, Any]:
    """
    Process a customer support ticket.

    Args:
        ticket_content: The content of the ticket
        customer_id: The customer's ID
        priority: Optional priority override

    Returns:
        Dictionary with processing results
    """
    # Implementation
    return {"status": "processed", "id": ticket_id}

# Avoid
def process_ticket(ticket_content, customer_id, priority=None):
    # No types, no docstring
    return {"status": "processed", "id": ticket_id}

Agent Package Structure

my_agent/
├── __init__.py              # Package initialization
├── __main__.py              # CLI entry point
├── agent.json               # Agent definition (nodes, edges, goal)
├── tools.py                 # Custom tools (optional)
├── mcp_servers.json         # MCP server config (optional)
├── README.md                # Agent documentation
└── tests/                   # Test files
    ├── __init__.py
    ├── test_constraint.py   # Constraint tests
    └── test_success.py      # Success criteria tests

File Naming

Type Convention Example
Modules snake_case ticket_handler.py
Classes PascalCase TicketHandler
Functions/Variables snake_case process_ticket()
Constants UPPER_SNAKE_CASE MAX_RETRIES = 3
Test files test_ prefix test_ticket_handler.py
Agent packages snake_case support_ticket_agent/

Import Order

  1. Standard library
  2. Third-party packages
  3. Framework imports
  4. Local imports
# Standard library
import json
from typing import Dict, Any

# Third-party
import litellm
from pydantic import BaseModel

# Framework
from framework.runner import AgentRunner
from framework.context import NodeContext

# Local
from .tools import custom_tool

Git Workflow

Branch Naming

feature/add-user-authentication
bugfix/fix-login-redirect
hotfix/security-patch
chore/update-dependencies
docs/improve-readme

Commit Messages

Follow Conventional Commits:

<type>(<scope>): <description>

[optional body]

[optional footer]

Types:

  • feat - New feature
  • fix - Bug fix
  • docs - Documentation only
  • style - Formatting, missing semicolons, etc.
  • refactor - Code change that neither fixes a bug nor adds a feature
  • test - Adding or updating tests
  • chore - Maintenance tasks

Examples:

feat(auth): add JWT authentication

fix(api): handle null response from external service

docs(readme): update installation instructions

chore(deps): update React to 18.2.0

Pull Request Process

  1. Create a feature branch from main
  2. Make your changes with clear commits
  3. Run tests locally: make test
  4. Run linting: make check
  5. Push and create a PR
  6. Fill out the PR template
  7. Request review from CODEOWNERS
  8. Address feedback
  9. Squash and merge when approved


Common Tasks

Adding Python Dependencies

# Add to core framework
cd core
uv add <package>

# Add to tools package
cd tools
uv add <package>

Creating a New Agent

# Option 1: Use Claude Code skill (recommended)
claude> /hive

# Option 2: Create manually
# Note: exports/ is initially empty (gitignored). Create your agent directory:
mkdir -p exports/my_new_agent
cd exports/my_new_agent
# Create agent.json, tools.py, README.md (see Agent Package Structure below)

# Option 3: Use the agent builder MCP tools (advanced)
# See core/MCP_BUILDER_TOOLS_GUIDE.md

Adding Custom Tools to an Agent

# exports/my_agent/tools.py
from typing import Dict, Any

def my_custom_tool(param1: str, param2: int) -> Dict[str, Any]:
    """
    Description of what this tool does.

    Args:
        param1: Description of param1
        param2: Description of param2

    Returns:
        Dictionary with tool results
    """
    # Implementation
    return {"result": "success", "data": ...}

# Register tool in agent.json
{
  "nodes": [
    {
      "node_id": "use_tool",
      "node_type": "event_loop",
      "tools": ["my_custom_tool"],
      ...
    }
  ]
}

Adding MCP Server Integration

# 1. Create mcp_servers.json in your agent package
# exports/my_agent/mcp_servers.json
{
  "tools": {
    "transport": "stdio",
    "command": "python",
    "args": ["-m", "aden_tools.mcp_server"],
    "cwd": "tools/",
    "description": "File system and web tools"
  }
}

# 2. Reference tools in agent.json
{
  "nodes": [
    {
      "node_id": "search",
      "tools": ["web_search", "web_scrape"],
      ...
    }
  ]
}

Setting Environment Variables

# Add to your shell profile (~/.bashrc, ~/.zshrc, etc.)
export ANTHROPIC_API_KEY="your-key-here"
export OPENAI_API_KEY="your-key-here"
export BRAVE_SEARCH_API_KEY="your-key-here"

# Or create .env file (not committed to git)
echo 'ANTHROPIC_API_KEY=your-key-here' >> .env

Debugging Agent Execution

# Run with verbose output
hive run exports/my_agent --verbose --input '{"task": "..."}'

Troubleshooting

Port Already in Use

# Find process using port
lsof -i :3000
lsof -i :4000

# Kill process
kill -9 <PID>

Environment Variables Not Loading

# Verify .env file exists at project root
cat .env

# Or check shell environment
echo $ANTHROPIC_API_KEY

# Create .env if needed
# Then add your API keys

Getting Help

  • Documentation: Check the /docs folder
  • Issues: Search existing issues
  • Discord: Join our community
  • Code Review: Tag a maintainer on your PR

Happy coding! 🐝