mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-30 11:41:04 +00:00
* refactor: share talk event metric extraction * refactor: reuse shared coercion helpers * refactor: reuse shared primitive guards * refactor: reuse shared record guard * refactor: reuse shared primitive helpers * refactor: reuse shared string guards * refactor: reuse shared non-empty string guard * refactor: share plugin primitive coercion helpers * refactor: reuse plugin coercion helpers * refactor: reuse plugin coercion helpers in more plugins * refactor: reuse channel coercion helpers * refactor: reuse monitor coercion helpers * refactor: reuse provider coercion helpers * refactor: reuse core coercion helpers * refactor: reuse runtime coercion helpers * refactor: reuse helper coercion in codex paths * refactor: reuse helper coercion in runtime paths * refactor: reuse codex app-server coercion helpers * refactor: reuse codex record helpers * refactor: reuse migration and qa record helpers * refactor: reuse feishu and core helper guards * refactor: reuse browser and policy coercion helpers * refactor: reuse memory wiki record helper * refactor: share boolean coercion helpers * refactor: reuse finite number coercion * refactor: reuse trimmed string list helpers * refactor: reuse string list normalization * refactor: reuse remaining string list helpers * refactor: reuse string entry normalizer * refactor: share sorted string helpers * refactor: share string list normalization * test: preserve command registry browser imports * refactor: reuse trimmed list helpers * refactor: reuse string dedupe helpers * refactor: reuse local dedupe helpers * refactor: reuse more string dedupe helpers * refactor: reuse command string dedupe helpers * refactor: dedupe memory path lists with helper * refactor: expose string dedupe helpers to plugins * refactor: reuse core string dedupe helpers * refactor: reuse shared unique value helpers * refactor: reuse unique helpers in agent utilities * refactor: reuse unique helpers in config plumbing * refactor: reuse unique helpers in extensions * refactor: reuse unique helpers in core utilities * refactor: reuse unique helpers in qa plugins * refactor: reuse unique helpers in memory plugins * refactor: reuse unique helpers in channel plugins * refactor: reuse unique helpers in core tails * refactor: reuse unique helper in comfy workflow * refactor: reuse unique helpers in test utilities * refactor: expose unique value helper to plugins * refactor: reuse unique helpers for numeric lists * refactor: replace index dedupe filters * refactor: reuse string entry normalization * refactor: reuse string normalization in plugin helpers * refactor: reuse string normalization in extension helpers * refactor: reuse string normalization in channel parsers * refactor: reuse string normalization in memory search * refactor: reuse string normalization in provider parsers * refactor: reuse string normalization in qa helpers * refactor: reuse string normalization in infra parsers * refactor: reuse string normalization in messaging parsers * refactor: reuse string normalization in core parsers * refactor: reuse string normalization in extension parsers * refactor: reuse string normalization in remaining parsers * refactor: reuse string normalization in final parser spots * refactor: reuse string normalization in qa media helpers * refactor: reuse normalization in provider and media lists * refactor: reuse normalization for remaining set filters * refactor: reuse normalization in policy allowlists * refactor: reuse normalization in session and owner lists * refactor: centralize primitive string lists * refactor: reuse lowercase entry helpers * refactor: reuse sorted string helpers * refactor: reuse unique trimmed helpers * refactor: reuse string normalization helpers * refactor: reuse catalog string helpers * refactor: reuse remaining string helpers * refactor: simplify remaining list normalization * refactor: reuse codex auth order normalization * chore: refresh plugin sdk api baseline * fix: make shared string sorting deterministic * chore: refresh plugin sdk api baseline * fix: align host env security ordering
111 lines
3.2 KiB
TypeScript
111 lines
3.2 KiB
TypeScript
import {
|
|
normalizeLowercaseStringOrEmpty,
|
|
normalizeOptionalLowercaseString,
|
|
normalizeStringEntriesLower,
|
|
} from "openclaw/plugin-sdk/string-coerce-runtime";
|
|
import { hasIrcControlChars } from "./control-chars.js";
|
|
import type { IrcInboundMessage } from "./types.js";
|
|
|
|
const IRC_TARGET_PATTERN = /^[^\s:]+$/u;
|
|
|
|
export function isChannelTarget(target: string): boolean {
|
|
return target.startsWith("#") || target.startsWith("&");
|
|
}
|
|
|
|
export function normalizeIrcMessagingTarget(raw: string): string | undefined {
|
|
const trimmed = raw.trim();
|
|
if (!trimmed) {
|
|
return undefined;
|
|
}
|
|
let target = trimmed;
|
|
const lowered = normalizeLowercaseStringOrEmpty(target);
|
|
if (lowered.startsWith("irc:")) {
|
|
target = target.slice("irc:".length).trim();
|
|
}
|
|
if (normalizeLowercaseStringOrEmpty(target).startsWith("channel:")) {
|
|
target = target.slice("channel:".length).trim();
|
|
if (!target.startsWith("#") && !target.startsWith("&")) {
|
|
target = `#${target}`;
|
|
}
|
|
}
|
|
if (normalizeLowercaseStringOrEmpty(target).startsWith("user:")) {
|
|
target = target.slice("user:".length).trim();
|
|
}
|
|
if (!target || !looksLikeIrcTargetId(target)) {
|
|
return undefined;
|
|
}
|
|
return target;
|
|
}
|
|
|
|
export function looksLikeIrcTargetId(raw: string): boolean {
|
|
const trimmed = raw.trim();
|
|
if (!trimmed) {
|
|
return false;
|
|
}
|
|
if (hasIrcControlChars(trimmed)) {
|
|
return false;
|
|
}
|
|
return IRC_TARGET_PATTERN.test(trimmed);
|
|
}
|
|
|
|
export function normalizeIrcAllowEntry(raw: string): string {
|
|
let value = normalizeLowercaseStringOrEmpty(raw);
|
|
if (!value) {
|
|
return "";
|
|
}
|
|
if (value.startsWith("irc:")) {
|
|
value = value.slice("irc:".length);
|
|
}
|
|
if (value.startsWith("user:")) {
|
|
value = value.slice("user:".length);
|
|
}
|
|
return value.trim();
|
|
}
|
|
|
|
export function normalizeIrcAllowlist(entries?: Array<string | number>): string[] {
|
|
return (entries ?? []).map((entry) => normalizeIrcAllowEntry(String(entry))).filter(Boolean);
|
|
}
|
|
|
|
export function buildIrcAllowlistCandidates(
|
|
message: IrcInboundMessage,
|
|
params?: { allowNameMatching?: boolean },
|
|
): string[] {
|
|
const nick = normalizeLowercaseStringOrEmpty(message.senderNick);
|
|
const user = normalizeOptionalLowercaseString(message.senderUser);
|
|
const host = normalizeOptionalLowercaseString(message.senderHost);
|
|
const candidates = new Set<string>();
|
|
if (nick && params?.allowNameMatching === true) {
|
|
candidates.add(nick);
|
|
}
|
|
if (nick && user) {
|
|
candidates.add(`${nick}!${user}`);
|
|
}
|
|
if (nick && host) {
|
|
candidates.add(`${nick}@${host}`);
|
|
}
|
|
if (nick && user && host) {
|
|
candidates.add(`${nick}!${user}@${host}`);
|
|
}
|
|
return [...candidates];
|
|
}
|
|
|
|
export function resolveIrcAllowlistMatch(params: {
|
|
allowFrom: string[];
|
|
message: IrcInboundMessage;
|
|
allowNameMatching?: boolean;
|
|
}): { allowed: boolean; source?: string } {
|
|
const allowFrom = new Set(normalizeStringEntriesLower(params.allowFrom));
|
|
if (allowFrom.has("*")) {
|
|
return { allowed: true, source: "wildcard" };
|
|
}
|
|
const candidates = buildIrcAllowlistCandidates(params.message, {
|
|
allowNameMatching: params.allowNameMatching,
|
|
});
|
|
for (const candidate of candidates) {
|
|
if (allowFrom.has(candidate)) {
|
|
return { allowed: true, source: candidate };
|
|
}
|
|
}
|
|
return { allowed: false };
|
|
}
|