Skip to main content

No project description provided

Project description

Ainator

Ainator is a CLI/API framework for AI agents built on the agno framework. It provides interactive chat, persistent sessions, knowledge bases (RAG), and built-in tools for shell execution, file operations, and web search.

Features

  • Interactive Chat: Persistent sessions with compression and summarization
  • Knowledge Bases (RAG): Embed code repositories (AST-aware chunking), websites, and directories
  • Built-in Tools: Shell execution (with safety controls), file operations, DuckDuckGo search
  • Session Management: List, switch, show, and compress sessions
  • Learning & Memory: User profile, memory, and session context
  • Cultural Knowledge: Context-aware cultural knowledge integration
  • KeyboardInterrupt Handling: Proper handling of interruption signals
  • Skills System: Extensible via .ainator/skills/ directory
  • Web Server: FastAPI server with Swagger documentation
  • Model Support: VLLM, DeepSeek, OpenAI, Anthropic...

Installation

pip install ainator

Quick Start

# Run a one-off prompt (creates new session)
ainator hi "What is the capital of France?"

# Continue in existing session
ainator but "Tell me more about that"

# Or start interactive chat
ainator chat

# Or Start the web server (localhost:7777/docs)
ainator server
# Then consume it through https://github.com/agno-agi/agent-ui

Commands

Chat & Prompt

  • ainator hi "your prompt" - One-off prompt execution (creates new session)
  • ainator but "your prompt" - Continue in existing session
  • ainator chat - Interactive chat session

Test-Driven Development & Fixing

  • ainator fix "python my_script.py or any command or pytest" - Run until rc == 0

Session Management

  • ainator sessions - List all sessions
  • ainator switch <id> - Switch to a session
  • ainator show - Show messages in current session

Skills Management

  • ainator skills - List available skills

RAG Management

  • ainator rag code add ./path/to/repo python - Add code repository
  • ainator rag website add <url> - Add website content
  • ainator rag search <knowledge-name> "query" - Search knowledge base
  • ainator rag remove <knowledge-name> - Remove knowledge base
  • ainator rag - Show RAG status

Server

  • ainator server - Start FastAPI web server (port 7777)

Configuration

Configuration file is auto-managed, but you can still hack it if you want to tweak parameters: .ainator/config.yml

Example Configuration

agent:
    add_culture_to_context: true
    add_history_to_context: true
    compress_tool_results: true
    enable_session_summaries: true
    reasoning: true
    reasoning_max_steps: 5
    reasoning_min_steps: 2
    store_events: true
    update_cultural_knowledge: true
    update_memory_on_run: true
compression_manager: agno.compression.manager:CompressionManager compress_token_limit=60000 compress_tool_results=True
compression_model: agno.models.vllm:VLLM id=coder
db: ainator.db.sqlite:AsyncSqliteDb db_file=/home/jpic/src/ainator/.ainator/agno.db
extra_skills: []
knowledge:
    agno:
        path: /home/jpic/src/agno/libs/agno/agno
        plugin: code
learning_machine: agno.learn:LearningMachine user_profile=False user_memory=False session_context=True entity_memory=False learned_knowledge=True
model: agno.models.vllm:VLLM id=coder
session_id: bf51cd29-c374-4074-b0eb-faa54f2a6e70
session_name: Fixing Configuration Tests with Temporary Directories
tools:
- agno.tools.file:FileTools base_dir=/home/jpic/src/ainator
- agno.tools.shell:ShellTools
- agno.tools.duckduckgo:DuckDuckGoTools

Model Configuration Examples

# VLLM
model: agno.models.vllm:VLLM id=coder

# DeepSeek
model: agno.models.deepseek:DeepSeek id=deepseek-chat

Environment Variables

  • AINATOR_MODEL - Override the model configuration

Architecture

Core Framework

  • agno: Core AI agent framework (agents, models, tools, SQLite database)
  • cli2: Command-line interface framework

Knowledge Plugins

  • code: Repository embedding with AST-aware chunking
    • Uses llama-index CodeSplitter and HierarchicalNodeParser
    • BAAI/bge-small-en-v1.5 embeddings
    • LanceDB vector storage
  • site: Website scraping with Parsel
  • generic: Directory embedding descriptive file names is required

Skills System

Extensible via .ainator/skills/ directory, just create a skill in there or clone a skills repo such as:

git clone https://github.com/anthropics/skills .ainator/skills/anthropics

Renderer

Streaming Markdown output

Server

FastAPI server via AgentOS, consumable with AgentUI or the AgentOS client, or plain HTTP even.

Tools

  • Enhanced shell execution with chunked output
  • File operations
  • DuckDuckGo search
  • Custom knowledge tools (RAGs)

Compression

Automatic

Learning

  • User profile management
  • Memory system
  • Session context tracking

Development

Installation for Development

pip install -e '.'

Testing

pytest tests/

Version

Version 0.0.3 (defined in src/ainator/__about__.py)

License

MIT © 2026-present jpic

Links

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

ainator-0.0.21.tar.gz (24.6 kB view details)

Uploaded Source

Built Distribution

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

ainator-0.0.21-py3-none-any.whl (24.0 kB view details)

Uploaded Python 3

File details

Details for the file ainator-0.0.21.tar.gz.

File metadata

  • Download URL: ainator-0.0.21.tar.gz
  • Upload date:
  • Size: 24.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for ainator-0.0.21.tar.gz
Algorithm Hash digest
SHA256 13195eb134d06e6ad9af258b3f9453ea935571c7876f6611e3e96b0a850ec27b
MD5 e451c8f1d2f3f229f6bf6ba06a1f2eb5
BLAKE2b-256 a0aee5c085506c23baad343abe206f73d9fbc7f82f8ae9641c7f4627f03d7703

See more details on using hashes here.

File details

Details for the file ainator-0.0.21-py3-none-any.whl.

File metadata

  • Download URL: ainator-0.0.21-py3-none-any.whl
  • Upload date:
  • Size: 24.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for ainator-0.0.21-py3-none-any.whl
Algorithm Hash digest
SHA256 7a363b5a1ad607375d6fe9d8d8ec2969306c1d53490aa3ef1d675226c796bf74
MD5 6ac23a6395273b444cbcd021bfefb579
BLAKE2b-256 98321bd27fafb027d1d29307e8c1e1f9f3446adf64145b556332140a81ae135c

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