actualize

This commit is contained in:
InsanusMokrassar 2021-02-23 13:29:17 +06:00
parent 23af90137e
commit 19afa7c5aa
1 changed files with 3 additions and 20 deletions

View File

@ -23,8 +23,7 @@ import dev.inmo.tgbotapi.extensions.utils.*
import dev.inmo.tgbotapi.extensions.utils.formatting.buildEntities
import dev.inmo.tgbotapi.extensions.utils.formatting.regular
import dev.inmo.tgbotapi.extensions.utils.shortcuts.executeUnsafe
import dev.inmo.tgbotapi.libraries.cache.admins.AdminsCacheAPI
import dev.inmo.tgbotapi.libraries.cache.admins.adminsPlugin
import dev.inmo.tgbotapi.libraries.cache.admins.*
import dev.inmo.tgbotapi.requests.DeleteMessage
import dev.inmo.tgbotapi.types.BotCommand
import dev.inmo.tgbotapi.types.MessageEntity.textsources.mention
@ -45,12 +44,6 @@ import org.jetbrains.exposed.sql.Database
private const val enableAutoDeleteCommands = "captcha_auto_delete_commands_on"
private const val disableAutoDeleteCommands = "captcha_auto_delete_commands_off"
private suspend fun AdminsCacheAPI.verifyMessageFromAdmin(message: CommonMessage<*>) = when (message) {
is CommonGroupContentMessage<*> -> getChatAdmins(message.chat.id) ?.any { it.user.id == message.user.id } == true
is AnonymousGroupContentMessage<*> -> true
else -> false
}
@Serializable
class CaptchaBotPlugin : Plugin {
override suspend fun getCommands(): List<BotCommand> = listOf(
@ -160,21 +153,11 @@ class CaptchaBotPlugin : Plugin {
}
if (adminsAPI != null) {
suspend fun <T : MessageContent> CommonMessage<T>.doAfterVerification(block: suspend () -> Unit) {
val chat = chat
if (chat is PublicChat) {
val verified = adminsAPI.verifyMessageFromAdmin(this)
if (verified) {
block()
}
}
}
onCommand(
enableAutoDeleteCommands,
requireOnlyCommandInMessage = false
) { message ->
message.doAfterVerification {
message.doAfterVerification(adminsAPI) {
val settings = message.chat.settings()
repo.update(
@ -189,7 +172,7 @@ class CaptchaBotPlugin : Plugin {
disableAutoDeleteCommands,
requireOnlyCommandInMessage = false
) { message ->
message.doAfterVerification {
message.doAfterVerification(adminsAPI) {
val settings = message.chat.settings()
repo.update(