ylib-wecom-openclaw-plugin 2026.4.29
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/README.md +596 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +99 -0
- package/dist/src/accounts.d.ts +57 -0
- package/dist/src/accounts.js +247 -0
- package/dist/src/agent/api-client.d.ts +95 -0
- package/dist/src/agent/api-client.js +425 -0
- package/dist/src/agent/handler.d.ts +64 -0
- package/dist/src/agent/handler.js +731 -0
- package/dist/src/agent/index.d.ts +5 -0
- package/dist/src/agent/index.js +21 -0
- package/dist/src/agent/webhook.d.ts +25 -0
- package/dist/src/agent/webhook.js +294 -0
- package/dist/src/agent/xml.d.ts +21 -0
- package/dist/src/agent/xml.js +43 -0
- package/dist/src/channel.d.ts +5 -0
- package/dist/src/channel.js +815 -0
- package/dist/src/chat-queue.d.ts +31 -0
- package/dist/src/chat-queue.js +53 -0
- package/dist/src/config-schema.d.ts +587 -0
- package/dist/src/config-schema.js +146 -0
- package/dist/src/const.d.ts +128 -0
- package/dist/src/const.js +168 -0
- package/dist/src/dm-policy.d.ts +29 -0
- package/dist/src/dm-policy.js +146 -0
- package/dist/src/dynamic-agent.d.ts +37 -0
- package/dist/src/dynamic-agent.js +67 -0
- package/dist/src/dynamic-routing.d.ts +65 -0
- package/dist/src/dynamic-routing.js +62 -0
- package/dist/src/endpoint-dispatch.d.ts +54 -0
- package/dist/src/endpoint-dispatch.js +967 -0
- package/dist/src/endpoint-event-adapter.d.ts +15 -0
- package/dist/src/endpoint-event-adapter.js +427 -0
- package/dist/src/group-policy.d.ts +30 -0
- package/dist/src/group-policy.js +126 -0
- package/dist/src/http.d.ts +27 -0
- package/dist/src/http.js +168 -0
- package/dist/src/im-runtime-telemetry.d.ts +25 -0
- package/dist/src/im-runtime-telemetry.js +68 -0
- package/dist/src/interface.d.ts +192 -0
- package/dist/src/interface.js +5 -0
- package/dist/src/markdown-chunk.d.ts +1 -0
- package/dist/src/markdown-chunk.js +396 -0
- package/dist/src/mcp/index.d.ts +6 -0
- package/dist/src/mcp/index.js +28 -0
- package/dist/src/mcp/interceptors/biz-error.d.ts +11 -0
- package/dist/src/mcp/interceptors/biz-error.js +73 -0
- package/dist/src/mcp/interceptors/doc-auth-error.d.ts +10 -0
- package/dist/src/mcp/interceptors/doc-auth-error.js +235 -0
- package/dist/src/mcp/interceptors/index.d.ts +35 -0
- package/dist/src/mcp/interceptors/index.js +143 -0
- package/dist/src/mcp/interceptors/msg-media.d.ts +11 -0
- package/dist/src/mcp/interceptors/msg-media.js +201 -0
- package/dist/src/mcp/interceptors/smartpage-create.d.ts +30 -0
- package/dist/src/mcp/interceptors/smartpage-create.js +252 -0
- package/dist/src/mcp/interceptors/smartpage-export.d.ts +17 -0
- package/dist/src/mcp/interceptors/smartpage-export.js +135 -0
- package/dist/src/mcp/interceptors/smartsheet-upload.d.ts +22 -0
- package/dist/src/mcp/interceptors/smartsheet-upload.js +388 -0
- package/dist/src/mcp/interceptors/types.d.ts +64 -0
- package/dist/src/mcp/interceptors/types.js +8 -0
- package/dist/src/mcp/schema.d.ts +11 -0
- package/dist/src/mcp/schema.js +115 -0
- package/dist/src/mcp/tool.d.ts +63 -0
- package/dist/src/mcp/tool.js +318 -0
- package/dist/src/mcp/transport.d.ts +94 -0
- package/dist/src/mcp/transport.js +702 -0
- package/dist/src/media-handler.d.ts +55 -0
- package/dist/src/media-handler.js +306 -0
- package/dist/src/media-uploader.d.ts +142 -0
- package/dist/src/media-uploader.js +446 -0
- package/dist/src/message-parser.d.ts +104 -0
- package/dist/src/message-parser.js +232 -0
- package/dist/src/message-sender.d.ts +54 -0
- package/dist/src/message-sender.js +210 -0
- package/dist/src/monitor.d.ts +69 -0
- package/dist/src/monitor.js +1846 -0
- package/dist/src/onboarding.d.ts +8 -0
- package/dist/src/onboarding.js +248 -0
- package/dist/src/openclaw-compat.d.ts +148 -0
- package/dist/src/openclaw-compat.js +839 -0
- package/dist/src/proactive-markdown-send.d.ts +14 -0
- package/dist/src/proactive-markdown-send.js +205 -0
- package/dist/src/reqid-store.d.ts +23 -0
- package/dist/src/reqid-store.js +136 -0
- package/dist/src/runtime.d.ts +2 -0
- package/dist/src/runtime.js +7 -0
- package/dist/src/shared/command-auth.d.ts +23 -0
- package/dist/src/shared/command-auth.js +112 -0
- package/dist/src/shared/xml-parser.d.ts +46 -0
- package/dist/src/shared/xml-parser.js +228 -0
- package/dist/src/state-dir-resolve.d.ts +2 -0
- package/dist/src/state-dir-resolve.js +33 -0
- package/dist/src/state-manager.d.ts +115 -0
- package/dist/src/state-manager.js +413 -0
- package/dist/src/target.d.ts +35 -0
- package/dist/src/target.js +71 -0
- package/dist/src/template-card-manager.d.ts +55 -0
- package/dist/src/template-card-manager.js +316 -0
- package/dist/src/template-card-parser.d.ts +37 -0
- package/dist/src/template-card-parser.js +672 -0
- package/dist/src/timeout.d.ts +20 -0
- package/dist/src/timeout.js +57 -0
- package/dist/src/types/account.d.ts +29 -0
- package/dist/src/types/account.js +5 -0
- package/dist/src/types/config.d.ts +98 -0
- package/dist/src/types/config.js +8 -0
- package/dist/src/types/constants.d.ts +42 -0
- package/dist/src/types/constants.js +45 -0
- package/dist/src/types/index.d.ts +7 -0
- package/dist/src/types/index.js +17 -0
- package/dist/src/types/message.d.ts +238 -0
- package/dist/src/types/message.js +6 -0
- package/dist/src/utils.d.ts +148 -0
- package/dist/src/utils.js +92 -0
- package/dist/src/version.d.ts +2 -0
- package/dist/src/version.js +28 -0
- package/dist/src/webhook/command-auth.d.ts +47 -0
- package/dist/src/webhook/command-auth.js +137 -0
- package/dist/src/webhook/gateway.d.ts +36 -0
- package/dist/src/webhook/gateway.js +297 -0
- package/dist/src/webhook/handler.d.ts +19 -0
- package/dist/src/webhook/handler.js +481 -0
- package/dist/src/webhook/helpers.d.ts +157 -0
- package/dist/src/webhook/helpers.js +936 -0
- package/dist/src/webhook/http.d.ts +27 -0
- package/dist/src/webhook/http.js +168 -0
- package/dist/src/webhook/index.d.ts +11 -0
- package/dist/src/webhook/index.js +43 -0
- package/dist/src/webhook/media.d.ts +30 -0
- package/dist/src/webhook/media.js +152 -0
- package/dist/src/webhook/monitor.d.ts +59 -0
- package/dist/src/webhook/monitor.js +1672 -0
- package/dist/src/webhook/state.d.ts +220 -0
- package/dist/src/webhook/state.js +568 -0
- package/dist/src/webhook/target.d.ts +41 -0
- package/dist/src/webhook/target.js +165 -0
- package/dist/src/webhook/types.d.ts +348 -0
- package/dist/src/webhook/types.js +36 -0
- package/dist/src/webhook/video-frame.d.ts +13 -0
- package/dist/src/webhook/video-frame.js +108 -0
- package/openclaw.plugin.json +19 -0
- package/package.json +96 -0
- package/schema.json +534 -0
- package/scripts/generate-schema.mjs +33 -0
- package/skills/wecom-contact/SKILL.md +162 -0
- package/skills/wecom-doc/SKILL.md +162 -0
- package/skills/wecom-doc/references/create-doc.md +56 -0
- package/skills/wecom-doc/references/edit-doc-content.md +68 -0
- package/skills/wecom-doc/references/get-doc-content.md +88 -0
- package/skills/wecom-doc/references/smartpage-create.md +125 -0
- package/skills/wecom-doc/references/smartpage-export.md +160 -0
- package/skills/wecom-meeting/SKILL.md +441 -0
- package/skills/wecom-meeting/references/example-full.md +30 -0
- package/skills/wecom-meeting/references/example-reminder.md +46 -0
- package/skills/wecom-meeting/references/example-security.md +22 -0
- package/skills/wecom-meeting/references/response-get-meeting-info.md +148 -0
- package/skills/wecom-msg/SKILL.md +157 -0
- package/skills/wecom-msg/references/api-get-messages.md +93 -0
- package/skills/wecom-msg/references/api-get-msg-chat-list.md +58 -0
- package/skills/wecom-msg/references/api-get-msg-media.md +44 -0
- package/skills/wecom-msg/references/api-send-message.md +39 -0
- package/skills/wecom-preflight/SKILL.md +141 -0
- package/skills/wecom-schedule/SKILL.md +161 -0
- package/skills/wecom-schedule/references/api-check-availability.md +56 -0
- package/skills/wecom-schedule/references/api-create-schedule.md +38 -0
- package/skills/wecom-schedule/references/api-get-schedule-detail.md +81 -0
- package/skills/wecom-schedule/references/api-update-schedule.md +32 -0
- package/skills/wecom-schedule/references/ref-reminders.md +24 -0
- package/skills/wecom-send-media/SKILL.md +68 -0
- package/skills/wecom-send-template-card/SKILL.md +157 -0
- package/skills/wecom-send-template-card/references/api-template-card-types.md +358 -0
- package/skills/wecom-smartsheet/SKILL.md +164 -0
- package/skills/wecom-smartsheet/references/smartsheet-cell-value-formats.md +163 -0
- package/skills/wecom-smartsheet/references/smartsheet-field-types.md +44 -0
- package/skills/wecom-smartsheet/references/smartsheet-get-records.md +96 -0
- package/skills/wecom-smartsheet/references/webhook-examples.md +185 -0
- package/skills/wecom-smartsheet/references/webhook-fallback.md +184 -0
- package/skills/wecom-todo/SKILL.md +392 -0
- package/skills/wecom-todo/examples/workflows.md +163 -0
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Webhook 模式状态管理
|
|
3
|
+
*
|
|
4
|
+
* 从 @mocrane/wecom monitor/state.ts 完整迁移。
|
|
5
|
+
* 包含 StreamStore(流状态存储)、ActiveReplyStore(主动回复地址存储)、MonitorState(全局容器)。
|
|
6
|
+
*/
|
|
7
|
+
import type { StreamState, PendingInbound, WecomWebhookTarget, WebhookInboundMessage } from "./types.js";
|
|
8
|
+
export declare const LIMITS: {
|
|
9
|
+
STREAM_TTL_MS: number;
|
|
10
|
+
ACTIVE_REPLY_TTL_MS: number;
|
|
11
|
+
DEFAULT_DEBOUNCE_MS: number;
|
|
12
|
+
STREAM_MAX_BYTES: number;
|
|
13
|
+
REQUEST_TIMEOUT_MS: number;
|
|
14
|
+
};
|
|
15
|
+
/**
|
|
16
|
+
* **StreamStore (流状态会话存储)**
|
|
17
|
+
*
|
|
18
|
+
* 管理企业微信回调的流式会话状态、消息去重和防抖聚合逻辑。
|
|
19
|
+
* 负责维护 msgid 到 streamId 的映射,以及临时缓存待处理的 Pending 消息。
|
|
20
|
+
*/
|
|
21
|
+
export declare class StreamStore {
|
|
22
|
+
private streams;
|
|
23
|
+
private msgidToStreamId;
|
|
24
|
+
private pendingInbounds;
|
|
25
|
+
private conversationState;
|
|
26
|
+
private streamIdToBatchKey;
|
|
27
|
+
private batchStreamIdToAckStreamIds;
|
|
28
|
+
private onFlush?;
|
|
29
|
+
/**
|
|
30
|
+
* **setFlushHandler (设置防抖刷新回调)**
|
|
31
|
+
*
|
|
32
|
+
* 当防抖计时器结束时调用的处理函数。通常用于触发 Agent 进行消息处理。
|
|
33
|
+
* @param handler 回调函数,接收聚合后的 PendingInbound 对象
|
|
34
|
+
*/
|
|
35
|
+
setFlushHandler(handler: (pending: PendingInbound) => void): void;
|
|
36
|
+
/**
|
|
37
|
+
* **createStream (创建流会话)**
|
|
38
|
+
*
|
|
39
|
+
* 初始化一个新的流式会话状态。
|
|
40
|
+
* @param params.msgid (可选) 企业微信消息 ID,用于后续去重映射
|
|
41
|
+
* @returns 生成的 streamId (Hex 字符串)
|
|
42
|
+
*/
|
|
43
|
+
createStream(params: {
|
|
44
|
+
msgid?: string;
|
|
45
|
+
conversationKey?: string;
|
|
46
|
+
batchKey?: string;
|
|
47
|
+
}): string;
|
|
48
|
+
/**
|
|
49
|
+
* **getStream (获取流状态)**
|
|
50
|
+
*
|
|
51
|
+
* 根据 streamId 获取当前的会话状态。
|
|
52
|
+
* @param streamId 流会话 ID
|
|
53
|
+
*/
|
|
54
|
+
getStream(streamId: string): StreamState | undefined;
|
|
55
|
+
/**
|
|
56
|
+
* **getStreamByMsgId (通过 msgid 查找流 ID)**
|
|
57
|
+
*
|
|
58
|
+
* 用于消息去重:检查该 msgid 是否已经关联由正在进行或已完成的流会话。
|
|
59
|
+
* @param msgid 企业微信消息 ID
|
|
60
|
+
*/
|
|
61
|
+
getStreamByMsgId(msgid: string): string | undefined;
|
|
62
|
+
/** 手动设置 msgid → streamId 映射 */
|
|
63
|
+
setStreamIdForMsgId(msgid: string, streamId: string): void;
|
|
64
|
+
/**
|
|
65
|
+
* 将“回执流”(ack stream) 关联到某个“批次流”(batch stream)。
|
|
66
|
+
* 用于:当用户连发多条消息被合并排队时,让后续消息的 stream 最终也能更新为可理解的提示,而不是永久停留在“已合并排队…”。
|
|
67
|
+
*/
|
|
68
|
+
addAckStreamForBatch(params: {
|
|
69
|
+
batchStreamId: string;
|
|
70
|
+
ackStreamId: string;
|
|
71
|
+
}): void;
|
|
72
|
+
/**
|
|
73
|
+
* 取出并清空某个批次流关联的所有回执流。
|
|
74
|
+
*/
|
|
75
|
+
drainAckStreamsForBatch(batchStreamId: string): string[];
|
|
76
|
+
/**
|
|
77
|
+
* **updateStream (更新流状态)**
|
|
78
|
+
*
|
|
79
|
+
* 原子更新流状态,并自动刷新 updatedAt 时间戳。
|
|
80
|
+
* @param streamId 流会话 ID
|
|
81
|
+
* @param mutator 状态修改函数
|
|
82
|
+
*/
|
|
83
|
+
updateStream(streamId: string, mutator: (state: StreamState) => void): void;
|
|
84
|
+
/**
|
|
85
|
+
* **markStarted (标记流开始)**
|
|
86
|
+
*
|
|
87
|
+
* 标记该流会话已经开始处理(通常在 Agent 启动后调用)。
|
|
88
|
+
*/
|
|
89
|
+
markStarted(streamId: string): void;
|
|
90
|
+
/**
|
|
91
|
+
* **markFinished (标记流结束)**
|
|
92
|
+
*
|
|
93
|
+
* 标记该流会话已完成,不再接收内容更新。
|
|
94
|
+
*/
|
|
95
|
+
markFinished(streamId: string): void;
|
|
96
|
+
/**
|
|
97
|
+
* **addPendingMessage (添加待处理消息 / 防抖聚合)**
|
|
98
|
+
*
|
|
99
|
+
* 将收到的消息加入待处理队列。如果相同 pendingKey 已存在,则是防抖聚合;否则创建新条目。
|
|
100
|
+
* 会自动设置或重置防抖定时器。
|
|
101
|
+
*
|
|
102
|
+
* @param params 消息参数
|
|
103
|
+
* @returns { streamId, isNew } isNew=true 表示这是新的一组消息,需初始化 ActiveReply
|
|
104
|
+
*/
|
|
105
|
+
addPendingMessage(params: {
|
|
106
|
+
conversationKey: string;
|
|
107
|
+
target: WecomWebhookTarget;
|
|
108
|
+
msg: WebhookInboundMessage;
|
|
109
|
+
msgContent: string;
|
|
110
|
+
nonce: string;
|
|
111
|
+
timestamp: string;
|
|
112
|
+
debounceMs?: number;
|
|
113
|
+
}): {
|
|
114
|
+
streamId: string;
|
|
115
|
+
status: "active_new" | "active_merged" | "queued_new" | "queued_merged";
|
|
116
|
+
};
|
|
117
|
+
/**
|
|
118
|
+
* 请求刷新:如果该批次当前为 active,则立即 flush;否则标记 ready,等待前序批次完成后再 flush。
|
|
119
|
+
*/
|
|
120
|
+
private requestFlush;
|
|
121
|
+
/**
|
|
122
|
+
* **flushPending (触发消息处理)**
|
|
123
|
+
*
|
|
124
|
+
* 内部方法:防抖时间结束后,将聚合的消息一次性推送给 flushHandler。
|
|
125
|
+
*/
|
|
126
|
+
private flushPending;
|
|
127
|
+
/**
|
|
128
|
+
* 在一个 stream 完成后推进会话队列:将 queued 批次提升为 active,并在需要时触发 flush。
|
|
129
|
+
*/
|
|
130
|
+
onStreamFinished(streamId: string): void;
|
|
131
|
+
/**
|
|
132
|
+
* **prune (清理过期状态)**
|
|
133
|
+
*
|
|
134
|
+
* 清理过期的流会话、msgid 映射以及残留的 Pending 消息。
|
|
135
|
+
* @param now 当前时间戳 (毫秒)
|
|
136
|
+
*/
|
|
137
|
+
prune(now?: number): void;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* **ActiveReplyStore (主动回复地址存储)**
|
|
141
|
+
*
|
|
142
|
+
* 管理企业微信回调中的 `response_url` (用于被动回复转主动推送) 和 `proxyUrl`。
|
|
143
|
+
* 支持 'once' (一次性) 或 'multi' (多次) 使用策略。
|
|
144
|
+
*/
|
|
145
|
+
export declare class ActiveReplyStore {
|
|
146
|
+
private policy;
|
|
147
|
+
private activeReplies;
|
|
148
|
+
/**
|
|
149
|
+
* @param policy 使用策略: "once" (默认,销毁式) 或 "multi"
|
|
150
|
+
*/
|
|
151
|
+
constructor(policy?: "once" | "multi");
|
|
152
|
+
/**
|
|
153
|
+
* **store (存储回复地址)**
|
|
154
|
+
*
|
|
155
|
+
* 关联 streamId 与 response_url。
|
|
156
|
+
*/
|
|
157
|
+
store(streamId: string, responseUrl?: string, proxyUrl?: string): void;
|
|
158
|
+
/**
|
|
159
|
+
* **getUrl (获取回复地址)**
|
|
160
|
+
*
|
|
161
|
+
* 获取指定 streamId 关联的 response_url。
|
|
162
|
+
*/
|
|
163
|
+
getUrl(streamId: string): string | undefined;
|
|
164
|
+
/**
|
|
165
|
+
* 获取关联的代理 URL
|
|
166
|
+
*/
|
|
167
|
+
getProxyUrl(streamId: string): string | undefined;
|
|
168
|
+
/**
|
|
169
|
+
* **use (消耗回复地址)**
|
|
170
|
+
*
|
|
171
|
+
* 使用存储的 response_url 执行操作。
|
|
172
|
+
* - 如果策略是 "once",第二次调用会抛错。
|
|
173
|
+
* - 自动更新使用时间 (usedAt)。
|
|
174
|
+
*
|
|
175
|
+
* @param streamId 流会话 ID
|
|
176
|
+
* @param fn 执行函数,接收 { responseUrl, proxyUrl }
|
|
177
|
+
*/
|
|
178
|
+
use(streamId: string, fn: (params: {
|
|
179
|
+
responseUrl: string;
|
|
180
|
+
proxyUrl?: string;
|
|
181
|
+
}) => Promise<void>): Promise<void>;
|
|
182
|
+
/**
|
|
183
|
+
* **prune (清理过期地址)**
|
|
184
|
+
*
|
|
185
|
+
* 清理超过 TTL 的 active reply 记录。
|
|
186
|
+
*/
|
|
187
|
+
prune(now?: number): void;
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* **MonitorState (全局监控状态容器)**
|
|
191
|
+
*
|
|
192
|
+
* 模块单例,统一管理 StreamStore 和 ActiveReplyStore 实例。
|
|
193
|
+
* 提供生命周期方法 (startPruning / stopPruning) 以自动清理过期数据。
|
|
194
|
+
*/
|
|
195
|
+
export declare class WebhookMonitorState {
|
|
196
|
+
/** 主要的流状态存储 */
|
|
197
|
+
readonly streamStore: StreamStore;
|
|
198
|
+
/** 主动回复地址存储 */
|
|
199
|
+
readonly activeReplyStore: ActiveReplyStore;
|
|
200
|
+
private pruneInterval?;
|
|
201
|
+
/**
|
|
202
|
+
* **startPruning (启动自动清理)**
|
|
203
|
+
*
|
|
204
|
+
* 启动定时器,定期清理过期的流和回复地址。应在插件有活跃 Target 时调用。
|
|
205
|
+
* @param intervalMs 清理间隔 (默认 60s)
|
|
206
|
+
*/
|
|
207
|
+
startPruning(intervalMs?: number): void;
|
|
208
|
+
/**
|
|
209
|
+
* **stopPruning (停止自动清理)**
|
|
210
|
+
*
|
|
211
|
+
* 停止定时器。应在插件无活跃 Target 时调用以释放资源。
|
|
212
|
+
*/
|
|
213
|
+
stopPruning(): void;
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* **monitorState (全局单例)**
|
|
217
|
+
*
|
|
218
|
+
* 导出全局唯一的 MonitorState 实例,供整个应用共享状态。
|
|
219
|
+
*/
|
|
220
|
+
export declare const monitorState: WebhookMonitorState;
|