No description
Find a file
Teknium ce7418e274
feat: interactive MCP tool configuration in hermes tools (#1694)
Add the ability to selectively enable/disable individual MCP server
tools through the interactive 'hermes tools' TUI.

Changes:
- tools/mcp_tool.py: Add probe_mcp_server_tools() — lightweight function
  that temporarily connects to configured MCP servers, discovers their
  tools (names + descriptions), and disconnects. No registry side effects.

- hermes_cli/tools_config.py: Add 'Configure MCP tools' option to the
  interactive menu. When selected:
  1. Probes all enabled MCP servers for their available tools
  2. Shows a per-server curses checklist with tool descriptions
  3. Pre-selects tools based on existing include/exclude config
  4. Writes changes back as tools.exclude entries in config.yaml
  5. Reports which servers failed to connect

The existing CLI commands (hermes tools enable/disable server:tool)
continue to work unchanged. This adds the interactive TUI counterpart
so users can browse and toggle MCP tools visually.

Tests: 22 new tests covering probe function edge cases and interactive
flow (pre-selection, exclude/include modes, description truncation,
multi-server handling, error paths).
2026-03-17 03:48:44 -07:00
.github docs: stabilize website diagrams 2026-03-14 22:49:57 -07:00
.plans Merge PR #724: feat: --yolo flag to bypass all approval prompts 2026-03-10 20:56:30 -07:00
acp_adapter feat(acp): support slash commands in ACP adapter (#1532) 2026-03-16 05:19:36 -07:00
acp_registry feat: restore ACP server implementation from PR #949 (#1254) 2026-03-14 00:09:05 -07:00
agent feat: add route-aware pricing estimates (#1695) 2026-03-17 03:44:44 -07:00
assets Update banner image to new version 2026-02-25 11:53:44 -08:00
cron feat: add SMS (Twilio) platform adapter 2026-03-17 03:14:53 -07:00
datagen-config-examples feat: add WebResearchEnv RL environment for multi-step web research 2026-03-05 14:34:36 +00:00
docs feat: add route-aware pricing estimates (#1695) 2026-03-17 03:44:44 -07:00
environments fix: support multiple parallel tool calls in DeepSeek V3 parser (#989) 2026-03-15 03:55:24 +01:00
gateway Merge pull request #1697 from NousResearch/fix/gateway-skill-command-nameref 2026-03-17 03:46:08 -07:00
hermes_cli feat: interactive MCP tool configuration in hermes tools (#1694) 2026-03-17 03:48:44 -07:00
honcho_integration fix: thread safety for concurrent subagent delegation (#1672) 2026-03-17 02:53:33 -07:00
landingpage fix: redesign landing page with Nous blue palette and cleaner layout (#974) 2026-03-13 12:03:38 -07:00
mini-swe-agent@07aa6a7385 Update environment configuration and enhance terminal tool integration 2026-01-23 12:26:53 +00:00
optional-skills feat(skills): add Sherlock OSINT username search skill 2026-03-17 02:48:21 -07:00
scripts fix(whatsapp): support LID format in self-chat mode (#1556) 2026-03-17 02:40:55 -07:00
skills feat(skills): add inference.sh skill (terminal-based, no custom tools) (#1686) 2026-03-17 03:06:53 -07:00
tests feat: interactive MCP tool configuration in hermes tools (#1694) 2026-03-17 03:48:44 -07:00
tinker-atropos@65f084ee80 Add tinker-atropos submodule and update RL training tools 2026-02-04 10:36:01 -08:00
tools feat: interactive MCP tool configuration in hermes tools (#1694) 2026-03-17 03:48:44 -07:00
website docs: comprehensive documentation update for recent features 2026-03-17 03:42:02 -07:00
.env.example feat(provider): add OpenCode Zen and OpenCode Go providers 2026-03-17 02:02:43 -07:00
.gitignore feat: add versioning infrastructure and release script 2026-03-12 01:35:47 -07:00
.gitmodules Add tinker-atropos submodule and update RL training tools 2026-02-04 10:36:01 -08:00
AGENTS.md refactor: centralize slash command registry (#1603) 2026-03-16 23:21:03 -07:00
batch_runner.py Merge PR #608: fix: remove unused imports and unnecessary f-strings 2026-03-10 04:16:23 -07:00
cli-config.yaml.example fix(docker): add explicit env allowlist for container credentials (#1436) 2026-03-17 02:34:35 -07:00
cli.py feat: add route-aware pricing estimates (#1695) 2026-03-17 03:44:44 -07:00
CONTRIBUTING.md refactor: centralize slash command registry (#1603) 2026-03-16 23:21:03 -07:00
hermes Add a claude code-like CLI 2026-01-31 06:30:48 +00:00
hermes_constants.py feat: add Vercel AI Gateway provider (#1628) 2026-03-17 00:12:16 -07:00
hermes_state.py feat: add route-aware pricing estimates (#1695) 2026-03-17 03:44:44 -07:00
hermes_time.py fix(timezone): add timezone-aware clock across agent, cron, and execute_code 2026-03-03 18:23:40 +05:30
LICENSE fix: restore missing MIT license file 2026-03-07 13:43:08 -08:00
mini_swe_runner.py fix: worktree-aware minisweagent path discovery + clean up requirements check (#1248) 2026-03-13 23:39:51 -07:00
minisweagent_path.py fix: worktree-aware minisweagent path discovery + clean up requirements check (#1248) 2026-03-13 23:39:51 -07:00
model_tools.py Revert "feat: add inference.sh integration (infsh tool + skill) (#1682)" (#1684) 2026-03-17 03:01:30 -07:00
package-lock.json chore: update package-lock.json with new dependencies and version upgrades 2026-02-21 00:32:26 -08:00
package.json chore: update agent-browser dependency and clean up stale daemon processes 2026-02-20 23:40:42 -08:00
pyproject.toml feat: add Mattermost and Matrix gateway adapters 2026-03-17 03:18:16 -07:00
README.md fix: email send_typing metadata + ☤ Hermes staff symbol (#1431, #1420) 2026-03-17 02:37:40 -07:00
RELEASE_v0.2.0.md chore: rebuild changelog with correct time window (Feb 25 12PM PST onwards) 2026-03-12 02:33:50 -07:00
RELEASE_v0.3.0.md chore: release v0.3.0 (v2026.3.17) 2026-03-17 00:38:48 -07:00
requirements.txt Cleanup time! 2026-02-20 23:23:32 -08:00
rl_cli.py fix(config): reload .env over stale shell overrides 2026-03-15 06:46:28 -07:00
run_agent.py Merge pull request #1700 from NousResearch/fix/redacting-formatter-import 2026-03-17 03:46:49 -07:00
setup-hermes.sh fix(setup): improve shell config detection for PATH setup 2026-03-03 14:39:46 +03:00
toolset_distributions.py Refactor BatchRunner and AIAgent for enhanced reasoning and tool management, improved tool definitions for fileops 2026-02-08 20:19:14 +00:00
toolsets.py feat: add SMS (Twilio) platform adapter 2026-03-17 03:14:53 -07:00
trajectory_compressor.py fix: harden trajectory compressor summary content handling 2026-03-14 11:03:25 -07:00
utils.py test: cover atomic temp cleanup on interrupts 2026-03-14 22:31:51 -07:00
uv.lock merge: resolve conflict with main (add mcp + homeassistant extras) 2026-03-03 14:52:22 +03:00

Hermes Agent

Hermes Agent ☤

Documentation Discord License: MIT Built by Nous Research

The self-improving AI agent built by Nous Research. 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, OpenRouter (200+ models), z.ai/GLM, Kimi/Moonshot, MiniMax, OpenAI, or your own endpoint. Switch with hermes model — no code changes, no lock-in.

A real terminal interfaceFull TUI with multiline editing, slash-command autocomplete, conversation history, interrupt-and-redirect, and streaming tool output.
Lives where you doTelegram, Discord, Slack, WhatsApp, Signal, and CLI — all from a single gateway process. Voice memo transcription, cross-platform conversation continuity.
A closed learning loopAgent-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. Honcho dialectic user modeling. Compatible with the agentskills.io open standard.
Scheduled automationsBuilt-in cron scheduler with delivery to any platform. Daily reports, nightly backups, weekly audits — all in natural language, running unattended.
Delegates and parallelizesSpawn isolated subagents for parallel workstreams. Write Python scripts that call tools via RPC, collapsing multi-step pipelines into zero-context-cost turns.
Runs anywhere, not just your laptopSix 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.
Research-readyBatch trajectory generation, Atropos RL environments, trajectory compression for training the next generation of tool-calling models.

Quick Install

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

Works on Linux, macOS, and WSL2. The installer handles everything — Python, Node.js, dependencies, and the hermes command. No prerequisites except git.

Windows: Native Windows is not supported. Please install WSL2 and run the command above.

After installation:

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

Getting Started

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 →

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> /skills or /<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 and the Messaging Gateway guide.


Documentation

All documentation lives at hermes-agent.nousresearch.com/docs:

Section What's Covered
Quickstart Install → setup → first conversation in 2 minutes
CLI Usage Commands, keybindings, personalities, sessions
Configuration Config file, providers, models, all options
Messaging Gateway Telegram, Discord, Slack, WhatsApp, Signal, Home Assistant
Security Command approval, DM pairing, container isolation
Tools & Toolsets 40+ tools, toolset system, terminal backends
Skills System Procedural memory, Skills Hub, creating skills
Memory Persistent memory, user profiles, best practices
MCP Integration Connect any MCP server for extended capabilities
Cron Scheduling Scheduled tasks with platform delivery
Context Files Project context that shapes every conversation
Architecture Project structure, agent loop, key classes
Contributing Development setup, PR process, code style
CLI Reference All commands and flags
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:

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 for development setup, code style, and PR process.

Quick start for contributors:

git clone https://github.com/NousResearch/hermes-agent.git
cd hermes-agent
git submodule update --init mini-swe-agent   # required terminal backend
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]"
uv pip install -e "./mini-swe-agent"
python -m pytest tests/ -q

RL Training (optional): To work on the RL/Tinker-Atropos integration, also run:

git submodule update --init tinker-atropos
uv pip install -e "./tinker-atropos"

Community


License

MIT — see LICENSE.

Built by Nous Research.