request optimize
This commit is contained in:
parent
7bed18ee6d
commit
06b8df5f82
|
@ -56,6 +56,9 @@ object Request {
|
||||||
|
|
||||||
private var listener: RequestListener? = null
|
private var listener: RequestListener? = null
|
||||||
|
|
||||||
|
private var initRetryTimes = 0
|
||||||
|
private var initRetryMaxTimes = 1
|
||||||
|
|
||||||
fun onCreate() {
|
fun onCreate() {
|
||||||
Log.i(TAG, "onCreate")
|
Log.i(TAG, "onCreate")
|
||||||
fetchInfoV2()
|
fetchInfoV2()
|
||||||
|
@ -66,11 +69,22 @@ object Request {
|
||||||
handler.removeCallbacks(tokenRunnable)
|
handler.removeCallbacks(tokenRunnable)
|
||||||
}
|
}
|
||||||
|
|
||||||
var call: Call<LiveInfo>? = null
|
private var call: Call<LiveInfo>? = null
|
||||||
private var callAuth: Call<Auth>? = null
|
private var callAuth: Call<Auth>? = null
|
||||||
|
private var callInfo: Call<Info>? = null
|
||||||
|
private var fAuth: Call<FAuth>? = null
|
||||||
|
private var callPage: Call<pageModel.Response>? = null
|
||||||
|
|
||||||
|
private fun cancelCall() {
|
||||||
|
call?.cancel()
|
||||||
|
callAuth?.cancel()
|
||||||
|
callInfo?.cancel()
|
||||||
|
fAuth?.cancel()
|
||||||
|
callPage?.cancel()
|
||||||
|
}
|
||||||
|
|
||||||
private fun fetchAuth(tvModel: TVViewModel, cookie: String) {
|
private fun fetchAuth(tvModel: TVViewModel, cookie: String) {
|
||||||
callAuth?.cancel()
|
cancelCall()
|
||||||
|
|
||||||
val title = tvModel.title.value
|
val title = tvModel.title.value
|
||||||
|
|
||||||
|
@ -146,8 +160,9 @@ object Request {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fun fetchVideo(tvModel: TVViewModel, cookie: String) {
|
private fun fetchVideo(tvModel: TVViewModel, cookie: String) {
|
||||||
call?.cancel()
|
cancelCall()
|
||||||
|
|
||||||
if (::btraceRunnable.isInitialized) {
|
if (::btraceRunnable.isInitialized) {
|
||||||
handler.removeCallbacks(btraceRunnable)
|
handler.removeCallbacks(btraceRunnable)
|
||||||
}
|
}
|
||||||
|
@ -283,37 +298,23 @@ object Request {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fun fetchAuth(tvModel: TVViewModel) {
|
private fun fetchAuth(tvModel: TVViewModel) {
|
||||||
|
cancelCall()
|
||||||
if (token == "") {
|
if (token == "") {
|
||||||
yspTokenService.getInfo("")
|
callInfo = yspTokenService.getInfo("")
|
||||||
.enqueue(object : Callback<Info> {
|
callInfo?.enqueue(object : Callback<Info> {
|
||||||
override fun onResponse(call: Call<Info>, response: Response<Info>) {
|
override fun onResponse(call: Call<Info>, response: Response<Info>) {
|
||||||
if (response.isSuccessful) {
|
if (response.isSuccessful) {
|
||||||
token = response.body()?.data?.token!!
|
token = response.body()?.data?.token!!
|
||||||
Log.i(TAG, "info success $token")
|
Log.i(TAG, "info success $token")
|
||||||
val cookie =
|
val cookie =
|
||||||
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109;yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109;yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
||||||
fetchAuth(tvModel, cookie)
|
fetchAuth(tvModel, cookie)
|
||||||
} else {
|
} else {
|
||||||
Log.e(TAG, "info status error")
|
Log.e(TAG, "info status error")
|
||||||
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
|
||||||
tvModel.tokenRetryTimes++
|
|
||||||
fetchAuth(tvModel)
|
|
||||||
} else {
|
|
||||||
if (!tvModel.getTV().mustToken) {
|
|
||||||
val cookie =
|
|
||||||
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109"
|
|
||||||
fetchAuth(tvModel, cookie)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onFailure(call: Call<Info>, t: Throwable) {
|
|
||||||
Log.e(TAG, "info request error $t")
|
|
||||||
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
||||||
tvModel.tokenRetryTimes++
|
tvModel.tokenRetryTimes++
|
||||||
fetchVideo(tvModel)
|
fetchAuth(tvModel)
|
||||||
} else {
|
} else {
|
||||||
if (!tvModel.getTV().mustToken) {
|
if (!tvModel.getTV().mustToken) {
|
||||||
val cookie =
|
val cookie =
|
||||||
|
@ -322,7 +323,22 @@ object Request {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
override fun onFailure(call: Call<Info>, t: Throwable) {
|
||||||
|
Log.e(TAG, "info request error $t")
|
||||||
|
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
||||||
|
tvModel.tokenRetryTimes++
|
||||||
|
fetchVideo(tvModel)
|
||||||
|
} else {
|
||||||
|
if (!tvModel.getTV().mustToken) {
|
||||||
|
val cookie =
|
||||||
|
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109"
|
||||||
|
fetchAuth(tvModel, cookie)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
val cookie =
|
val cookie =
|
||||||
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109;yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109;yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
||||||
|
@ -330,35 +346,21 @@ object Request {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun fetchVideo(tvModel: TVViewModel) {
|
private fun fetchVideo(tvModel: TVViewModel) {
|
||||||
|
cancelCall()
|
||||||
Log.d(TAG, "fetchVideo")
|
Log.d(TAG, "fetchVideo")
|
||||||
if (token == "") {
|
if (token == "") {
|
||||||
yspTokenService.getInfo("")
|
callInfo = yspTokenService.getInfo("")
|
||||||
.enqueue(object : Callback<Info> {
|
callInfo?.enqueue(object : Callback<Info> {
|
||||||
override fun onResponse(call: Call<Info>, response: Response<Info>) {
|
override fun onResponse(call: Call<Info>, response: Response<Info>) {
|
||||||
if (response.isSuccessful && response.body()?.data?.token != null) {
|
if (response.isSuccessful && response.body()?.data?.token != null) {
|
||||||
token = response.body()?.data?.token!!
|
token = response.body()?.data?.token!!
|
||||||
Log.i(TAG, "info success $token")
|
Log.i(TAG, "info success $token")
|
||||||
val cookie =
|
val cookie =
|
||||||
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109; yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109; yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
||||||
fetchVideo(tvModel, cookie)
|
fetchVideo(tvModel, cookie)
|
||||||
} else {
|
} else {
|
||||||
Log.e(TAG, "info status error")
|
Log.e(TAG, "info status error")
|
||||||
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
|
||||||
tvModel.tokenRetryTimes++
|
|
||||||
fetchVideo(tvModel)
|
|
||||||
} else {
|
|
||||||
if (!tvModel.getTV().mustToken) {
|
|
||||||
val cookie =
|
|
||||||
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109"
|
|
||||||
fetchVideo(tvModel, cookie)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onFailure(call: Call<Info>, t: Throwable) {
|
|
||||||
Log.e(TAG, "info request error $t")
|
|
||||||
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
||||||
tvModel.tokenRetryTimes++
|
tvModel.tokenRetryTimes++
|
||||||
fetchVideo(tvModel)
|
fetchVideo(tvModel)
|
||||||
|
@ -370,7 +372,22 @@ object Request {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}
|
||||||
|
|
||||||
|
override fun onFailure(call: Call<Info>, t: Throwable) {
|
||||||
|
Log.e(TAG, "info request error $t")
|
||||||
|
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
||||||
|
tvModel.tokenRetryTimes++
|
||||||
|
fetchVideo(tvModel)
|
||||||
|
} else {
|
||||||
|
if (!tvModel.getTV().mustToken) {
|
||||||
|
val cookie =
|
||||||
|
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109"
|
||||||
|
fetchVideo(tvModel, cookie)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
val cookie =
|
val cookie =
|
||||||
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109; yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
"versionName=99.99.99; versionCode=999999; vplatform=109; platformVersion=Chrome; deviceModel=120; appid=1400421205; yspappid=519748109; yspopenid=vu0-8lgGV2LW9QjDeuBFsX8yMnzs37Q3_HZF6XyVDpGR_I; vusession=$token"
|
||||||
|
@ -378,11 +395,8 @@ object Request {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private var fAuth: Call<FAuth>? = null
|
private fun fetchFAuth(tvModel: TVViewModel) {
|
||||||
fun fetchFAuth(tvModel: TVViewModel) {
|
cancelCall()
|
||||||
call?.cancel()
|
|
||||||
callAuth?.cancel()
|
|
||||||
fAuth?.cancel()
|
|
||||||
|
|
||||||
val title = tvModel.title.value
|
val title = tvModel.title.value
|
||||||
|
|
||||||
|
@ -399,11 +413,11 @@ object Request {
|
||||||
// Log.d(TAG, "$title url $url")
|
// Log.d(TAG, "$title url $url")
|
||||||
tvModel.addVideoUrl(url)
|
tvModel.addVideoUrl(url)
|
||||||
tvModel.allReady()
|
tvModel.allReady()
|
||||||
tvModel.tokenRetryTimes = 0
|
tvModel.tokenFHRetryTimes = 0
|
||||||
} else {
|
} else {
|
||||||
Log.e(TAG, "auth status error ${response.code()}")
|
Log.e(TAG, "auth status error ${response.code()}")
|
||||||
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
if (tvModel.tokenFHRetryTimes < tvModel.tokenFHRetryMaxTimes) {
|
||||||
tvModel.tokenRetryTimes++
|
tvModel.tokenFHRetryTimes++
|
||||||
fetchFAuth(tvModel)
|
fetchFAuth(tvModel)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -411,8 +425,8 @@ object Request {
|
||||||
|
|
||||||
override fun onFailure(call: Call<FAuth>, t: Throwable) {
|
override fun onFailure(call: Call<FAuth>, t: Throwable) {
|
||||||
Log.e(TAG, "auth request error $t")
|
Log.e(TAG, "auth request error $t")
|
||||||
if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) {
|
if (tvModel.tokenFHRetryTimes < tvModel.tokenFHRetryMaxTimes) {
|
||||||
tvModel.tokenRetryTimes++
|
tvModel.tokenFHRetryTimes++
|
||||||
fetchFAuth(tvModel)
|
fetchFAuth(tvModel)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -444,7 +458,7 @@ object Request {
|
||||||
|
|
||||||
class TokenRunnable : Runnable {
|
class TokenRunnable : Runnable {
|
||||||
override fun run() {
|
override fun run() {
|
||||||
fetchToken()
|
// fetchToken()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -487,14 +501,20 @@ object Request {
|
||||||
Utils.setBetween(c * 1000L)
|
Utils.setBetween(c * 1000L)
|
||||||
Log.i(TAG, "current time $c")
|
Log.i(TAG, "current time $c")
|
||||||
}
|
}
|
||||||
|
listener?.onRequestFinished()
|
||||||
} else {
|
} else {
|
||||||
Log.e(TAG, "token status error")
|
Log.e(TAG, "token status error")
|
||||||
handler.postDelayed(
|
handler.postDelayed(
|
||||||
tokenRunnable,
|
tokenRunnable,
|
||||||
30 * 60 * 1000
|
30 * 60 * 1000
|
||||||
)
|
)
|
||||||
|
if (initRetryTimes < initRetryMaxTimes) {
|
||||||
|
initRetryTimes++
|
||||||
|
fetchInfoV2()
|
||||||
|
} else {
|
||||||
|
listener?.onRequestFinished()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
listener?.onRequestFinished()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onFailure(call: Call<InfoV2>, t: Throwable) {
|
override fun onFailure(call: Call<InfoV2>, t: Throwable) {
|
||||||
|
@ -503,7 +523,13 @@ object Request {
|
||||||
tokenRunnable,
|
tokenRunnable,
|
||||||
30 * 60 * 1000
|
30 * 60 * 1000
|
||||||
)
|
)
|
||||||
listener?.onRequestFinished()
|
|
||||||
|
if (initRetryTimes < initRetryMaxTimes) {
|
||||||
|
initRetryTimes++
|
||||||
|
fetchInfoV2()
|
||||||
|
} else {
|
||||||
|
listener?.onRequestFinished()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -599,7 +625,8 @@ object Request {
|
||||||
}
|
}
|
||||||
|
|
||||||
fun fetchPage() {
|
fun fetchPage() {
|
||||||
yspProtoService.getPage().enqueue(object : Callback<pageModel.Response> {
|
callPage = yspProtoService.getPage()
|
||||||
|
callPage?.enqueue(object : Callback<pageModel.Response> {
|
||||||
override fun onResponse(
|
override fun onResponse(
|
||||||
call: Call<pageModel.Response>,
|
call: Call<pageModel.Response>,
|
||||||
response: Response<pageModel.Response>
|
response: Response<pageModel.Response>
|
||||||
|
|
|
@ -22,10 +22,11 @@ class TVViewModel(private var tv: TV) : ViewModel() {
|
||||||
private var itemPosition: Int = 0
|
private var itemPosition: Int = 0
|
||||||
|
|
||||||
var retryTimes = 0
|
var retryTimes = 0
|
||||||
var tokenRetryTimes = 0
|
|
||||||
var retryMaxTimes = 8
|
var retryMaxTimes = 8
|
||||||
var tokenRetryMaxTimes = 2
|
var tokenRetryTimes = 0
|
||||||
var programUpdateTime: Long = 0
|
var tokenRetryMaxTimes = 0
|
||||||
|
var tokenFHRetryTimes = 0
|
||||||
|
var tokenFHRetryMaxTimes = 2
|
||||||
|
|
||||||
private val _errInfo = MutableLiveData<String>()
|
private val _errInfo = MutableLiveData<String>()
|
||||||
val errInfo: LiveData<String>
|
val errInfo: LiveData<String>
|
||||||
|
|
|
@ -130,7 +130,7 @@
|
||||||
"programId": "600004078",
|
"programId": "600004078",
|
||||||
"needToken": true,
|
"needToken": true,
|
||||||
"mustToken": false,
|
"mustToken": false,
|
||||||
"title": "CCTV9 记录",
|
"title": "CCTV9 纪录",
|
||||||
"videoUrl": [
|
"videoUrl": [
|
||||||
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226197/index.m3u8"
|
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226197/index.m3u8"
|
||||||
]
|
]
|
||||||
|
|
Loading…
Reference in New Issue