@lanmers/wecom-openclaw-plugin-agents 3.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/README.md +326 -0
- package/dist/index.cjs.js +3617 -0
- package/dist/index.cjs.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.esm.js +3591 -0
- package/dist/index.esm.js.map +1 -0
- package/dist/src/channel.d.ts +11 -0
- package/dist/src/const.d.ts +74 -0
- package/dist/src/dm-policy.d.ts +29 -0
- package/dist/src/group-policy.d.ts +29 -0
- package/dist/src/interface.d.ts +154 -0
- package/dist/src/mcp/index.d.ts +6 -0
- package/dist/src/mcp/schema.d.ts +11 -0
- package/dist/src/mcp/tool.d.ts +55 -0
- package/dist/src/mcp/transport.d.ts +61 -0
- package/dist/src/mcp-config.d.ts +29 -0
- package/dist/src/media-handler.d.ts +36 -0
- package/dist/src/media-uploader.d.ts +131 -0
- package/dist/src/message-parser.d.ts +72 -0
- package/dist/src/message-sender.d.ts +23 -0
- package/dist/src/monitor.d.ts +27 -0
- package/dist/src/onboarding.d.ts +5 -0
- package/dist/src/openclaw-compat.d.ts +48 -0
- package/dist/src/reqid-store.d.ts +31 -0
- package/dist/src/runtime.d.ts +3 -0
- package/dist/src/state-manager.d.ts +76 -0
- package/dist/src/timeout.d.ts +20 -0
- package/dist/src/utils.d.ts +80 -0
- package/dist/src/version.d.ts +2 -0
- package/openclaw.plugin.json +14 -0
- package/package.json +73 -0
- package/skills/wecom-contact-lookup/SKILL.md +162 -0
- package/skills/wecom-doc/SKILL.md +363 -0
- package/skills/wecom-doc/references/doc-api.md +224 -0
- package/skills/wecom-doc-manager/SKILL.md +64 -0
- package/skills/wecom-doc-manager/references/api-create-doc.md +56 -0
- package/skills/wecom-doc-manager/references/api-edit-doc-content.md +68 -0
- package/skills/wecom-doc-manager/references/api-export-document.md +88 -0
- package/skills/wecom-edit-todo/SKILL.md +249 -0
- package/skills/wecom-get-todo-detail/SKILL.md +143 -0
- package/skills/wecom-get-todo-list/SKILL.md +127 -0
- package/skills/wecom-meeting-create/SKILL.md +158 -0
- package/skills/wecom-meeting-create/references/example-full.md +30 -0
- package/skills/wecom-meeting-create/references/example-reminder.md +46 -0
- package/skills/wecom-meeting-create/references/example-security.md +22 -0
- package/skills/wecom-meeting-manage/SKILL.md +136 -0
- package/skills/wecom-meeting-query/SKILL.md +330 -0
- package/skills/wecom-preflight/SKILL.md +141 -0
- package/skills/wecom-schedule/SKILL.md +159 -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 +30 -0
- package/skills/wecom-schedule/references/ref-reminders.md +24 -0
- package/skills/wecom-smartsheet-data/SKILL.md +71 -0
- package/skills/wecom-smartsheet-data/references/api-get-records.md +61 -0
- package/skills/wecom-smartsheet-data/references/cell-value-formats.md +120 -0
- package/skills/wecom-smartsheet-schema/SKILL.md +92 -0
- package/skills/wecom-smartsheet-schema/references/field-types.md +43 -0
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# create_doc API
|
|
2
|
+
|
|
3
|
+
新建文档、表格或智能表格。创建成功后返回文档访问链接和 docid。
|
|
4
|
+
|
|
5
|
+
## 技能定义
|
|
6
|
+
|
|
7
|
+
```json
|
|
8
|
+
{
|
|
9
|
+
"name": "create_doc",
|
|
10
|
+
"description": "新建文档、表格或智能表格。支持在指定空间和目录下创建,可设置文档管理员。创建成功后返回文档访问链接和 docid(docid 仅在创建时返回,需妥善保存)。注意:创建智能表格(doc_type=10)时,文档会默认包含一个子表,可通过 smartsheet_get_sheet 查询其 sheet_id,无需额外调用 smartsheet_add_sheet。",
|
|
11
|
+
"inputSchema": {
|
|
12
|
+
"properties": {
|
|
13
|
+
"doc_type": {
|
|
14
|
+
"description": "文档类型:3-文档,10-智能表格",
|
|
15
|
+
"enum": [3, 10],
|
|
16
|
+
"title": "Doc Type",
|
|
17
|
+
"type": "integer"
|
|
18
|
+
},
|
|
19
|
+
"doc_name": {
|
|
20
|
+
"description": "文档名字,最多 255 个字符,超过会被截断",
|
|
21
|
+
"title": "Doc Name",
|
|
22
|
+
"type": "string"
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
"required": ["doc_type", "doc_name"],
|
|
26
|
+
"title": "create_docArguments",
|
|
27
|
+
"type": "object"
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
## 请求示例
|
|
33
|
+
|
|
34
|
+
```json
|
|
35
|
+
{
|
|
36
|
+
"doc_type": 3,
|
|
37
|
+
"doc_name": "项目周报"
|
|
38
|
+
}
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
## 响应示例
|
|
42
|
+
|
|
43
|
+
```json
|
|
44
|
+
{
|
|
45
|
+
"errcode": 0,
|
|
46
|
+
"errmsg": "ok",
|
|
47
|
+
"url": "https://doc.weixin.qq.com/doc/xxx",
|
|
48
|
+
"docid": "DOCID"
|
|
49
|
+
}
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
## 注意事项
|
|
53
|
+
|
|
54
|
+
- `doc_type=3` 创建普通文档
|
|
55
|
+
- `doc_type=10` 创建智能表格,默认包含一个子表
|
|
56
|
+
- docid 仅在创建时返回,后续无法再获取,务必保存
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
# edit_doc_content API
|
|
2
|
+
|
|
3
|
+
编辑(覆写)文档内容。
|
|
4
|
+
|
|
5
|
+
## 技能定义
|
|
6
|
+
|
|
7
|
+
```json
|
|
8
|
+
{
|
|
9
|
+
"name": "edit_doc_content",
|
|
10
|
+
"description": "编辑文档内容",
|
|
11
|
+
"inputSchema": {
|
|
12
|
+
"properties": {
|
|
13
|
+
"docid": {
|
|
14
|
+
"description": "文档 id,与 url 二选一传入",
|
|
15
|
+
"title": "Docid",
|
|
16
|
+
"type": "string"
|
|
17
|
+
},
|
|
18
|
+
"url": {
|
|
19
|
+
"description": "文档的访问链接,与 docid 二选一传入",
|
|
20
|
+
"title": "URL",
|
|
21
|
+
"type": "string"
|
|
22
|
+
},
|
|
23
|
+
"content": {
|
|
24
|
+
"description": "覆写的文档内容",
|
|
25
|
+
"title": "Content",
|
|
26
|
+
"type": "string"
|
|
27
|
+
},
|
|
28
|
+
"content_type": {
|
|
29
|
+
"description": "内容类型格式。1:markdown",
|
|
30
|
+
"enum": [1],
|
|
31
|
+
"title": "Content Type",
|
|
32
|
+
"type": "integer"
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
"oneOf": [
|
|
36
|
+
{ "required": ["docid", "content", "content_type"] },
|
|
37
|
+
{ "required": ["url", "content", "content_type"] }
|
|
38
|
+
],
|
|
39
|
+
"title": "edit_doc_contentArguments",
|
|
40
|
+
"type": "object"
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## 请求示例
|
|
46
|
+
|
|
47
|
+
```json
|
|
48
|
+
{
|
|
49
|
+
"docid": "DOCID",
|
|
50
|
+
"content": "# 标题\n\n正文内容",
|
|
51
|
+
"content_type": 1
|
|
52
|
+
}
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## 响应示例
|
|
56
|
+
|
|
57
|
+
```json
|
|
58
|
+
{
|
|
59
|
+
"errcode": 0,
|
|
60
|
+
"errmsg": "ok"
|
|
61
|
+
}
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
## 注意事项
|
|
65
|
+
|
|
66
|
+
- `content_type` 当前仅支持 `1`(Markdown 格式)
|
|
67
|
+
- 此操作为**覆写**,会替换文档全部内容
|
|
68
|
+
- 建议先调用 `get_document` 了解当前内容再编辑
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
# get_doc_content API
|
|
2
|
+
|
|
3
|
+
获取企业微信文档的完整内容数据,以 Markdown 格式返回。该接口采用异步轮询机制:首次调用无需传 task_id,接口会返回 task_id;若 task_done 为 false,需携带该 task_id 再次调用,直到 task_done 为 true 时返回完整内容。
|
|
4
|
+
|
|
5
|
+
## 技能定义
|
|
6
|
+
|
|
7
|
+
```json
|
|
8
|
+
{
|
|
9
|
+
"name": "get_doc_content",
|
|
10
|
+
"description": "获取企业微信文档的完整内容数据,以 Markdown 格式返回。该接口采用异步轮询机制:首次调用无需传 task_id,接口会返回 task_id;若 task_done 为 false,需携带该 task_id 再次调用,直到 task_done 为 true 时返回完整内容。",
|
|
11
|
+
"inputSchema": {
|
|
12
|
+
"properties": {
|
|
13
|
+
"docid": {
|
|
14
|
+
"description": "文档的 docid,与 url 二选一传入",
|
|
15
|
+
"title": "Doc ID",
|
|
16
|
+
"type": "string"
|
|
17
|
+
},
|
|
18
|
+
"url": {
|
|
19
|
+
"description": "文档的访问链接,与 docid 二选一传入",
|
|
20
|
+
"title": "URL",
|
|
21
|
+
"type": "string"
|
|
22
|
+
},
|
|
23
|
+
"type": {
|
|
24
|
+
"description": "内容返回格式。2: Markdown 格式",
|
|
25
|
+
"enum": [2],
|
|
26
|
+
"title": "Type",
|
|
27
|
+
"type": "integer"
|
|
28
|
+
},
|
|
29
|
+
"task_id": {
|
|
30
|
+
"description": "任务 ID,用于异步轮询。初次调用时不填,后续轮询时填写上次返回的 task_id",
|
|
31
|
+
"title": "Task ID",
|
|
32
|
+
"type": "string"
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
"oneOf": [
|
|
36
|
+
{ "required": ["docid", "type"] },
|
|
37
|
+
{ "required": ["url", "type"] }
|
|
38
|
+
],
|
|
39
|
+
"title": "get_doc_contentArguments",
|
|
40
|
+
"type": "object"
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## 参数说明
|
|
46
|
+
|
|
47
|
+
| 参数 | 类型 | 必填 | 说明 |
|
|
48
|
+
|---|---|---|---|
|
|
49
|
+
| docid | string | 与 url 二选一 | 文档的 docid |
|
|
50
|
+
| url | string | 与 docid 二选一 | 文档的访问链接 |
|
|
51
|
+
| type | integer | 是 | 内容返回格式,固定传 `2`(Markdown 格式) |
|
|
52
|
+
| task_id | string | 否 | 任务 ID,初次调用不填,后续轮询时填写上次返回的 task_id |
|
|
53
|
+
|
|
54
|
+
## 异步轮询机制
|
|
55
|
+
|
|
56
|
+
1. **首次调用**:传入 `docid`/`url` 和 `type: 2`,不传 `task_id`
|
|
57
|
+
2. **检查响应**:若 `task_done` 为 `false`,记录返回的 `task_id`
|
|
58
|
+
3. **轮询调用**:携带 `task_id` 再次调用,直到 `task_done` 为 `true`
|
|
59
|
+
4. **获取内容**:当 `task_done` 为 `true` 时,`content` 字段包含完整的 Markdown 内容
|
|
60
|
+
|
|
61
|
+
## 请求示例
|
|
62
|
+
|
|
63
|
+
```json
|
|
64
|
+
// 首次调用
|
|
65
|
+
{
|
|
66
|
+
"docid": "DOCID",
|
|
67
|
+
"type": 2
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// 轮询调用
|
|
71
|
+
{
|
|
72
|
+
"docid": "DOCID",
|
|
73
|
+
"type": 2,
|
|
74
|
+
"task_id": "xxx"
|
|
75
|
+
}
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
## 响应示例
|
|
79
|
+
|
|
80
|
+
```json
|
|
81
|
+
{
|
|
82
|
+
"errcode": 0,
|
|
83
|
+
"errmsg": "ok",
|
|
84
|
+
"content": "# 文档标题\n\n文档正文内容...",
|
|
85
|
+
"task_id": "xxxxx",
|
|
86
|
+
"task_done": true
|
|
87
|
+
}
|
|
88
|
+
```
|
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: wecom-edit-todo
|
|
3
|
+
description: 企业微信待办事项编辑技能,支持创建、更新、删除待办及变更用户处理进度状态。在用户说"帮我创建一个待办"、"把这个任务分派给张三"、"标记待办完成"、"删掉那个待办"、"帮我建个提醒"、"更新一下待办内容"、"把提醒时间改到下周"、"接受这个待办"、"拒绝这个待办"等需要对待办进行写操作的场景时使用。
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# 企业微信待办事项编辑技能
|
|
7
|
+
|
|
8
|
+
> `wecom_mcp` 是一个 MCP tool,所有操作通过调用该 tool 完成。
|
|
9
|
+
|
|
10
|
+
> ⚠️ **前置条件**:首次调用 `wecom_mcp` 前,必须按 `wecom-preflight` 技能执行前置条件检查,确保工具已加入白名单。
|
|
11
|
+
|
|
12
|
+
通过 `wecom_mcp` tool 对企业微信待办事项进行写操作,支持四种操作:创建待办、更新待办、删除待办、变更用户状态。
|
|
13
|
+
|
|
14
|
+
## 行为策略
|
|
15
|
+
|
|
16
|
+
**重试策略**: 遭遇"返回 HTTP 错误"或"HTTP 请求失败"时,主动重试,最多重试三次。
|
|
17
|
+
|
|
18
|
+
---
|
|
19
|
+
|
|
20
|
+
## 操作
|
|
21
|
+
|
|
22
|
+
### 1. 创建待办
|
|
23
|
+
|
|
24
|
+
创建一个新的待办事项,可指定内容、分派人和提醒时间:
|
|
25
|
+
|
|
26
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo create_todo '<json格式的入参>'`
|
|
27
|
+
|
|
28
|
+
**参数说明:**
|
|
29
|
+
|
|
30
|
+
需要遵循 “注意事项”中的格式要求:
|
|
31
|
+
|
|
32
|
+
| 参数 | 类型 | 必填 | 说明 |
|
|
33
|
+
|------|------|------|------|
|
|
34
|
+
| `content` | string | ✅ | 待办内容 |
|
|
35
|
+
| `follower_list` | object | ❌ | 分派人列表,格式见注意事项第 7 条 |
|
|
36
|
+
| `remind_time` | string | ❌ | 提醒时间,格式:`YYYY-MM-DD HH:mm:ss` |
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
**调用示例:**
|
|
40
|
+
|
|
41
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo create_todo '{"content": "<待办的内容>", "remind_time": "2025-06-01 09:00:00"}'`
|
|
42
|
+
|
|
43
|
+
**返回格式:**
|
|
44
|
+
|
|
45
|
+
```json
|
|
46
|
+
{
|
|
47
|
+
"errcode": 0,
|
|
48
|
+
"errmsg": "ok",
|
|
49
|
+
"todo_id": "TODO_ID"
|
|
50
|
+
}
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
---
|
|
54
|
+
|
|
55
|
+
### 2. 更新待办
|
|
56
|
+
|
|
57
|
+
修改已有待办事项的内容、分派人、状态或提醒时间:
|
|
58
|
+
|
|
59
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo update_todo '<json格式的入参>'`
|
|
60
|
+
|
|
61
|
+
**参数说明:**
|
|
62
|
+
|
|
63
|
+
需要遵循 “注意事项”中的格式要求:
|
|
64
|
+
|
|
65
|
+
| 参数 | 类型 | 必填 | 说明 |
|
|
66
|
+
|------|------|------|------|
|
|
67
|
+
| `todo_id` | string | ✅ | 待办 ID |
|
|
68
|
+
| `content` | string | ❌ | 新的待办内容 |
|
|
69
|
+
| `follower_list` | object | ❌ | 新的分派人列表(全量替换,非追加),格式见注意事项第 7 条。若要新增分派人,需先查出现有分派人,合并后一起提交 |
|
|
70
|
+
| `todo_status` | number | ❌ | 新的待办状态:`0`-已完成,`1`-进行中。删除请使用 `delete_todo` |
|
|
71
|
+
| `remind_time` | string | ❌ | 新的提醒时间 |
|
|
72
|
+
|
|
73
|
+
**调用示例:**
|
|
74
|
+
|
|
75
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo update_todo '{"todo_id": "TODO_ID", "content": "<待办的内容>", "remind_time": "2025-07-01 09:00:00"}'`
|
|
76
|
+
|
|
77
|
+
**返回格式:**
|
|
78
|
+
|
|
79
|
+
```json
|
|
80
|
+
{
|
|
81
|
+
"errcode": 0,
|
|
82
|
+
"errmsg": "ok"
|
|
83
|
+
}
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
---
|
|
87
|
+
|
|
88
|
+
### 3. 删除待办
|
|
89
|
+
|
|
90
|
+
删除指定的待办事项:
|
|
91
|
+
|
|
92
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo delete_todo '<json格式的入参>'`
|
|
93
|
+
|
|
94
|
+
**参数说明:**
|
|
95
|
+
|
|
96
|
+
需要遵循 “注意事项”中的格式要求:
|
|
97
|
+
|
|
98
|
+
| 参数 | 类型 | 必填 | 说明 |
|
|
99
|
+
|------|------|------|------|
|
|
100
|
+
| `todo_id` | string | ✅ | 待办 ID |
|
|
101
|
+
|
|
102
|
+
**调用示例:**
|
|
103
|
+
|
|
104
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo delete_todo '{"todo_id": "TODO_ID"}'`
|
|
105
|
+
|
|
106
|
+
**返回格式:**
|
|
107
|
+
|
|
108
|
+
```json
|
|
109
|
+
{
|
|
110
|
+
"errcode": 0,
|
|
111
|
+
"errmsg": "ok"
|
|
112
|
+
}
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
> 删除操作不可撤销,执行前应向用户确认。
|
|
116
|
+
> 注意:`delete_todo` 与 `update_todo` 设置 `todo_status=2` 效果相同,优先使用 `delete_todo`。
|
|
117
|
+
|
|
118
|
+
---
|
|
119
|
+
|
|
120
|
+
### 4. 变更用户待办状态
|
|
121
|
+
|
|
122
|
+
更改当前用户在某个待办中的状态(拒绝/接受/已完成):
|
|
123
|
+
|
|
124
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo change_todo_user_status '<json格式的入参>'`
|
|
125
|
+
|
|
126
|
+
**参数说明:**
|
|
127
|
+
|
|
128
|
+
需要遵循 “注意事项”中的格式要求:
|
|
129
|
+
|
|
130
|
+
| 参数 | 类型 | 必填 | 说明 |
|
|
131
|
+
|------|------|------|------|
|
|
132
|
+
| `todo_id` | string | ✅ | 待办 ID |
|
|
133
|
+
| `user_status` | number | ✅ | 用户状态:`0`-拒绝,`1`-接受,`2`-已完成 |
|
|
134
|
+
|
|
135
|
+
**调用示例:**
|
|
136
|
+
|
|
137
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo change_todo_user_status '{"todo_id": "TODO_ID", "user_status": 2}'`
|
|
138
|
+
|
|
139
|
+
**返回格式:**
|
|
140
|
+
|
|
141
|
+
```json
|
|
142
|
+
{
|
|
143
|
+
"errcode": 0,
|
|
144
|
+
"errmsg": "ok"
|
|
145
|
+
}
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
---
|
|
149
|
+
|
|
150
|
+
## 典型工作流
|
|
151
|
+
|
|
152
|
+
### 创建待办并分派给同事
|
|
153
|
+
|
|
154
|
+
用户问:"帮我创建一个待办,让张三下周一前完成需求文档"
|
|
155
|
+
|
|
156
|
+
1. 第一步:通过 wecom-contact-lookup 技能查询张三的 userid,在返回结果中筛选姓名为"张三"的成员,获取其 userid
|
|
157
|
+
2. 第二步:创建待办并分派,使用 `wecom_mcp` tool 调用 `wecom_mcp call todo create_todo '{"content": "<待办的内容>", "follower_list": {"followers": [{"follower_id": "zhangsan", "follower_status": 1}]}, "remind_time": "2025-03-24 09:00:00"}'`
|
|
158
|
+
|
|
159
|
+
> `follower_id` 必须来自 `wecom-contact-lookup` 技能的 `get_userlist` 接口返回的 `userid`,禁止自行猜测。若搜索结果有多个同名人员,需展示候选列表让用户确认。
|
|
160
|
+
|
|
161
|
+
### 标记待办完成
|
|
162
|
+
|
|
163
|
+
需要区分两种场景:**标记待办本身完成**(改 `todo_status`)和**标记我的参与状态为完成**(改 `user_status`)。
|
|
164
|
+
|
|
165
|
+
#### 场景 A:标记待办本身完成
|
|
166
|
+
|
|
167
|
+
用户问:"把'完成Q2规划文档'这个待办标记为完成" / "关闭这个待办"
|
|
168
|
+
|
|
169
|
+
1. 第一步:通过 wecom-get-todo-list 获取待办列表,找到目标待办的 todo_id。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_list '{}'`
|
|
170
|
+
2. 第二步:通过 wecom-get-todo-detail 获取详情,确认是目标待办。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '{"todo_id_list": ["TODO_ID"]}'`
|
|
171
|
+
3. 第三步:确认后,将待办状态改为已完成。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo update_todo '{"todo_id": "TODO_ID", "todo_status": 0}'`
|
|
172
|
+
|
|
173
|
+
#### 场景 B:标记我的参与状态为完成
|
|
174
|
+
|
|
175
|
+
用户问:"我已经完成了这个待办" / "标记我的部分为完成"
|
|
176
|
+
|
|
177
|
+
1. 第一步:通过 wecom-get-todo-list 获取待办列表,找到目标待办的 todo_id。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_list '{}'`
|
|
178
|
+
2. 第二步:通过 wecom-get-todo-detail 获取详情,确认是目标待办。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '{"todo_id_list": ["TODO_ID"]}'`
|
|
179
|
+
3. 第三步:确认后,变更当前用户的参与状态为已完成。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo change_todo_user_status '{"todo_id": "TODO_ID", "user_status": 2}'`
|
|
180
|
+
|
|
181
|
+
> **如何判断用户意图:** 如果用户说"标记完成"且该待办是自己创建的、没有其他分派人,通常指场景 A(标记待办本身完成)。如果该待办有多个参与人,用户可能只是想标记自己那部分完成(场景 B)。不确定时应向用户确认。
|
|
182
|
+
|
|
183
|
+
> 用户提供的是待办内容描述而非 ID,所以需要先通过 wecom-get-todo-list 和 wecom-get-todo-detail 查找再匹配。匹配到多个相似待办时,列出候选项让用户确认。
|
|
184
|
+
|
|
185
|
+
### 更新待办内容或提醒时间
|
|
186
|
+
|
|
187
|
+
用户问:"把那个需求文档的待办提醒时间改到下周五"
|
|
188
|
+
|
|
189
|
+
1. 第一步:查找目标待办。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_list '{}'`,再使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '{"todo_id_list": ["TODO_ID_1", "TODO_ID_2"]}'`
|
|
190
|
+
2. 第二步:确认目标后更新。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo update_todo '{"todo_id": "TODO_ID", "remind_time": "2025-03-28 09:00:00"}'`
|
|
191
|
+
|
|
192
|
+
### 删除待办
|
|
193
|
+
|
|
194
|
+
用户问:"删掉'代码评审'那个待办"
|
|
195
|
+
|
|
196
|
+
1. 第一步:查找目标待办。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_list '{}'`,再使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '{"todo_id_list": ["TODO_ID"]}'`
|
|
197
|
+
2. 第二步:向用户确认后删除。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo delete_todo '{"todo_id": "TODO_ID"}'`
|
|
198
|
+
|
|
199
|
+
> 删除前必须向用户确认,确认措辞示例:"确认删除待办'代码评审'吗?删除后不可恢复。"
|
|
200
|
+
|
|
201
|
+
---
|
|
202
|
+
|
|
203
|
+
## 注意事项
|
|
204
|
+
|
|
205
|
+
1. **todo_id 来源规则**
|
|
206
|
+
- `todo_id` 必须来自 `wecom-get-todo-list` 返回的结果,禁止自行推测或构造
|
|
207
|
+
- 用户通常提供待办内容描述而非 ID,应先通过 wecom-get-todo-list 查列表再匹配
|
|
208
|
+
- 若匹配到多个相似待办,展示候选列表让用户确认
|
|
209
|
+
|
|
210
|
+
2. **follower_id 来源规则**
|
|
211
|
+
- `follower_id` 即 `userid`,必须通过 `wecom-contact-lookup` 技能的 `get_userlist` 接口获取
|
|
212
|
+
- 禁止根据用户姓名自行猜测 userid
|
|
213
|
+
- 若搜索结果有多个同名人员,展示候选列表让用户选择
|
|
214
|
+
|
|
215
|
+
3. **时间格式**
|
|
216
|
+
- 所有时间参数使用 `YYYY-MM-DD HH:mm:ss` 格式
|
|
217
|
+
- 用户说"明天"、"下周一"等相对时间时,根据当前日期推算具体日期
|
|
218
|
+
|
|
219
|
+
4. **状态值含义**
|
|
220
|
+
- 待办状态(`todo_status`):`0`-已完成,`1`-进行中,`2`-已删除
|
|
221
|
+
- 用户状态(`user_status`):`0`-拒绝,`1`-接受,`2`-已完成
|
|
222
|
+
- 分派人状态(`follower_status`):`0`-拒绝,`1`-接受,`2`-已完成
|
|
223
|
+
|
|
224
|
+
5. **破坏性操作确认**
|
|
225
|
+
- 删除待办(`delete_todo`)前必须向用户确认
|
|
226
|
+
- 变更状态为"拒绝"(`user_status=0`)前建议向用户确认
|
|
227
|
+
|
|
228
|
+
6. **错误处理**
|
|
229
|
+
- 若 `errcode` 不为 `0`,说明接口调用失败,告知用户 `errmsg` 中的错误信息
|
|
230
|
+
|
|
231
|
+
7. **follower_list** 的格式(作为输入参数的时候)
|
|
232
|
+
|
|
233
|
+
```json
|
|
234
|
+
"follower_list": { // 分派人列表
|
|
235
|
+
"followers": [ // 注意里面还有一层是 "followers",它的value才是真正的列表数组
|
|
236
|
+
{
|
|
237
|
+
"follower_id": "FOLLOWER_ID", // 分派人id
|
|
238
|
+
"follower_status": 1 // 分派人状态:0-拒绝, 1-接受, 2-已完成
|
|
239
|
+
}
|
|
240
|
+
]
|
|
241
|
+
}
|
|
242
|
+
```
|
|
243
|
+
> `follower_id` 即 userid,需要通过 `wecom-contact-lookup` 查询获取,禁止自行猜测或构造。
|
|
244
|
+
|
|
245
|
+
## 相关技能
|
|
246
|
+
|
|
247
|
+
- **获取待办列表**:`wecom-get-todo-list` — 查询待办概要列表,获取 todo_id
|
|
248
|
+
- **获取待办详情**:`wecom-get-todo-detail` — 根据 todo_id 获取完整内容
|
|
249
|
+
- **通讯录查询**:`wecom-contact-lookup` 的 `get_userlist` — 获取成员 userid,用于 `follower_id`
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: wecom-get-todo-detail
|
|
3
|
+
description: 企业微信待办详情批量查询技能,根据待办 ID 列表获取完整信息(包含待办内容和分派人)。在用户说"看看这个待办的详情"、"待办内容是什么"、"这个待办分派给谁了"、"告诉我待办的具体信息"等需要查看待办完整内容的场景时使用。通常配合 wecom-get-todo-list 使用——先获取待办 ID 列表,再用本技能获取详情。
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# 企业微信待办详情查询技能
|
|
7
|
+
|
|
8
|
+
> `wecom_mcp` 是一个 MCP tool,所有操作通过调用该 tool 完成。
|
|
9
|
+
|
|
10
|
+
> ⚠️ **前置条件**:首次调用 `wecom_mcp` 前,必须按 `wecom-preflight` 技能执行前置条件检查,确保工具已加入白名单。
|
|
11
|
+
|
|
12
|
+
通过 `wecom_mcp` tool 根据待办 ID 列表批量查询完整详情,包含待办内容和分派人信息。
|
|
13
|
+
|
|
14
|
+
## 行为策略
|
|
15
|
+
|
|
16
|
+
**人员 ID 转姓名(关键步骤)**: 返回结果中的 `follower_id` 和 `creator_id` 都是系统内部 ID,直接展示给用户毫无意义——用户不认识这些 ID,只认识姓名。因此在向用户展示待办详情之前,必须先调用 `wecom-contact-lookup` 技能获取通讯录,将所有 `follower_id` 和 `creator_id` 匹配为真实姓名。具体做法:
|
|
17
|
+
|
|
18
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call contact get_userlist '{}'` 获取通讯录,在返回的 userlist 中,用 userid 字段匹配 follower_id / creator_id,取对应的 name。
|
|
19
|
+
|
|
20
|
+
如果通讯录中找不到某个 ID,展示时标注"未知用户(ID: xxx)"即可。
|
|
21
|
+
|
|
22
|
+
**重试策略**: 遭遇"返回 HTTP 错误"或"HTTP 请求失败"时,主动重试,最多重试三次。
|
|
23
|
+
|
|
24
|
+
---
|
|
25
|
+
|
|
26
|
+
## 调用方式
|
|
27
|
+
|
|
28
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '<json格式的入参>'`
|
|
29
|
+
|
|
30
|
+
## 参数说明
|
|
31
|
+
|
|
32
|
+
| 参数 | 类型 | 必填 | 说明 |
|
|
33
|
+
|------|------|------|------|
|
|
34
|
+
| `todo_id_list` | array | ✅ | 待办 ID 列表,最多 20 个 |
|
|
35
|
+
|
|
36
|
+
**调用示例:**
|
|
37
|
+
|
|
38
|
+
使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '{"todo_id_list": ["TODO_ID_1", "TODO_ID_2"]}'`
|
|
39
|
+
|
|
40
|
+
## 返回格式
|
|
41
|
+
|
|
42
|
+
```json
|
|
43
|
+
{
|
|
44
|
+
"errcode": 0,
|
|
45
|
+
"errmsg": "ok",
|
|
46
|
+
"data_list": [
|
|
47
|
+
{
|
|
48
|
+
"todo_id": "TODO_ID",
|
|
49
|
+
"todo_status": 1,
|
|
50
|
+
"content": "完成Q2规划文档",
|
|
51
|
+
"follower_list": {
|
|
52
|
+
"followers": [
|
|
53
|
+
{
|
|
54
|
+
"follower_id": "FOLLOWER_ID",
|
|
55
|
+
"follower_status": 1,
|
|
56
|
+
"update_time": "2025-01-16 14:20:00"
|
|
57
|
+
}
|
|
58
|
+
]
|
|
59
|
+
},
|
|
60
|
+
"creator_id": "CREATOR_ID",
|
|
61
|
+
"user_status": 1,
|
|
62
|
+
"remind_time": "2025-06-01 09:00:00",
|
|
63
|
+
"create_time": "2025-01-15 10:30:00",
|
|
64
|
+
"update_time": "2025-01-16 14:20:00"
|
|
65
|
+
}
|
|
66
|
+
]
|
|
67
|
+
}
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
## 返回字段说明
|
|
71
|
+
|
|
72
|
+
| 字段 | 类型 | 说明 |
|
|
73
|
+
|------|------|------|
|
|
74
|
+
| `data_list` | array | 待办详情列表,最多 20 条 |
|
|
75
|
+
| `data_list[].todo_id` | string | 待办 ID |
|
|
76
|
+
| `data_list[].todo_status` | number | 待办状态:`0`-已完成,`1`-进行中,`2`-已删除 |
|
|
77
|
+
| `data_list[].content` | string | 待办内容 |
|
|
78
|
+
| `data_list[].follower_list.followers` | array | 分派人列表 |
|
|
79
|
+
| `data_list[].follower_list.followers[].follower_id` | string | 分派人 ID(即 userid)— **展示前需通过 wecom-contact-lookup 转为姓名** |
|
|
80
|
+
| `data_list[].follower_list.followers[].follower_status` | number | 分派人状态:`0`-拒绝,`1`-接受,`2`-已完成 |
|
|
81
|
+
| `data_list[].follower_list.followers[].update_time` | string | 分派人状态更新时间 |
|
|
82
|
+
| `data_list[].creator_id` | string | 创建人 ID — **展示前需通过 wecom-contact-lookup 转为姓名** |
|
|
83
|
+
| `data_list[].user_status` | number | 当前用户状态 |
|
|
84
|
+
| `data_list[].remind_time` | string | 提醒时间 |
|
|
85
|
+
| `data_list[].create_time` | string | 创建时间 |
|
|
86
|
+
| `data_list[].update_time` | string | 更新时间 |
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## 典型工作流
|
|
91
|
+
|
|
92
|
+
### 列表 + 详情联合查询(三步缺一不可)
|
|
93
|
+
|
|
94
|
+
用户问:"看看我最近的待办" / "我有哪些待办事项?"
|
|
95
|
+
|
|
96
|
+
1. 第一步:通过 wecom-get-todo-list 获取待办列表。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_list '{}'`
|
|
97
|
+
2. 第二步:根据返回的 todo_id 批量获取详情。使用 `wecom_mcp` tool 调用 `wecom_mcp call todo get_todo_detail '{"todo_id_list": ["TODO_ID_1", "TODO_ID_2", "TODO_ID_3"]}'`
|
|
98
|
+
3. 第三步(不要跳过!):通过 wecom-contact-lookup 获取通讯录,将 follower_id / creator_id 转为姓名。用返回的 userlist 中的 userid 匹配 follower_id 和 creator_id,取 name 字段作为展示姓名
|
|
99
|
+
|
|
100
|
+
> 第三步是展示可读结果的前提。没有这一步,用户看到的是一串无意义的 ID 而非姓名。
|
|
101
|
+
|
|
102
|
+
**展示格式(注意:分派人和创建人必须显示为姓名,不是 ID):**
|
|
103
|
+
|
|
104
|
+
```
|
|
105
|
+
📋 您当前的待办事项(共 3 项)
|
|
106
|
+
|
|
107
|
+
1. 🔵 完成Q2规划文档
|
|
108
|
+
- 待办状态:进行中 | 我的状态:已接受
|
|
109
|
+
- 提醒时间:2025-06-01 09:00
|
|
110
|
+
- 分派人:张三、李四
|
|
111
|
+
- 创建时间:2025-01-15
|
|
112
|
+
|
|
113
|
+
2. 🔵 提交周报
|
|
114
|
+
- 待办状态:进行中 | 我的状态:已接受
|
|
115
|
+
- 提醒时间:2025-03-17 18:00
|
|
116
|
+
- 创建时间:2025-03-10
|
|
117
|
+
|
|
118
|
+
3. ☑️ 代码评审
|
|
119
|
+
- 待办状态:已完成 | 我的状态:已完成
|
|
120
|
+
- 创建时间:2025-03-01
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
---
|
|
124
|
+
|
|
125
|
+
## 注意事项
|
|
126
|
+
|
|
127
|
+
1. **人员 ID 必须转姓名**
|
|
128
|
+
- 返回结果中的 `follower_id` 和 `creator_id` 是系统内部标识,用户无法识别
|
|
129
|
+
- 展示待办详情前,先使用 `wecom_mcp` tool 调用 `wecom_mcp call contact get_userlist '{}'` 获取通讯录
|
|
130
|
+
- 用通讯录的 `userid` 匹配 `follower_id` / `creator_id`,用 `name` 替换展示
|
|
131
|
+
|
|
132
|
+
2. **todo_id 来源规则**
|
|
133
|
+
- `todo_id` 必须来自 `wecom-get-todo-list` 返回的结果,禁止自行推测或构造
|
|
134
|
+
- 用户通常提供待办内容描述而非 ID,应先通过 `wecom-get-todo-list` 查列表再匹配
|
|
135
|
+
|
|
136
|
+
3. **状态值含义**
|
|
137
|
+
- 待办状态(`todo_status`):`0`-已完成,`1`-进行中,`2`-已删除
|
|
138
|
+
- 用户状态(`user_status`):`0`-拒绝,`1`-接受,`2`-已完成
|
|
139
|
+
- 分派人状态(`follower_status`):`0`-拒绝,`1`-接受,`2`-已完成
|
|
140
|
+
|
|
141
|
+
4. **错误处理**:若 `errcode` 不为 `0`,告知用户 `errmsg` 中的错误信息
|
|
142
|
+
|
|
143
|
+
5. **单次上限**:`todo_id_list` 最多传 20 个 ID,超过需要分批请求
|