From 8aa104c54c361f5c9a06a62cfd4774d7734ee153 Mon Sep 17 00:00:00 2001 From: Yurii Zhuk Date: Sun, 8 Sep 2024 17:45:46 +0300 Subject: [PATCH] Refactor processQueue: add exit condition to chunk sending loop --- .../mobile_sdk/data/chats/FileUploader.kt | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/mobile-sdk/src/main/java/com/webitel/mobile_sdk/data/chats/FileUploader.kt b/mobile-sdk/src/main/java/com/webitel/mobile_sdk/data/chats/FileUploader.kt index 8a2a599..d075d83 100644 --- a/mobile-sdk/src/main/java/com/webitel/mobile_sdk/data/chats/FileUploader.kt +++ b/mobile-sdk/src/main/java/com/webitel/mobile_sdk/data/chats/FileUploader.kt @@ -129,6 +129,7 @@ internal class FileUploader(val api: ChatApi) { } catch (e: Exception) { isUploading = false call?.cancel(e.message, e) + call = null } } processQueue(request, call) @@ -311,6 +312,7 @@ internal class FileUploader(val api: ChatApi) { ) return } + handler.make { if (activeChunksCount.get() > maxActiveChunks) { return@make @@ -319,20 +321,30 @@ internal class FileUploader(val api: ChatApi) { try { while (request.transferRequest.stream.read(fiveKB).also { length = it } > 0) { isChunkSending = true - logger.debug("Chunk Upload", "Chunk size: $length bytes, Active: ${activeChunksCount.get()}") + logger.debug( + "Chunk Upload", + "Chunk size: $length bytes, Active: ${activeChunksCount.get()}" + ) val chunk = Media.UploadRequest.newBuilder() .setPart(ByteString.copyFrom(fiveKB, 0, length)) .build() + if (!isUploading) { + isChunkSending = false + break + } + call?.onNext(chunk) - if (activeChunksCount.incrementAndGet() > maxActiveChunks) { + + if (activeChunksCount.incrementAndGet() > maxActiveChunks || !isUploading) { isChunkSending = false break } } finalizeSendingIfNeeded(request, call) + } catch (e: Exception) { handleUploadError(e, request, activeProcess) }