2021-02-07 12:44:38 +06:00
[Participate in our common survey ☺ ](https://forms.gle/q6Xf8K3fD1pPsYUw9 )
2021-02-05 01:18:38 +06:00
2018-12-26 16:07:24 +08:00
# TelegramBotAPI
2021-02-11 12:06:34 +06:00
Hello! This is a set of libraries for working with Telegram Bot API.
2020-11-16 21:59:25 +06:00
2021-02-07 18:02:20 +06:00
| Common info | [data:image/s3,"s3://crabby-images/5932a/5932aa51538886223ab929fcfa346ff5db2427ab" alt="Awesome Kotlin Badge "](https://github.com/KotlinBy/awesome-kotlin) [data:image/s3,"s3://crabby-images/0106d/0106d363b4aa08ed3b754bed1be0cd521721eeff" alt="Build Status "](https://github.com/InsanusMokrassar/TelegramBotAPI/actions) [Small survey ](https://forms.gle/2Hex2ynbHWHhi1KY7 )|
2020-04-08 14:34:55 +06:00
| -------------------------------------:|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
2021-06-17 15:34:53 +06:00
| Useful links | [data:image/s3,"s3://crabby-images/27090/27090a3355fbb8a2035267980acd7c5c7a852b97" alt="Chat in Telegram "](https://t.me/InMoTelegramBotAPI) [data:image/s3,"s3://crabby-images/7b699/7b6996345a19dcdcc0b69d57523431d7491ad3df" alt="Create bot "](https://github.com/InsanusMokrassar/TelegramBotAPI-bot_template/generate) [data:image/s3,"s3://crabby-images/4d5f2/4d5f2715e88ad9bdb88d243f90f1095af1fed53d" alt="KDocs "](https://tgbotapi.inmo.dev/index.html) [Examples ](https://github.com/InsanusMokrassar/TelegramBotAPI-examples/ ), [Mini tutorial ](https://bookstack.inmo.dev/books/telegrambotapi/chapter/introduction-tutorial ) |
2021-02-07 18:02:20 +06:00
| TelegramBotAPI Core status | [data:image/s3,"s3://crabby-images/8573d/8573d48641cf234dc852cc7cfcf04bed126f4951" alt="Maven Central "](https://maven-badges.herokuapp.com/maven-central/dev.inmo/tgbotapi.core) |
| TelegramBotAPI API Extensions status | [data:image/s3,"s3://crabby-images/ddcb0/ddcb0484178d6c7bbd3a955e271f7a6c0b75ebd4" alt="Maven Central "](https://maven-badges.herokuapp.com/maven-central/dev.inmo/tgbotapi.extensions.api) |
| TelegramBotAPI Util Extensions status | [data:image/s3,"s3://crabby-images/b891f/b891f33dc7dfde849f38f1de0e5bd262d50046cd" alt="Maven Central "](https://maven-badges.herokuapp.com/maven-central/dev.inmo/tgbotapi.extensions.utils) |
| TelegramBotAPI Behaviour Builder Extensions status | [data:image/s3,"s3://crabby-images/8b0fd/8b0fdd5fa2c496ba9d0babd448c0f2371a893835" alt="Maven Central "](https://maven-badges.herokuapp.com/maven-central/dev.inmo/tgbotapi.extensions.behaviour_builder) |
| TelegramBotAPI All status | [data:image/s3,"s3://crabby-images/c04a1/c04a1c44559247391f838d82963320605e549a61" alt="Maven Central "](https://maven-badges.herokuapp.com/maven-central/dev.inmo/tgbotapi) |
2018-12-26 16:07:24 +08:00
2021-02-11 12:06:34 +06:00
## Examples
2020-04-17 15:43:43 +06:00
2021-02-13 01:38:31 +06:00
There are several things you need to do to launch examples below:
* Add `mavenCentral()` to your project repositories
* [Maven variant ](https://github.com/InsanusMokrassar/TelegramBotAPI/wiki/Including-in-your-project#pomxml )
* Add dependency `implementation "dev.inmo:tgbotapi:$tgbotapi_version"`
2021-02-13 01:42:35 +06:00
* Replace `tgbotapi_version` with exact version (see last one in the table above) or put variable with this name in project
2021-02-13 01:38:31 +06:00
* Alternative variant for maven [here ](https://github.com/InsanusMokrassar/TelegramBotAPI/wiki/Including-in-your-project#telegrambotapi )
2021-02-13 10:09:33 +06:00
More including instructions [available here ](https://github.com/InsanusMokrassar/TelegramBotAPI/wiki/Including-in-your-project ).
Other configuration examples:
* [For multiplatform ](https://github.com/InsanusMokrassar/TelegramBotAPI-examples/tree/master/ResenderBot )
* [For JVM ](https://github.com/InsanusMokrassar/TelegramBotAPI-examples/blob/master/GetMeBot/build.gradle )
2021-02-13 01:38:31 +06:00
2021-02-11 12:06:34 +06:00
### Most common example
2020-04-17 15:43:43 +06:00
2021-02-11 12:06:34 +06:00
```kotlin
suspend fun main() {
val bot = telegramBot(TOKEN)
2020-04-17 15:43:43 +06:00
2021-02-11 12:06:34 +06:00
bot.buildBehaviour {
println(getMe())
onCommand("start") {
reply(it, "Hi:)")
2020-04-17 15:43:43 +06:00
}
2021-02-11 12:06:34 +06:00
}.join()
2020-04-17 15:43:43 +06:00
}
```
2021-02-11 12:06:34 +06:00
In this example you will see information about this bot at the moment of starting and answer with `Hi:)` every time it
gets message `/start`
2020-05-14 14:07:23 +06:00
2021-02-11 12:06:34 +06:00
### Handling only last messages
2020-04-08 15:28:03 +06:00
2021-02-11 12:06:34 +06:00
```kotlin
suspend fun main() {
val bot = telegramBot(TOKEN)
2020-05-14 13:44:18 +06:00
2021-02-11 12:06:34 +06:00
val flowsUpdatesFilter = FlowsUpdatesFilter()
bot.buildBehaviour(flowUpdatesFilter = flowsUpdatesFilter) {
println(getMe())
onCommand("start") {
reply(it, "Hi:)")
}
2020-05-14 13:44:18 +06:00
2021-02-11 13:37:24 +06:00
retrieveAccumulatedUpdates(this).join()
2021-02-11 13:35:06 +06:00
}
2021-02-11 12:06:34 +06:00
}
2020-05-14 13:44:18 +06:00
```
2021-02-11 12:06:34 +06:00
The main difference with the previous example is that bot will get only last updates (accumulated before bot launch
and maybe some updates it got after launch)
2020-05-14 13:44:18 +06:00
2021-02-11 12:06:34 +06:00
### Build a little bit more complex behaviour
2020-05-14 13:44:18 +06:00
2021-02-11 12:06:34 +06:00
```kotlin
suspend fun main() {
val bot = telegramBot(TOKEN)
2020-05-14 13:44:18 +06:00
2021-02-11 12:06:34 +06:00
bot.buildBehaviour {
println(getMe())
2020-05-14 13:44:18 +06:00
2021-02-11 12:06:34 +06:00
val nameReplyMarkup = ReplyKeyboardMarkup(
matrix {
row {
+SimpleKeyboardButton("nope")
}
}
)
onCommand("start") {
val photo = waitPhoto(
SendTextMessage(it.chat.id, "Send me your photo please")
).first()
val name = waitText(
SendTextMessage(
it.chat.id,
"Send me your name or choose \"nope\"",
2021-02-11 13:38:55 +06:00
replyMarkup = nameReplyMarkup
2021-02-11 12:06:34 +06:00
)
).first().text.takeIf { it != "nope" }
sendPhoto(
it.chat,
photo.mediaCollection,
entities = buildEntities {
if (name != null) regular(name) // may be collapsed up to name ?.let(::regular)
}
)
}
}.join()
2020-05-14 13:44:18 +06:00
}
```
2021-02-11 12:06:34 +06:00
### More examples
You may find examples in [this project ](https://github.com/InsanusMokrassar/TelegramBotAPI-examples ). Besides, you are
always welcome in our [wiki ](https://github.com/InsanusMokrassar/TelegramBotAPI/wiki/About-this-project ) and
[chat ](https://t.me/InMoTelegramBotAPIChat ).