7.1 KiB
Major version 0
开发版本. 频繁更新, 不保证高稳定性
0.13.0
2020/2/12
mirai-core
- 修改 BotFactory, 添加
context
参数. - currentTimeMillis 减少不必要对象创建
- 优化无锁链表性能 (大幅提升
addAll
性能)
mirai-core-qqanroid
安卓协议发布, 基于最新 QQ, 版本 8.2.0
支持的功能:
- 登录: 密码登录. 设备锁支持, 不安全状态支持, 图片验证码支持, 滑动验证码支持.
- 消息: 文字消息, 图片消息(含表情消息), 群员 At.
- 列表: 群列表, 群员列表, 好友列表均已稳定.
- 群操作: 查看和修改群名, 查看和修改群属性(含全体禁言, 坦白说, 自动批准加入, 匿名聊天, 允许成员拉人), 设置和解除成员禁言, 查看和修改成员名片, 踢出成员.
- 消息事件: 接受群消息和好友消息并解析
- 群事件: 群员加入, 群员离开, 禁言和解除禁言, 群属性(含全体禁言, 坦白说, 匿名聊天, 允许成员拉人)改动.
mirai-api-http
HTTP API 已完成, by @ryoii.
详见 README
Mirai 仍处于快速迭代状态. 将来仍可能会有 API 改动.
0.12.0
2020/1/19
mirai-core
- 监听消息时允许使用条件式的表达式, 如:
(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"
- Message: 修复
eq
无法正确判断的问题; 性能优化. - 简化 logger 结构(API 不变).
- 事件
cancelled
属性修改为val
(以前是var
withprivate set
)
0.11.0
2020/1/12
mirai-core
- 弃用
BotAccount.id
. 将来它可能会被改名成为邮箱等账号. QQ 号码需通过bot.uin
获取. Gender
由inline class
改为 enumString.chain()
改为String.toChain()
List<Message>.chain()
改为List<Message>.toChain()
mirai-core-timpc
- 修复在有入群验证时无法解析群资料的问题 (#30)
0.10.6
2020/1/8
TIMPC
- Fix #27, 群成员找不到的问题
- 一些小优化
0.10.5
2020/1/3
- 修复有时表情消息无法解析的问题
- 为心跳增加重试, 降低掉线概率
- 消息中的换行输出为 \n
- 其他一些小问题修复
0.10.4
2020/1/1
- 事件处理抛出异常时不停止监听
- 添加
Bot(qq, password, config=Default)
- 一些性能优化
0.10.3
2020/1/1
- 修复一个由 atomicfu 的 bug 导致的 VerifyError
- 添加
ExternalImageAndroid
- 事件处理抛出异常时正确地停止监听
0.10.1
2019/12/30
Bot 构造
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/15
- 修复 GroupId.toGroupInternalId 错误
- 修复解析群消息时小概率出现的一个错误
0.8.1
2019/12/15
- 修复有时群资料无法获取的情况
- 现在
At.qq
,Long.qq
等函数不再是suspend
0.8.0
2019/12/14
协议
- 现在查询群资料时可处理群号无效的情况
- 现在能正常分辨禁言事件包
功能
- 增加无锁链表: LockFreeLinkedList, 并将 ContactList 的实现改为该无锁链表
- ContactSystem.getQQ 不再是
suspend
- ContactSystem.getGroup 仍是
suspend
, 原因为需要查询群资料. 在群 ID 无效时抛出GroupNotFoundException
优化
- 日志中, 发送给服务器的包将会被以名字记录, 而不是 id
0.7.5
2019/12/09
- 修复验证码包发出后无回复 (错误的验证码包)
0.7.4
2019/12/08
- 修复 bug
- 优化 JVM 平台上需要验证码时的提示
0.7.3
2019/12/07
- 删除 klock 依赖, 添加 Time.kt. 待将来 kotlin Duration 稳定后替换为 Duration
0.7.2
2019/12/07
- 使所有协议相关类
internal
- 去掉一些
close
的不应该有的suspend
QQ
,Member
,Group
现在继承接口CoroutineScope
- 将
LoginResult
由inline class
修改为enum class
- 添加和修改了
BotAccount
和Bot
的构造器
0.7.1
2019/12/05
- 修复禁言时间范围错误的问题
- 禁言的扩展函数现在会传递实际函数的返回值
0.7.0
2019/12/04
协议
- 重新分析验证码包, 解决一些无法解析的情况. (这可能会产生新的问题, 遇到后请提交 issue)
- 重新分析提交密码包
- 提交验证码仍可能出现问题 (已在
0.7.5
修复)
功能
- XML 消息 DSL 构造支持 (实验性) (暂不支持发送)
- 群成员列表现在包含群主 (原本就应该包含)
- 在消息事件处理中添加获取
.qq()
和.group()
的扩展函数. - 现在处理群消息时 sender 为 Member (以前为 QQ)
- 修改
Message.concat
为Message.followedBy
- 修改成员权限
OPERATOR
为ADMINISTRATOR
- bot.subscribeAll<>() 等函数的 handler lambda 的 receiver 由 Bot 改变为 BotSession; 此变动不会造成现有代码的修改, 但并不兼容旧版本编译的代码
性能优化
- 内联 ContactList
- 2 个 Contact.sendMessage 重载改为内联扩展函数 (需要添加 import)
- 其他小优化
0.6.1
2019/12/03
- 新增: 无法解析密码包/验证码包时的调试输出. 以兼容更多的设备情况
- 新增:
MessagePacket
下At.qq()
捷径获取 QQ
0.6.0
2019/12/02
- 新增: 禁言群成员 (
Member.mute(TimeSpan|Duration|MonthsSpan|Int|UInt)
) - 新增: 解禁群成员 (
Member.unmute()
) - 修复: ContactList key 无法匹配 (Kotlin 内联类型泛型投影错误)