* feat: per-channel responsePrefix override
Add responsePrefix field to all channel config types and Zod schemas,
enabling per-channel and per-account outbound response prefix overrides.
Resolution cascade (most specific wins):
L1: channels.<ch>.accounts.<id>.responsePrefix
L2: channels.<ch>.responsePrefix
L3: (reserved for channels.defaults)
L4: messages.responsePrefix (existing global)
Semantics:
- undefined -> inherit from parent level
- empty string -> explicitly no prefix (stops cascade)
- "auto" -> derive [identity.name] from routed agent
Changes:
- Core logic: resolveResponsePrefix() in identity.ts accepts
optional channel/accountId and walks the cascade
- resolveEffectiveMessagesConfig() passes channel context through
- Types: responsePrefix added to WhatsApp, Telegram, Discord, Slack,
Signal, iMessage, Google Chat, MS Teams, Feishu, BlueBubbles configs
- Zod schemas: responsePrefix added for config validation
- All channel handlers wired: telegram, discord, slack, signal,
imessage, line, heartbeat runner, route-reply, native commands
- 23 new tests covering backward compat, channel/account levels,
full cascade, auto keyword, empty string stops, unknown fallthrough
Fully backward compatible - no existing config is affected.
Fixes #8857
* fix: address CI lint + review feedback
- Replace Record<string, any> with proper typed helpers (no-explicit-any)
- Add curly braces to single-line if returns (eslint curly)
- Fix JSDoc: 'Per-channel' → 'channel/account' on shared config types
- Extract getChannelConfig() helper for type-safe dynamic key access
* fix: finish responsePrefix overrides (#9001) (thanks @mudrii)
* fix: normalize prefix wiring and types (#9001) (thanks @mudrii)
---------
Co-authored-by: Gustavo Madeira Santana <gumadeiras@gmail.com>
112 lines
4.5 KiB
TypeScript
112 lines
4.5 KiB
TypeScript
import type {
|
|
BlockStreamingCoalesceConfig,
|
|
DmPolicy,
|
|
GroupPolicy,
|
|
MarkdownConfig,
|
|
} from "./types.base.js";
|
|
import type { ChannelHeartbeatVisibilityConfig } from "./types.channels.js";
|
|
import type { DmConfig } from "./types.messages.js";
|
|
import type { GroupToolPolicyBySenderConfig, GroupToolPolicyConfig } from "./types.tools.js";
|
|
|
|
export type MSTeamsWebhookConfig = {
|
|
/** Port for the webhook server. Default: 3978. */
|
|
port?: number;
|
|
/** Path for the messages endpoint. Default: /api/messages. */
|
|
path?: string;
|
|
};
|
|
|
|
/** Reply style for MS Teams messages. */
|
|
export type MSTeamsReplyStyle = "thread" | "top-level";
|
|
|
|
/** Channel-level config for MS Teams. */
|
|
export type MSTeamsChannelConfig = {
|
|
/** Require @mention to respond. Default: true. */
|
|
requireMention?: boolean;
|
|
/** Optional tool policy overrides for this channel. */
|
|
tools?: GroupToolPolicyConfig;
|
|
toolsBySender?: GroupToolPolicyBySenderConfig;
|
|
/** Reply style: "thread" replies to the message, "top-level" posts a new message. */
|
|
replyStyle?: MSTeamsReplyStyle;
|
|
};
|
|
|
|
/** Team-level config for MS Teams. */
|
|
export type MSTeamsTeamConfig = {
|
|
/** Default requireMention for channels in this team. */
|
|
requireMention?: boolean;
|
|
/** Default tool policy for channels in this team. */
|
|
tools?: GroupToolPolicyConfig;
|
|
toolsBySender?: GroupToolPolicyBySenderConfig;
|
|
/** Default reply style for channels in this team. */
|
|
replyStyle?: MSTeamsReplyStyle;
|
|
/** Per-channel overrides. Key is conversation ID (e.g., "19:...@thread.tacv2"). */
|
|
channels?: Record<string, MSTeamsChannelConfig>;
|
|
};
|
|
|
|
export type MSTeamsConfig = {
|
|
/** If false, do not start the MS Teams provider. Default: true. */
|
|
enabled?: boolean;
|
|
/** Optional provider capability tags used for agent/runtime guidance. */
|
|
capabilities?: string[];
|
|
/** Markdown formatting overrides (tables). */
|
|
markdown?: MarkdownConfig;
|
|
/** Allow channel-initiated config writes (default: true). */
|
|
configWrites?: boolean;
|
|
/** Azure Bot App ID (from Azure Bot registration). */
|
|
appId?: string;
|
|
/** Azure Bot App Password / Client Secret. */
|
|
appPassword?: string;
|
|
/** Azure AD Tenant ID (for single-tenant bots). */
|
|
tenantId?: string;
|
|
/** Webhook server configuration. */
|
|
webhook?: MSTeamsWebhookConfig;
|
|
/** Direct message access policy (default: pairing). */
|
|
dmPolicy?: DmPolicy;
|
|
/** Allowlist for DM senders (AAD object IDs or UPNs). */
|
|
allowFrom?: Array<string>;
|
|
/** Optional allowlist for group/channel senders (AAD object IDs or UPNs). */
|
|
groupAllowFrom?: Array<string>;
|
|
/**
|
|
* Controls how group/channel messages are handled:
|
|
* - "open": groups bypass allowFrom; mention-gating applies
|
|
* - "disabled": block all group messages
|
|
* - "allowlist": only allow group messages from senders in groupAllowFrom/allowFrom
|
|
*/
|
|
groupPolicy?: GroupPolicy;
|
|
/** Outbound text chunk size (chars). Default: 4000. */
|
|
textChunkLimit?: number;
|
|
/** Chunking mode: "length" (default) splits by size; "newline" splits on every newline. */
|
|
chunkMode?: "length" | "newline";
|
|
/** Merge streamed block replies before sending. */
|
|
blockStreamingCoalesce?: BlockStreamingCoalesceConfig;
|
|
/**
|
|
* Allowed host suffixes for inbound attachment downloads.
|
|
* Use ["*"] to allow any host (not recommended).
|
|
*/
|
|
mediaAllowHosts?: Array<string>;
|
|
/**
|
|
* Allowed host suffixes for attaching Authorization headers to inbound media retries.
|
|
* Use specific hosts only; avoid multi-tenant suffixes.
|
|
*/
|
|
mediaAuthAllowHosts?: Array<string>;
|
|
/** Default: require @mention to respond in channels/groups. */
|
|
requireMention?: boolean;
|
|
/** Max group/channel messages to keep as history context (0 disables). */
|
|
historyLimit?: number;
|
|
/** Max DM turns to keep as history context. */
|
|
dmHistoryLimit?: number;
|
|
/** Per-DM config overrides keyed by user ID. */
|
|
dms?: Record<string, DmConfig>;
|
|
/** Default reply style: "thread" replies to the message, "top-level" posts a new message. */
|
|
replyStyle?: MSTeamsReplyStyle;
|
|
/** Per-team config. Key is team ID (from the /team/ URL path segment). */
|
|
teams?: Record<string, MSTeamsTeamConfig>;
|
|
/** Max media size in MB (default: 100MB for OneDrive upload support). */
|
|
mediaMaxMb?: number;
|
|
/** SharePoint site ID for file uploads in group chats/channels (e.g., "contoso.sharepoint.com,guid1,guid2"). */
|
|
sharePointSiteId?: string;
|
|
/** Heartbeat visibility settings for this channel. */
|
|
heartbeat?: ChannelHeartbeatVisibilityConfig;
|
|
/** Outbound response prefix override for this channel/account. */
|
|
responsePrefix?: string;
|
|
};
|