Metadata-Version: 2.4
Name: hermes-agent
Version: 0.11.0
Summary: The self-improving AI agent — creates skills from experience, improves them during use, and runs anywhere
Author: Nous Research
License: MIT
Requires-Python: >=3.11
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: openai<3,>=2.21.0
Requires-Dist: anthropic<1,>=0.39.0
Requires-Dist: python-dotenv<2,>=1.2.1
Requires-Dist: fire<1,>=0.7.1
Requires-Dist: httpx[socks]<1,>=0.28.1
Requires-Dist: rich<15,>=14.3.3
Requires-Dist: tenacity<10,>=9.1.4
Requires-Dist: pyyaml<7,>=6.0.2
Requires-Dist: requests<3,>=2.33.0
Requires-Dist: jinja2<4,>=3.1.5
Requires-Dist: pydantic<3,>=2.12.5
Requires-Dist: prompt_toolkit<4,>=3.0.52
Requires-Dist: exa-py<3,>=2.9.0
Requires-Dist: firecrawl-py<5,>=4.16.0
Requires-Dist: parallel-web<1,>=0.4.2
Requires-Dist: fal-client<1,>=0.13.1
Requires-Dist: edge-tts<8,>=7.2.7
Requires-Dist: PyJWT[crypto]<3,>=2.12.0
Provides-Extra: modal
Requires-Dist: modal<2,>=1.0.0; extra == "modal"
Provides-Extra: daytona
Requires-Dist: daytona<1,>=0.148.0; extra == "daytona"
Provides-Extra: dev
Requires-Dist: debugpy<2,>=1.8.0; extra == "dev"
Requires-Dist: pytest<10,>=9.0.2; extra == "dev"
Requires-Dist: pytest-asyncio<2,>=1.3.0; extra == "dev"
Requires-Dist: pytest-xdist<4,>=3.0; extra == "dev"
Requires-Dist: mcp<2,>=1.2.0; extra == "dev"
Requires-Dist: ty<0.0.22,>=0.0.1a29; extra == "dev"
Requires-Dist: ruff; extra == "dev"
Provides-Extra: messaging
Requires-Dist: python-telegram-bot[webhooks]<23,>=22.6; extra == "messaging"
Requires-Dist: discord.py[voice]<3,>=2.7.1; extra == "messaging"
Requires-Dist: aiohttp<4,>=3.13.3; extra == "messaging"
Requires-Dist: slack-bolt<2,>=1.18.0; extra == "messaging"
Requires-Dist: slack-sdk<4,>=3.27.0; extra == "messaging"
Requires-Dist: qrcode<8,>=7.0; extra == "messaging"
Provides-Extra: cron
Requires-Dist: croniter<7,>=6.0.0; extra == "cron"
Provides-Extra: slack
Requires-Dist: slack-bolt<2,>=1.18.0; extra == "slack"
Requires-Dist: slack-sdk<4,>=3.27.0; extra == "slack"
Provides-Extra: matrix
Requires-Dist: mautrix[encryption]<1,>=0.20; extra == "matrix"
Requires-Dist: Markdown<4,>=3.6; extra == "matrix"
Requires-Dist: aiosqlite>=0.20; extra == "matrix"
Requires-Dist: asyncpg>=0.29; extra == "matrix"
Requires-Dist: aiohttp-socks<1,>=0.10; extra == "matrix"
Provides-Extra: cli
Requires-Dist: simple-term-menu<2,>=1.0; extra == "cli"
Provides-Extra: tts-premium
Requires-Dist: elevenlabs<2,>=1.0; extra == "tts-premium"
Provides-Extra: voice
Requires-Dist: faster-whisper<2,>=1.0.0; extra == "voice"
Requires-Dist: sounddevice<1,>=0.4.6; extra == "voice"
Requires-Dist: numpy<3,>=1.24.0; extra == "voice"
Provides-Extra: pty
Requires-Dist: ptyprocess<1,>=0.7.0; sys_platform != "win32" and extra == "pty"
Requires-Dist: pywinpty<3,>=2.0.0; sys_platform == "win32" and extra == "pty"
Provides-Extra: honcho
Requires-Dist: honcho-ai<3,>=2.0.1; extra == "honcho"
Provides-Extra: mcp
Requires-Dist: mcp<2,>=1.2.0; extra == "mcp"
Provides-Extra: homeassistant
Requires-Dist: aiohttp<4,>=3.9.0; extra == "homeassistant"
Provides-Extra: sms
Requires-Dist: aiohttp<4,>=3.9.0; extra == "sms"
Provides-Extra: acp
Requires-Dist: agent-client-protocol<1.0,>=0.9.0; extra == "acp"
Provides-Extra: mistral
Requires-Dist: mistralai<3,>=2.3.0; extra == "mistral"
Provides-Extra: bedrock
Requires-Dist: boto3<2,>=1.35.0; extra == "bedrock"
Provides-Extra: termux
Requires-Dist: python-telegram-bot[webhooks]<23,>=22.6; extra == "termux"
Requires-Dist: hermes-agent[cron]; extra == "termux"
Requires-Dist: hermes-agent[cli]; extra == "termux"
Requires-Dist: hermes-agent[pty]; extra == "termux"
Requires-Dist: hermes-agent[mcp]; extra == "termux"
Requires-Dist: hermes-agent[honcho]; extra == "termux"
Requires-Dist: hermes-agent[acp]; extra == "termux"
Provides-Extra: dingtalk
Requires-Dist: dingtalk-stream<1,>=0.20; extra == "dingtalk"
Requires-Dist: alibabacloud-dingtalk>=2.0.0; extra == "dingtalk"
Requires-Dist: qrcode<8,>=7.0; extra == "dingtalk"
Provides-Extra: feishu
Requires-Dist: lark-oapi<2,>=1.5.3; extra == "feishu"
Requires-Dist: qrcode<8,>=7.0; extra == "feishu"
Provides-Extra: google
Requires-Dist: google-api-python-client<3,>=2.100; extra == "google"
Requires-Dist: google-auth-oauthlib<2,>=1.0; extra == "google"
Requires-Dist: google-auth-httplib2<1,>=0.2; extra == "google"
Provides-Extra: web
Requires-Dist: fastapi<1,>=0.104.0; extra == "web"
Requires-Dist: uvicorn[standard]<1,>=0.24.0; extra == "web"
Provides-Extra: rl
Requires-Dist: atroposlib @ git+https://github.com/NousResearch/atropos.git@c20c85256e5a45ad31edf8b7276e9c5ee1995a30 ; extra == "rl"
Requires-Dist: tinker @ git+https://github.com/thinking-machines-lab/tinker.git@30517b667f18a3dfb7ef33fb56cf686d5820ba2b ; extra == "rl"
Requires-Dist: fastapi<1,>=0.104.0; extra == "rl"
Requires-Dist: uvicorn[standard]<1,>=0.24.0; extra == "rl"
Requires-Dist: wandb<1,>=0.15.0; extra == "rl"
Provides-Extra: yc-bench
Requires-Dist: yc-bench @ git+https://github.com/collinear-ai/yc-bench.git@bfb0c88062450f46341bd9a5298903fc2e952a5c ; python_version >= "3.12" and extra == "yc-bench"
Provides-Extra: all
Requires-Dist: hermes-agent[modal]; extra == "all"
Requires-Dist: hermes-agent[daytona]; extra == "all"
Requires-Dist: hermes-agent[messaging]; extra == "all"
Requires-Dist: hermes-agent[matrix]; sys_platform == "linux" and extra == "all"
Requires-Dist: hermes-agent[cron]; extra == "all"
Requires-Dist: hermes-agent[cli]; extra == "all"
Requires-Dist: hermes-agent[dev]; extra == "all"
Requires-Dist: hermes-agent[tts-premium]; extra == "all"
Requires-Dist: hermes-agent[slack]; extra == "all"
Requires-Dist: hermes-agent[pty]; extra == "all"
Requires-Dist: hermes-agent[honcho]; extra == "all"
Requires-Dist: hermes-agent[mcp]; extra == "all"
Requires-Dist: hermes-agent[homeassistant]; extra == "all"
Requires-Dist: hermes-agent[sms]; extra == "all"
Requires-Dist: hermes-agent[acp]; extra == "all"
Requires-Dist: hermes-agent[voice]; extra == "all"
Requires-Dist: hermes-agent[dingtalk]; extra == "all"
Requires-Dist: hermes-agent[feishu]; extra == "all"
Requires-Dist: hermes-agent[google]; extra == "all"
Requires-Dist: hermes-agent[mistral]; extra == "all"
Requires-Dist: hermes-agent[bedrock]; extra == "all"
Requires-Dist: hermes-agent[web]; extra == "all"
Dynamic: license-file

<p align="center">
  <img src="assets/banner.png" alt="Hermes Agent" width="100%">
</p>

# Hermes Agent ☤

<p align="center">
  <a href="https://hermes-agent.nousresearch.com/docs/"><img src="https://img.shields.io/badge/Docs-hermes--agent.nousresearch.com-FFD700?style=for-the-badge" alt="Documentation"></a>
  <a href="https://discord.gg/NousResearch"><img src="https://img.shields.io/badge/Discord-5865F2?style=for-the-badge&logo=discord&logoColor=white" alt="Discord"></a>
  <a href="https://github.com/NousResearch/hermes-agent/blob/main/LICENSE"><img src="https://img.shields.io/badge/License-MIT-green?style=for-the-badge" alt="License: MIT"></a>
  <a href="https://nousresearch.com"><img src="https://img.shields.io/badge/Built%20by-Nous%20Research-blueviolet?style=for-the-badge" alt="Built by Nous Research"></a>
</p>

**The self-improving AI agent built by [Nous Research](https://nousresearch.com).** It's the only agent with a built-in learning loop — it creates skills from experience, improves them during use, nudges itself to persist knowledge, searches its own past conversations, and builds a deepening model of who you are across sessions. Run it on a $5 VPS, a GPU cluster, or serverless infrastructure that costs nearly nothing when idle. It's not tied to your laptop — talk to it from Telegram while it works on a cloud VM.

Use any model you want — [Nous Portal](https://portal.nousresearch.com), [OpenRouter](https://openrouter.ai) (200+ models), [NVIDIA NIM](https://build.nvidia.com) (Nemotron), [Xiaomi MiMo](https://platform.xiaomimimo.com), [z.ai/GLM](https://z.ai), [Kimi/Moonshot](https://platform.moonshot.ai), [MiniMax](https://www.minimax.io), [Hugging Face](https://huggingface.co), OpenAI, or your own endpoint. Switch with `hermes model` — no code changes, no lock-in.

<table>
<tr><td><b>A real terminal interface</b></td><td>Full TUI with multiline editing, slash-command autocomplete, conversation history, interrupt-and-redirect, and streaming tool output.</td></tr>
<tr><td><b>Lives where you do</b></td><td>Telegram, Discord, Slack, WhatsApp, Signal, and CLI — all from a single gateway process. Voice memo transcription, cross-platform conversation continuity.</td></tr>
<tr><td><b>A closed learning loop</b></td><td>Agent-curated memory with periodic nudges. Autonomous skill creation after complex tasks. Skills self-improve during use. FTS5 session search with LLM summarization for cross-session recall. <a href="https://github.com/plastic-labs/honcho">Honcho</a> dialectic user modeling. Compatible with the <a href="https://agentskills.io">agentskills.io</a> open standard.</td></tr>
<tr><td><b>Scheduled automations</b></td><td>Built-in cron scheduler with delivery to any platform. Daily reports, nightly backups, weekly audits — all in natural language, running unattended.</td></tr>
<tr><td><b>Delegates and parallelizes</b></td><td>Spawn isolated subagents for parallel workstreams. Write Python scripts that call tools via RPC, collapsing multi-step pipelines into zero-context-cost turns.</td></tr>
<tr><td><b>Runs anywhere, not just your laptop</b></td><td>Six terminal backends — local, Docker, SSH, Daytona, Singularity, and Modal. Daytona and Modal offer serverless persistence — your agent's environment hibernates when idle and wakes on demand, costing nearly nothing between sessions. Run it on a $5 VPS or a GPU cluster.</td></tr>
<tr><td><b>Research-ready</b></td><td>Batch trajectory generation, Atropos RL environments, trajectory compression for training the next generation of tool-calling models.</td></tr>
</table>

---

## Quick Install

```bash
curl -fsSL https://raw.githubusercontent.com/NousResearch/hermes-agent/main/scripts/install.sh | bash
```

Works on Linux, macOS, WSL2, and Android via Termux. The installer handles the platform-specific setup for you.

> **Android / Termux:** The tested manual path is documented in the [Termux guide](https://hermes-agent.nousresearch.com/docs/getting-started/termux). On Termux, Hermes installs a curated `.[termux]` extra because the full `.[all]` extra currently pulls Android-incompatible voice dependencies.
>
> **Windows:** Native Windows is not supported. Please install [WSL2](https://learn.microsoft.com/en-us/windows/wsl/install) and run the command above.

After installation:

```bash
source ~/.bashrc    # reload shell (or: source ~/.zshrc)
hermes              # start chatting!
```

---

## Getting Started

```bash
hermes              # Interactive CLI — start a conversation
hermes model        # Choose your LLM provider and model
hermes tools        # Configure which tools are enabled
hermes config set   # Set individual config values
hermes gateway      # Start the messaging gateway (Telegram, Discord, etc.)
hermes setup        # Run the full setup wizard (configures everything at once)
hermes claw migrate # Migrate from OpenClaw (if coming from OpenClaw)
hermes update       # Update to the latest version
hermes doctor       # Diagnose any issues
```

📖 **[Full documentation →](https://hermes-agent.nousresearch.com/docs/)**

## CLI vs Messaging Quick Reference

Hermes has two entry points: start the terminal UI with `hermes`, or run the gateway and talk to it from Telegram, Discord, Slack, WhatsApp, Signal, or Email. Once you're in a conversation, many slash commands are shared across both interfaces.

| Action | CLI | Messaging platforms |
|---------|-----|---------------------|
| Start chatting | `hermes` | Run `hermes gateway setup` + `hermes gateway start`, then send the bot a message |
| Start fresh conversation | `/new` or `/reset` | `/new` or `/reset` |
| Change model | `/model [provider:model]` | `/model [provider:model]` |
| Set a personality | `/personality [name]` | `/personality [name]` |
| Retry or undo the last turn | `/retry`, `/undo` | `/retry`, `/undo` |
| Compress context / check usage | `/compress`, `/usage`, `/insights [--days N]` | `/compress`, `/usage`, `/insights [days]` |
| Browse skills | `/skills` or `/<skill-name>` | `/<skill-name>` |
| Interrupt current work | `Ctrl+C` or send a new message | `/stop` or send a new message |
| Platform-specific status | `/platforms` | `/status`, `/sethome` |

For the full command lists, see the [CLI guide](https://hermes-agent.nousresearch.com/docs/user-guide/cli) and the [Messaging Gateway guide](https://hermes-agent.nousresearch.com/docs/user-guide/messaging).

---

## Documentation

All documentation lives at **[hermes-agent.nousresearch.com/docs](https://hermes-agent.nousresearch.com/docs/)**:

| Section | What's Covered |
|---------|---------------|
| [Quickstart](https://hermes-agent.nousresearch.com/docs/getting-started/quickstart) | Install → setup → first conversation in 2 minutes |
| [CLI Usage](https://hermes-agent.nousresearch.com/docs/user-guide/cli) | Commands, keybindings, personalities, sessions |
| [Configuration](https://hermes-agent.nousresearch.com/docs/user-guide/configuration) | Config file, providers, models, all options |
| [Messaging Gateway](https://hermes-agent.nousresearch.com/docs/user-guide/messaging) | Telegram, Discord, Slack, WhatsApp, Signal, Home Assistant |
| [Security](https://hermes-agent.nousresearch.com/docs/user-guide/security) | Command approval, DM pairing, container isolation |
| [Tools & Toolsets](https://hermes-agent.nousresearch.com/docs/user-guide/features/tools) | 40+ tools, toolset system, terminal backends |
| [Skills System](https://hermes-agent.nousresearch.com/docs/user-guide/features/skills) | Procedural memory, Skills Hub, creating skills |
| [Memory](https://hermes-agent.nousresearch.com/docs/user-guide/features/memory) | Persistent memory, user profiles, best practices |
| [MCP Integration](https://hermes-agent.nousresearch.com/docs/user-guide/features/mcp) | Connect any MCP server for extended capabilities |
| [Cron Scheduling](https://hermes-agent.nousresearch.com/docs/user-guide/features/cron) | Scheduled tasks with platform delivery |
| [Context Files](https://hermes-agent.nousresearch.com/docs/user-guide/features/context-files) | Project context that shapes every conversation |
| [Architecture](https://hermes-agent.nousresearch.com/docs/developer-guide/architecture) | Project structure, agent loop, key classes |
| [Contributing](https://hermes-agent.nousresearch.com/docs/developer-guide/contributing) | Development setup, PR process, code style |
| [CLI Reference](https://hermes-agent.nousresearch.com/docs/reference/cli-commands) | All commands and flags |
| [Environment Variables](https://hermes-agent.nousresearch.com/docs/reference/environment-variables) | Complete env var reference |

---

## Migrating from OpenClaw

If you're coming from OpenClaw, Hermes can automatically import your settings, memories, skills, and API keys.

**During first-time setup:** The setup wizard (`hermes setup`) automatically detects `~/.openclaw` and offers to migrate before configuration begins.

**Anytime after install:**

```bash
hermes claw migrate              # Interactive migration (full preset)
hermes claw migrate --dry-run    # Preview what would be migrated
hermes claw migrate --preset user-data   # Migrate without secrets
hermes claw migrate --overwrite  # Overwrite existing conflicts
```

What gets imported:
- **SOUL.md** — persona file
- **Memories** — MEMORY.md and USER.md entries
- **Skills** — user-created skills → `~/.hermes/skills/openclaw-imports/`
- **Command allowlist** — approval patterns
- **Messaging settings** — platform configs, allowed users, working directory
- **API keys** — allowlisted secrets (Telegram, OpenRouter, OpenAI, Anthropic, ElevenLabs)
- **TTS assets** — workspace audio files
- **Workspace instructions** — AGENTS.md (with `--workspace-target`)

See `hermes claw migrate --help` for all options, or use the `openclaw-migration` skill for an interactive agent-guided migration with dry-run previews.

---

## Contributing

We welcome contributions! See the [Contributing Guide](https://hermes-agent.nousresearch.com/docs/developer-guide/contributing) for development setup, code style, and PR process.

Quick start for contributors — clone and go with `setup-hermes.sh`:

```bash
git clone https://github.com/NousResearch/hermes-agent.git
cd hermes-agent
./setup-hermes.sh     # installs uv, creates venv, installs .[all], symlinks ~/.local/bin/hermes
./hermes              # auto-detects the venv, no need to `source` first
```

Manual path (equivalent to the above):

```bash
curl -LsSf https://astral.sh/uv/install.sh | sh
uv venv venv --python 3.11
source venv/bin/activate
uv pip install -e ".[all,dev]"
scripts/run_tests.sh
```

> **RL Training (optional):** The RL/Atropos integration (`environments/`) ships via the `atroposlib` and `tinker` dependencies pulled in by `.[all,dev]` — no submodule setup required.

---

## Community

- 💬 [Discord](https://discord.gg/NousResearch)
- 📚 [Skills Hub](https://agentskills.io)
- 🐛 [Issues](https://github.com/NousResearch/hermes-agent/issues)
- 🔌 [HermesClaw](https://github.com/AaronWong1999/hermesclaw) — Community WeChat bridge: Run Hermes Agent and OpenClaw on the same WeChat account.

---

## License

MIT — see [LICENSE](LICENSE).

Built by [Nous Research](https://nousresearch.com).
