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.11.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.11-py3-none-any.whl (24.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ainator-0.0.11.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.11.tar.gz
Algorithm Hash digest
SHA256 2eee61d7df49fa2e93a2f21ba00c97b2320b8b1171d502e4873e3eef440348cd
MD5 6a83174b1f4d5331814e80feff1edeb7
BLAKE2b-256 b7010647fb25568d607d0401a1bcaf91f4e9e85cd11b454c7ae2343b7a1e4622

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ainator-0.0.11-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.11-py3-none-any.whl
Algorithm Hash digest
SHA256 4ec7bf76b16bc6ae9eb890d3ea73286f34b7e9933019fde5f752cc007b38899e
MD5 0a0135898fb1094a44f8c5d43370f198
BLAKE2b-256 265804ae3bc3380df272b44453c7d9dfa944e2a44d0fb33532e8e570880a38d5

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