PlaguBot/bot/src/main/kotlin/dev/inmo/plagubot/PlaguBot.kt

104 lines
3.4 KiB
Kotlin
Raw Normal View History

2021-04-03 16:04:18 +00:00
package dev.inmo.plagubot
2022-06-11 13:15:09 +00:00
import dev.inmo.kslog.common.*
import dev.inmo.micro_utils.coroutines.runCatchingSafely
import dev.inmo.plagubot.config.*
2022-05-13 07:04:49 +00:00
import dev.inmo.tgbotapi.bot.ktor.telegramBot
2022-05-16 17:58:16 +00:00
import dev.inmo.tgbotapi.extensions.api.webhook.deleteWebhook
2021-11-12 08:05:42 +00:00
import dev.inmo.tgbotapi.extensions.behaviour_builder.*
2022-05-16 14:07:57 +00:00
import dev.inmo.tgbotapi.extensions.utils.updates.retrieving.startGettingOfUpdatesByLongPolling
2021-04-03 16:04:18 +00:00
import kotlinx.coroutines.*
import kotlinx.serialization.Serializable
import kotlinx.serialization.Transient
2022-05-16 14:07:57 +00:00
import kotlinx.serialization.json.JsonObject
2021-04-03 16:04:18 +00:00
import org.jetbrains.exposed.sql.Database
2022-05-16 17:58:16 +00:00
import org.koin.core.Koin
2022-05-16 14:07:57 +00:00
import org.koin.core.KoinApplication
import org.koin.core.context.GlobalContext
2022-05-16 17:58:16 +00:00
import org.koin.core.module.Module
import org.koin.core.scope.Scope
2022-05-16 14:07:57 +00:00
import org.koin.dsl.module
2022-05-16 18:08:45 +00:00
import java.util.logging.Level
import java.util.logging.Logger
2021-04-03 16:04:18 +00:00
2022-05-16 17:58:16 +00:00
val Scope.plagubot: PlaguBot
2022-05-16 14:07:57 +00:00
get() = get()
2021-04-03 16:04:18 +00:00
@Serializable
data class PlaguBot(
2022-05-16 14:07:57 +00:00
private val json: JsonObject,
2021-04-03 16:04:18 +00:00
private val config: Config
) : Plugin {
@Transient
private val bot = telegramBot(config.botToken)
2022-05-16 17:58:16 +00:00
override fun Module.setupDI(database: Database, params: JsonObject) {
single { config }
single { config.plugins }
single { config.databaseConfig }
single { config.databaseConfig.database }
single { defaultJsonFormat }
single { this@PlaguBot }
includes(
2022-05-16 18:08:45 +00:00
config.plugins.mapNotNull {
runCatching {
module {
with(it) {
setupDI(database, params)
}
2022-05-16 17:58:16 +00:00
}
2022-05-16 18:08:45 +00:00
}.onFailure { e ->
2022-06-11 13:15:09 +00:00
logger.log(LogLevel.WARNING, "Unable to load DI part of $it", e)
2022-05-16 18:08:45 +00:00
}.getOrNull()
2022-05-16 17:58:16 +00:00
}
)
}
override suspend fun BehaviourContext.setupBotPlugin(koin: Koin) {
config.plugins.map {
launch {
runCatchingSafely {
logger.info("Start loading of $it")
with(it) {
setupBotPlugin(koin)
}
}.onFailure { e ->
2022-06-11 13:15:09 +00:00
logger.log(LogLevel.WARNING, "Unable to load bot part of $it", e)
}.onSuccess {
logger.info("Complete loading of $it")
2022-05-16 18:08:45 +00:00
}
2022-05-16 17:58:16 +00:00
}
}.joinAll()
2021-04-03 16:04:18 +00:00
}
/**
* This method will create an [Job] which will be the main [Job] of ran instance
*/
suspend fun start(
2022-05-16 17:58:16 +00:00
scope: CoroutineScope = CoroutineScope(Dispatchers.IO)
2022-05-16 14:07:57 +00:00
): Job {
2022-05-16 18:08:45 +00:00
logger.info("Start initialization")
2022-05-16 14:07:57 +00:00
val koinApp = KoinApplication.init()
koinApp.modules(
module {
2022-05-16 17:58:16 +00:00
setupDI(config.databaseConfig.database, json)
2022-05-16 14:07:57 +00:00
}
)
2022-05-16 18:08:45 +00:00
logger.info("Modules loaded")
2022-05-16 17:58:16 +00:00
GlobalContext.startKoin(koinApp)
2022-05-16 18:08:45 +00:00
logger.info("Koin started")
2022-05-16 14:07:57 +00:00
lateinit var behaviourContext: BehaviourContext
bot.buildBehaviour(scope = scope) {
2022-05-16 18:08:45 +00:00
logger.info("Start setup of bot part")
2022-05-16 14:07:57 +00:00
behaviourContext = this
2022-05-16 17:58:16 +00:00
setupBotPlugin(koinApp.koin)
deleteWebhook()
2022-05-16 14:07:57 +00:00
}
2022-05-16 18:08:45 +00:00
logger.info("Behaviour builder has been setup")
return bot.startGettingOfUpdatesByLongPolling(scope = behaviourContext, updatesFilter = behaviourContext).also {
logger.info("Long polling has been started")
}
2021-04-03 16:04:18 +00:00
}
}