mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-29 17:35:13 +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
127 lines
4.2 KiB
TypeScript
127 lines
4.2 KiB
TypeScript
import { isAllowedParsedChatSender as isAllowedParsedChatSenderShared } from "../channels/plugins/chat-target-prefixes.js";
|
|
import { normalizeOptionalLowercaseString } from "../shared/string-coerce.js";
|
|
import { normalizeStringEntries } from "../shared/string-normalization.js";
|
|
|
|
export type {
|
|
AllowlistMatch,
|
|
AllowlistMatchSource,
|
|
CompiledAllowlist,
|
|
} from "../channels/allowlist-match.js";
|
|
export type { AllowlistUserResolutionLike } from "../channels/allowlists/resolve-utils.js";
|
|
export {
|
|
compileAllowlist,
|
|
formatAllowlistMatchMeta,
|
|
resolveAllowlistCandidates,
|
|
resolveAllowlistMatchByCandidates,
|
|
resolveAllowlistMatchSimple,
|
|
resolveCompiledAllowlistMatch,
|
|
} from "../channels/allowlist-match.js";
|
|
export {
|
|
firstDefined,
|
|
isSenderIdAllowed,
|
|
mergeDmAllowFromSources,
|
|
resolveGroupAllowFromSources,
|
|
} from "../channels/allow-from.js";
|
|
export {
|
|
addAllowlistUserEntriesFromConfigEntry,
|
|
buildAllowlistResolutionSummary,
|
|
canonicalizeAllowlistWithResolvedIds,
|
|
mergeAllowlist,
|
|
patchAllowlistUsersInConfigEntries,
|
|
summarizeMapping,
|
|
} from "../channels/allowlists/resolve-utils.js";
|
|
|
|
/** Lowercase and optionally strip prefixes from allowlist entries before sender comparisons. */
|
|
export function formatAllowFromLowercase(params: {
|
|
allowFrom: Array<string | number>;
|
|
stripPrefixRe?: RegExp;
|
|
}): string[] {
|
|
return normalizeStringEntries(params.allowFrom)
|
|
.map((entry) => (params.stripPrefixRe ? entry.replace(params.stripPrefixRe, "") : entry))
|
|
.map((entry) => normalizeOptionalLowercaseString(entry))
|
|
.filter((entry): entry is string => Boolean(entry));
|
|
}
|
|
|
|
/** Normalize allowlist entries through a channel-provided parser or canonicalizer. */
|
|
export function formatNormalizedAllowFromEntries(params: {
|
|
allowFrom: Array<string | number>;
|
|
normalizeEntry: (entry: string) => string | undefined | null;
|
|
}): string[] {
|
|
return normalizeStringEntries(params.allowFrom)
|
|
.map((entry) => params.normalizeEntry(entry))
|
|
.filter((entry): entry is string => Boolean(entry));
|
|
}
|
|
|
|
/** Check whether a sender id matches a simple normalized allowlist with wildcard support. */
|
|
export function isNormalizedSenderAllowed(params: {
|
|
senderId: string | number;
|
|
allowFrom: Array<string | number>;
|
|
stripPrefixRe?: RegExp;
|
|
}): boolean {
|
|
const normalizedAllow = formatAllowFromLowercase({
|
|
allowFrom: params.allowFrom,
|
|
stripPrefixRe: params.stripPrefixRe,
|
|
});
|
|
if (normalizedAllow.length === 0) {
|
|
return false;
|
|
}
|
|
if (normalizedAllow.includes("*")) {
|
|
return true;
|
|
}
|
|
const sender = normalizeOptionalLowercaseString(String(params.senderId));
|
|
return sender ? normalizedAllow.includes(sender) : false;
|
|
}
|
|
|
|
type ParsedChatAllowTarget =
|
|
| { kind: "chat_id"; chatId: number }
|
|
| { kind: "chat_guid"; chatGuid: string }
|
|
| { kind: "chat_identifier"; chatIdentifier: string }
|
|
| { kind: "handle"; handle: string };
|
|
|
|
/** Match allowlist entries against senders, with conversation targets requiring explicit opt-in. */
|
|
export function isAllowedParsedChatSender(params: {
|
|
allowFrom: Array<string | number>;
|
|
sender: string;
|
|
chatId?: number | null;
|
|
chatGuid?: string | null;
|
|
chatIdentifier?: string | null;
|
|
allowConversationTargets?: boolean | null;
|
|
normalizeSender: (sender: string) => string;
|
|
parseAllowTarget: (entry: string) => ParsedChatAllowTarget;
|
|
}): boolean {
|
|
return isAllowedParsedChatSenderShared(params);
|
|
}
|
|
|
|
export type BasicAllowlistResolutionEntry = {
|
|
input: string;
|
|
resolved: boolean;
|
|
id?: string;
|
|
name?: string;
|
|
note?: string;
|
|
};
|
|
|
|
/** Clone allowlist resolution entries into a plain serializable shape for UI and docs output. */
|
|
export function mapBasicAllowlistResolutionEntries(
|
|
entries: BasicAllowlistResolutionEntry[],
|
|
): BasicAllowlistResolutionEntry[] {
|
|
return entries.map((entry) => ({
|
|
input: entry.input,
|
|
resolved: entry.resolved,
|
|
id: entry.id,
|
|
name: entry.name,
|
|
note: entry.note,
|
|
}));
|
|
}
|
|
|
|
/** Map allowlist inputs sequentially so resolver side effects stay ordered and predictable. */
|
|
export async function mapAllowlistResolutionInputs<T>(params: {
|
|
inputs: string[];
|
|
mapInput: (input: string) => Promise<T> | T;
|
|
}): Promise<T[]> {
|
|
const results: T[] = [];
|
|
for (const input of params.inputs) {
|
|
results.push(await params.mapInput(input));
|
|
}
|
|
return results;
|
|
}
|