| タイトル | NousResearch hermes-agent 2026.4.16 Missing Authorization (CWE-862) |
|---|
| 説明 | # Technical Details
A dangerous command approval bypass exists in the `check_all_command_guards()` method in `tools/approval.py` of hermes-agent.
The application fails to safely handle default contexts in `batch_runner.py` by treating unknown execution contexts (where interactive environment variables are unset) as implicitly safe instead of implicitly dangerous, allowing all flagged dangerous commands to be auto-approved.
# Vulnerable Code
File: tools/approval.py
Method: check_all_command_guards()
Why: The function checks for interactive environment variables (HERMES_INTERACTIVE, HERMES_GATEWAY_SESSION, HERMES_EXEC_ASK, HERMES_CRON_SESSION) and if none are set, the code falls through to an insecure default returning `{"approved": True, "message": None}` for any command.
# Reproduction
1. Prepare a `hermes-agent` environment.
2. Run a batch execution process using `batch_runner.py` with an unset interactive context.
3. Supply a malicious JSONL dataset containing a prompt injection payload that executes dangerous shell commands (e.g., `rm -rf /`).
4. Observe the commands are executed directly without approval.
# Impact
- Arbitrary command execution (RCE) on the host running the batch runner.
- Credential theft (e.g., reading `~/.hermes/.env`).
- Establishment of reverse shells or data exfiltration. |
|---|
| ソース | ⚠️ https://gist.github.com/YLChen-007/22cada4c9060f5123dde6185135ae3ab |
|---|
| ユーザー | Eric-h (UID 97582) |
|---|
| 送信 | 2026年04月24日 14:35 (1 月 ago) |
|---|
| モデレーション | 2026年05月23日 11:19 (29 days later) |
|---|
| ステータス | 承諾済み |
|---|
| VulDBエントリ | 365313 [NousResearch hermes-agent 迄 2026.4.16 Batch Runner tools/approval.py check_all_command_guards 特権昇格] |
|---|
| ポイント | 20 |
|---|