manager: improved module mount system & fixed bug for module installation file name error

This commit is contained in:
Rifat Azad
2025-01-08 11:13:29 +06:00
parent 159d9d2594
commit 6bbe40dfda
8 changed files with 42 additions and 45 deletions

View File

@@ -354,6 +354,10 @@ private fun InfoCard() {
mutableStateOf(prefs.getBoolean("use_overlay_fs", false)) mutableStateOf(prefs.getBoolean("use_overlay_fs", false))
} }
LaunchedEffect(Unit) {
useOverlayFs = prefs.getBoolean("use_overlay_fs", false)
}
ElevatedCard { ElevatedCard {
Column( Column(
modifier = Modifier modifier = Modifier
@@ -429,10 +433,8 @@ private fun InfoCard() {
InfoCardItem( InfoCardItem(
label = stringResource(R.string.home_module_mount), label = stringResource(R.string.home_module_mount),
content = if (useOverlayFs) { content = if (useOverlayFs) {
// Show different content if OverlayFS is enabled
stringResource(R.string.home_overlayfs_mount) stringResource(R.string.home_overlayfs_mount)
} else { } else {
// Default content when OverlayFS is not enabled
stringResource(R.string.home_magic_mount) stringResource(R.string.home_magic_mount)
}, },
icon = Icons.Filled.SettingsSuggest, icon = Icons.Filled.SettingsSuggest,

View File

@@ -96,6 +96,7 @@ import com.rifsxd.ksunext.R
import com.rifsxd.ksunext.ui.component.ConfirmResult import com.rifsxd.ksunext.ui.component.ConfirmResult
import com.rifsxd.ksunext.ui.component.rememberConfirmDialog import com.rifsxd.ksunext.ui.component.rememberConfirmDialog
import com.rifsxd.ksunext.ui.component.rememberLoadingDialog import com.rifsxd.ksunext.ui.component.rememberLoadingDialog
import com.rifsxd.ksunext.ui.util.*
import com.rifsxd.ksunext.ui.util.DownloadListener import com.rifsxd.ksunext.ui.util.DownloadListener
import com.rifsxd.ksunext.ui.util.LocalSnackbarHost import com.rifsxd.ksunext.ui.util.LocalSnackbarHost
import com.rifsxd.ksunext.ui.util.download import com.rifsxd.ksunext.ui.util.download
@@ -240,8 +241,7 @@ fun ModuleScreen(navigator: DestinationsNavigator) {
) { innerPadding -> ) { innerPadding ->
// confirmation dialog // confirmation dialog
if (showConfirmDialog && zipUri != null) { if (showConfirmDialog && zipUri != null) {
// extract the module name from the zipUri val moduleName = getFileName(context, zipUri!!)
val moduleName = zipUri?.lastPathSegment?.substringAfterLast('/') ?: "Unknown Module"
AlertDialog( AlertDialog(
onDismissRequest = { showConfirmDialog = false }, onDismissRequest = { showConfirmDialog = false },
@@ -251,7 +251,6 @@ fun ModuleScreen(navigator: DestinationsNavigator) {
navigator.navigate(FlashScreenDestination(FlashIt.FlashModule(zipUri!!))) navigator.navigate(FlashScreenDestination(FlashIt.FlashModule(zipUri!!)))
viewModel.markNeedRefresh() viewModel.markNeedRefresh()
}) { }) {
Text(stringResource(R.string.confirm)) Text(stringResource(R.string.confirm))
} }
@@ -261,15 +260,16 @@ fun ModuleScreen(navigator: DestinationsNavigator) {
Text(stringResource(android.R.string.cancel)) Text(stringResource(android.R.string.cancel))
} }
}, },
title = { Text(stringResource(R.string.confirm_module_installation)) }, title = { Text(stringResource(R.string.module)) },
text = { text = {
Text( Text(
stringResource(R.string.module_install_prompt_with_name, moduleName) stringResource(R.string.module_install_prompt_with_name, moduleName)
) )
} }
) )
} }
when { when {
hasMagisk -> { hasMagisk -> {
Box( Box(

View File

@@ -70,6 +70,7 @@ import kotlinx.coroutines.launch
import kotlinx.coroutines.withContext import kotlinx.coroutines.withContext
import com.rifsxd.ksunext.BuildConfig import com.rifsxd.ksunext.BuildConfig
import com.rifsxd.ksunext.Natives import com.rifsxd.ksunext.Natives
import com.rifsxd.ksunext.ksuApp
import com.rifsxd.ksunext.R import com.rifsxd.ksunext.R
import com.rifsxd.ksunext.ui.component.AboutDialog import com.rifsxd.ksunext.ui.component.AboutDialog
import com.rifsxd.ksunext.ui.component.ConfirmResult import com.rifsxd.ksunext.ui.component.ConfirmResult
@@ -168,7 +169,9 @@ fun SettingScreen(navigator: DestinationsNavigator) {
) )
} }
var showRestartDialog by remember { mutableStateOf(false) } val isManager = Natives.becomeManager(ksuApp.packageName)
var showRebootDialog by remember { mutableStateOf(false) }
SwitchItem( SwitchItem(
icon = Icons.Filled.Build, icon = Icons.Filled.Build,
@@ -178,24 +181,25 @@ fun SettingScreen(navigator: DestinationsNavigator) {
) { ) {
prefs.edit().putBoolean("use_overlay_fs", it).apply() prefs.edit().putBoolean("use_overlay_fs", it).apply()
useOverlayFs = it useOverlayFs = it
showRestartDialog = true if (isManager) install()
showRebootDialog = true
} }
if (showRestartDialog) { if (showRebootDialog) {
AlertDialog( AlertDialog(
onDismissRequest = { showRestartDialog = false }, onDismissRequest = { showRebootDialog = false },
title = { Text(stringResource(R.string.restart_required)) }, title = { Text(stringResource(R.string.reboot_required)) },
text = { Text(stringResource(R.string.restart_message)) }, text = { Text(stringResource(R.string.reboot_message)) },
confirmButton = { confirmButton = {
TextButton(onClick = { TextButton(onClick = {
showRestartDialog = false showRebootDialog = false
restartKsuNext(context) reboot()
}) { }) {
Text(stringResource(R.string.restart_now)) Text(stringResource(R.string.reboot))
} }
}, },
dismissButton = { dismissButton = {
TextButton(onClick = { showRestartDialog = false }) { TextButton(onClick = { showRebootDialog = false }) {
Text(stringResource(R.string.later)) Text(stringResource(R.string.later))
} }
} }

View File

@@ -427,6 +427,21 @@ fun getAppProfileTemplate(id: String): String {
.to(ArrayList(), null).exec().out.joinToString("\n") .to(ArrayList(), null).exec().out.joinToString("\n")
} }
fun getFileName(context: Context, uri: Uri): String {
var name = "Unknown Module"
if (uri.scheme == ContentResolver.SCHEME_CONTENT) {
val cursor: Cursor? = context.contentResolver.query(uri, null, null, null, null)
cursor?.use {
if (it.moveToFirst()) {
name = it.getString(it.getColumnIndexOrThrow(OpenableColumns.DISPLAY_NAME))
}
}
} else if (uri.scheme == "file") {
name = uri.lastPathSegment ?: "Unknown Module"
}
return name
}
fun setAppProfileTemplate(id: String, template: String): Boolean { fun setAppProfileTemplate(id: String, template: String): Boolean {
val shell = getRootShell() val shell = getRootShell()
val escapedTemplate = template.replace("\"", "\\\"") val escapedTemplate = template.replace("\"", "\\\"")
@@ -460,11 +475,4 @@ fun launchApp(packageName: String) {
fun restartApp(packageName: String) { fun restartApp(packageName: String) {
forceStopApp(packageName) forceStopApp(packageName)
launchApp(packageName) launchApp(packageName)
} }
fun restartKsuNext(context: Context) {
val intent = context.packageManager.getLaunchIntentForPackage(context.packageName)
intent?.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP or Intent.FLAG_ACTIVITY_NEW_TASK)
context.startActivity(intent)
Runtime.getRuntime().exit(0)
}

View File

@@ -31,7 +31,6 @@
<string name="module_failed_to_disable">Gagal menonaktifkan modul: %s</string> <string name="module_failed_to_disable">Gagal menonaktifkan modul: %s</string>
<string name="module_empty">Tidak ada modul</string> <string name="module_empty">Tidak ada modul</string>
<string name="module">Modul</string> <string name="module">Modul</string>
<string name="confirm_module_installation">Yakin instal</string>
<string name="module_install_prompt_with_name">Anda ingin melanjutkan pemasangan modul %1$s?</string> <string name="module_install_prompt_with_name">Anda ingin melanjutkan pemasangan modul %1$s?</string>
<string name="module_sort_a_to_z">Menyortir (A - Z)</string> <string name="module_sort_a_to_z">Menyortir (A - Z)</string>
<string name="module_sort_z_to_a">Menyortir (Z - A)</string> <string name="module_sort_z_to_a">Menyortir (Z - A)</string>
@@ -68,10 +67,6 @@
<string name="home_overlayfs_mount">OverlayFS</string> <string name="home_overlayfs_mount">OverlayFS</string>
<string name="use_overlay_fs">Use OverlayFS</string> <string name="use_overlay_fs">Use OverlayFS</string>
<string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string> <string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string>
<string name="restart_required">Restart Required</string>
<string name="restart_message">Changes will take effect after restarting the app. Would you like to restart now?</string>
<string name="restart_now">Restart Now</string>
<string name="later">Later</string>
<string name="home_next_kernelsu">🔥 Pembangunan Next</string> <string name="home_next_kernelsu">🔥 Pembangunan Next</string>
<string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string> <string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string>
<string name="home_next_kernelsu_body">Next cabang eksperimental. Lihat di GitHub!</string> <string name="home_next_kernelsu_body">Next cabang eksperimental. Lihat di GitHub!</string>

View File

@@ -31,7 +31,6 @@
<string name="module_failed_to_disable">Falha ao desativar o módulo %s</string> <string name="module_failed_to_disable">Falha ao desativar o módulo %s</string>
<string name="module_empty">Nenhum módulo instalado</string> <string name="module_empty">Nenhum módulo instalado</string>
<string name="module">Módulo</string> <string name="module">Módulo</string>
<string name="confirm_module_installation">Confirmação de instalação</string>
<string name="module_install_prompt_with_name">Deseja continuar instalando o módulo %1$s?</string> <string name="module_install_prompt_with_name">Deseja continuar instalando o módulo %1$s?</string>
<string name="module_sort_a_to_z">Ordenar (A-Z)</string> <string name="module_sort_a_to_z">Ordenar (A-Z)</string>
<string name="module_sort_z_to_a">Ordenar (Z-A)</string> <string name="module_sort_z_to_a">Ordenar (Z-A)</string>
@@ -68,10 +67,6 @@
<string name="home_overlayfs_mount">OverlayFS</string> <string name="home_overlayfs_mount">OverlayFS</string>
<string name="use_overlay_fs">Use OverlayFS</string> <string name="use_overlay_fs">Use OverlayFS</string>
<string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string> <string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string>
<string name="restart_required">Restart Required</string>
<string name="restart_message">Changes will take effect after restarting the app. Would you like to restart now?</string>
<string name="restart_now">Restart Now</string>
<string name="later">Later</string>
<string name="home_next_kernelsu">🔥 Compilação next</string> <string name="home_next_kernelsu">🔥 Compilação next</string>
<string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string> <string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string>
<string name="home_next_kernelsu_body">Branch next experimental. Confira no GitHub!</string> <string name="home_next_kernelsu_body">Branch next experimental. Confira no GitHub!</string>

View File

@@ -31,7 +31,6 @@
<string name="module_failed_to_disable">无法禁用模块: %s</string> <string name="module_failed_to_disable">无法禁用模块: %s</string>
<string name="module_empty">没有安装模块</string> <string name="module_empty">没有安装模块</string>
<string name="module">模块</string> <string name="module">模块</string>
<string name="confirm_module_installation">确认安装</string>
<string name="module_install_prompt_with_name">是否要继续安装模块 %1$s </string> <string name="module_install_prompt_with_name">是否要继续安装模块 %1$s </string>
<string name="module_sort_a_to_z">种类 (A - Z)</string> <string name="module_sort_a_to_z">种类 (A - Z)</string>
<string name="module_sort_z_to_a">种类 (Z - A)</string> <string name="module_sort_z_to_a">种类 (Z - A)</string>
@@ -67,10 +66,6 @@
<string name="home_overlayfs_mount">OverlayFS</string> <string name="home_overlayfs_mount">OverlayFS</string>
<string name="use_overlay_fs">Use OverlayFS</string> <string name="use_overlay_fs">Use OverlayFS</string>
<string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string> <string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string>
<string name="restart_required">Restart Required</string>
<string name="restart_message">Changes will take effect after restarting the app. Would you like to restart now?</string>
<string name="restart_now">Restart Now</string>
<string name="later">Later</string>
<string name="module_magisk_conflict">因与 Magisk 有冲突,所有模块不可用!</string> <string name="module_magisk_conflict">因与 Magisk 有冲突,所有模块不可用!</string>
<string name="home_next_kernelsu">🔥 Next 构建</string> <string name="home_next_kernelsu">🔥 Next 构建</string>
<string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string> <string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string>

View File

@@ -31,7 +31,6 @@
<string name="module_failed_to_disable">Failed to disable module: %s</string> <string name="module_failed_to_disable">Failed to disable module: %s</string>
<string name="module_empty">No module installed</string> <string name="module_empty">No module installed</string>
<string name="module">Module</string> <string name="module">Module</string>
<string name="confirm_module_installation">Install confirmation</string>
<string name="module_install_prompt_with_name">Do you want to continue installing module %1$s?</string> <string name="module_install_prompt_with_name">Do you want to continue installing module %1$s?</string>
<string name="module_sort_a_to_z">Sort (A-Z)</string> <string name="module_sort_a_to_z">Sort (A-Z)</string>
<string name="module_sort_z_to_a">Sort (Z-A)</string> <string name="module_sort_z_to_a">Sort (Z-A)</string>
@@ -68,9 +67,8 @@
<string name="home_overlayfs_mount">OverlayFS</string> <string name="home_overlayfs_mount">OverlayFS</string>
<string name="use_overlay_fs">Use OverlayFS</string> <string name="use_overlay_fs">Use OverlayFS</string>
<string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string> <string name="use_overlay_fs_summary">Toggle between using OverlayFS or Magic for KernelSU Next\'s mount system.</string>
<string name="restart_required">Restart Required</string> <string name="reboot_required">Reboot Required</string>
<string name="restart_message">Changes will take effect after restarting the app. Would you like to restart now?</string> <string name="reboot_message">Changes will take effect after rebooting the system. Would you like to reboot now?</string>
<string name="restart_now">Restart Now</string>
<string name="later">Later</string> <string name="later">Later</string>
<string name="home_next_kernelsu">🔥 Next build</string> <string name="home_next_kernelsu">🔥 Next build</string>
<string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string> <string name="home_next_kernelsu_repo">https://github.com/rifsxd/KernelSU-Next</string>