mirror of
				https://github.com/mihonapp/mihon.git
				synced 2025-10-26 12:00:41 +01:00 
			
		
		
		
	Merge branch 'sync-part-final' into feat/add-sync-triggers-experimental
This commit is contained in:
		
							
								
								
									
										5
									
								
								app/proguard-rules.pro
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								app/proguard-rules.pro
									
									
									
									
										vendored
									
									
								
							| @@ -80,7 +80,4 @@ | ||||
| -keep class com.google.api.services.** { *; } | ||||
|  | ||||
| # Google OAuth | ||||
| -keep class com.google.api.client.** { *; } | ||||
|  | ||||
| # Keep backup models, otherwise gson fails on release builds. | ||||
| -keep class eu.kanade.tachiyomi.data.backup.models.** { *; } | ||||
| -keep class com.google.api.client.** { *; } | ||||
| @@ -18,11 +18,10 @@ import com.google.api.client.json.jackson2.JacksonFactory | ||||
| import com.google.api.services.drive.Drive | ||||
| import com.google.api.services.drive.DriveScopes | ||||
| import com.google.api.services.drive.model.File | ||||
| import com.google.gson.Gson | ||||
| import com.google.gson.stream.JsonWriter | ||||
| import kotlinx.coroutines.Dispatchers | ||||
| import kotlinx.coroutines.delay | ||||
| import kotlinx.coroutines.withContext | ||||
| import kotlinx.serialization.encodeToString | ||||
| import kotlinx.serialization.json.Json | ||||
| import logcat.LogPriority | ||||
| import logcat.logcat | ||||
| @@ -35,7 +34,6 @@ import java.io.ByteArrayInputStream | ||||
| import java.io.ByteArrayOutputStream | ||||
| import java.io.IOException | ||||
| import java.io.InputStreamReader | ||||
| import java.io.OutputStreamWriter | ||||
| import java.time.Instant | ||||
| import java.util.zip.GZIPInputStream | ||||
| import java.util.zip.GZIPOutputStream | ||||
| @@ -139,12 +137,14 @@ class GoogleDriveSyncService(context: Context, json: Json, syncPreferences: Sync | ||||
|         return withContext(Dispatchers.IO) { | ||||
|             try { | ||||
|                 val gzipInputStream = GZIPInputStream(ByteArrayInputStream(outputStream.toByteArray())) | ||||
|                 val gson = Gson() | ||||
|                 val syncData = gson.fromJson(gzipInputStream.reader(Charsets.UTF_8), SyncData::class.java) | ||||
|                 val jsonString = gzipInputStream.bufferedReader(Charsets.UTF_8).use { it.readText() } | ||||
|                 val syncData = json.decodeFromString(SyncData.serializer(), jsonString) | ||||
|                 logcat(LogPriority.DEBUG) { "JSON deserialized successfully" } | ||||
|                 syncData | ||||
|             } catch (e: Exception) { | ||||
|                 logcat(LogPriority.ERROR) { "Failed to convert json to sync data: ${e.message}" } | ||||
|                 logcat( | ||||
|                     LogPriority.ERROR, | ||||
|                 ) { "Failed to convert json to sync data with kotlinx.serialization: ${e.message}" } | ||||
|                 throw Exception(e.message) | ||||
|             } | ||||
|         } | ||||
| @@ -158,13 +158,11 @@ class GoogleDriveSyncService(context: Context, json: Json, syncPreferences: Sync | ||||
|         val byteArrayOutputStream = ByteArrayOutputStream() | ||||
|  | ||||
|         withContext(Dispatchers.IO) { | ||||
|             val jsonData = json.encodeToString(syncData) | ||||
|             val gzipOutputStream = GZIPOutputStream(byteArrayOutputStream) | ||||
|             val jsonWriter = JsonWriter(OutputStreamWriter(gzipOutputStream, Charsets.UTF_8)) | ||||
|             val gson = Gson().newBuilder().serializeNulls().create() | ||||
|  | ||||
|             jsonWriter.use { jWriter -> | ||||
|                 gson.toJson(syncData, SyncData::class.java, jWriter) | ||||
|             } | ||||
|             gzipOutputStream.write(jsonData.toByteArray(Charsets.UTF_8)) | ||||
|             gzipOutputStream.close() | ||||
|             logcat(LogPriority.DEBUG) { "JSON serialized successfully" } | ||||
|         } | ||||
|  | ||||
|         val byteArrayContent = ByteArrayContent("application/octet-stream", byteArrayOutputStream.toByteArray()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user