mirror of
https://github.com/tuskyapp/Tusky
synced 2025-01-21 02:55:58 +01:00
don't crash on unexpected json responses (#3635)
This commit is contained in:
commit
7016fa3abc
@ -332,7 +332,7 @@ class AccountListFragment :
|
||||
|
||||
val linkHeader = response.headers()["Link"]
|
||||
onFetchAccountsSuccess(accountList, linkHeader)
|
||||
} catch (exception: IOException) {
|
||||
} catch (exception: Exception) {
|
||||
onFetchAccountsFailure(exception)
|
||||
}
|
||||
}
|
||||
|
@ -1,9 +1,10 @@
|
||||
package com.keylesspalace.tusky.components.timeline.util
|
||||
|
||||
import com.google.gson.JsonParseException
|
||||
import retrofit2.HttpException
|
||||
import java.io.IOException
|
||||
|
||||
fun Throwable.isExpected() = this is IOException || this is HttpException
|
||||
fun Throwable.isExpected() = this is IOException || this is HttpException || this is JsonParseException
|
||||
|
||||
inline fun <T> ifExpected(
|
||||
t: Throwable,
|
||||
|
@ -15,6 +15,7 @@
|
||||
|
||||
package com.keylesspalace.tusky.components.timeline.viewmodel
|
||||
|
||||
import android.util.Log
|
||||
import androidx.paging.ExperimentalPagingApi
|
||||
import androidx.paging.LoadType
|
||||
import androidx.paging.PagingState
|
||||
@ -117,6 +118,7 @@ class CachedTimelineRemoteMediator(
|
||||
return MediatorResult.Success(endOfPaginationReached = statuses.isEmpty())
|
||||
} catch (e: Exception) {
|
||||
return ifExpected(e) {
|
||||
Log.w(TAG, "Failed to load timeline", e)
|
||||
MediatorResult.Error(e)
|
||||
}
|
||||
}
|
||||
@ -175,4 +177,8 @@ class CachedTimelineRemoteMediator(
|
||||
}
|
||||
return overlappedStatuses
|
||||
}
|
||||
|
||||
companion object {
|
||||
private const val TAG = "CachedTimelineRM"
|
||||
}
|
||||
}
|
||||
|
@ -15,6 +15,7 @@
|
||||
|
||||
package com.keylesspalace.tusky.components.timeline.viewmodel
|
||||
|
||||
import android.util.Log
|
||||
import androidx.paging.ExperimentalPagingApi
|
||||
import androidx.paging.LoadType
|
||||
import androidx.paging.PagingState
|
||||
@ -106,8 +107,13 @@ class NetworkTimelineRemoteMediator(
|
||||
return MediatorResult.Success(endOfPaginationReached = statuses.isEmpty())
|
||||
} catch (e: Exception) {
|
||||
return ifExpected(e) {
|
||||
Log.w(TAG, "Failed to load timeline", e)
|
||||
MediatorResult.Error(e)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
companion object {
|
||||
private const val TAG = "NetworkTimelineRM"
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user