refactor: compute base config schema at runtime

This commit is contained in:
Peter Steinberger
2026-05-05 19:55:32 +01:00
parent 7dc6007aee
commit 55d1cf87d7
9 changed files with 36 additions and 29535 deletions

View File

@@ -31,7 +31,6 @@ export const RELEASE_METADATA_PATHS = new Set([
"docs/.generated/config-baseline.sha256",
"docs/install/updating.md",
"package.json",
"src/config/schema.base.generated.ts",
]);
/** @typedef {"core" | "coreTests" | "extensions" | "extensionTests" | "apps" | "docs" | "tooling" | "liveDockerTooling" | "releaseMetadata" | "all"} ChangedLane */

View File

@@ -8,7 +8,6 @@ const VERSION_ONLY_TEXT_PATHS = new Set([
"apps/ios/Config/Version.xcconfig",
"apps/ios/version.json",
"apps/macos/Sources/OpenClaw/Resources/Info.plist",
"src/config/schema.base.generated.ts",
]);
function normalizePath(input) {

View File

@@ -1,85 +1,22 @@
#!/usr/bin/env node
import fs from "node:fs";
import path from "node:path";
import { fileURLToPath } from "node:url";
import { computeBaseConfigSchemaResponse } from "../src/config/schema-base.js";
import { formatGeneratedModule } from "./lib/format-generated-module.mjs";
const GENERATED_BY = "scripts/generate-base-config-schema.ts";
const DEFAULT_OUTPUT_PATH = "src/config/schema.base.generated.ts";
const REPO_ROOT = path.resolve(path.dirname(fileURLToPath(import.meta.url)), "..");
function readIfExists(filePath: string): string | null {
try {
return fs.readFileSync(filePath, "utf8");
} catch {
return null;
}
}
function formatTypeScriptModule(source: string, outputPath: string): string {
return formatGeneratedModule(source, {
repoRoot: REPO_ROOT,
outputPath,
errorLabel: "base config schema",
export function checkBaseConfigSchema(): void {
computeBaseConfigSchemaResponse({
generatedAt: "2026-05-05T00:00:00.000Z",
});
}
export function renderBaseConfigSchemaModule(params?: { generatedAt?: string }): string {
const payload = computeBaseConfigSchemaResponse({
generatedAt: params?.generatedAt ?? new Date().toISOString(),
});
return formatTypeScriptModule(
`// Auto-generated by ${GENERATED_BY}. Do not edit directly.
import type { BaseConfigSchemaResponse } from "./schema-base.js";
export const GENERATED_BASE_CONFIG_SCHEMA: BaseConfigSchemaResponse = ${JSON.stringify(payload, null, 2)};
`,
DEFAULT_OUTPUT_PATH,
);
}
export function writeBaseConfigSchemaModule(params?: {
repoRoot?: string;
outputPath?: string;
check?: boolean;
}): { changed: boolean; wrote: boolean; outputPath: string } {
const repoRoot = path.resolve(params?.repoRoot ?? REPO_ROOT);
const outputPath = path.resolve(repoRoot, params?.outputPath ?? DEFAULT_OUTPUT_PATH);
const current = readIfExists(outputPath);
const generatedAt =
current?.match(/generatedAt:\s*"([^"]+)"/u)?.[1] ??
current?.match(/"generatedAt":\s*"([^"]+)"/u)?.[1] ??
new Date().toISOString();
const next = renderBaseConfigSchemaModule({ generatedAt });
const changed = current !== next;
if (params?.check) {
return { changed, wrote: false, outputPath };
}
if (changed) {
fs.writeFileSync(outputPath, next, "utf8");
}
return { changed, wrote: changed, outputPath };
}
const args = new Set(process.argv.slice(2));
if (args.has("--check") && args.has("--write")) {
throw new Error("Use either --check or --write, not both.");
}
if (import.meta.url === new URL(process.argv[1] ?? "", "file://").href) {
const result = writeBaseConfigSchemaModule({ check: args.has("--check") });
if (result.changed) {
if (args.has("--check")) {
console.error(
`[base-config-schema] stale generated output at ${path.relative(process.cwd(), result.outputPath)}`,
);
process.exitCode = 1;
} else {
console.log(`[base-config-schema] wrote ${path.relative(process.cwd(), result.outputPath)}`);
}
checkBaseConfigSchema();
if (args.has("--write")) {
console.log("[base-config-schema] runtime-computed; no generated file to write");
} else {
console.log("[base-config-schema] ok");
}
}