50 Commits

Author SHA1 Message Date
renovate[bot]
aa12de40cb Update kotlin to v2.2.20 2025-09-10 08:24:55 +00:00
56c327cd97 Merge pull request #30 from InsanusMokrassar/renovate/tgbotapi
Update dependency dev.inmo:tgbotapi to v24.0.2
2025-03-30 22:45:45 +06:00
renovate[bot]
a767563a9a Update dependency dev.inmo:tgbotapi to v24.0.2 2025-03-30 16:45:32 +00:00
c997084d86 Merge pull request #31 from InsanusMokrassar/renovate/ktor-monorepo
Update dependency io.ktor:ktor-client-okhttp to v3.1.2
2025-03-30 22:44:56 +06:00
cef55f412a Merge pull request #29 from InsanusMokrassar/renovate/kotlin
Update kotlin to v2.1.20
2025-03-30 22:44:34 +06:00
renovate[bot]
0e4c009c09 Update dependency io.ktor:ktor-client-okhttp to v3.1.2 2025-03-27 16:52:47 +00:00
renovate[bot]
6d997e4fe0 Update kotlin to v2.1.20 2025-03-20 12:49:41 +00:00
c91fff9a97 Merge pull request #25 from InsanusMokrassar/renovate/major-tgbotapi
Update dependency dev.inmo:tgbotapi to v24
2025-03-09 18:14:10 +06:00
renovate[bot]
13b52ba699 Update dependency dev.inmo:tgbotapi to v24 2025-03-09 12:14:01 +00:00
36763aac7c Merge pull request #26 from InsanusMokrassar/renovate/ktor-monorepo
Update dependency io.ktor:ktor-client-okhttp to v3.1.1
2025-03-09 18:13:42 +06:00
renovate[bot]
84e5dce2f4 Update dependency io.ktor:ktor-client-okhttp to v3.1.1 2025-02-24 19:36:49 +00:00
235dbabe21 Update libs.versions.toml 2025-02-16 10:48:05 +06:00
1fa3d1d289 Update gradle-wrapper.properties 2025-02-02 09:16:49 +06:00
4b2c9863e1 Update libs.versions.toml 2025-02-02 09:16:36 +06:00
a35790afb0 Merge pull request #14 from InsanusMokrassar/renovate/major-tgbotapi
Update dependency dev.inmo:tgbotapi to v23
2025-01-03 12:19:33 +06:00
renovate[bot]
413f732c43 Update dependency dev.inmo:tgbotapi to v23 2025-01-03 06:19:22 +00:00
fefc185605 Merge pull request #11 from InsanusMokrassar/renovate/major-ktor-monorepo
Update dependency io.ktor:ktor-client-okhttp to v3
2025-01-03 12:18:53 +06:00
b3d54ac79a Merge pull request #19 from InsanusMokrassar/renovate/kotlin
Update kotlin to v2.1.0
2025-01-03 12:17:08 +06:00
renovate[bot]
15b0d8fff7 Update dependency io.ktor:ktor-client-okhttp to v3 2024-12-18 23:38:57 +00:00
renovate[bot]
9266bc68dd Update dependency org.jetbrains.kotlin.jvm to v2.1.0 2024-11-27 17:08:34 +00:00
a596620ea5 Merge pull request #10 from InsanusMokrassar/renovate/tgbotapi
Update dependency dev.inmo:tgbotapi to v18.2.2
2024-10-22 15:36:16 +06:00
renovate[bot]
3824cf2a8b Update dependency dev.inmo:tgbotapi to v18.2.2 2024-10-22 09:35:58 +00:00
6e4f31ad22 Merge pull request #12 from InsanusMokrassar/renovate/kotlin-monorepo
Update kotlin monorepo to v2.0.21
2024-10-22 15:35:43 +06:00
renovate[bot]
f176a18308 Update kotlin monorepo to v2.0.21 2024-10-10 10:22:17 +00:00
1a0fd756e6 Merge pull request #9 from InsanusMokrassar/renovate/major-tgbotapi
Update dependency dev.inmo:tgbotapi to v18
2024-09-26 07:59:59 +06:00
renovate[bot]
3ae0c9e21e Update dependency dev.inmo:tgbotapi to v18 2024-09-08 23:08:02 +00:00
e24941d1b9 Merge pull request #5 from InsanusMokrassar/renovate/ktor-monorepo
Update dependency io.ktor:ktor-client-okhttp to v2.3.12
2024-09-06 16:42:31 +06:00
26d8d123f8 Merge pull request #6 from InsanusMokrassar/renovate/kotlin-monorepo
Update kotlin monorepo to v2.0.20
2024-09-06 16:41:13 +06:00
renovate[bot]
0f633ef7e9 Update kotlin monorepo to v2.0.20 2024-09-06 10:40:54 +00:00
renovate[bot]
ce441d36c1 Update dependency io.ktor:ktor-client-okhttp to v2.3.12 2024-09-06 10:40:49 +00:00
c2d44b87db Merge pull request #4 from InsanusMokrassar/renovate/configure
Configure Renovate
2024-09-06 16:39:44 +06:00
renovate[bot]
3843bafb33 Add renovate.json 2024-09-06 10:37:30 +00:00
e07c673ba0 add .kotlin to .gitignore 2024-08-14 16:45:15 +06:00
a4c50d6f54 build fix 2024-08-14 16:19:51 +06:00
83fe9adaf0 Update build.yml 2024-08-14 16:16:51 +06:00
82fbd7a471 Update libs.versions.toml 2024-08-14 16:14:52 +06:00
c4f214758d small fix for password setting up in authenticator 2023-10-11 21:25:46 +06:00
22562426e7 update template 2023-10-11 21:02:36 +06:00
ee1bb997ab Update README.md 2023-10-11 19:14:33 +06:00
3c452d2417 Update libs.versions.toml 2023-10-11 19:05:25 +06:00
d08b371e26 Update libs.versions.toml 2023-09-30 07:31:33 +06:00
f8b5a6c139 Update libs.versions.toml 2023-09-29 19:39:01 +06:00
fc921b530e Update libs.versions.toml 2023-08-22 13:48:15 +06:00
550ae4da60 Update libs.versions.toml 2023-08-13 11:08:32 +06:00
8306b79953 Update libs.versions.toml 2023-06-10 15:12:26 +06:00
9d08354e65 Update libs.versions.toml 2023-05-20 22:18:09 +06:00
d16dca314a Update libs.versions.toml 2023-05-06 23:26:31 +06:00
e648090336 Update libs.versions.toml 2023-05-04 08:44:13 +06:00
8354866654 Update libs.versions.toml 2023-04-29 00:29:15 +06:00
b0a11c3bd6 Update libs.versions.toml 2023-04-23 20:50:54 +06:00
13 changed files with 190 additions and 18 deletions

View File

@@ -8,9 +8,9 @@ jobs:
steps:
- uses: actions/checkout@v2
- name: Set up JDK 11
- name: Set up JDK 17
uses: actions/setup-java@v1
with:
java-version: 11
java-version: 17
- name: Build with Gradle
run: ./gradlew build

1
.gitignore vendored
View File

@@ -1,4 +1,5 @@
.idea
.kotlin
out/*
*.iml
target

View File

@@ -22,11 +22,59 @@ there is [Makefile](Makefile) and you may use something like `make buildAndStart
It is important to replace `"TOKEN"` in [Dockerfile](Dockerfile) or remove and add some config as a volume.
### Config
But you may set up several things for your bot. You should start with adding client object:
```json
{
"token": "your bot token",
"client": {
"connectionTimeoutMillis": 10000,
"requestTimeoutMillis": 10000,
"responseTimeoutMillis": 10000,
"proxy": {
"hostname": "127.0.0.1",
"port": 1080,
"type": "socks",
"username": "username",
"password": "password"
}
}
}
```
__Required__ fields:
* `token`
* `client/proxy/hostname` (if you pass `client` and `proxy` fields) - hostname of proxy server
* `client/proxy/password` - password for authentication on proxy server, required if `client/proxy/type` is `socks` and `client/proxy/username` passed
__Optional__ fields:
* `client` - object with client configs
* `client/connectionTimeoutMillis` - timeout for connection to the server
* `client/requestTimeoutMillis` - timeout for request complete (when request taken on server)
* `client/responseTimeoutMillis` - timeout for getting a response after request taken on server
* `client/proxy` - proxy settings
* `client/proxy/port` - port of proxy server
* `client/proxy/type` - type of proxy server (can be `socks` or `http`)
* `client/proxy/username` - username for authentication on proxy server
* `client/proxy/password` - password for authentication on proxy server
Basically, your config looks like an object with token:
```json
{
"token": "your bot token"
}
```
## What next?
There are several ways to continue:
* [Tutorials](https://bookstack.inmo.dev/books/telegrambotapi)
* [Tutorials](https://docs.inmo.dev/tgbotapi/index.html)
* [Github readme](https://github.com/InsanusMokrassar/TelegramBotAPI)
In other words, this template (and [TelegramBotAPI library](https://github.com/InsanusMokrassar/TelegramBotAPI)) does

View File

@@ -24,6 +24,7 @@ dependencies {
implementation libs.kotlin
implementation libs.tgbotapi
implementation libs.ktor.client.okhttp
}
application {
@@ -31,6 +32,6 @@ application {
}
java {
sourceCompatibility = JavaVersion.VERSION_11
targetCompatibility = JavaVersion.VERSION_11
sourceCompatibility = JavaVersion.VERSION_17
targetCompatibility = JavaVersion.VERSION_17
}

View File

@@ -1,3 +1,15 @@
{
"token": "your bot token"
"token": "your bot token",
"client": {
"connectionTimeoutMillis": 10000,
"requestTimeoutMillis": 10000,
"responseTimeoutMillis": 10000,
"proxy": {
"hostname": "127.0.0.1",
"port": 1080,
"type": "socks",
"username": "username",
"password": "password"
}
}
}

View File

@@ -1,13 +1,16 @@
[versions]
kotlin = "1.8.20"
tgbotapi = "7.0.2"
kotlin = "2.2.20"
tgbotapi = "24.0.2"
ktor = "3.1.2"
[libraries]
kotlin = { module = "org.jetbrains.kotlin:kotlin-stdlib", version.ref = "kotlin" }
tgbotapi = { module = "dev.inmo:tgbotapi", version.ref = "tgbotapi" }
ktor-client-okhttp = { module = "io.ktor:ktor-client-okhttp", version.ref = "ktor" }
# Libs for classpath
kotlin-gradle-plugin = { module = "org.jetbrains.kotlin:kotlin-gradle-plugin", version.ref = "kotlin" }
kotlin-serialization-plugin = { module = "org.jetbrains.kotlin:kotlin-serialization", version.ref = "kotlin" }

View File

@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6.1-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-8.12.1-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

6
renovate.json Normal file
View File

@@ -0,0 +1,6 @@
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": [
"config:recommended"
]
}

View File

@@ -1,3 +1 @@
rootProject.name = 'telegram_bot'
enableFeaturePreview("VERSION_CATALOGS")

View File

@@ -1,8 +1,11 @@
import config.Config
import dev.inmo.tgbotapi.bot.ktor.telegramBot
import dev.inmo.tgbotapi.extensions.api.bot.getMe
import dev.inmo.tgbotapi.extensions.api.send.reply
import dev.inmo.tgbotapi.extensions.behaviour_builder.buildBehaviourWithLongPolling
import dev.inmo.tgbotapi.extensions.behaviour_builder.triggers_handling.onCommand
import io.ktor.client.*
import io.ktor.client.engine.okhttp.*
import java.io.File
import kotlinx.coroutines.*
import kotlinx.serialization.json.Json
@@ -16,7 +19,14 @@ suspend fun main(args: Array<String>) {
// decode config
val config: Config = json.decodeFromString(Config.serializer(), File(args.first()).readText())
// that is your bot
val bot = telegramBot(config.token)
val bot = telegramBot(config.token) {
client = HttpClient(OkHttp) {
config.client ?.apply {
// setting up telegram bot client
setupConfig()
}
}
}
// that is kotlin coroutine scope which will be used in requests and parallel works under the hood
val scope = CoroutineScope(Dispatchers.Default)

View File

@@ -1,6 +0,0 @@
import kotlinx.serialization.Serializable
@Serializable
data class Config(
val token: String
)

View File

@@ -0,0 +1,9 @@
package config
import kotlinx.serialization.Serializable
@Serializable
data class Config(
val token: String,
val client: HttpClientConfig? = null
)

View File

@@ -0,0 +1,90 @@
package config
import dev.inmo.tgbotapi.types.MilliSeconds
import io.ktor.client.HttpClientConfig
import io.ktor.client.engine.okhttp.*
import io.ktor.client.plugins.*
import io.ktor.client.request.*
import io.ktor.http.*
import kotlinx.serialization.Serializable
import java.net.*
import java.util.*
import java.util.concurrent.TimeUnit
@Serializable
data class HttpClientConfig(
val connectionTimeoutMillis: MilliSeconds? = null,
val requestTimeoutMillis: MilliSeconds? = null,
val responseTimeoutMillis: MilliSeconds? = null,
val proxy: ProxyConfig? = null
) {
@Serializable
data class ProxyConfig(
val hostname: String,
val type: ProxyType = ProxyType.socks,
val port: Int = type.defaultPort,
val username: String? = null,
val password: String? = null
) {
@Serializable
enum class ProxyType(val defaultPort: Int, val proxyType: Proxy.Type) {
socks(1080, Proxy.Type.SOCKS),
http(3128, Proxy.Type.HTTP),
}
val socketAddress
get() = InetSocketAddress(hostname, port)
}
fun HttpClientConfig<OkHttpConfig>.setupConfig() {
// setting up telegram bot client
engine {
// Start setup bot client engine configuration
config {
// setting up connection timeout millis
connectionTimeoutMillis ?.let { connectTimeout(it, TimeUnit.MILLISECONDS) }
// setting up write timeout millis
requestTimeoutMillis ?.let { writeTimeout(it, TimeUnit.MILLISECONDS) }
// setting up read timeout millis
responseTimeoutMillis ?.let { readTimeout(it, TimeUnit.MILLISECONDS) }
// Start setup bot client engine proxy
this@HttpClientConfig.proxy ?.let { proxyConfig ->
proxy(
Proxy(
proxyConfig.type.proxyType,
proxyConfig.socketAddress
)
)
proxyConfig.username ?.let { username ->
when (proxyConfig.type) {
config.HttpClientConfig.ProxyConfig.ProxyType.socks -> {
val passwordAuthentication = PasswordAuthentication(
username,
proxyConfig.password ?.toCharArray() ?: error("For Socks proxy you should use both username and password or do not use authentication at all")
)
Authenticator.setDefault(object : Authenticator() {
override fun getPasswordAuthentication(): PasswordAuthentication? {
return if (requestingHost.lowercase() == proxyConfig.hostname.lowercase()) {
passwordAuthentication
} else {
null
}
}
})
}
config.HttpClientConfig.ProxyConfig.ProxyType.http -> {
val passwordSuffix = proxyConfig.password ?.let { ":$it" }
val credentials = Base64.getEncoder().encodeToString("${username}${passwordSuffix}".toByteArray())
this@setupConfig.defaultRequest {
header(HttpHeaders.ProxyAuthorization, "Basic $credentials")
}
}
}
}
}
}
}
}
}