@zhin.js/adapter-onebot11 1.0.17 → 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.
Files changed (3) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/README.md +345 -41
  3. package/package.json +2 -2
package/CHANGELOG.md CHANGED
@@ -1,5 +1,17 @@
1
1
  # @zhin.js/adapter-onebot11
2
2
 
3
+ ## 1.0.19
4
+
5
+ ### Patch Changes
6
+
7
+ - zhin.js@1.0.17
8
+
9
+ ## 1.0.18
10
+
11
+ ### Patch Changes
12
+
13
+ - zhin.js@1.0.16
14
+
3
15
  ## 1.0.17
4
16
 
5
17
  ### Patch Changes
package/README.md CHANGED
@@ -1,25 +1,28 @@
1
1
  # @zhin.js/adapter-onebot11
2
2
 
3
- 基于 OneBot v11 协议的 Zhin 机器人适配器,通过 WebSocket 连接各种支持 OneBot 协议的机器人客户端。
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
- npm install @zhin.js/adapter-onebot11
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
- name: 'my-bot', // 机器人名称
32
- url: process.env.ONEBOT_URL || 'ws://localhost:8080', // OneBot服务器地址
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: ['adapter-onebot11']
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
- ## 支持的OneBot实现
263
+ ## 连接模式对比
43
264
 
44
- - go-cqhttp
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
- ### API调用
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
- 适配器会自动处理WebSocket连接:
71
- - 支持Bearer Token认证
72
- - 自动处理断线重连
73
- - API请求超时管理
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
- npm run build # 构建
84
- npm run clean # 清理构建文件
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.17",
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.15",
41
+ "zhin.js": "1.0.17",
42
42
  "@zhin.js/types": "1.0.5",
43
43
  "@zhin.js/http": "1.0.7"
44
44
  },