Magisk/scripts/uninstaller.sh

180 lines
4.6 KiB
Bash
Raw Permalink Normal View History

2018-06-27 06:00:01 +08:00
#MAGISK
############################################
# Magisk Uninstaller (updater-script)
############################################
2017-06-04 00:03:36 +08:00
##############
2018-06-27 06:00:01 +08:00
# Preparation
##############
2018-06-27 06:00:01 +08:00
# Default permissions
umask 022
2017-07-10 00:17:34 +08:00
2018-06-27 06:00:01 +08:00
OUTFD=$2
APK="$3"
COMMONDIR=$INSTALLER/assets
CHROMEDIR=$INSTALLER/assets/chromeos
2017-02-06 03:22:37 +08:00
if [ ! -f $COMMONDIR/util_functions.sh ]; then
2018-06-27 06:00:01 +08:00
echo "! Unable to extract zip file!"
exit 1
fi
2018-06-27 06:00:01 +08:00
# Load utility functions
. $COMMONDIR/util_functions.sh
2018-06-27 06:00:01 +08:00
2018-08-28 22:03:12 -04:00
setup_flashable
2017-09-16 03:48:58 +08:00
############
# Detection
############
if echo $MAGISK_VER | grep -q '\.'; then
PRETTY_VER=$MAGISK_VER
else
PRETTY_VER="$MAGISK_VER($MAGISK_VER_CODE)"
fi
print_title "Magisk $PRETTY_VER Uninstaller"
2018-06-27 06:00:01 +08:00
is_mounted /data || mount /data || abort "! Unable to mount /data, please uninstall with Magisk Manager"
mount_partitions
check_data
$DATA_DE || abort "! Cannot access /data, please uninstall with Magisk Manager"
if ! $BOOTMODE; then
# Mounting stuffs in recovery (best effort)
mount_name metadata /metadata
mount_name "cache cac" /cache
mount_name persist /persist
fi
get_flags
find_boot_image
[ -z $BOOTIMAGE ] && abort "! Unable to detect target image"
ui_print "- Target image: $BOOTIMAGE"
2018-06-26 22:41:03 +08:00
# Detect version and architecture
2018-06-27 06:00:01 +08:00
api_level_arch_detect
ui_print "- Device platform: $ARCH"
BINDIR=$INSTALLER/lib/$ARCH32
[ ! -d "$BINDIR" ] && BINDIR=$INSTALLER/lib/armeabi-v7a
cd $BINDIR
for file in lib*.so; do mv "$file" "${file:3:${#file}-6}"; done
cd /
chmod -R 755 $CHROMEDIR $BINDIR
cp -af $CHROMEDIR/. $BINDIR/chromeos
2018-06-27 06:00:01 +08:00
############
2018-06-27 06:00:01 +08:00
# Uninstall
############
2018-06-27 06:00:01 +08:00
cd $BINDIR
2017-02-06 03:22:37 +08:00
2018-06-26 22:41:03 +08:00
CHROMEOS=false
2017-02-06 03:22:37 +08:00
2017-09-06 16:13:23 +08:00
ui_print "- Unpacking boot image"
# Dump image for MTD/NAND character device boot partitions
if [ -c $BOOTIMAGE ]; then
nanddump -f boot.img $BOOTIMAGE
BOOTNAND=$BOOTIMAGE
BOOTIMAGE=boot.img
fi
./magiskboot unpack "$BOOTIMAGE"
2017-12-12 03:04:55 +08:00
2017-07-18 15:07:39 +08:00
case $? in
1 )
abort "! Unsupported/Unknown image format"
2017-07-18 15:07:39 +08:00
;;
2018-08-09 18:13:07 +08:00
2 )
2017-12-12 03:04:55 +08:00
ui_print "- ChromeOS boot image detected"
2017-07-18 15:07:39 +08:00
CHROMEOS=true
;;
esac
2017-02-06 03:22:37 +08:00
# Restore the original boot partition path
[ "$BOOTNAND" ] && BOOTIMAGE=$BOOTNAND
2017-03-12 18:13:58 +08:00
# Detect boot image state
2017-09-16 03:48:58 +08:00
ui_print "- Checking ramdisk status"
if [ -e ramdisk.cpio ]; then
./magiskboot cpio ramdisk.cpio test
STATUS=$?
else
# Stock A only system-as-root
STATUS=0
fi
case $((STATUS & 3)) in
2017-07-10 00:17:34 +08:00
0 ) # Stock boot
ui_print "- Stock boot image detected"
2017-03-12 18:13:58 +08:00
;;
2018-08-09 18:13:07 +08:00
1 ) # Magisk patched
ui_print "- Magisk patched image detected"
2017-03-12 18:13:58 +08:00
# Find SHA1 of stock boot image
SHA1=$(./magiskboot cpio ramdisk.cpio sha1 2>/dev/null)
BACKUPDIR=/data/magisk_backup_$SHA1
if [ -d $BACKUPDIR ]; then
2018-06-27 06:00:01 +08:00
ui_print "- Restoring stock boot image"
flash_image $BACKUPDIR/boot.img.gz $BOOTIMAGE
for name in dtb dtbo dtbs; do
[ -f $BACKUPDIR/${name}.img.gz ] || continue
IMAGE=$(find_block $name$SLOT)
[ -z $IMAGE ] && continue
ui_print "- Restoring stock $name image"
flash_image $BACKUPDIR/${name}.img.gz $IMAGE
done
2018-06-27 06:00:01 +08:00
else
2017-09-06 16:13:23 +08:00
ui_print "! Boot image backup unavailable"
ui_print "- Restoring ramdisk with internal backup"
./magiskboot cpio ramdisk.cpio restore
if ! ./magiskboot cpio ramdisk.cpio "exists init"; then
# A only system-as-root
rm -f ramdisk.cpio
fi
./magiskboot repack $BOOTIMAGE
2017-09-27 15:26:21 +08:00
# Sign chromeos boot
$CHROMEOS && sign_chromeos
2018-08-10 18:59:14 +08:00
ui_print "- Flashing restored boot image"
flash_image new-boot.img $BOOTIMAGE || abort "! Insufficient partition size"
2017-03-12 18:13:58 +08:00
fi
;;
2 ) # Unsupported
ui_print "! Boot image patched by unsupported programs"
2017-09-06 16:13:23 +08:00
abort "! Cannot uninstall"
2017-03-12 18:13:58 +08:00
;;
esac
2017-09-06 16:13:23 +08:00
ui_print "- Removing Magisk files"
rm -rf \
/cache/*magisk* /cache/unblock /data/*magisk* /data/cache/*magisk* /data/property/*magisk* \
/data/Magisk.apk /data/busybox /data/custom_ramdisk_patch.sh /data/adb/*magisk* \
/data/adb/post-fs-data.d /data/adb/service.d /data/adb/modules* \
/data/unencrypted/magisk /metadata/magisk /persist/magisk /mnt/vendor/persist/magisk
2017-02-06 03:22:37 +08:00
ADDOND=/system/addon.d/99-magisk.sh
if [ -f $ADDOND ]; then
blockdev --setrw /dev/block/mapper/system$SLOT 2>/dev/null
mount -o rw,remount /system || mount -o rw,remount /
rm -f $ADDOND
2018-06-26 22:41:03 +08:00
fi
2018-06-27 06:00:01 +08:00
cd /
if $BOOTMODE; then
ui_print "********************************************"
ui_print " Magisk Manager will uninstall itself, and"
ui_print " the device will reboot after a few seconds"
ui_print "********************************************"
2018-06-27 06:00:01 +08:00
(sleep 8; /system/bin/reboot)&
else
ui_print "********************************************"
ui_print " Magisk Manager will not be uninstalled"
ui_print " Please uninstall it manually after reboot"
ui_print "********************************************"
2018-06-27 06:00:01 +08:00
recovery_cleanup
ui_print "- Done"
fi
rm -rf $TMPDIR
exit 0