From 376e7977f00ddf4a2148fe98b6b33174ee1a86b7 Mon Sep 17 00:00:00 2001 From: topjohnwu Date: Thu, 15 Nov 2018 01:36:03 -0500 Subject: [PATCH] Deprecate path /sbin/.core, switch to /sbin/.magisk Symlink is preserved for backwards compatibility --- app/src/full/java/com/topjohnwu/magisk/Const.java | 2 +- .../com/topjohnwu/magisk/database/MagiskDB.java | 2 +- .../java/com/topjohnwu/magisk/utils/RootUtils.java | 5 ++++- app/src/full/res/raw/utils.sh | 8 ++++---- native/jni/daemon/bootstages.cpp | 3 +++ native/jni/include/magisk.h | 2 +- scripts/util_functions.sh | 14 +++++++------- 7 files changed, 21 insertions(+), 15 deletions(-) diff --git a/app/src/full/java/com/topjohnwu/magisk/Const.java b/app/src/full/java/com/topjohnwu/magisk/Const.java index 3656bc1df..178189ce7 100644 --- a/app/src/full/java/com/topjohnwu/magisk/Const.java +++ b/app/src/full/java/com/topjohnwu/magisk/Const.java @@ -27,7 +27,7 @@ public class Const { MAGISK_PATH = MAGISK_DISABLE_FILE = MAGISK_HOST_FILE = new File("xxx"); } - public static final String BUSYBOX_PATH = "/sbin/.core/busybox"; + public static final String BUSYBOX_PATH = "/sbin/.magisk/busybox"; public static final String TMP_FOLDER_PATH = "/dev/tmp"; public static final String MAGISK_LOG = "/cache/magisk.log"; public static final String MANAGER_CONFIGS = ".tmp.magisk.config"; diff --git a/app/src/full/java/com/topjohnwu/magisk/database/MagiskDB.java b/app/src/full/java/com/topjohnwu/magisk/database/MagiskDB.java index da67deaeb..e443d31c9 100644 --- a/app/src/full/java/com/topjohnwu/magisk/database/MagiskDB.java +++ b/app/src/full/java/com/topjohnwu/magisk/database/MagiskDB.java @@ -20,7 +20,7 @@ public class MagiskDB { static final String SETTINGS_TABLE = "settings"; static final String STRINGS_TABLE = "strings"; static final File LEGACY_MANAGER_DB = - new File(Utils.fmt("/sbin/.core/db-%d/magisk.db", Const.USER_ID)); + new File(Utils.fmt("/sbin/.magisk/db-%d/magisk.db", Const.USER_ID)); @NonNull public static MagiskDB getInstance() { diff --git a/app/src/full/java/com/topjohnwu/magisk/utils/RootUtils.java b/app/src/full/java/com/topjohnwu/magisk/utils/RootUtils.java index 2c84a45ef..750cb8933 100644 --- a/app/src/full/java/com/topjohnwu/magisk/utils/RootUtils.java +++ b/app/src/full/java/com/topjohnwu/magisk/utils/RootUtils.java @@ -29,12 +29,15 @@ public class RootUtils extends Shell.Initializer { public boolean onInit(Context context, @NonNull Shell shell) { Shell.Job job = shell.newJob(); if (shell.isRoot()) { + if (!new SuFile("/sbin/.magisk").exists()) + job.add("ln -s /sbin/.core /sbin/.magisk"); + InputStream magiskUtils = context.getResources().openRawResource(R.raw.util_functions); InputStream managerUtils = context.getResources().openRawResource(R.raw.utils); job.add(magiskUtils).add(managerUtils); Const.MAGISK_DISABLE_FILE = new SuFile("/cache/.disable_magisk"); - SuFile file = new SuFile("/sbin/.core/img"); + SuFile file = new SuFile("/sbin/.magisk/img"); if (file.exists()) { Const.MAGISK_PATH = file; } else if ((file = new SuFile("/dev/magisk/img")).exists()) { diff --git a/app/src/full/res/raw/utils.sh b/app/src/full/res/raw/utils.sh index 6a550b65c..a5febef9a 100644 --- a/app/src/full/res/raw/utils.sh +++ b/app/src/full/res/raw/utils.sh @@ -6,7 +6,7 @@ db_sepatch() { db_clean() { local USERID=$1 - local DIR="/sbin/.core/db-${USERID}" + local DIR="/sbin/.magisk/db-${USERID}" umount -l /data/user*/*/*/databases/su.db $DIR $DIR/* rm -rf $DIR [ "$USERID" = "*" ] && rm -fv /data/adb/magisk.db* @@ -26,7 +26,7 @@ db_restore() { db_setup() { local USER=$1 local USERID=$(($USER / 100000)) - local DIR=/sbin/.core/db-${USERID} + local DIR=/sbin/.magisk/db-${USERID} mkdir -p $DIR touch $DIR/magisk.db mount -o bind /data/adb/magisk.db $DIR/magisk.db @@ -49,8 +49,8 @@ fix_env() { sh update-binary extract rm -f update-binary magisk.apk cd / - rm -rf /sbin/.core/busybox/* - /sbin/.core/mirror/bin/busybox --install -s /sbin/.core/busybox + rm -rf /sbin/.magisk/busybox/* + /sbin/.magisk/mirror/bin/busybox --install -s /sbin/.magisk/busybox } direct_install() { diff --git a/native/jni/daemon/bootstages.cpp b/native/jni/daemon/bootstages.cpp index 6ecfd6644..952effb3e 100644 --- a/native/jni/daemon/bootstages.cpp +++ b/native/jni/daemon/bootstages.cpp @@ -417,6 +417,9 @@ static bool magisk_env() { unlink("/data/magisk.img"); unlink("/data/magisk_debug.log"); + // Symlink for legacy path users + symlink(MAGISKTMP, "/sbin/.core"); + // Create directories in tmpfs overlay xmkdirs(MIRRDIR "/system", 0755); xmkdir(MIRRDIR "/bin", 0755); diff --git a/native/jni/include/magisk.h b/native/jni/include/magisk.h index 3c3a7d0d1..6da21e3e5 100644 --- a/native/jni/include/magisk.h +++ b/native/jni/include/magisk.h @@ -12,7 +12,7 @@ #define LOGFILE "/cache/magisk.log" #define UNBLOCKFILE "/dev/.magisk.unblock" #define DISABLEFILE "/cache/.disable_magisk" -#define MAGISKTMP "/sbin/.core" +#define MAGISKTMP "/sbin/.magisk" #define BLOCKDIR MAGISKTMP "/block" #define MIRRDIR MAGISKTMP "/mirror" #define BBPATH MAGISKTMP "/busybox" diff --git a/scripts/util_functions.sh b/scripts/util_functions.sh index d78ae391a..f9409bf10 100644 --- a/scripts/util_functions.sh +++ b/scripts/util_functions.sh @@ -15,10 +15,10 @@ $BOOTMODE || ps | grep zygote | grep -qv grep && BOOTMODE=true $BOOTMODE || ps -A | grep zygote | grep -qv grep && BOOTMODE=true # Presets +MAGISKTMP=/sbin/.magisk [ -z $NVBASE ] && NVBASE=/data/adb [ -z $MAGISKBIN ] && MAGISKBIN=$NVBASE/magisk [ -z $IMG ] && IMG=$NVBASE/magisk.img -[ -z $MOUNTPATH ] && MOUNTPATH=/sbin/.core/img # Bootsigner related stuff BOOTSIGNERCLASS=a.a @@ -306,9 +306,9 @@ check_data() { } setup_bb() { - if [ -x /sbin/.core/busybox/busybox ]; then + if [ -x $MAGISKTMP/busybox/busybox ]; then # Make sure this path is in the front - echo $PATH | grep -q '^/sbin/.core/busybox' || export PATH=/sbin/.core/busybox:$PATH + echo $PATH | grep -q "^$MAGISKTMP/busybox" || export PATH=$MAGISKTMP/busybox:$PATH elif [ -x $TMPDIR/bin/busybox ]; then # Make sure this path is in the front echo $PATH | grep -q "^$TMPDIR/bin" || export PATH=$TMPDIR/bin:$PATH @@ -322,11 +322,11 @@ setup_bb() { } boot_actions() { - if [ ! -d /sbin/.core/mirror/bin ]; then - mkdir -p /sbin/.core/mirror/bin - mount -o bind $MAGISKBIN /sbin/.core/mirror/bin + if [ ! -d $MAGISKTMP/mirror/bin ]; then + mkdir -p $MAGISKTMP/mirror/bin + mount -o bind $MAGISKBIN $MAGISKTMP/mirror/bin fi - MAGISKBIN=/sbin/.core/mirror/bin + MAGISKBIN=$MAGISKTMP/mirror/bin setup_bb }