mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-06-09 08:21:50 +00:00
Batch extraction of every remaining subcommand whose handler is top-level and whose parser block is pure argparse: model, setup, postinstall, whatsapp, slack, login, logout, auth, status, webhook, hooks, doctor, security, dump, debug, backup, import, config, version, update, uninstall, dashboard, gui, logs, prompt-size. Each becomes hermes_cli/subcommands/<name>.py with build_<name>_parser() and an injected handler (no main import). dashboard also injects cmd_dashboard_register for its nested 'register' action. Behavior-neutral: all 25 subcommands' --help output (and nested subaction help) diff-verified byte-identical to pre-extraction. Two RawDescriptionHelpFormatter epilogs (debug, logs) needed their multi-line string interiors preserved at column 0 — caught by the --help diff, not compile. main() 3297 -> 1798 LOC across this PR; add_parser calls in main.py 179 -> 89. Validation: tests/hermes_cli/ 6476 passed / 0 failed under per-file process isolation; new test_subcommands_batch.py smoke-tests all 25 builders + the dashboard two-handler case.
76 lines
2.7 KiB
Python
76 lines
2.7 KiB
Python
"""``hermes webhook`` subcommand parser.
|
|
|
|
Extracted verbatim from ``hermes_cli/main.py:main()`` (god-file Phase 2).
|
|
Handler injected to avoid importing ``main``.
|
|
"""
|
|
|
|
from __future__ import annotations
|
|
|
|
from typing import Callable
|
|
|
|
|
|
def build_webhook_parser(subparsers, *, cmd_webhook: Callable) -> None:
|
|
"""Attach the ``webhook`` subcommand to ``subparsers``."""
|
|
# =========================================================================
|
|
# webhook command
|
|
# =========================================================================
|
|
webhook_parser = subparsers.add_parser(
|
|
"webhook",
|
|
help="Manage dynamic webhook subscriptions",
|
|
description="Create, list, and remove webhook subscriptions for event-driven agent activation",
|
|
)
|
|
webhook_subparsers = webhook_parser.add_subparsers(dest="webhook_action")
|
|
|
|
wh_sub = webhook_subparsers.add_parser(
|
|
"subscribe", aliases=["add"], help="Create a webhook subscription"
|
|
)
|
|
wh_sub.add_argument("name", help="Route name (used in URL: /webhooks/<name>)")
|
|
wh_sub.add_argument(
|
|
"--prompt", default="", help="Prompt template with {dot.notation} payload refs"
|
|
)
|
|
wh_sub.add_argument(
|
|
"--events", default="", help="Comma-separated event types to accept"
|
|
)
|
|
wh_sub.add_argument("--description", default="", help="What this subscription does")
|
|
wh_sub.add_argument(
|
|
"--skills", default="", help="Comma-separated skill names to load"
|
|
)
|
|
wh_sub.add_argument(
|
|
"--deliver",
|
|
default="log",
|
|
help="Delivery target: log, telegram, discord, slack, etc.",
|
|
)
|
|
wh_sub.add_argument(
|
|
"--deliver-chat-id",
|
|
default="",
|
|
help="Target chat ID for cross-platform delivery",
|
|
)
|
|
wh_sub.add_argument(
|
|
"--secret", default="", help="HMAC secret (auto-generated if omitted)"
|
|
)
|
|
wh_sub.add_argument(
|
|
"--deliver-only",
|
|
action="store_true",
|
|
help="Skip the agent — deliver the rendered prompt directly as the "
|
|
"message. Zero LLM cost. Requires --deliver to be a real target "
|
|
"(not 'log').",
|
|
)
|
|
|
|
webhook_subparsers.add_parser(
|
|
"list", aliases=["ls"], help="List all dynamic subscriptions"
|
|
)
|
|
|
|
wh_rm = webhook_subparsers.add_parser(
|
|
"remove", aliases=["rm"], help="Remove a subscription"
|
|
)
|
|
wh_rm.add_argument("name", help="Subscription name to remove")
|
|
|
|
wh_test = webhook_subparsers.add_parser(
|
|
"test", help="Send a test POST to a webhook route"
|
|
)
|
|
wh_test.add_argument("name", help="Subscription name to test")
|
|
wh_test.add_argument(
|
|
"--payload", default="", help="JSON payload to send (default: test payload)"
|
|
)
|
|
|
|
webhook_parser.set_defaults(func=cmd_webhook)
|