All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.network.handler.state.SafeStateObserver.kt Maven / Gradle / Ivy

There is a newer version: 2.16.0
Show newest version
/*
 * Copyright 2019-2022 Mamoe Technologies and contributors.
 *
 * 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证.
 * Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link.
 *
 * https://github.com/mamoe/mirai/blob/dev/LICENSE
 */

package net.mamoe.mirai.internal.network.handler.state

import net.mamoe.mirai.internal.network.handler.NetworkHandler
import net.mamoe.mirai.internal.network.handler.NetworkHandlerSupport
import net.mamoe.mirai.utils.MiraiLogger
import net.mamoe.mirai.utils.error

internal fun StateObserver.safe(logger: MiraiLogger): StateObserver {
    if (this is SafeStateObserver) return this
    return SafeStateObserver(this, logger)
}

/**
 * Catches exception then log by [logger]
 */
internal class SafeStateObserver(
    val delegate: StateObserver,
    val logger: MiraiLogger,
) : StateObserver {

    override fun toString(): String {
        return "SafeStateObserver(delegate=$delegate)"
    }

    override fun beforeStateChanged(
        networkHandler: NetworkHandlerSupport,
        previous: NetworkHandlerSupport.BaseStateImpl,
        new: NetworkHandlerSupport.BaseStateImpl
    ) {
        try {
            delegate.beforeStateChanged(networkHandler, previous, new)
        } catch (e: Throwable) {
            logger.error(
                { "Internal error: exception in StateObserver $delegate" },
                ExceptionInStateObserverException(e)
            )
        }
    }

    override fun stateChanged(
        networkHandler: NetworkHandlerSupport,
        previous: NetworkHandlerSupport.BaseStateImpl,
        new: NetworkHandlerSupport.BaseStateImpl,
    ) {
        try {
            delegate.stateChanged(networkHandler, previous, new)
        } catch (e: Throwable) {
            logger.error(
                { "Internal error: exception in StateObserver $delegate" },
                ExceptionInStateObserverException(e)
            )
        }
    }

    override fun exceptionOnCreatingNewState(
        networkHandler: NetworkHandlerSupport,
        previousState: NetworkHandlerSupport.BaseStateImpl,
        exception: Throwable,
    ) {
        try {
            delegate.exceptionOnCreatingNewState(networkHandler, previousState, exception)
        } catch (e: Throwable) {
            logger.error(
                { "Internal error: exception in StateObserver $delegate" },
                ExceptionInStateObserverException(e)
            )
        }
    }

    override suspend fun beforeStateResume(networkHandler: NetworkHandler, state: NetworkHandlerSupport.BaseStateImpl) {
        try {
            delegate.beforeStateResume(networkHandler, state)
        } catch (e: Throwable) {
            logger.error(
                { "Internal error: exception in StateObserver $delegate" },
                ExceptionInStateObserverException(e)
            )
        }
    }

    override suspend fun afterStateResume(
        networkHandler: NetworkHandler,
        state: NetworkHandlerSupport.BaseStateImpl,
        result: Result,
    ) {
        try {
            delegate.afterStateResume(networkHandler, state, result)
        } catch (e: Throwable) {
            logger.error(
                { "Internal error: exception in StateObserver $delegate" },
                ExceptionInStateObserverException(e)
            )
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy