跳到主要内容
本文尚未翻译

本文暂时显示英文原文,中文翻译正在进行中。翻译完成后将自动更新。

原文链接:English Version

Discord Setup

Hermes Agent integrates with Discord as a bot, letting you chat with your AI assistant through direct messages or server channels. The bot receives your messages, processes them through the Hermes Agent pipeline (including tool use, memory, and reasoning), and responds in real time. It supports text, voice messages, file attachments, and slash commands.

Before setup, here's the part most people want to know: how Hermes behaves once it's in your server.

How Hermes Behaves

ContextBehavior
DMsHermes responds to every message. No @mention needed. Each DM has its own session.
Server channelsBy default, Hermes only responds when you @mention it. If you post in a channel without mentioning it, Hermes ignores the message.
Free-response channelsYou can make specific channels mention-free with DISCORD_FREE_RESPONSE_CHANNELS, or disable mentions globally with DISCORD_REQUIRE_MENTION=false.
ThreadsHermes replies in the same thread. Mention rules still apply unless that thread or its parent channel is configured as free-response. Threads stay isolated from the parent channel for session history.
Shared channels with multiple usersBy default, Hermes isolates session history per user inside the channel for safety and clarity. Two people talking in the same channel do not share one transcript unless you explicitly disable that.
Messages mentioning other usersWhen DISCORD_IGNORE_NO_MENTION is true (the default), Hermes stays silent if a message @mentions other users but does not mention the bot. This prevents the bot from jumping into conversations directed at other people. Set to false if you want the bot to respond to all messages regardless of who is mentioned. This only applies in server channels, not DMs.
提示

If you want a normal bot-help channel where people can talk to Hermes without tagging it every time, add that channel to DISCORD_FREE_RESPONSE_CHANNELS.

Discord Gateway Model

Hermes on Discord is not a webhook that replies statelessly. It runs through the full messaging gateway, which means each incoming message goes through:

  1. authorization (DISCORD_ALLOWED_USERS)
  2. mention / free-response checks
  3. session lookup
  4. session transcript loading
  5. normal Hermes agent execution, including tools, memory, and slash commands
  6. response delivery back to Discord

That matters because behavior in a busy server depends on both Discord routing and Hermes session policy.

Session Model in Discord

By default:

  • each DM gets its own session
  • each server thread gets its own session namespace
  • each user in a shared channel gets their own session inside that channel

So if Alice and Bob both talk to Hermes in #research, Hermes treats those as separate conversations by default even though they are using the same visible Discord channel.

This is controlled by config.yaml:

group_sessions_per_user: true

Set it to false only if you explicitly want one shared conversation for the entire room:

group_sessions_per_user: false

Shared sessions can be useful for a collaborative room, but they also mean:

  • users share context growth and token costs
  • one person's long tool-heavy task can bloat everyone else's context
  • one person's in-flight run can interrupt another person's follow-up in the same room

Interrupts and Concurrency

Hermes tracks running agents by session key.

With the default group_sessions_per_user: true:

  • Alice interrupting her own in-flight request only affects Alice's session in that channel
  • Bob can keep talking in the same channel without inheriting Alice's history or interrupting Alice's run

With group_sessions_per_user: false:

  • the whole room shares one running-agent slot for that channel/thread
  • follow-up messages from different people can interrupt or queue behind each other

This guide walks you through the full setup process — from creating your bot on Discord's Developer Portal to sending your first message.

Step 1: Create a Discord Application

  1. Go to the Discord Developer Portal and sign in with your Discord account.
  2. Click New Application in the top-right corner.
  3. Enter a name for your application (e.g., "Hermes Agent") and accept the Developer Terms of Service.
  4. Click Create.

You'll land on the General Information page. Note the Application ID — you'll need it later to build the invite URL.

Step 2: Create the Bot

  1. In the left sidebar, click Bot.
  2. Discord automatically creates a bot user for your application. You'll see the bot's username, which you can customize.
  3. Under Authorization Flow:
    • Set Public Bot to ON — required to use the Discord-provided invite link (recommended). This allows the Installation tab to generate a default authorization URL.
    • Leave Require OAuth2 Code Grant set to OFF.
提示

You can set a custom avatar and banner for your bot on this page. This is what users will see in Discord.

Private Bot Alternative

If you prefer to keep your bot private (Public Bot = OFF), you must use the Manual URL method in Step 5 instead of the Installation tab. The Discord-provided link requires Public Bot to be enabled.

Step 3: Enable Privileged Gateway Intents

This is the most critical step in the entire setup. Without the correct intents enabled, your bot will connect to Discord but will not be able to read message content.

On the Bot page, scroll down to Privileged Gateway Intents. You'll see three toggles:

IntentPurposeRequired?
Presence IntentSee user online/offline statusOptional
Server Members IntentAccess the member list, resolve usernamesRequired
Message Content IntentRead the text content of messagesRequired

Enable both Server Members Intent and Message Content Intent by toggling them ON.

  • Without Message Content Intent, your bot receives message events but the message text is empty — the bot literally cannot see what you typed.
  • Without Server Members Intent, the bot cannot resolve usernames for the allowed users list and may fail to identify who is messaging it.
This is the #1 reason Discord bots don't work

If your bot is online but never responds to messages, the Message Content Intent is almost certainly disabled. Go back to the Developer Portal, select your application → Bot → Privileged Gateway Intents, and make sure Message Content Intent is toggled ON. Click Save Changes.

Regarding server count:

  • If your bot is in fewer than 100 servers, you can simply toggle intents on and off freely.
  • If your bot is in 100 or more servers, Discord requires you to submit a verification application to use privileged intents. For personal use, this is not a concern.

Click Save Changes at the bottom of the page.

Step 4: Get the Bot Token

The bot token is the credential Hermes Agent uses to log in as your bot. Still on the Bot page:

  1. Under the Token section, click Reset Token.
  2. If you have two-factor authentication enabled on your Discord account, enter your 2FA code.
  3. Discord will display your new token. Copy it immediately.
Token shown only once

The token is only displayed once. If you lose it, you'll need to reset it and generate a new one. Never share your token publicly or commit it to Git — anyone with this token has full control of your bot.

Store the token somewhere safe (a password manager, for example). You'll need it in Step 8.

Step 5: Generate the Invite URL

You need an OAuth2 URL to invite the bot to your server. There are two ways to do this:

Requires Public Bot

This method requires Public Bot to be set to ON in Step 2. If you set Public Bot to OFF, use the Manual URL method below instead.

  1. In the left sidebar, click Installation.
  2. Under Installation Contexts, enable Guild Install.
  3. For Install Link, select Discord Provided Link.
  4. Under Default Install Settings for Guild Install:
    • Scopes: select bot and applications.commands
    • Permissions: select the permissions listed below.

Option B: Manual URL

You can construct the invite URL directly using this format:

https://discord.com/oauth2/authorize?client_id=YOUR_APP_ID&scope=bot+applications.commands&permissions=274878286912

Replace YOUR_APP_ID with the Application ID from Step 1.

Required Permissions

These are the minimum permissions your bot needs:

  • View Channels — see the channels it has access to
  • Send Messages — respond to your messages
  • Embed Links — format rich responses
  • Attach Files — send images, audio, and file outputs
  • Read Message History — maintain conversation context
  • Send Messages in Threads — respond in thread conversations
  • Add Reactions — react to messages for acknowledgment

Permission Integers

LevelPermissions IntegerWhat's Included
Minimal117760View Channels, Send Messages, Read Message History, Attach Files
Recommended274878286912All of the above plus Embed Links, Send Messages in Threads, Add Reactions

Step 6: Invite to Your Server

  1. Open the invite URL in your browser (from the Installation tab or the manual URL you constructed).
  2. In the Add to Server dropdown, select your server.
  3. Click Continue, then Authorize.
  4. Complete the CAPTCHA if prompted.
信息

You need the Manage Server permission on the Discord server to invite a bot. If you don't see your server in the dropdown, ask a server admin to use the invite link instead.

After authorizing, the bot will appear in your server's member list (it will show as offline until you start the Hermes gateway).

Step 7: Find Your Discord User ID

Hermes Agent uses your Discord User ID to control who can interact with the bot. To find it:

  1. Open Discord (desktop or web app).
  2. Go to SettingsAdvanced → toggle Developer Mode to ON.
  3. Close settings.
  4. Right-click your own username (in a message, the member list, or your profile) → Copy User ID.

Your User ID is a long number like 284102345871466496.

提示

Developer Mode also lets you copy Channel IDs and Server IDs the same way — right-click the channel or server name and select Copy ID. You'll need a Channel ID if you want to set a home channel manually.

Step 8: Configure Hermes Agent

Run the guided setup command:

hermes gateway setup

Select Discord when prompted, then paste your bot token and user ID when asked.

Option B: Manual Configuration

Add the following to your ~/.hermes/.env file:

# Required
DISCORD_BOT_TOKEN=your-bot-token
DISCORD_ALLOWED_USERS=284102345871466496

# Multiple allowed users (comma-separated)
# DISCORD_ALLOWED_USERS=284102345871466496,198765432109876543

Then start the gateway:

hermes gateway

The bot should come online in Discord within a few seconds. Send it a message — either a DM or in a channel it can see — to test.

提示

You can run hermes gateway in the background or as a systemd service for persistent operation. See the deployment docs for details.

Configuration Reference

Discord behavior is controlled through two files: ~/.hermes/.env for credentials and env-level toggles, and ~/.hermes/config.yaml for structured settings. Environment variables always take precedence over config.yaml values when both are set.

Environment Variables (.env)

VariableRequiredDefaultDescription
DISCORD_BOT_TOKENYesBot token from the Discord Developer Portal.
DISCORD_ALLOWED_USERSYesComma-separated Discord user IDs allowed to interact with the bot. Without this, the gateway denies all users.
DISCORD_HOME_CHANNELNoChannel ID where the bot sends proactive messages (cron output, reminders, notifications).
DISCORD_HOME_CHANNEL_NAMENo"Home"Display name for the home channel in logs and status output.
DISCORD_REQUIRE_MENTIONNotrueWhen true, the bot only responds in server channels when @mentioned. Set to false to respond to all messages in every channel.
DISCORD_FREE_RESPONSE_CHANNELSNoComma-separated channel IDs where the bot responds without requiring an @mention, even when DISCORD_REQUIRE_MENTION is true.
DISCORD_IGNORE_NO_MENTIONNotrueWhen true, the bot stays silent if a message @mentions other users but does not mention the bot. Prevents the bot from jumping into conversations directed at other people. Only applies in server channels, not DMs.
DISCORD_AUTO_THREADNotrueWhen true, automatically creates a new thread for every @mention in a text channel, so each conversation is isolated (similar to Slack behavior). Messages already inside threads or DMs are unaffected.
DISCORD_ALLOW_BOTSNo"none"Controls how the bot handles messages from other Discord bots. "none" — ignore all other bots. "mentions" — only accept bot messages that @mention Hermes. "all" — accept all bot messages.
DISCORD_REACTIONSNotrueWhen true, the bot adds emoji reactions to messages during processing (👀 when starting, ✅ on success, ❌ on error). Set to false to disable reactions entirely.
DISCORD_IGNORED_CHANNELSNoComma-separated channel IDs where the bot never responds, even when @mentioned. Takes priority over all other channel settings.
DISCORD_NO_THREAD_CHANNELSNoComma-separated channel IDs where the bot responds directly in the channel instead of creating a thread. Only relevant when DISCORD_AUTO_THREAD is true.

Config File (config.yaml)

The discord section in ~/.hermes/config.yaml mirrors the env vars above. Config.yaml settings are applied as defaults — if the equivalent env var is already set, the env var wins.

# Discord-specific settings
discord:
require_mention: true # Require @mention in server channels
free_response_channels: "" # Comma-separated channel IDs (or YAML list)
auto_thread: true # Auto-create threads on @mention
reactions: true # Add emoji reactions during processing
ignored_channels: [] # Channel IDs where bot never responds
no_thread_channels: [] # Channel IDs where bot responds without threading

# Session isolation (applies to all gateway platforms, not just Discord)
group_sessions_per_user: true # Isolate sessions per user in shared channels

discord.require_mention

Type: boolean — Default: true

When enabled, the bot only responds in server channels when directly @mentioned. DMs always get a response regardless of this setting.

discord.free_response_channels

Type: string or list — Default: ""

Channel IDs where the bot responds to all messages without needing an @mention. Accepts either a comma-separated string or a YAML list:

# String format
discord:
free_response_channels: "1234567890,9876543210"

# List format
discord:
free_response_channels:
- 1234567890
- 9876543210

If a thread's parent channel is in this list, the thread also becomes mention-free.

discord.auto_thread

Type: boolean — Default: true

When enabled, every @mention in a regular text channel automatically creates a new thread for the conversation. This keeps the main channel clean and gives each conversation its own isolated session history. Once a thread is created, subsequent messages in that thread don't require @mention — the bot knows it's already participating.

Messages sent in existing threads or DMs are unaffected by this setting.

discord.reactions

Type: boolean — Default: true

Controls whether the bot adds emoji reactions to messages as visual feedback:

  • 👀 added when the bot starts processing your message
  • ✅ added when the response is delivered successfully
  • ❌ added if an error occurs during processing

Disable this if you find the reactions distracting or if the bot's role doesn't have the Add Reactions permission.

discord.ignored_channels

Type: string or list — Default: []

Channel IDs where the bot never responds, even when directly @mentioned. This takes the highest priority — if a channel is in this list, the bot silently ignores all messages there, regardless of require_mention, free_response_channels, or any other setting.

# String format
discord:
ignored_channels: "1234567890,9876543210"

# List format
discord:
ignored_channels:
- 1234567890
- 9876543210

If a thread's parent channel is in this list, messages in that thread are also ignored.

discord.no_thread_channels

Type: string or list — Default: []

Channel IDs where the bot responds directly in the channel instead of auto-creating a thread. This only has an effect when auto_thread is true (the default). In these channels, the bot responds inline like a normal message rather than spawning a new thread.

discord:
no_thread_channels:
- 1234567890 # Bot responds inline here

Useful for channels dedicated to bot interaction where threads would add unnecessary noise.

group_sessions_per_user

Type: boolean — Default: true

This is a global gateway setting (not Discord-specific) that controls whether users in the same channel get isolated session histories.

When true: Alice and Bob talking in #research each have their own separate conversation with Hermes. When false: the entire channel shares one conversation transcript and one running-agent slot.

group_sessions_per_user: true

See the Session Model section above for the full implications of each mode.

display.tool_progress

Type: string — Default: "all"Values: off, new, all, verbose

Controls whether the bot sends progress messages in the chat while processing (e.g., "Reading file...", "Running terminal command..."). This is a global gateway setting that applies to all platforms.

display:
tool_progress: "all" # off | new | all | verbose
  • off — no progress messages
  • new — only show the first tool call per turn
  • all — show all tool calls (truncated to 40 characters in gateway messages)
  • verbose — show full tool call details (can produce long messages)

display.tool_progress_command

Type: boolean — Default: false

When enabled, makes the /verbose slash command available in the gateway, letting you cycle through tool progress modes (off → new → all → verbose → off) without editing config.yaml.

display:
tool_progress_command: true

Interactive Model Picker

Send /model with no arguments in a Discord channel to open a dropdown-based model picker:

  1. Provider selection — a Select dropdown showing available providers (up to 25).
  2. Model selection — a second dropdown with models for the chosen provider (up to 25).

The picker times out after 120 seconds. Only authorized users (those in DISCORD_ALLOWED_USERS) can interact with it. If you know the model name, type /model <name> directly.

Native Slash Commands for Skills

Hermes automatically registers installed skills as native Discord Application Commands. This means skills appear in Discord's autocomplete / menu alongside built-in commands.

  • Each skill becomes a Discord slash command (e.g., /code-review, /ascii-art)
  • Skills accept an optional args string parameter
  • Discord has a limit of 100 application commands per bot — if you have more skills than available slots, extra skills are skipped with a warning in the logs
  • Skills are registered during bot startup alongside built-in commands like /model, /reset, and /background

No extra configuration is needed — any skill installed via hermes skills install is automatically registered as a Discord slash command on the next gateway restart.

Home Channel

You can designate a "home channel" where the bot sends proactive messages (such as cron job output, reminders, and notifications). There are two ways to set it:

Using the Slash Command

Type /sethome in any Discord channel where the bot is present. That channel becomes the home channel.

Manual Configuration

Add these to your ~/.hermes/.env:

DISCORD_HOME_CHANNEL=123456789012345678
DISCORD_HOME_CHANNEL_NAME="#bot-updates"

Replace the ID with the actual channel ID (right-click → Copy Channel ID with Developer Mode on).

Voice Messages

Hermes Agent supports Discord voice messages:

  • Incoming voice messages are automatically transcribed using the configured STT provider: local faster-whisper (no key), Groq Whisper (GROQ_API_KEY), or OpenAI Whisper (VOICE_TOOLS_OPENAI_KEY).
  • Text-to-speech: Use /voice tts to have the bot send spoken audio responses alongside text replies.
  • Discord voice channels: Hermes can also join a voice channel, listen to users speaking, and talk back in the channel.

For the full setup and operational guide, see:

Troubleshooting

Bot is online but not responding to messages

Cause: Message Content Intent is disabled.

Fix: Go to Developer Portal → your app → Bot → Privileged Gateway Intents → enable Message Content Intent → Save Changes. Restart the gateway.

"Disallowed Intents" error on startup

Cause: Your code requests intents that aren't enabled in the Developer Portal.

Fix: Enable all three Privileged Gateway Intents (Presence, Server Members, Message Content) in the Bot settings, then restart.

Bot can't see messages in a specific channel

Cause: The bot's role doesn't have permission to view that channel.

Fix: In Discord, go to the channel's settings → Permissions → add the bot's role with View Channel and Read Message History enabled.

403 Forbidden errors

Cause: The bot is missing required permissions.

Fix: Re-invite the bot with the correct permissions using the URL from Step 5, or manually adjust the bot's role permissions in Server Settings → Roles.

Bot is offline

Cause: The Hermes gateway isn't running, or the token is incorrect.

Fix: Check that hermes gateway is running. Verify DISCORD_BOT_TOKEN in your .env file. If you recently reset the token, update it.

"User not allowed" / Bot ignores you

Cause: Your User ID isn't in DISCORD_ALLOWED_USERS.

Fix: Add your User ID to DISCORD_ALLOWED_USERS in ~/.hermes/.env and restart the gateway.

People in the same channel are sharing context unexpectedly

Cause: group_sessions_per_user is disabled, or the platform cannot provide a user ID for the messages in that context.

Fix: Set this in ~/.hermes/config.yaml and restart the gateway:

group_sessions_per_user: true

If you intentionally want a shared room conversation, leave it off — just expect shared transcript history and shared interrupt behavior.

Security

注意

Always set DISCORD_ALLOWED_USERS to restrict who can interact with the bot. Without it, the gateway denies all users by default as a safety measure. Only add User IDs of people you trust — authorized users have full access to the agent's capabilities, including tool use and system access.

For more information on securing your Hermes Agent deployment, see the Security Guide.