From b6c24e008db6d3b1c3f8e45ef259180c854ea437 Mon Sep 17 00:00:00 2001 From: Him188 Date: Sun, 29 Mar 2020 13:34:54 +0800 Subject: [PATCH] Plan for redesigning of MessageSource --- .../net/mamoe/mirai/qqandroid/QQAndroidBot.kt | 6 +++-- .../mirai/qqandroid/contact/GroupImpl.kt | 2 +- .../mirai/qqandroid/contact/MemberImpl.kt | 2 ++ .../mamoe/mirai/qqandroid/contact/QQImpl.kt | 1 + .../qqandroid/message/MessageSourceImpl.kt | 4 +++- .../mamoe/mirai/qqandroid/message/messages.kt | 1 + .../network/protocol/packet/chat/MultiMsg.kt | 2 +- .../packet/chat/receive/MessageSvc.kt | 4 ++-- .../androidMain/kotlin/net/mamoe/mirai/Bot.kt | 2 ++ .../net/mamoe/mirai/BotJavaFriendlyAPI.kt | 4 ++++ .../net/mamoe/mirai/message/MessageReceipt.kt | 9 ++++++-- .../commonMain/kotlin/net.mamoe.mirai/Bot.kt | 11 ++++++++++ .../net.mamoe.mirai/message/MessageReceipt.kt | 16 +++++++++++++- .../message/data/MessageChain.kt | 1 + .../message/data/MessageSource.kt | 22 +++++++++++++++++-- .../message/data/QuoteReply.kt | 6 +++-- .../src/jvmMain/kotlin/net/mamoe/mirai/Bot.kt | 2 ++ .../net/mamoe/mirai/BotJavaFriendlyAPI.kt | 4 ++++ .../net/mamoe/mirai/message/MessageReceipt.kt | 6 ++++- 19 files changed, 90 insertions(+), 15 deletions(-) diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/QQAndroidBot.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/QQAndroidBot.kt index dfc2c6c99..8992479be 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/QQAndroidBot.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/QQAndroidBot.kt @@ -163,6 +163,7 @@ internal abstract class QQAndroidBotBase constructor( TODO("not implemented") } + @ExperimentalMessageSource override suspend fun recall(source: MessageSource) { if (source.senderId != uin && source.groupId != 0L) { getGroup(source.groupId).checkBotPermissionOperator() @@ -382,8 +383,9 @@ internal abstract class QQAndroidBotBase constructor( val data = chain.calculateValidationDataForGroup( sequenceId = client.atomicNextMessageSequenceId(), time = time.toInt(), - random = Random.nextInt().absoluteValue.toULong().toLong(), - group + random = Random.nextInt().absoluteValue.toUInt(), + groupCode, + group.botAsMember.nameCardOrNick ) val response = diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/GroupImpl.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/GroupImpl.kt index 2f66dcc24..58f50ed1c 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/GroupImpl.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/GroupImpl.kt @@ -278,7 +278,7 @@ internal class GroupImpl( check(!isBotMuted) { "bot is muted. Remaining seconds=$botMuteRemaining" } val event = GroupMessageSendEvent(this, message.asMessageChain()).broadcast() if (event.isCancelled) { - throw EventCancelledException("cancelled by FriendMessageSendEvent") + throw EventCancelledException("cancelled by GroupMessageSendEvent") } lateinit var source: MessageSourceFromSendGroup bot.network.run { diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/MemberImpl.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/MemberImpl.kt index 0642a2cff..b4d203af6 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/MemberImpl.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/MemberImpl.kt @@ -7,6 +7,8 @@ * https://github.com/mamoe/mirai/blob/master/LICENSE */ +@file:Suppress("EXPERIMENTAL_API_USAGE") + package net.mamoe.mirai.qqandroid.contact import kotlinx.coroutines.launch diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/QQImpl.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/QQImpl.kt index 0e3b72fbe..f82210552 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/QQImpl.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/contact/QQImpl.kt @@ -8,6 +8,7 @@ */ @file:OptIn(MiraiInternalAPI::class, LowLevelAPI::class) +@file:Suppress("EXPERIMENTAL_API_USAGE") package net.mamoe.mirai.qqandroid.contact diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/MessageSourceImpl.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/MessageSourceImpl.kt index c33a7543d..6fbc7dfb3 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/MessageSourceImpl.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/MessageSourceImpl.kt @@ -7,6 +7,8 @@ * https://github.com/mamoe/mirai/blob/master/LICENSE */ +@file:Suppress("EXPERIMENTAL_API_USAGE", "EXPERIMENTAL_OVERRIDE") + package net.mamoe.mirai.qqandroid.message import kotlinx.coroutines.CoroutineScope @@ -146,7 +148,7 @@ internal abstract class MessageSourceFromSend : MessageSource { } private val elems by lazy { - originalMessage.toRichTextElems(groupId != 0L) + originalMessage.toRichTextElems(groupId != 0L, true) } private fun toJceDataImplForFriend(): ImMsgBody.SourceMsg { diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/messages.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/messages.kt index 6adc855e8..6cc9dda2e 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/messages.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/message/messages.kt @@ -7,6 +7,7 @@ * https://github.com/mamoe/mirai/blob/master/LICENSE */ @file: OptIn(MiraiExperimentalAPI::class, MiraiInternalAPI::class, LowLevelAPI::class, ExperimentalUnsignedTypes::class) +@file:Suppress("EXPERIMENTAL_API_USAGE") package net.mamoe.mirai.qqandroid.message diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/MultiMsg.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/MultiMsg.kt index 175c70785..4c19c70c8 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/MultiMsg.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/MultiMsg.kt @@ -52,7 +52,7 @@ internal fun MessageChain.calculateValidationDataForGroup( groupCode: Long, botMemberNameCard: String ): MessageValidationData { - val richTextElems = this.toRichTextElems(true) + val richTextElems = this.toRichTextElems(true, false) val msgTransmit = MsgTransmit.PbMultiMsgTransmit( msg = listOf( diff --git a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/receive/MessageSvc.kt b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/receive/MessageSvc.kt index 531074246..ebaa96325 100644 --- a/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/receive/MessageSvc.kt +++ b/mirai-core-qqandroid/src/commonMain/kotlin/net/mamoe/mirai/qqandroid/network/protocol/packet/chat/receive/MessageSvc.kt @@ -319,7 +319,7 @@ internal class MessageSvc { contentHead = MsgComm.ContentHead(pkgNum = 1), msgBody = ImMsgBody.MsgBody( richText = ImMsgBody.RichText( - elems = message.toRichTextElems(false) + elems = message.toRichTextElems(false, true) ) ), msgSeq = source.sequenceId, @@ -372,7 +372,7 @@ internal class MessageSvc { contentHead = MsgComm.ContentHead(pkgNum = 1), msgBody = ImMsgBody.MsgBody( richText = ImMsgBody.RichText( - elems = message.toRichTextElems(true) + elems = message.toRichTextElems(true, true) ) ), msgSeq = client.atomicNextMessageSequenceId(), diff --git a/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/Bot.kt b/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/Bot.kt index fd61cac27..6eb67021e 100644 --- a/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/Bot.kt +++ b/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/Bot.kt @@ -7,6 +7,7 @@ import kotlinx.coroutines.io.ByteReadChannel import net.mamoe.mirai.contact.* import net.mamoe.mirai.data.AddFriendResult import net.mamoe.mirai.message.MessageReceipt +import net.mamoe.mirai.message.data.ExperimentalMessageSource import net.mamoe.mirai.message.data.Image import net.mamoe.mirai.message.data.MessageChain import net.mamoe.mirai.message.data.MessageSource @@ -152,6 +153,7 @@ actual abstract class Bot actual constructor() : CoroutineScope, LowLevelBotAPIA * @see _lowLevelRecallFriendMessage 低级 API * @see _lowLevelRecallGroupMessage 低级 API */ + @ExperimentalMessageSource @JvmSynthetic actual abstract suspend fun recall(source: MessageSource) diff --git a/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt b/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt index 5e0d51757..bdbb0a9a1 100644 --- a/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt +++ b/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt @@ -5,6 +5,7 @@ import net.mamoe.mirai.contact.PermissionDeniedException import net.mamoe.mirai.contact.recall import net.mamoe.mirai.data.AddFriendResult import net.mamoe.mirai.message.MessageReceipt +import net.mamoe.mirai.message.data.ExperimentalMessageSource import net.mamoe.mirai.message.data.Image import net.mamoe.mirai.message.data.MessageChain import net.mamoe.mirai.message.data.MessageSource @@ -61,6 +62,7 @@ actual abstract class BotJavaFriendlyAPI actual constructor() { * * @see Bot.recall (扩展函数) 接受参数 [MessageChain] */ + @ExperimentalMessageSource @JvmName("recall") fun __recallBlockingForJava__(source: MessageSource) { runBlocking { recall(source) } @@ -88,6 +90,7 @@ actual abstract class BotJavaFriendlyAPI actual constructor() { * @param millis 延迟的时间, 单位为毫秒 * @see recall */ + @ExperimentalMessageSource @JvmName("recallIn") fun __recallIn_MemberForJava__(source: MessageSource, millis: Long) { runBlocking { recallIn(source, millis) } @@ -148,6 +151,7 @@ actual abstract class BotJavaFriendlyAPI actual constructor() { /** * 异步调用 [__recallBlockingForJava__] */ + @ExperimentalMessageSource @JvmName("recallAsync") fun __recallAsyncForJava__(source: MessageSource): Future { return future { recall(source) } diff --git a/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt b/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt index 4f4b4cb70..055ae7884 100644 --- a/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt +++ b/mirai-core/src/androidMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt @@ -29,7 +29,8 @@ import net.mamoe.mirai.utils.unsafeWeakRef */ @Suppress("FunctionName") @OptIn(MiraiInternalAPI::class) -actual open class MessageReceipt actual constructor( +actual open class MessageReceipt @OptIn(ExperimentalMessageSource::class) +actual constructor( actual val source: MessageSource, target: C, private val botAsMember: Member? @@ -56,6 +57,7 @@ actual open class MessageReceipt actual constructor( * @see Bot.recall * @throws IllegalStateException 当此消息已经被撤回或正计划撤回时 */ + @OptIn(ExperimentalMessageSource::class) actual suspend fun recall() { @Suppress("BooleanLiteralArgument") if (_isRecalled.compareAndSet(false, true)) { @@ -82,7 +84,8 @@ actual open class MessageReceipt actual constructor( if (_isRecalled.compareAndSet(false, true)) { return when (val contact = target) { is QQ, - is Group -> contact.bot.recallIn(source, millis) + is Group, + -> contact.bot.recallIn(source, millis) else -> error("Unknown contact type") } } else error("message is already or planned to be recalled") @@ -92,6 +95,7 @@ actual open class MessageReceipt actual constructor( * [确保 sequenceId可用][MessageSource.ensureSequenceIdAvailable] 然后引用这条消息. * @see MessageChain.quote 引用一条消息 */ + @OptIn(ExperimentalMessageSource::class) actual open suspend fun quote(): QuoteReplyToSend { this.source.ensureSequenceIdAvailable() @OptIn(LowLevelAPI::class) @@ -105,6 +109,7 @@ actual open class MessageReceipt actual constructor( * * @see MessageChain.quote 引用一条消息 */ + @OptIn(ExperimentalMessageSource::class) @LowLevelAPI @Suppress("FunctionName") actual fun _unsafeQuote(): QuoteReplyToSend { diff --git a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/Bot.kt b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/Bot.kt index 917d932f5..b0327a938 100644 --- a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/Bot.kt +++ b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/Bot.kt @@ -19,6 +19,7 @@ import kotlinx.coroutines.launch import net.mamoe.mirai.contact.* import net.mamoe.mirai.data.AddFriendResult import net.mamoe.mirai.message.MessageReceipt +import net.mamoe.mirai.message.data.ExperimentalMessageSource import net.mamoe.mirai.message.data.Image import net.mamoe.mirai.message.data.MessageChain import net.mamoe.mirai.message.data.MessageSource @@ -33,6 +34,7 @@ import kotlin.jvm.JvmSynthetic /** * 登录, 返回 [this] */ +@JvmSynthetic suspend inline fun B.alsoLogin(): B = also { login() } // 任何人都能看到这个方法 @@ -167,6 +169,7 @@ expect abstract class Bot() : CoroutineScope, LowLevelBotAPIAccessor { * @see _lowLevelRecallFriendMessage 低级 API * @see _lowLevelRecallGroupMessage 低级 API */ + @ExperimentalMessageSource @JvmSynthetic abstract suspend fun recall(source: MessageSource) @@ -223,6 +226,7 @@ expect abstract class Bot() : CoroutineScope, LowLevelBotAPIAccessor { * @throws PermissionDeniedException 当 [Bot] 无权限操作时 * @see Bot.recall */ +@JvmSynthetic suspend inline fun Bot.recall(message: MessageChain) = this.recall(message[MessageSource]) /** @@ -233,6 +237,7 @@ suspend inline fun Bot.recall(message: MessageChain) = this.recall(message[Messa * @param coroutineContext 额外的 [CoroutineContext] * @see recall */ +@JvmSynthetic inline fun Bot.recallIn( source: MessageSource, millis: Long, @@ -249,6 +254,7 @@ inline fun Bot.recallIn( * @param coroutineContext 额外的 [CoroutineContext] * @see recall */ +@JvmSynthetic inline fun Bot.recallIn( message: MessageChain, millis: Long, @@ -265,15 +271,20 @@ inline fun Bot.recallIn( * * @param cause 原因. 为 null 时视为正常关闭, 非 null 时视为异常关闭 */ +@JvmSynthetic suspend inline fun Bot.closeAndJoin(cause: Throwable? = null) { close(cause) coroutineContext[Job]?.join() } +@JvmSynthetic inline fun Bot.containsFriend(id: Long): Boolean = this.friends.contains(id) +@JvmSynthetic inline fun Bot.containsGroup(id: Long): Boolean = this.groups.contains(id) +@JvmSynthetic inline fun Bot.getFriendOrNull(id: Long): QQ? = this.friends.getOrNull(id) +@JvmSynthetic inline fun Bot.getGroupOrNull(id: Long): Group? = this.groups.getOrNull(id) \ No newline at end of file diff --git a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/MessageReceipt.kt b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/MessageReceipt.kt index a3469caae..8c9b67d5f 100644 --- a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/MessageReceipt.kt +++ b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/MessageReceipt.kt @@ -15,12 +15,16 @@ import net.mamoe.mirai.LowLevelAPI import net.mamoe.mirai.contact.* import net.mamoe.mirai.message.data.* import net.mamoe.mirai.recallIn +import kotlin.jvm.JvmSynthetic /** * 发送消息后得到的回执. 可用于撤回. * * 此对象持有 [Contact] 的弱引用, [Bot] 离线后将会释放引用, 届时 [target] 将无法访问. * + * @param source 指代发送出去的消息 + * @param target 消息发送对象 + * * @see Group.sendMessage 发送群消息, 返回回执(此对象) * @see QQ.sendMessage 发送群消息, 返回回执(此对象) * @@ -28,11 +32,15 @@ import net.mamoe.mirai.recallIn * @see MessageReceipt.sourceSequenceId 源序列号 * @see MessageReceipt.sourceTime 源时间 */ -expect open class MessageReceipt( +expect open class MessageReceipt @OptIn(ExperimentalMessageSource::class) constructor( source: MessageSource, target: C, botAsMember: Member? ) { + /** + * 指代发送出去的消息 + */ + @ExperimentalMessageSource val source: MessageSource /** @@ -90,6 +98,8 @@ expect open class MessageReceipt( * * @see MessageSource.id */ +@get:JvmSynthetic +@ExperimentalMessageSource inline val MessageReceipt<*>.sourceId: Long get() = this.source.id /** @@ -97,6 +107,8 @@ inline val MessageReceipt<*>.sourceId: Long get() = this.source.id * * @see MessageSource.sequenceId */ +@get:JvmSynthetic +@ExperimentalMessageSource inline val MessageReceipt<*>.sourceSequenceId: Int get() = this.source.sequenceId /** @@ -104,6 +116,8 @@ inline val MessageReceipt<*>.sourceSequenceId: Int get() = this.source.sequenceI * * @see MessageSource.time */ +@get:JvmSynthetic +@ExperimentalMessageSource inline val MessageReceipt<*>.sourceTime: Long get() = this.source.time suspend inline fun MessageReceipt.quoteReply(message: Message) { 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 c31a8d3cd..8c25df318 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 @@ -127,6 +127,7 @@ inline fun MessageChain.any(): Boolean = this.any { it is /** * 获取第一个 [M] 类型的 [Message] 实例 */ +@OptIn(ExperimentalMessageSource::class) @JvmSynthetic @Suppress("UNCHECKED_CAST") fun MessageChain.firstOrNull(key: Message.Key): M? = when (key) { diff --git a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageSource.kt b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageSource.kt index 340caee53..4a385bc98 100644 --- a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageSource.kt +++ b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/MessageSource.kt @@ -19,6 +19,12 @@ import kotlin.jvm.JvmMultifileClass import kotlin.jvm.JvmName import kotlin.jvm.JvmSynthetic +/** + * MessageSource 正计划于 0.32 或 0.33 或之后进行 API 不兼容的重写. + */ +@RequiresOptIn(message = "MessageSource 正计划于 0.32 或 0.33 或之后进行 API 不兼容的重写", level = RequiresOptIn.Level.WARNING) +annotation class ExperimentalMessageSource + /** * 消息源, 它存在于 [MessageChain] 中, 用于表示这个消息的来源. * @@ -29,6 +35,7 @@ import kotlin.jvm.JvmSynthetic * @see Bot.recall 撤回一条消息 * @see MessageSource.quote 引用这条消息, 创建 [MessageChain] */ +@ExperimentalMessageSource interface MessageSource : Message, MessageMetadata { companion object Key : Message.Key @@ -82,6 +89,7 @@ interface MessageSource : Message, MessageMetadata { * 序列号. 若是机器人发出去的消息, 请先 [确保 sequenceId 可用][MessageSource.ensureSequenceIdAvailable] * @see MessageSource.id */ +@ExperimentalMessageSource @get:JvmSynthetic inline val MessageSource.sequenceId: Int get() = (this.id shr 32).toInt() @@ -90,6 +98,7 @@ inline val MessageSource.sequenceId: Int * 消息随机数. 由服务器或客户端指定后不能更改. 它是消息 id 的一部分. * @see MessageSource.id */ +@ExperimentalMessageSource @get:JvmSynthetic inline val MessageSource.messageRandom: Int get() = this.id.toInt() @@ -98,24 +107,33 @@ inline val MessageSource.messageRandom: Int /** * 消息 id. + * + * 仅接收到的消息才可以获取这个 id. + * * @see MessageSource.id */ +@ExperimentalMessageSource @get:JvmSynthetic inline val MessageChain.id: Long get() = this[MessageSource].id /** * 消息序列号, 可能来自服务器也可以发送时赋值, 不唯一. + * + * 仅接收到的消息才可以获取这个序列号. + * * @see MessageSource.id */ +@ExperimentalMessageSource @get:JvmSynthetic inline val MessageChain.sequenceId: Int - get() = this[MessageSource].sequenceId + get() = this.getOrNull(MessageSource)?.sequenceId ?: error("Only MessageChain from server has sequenceId") /** * 消息随机数. 由服务器或客户端指定后不能更改. 它是消息 id 的一部分. * @see MessageSource.id */ +@ExperimentalMessageSource @get:JvmSynthetic inline val MessageChain.messageRandom: Int - get() = this[MessageSource].messageRandom + get() = this.getOrNull(MessageSource)?.messageRandom ?: error("Only MessageChain from server has sequenceId") diff --git a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/QuoteReply.kt b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/QuoteReply.kt index ddc73e5dc..bb4135fd8 100644 --- a/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/QuoteReply.kt +++ b/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/message/data/QuoteReply.kt @@ -29,6 +29,7 @@ import kotlin.jvm.JvmName * 总是使用 [quote] 来构造这个实例. */ open class QuoteReply +@OptIn(ExperimentalMessageSource::class) @MiraiInternalAPI constructor(val source: MessageSource) : Message, MessageMetadata { companion object Key : Message.Key @@ -39,7 +40,7 @@ open class QuoteReply * 用于发送的引用回复. * 总是使用 [quote] 来构造实例. */ -@OptIn(MiraiInternalAPI::class) +@OptIn(MiraiInternalAPI::class, ExperimentalMessageSource::class) sealed class QuoteReplyToSend @MiraiInternalAPI constructor(source: MessageSource) : QuoteReply(source) { class ToGroup(source: MessageSource, val sender: QQ) : QuoteReplyToSend(source) { @@ -53,7 +54,7 @@ sealed class QuoteReplyToSend * 引用这条消息. * @see sender 消息发送人. */ -@OptIn(MiraiInternalAPI::class) +@OptIn(MiraiInternalAPI::class, ExperimentalMessageSource::class) fun MessageChain.quote(sender: QQ?): QuoteReplyToSend { this.firstOrNull()?.let { return it.quote(sender) @@ -65,6 +66,7 @@ fun MessageChain.quote(sender: QQ?): QuoteReplyToSend { * 引用这条消息. * @see from 消息来源. 若是好友发送 */ +@ExperimentalMessageSource @OptIn(MiraiInternalAPI::class) fun MessageSource.quote(from: QQ?): QuoteReplyToSend { return if (this.groupId != 0L) { diff --git a/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/Bot.kt b/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/Bot.kt index f5f9a80bb..723cdbc23 100644 --- a/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/Bot.kt +++ b/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/Bot.kt @@ -7,6 +7,7 @@ import kotlinx.coroutines.io.ByteReadChannel import net.mamoe.mirai.contact.* import net.mamoe.mirai.data.AddFriendResult import net.mamoe.mirai.message.MessageReceipt +import net.mamoe.mirai.message.data.ExperimentalMessageSource import net.mamoe.mirai.message.data.Image import net.mamoe.mirai.message.data.MessageChain import net.mamoe.mirai.message.data.MessageSource @@ -162,6 +163,7 @@ actual abstract class Bot actual constructor() : CoroutineScope, LowLevelBotAPIA * @see _lowLevelRecallFriendMessage 低级 API * @see _lowLevelRecallGroupMessage 低级 API */ + @ExperimentalMessageSource @JvmSynthetic actual abstract suspend fun recall(source: MessageSource) diff --git a/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt b/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt index 2958730af..3974289d2 100644 --- a/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt +++ b/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/BotJavaFriendlyAPI.kt @@ -5,6 +5,7 @@ import net.mamoe.mirai.contact.PermissionDeniedException import net.mamoe.mirai.contact.recall import net.mamoe.mirai.data.AddFriendResult import net.mamoe.mirai.message.MessageReceipt +import net.mamoe.mirai.message.data.ExperimentalMessageSource import net.mamoe.mirai.message.data.Image import net.mamoe.mirai.message.data.MessageChain import net.mamoe.mirai.message.data.MessageSource @@ -61,6 +62,7 @@ actual abstract class BotJavaFriendlyAPI actual constructor() { * * @see Bot.recall (扩展函数) 接受参数 [MessageChain] */ + @ExperimentalMessageSource @JvmName("recall") fun __recallBlockingForJava__(source: MessageSource) { runBlocking { recall(source) } @@ -88,6 +90,7 @@ actual abstract class BotJavaFriendlyAPI actual constructor() { * @param millis 延迟的时间, 单位为毫秒 * @see recall */ + @ExperimentalMessageSource @JvmName("recallIn") fun __recallIn_MemberForJava__(source: MessageSource, millis: Long) { runBlocking { recallIn(source, millis) } @@ -148,6 +151,7 @@ actual abstract class BotJavaFriendlyAPI actual constructor() { /** * 异步调用 [__recallBlockingForJava__] */ + @ExperimentalMessageSource @JvmName("recallAsync") fun __recallAsyncForJava__(source: MessageSource): Future { return future { recall(source) } diff --git a/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt b/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt index 58595ccbe..d77aea180 100644 --- a/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt +++ b/mirai-core/src/jvmMain/kotlin/net/mamoe/mirai/message/MessageReceipt.kt @@ -29,7 +29,8 @@ import net.mamoe.mirai.utils.unsafeWeakRef */ @Suppress("FunctionName") @OptIn(MiraiInternalAPI::class) -actual open class MessageReceipt actual constructor( +actual open class MessageReceipt @OptIn(ExperimentalMessageSource::class) +actual constructor( actual val source: MessageSource, target: C, private val botAsMember: Member? @@ -56,6 +57,7 @@ actual open class MessageReceipt actual constructor( * @see Bot.recall * @throws IllegalStateException 当此消息已经被撤回或正计划撤回时 */ + @OptIn(ExperimentalMessageSource::class) actual suspend fun recall() { @Suppress("BooleanLiteralArgument") if (_isRecalled.compareAndSet(false, true)) { @@ -84,6 +86,7 @@ actual open class MessageReceipt actual constructor( * [确保 sequenceId可用][MessageSource.ensureSequenceIdAvailable] 然后引用这条消息. * @see MessageChain.quote 引用一条消息 */ + @OptIn(ExperimentalMessageSource::class) actual open suspend fun quote(): QuoteReplyToSend { this.source.ensureSequenceIdAvailable() @OptIn(LowLevelAPI::class) @@ -97,6 +100,7 @@ actual open class MessageReceipt actual constructor( * * @see MessageChain.quote 引用一条消息 */ + @OptIn(ExperimentalMessageSource::class) @LowLevelAPI @Suppress("FunctionName") actual fun _unsafeQuote(): QuoteReplyToSend {