Skip to main content

AI agent framework with Chief and Chen, a conversational AI psychologist with web search and multi-provider support in your terminal.

Project description

Chief & Chen AI Agents

A sophisticated AI agent framework built with Pydantic AI, featuring two main applications: Chief and Chen. Both agents provide conversational AI interfaces with web search capabilities and configurable model providers.

Chen has been written as an AI psychologist with an extensive software engineering background. You can think of her like Wendy Rhoades that is always on your side.

On the other hand, Chief is a barebone agent with a barebone system prompt. Chief provides an entry point if you want to write your own agents using the same patterns that Chen uses.

Features

  • Dual Agent System: Chief and Chen applications with distinct personalities and capabilities
  • Multi-Provider Support: Anthropic, OpenAI, and OpenRouter integration
  • Web Search Integration: Powered by Tavily API for real-time information
  • Smart Configuration: Interactive onboarding with JSON-based settings management
  • MongoDB Persistence: Async document storage with Beanie ODM Not implemented yet
  • Rich CLI Interface: Beautiful terminal UI with Typer and Rich
  • MCP Support: Coming soon

Quick Start

Easy Installation (Recommended)

Install with a convenience script that creates convenient chen and chief commands:

curl -sSL https://raw.githubusercontent.com/tistaharahap/chief-ai/main/install.sh | bash

After installation, you can run:

chen --help    # Chen AI psychologist
chief --help   # Basic AI agent
chen           # Start Chen (triggers onboarding on first run)

Manual Installation

Alternatively, run directly with uvx:

# Run Chen directly
uvx --python 3.13 --from chief-ai chen --help

# Go straight to onboarding
uvx --python 3.13 --from chief-ai chen

Installation

# Clone and setup
git clone git@github.com:tistaharahap/chief-ai.git
cd chief
source .venv/bin/activate

# Install dependencies
rye sync

First Run (Chen)

# Launch Chen with automatic onboarding
rye run chen

Chen will guide you through interactive setup to configure your API keys and preferences.

First Run (Chief)

# Launch Chief
rye run chief

LLM Providers & Models Priority

In src/libagentic/providers.py, it is clear that the first choice is Anthropic's Claude 4 Sonnet.

If the anthropic_api_key in ~/.chen/settings.json is set, Claude 4 Sonnet will be the first choice. When all providers are set, the fallback becomes:

  1. claude-sonnet-4-20250514 via Anthropic
  2. gpt-5 via OpenAI
  3. deepseek/deepseek-chat-v3.1:free via OpenRouter

To use free models, simply set the OpenRouter API key and leave the others unset.

Configuration

Chen Configuration System

Chen uses a sophisticated JSON-based configuration system with interactive onboarding:

# View current settings
rye run chen config

# Set individual values
rye run chen config set anthropic_api_key "sk-ant-..."
rye run chen config set context_window 150000

# Manual onboarding
rye run chen onboard

# Reset all settings
rye run chen reset

Settings are stored in ~/.chen/settings.json with support for:

  • Anthropic, OpenAI, OpenRouter, and Tavily API keys
  • Configurable context window size
  • Automatic validation and type conversion

Environment Variables (Optional)

Environment variables serve as defaults during onboarding:

export ANTHROPIC_API_KEY="your-key-here"
export OPENAI_API_KEY="your-key-here"
export OPENROUTER_API_KEY="your-key-here"
export TAVILY_API_KEY="your-key-here"

Architecture

Core Structure

src/
├── appclis/              # CLI applications
│   ├── chen.py          # Chen agent with config system
│   ├── chief.py         # Chief agent
│   └── settings/        # Configuration management
├── libagentic/          # Core agent framework
│   ├── agents.py        # Agent factory functions
│   ├── providers.py     # Model provider configs
│   ├── prompts.py       # System prompts
│   └── tools/           # Agent tools and capabilities
└── libshared/           # Shared utilities
    └── mongo.py         # MongoDB base classes

Technology Stack

  • Pydantic AI: Core agent framework with Logfire integration
  • Typer + Rich: Beautiful CLI interfaces with command groups
  • Pydantic Settings: Type-safe configuration management
  • Beanie: Async MongoDB ODM for persistence
  • Tavily: Web search API integration
  • OpenRouter: Multi-provider LLM access

Development

Code Quality

# Lint and format
ruff check . --fix
ruff format .

# Type checking and final lint
ruff check .

Testing

# Run tests (when implemented)
pytest

# With coverage
pytest --cov=src

Model Providers

  • Default: deepseek/deepseek-chat-v3.1:free via OpenRouter, gpt-5 via OpenAI and claude-sonnet-4-20250514 via Anthropic
  • Supported: All Anthropic, OpenAI, and OpenRouter models
  • Configuration: Interactive setup or individual config commands
  • Fallbacks: Automatic provider selection based on availability

License

MIT License

Contributing

Contributions are welcome! Please open issues or pull requests for enhancements and bug fixes.

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

chief_ai-0.1.2.tar.gz (99.5 kB view details)

Uploaded Source

Built Distribution

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

chief_ai-0.1.2-py3-none-any.whl (40.8 kB view details)

Uploaded Python 3

File details

Details for the file chief_ai-0.1.2.tar.gz.

File metadata

  • Download URL: chief_ai-0.1.2.tar.gz
  • Upload date:
  • Size: 99.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for chief_ai-0.1.2.tar.gz
Algorithm Hash digest
SHA256 77897ec22556bd891b8883cf5d580891e37a8fc70ab52c30e75e838e22e6127e
MD5 94a94ec158b231d95647994dc50e01a1
BLAKE2b-256 79dea61cd959de9095643fea75bfa2801c32ac4a496aa5cfe8600b392ca196ff

See more details on using hashes here.

File details

Details for the file chief_ai-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: chief_ai-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 40.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for chief_ai-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 91af5d28d594b3353820072b410c456678bbdf4d24d17e24ad867592a0dd5331
MD5 89e97fadbb9f5aeb6698da4fc115a23e
BLAKE2b-256 a3b7591bb006e8c8aad19b013837677a4ed8db51b4bb0e488ef51f255ad0b755

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