feat: auto native commands defaults
This commit is contained in:
@@ -27,6 +27,7 @@
|
|||||||
- Runtime: memory index stored under `~/.clawdbot/memory/{agentId}.sqlite` with watch-on-by-default; inline status replies now stay auth-gated while inline prompts continue to the agent.
|
- Runtime: memory index stored under `~/.clawdbot/memory/{agentId}.sqlite` with watch-on-by-default; inline status replies now stay auth-gated while inline prompts continue to the agent.
|
||||||
- Discord: add `discord.allowBots` to permit bot-authored messages (still ignores its own messages) with docs warning about bot loops. (#802) — thanks @zknicker.
|
- Discord: add `discord.allowBots` to permit bot-authored messages (still ignores its own messages) with docs warning about bot loops. (#802) — thanks @zknicker.
|
||||||
- CLI/Onboarding: `clawdbot dashboard` prints/copies the tokenized Control UI link and opens it; onboarding now auto-opens the dashboard with your token and keeps the link in the summary.
|
- CLI/Onboarding: `clawdbot dashboard` prints/copies the tokenized Control UI link and opens it; onboarding now auto-opens the dashboard with your token and keeps the link in the summary.
|
||||||
|
- Commands: native slash commands now default to `"auto"` (on for Discord/Telegram, off for Slack) with per-provider overrides (`discord/telegram/slack.commands.native`) and docs updated.
|
||||||
|
|
||||||
### Fixes
|
### Fixes
|
||||||
- Auto-reply: inline `/status` now honors allowlists (authorized stripped + replied inline; unauthorized leaves text for the agent) to match command gating tests.
|
- Auto-reply: inline `/status` now honors allowlists (authorized stripped + replied inline; unauthorized leaves text for the agent) to match command gating tests.
|
||||||
|
|||||||
@@ -756,8 +756,8 @@ Controls how chat commands are enabled across connectors.
|
|||||||
Notes:
|
Notes:
|
||||||
- Text commands must be sent as a **standalone** message and use the leading `/` (no plain-text aliases).
|
- Text commands must be sent as a **standalone** message and use the leading `/` (no plain-text aliases).
|
||||||
- `commands.text: false` disables parsing chat messages for commands.
|
- `commands.text: false` disables parsing chat messages for commands.
|
||||||
- `commands.native: true` registers native commands on supported connectors (Discord/Slack/Telegram). Platforms without native commands still rely on text commands.
|
- `commands.native: "auto"` (default) turns on native commands for Discord/Telegram and leaves Slack off; unsupported providers stay text-only.
|
||||||
- `commands.native: false` skips native registration; Discord/Telegram clear previously registered commands on startup. Slack commands are managed in the Slack app.
|
- Set `commands.native: true|false` to force all, or override per provider with `discord.commands.native`, `telegram.commands.native`, `slack.commands.native` (bool or `"auto"`). `false` clears previously registered commands on Discord/Telegram at startup; Slack commands are managed in the Slack app.
|
||||||
- `commands.config: true` enables `/config` (reads/writes `clawdbot.json`).
|
- `commands.config: true` enables `/config` (reads/writes `clawdbot.json`).
|
||||||
- `commands.debug: true` enables `/debug` (runtime-only overrides).
|
- `commands.debug: true` enables `/debug` (runtime-only overrides).
|
||||||
- `commands.restart: true` enables `/restart` and the gateway tool restart action.
|
- `commands.restart: true` enables `/restart` and the gateway tool restart action.
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ Minimal config:
|
|||||||
- To ignore all DMs: set `discord.dm.enabled=false` or `discord.dm.policy="disabled"`.
|
- To ignore all DMs: set `discord.dm.enabled=false` or `discord.dm.policy="disabled"`.
|
||||||
8. Group DMs are ignored by default; enable via `discord.dm.groupEnabled` and optionally restrict by `discord.dm.groupChannels`.
|
8. Group DMs are ignored by default; enable via `discord.dm.groupEnabled` and optionally restrict by `discord.dm.groupChannels`.
|
||||||
9. Optional guild rules: set `discord.guilds` keyed by guild id (preferred) or slug, with per-channel rules.
|
9. Optional guild rules: set `discord.guilds` keyed by guild id (preferred) or slug, with per-channel rules.
|
||||||
10. Optional native commands: set `commands.native: true` to register native commands in Discord; set `commands.native: false` to clear previously registered native commands. Text commands are controlled by `commands.text` and must be sent as standalone `/...` messages. Use `commands.useAccessGroups: false` to bypass access-group checks for commands.
|
10. Optional native commands: `commands.native` defaults to `"auto"` (on for Discord/Telegram, off for Slack). Override with `discord.commands.native: true|false|"auto"`; `false` clears previously registered commands. Text commands are controlled by `commands.text` and must be sent as standalone `/...` messages. Use `commands.useAccessGroups: false` to bypass access-group checks for commands.
|
||||||
- Full command list + config: [Slash commands](/tools/slash-commands)
|
- Full command list + config: [Slash commands](/tools/slash-commands)
|
||||||
11. Optional guild context history: set `discord.historyLimit` (default 20, falls back to `messages.groupChat.historyLimit`) to include the last N guild messages as context when replying to a mention. Set `0` to disable.
|
11. Optional guild context history: set `discord.historyLimit` (default 20, falls back to `messages.groupChat.historyLimit`) to include the last N guild messages as context when replying to a mention. Set `0` to disable.
|
||||||
12. Reactions: the agent can trigger reactions via the `discord` tool (gated by `discord.actions.*`).
|
12. Reactions: the agent can trigger reactions via the `discord` tool (gated by `discord.actions.*`).
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ Minimal config:
|
|||||||
- `channel_rename`
|
- `channel_rename`
|
||||||
- `pin_added`, `pin_removed`
|
- `pin_added`, `pin_removed`
|
||||||
5) Invite the bot to channels you want it to read.
|
5) Invite the bot to channels you want it to read.
|
||||||
6) Slash Commands → create `/clawd` if you use `slack.slashCommand`. If you enable `commands.native`, add slash commands for the built-in chat commands (same names as `/help`).
|
6) Slash Commands → create `/clawd` if you use `slack.slashCommand`. If you enable native commands, add one slash command per built-in command (same names as `/help`). Native defaults to off for Slack unless you set `slack.commands.native: true` (global `commands.native` is `"auto"` which leaves Slack off).
|
||||||
7) App Home → enable the **Messages Tab** so users can DM the bot.
|
7) App Home → enable the **Messages Tab** so users can DM the bot.
|
||||||
|
|
||||||
Use the manifest below so scopes and events stay in sync.
|
Use the manifest below so scopes and events stay in sync.
|
||||||
@@ -138,7 +138,7 @@ Use this Slack app manifest to create the app quickly (adjust the name/command i
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
If you enable `commands.native`, add one `slash_commands` entry per command you want to expose (matching the `/help` list).
|
If you enable native commands, add one `slash_commands` entry per command you want to expose (matching the `/help` list). Override with `slack.commands.native`.
|
||||||
|
|
||||||
## Scopes (current vs optional)
|
## Scopes (current vs optional)
|
||||||
Slack's Conversations API is type-scoped: you only need the scopes for the
|
Slack's Conversations API is type-scoped: you only need the scopes for the
|
||||||
@@ -257,7 +257,7 @@ For fine-grained control, use these tags in agent responses:
|
|||||||
- DMs share the `main` session (like WhatsApp/Telegram).
|
- DMs share the `main` session (like WhatsApp/Telegram).
|
||||||
- Channels map to `agent:<agentId>:slack:channel:<channelId>` sessions.
|
- Channels map to `agent:<agentId>:slack:channel:<channelId>` sessions.
|
||||||
- Slash commands use `agent:<agentId>:slack:slash:<userId>` sessions (prefix configurable via `slack.slashCommand.sessionPrefix`).
|
- Slash commands use `agent:<agentId>:slack:slash:<userId>` sessions (prefix configurable via `slack.slashCommand.sessionPrefix`).
|
||||||
- Native command registration is controlled by `commands.native`; text commands require standalone `/...` messages and can be disabled with `commands.text: false`. Slack slash commands are managed in the Slack app and are not removed automatically. Use `commands.useAccessGroups: false` to bypass access-group checks for commands.
|
- Native command registration uses `commands.native` (global default `"auto"` → Slack off) and can be overridden per-workspace with `slack.commands.native`. Text commands require standalone `/...` messages and can be disabled with `commands.text: false`. Slack slash commands are managed in the Slack app and are not removed automatically. Use `commands.useAccessGroups: false` to bypass access-group checks for commands.
|
||||||
- Full command list + config: [Slash commands](/tools/slash-commands)
|
- Full command list + config: [Slash commands](/tools/slash-commands)
|
||||||
|
|
||||||
## DM security (pairing)
|
## DM security (pairing)
|
||||||
|
|||||||
@@ -315,5 +315,5 @@ Provider options:
|
|||||||
Related global options:
|
Related global options:
|
||||||
- `agents.list[].groupChat.mentionPatterns` (mention gating patterns).
|
- `agents.list[].groupChat.mentionPatterns` (mention gating patterns).
|
||||||
- `messages.groupChat.mentionPatterns` (global fallback).
|
- `messages.groupChat.mentionPatterns` (global fallback).
|
||||||
- `commands.native`, `commands.text`, `commands.useAccessGroups` (command behavior).
|
- `commands.native` (defaults to `"auto"` → on for Telegram/Discord, off for Slack), `commands.text`, `commands.useAccessGroups` (command behavior). Override with `telegram.commands.native`.
|
||||||
- `messages.responsePrefix`, `messages.ackReaction`, `messages.ackReactionScope`, `messages.removeAckAfterReply`.
|
- `messages.responsePrefix`, `messages.ackReaction`, `messages.ackReactionScope`, `messages.removeAckAfterReply`.
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ They run immediately, are stripped before the model sees the message, and the re
|
|||||||
```json5
|
```json5
|
||||||
{
|
{
|
||||||
commands: {
|
commands: {
|
||||||
native: false,
|
native: "auto",
|
||||||
text: true,
|
text: true,
|
||||||
config: false,
|
config: false,
|
||||||
debug: false,
|
debug: false,
|
||||||
@@ -36,9 +36,10 @@ They run immediately, are stripped before the model sees the message, and the re
|
|||||||
|
|
||||||
- `commands.text` (default `true`) enables parsing `/...` in chat messages.
|
- `commands.text` (default `true`) enables parsing `/...` in chat messages.
|
||||||
- On surfaces without native commands (WhatsApp/WebChat/Signal/iMessage/MS Teams), text commands still work even if you set this to `false`.
|
- On surfaces without native commands (WhatsApp/WebChat/Signal/iMessage/MS Teams), text commands still work even if you set this to `false`.
|
||||||
- `commands.native` (default `false`) registers native commands on Discord/Slack/Telegram.
|
- `commands.native` (default `"auto"`) registers native commands.
|
||||||
- `false` clears previously registered commands on Discord/Telegram at startup.
|
- Auto: on for Discord/Telegram; off for Slack (until you add slash commands); ignored for providers without native support.
|
||||||
- Slack commands are managed in the Slack app and are not removed automatically.
|
- Set `discord.commands.native`, `telegram.commands.native`, or `slack.commands.native` to override per provider (bool or `"auto"`).
|
||||||
|
- `false` clears previously registered commands on Discord/Telegram at startup. Slack commands are managed in the Slack app and are not removed automatically.
|
||||||
- `commands.config` (default `false`) enables `/config` (reads/writes `clawdbot.json`).
|
- `commands.config` (default `false`) enables `/config` (reads/writes `clawdbot.json`).
|
||||||
- `commands.debug` (default `false`) enables `/debug` (runtime-only overrides).
|
- `commands.debug` (default `false`) enables `/debug` (runtime-only overrides).
|
||||||
- `commands.useAccessGroups` (default `true`) enforces allowlists/policies for commands.
|
- `commands.useAccessGroups` (default `true`) enforces allowlists/policies for commands.
|
||||||
|
|||||||
35
src/config/commands.ts
Normal file
35
src/config/commands.ts
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
import type { NativeCommandsSetting } from "./types.js";
|
||||||
|
import { normalizeProviderId } from "../providers/registry.js";
|
||||||
|
import type { ProviderId } from "../providers/plugins/types.js";
|
||||||
|
|
||||||
|
function resolveAutoDefault(providerId?: ProviderId): boolean {
|
||||||
|
const id = normalizeProviderId(providerId);
|
||||||
|
if (!id) return false;
|
||||||
|
if (id === "discord" || id === "telegram") return true;
|
||||||
|
if (id === "slack") return false;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function resolveNativeCommandsEnabled(params: {
|
||||||
|
providerId: ProviderId;
|
||||||
|
providerSetting?: NativeCommandsSetting;
|
||||||
|
globalSetting?: NativeCommandsSetting;
|
||||||
|
}): boolean {
|
||||||
|
const { providerId, providerSetting, globalSetting } = params;
|
||||||
|
const setting =
|
||||||
|
providerSetting === undefined ? globalSetting : providerSetting;
|
||||||
|
if (setting === true) return true;
|
||||||
|
if (setting === false) return false;
|
||||||
|
// auto or undefined -> heuristic
|
||||||
|
return resolveAutoDefault(providerId);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function isNativeCommandsExplicitlyDisabled(params: {
|
||||||
|
providerSetting?: NativeCommandsSetting;
|
||||||
|
globalSetting?: NativeCommandsSetting;
|
||||||
|
}): boolean {
|
||||||
|
const { providerSetting, globalSetting } = params;
|
||||||
|
if (providerSetting === false) return true;
|
||||||
|
if (providerSetting === undefined) return globalSetting === false;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
@@ -283,6 +283,12 @@ const FIELD_HELP: Record<string, string> = {
|
|||||||
"Allow /restart and gateway restart tool actions (default: false).",
|
"Allow /restart and gateway restart tool actions (default: false).",
|
||||||
"commands.useAccessGroups":
|
"commands.useAccessGroups":
|
||||||
"Enforce access-group allowlists/policies for commands.",
|
"Enforce access-group allowlists/policies for commands.",
|
||||||
|
"discord.commands.native":
|
||||||
|
'Override native commands for Discord (bool or "auto").',
|
||||||
|
"telegram.commands.native":
|
||||||
|
'Override native commands for Telegram (bool or "auto").',
|
||||||
|
"slack.commands.native":
|
||||||
|
'Override native commands for Slack (bool or "auto").',
|
||||||
"session.agentToAgent.maxPingPongTurns":
|
"session.agentToAgent.maxPingPongTurns":
|
||||||
"Max reply-back turns between requester and target (0–5).",
|
"Max reply-back turns between requester and target (0–5).",
|
||||||
"messages.ackReaction":
|
"messages.ackReaction":
|
||||||
|
|||||||
@@ -359,6 +359,8 @@ export type TelegramAccountConfig = {
|
|||||||
name?: string;
|
name?: string;
|
||||||
/** Optional provider capability tags used for agent/runtime guidance. */
|
/** Optional provider capability tags used for agent/runtime guidance. */
|
||||||
capabilities?: string[];
|
capabilities?: string[];
|
||||||
|
/** Override native command registration for Telegram (bool or "auto"). */
|
||||||
|
commands?: ProviderCommandsConfig;
|
||||||
/**
|
/**
|
||||||
* Controls how Telegram direct chats (DMs) are handled:
|
* Controls how Telegram direct chats (DMs) are handled:
|
||||||
* - "pairing" (default): unknown senders get a pairing code; owner must approve
|
* - "pairing" (default): unknown senders get a pairing code; owner must approve
|
||||||
@@ -510,6 +512,8 @@ export type DiscordAccountConfig = {
|
|||||||
name?: string;
|
name?: string;
|
||||||
/** Optional provider capability tags used for agent/runtime guidance. */
|
/** Optional provider capability tags used for agent/runtime guidance. */
|
||||||
capabilities?: string[];
|
capabilities?: string[];
|
||||||
|
/** Override native command registration for Discord (bool or "auto"). */
|
||||||
|
commands?: ProviderCommandsConfig;
|
||||||
/** If false, do not start this Discord account. Default: true. */
|
/** If false, do not start this Discord account. Default: true. */
|
||||||
enabled?: boolean;
|
enabled?: boolean;
|
||||||
token?: string;
|
token?: string;
|
||||||
@@ -621,6 +625,8 @@ export type SlackAccountConfig = {
|
|||||||
name?: string;
|
name?: string;
|
||||||
/** Optional provider capability tags used for agent/runtime guidance. */
|
/** Optional provider capability tags used for agent/runtime guidance. */
|
||||||
capabilities?: string[];
|
capabilities?: string[];
|
||||||
|
/** Override native command registration for Slack (bool or "auto"). */
|
||||||
|
commands?: ProviderCommandsConfig;
|
||||||
/** If false, do not start this Slack account. Default: true. */
|
/** If false, do not start this Slack account. Default: true. */
|
||||||
enabled?: boolean;
|
enabled?: boolean;
|
||||||
botToken?: string;
|
botToken?: string;
|
||||||
@@ -1209,9 +1215,11 @@ export type MessagesConfig = {
|
|||||||
removeAckAfterReply?: boolean;
|
removeAckAfterReply?: boolean;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type NativeCommandsSetting = boolean | "auto";
|
||||||
|
|
||||||
export type CommandsConfig = {
|
export type CommandsConfig = {
|
||||||
/** Enable native command registration when supported (default: false). */
|
/** Enable native command registration when supported (default: "auto"). */
|
||||||
native?: boolean;
|
native?: NativeCommandsSetting;
|
||||||
/** Enable text command parsing (default: true). */
|
/** Enable text command parsing (default: true). */
|
||||||
text?: boolean;
|
text?: boolean;
|
||||||
/** Allow /config command (default: false). */
|
/** Allow /config command (default: false). */
|
||||||
@@ -1224,6 +1232,11 @@ export type CommandsConfig = {
|
|||||||
useAccessGroups?: boolean;
|
useAccessGroups?: boolean;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type ProviderCommandsConfig = {
|
||||||
|
/** Override native command registration for this provider (bool or "auto"). */
|
||||||
|
native?: NativeCommandsSetting;
|
||||||
|
};
|
||||||
|
|
||||||
export type BridgeBindMode = "auto" | "lan" | "tailnet" | "loopback";
|
export type BridgeBindMode = "auto" | "lan" | "tailnet" | "loopback";
|
||||||
|
|
||||||
export type BridgeConfig = {
|
export type BridgeConfig = {
|
||||||
|
|||||||
@@ -269,6 +269,7 @@ const TelegramAccountSchemaBase = z.object({
|
|||||||
name: z.string().optional(),
|
name: z.string().optional(),
|
||||||
capabilities: z.array(z.string()).optional(),
|
capabilities: z.array(z.string()).optional(),
|
||||||
enabled: z.boolean().optional(),
|
enabled: z.boolean().optional(),
|
||||||
|
commands: ProviderCommandsSchema,
|
||||||
dmPolicy: DmPolicySchema.optional().default("pairing"),
|
dmPolicy: DmPolicySchema.optional().default("pairing"),
|
||||||
botToken: z.string().optional(),
|
botToken: z.string().optional(),
|
||||||
tokenFile: z.string().optional(),
|
tokenFile: z.string().optional(),
|
||||||
@@ -367,6 +368,7 @@ const DiscordAccountSchema = z.object({
|
|||||||
name: z.string().optional(),
|
name: z.string().optional(),
|
||||||
capabilities: z.array(z.string()).optional(),
|
capabilities: z.array(z.string()).optional(),
|
||||||
enabled: z.boolean().optional(),
|
enabled: z.boolean().optional(),
|
||||||
|
commands: ProviderCommandsSchema,
|
||||||
token: z.string().optional(),
|
token: z.string().optional(),
|
||||||
allowBots: z.boolean().optional(),
|
allowBots: z.boolean().optional(),
|
||||||
groupPolicy: GroupPolicySchema.optional().default("allowlist"),
|
groupPolicy: GroupPolicySchema.optional().default("allowlist"),
|
||||||
@@ -440,6 +442,7 @@ const SlackAccountSchema = z.object({
|
|||||||
name: z.string().optional(),
|
name: z.string().optional(),
|
||||||
capabilities: z.array(z.string()).optional(),
|
capabilities: z.array(z.string()).optional(),
|
||||||
enabled: z.boolean().optional(),
|
enabled: z.boolean().optional(),
|
||||||
|
commands: ProviderCommandsSchema,
|
||||||
botToken: z.string().optional(),
|
botToken: z.string().optional(),
|
||||||
appToken: z.string().optional(),
|
appToken: z.string().optional(),
|
||||||
allowBots: z.boolean().optional(),
|
allowBots: z.boolean().optional(),
|
||||||
@@ -709,16 +712,28 @@ const MessagesSchema = z
|
|||||||
})
|
})
|
||||||
.optional();
|
.optional();
|
||||||
|
|
||||||
|
const NativeCommandsSettingSchema = z.union([
|
||||||
|
z.boolean(),
|
||||||
|
z.literal("auto"),
|
||||||
|
]);
|
||||||
|
|
||||||
|
const ProviderCommandsSchema = z
|
||||||
|
.object({
|
||||||
|
native: NativeCommandsSettingSchema.optional(),
|
||||||
|
})
|
||||||
|
.optional();
|
||||||
|
|
||||||
const CommandsSchema = z
|
const CommandsSchema = z
|
||||||
.object({
|
.object({
|
||||||
native: z.boolean().optional(),
|
native: NativeCommandsSettingSchema.optional().default("auto"),
|
||||||
text: z.boolean().optional(),
|
text: z.boolean().optional(),
|
||||||
config: z.boolean().optional(),
|
config: z.boolean().optional(),
|
||||||
debug: z.boolean().optional(),
|
debug: z.boolean().optional(),
|
||||||
restart: z.boolean().optional(),
|
restart: z.boolean().optional(),
|
||||||
useAccessGroups: z.boolean().optional(),
|
useAccessGroups: z.boolean().optional(),
|
||||||
})
|
})
|
||||||
.optional();
|
.optional()
|
||||||
|
.default({ native: "auto" });
|
||||||
|
|
||||||
const HeartbeatSchema = z
|
const HeartbeatSchema = z
|
||||||
.object({
|
.object({
|
||||||
|
|||||||
@@ -51,6 +51,10 @@ import { getReplyFromConfig } from "../auto-reply/reply.js";
|
|||||||
import type { ReplyPayload } from "../auto-reply/types.js";
|
import type { ReplyPayload } from "../auto-reply/types.js";
|
||||||
import type { ClawdbotConfig, ReplyToMode } from "../config/config.js";
|
import type { ClawdbotConfig, ReplyToMode } from "../config/config.js";
|
||||||
import { loadConfig } from "../config/config.js";
|
import { loadConfig } from "../config/config.js";
|
||||||
|
import {
|
||||||
|
isNativeCommandsExplicitlyDisabled,
|
||||||
|
resolveNativeCommandsEnabled,
|
||||||
|
} from "../config/commands.js";
|
||||||
import { resolveStorePath, updateLastRoute } from "../config/sessions.js";
|
import { resolveStorePath, updateLastRoute } from "../config/sessions.js";
|
||||||
import { danger, logVerbose, shouldLogVerbose } from "../globals.js";
|
import { danger, logVerbose, shouldLogVerbose } from "../globals.js";
|
||||||
import { formatDurationSeconds } from "../infra/format-duration.js";
|
import { formatDurationSeconds } from "../infra/format-duration.js";
|
||||||
@@ -403,8 +407,15 @@ export async function monitorDiscordProvider(opts: MonitorDiscordOpts = {}) {
|
|||||||
const dmPolicy = dmConfig?.policy ?? "pairing";
|
const dmPolicy = dmConfig?.policy ?? "pairing";
|
||||||
const groupDmEnabled = dmConfig?.groupEnabled ?? false;
|
const groupDmEnabled = dmConfig?.groupEnabled ?? false;
|
||||||
const groupDmChannels = dmConfig?.groupChannels;
|
const groupDmChannels = dmConfig?.groupChannels;
|
||||||
const nativeEnabled = cfg.commands?.native === true;
|
const nativeEnabled = resolveNativeCommandsEnabled({
|
||||||
const nativeDisabledExplicit = cfg.commands?.native === false;
|
providerId: "discord",
|
||||||
|
providerSetting: discordCfg.commands?.native,
|
||||||
|
globalSetting: cfg.commands?.native,
|
||||||
|
});
|
||||||
|
const nativeDisabledExplicit = isNativeCommandsExplicitlyDisabled({
|
||||||
|
providerSetting: discordCfg.commands?.native,
|
||||||
|
globalSetting: cfg.commands?.native,
|
||||||
|
});
|
||||||
const useAccessGroups = cfg.commands?.useAccessGroups !== false;
|
const useAccessGroups = cfg.commands?.useAccessGroups !== false;
|
||||||
const sessionPrefix = "discord:slash";
|
const sessionPrefix = "discord:slash";
|
||||||
const ephemeralDefault = true;
|
const ephemeralDefault = true;
|
||||||
|
|||||||
@@ -44,6 +44,7 @@ import type {
|
|||||||
SlackSlashCommandConfig,
|
SlackSlashCommandConfig,
|
||||||
} from "../config/config.js";
|
} from "../config/config.js";
|
||||||
import { loadConfig } from "../config/config.js";
|
import { loadConfig } from "../config/config.js";
|
||||||
|
import { resolveNativeCommandsEnabled } from "../config/commands.js";
|
||||||
import {
|
import {
|
||||||
resolveSessionKey,
|
resolveSessionKey,
|
||||||
resolveStorePath,
|
resolveStorePath,
|
||||||
@@ -1944,8 +1945,14 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const nativeCommands =
|
const nativeEnabled = resolveNativeCommandsEnabled({
|
||||||
cfg.commands?.native === true ? listNativeCommandSpecsForConfig(cfg) : [];
|
providerId: "slack",
|
||||||
|
providerSetting: account.config.commands?.native,
|
||||||
|
globalSetting: cfg.commands?.native,
|
||||||
|
});
|
||||||
|
const nativeCommands = nativeEnabled
|
||||||
|
? listNativeCommandSpecsForConfig(cfg)
|
||||||
|
: [];
|
||||||
if (nativeCommands.length > 0) {
|
if (nativeCommands.length > 0) {
|
||||||
for (const command of nativeCommands) {
|
for (const command of nativeCommands) {
|
||||||
app.command(
|
app.command(
|
||||||
|
|||||||
@@ -35,6 +35,10 @@ import { getReplyFromConfig } from "../auto-reply/reply.js";
|
|||||||
import type { ReplyPayload } from "../auto-reply/types.js";
|
import type { ReplyPayload } from "../auto-reply/types.js";
|
||||||
import type { ClawdbotConfig, ReplyToMode } from "../config/config.js";
|
import type { ClawdbotConfig, ReplyToMode } from "../config/config.js";
|
||||||
import { loadConfig } from "../config/config.js";
|
import { loadConfig } from "../config/config.js";
|
||||||
|
import {
|
||||||
|
isNativeCommandsExplicitlyDisabled,
|
||||||
|
resolveNativeCommandsEnabled,
|
||||||
|
} from "../config/commands.js";
|
||||||
import {
|
import {
|
||||||
resolveProviderGroupPolicy,
|
resolveProviderGroupPolicy,
|
||||||
resolveProviderGroupRequireMention,
|
resolveProviderGroupRequireMention,
|
||||||
@@ -291,8 +295,15 @@ export function createTelegramBot(opts: TelegramBotOptions) {
|
|||||||
};
|
};
|
||||||
const replyToMode = opts.replyToMode ?? telegramCfg.replyToMode ?? "first";
|
const replyToMode = opts.replyToMode ?? telegramCfg.replyToMode ?? "first";
|
||||||
const streamMode = resolveTelegramStreamMode(telegramCfg);
|
const streamMode = resolveTelegramStreamMode(telegramCfg);
|
||||||
const nativeEnabled = cfg.commands?.native === true;
|
const nativeEnabled = resolveNativeCommandsEnabled({
|
||||||
const nativeDisabledExplicit = cfg.commands?.native === false;
|
providerId: "telegram",
|
||||||
|
providerSetting: telegramCfg.commands?.native,
|
||||||
|
globalSetting: cfg.commands?.native,
|
||||||
|
});
|
||||||
|
const nativeDisabledExplicit = isNativeCommandsExplicitlyDisabled({
|
||||||
|
providerSetting: telegramCfg.commands?.native,
|
||||||
|
globalSetting: cfg.commands?.native,
|
||||||
|
});
|
||||||
const useAccessGroups = cfg.commands?.useAccessGroups !== false;
|
const useAccessGroups = cfg.commands?.useAccessGroups !== false;
|
||||||
const ackReactionScope = cfg.messages?.ackReactionScope ?? "group-mentions";
|
const ackReactionScope = cfg.messages?.ackReactionScope ?? "group-mentions";
|
||||||
const mediaMaxBytes =
|
const mediaMaxBytes =
|
||||||
|
|||||||
Reference in New Issue
Block a user