From d03de91c1ef649f8bd2eae6765dac3da8273d53b Mon Sep 17 00:00:00 2001 From: Li ZongYing Date: Sat, 16 Mar 2024 10:44:55 +0800 Subject: [PATCH] request optimize --- .../main/java/com/lizongying/mytv/Request.kt | 75 +++++++++++-------- .../com/lizongying/mytv/models/TVViewModel.kt | 14 ++-- 2 files changed, 50 insertions(+), 39 deletions(-) diff --git a/app/src/main/java/com/lizongying/mytv/Request.kt b/app/src/main/java/com/lizongying/mytv/Request.kt index 89198eb1..a27cdb58 100644 --- a/app/src/main/java/com/lizongying/mytv/Request.kt +++ b/app/src/main/java/com/lizongying/mytv/Request.kt @@ -72,14 +72,14 @@ object Request { private var call: Call? = null private var callAuth: Call? = null private var callInfo: Call? = null - private var fAuth: Call? = null + private var callFAuth: Call? = null private var callPage: Call? = null private fun cancelCall() { call?.cancel() callAuth?.cancel() callInfo?.cancel() - fAuth?.cancel() + callFAuth?.cancel() callPage?.cancel() } @@ -91,7 +91,6 @@ object Request { val data = YSP.getAuthData(tvModel) val request = AuthRequest(data) callAuth = request.let { yspApiService.getAuth("guid=${YSP.getGuid()}; $cookie", it) } - callAuth?.enqueue(object : Callback { override fun onResponse(call: Call, response: Response) { if (response.isSuccessful) { @@ -106,12 +105,12 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchAuth(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchAuth(tvModel) } } else { @@ -124,12 +123,12 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchAuth(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchAuth(tvModel) } } else { @@ -144,12 +143,12 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchAuth(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchAuth(tvModel) } } else { @@ -212,13 +211,13 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchVideo(tvModel, cookie) // fetchAuth(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchVideo(tvModel) // fetchAuth(tvModel) } @@ -237,13 +236,13 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchVideo(tvModel, cookie) // fetchAuth(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchVideo(tvModel) // fetchAuth(tvModel) } @@ -259,13 +258,13 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchVideo(tvModel, cookie) // fetchAuth(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchVideo(tvModel) // fetchAuth(tvModel) } @@ -282,12 +281,12 @@ object Request { if (tvModel.retryTimes < tvModel.retryMaxTimes) { tvModel.retryTimes++ if (tvModel.getTV().needToken) { - if (tvModel.tokenRetryTimes == tvModel.tokenRetryMaxTimes) { + if (tvModel.tokenYSPRetryTimes == tvModel.tokenYSPRetryMaxTimes) { if (!tvModel.getTV().mustToken) { fetchVideo(tvModel, cookie) } } else { - token = "" + tvModel.needGetToken = true fetchVideo(tvModel) } } else { @@ -300,20 +299,28 @@ object Request { private fun fetchAuth(tvModel: TVViewModel) { cancelCall() - if (token == "") { + if (tvModel.needGetToken) { callInfo = yspTokenService.getInfo("") callInfo?.enqueue(object : Callback { override fun onResponse(call: Call, response: Response) { - if (response.isSuccessful) { + if (response.isSuccessful && response.body()?.data?.token != null) { token = response.body()?.data?.token!! Log.i(TAG, "info success $token") + tvModel.needGetToken = false + tvModel.tokenYSPRetryTimes = 0 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" fetchAuth(tvModel, cookie) + } else if (response.code() == 304) { + tvModel.needGetToken = false + tvModel.tokenYSPRetryTimes = 0 + 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" + fetchVideo(tvModel, cookie) } else { Log.e(TAG, "info status error") - if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) { - tvModel.tokenRetryTimes++ + if (tvModel.tokenYSPRetryTimes < tvModel.tokenYSPRetryMaxTimes) { + tvModel.tokenYSPRetryTimes++ fetchAuth(tvModel) } else { if (!tvModel.getTV().mustToken) { @@ -327,8 +334,8 @@ object Request { override fun onFailure(call: Call, t: Throwable) { Log.e(TAG, "info request error $t") - if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) { - tvModel.tokenRetryTimes++ + if (tvModel.tokenYSPRetryTimes < tvModel.tokenYSPRetryMaxTimes) { + tvModel.tokenYSPRetryTimes++ fetchVideo(tvModel) } else { if (!tvModel.getTV().mustToken) { @@ -349,20 +356,28 @@ object Request { private fun fetchVideo(tvModel: TVViewModel) { cancelCall() Log.d(TAG, "fetchVideo") - if (token == "") { + if (tvModel.needGetToken) { callInfo = yspTokenService.getInfo("") callInfo?.enqueue(object : Callback { override fun onResponse(call: Call, response: Response) { if (response.isSuccessful && response.body()?.data?.token != null) { token = response.body()?.data?.token!! Log.i(TAG, "info success $token") + tvModel.needGetToken = false + tvModel.tokenYSPRetryTimes = 0 + 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" + fetchVideo(tvModel, cookie) + } else if (response.code() == 304) { + tvModel.needGetToken = false + tvModel.tokenYSPRetryTimes = 0 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" fetchVideo(tvModel, cookie) } else { Log.e(TAG, "info status error") - if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) { - tvModel.tokenRetryTimes++ + if (tvModel.tokenYSPRetryTimes < tvModel.tokenYSPRetryMaxTimes) { + tvModel.tokenYSPRetryTimes++ fetchVideo(tvModel) } else { if (!tvModel.getTV().mustToken) { @@ -376,8 +391,8 @@ object Request { override fun onFailure(call: Call, t: Throwable) { Log.e(TAG, "info request error $t") - if (tvModel.tokenRetryTimes < tvModel.tokenRetryMaxTimes) { - tvModel.tokenRetryTimes++ + if (tvModel.tokenYSPRetryTimes < tvModel.tokenYSPRetryMaxTimes) { + tvModel.tokenYSPRetryTimes++ fetchVideo(tvModel) } else { if (!tvModel.getTV().mustToken) { @@ -405,8 +420,8 @@ object Request { qa = "FHD" } - fAuth = fAuthService.getAuth(tokenFH, tvModel.getTV().pid, qa) - fAuth?.enqueue(object : Callback { + callFAuth = fAuthService.getAuth(tokenFH, tvModel.getTV().pid, qa) + callFAuth?.enqueue(object : Callback { override fun onResponse(call: Call, response: Response) { if (response.isSuccessful && response.body()?.data?.live_url != null) { val url = response.body()?.data?.live_url!! diff --git a/app/src/main/java/com/lizongying/mytv/models/TVViewModel.kt b/app/src/main/java/com/lizongying/mytv/models/TVViewModel.kt index cb8eb204..5fff4471 100644 --- a/app/src/main/java/com/lizongying/mytv/models/TVViewModel.kt +++ b/app/src/main/java/com/lizongying/mytv/models/TVViewModel.kt @@ -23,11 +23,13 @@ class TVViewModel(private var tv: TV) : ViewModel() { var retryTimes = 0 var retryMaxTimes = 8 - var tokenRetryTimes = 0 - var tokenRetryMaxTimes = 0 + var tokenYSPRetryTimes = 0 + var tokenYSPRetryMaxTimes = 0 var tokenFHRetryTimes = 0 var tokenFHRetryMaxTimes = 2 + var needGetToken = false + private val _errInfo = MutableLiveData() val errInfo: LiveData get() = _errInfo @@ -171,19 +173,13 @@ class TVViewModel(private var tv: TV) : ViewModel() { _epg.value = p.map { EPG(it.title, formatFTime(it.event_time)) }.toMutableList() } - private var mHeaders: Map? = mapOf() - - fun setHeaders(headers: Map) { - mHeaders = headers - } - /** * (playerView?.player as ExoPlayer).setMediaSource(tvViewModel.buildSource()) */ @OptIn(UnstableApi::class) fun buildSource(): HlsMediaSource { val httpDataSource = DefaultHttpDataSource.Factory() - mHeaders?.let { httpDataSource.setDefaultRequestProperties(it) } +// mHeaders?.let { httpDataSource.setDefaultRequestProperties(it) } return HlsMediaSource.Factory(httpDataSource).createMediaSource( MediaItem.fromUri(