No description
  • Python 76%
  • Gherkin 18.4%
  • RobotFramework 5.5%
Find a file
2026-04-05 07:50:09 +00:00
.devcontainer fix(devcontainer): Dockerfile build fails when .dockerignore excludes .git/ (#1234) 2026-03-31 21:14:46 +00:00
.forgejo chore(ci): capture nox output as CI artifacts and teach agents to read them 2026-04-04 19:58:49 +00:00
.opencode/agents chore(agents): improve agent efficiency, scope control, and PR/issue lifecycle 2026-04-05 00:37:25 -04:00
alembic fix(ci): fix remaining Robot Framework integration test failures 2026-04-04 20:38:16 +00:00
asv/benchmarks fix(tui,cli,tests): harden persona/input modes and stabilize parallel test execution 2026-03-18 10:09:06 +00:00
benchmarks test(providers): add ASV performance benchmark suite for the providers module 2026-04-05 03:55:26 +00:00
docs docs(timeline): update schedule adherence Day 95 (2026-04-05) 2026-04-05 06:17:10 +00:00
examples test(actors): fix actor examples missing provider fields and incorrect name 2026-04-02 23:31:25 +00:00
features fix(lsp): release lock before blocking I/O in LspLifecycleManager.restart_server() to prevent deadlock 2026-04-05 07:06:53 +00:00
hooks feat(resource): add cloud infrastructure resources 2026-03-17 13:14:37 -04:00
k8s feat(server): add Kubernetes Helm chart for server deployment (#1085) 2026-03-27 23:53:22 +00:00
robot feat(plan): wire invariant reconciliation actor auto-invocation 2026-04-05 05:46:05 +00:00
scripts build: runner for opencode project-builder 2026-04-05 01:09:18 -04:00
src/cleveragents fix(lsp): release lock before blocking I/O in LspLifecycleManager.restart_server() to prevent deadlock 2026-04-05 07:06:53 +00:00
typings style(robot/-and-typings/numpy): fix style problems found by ruff check 2026-02-12 02:47:08 +00:00
.bumpversion.cfg Added boilerplate code for python 2024-03-06 23:57:14 -05:00
.cz-config.js Initial commit 2024-01-25 23:10:04 -05:00
.cz.json Initial commit 2024-01-25 23:10:04 -05:00
.dockerignore feat(server): add Kubernetes Helm chart for server deployment (#1085) 2026-03-27 23:53:22 +00:00
.editorconfig Initial commit 2024-01-25 23:10:04 -05:00
.gitattributes Initial commit 2024-01-25 23:10:04 -05:00
.gitignore feat(tui): implement Permission Question Widget 2026-04-03 05:56:27 +00:00
.pre-commit-config.yaml feat(server): add Kubernetes Helm chart for server deployment (#1085) 2026-03-27 23:53:22 +00:00
.python-version Significantly revamped the base project to use more robust static checking including benchmarks and integration test support 2025-10-31 16:18:53 -04:00
.semgrep.yml fix(session): session create does not persist session for subsequent list 2026-04-02 16:51:04 +00:00
alembic.ini feat: continued with phase 2 adding database migration scripts to the mix 2025-11-13 18:25:24 -05:00
asv.conf.json feat(discovery): Add implicit runtime behavior extraction and analysis 2025-11-03 21:12:11 -05:00
ATTRIBUTIONS.md Initial commit 2024-01-25 23:10:04 -05:00
behave.ini test(resource): add failing tests for built-in git-checkout type bootstrap 2026-03-07 19:36:09 +00:00
CHANGELOG.md feat(plan): wire invariant reconciliation actor auto-invocation 2026-04-05 05:46:05 +00:00
clone_dir.txt fix(cli): make version command show actual git commit (#1520) 2026-04-02 21:30:05 +00:00
CODE_OF_CONDUCT.md Initial commit 2024-01-25 23:10:04 -05:00
CONTRIBUTING.md fix(cli): disallow mixing legacy and v3 plan workflows 2026-04-03 00:01:48 +00:00
CONTRIBUTORS.md test(cli): add regression-guard tests for Container.resolve() crash 2026-03-24 08:46:58 +00:00
Dockerfile fix(docker): copy README.md into build stage for hatchling 2026-02-12 06:35:02 +00:00
Dockerfile.server feat(server): add Kubernetes Helm chart for server deployment (#1085) 2026-03-27 23:53:22 +00:00
Dockerfile.server.dockerignore feat(server): add Kubernetes Helm chart for server deployment (#1085) 2026-03-27 23:53:22 +00:00
LICENSE Added Apache OSS license 2024-01-25 23:14:00 -05:00
mkdocs.yml fix(infra): resolve TLS handshake failure on git.dev.cleveragents.com 2026-04-02 23:59:37 +00:00
NOTICE Added Apache OSS license 2024-01-25 23:14:00 -05:00
noxfile.py chore(noxfile): extend pre-migrated database template to slow_integration_tests and e2e_tests 2026-04-03 17:31:35 +00:00
opencode.json ci(opencode.json): change based on Luis's comments 2026-03-05 23:39:16 +00:00
pyproject.toml fix(deps): upgrade aiohttp to 3.13.4 to remediate CVE-2026-34515 open redirect 2026-04-03 00:32:00 +00:00
pyrightconfig.json Merge branch 'master' into develop-20260217 2026-02-18 03:27:00 +00:00
README.md docs: update changelog, API docs, and architecture for 2026-04-02 merged PRs 2026-04-02 19:30:53 +00:00
robot.cfg Significantly revamped the base project to use more robust static checking including benchmarks and integration test support 2025-10-31 16:18:53 -04:00
vulture_whitelist.py feat(tui): implement Permission Question Widget 2026-04-03 05:56:27 +00:00

CleverAgents Core

CleverAgents is a Python-first automation platform. It provides a unified agents CLI, an interactive Textual TUI, embedded runtime, and service orchestration tools while embracing modern Python tooling.

Highlights

  • Unified CLI entry points: cleveragents and agents
  • Interactive TUI (agents tui) — full-screen Textual app with multi-session tabs, persona switching, slash commands, reference picker, and context-sensitive F1 help
  • Persona system — YAML-backed personas bind actors, argument presets, and scope references to named identities; persisted in ~/.config/cleveragents/personas/
  • Session management — create, list, export, and import conversation sessions; full JSON export/import for portability; Markdown transcript export (--format md) for human-readable sharing
  • First-run experienceActorSelectionOverlay guides new users to pick an actor on first TUI launch; creates a "default" persona automatically
  • Server modeagents server connect configures a remote CleverAgents server; Kubernetes Helm chart in k8s/ for production deployment
  • A2A integration — Agent-to-Agent protocol facade wires CLI and TUI to live application services (session, plan, registry, event)
  • Permissions screen — TUI overlay for reviewing tool permission requests with unified, side-by-side, and context diff views; session-scoped allow/reject decisions
  • Actor thought blocks — expandable reasoning trace widgets rendered inline in the conversation stream with muted styling
  • UKO runtime — Universal Knowledge Ontology query interface, inference engine, and graph persistence for ACMS context strategies
  • Database resource handler — full CRUD and checkpoint/rollback support for SQLite, PostgreSQL, MySQL, and DuckDB resources
  • Estimation lifecycleactor.default.estimation config key wires an estimation actor into the Strategize-to-Estimate lifecycle hook
  • Fast Typer/Click-based interface with parity for help/version behavior
  • Behavior-driven coverage via Behave and Robot Framework
  • Nox automation for linting, typing, testing, docs, builds, and benchmarks
  • MkDocs-powered documentation with CleverAgents branding

Quick Start

# clone the CleverAgents core repository
git clone https://git.cleverthis.com/cleveragents/core.git
cd core

# install dependencies
python -m venv .venv
source .venv/bin/activate
pip install -e ".[dev,tests,docs]"

# set up pre-commit hooks and verify tooling
bash scripts/setup-dev.sh

# verify the CLI
agents --help
agents --version

Launch the TUI

# install TUI extra
pip install -e ".[tui]"

# launch the interactive terminal UI
agents tui

Inside the TUI:

  • Type a message and press Enter to chat with the active actor
  • Press / to open the slash command overlay (67 commands across 14 groups)
  • Press @ to open the reference picker and insert file/resource references
  • Press ! to enter shell mode and run a subprocess command
  • Press F1 to toggle the context-sensitive help panel
  • Press Ctrl+T to cycle through argument presets for the active persona
  • Press Ctrl+Q to quit

Session management

agents session create --actor openai/gpt-4o
agents session list
agents session export --session-id <ID> --output session.json
agents session import --input session.json

Server mode

# connect to a remote CleverAgents server
agents server connect --url https://my-server.example.com --token <TOKEN>

# check connection status
agents server status

Developing

Pre-commit hooks run automatically on every git commit (formatting, linting, type checking, security scanning). To run checks manually:

# core validation
nox -s format            # ruff auto-formatting
nox -s lint              # ruff linting
nox -s typecheck         # pyright type checking
nox -s unit_tests        # behave unit tests
nox -s integration_tests # robot integration tests

# quality & security
nox -s security_scan     # bandit security scanning
nox -s dead_code         # vulture dead code detection
nox -s complexity        # radon complexity analysis
nox -s pre_commit        # run all pre-commit hooks
nox -s adr_compliance    # verify ADR compliance

For the full quality automation guide, see docs/development/quality-automation.md.

Documentation

nox -s docs
nox -s serve_docs

Tests

Behave feature scenarios live under features/ and Robot suites under robot/. Use the Nox sessions above to execute them in parity with the implementation plan.

Observability

LangSmith tracing is optional and off by default. Enable it by exporting CLEVERAGENTS_LANGSMITH_ENABLED=true along with a project name and API key (CLEVERAGENTS_LANGSMITH_PROJECT, CLEVERAGENTS_LANGSMITH_API_KEY). The settings module automatically mirrors these values to LANGCHAIN_TRACING_V2, LANGCHAIN_PROJECT, and LANGCHAIN_API_KEY, so LangChain/LangGraph agents emit traces without extra wiring. Additional knobs such as CLEVERAGENTS_LANGSMITH_ENDPOINT, CLEVERAGENTS_LANGSMITH_USER_ID, and CLEVERAGENTS_LANGSMITH_TAGS are documented in docs/observability.md.

LLM provider configuration

CleverAgents ships with a LangChain/LangGraph powered provider registry that discovers whichever API keys you export and automatically selects the best available provider. The CLI now uses actors: select an actor with --actor <name> (or set a default via agents actor set-default). Actors embed provider/model choices; built-in actors are seeded from CLEVERAGENTS_DEFAULT_PROVIDER / CLEVERAGENTS_DEFAULT_MODEL, then fall back to the built-in order (openai → anthropic → google → azure → openrouter → groq → together → cohere → gemini).

Required environment variables

Provider Primary variables
OpenAI OPENAI_API_KEY
Anthropic ANTHROPIC_API_KEY
Google GOOGLE_API_KEY or GOOGLE_GENAI_API_KEY
Azure OpenAI AZURE_OPENAI_API_KEY plus AZURE_OPENAI_ENDPOINT/AZURE_OPENAI_DEPLOYMENT
OpenRouter OPENROUTER_API_KEY (+ optional CLEVERAGENTS_OPENROUTER_ORGANIZATION for sanitized headers)
Gemini GEMINI_API_KEY or GOOGLE_GEMINI_API_KEY
Cohere COHERE_API_KEY
Groq GROQ_API_KEY
Together TOGETHER_API_KEY

Set CLEVERAGENTS_DEFAULT_PROVIDER to pin the global provider (for example export CLEVERAGENTS_DEFAULT_PROVIDER=openai) and CLEVERAGENTS_DEFAULT_MODEL to lock in a model ID. When unset, the registry picks the first configured provider and uses its published default model such as gpt-4o for OpenAI or claude-sonnet-4-20250514 for Anthropic.

Diagnostics and testing shortcuts

  • agents diagnostics prints whether the registry can see your credentials and which actor/provider is selected.
  • agents tell and agents build require --actor <name> unless a default actor is set; use agents actor set-default <name> to configure one.
  • Built-in actors (<provider>/<model>) are immutable, custom actors must be named local/<id>, and the default actor cannot be removed. Use --unsafe when adding/updating configs marked unsafe; runtime only warns when invoking unsafe actors.
  • CLEVERAGENTS_TESTING_USE_MOCK_AI=true forces the in-repo mock provider so Behave/Robot suites never hit external APIs.
  • The full capability matrix (streaming, tool calls, JSON mode, etc.) is documented in docs/reference/providers.md.