mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-23 14:20:24 +08:00
[core] Try to fix rand id fetching
This commit is contained in:
parent
00486e7900
commit
8c5a22a14e
@ -13,6 +13,7 @@ import net.mamoe.mirai.contact.Contact
|
|||||||
import net.mamoe.mirai.contact.roaming.RoamingMessage
|
import net.mamoe.mirai.contact.roaming.RoamingMessage
|
||||||
import net.mamoe.mirai.contact.roaming.RoamingMessages
|
import net.mamoe.mirai.contact.roaming.RoamingMessages
|
||||||
import net.mamoe.mirai.internal.contact.AbstractContact
|
import net.mamoe.mirai.internal.contact.AbstractContact
|
||||||
|
import net.mamoe.mirai.internal.message.source.decodeRandom
|
||||||
import net.mamoe.mirai.internal.network.protocol.data.proto.MsgComm
|
import net.mamoe.mirai.internal.network.protocol.data.proto.MsgComm
|
||||||
import net.mamoe.mirai.utils.mapToIntArray
|
import net.mamoe.mirai.utils.mapToIntArray
|
||||||
import net.mamoe.mirai.utils.toLongUnsigned
|
import net.mamoe.mirai.utils.toLongUnsigned
|
||||||
@ -31,7 +32,7 @@ internal abstract class AbstractRoamingMessages : RoamingMessages {
|
|||||||
override val time: Long get() = message.msgHead.msgTime.toLongUnsigned()
|
override val time: Long get() = message.msgHead.msgTime.toLongUnsigned()
|
||||||
override val ids: IntArray by lazy { messages.mapToIntArray { it.msgHead.msgSeq } }
|
override val ids: IntArray by lazy { messages.mapToIntArray { it.msgHead.msgSeq } }
|
||||||
override val internalIds: IntArray by lazy {
|
override val internalIds: IntArray by lazy {
|
||||||
messages.mapToIntArray { it.msgBody.richText.attr?.random ?: 0 } // other client 消息的这个是0
|
messages.mapToIntArray { it.decodeRandom() }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -56,9 +56,7 @@ internal class OnlineMessageSourceFromFriendImpl(
|
|||||||
override val isRecalledOrPlanned: Boolean get() = _isRecalledOrPlanned.value
|
override val isRecalledOrPlanned: Boolean get() = _isRecalledOrPlanned.value
|
||||||
override fun setRecalled(): Boolean = _isRecalledOrPlanned.compareAndSet(expect = false, update = true)
|
override fun setRecalled(): Boolean = _isRecalledOrPlanned.compareAndSet(expect = false, update = true)
|
||||||
override val ids: IntArray get() = sequenceIds // msg.msgBody.richText.attr!!.random
|
override val ids: IntArray get() = sequenceIds // msg.msgBody.richText.attr!!.random
|
||||||
override val internalIds: IntArray = msg.mapToIntArray {
|
override val internalIds: IntArray = msg.mapToIntArray { it.decodeRandom() }
|
||||||
it.msgBody.richText.attr?.random ?: 0
|
|
||||||
} // other client 消息的这个是0
|
|
||||||
override val time: Int = msg.first().msgHead.msgTime
|
override val time: Int = msg.first().msgHead.msgTime
|
||||||
override var originalMessageLazy = lazy {
|
override var originalMessageLazy = lazy {
|
||||||
msg.toMessageChainNoSource(bot, 0, MessageSourceKind.FRIEND)
|
msg.toMessageChainNoSource(bot, 0, MessageSourceKind.FRIEND)
|
||||||
@ -95,9 +93,7 @@ internal class OnlineMessageSourceFromStrangerImpl(
|
|||||||
override fun setRecalled(): Boolean = _isRecalledOrPlanned.compareAndSet(expect = false, update = true)
|
override fun setRecalled(): Boolean = _isRecalledOrPlanned.compareAndSet(expect = false, update = true)
|
||||||
|
|
||||||
override val ids: IntArray get() = sequenceIds // msg.msgBody.richText.attr!!.random
|
override val ids: IntArray get() = sequenceIds // msg.msgBody.richText.attr!!.random
|
||||||
override val internalIds: IntArray = msg.mapToIntArray {
|
override val internalIds: IntArray = msg.mapToIntArray { it.decodeRandom() }
|
||||||
it.msgBody.richText.attr?.random ?: 0
|
|
||||||
} // other client 消息的这个是0
|
|
||||||
override val time: Int = msg.first().msgHead.msgTime
|
override val time: Int = msg.first().msgHead.msgTime
|
||||||
override var originalMessageLazy = lazy {
|
override var originalMessageLazy = lazy {
|
||||||
msg.toMessageChainNoSource(bot, 0, MessageSourceKind.STRANGER)
|
msg.toMessageChainNoSource(bot, 0, MessageSourceKind.STRANGER)
|
||||||
@ -159,6 +155,13 @@ private fun List<MsgComm.Msg>.toJceDataPrivate(ids: IntArray): ImMsgBody.SourceM
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal fun MsgComm.Msg.decodeRandom(): Int {
|
||||||
|
msgBody.richText.attr?.random?.let { return it }
|
||||||
|
|
||||||
|
// msg uin = 0x100000000000000 or rand.toLongUnsigned()
|
||||||
|
return msgHead.msgUid.toInt()
|
||||||
|
}
|
||||||
|
|
||||||
@Suppress("SERIALIZER_TYPE_INCOMPATIBLE")
|
@Suppress("SERIALIZER_TYPE_INCOMPATIBLE")
|
||||||
@Serializable(OnlineMessageSourceFromTempImpl.Serializer::class)
|
@Serializable(OnlineMessageSourceFromTempImpl.Serializer::class)
|
||||||
internal class OnlineMessageSourceFromTempImpl(
|
internal class OnlineMessageSourceFromTempImpl(
|
||||||
@ -168,7 +171,7 @@ internal class OnlineMessageSourceFromTempImpl(
|
|||||||
object Serializer : KSerializer<MessageSource> by MessageSourceSerializerImpl("OnlineMessageSourceFromTemp")
|
object Serializer : KSerializer<MessageSource> by MessageSourceSerializerImpl("OnlineMessageSourceFromTemp")
|
||||||
|
|
||||||
override val sequenceIds: IntArray = msg.mapToIntArray { it.msgHead.msgSeq }
|
override val sequenceIds: IntArray = msg.mapToIntArray { it.msgHead.msgSeq }
|
||||||
override val internalIds: IntArray = msg.mapToIntArray { it.msgBody.richText.attr!!.random }
|
override val internalIds: IntArray = msg.mapToIntArray { it.decodeRandom() }
|
||||||
|
|
||||||
private val _isRecalledOrPlanned = atomic(false)
|
private val _isRecalledOrPlanned = atomic(false)
|
||||||
|
|
||||||
@ -217,7 +220,7 @@ internal class OnlineMessageSourceFromGroupImpl(
|
|||||||
override val isRecalledOrPlanned: Boolean get() = _isRecalledOrPlanned.value
|
override val isRecalledOrPlanned: Boolean get() = _isRecalledOrPlanned.value
|
||||||
override fun setRecalled(): Boolean = _isRecalledOrPlanned.compareAndSet(expect = false, update = true)
|
override fun setRecalled(): Boolean = _isRecalledOrPlanned.compareAndSet(expect = false, update = true)
|
||||||
override val sequenceIds: IntArray = msg.mapToIntArray { it.msgHead.msgSeq }
|
override val sequenceIds: IntArray = msg.mapToIntArray { it.msgHead.msgSeq }
|
||||||
override val internalIds: IntArray = msg.mapToIntArray { it.msgBody.richText.attr!!.random }
|
override val internalIds: IntArray = msg.mapToIntArray { it.decodeRandom() }
|
||||||
override val ids: IntArray get() = sequenceIds
|
override val ids: IntArray get() = sequenceIds
|
||||||
override val time: Int = msg.first().msgHead.msgTime
|
override val time: Int = msg.first().msgHead.msgTime
|
||||||
override var originalMessageLazy = lazy {
|
override var originalMessageLazy = lazy {
|
||||||
|
Loading…
Reference in New Issue
Block a user