Files
opencode-antigravity-auth/script/build-schema.ts
Noe 9fd7c40533 fix: sync JSON schema with Zod schema, add missing properties (#422)
The JSON schema (with additionalProperties: false) was missing 8 properties
present in the Zod config schema, causing IDE validation errors for valid
config keys: scheduling_mode, max_cache_first_wait_seconds,
failure_ttl_seconds, toast_scope, request_jitter_max_ms,
soft_quota_threshold_percent, quota_refresh_interval_minutes,
soft_quota_cache_ttl_minutes.

Also adds descriptions for quota_fallback, cli_first, and all new properties
to the build script so they survive future regenerations.
2026-02-11 11:59:02 +00:00

110 lines
5.4 KiB
TypeScript

import { writeFileSync, mkdirSync } from "node:fs";
import { dirname, join } from "node:path";
import { fileURLToPath } from "node:url";
import { AntigravityConfigSchema } from "../src/plugin/config/schema.js";
const __dirname = dirname(fileURLToPath(import.meta.url));
const outputPath = join(__dirname, "../assets/antigravity.schema.json");
// Use zod v4's built-in toJSONSchema method
const rawSchema = AntigravityConfigSchema.toJSONSchema({
unrepresentable: "any",
override: (_ctx) => undefined // Use default handling
}) as Record<string, unknown>;
// Remove the "required" array since all fields have defaults and are optional
// This preserves backwards compatibility with the draft-07 schema behavior
delete rawSchema.required;
const envVarDescriptions: Record<string, string> = {
quiet_mode:
"Suppress most toast notifications (rate limit, account switching). Recovery toasts always shown. Env: OPENCODE_ANTIGRAVITY_QUIET=1",
debug:
"Enable debug logging to file. Env: OPENCODE_ANTIGRAVITY_DEBUG=1 (or =2 for verbose)",
log_dir:
"Custom directory for debug logs. Env: OPENCODE_ANTIGRAVITY_LOG_DIR=/path/to/logs",
keep_thinking:
"Preserve thinking blocks for Claude models using signature caching. May cause signature errors. Env: OPENCODE_ANTIGRAVITY_KEEP_THINKING=1",
session_recovery:
"Enable automatic session recovery from tool_result_missing errors. Env: OPENCODE_ANTIGRAVITY_SESSION_RECOVERY=1",
auto_resume:
"Automatically send resume prompt after successful recovery. Env: OPENCODE_ANTIGRAVITY_AUTO_RESUME=1",
resume_text:
"Custom text to send when auto-resuming after recovery. Env: OPENCODE_ANTIGRAVITY_RESUME_TEXT=continue",
empty_response_max_attempts:
"Maximum retry attempts when Antigravity returns an empty response (no candidates).",
empty_response_retry_delay_ms:
"Delay in milliseconds between empty response retries.",
tool_id_recovery:
"Enable tool ID orphan recovery. Matches mismatched tool responses by function name or creates placeholders.",
claude_tool_hardening:
"Enable tool hallucination prevention for Claude models. Injects parameter signatures and strict usage rules.",
proactive_token_refresh:
"Enable proactive background token refresh before expiry, ensuring requests never block.",
proactive_refresh_buffer_seconds:
"Seconds before token expiry to trigger proactive refresh.",
proactive_refresh_check_interval_seconds:
"Interval between proactive refresh checks in seconds.",
auto_update: "Enable automatic plugin updates. Env: OPENCODE_ANTIGRAVITY_AUTO_UPDATE=1",
quota_fallback:
"Deprecated: accepted for backward compatibility but ignored at runtime. Gemini fallback between Antigravity and Gemini CLI is always enabled.",
cli_first:
"Prefer gemini-cli routing before Antigravity for Gemini models. When false (default), Antigravity is tried first and gemini-cli is fallback.",
toast_scope:
"Controls which sessions show toast notifications. 'root_only' (default) shows in root session only, 'all' shows in all sessions.",
scheduling_mode:
"Rate limit scheduling strategy. 'cache_first' (default) waits for cooldowns, 'balance' distributes across accounts, 'performance_first' picks fastest available.",
max_cache_first_wait_seconds:
"Maximum seconds to wait for a rate-limited account in cache_first mode before switching.",
failure_ttl_seconds:
"Time in seconds before a failed account is eligible for retry.",
request_jitter_max_ms:
"Maximum random jitter in milliseconds added to outgoing requests to avoid thundering herd.",
soft_quota_threshold_percent:
"Percentage of quota usage that triggers soft quota warnings and preemptive account switching.",
quota_refresh_interval_minutes:
"Interval in minutes between quota usage checks. Set to 0 to disable periodic checks.",
soft_quota_cache_ttl_minutes:
"TTL for cached soft quota data. 'auto' (default) calculates from refresh interval, or set a fixed number of minutes.",
};
const signatureCacheDescriptions: Record<string, string> = {
enabled: "Enable disk caching of thinking block signatures.",
memory_ttl_seconds: "In-memory TTL in seconds.",
disk_ttl_seconds: "Disk TTL in seconds.",
write_interval_seconds: "Background write interval in seconds.",
};
function addDescriptions(schema: Record<string, unknown>): void {
const props = schema.properties as Record<string, Record<string, unknown>> | undefined;
if (!props) return;
for (const [key, prop] of Object.entries(props)) {
if (envVarDescriptions[key]) {
prop.description = envVarDescriptions[key];
}
if (key === "signature_cache" && prop.properties) {
const cacheProps = prop.properties as Record<string, Record<string, unknown>>;
for (const [cacheKey, cacheProp] of Object.entries(cacheProps)) {
if (signatureCacheDescriptions[cacheKey]) {
cacheProp.description = signatureCacheDescriptions[cacheKey];
}
}
prop.description = "Signature cache configuration for persisting thinking block signatures. Only used when keep_thinking is enabled.";
}
}
}
const definitions = rawSchema.definitions as Record<string, Record<string, unknown>> | undefined;
if (definitions?.AntigravityConfig) {
addDescriptions(definitions.AntigravityConfig);
} else {
addDescriptions(rawSchema);
}
mkdirSync(dirname(outputPath), { recursive: true });
writeFileSync(outputPath, JSON.stringify(rawSchema, null, 2) + "\n");
console.log(`Schema written to ${outputPath}`);