Magisk/scripts/addon.d.sh

99 lines
1.8 KiB
Bash
Raw Normal View History

2017-06-18 18:15:44 +02:00
#!/sbin/sh
##########################################################################################
2017-07-30 21:03:52 +02:00
#
2017-06-18 18:15:44 +02:00
# Magisk Survival Script for ROMs with addon.d support
# by topjohnwu
2017-07-30 21:03:52 +02:00
#
2017-06-18 18:15:44 +02:00
# Inspired by 99-flashafterupdate.sh of osm0sis @ xda-developers
2017-07-30 21:03:52 +02:00
#
2017-06-18 18:15:44 +02:00
##########################################################################################
. /tmp/backuptool.functions
main() {
# Magisk binaries
MAGISKBIN=/data/magisk
2017-09-26 14:21:43 +02:00
# This script always runs in recovery
2017-06-18 18:15:44 +02:00
BOOTMODE=false
2017-09-26 14:21:43 +02:00
mount /data 2>/dev/null
2017-07-02 15:36:09 +02:00
if [ ! -d $MAGISKBIN ]; then
echo "! Cannot find Magisk binaries!"
exit 1
fi
2017-06-18 18:15:44 +02:00
# Wait for post addon.d processes to finish
sleep 5
2017-07-09 18:17:34 +02:00
# Load utility functions
2017-06-18 18:15:44 +02:00
. $MAGISKBIN/util_functions.sh
ui_print "************************"
2017-07-30 21:03:52 +02:00
ui_print "* Magisk v$MAGISK_VER addon.d"
2017-06-18 18:15:44 +02:00
ui_print "************************"
2017-09-26 14:21:43 +02:00
mount_partitions
2017-07-02 15:36:09 +02:00
2017-09-26 14:21:43 +02:00
api_level_arch_detect
2017-06-24 16:38:20 +02:00
recovery_actions
2017-06-18 18:15:44 +02:00
2017-09-26 14:21:43 +02:00
remove_system_su
2017-06-18 18:15:44 +02:00
find_boot_image
[ -z $BOOTIMAGE ] && abort "! Unable to detect boot image"
2017-11-10 18:33:50 +01:00
ui_print "- Found boot image: $BOOTIMAGE"
2017-06-18 18:15:44 +02:00
SOURCEDMODE=true
cd $MAGISKBIN
# Source the boot patcher
2017-06-24 16:38:20 +02:00
. $MAGISKBIN/boot_patch.sh "$BOOTIMAGE"
2017-06-18 18:15:44 +02:00
2017-11-10 18:33:50 +01:00
flash_boot_image new-boot.img "$BOOTIMAGE"
rm -f new-boot.img
2017-09-26 14:21:43 +02:00
if [ -f stock_boot* ]; then
rm -f /data/stock_boot* 2>/dev/null
2017-11-10 18:33:50 +01:00
is_mounted /data && mv stock_boot* /data
2017-06-18 18:15:44 +02:00
fi
2017-09-26 14:21:43 +02:00
2017-11-10 18:33:50 +01:00
patch_dtbo_image
if [ -f stock_dtbo* ]; then
rm -f /data/stock_dtbo* 2>/dev/null
is_mounted /data && mv stock_dtbo* /data
fi
2017-06-18 18:15:44 +02:00
cd /
2017-07-02 15:36:09 +02:00
recovery_cleanup
2017-06-18 18:15:44 +02:00
ui_print "- Done"
exit 0
}
case "$1" in
backup)
# Stub
;;
restore)
# Stub
;;
pre-backup)
# Stub
;;
post-backup)
# Stub
;;
pre-restore)
# Stub
;;
post-restore)
# Get the FD for ui_print
OUTFD=`ps | grep -v grep | grep -oE "update(.*)" | cut -d" " -f3`
2017-07-30 21:03:52 +02:00
# Run the main function in a parallel subshell
2017-06-18 18:15:44 +02:00
(main) &
;;
esac