SubwayTooter-Android-App/app/src/main/java/jp/juggler/subwaytooter/util/SimpleHttpClient.kt

93 lines
2.3 KiB
Kotlin
Raw Normal View History

2018-01-12 10:01:25 +01:00
package jp.juggler.subwaytooter.util
import android.content.Context
2018-01-12 10:01:25 +01:00
import okhttp3.*
import android.net.ConnectivityManager
import android.net.NetworkInfo
2018-01-12 10:01:25 +01:00
// okhttpそのままだとモックしづらいので
// リクエストを投げてレスポンスを得る部分をインタフェースにまとめる
interface CurrentCallCallback {
fun onCallCreated(call : Call)
}
interface SimpleHttpClient {
2018-01-12 10:01:25 +01:00
var currentCallCallback : CurrentCallCallback?
fun getResponse(
request : Request,
tmpOkhttpClient : OkHttpClient? = null
) : Response
fun getWebSocket(
request : Request,
webSocketListener : WebSocketListener
) : WebSocket
2018-01-12 10:01:25 +01:00
}
class SimpleHttpClientImpl(
context : Context,
private val okHttpClient : OkHttpClient
) : SimpleHttpClient {
companion object {
val log = LogCategory("SimpleHttpClientImpl")
var connectivityManager : ConnectivityManager? = null
}
init {
if(connectivityManager == null) {
connectivityManager =
context.getSystemService(Context.CONNECTIVITY_SERVICE) as? ConnectivityManager
}
}
2018-01-12 10:01:25 +01:00
override var currentCallCallback : CurrentCallCallback? = null
override fun getResponse(
request : Request,
tmpOkhttpClient : OkHttpClient?
) : Response {
checkNetworkState()
val call = (tmpOkhttpClient ?: this.okHttpClient).newCall(request)
2018-01-12 10:01:25 +01:00
currentCallCallback?.onCallCreated(call)
return call.execute()
}
override fun getWebSocket(
request : Request,
webSocketListener : WebSocketListener
) : WebSocket {
checkNetworkState()
return okHttpClient.newWebSocket(request, webSocketListener)
2018-01-12 10:01:25 +01:00
}
private fun checkNetworkState() {
val cm = connectivityManager
if(cm == null) {
log.d("missing ConnectivityManager")
} else {
val networkInfo = cm.activeNetworkInfo
?: throw RuntimeException("missing ActiveNetwork")
val state = networkInfo.state
val detailedState = networkInfo.detailedState
if(! networkInfo.isConnected) {
throw RuntimeException("network not ready. state=$state detail=$detailedState")
}
if(state == NetworkInfo.State.CONNECTED && detailedState == NetworkInfo.DetailedState.CONNECTED) {
// no logging
} else {
log.d("checkNetworkState state=$state detail=$detailedState")
}
}
}
2018-01-12 10:01:25 +01:00
}