开发版本. 频繁更新, 不保证高稳定性
0.30.0 -此版本为二进制不兼容更新, 全部使用者都需要重新编译.
源码兼容的优化:
@Depreacted 兼容@JvmName 以兼容将来的改变 (新 MPP 模块等级制架构)MessageChain 工具函数消息部分:
SingleMessage 现在实现接口 CharSequence 和 Comparable<String>FriendImage, GroupImage, OnlineImage, OfflineImage 增加 companion object KeyRichMessage, 将所有子类聚合到一个文件XmlMessageHelper 为 RichMessage.CompationbuildXMLMessage 改为 buildXmlMessage事件部分:
加强 selectMessages, 增加回复, 引用回复, 默认值, 超时支持:
原处理方式:
val message = nextMessageOrNull(10.secondsToMillis) ?: kotlin.run {
quoteReply("请在 10 秒内发送一张图片")
return@case
}
val image = message.getOrNull(OnlineImage) ?: kotlin.run {
reply(message.quote() + "请发送一张图片")
return@case
}
reply(message.quote() + image.originUrl)
使用 selectMessages DSL:
selectMessagesUnit {
has<OnlineImage>() quoteReply {
message[OnlineImage].originUrl
}
timeout(10.secondsToMillis) quoteReply {
"请在 10 秒内发送图片以获取链接"
}
defaultQuoteReply {
"请发送一张图片"
}
}
0.29.1 2020/3/220.29.0 2020/3/22引入新消息监听 DSL: whileSelectMessages, 简化连续监听过程
bot.subscribeMessages {
"开启复读模式" `->` {
reply("成功开启")
whileSelectMessages {
"stop" `->` {
reply("已关闭复读")
false // 停止循环
}
default {
reply(message)
true // 继续循环
}
}
reply("复读模式结束")
}
}
引入新消息监听 DSL: selectMessages, 简化筛选监听过程
bot.subscribeMessages {
"test" `->` {
reply("choose option: 'hello', 'hi'")
val value: String = selectMessages {
"hello" `->` { "123" }
"hi" `->` { "222" }
default { "default value" }
}
reply(value)
}
}
监听消息的 DSL 新增 infix fun String.->(block)
处理 StatSvc.ReqMSFOffline (#150)
Contact.sendMessage 现在接受 Message 参数, 而不是 MessageChain 以兼容 CombinedMessage
Member.sendMessage 现在返回 MessageReceipt<Member> 而不是 QQ 泛型
调整 JVM MessageUtils 中一些方法的可见性 (@JvmSynthetic)
调整命名: OfflineImage.queryOriginUrl 改为 OfflineImage.queryUrl
允许手动重新初始化 Bot (BotNetworkHandler.init), 确保重初始化资源释放
0.28.0 2020/3/190.27.0 2020/3/8XML, Json, LightApp 等 RichMessage0.26.2 2020/3/8MessageChain.repeat 与 MessageChain.timesPlatformLogger 可重定向输出NullMessageChain.equals 判断不正确的问题PlainText.of 以应对一些特殊情况0.26.1 2020/3/8Kotlin 版本到 1.3.70kotlinx.coroutines, atomicfu, kotlinx.coroutines 依赖版本0.26.0 2020/3/70.25.0 2020/3/6Image 类型: Online/Offline Image, Friend/Group Image0.24.1 2020/3/3Member 的委托 QQ 弱引用被释放的问题Bot.friends 替代 Bot.qqsBot.containsFriend, Bot.containsGroup 替代 Bot.containsBotFactory.Bot(String, ByteArray) 用 md5 密码登录BotFactory 等类型的一些扩展指定 JvmNameBot.QQ 到低级 API0.24.0 2020/3/1MessageSource.originalMessage: MessageChain 以获取源消息内容Bot.recall)MessageReceipt.quoteReply新增 MessageRecallEvent
整理 MessageChain 的构造, 优化性能
整理所有网络层代码, 弃用 kotlinx.io 而使用 io.ktor.utils.io
其他杂项优化
0.23.0 2020/2/28MessageReceipt.source 现在为 public. 可获取源消息 id0.22.0 2020/2/24MessageChain, 引入 CombinedMessage. (兼容大部分原 API)MessageChainBuilder, buildMessageChainExternalImage 现在接收多种输入参数.sequenceId 时抛出异常的问题0.21.0 2020/2/23QuoteReply 架构, 支持引用任意群/好友消息回复给任意群/好友.0.20.0 2020/2/23支持图片下载: image.channel(): ByteReadChannel, image.url()
添加 LockFreeLinkedList<E>.iterator
添加 LockFreeLinkedList<E>.forEachNode
并行处理事件监听
添加 nextMessageContaining 和相关可空版本
'撤回' 从 Contact 移动到 Bot
删除 MessageSource.sourceMessage
让 MessageSource 拥有唯一的 long 类型 id, 删除原 uid 和 sequence 结构.
修复 Message.eq 歧义
0.19.1 2020/2/21Group.recall, MessageReceipt.recallGroup.recallIn, MessageReceipt.recallInsendMessage 返回 MessageReceipt 以实现撤回功能MessageChain.addOrRemoveContactList.firstOrNull, ContactList.firstsubscribingGetAsync 启动一个协程并从一个事件从获取返回值到 Deferred.subscribingGet 挂起当前协程并从一个事件从获取返回值.nextMessage 挂起当前协程并等待下一条消息:使用该示例, 发送两条消息, 一条为 "禁言", 另一条包含一个 At
case("禁言") {
val value: At = nextMessage { message.any(At) }[At]
value.member().mute(10)
}
示例 2:
case("复读下一条") {
reply(nextMessage().message)
}
At 无法发送的问题{xxxxxxxx-xxxx-xxxx-xxxxxxxxxxxx}.jpg 形式(固定长度 37)0.18.0 2020/2/20MessageSource.timecoroutineContextoperator 的事件添加 .isByBot 的属性扩展Contact 添加 toString() (#80)Member.muteTimeRemainingAt 的 display (#73), 同时修复 QuoteReply 无法显示问题 (#54).BotReloginEvent (#78)0.17.0 2020/2/20FacegroupCardOrNick 为 nameCardOrNickMessageChain.foreachContent(lambda) 和 Message.hasContent(): Boolean0.16.0 2020/2/19Bot.subscribe 等筛选 Bot 实例的监听方法0.15.5 2020/2/19MiraiLogger 添加 common property val isEnabled: BooleanBot close 后仍会重连bot.logger 记录 (verbose).info -> verboseBot 的 log 记录Bot 或 NetworkHandler 关闭时取消 job 的逻辑0.15.4 2020/2/18atomicfu 以解决其编译错误的问题. (#60)0.15.3 2020/2/180.15.2 2020/2/18atomicfu 编译错误的问题0.15.1 2020/2/15false.BotOnlineEvent0.15.0 2020/2/14BotReloginEvent 和 BotOfflineEvent.DroppedAtAll 现在实现 Message.KeyBotConfiguration DSL, 支持自动将设备信息存储在文件系统等新增 MessageSource.quote(Member)
更好的网络层连接逻辑
密码错误后不再重试登录
掉线后尝试快速重连, 失败则普通重连 (#47)
有原因的登录失败时将抛出特定异常: LoginFailedException
默认心跳时间调整为 60s
0.14.0 2020/2/13AtAllAtAll 的发送和解析小优化:
GroupMessage 添加 quoteReply(Message), 可快速引用消息并回复CoroutineScope.subscribeMessages 添加返回值. 返回 lambda 的返回值At 的空格处理 (自动为 At 之后的消息添加空格)BotConfiguration 中一些过时的设置0.13.0 2020/2/12context 参数.addAll 性能)安卓协议发布, 基于最新 QQ, 版本 8.2.0
支持的功能:
HTTP API 已完成, by @ryoii.
详见 README
Mirai 仍处于快速迭代状态. 将来仍可能会有 API 改动.
0.12.0 2020/1/19监听消息时允许使用条件式的表达式, 如:
(contains("1") and has<Image>()){
reply("Your message has a string '1' and an image contained")
}
(contains("1") or endsWith("2")){
}
原有单一条件语法不变:
contains("1"){
}
"Hello" reply "World"
eq 无法正确判断的问题; 性能优化.cancelled 属性修改为 val (以前是 var with private set)0.11.0 2020/1/12BotAccount.id. 将来它可能会被改名成为邮箱等账号. QQ 号码需通过 bot.uin 获取.Gender 由 inline class 改为 enumString.chain() 改为 String.toChain()List<Message>.chain() 改为 List<Message>.toChain()
修复在有入群验证时无法解析群资料的问题 (#30)
0.10.6 2020/1/8TIMPC
0.10.5 2020/1/30.10.4 2020/1/1Bot(qq, password, config=Default)0.10.3 2020/1/1ExternalImageAndroid0.10.1 2019/12/30Bot 构造
Bot 构造时修改 BotConfiguration 而不是登录时.
移除 CoroutineScope.Bot
移除 suspend Bot(...)
添加 Bot(..., BotConfiguration.() -> Unit)
添加 Bot(..., BotConfiguration = BotConfiguration.Default)
其他
全面的在线状态 (OnlineStatus)
移动部分文件, 模块化
0.10.0 2019/12/23事件优化
更快的监听过程
现在监听不再是 suspend, 而必须显式指定 CoroutineScope. 详见 Subscribers.kt
删除原本的 bot.subscribe 等监听模式.
其他
Contact 现在实现接口 CoroutineScope
0.9.0 2019/12/20协议模块独立
现在 mirai-core 只提供基础的抽象类. 具体的各协议实现为 mirai-core-PROTOCOL.
这些模块都继承自 mirai-core.
现在, 要使用 mirai, 必须依赖于特定的协议模块, 如 mirai-core-timpc.
查阅 API 时请查看 mirai-core.
每个模块只提供少量的额外方法. 我们会给出详细列表.
在目前的开发中您无需考虑多协议兼容.
Bot 构造
协议抽象后构造 Bot 需指定协议的 BotFactory.
在 JVM 平台, Mirai 通过 classname 自动加载协议模块的 BotFactory, 因此若您只使用一套协议, 则无需修改现行源码
事件
大部分事件包名修改.
UInt -> Long
修改全部 QQ ID, Group ID 的类型由 UInt 为 Long.
此为 API 不兼容更新, 请将所有无符号标志 u 删除即可. 如 123456u 改为 123456
另还有其他 API 的包名或签名修改. 请使用 IDE 自动修补 import 即可.
0.8.2 2019/12/150.8.1 2019/12/15At.qq, Long.qq 等函数不再是 suspend0.8.0 2019/12/14协议
功能
suspendsuspend, 原因为需要查询群资料. 在群 ID 无效时抛出 GroupNotFoundException优化
0.7.5 2019/12/090.7.4 2019/12/080.7.3 2019/12/070.7.2 2019/12/07internalclose 的不应该有的 suspendQQ, Member, Group 现在继承接口 CoroutineScopeLoginResult 由 inline class 修改为 enum classBotAccount 和 Bot 的构造器0.7.1 2019/12/050.7.0 2019/12/04协议
0.7.5 修复)功能
.qq() 和 .group() 的扩展函数.Message.concat 为 Message.followedByOPERATOR 为 ADMINISTRATOR性能优化
0.6.1 2019/12/03MessagePacket 下 At.qq() 捷径获取 QQ0.6.0 2019/12/02Member.mute(TimeSpan|Duration|MonthsSpan|Int|UInt))Member.unmute())