|
|
|
|
@@ -45,17 +45,41 @@ function runOpenclaw(args, { allowFail = false } = {}) {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function validateNoReplyModelAvailable() {
|
|
|
|
|
const modelRef = `${NO_REPLY_PROVIDER_ID}/${NO_REPLY_MODEL_ID}`;
|
|
|
|
|
const list = runOpenclaw(["models", "list"], { allowFail: true }) || "";
|
|
|
|
|
if (!list.includes(modelRef)) {
|
|
|
|
|
throw new Error(`post-install validation failed: model not listed: ${modelRef}`);
|
|
|
|
|
function sleep(ms) {
|
|
|
|
|
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const status = runOpenclaw(["models", "status", "--json"], { allowFail: true }) || "";
|
|
|
|
|
if (!status.includes(NO_REPLY_PROVIDER_ID)) {
|
|
|
|
|
throw new Error(`post-install validation failed: provider not visible in models status: ${NO_REPLY_PROVIDER_ID}`);
|
|
|
|
|
async function waitForGatewayReady(maxWaitMs = 30000) {
|
|
|
|
|
const start = Date.now();
|
|
|
|
|
const interval = 1500;
|
|
|
|
|
while (Date.now() - start < maxWaitMs) {
|
|
|
|
|
const probe = runOpenclaw(["gateway", "status"], { allowFail: true }) || "";
|
|
|
|
|
if (probe.includes("RPC probe: ok")) return true;
|
|
|
|
|
console.log(`[whispergate] waiting for gateway ready... (${Math.round((Date.now() - start) / 1000)}s)`);
|
|
|
|
|
await sleep(interval);
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function validateNoReplyModelAvailable(retries = 5, delayMs = 2000) {
|
|
|
|
|
const modelRef = `${NO_REPLY_PROVIDER_ID}/${NO_REPLY_MODEL_ID}`;
|
|
|
|
|
|
|
|
|
|
for (let attempt = 1; attempt <= retries; attempt++) {
|
|
|
|
|
const list = runOpenclaw(["models", "list"], { allowFail: true }) || "";
|
|
|
|
|
if (list.includes(modelRef)) {
|
|
|
|
|
const status = runOpenclaw(["models", "status", "--json"], { allowFail: true }) || "";
|
|
|
|
|
if (status.includes(NO_REPLY_PROVIDER_ID)) {
|
|
|
|
|
console.log(`[whispergate] model validation passed on attempt ${attempt}`);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (attempt < retries) {
|
|
|
|
|
console.log(`[whispergate] model not yet visible (attempt ${attempt}/${retries}), retrying in ${delayMs}ms...`);
|
|
|
|
|
await sleep(delayMs);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
throw new Error(`post-install validation failed: model not listed after ${retries} attempts: ${modelRef}`);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getJson(pathKey) {
|
|
|
|
|
@@ -175,7 +199,13 @@ if (mode === "install") {
|
|
|
|
|
setJson(PATH_PROVIDERS, providers);
|
|
|
|
|
|
|
|
|
|
runOpenclaw(["gateway", "restart"]);
|
|
|
|
|
validateNoReplyModelAvailable();
|
|
|
|
|
console.log("[whispergate] gateway restart issued, waiting for ready...");
|
|
|
|
|
const ready = await waitForGatewayReady();
|
|
|
|
|
if (!ready) {
|
|
|
|
|
throw new Error("gateway did not become ready within 30s after restart");
|
|
|
|
|
}
|
|
|
|
|
console.log("[whispergate] gateway ready, validating model...");
|
|
|
|
|
await validateNoReplyModelAvailable();
|
|
|
|
|
|
|
|
|
|
const after = {
|
|
|
|
|
[PATH_PLUGINS_LOAD]: getJson(PATH_PLUGINS_LOAD),
|
|
|
|
|
|