mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 09:10:07 +00:00 
			
		
		
		
	add passing of default engines in HttpClient constructors
This commit is contained in:
		| @@ -2,6 +2,9 @@ | ||||
|  | ||||
| ## 28.0.3 | ||||
|  | ||||
| * `Core`: | ||||
|   * Add passing of default engines in `HttpClient` constructors | ||||
|  | ||||
| ## 28.0.2 | ||||
|  | ||||
| * `Core`: | ||||
|   | ||||
| @@ -37,6 +37,8 @@ kotlin-test-js = { module = "org.jetbrains.kotlin:kotlin-test-js", version.ref = | ||||
|  | ||||
| ktor-client-core = { module = "io.ktor:ktor-client-core", version.ref = "ktor" } | ||||
| ktor-client-cio = { module = "io.ktor:ktor-client-cio", version.ref = "ktor" } | ||||
| ktor-client-java = { module = "io.ktor:ktor-client-java", version.ref = "ktor" } | ||||
| ktor-client-js = { module = "io.ktor:ktor-client-js", version.ref = "ktor" } | ||||
| ktor-client-curl = { module = "io.ktor:ktor-client-curl", version.ref = "ktor" } | ||||
| ktor-client-winhttp = { module = "io.ktor:ktor-client-winhttp", version.ref = "ktor" } | ||||
| ktor-server = { module = "io.ktor:ktor-server", version.ref = "ktor" } | ||||
|   | ||||
| @@ -3,6 +3,7 @@ package dev.inmo.tgbotapi.extensions.api | ||||
| import dev.inmo.tgbotapi.bot.ktor.telegramBot | ||||
| import dev.inmo.tgbotapi.bot.TelegramBot | ||||
| import dev.inmo.tgbotapi.utils.TelegramAPIUrlsKeeper | ||||
| import dev.inmo.tgbotapi.utils.defaultKtorEngine | ||||
| import dev.inmo.tgbotapi.utils.telegramBotAPIDefaultUrl | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.HttpClientConfig | ||||
| @@ -13,7 +14,7 @@ import io.ktor.client.engine.* | ||||
|  */ | ||||
| public fun telegramBot( | ||||
|     urlsKeeper: TelegramAPIUrlsKeeper, | ||||
|     client: HttpClient = HttpClient() | ||||
|     client: HttpClient = HttpClient(defaultKtorEngine) | ||||
| ): TelegramBot = telegramBot(urlsKeeper) { | ||||
|     this.client = client | ||||
| } | ||||
| @@ -68,7 +69,7 @@ public fun telegramBot( | ||||
|     apiUrl: String = telegramBotAPIDefaultUrl, | ||||
|     testServer: Boolean = false, | ||||
|     fileLinkUrlMapper: TelegramAPIUrlsKeeper.(String) -> String = { "${fileBaseUrl}/$it" }, | ||||
|     client: HttpClient = HttpClient() | ||||
|     client: HttpClient = HttpClient(defaultKtorEngine) | ||||
| ): TelegramBot = telegramBot(TelegramAPIUrlsKeeper(token, testServer, apiUrl, fileLinkUrlMapper), client) | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
|   | ||||
| @@ -30506,6 +30506,10 @@ public final class dev/inmo/tgbotapi/utils/DefaultKSLogKt { | ||||
| 	public static final fun setDefaultKTgBotAPIKSLogSystemTag (Ljava/lang/String;)V | ||||
| } | ||||
| 
 | ||||
| public final class dev/inmo/tgbotapi/utils/DefaultKtorEngine_jvmKt { | ||||
| 	public static final fun getDefaultKtorEngine ()Lio/ktor/client/engine/HttpClientEngineFactory; | ||||
| } | ||||
| 
 | ||||
| public final class dev/inmo/tgbotapi/utils/DeserializeWithUnknownKt { | ||||
| 	public static final fun deserializeEitherWithRaw (Lkotlinx/serialization/encoding/Decoder;Lkotlinx/serialization/KSerializer;)Ldev/inmo/micro_utils/common/Either; | ||||
| 	public static final fun deserializeWithRaw (Lkotlinx/serialization/encoding/Decoder;Lkotlinx/serialization/KSerializer;)Lkotlin/Pair; | ||||
|   | ||||
| @@ -47,12 +47,19 @@ kotlin { | ||||
|                 api libs.ktor.server.host.common | ||||
|  | ||||
|                 api libs.ktor.client.cio | ||||
|                 api libs.ktor.client.java | ||||
|  | ||||
|                 api libs.javax.activation | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         linuxX64Main { | ||||
|         jsMain { | ||||
|             dependencies { | ||||
|                 api libs.ktor.client.js | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         linuxMain { | ||||
|             dependencies { | ||||
|                 api libs.ktor.client.curl | ||||
|             } | ||||
| @@ -64,7 +71,7 @@ kotlin { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         mingwX64Main { | ||||
|         mingwMain { | ||||
|             dependencies { | ||||
|                 api libs.ktor.client.winhttp | ||||
|             } | ||||
|   | ||||
| @@ -8,6 +8,7 @@ import dev.inmo.tgbotapi.bot.settings.limiters.RequestLimiter | ||||
| import dev.inmo.tgbotapi.requests.abstracts.Request | ||||
| import dev.inmo.tgbotapi.utils.DefaultKTgBotAPIKSLog | ||||
| import dev.inmo.tgbotapi.utils.TelegramAPIUrlsKeeper | ||||
| import dev.inmo.tgbotapi.utils.defaultKtorEngine | ||||
| import dev.inmo.tgbotapi.utils.nonstrictJsonFormat | ||||
| import io.ktor.client.* | ||||
| import kotlinx.serialization.json.Json | ||||
| @@ -37,7 +38,7 @@ expect class KtorRequestsExecutor internal constructor( | ||||
|  | ||||
| fun KtorRequestsExecutor( | ||||
|     telegramAPIUrlsKeeper: TelegramAPIUrlsKeeper, | ||||
|     client: HttpClient = HttpClient(), | ||||
|     client: HttpClient = HttpClient(defaultKtorEngine), | ||||
|     callsFactories: List<KtorCallFactory> = emptyList(), | ||||
|     excludeDefaultFactories: Boolean = false, | ||||
|     requestsLimiter: RequestLimiter = ExceptionsOnlyLimiter, | ||||
|   | ||||
| @@ -21,7 +21,7 @@ fun createTelegramBotDefaultKtorCallRequestsFactories(logger: KSLog? = null) = l | ||||
| class KtorRequestsExecutorBuilder( | ||||
|     var telegramAPIUrlsKeeper: TelegramAPIUrlsKeeper | ||||
| ) { | ||||
|     var client: HttpClient = HttpClient() | ||||
|     var client: HttpClient = HttpClient(defaultKtorEngine) | ||||
|     var callsFactories: List<KtorCallFactory> = emptyList() | ||||
|     var excludeDefaultFactories: Boolean = false | ||||
|     var requestsLimiter: RequestLimiter = ExceptionsOnlyLimiter | ||||
|   | ||||
| @@ -0,0 +1,5 @@ | ||||
| package dev.inmo.tgbotapi.utils | ||||
|  | ||||
| import io.ktor.client.engine.HttpClientEngineFactory | ||||
|  | ||||
| expect val defaultKtorEngine: HttpClientEngineFactory<*> | ||||
| @@ -0,0 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.utils | ||||
|  | ||||
| import io.ktor.client.engine.HttpClientEngineFactory | ||||
| import io.ktor.client.engine.js.Js | ||||
|  | ||||
| actual val defaultKtorEngine: HttpClientEngineFactory<*> by lazy { | ||||
|     Js | ||||
| } | ||||
| @@ -0,0 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.utils | ||||
|  | ||||
| import io.ktor.client.engine.HttpClientEngineFactory | ||||
| import io.ktor.client.engine.java.Java | ||||
|  | ||||
| actual val defaultKtorEngine: HttpClientEngineFactory<*> by lazy { | ||||
|     Java | ||||
| } | ||||
| @@ -1,5 +1,6 @@ | ||||
| package dev.inmo.tgbotapi.bot.ktor.base | ||||
|  | ||||
| import dev.inmo.tgbotapi.utils.defaultKtorEngine | ||||
| import io.ktor.client.* | ||||
| import io.ktor.client.engine.cio.* | ||||
|  | ||||
| @@ -21,4 +22,8 @@ internal actual inline fun platformClientCopy(client: HttpClient): HttpClient = | ||||
|     HttpClient(CIO) { | ||||
|         this.plusAssign(config) | ||||
|     } | ||||
| } ?: throw IllegalArgumentException("On LinuxX64 TelegramBotAPI currently support only Curl Ktor HttpClient engine") | ||||
| } ?: HttpClient( | ||||
|     defaultKtorEngine | ||||
| ) { | ||||
|     install(client) | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.utils | ||||
|  | ||||
| import io.ktor.client.engine.HttpClientEngineFactory | ||||
| import io.ktor.client.engine.curl.Curl | ||||
|  | ||||
| actual val defaultKtorEngine: HttpClientEngineFactory<*> by lazy { | ||||
|     Curl | ||||
| } | ||||
| @@ -1,6 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.bot.ktor.base | ||||
|  | ||||
| import dev.inmo.tgbotapi.utils.defaultKtorEngine | ||||
| import io.ktor.client.* | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.engine.curl.* | ||||
|  | ||||
| /** | ||||
| @@ -21,4 +23,8 @@ internal actual inline fun platformClientCopy(client: HttpClient): HttpClient = | ||||
|     HttpClient(Curl) { | ||||
|         this.plusAssign(config) | ||||
|     } | ||||
| } ?: throw IllegalArgumentException("On LinuxX64 TelegramBotAPI currently support only Curl Ktor HttpClient engine") | ||||
| } ?: HttpClient( | ||||
|         defaultKtorEngine | ||||
| ) { | ||||
|     install(client) | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,8 @@ | ||||
| package dev.inmo.tgbotapi.utils | ||||
|  | ||||
| import io.ktor.client.engine.HttpClientEngineFactory | ||||
| import io.ktor.client.engine.winhttp.WinHttp | ||||
|  | ||||
| actual val defaultKtorEngine: HttpClientEngineFactory<*> by lazy { | ||||
|     WinHttp | ||||
| } | ||||
| @@ -2,6 +2,7 @@ package dev.inmo.tgbotapi.extensions.utils.extensions | ||||
|  | ||||
| import dev.inmo.tgbotapi.types.files.PathedFile | ||||
| import dev.inmo.tgbotapi.utils.TelegramAPIUrlsKeeper | ||||
| import dev.inmo.tgbotapi.utils.defaultKtorEngine | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.request.get | ||||
| import io.ktor.client.statement.readBytes | ||||
| @@ -19,5 +20,5 @@ suspend fun HttpClient.loadFile( | ||||
|  | ||||
| suspend fun PathedFile.download( | ||||
|     telegramAPIUrlsKeeper: TelegramAPIUrlsKeeper, | ||||
|     client: HttpClient = HttpClient() | ||||
|     client: HttpClient = HttpClient(defaultKtorEngine) | ||||
| ) = client.loadFile(telegramAPIUrlsKeeper, this) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user