3.6 KiB
3.6 KiB
summary, read_when
| summary | read_when | |
|---|---|---|
| Elevated exec mode and /elevated directives |
|
Elevated Mode (/elevated directives)
What it does
- Elevated mode allows the exec tool to run with elevated privileges when the feature is available and the sender is approved.
- The bash chat command (
!;/bashalias) uses the sametools.elevatedallowlists because it always runs on the host. - Optional for sandboxed agents: elevated only changes behavior when the agent is running in a sandbox. If the agent already runs unsandboxed, elevated is effectively a no-op.
- Directive forms:
/elevated on,/elevated off,/elev on,/elev off. - Only
on|offare accepted; anything else returns a hint and does not change state.
What it controls (and what it doesn’t)
- Availability gates:
tools.elevatedis the global baseline.agents.list[].tools.elevatedcan further restrict elevated per agent (both must allow). - Per-session state:
/elevated on|offsets the elevated level for the current session key. - Inline directive:
/elevated oninside a message applies to that message only. - Groups: In group chats, elevated directives are only honored when the agent is mentioned. Command-only messages that bypass mention requirements are treated as mentioned.
- Host execution: elevated runs
execon the host (bypasses sandbox). - Unsandboxed agents: when there is no sandbox to bypass, elevated does not change where
execruns. - Tool policy still applies: if
execis denied by tool policy, elevated cannot be used.
Note:
- Sandbox on:
/elevated onruns thatexeccommand on the host. - Sandbox off:
/elevated ondoes not change execution (already on host).
When elevated matters
- Only impacts
execwhen the agent is running sandboxed (it drops the sandbox for that command). - For unsandboxed agents, elevated does not change execution; it only affects gating, logging, and status.
Resolution order
- Inline directive on the message (applies only to that message).
- Session override (set by sending a directive-only message).
- Global default (
agents.defaults.elevatedDefaultin config).
Setting a session default
- Send a message that is only the directive (whitespace allowed), e.g.
/elevated on. - Confirmation reply is sent (
Elevated mode enabled./Elevated mode disabled.). - If elevated access is disabled or the sender is not on the approved allowlist, the directive replies with an actionable error (runtime sandboxed/direct + failing config key paths) and does not change session state.
- Send
/elevated(or/elevated:) with no argument to see the current elevated level.
Availability + allowlists
- Feature gate:
tools.elevated.enabled(default can be off via config even if the code supports it). - Sender allowlist:
tools.elevated.allowFromwith per-provider allowlists (e.g.discord,whatsapp). - Per-agent gate:
agents.list[].tools.elevated.enabled(optional; can only further restrict). - Per-agent allowlist:
agents.list[].tools.elevated.allowFrom(optional; when set, the sender must match both global + per-agent allowlists). - Discord fallback: if
tools.elevated.allowFrom.discordis omitted, thechannels.discord.dm.allowFromlist is used as a fallback. Settools.elevated.allowFrom.discord(even[]) to override. Per-agent allowlists do not use the fallback. - All gates must pass; otherwise elevated is treated as unavailable.
Logging + status
- Elevated exec calls are logged at info level.
- Session status includes elevated mode (e.g.
elevated=on).