@junjiezhang/openclaw-wecom-plugin 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +227 -0
- package/dist/accounts.d.ts +19 -0
- package/dist/accounts.d.ts.map +1 -0
- package/dist/accounts.js +52 -0
- package/dist/accounts.js.map +1 -0
- package/dist/bot.d.ts +30 -0
- package/dist/bot.d.ts.map +1 -0
- package/dist/bot.js +290 -0
- package/dist/bot.js.map +1 -0
- package/dist/channel.d.ts +4 -0
- package/dist/channel.d.ts.map +1 -0
- package/dist/channel.js +254 -0
- package/dist/channel.js.map +1 -0
- package/dist/client.d.ts +7 -0
- package/dist/client.d.ts.map +1 -0
- package/dist/client.js +41 -0
- package/dist/client.js.map +1 -0
- package/dist/config-schema.d.ts +73 -0
- package/dist/config-schema.d.ts.map +1 -0
- package/dist/config-schema.js +79 -0
- package/dist/config-schema.js.map +1 -0
- package/dist/dedup.d.ts +3 -0
- package/dist/dedup.d.ts.map +1 -0
- package/dist/dedup.js +39 -0
- package/dist/dedup.js.map +1 -0
- package/dist/directory.d.ts +38 -0
- package/dist/directory.d.ts.map +1 -0
- package/dist/directory.js +66 -0
- package/dist/directory.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +16 -0
- package/dist/index.js.map +1 -0
- package/dist/media.d.ts +17 -0
- package/dist/media.d.ts.map +1 -0
- package/dist/media.js +64 -0
- package/dist/media.js.map +1 -0
- package/dist/monitor.d.ts +9 -0
- package/dist/monitor.d.ts.map +1 -0
- package/dist/monitor.js +233 -0
- package/dist/monitor.js.map +1 -0
- package/dist/outbound.d.ts +3 -0
- package/dist/outbound.d.ts.map +1 -0
- package/dist/outbound.js +24 -0
- package/dist/outbound.js.map +1 -0
- package/dist/policy.d.ts +29 -0
- package/dist/policy.d.ts.map +1 -0
- package/dist/policy.js +65 -0
- package/dist/policy.js.map +1 -0
- package/dist/probe.d.ts +6 -0
- package/dist/probe.d.ts.map +1 -0
- package/dist/probe.js +7 -0
- package/dist/probe.js.map +1 -0
- package/dist/reply-dispatcher.d.ts +16 -0
- package/dist/reply-dispatcher.d.ts.map +1 -0
- package/dist/reply-dispatcher.js +57 -0
- package/dist/reply-dispatcher.js.map +1 -0
- package/dist/runtime.d.ts +4 -0
- package/dist/runtime.d.ts.map +1 -0
- package/dist/runtime.js +11 -0
- package/dist/runtime.js.map +1 -0
- package/dist/send.d.ts +18 -0
- package/dist/send.d.ts.map +1 -0
- package/dist/send.js +61 -0
- package/dist/send.js.map +1 -0
- package/dist/targets.d.ts +4 -0
- package/dist/targets.d.ts.map +1 -0
- package/dist/targets.js +16 -0
- package/dist/targets.js.map +1 -0
- package/dist/types.d.ts +2 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/openclaw.plugin.json +12 -0
- package/package.json +64 -0
- package/src/accounts.ts +81 -0
- package/src/bot.ts +410 -0
- package/src/channel.ts +278 -0
- package/src/client.ts +55 -0
- package/src/config-schema.ts +102 -0
- package/src/dedup.ts +60 -0
- package/src/directory.ts +150 -0
- package/src/index.ts +20 -0
- package/src/media.ts +105 -0
- package/src/monitor.ts +344 -0
- package/src/outbound.ts +26 -0
- package/src/policy.ts +108 -0
- package/src/probe.ts +13 -0
- package/src/reply-dispatcher.ts +78 -0
- package/src/runtime.ts +14 -0
- package/src/send.ts +91 -0
- package/src/targets.ts +21 -0
- package/src/types.d.ts +17 -0
- package/src/types.ts +3 -0
- package/tsconfig.json +32 -0
- package/types.d.ts +43 -0
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { fetchWithSsrFGuard } from "openclaw/plugin-sdk";
|
|
2
|
+
import { getWeComAccessToken } from "./client.js";
|
|
3
|
+
const WECOM_API_POLICY = { allowedHostnames: ["qyapi.weixin.qq.com"] };
|
|
4
|
+
export async function getUserInfoWeCom({ cfg, userId, accountId, }) {
|
|
5
|
+
const accessToken = await getWeComAccessToken({ cfg, accountId });
|
|
6
|
+
const url = `https://qyapi.weixin.qq.com/cgi-bin/user/get?access_token=${accessToken}&userid=${userId}`;
|
|
7
|
+
const { response, release } = await fetchWithSsrFGuard({
|
|
8
|
+
url,
|
|
9
|
+
policy: WECOM_API_POLICY,
|
|
10
|
+
auditContext: "wecom-get-user-info",
|
|
11
|
+
});
|
|
12
|
+
let data;
|
|
13
|
+
try {
|
|
14
|
+
data = await response.json();
|
|
15
|
+
}
|
|
16
|
+
finally {
|
|
17
|
+
await release();
|
|
18
|
+
}
|
|
19
|
+
if (data.errcode !== 0) {
|
|
20
|
+
throw new Error(`Failed to get user info: ${data.errmsg}`);
|
|
21
|
+
}
|
|
22
|
+
return data;
|
|
23
|
+
}
|
|
24
|
+
export async function getDepartmentListWeCom({ cfg, departmentId, accountId, }) {
|
|
25
|
+
const accessToken = await getWeComAccessToken({ cfg, accountId });
|
|
26
|
+
const url = departmentId
|
|
27
|
+
? `https://qyapi.weixin.qq.com/cgi-bin/department/list?access_token=${accessToken}&id=${departmentId}`
|
|
28
|
+
: `https://qyapi.weixin.qq.com/cgi-bin/department/list?access_token=${accessToken}`;
|
|
29
|
+
const { response, release } = await fetchWithSsrFGuard({
|
|
30
|
+
url,
|
|
31
|
+
policy: WECOM_API_POLICY,
|
|
32
|
+
auditContext: "wecom-get-department-list",
|
|
33
|
+
});
|
|
34
|
+
let data;
|
|
35
|
+
try {
|
|
36
|
+
data = await response.json();
|
|
37
|
+
}
|
|
38
|
+
finally {
|
|
39
|
+
await release();
|
|
40
|
+
}
|
|
41
|
+
if (data.errcode !== 0) {
|
|
42
|
+
throw new Error(`Failed to get department list: ${data.errmsg}`);
|
|
43
|
+
}
|
|
44
|
+
return (data.department ?? []);
|
|
45
|
+
}
|
|
46
|
+
export async function getDepartmentUsersWeCom({ cfg, departmentId, fetchChild, accountId, }) {
|
|
47
|
+
const accessToken = await getWeComAccessToken({ cfg, accountId });
|
|
48
|
+
const url = `https://qyapi.weixin.qq.com/cgi-bin/user/simplelist?access_token=${accessToken}&department_id=${departmentId}&fetch_child=${fetchChild ? 1 : 0}`;
|
|
49
|
+
const { response, release } = await fetchWithSsrFGuard({
|
|
50
|
+
url,
|
|
51
|
+
policy: WECOM_API_POLICY,
|
|
52
|
+
auditContext: "wecom-get-department-users",
|
|
53
|
+
});
|
|
54
|
+
let data;
|
|
55
|
+
try {
|
|
56
|
+
data = await response.json();
|
|
57
|
+
}
|
|
58
|
+
finally {
|
|
59
|
+
await release();
|
|
60
|
+
}
|
|
61
|
+
if (data.errcode !== 0) {
|
|
62
|
+
throw new Error(`Failed to get department users: ${data.errmsg}`);
|
|
63
|
+
}
|
|
64
|
+
return (data.userlist ?? []);
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=directory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"directory.js","sourceRoot":"","sources":["../src/directory.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { OpenClawPluginApi } from "openclaw/plugin-sdk";
|
|
2
|
+
export { wecomPlugin } from "./channel.js";
|
|
3
|
+
declare const plugin: {
|
|
4
|
+
id: string;
|
|
5
|
+
name: string;
|
|
6
|
+
description: string;
|
|
7
|
+
version: string;
|
|
8
|
+
register(api: OpenClawPluginApi): void;
|
|
9
|
+
};
|
|
10
|
+
export default plugin;
|
|
11
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAI7D,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,QAAA,MAAM,MAAM;;;;;kBAMI,iBAAiB;CAKhC,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { wecomPlugin } from "./channel.js";
|
|
2
|
+
import { setWeComRuntime } from "./runtime.js";
|
|
3
|
+
export { wecomPlugin } from "./channel.js";
|
|
4
|
+
const plugin = {
|
|
5
|
+
id: "wecom",
|
|
6
|
+
name: "WeCom",
|
|
7
|
+
description: "WeCom (企业微信) channel plugin for OpenClaw",
|
|
8
|
+
version: "1.0.0",
|
|
9
|
+
register(api) {
|
|
10
|
+
setWeComRuntime(api.runtime);
|
|
11
|
+
api.registerChannel({ plugin: wecomPlugin });
|
|
12
|
+
api.logger.info("wecom: plugin registered successfully");
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
export default plugin;
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,MAAM,MAAM,GAAG;IACb,EAAE,EAAE,OAAO;IACX,IAAI,EAAE,OAAO;IACb,WAAW,EAAE,0CAA0C;IACvD,OAAO,EAAE,OAAO;IAEhB,QAAQ,CAAC,GAAsB;QAC7B,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QAC7B,GAAG,CAAC,eAAe,CAAC,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC,CAAC;QAC7C,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,uCAAuC,CAAC,CAAC;IAC3D,CAAC;CACF,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
package/dist/media.d.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { ClawdbotConfig } from "openclaw/plugin-sdk";
|
|
2
|
+
export type DownloadImageResult = {
|
|
3
|
+
buffer: Buffer;
|
|
4
|
+
contentType?: string;
|
|
5
|
+
fileName?: string;
|
|
6
|
+
};
|
|
7
|
+
export declare function downloadImageWeCom(params: {
|
|
8
|
+
cfg: ClawdbotConfig;
|
|
9
|
+
mediaId: string;
|
|
10
|
+
accountId?: string;
|
|
11
|
+
}): Promise<DownloadImageResult>;
|
|
12
|
+
export declare function saveInboundImage(params: {
|
|
13
|
+
buffer: Buffer;
|
|
14
|
+
fileName: string;
|
|
15
|
+
accountId: string;
|
|
16
|
+
}): Promise<string>;
|
|
17
|
+
//# sourceMappingURL=media.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"media.d.ts","sourceRoot":"","sources":["../src/media.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAK1D,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAQF,wBAAsB,kBAAkB,CAAC,MAAM,EAAE;IAC/C,GAAG,EAAE,cAAc,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CA0C/B;AAoBD,wBAAsB,gBAAgB,CAAC,MAAM,EAAE;IAC7C,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACnB,GAAG,OAAO,CAAC,MAAM,CAAC,CAclB"}
|
package/dist/media.js
ADDED
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import fs from "fs";
|
|
2
|
+
import os from "os";
|
|
3
|
+
import path from "path";
|
|
4
|
+
import { fetchWithSsrFGuard } from "openclaw/plugin-sdk";
|
|
5
|
+
import { resolveWeComAccount } from "./accounts.js";
|
|
6
|
+
import { getWeComAccessToken } from "./client.js";
|
|
7
|
+
const WECOM_API_POLICY = { allowedHostnames: ["qyapi.weixin.qq.com"] };
|
|
8
|
+
export async function downloadImageWeCom(params) {
|
|
9
|
+
const { cfg, mediaId, accountId } = params;
|
|
10
|
+
const account = resolveWeComAccount({ cfg, accountId });
|
|
11
|
+
if (!account.configured) {
|
|
12
|
+
throw new Error(`WeCom account "${account.accountId}" not configured`);
|
|
13
|
+
}
|
|
14
|
+
const accessToken = await getWeComAccessToken({ cfg, accountId });
|
|
15
|
+
const url = `https://qyapi.weixin.qq.com/cgi-bin/media/get?access_token=${accessToken}&media_id=${mediaId}`;
|
|
16
|
+
const { response, release } = await fetchWithSsrFGuard({
|
|
17
|
+
url,
|
|
18
|
+
policy: WECOM_API_POLICY,
|
|
19
|
+
auditContext: "wecom-download-image",
|
|
20
|
+
});
|
|
21
|
+
try {
|
|
22
|
+
if (!response.ok) {
|
|
23
|
+
throw new Error(`WeCom image download failed: ${response.status} ${response.statusText}`);
|
|
24
|
+
}
|
|
25
|
+
const contentType = response.headers.get("content-type");
|
|
26
|
+
if (contentType?.includes("application/json")) {
|
|
27
|
+
const errorData = await response.json();
|
|
28
|
+
throw new Error(`WeCom image download error ${errorData.errcode}: ${errorData.errmsg}`);
|
|
29
|
+
}
|
|
30
|
+
const buffer = Buffer.from(await response.arrayBuffer());
|
|
31
|
+
let fileName = `image_${mediaId}`;
|
|
32
|
+
if (contentType) {
|
|
33
|
+
const ext = contentTypeToExtension(contentType);
|
|
34
|
+
if (ext) {
|
|
35
|
+
fileName = `image_${mediaId}${ext}`;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return { buffer, contentType: contentType ?? undefined, fileName };
|
|
39
|
+
}
|
|
40
|
+
finally {
|
|
41
|
+
await release();
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
function contentTypeToExtension(contentType) {
|
|
45
|
+
const map = {
|
|
46
|
+
"image/jpeg": ".jpg",
|
|
47
|
+
"image/png": ".png",
|
|
48
|
+
"image/gif": ".gif",
|
|
49
|
+
"image/webp": ".webp",
|
|
50
|
+
"image/bmp": ".bmp",
|
|
51
|
+
"image/tiff": ".tiff",
|
|
52
|
+
};
|
|
53
|
+
return map[contentType] || null;
|
|
54
|
+
}
|
|
55
|
+
export async function saveInboundImage(params) {
|
|
56
|
+
const { buffer, fileName, accountId } = params;
|
|
57
|
+
const mediaDir = path.join(os.homedir(), ".openclaw", "media", "inbound");
|
|
58
|
+
await fs.promises.mkdir(mediaDir, { recursive: true });
|
|
59
|
+
const uniqueName = `${accountId}_${Date.now()}_${fileName}`;
|
|
60
|
+
const filePath = path.join(mediaDir, uniqueName);
|
|
61
|
+
await fs.promises.writeFile(filePath, buffer);
|
|
62
|
+
return filePath;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=media.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"media.js","sourceRoot":"","sources":["../src/media.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ClawdbotConfig, RuntimeEnv } from "openclaw/plugin-sdk";
|
|
2
|
+
export type MonitorWeComOpts = {
|
|
3
|
+
config?: ClawdbotConfig;
|
|
4
|
+
runtime?: RuntimeEnv;
|
|
5
|
+
abortSignal?: AbortSignal;
|
|
6
|
+
accountId?: string;
|
|
7
|
+
};
|
|
8
|
+
export declare function monitorWeComProvider(opts: MonitorWeComOpts): Promise<() => void>;
|
|
9
|
+
//# sourceMappingURL=monitor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"monitor.d.ts","sourceRoot":"","sources":["../src/monitor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,UAAU,EAAgB,MAAM,qBAAqB,CAAC;AAOpF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,MAAM,CAAC,EAAE,cAAc,CAAC;IACxB,OAAO,CAAC,EAAE,UAAU,CAAC;IACrB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAySF,wBAAsB,oBAAoB,CAAC,IAAI,EAAE,gBAAgB,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,CAgCtF"}
|
package/dist/monitor.js
ADDED
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
import * as crypto from "crypto";
|
|
2
|
+
import * as http from "http";
|
|
3
|
+
import { installRequestBodyLimitGuard } from "openclaw/plugin-sdk";
|
|
4
|
+
import { resolveWeComAccount } from "./accounts.js";
|
|
5
|
+
import { handleWeComMessage } from "./bot.js";
|
|
6
|
+
const httpServers = new Map();
|
|
7
|
+
const chatHistoriesMap = new Map();
|
|
8
|
+
const WECOM_WEBHOOK_MAX_BODY_BYTES = 1024 * 1024;
|
|
9
|
+
const WECOM_WEBHOOK_BODY_TIMEOUT_MS = 30_000;
|
|
10
|
+
function verifyWeComSignature(signature, timestamp, nonce, body, token) {
|
|
11
|
+
const arr = [token, timestamp, nonce, body].sort();
|
|
12
|
+
const str = arr.join("");
|
|
13
|
+
const hash = crypto.createHash("sha1").update(str).digest("hex");
|
|
14
|
+
return hash === signature;
|
|
15
|
+
}
|
|
16
|
+
function decryptWeComMessage(encrypt, encodingAESKey) {
|
|
17
|
+
const key = Buffer.from(encodingAESKey + "=", "base64");
|
|
18
|
+
const encryptBuffer = Buffer.from(encrypt, "base64");
|
|
19
|
+
const decipher = crypto.createDecipheriv("aes-256-cbc", key, key.slice(0, 16));
|
|
20
|
+
decipher.setAutoPadding(false);
|
|
21
|
+
let decrypted = Buffer.concat([decipher.update(encryptBuffer), decipher.final()]);
|
|
22
|
+
const pad = decrypted[decrypted.length - 1];
|
|
23
|
+
decrypted = decrypted.slice(0, decrypted.length - pad);
|
|
24
|
+
const msgLen = decrypted.readUInt32BE(16);
|
|
25
|
+
const message = decrypted.slice(20, 20 + msgLen).toString("utf8");
|
|
26
|
+
const corpId = decrypted.slice(20 + msgLen).toString("utf8");
|
|
27
|
+
return { message, corpId };
|
|
28
|
+
}
|
|
29
|
+
async function monitorWeComWebhook({ cfg, account, runtime, abortSignal, }) {
|
|
30
|
+
const { accountId } = account;
|
|
31
|
+
const log = runtime?.log ?? console.log;
|
|
32
|
+
const error = runtime?.error ?? console.error;
|
|
33
|
+
const port = account.config?.webhookPort ?? 3000;
|
|
34
|
+
const path = account.config?.webhookPath ?? "/wecom/events";
|
|
35
|
+
const host = account.config?.webhookHost ?? "127.0.0.1";
|
|
36
|
+
const token = account.config?.token;
|
|
37
|
+
const encodingAESKey = account.config?.encodingAESKey;
|
|
38
|
+
if (!token || !encodingAESKey) {
|
|
39
|
+
throw new Error(`WeCom account "${accountId}" requires token and encodingAESKey`);
|
|
40
|
+
}
|
|
41
|
+
log(`wecom[${accountId}]: starting Webhook server on ${host}:${port}, path ${path}...`);
|
|
42
|
+
let chatHistories = chatHistoriesMap.get(accountId);
|
|
43
|
+
if (!chatHistories) {
|
|
44
|
+
chatHistories = new Map();
|
|
45
|
+
chatHistoriesMap.set(accountId, chatHistories);
|
|
46
|
+
}
|
|
47
|
+
const server = http.createServer();
|
|
48
|
+
server.on("request", async (req, res) => {
|
|
49
|
+
const urlPath = req.url?.split("?")[0];
|
|
50
|
+
if (urlPath !== path) {
|
|
51
|
+
res.statusCode = 404;
|
|
52
|
+
res.end("Not Found");
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
if (req.method === "GET") {
|
|
56
|
+
const url = new URL(req.url, `http://${req.headers.host}`);
|
|
57
|
+
const msgSignature = url.searchParams.get("msg_signature");
|
|
58
|
+
const timestamp = url.searchParams.get("timestamp");
|
|
59
|
+
const nonce = url.searchParams.get("nonce");
|
|
60
|
+
const echostr = url.searchParams.get("echostr");
|
|
61
|
+
if (!msgSignature || !timestamp || !nonce || !echostr) {
|
|
62
|
+
res.statusCode = 400;
|
|
63
|
+
res.end("Bad Request");
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
try {
|
|
67
|
+
if (!verifyWeComSignature(msgSignature, timestamp, nonce, echostr, token)) {
|
|
68
|
+
error(`wecom[${accountId}]: signature verification failed`);
|
|
69
|
+
res.statusCode = 401;
|
|
70
|
+
res.end("Unauthorized");
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
const { message, corpId } = decryptWeComMessage(echostr, encodingAESKey);
|
|
74
|
+
const expectedCorpId = account.corpId;
|
|
75
|
+
if (corpId !== expectedCorpId) {
|
|
76
|
+
error(`wecom[${accountId}]: corpId mismatch, expected=${expectedCorpId}, got=${corpId}`);
|
|
77
|
+
res.statusCode = 403;
|
|
78
|
+
res.end("Forbidden");
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
res.statusCode = 200;
|
|
82
|
+
res.setHeader("Content-Type", "text/plain; charset=utf-8");
|
|
83
|
+
res.end(message);
|
|
84
|
+
log(`wecom[${accountId}]: URL verification successful`);
|
|
85
|
+
}
|
|
86
|
+
catch (err) {
|
|
87
|
+
error(`wecom[${accountId}]: URL verification error: ${String(err)}`);
|
|
88
|
+
res.statusCode = 500;
|
|
89
|
+
res.end("Internal Server Error");
|
|
90
|
+
}
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (req.method === "POST") {
|
|
94
|
+
const guard = installRequestBodyLimitGuard(req, res, {
|
|
95
|
+
maxBytes: WECOM_WEBHOOK_MAX_BODY_BYTES,
|
|
96
|
+
timeoutMs: WECOM_WEBHOOK_BODY_TIMEOUT_MS,
|
|
97
|
+
responseFormat: "text",
|
|
98
|
+
});
|
|
99
|
+
if (guard.isTripped()) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
const chunks = [];
|
|
103
|
+
req.on("data", (chunk) => chunks.push(chunk));
|
|
104
|
+
req.on("end", async () => {
|
|
105
|
+
try {
|
|
106
|
+
const body = Buffer.concat(chunks).toString("utf8");
|
|
107
|
+
const encryptMatch = body.match(/<Encrypt><!\[CDATA\[(.*?)\]\]><\/Encrypt>/);
|
|
108
|
+
if (!encryptMatch) {
|
|
109
|
+
error(`wecom[${accountId}]: failed to extract Encrypt from XML body`);
|
|
110
|
+
res.statusCode = 400;
|
|
111
|
+
res.end("Bad Request");
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
const encrypt = encryptMatch[1];
|
|
115
|
+
const url = new URL(req.url, `http://${req.headers.host}`);
|
|
116
|
+
const msgSignature = url.searchParams.get("msg_signature");
|
|
117
|
+
const timestamp = url.searchParams.get("timestamp");
|
|
118
|
+
const nonce = url.searchParams.get("nonce");
|
|
119
|
+
if (!msgSignature || !timestamp || !nonce) {
|
|
120
|
+
res.statusCode = 400;
|
|
121
|
+
res.end("Bad Request");
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
if (!verifyWeComSignature(msgSignature, timestamp, nonce, encrypt, token)) {
|
|
125
|
+
error(`wecom[${accountId}]: signature verification failed`);
|
|
126
|
+
res.statusCode = 401;
|
|
127
|
+
res.end("Unauthorized");
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
const { message } = decryptWeComMessage(encrypt, encodingAESKey);
|
|
131
|
+
const event = {
|
|
132
|
+
ToUserName: message.match(/<ToUserName><!\[CDATA\[(.*?)\]\]><\/ToUserName>/)?.[1] || "",
|
|
133
|
+
FromUserName: message.match(/<FromUserName><!\[CDATA\[(.*?)\]\]><\/FromUserName>/)?.[1] || "",
|
|
134
|
+
CreateTime: Number.parseInt(message.match(/<CreateTime>(\d+)<\/CreateTime>/)?.[1] || "0"),
|
|
135
|
+
MsgType: message.match(/<MsgType><!\[CDATA\[(.*?)\]\]><\/MsgType>/)?.[1] || "",
|
|
136
|
+
Content: message.match(/<Content><!\[CDATA\[(.*?)\]\]><\/Content>/)?.[1],
|
|
137
|
+
MsgId: message.match(/<MsgId>(\d+)<\/MsgId>/)?.[1] || "",
|
|
138
|
+
AgentID: message.match(/<AgentID>(\d+)<\/AgentID>/)?.[1] || "",
|
|
139
|
+
PicUrl: message.match(/<PicUrl><!\[CDATA\[(.*?)\]\]><\/PicUrl>/)?.[1],
|
|
140
|
+
MediaId: message.match(/<MediaId><!\[CDATA\[(.*?)\]\]><\/MediaId>/)?.[1],
|
|
141
|
+
Title: message.match(/<Title><!\[CDATA\[(.*?)\]\]><\/Title>/)?.[1],
|
|
142
|
+
Description: message.match(/<Description><!\[CDATA\[(.*?)\]\]><\/Description>/)?.[1],
|
|
143
|
+
FileKey: message.match(/<FileKey><!\[CDATA\[(.*?)\]\]><\/FileKey>/)?.[1],
|
|
144
|
+
Location_X: message.match(/<Location_X>(.*?)<\/Location_X>/)?.[1],
|
|
145
|
+
Location_Y: message.match(/<Location_Y>(.*?)<\/Location_Y>/)?.[1],
|
|
146
|
+
Scale: message.match(/<Scale>(\d+)<\/Scale>/)?.[1],
|
|
147
|
+
Label: message.match(/<Label><!\[CDATA\[(.*?)\]\]><\/Label>/)?.[1],
|
|
148
|
+
Url: message.match(/<Url><!\[CDATA\[(.*?)\]\]><\/Url>/)?.[1],
|
|
149
|
+
ChatId: message.match(/<ChatId><!\[CDATA\[(.*?)\]\]><\/ChatId>/)?.[1],
|
|
150
|
+
ChatType: message.match(/<ChatType><!\[CDATA\[(.*?)\]\]><\/ChatType>/)?.[1],
|
|
151
|
+
};
|
|
152
|
+
log(`wecom[${accountId}]: received message from ${event.FromUserName}, type=${event.MsgType}`);
|
|
153
|
+
handleWeComMessage({
|
|
154
|
+
cfg,
|
|
155
|
+
event,
|
|
156
|
+
runtime,
|
|
157
|
+
chatHistories,
|
|
158
|
+
accountId: accountId,
|
|
159
|
+
}).catch((err) => {
|
|
160
|
+
error(`wecom[${accountId}]: unexpected error handling message: ${String(err)}`);
|
|
161
|
+
});
|
|
162
|
+
res.statusCode = 200;
|
|
163
|
+
res.end("success");
|
|
164
|
+
}
|
|
165
|
+
catch (err) {
|
|
166
|
+
if (!guard.isTripped()) {
|
|
167
|
+
error(`wecom[${accountId}]: webhook handler error: ${String(err)}`);
|
|
168
|
+
res.statusCode = 500;
|
|
169
|
+
res.end("Internal Server Error");
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
finally {
|
|
173
|
+
guard.dispose();
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
res.statusCode = 405;
|
|
179
|
+
res.end("Method Not Allowed");
|
|
180
|
+
});
|
|
181
|
+
httpServers.set(accountId, server);
|
|
182
|
+
return new Promise((resolve, reject) => {
|
|
183
|
+
const cleanup = (callback) => {
|
|
184
|
+
server.close(() => {
|
|
185
|
+
httpServers.delete(accountId);
|
|
186
|
+
callback?.();
|
|
187
|
+
});
|
|
188
|
+
};
|
|
189
|
+
const handleAbort = () => {
|
|
190
|
+
log(`wecom[${accountId}]: abort signal received, stopping`);
|
|
191
|
+
cleanup(() => resolve());
|
|
192
|
+
};
|
|
193
|
+
if (abortSignal?.aborted) {
|
|
194
|
+
cleanup(() => resolve());
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
197
|
+
abortSignal?.addEventListener("abort", handleAbort, { once: true });
|
|
198
|
+
server.on("error", (err) => {
|
|
199
|
+
error(`wecom[${accountId}]: server error: ${String(err)}`);
|
|
200
|
+
abortSignal?.removeEventListener("abort", handleAbort);
|
|
201
|
+
cleanup(() => reject(err));
|
|
202
|
+
});
|
|
203
|
+
server.listen(port, host, () => {
|
|
204
|
+
log(`wecom[${accountId}]: Webhook server listening on ${host}:${port}${path}`);
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
export async function monitorWeComProvider(opts) {
|
|
209
|
+
const { config, runtime, abortSignal, accountId } = opts;
|
|
210
|
+
if (!config) {
|
|
211
|
+
throw new Error("Config is required");
|
|
212
|
+
}
|
|
213
|
+
const account = resolveWeComAccount({ cfg: config, accountId });
|
|
214
|
+
if (!account.configured) {
|
|
215
|
+
throw new Error(`WeCom account "${account.accountId}" is not configured`);
|
|
216
|
+
}
|
|
217
|
+
const log = runtime?.log ?? console.log;
|
|
218
|
+
log(`wecom[${account.accountId}]: starting monitor...`);
|
|
219
|
+
await monitorWeComWebhook({
|
|
220
|
+
cfg: config,
|
|
221
|
+
account,
|
|
222
|
+
runtime,
|
|
223
|
+
abortSignal,
|
|
224
|
+
});
|
|
225
|
+
return () => {
|
|
226
|
+
const server = httpServers.get(account.accountId);
|
|
227
|
+
if (server) {
|
|
228
|
+
server.close();
|
|
229
|
+
httpServers.delete(account.accountId);
|
|
230
|
+
}
|
|
231
|
+
};
|
|
232
|
+
}
|
|
233
|
+
//# sourceMappingURL=monitor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"monitor.js","sourceRoot":"","sources":["../src/monitor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outbound.d.ts","sourceRoot":"","sources":["../src/outbound.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAGlE,eAAO,MAAM,aAAa,EAAE,sBAsB3B,CAAC"}
|
package/dist/outbound.js
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { sendMessageWeCom } from "./send.js";
|
|
2
|
+
export const wecomOutbound = {
|
|
3
|
+
deliveryMode: "direct",
|
|
4
|
+
sendText: async ({ cfg, to, text, accountId }) => {
|
|
5
|
+
const result = await sendMessageWeCom({
|
|
6
|
+
cfg,
|
|
7
|
+
to,
|
|
8
|
+
text,
|
|
9
|
+
accountId: accountId ?? undefined,
|
|
10
|
+
});
|
|
11
|
+
return { channel: "wecom", ...result };
|
|
12
|
+
},
|
|
13
|
+
sendMedia: async ({ cfg, to, text, mediaUrl, accountId }) => {
|
|
14
|
+
const content = [text?.trim(), mediaUrl].filter(Boolean).join("\n");
|
|
15
|
+
const result = await sendMessageWeCom({
|
|
16
|
+
cfg,
|
|
17
|
+
to,
|
|
18
|
+
text: content || "(media)",
|
|
19
|
+
accountId: accountId ?? undefined,
|
|
20
|
+
});
|
|
21
|
+
return { channel: "wecom", ...result };
|
|
22
|
+
},
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=outbound.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outbound.js","sourceRoot":"","sources":["../src/outbound.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAE7C,MAAM,CAAC,MAAM,aAAa,GAA2B;IACnD,YAAY,EAAE,QAAQ;IACtB,QAAQ,EAAE,KAAK,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,EAAE,EAAE;QAC/C,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC;YACpC,GAAG;YACH,EAAE;YACF,IAAI;YACJ,SAAS,EAAE,SAAS,IAAI,SAAS;SAClC,CAAC,CAAC;QACH,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,CAAC;IACzC,CAAC;IACD,SAAS,EAAE,KAAK,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,EAAE,EAAE;QAE1D,MAAM,OAAO,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpE,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAC;YACpC,GAAG;YACH,EAAE;YACF,IAAI,EAAE,OAAO,IAAI,SAAS;YAC1B,SAAS,EAAE,SAAS,IAAI,SAAS;SAClC,CAAC,CAAC;QACH,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,MAAM,EAAE,CAAC;IACzC,CAAC;CACF,CAAC"}
|
package/dist/policy.d.ts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { AllowlistMatch, ChannelGroupContext, GroupToolPolicyConfig } from "openclaw/plugin-sdk";
|
|
2
|
+
import type { WeComConfig, WeComGroupConfig } from "./types.js";
|
|
3
|
+
export type WeComAllowlistMatch = AllowlistMatch<"wildcard" | "id">;
|
|
4
|
+
export declare function resolveWeComAllowlistMatch(params: {
|
|
5
|
+
allowFrom: Array<string | number>;
|
|
6
|
+
senderId: string;
|
|
7
|
+
senderIds?: Array<string | null | undefined>;
|
|
8
|
+
senderName?: string | null;
|
|
9
|
+
}): WeComAllowlistMatch;
|
|
10
|
+
export declare function resolveWeComGroupConfig(params: {
|
|
11
|
+
cfg?: WeComConfig;
|
|
12
|
+
groupId?: string | null;
|
|
13
|
+
}): WeComGroupConfig | undefined;
|
|
14
|
+
export declare function resolveWeComGroupToolPolicy(params: ChannelGroupContext): GroupToolPolicyConfig | undefined;
|
|
15
|
+
export declare function isWeComGroupAllowed(params: {
|
|
16
|
+
groupPolicy: "open" | "allowlist" | "disabled";
|
|
17
|
+
allowFrom: Array<string | number>;
|
|
18
|
+
senderId: string;
|
|
19
|
+
senderIds?: Array<string | null | undefined>;
|
|
20
|
+
senderName?: string | null;
|
|
21
|
+
}): boolean;
|
|
22
|
+
export declare function resolveWeComReplyPolicy(params: {
|
|
23
|
+
isDirectMessage: boolean;
|
|
24
|
+
globalConfig?: WeComConfig;
|
|
25
|
+
groupConfig?: WeComGroupConfig;
|
|
26
|
+
}): {
|
|
27
|
+
requireMention: boolean;
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../src/policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EACd,mBAAmB,EACnB,qBAAqB,EACtB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEhE,MAAM,MAAM,mBAAmB,GAAG,cAAc,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;AAepE,wBAAgB,0BAA0B,CAAC,MAAM,EAAE;IACjD,SAAS,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC;IAC7C,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC5B,GAAG,mBAAmB,CAuBtB;AAED,wBAAgB,uBAAuB,CAAC,MAAM,EAAE;IAC9C,GAAG,CAAC,EAAE,WAAW,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB,GAAG,gBAAgB,GAAG,SAAS,CAG/B;AAED,wBAAgB,2BAA2B,CACzC,MAAM,EAAE,mBAAmB,GAC1B,qBAAqB,GAAG,SAAS,CAYnC;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE;IAC1C,WAAW,EAAE,MAAM,GAAG,WAAW,GAAG,UAAU,CAAC;IAC/C,SAAS,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC;IAC7C,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CAC5B,GAAG,OAAO,CASV;AAED,wBAAgB,uBAAuB,CAAC,MAAM,EAAE;IAC9C,eAAe,EAAE,OAAO,CAAC;IACzB,YAAY,CAAC,EAAE,WAAW,CAAC;IAC3B,WAAW,CAAC,EAAE,gBAAgB,CAAC;CAChC,GAAG;IAAE,cAAc,EAAE,OAAO,CAAA;CAAE,CAS9B"}
|
package/dist/policy.js
ADDED
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { normalizeWeComTarget } from "./targets.js";
|
|
2
|
+
function normalizeWeComAllowEntry(raw) {
|
|
3
|
+
const trimmed = raw.trim();
|
|
4
|
+
if (!trimmed) {
|
|
5
|
+
return "";
|
|
6
|
+
}
|
|
7
|
+
if (trimmed === "*") {
|
|
8
|
+
return "*";
|
|
9
|
+
}
|
|
10
|
+
const withoutProviderPrefix = trimmed.replace(/^wecom:/i, "");
|
|
11
|
+
const normalized = normalizeWeComTarget(withoutProviderPrefix) ?? withoutProviderPrefix;
|
|
12
|
+
return normalized.trim().toLowerCase();
|
|
13
|
+
}
|
|
14
|
+
export function resolveWeComAllowlistMatch(params) {
|
|
15
|
+
const allowFrom = params.allowFrom
|
|
16
|
+
.map((entry) => normalizeWeComAllowEntry(String(entry)))
|
|
17
|
+
.filter(Boolean);
|
|
18
|
+
if (allowFrom.length === 0) {
|
|
19
|
+
return { allowed: false };
|
|
20
|
+
}
|
|
21
|
+
if (allowFrom.includes("*")) {
|
|
22
|
+
return { allowed: true, matchKey: "*", matchSource: "wildcard" };
|
|
23
|
+
}
|
|
24
|
+
const senderCandidates = [params.senderId, ...(params.senderIds ?? [])]
|
|
25
|
+
.map((entry) => normalizeWeComAllowEntry(String(entry ?? "")))
|
|
26
|
+
.filter(Boolean);
|
|
27
|
+
for (const senderId of senderCandidates) {
|
|
28
|
+
if (allowFrom.includes(senderId)) {
|
|
29
|
+
return { allowed: true, matchKey: senderId, matchSource: "id" };
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return { allowed: false };
|
|
33
|
+
}
|
|
34
|
+
export function resolveWeComGroupConfig(params) {
|
|
35
|
+
return undefined;
|
|
36
|
+
}
|
|
37
|
+
export function resolveWeComGroupToolPolicy(params) {
|
|
38
|
+
const cfg = params.cfg.channels?.wecom;
|
|
39
|
+
if (!cfg) {
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
const groupConfig = resolveWeComGroupConfig({
|
|
43
|
+
cfg,
|
|
44
|
+
groupId: params.groupId,
|
|
45
|
+
});
|
|
46
|
+
return groupConfig?.tools;
|
|
47
|
+
}
|
|
48
|
+
export function isWeComGroupAllowed(params) {
|
|
49
|
+
const { groupPolicy } = params;
|
|
50
|
+
if (groupPolicy === "disabled") {
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
if (groupPolicy === "open") {
|
|
54
|
+
return true;
|
|
55
|
+
}
|
|
56
|
+
return resolveWeComAllowlistMatch(params).allowed;
|
|
57
|
+
}
|
|
58
|
+
export function resolveWeComReplyPolicy(params) {
|
|
59
|
+
if (params.isDirectMessage) {
|
|
60
|
+
return { requireMention: false };
|
|
61
|
+
}
|
|
62
|
+
const requireMention = params.groupConfig?.requireMention ?? params.globalConfig?.requireMention ?? false;
|
|
63
|
+
return { requireMention };
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.js","sourceRoot":"","sources":["../src/policy.ts"],"names":[],"mappings":"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"}
|
package/dist/probe.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"probe.d.ts","sourceRoot":"","sources":["../src/probe.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAEvD,wBAAsB,UAAU,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC;IACvE,EAAE,EAAE,OAAO,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC,CAOD"}
|
package/dist/probe.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"probe.js","sourceRoot":"","sources":["../src/probe.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,OAA6B;IAI5D,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QACxB,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,gBAAgB,EAAE,CAAC;IAChD,CAAC;IAGD,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC;AACtB,CAAC"}
|