MODPATH="${0%/*}" . $MODPATH/common_func.sh if [ -d "/data/adb/modules/tricky_store" ]; then mv /data/adb/tricky_store/keybox.xml /data/adb/tricky_store/keybox.xml.orig cp "$MODPATH"/keybox.xml /data/adb/tricky_store/keybox.xml fi # Conditional sensitive properties # Magisk Recovery Mode resetprop_if_match ro.boot.mode recovery unknown resetprop_if_match ro.bootmode recovery unknown resetprop_if_match vendor.boot.mode recovery unknown # SELinux resetprop_if_diff ro.boot.selinux enforcing # use delete since it can be 0 or 1 for enforcing depending on OEM if [ -n "$(resetprop ro.build.selinux)" ]; then resetprop --delete ro.build.selinux fi # use toybox to protect stat access time reading if [ "$(toybox cat /sys/fs/selinux/enforce)" = "0" ]; then chmod 640 /sys/fs/selinux/enforce chmod 440 /sys/fs/selinux/policy fi # Conditional late sensitive properties until [ "$(getprop sys.boot_completed)" = "1" ]; do sleep 1 done # SafetyNet/Play Integrity + OEM # avoid bootloop on some Xiaomi devices resetprop_if_diff ro.secureboot.lockstate locked # avoid breaking Realme fingerprint scanners resetprop_if_diff ro.boot.flash.locked 1 resetprop_if_diff ro.boot.realme.lockstate 1 # avoid breaking Oppo fingerprint scanners resetprop_if_diff ro.boot.vbmeta.device_state locked # avoid breaking OnePlus display modes/fingerprint scanners resetprop_if_diff vendor.boot.verifiedbootstate green # avoid breaking OnePlus/Oppo fingerprint scanners on OOS/ColorOS 12+ resetprop_if_diff ro.boot.verifiedbootstate green resetprop_if_diff ro.boot.veritymode enforcing resetprop_if_diff vendor.boot.vbmeta.device_state locked # Other resetprop_if_diff sys.oem_unlock_allowed 0