fix(gateway): support quick commands from GatewayConfig
This commit is contained in:
parent
41f22de20f
commit
ce56b45514
3 changed files with 30 additions and 1 deletions
|
|
@ -151,6 +151,9 @@ class GatewayConfig:
|
||||||
|
|
||||||
# Reset trigger commands
|
# Reset trigger commands
|
||||||
reset_triggers: List[str] = field(default_factory=lambda: ["/new", "/reset"])
|
reset_triggers: List[str] = field(default_factory=lambda: ["/new", "/reset"])
|
||||||
|
|
||||||
|
# User-defined quick commands (slash commands that bypass the agent loop)
|
||||||
|
quick_commands: Dict[str, Any] = field(default_factory=dict)
|
||||||
|
|
||||||
# Storage paths
|
# Storage paths
|
||||||
sessions_dir: Path = field(default_factory=lambda: get_hermes_home() / "sessions")
|
sessions_dir: Path = field(default_factory=lambda: get_hermes_home() / "sessions")
|
||||||
|
|
@ -218,6 +221,7 @@ class GatewayConfig:
|
||||||
p.value: v.to_dict() for p, v in self.reset_by_platform.items()
|
p.value: v.to_dict() for p, v in self.reset_by_platform.items()
|
||||||
},
|
},
|
||||||
"reset_triggers": self.reset_triggers,
|
"reset_triggers": self.reset_triggers,
|
||||||
|
"quick_commands": self.quick_commands,
|
||||||
"sessions_dir": str(self.sessions_dir),
|
"sessions_dir": str(self.sessions_dir),
|
||||||
"always_log_local": self.always_log_local,
|
"always_log_local": self.always_log_local,
|
||||||
}
|
}
|
||||||
|
|
@ -252,12 +256,17 @@ class GatewayConfig:
|
||||||
if "sessions_dir" in data:
|
if "sessions_dir" in data:
|
||||||
sessions_dir = Path(data["sessions_dir"])
|
sessions_dir = Path(data["sessions_dir"])
|
||||||
|
|
||||||
|
quick_commands = data.get("quick_commands", {})
|
||||||
|
if not isinstance(quick_commands, dict):
|
||||||
|
quick_commands = {}
|
||||||
|
|
||||||
return cls(
|
return cls(
|
||||||
platforms=platforms,
|
platforms=platforms,
|
||||||
default_reset_policy=default_policy,
|
default_reset_policy=default_policy,
|
||||||
reset_by_type=reset_by_type,
|
reset_by_type=reset_by_type,
|
||||||
reset_by_platform=reset_by_platform,
|
reset_by_platform=reset_by_platform,
|
||||||
reset_triggers=data.get("reset_triggers", ["/new", "/reset"]),
|
reset_triggers=data.get("reset_triggers", ["/new", "/reset"]),
|
||||||
|
quick_commands=quick_commands,
|
||||||
sessions_dir=sessions_dir,
|
sessions_dir=sessions_dir,
|
||||||
always_log_local=data.get("always_log_local", True),
|
always_log_local=data.get("always_log_local", True),
|
||||||
)
|
)
|
||||||
|
|
|
||||||
|
|
@ -1013,7 +1013,10 @@ class GatewayRunner:
|
||||||
|
|
||||||
# User-defined quick commands (bypass agent loop, no LLM call)
|
# User-defined quick commands (bypass agent loop, no LLM call)
|
||||||
if command:
|
if command:
|
||||||
quick_commands = self.config.get("quick_commands", {})
|
if isinstance(self.config, dict):
|
||||||
|
quick_commands = self.config.get("quick_commands", {}) or {}
|
||||||
|
else:
|
||||||
|
quick_commands = getattr(self.config, "quick_commands", {}) or {}
|
||||||
if command in quick_commands:
|
if command in quick_commands:
|
||||||
qcmd = quick_commands[command]
|
qcmd = quick_commands[command]
|
||||||
if qcmd.get("type") == "exec":
|
if qcmd.get("type") == "exec":
|
||||||
|
|
|
||||||
|
|
@ -146,3 +146,20 @@ class TestGatewayQuickCommands:
|
||||||
result = await runner._handle_message(event)
|
result = await runner._handle_message(event)
|
||||||
assert result is not None
|
assert result is not None
|
||||||
assert "timed out" in result.lower()
|
assert "timed out" in result.lower()
|
||||||
|
|
||||||
|
@pytest.mark.asyncio
|
||||||
|
async def test_gateway_config_object_supports_quick_commands(self):
|
||||||
|
from gateway.config import GatewayConfig
|
||||||
|
from gateway.run import GatewayRunner
|
||||||
|
|
||||||
|
runner = GatewayRunner.__new__(GatewayRunner)
|
||||||
|
runner.config = GatewayConfig(
|
||||||
|
quick_commands={"limits": {"type": "exec", "command": "echo ok"}}
|
||||||
|
)
|
||||||
|
runner._running_agents = {}
|
||||||
|
runner._pending_messages = {}
|
||||||
|
runner._is_user_authorized = MagicMock(return_value=True)
|
||||||
|
|
||||||
|
event = self._make_event("limits")
|
||||||
|
result = await runner._handle_message(event)
|
||||||
|
assert result == "ok"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue