Magisk/scripts/magisk_uninstaller.sh

131 lines
4.3 KiB
Bash
Raw Normal View History

2017-03-19 22:03:52 +01:00
[ -z $BOOTMODE ] && BOOTMODE=false
2017-02-05 20:22:37 +01:00
2017-03-12 11:13:58 +01:00
# This path should work in any cases
TMPDIR=/dev/tmp
2017-02-05 20:22:37 +01:00
2017-03-12 11:13:58 +01:00
BOOTTMP=$TMPDIR/boottmp
MAGISKBIN=/data/magisk
CHROMEDIR=$MAGISKBIN/chromeos
2017-02-05 20:22:37 +01:00
SYSTEMLIB=/system/lib
[ -d /system/lib64 ] && SYSTEMLIB=/system/lib64
2017-03-12 11:13:58 +01:00
# Default permissions
umask 022
2017-06-03 14:19:01 +02:00
# Call ui_print_wrap if exists, or else simply use echo
# Useful when wrapped in flashable zip
ui_print_wrap() {
type ui_print >/dev/null 2>&1 && ui_print "$1" || echo "$1"
2017-02-05 20:22:37 +01:00
}
grep_prop() {
REGEX="s/^$1=//p"
shift
FILES=$@
if [ -z "$FILES" ]; then
FILES='/system/build.prop'
fi
2017-03-12 11:13:58 +01:00
cat $FILES 2>/dev/null | sed -n "$REGEX" | head -n 1
2017-02-05 20:22:37 +01:00
}
find_boot_image() {
if [ -z "$BOOTIMAGE" ]; then
for PARTITION in kern-a KERN-A android_boot ANDROID_BOOT kernel KERNEL boot BOOT lnx LNX; do
BOOTIMAGE=`readlink /dev/block/by-name/$PARTITION || readlink /dev/block/platform/*/by-name/$PARTITION || readlink /dev/block/platform/*/*/by-name/$PARTITION`
if [ ! -z "$BOOTIMAGE" ]; then break; fi
done
fi
if [ -z "$BOOTIMAGE" ]; then
FSTAB="/etc/recovery.fstab"
[ ! -f "$FSTAB" ] && FSTAB="/etc/recovery.fstab.bak"
[ -f "$FSTAB" ] && BOOTIMAGE=`grep -E '\b/boot\b' "$FSTAB" | grep -oE '/dev/[a-zA-Z0-9_./-]*'`
fi
}
# Environments
2017-02-05 20:22:37 +01:00
# Set permissions
2017-03-12 11:13:58 +01:00
chmod -R 755 $CHROMEDIR/futility $MAGISKBIN 2>/dev/null
2017-02-05 20:22:37 +01:00
# Find the boot image
find_boot_image
if [ -z "$BOOTIMAGE" ]; then
2017-06-03 14:19:01 +02:00
ui_print_wrap "! Unable to detect boot image"
2017-02-05 20:22:37 +01:00
exit 1
fi
2017-06-03 14:19:01 +02:00
ui_print_wrap "- Found Boot Image: $BOOTIMAGE"
2017-02-05 20:22:37 +01:00
2017-03-12 11:13:58 +01:00
rm -rf $BOOTTMP 2>/dev/null
mkdir -p $BOOTTMP
cd $BOOTTMP
2017-02-05 20:22:37 +01:00
2017-06-03 14:19:01 +02:00
ui_print_wrap "- Unpacking boot image"
2017-03-12 11:13:58 +01:00
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --unpack $BOOTIMAGE
if [ $? -ne 0 ]; then
2017-06-03 14:19:01 +02:00
ui_print_wrap "! Unable to unpack boot image"
exit 1
fi
2017-02-05 20:22:37 +01:00
2017-03-12 11:13:58 +01:00
# Update our previous backup to new format if exists
if [ -f /data/stock_boot.img ]; then
SHA1=`LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --sha1 /data/stock_boot.img | tail -n 1`
STOCKDUMP=/data/stock_boot_${SHA1}.img
mv /data/stock_boot.img $STOCKDUMP
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --compress $STOCKDUMP
fi
2017-02-05 20:22:37 +01:00
2017-03-12 11:13:58 +01:00
# Detect boot image state
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --cpio-test ramdisk.cpio
case $? in
0 )
2017-06-03 14:19:01 +02:00
ui_print_wrap "! Magisk is not installed!"
ui_print_wrap "! Nothing to uninstall"
2017-03-12 11:13:58 +01:00
exit
;;
1 )
# Find SHA1 of stock boot image
if [ -z $SHA1 ]; then
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --cpio-extract ramdisk.cpio init.magisk.rc init.magisk.rc
SHA1=`grep_prop "# STOCKSHA1" init.magisk.rc`
[ ! -z $SHA1 ] && STOCKDUMP=/data/stock_boot_${SHA1}.img
rm -f init.magisk.rc
2017-02-05 20:22:37 +01:00
fi
2017-03-12 11:13:58 +01:00
if [ -f ${STOCKDUMP}.gz ]; then
2017-06-03 14:19:01 +02:00
ui_print_wrap "- Boot image backup found!"
2017-03-12 11:13:58 +01:00
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --decompress ${STOCKDUMP}.gz stock_boot.img
else
2017-06-03 14:19:01 +02:00
ui_print_wrap "! Boot image backup unavailable"
ui_print_wrap "- Restoring ramdisk with backup"
2017-03-12 11:13:58 +01:00
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --cpio-restore ramdisk.cpio
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --repack $BOOTIMAGE stock_boot.img
fi
;;
2 )
2017-06-03 14:19:01 +02:00
ui_print_wrap "- SuperSU patched image detected"
2017-03-12 11:13:58 +01:00
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --cpio-restore ramdisk.cpio
LD_LIBRARY_PATH=$SYSTEMLIB $MAGISKBIN/magiskboot --repack $BOOTIMAGE stock_boot.img
;;
esac
# Sign chromeos boot
if [ -f chromeos ]; then
echo > config
echo > bootloader
2017-03-12 12:22:15 +01:00
LD_LIBRARY_PATH=$SYSTEMLIB $CHROMEDIR/futility vbutil_kernel --pack stock_boot.img.signed --keyblock $CHROMEDIR/kernel.keyblock --signprivate $CHROMEDIR/kernel_data_key.vbprivk --version 1 --vmlinuz stock_boot.img --config config --arch arm --bootloader bootloader --flags 0x1
rm -f stock_boot.img
mv stock_boot.img.signed stock_boot.img
2017-02-05 20:22:37 +01:00
fi
2017-06-03 14:19:01 +02:00
ui_print_wrap "- Flashing stock/reverted image"
2017-02-05 20:22:37 +01:00
[ ! -L "$BOOTIMAGE" ] && dd if=/dev/zero of=$BOOTIMAGE bs=4096 2>/dev/null
2017-03-12 11:13:58 +01:00
dd if=stock_boot.img of=$BOOTIMAGE bs=4096
2017-02-05 20:22:37 +01:00
2017-06-03 14:19:01 +02:00
ui_print_wrap "- 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 \
/cache/magisk /cache/magisk_merge /cache/magisk_mount /cache/unblock /cache/magisk_uninstaller.sh \
/data/Magisk.apk /data/magisk.apk /data/magisk.img /data/magisk_merge.img \
/data/busybox /data/magisk /data/custom_ramdisk_patch.sh 2>/dev/null
2017-03-12 11:13:58 +01:00
$BOOTMODE && reboot