2018-03-20 17:52:53 +00:00
|
|
|
#!/sbin/sh
|
|
|
|
##########################################################################################
|
|
|
|
#
|
2020-08-13 06:50:52 +00:00
|
|
|
# NanoDroid Patcher (Haystack Frontend)
|
2018-03-20 17:52:53 +00:00
|
|
|
# by Nanolx
|
|
|
|
#
|
|
|
|
##########################################################################################
|
|
|
|
|
2020-04-18 08:28:32 +00:00
|
|
|
VERSION=22.6.90.99999999
|
2019-06-09 20:12:18 +00:00
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
##########################################################################################
|
|
|
|
# Generic Functions
|
|
|
|
##########################################################################################
|
|
|
|
|
2019-06-09 20:12:18 +00:00
|
|
|
show_banner () {
|
|
|
|
ui_print " "
|
|
|
|
ui_print "********************************"
|
|
|
|
ui_print " NanoDroid "
|
|
|
|
ui_print " Framework Patcher "
|
|
|
|
ui_print " Powered by DexPatcher "
|
|
|
|
ui_print " ${VERSION} "
|
|
|
|
ui_print "********************************"
|
|
|
|
ui_print " "
|
|
|
|
}
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
setup_environment () {
|
|
|
|
TMPDIR=/dev/tmp/install
|
2018-09-08 17:16:45 +00:00
|
|
|
|
2018-09-08 19:43:28 +00:00
|
|
|
export ANDROID_DATA=${TMPDIR}
|
2018-08-29 15:01:33 +00:00
|
|
|
export PATCHER_ADDOND_DATA=/data/adb/nanodroid_patcher
|
2018-09-08 17:16:45 +00:00
|
|
|
|
2018-12-22 17:46:34 +00:00
|
|
|
if [ -f /data/adb/magisk/util_functions.sh ]; then
|
|
|
|
NVBASE=/data/adb
|
|
|
|
elif [ -f /data/magisk/util_functions.sh ]; then
|
|
|
|
NVBASE=/data
|
|
|
|
fi
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
ui_print() {
|
2019-06-09 20:12:18 +00:00
|
|
|
${BOOTMODE} && echo "${1}" || \
|
|
|
|
echo -e "ui_print ${1}\nui_print" >> /proc/self/fd/${OUTFD}
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
is_mounted () {
|
|
|
|
if [ ! -z "$2" ]; then
|
|
|
|
cat /proc/mounts | grep $1 | grep $2, >/dev/null
|
|
|
|
else
|
|
|
|
cat /proc/mounts | grep $1 >/dev/null
|
|
|
|
fi
|
|
|
|
return $?
|
|
|
|
}
|
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
# taken from Magisk, with modifications for NanoDroid
|
|
|
|
mount_apex_loop () {
|
|
|
|
local number=0
|
|
|
|
local minorx=1
|
|
|
|
local loop
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
[ -e /dev/block/loop1 ] && minorx=$(stat -Lc '%T' /dev/block/loop1)
|
|
|
|
|
|
|
|
apex_mount="${1}"
|
|
|
|
mkdir -p "${apex_mount}"
|
|
|
|
|
|
|
|
while [ ${number} -lt 64 ]; do
|
|
|
|
loop=/dev/block/loop${number}
|
|
|
|
[ -e ${loop} ] || mknod ${loop} b 7 $((number * minorx))
|
|
|
|
|
|
|
|
echo " *** mount_apex_loop [loop] ${loop}"
|
|
|
|
echo " *** mount_apex_loop [apex_mount] ${apex_mount}"
|
|
|
|
|
|
|
|
if losetup "${loop}" /apex/apex_payload.img; then
|
|
|
|
if mount -text4 -oro,noatime "${loop}" "${apex_mount}"; then
|
|
|
|
rm -f /apex/apex_payload.img
|
|
|
|
break
|
|
|
|
fi
|
2019-10-12 18:00:52 +00:00
|
|
|
fi
|
2020-08-11 19:25:48 +00:00
|
|
|
|
|
|
|
number=$((number + 1))
|
2019-10-12 18:00:52 +00:00
|
|
|
done
|
2020-08-11 19:25:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# taken from Magisk, with modifications for NanoDroid
|
|
|
|
mount_apex () {
|
|
|
|
APEX_LD=""
|
2019-10-08 18:46:47 +00:00
|
|
|
|
2020-04-15 18:06:20 +00:00
|
|
|
if ${BOOTMODE}; then
|
2020-08-11 19:25:48 +00:00
|
|
|
APEX_LD=/system/apex/com.android.runtime
|
2020-04-15 18:06:20 +00:00
|
|
|
else
|
2020-08-11 19:25:48 +00:00
|
|
|
APEX_LD=/apex/com.android.runtime
|
2020-04-15 18:06:20 +00:00
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
mkdir -p /apex
|
2019-10-08 18:46:47 +00:00
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
for apex in /system/apex/*; do
|
|
|
|
apex_mount="/apex/$(basename ${apex} .apex)"
|
|
|
|
apex_loop="/dev/loop_apex_$(basename ${apex} .apex)"
|
2019-10-08 18:46:47 +00:00
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
[ "${apex_mount}" == /apex/com.android.runtime.release ] && apex_mount=/apex/com.android.runtime
|
|
|
|
[ "${apex_mount}" == /apex/com.android.runtime.debug ] && apex_mount=/apex/com.android.runtime
|
2020-04-17 18:45:32 +00:00
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
if [ -f "${apex}" ]; then
|
|
|
|
unzip -oq "${apex}" apex_payload.img -d /apex
|
|
|
|
mount_apex_loop "${apex_mount}" || error "APEX loop setup failed!"
|
|
|
|
elif [ -d "${apex}" ]; then
|
|
|
|
mount -o bind "${apex}" "${apex_mount}"
|
|
|
|
fi
|
|
|
|
done
|
2020-04-17 18:45:32 +00:00
|
|
|
|
|
|
|
export ANDROID_RUNTIME_ROOT=/apex/com.android.runtime
|
|
|
|
export ANDROID_TZDATA_ROOT=/apex/com.android.tzdata
|
2019-10-08 18:46:47 +00:00
|
|
|
fi
|
2020-04-07 10:25:31 +00:00
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
echo " INFO: #10 [APEX_LD] ${APEX_LD}"
|
|
|
|
echo " INFO: #11 [APEX [ALL]] $(ls /system/apex/*.apex)"
|
2019-10-23 19:33:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# taken from Magisk, with minor modifications for NanoDroid
|
|
|
|
mount_partitions () {
|
|
|
|
DEVICE_AB=FALSE
|
|
|
|
VENDOR_COMPAT=FALSE
|
|
|
|
SYSTEM_AS_ROOT=FALSE
|
|
|
|
|
|
|
|
SLOT=$(grep_cmdline androidboot.slot_suffix)
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #1 [SLOT] ${SLOT}"
|
2019-10-23 19:33:46 +00:00
|
|
|
if [ -z ${SLOT} ]; then
|
|
|
|
SLOT=$(grep_cmdline androidboot.slot)
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #2 [SLOT] ${SLOT}"
|
2019-10-23 20:05:21 +00:00
|
|
|
if [ ! -z ${SLOT} ]; then
|
2019-10-23 19:33:46 +00:00
|
|
|
SLOT=_${SLOT}
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #3 [SLOT] ${SLOT}"
|
2019-10-23 19:33:46 +00:00
|
|
|
DEVICE_AB=TRUE
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
system_tmp=$(find /dev/block -type l -name system${SLOT} | head -n 1)
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #4 [system_tmp] ${system_tmp}"
|
2019-10-23 19:33:46 +00:00
|
|
|
SYSTEM_BLOCK=$(readlink -f ${system_tmp})
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #5 [SYSTEM_BLOCK] ${SYSTEM_BLOCK}"
|
2019-10-23 19:33:46 +00:00
|
|
|
|
|
|
|
is_mounted /data || mount /data || error "failed to mount /data!"
|
2019-10-08 18:46:47 +00:00
|
|
|
|
2019-10-23 19:33:46 +00:00
|
|
|
mount -o bind /dev/urandom /dev/random
|
2019-10-29 18:38:30 +00:00
|
|
|
! is_mounted /system && mount -o rw /system
|
|
|
|
! is_mounted /system && mount -o rw ${SYSTEM_BLOCK} /system
|
|
|
|
! is_mounted /system && error "failed to mount /system!"
|
2019-10-23 19:33:46 +00:00
|
|
|
|
|
|
|
if [ -f /system/init.rc ]; then
|
|
|
|
SYSTEM_AS_ROOT=true
|
|
|
|
[ -L /system_root ] && rm -f /system_root
|
|
|
|
mkdir /system_root 2>/dev/null
|
|
|
|
mount --move /system /system_root
|
|
|
|
mount -o bind /system_root/system /system
|
|
|
|
fi
|
|
|
|
|
|
|
|
vendor_tmp=$(find /dev/block -type l -name vendor${SLOT} | head -n 1)
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #6 [vendor_tmp] ${vendor_tmp}"
|
2019-10-23 19:33:46 +00:00
|
|
|
VENDOR_BLOCK=$(readlink -f ${vendor_tmp})
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #7 [VENDOR_BLOCK] ${VENDOR_BLOCK}"
|
2019-10-08 18:46:47 +00:00
|
|
|
|
2019-10-29 18:38:30 +00:00
|
|
|
! is_mounted /vendor && mount -o ro /vendor || mount -o ro ${VENDOR_BLOCK} /vendor
|
|
|
|
|
|
|
|
if [ -d /system/vendor ]; then
|
2018-08-29 15:01:33 +00:00
|
|
|
### XXX work-around required for some ROMs
|
2019-10-08 18:46:47 +00:00
|
|
|
VENDOR_COMPAT=TRUE
|
2019-11-14 19:26:32 +00:00
|
|
|
ln -sf /system/vendor /vendor >/dev/null
|
2019-10-29 18:38:30 +00:00
|
|
|
fi
|
2019-10-23 19:33:46 +00:00
|
|
|
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " "
|
|
|
|
mount | awk '{print $1 " on " $3 " params: " $6}'
|
|
|
|
echo " "
|
2019-10-23 19:33:46 +00:00
|
|
|
|
2019-10-29 18:38:30 +00:00
|
|
|
echo " INFO: #8 [prop]"
|
|
|
|
ls -l /system/*.prop
|
2018-08-27 19:25:03 +00:00
|
|
|
|
2019-10-29 18:38:30 +00:00
|
|
|
export build_props=$(find /system /system_root /vendor -type f -name build.prop)
|
|
|
|
echo " INFO: #9 [build_props] ${build_props}"
|
2019-10-23 19:33:46 +00:00
|
|
|
|
2019-10-29 18:38:30 +00:00
|
|
|
[ -z "${build_props}" ] && error "failed to mount /system (unsupported A/B device?)"
|
2019-10-23 19:33:46 +00:00
|
|
|
|
2019-10-29 18:38:30 +00:00
|
|
|
mount_apex
|
2020-08-13 06:50:52 +00:00
|
|
|
|
|
|
|
${BOOTMODE} && export LD_CONFIG_FILE="/system/etc/ld.config.txt" || \
|
|
|
|
export LD_CONFIG_FILE="${APEX_LD}/etc/ld.config.txt"
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
2020-08-11 19:25:48 +00:00
|
|
|
umount_partitions () {
|
|
|
|
umount -l /system_root 2>/dev/null
|
|
|
|
umount -l /system 2>/dev/null
|
|
|
|
umount -l /vendor 2>/dev/null
|
|
|
|
umount -l /dev/random 2>/dev/null
|
|
|
|
|
|
|
|
mount | awk '/ \/apex/{print $3}' | while read apex_mount; do
|
|
|
|
umount -l "${apex_mount}" 2>/dev/null
|
|
|
|
done
|
|
|
|
|
|
|
|
mount | awk '/ \/apex/{print $1}' | while read apex_loop; do
|
|
|
|
losetup -d "${apex_loop}" 2>/dev/null
|
|
|
|
done
|
|
|
|
|
|
|
|
unset ANDROID_RUNTIME_ROOT
|
|
|
|
unset ANDROID_TZDATA_ROOT
|
|
|
|
unset BOOTCLASSPATH
|
|
|
|
|
|
|
|
rm -rf ${APEX_TMP}/apex
|
|
|
|
rm -rf /apex
|
|
|
|
}
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
error () {
|
2018-09-06 18:27:19 +00:00
|
|
|
ui_print " "
|
|
|
|
ui_print " !! ${@}"
|
|
|
|
ui_print " "
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2019-04-20 11:08:07 +00:00
|
|
|
set_perm () {
|
|
|
|
chown ${2}:${3} ${1} || error "failed change owner for ${1}"
|
|
|
|
chmod ${4} ${1} || error "failed to change mode for ${1}"
|
|
|
|
|
|
|
|
if [ ! -z "${5}" ]; then
|
|
|
|
chcon ${5} ${1} 2>/dev/null
|
|
|
|
else chcon 'u:object_r:system_file:s0' ${1} 2>/dev/null
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
set_perm_recursive() {
|
|
|
|
find ${1} -type d 2>/dev/null | while read dir; do
|
|
|
|
set_perm ${dir} ${2} ${3} ${4} ${6}
|
|
|
|
done
|
|
|
|
find ${1} -type f 2>/dev/null | while read file; do
|
|
|
|
set_perm ${file} ${2} ${3} ${5} ${6}
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
set_perm_data () {
|
|
|
|
if [ "${1}" = "-r" ]; then
|
|
|
|
echo " perm: data [recursive] {${2}}"
|
|
|
|
set_perm_recursive ${2} 0 0 0755 0644
|
|
|
|
else
|
|
|
|
echo " perm: data [single] {${1}}"
|
|
|
|
set_perm ${1} 0 0 0644
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
##########################################################################################
|
|
|
|
# Device Functions
|
|
|
|
##########################################################################################
|
|
|
|
|
|
|
|
detect_outfd () {
|
2018-09-08 18:02:24 +00:00
|
|
|
if [ -z $OUTFD ] || readlink /proc/$$/fd/$OUTFD | grep -q /tmp; then
|
|
|
|
# We will have to manually find out OUTFD
|
2018-03-20 17:52:53 +00:00
|
|
|
for FD in `ls /proc/$$/fd`; do
|
2018-09-08 18:02:24 +00:00
|
|
|
if readlink /proc/$$/fd/$FD | grep -q pipe; then
|
|
|
|
if ps | grep -v grep | grep -q " 3 $FD "; then
|
2018-03-20 17:52:53 +00:00
|
|
|
OUTFD=$FD
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
detect_bootmode () {
|
2018-11-09 20:21:27 +00:00
|
|
|
[ -z ${BOOTMODE} ] && BOOTMODE=false
|
|
|
|
${BOOTMODE} || ps | grep zygote | grep -qv grep && BOOTMODE=true
|
2018-09-01 17:14:09 +00:00
|
|
|
${BOOTMODE} || ps -A | grep zygote | grep -qv grep && BOOTMODE=true
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
grep_prop() {
|
2018-12-27 21:11:09 +00:00
|
|
|
[ -f /vendor/build.prop ] && \
|
|
|
|
FILES="/system/build.prop /vendor/build.prop" || \
|
|
|
|
FILES="/system/build.prop"
|
|
|
|
|
|
|
|
sed -n "s/^${1}=//p" ${FILES} | head -n 1
|
2018-08-05 11:17:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
grep_cmdline() {
|
|
|
|
local REGEX="s/^${1}=//p"
|
|
|
|
sed -E 's/ +/\n/g' /proc/cmdline | \
|
|
|
|
sed -n "${REGEX}" 2>/dev/null
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
2018-08-26 19:07:23 +00:00
|
|
|
detect_odex () {
|
2018-08-27 18:04:25 +00:00
|
|
|
SERVICES_JAR_DEX=$(unzip -lq /system/framework/services.jar | grep classes.dex)
|
|
|
|
|
2018-08-27 19:46:52 +00:00
|
|
|
if [ -n "$(find '/system/framework/' -name 'services.vdex')" ]; then
|
2018-08-27 19:41:36 +00:00
|
|
|
ROM_DEX_STATUS=VDEX
|
2018-08-27 19:46:52 +00:00
|
|
|
elif [ -n "$(find '/system/framework/' -name 'services.odex')" ]; then
|
2018-08-27 19:41:36 +00:00
|
|
|
ROM_DEX_STATUS=ODEX
|
2018-08-27 19:51:18 +00:00
|
|
|
else ROM_DEX_STATUS=UNKOWN
|
2018-08-24 19:24:01 +00:00
|
|
|
fi
|
2018-08-26 19:08:04 +00:00
|
|
|
|
2018-08-27 19:41:36 +00:00
|
|
|
[ "${SERVICES_JAR_DEX}" ] && ROM_DEX_STATUS=DEODEX
|
|
|
|
|
2018-08-27 19:51:18 +00:00
|
|
|
ui_print " "
|
|
|
|
ui_print " ++"
|
|
|
|
ui_print " ++ services.jar status: ${ROM_DEX_STATUS}"
|
|
|
|
ui_print " ++"
|
2018-09-06 18:44:11 +00:00
|
|
|
|
|
|
|
[ "${SDK_VERSION}" -gt 27 -a "${ROM_DEX_STATUS}" != "DEODEX" ] && \
|
2020-04-15 18:35:15 +00:00
|
|
|
error "Android 9 or newer is only supported on de-odexed ROMs currently"
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
detect_arch () {
|
|
|
|
ABI=$(grep_prop ro.product.cpu.abi | cut -c-3)
|
|
|
|
ABI2=$(grep_prop ro.product.cpu.abi2 | cut -c-3)
|
|
|
|
ABILONG=$(grep_prop ro.product.cpu.abi)
|
|
|
|
|
|
|
|
ARCH=arm
|
|
|
|
|
|
|
|
[ "$ABI" = "x86" ] && ARCH=x86
|
|
|
|
[ "$ABI2" = "x86" ] && ARCH=x86
|
|
|
|
[ "$ABILONG" = "arm64-v8a" ] && ARCH=arm64
|
|
|
|
[ "$ABILONG" = "x86_64" ] && ARCH=x86_64
|
|
|
|
|
|
|
|
case ${ARCH} in
|
|
|
|
arm | arm64 )
|
|
|
|
ZIPB=${BASEDIR}/zip.arm
|
2018-11-14 21:22:38 +00:00
|
|
|
FILE=${BASEDIR}/file.arm
|
2018-08-26 16:58:59 +00:00
|
|
|
|
|
|
|
if [ -f ${TMPDIR}/busybox.arm ]; then
|
|
|
|
BUSY=${TMPDIR}/busybox.arm
|
|
|
|
else BUSY=${BASEDIR}/busybox.arm
|
|
|
|
fi
|
2018-03-20 17:52:53 +00:00
|
|
|
;;
|
|
|
|
x86 | x86_64 )
|
|
|
|
ZIPB=${BASEDIR}/zip.x86
|
2018-11-14 21:22:38 +00:00
|
|
|
FILE=${BASEDIR}/file.x86
|
2018-08-26 16:58:59 +00:00
|
|
|
|
|
|
|
if [ -f ${TMPDIR}/busybox.x86 ]; then
|
|
|
|
BUSY=${TMPDIR}/busybox.x86
|
|
|
|
else BUSY=${BASEDIR}/busybox.x86
|
|
|
|
fi
|
2018-03-20 17:52:53 +00:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2019-04-25 18:43:45 +00:00
|
|
|
V_EX=${BASEDIR}/vdexExtractor.${ARCH}
|
|
|
|
|
|
|
|
chmod 0755 ${BUSY}
|
|
|
|
|
|
|
|
rm -rf ${BASEDIR}/busybox
|
|
|
|
mkdir -p ${BASEDIR}/busybox
|
|
|
|
|
|
|
|
ln -sf ${BUSY} ${BASEDIR}/busybox/busybox
|
|
|
|
${BUSY} --install -s ${BASEDIR}/busybox/
|
|
|
|
|
|
|
|
export PATH="${BASEDIR}/busybox:/system/bin:/system/xbin"
|
|
|
|
|
2020-08-13 06:50:52 +00:00
|
|
|
DALVIKVM_BIN=$(ls -l ${APEX_LD}/bin/dalvikvm | awk '{print $NF}')
|
|
|
|
DALVIKVM_ARCH=$("${FILE}" -m "${BASEDIR}/magic.mgc" -L ${APEX_LD}/bin/dalvikvm)
|
2018-11-14 21:22:38 +00:00
|
|
|
|
2018-10-02 21:32:20 +00:00
|
|
|
case ${DALVIKVM_BIN} in
|
2020-01-25 19:53:11 +00:00
|
|
|
*dalvikvm32* )
|
2020-04-15 18:06:20 +00:00
|
|
|
export LD_LIBRARY_PATH="${APEX_LD}/lib:/system/lib:/vendor/lib:/system/vendor/lib"
|
2018-11-19 21:13:15 +00:00
|
|
|
;;
|
|
|
|
|
2020-01-25 19:53:11 +00:00
|
|
|
*dalvikvm64* )
|
2020-04-15 18:06:20 +00:00
|
|
|
export LD_LIBRARY_PATH="${APEX_LD}/lib64:/system/lib64:/vendor/lib64:/system/vendor/lib64"
|
2018-11-19 21:13:15 +00:00
|
|
|
;;
|
|
|
|
|
2020-01-25 19:53:11 +00:00
|
|
|
*dalvikvm* )
|
2018-11-14 21:22:38 +00:00
|
|
|
case ${DALVIKVM_ARCH} in
|
|
|
|
*32-bit* )
|
2020-04-15 18:06:20 +00:00
|
|
|
export LD_LIBRARY_PATH="${APEX_LD}/lib:/system/lib:/vendor/lib:/system/vendor/lib"
|
2018-11-14 21:22:38 +00:00
|
|
|
;;
|
|
|
|
|
|
|
|
*64-bit* )
|
2020-04-15 18:06:20 +00:00
|
|
|
export LD_LIBRARY_PATH="${APEX_LD}/lib64:/system/lib64:/vendor/lib64:/system/vendor/lib64"
|
2018-11-14 21:22:38 +00:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
2018-10-02 21:32:20 +00:00
|
|
|
esac
|
2018-08-26 13:04:23 +00:00
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
ui_print " > device architecture: ${ARCH}"
|
|
|
|
}
|
|
|
|
|
|
|
|
detect_sdk () {
|
|
|
|
SDK_VERSION=$(grep_prop ro.build.version.sdk)
|
|
|
|
|
2020-04-04 12:12:19 +00:00
|
|
|
[ "${SDK_VERSION}" -gt 29 ] && \
|
|
|
|
error "Android versions beyond Android 10 are not yet supported"
|
2018-08-26 17:03:06 +00:00
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
[ "${SDK_VERSION}" -lt 16 ] && \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "Android versions before Jelly Bean are not supported"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2018-12-27 21:11:09 +00:00
|
|
|
if [ "${SDK_VERSION}" -gt 25 ]; then
|
|
|
|
BAKSMALI="${BASEDIR}/baksmali_26.dex"
|
|
|
|
SMALI="${BASEDIR}/smali_26.dex"
|
|
|
|
elif [ "${SDK_VERSION}" -gt 23 ]; then
|
|
|
|
BAKSMALI="${BASEDIR}/baksmali_25.dex"
|
|
|
|
SMALI="${BASEDIR}/smali_25.dex"
|
|
|
|
else
|
|
|
|
BAKSMALI="${BASEDIR}/baksmali_23.dex"
|
|
|
|
SMALI="${BASEDIR}/smali_23.dex"
|
|
|
|
fi
|
2018-08-27 16:53:57 +00:00
|
|
|
|
2020-01-17 20:10:23 +00:00
|
|
|
if [ "${SDK_VERSION}" -gt 25 ]; then
|
|
|
|
DEXPATCHER="${BASEDIR}/dexpatcher_26.dex"
|
|
|
|
else DEXPATCHER="${BASEDIR}/dexpatcher_19.dex"
|
|
|
|
fi
|
|
|
|
|
2018-09-19 16:42:34 +00:00
|
|
|
PATCH_CORE="${BASEDIR}/core_services.jar.dex"
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
if [ "${SDK_VERSION}" -lt 24 ]; then
|
|
|
|
ui_print " > Android 4.1 - 6.0 (SDK ${SDK_VERSION}) detected"
|
|
|
|
PATCH_HOOK="${BASEDIR}/hook_4.1-6.0_services.jar.dex"
|
|
|
|
else
|
2020-04-04 12:12:19 +00:00
|
|
|
ui_print " > Android 7.0 - 10.0 (SDK ${SDK_VERSION}) detected"
|
|
|
|
PATCH_HOOK="${BASEDIR}/hook_7.0-10.0_services.jar.dex"
|
2018-03-20 17:52:53 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
[ "${SDK_VERSION}" -gt 21 ] && DEX_OPTS="--multi-dex-threaded"
|
|
|
|
}
|
|
|
|
|
2018-12-27 21:11:09 +00:00
|
|
|
##########################################################################################
|
|
|
|
# by @ale5000
|
|
|
|
##########################################################################################
|
|
|
|
|
|
|
|
search_fake_package_signature () {
|
|
|
|
PERMISSION=android.permission.FAKE_PACKAGE_SIGNATURE
|
|
|
|
PERMISSION_OD=$(echo -n "${PERMISSION}" | od -A n -t x1 | tr -d '\n' | sed -e 's/^ //g;s/ /00/g')
|
|
|
|
HAS_FAKESIGN=false
|
|
|
|
|
|
|
|
FW_RES_DIR="${TMPDIR}/framework-res"
|
2019-03-09 21:16:47 +00:00
|
|
|
|
|
|
|
if [ ! -f ${FW_RES_DIR}/AndroidManifest.xml ]; then
|
|
|
|
mkdir -p "${FW_RES_DIR}"
|
2019-04-25 18:49:26 +00:00
|
|
|
unzip -oq /system/framework/framework-res.apk -d "${FW_RES_DIR}"
|
2019-03-09 21:16:47 +00:00
|
|
|
fi
|
2018-12-27 21:11:09 +00:00
|
|
|
|
|
|
|
grep -qF "${PERMISSION}" "${FW_RES_DIR}/AndroidManifest.xml" && HAS_FAKESIGN=true
|
|
|
|
od -A n -t x1 "${FW_RES_DIR}/AndroidManifest.xml" | tr -d ' \n' | grep -qF "${PERMISSION_OD}" && HAS_FAKESIGN=true
|
|
|
|
|
|
|
|
${HAS_FAKESIGN} && return 0 || return 1
|
|
|
|
}
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
##########################################################################################
|
|
|
|
# Patcher Functions
|
|
|
|
##########################################################################################
|
|
|
|
|
|
|
|
setup_patcher () {
|
|
|
|
ui_print " > preparing environment"
|
|
|
|
|
|
|
|
rm -rf ${TMPDIR}
|
|
|
|
mkdir -p ${TMPDIR}
|
|
|
|
|
2019-04-25 18:49:26 +00:00
|
|
|
unzip -oq "${ZIP}" -d ${TMPDIR} || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "failed to prepare environment"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2018-09-08 18:16:54 +00:00
|
|
|
for bin in zip.arm zip.x86 \
|
2018-08-26 16:02:36 +00:00
|
|
|
vdexExtractor.arm vdexExtractor.x86 \
|
2018-11-19 17:26:45 +00:00
|
|
|
vdexExtractor.arm64 vdexExtractor.x86_64 \
|
2018-11-14 21:22:38 +00:00
|
|
|
file.arm file.x86; do
|
2018-03-20 17:52:53 +00:00
|
|
|
chmod 0755 "${BASEDIR}/${bin}" || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "failed to prepare environment"
|
2018-03-20 17:52:53 +00:00
|
|
|
done
|
2018-08-27 18:59:47 +00:00
|
|
|
|
|
|
|
mkdir -p /data/adb/
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
2018-09-05 19:31:44 +00:00
|
|
|
call_dalvikvm () {
|
2020-04-17 18:45:32 +00:00
|
|
|
FRAME=/system/framework
|
2020-08-13 06:50:52 +00:00
|
|
|
APEXB=${APEX_LD}/javalib
|
|
|
|
|
|
|
|
export BOOTCLASSPATH=${APEXB}/core-oj.jar:${APEXB}/core-libart.jar:${APEXB}/okhttp.jar:\
|
|
|
|
${APEXB}/bouncycastle.jar:${APEXB}/apache-xml.jar:${FRAME}/framework.jar:\
|
|
|
|
${FRAME}/ext.jar:${FRAME}/telephony-common.jar:${FRAME}/voip-common.jar:\
|
|
|
|
${FRAME}/ims-common.jar:${FRAME}/android.test.base.jar:${FRAME}/telephony-ext.jar:\
|
2020-08-11 19:25:48 +00:00
|
|
|
/apex/com.android.conscrypt/javalib/conscrypt.jar:\
|
|
|
|
/apex/com.android.media/javalib/updatable-media.jar
|
2018-09-05 19:31:44 +00:00
|
|
|
|
2020-08-13 06:50:52 +00:00
|
|
|
supported_opts=$(${APEX_LD}/bin/dalvikvm --help 2>&1)
|
2019-08-19 17:26:27 +00:00
|
|
|
|
|
|
|
DALVIKVM_OPTS=""
|
|
|
|
|
|
|
|
[[ "${supported_opts}" == *\[no\]image-dex2oat* ]] && DALVIKVM_OPTS="${DALVIKVM_OPTS} -Xnoimage-dex2oat"
|
|
|
|
[[ "${supported_opts}" == *verbose:*gc* ]] && DALVIKVM_OPTS="${DALVIKVM_OPTS} -verbose:gc"
|
|
|
|
[[ "${supported_opts}" == *verbose:*jit* ]] && DALVIKVM_OPTS="${DALVIKVM_OPTS} -verbose:jit"
|
|
|
|
[[ "${supported_opts}" == *verbose:*jni* ]] && DALVIKVM_OPTS="${DALVIKVM_OPTS} -verbose:jni"
|
|
|
|
[[ "${supported_opts}" == *verbose:*class* ]] && DALVIKVM_OPTS="${DALVIKVM_OPTS} -verbose:class"
|
2018-09-08 17:21:26 +00:00
|
|
|
|
2020-08-13 06:50:52 +00:00
|
|
|
${APEX_LD}/bin/dalvikvm ${DALVIKVM_OPTS} "${@}"
|
2018-09-05 19:31:44 +00:00
|
|
|
}
|
|
|
|
|
2018-10-20 21:56:49 +00:00
|
|
|
deodex_vdex () {
|
|
|
|
ui_print " >> deodexing services.jar [VDEX]"
|
|
|
|
|
2019-04-12 17:39:06 +00:00
|
|
|
cp /system/framework/oat/${ARCH}/services.vdex \
|
|
|
|
${BASEDIR}/services.vdex || \
|
|
|
|
error "failed to copy services.vdex"
|
|
|
|
|
|
|
|
${V_EX} -i ${BASEDIR}/services.vdex \
|
|
|
|
--ignore-crc-error --debug=4 || \
|
|
|
|
error "failed to deodex services.vdex"
|
|
|
|
|
|
|
|
mv ${BASEDIR}/services.apk_classes.dex ${BASEDIR}/classes.dex || \
|
|
|
|
error "failed to deodex services.vdex"
|
|
|
|
|
|
|
|
${ZIPB} -j "${BASEDIR}/services.jar" \
|
|
|
|
"${BASEDIR}/classes.dex" || \
|
|
|
|
error "zip failed"
|
2018-10-20 21:56:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
deodex_odex () {
|
|
|
|
ui_print " >> deodexing services.jar [ODEX]"
|
|
|
|
|
|
|
|
cp "/system/framework/oat/${ARCH}/services.odex" "${BASEDIR}"
|
|
|
|
|
|
|
|
# baksmali/smali options switches (version dependent)
|
|
|
|
MAIN=Main
|
|
|
|
DEODEX="x"
|
|
|
|
ASSEMBLE="a"
|
|
|
|
BOOTCLASSPATH="-b"
|
|
|
|
CLASSPATHDIR="-d"
|
|
|
|
|
|
|
|
if [ "${SDK_VERSION}" -lt 24 ]; then
|
|
|
|
MAIN=main
|
|
|
|
DEODEX="-x"
|
|
|
|
ASSEMBLE=
|
|
|
|
BOOTCLASSPATH="-c"
|
|
|
|
fi
|
|
|
|
|
|
|
|
ui_print " [1] baksmali services.odex"
|
|
|
|
|
|
|
|
call_dalvikvm \
|
|
|
|
-classpath "${BAKSMALI}" \
|
|
|
|
org.jf.baksmali.${MAIN} \
|
|
|
|
${DEODEX} \
|
|
|
|
${BOOTCLASSPATH} "/system/framework/${ARCH}/boot.oat" \
|
|
|
|
${CLASSPATHDIR} "/system/framework/${ARCH}" \
|
|
|
|
${CLASSPATHDIR} "/system/framework" \
|
|
|
|
-o "${BASEDIR}/services.jar-deodex" \
|
|
|
|
"${BASEDIR}/services.odex" || \
|
|
|
|
error "failed to deodex services.jar"
|
|
|
|
|
|
|
|
ui_print " [2] smali services.odex"
|
|
|
|
|
|
|
|
call_dalvikvm \
|
|
|
|
-classpath "${SMALI}" \
|
|
|
|
org.jf.smali.${MAIN} \
|
|
|
|
${ASSEMBLE} \
|
|
|
|
-o "${BASEDIR}/services.jar-deodex/classes.dex" \
|
|
|
|
"${BASEDIR}/services.jar-deodex" || \
|
|
|
|
error "failed to rebuild classes.dex"
|
|
|
|
|
|
|
|
${ZIPB} -j "${BASEDIR}/services.jar" \
|
|
|
|
"${BASEDIR}/services.jar-deodex"/classes*.dex || \
|
|
|
|
error "zip failed"
|
|
|
|
|
|
|
|
rm -rf "${BASEDIR}/services.jar-deodex"
|
|
|
|
}
|
|
|
|
|
2018-03-20 17:52:53 +00:00
|
|
|
patch_services () {
|
|
|
|
ui_print " "
|
|
|
|
ui_print " > patching signature spoofing support"
|
|
|
|
ui_print " "
|
|
|
|
|
|
|
|
cp /system/framework/services.jar \
|
|
|
|
${BASEDIR}/services.jar || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "failed to copy services.jar"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2018-08-25 19:43:43 +00:00
|
|
|
if [ "${ROM_DEX_STATUS}" = "VDEX" ]; then
|
2018-10-20 21:56:49 +00:00
|
|
|
deodex_vdex
|
2018-08-25 21:23:26 +00:00
|
|
|
elif [ "${ROM_DEX_STATUS}" = "ODEX" ]; then
|
2018-10-20 21:56:49 +00:00
|
|
|
deodex_odex
|
2018-08-25 19:43:43 +00:00
|
|
|
fi
|
2018-08-24 19:47:56 +00:00
|
|
|
|
|
|
|
mkdir -p "${BASEDIR}/services.jar-mod"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2019-03-17 20:03:13 +00:00
|
|
|
PATCHES="${PATCH_HOOK} ${PATCH_CORE}"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
|
|
|
ui_print " >> patching services.jar"
|
2018-10-20 21:56:49 +00:00
|
|
|
|
2018-09-05 19:31:44 +00:00
|
|
|
call_dalvikvm \
|
2020-01-17 20:10:23 +00:00
|
|
|
-classpath "${DEXPATCHER}" \
|
2018-03-20 17:52:53 +00:00
|
|
|
lanchon.dexpatcher.Main \
|
|
|
|
${DEX_OPTS} --api-level "${SDK_VERSION}" \
|
2018-08-26 16:02:36 +00:00
|
|
|
--verbose --debug --output ${BASEDIR}/services.jar-mod \
|
2018-03-20 17:52:53 +00:00
|
|
|
${BASEDIR}/services.jar ${PATCHES} || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "failed to apply patches"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2018-08-30 18:06:20 +00:00
|
|
|
${ZIPB} -d "${BASEDIR}/services.jar" \
|
2018-08-26 10:53:17 +00:00
|
|
|
'classes*.dex' || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "zip failed"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2018-08-30 18:06:20 +00:00
|
|
|
${ZIPB} -j "${BASEDIR}/services.jar" \
|
2018-08-26 10:53:17 +00:00
|
|
|
"${BASEDIR}/services.jar-mod"/classes*.dex || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "zip failed"
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
backup_services_jar () {
|
2019-05-05 10:13:21 +00:00
|
|
|
ui_print " << backing up services.jar to: /data/media/0/nanodroid_backups"
|
2018-12-25 19:41:09 +00:00
|
|
|
services_name="services.jar_$(grep_prop ro.build.flavor)_$(grep_prop ro.build.id)"
|
|
|
|
|
2019-05-05 10:13:21 +00:00
|
|
|
mkdir -p /data/media/0/nanodroid_backups
|
|
|
|
cp /system/framework/services.jar "/data/media/0/nanodroid_backups/${services_name}" || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "failed to backup services.jar"
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
install_services () {
|
|
|
|
ui_print " "
|
2019-05-11 20:22:28 +00:00
|
|
|
for destination in /data/adb/modules/NanoDroid /data/adb/modules/NanoDroid_microG /; do
|
2018-03-20 17:52:53 +00:00
|
|
|
if [ -d ${destination} ]; then
|
|
|
|
install_path="${destination}"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ "${install_path}" = "/" ]; then
|
|
|
|
mount -orw,remount /system || \
|
2018-09-06 18:43:18 +00:00
|
|
|
error "failed to mount /system read-write"
|
2018-03-20 17:52:53 +00:00
|
|
|
backup_services_jar
|
|
|
|
fi
|
|
|
|
|
|
|
|
ui_print " << installing patched files to: ${install_path}"
|
|
|
|
|
|
|
|
mkdir -p "${install_path}/system/framework"
|
2019-04-12 17:39:06 +00:00
|
|
|
cp ${BASEDIR}/services.jar "${install_path}/system/framework/" \
|
2018-09-06 18:43:18 +00:00
|
|
|
|| error "failed to install services.jar"
|
2019-04-20 11:08:07 +00:00
|
|
|
set_perm_data "${install_path}/system/framework/services.jar"
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2019-04-12 17:39:06 +00:00
|
|
|
cp "${BASEDIR}/org.spoofing.apk" "${install_path}/system/framework/"
|
2019-04-20 11:08:07 +00:00
|
|
|
set_perm_data "${install_path}/system/framework/org.spoofing.apk"
|
2019-04-12 17:39:06 +00:00
|
|
|
|
2018-08-24 19:24:01 +00:00
|
|
|
touch /data/adb/NanoDroid_Patched
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
##########################################################################################
|
|
|
|
# addon.d
|
|
|
|
##########################################################################################
|
|
|
|
|
|
|
|
install_addond () {
|
|
|
|
ui_print " "
|
|
|
|
ui_print " Installing addon.d restoration setup"
|
|
|
|
|
2018-09-08 18:20:07 +00:00
|
|
|
rm -rf ${PATCHER_ADDOND_DATA}
|
2018-08-29 15:01:33 +00:00
|
|
|
mkdir -p ${PATCHER_ADDOND_DATA}
|
2018-03-20 17:52:53 +00:00
|
|
|
|
|
|
|
[ -d /data/nanomod.patcher ] && rm -rf /data/nanomod.patcher
|
|
|
|
[ -d /data/adb/nanomod_patcher ] && rm -rf /data/nanomod_patcher
|
2018-04-10 19:47:19 +00:00
|
|
|
rm -f /system/addon.d/75-nanomodpatcher.sh \
|
2018-09-17 17:04:45 +00:00
|
|
|
/system/addon.d/75-nanodroidpatcher.sh \
|
|
|
|
/system/addon.d/999-nanodroidpatcher.sh
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2020-01-19 18:47:40 +00:00
|
|
|
for file in core_services.jar.dex dexpatcher_19.dex dexpatcher_26.dex \
|
2020-04-04 12:12:19 +00:00
|
|
|
hook_4.1-6.0_services.jar.dex hook_7.0-10.0_services.jar.dex \
|
2019-03-17 20:03:13 +00:00
|
|
|
baksmali_23.dex baksmali_25.dex baksmali_26.dex \
|
|
|
|
smali_23.dex smali_25.dex smali_26.dex \
|
2019-04-12 17:39:06 +00:00
|
|
|
magic.mgc org.spoofing.apk; do
|
2018-08-29 15:01:33 +00:00
|
|
|
cp "${BASEDIR}/${file}" ${PATCHER_ADDOND_DATA}/
|
2018-03-20 17:52:53 +00:00
|
|
|
done
|
|
|
|
|
2018-08-29 15:01:33 +00:00
|
|
|
cp /dev/tmp/CommonPatcher ${PATCHER_ADDOND_DATA}/
|
2018-03-20 17:52:53 +00:00
|
|
|
|
2018-11-14 21:22:38 +00:00
|
|
|
for file in ${ZIPB} ${V_EX} ${BUSY} ${FILE}; do
|
2018-09-08 18:16:54 +00:00
|
|
|
cp ${file} ${PATCHER_ADDOND_DATA}/
|
|
|
|
chmod 0755 ${PATCHER_ADDOND_DATA}/$(basename "${file}")
|
|
|
|
done
|
2018-08-26 16:58:59 +00:00
|
|
|
|
2018-09-04 17:16:04 +00:00
|
|
|
mkdir -p /system/addon.d/
|
2018-09-15 20:05:03 +00:00
|
|
|
cp "${BASEDIR}/70-nanodroidpatcher.sh" /system/addon.d/
|
|
|
|
chmod 0755 /system/addon.d/70-nanodroidpatcher.sh
|
2018-03-20 17:52:53 +00:00
|
|
|
}
|