sophhub 0.4.7 → 0.4.9
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/package.json +1 -1
- package/skills/bot-api-status/skill.json +10 -2
- package/skills/bot-api-status/src/SKILL.md +11 -1
- package/skills/bot-api-status/src/pyproject.toml +1 -1
- package/skills/bot-api-status/src/scripts/secret.py +17 -1
- package/skills/claw-agent-get-send/skill.json +21 -0
- package/skills/claw-agent-get-send/src/SKILL.md +72 -0
- package/skills/claw-agent-get-send/src/pyproject.toml +5 -0
- package/skills/claw-agent-get-send/src/reference-http.md +149 -0
- package/skills/claw-agent-get-send/src/scripts/appia_claw.py +287 -0
- package/skills/share-skill/skill.json +20 -0
- package/skills/share-skill/src/SKILL.md +261 -0
- package/skills/share-skill/src/scripts/share_skill_to_friend.py +1031 -0
- package/skills/sophnet-qa-install/skill.json +13 -6
- package/skills/sophnet-training-install/skill.json +13 -6
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: share-skill
|
|
3
|
+
description: 列出当前用户容器中实际安装的 Skill,按 openclaw skills list 返回的 source 字段分组,引导用户选择 Skill、选择虾友后直接发送 web 格式 Skill 分享卡片。Use when the user asks to share or introduce an installed Skill to a Sophclaw friend / 虾友.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# 向虾友介绍 Skill
|
|
7
|
+
|
|
8
|
+
用于把当前容器里实际安装的某个 Skill 按 web 前端一致的 Skill 分享卡片格式发送给虾友。必须按顺序执行:**选择 Skill → 选择虾友 → 直接发送**。
|
|
9
|
+
|
|
10
|
+
## Processing Mode
|
|
11
|
+
|
|
12
|
+
**STRICT SERIAL PROCESSING ONLY** — 不并行发送;用户选定 Skill 和虾友后直接发送,不再追加确认步骤。
|
|
13
|
+
|
|
14
|
+
## Prerequisites
|
|
15
|
+
|
|
16
|
+
- Python 3.10+、uv
|
|
17
|
+
- 本机存在有效 JWT:`/home/node/.openclaw/jwt.json`
|
|
18
|
+
- 能执行 `openclaw skills list --json`;如环境命令名不同,用脚本参数 `--skills-command` 指定
|
|
19
|
+
- 能执行 `openclaw skills info <name> --json`;如环境命令名不同,用脚本参数 `--skill-info-command-template` 指定
|
|
20
|
+
- 虾友接口与 DM 发送接口可访问,默认 API base URL:`https://yagent.sophnet.com/api`
|
|
21
|
+
- **所有脚本调用均使用 `uv run`**,不要直接用 `python`。
|
|
22
|
+
|
|
23
|
+
## 脚本入口
|
|
24
|
+
|
|
25
|
+
`{baseDir}` 为本 Skill 根目录:
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py <command> [args...]
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
常用命令:
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py list-skills
|
|
35
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py list-friends
|
|
36
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py send --skill "<skill-name>" --friend-id <id> --friend-name "<name>"
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
脚本会优先解析 JSON;如果 OpenClaw 命令输出包含 banner/config warnings,会自动从噪声中提取 JSON;如果实际拿到的是 `openclaw skills list` 的表格输出,也会尽量解析表格中的 Skill 名称、描述、状态和 Source。展示标签直接使用返回的 `source` 字段。
|
|
40
|
+
|
|
41
|
+
## Step 1:选择 Skill
|
|
42
|
+
|
|
43
|
+
先执行:
|
|
44
|
+
|
|
45
|
+
```bash
|
|
46
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py list-skills
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
输出 JSON:
|
|
50
|
+
|
|
51
|
+
```json
|
|
52
|
+
{
|
|
53
|
+
"skills": [
|
|
54
|
+
{
|
|
55
|
+
"index": 1,
|
|
56
|
+
"name": "image-classify",
|
|
57
|
+
"description": "照片分类器。通过人脸识别对照片进行分类、搜索和管理。",
|
|
58
|
+
"tag": "openclaw-workspace",
|
|
59
|
+
"status": "可用"
|
|
60
|
+
}
|
|
61
|
+
],
|
|
62
|
+
"groups": [
|
|
63
|
+
{ "tag": "openclaw-workspace", "collapsedByDefault": false, "count": 1, "skills": [] },
|
|
64
|
+
{ "tag": "openclaw-managed", "collapsedByDefault": false, "count": 0, "skills": [] },
|
|
65
|
+
{ "tag": "openclaw-bundled", "collapsedByDefault": true, "count": 0, "skills": [] }
|
|
66
|
+
]
|
|
67
|
+
}
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
向用户展示时使用以下格式。若 `description` 不是中文,先改写成自然中文再展示:
|
|
71
|
+
|
|
72
|
+
```text
|
|
73
|
+
🧩 **请选择要介绍给虾友的 Skill**
|
|
74
|
+
|
|
75
|
+
1️⃣ **<name>**
|
|
76
|
+
📝 功能:<中文 description>
|
|
77
|
+
|
|
78
|
+
2️⃣ **<name>**
|
|
79
|
+
📝 功能:<中文 description>
|
|
80
|
+
|
|
81
|
+
...
|
|
82
|
+
|
|
83
|
+
📦 **其他内置 skill**(共 <count> 个,已折叠)
|
|
84
|
+
包含 openclaw-bundled、agents-skills-personal 等来源的 skill
|
|
85
|
+
|
|
86
|
+
💬 请回复 **序号** 或 **Skill 名称**。
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
**展示规则:**
|
|
90
|
+
|
|
91
|
+
1. `openclaw-workspace` 和 `openclaw-managed` 的 skill 直接列出,**不显示分组标题**
|
|
92
|
+
2. `openclaw-bundled` 和 `agents-skills-personal` 归入"其他内置 skill"分组,默认折叠
|
|
93
|
+
3. 其它 source 如出现,也归入"其他内置 skill"分组
|
|
94
|
+
4. 标签(如 `[openclaw-workspace]`)**不显示**,保持界面简洁
|
|
95
|
+
5. 排序:openclaw-workspace → openclaw-managed → 其他内置 skill
|
|
96
|
+
|
|
97
|
+
## Step 2:选择虾友
|
|
98
|
+
|
|
99
|
+
用户选定 Skill 后执行:
|
|
100
|
+
|
|
101
|
+
```bash
|
|
102
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py list-friends
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
输出 JSON:
|
|
106
|
+
|
|
107
|
+
```json
|
|
108
|
+
{
|
|
109
|
+
"friends": [
|
|
110
|
+
{
|
|
111
|
+
"index": 1,
|
|
112
|
+
"friendId": 23725,
|
|
113
|
+
"displayName": "小李",
|
|
114
|
+
"levelName": "Sophclaw 虾友"
|
|
115
|
+
}
|
|
116
|
+
]
|
|
117
|
+
}
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
只展示非官方客服的虾友,使用以下格式:
|
|
121
|
+
|
|
122
|
+
```text
|
|
123
|
+
🦞 **请选择要发送给哪位虾友**
|
|
124
|
+
|
|
125
|
+
1️⃣ **<displayName>**
|
|
126
|
+
🌟 <levelIcon> <levelName>
|
|
127
|
+
|
|
128
|
+
2️⃣ **<displayName>**
|
|
129
|
+
🌟 <levelIcon> <levelName>
|
|
130
|
+
|
|
131
|
+
💬 请回复 **序号** 或 **虾友昵称/备注**。
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
`displayName` 的生成规则:优先使用虾友备注名 `remark`,没有备注时使用昵称 `nickname`,都没有时显示「未命名虾友」。内部保留 `friendId` 供脚本调用,但**不要向用户展示虾友号**。如果昵称重复,只用列表序号区分,并可提示用户按序号选择。
|
|
135
|
+
|
|
136
|
+
## Step 3:发送(含敏感信息确认)
|
|
137
|
+
|
|
138
|
+
用户选定虾友后,发送自定义 Skill 前,脚本会先扫描 Skill 目录是否包含私钥、token、`.env`、凭据文件等秘钥相关敏感信息。
|
|
139
|
+
|
|
140
|
+
### 敏感信息检测
|
|
141
|
+
|
|
142
|
+
脚本会检测以下敏感信息:
|
|
143
|
+
- 敏感文件名:`.env`、`.env.local`、`credentials.json`、`id_rsa` 等
|
|
144
|
+
- 敏感文件后缀:`.pem`、`.key`、`.p12`、`.pfx` 等
|
|
145
|
+
- 敏感文件名关键词:`token`、`secret`、`password`、`credential`、`private_key` 等
|
|
146
|
+
- 文件内容:私钥块、AWS Access Key、GitHub Token、Slack Token、JWT 等
|
|
147
|
+
|
|
148
|
+
### 发送流程
|
|
149
|
+
|
|
150
|
+
首次发送(不带 `--allow-sensitive`):
|
|
151
|
+
|
|
152
|
+
```bash
|
|
153
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py send \
|
|
154
|
+
--skill "<skill-name>" \
|
|
155
|
+
--friend-id <friendId> \
|
|
156
|
+
--friend-name "<display-name>" \
|
|
157
|
+
--description-zh "<中文功能介绍>"
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
如果检测到敏感信息,脚本会返回错误:
|
|
161
|
+
|
|
162
|
+
```json
|
|
163
|
+
{
|
|
164
|
+
"error": "检测到要分享的 Skill 目录中可能包含秘钥相关敏感信息。\n命中项:\n- resources/bearer_token.txt: 文件名包含敏感关键词: token\n\n如需继续发送,请添加 --allow-sensitive 参数确认。"
|
|
165
|
+
}
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
**此时 Agent 应向用户展示敏感信息列表,询问是否确认发送:**
|
|
169
|
+
|
|
170
|
+
```text
|
|
171
|
+
━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━
|
|
172
|
+
|
|
173
|
+
🚨 **安全警告:检测到敏感信息**
|
|
174
|
+
|
|
175
|
+
该 Skill 包含以下敏感内容,分享后接收方将获得完整访问权限:
|
|
176
|
+
|
|
177
|
+
| 文件路径 | 检测原因 |
|
|
178
|
+
|----------------------------------|------------------------------|
|
|
179
|
+
| `resources/bearer_token.txt` | 文件名包含敏感关键词: token |
|
|
180
|
+
| `scripts/send_email.py` | 疑似秘钥字段赋值 |
|
|
181
|
+
|
|
182
|
+
⚠️ **风险提示**
|
|
183
|
+
• 接收方将获得这些敏感文件的完整内容
|
|
184
|
+
• 可能导致凭据泄露、API 被滥用等安全风险
|
|
185
|
+
• 建议仅在确认接收方完全可信的情况下发送
|
|
186
|
+
|
|
187
|
+
💬 请回复 **「确认发送」** 继续发送,或回复 **「取消」** 返回。
|
|
188
|
+
|
|
189
|
+
━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━ ━
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
**注意:** 表格使用标准 Markdown 格式 `| 列1 | 列2 |`,便于阅读和对齐。
|
|
193
|
+
|
|
194
|
+
用户确认后,使用 `--allow-sensitive` 参数重新发送:
|
|
195
|
+
|
|
196
|
+
```bash
|
|
197
|
+
uv run {baseDir}/scripts/share_skill_to_friend.py send \
|
|
198
|
+
--skill "<skill-name>" \
|
|
199
|
+
--friend-id <friendId> \
|
|
200
|
+
--friend-name "<display-name>" \
|
|
201
|
+
--description-zh "<中文功能介绍>" \
|
|
202
|
+
--allow-sensitive
|
|
203
|
+
```
|
|
204
|
+
|
|
205
|
+
### 发送结果
|
|
206
|
+
|
|
207
|
+
发送成功后返回:
|
|
208
|
+
|
|
209
|
+
```json
|
|
210
|
+
{
|
|
211
|
+
"success": true,
|
|
212
|
+
"skill": "operations-dashboard",
|
|
213
|
+
"friend": { "friendId": 34200, "displayName": "黄志举" },
|
|
214
|
+
"messageId": "<message-id>",
|
|
215
|
+
"message": "📝 功能介绍:...\n[claw-skill-share]\n{\"v\":1,...}\n[/claw-skill-share]"
|
|
216
|
+
}
|
|
217
|
+
```
|
|
218
|
+
|
|
219
|
+
Agent 应向用户提示:
|
|
220
|
+
|
|
221
|
+
```text
|
|
222
|
+
✅已发送 `operations-dashboard` skill 给虾友「黄志举」
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
如果包含敏感信息,返回结果会额外包含 `sensitiveFindings` 和 `sensitiveWarning` 字段:
|
|
226
|
+
|
|
227
|
+
```json
|
|
228
|
+
{
|
|
229
|
+
"success": true,
|
|
230
|
+
"skill": "operations-dashboard",
|
|
231
|
+
"friend": { "friendId": 34200, "displayName": "黄志举" },
|
|
232
|
+
"messageId": "<message-id>",
|
|
233
|
+
"sensitiveFindings": [
|
|
234
|
+
{ "path": "resources/bearer_token.txt", "reason": "文件名包含敏感关键词: token" }
|
|
235
|
+
],
|
|
236
|
+
"sensitiveWarning": "已发送包含敏感信息的 Skill,请确认接收方可信"
|
|
237
|
+
}
|
|
238
|
+
```
|
|
239
|
+
|
|
240
|
+
如果包含敏感信息,Agent 应在成功提示中提醒用户:
|
|
241
|
+
|
|
242
|
+
```text
|
|
243
|
+
✅已发送 `operations-dashboard` skill 给虾友「黄志举」
|
|
244
|
+
|
|
245
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
246
|
+
⚠️ **安全提醒**
|
|
247
|
+
该 Skill 已包含敏感文件一并发送给接收方:
|
|
248
|
+
• `resources/bearer_token.txt`
|
|
249
|
+
|
|
250
|
+
请确认接收方可信,必要时建议轮换相关凭据。
|
|
251
|
+
━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
252
|
+
```
|
|
253
|
+
|
|
254
|
+
## Safety
|
|
255
|
+
|
|
256
|
+
- 发送消息必须使用 web 前端一致的 `[claw-skill-share]` 卡片格式。
|
|
257
|
+
- 用户侧输出不展示内部 JSON、`packageUrl`、本地文件路径、密钥或环境变量值。
|
|
258
|
+
- 分享自定义 Skill 前会扫描敏感信息;命中时必须让用户确认后才可发送。
|
|
259
|
+
- 敏感信息检测到的文件路径和原因可向用户展示,但**不要展示文件内容或密钥值**。
|
|
260
|
+
- 不要替用户猜测虾友;必须让用户从列表中选择,或在用户主动提供时内部使用 `friendId`。
|
|
261
|
+
- 用户侧输出中不要展示虾友号 / `friendId`。
|