Files
2026-05-02 15:12:14 +01:00

121 lines
3.8 KiB
TypeScript

import {
definePluginEntry,
type AnyAgentTool,
type OpenClawPluginNodeHostCommand,
} from "openclaw/plugin-sdk/plugin-entry";
import { createFileTransferNodeInvokePolicy } from "./src/shared/node-invoke-policy.js";
import {
DIR_FETCH_TOOL_DESCRIPTOR,
DIR_LIST_TOOL_DESCRIPTOR,
FILE_FETCH_TOOL_DESCRIPTOR,
FILE_WRITE_TOOL_DESCRIPTOR,
} from "./src/tools/descriptors.js";
type FileTransferToolDescriptor = Pick<
AnyAgentTool,
"label" | "name" | "description" | "parameters"
>;
function readNodeCommandParams(paramsJSON: string | null | undefined): unknown {
return paramsJSON ? JSON.parse(paramsJSON) : {};
}
function createLazyTool(
descriptor: FileTransferToolDescriptor,
loadTool: () => Promise<AnyAgentTool>,
): AnyAgentTool {
let toolPromise: Promise<AnyAgentTool> | undefined;
const loadOnce = () => {
toolPromise ??= loadTool();
return toolPromise;
};
return {
...descriptor,
async execute(toolCallId, args, signal, onUpdate) {
const tool = await loadOnce();
return await tool.execute(toolCallId, args, signal, onUpdate);
},
};
}
const fileTransferNodeHostCommands: OpenClawPluginNodeHostCommand[] = [
{
command: "file.fetch",
cap: "file",
dangerous: true,
handle: async (paramsJSON) => {
const { handleFileFetch } = await import("./src/node-host/file-fetch.js");
const params = readNodeCommandParams(paramsJSON) as Parameters<typeof handleFileFetch>[0];
const result = await handleFileFetch(params);
return JSON.stringify(result);
},
},
{
command: "dir.list",
cap: "file",
dangerous: true,
handle: async (paramsJSON) => {
const { handleDirList } = await import("./src/node-host/dir-list.js");
const params = readNodeCommandParams(paramsJSON) as Parameters<typeof handleDirList>[0];
const result = await handleDirList(params);
return JSON.stringify(result);
},
},
{
command: "dir.fetch",
cap: "file",
dangerous: true,
handle: async (paramsJSON) => {
const { handleDirFetch } = await import("./src/node-host/dir-fetch.js");
const params = readNodeCommandParams(paramsJSON) as Parameters<typeof handleDirFetch>[0];
const result = await handleDirFetch(params);
return JSON.stringify(result);
},
},
{
command: "file.write",
cap: "file",
dangerous: true,
handle: async (paramsJSON) => {
const { handleFileWrite } = await import("./src/node-host/file-write.js");
const params = readNodeCommandParams(paramsJSON) as Parameters<typeof handleFileWrite>[0];
const result = await handleFileWrite(params);
return JSON.stringify(result);
},
},
];
export default definePluginEntry({
id: "file-transfer",
name: "File Transfer",
description: "Fetch, list, and write files on paired nodes via dedicated node commands.",
nodeHostCommands: fileTransferNodeHostCommands,
register(api) {
api.registerNodeInvokePolicy(createFileTransferNodeInvokePolicy());
api.registerTool(
createLazyTool(FILE_FETCH_TOOL_DESCRIPTOR, async () => {
const { createFileFetchTool } = await import("./src/tools/file-fetch-tool.js");
return createFileFetchTool();
}),
);
api.registerTool(
createLazyTool(DIR_LIST_TOOL_DESCRIPTOR, async () => {
const { createDirListTool } = await import("./src/tools/dir-list-tool.js");
return createDirListTool();
}),
);
api.registerTool(
createLazyTool(DIR_FETCH_TOOL_DESCRIPTOR, async () => {
const { createDirFetchTool } = await import("./src/tools/dir-fetch-tool.js");
return createDirFetchTool();
}),
);
api.registerTool(
createLazyTool(FILE_WRITE_TOOL_DESCRIPTOR, async () => {
const { createFileWriteTool } = await import("./src/tools/file-write-tool.js");
return createFileWriteTool();
}),
);
},
});