mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-05-03 09:17:09 +08:00
Broad drift audit against origin/main (b52b63396).
Reference pages (most user-visible drift):
- slash-commands: add /busy, /curator, /footer, /indicator, /redraw, /steer
that were missing; drop non-existent /terminal-setup; fix /q footnote
(resolves to /queue, not /quit); extend CLI-only list with all 24
CLI-only commands in the registry
- cli-commands: add dedicated sections for hermes curator / fallback /
hooks (new subcommands not previously documented); remove stale
hermes honcho standalone section (the plugin registers dynamically
via hermes memory); list curator/fallback/hooks in top-level table;
fix completion to include fish
- toolsets-reference: document the real 52-toolset count; split browser
vs browser-cdp; add discord / discord_admin / spotify / yuanbao;
correct hermes-cli tool count from 36 to 38; fix misleading claim
that hermes-homeassistant adds tools (it's identical to hermes-cli)
- tools-reference: bump tool count 55 -> 68; add 7 Spotify, 5 Yuanbao,
2 Discord toolsets; move browser_cdp/browser_dialog to their own
browser-cdp toolset section
- environment-variables: add 40+ user-facing HERMES_* vars that were
undocumented (--yolo, --accept-hooks, --ignore-*, inference model
override, agent/stream/checkpoint timeouts, OAuth trace, per-platform
batch tuning for Telegram/Discord/Matrix/Feishu/WeCom, cron knobs,
gateway restart/connect timeouts); dedupe the Cron Scheduler section;
replace stale QQ_SANDBOX with QQ_PORTAL_HOST
User-guide (top level):
- cli.md: compression preserves last 20 turns, not 4 (protect_last_n: 20)
- configuration.md: display.platforms is the canonical per-platform
override key; tool_progress_overrides is deprecated and auto-migrated
- profiles.md: model.default is the config key, not model.model
- sessions.md: CLI/TUI session IDs use 6-char hex, gateway uses 8
- checkpoints-and-rollback.md: destructive-command list now matches
_DESTRUCTIVE_PATTERNS (adds rmdir, cp, install, dd)
- docker.md: the container runs as non-root hermes (UID 10000) via
gosu; fix install command (uv pip); add missing --insecure on the
dashboard compose example (required for non-loopback bind)
- security.md: systemctl danger pattern also matches 'restart'
- index.md: built-in tool count 47 -> 68
- integrations/index.md: 6 STT providers, 8 memory providers
- integrations/providers.md: drop fictional dashscope/qwen aliases
Features:
- overview.md: 9 image models (not 8), 9 TTS providers (not 5),
8 memory providers (Supermemory was missing)
- tool-gateway.md: 9 image models
- tools.md: extend common-toolsets list with search / messaging /
spotify / discord / debugging / safe
- fallback-providers.md: add 6 real providers from PROVIDER_REGISTRY
(lmstudio, kimi-coding-cn, stepfun, alibaba-coding-plan,
tencent-tokenhub, azure-foundry)
- plugins.md: Available Hooks table now includes on_session_finalize,
on_session_reset, subagent_stop
- built-in-plugins.md: add the 7 bundled plugins the page didn't
mention (spotify, google_meet, three image_gen providers, two
dashboard examples)
- web-dashboard.md: add --insecure and --tui flags
- cron.md: hermes cron create takes positional schedule/prompt, not
flags
Messaging:
- telegram.md: TELEGRAM_WEBHOOK_SECRET is now REQUIRED when
TELEGRAM_WEBHOOK_URL is set (gateway refuses to start without it
per GHSA-3vpc-7q5r-276h). Biggest user-visible drift in the batch.
- discord.md: HERMES_DISCORD_TEXT_BATCH_SPLIT_DELAY_SECONDS default
is 2.0, not 0.1
- dingtalk.md: document DINGTALK_REQUIRE_MENTION /
FREE_RESPONSE_CHATS / MENTION_PATTERNS / HOME_CHANNEL /
ALLOW_ALL_USERS that the adapter supports
- bluebubbles.md: drop fictional BLUEBUBBLES_SEND_READ_RECEIPTS env
var; the setting lives in platforms.bluebubbles.extra only
- qqbot.md: drop dead QQ_SANDBOX; add real QQ_PORTAL_HOST and
QQ_GROUP_ALLOWED_USERS
- wecom-callback.md: replace 'hermes gateway start' (service-only)
with 'hermes gateway' for first-time setup
Developer-guide:
- architecture.md: refresh tool/toolset counts (61/52), terminal
backend count (7), line counts for run_agent.py (~13.7k), cli.py
(~11.5k), main.py (~10.4k), setup.py (~3.5k), gateway/run.py
(~12.2k), mcp_tool.py (~3.1k); add yuanbao adapter, bump platform
adapter count 18 -> 20
- agent-loop.md: run_agent.py line count 10.7k -> 13.7k
- tools-runtime.md: add vercel_sandbox backend
- adding-tools.md: remove stale 'Discovery import added to
model_tools.py' checklist item (registry auto-discovery)
- adding-platform-adapters.md: mark send_typing / get_chat_info as
concrete base methods; only connect/disconnect/send are abstract
- acp-internals.md: ACP sessions now persist to SessionDB
(~/.hermes/state.db); acp.run_agent call uses
use_unstable_protocol=True
- cron-internals.md: gateway runs scheduler in a dedicated background
thread via _start_cron_ticker, not on a maintenance cycle; locking
is cross-process via fcntl.flock (Unix) / msvcrt.locking (Windows)
- gateway-internals.md: gateway/run.py ~12k lines
- provider-runtime.md: cron DOES support fallback (run_job reads
fallback_providers from config)
- session-storage.md: SCHEMA_VERSION = 11 (not 9); add migrations
10 and 11 (trigram FTS, inline-mode FTS5 re-index); add
api_call_count column to Sessions DDL; document messages_fts_trigram
and state_meta in the architecture tree
- context-compression-and-caching.md: remove the obsolete 'context
pressure warnings' section (warnings were removed for causing
models to give up early)
- context-engine-plugin.md: compress() signature now includes
focus_topic param
- extending-the-cli.md: _build_tui_layout_children signature now
includes model_picker_widget; add to default layout
Also fixed three pre-existing broken links/anchors the build warned
about (docker.md -> api-server.md, yuanbao.md -> cron-jobs.md and
tips#background-tasks, nix-setup.md -> #container-aware-cli).
Regenerated per-skill pages via website/scripts/generate-skill-docs.py
so catalog tables and sidebar are consistent with current SKILL.md
frontmatter.
docusaurus build: clean, no broken links or anchors.
188 lines
7.4 KiB
Markdown
188 lines
7.4 KiB
Markdown
---
|
|
title: "Nous Tool Gateway"
|
|
description: "Route web search, image generation, text-to-speech, and browser automation through your Nous subscription — no extra API keys needed"
|
|
sidebar_label: "Tool Gateway"
|
|
sidebar_position: 2
|
|
---
|
|
|
|
# Nous Tool Gateway
|
|
|
|
:::tip Get Started
|
|
The Tool Gateway is included with paid Nous Portal subscriptions. **[Manage your subscription →](https://portal.nousresearch.com/manage-subscription)**
|
|
:::
|
|
|
|
The **Tool Gateway** lets paid [Nous Portal](https://portal.nousresearch.com) subscribers use web search, image generation, text-to-speech, and browser automation through their existing subscription — no need to sign up for separate API keys from Firecrawl, FAL, OpenAI, or Browser Use.
|
|
|
|
## What's Included
|
|
|
|
| Tool | What It Does | Direct Alternative |
|
|
|------|--------------|--------------------|
|
|
| **Web search & extract** | Search the web and extract page content via Firecrawl | `FIRECRAWL_API_KEY`, `EXA_API_KEY`, `PARALLEL_API_KEY`, `TAVILY_API_KEY` |
|
|
| **Image generation** | Generate images via FAL (9 models: FLUX 2 Klein/Pro, GPT-Image 1.5/2, Nano Banana Pro, Ideogram V3, Recraft V4 Pro, Qwen, Z-Image Turbo) | `FAL_KEY` |
|
|
| **Text-to-speech** | Convert text to speech via OpenAI TTS | `VOICE_TOOLS_OPENAI_KEY`, `ELEVENLABS_API_KEY` |
|
|
| **Browser automation** | Control cloud browsers via Browser Use | `BROWSER_USE_API_KEY`, `BROWSERBASE_API_KEY` |
|
|
|
|
All four tools bill to your Nous subscription. You can enable any combination — for example, use the gateway for web and image generation while keeping your own ElevenLabs key for TTS.
|
|
|
|
## Eligibility
|
|
|
|
The Tool Gateway is available to **paid** [Nous Portal](https://portal.nousresearch.com/manage-subscription) subscribers. Free-tier accounts do not have access — [upgrade your subscription](https://portal.nousresearch.com/manage-subscription) to unlock it.
|
|
|
|
To check your status:
|
|
|
|
```bash
|
|
hermes status
|
|
```
|
|
|
|
Look for the **Nous Tool Gateway** section. It shows which tools are active via the gateway, which use direct keys, and which aren't configured.
|
|
|
|
## Enabling the Tool Gateway
|
|
|
|
### During model setup
|
|
|
|
When you run `hermes model` and select Nous Portal as your provider, Hermes automatically offers to enable the Tool Gateway:
|
|
|
|
```
|
|
Your Nous subscription includes the Tool Gateway.
|
|
|
|
The Tool Gateway gives you access to web search, image generation,
|
|
text-to-speech, and browser automation through your Nous subscription.
|
|
No need to sign up for separate API keys — just pick the tools you want.
|
|
|
|
○ Web search & extract (Firecrawl) — not configured
|
|
○ Image generation (FAL) — not configured
|
|
○ Text-to-speech (OpenAI TTS) — not configured
|
|
○ Browser automation (Browser Use) — not configured
|
|
|
|
● Enable Tool Gateway
|
|
○ Skip
|
|
```
|
|
|
|
Select **Enable Tool Gateway** and you're done.
|
|
|
|
If you already have direct API keys for some tools, the prompt adapts — you can enable the gateway for all tools (your existing keys are kept in `.env` but not used at runtime), enable only for unconfigured tools, or skip entirely.
|
|
|
|
### Via `hermes tools`
|
|
|
|
You can also enable the gateway tool-by-tool through the interactive tool configuration:
|
|
|
|
```bash
|
|
hermes tools
|
|
```
|
|
|
|
Select a tool category (Web, Browser, Image Generation, or TTS), then choose **Nous Subscription** as the provider. This sets `use_gateway: true` for that tool in your config.
|
|
|
|
### Manual configuration
|
|
|
|
Set the `use_gateway` flag directly in `~/.hermes/config.yaml`:
|
|
|
|
```yaml
|
|
web:
|
|
backend: firecrawl
|
|
use_gateway: true
|
|
|
|
image_gen:
|
|
use_gateway: true
|
|
|
|
tts:
|
|
provider: openai
|
|
use_gateway: true
|
|
|
|
browser:
|
|
cloud_provider: browser-use
|
|
use_gateway: true
|
|
```
|
|
|
|
## How It Works
|
|
|
|
When `use_gateway: true` is set for a tool, the runtime routes API calls through the Nous Tool Gateway instead of using direct API keys:
|
|
|
|
1. **Web tools** — `web_search` and `web_extract` use the gateway's Firecrawl endpoint
|
|
2. **Image generation** — `image_generate` uses the gateway's FAL endpoint
|
|
3. **TTS** — `text_to_speech` uses the gateway's OpenAI Audio endpoint
|
|
4. **Browser** — `browser_navigate` and other browser tools use the gateway's Browser Use endpoint
|
|
|
|
The gateway authenticates using your Nous Portal credentials (stored in `~/.hermes/auth.json` after `hermes model`).
|
|
|
|
### Precedence
|
|
|
|
Each tool checks `use_gateway` first:
|
|
|
|
- **`use_gateway: true`** → route through the gateway, even if direct API keys exist in `.env`
|
|
- **`use_gateway: false`** (or absent) → use direct API keys if available, fall back to gateway only when no direct keys exist
|
|
|
|
This means you can switch between gateway and direct keys at any time without deleting your `.env` credentials.
|
|
|
|
## Switching Back to Direct Keys
|
|
|
|
To stop using the gateway for a specific tool:
|
|
|
|
```bash
|
|
hermes tools # Select the tool → choose a direct provider
|
|
```
|
|
|
|
Or set `use_gateway: false` in config:
|
|
|
|
```yaml
|
|
web:
|
|
backend: firecrawl
|
|
use_gateway: false # Now uses FIRECRAWL_API_KEY from .env
|
|
```
|
|
|
|
When you select a non-gateway provider in `hermes tools`, the `use_gateway` flag is automatically set to `false` to prevent contradictory config.
|
|
|
|
## Checking Status
|
|
|
|
```bash
|
|
hermes status
|
|
```
|
|
|
|
The **Nous Tool Gateway** section shows:
|
|
|
|
```
|
|
◆ Nous Tool Gateway
|
|
Nous Portal ✓ managed tools available
|
|
Web tools ✓ active via Nous subscription
|
|
Image gen ✓ active via Nous subscription
|
|
TTS ✓ active via Nous subscription
|
|
Browser ○ active via Browser Use key
|
|
Modal ○ available via subscription (optional)
|
|
```
|
|
|
|
Tools marked "active via Nous subscription" are routed through the gateway. Tools with their own keys show which provider is active.
|
|
|
|
## Advanced: Self-Hosted Gateway
|
|
|
|
For self-hosted or custom gateway deployments, you can override the gateway endpoints via environment variables in `~/.hermes/.env`:
|
|
|
|
```bash
|
|
TOOL_GATEWAY_DOMAIN=nousresearch.com # Base domain for gateway routing
|
|
TOOL_GATEWAY_SCHEME=https # HTTP or HTTPS (default: https)
|
|
TOOL_GATEWAY_USER_TOKEN=your-token # Auth token (normally auto-populated)
|
|
FIRECRAWL_GATEWAY_URL=https://... # Override for the Firecrawl endpoint specifically
|
|
```
|
|
|
|
These env vars are always visible in the configuration regardless of subscription status — they're useful for custom infrastructure setups.
|
|
|
|
## FAQ
|
|
|
|
### Do I need to delete my existing API keys?
|
|
|
|
No. When `use_gateway: true` is set, the runtime skips direct API keys and routes through the gateway. Your keys stay in `.env` untouched. If you later disable the gateway, they'll be used again automatically.
|
|
|
|
### Can I use the gateway for some tools and direct keys for others?
|
|
|
|
Yes. The `use_gateway` flag is per-tool. You can mix and match — for example, gateway for web and image generation, your own ElevenLabs key for TTS, and Browserbase for browser automation.
|
|
|
|
### What if my subscription expires?
|
|
|
|
Tools that were routed through the gateway will stop working until you [renew your subscription](https://portal.nousresearch.com/manage-subscription) or switch to direct API keys via `hermes tools`.
|
|
|
|
### Does the gateway work with the messaging gateway?
|
|
|
|
Yes. The Tool Gateway routes tool API calls regardless of whether you're using the CLI, Telegram, Discord, or any other messaging platform. It operates at the tool runtime level, not the entry point level.
|
|
|
|
### Is Modal included?
|
|
|
|
Modal (serverless terminal backend) is available as an optional add-on through the Nous subscription. It's not enabled by the Tool Gateway prompt — configure it separately via `hermes setup terminal` or in `config.yaml`.
|