mirror of
https://github.com/NousResearch/hermes-agent.git
synced 2026-06-27 11:22:03 +00:00
By default `hermes slack manifest` opts the app into Slack's AI Assistant container (assistant_view feature + assistant:write scope + assistant_thread_* events). Slack then renders DMs as the right-hand Assistant split-pane, where every exchange is a thread and bare slash commands (/help, /new, ...) are not delivered as normal command events — they only work when the bot is @mentioned. There was no way to opt out short of hand-editing the generated JSON. Add --no-assistant to emit a flat-DM manifest that omits those three pieces, so DMs render as a normal chat and slash commands dispatch inline. The regular messaging surface (Messages tab, slash commands, Socket Mode, channel + DM scopes/events) is preserved in both modes. Default behaviour is unchanged (assistant mode still on). Tests: cover both manifest modes and the argparse wiring.
68 lines
2.5 KiB
Python
68 lines
2.5 KiB
Python
"""``hermes slack`` 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_slack_parser(subparsers, *, cmd_slack: Callable) -> None:
|
|
"""Attach the ``slack`` subcommand to ``subparsers``."""
|
|
# =========================================================================
|
|
# slack command
|
|
# =========================================================================
|
|
slack_parser = subparsers.add_parser(
|
|
"slack",
|
|
help="Slack integration helpers (manifest generation, etc.)",
|
|
description="Slack integration helpers for Hermes.",
|
|
)
|
|
slack_sub = slack_parser.add_subparsers(dest="slack_command")
|
|
slack_manifest = slack_sub.add_parser(
|
|
"manifest",
|
|
help="Print or write a Slack app manifest with every gateway command "
|
|
"registered as a native slash (/btw, /stop, /model, ...)",
|
|
description=(
|
|
"Generate a Slack app manifest that registers every gateway "
|
|
"command in COMMAND_REGISTRY as a first-class Slack slash "
|
|
"command (matching Discord and Telegram parity). Paste the "
|
|
"output into Slack app config → Features → App Manifest → "
|
|
"Edit, then Save. Reinstall the app if Slack prompts for it."
|
|
),
|
|
)
|
|
slack_manifest.add_argument(
|
|
"--write",
|
|
nargs="?",
|
|
const=True,
|
|
default=None,
|
|
metavar="PATH",
|
|
help="Write manifest to a file instead of stdout. With no PATH "
|
|
"writes to $HERMES_HOME/slack-manifest.json.",
|
|
)
|
|
slack_manifest.add_argument(
|
|
"--name",
|
|
default=None,
|
|
help='Bot display name (default: "Hermes")',
|
|
)
|
|
slack_manifest.add_argument(
|
|
"--description",
|
|
default=None,
|
|
help="Bot description shown in Slack's app directory.",
|
|
)
|
|
slack_manifest.add_argument(
|
|
"--slashes-only",
|
|
action="store_true",
|
|
help="Emit only the features.slash_commands array (for merging "
|
|
"into an existing manifest manually).",
|
|
)
|
|
slack_manifest.add_argument(
|
|
"--no-assistant",
|
|
action="store_true",
|
|
help="Omit Slack AI Assistant mode (assistant_view, assistant:write "
|
|
"scope, assistant_thread_* events). DMs then render as a flat chat "
|
|
"where bare slash commands (/help, /new) work inline instead of "
|
|
"Slack's Assistant thread pane.",
|
|
)
|
|
slack_parser.set_defaults(func=cmd_slack)
|