Route Hermes delegate_task(background=True) to named, persistent AgentMint subagents.
Project description
agentmint-hermes-runner
Python adapter that bridges Hermes' delegate_task(background=True) to named, persistent AgentMint subagents — specialists that accumulate /workspace/MEMORY.md across calls. Two setup paths; combine freely:
| Mode | What it does | Best for |
|---|---|---|
| Persistent | delegate_task(background=True) routes to a pre-minted named subagent (via default_agent_name, or via an agentmint-<name> entry the LLM passes in toolsets). Its /workspace/MEMORY.md accumulates across calls. |
One long-running specialist that learns OR LLM picking among many specialists per call (via toolset hack — see below) |
| Plugin tool | Hermes auto-discovers a new agentmint_delegate(agent_name, goal, ...) tool from this package's entry-point. LLM picks the subagent per call. |
Cleaner per-call routing when you can expose a new tool to the LLM |
The Hermes-installable skill that drives this adapter lives in a separate catalog repo: mesutcelik/agentmint-skills —
hermes skills install mesutcelik/agentmint-skills/hermes-delegate-task. The skill references this package by its PyPI name (pip install agentmint-hermes-runner).
Status
v0.8.0 — alpha. Auth backends: BearerAuth (Stripe-Link), TempoAuth (Tempo USDC.e — Tier 1 direct only; the delegate_task patches require Bearer). Requires AgentMint API ≥ 0.10.0 for workspace_files support; ≥ 0.7.0 for the rest.
Setup — persistent (default routing)
Every delegate_task(background=True) lands in one named subagent:
import os
from agentmint_hermes_runner import AgentMintDispatcher, BearerAuth, install_delegate_task_wrapper
dispatcher = AgentMintDispatcher(auth=BearerAuth(jwt=os.environ["AGENTMINT_JWT"]))
install_delegate_task_wrapper(dispatcher, default_agent_name="default-worker")
Pre-mint default-worker once (agent.create via curl). Its MEMORY.md grows across every delegation.
Setup — persistent (per-call routing via toolset hack)
When the LLM should pick a specialist per call, but you don't want to expose a new tool, encode the target name in toolsets:
# Operator wires the adapter the same way — default_agent_name is optional:
install_delegate_task_wrapper(dispatcher, default_agent_name="default-worker")
# The LLM then dispatches like this:
delegate_task(
background=True,
goal="Review the diff",
toolsets=["terminal", "file", "agentmint-pr-reviewer-myrepo"],
)
The adapter parses agentmint-pr-reviewer-myrepo from toolsets, routes to that subagent (overriding default_agent_name), and strips the entry from the toolset list before composing the prompt.
This is a workaround for Hermes' delegate_task not accepting a dispatcher-target argument. A formal proposal is in docs/hermes-feature-request.md — when an upstream extension lands, this hack will be deprecated.
Setup — plugin tool (named fleet, cleanest)
from agentmint_hermes_runner import AgentMintDispatcher, BearerAuth, set_dispatcher
dispatcher = AgentMintDispatcher(auth=BearerAuth(jwt=os.environ["AGENTMINT_JWT"]))
set_dispatcher(dispatcher) # registers agentmint_delegate via the entry-point
Hermes' plugin discovery (hermes_agent.plugins entry-point) auto-registers agentmint_delegate when this package is pip-installed. The LLM can now call:
agentmint_delegate(agent_name="reviewer-myrepo", goal="Review the diff", async_=True)
agentmint_delegate(agent_name="support-acme", goal="Reply to ticket #42", async_=True)
Combine with install_delegate_task_wrapper(dispatcher, default_agent_name=...) if you want BOTH delegate_task and agentmint_delegate to dispatch to AgentMint.
See examples/persistent.py and examples/plugin.py for complete operator setup snippets.
Install
pip install agentmint-hermes-runner
Test
pip install -e ".[dev]"
pytest
ruff check .
Lower-level surface
If you want to drive AgentMint directly without the delegate_task patch or the plugin tool:
result = dispatcher.dispatch(
agent_name="reviewer-myrepo",
goal="Review the diff at /workspace/pr-42.diff and flag risks.",
context="Project at /workspace, Python 3.11, uses Flask + PyJWT.",
toolsets=["terminal", "file"], # "web" raises UnsupportedToolset
role="leaf", # or "orchestrator"
max_iterations=50,
child_timeout_seconds=600,
workspace_files=[ # ship inputs into the sandbox before the run
{"path": "/workspace/pr-42.diff", "content": "diff --git a/foo ..."},
],
cleanup_paths=["/workspace/pr-42.diff"], # wipe them after the run
)
# Batch dispatch (Hermes tasks=[…] analog):
results = dispatcher.dispatch_batch(
tasks=[
Task(agent_name="researcher-wasm", goal="WASM 2026 survey"),
Task(agent_name="researcher-riscv", goal="RISC-V 2026 survey"),
],
max_concurrent_children=3,
child_timeout_seconds=900,
)
Known unsupported
toolsets=["web"]— no canonical AgentMint web-fetch skill yet. RaisesUnsupportedToolset.max_spawn_depth— AgentMint sandboxes aren't structurally bounded by depth.- Tempo + the
delegate_taskpatches — polling againstagent.run.statusis Bearer-only. Tempo customers can use Tier 1 (direct curl) but not the install/plugin paths above.
License
MIT
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agentmint_hermes_runner-0.8.0.tar.gz.
File metadata
- Download URL: agentmint_hermes_runner-0.8.0.tar.gz
- Upload date:
- Size: 25.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
018fbb75936d5803467b54bec51ec9312de7c052e3462a925221967634795161
|
|
| MD5 |
6ec532cc4a47481d0f5023b0cf204100
|
|
| BLAKE2b-256 |
556140e01adc1a145dbd9fcba96825d218b52d86347c7206fe79483a2d9d44ca
|
Provenance
The following attestation bundles were made for agentmint_hermes_runner-0.8.0.tar.gz:
Publisher:
release.yml on mesutcelik/agentmint-hermes
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agentmint_hermes_runner-0.8.0.tar.gz -
Subject digest:
018fbb75936d5803467b54bec51ec9312de7c052e3462a925221967634795161 - Sigstore transparency entry: 1872399962
- Sigstore integration time:
-
Permalink:
mesutcelik/agentmint-hermes@e21d5b4caccbc1430b819690756ebd275da28b57 -
Branch / Tag:
refs/tags/v0.8.0 - Owner: https://github.com/mesutcelik
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e21d5b4caccbc1430b819690756ebd275da28b57 -
Trigger Event:
push
-
Statement type:
File details
Details for the file agentmint_hermes_runner-0.8.0-py3-none-any.whl.
File metadata
- Download URL: agentmint_hermes_runner-0.8.0-py3-none-any.whl
- Upload date:
- Size: 20.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0dda7e35f09ba7ba776bbf5c41d1beae7404e6e8ef6228dd892dcc8d6875ebaf
|
|
| MD5 |
80ddfdf1508ff55704656d68179caf1c
|
|
| BLAKE2b-256 |
e39540c8092f0c990d0ffb60cc0e68129024890b93920af5ec694b906eba949e
|
Provenance
The following attestation bundles were made for agentmint_hermes_runner-0.8.0-py3-none-any.whl:
Publisher:
release.yml on mesutcelik/agentmint-hermes
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
agentmint_hermes_runner-0.8.0-py3-none-any.whl -
Subject digest:
0dda7e35f09ba7ba776bbf5c41d1beae7404e6e8ef6228dd892dcc8d6875ebaf - Sigstore transparency entry: 1872399986
- Sigstore integration time:
-
Permalink:
mesutcelik/agentmint-hermes@e21d5b4caccbc1430b819690756ebd275da28b57 -
Branch / Tag:
refs/tags/v0.8.0 - Owner: https://github.com/mesutcelik
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@e21d5b4caccbc1430b819690756ebd275da28b57 -
Trigger Event:
push
-
Statement type: