module: fix INSTALL_FAILED_VERSION_DOWNGRADE again

This commit is contained in:
j-hc 2024-10-20 11:43:33 +03:00
parent d23d0d57e9
commit 7aad796fff
No known key found for this signature in database
GPG Key ID: CDF97F1DBFE904CD
3 changed files with 57 additions and 58 deletions

View File

@ -6,8 +6,6 @@ if [ -n "$MODULE_ARCH" ] && [ "$MODULE_ARCH" != "$ARCH" ]; then
Your device: $ARCH Your device: $ARCH
Module: $MODULE_ARCH" Module: $MODULE_ARCH"
fi fi
alias cmpr="$MODPATH/bin/$ARCH/cmpr"
if [ "$ARCH" = "arm" ]; then if [ "$ARCH" = "arm" ]; then
ARCH_LIB=armeabi-v7a ARCH_LIB=armeabi-v7a
elif [ "$ARCH" = "arm64" ]; then elif [ "$ARCH" = "arm64" ]; then
@ -23,9 +21,7 @@ set_perm_recursive "$MODPATH/bin" 0 0 0755 0777
if su -M -c true >/dev/null 2>/dev/null; then if su -M -c true >/dev/null 2>/dev/null; then
alias mm='su -M -c' alias mm='su -M -c'
else else alias mm='nsenter -t1 -m'; fi
alias mm='nsenter -t1 -m'
fi
mm grep -F "$PKG_NAME" /proc/mounts | while read -r line; do mm grep -F "$PKG_NAME" /proc/mounts | while read -r line; do
ui_print "* Un-mount" ui_print "* Un-mount"
@ -34,27 +30,27 @@ mm grep -F "$PKG_NAME" /proc/mounts | while read -r line; do
done done
am force-stop "$PKG_NAME" am force-stop "$PKG_NAME"
if ! (pm path "$PKG_NAME" >/dev/null 2>&1 </dev/null); then pmex() {
if ! op=$(pm install-existing "$PKG_NAME" 2>&1 </dev/null) && echo "$op" | grep -qv NameNotFoundException; then OP=$(pm "$@" 2>&1 </dev/null)
ui_print "ERROR: install-existing failed" RET=$?
abort "$op" echo "$OP"
return $RET
}
if ! pmex path "$PKG_NAME" >/dev/null; then
if pmex install-existing "$PKG_NAME" >/dev/null; then
ui_print "* Installed existing $PKG_NAME"
fi fi
ui_print "* Installed existing $PKG_NAME"
fi fi
INS=true
IS_SYS=false IS_SYS=false
if BASEPATH=$(pm path "$PKG_NAME" 2>&1 </dev/null); then INS=true
if BASEPATH=$(pmex path "$PKG_NAME"); then
echo >&2 "'$BASEPATH'"
BASEPATH=${BASEPATH##*:} BASEPATH=${BASEPATH%/*} BASEPATH=${BASEPATH##*:} BASEPATH=${BASEPATH%/*}
if echo "$BASEPATH" | grep -qF -e '/system/' -e '/product/'; then if echo "$BASEPATH" | grep -qF -e '/system/' -e '/product/'; then
ui_print "* $PKG_NAME is a system app" ui_print "* $PKG_NAME is a system app."
if [ "${BASEPATH:1:6}" != system ]; then BASEPATH=/system${BASEPATH}; fi
IS_SYS=true IS_SYS=true
elif [ ! -d "${BASEPATH}/lib" ]; then
ui_print "* Invalid installation found. Uninstalling..."
if ! op=$(pm uninstall -k --user 0 "$PKG_NAME" 2>&1 </dev/null); then
abort "$op"
fi
elif [ ! -f "$MODPATH/$PKG_NAME.apk" ]; then elif [ ! -f "$MODPATH/$PKG_NAME.apk" ]; then
ui_print "* Stock $PKG_NAME APK was not found" ui_print "* Stock $PKG_NAME APK was not found"
VERSION=$(dumpsys package "$PKG_NAME" | grep -m1 versionName) VERSION="${VERSION#*=}" VERSION=$(dumpsys package "$PKG_NAME" | grep -m1 versionName) VERSION="${VERSION#*=}"
@ -67,7 +63,7 @@ if BASEPATH=$(pm path "$PKG_NAME" 2>&1 </dev/null); then
module: $PKG_VER module: $PKG_VER
" "
fi fi
elif cmpr "$BASEPATH/base.apk" "$MODPATH/$PKG_NAME.apk"; then elif "${MODPATH:?}/bin/$ARCH/cmpr" "$BASEPATH/base.apk" "$MODPATH/$PKG_NAME.apk"; then
ui_print "* $PKG_NAME is up-to-date" ui_print "* $PKG_NAME is up-to-date"
INS=false INS=false
fi fi
@ -81,33 +77,34 @@ install() {
VERIF_ADB=$(settings get global verifier_verify_adb_installs) VERIF_ADB=$(settings get global verifier_verify_adb_installs)
settings put global verifier_verify_adb_installs 0 settings put global verifier_verify_adb_installs 0
SZ=$(stat -c "%s" "$MODPATH/$PKG_NAME.apk") SZ=$(stat -c "%s" "$MODPATH/$PKG_NAME.apk")
for _ in 1 2; do
while true; do if ! SES=$(pmex install-create --user 0 -i com.android.vending -r -d -S "$SZ"); then
if ! SES=$(pm install-create --user 0 -i com.android.vending -r -d -S "$SZ" 2>&1 </dev/null); then
ui_print "ERROR: install-create failed" ui_print "ERROR: install-create failed"
settings put global verifier_verify_adb_installs "$VERIF_ADB" settings put global verifier_verify_adb_installs "$VERIF_ADB"
abort "$SES" abort "$SES"
fi fi
SES=${SES#*[} SES=${SES%]*} SES=${SES#*[} SES=${SES%]*}
set_perm "$MODPATH/$PKG_NAME.apk" 1000 1000 644 u:object_r:apk_data_file:s0 set_perm "$MODPATH/$PKG_NAME.apk" 1000 1000 644 u:object_r:apk_data_file:s0
if ! op=$(pm install-write -S "$SZ" "$SES" "$PKG_NAME.apk" "$MODPATH/$PKG_NAME.apk" 2>&1 </dev/null); then if ! op=$(pmex install-write -S "$SZ" "$SES" "$PKG_NAME.apk" "$MODPATH/$PKG_NAME.apk"); then
ui_print "ERROR: install-write failed" ui_print "ERROR: install-write failed"
settings put global verifier_verify_adb_installs "$VERIF_ADB" settings put global verifier_verify_adb_installs "$VERIF_ADB"
abort "$op" abort "$op"
fi fi
if ! op=$(pm install-commit "$SES" 2>&1 </dev/null); then if ! op=$(pmex install-commit "$SES"); then
if echo "$op" | grep -q INSTALL_FAILED_VERSION_DOWNGRADE; then if echo "$op" | grep -q INSTALL_FAILED_VERSION_DOWNGRADE; then
ui_print "* ERROR: INSTALL_FAILED_VERSION_DOWNGRADE" ui_print "* Handling INSTALL_FAILED_VERSION_DOWNGRADE.."
if [ "$IS_SYS" = true ]; then if [ "$IS_SYS" = true ]; then
ui_print "* Use system mount mode" mkdir -p /data/adb/rvhc/empty /data/adb/post-fs-data.d
BASEPATH=${MODPATH}${BASEPATH} SCNM="/data/adb/post-fs-data.d/$PKG_NAME-uninstall.sh"
set_perm "$BASEPATH" 1000 1000 755 u:object_r:system_file:s0 echo "mount -o bind /data/adb/rvhc/empty $BASEPATH" >"$SCNM"
RVPATH=$BASEPATH/${BASEPATH##*/}.apk chmod +x "$SCNM"
rm "$MODPATH/service.sh" "$MODPATH/uninstall.sh" ui_print "* Created the uninstall script."
break ui_print ""
ui_print "* Reboot and reflash the module!"
abort
else else
ui_print "* Uninstalling..." ui_print "* Uninstalling..."
if ! op=$(pm uninstall -k --user 0 "$PKG_NAME" 2>&1 </dev/null); then if ! op=$(pmex uninstall -k --user 0 "$PKG_NAME"); then
ui_print "$op" ui_print "$op"
fi fi
continue continue
@ -117,9 +114,10 @@ install() {
settings put global verifier_verify_adb_installs "$VERIF_ADB" settings put global verifier_verify_adb_installs "$VERIF_ADB"
abort "$op" abort "$op"
fi fi
if BASEPATH=$(pm path "$PKG_NAME" 2>&1 </dev/null); then if BASEPATH=$(pmex path "$PKG_NAME"); then
BASEPATH=${BASEPATH##*:} BASEPATH=${BASEPATH%/*} BASEPATH=${BASEPATH##*:} BASEPATH=${BASEPATH%/*}
else else
settings put global verifier_verify_adb_installs "$VERIF_ADB"
abort "ERROR: install $PKG_NAME manually and reflash the module" abort "ERROR: install $PKG_NAME manually and reflash the module"
fi fi
break break
@ -138,28 +136,26 @@ if [ -z "$(ls -A1 "$BASEPATHLIB")" ]; then
fi fi
set_perm_recursive "${BASEPATH}/lib" 1000 1000 755 755 u:object_r:apk_data_file:s0 set_perm_recursive "${BASEPATH}/lib" 1000 1000 755 755 u:object_r:apk_data_file:s0
fi fi
if [ "$IS_SYS" = false ]; then mkdir -p "/data/adb/rvhc"; fi ui_print "* Setting Permissions"
set_perm "$MODPATH/base.apk" 1000 1000 644 u:object_r:apk_data_file:s0
ui_print "* Mounting $PKG_NAME"
mkdir -p "/data/adb/rvhc"
RVPATH=/data/adb/rvhc/${MODPATH##*/}.apk
mv -f "$MODPATH/base.apk" "$RVPATH" mv -f "$MODPATH/base.apk" "$RVPATH"
ui_print "* Setting Permissions" if ! op=$(mm mount -o bind "$RVPATH" "$BASEPATH/base.apk" 2>&1); then
set_perm "$RVPATH" 1000 1000 644 u:object_r:apk_data_file:s0 ui_print "ERROR: Mount failed!"
ui_print "$op"
if [ "$IS_SYS" = false ]; then
ui_print "* Mounting $PKG_NAME"
if ! op=$(mm mount -o bind "$RVPATH" "$BASEPATH/base.apk" 2>&1); then
ui_print "ERROR: Mount failed!"
ui_print "$op"
fi
am force-stop "$PKG_NAME"
ui_print "* Optimizing $PKG_NAME"
nohup cmd package compile --reset "$PKG_NAME" >/dev/null 2>&1 &
fi fi
am force-stop "$PKG_NAME"
ui_print "* Optimizing $PKG_NAME"
nohup cmd package compile --reset "$PKG_NAME" >/dev/null 2>&1 &
ui_print "* Cleanup" ui_print "* Cleanup"
rm -rf "${MODPATH:?}/bin" "$MODPATH/$PKG_NAME.apk" rm -rf "${MODPATH:?}/bin" "$MODPATH/$PKG_NAME.apk"
if [ -d "/data/adb/modules/zygisk-assistant" ]; then if [ "$KSU" ] && [ -d "/data/adb/modules/zygisk-assistant" ]; then
ui_print "* If you are using zygisk-assistant, you need to" ui_print "* If you are using zygisk-assistant, you need to"
ui_print " give root permissions to $PKG_NAME" ui_print " give root permissions to $PKG_NAME"
fi fi

View File

@ -11,21 +11,21 @@ while
[ $svcl = 20 ] [ $svcl = 20 ]
do sleep 2; done do sleep 2; done
sleep 5 sleep 5
if [ $svcl != 0 ]; then
err "app not installed"
exit
fi
BASEPATH=${BASEPATH##*:} BASEPATH=${BASEPATH%/*}
err() { err() {
[ ! -f "$MODDIR/err" ] && cp "$MODDIR/module.prop" "$MODDIR/err" [ ! -f "$MODDIR/err" ] && cp "$MODDIR/module.prop" "$MODDIR/err"
sed -i "s/^des.*/description=⚠️ Needs reflash: '${1}'/g" "$MODDIR/module.prop" sed -i "s/^des.*/description=⚠️ Needs reflash: '${1}'/g" "$MODDIR/module.prop"
} }
if [ $svcl != 0 ]; then
err "app not installed"
exit
fi
BASEPATH=${BASEPATH##*:} BASEPATH=${BASEPATH%/*}
if [ ! -d "$BASEPATH/lib" ]; then if [ ! -d "$BASEPATH/lib" ]; then
err "system force-rebooted (fix your ROM)" ls -Zla "$BASEPATH" >"$MODDIR/log.txt"
exit ls -Zla "$BASEPATH/lib" >>"$MODDIR/log.txt"
fi else rm "$MODDIR/log.txt"; fi
VERSION=$(dumpsys package "$PKG_NAME" | grep -m1 versionName) VERSION="${VERSION#*=}" VERSION=$(dumpsys package "$PKG_NAME" | grep -m1 versionName) VERSION="${VERSION#*=}"
if [ "$VERSION" != "$PKG_VER" ] && [ "$VERSION" ]; then if [ "$VERSION" != "$PKG_VER" ] && [ "$VERSION" ]; then
err "version mismatch (installed:${VERSION}, module:$PKG_VER)" err "version mismatch (installed:${VERSION}, module:$PKG_VER)"

View File

@ -1,6 +1,9 @@
#!/system/bin/sh #!/system/bin/sh
{ {
MODDIR=${0%/*} MODDIR=${0%/*}
rm "/data/adb/rvhc/${MODDIR##*/}".apk . "$MODDIR/config"
rm "/data/adb/rvhc/${MODDIR##*/}.apk"
rmdir "/data/adb/rvhc" rmdir "/data/adb/rvhc"
rm "/data/adb/post-fs-data.d/$PKG_NAME-uninstall.sh"
} & } &