mirror of https://github.com/openclaw/openclaw.git
72 lines
2.1 KiB
TypeScript
72 lines
2.1 KiB
TypeScript
import { Type } from "@sinclair/typebox";
|
|
import type { ChannelAgentTool } from "openclaw/plugin-sdk/channel-runtime";
|
|
|
|
export function createRuntimeWhatsAppLoginTool(): ChannelAgentTool {
|
|
return {
|
|
label: "WhatsApp Login",
|
|
name: "whatsapp_login",
|
|
ownerOnly: true,
|
|
description: "Generate a WhatsApp QR code for linking, or wait for the scan to complete.",
|
|
parameters: Type.Object({
|
|
action: Type.Unsafe<"start" | "wait">({
|
|
type: "string",
|
|
enum: ["start", "wait"],
|
|
}),
|
|
timeoutMs: Type.Optional(Type.Number()),
|
|
force: Type.Optional(Type.Boolean()),
|
|
}),
|
|
execute: async (_toolCallId, args) => {
|
|
const { startWebLoginWithQr, waitForWebLogin } =
|
|
await import("../../../extensions/whatsapp/src/login-qr.js");
|
|
const action = (args as { action?: string })?.action ?? "start";
|
|
if (action === "wait") {
|
|
const result = await waitForWebLogin({
|
|
timeoutMs:
|
|
typeof (args as { timeoutMs?: unknown }).timeoutMs === "number"
|
|
? (args as { timeoutMs?: number }).timeoutMs
|
|
: undefined,
|
|
});
|
|
return {
|
|
content: [{ type: "text", text: result.message }],
|
|
details: { connected: result.connected },
|
|
};
|
|
}
|
|
|
|
const result = await startWebLoginWithQr({
|
|
timeoutMs:
|
|
typeof (args as { timeoutMs?: unknown }).timeoutMs === "number"
|
|
? (args as { timeoutMs?: number }).timeoutMs
|
|
: undefined,
|
|
force:
|
|
typeof (args as { force?: unknown }).force === "boolean"
|
|
? (args as { force?: boolean }).force
|
|
: false,
|
|
});
|
|
|
|
if (!result.qrDataUrl) {
|
|
return {
|
|
content: [
|
|
{
|
|
type: "text",
|
|
text: result.message,
|
|
},
|
|
],
|
|
details: { qr: false },
|
|
};
|
|
}
|
|
|
|
const text = [
|
|
result.message,
|
|
"",
|
|
"Open WhatsApp -> Linked Devices and scan:",
|
|
"",
|
|
``,
|
|
].join("\n");
|
|
return {
|
|
content: [{ type: "text", text }],
|
|
details: { qr: true },
|
|
};
|
|
},
|
|
};
|
|
}
|