Files
openclaw/src/gateway/server-methods-list.ts
Peter Steinberger 85beee613c docs: clarify inline code comments
Comment-only follow-up documenting reusable gateway, auth, proxy, device, Talk, session, and agent helper contracts.\n\nVerification: git diff --check plus targeted tests recorded in PR body.
2026-05-31 14:37:41 +01:00

66 lines
2.0 KiB
TypeScript

import { listLoadedChannelPlugins } from "../channels/plugins/registry-loaded.js";
import { GATEWAY_EVENT_UPDATE_AVAILABLE } from "./events.js";
import { listCoreAdvertisedGatewayMethodNames } from "./methods/core-descriptors.js";
import { GATEWAY_AUX_METHODS } from "./server-aux-methods.js";
type GatewayMethodChannelPlugin = {
gatewayMethods?: readonly string[];
gatewayMethodDescriptors?: readonly { name: string }[];
};
/** Lists core methods intentionally advertised to gateway clients. */
export function listCoreGatewayMethods(): string[] {
return listCoreAdvertisedGatewayMethodNames();
}
function listChannelGatewayMethods(): string[] {
const methods: string[] = [];
for (const plugin of listLoadedChannelPlugins() as GatewayMethodChannelPlugin[]) {
// Plugins may still expose legacy names while newer plugins expose descriptors.
// Merge both so method discovery stays compatible during descriptor adoption.
methods.push(...(plugin.gatewayMethods ?? []));
for (const descriptor of plugin.gatewayMethodDescriptors ?? []) {
methods.push(descriptor.name);
}
}
return methods;
}
/** Returns the de-duplicated gateway method catalog advertised through method-list APIs. */
export function listGatewayMethods(): string[] {
return Array.from(
new Set([...listCoreGatewayMethods(), ...GATEWAY_AUX_METHODS, ...listChannelGatewayMethods()]),
);
}
/** Gateway event names that clients can subscribe to or receive over the wire. */
export const GATEWAY_EVENTS = [
"connect.challenge",
"agent",
"chat",
"session.message",
"session.operation",
"session.tool",
"sessions.changed",
"presence",
"tick",
"talk.mode",
"talk.event",
"shutdown",
"health",
"heartbeat",
"cron",
"node.pair.requested",
"node.pair.resolved",
"node.invoke.request",
"device.pair.requested",
"device.pair.resolved",
"voicewake.changed",
"voicewake.routing.changed",
"exec.approval.requested",
"exec.approval.resolved",
"plugin.approval.requested",
"plugin.approval.resolved",
GATEWAY_EVENT_UPDATE_AVAILABLE,
];