mirror of
https://github.com/InsanusMokrassar/TelegramBotAPI-examples.git
synced 2026-06-07 16:17:18 +00:00
buildable new bots
This commit is contained in:
21
ChatManagementBot/build.gradle
Normal file
21
ChatManagementBot/build.gradle
Normal file
@@ -0,0 +1,21 @@
|
||||
buildscript {
|
||||
repositories {
|
||||
mavenCentral()
|
||||
}
|
||||
|
||||
dependencies {
|
||||
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||
}
|
||||
}
|
||||
|
||||
apply plugin: 'kotlin'
|
||||
apply plugin: 'application'
|
||||
|
||||
mainClassName="ChatManagementBotKt"
|
||||
|
||||
|
||||
dependencies {
|
||||
implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
|
||||
|
||||
implementation "dev.inmo:tgbotapi:$telegram_bot_api_version"
|
||||
}
|
||||
146
ChatManagementBot/src/main/kotlin/ChatManagementBot.kt
Normal file
146
ChatManagementBot/src/main/kotlin/ChatManagementBot.kt
Normal file
@@ -0,0 +1,146 @@
|
||||
import dev.inmo.kslog.common.KSLog
|
||||
import dev.inmo.kslog.common.LogLevel
|
||||
import dev.inmo.kslog.common.defaultMessageFormatter
|
||||
import dev.inmo.kslog.common.setDefaultKSLog
|
||||
import dev.inmo.tgbotapi.extensions.api.bot.getMe
|
||||
import dev.inmo.tgbotapi.extensions.api.chat.get.getChatAdministrators
|
||||
import dev.inmo.tgbotapi.extensions.api.send.deleteAllUserMessageReactions
|
||||
import dev.inmo.tgbotapi.extensions.api.send.deleteUserMessageReaction
|
||||
import dev.inmo.tgbotapi.extensions.api.send.reply
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.filters.chatMemberGotRestrictedFilter
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.filters.chatMemberGotRestrictionsChangedFilter
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.telegramBotWithBehaviourAndLongPolling
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onChatMemberUpdated
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onCommand
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onContentMessage
|
||||
import dev.inmo.tgbotapi.extensions.behaviour_builder.utils.plus
|
||||
import dev.inmo.tgbotapi.extensions.utils.chatContentMessageOrNull
|
||||
import dev.inmo.tgbotapi.extensions.utils.contentMessageOrNull
|
||||
import dev.inmo.tgbotapi.extensions.utils.fromUserChatMessageOrNull
|
||||
import dev.inmo.tgbotapi.extensions.utils.fromUserMessageOrNull
|
||||
import dev.inmo.tgbotapi.extensions.utils.publicChatOrNull
|
||||
import dev.inmo.tgbotapi.extensions.utils.restrictedMemberChatMemberOrNull
|
||||
import dev.inmo.tgbotapi.types.chat.CommonBot
|
||||
import dev.inmo.tgbotapi.types.chat.ChatPermissions
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
import kotlinx.coroutines.Dispatchers
|
||||
|
||||
/**
|
||||
* This bot demonstrates Chat Management API features added in Bot API 9.x:
|
||||
*
|
||||
* 1. `can_react_to_messages` field in `ChatMemberRestricted` — printed when a member's
|
||||
* restrictions are changed (requires the bot to be an admin in the group).
|
||||
* `RestrictedMemberChatMember` also implements `ChatPermissions`, so the same field
|
||||
* covers both `ChatMemberRestricted` and `ChatPermissions` from the spec.
|
||||
*
|
||||
* 2. `return_bots` in `getChatAdministrators` — `/admins` command lists all admins
|
||||
* including other bots (retrieveOtherBots = true).
|
||||
*
|
||||
* 3. `deleteAllMessageReactions` — `/deleteallreactions` in reply to a message removes
|
||||
* all reactions that the replied message's author has left across the entire chat.
|
||||
*
|
||||
* 4. `deleteMessageReaction` — `/deletereaction` in reply to a message removes the
|
||||
* reaction the replied message's author placed on that specific message.
|
||||
*
|
||||
* 5. Seeing messages from other bots in groups — demonstrated via `canReadAllGroupMessages`
|
||||
* from `getMe()`. When true (privacy mode off), the bot receives messages from other bots.
|
||||
* All such messages are logged.
|
||||
*
|
||||
* Usage: pass the bot token as the first argument. Optional: `debug`, `testServer`.
|
||||
*/
|
||||
suspend fun main(vararg args: String) {
|
||||
val botToken = args.first()
|
||||
val isDebug = args.any { it == "debug" }
|
||||
val isTestServer = args.any { it == "testServer" }
|
||||
|
||||
if (isDebug) {
|
||||
setDefaultKSLog(
|
||||
KSLog { level: LogLevel, tag: String?, message: Any, throwable: Throwable? ->
|
||||
println(defaultMessageFormatter(level, tag, message, throwable))
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
telegramBotWithBehaviourAndLongPolling(
|
||||
botToken,
|
||||
CoroutineScope(Dispatchers.IO),
|
||||
testServer = isTestServer
|
||||
) {
|
||||
val me = getMe()
|
||||
println("Bot: ${me.firstName} (@${me.username?.username})")
|
||||
|
||||
// Feature 5: canReadAllGroupMessages (can_read_all_group_messages) from getMe()
|
||||
// When true, the bot receives messages from other bots in groups (privacy mode off)
|
||||
println("canReadAllGroupMessages: ${me.canReadAllGroupMessages}")
|
||||
|
||||
// Feature 1: can_react_to_messages in ChatMemberRestricted and ChatPermissions
|
||||
// RestrictedMemberChatMember implements ChatPermissions, so canReactToMessages
|
||||
// appears in both types as required by the Telegram Bot API spec
|
||||
onChatMemberUpdated(
|
||||
initialFilter = chatMemberGotRestrictedFilter + chatMemberGotRestrictionsChangedFilter
|
||||
) { update ->
|
||||
val restricted = update.newChatMemberState.restrictedMemberChatMemberOrNull()
|
||||
?: return@onChatMemberUpdated
|
||||
println("Restriction update for ${update.member.firstName}:")
|
||||
// canReactToMessages as ChatMemberRestricted field
|
||||
println(" canReactToMessages (ChatMemberRestricted): ${restricted.canReactToMessages}")
|
||||
// same field via ChatPermissions — RestrictedMemberChatMember : ChatPermissions
|
||||
val permissions: ChatPermissions = restricted
|
||||
println(" canReactToMessages (ChatPermissions): ${permissions.canReactToMessages}")
|
||||
}
|
||||
|
||||
// Feature 2: return_bots parameter in getChatAdministrators
|
||||
// retrieveOtherBots = true corresponds to return_bots = true in the Telegram API
|
||||
onCommand("admins") { message ->
|
||||
val chat = message.chat.publicChatOrNull() ?: run {
|
||||
reply(message) { +"This command works only in groups/supergroups/channels" }
|
||||
return@onCommand
|
||||
}
|
||||
val admins = getChatAdministrators(chat, retrieveOtherBots = true)
|
||||
reply(message) {
|
||||
+"Administrators (retrieveOtherBots=true, includes bots):\n"
|
||||
admins.forEach { admin ->
|
||||
val kind = if (admin.user is CommonBot) "bot" else "user"
|
||||
+"• ${admin.user.firstName} [$kind]\n"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Feature 4: deleteMessageReaction
|
||||
// Deletes a specific reaction by the replied message's author on that message
|
||||
onCommand("deletereaction") { message ->
|
||||
val replied = message.replyTo ?.fromUserChatMessageOrNull() ?: run {
|
||||
reply(message) { +"Reply to a message to remove that user's reaction from it" }
|
||||
return@onCommand
|
||||
}
|
||||
deleteUserMessageReaction(replied, replied.user.id)
|
||||
reply(message) { +"Deleted reaction by ${replied.user.firstName} on the replied message" }
|
||||
}
|
||||
|
||||
// Feature 3: deleteAllMessageReactions
|
||||
// Deletes all reactions that the replied message's author has left in this chat
|
||||
onCommand("deleteallreactions") { message ->
|
||||
val replied = message.replyTo?.fromUserMessageOrNull() ?: run {
|
||||
reply(message) { +"Reply to a message to clear all reactions of that user in this chat" }
|
||||
return@onCommand
|
||||
}
|
||||
deleteAllUserMessageReactions(message.chat, replied.user.id)
|
||||
reply(message) { +"Deleted all reactions by ${replied.user.firstName} in this chat" }
|
||||
}
|
||||
|
||||
// Feature 5: messages from other bots in groups
|
||||
// Bots with canReadAllGroupMessages=true (privacy mode off) receive messages from other bots.
|
||||
// This handler logs all such messages to demonstrate the feature.
|
||||
onContentMessage(
|
||||
initialFilter = { msg ->
|
||||
val user = msg.fromUserMessageOrNull()?.user
|
||||
user is CommonBot && user.id != me.id
|
||||
}
|
||||
) { message ->
|
||||
val sender = message.fromUserMessageOrNull()?.user
|
||||
println("Message from other bot received (canReadAllGroupMessages=${me.canReadAllGroupMessages}):")
|
||||
println(" sender: ${sender?.firstName} (@${(sender as? CommonBot)?.username?.username})")
|
||||
println(" content: ${message.content}")
|
||||
}
|
||||
}.second.join()
|
||||
}
|
||||
Reference in New Issue
Block a user