mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-07 08:30:11 +08:00
Fix sso and event logging
This commit is contained in:
parent
971685a2b0
commit
5fa54114c1
@ -14,9 +14,13 @@ package net.mamoe.mirai.event
|
||||
import kotlinx.coroutines.runBlocking
|
||||
import kotlinx.coroutines.sync.Mutex
|
||||
import kotlinx.coroutines.sync.withLock
|
||||
import net.mamoe.mirai.event.events.BotEvent
|
||||
import net.mamoe.mirai.internal.event.broadcastInternal
|
||||
import net.mamoe.mirai.internal.network.Packet
|
||||
import net.mamoe.mirai.utils.JavaFriendlyAPI
|
||||
import net.mamoe.mirai.utils.MiraiExperimentalApi
|
||||
import net.mamoe.mirai.utils.MiraiLogger
|
||||
import net.mamoe.mirai.utils.verbose
|
||||
|
||||
/**
|
||||
* 可被监听的类, 可以是任何 class 或 object.
|
||||
@ -149,6 +153,14 @@ public suspend fun <E : Event> E.broadcast(): E = apply {
|
||||
}
|
||||
this.broadCastLock.withLock {
|
||||
this._intercepted = false
|
||||
if (EventDisabled) return@withLock
|
||||
if (this is Packet.NoEventLog) return@withLock
|
||||
if (this is Packet) return@withLock // all [Packet]s are logged in [LoggingPacketHandler]
|
||||
if (this is BotEvent) {
|
||||
this.bot.logger.verbose { "Event: $this" }
|
||||
} else {
|
||||
MiraiLogger.TopLevel.verbose { "Event: $this" }
|
||||
}
|
||||
this.broadcastInternal() // inline, no extra cost
|
||||
}
|
||||
}
|
||||
|
@ -100,7 +100,6 @@ internal object GlobalEventListeners {
|
||||
// inline: NO extra Continuation
|
||||
@Suppress("UNCHECKED_CAST")
|
||||
internal suspend inline fun AbstractEvent.broadcastInternal() {
|
||||
if (EventDisabled) return
|
||||
callAndRemoveIfRequired(this@broadcastInternal)
|
||||
}
|
||||
|
||||
|
@ -21,6 +21,7 @@ import kotlinx.serialization.json.*
|
||||
import net.mamoe.mirai.*
|
||||
import net.mamoe.mirai.contact.*
|
||||
import net.mamoe.mirai.data.*
|
||||
import net.mamoe.mirai.event.broadcast
|
||||
import net.mamoe.mirai.event.events.BotInvitedJoinGroupRequestEvent
|
||||
import net.mamoe.mirai.event.events.FriendAddEvent
|
||||
import net.mamoe.mirai.event.events.MemberJoinRequestEvent
|
||||
@ -43,7 +44,6 @@ import net.mamoe.mirai.internal.network.protocol.packet.login.StatSvc
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.sendAndExpect
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.summarycard.SummaryCard
|
||||
import net.mamoe.mirai.internal.utils.MiraiProtocolInternal
|
||||
import net.mamoe.mirai.internal.utils.broadcastWithBot
|
||||
import net.mamoe.mirai.internal.utils.crypto.TEA
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.loadAs
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.toByteArray
|
||||
@ -156,7 +156,7 @@ internal open class MiraiImpl : IMirai, LowLevelApiAccessor {
|
||||
)
|
||||
|
||||
event.bot.getFriend(event.fromId)?.let { friend ->
|
||||
FriendAddEvent(friend).broadcastWithBot(event.bot)
|
||||
FriendAddEvent(friend).broadcast()
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -10,6 +10,7 @@
|
||||
|
||||
package net.mamoe.mirai.internal
|
||||
|
||||
import kotlinx.atomicfu.atomic
|
||||
import kotlinx.coroutines.launch
|
||||
import kotlinx.coroutines.runBlocking
|
||||
import kotlinx.coroutines.sync.Mutex
|
||||
@ -30,6 +31,8 @@ import net.mamoe.mirai.internal.network.context.SsoProcessorContextImpl
|
||||
import net.mamoe.mirai.internal.network.handler.NetworkHandler
|
||||
import net.mamoe.mirai.internal.network.handler.NetworkHandler.State
|
||||
import net.mamoe.mirai.internal.network.handler.NetworkHandlerContextImpl
|
||||
import net.mamoe.mirai.internal.network.handler.NetworkHandlerSupport
|
||||
import net.mamoe.mirai.internal.network.handler.NetworkHandlerSupport.BaseStateImpl
|
||||
import net.mamoe.mirai.internal.network.handler.selector.FactoryKeepAliveNetworkHandlerSelector
|
||||
import net.mamoe.mirai.internal.network.handler.selector.SelectorNetworkHandler
|
||||
import net.mamoe.mirai.internal.network.handler.state.*
|
||||
@ -103,13 +106,20 @@ internal open class QQAndroidBot constructor(
|
||||
val components = this
|
||||
return StateObserver.chainOfNotNull(
|
||||
components[BotInitProcessor].asObserver(),
|
||||
StateChangedObserver(to = State.OK) { new ->
|
||||
object : StateChangedObserver(State.OK) {
|
||||
private val shouldBroadcastRelogin = atomic(false)
|
||||
override fun stateChanged0(
|
||||
networkHandler: NetworkHandlerSupport,
|
||||
previous: BaseStateImpl,
|
||||
new: BaseStateImpl
|
||||
) {
|
||||
bot.launch(logger.asCoroutineExceptionHandler()) {
|
||||
BotOnlineEvent(bot).broadcast()
|
||||
if (bot.components[SsoProcessor].firstLoginSucceed) { // TODO: 2021/4/21 actually no use
|
||||
if (shouldBroadcastRelogin.compareAndSet(false, true)) {
|
||||
BotReloginEvent(bot, new.getCause()).broadcast()
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
StateChangedObserver(State.OK, State.CONNECTING) { new ->
|
||||
bot.launch(logger.asCoroutineExceptionHandler()) {
|
||||
@ -155,8 +165,9 @@ internal open class QQAndroidBot constructor(
|
||||
set(ServerList, ServerListImpl())
|
||||
set(
|
||||
PacketHandler, PacketHandlerChain(
|
||||
LoggingPacketHandler(bot, components, networkLogger),
|
||||
EventBroadcasterPacketHandler(bot, components, logger)
|
||||
LoggingPacketHandler(bot, networkLogger),
|
||||
EventBroadcasterPacketHandler(networkLogger),
|
||||
CallPacketFactoryPacketHandler(bot)
|
||||
)
|
||||
)
|
||||
set(PacketCodec, PacketCodecImpl())
|
||||
|
@ -38,7 +38,6 @@ import net.mamoe.mirai.internal.network.protocol.packet.chat.voice.voiceCodec
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.list.ProfileService
|
||||
import net.mamoe.mirai.internal.utils.GroupPkgMsgParsingCache
|
||||
import net.mamoe.mirai.internal.utils.RemoteFileImpl
|
||||
import net.mamoe.mirai.internal.utils.broadcastWithBot
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.toByteArray
|
||||
import net.mamoe.mirai.message.MessageReceipt
|
||||
import net.mamoe.mirai.message.data.*
|
||||
@ -111,7 +110,7 @@ internal class GroupImpl(
|
||||
}
|
||||
}
|
||||
}
|
||||
BotLeaveEvent.Active(this).broadcastWithBot(bot)
|
||||
BotLeaveEvent.Active(this).broadcast()
|
||||
return true
|
||||
}
|
||||
|
||||
|
@ -13,16 +13,18 @@ package net.mamoe.mirai.internal.contact
|
||||
|
||||
import kotlinx.atomicfu.AtomicInt
|
||||
import kotlinx.atomicfu.atomic
|
||||
import kotlinx.coroutines.*
|
||||
import kotlinx.coroutines.CancellationException
|
||||
import kotlinx.coroutines.cancel
|
||||
import kotlinx.coroutines.launch
|
||||
import net.mamoe.mirai.LowLevelApi
|
||||
import net.mamoe.mirai.contact.*
|
||||
import net.mamoe.mirai.data.MemberInfo
|
||||
import net.mamoe.mirai.event.broadcast
|
||||
import net.mamoe.mirai.event.events.*
|
||||
import net.mamoe.mirai.internal.message.OnlineMessageSourceToTempImpl
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.chat.TroopManagement
|
||||
import net.mamoe.mirai.internal.utils.broadcastWithBot
|
||||
import net.mamoe.mirai.message.MessageReceipt
|
||||
import net.mamoe.mirai.message.data.*
|
||||
import net.mamoe.mirai.message.data.Message
|
||||
import net.mamoe.mirai.utils.cast
|
||||
import net.mamoe.mirai.utils.currentTimeSeconds
|
||||
import kotlin.contracts.ExperimentalContracts
|
||||
@ -99,7 +101,7 @@ internal class NormalMemberImpl constructor(
|
||||
newValue
|
||||
).sendWithoutExpect()
|
||||
}
|
||||
MemberCardChangeEvent(oldValue, newValue, this@NormalMemberImpl).broadcastWithBot(bot)
|
||||
MemberCardChangeEvent(oldValue, newValue, this@NormalMemberImpl).broadcast()
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -119,7 +121,7 @@ internal class NormalMemberImpl constructor(
|
||||
newValue
|
||||
).sendWithoutExpect()
|
||||
}
|
||||
MemberSpecialTitleChangeEvent(oldValue, newValue, this@NormalMemberImpl, null).broadcastWithBot(bot)
|
||||
MemberSpecialTitleChangeEvent(oldValue, newValue, this@NormalMemberImpl, null).broadcast()
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -142,7 +144,7 @@ internal class NormalMemberImpl constructor(
|
||||
}
|
||||
|
||||
@Suppress("RemoveRedundantQualifierName") // or unresolved reference
|
||||
net.mamoe.mirai.event.events.MemberMuteEvent(this@NormalMemberImpl, durationSeconds, null).broadcastWithBot(bot)
|
||||
(net.mamoe.mirai.event.events.MemberMuteEvent(this@NormalMemberImpl, durationSeconds, null).broadcast())
|
||||
this._muteTimestamp = currentTimeSeconds().toInt() + durationSeconds
|
||||
}
|
||||
|
||||
@ -158,7 +160,7 @@ internal class NormalMemberImpl constructor(
|
||||
}
|
||||
|
||||
@Suppress("RemoveRedundantQualifierName") // or unresolved reference
|
||||
net.mamoe.mirai.event.events.MemberUnmuteEvent(this@NormalMemberImpl, null).broadcastWithBot(bot)
|
||||
(net.mamoe.mirai.event.events.MemberUnmuteEvent(this@NormalMemberImpl, null).broadcast())
|
||||
this._muteTimestamp = 0
|
||||
}
|
||||
|
||||
@ -179,7 +181,7 @@ internal class NormalMemberImpl constructor(
|
||||
@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE")
|
||||
group.members.delegate.removeIf { it.id == this@NormalMemberImpl.id }
|
||||
this@NormalMemberImpl.cancel(CancellationException("Kicked by bot"))
|
||||
MemberLeaveEvent.Kick(this@NormalMemberImpl, null).broadcastWithBot(bot)
|
||||
MemberLeaveEvent.Kick(this@NormalMemberImpl, null).broadcast()
|
||||
}
|
||||
}
|
||||
|
||||
@ -208,7 +210,7 @@ internal class NormalMemberImpl constructor(
|
||||
|
||||
this@NormalMemberImpl.permission = new
|
||||
|
||||
MemberPermissionChangeEvent(this@NormalMemberImpl, origin, new).broadcastWithBot(bot)
|
||||
MemberPermissionChangeEvent(this@NormalMemberImpl, origin, new).broadcast()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -27,7 +27,7 @@ private val ServerListSerializer: KSerializer<Set<ServerAddress>> =
|
||||
SetSerializer(ServerAddress.serializer())
|
||||
|
||||
internal interface BdhSessionSyncer {
|
||||
var bdhSession: CompletableDeferred<BdhSession>
|
||||
val bdhSession: CompletableDeferred<BdhSession>
|
||||
val hasSession: Boolean
|
||||
|
||||
fun overrideSession(
|
||||
@ -47,8 +47,9 @@ internal interface BdhSessionSyncer {
|
||||
internal class BdhSessionSyncerImpl(
|
||||
private val configuration: BotConfiguration,
|
||||
private val logger: MiraiLogger,
|
||||
private val componentStorage: ComponentStorage,
|
||||
private val context: ComponentStorage,
|
||||
) : BdhSessionSyncer {
|
||||
@Volatile
|
||||
override var bdhSession: CompletableDeferred<BdhSession> = CompletableDeferred()
|
||||
override val hasSession: Boolean
|
||||
get() = kotlin.runCatching { bdhSession.getCompleted() }.isSuccess
|
||||
@ -75,7 +76,7 @@ internal class BdhSessionSyncerImpl(
|
||||
logger.verbose("Loading server list from cache.")
|
||||
kotlin.runCatching {
|
||||
val list = JsonForCache.decodeFromString(ServerListSerializer, serverListCacheFile.readText())
|
||||
componentStorage[ServerList].setPreferred(list.map { ServerAddress(it.host, it.port) })
|
||||
context[ServerList].setPreferred(list.map { ServerAddress(it.host, it.port) })
|
||||
}.onFailure {
|
||||
logger.warning("Error in loading server list from cache", it)
|
||||
}
|
||||
@ -111,7 +112,7 @@ internal class BdhSessionSyncerImpl(
|
||||
serverListCacheFile.writeText(
|
||||
JsonForCache.encodeToString(
|
||||
ServerListSerializer,
|
||||
componentStorage[ServerList].getPreferred()
|
||||
context[ServerList].getPreferred()
|
||||
)
|
||||
)
|
||||
}.onFailure {
|
||||
|
@ -70,7 +70,8 @@ internal class BotInitProcessorImpl(
|
||||
|
||||
// do them parallel.
|
||||
supervisorScope {
|
||||
// launch { syncMessageSvc() }
|
||||
launch { syncMessageSvc() }
|
||||
launch { context[BdhSessionSyncer].loadFromCache() }
|
||||
launch { context[OtherClientUpdater].update() }
|
||||
launch { context[ContactUpdater].loadAll(registerResp.origin) }
|
||||
}
|
||||
|
@ -18,7 +18,7 @@ import net.mamoe.mirai.event.ConcurrencyKind
|
||||
import net.mamoe.mirai.event.EventPriority
|
||||
import net.mamoe.mirai.event.events.BotOfflineEvent
|
||||
import net.mamoe.mirai.event.subscribeAlways
|
||||
import net.mamoe.mirai.internal.QQAndroidBot
|
||||
import net.mamoe.mirai.internal.AbstractBot
|
||||
import net.mamoe.mirai.internal.asQQAndroidBot
|
||||
import net.mamoe.mirai.internal.network.component.ComponentKey
|
||||
import net.mamoe.mirai.internal.network.handler.NetworkHandler
|
||||
@ -37,13 +37,13 @@ internal interface BotOfflineEventMonitor {
|
||||
/**
|
||||
* Attach a listener to the [scope]. [scope] is usually the scope of [NetworkHandler.State.OK].
|
||||
*/
|
||||
fun attachJob(bot: QQAndroidBot, scope: CoroutineScope)
|
||||
fun attachJob(bot: AbstractBot, scope: CoroutineScope)
|
||||
}
|
||||
|
||||
private data class BotClosedByEvent(val event: BotOfflineEvent) : RuntimeException("Bot is closed by event '$event'.")
|
||||
|
||||
internal class BotOfflineEventMonitorImpl : BotOfflineEventMonitor {
|
||||
override fun attachJob(bot: QQAndroidBot, scope: CoroutineScope) {
|
||||
override fun attachJob(bot: AbstractBot, scope: CoroutineScope) {
|
||||
bot.eventChannel.parentScope(scope).subscribeAlways(
|
||||
::onEvent,
|
||||
priority = EventPriority.MONITOR,
|
||||
@ -79,23 +79,17 @@ internal class BotOfflineEventMonitorImpl : BotOfflineEventMonitor {
|
||||
is BotOfflineEvent.Force -> {
|
||||
bot.logger.info { "Connection occupied by another android device: ${event.message}" }
|
||||
closeNetwork()
|
||||
if (event.reconnect) {
|
||||
bot.logger.info { "Reconnecting..." }
|
||||
} else {
|
||||
}
|
||||
}
|
||||
is BotOfflineEvent.MsfOffline,
|
||||
is BotOfflineEvent.Dropped,
|
||||
is BotOfflineEvent.RequireReconnect,
|
||||
-> {
|
||||
// nothing to do
|
||||
val causeMessage = event.castOrNull<BotOfflineEvent.CauseAware>()?.cause?.toString() ?: event.toString()
|
||||
bot.logger.info { "Connection lost, retrying login ($causeMessage)." }
|
||||
}
|
||||
}
|
||||
|
||||
if (event.reconnect) {
|
||||
val causeMessage = event.castOrNull<BotOfflineEvent.CauseAware>()?.cause?.toString() ?: event.toString()
|
||||
bot.logger.info { "Connection lost, retrying login ($causeMessage)." }
|
||||
|
||||
bot.launch {
|
||||
val success: Boolean
|
||||
val time = measureTime {
|
||||
|
@ -20,9 +20,9 @@ import net.mamoe.mirai.internal.contact.replaceMagicCodes
|
||||
import net.mamoe.mirai.internal.network.Packet
|
||||
import net.mamoe.mirai.internal.network.ParseErrorPacket
|
||||
import net.mamoe.mirai.internal.network.component.ComponentKey
|
||||
import net.mamoe.mirai.internal.network.component.ComponentStorage
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.IncomingPacket
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.*
|
||||
import net.mamoe.mirai.utils.MiraiLogger
|
||||
import net.mamoe.mirai.utils.cast
|
||||
import net.mamoe.mirai.utils.verbose
|
||||
|
||||
internal interface PacketHandler {
|
||||
@ -32,11 +32,10 @@ internal interface PacketHandler {
|
||||
}
|
||||
|
||||
internal class PacketHandlerChain(
|
||||
private val instances: Collection<PacketHandler>,
|
||||
primaryConstructorMark: Any?
|
||||
private val instances: Collection<PacketHandler>
|
||||
) : PacketHandler {
|
||||
constructor(vararg instances: PacketHandler?) : this(instances.filterNotNull(), null)
|
||||
constructor(instances: Iterable<PacketHandler?>) : this(instances.filterNotNull(), null)
|
||||
constructor(vararg instances: PacketHandler?) : this(instances.filterNotNull())
|
||||
constructor(instances: Iterable<PacketHandler?>) : this(instances.filterNotNull())
|
||||
|
||||
override suspend fun handlePacket(incomingPacket: IncomingPacket) {
|
||||
for (instance in instances) {
|
||||
@ -55,8 +54,7 @@ internal data class ExceptionInPacketHandlerException(
|
||||
) : IllegalStateException("Exception in PacketHandler '$packetHandler'.")
|
||||
|
||||
internal class LoggingPacketHandler(
|
||||
val bot: QQAndroidBot,
|
||||
val context: ComponentStorage,
|
||||
private val bot: QQAndroidBot,
|
||||
private val logger: MiraiLogger,
|
||||
) : PacketHandler {
|
||||
override suspend fun handlePacket(incomingPacket: IncomingPacket) {
|
||||
@ -66,10 +64,10 @@ internal class LoggingPacketHandler(
|
||||
packet is ParseErrorPacket -> {
|
||||
packet.direction.getLogger(bot).error(packet.error)
|
||||
}
|
||||
packet is MessageEvent -> packet.logMessageReceived()
|
||||
packet is Packet.NoLog -> {
|
||||
// nothing to do
|
||||
}
|
||||
packet is MessageEvent -> packet.logMessageReceived()
|
||||
packet is Event && packet !is Packet.NoEventLog -> bot.logger.verbose {
|
||||
"Event: $packet".replaceMagicCodes()
|
||||
}
|
||||
@ -81,8 +79,6 @@ internal class LoggingPacketHandler(
|
||||
}
|
||||
|
||||
internal class EventBroadcasterPacketHandler(
|
||||
val bot: QQAndroidBot,
|
||||
val context: ComponentStorage,
|
||||
private val logger: MiraiLogger,
|
||||
) : PacketHandler {
|
||||
|
||||
@ -111,3 +107,25 @@ internal class EventBroadcasterPacketHandler(
|
||||
|
||||
override fun toString(): String = "LoggingPacketHandler"
|
||||
}
|
||||
|
||||
internal class CallPacketFactoryPacketHandler(
|
||||
private val bot: QQAndroidBot,
|
||||
) : PacketHandler {
|
||||
|
||||
override suspend fun handlePacket(incomingPacket: IncomingPacket) {
|
||||
val factory = KnownPacketFactories.findPacketFactory(incomingPacket.commandName) ?: return
|
||||
factory.cast<PacketFactory<Packet?>>().run {
|
||||
when (this) {
|
||||
is IncomingPacketFactory -> {
|
||||
val r = bot.handle(incomingPacket.data, incomingPacket.sequenceId)
|
||||
if (r != null) {
|
||||
bot.network.sendWithoutExpect(r)
|
||||
}
|
||||
}
|
||||
is OutgoingPacketFactory -> bot.handle(incomingPacket.data)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
override fun toString(): String = "CallPacketFactoryPacketHandler"
|
||||
}
|
@ -39,7 +39,7 @@ import net.mamoe.mirai.utils.info
|
||||
import net.mamoe.mirai.utils.withExceptionCollector
|
||||
|
||||
/**
|
||||
* Handles login, and acts also as a mediator of [BotInitProcessor], []
|
||||
* Handles login, and acts also as a mediator of [BotInitProcessor]
|
||||
*/
|
||||
internal interface SsoProcessor {
|
||||
val client: QQAndroidClient
|
||||
@ -108,6 +108,7 @@ internal class SsoProcessorImpl(
|
||||
*/
|
||||
@Throws(LoginFailedException::class)
|
||||
override suspend fun login(handler: NetworkHandler) = withExceptionCollector {
|
||||
ssoContext.bot.components[BdhSessionSyncer].loadServerListFromCache()
|
||||
if (client.wLoginSigInfoInitialized) {
|
||||
kotlin.runCatching {
|
||||
FastLoginImpl(handler).doLogin()
|
||||
@ -121,7 +122,7 @@ internal class SsoProcessorImpl(
|
||||
}
|
||||
ssoContext.accountSecretsManager.saveSecrets(ssoContext.account, AccountSecretsImpl(client))
|
||||
registerClientOnline(handler)
|
||||
ssoContext.bot.logger.info { "SSO login successful." }
|
||||
ssoContext.bot.logger.info { "Login successful." }
|
||||
}
|
||||
|
||||
private suspend fun registerClientOnline(handler: NetworkHandler): StatSvc.Register.Response {
|
||||
|
@ -21,6 +21,7 @@ import net.mamoe.mirai.internal.network.protocol.packet.OutgoingPacket
|
||||
import net.mamoe.mirai.utils.*
|
||||
import java.util.concurrent.ConcurrentLinkedQueue
|
||||
import kotlin.coroutines.CoroutineContext
|
||||
import kotlin.reflect.KClass
|
||||
|
||||
/**
|
||||
* Implements basic logics of [NetworkHandler]
|
||||
@ -184,12 +185,16 @@ internal abstract class NetworkHandlerSupport(
|
||||
val new: BaseStateImpl,
|
||||
) : CancellationException("State is switched from $old to $new")
|
||||
|
||||
|
||||
protected inline fun <reified S : BaseStateImpl> setState(noinline new: () -> S): S? = setState(S::class, new)
|
||||
|
||||
/**
|
||||
* Calculate [new state][new] and set it as the current, returning the new state, or `null` if state has concurrently been set to CLOSED.
|
||||
*
|
||||
* You may need to call [BaseStateImpl.resumeConnection] to activate the new state, as states are lazy.
|
||||
*/
|
||||
protected fun <S : BaseStateImpl> setState(new: () -> S): S? = synchronized(this) {
|
||||
protected fun <S : BaseStateImpl> setState(newType: KClass<S>, new: () -> S): S? = synchronized(this) {
|
||||
if (_state::class == newType) return@synchronized null // already set to expected state by another thread.
|
||||
if (_state.correspondingState == NetworkHandler.State.CLOSED) return null // error("Cannot change state while it has already been CLOSED.")
|
||||
|
||||
val stateObserver = context.getOrNull(StateObserver)
|
||||
|
@ -30,10 +30,7 @@ import net.mamoe.mirai.internal.network.handler.NetworkHandlerSupport
|
||||
import net.mamoe.mirai.internal.network.handler.logger
|
||||
import net.mamoe.mirai.internal.network.handler.state.StateObserver
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.OutgoingPacket
|
||||
import net.mamoe.mirai.utils.ExceptionCollector
|
||||
import net.mamoe.mirai.utils.childScope
|
||||
import net.mamoe.mirai.utils.debug
|
||||
import net.mamoe.mirai.utils.systemProp
|
||||
import net.mamoe.mirai.utils.*
|
||||
import java.net.SocketAddress
|
||||
import kotlin.coroutines.CoroutineContext
|
||||
import io.netty.channel.Channel as NettyChannel
|
||||
@ -218,7 +215,9 @@ internal open class NettyNetworkHandler(
|
||||
context[SsoProcessor].login(this@NettyNetworkHandler)
|
||||
}.apply {
|
||||
invokeOnCompletion { error ->
|
||||
if (error != null) {
|
||||
if (error == null) {
|
||||
this@NettyNetworkHandler.launch { resumeConnection() }
|
||||
} else {
|
||||
if (error is StateSwitchingException && error.new is StateConnecting) {
|
||||
return@invokeOnCompletion // already been switching to CONNECTING
|
||||
}
|
||||
@ -303,7 +302,7 @@ internal open class NettyNetworkHandler(
|
||||
}.apply {
|
||||
invokeOnCompletion { e ->
|
||||
if (e != null) {
|
||||
logger.debug { "x" }
|
||||
logger.info { "Heartbeat failed: $e." }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -25,6 +25,7 @@ import net.mamoe.mirai.contact.NormalMember
|
||||
import net.mamoe.mirai.data.MemberInfo
|
||||
import net.mamoe.mirai.event.AbstractEvent
|
||||
import net.mamoe.mirai.event.Event
|
||||
import net.mamoe.mirai.event.broadcast
|
||||
import net.mamoe.mirai.event.events.*
|
||||
import net.mamoe.mirai.internal.QQAndroidBot
|
||||
import net.mamoe.mirai.internal.contact.*
|
||||
@ -46,7 +47,6 @@ import net.mamoe.mirai.internal.network.protocol.packet.OutgoingPacketFactory
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.buildOutgoingUniPacket
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.chat.NewContact
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.list.FriendList
|
||||
import net.mamoe.mirai.internal.utils.broadcastWithBot
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.loadAs
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.readProtoBuf
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.writeProtoBuf
|
||||
@ -203,7 +203,7 @@ internal object MessageSvcPbGetMsg : OutgoingPacketFactory<MessageSvcPbGetMsg.Re
|
||||
client,
|
||||
MsgSvc.SyncFlag.CONTINUE,
|
||||
bot.client.syncingController.syncCookie
|
||||
).sendAndExpect<Packet>()
|
||||
).sendAndExpect()
|
||||
}
|
||||
return
|
||||
}
|
||||
@ -214,7 +214,7 @@ internal object MessageSvcPbGetMsg : OutgoingPacketFactory<MessageSvcPbGetMsg.Re
|
||||
client,
|
||||
MsgSvc.SyncFlag.CONTINUE,
|
||||
bot.client.syncingController.syncCookie
|
||||
).sendAndExpect<Packet>()
|
||||
).sendAndExpect()
|
||||
}
|
||||
return
|
||||
}
|
||||
@ -568,7 +568,7 @@ internal suspend fun MsgComm.Msg.transform(bot: QQAndroidBot, fromSync: Boolean
|
||||
Mirai.newStranger(bot, StrangerInfoImpl(id, nick, fromGroup)).let {
|
||||
bot.getStranger(id)?.let { previous ->
|
||||
bot.strangers.remove(id)
|
||||
StrangerRelationChangeEvent.Deleted(previous).broadcastWithBot(bot)
|
||||
StrangerRelationChangeEvent.Deleted(previous).broadcast()
|
||||
}
|
||||
bot.strangers.delegate.add(it)
|
||||
|
||||
|
@ -15,6 +15,7 @@ import kotlinx.io.core.ByteReadPacket
|
||||
import net.mamoe.mirai.contact.Member
|
||||
import net.mamoe.mirai.event.AbstractEvent
|
||||
import net.mamoe.mirai.event.Event
|
||||
import net.mamoe.mirai.event.broadcast
|
||||
import net.mamoe.mirai.event.events.GroupMessageEvent
|
||||
import net.mamoe.mirai.event.events.GroupMessageSyncEvent
|
||||
import net.mamoe.mirai.event.events.MemberCardChangeEvent
|
||||
@ -33,9 +34,8 @@ import net.mamoe.mirai.internal.network.protocol.data.proto.MsgComm
|
||||
import net.mamoe.mirai.internal.network.protocol.data.proto.MsgOnlinePush
|
||||
import net.mamoe.mirai.internal.network.protocol.data.proto.Oidb0x8fc
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.IncomingPacketFactory
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.chat.receive.OnlinePushPbPushGroupMsg.MemberNick.Companion.generateMemberNickFromMember
|
||||
import net.mamoe.mirai.internal.utils.broadcastWithBot
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.loadAs
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.chat.receive.OnlinePushPbPushGroupMsg.MemberNick.Companion.generateMemberNickFromMember
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.readProtoBuf
|
||||
import net.mamoe.mirai.message.data.MessageSourceKind.GROUP
|
||||
import net.mamoe.mirai.utils.*
|
||||
@ -162,14 +162,14 @@ internal object OnlinePushPbPushGroupMsg : IncomingPacketFactory<Packet?>("Onlin
|
||||
new.nick.let { name ->
|
||||
if (currentNameCard != name) {
|
||||
sender._nameCard = name
|
||||
MemberCardChangeEvent(currentNameCard, name, sender).broadcastWithBot(sender.bot)
|
||||
MemberCardChangeEvent(currentNameCard, name, sender).broadcast()
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// 说明删除了群名片
|
||||
if (currentNameCard.isNotEmpty()) {
|
||||
sender._nameCard = ""
|
||||
MemberCardChangeEvent(currentNameCard, "", sender).broadcastWithBot(sender.bot)
|
||||
MemberCardChangeEvent(currentNameCard, "", sender).broadcast()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -11,6 +11,7 @@ package net.mamoe.mirai.internal.network.protocol.packet.list
|
||||
|
||||
import kotlinx.io.core.ByteReadPacket
|
||||
import net.mamoe.mirai.contact.Stranger
|
||||
import net.mamoe.mirai.event.broadcast
|
||||
import net.mamoe.mirai.event.events.StrangerRelationChangeEvent
|
||||
import net.mamoe.mirai.internal.QQAndroidBot
|
||||
import net.mamoe.mirai.internal.network.Packet
|
||||
@ -20,7 +21,6 @@ import net.mamoe.mirai.internal.network.protocol.data.proto.Oidb0x5d4
|
||||
import net.mamoe.mirai.internal.network.protocol.data.proto.OidbSso
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.OutgoingPacketFactory
|
||||
import net.mamoe.mirai.internal.network.protocol.packet.buildOutgoingUniPacket
|
||||
import net.mamoe.mirai.internal.utils.broadcastWithBot
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.loadAs
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.readProtoBuf
|
||||
import net.mamoe.mirai.internal.utils.io.serialization.toByteArray
|
||||
@ -96,7 +96,7 @@ internal class StrangerList {
|
||||
pkg.bodybuffer.loadAs(Oidb0x5d4.RspBody.serializer()).result.forEach { delResult ->
|
||||
bot.getStranger(delResult.uin)?.let {
|
||||
bot.strangers.remove(delResult.uin)
|
||||
StrangerRelationChangeEvent.Deleted(it).broadcastWithBot(bot)
|
||||
StrangerRelationChangeEvent.Deleted(it).broadcast()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -16,10 +16,12 @@ import net.mamoe.mirai.internal.contact.replaceMagicCodes
|
||||
import net.mamoe.mirai.internal.network.Packet
|
||||
import net.mamoe.mirai.utils.verbose
|
||||
|
||||
@Deprecated("broad", ReplaceWith("this.broadcast()", "net.mamoe.mirai.event.broadcast"))
|
||||
internal suspend fun <T : Event> T.broadcastWithBot(bot: Bot): T {
|
||||
this.let log@{ event ->
|
||||
val logger = bot.logger
|
||||
if (event is Packet.NoLog) return@log
|
||||
if (event is Packet.NoEventLog) return@log
|
||||
if (event is Packet.NoEventLog) {
|
||||
logger.verbose { "Recv: $event".replaceMagicCodes() }
|
||||
} else {
|
||||
|
@ -10,6 +10,7 @@
|
||||
package net.mamoe.mirai.internal.network.framework
|
||||
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
import net.mamoe.mirai.internal.AbstractBot
|
||||
import net.mamoe.mirai.internal.MockBot
|
||||
import net.mamoe.mirai.internal.QQAndroidBot
|
||||
import net.mamoe.mirai.internal.network.QQAndroidClient
|
||||
@ -109,13 +110,13 @@ internal abstract class AbstractRealNetworkHandlerTest<H : NetworkHandler> : Abs
|
||||
set(ContactUpdater, ContactUpdaterImpl(bot, components, networkLogger))
|
||||
set(BdhSessionSyncer, BdhSessionSyncerImpl(configuration, networkLogger, components))
|
||||
set(ServerList, ServerListImpl())
|
||||
set(PacketHandler, LoggingPacketHandler(bot, components, networkLogger))
|
||||
set(PacketHandler, LoggingPacketHandler(bot, networkLogger))
|
||||
set(PacketCodec, PacketCodecImpl())
|
||||
set(OtherClientUpdater, OtherClientUpdaterImpl(bot, components, bot.logger))
|
||||
set(ConfigPushSyncer, ConfigPushSyncerImpl())
|
||||
|
||||
set(BotOfflineEventMonitor, object : BotOfflineEventMonitor {
|
||||
override fun attachJob(bot: QQAndroidBot, scope: CoroutineScope) {
|
||||
override fun attachJob(bot: AbstractBot, scope: CoroutineScope) {
|
||||
}
|
||||
})
|
||||
set(StateObserver, bot.run { stateObserverChain() })
|
||||
|
Loading…
Reference in New Issue
Block a user