/
message-type.ts
450 lines (420 loc) · 9.24 KB
/
message-type.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
/**
* 消息类型,与 [Mirai-api-http 消息类型一览](https://github.com/project-mirai/mirai-api-http/blob/master/docs/MessageType.md) 保持一致
* @packageDocumentation
*/
import type { SendMessage } from './api/params'
import type * as Contact from './contact'
// eslint-disable-next-line ts/no-namespace
export namespace MessageType {
interface BaseSingleMessage {
type: string
}
/**
* 源消息类型
*/
export interface Source extends BaseSingleMessage {
type: 'Source'
/**
* 消息的识别号,用于引用回复(Source 类型永远为 chain 的第一个元素)
*/
id: number
/**
* 时间戳
*/
time: number
}
/**
* 引用消息类型
*/
export interface Quote extends BaseSingleMessage {
type: 'Quote'
/**
* 被引用回复的原消息的messageId
*/
id: number
/**
* 被引用回复的原消息所接收的群号,当为好友消息时为0
*/
groupId?: number
/**
* 被引用回复的原消息的发送者的QQ号
*/
senderId?: number
/**
* 被引用回复的原消息的接收者者的QQ号(或群号)
*/
targetId?: number
/**
* 被引用回复的原消息的消息链对象
*/
origin?: MessageChain
}
/**
* 艾特某人消息
*/
export interface At extends BaseSingleMessage {
type: 'At'
/**
* 群员QQ号
*/
target: number
/**
* At 时显示的文字,发送消息时无效,自动使用群名片
*/
display: string
}
/**
* 艾特全体成员消息
*/
export interface AtAll extends BaseSingleMessage {
type: 'AtAll'
}
/**
* 原生表情消息
*/
export interface Face extends BaseSingleMessage {
type: 'Face'
/**
* QQ表情编号,可选,优先高于name
*/
faceId: number
/**
* QQ表情拼音,可选
*/
name: string
}
/**
* 文本消息
*/
export interface Plain extends BaseSingleMessage {
type: 'Plain'
/**
* 文字消息
*/
text: string
}
/**
* 图片消息
*/
export interface Image extends BaseSingleMessage {
type: 'Image'
/**
* 图片的 imageId,群图片与好友图片格式不同。不为空时将忽略 url 属性
*/
imageId: string | null
/**
* 图片的 URL,发送时可作网络图片的链接;接收时为腾讯图片服务器的链接,可用于图片下载
*/
url: string | null
/**
* 图片的路径,发送本地图片,相对路径于 `data/net.mamoe.mirai-api-http/images`
*/
path: string | null
/**
* 图片的 Base64 编码
*/
base64: string | null
}
/**
* 闪照消息
*/
export interface FlashImage extends BaseSingleMessage {
type: 'FlashImage'
/**
* 图片的imageId,群图片与好友图片格式不同。不为空时将忽略url属性
*/
imageId: string | null
/**
* 图片的URL,发送时可作网络图片的链接;接收时为腾讯图片服务器的链接,可用于图片下载
*/
url: string | null
/**
* 图片的路径,发送本地图片,相对路径于 `data/net.mamoe.mirai-api-http/images`
*/
path: string | null
}
/**
* 语音消息
*/
export interface Voice extends BaseSingleMessage {
type: 'Voice'
/**
* 语音的 voiceId,不为空时将忽略 url 属性
*/
voiceId: string | null
/**
* 语音的 URL,发送时可作网络语音的链接;接收时为腾讯语音服务器的链接,可用于语音下载
*/
url: string | null
/**
* 语音的路径,发送本地语音,路径相对于 JVM 工作路径(默认是当前路径,可通过 -Duser.dir=...指定),也可传入绝对路径。
*/
path: string | null
/**
* 语音的 Base64 编码
*/
base64: string | null
/**
* 返回的语音长度, 发送消息时可以不传
*/
length?: number
}
/**
* 富文本消息(譬如合并转发)
*/
export interface Xml extends BaseSingleMessage {
type: 'Xml'
/**
* XML文本
*/
xml: string
}
export interface Json extends BaseSingleMessage {
type: 'Json'
/**
* Json文本
*/
json: string
}
/**
* 小程序消息
*/
export interface App extends BaseSingleMessage {
type: 'App'
/**
* 内容
*/
content: string
}
/**
* "Poke": 戳一戳
* "ShowLove": 比心
* "Like": 点赞
* "Heartbroken": 心碎
* "SixSixSix": 666
* "FangDaZhao": 放大招
*/
export enum PokeName {
Poke = 'Poke',
ShowLove = 'ShowLove',
Like = 'Like',
Heartbroken = 'Heartbroken',
SixSixSix = 'SixSixSix',
FangDaZhao = 'FangDaZhao',
}
/**
* 戳一戳消息
*/
export interface Poke extends BaseSingleMessage {
type: 'Poke'
/**
* 戳一戳的类型
*/
name: PokeName
}
export interface Dice extends BaseSingleMessage {
type: 'Dice'
/**
* 点数
*/
value: number
}
export type ForwardNode =
| {
/**
* 发送者 id
*/
senderId: number
/**
* 时间戳, 单位 秒
*/
time: number
/**
* 发送者姓名
*/
senderName: string
messageChain: MessageChain
}
| {
/**
* 可以只使用消息messageId,从缓存中读取一条消息作为节点
*/
messageId: number
}
/**
* 转发
*/
export interface Forward extends BaseSingleMessage {
type: 'Forward'
/**
* 标题,XX的聊天记录
*/
title: string
/**
* 简介,[聊天记录]
*/
brief: string
/**
* 源
*/
source: string
/**
* 摘要,查看 3 条转发消息
*/
summary: string
/**
* 转发内容
*/
nodeList: ForwardNode[]
}
export interface File {
type: 'File'
/**
* 文件识别 id
*/
id: string
/**
* 文件名字
*/
name: string
/**
* 文件大小
*/
size: number
}
export type MusicShareKind = 'NeteaseCloudMusic' | 'QQMusic' | 'MiguMusic'
/**
* 音乐分享
*/
export interface MusicShare {
type: 'MusicShare'
/**
* 音乐应用类型
*/
kind: 'NeteaseCloudMusic' | 'QQMusic' | 'MiguMusic'
/**
* 消息卡片标题
*/
title: string
/**
* 消息卡片内容
*/
summary: string
/**
* 点击卡片跳转网页 URL
*/
jumpUrl: string
/**
* 消息卡片图片 URL
*/
pictureUrl: string
/**
* 音乐文件 URL
*/
musicUrl: string
/**
* 简介,在消息列表显示,默认为 `[分享]$title`
*/
brief?: string
}
export interface MiraiCode {
type: 'MiraiCode'
/**
* MiraiCode
* @example hello[mirai:at:1234567]
*/
code: string
}
export interface SingleMessageMap {
Source: Source
Quote: Quote
At: At
AtAll: AtAll
Face: Face
Plain: Plain
Image: Image
FlashImage: FlashImage
Voice: Voice
Xml: Xml
Json: Json
App: App
Poke: Poke
Dice: Dice
Forward: Forward
MusicShare: MusicShare
File: File
MiraiCode: MiraiCode
}
export type SingleMessageType = keyof SingleMessageMap
/**
* FriendMessage | GroupMessage | TempMessage 下的 MessageChain 中的单条消息类型
* 单条消息 此处命名与 mamoe/mirai-core 保持一致
*/
export type SingleMessage = SingleMessageMap[SingleMessageType]
/**
* 消息链
*/
export type MessageChain = Array<SingleMessage>
interface BaseChatMessage extends BaseSingleMessage {
type: 'GroupMessage' | 'TempMessage' | 'FriendMessage'
messageChain: MessageChain & {
0: Source
}
sender: Contact.User
/**
* 快捷回复函数
*/
reply: (msgChain: string | MessageChain, quote?: boolean) => Promise<SendMessage>
/**
* 消息文本
*/
plain: string
/**
* 是否为某群 groupId 发送
* msg.group(114514)
*/
group: (...groupIds: number[]) => boolean
/**
* 是否为某个好友 qq 发送
* msg.friend(114514)
*/
friend: (...qqs: number[]) => boolean
/**
* 获取消息链中第一次出现的消息类型
* 例如:msg.get('Quote')
*/
get: <T extends SingleMessage['type']>(
type: T
) => SingleMessageMap[T] | null
}
export interface FriendMessage extends BaseChatMessage {
type: 'FriendMessage'
sender: Contact.Friend
}
export interface GroupMessage extends BaseChatMessage {
type: 'GroupMessage'
sender: Contact.Member
/**
* 判断是否艾特某人(留空则判断是否艾特自己)
*/
isAt: (qq?: number) => boolean
}
export interface TempMessage extends BaseChatMessage {
type: 'TempMessage'
sender: Contact.Member
}
/**
* 包括 FriendMessage GroupMessage TempMessage
*/
export type ChatMessage = GroupMessage | TempMessage | FriendMessage
/**
* 聊天消息类型
*/
export type ChatMessageType = ChatMessage['type']
export interface ChatMessageMap {
message: ChatMessage
GroupMessage: GroupMessage
FriendMessage: FriendMessage
TempMessage: TempMessage
}
}