mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-17 17:10:53 +00:00
* refactor: extract filesystem safety primitives * refactor: use fs-safe for file access helpers * refactor: reuse fs-safe for media reads * refactor: use fs-safe for image reads * refactor: reuse fs-safe in qqbot media opener * refactor: reuse fs-safe for local media checks * refactor: consume cleaner fs-safe api * refactor: align fs-safe json option names * fix: preserve fs-safe migration contracts * refactor: use fs-safe primitive subpaths * refactor: use grouped fs-safe subpaths * refactor: align fs-safe api usage * refactor: adapt private state store api * chore: refresh proof gate * refactor: follow fs-safe json api split * refactor: follow reduced fs-safe surface * build: default fs-safe python helper off * fix: preserve fs-safe plugin sdk aliases * refactor: consolidate fs-safe usage * refactor: unify fs-safe store usage * refactor: trim fs-safe temp workspace usage * refactor: hide low-level fs-safe primitives * build: use published fs-safe package * fix: preserve outbound recovery durability after rebase * chore: refresh pr checks
30 lines
753 B
TypeScript
30 lines
753 B
TypeScript
import "./fs-safe-defaults.js";
|
|
export {
|
|
assertCanonicalPathWithinBase,
|
|
resolveSafeInstallDir,
|
|
safeDirName,
|
|
safePathSegmentHashed,
|
|
} from "@openclaw/fs-safe/advanced";
|
|
|
|
export function unscopedPackageName(name: string): string {
|
|
const trimmed = name.trim();
|
|
if (!trimmed) {
|
|
return trimmed;
|
|
}
|
|
return trimmed.includes("/") ? (trimmed.split("/").pop() ?? trimmed) : trimmed;
|
|
}
|
|
|
|
export function packageNameMatchesId(packageName: string, id: string): boolean {
|
|
const trimmedId = id.trim();
|
|
if (!trimmedId) {
|
|
return false;
|
|
}
|
|
|
|
const trimmedPackageName = packageName.trim();
|
|
if (!trimmedPackageName) {
|
|
return false;
|
|
}
|
|
|
|
return trimmedId === trimmedPackageName || trimmedId === unscopedPackageName(trimmedPackageName);
|
|
}
|