mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 01:00:13 +00:00 
			
		
		
		
	fixes and improvements
This commit is contained in:
		| @@ -13,14 +13,16 @@ import com.github.insanusmokrassar.TelegramBotAPI.utils.TelegramAPIUrlsKeeper | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.call.receive | ||||
| import io.ktor.client.features.ClientRequestException | ||||
| import io.ktor.client.features.HttpTimeout | ||||
| import io.ktor.client.statement.HttpStatement | ||||
| import io.ktor.client.statement.readText | ||||
| import kotlinx.coroutines.delay | ||||
| import kotlinx.coroutines.supervisorScope | ||||
| import kotlinx.serialization.json.Json | ||||
|  | ||||
| class KtorRequestsExecutor( | ||||
|     telegramAPIUrlsKeeper: TelegramAPIUrlsKeeper, | ||||
|     private val client: HttpClient = HttpClient(), | ||||
|     client: HttpClient = HttpClient(), | ||||
|     callsFactories: List<KtorCallFactory> = emptyList(), | ||||
|     excludeDefaultFactories: Boolean = false, | ||||
|     private val requestsLimiter: RequestLimiter = EmptyLimiter, | ||||
| @@ -34,50 +36,59 @@ class KtorRequestsExecutor( | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private val client = client.config { | ||||
|         install(HttpTimeout) | ||||
|     } | ||||
|  | ||||
|     override suspend fun <T : Any> execute(request: Request<T>): T { | ||||
|         return requestsLimiter.limit { | ||||
|             var statement: HttpStatement? = null | ||||
|             for (factory in callsFactories) { | ||||
|                 statement = factory.prepareCall( | ||||
|                     client, | ||||
|                     telegramAPIUrlsKeeper.commonAPIUrl, | ||||
|                     request | ||||
|                 ) | ||||
|                 if (statement != null) { | ||||
|                     break | ||||
|         return try { | ||||
|             supervisorScope { | ||||
|                 requestsLimiter.limit { | ||||
|                     var statement: HttpStatement? = null | ||||
|                     for (factory in callsFactories) { | ||||
|                         statement = factory.prepareCall( | ||||
|                             client, | ||||
|                             telegramAPIUrlsKeeper.commonAPIUrl, | ||||
|                             request | ||||
|                         ) | ||||
|                         if (statement != null) { | ||||
|                             break | ||||
|                         } | ||||
|                     } | ||||
|  | ||||
|                     val response = statement?.execute() ?: throw IllegalArgumentException("Can't execute request: $request") | ||||
|                     val content = response.receive<String>() | ||||
|                     val responseObject = jsonFormatter.parse(Response.serializer(), content) | ||||
|  | ||||
|                     (responseObject.result?.let { | ||||
|                         jsonFormatter.fromJson(request.resultDeserializer, it) | ||||
|                     } ?: responseObject.parameters?.let { | ||||
|                         val error = it.error | ||||
|                         if (error is RetryAfterError) { | ||||
|                             delay(error.leftToRetry) | ||||
|                             execute(request) | ||||
|                         } else { | ||||
|                             null | ||||
|                         } | ||||
|                     } ?: response.let { | ||||
|                         throw newRequestException( | ||||
|                             responseObject, | ||||
|                             content, | ||||
|                             "Can't get result object from $content" | ||||
|                         ) | ||||
|                     }) | ||||
|                 } | ||||
|             } | ||||
|             try { | ||||
|                 val response = statement ?.execute() ?: throw IllegalArgumentException("Can't execute request: $request") | ||||
|                 val content = response.receive<String>() | ||||
|                 val responseObject = jsonFormatter.parse(Response.serializer(), content) | ||||
|  | ||||
|                 (responseObject.result?.let { | ||||
|                     jsonFormatter.fromJson(request.resultDeserializer, it) | ||||
|                 } ?: responseObject.parameters?.let { | ||||
|                     val error = it.error | ||||
|                     if (error is RetryAfterError) { | ||||
|                         delay(error.leftToRetry) | ||||
|                         execute(request) | ||||
|                     } else { | ||||
|                         null | ||||
|                     } | ||||
|                 } ?: response.let { | ||||
|                     throw newRequestException( | ||||
|                         responseObject, | ||||
|                         content, | ||||
|                         "Can't get result object from $content" | ||||
|                     ) | ||||
|                 }) | ||||
|             } catch (e: ClientRequestException) { | ||||
|                 val content = e.response.readText() | ||||
|                 val responseObject = jsonFormatter.parse(Response.serializer(), content) | ||||
|                 throw newRequestException( | ||||
|                     responseObject, | ||||
|                     content, | ||||
|                     "Can't get result object from $content" | ||||
|                 ) | ||||
|             } | ||||
|         } catch (e: ClientRequestException) { | ||||
|             val content = e.response.readText() | ||||
|             val responseObject = jsonFormatter.parse(Response.serializer(), content) | ||||
|             throw newRequestException( | ||||
|                 responseObject, | ||||
|                 content, | ||||
|                 "Can't get result object from $content" | ||||
|             ) | ||||
|         } catch (e: Exception) { | ||||
|             throw e | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,10 @@ | ||||
| package com.github.insanusmokrassar.TelegramBotAPI.bot.Ktor.base | ||||
|  | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.bot.Ktor.KtorCallFactory | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.GetUpdates | ||||
| import com.github.insanusmokrassar.TelegramBotAPI.requests.abstracts.Request | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.features.timeout | ||||
| import io.ktor.client.request.* | ||||
| import io.ktor.client.statement.HttpStatement | ||||
| import io.ktor.http.ContentType | ||||
| @@ -28,6 +30,16 @@ abstract class AbstractRequestCallFactory : KtorCallFactory { | ||||
|                 method = HttpMethod.Post | ||||
|                 accept(ContentType.Application.Json) | ||||
|  | ||||
|                 if (request is GetUpdates) { | ||||
|                     request.timeout ?.times(1000L) ?.let { customTimeoutMillis -> | ||||
|                         if (customTimeoutMillis > 0) { | ||||
|                             timeout { | ||||
|                                 requestTimeoutMillis = customTimeoutMillis | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 body = preparedBody | ||||
|             }, | ||||
|             client | ||||
|   | ||||
		Reference in New Issue
	
	Block a user