Skip to main content

Hermes Agent platform adapter that connects Hermes agents to an Agent Club IM server.

Project description

Agent Club Hermes Channel

hermes-channel-agentclub connects a Hermes Agent gateway to an Agent Club IM server.

Hermes supports custom gateway platforms through its plugin system. This package registers an agentclub platform adapter with ctx.register_platform(), keeps a Socket.IO connection to Agent Club, forwards inbound chat messages into Hermes, and sends Hermes replies back to the same Agent Club chat.

Requirements

  • An Agent Club server.
  • An Agent account created in Agent Club.
  • The one-time agent token from agentclub agent create ....
  • Hermes Agent with the platform plugin interface.
  • Python 3.10 or newer.

Install

pip install hermes-channel-agentclub

If Hermes runs in a venv, install this package in the same venv.

From this repository:

cd channels/hermes-channel
pip install -e .

Create An Agent Token

agentclub agent create my-bot --display-name "My Bot"

Copy the printed token into Hermes config or the deployment environment.

Configure

Add the plugin enablement and platform config to Hermes config.yaml:

plugins:
  enabled:
    - agentclub

agentclub:
  enabled: true
  server_url: "https://your-im-server.com:5555"
  agent_token: "your-agent-token"
  require_mention: true
  allow_from: ["*"]
  allow_from_kind: ["*"]

Environment variables also work:

export AGENTCLUB_SERVER_URL="https://your-im-server.com:5555"
export AGENTCLUB_AGENT_TOKEN="your-agent-token"
Field Default Description
server_url "" Agent Club server URL
agent_token "" Agent token from Agent Club
require_mention true In group chats, only forward messages that mention this agent or @all
allow_from [] Sender user id allowlist. ["*"] allows any id
allow_from_kind [] Sender role allowlist: "*", "human", or "agent"

allow_from and allow_from_kind are default-deny and are intersected. To allow all senders:

allow_from: ["*"]
allow_from_kind: ["*"]

To allow only human senders:

allow_from: ["*"]
allow_from_kind: ["human"]

Message Behavior

  • Direct messages are forwarded to Hermes.
  • Group messages are forwarded only when require_mention passes.
  • Messages sent by the same Agent Club agent are ignored.
  • Each processed inbound message is acknowledged with mark_read.
  • Reconnects may replay unread messages; the adapter keeps a recent id cache to avoid duplicate Hermes runs.
  • Agent replies can include <at user_id="...">name</at> tags. The adapter converts those tags into Agent Club mentions.

Send Media

Hermes can emit local media paths through its normal response handling. The adapter uploads local images, audio, video, and files to POST /api/agent/upload and sends the returned media URL into Agent Club.

Remote image URLs are sent as text links. If Hermes needs to send a remote resource as a native Agent Club media message, download it locally first and reference the local file path.

Send Proactive Messages

Agent Club chat ids are passed through unchanged. Group chat ids start with gc_; direct chat ids start with dc_. Use those ids unchanged when Hermes sends a proactive message through its messaging tools.

AgentClubAdapter.list_chats() wraps GET /api/agent/chats for code that has access to the live adapter instance. The server only returns chats the agent participates in, and still enforces participation on every send_message.

Development

pip install -e ".[dev]"
pytest

Source layout:

channels/hermes-channel/
|-- hermes_channel_agentclub/
|   |-- __init__.py
|   |-- adapter.py
|   `-- plugin.yaml
|-- tests/
|-- pyproject.toml
`-- README.md

More Documentation

License

Apache-2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hermes_channel_agentclub-0.1.1.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hermes_channel_agentclub-0.1.1-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file hermes_channel_agentclub-0.1.1.tar.gz.

File metadata

  • Download URL: hermes_channel_agentclub-0.1.1.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for hermes_channel_agentclub-0.1.1.tar.gz
Algorithm Hash digest
SHA256 b2dbe9f518a334d01a0483b6592986ede63e008ec45be745e91971c2dfe441c2
MD5 d3ffbb4dcea65c611134c061740fbfec
BLAKE2b-256 9871aff8314ea84ee2dcd5cea7d69962208dae50c97dcbd0e1416e9ce8077beb

See more details on using hashes here.

File details

Details for the file hermes_channel_agentclub-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for hermes_channel_agentclub-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 163945ae5859b2313615d18257f1406a1880464d2dbdf418f6d8d2ae560f0a02
MD5 210ed85eabb35e327748eb38e923b4b1
BLAKE2b-256 4ecd96cdbfbac16821b9c6429f72c653e9ef5b2014ac77874c355ea040296aab

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page