From 9047fd0d4c664dec79ae2c78f9cfc25314842c99 Mon Sep 17 00:00:00 2001 From: Him188 Date: Tue, 3 Mar 2020 09:47:33 +0800 Subject: [PATCH] Bump version to 8.2.7 --- CHANGELOG.md | 3 ++ README.md | 44 +++++++++---------- .../qqandroid/network/QQAndroidClient.kt | 10 +++-- .../network/protocol/data/proto/Cmd0x352.kt | 2 +- .../protocol/data/proto/ImageRequest.kt | 2 +- .../message/data/MessageChain.kt | 3 +- 6 files changed, 33 insertions(+), 31 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b3e701dcc..9a08db6d3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,9 @@ 开发版本. 频繁更新, 不保证高稳定性 +## `0.25.0` 还未发布 +- 适配 8.2.7 版本(2020/3/3)协议 + ## `0.24.1` 2020/3/3 - 修复 `Member` 的委托 `QQ` 弱引用被释放的问题 - 用 `Bot.friends` 替代 `Bot.qqs` diff --git a/README.md b/README.md index f017a3c13..98e4482b8 100644 --- a/README.md +++ b/README.md @@ -24,18 +24,19 @@ Mirai 是一个在全平台下运行,提供 QQ Android 和 TIM PC 协议支持 多平台 **QQ Android** 和 **TIM PC** 协议支持库与高效率的机器人框架. 纯 Kotlin 实现协议和支持框架,模块全部免费开源。 -目前可运行在 JVM 或 Android。 -Mirai既可以作为你项目中的QQ协议支持Lib, 也可以作为单独的Application与插件承载QQ机器人 +目前可运行在 JVM 或 Android 平台。 +mirai 既可以作为你项目中的 QQ 协议支持库, 也可以作为单独的应用程序与插件承载 QQ 机器人服务。 **一切开发旨在学习,请勿用于非法用途** -加入 Gitter, 或加入 QQ 群: 655057127 - +加入 [![Gitter](https://badges.gitter.im/mamoe/mirai.svg)](https://gitter.im/mamoe/mirai?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge), 或加入 QQ 群: 655057127 ## 开始使用Mirai -Mirai支持以多种方式进行部署,但是目前,我们在集中对mirai-core,mirai-japt, mirai-api-http, mirai-console等核心模块进行特性的开发。 +Mirai 目前为快速流转(Moving fast)状态, 增量版本之间可能不具有兼容性,任何功能都可能在没有警告的情况下添加、删除或者更改。 + +Mirai 源码完全开放, 您可以参考 Mirai 的协议实现来开发其他框架, 但需注明来源并遵守开源协议要求 (AGPLv3)。 ### 开发者 @@ -43,35 +44,30 @@ Mirai支持以多种方式进行部署,但是目前,我们在集中对mirai- #### 使用 mirai 作为服务器,为 mirai 开发插件 -- (mirai 官方)`Java` 或 `Kotlin`: 为 [mirai-console](https://github.com/mamoe/mirai-console) 直接编写插件并与其他插件开发者合作共享 -- (来自社区)C, C++ 等原生语言: [mirai-native](https://github.com/iTXTech/mirai-native) 支持酷Q插件在mirai上运行 -- (来自社区)Python: [python-mirai](https://github.com/Chenwe-i-lin/python-mirai) 基于`Mirai-http-api`的 Mirai Framework for Python -- (来自社区)JavaScript(NodeJS) [node-mirai](https://github.com/RedBeanN/node-mirai) Mirai的NodeJs SDK -- (mirai 官方)其他任意语言: [mirai HTTP 接口](https://github.com/mamoe/mirai/tree/master/mirai-api-http) 进行接入 +- (官方)`Java` 或 `Kotlin`: 为 [mirai-console](https://github.com/mamoe/mirai-console) 直接编写插件并与其他插件开发者合作共享 +- (社区)`C`, `C++` 等原生语言: [mirai-native](https://github.com/iTXTech/mirai-native) 支持酷Q插件在mirai上运行 +- (社区)`Python`: [python-mirai](https://github.com/Chenwe-i-lin/python-mirai) 基于`Mirai-http-api`的 Mirai Framework for Python +- (社区)`JavaScript`(`NodeJS`) [node-mirai](https://github.com/RedBeanN/node-mirai) Mirai的NodeJs SDK +- (官方)其他任意语言: [mirai HTTP 接口](https://github.com/mamoe/mirai/tree/master/mirai-api-http) 进行接入 #### 使用 mirai 为第三方依赖库引入项目 Demos: [mirai-demos](https://github.com/mamoe/mirai-demos) -- Kotlin 简略版: [Mirai Guide - Quick Start](/docs/guide_quick_start.md) -- Kotlin 新手版: [Mirai Guide - Getting Started](/docs/guide_getting_started.md) -- Java: 待添加 - +- `Kotlin` 简略版: [Mirai Guide - Quick Start](/docs/guide_quick_start.md) +- `Kotlin` 新手版: [Mirai Guide - Getting Started](/docs/guide_getting_started.md) +- `Java`: 查看上述 Demos ### 使用者 -- [mirai-console](https://github.com/mamoe/mirai/tree/master/mirai-console) 支持插件, **全平台可运行(UI版, Unix版, Android版, Web版)** **本模块正在完善** - - +- [mirai-console](https://github.com/mamoe/mirai/tree/master/mirai-console) 支持插件 **本模块正在完善** ### 我是其他平台的使用者 #### 酷Q平台用户: -- 酷Q的插件可以在 `Mirai` 中加载, 详见 [Mirai-Native](https://github.com/iTXTech/mirai-native) -- 使用 `酷Q HTTPAPI` 的插件将可以在`mirai`中加载,`Mirai-CQ-Adapter` 正在计划中 - - +- 酷Q的插件可以在 mirai 中加载, 详见 [Mirai-Native](https://github.com/iTXTech/mirai-native) +- 使用 `酷Q HTTP API` 的插件将可以在 mirai 中加载,`Mirai-CQ-Adapter` 正在进行中 ## 更新日志 @@ -89,7 +85,7 @@ Demos: [mirai-demos](https://github.com/mamoe/mirai-demos) ### mirai-core-qqandroid - QQ for Android (8.2.0 版本,2019 年 12 月)协议的实现,目前完成大部分。 + QQ for Android (8.2.7 版本,2020 年 3 月)协议的实现,目前完成大部分。 - 高兼容性:协议仅含极少部分为硬编码,其余全部随官方方式动态生成 - 高安全性:密匙随机,ECDH 动态计算 @@ -109,9 +105,9 @@ TIM PC (2.3.2 版本,2019 年 8 月)协议的实现 ## 加入开发 我们欢迎一切形式的贡献。 -我们也期待有更多人能加入 `Mirai` 的开发。 +我们也期待有更多人能加入 mirai 的开发。 -若在使用过程中有任何疑问, 可提交 `issue` 或是[邮件联系](mailto:support@mamoe.net). 我们希望 `Mirai` 变得更易用. +若在使用过程中有任何疑问, 可提交 `issue` 或是[邮件联系](mailto:support@mamoe.net). 我们希望 mirai 变得更易用. 您的 `star` 是对我们最大的鼓励(点击项目右上角) diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/QQAndroidClient.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/QQAndroidClient.kt index 72717ec51..7d2801ffa 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/QQAndroidClient.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/QQAndroidClient.kt @@ -100,8 +100,8 @@ internal open class QQAndroidClient( var openAppId: Long = 715019303L - val apkVersionName: ByteArray get() = "8.2.0".toByteArray() - val buildVer: String get() = "8.2.0.1296" + val apkVersionName: ByteArray get() = "8.2.7".toByteArray() + val buildVer: String get() = "8.2.7.4410" private val messageSequenceId: AtomicInt = atomic(22911) internal fun atomicNextMessageSequenceId(): Int = messageSequenceId.getAndAdd(2) @@ -122,7 +122,7 @@ internal open class QQAndroidClient( val apkSignatureMd5: ByteArray = "A6 B7 45 BF 24 A2 C2 77 52 77 16 F6 F3 6E B6 8D".hexToBytes() /** - * 协议版本?, 8.2.0 的为 8001 + * 协议版本?, 8.2.7 的为 8001 */ val protocolVersion: Short = 8001 @@ -164,10 +164,12 @@ internal open class QQAndroidClient( var t530: ByteArray? = null var t528: ByteArray? = null + /** * t108 时更新 */ - var ksid: ByteArray = "|454001228437590|A8.2.0.27f6ea96".toByteArray() + var ksid: ByteArray = "|454001228437590|A8.2.7.27f6ea96".toByteArray() + /** * t186 */ diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/Cmd0x352.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/Cmd0x352.kt index 2052c3326..dbb85d0fd 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/Cmd0x352.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/Cmd0x352.kt @@ -141,7 +141,7 @@ internal class Cmd0x352 : ProtoBuf { * SHARPP: 1004 */ @SerialId(16) val imgType: Int = 1000, - @SerialId(17) val buildVer: String = "8.2.0.1296",//版本号 + @SerialId(17) val buildVer: String = "8.2.7.4410",//版本号 @SerialId(18) val fileIndex: ByteArray = EMPTY_BYTE_ARRAY,//default @SerialId(19) val fileStoreDays: Int = 0,//default @SerialId(20) val stepFlag: Int = 0,//default diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/ImageRequest.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/ImageRequest.kt index 09771459d..87b0f7de4 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/ImageRequest.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/data/proto/ImageRequest.kt @@ -35,7 +35,7 @@ internal class GetImgUrlReq( @SerialId(10) val innerIP: Int = 0,//确定 @SerialId(11) val addressBook: Int = 0,//[ChatType.internalID]== 1006为1[为CONTACT时] 我觉得发0没问题 @SerialId(12) val buType: Int = 1,//确定 - @SerialId(13) val buildVer: String = "8.2.0.1296",//版本号 + @SerialId(13) val buildVer: String = "8.2.7.4410",//版本号 @SerialId(14) val timestamp: Int = currentTimeSeconds.toInt(),//(pic_up_timestamp) @SerialId(15) val requestTransferType: Int = 1 ) : ImgReq \ No newline at end of file diff --git a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageChain.kt b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageChain.kt index 61a597034..48eecf939 100644 --- a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageChain.kt +++ b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageChain.kt @@ -184,11 +184,12 @@ inline fun MessageChain.orNull(): OrNullDelegate = OrN * ``` * @see orNull 提供一个不存在则 null 的委托 */ +@Suppress("RemoveExplicitTypeArguments") @JvmSynthetic inline fun MessageChain.orElse( lazyDefault: () -> T ): OrNullDelegate = - OrNullDelegate(this.firstOrNull() ?: lazyDefault()) + OrNullDelegate(this.firstOrNull() ?: lazyDefault()) // endregion delegate