mirror of
https://github.com/InsanusMokrassar/TelegramBotApiLibraries.git
synced 2024-12-22 16:47:16 +00:00
commit
fd33cbfca3
@ -21,9 +21,7 @@ val Koin.adminsPlugin: AdminsPlugin?
|
||||
get() = getOrNull()
|
||||
|
||||
@Serializable
|
||||
class AdminsPlugin(
|
||||
private val chatsSettings: Map<ChatId, AdminsCacheSettings>? = null
|
||||
) : Plugin {
|
||||
class AdminsPlugin : Plugin {
|
||||
@Transient
|
||||
private val globalAdminsCacheAPI = MutableStateFlow<AdminsCacheAPI?>(null)
|
||||
@Transient
|
||||
@ -31,15 +29,10 @@ class AdminsPlugin(
|
||||
private val mutex = Mutex()
|
||||
|
||||
suspend fun adminsAPI(database: Database): AdminsCacheAPI {
|
||||
return when (chatsSettings) {
|
||||
null -> {
|
||||
val flow = mutex.withLock {
|
||||
databaseToAdminsCacheAPI.getOrPut(database){ MutableStateFlow(null) }
|
||||
}
|
||||
flow.first { it != null }!!
|
||||
}
|
||||
else -> globalAdminsCacheAPI.first { it != null }!!
|
||||
}
|
||||
return flow.filterNotNull().first()
|
||||
}
|
||||
|
||||
override fun Module.setupDI(database: Database, params: JsonObject) {
|
||||
@ -48,8 +41,6 @@ class AdminsPlugin(
|
||||
|
||||
override suspend fun BehaviourContext.setupBotPlugin(koin: Koin) {
|
||||
with(koin) {
|
||||
when (chatsSettings) {
|
||||
null -> {
|
||||
mutex.withLock {
|
||||
val flow = databaseToAdminsCacheAPI.getOrPut(koin.get()){ MutableStateFlow(null) }
|
||||
if (flow.value == null) {
|
||||
@ -57,10 +48,5 @@ class AdminsPlugin(
|
||||
}
|
||||
}
|
||||
}
|
||||
else -> mutex.withLock {
|
||||
globalAdminsCacheAPI.value = AdminsCacheAPI(koin.get())
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -33,5 +33,5 @@ dokka_version=1.6.21
|
||||
# Project data
|
||||
|
||||
group=dev.inmo
|
||||
version=0.4.0
|
||||
android_code_version=24
|
||||
version=0.4.1
|
||||
android_code_version=25
|
||||
|
Loading…
Reference in New Issue
Block a user