mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-07 16:40:43 +08:00
Fix #106
This commit is contained in:
parent
b9d5fa4c14
commit
095feaf5cb
@ -36,6 +36,8 @@ import net.mamoe.mirai.qqandroid.network.protocol.packet.chat.receive.MessageSvc
|
|||||||
import net.mamoe.mirai.qqandroid.utils.toIpV4AddressString
|
import net.mamoe.mirai.qqandroid.utils.toIpV4AddressString
|
||||||
import net.mamoe.mirai.utils.*
|
import net.mamoe.mirai.utils.*
|
||||||
import net.mamoe.mirai.utils.io.toUHexString
|
import net.mamoe.mirai.utils.io.toUHexString
|
||||||
|
import kotlin.contracts.ExperimentalContracts
|
||||||
|
import kotlin.contracts.contract
|
||||||
import kotlin.coroutines.CoroutineContext
|
import kotlin.coroutines.CoroutineContext
|
||||||
import net.mamoe.mirai.qqandroid.network.protocol.data.jce.FriendInfo as JceFriendInfo
|
import net.mamoe.mirai.qqandroid.network.protocol.data.jce.FriendInfo as JceFriendInfo
|
||||||
|
|
||||||
@ -356,10 +358,14 @@ internal class MemberInfoImpl(
|
|||||||
override val muteTimestamp: Int = jceInfo.dwShutupTimestap?.toInt() ?: 0
|
override val muteTimestamp: Int = jceInfo.dwShutupTimestap?.toInt() ?: 0
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
@OptIn(ExperimentalContracts::class)
|
||||||
* 对GroupImpl
|
internal fun GroupImpl.Companion.checkIsInstance(expression: Boolean) {
|
||||||
* 中name/announcement的更改会直接向服务器异步汇报
|
contract {
|
||||||
*/
|
returns() implies expression
|
||||||
|
}
|
||||||
|
check(expression) { "group is not an instanceof GroupImpl!! DO NOT interlace two or more protocol implementations!!" }
|
||||||
|
}
|
||||||
|
|
||||||
@Suppress("PropertyName")
|
@Suppress("PropertyName")
|
||||||
@OptIn(MiraiInternalAPI::class)
|
@OptIn(MiraiInternalAPI::class)
|
||||||
internal class GroupImpl(
|
internal class GroupImpl(
|
||||||
@ -368,6 +374,10 @@ internal class GroupImpl(
|
|||||||
groupInfo: GroupInfo,
|
groupInfo: GroupInfo,
|
||||||
members: Sequence<MemberInfo>
|
members: Sequence<MemberInfo>
|
||||||
) : Group() {
|
) : Group() {
|
||||||
|
companion object {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
override val bot: QQAndroidBot by bot.unsafeWeakRef()
|
override val bot: QQAndroidBot by bot.unsafeWeakRef()
|
||||||
val uin: Long = groupInfo.uin
|
val uin: Long = groupInfo.uin
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@ import net.mamoe.mirai.message.GroupMessage
|
|||||||
import net.mamoe.mirai.qqandroid.GroupImpl
|
import net.mamoe.mirai.qqandroid.GroupImpl
|
||||||
import net.mamoe.mirai.qqandroid.MemberImpl
|
import net.mamoe.mirai.qqandroid.MemberImpl
|
||||||
import net.mamoe.mirai.qqandroid.QQAndroidBot
|
import net.mamoe.mirai.qqandroid.QQAndroidBot
|
||||||
|
import net.mamoe.mirai.qqandroid.checkIsInstance
|
||||||
import net.mamoe.mirai.qqandroid.io.serialization.decodeUniPacket
|
import net.mamoe.mirai.qqandroid.io.serialization.decodeUniPacket
|
||||||
import net.mamoe.mirai.qqandroid.io.serialization.readProtoBuf
|
import net.mamoe.mirai.qqandroid.io.serialization.readProtoBuf
|
||||||
import net.mamoe.mirai.qqandroid.message.toMessageChain
|
import net.mamoe.mirai.qqandroid.message.toMessageChain
|
||||||
@ -111,7 +112,9 @@ internal class OnlinePush {
|
|||||||
val group = bot.getGroupByUin(content.fromUin) as GroupImpl
|
val group = bot.getGroupByUin(content.fromUin) as GroupImpl
|
||||||
if (var5 == 0L && this.remaining == 1L) {//管理员变更
|
if (var5 == 0L && this.remaining == 1L) {//管理员变更
|
||||||
val newPermission =
|
val newPermission =
|
||||||
if (this.readByte().toInt() == 1) MemberPermission.ADMINISTRATOR else MemberPermission.MEMBER
|
if (this.readByte()
|
||||||
|
.toInt() == 1
|
||||||
|
) MemberPermission.ADMINISTRATOR else MemberPermission.MEMBER
|
||||||
|
|
||||||
return if (target == bot.uin) {
|
return if (target == bot.uin) {
|
||||||
BotGroupPermissionChangeEvent(
|
BotGroupPermissionChangeEvent(
|
||||||
@ -188,22 +191,21 @@ internal class OnlinePush {
|
|||||||
override suspend fun ByteReadPacket.decode(bot: QQAndroidBot, sequenceId: Int): Packet {
|
override suspend fun ByteReadPacket.decode(bot: QQAndroidBot, sequenceId: Int): Packet {
|
||||||
val reqPushMsg = decodeUniPacket(OnlinePushPack.SvcReqPushMsg.serializer(), "req")
|
val reqPushMsg = decodeUniPacket(OnlinePushPack.SvcReqPushMsg.serializer(), "req")
|
||||||
|
|
||||||
@Suppress("USELESS_CAST") // 不要信任 kotlin 类型推断
|
|
||||||
val packets: Sequence<Packet> =
|
val packets: Sequence<Packet> =
|
||||||
reqPushMsg.vMsgInfos.asSequence().flatMap<MsgInfo, Packet> { msgInfo: MsgInfo ->
|
reqPushMsg.vMsgInfos.asSequence().flatMap<MsgInfo, Packet> { msgInfo: MsgInfo ->
|
||||||
msgInfo.vMsg!!.read {
|
msgInfo.vMsg!!.read {
|
||||||
when (msgInfo.shMsgType.toInt()) {
|
when (msgInfo.shMsgType.toInt()) {
|
||||||
732 -> {
|
732 -> {
|
||||||
val group = bot.getGroup(this.readUInt().toLong())
|
val group = bot.getGroup(this.readUInt().toLong())
|
||||||
group as GroupImpl
|
GroupImpl.checkIsInstance(group is GroupImpl)
|
||||||
|
|
||||||
when (val internalType = this.readByte().toInt().also { this.discardExact(1) }) {
|
when (val internalType = this.readByte().toInt().also { this.discardExact(1) }) {
|
||||||
0x0c -> { // mute
|
0x0c -> { // mute
|
||||||
val operatorUin = this.readUInt().toLong()
|
val operatorUin = this.readUInt().toLong()
|
||||||
if (operatorUin == bot.uin) {
|
if (operatorUin == bot.uin) {
|
||||||
return@flatMap sequenceOf<Packet>()
|
return@flatMap sequenceOf()
|
||||||
}
|
}
|
||||||
val operator = group[operatorUin]
|
val operator = group.getOrNull(operatorUin) ?: return@flatMap sequenceOf()
|
||||||
this.readUInt().toLong() // time
|
this.readUInt().toLong() // time
|
||||||
this.discardExact(2)
|
this.discardExact(2)
|
||||||
val target = this.readUInt().toLong()
|
val target = this.readUInt().toLong()
|
||||||
@ -217,7 +219,7 @@ internal class OnlinePush {
|
|||||||
new = false,
|
new = false,
|
||||||
operator = operator,
|
operator = operator,
|
||||||
group = group
|
group = group
|
||||||
) as Packet
|
)
|
||||||
)
|
)
|
||||||
} else {
|
} else {
|
||||||
return@flatMap sequenceOf(
|
return@flatMap sequenceOf(
|
||||||
@ -226,58 +228,58 @@ internal class OnlinePush {
|
|||||||
new = true,
|
new = true,
|
||||||
operator = operator,
|
operator = operator,
|
||||||
group = group
|
group = group
|
||||||
) as Packet
|
)
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (target == bot.uin) {
|
if (target == bot.uin) {
|
||||||
if (group._botMuteTimestamp != time) {
|
if (group._botMuteTimestamp == time) {
|
||||||
if (time == 0) {
|
|
||||||
group._botMuteTimestamp = 0
|
|
||||||
return@flatMap sequenceOf(BotUnmuteEvent(operator) as Packet)
|
|
||||||
} else {
|
|
||||||
group._botMuteTimestamp = time
|
|
||||||
return@flatMap sequenceOf(
|
|
||||||
BotMuteEvent(
|
|
||||||
durationSeconds = time,
|
|
||||||
operator = operator
|
|
||||||
) as Packet
|
|
||||||
)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return@flatMap sequenceOf()
|
return@flatMap sequenceOf()
|
||||||
}
|
}
|
||||||
} else {
|
if (time == 0) {
|
||||||
val member = group[target]
|
group._botMuteTimestamp = 0
|
||||||
member as MemberImpl
|
return@flatMap sequenceOf(BotUnmuteEvent(operator))
|
||||||
if (member._muteTimestamp != time) {
|
|
||||||
if (time == 0) {
|
|
||||||
member._muteTimestamp = 0
|
|
||||||
return@flatMap sequenceOf(
|
|
||||||
MemberUnmuteEvent(
|
|
||||||
member,
|
|
||||||
operator
|
|
||||||
) as Packet
|
|
||||||
)
|
|
||||||
} else {
|
|
||||||
member._muteTimestamp = time
|
|
||||||
return@flatMap sequenceOf(
|
|
||||||
MemberMuteEvent(
|
|
||||||
member,
|
|
||||||
time,
|
|
||||||
operator
|
|
||||||
) as Packet
|
|
||||||
)
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
|
group._botMuteTimestamp = time
|
||||||
|
return@flatMap sequenceOf(
|
||||||
|
BotMuteEvent(
|
||||||
|
durationSeconds = time,
|
||||||
|
operator = operator
|
||||||
|
)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
val member = group.getOrNull(target) ?: return@flatMap sequenceOf()
|
||||||
|
member as MemberImpl
|
||||||
|
if (member._muteTimestamp == time) {
|
||||||
return@flatMap sequenceOf()
|
return@flatMap sequenceOf()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (time == 0) {
|
||||||
|
member._muteTimestamp = 0
|
||||||
|
return@flatMap sequenceOf(
|
||||||
|
MemberUnmuteEvent(
|
||||||
|
member,
|
||||||
|
operator
|
||||||
|
)
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
member._muteTimestamp = time
|
||||||
|
return@flatMap sequenceOf(
|
||||||
|
MemberMuteEvent(
|
||||||
|
member,
|
||||||
|
time,
|
||||||
|
operator
|
||||||
|
)
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
0x0e -> {
|
0x0e -> {
|
||||||
// 匿名
|
// 匿名
|
||||||
val operator = group[this.readUInt().toLong()]
|
val operator =
|
||||||
|
group.getOrNull(this.readUInt().toLong()) ?: return@flatMap sequenceOf()
|
||||||
val switch = this.readInt() == 0
|
val switch = this.readInt() == 0
|
||||||
return@flatMap sequenceOf(
|
return@flatMap sequenceOf(
|
||||||
GroupAllowAnonymousChatEvent(
|
GroupAllowAnonymousChatEvent(
|
||||||
@ -342,6 +344,9 @@ internal class OnlinePush {
|
|||||||
discard(1)
|
discard(1)
|
||||||
val proto = readProtoBuf(TroopTips0x857.NotifyMsgBody.serializer())
|
val proto = readProtoBuf(TroopTips0x857.NotifyMsgBody.serializer())
|
||||||
proto.optMsgRecall?.let { recallReminder ->
|
proto.optMsgRecall?.let { recallReminder ->
|
||||||
|
|
||||||
|
val memebr =
|
||||||
|
group.getOrNull(recallReminder.uin) ?: return@flatMap sequenceOf()
|
||||||
return@flatMap recallReminder.recalledMsgList.asSequence()
|
return@flatMap recallReminder.recalledMsgList.asSequence()
|
||||||
.mapNotNull { meta ->
|
.mapNotNull { meta ->
|
||||||
if (meta.authorUin == bot.uin) {
|
if (meta.authorUin == bot.uin) {
|
||||||
@ -349,32 +354,13 @@ internal class OnlinePush {
|
|||||||
} else MessageRecallEvent.GroupRecall(
|
} else MessageRecallEvent.GroupRecall(
|
||||||
bot,
|
bot,
|
||||||
meta.authorUin,
|
meta.authorUin,
|
||||||
meta.seq.toLong().shl(32) or meta.msgRandom.toLong().and(
|
meta.seq.toLong().shl(32) or
|
||||||
0xffffffff
|
meta.msgRandom.toLong().and(0xffffffff),
|
||||||
),
|
|
||||||
meta.time,
|
meta.time,
|
||||||
group.get(recallReminder.uin),
|
memebr,
|
||||||
group
|
group
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
optMsgRecall=MessageRecallReminder#1345636186 {
|
|
||||||
groupType=0x00000000(0)
|
|
||||||
nickname=<Empty ByteArray>
|
|
||||||
opType=0x00000000(0)
|
|
||||||
recalledMsgList=[MessageMeta#1828757853 {
|
|
||||||
authorUin=0x000000003E033FA2(1040400290)
|
|
||||||
msgFlag=0x00000000(0)
|
|
||||||
msgRandom=0x509119DC(1351686620)
|
|
||||||
msgType=0x00000000(0)
|
|
||||||
seq=0x0000EB4B(60235)
|
|
||||||
time=0x5E50C4EC(1582351596)
|
|
||||||
}]
|
|
||||||
reminderContent=<Empty ByteArray>
|
|
||||||
uin=0x000000003E033FA2(1040400290)
|
|
||||||
userdef=08 00 12 0A 08 CB D6 03 10 00 18 01 20 00
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return@flatMap sequenceOf()
|
return@flatMap sequenceOf()
|
||||||
@ -384,7 +370,10 @@ internal class OnlinePush {
|
|||||||
// println(msgInfo.vMsg.toUHexString())
|
// println(msgInfo.vMsg.toUHexString())
|
||||||
// }
|
// }
|
||||||
else -> {
|
else -> {
|
||||||
bot.network.logger.debug { "unknown group internal type $internalType , data: " + this.readBytes().toUHexString() + " " }
|
bot.network.logger.debug {
|
||||||
|
"unknown group internal type $internalType , data: " + this.readBytes()
|
||||||
|
.toUHexString() + " "
|
||||||
|
}
|
||||||
return@flatMap sequenceOf()
|
return@flatMap sequenceOf()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user