refactor(plugins): reuse plugin service runtime context

This commit is contained in:
Peter Steinberger
2026-02-18 17:22:20 +00:00
parent 64a10e64e4
commit 5ae4595bb9
2 changed files with 155 additions and 25 deletions

View File

@@ -2,9 +2,31 @@ import type { OpenClawConfig } from "../config/config.js";
import { STATE_DIR } from "../config/paths.js";
import { createSubsystemLogger } from "../logging/subsystem.js";
import type { PluginRegistry } from "./registry.js";
import type { OpenClawPluginServiceContext, PluginLogger } from "./types.js";
const log = createSubsystemLogger("plugins");
function createPluginLogger(): PluginLogger {
return {
info: (msg) => log.info(msg),
warn: (msg) => log.warn(msg),
error: (msg) => log.error(msg),
debug: (msg) => log.debug(msg),
};
}
function createServiceContext(params: {
config: OpenClawConfig;
workspaceDir?: string;
}): OpenClawPluginServiceContext {
return {
config: params.config,
workspaceDir: params.workspaceDir,
stateDir: STATE_DIR,
logger: createPluginLogger(),
};
}
export type PluginServicesHandle = {
stop: () => Promise<void>;
};
@@ -18,37 +40,18 @@ export async function startPluginServices(params: {
id: string;
stop?: () => void | Promise<void>;
}> = [];
const serviceContext = createServiceContext({
config: params.config,
workspaceDir: params.workspaceDir,
});
for (const entry of params.registry.services) {
const service = entry.service;
try {
await service.start({
config: params.config,
workspaceDir: params.workspaceDir,
stateDir: STATE_DIR,
logger: {
info: (msg) => log.info(msg),
warn: (msg) => log.warn(msg),
error: (msg) => log.error(msg),
debug: (msg) => log.debug(msg),
},
});
await service.start(serviceContext);
running.push({
id: service.id,
stop: service.stop
? () =>
service.stop?.({
config: params.config,
workspaceDir: params.workspaceDir,
stateDir: STATE_DIR,
logger: {
info: (msg) => log.info(msg),
warn: (msg) => log.warn(msg),
error: (msg) => log.error(msg),
debug: (msg) => log.debug(msg),
},
})
: undefined,
stop: service.stop ? () => service.stop?.(serviceContext) : undefined,
});
} catch (err) {
log.error(`plugin service failed (${service.id}): ${String(err)}`);