No description
Find a file
teknium1 d29249b8fa feat: local browser backend — zero-cost headless Chromium via agent-browser
Add local browser mode as an automatic fallback when Browserbase
credentials are not configured. Uses the same agent-browser CLI with
--session (local Chromium) instead of --cdp (cloud Browserbase).

The agent-facing API is completely unchanged — all 10 browser_* tools
produce identical output in both modes. Auto-detection:
  - BROWSERBASE_API_KEY set → cloud mode (existing behavior)
  - No key → local mode (new, free, headless Chromium)

Changes:
- _is_local_mode(): auto-detect based on env vars
- _create_local_session(): lightweight session (no API call)
- _get_session_info(): branches on local vs cloud
- _run_browser_command(): --session in local, --cdp in cloud
- check_browser_requirements(): only needs agent-browser CLI in local mode
- _emergency_cleanup: CLI close in local, API release in cloud
- cleanup_browser/browser_close: skip BB API calls in local mode
- Registry: removed requires_env — check_fn handles both modes

Setup for local mode:
  npm install -g agent-browser
  agent-browser install              # downloads Chromium
  agent-browser install --with-deps  # also installs system libs (Docker/Debian)

Closes #374 (Phase 1)
2026-03-07 01:14:57 -08:00
.github ci: pin tests to Python 3.11 only 2026-03-05 07:55:01 -08:00
agent feat: platform-conditional skill loading + Apple/macOS skills 2026-03-07 00:47:54 -08:00
assets Update banner image to new version 2026-02-25 11:53:44 -08:00
cron Merge PR #309: fix(timezone): timezone-aware now() for prompt, cron, and execute_code 2026-03-07 00:04:41 -08:00
datagen-config-examples Provide example datagen config scripts 2026-02-25 02:27:41 -08:00
docs refactor: extract clipboard methods + comprehensive tests (37 tests) 2026-03-05 18:07:53 -08:00
environments docs: add Environments, Benchmarks & Data Generation guide 2026-03-06 23:31:45 -08:00
gateway Merge PR #309: fix(timezone): timezone-aware now() for prompt, cron, and execute_code 2026-03-07 00:04:41 -08:00
hermes_cli fix: simplify timezone migration to use os.getenv directly 2026-03-07 00:05:05 -08:00
honcho_integration Merge PR #243: fix(honcho): auto-enable when API key is present 2026-03-02 05:13:33 -08:00
landingpage feat: add gateway setup wizard and update steps to landing page 2026-03-05 06:33:40 -08:00
mini-swe-agent@07aa6a7385 Update environment configuration and enhance terminal tool integration 2026-01-23 12:26:53 +00:00
optional-skills fix: review fixes — path traversal guard, trust_style consistency, edge cases 2026-03-06 01:40:01 -08:00
scripts Merge PR #292: feat(whatsapp): native media attachments for images, videos and documents 2026-03-05 08:35:13 -08:00
skills feat: platform-conditional skill loading + Apple/macOS skills 2026-03-07 00:47:54 -08:00
tests feat: platform-conditional skill loading + Apple/macOS skills 2026-03-07 00:47:54 -08:00
tinker-atropos@65f084ee80 Add tinker-atropos submodule and update RL training tools 2026-02-04 10:36:01 -08:00
tools feat: local browser backend — zero-cost headless Chromium via agent-browser 2026-03-07 01:14:57 -08:00
website feat: platform-conditional skill loading + Apple/macOS skills 2026-03-07 00:47:54 -08:00
.env.example feat: add z.ai/GLM, Kimi/Moonshot, MiniMax as first-class providers 2026-03-06 18:55:18 -08:00
.gitignore Provide example datagen config scripts 2026-02-25 02:27:41 -08:00
.gitmodules Add tinker-atropos submodule and update RL training tools 2026-02-04 10:36:01 -08:00
AGENTS.md feat: platform-conditional skill loading + Apple/macOS skills 2026-03-07 00:47:54 -08:00
batch_runner.py refactor: extract atomic_json_write helper, add 24 checkpoint tests 2026-03-06 05:50:12 -08:00
cli-config.yaml.example feat: add z.ai/GLM, Kimi/Moonshot, MiniMax as first-class providers 2026-03-06 18:55:18 -08:00
cli.py feat: add z.ai/GLM, Kimi/Moonshot, MiniMax as first-class providers 2026-03-06 18:55:18 -08:00
CONTRIBUTING.md feat: platform-conditional skill loading + Apple/macOS skills 2026-03-07 00:47:54 -08:00
hermes Add a claude code-like CLI 2026-01-31 06:30:48 +00:00
hermes_constants.py Cleanup time! 2026-02-20 23:23:32 -08:00
hermes_state.py fix: /retry, /undo, /compress, and /reset gateway commands (#210) 2026-03-02 00:14:49 -08:00
hermes_time.py fix(timezone): add timezone-aware clock across agent, cron, and execute_code 2026-03-03 18:23:40 +05:30
mini_swe_runner.py fix(agent): update error message for unsupported Anthropic API endpoints to clarify usage of OpenRouter 2026-02-27 23:23:31 -08:00
model_tools.py fix: execute_code and delegate_task now respect disabled toolsets 2026-03-06 17:36:14 -08: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 YC-Bench long-horizon agent benchmark environment 2026-03-06 19:25:56 -08:00
README.md feat: add z.ai/GLM, Kimi/Moonshot, MiniMax as first-class providers 2026-03-06 18:55:18 -08:00
requirements.txt Cleanup time! 2026-02-20 23:23:32 -08:00
rl_cli.py fix: respect HERMES_HOME and add encoding fallback in rl_cli.py 2026-02-26 19:01:13 +11:00
run_agent.py Merge PR #309: fix(timezone): timezone-aware now() for prompt, cron, and execute_code 2026-03-07 00:04:41 -08: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: enhance Home Assistant integration with service discovery and setup 2026-03-03 05:16:53 -08:00
trajectory_compressor.py Cleanup time! 2026-02-20 23:23:32 -08:00
utils.py refactor: extract atomic_json_write helper, add 24 checkpoint tests 2026-03-06 05:50:12 -08: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, 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 setup        # configure your LLM provider
hermes              # start chatting!

Getting Started

hermes              # Interactive CLI — start a conversation
hermes model        # Switch provider or model
hermes setup        # Re-run the setup wizard
hermes gateway      # Start the messaging gateway (Telegram, Discord, etc.)
hermes update       # Update to the latest version
hermes doctor       # Diagnose any issues

📖 Full documentation →


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, 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

Contributing

We welcome contributions! See the Contributing Guide for development setup, code style, and PR process.

Quick start for contributors:

git clone --recurse-submodules https://github.com/NousResearch/hermes-agent.git
cd hermes-agent
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

Community


License

MIT — see LICENSE.

Built by Nous Research.