Files
openclaw/src/cli/plugins-registry-refresh.ts
2026-04-28 18:03:01 +01:00

45 lines
1.8 KiB
TypeScript

import type { OpenClawConfig } from "../config/types.openclaw.js";
import { formatErrorMessage } from "../infra/errors.js";
import { loadInstalledPluginIndexInstallRecords } from "../plugins/installed-plugin-index-records.js";
import type { InstalledPluginIndexRefreshReason } from "../plugins/installed-plugin-index.js";
import { tracePluginLifecyclePhaseAsync } from "../plugins/plugin-lifecycle-trace.js";
import { refreshPluginRegistry } from "../plugins/plugin-registry.js";
export type PluginRegistryRefreshLogger = {
warn?: (message: string) => void;
};
export async function refreshPluginRegistryAfterConfigMutation(params: {
config: OpenClawConfig;
reason: InstalledPluginIndexRefreshReason;
workspaceDir?: string;
env?: NodeJS.ProcessEnv;
installRecords?: Awaited<ReturnType<typeof loadInstalledPluginIndexInstallRecords>>;
traceCommand?: string;
logger?: PluginRegistryRefreshLogger;
}): Promise<void> {
try {
const installRecords =
params.installRecords ??
(await tracePluginLifecyclePhaseAsync(
"install records load",
() => loadInstalledPluginIndexInstallRecords(params.env ? { env: params.env } : {}),
{ command: params.traceCommand ?? "registry-refresh" },
));
await tracePluginLifecyclePhaseAsync(
"registry refresh",
() =>
refreshPluginRegistry({
config: params.config,
reason: params.reason,
installRecords,
...(params.workspaceDir ? { workspaceDir: params.workspaceDir } : {}),
...(params.env ? { env: params.env } : {}),
}),
{ command: params.traceCommand ?? "registry-refresh", reason: params.reason },
);
} catch (error) {
params.logger?.warn?.(`Plugin registry refresh failed: ${formatErrorMessage(error)}`);
}
}