Magisk/scripts/magisk_uninstaller.sh

122 lines
3.8 KiB
Bash
Raw Normal View History

2017-06-03 18:03:36 +02:00
#!/system/bin/sh
##########################################################################################
#
# Magisk Uninstaller
# by topjohnwu
2017-07-24 20:02:19 +02:00
#
2017-06-03 18:03:36 +02:00
# This script can be placed in /cache/magisk_uninstaller.sh
# The Magisk main binary will pick up the script, and uninstall itself, following a reboot
# This script can also be used in flashable zip with the uninstaller_loader.sh
2017-07-24 20:02:19 +02:00
#
2017-07-09 18:17:34 +02:00
# This script will try to do restoration with the following:
# 1-1. Find and restore the original stock boot image dump (OTA proof)
# 1-2. If 1-1 fails, restore ramdisk from the internal backup
# (ramdisk fully restored, not OTA friendly)
# 1-3. If 1-2 fails, it will remove added files in ramdisk, however modified files
2017-07-24 20:02:19 +02:00
# are remained modified, because we have no backups. By doing so, Magisk will
2017-07-09 18:17:34 +02:00
# not be started at boot, but this isn't actually 100% cleaned up
# 2. Remove all Magisk related files
# (The list is LARGE, most likely due to bad decision in early versions
# the latest versions has much less bloat to cleanup)
2017-06-03 18:03:36 +02:00
#
##########################################################################################
2017-07-09 18:17:34 +02:00
[ -z $BOOTMODE ] && BOOTMODE=false
MAGISKBIN=/data/magisk
CHROMEDIR=$MAGISKBIN/chromeos
2017-02-05 20:22:37 +01:00
if [ ! -f $MAGISKBIN/magiskboot -o ! -f $MAGISKBIN/util_functions.sh ]; then
2017-09-06 10:13:23 +02:00
echo "! Cannot find $MAGISKBIN"
exit 1
fi
2017-09-15 21:48:58 +02:00
if $BOOTMODE; then
# Load utility functions
. $MAGISKBIN/util_functions.sh
boot_actions
mount_partitions
else
recovery_actions
fi
cd $MAGISKBIN
2017-02-05 20:22:37 +01:00
# Find the boot image
find_boot_image
2017-07-09 18:17:34 +02:00
[ -z $BOOTIMAGE ] && abort "! Unable to detect boot image"
2017-02-05 20:22:37 +01:00
2017-09-06 10:13:23 +02:00
ui_print "- Found Boot Image: $BOOTIMAGE"
2017-02-05 20:22:37 +01:00
2017-09-15 21:48:58 +02:00
migrate_boot_backup
2017-02-05 20:22:37 +01:00
2017-09-06 10:13:23 +02:00
ui_print "- Unpacking boot image"
2017-07-09 18:17:34 +02:00
./magiskboot --unpack "$BOOTIMAGE"
2017-07-18 09:07:39 +02:00
CHROMEOS=false
case $? in
1 )
2017-09-06 10:13:23 +02:00
abort "! Unable to unpack boot image"
2017-07-18 09:07:39 +02:00
;;
2 )
CHROMEOS=true
;;
3 )
2017-09-06 10:13:23 +02:00
ui_print "! Sony ELF32 format detected"
abort "! Please use BootBridge from @AdrianDC to flash Magisk"
2017-07-18 09:07:39 +02:00
;;
4 )
2017-09-06 10:13:23 +02:00
ui_print "! Sony ELF64 format detected"
abort "! Stock kernel cannot be patched, please use a custom kernel"
2017-07-18 09:07:39 +02:00
esac
2017-02-05 20:22:37 +01:00
2017-03-12 11:13:58 +01:00
# Detect boot image state
2017-09-15 21:48:58 +02:00
ui_print "- Checking ramdisk status"
2017-07-09 18:17:34 +02:00
./magiskboot --cpio-test ramdisk.cpio
2017-03-12 11:13:58 +01:00
case $? in
2017-07-09 18:17:34 +02:00
0 ) # Stock boot
2017-09-06 10:13:23 +02:00
ui_print "- Stock boot image detected!"
abort "! Magisk is not installed!"
2017-03-12 11:13:58 +01:00
;;
2017-07-09 18:17:34 +02:00
1 ) # Magisk patched
2017-09-06 10:13:23 +02:00
ui_print "- Magisk patched image detected!"
2017-03-12 11:13:58 +01:00
# Find SHA1 of stock boot image
2017-09-06 10:13:23 +02:00
[ -z $SHA1 ] && SHA1=`./magiskboot --cpio-stocksha1 ramdisk.cpio 2>/dev/null`
2017-07-09 18:17:34 +02:00
[ ! -z $SHA1 ] && STOCKDUMP=/data/stock_boot_${SHA1}.img
2017-03-12 11:13:58 +01:00
if [ -f ${STOCKDUMP}.gz ]; then
2017-09-06 10:13:23 +02:00
ui_print "- Boot image backup found!"
./magiskboot --decompress ${STOCKDUMP}.gz new-boot.img
2017-03-12 11:13:58 +01:00
else
2017-09-06 10:13:23 +02:00
ui_print "! Boot image backup unavailable"
ui_print "- Restoring ramdisk with internal backup"
2017-07-09 18:17:34 +02:00
./magiskboot --cpio-restore ramdisk.cpio
2017-09-06 10:13:23 +02:00
./magiskboot --repack $BOOTIMAGE new-boot.img
2017-03-12 11:13:58 +01:00
fi
;;
2017-06-03 18:03:36 +02:00
2 ) # Other patched
2017-09-06 10:13:23 +02:00
ui_print "! Boot image patched by other programs!"
abort "! Cannot uninstall"
2017-03-12 11:13:58 +01:00
;;
esac
# Sign chromeos boot
2017-09-06 10:13:23 +02:00
$CHROMEOS && sign_chromeos
2017-06-03 18:03:36 +02:00
2017-09-06 10:13:23 +02:00
ui_print "- Flashing stock/reverted image"
2017-07-09 18:17:34 +02:00
if [ -L "$BOOTIMAGE" ]; then
2017-09-06 10:13:23 +02:00
dd if=new-boot.img of="$BOOTIMAGE" bs=4096
2017-06-03 18:03:36 +02:00
else
2017-09-06 10:13:23 +02:00
cat new-boot.img /dev/zero | dd of="$BOOTIMAGE" bs=4096 >/dev/null 2>&1
2017-06-03 18:03:36 +02:00
fi
2017-09-06 10:13:23 +02:00
rm -f new-boot.img
cd /
2017-02-05 20:22:37 +01:00
2017-09-06 10:13:23 +02:00
ui_print "- Removing Magisk files"
2017-02-05 20:22:37 +01:00
rm -rf /cache/magisk.log /cache/last_magisk.log /cache/magiskhide.log /cache/.disable_magisk \
2017-09-06 10:13:23 +02:00
/cache/magisk /cache/magisk_merge /cache/magisk_mount /cache/unblock /cache/magisk_uninstaller.sh \
2017-06-07 21:20:49 +02:00
/data/Magisk.apk /data/magisk.apk /data/magisk.img /data/magisk_merge.img /data/magisk_debug.log \
2017-07-18 21:24:07 +02:00
/data/busybox /data/magisk /data/custom_ramdisk_patch.sh /data/property/*magisk* \
2017-09-15 21:48:58 +02:00
/data/app/com.topjohnwu.magisk* /data/user*/*/com.topjohnwu.magisk 2>/dev/null
2017-02-05 20:22:37 +01:00
2017-09-15 21:48:58 +02:00
$BOOTMODE && reboot || recovery_cleanup