mirror of
https://github.com/openclaw/openclaw.git
synced 2026-06-03 17:14:06 +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
66 lines
1.8 KiB
TypeScript
66 lines
1.8 KiB
TypeScript
import { isRecord as isJsonObject } from "../shared/record-coerce.js";
|
|
|
|
function failOrUndefined(params: { onMissing: "throw" | "undefined"; message: string }): undefined {
|
|
if (params.onMissing === "throw") {
|
|
throw new Error(params.message);
|
|
}
|
|
return undefined;
|
|
}
|
|
|
|
function decodeJsonPointerToken(token: string): string {
|
|
return token.replace(/~1/g, "/").replace(/~0/g, "~");
|
|
}
|
|
|
|
export function encodeJsonPointerToken(token: string): string {
|
|
return token.replace(/~/g, "~0").replace(/\//g, "~1");
|
|
}
|
|
|
|
export function readJsonPointer(
|
|
root: unknown,
|
|
pointer: string,
|
|
options: { onMissing?: "throw" | "undefined" } = {},
|
|
): unknown {
|
|
const onMissing = options.onMissing ?? "throw";
|
|
if (!pointer.startsWith("/")) {
|
|
return failOrUndefined({
|
|
onMissing,
|
|
message:
|
|
'File-backed secret ids must be absolute JSON pointers (for example: "/providers/openai/apiKey").',
|
|
});
|
|
}
|
|
|
|
const tokens = pointer
|
|
.slice(1)
|
|
.split("/")
|
|
.map((token) => decodeJsonPointerToken(token));
|
|
|
|
let current: unknown = root;
|
|
for (const token of tokens) {
|
|
if (Array.isArray(current)) {
|
|
const index = Number.parseInt(token, 10);
|
|
if (!Number.isFinite(index) || index < 0 || index >= current.length) {
|
|
return failOrUndefined({
|
|
onMissing,
|
|
message: `JSON pointer segment "${token}" is out of bounds.`,
|
|
});
|
|
}
|
|
current = current[index];
|
|
continue;
|
|
}
|
|
if (!isJsonObject(current)) {
|
|
return failOrUndefined({
|
|
onMissing,
|
|
message: `JSON pointer segment "${token}" does not exist.`,
|
|
});
|
|
}
|
|
if (!Object.hasOwn(current, token)) {
|
|
return failOrUndefined({
|
|
onMissing,
|
|
message: `JSON pointer segment "${token}" does not exist.`,
|
|
});
|
|
}
|
|
current = current[token];
|
|
}
|
|
return current;
|
|
}
|