mirror of
				https://github.com/InsanusMokrassar/TelegramBotAPI.git
				synced 2025-10-25 09:10:07 +00:00 
			
		
		
		
	now requests executor in updates poller is strong
This commit is contained in:
		| @@ -11,16 +11,13 @@ import com.github.insanusmokrassar.TelegramBotAPI.utils.toMediaGroupUpdate | |||||||
| import kotlinx.coroutines.* | import kotlinx.coroutines.* | ||||||
| import java.util.concurrent.Executors | import java.util.concurrent.Executors | ||||||
|  |  | ||||||
| private val updatesPollerRequestExecutorCollectedException = IllegalStateException("RequestsExecutor was collected by GC. Can't continue getting updates by polling") |  | ||||||
|  |  | ||||||
| class UpdatesPoller( | class UpdatesPoller( | ||||||
|     requestsExecutor: RequestsExecutor, |     private val executor: RequestsExecutor, | ||||||
|     private val requestsDelayMillis: Long = 1000, |     private val requestsDelayMillis: Long = 1000, | ||||||
|     private val scope: CoroutineScope = CoroutineScope(Executors.newFixedThreadPool(4).asCoroutineDispatcher()), |     private val scope: CoroutineScope = CoroutineScope(Executors.newFixedThreadPool(4).asCoroutineDispatcher()), | ||||||
|     private val allowedUpdates: List<String>? = null, |     private val allowedUpdates: List<String>? = null, | ||||||
|     private val block: UpdateReceiver<Any> |     private val block: UpdateReceiver<Any> | ||||||
| ) { | ) { | ||||||
|     private val executor = requestsExecutor.asReference() |  | ||||||
|     private var lastHandledUpdate: UpdateIdentifier = 0L |     private var lastHandledUpdate: UpdateIdentifier = 0L | ||||||
|     private val mediaGroup: MutableList<MediaGroupUpdate> = mutableListOf() |     private val mediaGroup: MutableList<MediaGroupUpdate> = mutableListOf() | ||||||
|  |  | ||||||
| @@ -51,14 +48,14 @@ class UpdatesPoller( | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private suspend fun getUpdates(): List<Update> { |     private suspend fun getUpdates(): List<Update> { | ||||||
|         return executor.get() ?.execute( |         return executor.execute( | ||||||
|             GetUpdates( |             GetUpdates( | ||||||
|                 lastHandledUpdate + 1, // incremented because offset counted from 1 when updates id from 0 |                 lastHandledUpdate + 1, // incremented because offset counted from 1 when updates id from 0 | ||||||
|                 allowed_updates = allowedUpdates |                 allowed_updates = allowedUpdates | ||||||
|             ) |             ) | ||||||
|         ) ?.map { |         ) ?.map { | ||||||
|             it.asUpdate |             it.asUpdate | ||||||
|         } ?: throw updatesPollerRequestExecutorCollectedException |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private suspend fun handleUpdates(updates: List<Update>) { |     private suspend fun handleUpdates(updates: List<Update>) { | ||||||
| @@ -82,9 +79,6 @@ class UpdatesPoller( | |||||||
|                 try { |                 try { | ||||||
|                     handleUpdates(getUpdates()) |                     handleUpdates(getUpdates()) | ||||||
|                 } catch (e: Exception) { |                 } catch (e: Exception) { | ||||||
|                     if (e == updatesPollerRequestExecutorCollectedException) { |  | ||||||
|                         throw IllegalArgumentException(e.message) |  | ||||||
|                     } |  | ||||||
|                     e.printStackTrace() |                     e.printStackTrace() | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user