内置插件
Hermes 附带了一小组与仓库捆绑的插件。它们位于 <repo>/plugins/<name>/ 目录下,并与用户安装在 ~/.hermes/plugins/ 中的插件一起自动加载。它们使用与第三方插件相同的插件接口——钩子、工具、斜杠命令——只是维护在仓库内。
关于通用插件系统,请参阅插件页面;要编写自己的插件,请参阅构建 Hermes 插件。
发现机制
PluginManager 按顺序扫描四个来源:
- 捆绑 —
<repo>/plugins/<name>/(本文档所描述的) - 用户 —
~/.hermes/plugins/<name>/ - 项目 —
./.hermes/plugins/<name>/(需要设置HERMES_ENABLE_PROJECT_PLUGINS=1) - Pip 入口点 —
hermes_agent.plugins
当名称冲突时,后发现的来源会覆盖先前的——例如,一个名为 disk-cleanup 的用户插件会替换掉捆绑的同名插件。
plugins/memory/ 和 plugins/context_engine/ 被有意排除在捆绑扫描之外。这些目录使用自己的发现路径,因为内存提供者和上下文引擎是通过 hermes memory setup 或配置中的 context.engine 配置的单选提供者。
捆绑插件默认不启用
捆绑插件默认处于禁用状态。发现机制会找到它们(它们会出现在 hermes plugins list 和交互式 hermes plugins UI 中),但在你明确启用之前,它们不会加载:
hermes plugins enable disk-cleanup
或者通过 ~/.hermes/config.yaml:
plugins:
enabled:
- disk-cleanup
这与用户安装的插件使用相同的机制。捆绑插件永远不会自动启用——无论是全新安装,还是现有用户升级到更新的 Hermes 版本。你总是需要明确选择启用。
要再次关闭捆绑插件:
hermes plugins disable disk-cleanup
# 或者:从 config.yaml 的 plugins.enabled 中移除它
当前随附的插件
仓库在 plugins/ 下提供了以下捆绑插件。所有插件都是可选启用的——通过 hermes plugins enable <name> 启用。
| 插件 | 类型 | 用途 |
|---|---|---|
disk-cleanup | 钩子 + 斜杠命令 | 自动跟踪临时文件,并在会话结束时清理 |
observability/langfuse | 钩子 | 将对话轮次/LLM 调用/工具追踪到 Langfuse |
spotify | 后端(7 个工具) | 原生 Spotify 播放、队列、搜索、播放列表、专辑、库 |
google_meet | 独立 | 加入 Meet 通话、实时字幕转录、可选实时双工音频 |
image_gen/openai | 图像后端 | OpenAI gpt-image-2 图像生成后端(FAL 的替代方案) |
image_gen/openai-codex | 图像后端 | 通过 Codex OAuth 进行 OpenAI 图像生成 |
image_gen/xai | 图像后端 | xAI grok-2-image 后端 |
hermes-achievements | 仪表盘标签页 | 基于你真实的 Hermes 会话历史生成的 Steam 风格可收集徽章 |
example-dashboard | 仪表盘示例 | 用于扩展仪表盘的参考仪表盘插件 |
strike-freedom-cockpit | 仪表盘皮肤 | 示例自定义仪表盘皮肤 |
Memory providers (plugins/memory/*) 和 context engines (plugins/context_engine/*) 分别在 Memory Providers 中列出——它们分别通过 hermes memory 和 hermes plugins 管理。以下是两个基于钩子的长期运行插件的完整逐插件详情。 |
disk-cleanup
自动跟踪并移除会话期间创建的临时文件——测试脚本、临时输出、cron 日志、过期的 Chrome 配置文件——无需 Agent 记住调用某个工具。
工作原理:
| 钩子 | 行为 |
|---|---|
post_tool_call | 当 write_file / terminal / patch 在 HERMES_HOME 或 /tmp/hermes-* 内创建了匹配 test_*、tmp_* 或 *.test.* 的文件时,静默将其跟踪为 test / temp / cron-output。 |
on_session_end | 如果在该轮次中自动跟踪了任何测试文件,则执行安全的 quick 清理并记录一行摘要。否则保持静默。 |
删除规则:
| 类别 | 阈值 | 确认 |
|---|---|---|
test | 每次会话结束 | 从不 |
temp | 跟踪后超过 7 天 | 从不 |
cron-output | 跟踪后超过 14 天 | 从不 |
| HERMES_HOME 下的空目录 | 始终 | 从不 |
research | 超过 30 天,且超出最新的 10 个 | 始终(仅 deep 模式) |
chrome-profile | 跟踪后超过 14 天 | 始终(仅 deep 模式) |
| 大于 500 MB 的文件 | 从不自动 | 始终(仅 deep 模式) |
斜杠命令 — /disk-cleanup 在 CLI 和 gateway 会话中均可用:
/disk-cleanup status # 分类统计 + 最大的 10 个文件
/disk-cleanup dry-run # 预览而不删除
/disk-cleanup quick # 立即执行安全清理
/disk-cleanup deep # quick + 列出需要确认的项目
/disk-cleanup track <path> <category> # 手动跟踪
/disk-cleanup forget <path> # 停止跟踪(不删除文件)
状态 — 所有数据位于 $HERMES_HOME/disk-cleanup/:
| 文件 | 内容 |
|---|---|
tracked.json | 跟踪的路径,包含类别、大小和时间戳 |
tracked.json.bak | 上述文件的原子写入备份 |
cleanup.log | 仅追加的审计日志,记录每次跟踪/跳过/拒绝/删除 |
安全性 — 清理仅触及 HERMES_HOME 或 /tmp/hermes-* 下的路径。Windows 挂载点(/mnt/c/...)会被拒绝。已知的顶级状态目录(logs/、memories/、sessions/、cron/、cache/、skills/、plugins/、disk-cleanup/ 自身)即使为空也永远不会被删除——新安装不会在第一次会话结束时被清空。
启用: hermes plugins enable disk-cleanup(或在 hermes plugins 中勾选)。
再次禁用: hermes plugins disable disk-cleanup。
observability/langfuse
将 Hermes 的轮次、LLM 调用和工具调用追踪到 Langfuse——一个开源的 LLM 可观测性平台。每个轮次一个 span,每个 API 调用一个 generation,每个工具调用一个 tool observation。使用总量、按类型的 token 计数和成本估算均来自 Hermes 规范的 agent.usage_pricing 数字,因此 Langfuse 仪表盘会看到与 hermes logs 中相同的细分(input / output / cache_read_input_tokens / cache_creation_input_tokens / reasoning_tokens)。
该插件采用故障开放(fail-open)设计:未安装 SDK、缺少凭据或 Langfuse 出现临时错误时,都会在钩子中静默无操作,不会影响 Agent 循环。
配置(交互式 — 推荐):
hermes tools # → Langfuse Observability → Cloud 或 Self-Hosted
向导会收集你的密钥,pip install 安装 langfuse SDK,并将 observability/langfuse 添加到 plugins.enabled 中。重启 Hermes 后,下一次交互就会生成追踪数据。
配置(手动):
pip install langfuse
hermes plugins enable observability/langfuse
然后将凭据放入 ~/.hermes/.env:
HERMES_LANGFUSE_PUBLIC_KEY=pk-lf-...
HERMES_LANGFUSE_SECRET_KEY=sk-lf-...
HERMES_LANGFUSE_BASE_URL=https://cloud.langfuse.com # 或你的自托管 URL
工作原理:
| 钩子 | 行为 |
|---|---|
pre_api_request / pre_llm_call | 打开(或复用)一个每次交互的根跨度 "Hermes turn"。为此 API 调用启动一个 generation 子观测,输入为序列化后的最近消息。 |
post_api_request / post_llm_call | 关闭 generation,附加 usage_details、cost_details、finish_reason、助手输出及工具调用。如果没有工具调用且内容非空,则关闭该次交互。 |
pre_tool_call | 启动一个 tool 子观测,包含清理后的 args。 |
post_tool_call | 关闭工具观测,包含清理后的 result。read_file 的载荷会被摘要化(头部 + 尾部 + 省略行数),确保大文件读取保持在 HERMES_LANGFUSE_MAX_CHARS 限制内。 |
会话分组通过 langfuse.propagate_attributes 以 Hermes 会话 ID(或子 Agent 的任务 ID)为键,因此单个 hermes chat 会话中的所有内容都归属于同一个 Langfuse 会话。
验证:
hermes plugins list # observability/langfuse 应显示 "enabled"
hermes chat -q "hello" # 在 Langfuse UI 中检查 "Hermes turn" 追踪
可选调优(在 .env 中):
| 变量 | 默认值 | 用途 |
|---|---|---|
HERMES_LANGFUSE_ENV | — | 追踪的环境标签(production、staging 等) |
HERMES_LANGFUSE_RELEASE | — | 发布/版本标签 |
HERMES_LANGFUSE_SAMPLE_RATE | 1.0 | 传递给 SDK 的采样率(0.0–1.0) |
HERMES_LANGFUSE_MAX_CHARS | 12000 | 消息内容/工具参数/工具结果的每字段截断长度 |
HERMES_LANGFUSE_DEBUG | false | 插件详细日志记录到 agent.log |
Hermes 前缀和标准 SDK 环境变量(LANGFUSE_PUBLIC_KEY、LANGFUSE_SECRET_KEY、LANGFUSE_BASE_URL)均可接受——两者同时设置时,Hermes 前缀的变量优先。
性能: Langfuse 客户端在首次钩子调用后被缓存。如果凭据或 SDK 缺失,该判断结果也会被缓存——后续钩子会快速返回,无需重新检查环境变量或重新加载配置。
禁用: hermes plugins disable observability/langfuse。插件模块仍会被发现,但不会运行任何模块代码,直到你重新启用。
google_meet
让 Agent 能够加入、转录并参与 Google Meet 通话——记录会议笔记、总结对话内容、跟进特定要点,并(可选)通过 TTS 将回复语音播报回通话中。 它添加了什么:
- 一个无头虚拟参与者,通过浏览器自动化加入 Meet 链接
- 通过配置的 STT 提供商对会议音频进行实时转录
- 一个
meet_summarize/meet_speak/meet_followup工具集,Agent 调用它来根据听到的内容采取行动 - 会后产物(转录稿、带说话人标注的笔记、行动项)保存在
~/.hermes/cache/google_meet/<meeting_id>/下
设置:
hermes plugins enable google_meet
# 首次使用时,会提示你通过插件的 OAuth 流程登录——
# 需要一个有 Meet 访问权限的 Google 账号。如果会议强制要求“仅限受邀参与者加入”,
# 可能需要主持人批准。
从聊天中使用:
"加入 meet.google.com/abc-defg-hij 并做笔记。通话结束后,给我一份包含行动项的摘要。"
Agent 启动会议加入,在通话进行时将转录流式传回其上下文,并在会议结束时(或当你告诉它停止时)生成一份结构化的摘要。
何时使用: 定期站会,你希望机器人转录 + 总结给异步参与者;面试式访谈,你希望获得结构化笔记;任何你原本需要 Fireflies / Otter / Grain 的场景。如果你不希望 AI 旁听——就不要启用它。
禁用: hermes plugins disable google_meet。任何缓存的转录稿和录音会保留在 ~/.hermes/cache/google_meet/ 中,直到你手动删除。
hermes-achievements
在仪表盘上添加一个 Steam 风格的成就标签页——60 多个可收集、分级的徽章,根据你真实的 Hermes 会话历史生成。涉及工具链壮举、调试模式、氛围编码连击、技能/记忆使用、模型/提供商多样性、生活怪癖(周末和夜间会话)。最初由 @PCinkusz 作为外部插件编写;现在纳入树内,以便与 Hermes 功能变更保持同步。
工作原理:
- 在仪表盘后端扫描你整个
~/.hermes/state.db会话历史 - 每个会话的统计信息按
(started_at, last_active)指纹缓存,因此后续扫描只会重新分析新增或变更的会话 - 首次扫描在后台线程中运行——仪表盘永远不会等待它阻塞,即使数据库中有数千个会话
- 解锁状态持久化到
$HERMES_HOME/plugins/hermes-achievements/state.json
等级 progression: 铜 → 银 → 金 → 钻石 → 奥林匹亚。每张卡片都显示一个“计数规则”部分,列出正在跟踪的具体指标。
成就状态:
| 状态 | 含义 |
|---|---|
| 已解锁 | 至少达到一个等级 |
| 已发现 | 已知成就,进度可见,尚未获得 |
| 秘密 | 隐藏,直到 Hermes 在你的历史中检测到第一个相关信号 |
API —— 路由挂载在 /api/plugins/hermes-achievements/ 下:
| 端点 | 用途 |
|---|---|
GET /achievements | 完整目录,包含每个徽章的解锁状态(首次冷扫描运行时返回一个待定占位符) |
GET /scan-status | 后台扫描器的状态:idle / running / failed,上次持续时间,运行次数 |
GET /recent-unlocks | 最近解锁的二十个徽章,最新在前 |
GET /sessions/{id}/badges | 主要在某个特定会话中获得的徽章 |
POST /rescan | 手动同步重新扫描(阻塞;当用户点击重新扫描按钮时使用) |
POST /reset-state | 清除解锁历史和缓存的快照 |
状态文件 — 位于 $HERMES_HOME/plugins/hermes-achievements/ 目录下: |
| 文件 | 内容 |
|---|---|
state.json | 解锁历史:你获得了哪些徽章以及获得时间。在 Hermes 更新期间保持稳定。 |
scan_snapshot.json | 上次完成的扫描负载(仪表盘加载时立即提供) |
scan_checkpoint.json | 按指纹键控的每会话统计缓存(使热重扫变快) |
性能说明:
- 对约 8,000 个会话进行冷扫描需要几分钟。它在首次仪表盘请求时在后台线程中运行;UI 会看到一个待处理的占位符,并轮询
/scan-status。 - 冷扫描期间的增量结果 — 扫描器每约 250 个会话发布一次部分快照,因此每次仪表盘刷新都会显示随着扫描进行而解锁的更多徽章。无需长时间盯着零。
- 热重扫会为每个
started_at+last_active指纹与检查点匹配的会话重用每会话统计信息 — 即使历史记录很大也能在几秒内完成。 - 内存快照 TTL 为 120 秒;过期请求会立即提供旧快照并触发后台刷新。你永远不会因为 TTL 过期而等待旋转加载图标。
启用: 无需启用 — hermes-achievements 是一个仅仪表盘插件(无生命周期钩子,无模型可见工具)。它在首次启动时自动注册为 hermes dashboard 中的一个标签页。plugins.enabled 配置仅控制生命周期/工具插件;仪表盘插件完全通过其 dashboard/manifest.json 发现。
退出: 删除或重命名 plugins/hermes-achievements/dashboard/manifest.json,或者用 ~/.hermes/plugins/hermes-achievements/ 中同名且不提供仪表盘的用户插件覆盖它。该插件在 $HERMES_HOME/plugins/hermes-achievements/ 下的状态文件会保留 — 重新安装会保留你的解锁历史。
添加捆绑插件
捆绑插件的编写方式与任何其他 Hermes 插件完全相同 — 请参阅构建 Hermes 插件。唯一区别是:
- 目录位于
<repo>/plugins/<name>/而不是~/.hermes/plugins/<name>/ - 在
hermes plugins list中,清单源显示为bundled - 同名的用户插件会覆盖捆绑版本
当满足以下条件时,插件适合捆绑:
- 它没有可选依赖项(或者它们已经是
pip install .[all]的依赖项) - 该行为对大多数用户有益,并且是选择退出而非选择加入
- 逻辑与生命周期钩子相关联,否则 Agent 必须记得调用这些钩子
- 它补充了核心能力,而不会扩展模型可见的工具表面
反例 — 应保持为用户可安装插件而非捆绑的内容:带有 API 密钥的第三方集成、小众工作流、大型依赖树、任何会默认显著改变 Agent 行为的东西。