我的Retrofit自定义回调是合适的实现吗?

问题描述 投票:0回答:1

这里我将可变的livedata对象作为侦听器传递。可行,但这是正确的实现吗?此实现有任何隐藏的问题,还是有更好的解决方案?

BaseCallback.kt

abstract class BaseCallback<T> constructor(private val listener: MutableLiveData<*>) : Callback<T> {
   override fun onResponse(call: Call<T>, response: Response<T>) {
    when {
        response.code() == 401 -> {
        }
        response.isSuccessful -> {
            onSuccess(response.body())
        }
        else -> {
            val apiError = ErrorUtils.parseError(response)
            listener.value = ApiResult.Error(exception = apiError!!)
        }
    }
}

override fun onFailure(call: Call<T>, t: Throwable) {
    listener.value = ApiResult.Error(
        ApiError(message = t.message ?: "Oops Something Went Wrong!")
    )
}

abstract fun onSuccess(response: T?)
}

Viewmodel

private val _deviceListResponse = MutableLiveData<ApiResult<List<Device>>>()
val deviceListResponse: LiveData<ApiResult<List<Device>>> = _deviceListResponse

deviceRepo.getDevices().enqueue(object : BaseCallback<List<Device>>(_deviceListResponse) {
        override fun onSuccess(response: List<Device>?) {
            val devices = response ?: ArrayList()
            _deviceListResponse.value = ApiResult.Success(devices)
        }
    })
android kotlin retrofit2 android-livedata mutablelivedata
1个回答
0
投票

不,您不应该将LiveData传递给Callback,BaseCallback应该是独立的,这是一个简单的示例:

fun <T> baseCallBack(onSuccess: (response: T?) -> Unit, onFailure: (apiResult: ApiResult) -> Unit): Callback<T> {
    return object : Callback<T> {
        override fun onFailure(call: Call<T>, t: Throwable) {

        }

        override fun onResponse(call: Call<T>, response: Response<T>) {
            if (response.isSuccessful) {
                onSuccess(response.body())
            } else {
                onFailure(ApiResult.Error {
                    ApiError(message = t.message ?: "Oops Something Went Wrong!")
                })
            }
        }
    }
}
最新问题
© www.soinside.com 2019 - 2025. All rights reserved.