Convenient way to build Telegram bots using powerful Kotlin language. Support for Telegram Bot API 4.9. Method names are the same as in API.
- Support ByteArray type for file sending
- Support API 4.9 changes
- Added some extension functions to work with the keyboard. See sources for details
- JDK 8 or higher
- Kotlin 1.3 or higher
- Gradle
- IDE (optionally)
Gradle
repositories {
maven { url "https://jitpack.io" }
}
dependencies {
implementation "com.github.elbekD:kt-telegram-bot:$version"
}
Or Gradle Kotlin DSL
repositories {
maven("https://jitpack.io")
}
dependencies {
compile("com.github.elbekD:kt-telegram-bot:${version}")
}
fun main(args: Array<String>) {
val token = "<TOKEN>"
val bot = Bot.createPolling(token)
bot.onCommand("/start") { msg, _ ->
bot.sendMessage(msg.chat.id, "Hello World!")
}
bot.start()
}
Return type of bot's API methods is CompletableFuture<T>
.
Also it has extension suspend function await()
.
It is common case when you need to ask the user several questions sequentially and process user errors. Now you can create such chains easily. Sea the example below. Do not forget to call build()
method at the end.
fun main() {
val token = "<TOKEN>"
val username = "<BOT USERNAME>"
val bot = Bot.createPolling(username, token)
bot.chain("/start") { msg -> bot.sendMessage(msg.chat.id, "Hi! What is your name?") }
.then { msg -> bot.sendMessage(msg.chat.id, "Nice to meet you, ${msg.text}! Send something to me") }
.then { msg -> bot.sendMessage(msg.chat.id, "Fine! See you soon") }
.build()
bot.chain(
label = "location_chain",
predicate = { msg -> msg.location != null },
action = { msg ->
bot.sendMessage(
msg.chat.id,
"Fine, u've sent me a location. Is this where you want to order a taxi?(yes|no)"
)
})
.then("answer_choice") { msg ->
when (msg.text) {
"yes" -> bot.jumpToAndFire("order_taxi", msg)
"no" -> bot.jumpToAndFire("cancel_ordering", msg)
else -> {
bot.sendMessage(msg.chat.id, "Oops, I don't understand you. Just answer yes or no?")
bot.jumpTo("answer_choice", msg)
}
}
}
.then("order_taxi", isTerminal = true) { msg ->
bot.sendMessage(msg.chat.id, "Fine! Taxi is coming")
}
.then("cancel_ordering", isTerminal = true) { msg ->
bot.sendMessage(msg.chat.id, "Ok! See you next time")
}
.build()
bot.start()
}
Use ShadowJar plugin or any other way you like.
See details in source code.
Common methods
start()
stop()
Event handlers
onMessage
-- called on any messageremoveMessageAction
onEditedMessage
-- called on any edited messageremoveEditedMessageAction
onChannelPost
-- called on any channel postremoveChannelPostAction
onEditedChannelPost
-- called on any edited channel postremoveEditedChannelPostAction
onInlineQuery
-- called on any inline query or on specificquery
provided inInlineQuery
removeInlineQueryAction
onChosenInlineQuery
-- called on chosen inline query eventremoveChosenInlineQueryAction
onCallbackQuery
-- called on any callback query or on specificcallback_data
provided inInlineKeyboardButton
removeCallbackQueryAction
onShippingQuery
-- called on any shipping queryremoveShippingQueryAction
onPreCheckoutQuery
-- called on any pre checkout queryremovePreCheckoutQueryAction
onCommand
-- called on specific commandonAnyUpdate
-- called on any update
Helper methods
mediaPhoto
mediaVideo
mediaAnimation
mediaAudio
mediaDocument