ensureEnv even if getRemote fails

Co-authored-by: vvb2060 <vvb2060@gmail.com>
This commit is contained in:
LoveSy 2021-12-02 19:18:09 +08:00 committed by John Wu
parent 5c42830328
commit 41b701846f

View File

@ -45,7 +45,8 @@ class HomeViewModel(
var isNoticeVisible = Config.safetyNotice
set(value) = set(value, field, { field = it }, BR.noticeVisible)
val stateMagisk = when {
val stateMagisk
get() = when {
!Info.env.isActive -> MagiskState.NOT_INSTALLED
Info.env.magiskVersionCode < BuildConfig.VERSION_CODE -> MagiskState.OBSOLETE
else -> MagiskState.UP_TO_DATE
@ -55,7 +56,8 @@ class HomeViewModel(
var stateManager = MagiskState.LOADING
set(value) = set(value, field, { field = it }, BR.stateManager)
val magiskInstalledVersion get() = Info.env.run {
val magiskInstalledVersion
get() = Info.env.run {
if (isActive)
"$magiskVersionString ($magiskVersionCode)".asText()
else
@ -66,9 +68,9 @@ class HomeViewModel(
var managerRemoteVersion = R.string.loading.asText()
set(value) = set(value, field, { field = it }, BR.managerRemoteVersion)
val managerInstalledVersion = Info.stub?.let {
"${BuildConfig.VERSION_NAME} (${BuildConfig.VERSION_CODE}) (${it.version})"
} ?: "${BuildConfig.VERSION_NAME} (${BuildConfig.VERSION_CODE})"
val managerInstalledVersion
get() = "${BuildConfig.VERSION_NAME} (${BuildConfig.VERSION_CODE})" +
Info.stub?.let { " (${it.version})" }.orEmpty()
@get:Bindable
var stateManagerProgress = 0
@ -92,14 +94,11 @@ class HomeViewModel(
managerRemoteVersion =
"${magisk.version} (${magisk.versionCode}) (${stub.versionCode})".asText()
launch {
ensureEnv()
}
} ?: run {
state = State.LOADING_FAILED
managerRemoteVersion = R.string.not_available.asText()
}
ensureEnv()
}
val showTest = false
@ -137,14 +136,9 @@ class HomeViewModel(
}
private suspend fun ensureEnv() {
val invalidStates = listOf(
MagiskState.NOT_INSTALLED,
MagiskState.LOADING
)
if (invalidStates.any { it == stateMagisk } || shownDialog) return
val result = Shell.su("env_check ${Info.env.magiskVersionString} ${Info.env.magiskVersionCode}").await()
if (!result.isSuccess) {
if (MagiskState.NOT_INSTALLED == stateMagisk || shownDialog) return
val cmd = "env_check ${Info.env.magiskVersionString} ${Info.env.magiskVersionCode}"
if (!Shell.su(cmd).await().isSuccess) {
shownDialog = true
EnvFixDialog().publish()
}