@zhin.js/adapter-onebot11 1.0.18 → 1.0.19
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/CHANGELOG.md +6 -0
- package/README.md +345 -41
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
package/README.md
CHANGED
|
@@ -1,25 +1,28 @@
|
|
|
1
1
|
# @zhin.js/adapter-onebot11
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
Zhin.js OneBot v11 协议适配器,通过 WebSocket 连接各种支持 OneBot 协议的 QQ 机器人实现(如 go-cqhttp、Shamrock、LagrangeGo 等)。
|
|
4
4
|
|
|
5
5
|
## 功能特性
|
|
6
6
|
|
|
7
|
-
- 🔌 OneBot v11 协议兼容
|
|
8
|
-
- 🌐 WebSocket
|
|
9
|
-
- 🔐 Token 认证支持
|
|
7
|
+
- 🔌 完整 OneBot v11 协议兼容
|
|
8
|
+
- 🌐 WebSocket 客户端和服务器模式
|
|
9
|
+
- 🔐 Access Token 认证支持
|
|
10
10
|
- 🔄 自动重连机制
|
|
11
11
|
- 💓 心跳检测
|
|
12
12
|
- 📨 群聊和私聊消息处理
|
|
13
|
-
- 🛠️ 完整的API调用支持
|
|
13
|
+
- 🛠️ 完整的 API 调用支持
|
|
14
|
+
- 📝 消息段(Message Segment)完整支持
|
|
14
15
|
|
|
15
16
|
## 安装
|
|
16
17
|
|
|
17
18
|
```bash
|
|
18
|
-
|
|
19
|
+
pnpm add @zhin.js/adapter-onebot11 ws
|
|
19
20
|
```
|
|
20
21
|
|
|
21
22
|
## 配置
|
|
22
23
|
|
|
24
|
+
### WebSocket 客户端模式(正向 WS)
|
|
25
|
+
|
|
23
26
|
```typescript
|
|
24
27
|
// zhin.config.ts
|
|
25
28
|
import { defineConfig } from 'zhin.js'
|
|
@@ -28,58 +31,359 @@ export default defineConfig({
|
|
|
28
31
|
bots: [
|
|
29
32
|
{
|
|
30
33
|
context: 'onebot11',
|
|
31
|
-
|
|
32
|
-
|
|
34
|
+
type: 'ws', // WebSocket 客户端
|
|
35
|
+
name: 'my-bot',
|
|
36
|
+
url: 'ws://localhost:8080', // OneBot 服务地址
|
|
33
37
|
access_token: process.env.ONEBOT_TOKEN, // 访问令牌(可选)
|
|
34
|
-
reconnect_interval: 5000,
|
|
35
|
-
heartbeat_interval: 30000
|
|
38
|
+
reconnect_interval: 5000, // 重连间隔(毫秒)
|
|
39
|
+
heartbeat_interval: 30000 // 心跳间隔(毫秒)
|
|
36
40
|
}
|
|
37
41
|
],
|
|
38
|
-
plugins: [
|
|
42
|
+
plugins: [
|
|
43
|
+
'adapter-onebot11'
|
|
44
|
+
]
|
|
45
|
+
})
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
### WebSocket 服务器模式(反向 WS)
|
|
49
|
+
|
|
50
|
+
```typescript
|
|
51
|
+
export default defineConfig({
|
|
52
|
+
bots: [
|
|
53
|
+
{
|
|
54
|
+
context: 'onebot11.wss', // WebSocket 服务器
|
|
55
|
+
type: 'ws_reverse',
|
|
56
|
+
name: 'my-bot',
|
|
57
|
+
path: '/onebot/ws', // WebSocket 路径
|
|
58
|
+
access_token: process.env.ONEBOT_TOKEN, // 访问令牌(可选)
|
|
59
|
+
heartbeat_interval: 30000
|
|
60
|
+
}
|
|
61
|
+
],
|
|
62
|
+
plugins: [
|
|
63
|
+
'http', // 需要 HTTP 服务
|
|
64
|
+
'adapter-onebot11'
|
|
65
|
+
]
|
|
66
|
+
})
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## 支持的 OneBot 实现
|
|
70
|
+
|
|
71
|
+
### 推荐实现
|
|
72
|
+
|
|
73
|
+
| 实现 | 协议支持 | 稳定性 | 推荐度 |
|
|
74
|
+
|------|---------|--------|--------|
|
|
75
|
+
| [go-cqhttp](https://github.com/Mrs4s/go-cqhttp) | ✅ 完整 | ⭐⭐⭐⭐⭐ | 高 |
|
|
76
|
+
| [LagrangeGo](https://github.com/LagrangeDev/Lagrange.Core) | ✅ 完整 | ⭐⭐⭐⭐ | 高 |
|
|
77
|
+
| [Shamrock](https://github.com/whitechi73/OpenShamrock) | ✅ 完整 | ⭐⭐⭐⭐ | 中 |
|
|
78
|
+
| [NapCat](https://github.com/NapNeko/NapCatQQ) | ✅ 完整 | ⭐⭐⭐⭐ | 中 |
|
|
79
|
+
|
|
80
|
+
### 配置示例
|
|
81
|
+
|
|
82
|
+
#### go-cqhttp
|
|
83
|
+
|
|
84
|
+
```yaml
|
|
85
|
+
# config.yml
|
|
86
|
+
servers:
|
|
87
|
+
- ws:
|
|
88
|
+
host: 0.0.0.0
|
|
89
|
+
port: 8080
|
|
90
|
+
access-token: "your_token_here"
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
#### Shamrock
|
|
94
|
+
|
|
95
|
+
在 Shamrock 设置中:
|
|
96
|
+
1. 启用 WebSocket 服务
|
|
97
|
+
2. 设置端口(默认 5800)
|
|
98
|
+
3. 配置 Access Token(可选)
|
|
99
|
+
|
|
100
|
+
## 使用示例
|
|
101
|
+
|
|
102
|
+
### 基础消息处理
|
|
103
|
+
|
|
104
|
+
```typescript
|
|
105
|
+
import { addCommand, MessageCommand } from 'zhin.js'
|
|
106
|
+
|
|
107
|
+
addCommand(new MessageCommand('hello <name:text>')
|
|
108
|
+
.action(async (message, result) => {
|
|
109
|
+
return `你好,${result.params.name}!`
|
|
110
|
+
})
|
|
111
|
+
)
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
### 群聊消息
|
|
115
|
+
|
|
116
|
+
```typescript
|
|
117
|
+
import { onGroupMessage } from 'zhin.js'
|
|
118
|
+
|
|
119
|
+
onGroupMessage(async (message) => {
|
|
120
|
+
console.log(`群 ${message.$channel.id} 收到消息`)
|
|
121
|
+
await message.$reply('收到了!')
|
|
122
|
+
})
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
### 私聊消息
|
|
126
|
+
|
|
127
|
+
```typescript
|
|
128
|
+
import { onPrivateMessage } from 'zhin.js'
|
|
129
|
+
|
|
130
|
+
onPrivateMessage(async (message) => {
|
|
131
|
+
await message.$reply('你好!')
|
|
132
|
+
})
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
### 发送图片
|
|
136
|
+
|
|
137
|
+
```typescript
|
|
138
|
+
addCommand(new MessageCommand('pic <url:text>')
|
|
139
|
+
.action(async (message, result) => {
|
|
140
|
+
return [
|
|
141
|
+
{ type: 'image', data: { file: result.params.url } }
|
|
142
|
+
]
|
|
143
|
+
})
|
|
144
|
+
)
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
### 使用 CQ 码
|
|
148
|
+
|
|
149
|
+
```typescript
|
|
150
|
+
addCommand(new MessageCommand('cq')
|
|
151
|
+
.action(async (message) => {
|
|
152
|
+
return [
|
|
153
|
+
{ type: 'face', data: { id: '123' } },
|
|
154
|
+
{ type: 'text', data: { text: '表情' } }
|
|
155
|
+
]
|
|
156
|
+
})
|
|
157
|
+
)
|
|
158
|
+
```
|
|
159
|
+
|
|
160
|
+
## 消息类型支持
|
|
161
|
+
|
|
162
|
+
### 接收消息类型
|
|
163
|
+
|
|
164
|
+
- ✅ 文本消息(text)
|
|
165
|
+
- ✅ 图片消息(image)
|
|
166
|
+
- ✅ 语音消息(record)
|
|
167
|
+
- ✅ 视频消息(video)
|
|
168
|
+
- ✅ @ 提及(at)
|
|
169
|
+
- ✅ 表情(face)
|
|
170
|
+
- ✅ 引用回复(reply)
|
|
171
|
+
- ✅ 戳一戳(poke)
|
|
172
|
+
- ✅ 分享(share)
|
|
173
|
+
- ✅ 位置(location)
|
|
174
|
+
- ✅ 音乐分享(music)
|
|
175
|
+
- ✅ JSON 卡片(json)
|
|
176
|
+
- ✅ XML 卡片(xml)
|
|
177
|
+
|
|
178
|
+
### 发送消息类型
|
|
179
|
+
|
|
180
|
+
- ✅ 文本消息
|
|
181
|
+
- ✅ 图片消息(支持 URL、Base64、本地文件)
|
|
182
|
+
- ✅ 语音消息
|
|
183
|
+
- ✅ 视频消息
|
|
184
|
+
- ✅ @ 提及
|
|
185
|
+
- ✅ 表情
|
|
186
|
+
- ✅ 引用回复
|
|
187
|
+
- ✅ 戳一戳
|
|
188
|
+
- ✅ 分享卡片
|
|
189
|
+
- ✅ 音乐分享
|
|
190
|
+
- ✅ JSON/XML 卡片
|
|
191
|
+
|
|
192
|
+
## API 方法
|
|
193
|
+
|
|
194
|
+
### 消息相关
|
|
195
|
+
|
|
196
|
+
```typescript
|
|
197
|
+
const bot = app.adapters.get('onebot11')?.bots.get('my-bot')
|
|
198
|
+
|
|
199
|
+
// 发送群消息
|
|
200
|
+
await bot.callApi('send_group_msg', {
|
|
201
|
+
group_id: 123456,
|
|
202
|
+
message: '消息内容'
|
|
203
|
+
})
|
|
204
|
+
|
|
205
|
+
// 发送私聊消息
|
|
206
|
+
await bot.callApi('send_private_msg', {
|
|
207
|
+
user_id: 123456,
|
|
208
|
+
message: '消息内容'
|
|
209
|
+
})
|
|
210
|
+
|
|
211
|
+
// 撤回消息
|
|
212
|
+
await bot.callApi('delete_msg', {
|
|
213
|
+
message_id: 123456
|
|
214
|
+
})
|
|
215
|
+
```
|
|
216
|
+
|
|
217
|
+
### 信息获取
|
|
218
|
+
|
|
219
|
+
```typescript
|
|
220
|
+
// 获取登录信息
|
|
221
|
+
const loginInfo = await bot.callApi('get_login_info')
|
|
222
|
+
|
|
223
|
+
// 获取用户信息
|
|
224
|
+
const userInfo = await bot.callApi('get_stranger_info', {
|
|
225
|
+
user_id: 123456
|
|
226
|
+
})
|
|
227
|
+
|
|
228
|
+
// 获取群信息
|
|
229
|
+
const groupInfo = await bot.callApi('get_group_info', {
|
|
230
|
+
group_id: 123456
|
|
231
|
+
})
|
|
232
|
+
|
|
233
|
+
// 获取群成员列表
|
|
234
|
+
const memberList = await bot.callApi('get_group_member_list', {
|
|
235
|
+
group_id: 123456
|
|
236
|
+
})
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
### 群管理
|
|
240
|
+
|
|
241
|
+
```typescript
|
|
242
|
+
// 踢出群成员
|
|
243
|
+
await bot.callApi('set_group_kick', {
|
|
244
|
+
group_id: 123456,
|
|
245
|
+
user_id: 654321
|
|
246
|
+
})
|
|
247
|
+
|
|
248
|
+
// 禁言群成员
|
|
249
|
+
await bot.callApi('set_group_ban', {
|
|
250
|
+
group_id: 123456,
|
|
251
|
+
user_id: 654321,
|
|
252
|
+
duration: 600 // 秒
|
|
253
|
+
})
|
|
254
|
+
|
|
255
|
+
// 设置群名片
|
|
256
|
+
await bot.callApi('set_group_card', {
|
|
257
|
+
group_id: 123456,
|
|
258
|
+
user_id: 654321,
|
|
259
|
+
card: '新名片'
|
|
39
260
|
})
|
|
40
261
|
```
|
|
41
262
|
|
|
42
|
-
##
|
|
263
|
+
## 连接模式对比
|
|
43
264
|
|
|
44
|
-
|
|
45
|
-
- Mirai + mirai-api-http
|
|
46
|
-
- Shamrock
|
|
47
|
-
- LagrangeGo
|
|
48
|
-
- 其他兼容OneBot v11协议的实现
|
|
265
|
+
### 正向 WebSocket(客户端模式)
|
|
49
266
|
|
|
50
|
-
|
|
267
|
+
**优点:**
|
|
268
|
+
- ✅ 配置简单
|
|
269
|
+
- ✅ 主动连接,无需开放端口
|
|
270
|
+
- ✅ 适合本地开发
|
|
51
271
|
|
|
52
|
-
|
|
53
|
-
-
|
|
54
|
-
- 发送文本、图片等消息
|
|
55
|
-
- 消息回复功能
|
|
272
|
+
**缺点:**
|
|
273
|
+
- ❌ 需要 OneBot 实现提供 WebSocket 服务
|
|
56
274
|
|
|
57
|
-
###
|
|
58
|
-
- `get_stranger_info` - 获取用户信息
|
|
59
|
-
- `get_group_info` - 获取群组信息
|
|
60
|
-
- `send_group_msg` - 发送群消息
|
|
61
|
-
- `send_private_msg` - 发送私聊消息
|
|
275
|
+
### 反向 WebSocket(服务器模式)
|
|
62
276
|
|
|
63
|
-
|
|
64
|
-
-
|
|
65
|
-
-
|
|
66
|
-
-
|
|
277
|
+
**优点:**
|
|
278
|
+
- ✅ OneBot 实现主动连接
|
|
279
|
+
- ✅ 支持多个客户端连接
|
|
280
|
+
- ✅ 适合生产环境
|
|
67
281
|
|
|
68
|
-
|
|
282
|
+
**缺点:**
|
|
283
|
+
- ❌ 需要开放端口或使用内网穿透
|
|
284
|
+
- ❌ 配置相对复杂
|
|
69
285
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
286
|
+
## 消息 ID 格式
|
|
287
|
+
|
|
288
|
+
OneBot11 适配器的消息 ID 格式:`{message_id}`
|
|
289
|
+
|
|
290
|
+
撤回消息时直接使用数字 ID。
|
|
291
|
+
|
|
292
|
+
## 注意事项
|
|
293
|
+
|
|
294
|
+
### Access Token
|
|
295
|
+
|
|
296
|
+
建议配置 Access Token 增强安全性:
|
|
297
|
+
```typescript
|
|
298
|
+
{
|
|
299
|
+
access_token: process.env.ONEBOT_TOKEN
|
|
300
|
+
}
|
|
301
|
+
```
|
|
302
|
+
|
|
303
|
+
OneBot 实现需要配置相同的 Token。
|
|
304
|
+
|
|
305
|
+
### 重连机制
|
|
306
|
+
|
|
307
|
+
适配器会自动重连,可配置重连间隔:
|
|
308
|
+
```typescript
|
|
309
|
+
{
|
|
310
|
+
reconnect_interval: 5000 // 5秒后重连
|
|
311
|
+
}
|
|
312
|
+
```
|
|
313
|
+
|
|
314
|
+
### 心跳检测
|
|
315
|
+
|
|
316
|
+
心跳机制确保连接活跃:
|
|
317
|
+
```typescript
|
|
318
|
+
{
|
|
319
|
+
heartbeat_interval: 30000 // 30秒发送一次心跳
|
|
320
|
+
}
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
### API 超时
|
|
324
|
+
|
|
325
|
+
API 调用默认 30 秒超时,可在代码中调整。
|
|
326
|
+
|
|
327
|
+
## 常见问题
|
|
328
|
+
|
|
329
|
+
### Q: 连接不上 OneBot 服务?
|
|
330
|
+
|
|
331
|
+
A: 检查:
|
|
332
|
+
1. OneBot 服务是否启动
|
|
333
|
+
2. WebSocket 地址是否正确
|
|
334
|
+
3. Access Token 是否匹配
|
|
335
|
+
4. 防火墙是否阻止连接
|
|
336
|
+
|
|
337
|
+
### Q: 消息发送失败?
|
|
338
|
+
|
|
339
|
+
A: 可能原因:
|
|
340
|
+
1. 未登录或登录失败
|
|
341
|
+
2. 被风控限制
|
|
342
|
+
3. 群/好友不存在
|
|
343
|
+
4. 消息格式错误
|
|
344
|
+
|
|
345
|
+
### Q: 反向 WS 无法连接?
|
|
346
|
+
|
|
347
|
+
A: 确认:
|
|
348
|
+
1. HTTP 服务已启动
|
|
349
|
+
2. WebSocket 路径配置正确
|
|
350
|
+
3. OneBot 配置的反向 WS 地址正确
|
|
351
|
+
4. 端口已开放
|
|
352
|
+
|
|
353
|
+
### Q: 如何处理 CQ 码?
|
|
354
|
+
|
|
355
|
+
A: OneBot11 适配器自动处理 CQ 码转换,使用消息段格式即可:
|
|
356
|
+
```typescript
|
|
357
|
+
[
|
|
358
|
+
{ type: 'text', data: { text: '文本' } },
|
|
359
|
+
{ type: 'image', data: { file: 'url' } }
|
|
360
|
+
]
|
|
361
|
+
```
|
|
362
|
+
|
|
363
|
+
## 相关链接
|
|
364
|
+
|
|
365
|
+
- [OneBot 标准](https://github.com/botuniverse/onebot-11)
|
|
366
|
+
- [go-cqhttp](https://github.com/Mrs4s/go-cqhttp)
|
|
367
|
+
- [LagrangeGo](https://github.com/LagrangeDev/Lagrange.Core)
|
|
368
|
+
- [Shamrock](https://github.com/whitechi73/OpenShamrock)
|
|
369
|
+
- [Zhin.js 官方文档](https://github.com/zhinjs/zhin)
|
|
74
370
|
|
|
75
371
|
## 依赖项
|
|
76
372
|
|
|
77
|
-
- `ws` - WebSocket
|
|
78
|
-
- `zhin.js` - Zhin核心框架
|
|
373
|
+
- `ws` - WebSocket 客户端/服务器库
|
|
374
|
+
- `zhin.js` - Zhin 核心框架
|
|
79
375
|
|
|
80
376
|
## 开发
|
|
81
377
|
|
|
82
378
|
```bash
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
```
|
|
379
|
+
pnpm build # 构建
|
|
380
|
+
pnpm clean # 清理构建文件
|
|
381
|
+
```
|
|
382
|
+
|
|
383
|
+
## 许可证
|
|
384
|
+
|
|
385
|
+
MIT License
|
|
386
|
+
|
|
387
|
+
## 贡献
|
|
388
|
+
|
|
389
|
+
欢迎提交 Issue 和 Pull Request!
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@zhin.js/adapter-onebot11",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.19",
|
|
4
4
|
"description": "zhin adapter for onebot11",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./lib/index.js",
|
|
@@ -38,7 +38,7 @@
|
|
|
38
38
|
"typescript": "^5.3.0"
|
|
39
39
|
},
|
|
40
40
|
"peerDependencies": {
|
|
41
|
-
"zhin.js": "1.0.
|
|
41
|
+
"zhin.js": "1.0.17",
|
|
42
42
|
"@zhin.js/types": "1.0.5",
|
|
43
43
|
"@zhin.js/http": "1.0.7"
|
|
44
44
|
},
|