diff --git a/README.md b/README.md
index b8477f47..fa2a841c 100644
--- a/README.md
+++ b/README.md
@@ -14,6 +14,17 @@
## 更新日志
+### v1.6.6(通用)
+
+* 更新重庆卫视图标
+* 凤凰卫视增强画质
+* 凤凰卫视增加EPG
+
+### v1.6.5(安卓5及以上专用)
+
+* 增加CETV1图标
+* 稳定性提升
+
### v1.6.4(通用)
* 增加CETV1
@@ -222,6 +233,7 @@ adb install my-tv.apk
* 节目增加预告
* 频道列表优化
* 自动更新
+* 時間
## 赞赏
diff --git a/app/build.gradle b/app/build.gradle
index 12e10ad2..1bf5012d 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -54,7 +54,7 @@ android {
}
kotlinOptions {
- jvmTarget=17
+ jvmTarget = 17
}
// Encapsulates your external native build configurations.
@@ -71,9 +71,14 @@ android {
static def VersionCode() {
try {
- def process = 'git rev-list --count HEAD'.execute()
+ def p = "git describe --tags --always"
+ def process = p.execute()
process.waitFor()
- return process.text.toInteger()
+ def replace = [v: "", ".": " ", "-": " "]
+ def arr = (process.text.trim().replace(replace) + " 0").split(" ")
+ def versionCode = arr[0].toInteger() * 16777216 + arr[1].toInteger() * 65536 + arr[2].toInteger() * 256 + arr[3].toInteger()
+ println("VersionCode $versionCode")
+ return versionCode
} catch (ignored) {
return 0
}
@@ -81,7 +86,7 @@ static def VersionCode() {
static def VersionName() {
try {
- def process = 'git describe --tags --always'.execute()
+ def process = "git describe --tags --always".execute()
process.waitFor()
return process.text.trim() - "v"
} catch (ignored) {
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 3bb6bc5c..3dbaa932 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -7,6 +7,7 @@
android:name="android.software.leanback"
android:required="true" />
+
? = 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/SP.kt b/app/src/main/java/com/lizongying/mytv/SP.kt
index 583bd5fc..7f8595ab 100644
--- a/app/src/main/java/com/lizongying/mytv/SP.kt
+++ b/app/src/main/java/com/lizongying/mytv/SP.kt
@@ -6,14 +6,19 @@ import android.content.SharedPreferences
object SP {
// Name of the sp file TODO Should use a meaningful name and do migrations
private const val SP_FILE_NAME = "MainActivity"
+
// If Change channel with up and down in reversed order or not
private const val KEY_CHANNEL_REVERSAL = "channel_reversal"
+
// If use channel num to select channel or not
private const val KEY_CHANNEL_NUM = "channel_num"
+
// If start app on device boot or not
private const val KEY_BOOT_STARTUP = "boot_startup"
+
// Position in list of the selected channel item
private const val KEY_POSITION = "position"
+
// guid
private const val KEY_GUID = "guid"
@@ -43,6 +48,6 @@ object SP {
set(value) = sp.edit().putInt(KEY_POSITION, value).apply()
var guid: String
- get() = sp.getString(KEY_GUID, "") ?: ""
+ get() = sp.getString(KEY_GUID, "") ?: ""
set(value) = sp.edit().putString(KEY_GUID, value).apply()
}
\ No newline at end of file
diff --git a/app/src/main/java/com/lizongying/mytv/SettingFragment.kt b/app/src/main/java/com/lizongying/mytv/SettingFragment.kt
index dbf63b52..10fc5a6e 100644
--- a/app/src/main/java/com/lizongying/mytv/SettingFragment.kt
+++ b/app/src/main/java/com/lizongying/mytv/SettingFragment.kt
@@ -27,8 +27,8 @@ class SettingFragment : DialogFragment() {
): View {
val context = requireContext() // It‘s safe to get context here.
_binding = DialogBinding.inflate(inflater, container, false)
- binding.version.text =
- "当前版本: ${context.appVersionName}\n获取最新: https://github.com/lizongying/my-tv/releases/"
+ binding.versionName.text = "当前版本: v${context.appVersionName}"
+ binding.version.text = "https://github.com/lizongying/my-tv"
binding.switchChannelReversal.run {
isChecked = SP.channelReversal
diff --git a/app/src/main/java/com/lizongying/mytv/TV.kt b/app/src/main/java/com/lizongying/mytv/TV.kt
index ee8b1fff..019d3707 100644
--- a/app/src/main/java/com/lizongying/mytv/TV.kt
+++ b/app/src/main/java/com/lizongying/mytv/TV.kt
@@ -7,7 +7,6 @@ data class TV(
var title: String,
var alias: String = "",
var videoUrl: List,
- var videoIndex: Int = 0,
var channel: String = "",
var logo: Any = "",
var pid: String = "",
@@ -23,7 +22,6 @@ data class TV(
"id=" + id +
", title='" + title + '\'' +
", videoUrl='" + videoUrl + '\'' +
- ", videoIndex='" + videoIndex + '\'' +
", logo='" + logo + '\'' +
", pid='" + pid + '\'' +
", sid='" + sid + '\'' +
diff --git a/app/src/main/java/com/lizongying/mytv/TVList.kt b/app/src/main/java/com/lizongying/mytv/TVList.kt
index a445fd91..9a6e9397 100644
--- a/app/src/main/java/com/lizongying/mytv/TVList.kt
+++ b/app/src/main/java/com/lizongying/mytv/TVList.kt
@@ -20,7 +20,6 @@ object TVList {
"CCTV1 综合",
"CCTV1",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226231/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/d57905b93540bd15f0c48230dbbbff7ee0d645ff539e38866e2d15c8b9f7dfcd.png?imageMogr2/format/webp",
"600001859",
@@ -34,7 +33,6 @@ object TVList {
"CCTV2 财经",
"CCTV2",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226195/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/20115388de0207131af17eac86c33049b95d69eaff064e55653a1b941810a006.png?imageMogr2/format/webp",
"600001800",
@@ -48,7 +46,6 @@ object TVList {
"CCTV3 综艺",
"CCTV3",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226397/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/7b7a65c712450da3deb6ca66fbacf4f9aee00d3f20bd80eafb5ada01ec63eb3a.png?imageMogr2/format/webp",
"600001801",
@@ -65,7 +62,6 @@ object TVList {
"http://39.134.24.161/dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226191/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226191/index.m3u8"
),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/f357e58fdbcc076a3d65e1f958c942b2e14f14342c60736ceed98b092d35356a.png?imageMogr2/format/webp",
"600001814",
@@ -79,7 +75,6 @@ object TVList {
"CCTV5 体育",
"CCTV5",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226395/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/0a6a7138952675983a3d854df7688557b286d59aa06166edae51506f9204d655.png?imageMogr2/format/webp",
"600001818",
@@ -93,7 +88,6 @@ object TVList {
"CCTV6 电影",
"CCTV6",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226393/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/741515efda91f03f455df8a7da4ee11fa9329139c276435cf0a9e2af398d5bf2.png?imageMogr2/format/webp",
"600108442",
@@ -107,7 +101,6 @@ object TVList {
"CCTV7 国防军事",
"CCTV7",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226192/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/b29af94e295ebdf646cefb68122c429b9cd921f498ca20d2d8070252536f9ff9.png?imageMogr2/format/webp",
"600004092",
@@ -121,7 +114,6 @@ object TVList {
"CCTV8 电视剧",
"CCTV8",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226391/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/ad51de94426a0ba039e6dd6a8534ea98ecc813a6176bde87b4f18cc34d6d7590.png?imageMogr2/format/webp",
"600001803",
@@ -135,7 +127,6 @@ object TVList {
"CCTV9 纪录",
"CCTV9",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226197/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/2ed1b4deeca179d5db806bb941790f82eb92a1b7299c1c38fe027f95a5caee5e.png?imageMogr2/format/webp",
"600004078",
@@ -149,7 +140,6 @@ object TVList {
"CCTV10 科教",
"CCTV10",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226189/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/aa6157ec65188cd41826e5a2f088c3d6d153205f5f6428258d12c59999e221aa.png?imageMogr2/format/webp",
"600001805",
@@ -163,7 +153,6 @@ object TVList {
"CCTV11 戏曲",
"CCTV11",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226240/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/ed12ed7c7a1034dae4350011fe039284c5d5a836506b28c9e32e3c75299625c0.png?imageMogr2/format/webp",
"600001806",
@@ -177,7 +166,6 @@ object TVList {
"CCTV12 社会与法",
"CCTV12",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226190/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/484083cffaa40df7e659565e8cb4d1cc740158a185512114167aa21fa0c59240.png?imageMogr2/format/webp",
"600001807",
@@ -191,10 +179,8 @@ object TVList {
"CCTV13 新闻",
"CCTV13",
listOf(
- "https://live-play.cctvnews.cctv.com/cctv/merge_cctv13.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226233/index.m3u8"
),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/266da7b43c03e2312186b4a999e0f060e8f15b10d2cc2c9aa32171819254cf1a.png?imageMogr2/format/webp",
"600001811",
@@ -208,7 +194,6 @@ object TVList {
"CCTV14 少儿",
"CCTV14",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226193/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/af6b603896938dc346fbb16abfc63c12cba54b0ec9d18770a15d347d115f12d5.png?imageMogr2/format/webp",
"600001809",
@@ -222,7 +207,6 @@ object TVList {
"CCTV15 音乐",
"CCTV15",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225785/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/2ceee92188ef684efe0d8b90839c4f3ad450d179dc64d59beff417059453af47.png?imageMogr2/format/webp",
"600001815",
@@ -239,7 +223,6 @@ object TVList {
"http://39.134.24.162/dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226921/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226921/index.m3u8"
),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/53793fa7bacd3a93ff6dc5d2758418985e1f952a316c335d663b572d8bdcd74d.png?imageMogr2/format/webp",
"600098637",
@@ -253,7 +236,6 @@ object TVList {
"CCTV17 农业农村",
"CCTV17",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226198/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/ddef563072f8bad2bea5b9e52674cb7b4ed50efb20c26e61994dfbdf05c1e3c0.png?imageMogr2/format/webp",
"600001810",
@@ -267,7 +249,6 @@ object TVList {
"CCTV5+ 体育赛事",
"CCTV5+",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226221/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/649ad76a90bfef55b05db9fe52e006487280f619089099d5dc971e387fc6eff0.png?imageMogr2/format/webp",
"600001817",
@@ -281,7 +262,6 @@ object TVList {
"CCTV4K 超高清",
"CCTV4K",
listOf(),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/3e9d06fd7244d950df5838750f1c6ac3456e172b51caca2c16d2282125b111e8.png?imageMogr2/format/webp",
"600002264",
@@ -295,7 +275,6 @@ object TVList {
"CCTV8K 超高清",
"CCTV8K",
listOf(),
- 0,
"央视",
R.drawable.cctv8k,
"600156816",
@@ -309,7 +288,6 @@ object TVList {
"风云剧场",
"CCTV风云剧场频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226950/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/4d549e53e6d0f632d5a633d1945280797b153e588f919221a07faa869812cc89.png?imageMogr2/format/webp",
"600099658",
@@ -323,7 +301,6 @@ object TVList {
"第一剧场",
"CCTV第一剧场频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226959/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/a556bd7d93ce65e18f243a8892b5604f4faa994a4897315914216a710a706208.png?imageMogr2/format/webp",
"600099655",
@@ -337,7 +314,6 @@ object TVList {
"怀旧剧场",
"CCTV怀旧剧场频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226972/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/5661bd04fecdb6e899f801147a22ab5d3a475bf2b62e30aec2c0023190ebc9b1.png?imageMogr2/format/webp",
"600099620",
@@ -351,7 +327,6 @@ object TVList {
"世界地理",
"CCTV世界地理频道",
listOf(),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/bb3c6c9e145d698137f5bb64a582021a01b51344b929003630eb769ea65832a9.png?imageMogr2/format/webp",
"600099637",
@@ -365,7 +340,6 @@ object TVList {
"风云音乐",
"CCTV风云音乐频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226953/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/bbf1d024c5228b8dd128b0e3cb1717d173fab4ee84c3a4c8a57b1a215362ca3b.png?imageMogr2/format/webp",
"600099660",
@@ -379,7 +353,6 @@ object TVList {
"兵器科技",
"CCTV兵器科技频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226975/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/4c6b6a6d3839889f34d33db3c2f80233b26b74d3489b393487635f8704e70796.png?imageMogr2/format/webp",
"600099649",
@@ -393,7 +366,6 @@ object TVList {
"风云足球",
"CCTV风云足球频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226984/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/cd1e2bb52b06a991de168733e5ff0f1d85adc8042d40c8f393f723543e5dd08a.png?imageMogr2/format/webp",
"600099636",
@@ -407,7 +379,6 @@ object TVList {
"高尔夫网球",
"CCTV高尔夫·网球频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226978/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/cdd1b31ede7a5ad049ed53d9a072422f829e72dd062ed2c19e077fdd01699071.png?imageMogr2/format/webp",
"600099659",
@@ -421,7 +392,6 @@ object TVList {
"女性时尚",
"CCTV女性时尚频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226969/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/fa28955ce8b2539d728bf4c6a13a46ff57ad76eae46627f7bcfb1ed8a613d3fc.png?imageMogr2/format/webp",
"600099650",
@@ -435,7 +405,6 @@ object TVList {
"央视文化精品",
"CCTV央视文化精品频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226981/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/14ac5ce40482cacd3d4b37435222bfe86af2b452a2f04ecbfc1d13d76edd7c57.png?imageMogr2/format/webp",
"600099653",
@@ -449,7 +418,6 @@ object TVList {
"央视台球",
"CCTV央视台球频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226956/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/10e14a92478011aa6c3c8562e62127f3b1908e29fcd78e4b2b24b9e6d3ec2fbc.png?imageMogr2/format/webp",
"600099652",
@@ -463,7 +431,6 @@ object TVList {
"电视指南",
"CCTV电视指南频道",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888893/224/3221226987/index.m3u8"),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/244d72c0eb1615ed7d51c2f5db5a67f306aa3f58c05bc2d34de3aa7e956dc8c9.png?imageMogr2/format/webp",
"600099656",
@@ -477,7 +444,6 @@ object TVList {
"卫生健康",
"CCTV卫生健康频道",
listOf(),
- 0,
"央视",
"https://resources.yangshipin.cn/assets/oms/image/202306/54a6863656fdfd8f803be193ddf22441c5000a108833889816fd2d8911715ce8.png?imageMogr2/format/webp",
"600099651",
@@ -493,7 +459,6 @@ object TVList {
"东方卫视",
"东方卫视",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226217/index.m3u8"),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/9bd372ca292a82ce3aa08772b07efc4af1f85c21d1f268ea33440c49e9a0a488.png?imageMogr2/format/webp",
"600002483",
@@ -510,7 +475,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226307/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226211/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/4120e89d3079d08aa17d382f69a2308ec70839b278367763c34a34666c75cb88.png?imageMogr2/format/webp",
"600002475",
@@ -527,7 +491,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226477/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226194/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/7a6be5a2bb1dc53a945c016ff1f525dc4a84c51db371c15c89aa55404b0ba784.png?imageMogr2/format/webp",
"600002508",
@@ -544,7 +507,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226546/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226201/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/ac4ed6058a87c101ae7147ebc38905d0cae047fb73fd277ee5049b84f52bda36.png?imageMogr2/format/webp",
"600002505",
@@ -561,7 +523,6 @@ object TVList {
"http://39.134.24.166/dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226200/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226200/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/380ad685c0c1d5b2c902246b8d2df6d3f9b45e2837abcfe493075bbded597a31.png?imageMogr2/format/webp",
"600002521",
@@ -578,7 +539,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226344/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225764/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/3c760d0d00463855890e8a1864ea4a6b6dd66b90c29b4ac714a4b17c16519871.png?imageMogr2/format/webp",
"600002503",
@@ -592,7 +552,6 @@ object TVList {
"山东卫视",
"山东卫视",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226209/index.m3u8"),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/22d403f07a7cf5410b3ad3ddb65a11aa229a32475fac213f5344c9f0ec330ca1.png?imageMogr2/format/webp",
"600002513",
@@ -606,7 +565,6 @@ object TVList {
"广东卫视",
"广东卫视",
listOf("http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226216/index.m3u8"),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/28886880a4dc0f06fb7e0a528a1def0591d61a65870e29176ede0cc92033bbfd.png?imageMogr2/format/webp",
"600002485",
@@ -623,7 +581,6 @@ object TVList {
"http://live.gxrb.com.cn/tv/gxtvlive03/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225770/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/54b7e97cb816bb223fe05f3fc44da2c7820eb66e8550c19d23100f2c414ecc38.png?imageMogr2/format/webp",
"600002509",
@@ -640,7 +597,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226409/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226202/index.m3u8"
),
- 0,
"地方",
R.drawable.chongqing,
"600002531",
@@ -657,7 +613,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226480/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225767/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/74925962148a6d31c85808b6cd4e444c2a54bab393d2c5fc85e960b50e22fa86.png?imageMogr2/format/webp",
"600002525",
@@ -674,7 +629,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226406/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225750/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/d545becdc81c60197b08c7f47380705e4665ed3fe55efc8b855e486f6e655378.png?imageMogr2/format/webp",
"600002493",
@@ -691,7 +645,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226474/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225793/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/4eb45f4781d33d872af027dc01c941559aab55667dd99cc5c22bef7037807b13.png?imageMogr2/format/webp",
"600002490",
@@ -708,7 +661,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221225728/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226222/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/f4f23633c578beea49a3841d88d3490100f029ee349059fa532869db889872c5.png?imageMogr2/format/webp",
"600002309",
@@ -725,7 +677,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226327/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226215/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/d8273ae9be698ce2db21f5b886ecac95a73429593f93713c60ed8c12c38bf0d3.png?imageMogr2/format/webp",
"600002498",
@@ -742,7 +693,6 @@ object TVList {
"http://hw-m-l.cztv.com/channels/lantian/channel01/1080p.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226199/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/a66c836bd98ba3e41a2e9a570d4b9c50dedc6839e9de333e2e78212ad505f37e.png?imageMogr2/format/webp",
"600002520",
@@ -759,7 +709,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226391/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226203/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/f35fa04b51b1ee4984b03578b65403570868ebca03c6c01e11b097f999a58d9b.png?imageMogr2/format/webp",
"600002532",
@@ -776,7 +725,6 @@ object TVList {
"http://39.134.24.166/dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226205/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221226205/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/d59fec04c902e3581c617136d02d4b9b8c4cbe64272781ddd3525e80c823edb7.png?imageMogr2/format/webp",
"600002481",
@@ -793,7 +741,6 @@ object TVList {
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225768/index.m3u8",
"http://39.134.24.166/dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225768/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/3276a414ae0eaa0f116f2045cd913367967d0c7c1e978e8621ac3879436c6ed7.png?imageMogr2/format/webp",
"600002516",
@@ -810,7 +757,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226341/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225766/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/3208fe6564a293c21b711333fb3edb05bb5b406cff840573c9a8d839680a1579.png?imageMogr2/format/webp",
"600002484",
@@ -827,7 +773,6 @@ object TVList {
"http://ottrrs.hl.chinamobile.com/PLTV/88888888/224/3221226465/index.m3u8",
"http://dbiptv.sn.chinamobile.com/PLTV/88888890/224/3221225769/index.m3u8"
),
- 0,
"地方",
"https://resources.yangshipin.cn/assets/oms/image/202306/6e060391fde0469801fc3d84dbf204b4f8d650d251f17d7595a6964c0bb99e81.png?imageMogr2/format/webp",
"600002506",
@@ -841,7 +786,6 @@ object TVList {
"天津卫视",
"天津卫视",
listOf(),
- 0,
"地方",
R.drawable.tianjin,
"600152137",
@@ -855,7 +799,6 @@ object TVList {
"新疆卫视",
"新疆卫视",
listOf(),
- 0,
"地方",
R.drawable.xinjiang,
"600152138",
@@ -869,7 +812,6 @@ object TVList {
"兵团卫视",
"兵团卫视",
listOf(),
- 0,
"地方",
R.drawable.bingtuan,
"600170344",
@@ -883,7 +825,6 @@ object TVList {
"CETV1",
"CETV1",
listOf(),
- 0,
"地方",
R.drawable.cetv1,
"600171827",
@@ -899,7 +840,6 @@ object TVList {
"凤凰卫视资讯台",
"",
listOf(),
- 0,
"港澳台",
"http://c1.fengshows-cdn.com/a/2021_22/79dcc3a9da358a3.png",
"7c96b084-60e1-40a9-89c5-682b994fb680",
@@ -913,7 +853,6 @@ object TVList {
"凤凰卫视中文台",
"",
listOf(),
- 0,
"港澳台",
"http://c1.fengshows-cdn.com/a/2021_22/ede3d9e09be28e5.png",
"f7f48462-9b13-485b-8101-7b54716411ec",
@@ -927,7 +866,6 @@ object TVList {
"凤凰卫视香港台",
"",
listOf(),
- 0,
"港澳台",
"http://c1.fengshows-cdn.com/a/2021_23/325d941090bee17.png",
"15e02d92-1698-416c-af2f-3e9a872b4d78",
@@ -943,7 +881,6 @@ object TVList {
"CGTN",
"CGTN",
listOf("http://live.cgtn.com/1000/prog_index.m3u8"),
- 0,
"国际",
"https://resources.yangshipin.cn/assets/oms/image/202306/a72dff758ca1c17cd0ecc8cedc11b893d208f409d5e6302faa0e9d298848abc3.png?imageMogr2/format/webp",
"600014550",
@@ -957,7 +894,6 @@ object TVList {
"CGTN 法语频道",
"CGTN法语频道",
listOf("https://livefr.cgtn.com/1000f/prog_index.m3u8"),
- 0,
"国际",
"https://resources.yangshipin.cn/assets/oms/image/202306/a8d0046a47433d952bf6ed17062deb8bd2184ba9aec0f7781df6bf9487a3ffcf.png?imageMogr2/format/webp",
"600084704",
@@ -971,7 +907,6 @@ object TVList {
"CGTN 俄语频道",
"CGTN俄语频道",
listOf("http://liveru.cgtn.com/1000r/prog_index.m3u8"),
- 0,
"国际",
"https://resources.yangshipin.cn/assets/oms/image/202306/bf0a820893cbaf20dd0333e27042e1ef9c8806e5b602b6a8c95af399db0bc77a.png?imageMogr2/format/webp",
"600084758",
@@ -985,7 +920,6 @@ object TVList {
"CGTN 阿拉伯语频道",
"CGTN阿拉伯语频道",
listOf("http://livear.cgtn.com/1000a/prog_index.m3u8"),
- 0,
"国际",
"https://resources.yangshipin.cn/assets/oms/image/202306/2e44e2aa3e7a1cedf07fd0ae59fe69e86a60a2632660a006e3e9e7397b2d107e.png?imageMogr2/format/webp",
"600084782",
@@ -1002,7 +936,6 @@ object TVList {
"http://livees.cgtn.com/500e/prog_index.m3u8",
"http://livees.cgtn.com/1000e/prog_index.m3u8"
),
- 0,
"国际",
"https://resources.yangshipin.cn/assets/oms/image/202309/7c337e3dbe64402ec7e4678a619a4a6d95144e42f35161181ff78e143b7cf67a.png?imageMogr2/format/webp",
"600084744",
@@ -1016,7 +949,6 @@ object TVList {
"CGTN 纪录频道",
"CGTN外语纪录频道",
listOf("https://livedoc.cgtn.com/500d/prog_index.m3u8"),
- 0,
"国际",
"https://resources.yangshipin.cn/assets/oms/image/202309/74d3ac436a7e374879578de1d87a941fbf566d39d5632b027c5097891ed32bd5.png?imageMogr2/format/webp",
"600084781",
diff --git a/app/src/main/java/com/lizongying/mytv/UpdateManager.kt b/app/src/main/java/com/lizongying/mytv/UpdateManager.kt
index 5616bdd4..4f84dace 100644
--- a/app/src/main/java/com/lizongying/mytv/UpdateManager.kt
+++ b/app/src/main/java/com/lizongying/mytv/UpdateManager.kt
@@ -1,5 +1,6 @@
package com.lizongying.mytv
+import android.app.Activity
import android.app.DownloadManager
import android.app.DownloadManager.Request
import android.content.BroadcastReceiver
@@ -13,8 +14,10 @@ import android.os.Environment
import android.os.Handler
import android.os.Looper
import android.util.Log
-import android.widget.Toast
-import com.lizongying.mytv.api.Release
+import androidx.core.app.ActivityCompat
+import androidx.core.content.PermissionChecker
+import androidx.core.content.PermissionChecker.checkSelfPermission
+import com.lizongying.mytv.api.ReleaseV2
import com.lizongying.mytv.requests.MyRequest
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
@@ -30,49 +33,79 @@ class UpdateManager(
ConfirmationDialogFragment.ConfirmationDialogListener {
private var myRequest = MyRequest()
- private var release: Release? = null
+ private var release: ReleaseV2? = null
private var downloadReceiver: DownloadReceiver? = null
fun checkAndUpdate() {
+ if (!haveStoragePermission()) {
+ return
+ }
CoroutineScope(Dispatchers.Main).launch {
+ var text = "版本获取失败"
try {
release = myRequest.getRelease()
- updateUI(release)
- Log.i(TAG, "versionCode $versionCode ${release?.data?.versionCode}")
- if (release != null) {
- if (release?.data?.versionCode!! >= versionCode) {
+ Log.i(TAG, "versionCode $versionCode ${release?.c}")
+ if (release?.c != null) {
+ if (release?.c!! >= versionCode) {
+ text = "最新版本:${release?.n}"
val dialog = ConfirmationDialogFragment(this@UpdateManager)
dialog.show(settingFragment.fragmentManager, "ConfirmationDialogFragment")
} else {
- Toast.makeText(context, "不需要更新", Toast.LENGTH_LONG)
- .show()
+ text = "已是最新版本,不需要更新"
}
}
} catch (e: Exception) {
Log.e(TAG, "Error occurred: ${e.message}", e)
}
+ updateUI(text)
}
}
- private fun updateUI(release: Release?) {
- if (release?.data?.versionName.isNullOrEmpty()) {
- settingFragment.setVersionName("版本获取失败")
- } else {
- settingFragment.setVersionName("最新版本:${release?.data?.versionName!!}")
+ private fun updateUI(text: String) {
+ settingFragment.setVersionName(text)
+ }
+
+ fun haveStoragePermission(): Boolean {
+ if (Build.VERSION.SDK_INT >= 23) {
+ if (checkSelfPermission(context, android.Manifest.permission.WRITE_EXTERNAL_STORAGE)
+ === PermissionChecker.PERMISSION_GRANTED
+ ) {
+ Log.e("Permission error", "You have permission")
+ return true
+ } else {
+ Log.e("Permission error", "You have asked for permission")
+ ActivityCompat.requestPermissions(
+ context as Activity, arrayOf(
+ android.Manifest.permission.WRITE_EXTERNAL_STORAGE
+ ), 1
+ )
+ return false
+ }
+ } else { //you don't need to worry about these stuff below api level 23
+ Log.e("Permission error", "You already have the permission")
+ return true
}
}
- private fun startDownload(release: Release) {
- val apkFileName = "my-tv-${release.data.versionName}.apk"
+
+ private fun startDownload(release: ReleaseV2) {
+ val apkFileName = "my-tv-${release.n}.apk"
Log.i(TAG, "apkFileName $apkFileName")
val downloadManager =
context.getSystemService(Context.DOWNLOAD_SERVICE) as DownloadManager
- val request = Request(Uri.parse(release.data.downloadUrl))
- Log.i(TAG, "url ${Uri.parse(release.data.downloadUrl)}")
- request.setDestinationInExternalPublicDir(Environment.DIRECTORY_DOWNLOADS, apkFileName)
+ val request = Request(Uri.parse(release.u))
+ Log.i(TAG, "url ${Uri.parse(release.u)}")
+ context.getExternalFilesDir(Environment.DIRECTORY_DOWNLOADS)?.mkdirs()
+ request.setDestinationInExternalFilesDir(
+ context,
+ Environment.DIRECTORY_DOWNLOADS,
+ apkFileName
+ )
request.setTitle("New Version Download")
request.setNotificationVisibility(Request.VISIBILITY_VISIBLE_NOTIFY_COMPLETED)
+ request.setAllowedOverRoaming(false)
+ request.setMimeType("application/vnd.android.package-archive")
// 获取下载任务的引用
val downloadReference = downloadManager.enqueue(request)
@@ -97,7 +130,11 @@ class UpdateManager(
}
}
- private fun getDownloadProgress(context: Context, downloadId: Long, progressListener: (Int) -> Unit) {
+ private fun getDownloadProgress(
+ context: Context,
+ downloadId: Long,
+ progressListener: (Int) -> Unit
+ ) {
val downloadManager = context.getSystemService(Context.DOWNLOAD_SERVICE) as DownloadManager
val handler = Handler(Looper.getMainLooper())
val intervalMillis: Long = 1000
@@ -179,7 +216,6 @@ class UpdateManager(
override fun onCancel() {
}
-
fun destroy() {
if (downloadReceiver != null) {
context.unregisterReceiver(downloadReceiver)
diff --git a/app/src/main/java/com/lizongying/mytv/api/ApiClient.kt b/app/src/main/java/com/lizongying/mytv/api/ApiClient.kt
index fb22208c..a8fbb605 100644
--- a/app/src/main/java/com/lizongying/mytv/api/ApiClient.kt
+++ b/app/src/main/java/com/lizongying/mytv/api/ApiClient.kt
@@ -1,7 +1,11 @@
package com.lizongying.mytv.api
+import android.os.Build
+import android.util.Log
+import okhttp3.ConnectionSpec
import okhttp3.OkHttpClient
+import okhttp3.TlsVersion
import retrofit2.Retrofit
import retrofit2.converter.gson.GsonConverterFactory
import retrofit2.converter.protobuf.ProtoConverterFactory
@@ -13,7 +17,6 @@ import javax.net.ssl.X509TrustManager
class ApiClient {
private val yspUrl = "https://player-api.yangshipin.cn/"
private val myUrl = "https://lyrics.run/"
- private val devUrl = "http://10.0.2.2:8081/"
private val protoUrl = "https://capi.yangshipin.cn/"
private val traceUrl = "https://btrace.yangshipin.cn/"
private val fUrl = "https://m.fengshows.com/"
@@ -68,6 +71,36 @@ class ApiClient {
.build().create(FAuthService::class.java)
}
+ private fun enableTls12OnPreLollipop(client: OkHttpClient.Builder): OkHttpClient.Builder {
+ if (Build.VERSION.SDK_INT >= 16 && Build.VERSION.SDK_INT < 22) {
+ try {
+ val sc = SSLContext.getInstance("TLSv1.2")
+
+ sc.init(null, null, null)
+
+ // a more robust version is to pass a custom X509TrustManager
+ // as the second parameter and make checkServerTrusted to accept your server.
+ // Credits: https://github.com/square/okhttp/issues/2372#issuecomment-1774955225
+ client.sslSocketFactory(Tls12SocketFactory(sc.socketFactory))
+
+ val cs = ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
+ .tlsVersions(TlsVersion.TLS_1_2)
+ .build()
+
+ val specs: MutableList = ArrayList()
+ specs.add(cs)
+ specs.add(ConnectionSpec.COMPATIBLE_TLS)
+ specs.add(ConnectionSpec.CLEARTEXT)
+
+ client.connectionSpecs(specs)
+ } catch (exc: java.lang.Exception) {
+ Log.e("OkHttpTLSCompat", "Error while setting TLS 1.2", exc)
+ }
+ }
+
+ return client
+ }
+
private fun getUnsafeOkHttpClient(): OkHttpClient {
try {
val trustAllCerts: Array = arrayOf(
@@ -93,11 +126,12 @@ class ApiClient {
val sslContext = SSLContext.getInstance("SSL")
sslContext.init(null, trustAllCerts, java.security.SecureRandom())
- return OkHttpClient.Builder()
+ val builder = OkHttpClient.Builder()
.sslSocketFactory(sslContext.socketFactory, trustAllCerts[0] as X509TrustManager)
.hostnameVerifier { _, _ -> true }
.dns(DnsCache())
- .build()
+
+ return enableTls12OnPreLollipop(builder).build()
} catch (e: Exception) {
throw RuntimeException(e)
diff --git a/app/src/main/java/com/lizongying/mytv/api/Info.kt b/app/src/main/java/com/lizongying/mytv/api/Info.kt
index 0bec143e..4a2e381e 100644
--- a/app/src/main/java/com/lizongying/mytv/api/Info.kt
+++ b/app/src/main/java/com/lizongying/mytv/api/Info.kt
@@ -22,18 +22,11 @@ data class InfoV2(
val c: Int?,
)
-data class Release(
- val code: Int?,
- val msg: String?,
- val data: Data,
-) {
- data class Data(
- val versionName: String,
- val versionCode: Int,
- val downloadUrl: String,
- val updateTime: Int,
- )
-}
+data class ReleaseV2(
+ val n: String?,
+ val u: String?,
+ val c: Int?,
+)
data class TimeResponse(
val data: Time
diff --git a/app/src/main/java/com/lizongying/mytv/api/ReleaseService.kt b/app/src/main/java/com/lizongying/mytv/api/ReleaseService.kt
index d06eea16..f26db56d 100644
--- a/app/src/main/java/com/lizongying/mytv/api/ReleaseService.kt
+++ b/app/src/main/java/com/lizongying/mytv/api/ReleaseService.kt
@@ -2,10 +2,11 @@ package com.lizongying.mytv.api
import retrofit2.Call
import retrofit2.http.GET
-
+import retrofit2.http.Path
interface ReleaseService {
- @GET("my-tv/v1/release")
+ @GET("my-tv/v2/release/{name}")
fun getRelease(
- ): Call
+ @Path("name") date: String = "1",
+ ): Call
}
\ No newline at end of file
diff --git a/app/src/main/java/com/lizongying/mytv/api/Tls12SocketFactory.kt b/app/src/main/java/com/lizongying/mytv/api/Tls12SocketFactory.kt
new file mode 100644
index 00000000..f701f833
--- /dev/null
+++ b/app/src/main/java/com/lizongying/mytv/api/Tls12SocketFactory.kt
@@ -0,0 +1,74 @@
+package com.lizongying.mytv.api
+
+import java.io.IOException
+import java.net.InetAddress
+import java.net.Socket
+import java.net.UnknownHostException
+import javax.net.ssl.SSLSocket
+import javax.net.ssl.SSLSocketFactory
+
+
+/**
+ * Enables TLS v1.2 when creating SSLSockets.
+ *
+ *
+ * For some reason, android supports TLS v1.2 from API 16, but enables it by
+ * default only from API 20.
+ * @link https://developer.android.com/reference/javax/net/ssl/SSLSocket.html
+ * @see SSLSocketFactory
+ */
+class Tls12SocketFactory(val delegate: SSLSocketFactory) : SSLSocketFactory() {
+ override fun getDefaultCipherSuites(): Array {
+ return delegate.defaultCipherSuites
+ }
+
+ override fun getSupportedCipherSuites(): Array {
+ return delegate.supportedCipherSuites
+ }
+
+ @Throws(IOException::class)
+ override fun createSocket(s: Socket, host: String, port: Int, autoClose: Boolean): Socket {
+ return patch(delegate.createSocket(s, host, port, autoClose))
+ }
+
+ @Throws(IOException::class, UnknownHostException::class)
+ override fun createSocket(host: String, port: Int): Socket {
+ return patch(delegate.createSocket(host, port))
+ }
+
+ @Throws(IOException::class, UnknownHostException::class)
+ override fun createSocket(
+ host: String,
+ port: Int,
+ localHost: InetAddress,
+ localPort: Int
+ ): Socket {
+ return patch(delegate.createSocket(host, port, localHost, localPort))
+ }
+
+ @Throws(IOException::class)
+ override fun createSocket(host: InetAddress, port: Int): Socket {
+ return patch(delegate.createSocket(host, port))
+ }
+
+ @Throws(IOException::class)
+ override fun createSocket(
+ address: InetAddress,
+ port: Int,
+ localAddress: InetAddress,
+ localPort: Int
+ ): Socket {
+ return patch(delegate.createSocket(address, port, localAddress, localPort))
+ }
+
+ private fun patch(s: Socket): Socket {
+ if (s is SSLSocket) {
+ s.enabledProtocols = TLS_V12_ONLY
+ }
+ return s
+ }
+
+ companion object {
+ private val TLS_V12_ONLY = arrayOf("TLSv1.2")
+ }
+}
\ No newline at end of file
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..1288cfb3 100644
--- a/app/src/main/java/com/lizongying/mytv/models/TVViewModel.kt
+++ b/app/src/main/java/com/lizongying/mytv/models/TVViewModel.kt
@@ -23,10 +23,12 @@ 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 tokenFHRetryMaxTimes = 4
+
+ var needGetToken = false
private val _errInfo = MutableLiveData()
val errInfo: LiveData
@@ -88,9 +90,8 @@ class TVViewModel(private var tv: TV) : ViewModel() {
} else {
tv.videoUrl = tv.videoUrl + listOf(url)
}
- tv.videoIndex = tv.videoUrl.lastIndex
_videoUrl.value = tv.videoUrl
- _videoIndex.value = tv.videoIndex
+ _videoIndex.value = tv.videoUrl.lastIndex
}
fun firstSource() {
@@ -118,7 +119,7 @@ class TVViewModel(private var tv: TV) : ViewModel() {
_id.value = tv.id
_title.value = tv.title
_videoUrl.value = tv.videoUrl
- _videoIndex.value = tv.videoIndex
+ _videoIndex.value = tv.videoUrl.lastIndex
_logo.value = tv.logo
_programId.value = tv.programId
_pid.value = tv.pid
@@ -171,19 +172,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(
diff --git a/app/src/main/java/com/lizongying/mytv/requests/MyRequest.kt b/app/src/main/java/com/lizongying/mytv/requests/MyRequest.kt
index 412c504e..17022eb3 100644
--- a/app/src/main/java/com/lizongying/mytv/requests/MyRequest.kt
+++ b/app/src/main/java/com/lizongying/mytv/requests/MyRequest.kt
@@ -1,7 +1,7 @@
package com.lizongying.mytv.requests
import com.lizongying.mytv.api.ApiClient
-import com.lizongying.mytv.api.Release
+import com.lizongying.mytv.api.ReleaseV2
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.withContext
import retrofit2.Call
@@ -13,17 +13,17 @@ import kotlin.coroutines.suspendCoroutine
class MyRequest {
private var releaseService = ApiClient().releaseService
- suspend fun getRelease(): Release? {
+ suspend fun getRelease(): ReleaseV2? {
return withContext(Dispatchers.IO) {
fetchRelease()
}
}
- private suspend fun fetchRelease(): Release? {
+ private suspend fun fetchRelease(): ReleaseV2? {
return suspendCoroutine { continuation ->
releaseService.getRelease()
- .enqueue(object : Callback {
- override fun onResponse(call: Call, response: Response) {
+ .enqueue(object : Callback {
+ override fun onResponse(call: Call, response: Response) {
if (response.isSuccessful) {
continuation.resume(response.body())
} else {
@@ -31,7 +31,7 @@ class MyRequest {
}
}
- override fun onFailure(call: Call, t: Throwable) {
+ override fun onFailure(call: Call, t: Throwable) {
continuation.resume(null)
}
})
diff --git a/app/src/main/res/raw/channels.json b/app/src/main/res/raw/channels.json
index 7b9f469a..2d6443af 100644
--- a/app/src/main/res/raw/channels.json
+++ b/app/src/main/res/raw/channels.json
@@ -1,7 +1,6 @@
[
{
"id": 0,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/d57905b93540bd15f0c48230dbbbff7ee0d645ff539e38866e2d15c8b9f7dfcd.png?imageMogr2/format/webp",
"pid": "600001859",
@@ -16,7 +15,6 @@
},
{
"id": 1,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/20115388de0207131af17eac86c33049b95d69eaff064e55653a1b941810a006.png?imageMogr2/format/webp",
"pid": "600001800",
@@ -31,7 +29,6 @@
},
{
"id": 2,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/7b7a65c712450da3deb6ca66fbacf4f9aee00d3f20bd80eafb5ada01ec63eb3a.png?imageMogr2/format/webp",
"pid": "600001801",
@@ -46,7 +43,6 @@
},
{
"id": 3,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/f357e58fdbcc076a3d65e1f958c942b2e14f14342c60736ceed98b092d35356a.png?imageMogr2/format/webp",
"pid": "600001814",
@@ -62,7 +58,6 @@
},
{
"id": 4,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/0a6a7138952675983a3d854df7688557b286d59aa06166edae51506f9204d655.png?imageMogr2/format/webp",
"pid": "600001818",
@@ -77,7 +72,6 @@
},
{
"id": 5,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/741515efda91f03f455df8a7da4ee11fa9329139c276435cf0a9e2af398d5bf2.png?imageMogr2/format/webp",
"pid": "600001802",
@@ -92,7 +86,6 @@
},
{
"id": 6,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/b29af94e295ebdf646cefb68122c429b9cd921f498ca20d2d8070252536f9ff9.png?imageMogr2/format/webp",
"pid": "600004092",
@@ -107,7 +100,6 @@
},
{
"id": 7,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/ad51de94426a0ba039e6dd6a8534ea98ecc813a6176bde87b4f18cc34d6d7590.png?imageMogr2/format/webp",
"pid": "600001803",
@@ -122,7 +114,6 @@
},
{
"id": 8,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/2ed1b4deeca179d5db806bb941790f82eb92a1b7299c1c38fe027f95a5caee5e.png?imageMogr2/format/webp",
"pid": "600004078",
@@ -137,7 +128,6 @@
},
{
"id": 9,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/aa6157ec65188cd41826e5a2f088c3d6d153205f5f6428258d12c59999e221aa.png?imageMogr2/format/webp",
"pid": "600001805",
@@ -152,7 +142,6 @@
},
{
"id": 10,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/ed12ed7c7a1034dae4350011fe039284c5d5a836506b28c9e32e3c75299625c0.png?imageMogr2/format/webp",
"pid": "600001806",
@@ -167,7 +156,6 @@
},
{
"id": 11,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/484083cffaa40df7e659565e8cb4d1cc740158a185512114167aa21fa0c59240.png?imageMogr2/format/webp",
"pid": "600001807",
@@ -182,7 +170,6 @@
},
{
"id": 12,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/266da7b43c03e2312186b4a999e0f060e8f15b10d2cc2c9aa32171819254cf1a.png?imageMogr2/format/webp",
"pid": "600001811",
@@ -198,7 +185,6 @@
},
{
"id": 13,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/af6b603896938dc346fbb16abfc63c12cba54b0ec9d18770a15d347d115f12d5.png?imageMogr2/format/webp",
"pid": "600001809",
@@ -213,7 +199,6 @@
},
{
"id": 14,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/2ceee92188ef684efe0d8b90839c4f3ad450d179dc64d59beff417059453af47.png?imageMogr2/format/webp",
"pid": "600001815",
@@ -228,7 +213,6 @@
},
{
"id": 15,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/53793fa7bacd3a93ff6dc5d2758418985e1f952a316c335d663b572d8bdcd74d.png?imageMogr2/format/webp",
"pid": "600098637",
@@ -244,7 +228,6 @@
},
{
"id": 16,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/ddef563072f8bad2bea5b9e52674cb7b4ed50efb20c26e61994dfbdf05c1e3c0.png?imageMogr2/format/webp",
"pid": "600001810",
@@ -259,7 +242,6 @@
},
{
"id": 17,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/649ad76a90bfef55b05db9fe52e006487280f619089099d5dc971e387fc6eff0.png?imageMogr2/format/webp",
"pid": "600001817",
@@ -274,7 +256,6 @@
},
{
"id": 18,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/3e9d06fd7244d950df5838750f1c6ac3456e172b51caca2c16d2282125b111e8.png?imageMogr2/format/webp",
"pid": "600002264",
@@ -289,7 +270,6 @@
},
{
"id": 19,
- "videoIndex": 0,
"channel": "央视",
"logo": "",
"pid": "600156816",
@@ -304,7 +284,6 @@
},
{
"id": 20,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/4d549e53e6d0f632d5a633d1945280797b153e588f919221a07faa869812cc89.png?imageMogr2/format/webp",
"pid": "600099658",
@@ -319,7 +298,6 @@
},
{
"id": 21,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/a556bd7d93ce65e18f243a8892b5604f4faa994a4897315914216a710a706208.png?imageMogr2/format/webp",
"pid": "600099655",
@@ -334,7 +312,6 @@
},
{
"id": 22,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/5661bd04fecdb6e899f801147a22ab5d3a475bf2b62e30aec2c0023190ebc9b1.png?imageMogr2/format/webp",
"pid": "600099620",
@@ -349,7 +326,6 @@
},
{
"id": 23,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/bb3c6c9e145d698137f5bb64a582021a01b51344b929003630eb769ea65832a9.png?imageMogr2/format/webp",
"pid": "600099637",
@@ -364,7 +340,6 @@
},
{
"id": 24,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/bbf1d024c5228b8dd128b0e3cb1717d173fab4ee84c3a4c8a57b1a215362ca3b.png?imageMogr2/format/webp",
"pid": "600099660",
@@ -379,7 +354,6 @@
},
{
"id": 25,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/4c6b6a6d3839889f34d33db3c2f80233b26b74d3489b393487635f8704e70796.png?imageMogr2/format/webp",
"pid": "600099649",
@@ -394,7 +368,6 @@
},
{
"id": 26,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/cd1e2bb52b06a991de168733e5ff0f1d85adc8042d40c8f393f723543e5dd08a.png?imageMogr2/format/webp",
"pid": "600099636",
@@ -409,7 +382,6 @@
},
{
"id": 27,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/cdd1b31ede7a5ad049ed53d9a072422f829e72dd062ed2c19e077fdd01699071.png?imageMogr2/format/webp",
"pid": "600099659",
@@ -424,7 +396,6 @@
},
{
"id": 28,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/fa28955ce8b2539d728bf4c6a13a46ff57ad76eae46627f7bcfb1ed8a613d3fc.png?imageMogr2/format/webp",
"pid": "600099650",
@@ -439,7 +410,6 @@
},
{
"id": 29,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/14ac5ce40482cacd3d4b37435222bfe86af2b452a2f04ecbfc1d13d76edd7c57.png?imageMogr2/format/webp",
"pid": "600099653",
@@ -454,7 +424,6 @@
},
{
"id": 30,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/10e14a92478011aa6c3c8562e62127f3b1908e29fcd78e4b2b24b9e6d3ec2fbc.png?imageMogr2/format/webp",
"pid": "600099652",
@@ -469,7 +438,6 @@
},
{
"id": 31,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/244d72c0eb1615ed7d51c2f5db5a67f306aa3f58c05bc2d34de3aa7e956dc8c9.png?imageMogr2/format/webp",
"pid": "600099656",
@@ -484,7 +452,6 @@
},
{
"id": 32,
- "videoIndex": 0,
"channel": "央视",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/54a6863656fdfd8f803be193ddf22441c5000a108833889816fd2d8911715ce8.png?imageMogr2/format/webp",
"pid": "600099651",
@@ -499,7 +466,6 @@
},
{
"id": 33,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/9bd372ca292a82ce3aa08772b07efc4af1f85c21d1f268ea33440c49e9a0a488.png?imageMogr2/format/webp",
"pid": "600002483",
@@ -514,7 +480,6 @@
},
{
"id": 34,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/4120e89d3079d08aa17d382f69a2308ec70839b278367763c34a34666c75cb88.png?imageMogr2/format/webp",
"pid": "600002475",
@@ -530,7 +495,6 @@
},
{
"id": 35,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/7a6be5a2bb1dc53a945c016ff1f525dc4a84c51db371c15c89aa55404b0ba784.png?imageMogr2/format/webp",
"pid": "600002508",
@@ -546,7 +510,6 @@
},
{
"id": 36,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/ac4ed6058a87c101ae7147ebc38905d0cae047fb73fd277ee5049b84f52bda36.png?imageMogr2/format/webp",
"pid": "600002505",
@@ -562,7 +525,6 @@
},
{
"id": 37,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/380ad685c0c1d5b2c902246b8d2df6d3f9b45e2837abcfe493075bbded597a31.png?imageMogr2/format/webp",
"pid": "600002521",
@@ -578,7 +540,6 @@
},
{
"id": 38,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/3c760d0d00463855890e8a1864ea4a6b6dd66b90c29b4ac714a4b17c16519871.png?imageMogr2/format/webp",
"pid": "600002503",
@@ -594,7 +555,6 @@
},
{
"id": 39,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/22d403f07a7cf5410b3ad3ddb65a11aa229a32475fac213f5344c9f0ec330ca1.png?imageMogr2/format/webp",
"pid": "600002513",
@@ -609,7 +569,6 @@
},
{
"id": 40,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/28886880a4dc0f06fb7e0a528a1def0591d61a65870e29176ede0cc92033bbfd.png?imageMogr2/format/webp",
"pid": "600002485",
@@ -624,7 +583,6 @@
},
{
"id": 41,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/54b7e97cb816bb223fe05f3fc44da2c7820eb66e8550c19d23100f2c414ecc38.png?imageMogr2/format/webp",
"pid": "600002509",
@@ -640,7 +598,6 @@
},
{
"id": 42,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/657651f411de2673d1770d9a78b44c1265704f7468cc41d4be7f51d630768494.png?imageMogr2/format/webp",
"pid": "600002531",
@@ -656,7 +613,6 @@
},
{
"id": 43,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/74925962148a6d31c85808b6cd4e444c2a54bab393d2c5fc85e960b50e22fa86.png?imageMogr2/format/webp",
"pid": "600002525",
@@ -672,7 +628,6 @@
},
{
"id": 44,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/d545becdc81c60197b08c7f47380705e4665ed3fe55efc8b855e486f6e655378.png?imageMogr2/format/webp",
"pid": "600002493",
@@ -688,7 +643,6 @@
},
{
"id": 45,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/4eb45f4781d33d872af027dc01c941559aab55667dd99cc5c22bef7037807b13.png?imageMogr2/format/webp",
"pid": "600002490",
@@ -704,7 +658,6 @@
},
{
"id": 46,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/f4f23633c578beea49a3841d88d3490100f029ee349059fa532869db889872c5.png?imageMogr2/format/webp",
"pid": "600002309",
@@ -720,7 +673,6 @@
},
{
"id": 47,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/d8273ae9be698ce2db21f5b886ecac95a73429593f93713c60ed8c12c38bf0d3.png?imageMogr2/format/webp",
"pid": "600002498",
@@ -736,7 +688,6 @@
},
{
"id": 48,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/a66c836bd98ba3e41a2e9a570d4b9c50dedc6839e9de333e2e78212ad505f37e.png?imageMogr2/format/webp",
"pid": "600002520",
@@ -752,7 +703,6 @@
},
{
"id": 49,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/f35fa04b51b1ee4984b03578b65403570868ebca03c6c01e11b097f999a58d9b.png?imageMogr2/format/webp",
"pid": "600002532",
@@ -768,7 +718,6 @@
},
{
"id": 50,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/d59fec04c902e3581c617136d02d4b9b8c4cbe64272781ddd3525e80c823edb7.png?imageMogr2/format/webp",
"pid": "600002481",
@@ -784,7 +733,6 @@
},
{
"id": 51,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/3276a414ae0eaa0f116f2045cd913367967d0c7c1e978e8621ac3879436c6ed7.png?imageMogr2/format/webp",
"pid": "600002516",
@@ -800,7 +748,6 @@
},
{
"id": 52,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/3208fe6564a293c21b711333fb3edb05bb5b406cff840573c9a8d839680a1579.png?imageMogr2/format/webp",
"pid": "600002484",
@@ -816,7 +763,6 @@
},
{
"id": 53,
- "videoIndex": 0,
"channel": "地方",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/6e060391fde0469801fc3d84dbf204b4f8d650d251f17d7595a6964c0bb99e81.png?imageMogr2/format/webp",
"pid": "600002506",
@@ -832,7 +778,6 @@
},
{
"id": 54,
- "videoIndex": 0,
"channel": "地方",
"logo": "",
"pid": "600152137",
@@ -847,7 +792,6 @@
},
{
"id": 55,
- "videoIndex": 0,
"channel": "地方",
"logo": "",
"pid": "600152138",
@@ -862,7 +806,6 @@
},
{
"id": 56,
- "videoIndex": 0,
"channel": "国际",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/a72dff758ca1c17cd0ecc8cedc11b893d208f409d5e6302faa0e9d298848abc3.png?imageMogr2/format/webp",
"pid": "600014550",
@@ -877,7 +820,6 @@
},
{
"id": 57,
- "videoIndex": 0,
"channel": "国际",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/a8d0046a47433d952bf6ed17062deb8bd2184ba9aec0f7781df6bf9487a3ffcf.png?imageMogr2/format/webp",
"pid": "600084704",
@@ -892,7 +834,6 @@
},
{
"id": 58,
- "videoIndex": 0,
"channel": "国际",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/bf0a820893cbaf20dd0333e27042e1ef9c8806e5b602b6a8c95af399db0bc77a.png?imageMogr2/format/webp",
"pid": "600084758",
@@ -907,7 +848,6 @@
},
{
"id": 59,
- "videoIndex": 0,
"channel": "国际",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202306/2e44e2aa3e7a1cedf07fd0ae59fe69e86a60a2632660a006e3e9e7397b2d107e.png?imageMogr2/format/webp",
"pid": "600084782",
@@ -922,7 +862,6 @@
},
{
"id": 60,
- "videoIndex": 0,
"channel": "国际",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202309/7c337e3dbe64402ec7e4678a619a4a6d95144e42f35161181ff78e143b7cf67a.png?imageMogr2/format/webp",
"pid": "600084744",
@@ -938,7 +877,6 @@
},
{
"id": 61,
- "videoIndex": 0,
"channel": "国际",
"logo": "https://resources.yangshipin.cn/assets/oms/image/202309/74d3ac436a7e374879578de1d87a941fbf566d39d5632b027c5097891ed32bd5.png?imageMogr2/format/webp",
"pid": "600084781",
diff --git a/build.gradle b/build.gradle
index 479de024..40928c7a 100644
--- a/build.gradle
+++ b/build.gradle
@@ -1,6 +1,6 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
- id 'com.android.application' version '8.2.2' apply false
- id 'com.android.library' version '8.2.2' apply false
+ id 'com.android.application' version '8.3.0' apply false
+ id 'com.android.library' version '8.3.0' apply false
id 'org.jetbrains.kotlin.android' version '1.9.22' apply false
}
\ No newline at end of file
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index 99e680a5..65a247e0 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -1,6 +1,6 @@
#Fri Dec 01 13:53:24 HKT 2023
distributionBase=GRADLE_USER_HOME
-distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-rc-1-bin.zip
distributionPath=wrapper/dists
zipStorePath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME