2023-11-29 12:19:14 +08:00
|
|
|
# Conditional sensitive properties
|
2023-11-25 03:58:30 +08:00
|
|
|
|
2023-11-29 12:19:14 +08:00
|
|
|
resetprop_if_diff() {
|
|
|
|
local NAME=$1
|
|
|
|
local EXPECTED=$2
|
|
|
|
local CURRENT=$(resetprop $NAME)
|
2024-01-12 20:32:32 +08:00
|
|
|
|
2024-02-03 22:24:43 +08:00
|
|
|
[ -z "$CURRENT" ] || [ "$CURRENT" == "$EXPECTED" ] || resetprop $NAME $EXPECTED
|
2023-11-25 03:58:30 +08:00
|
|
|
}
|
2023-12-01 01:28:01 +08:00
|
|
|
|
2023-11-29 12:19:14 +08:00
|
|
|
resetprop_if_match() {
|
|
|
|
local NAME=$1
|
|
|
|
local CONTAINS=$2
|
|
|
|
local VALUE=$3
|
2024-01-12 20:32:32 +08:00
|
|
|
|
2024-02-03 22:24:43 +08:00
|
|
|
[[ "$(resetprop $NAME)" == *"$CONTAINS"* ]] && resetprop $NAME $VALUE
|
2023-11-29 12:19:14 +08:00
|
|
|
}
|
|
|
|
|
2023-11-25 03:58:30 +08:00
|
|
|
# Magisk recovery mode
|
2023-11-29 12:19:14 +08:00
|
|
|
resetprop_if_match ro.bootmode recovery unknown
|
|
|
|
resetprop_if_match ro.boot.mode recovery unknown
|
|
|
|
resetprop_if_match vendor.boot.mode recovery unknown
|
2023-11-25 03:58:30 +08:00
|
|
|
|
2023-11-29 12:19:14 +08:00
|
|
|
# SELinux
|
2023-11-30 00:49:52 +08:00
|
|
|
if [ -n "$(resetprop ro.build.selinux)" ]; then
|
|
|
|
resetprop --delete ro.build.selinux
|
2023-11-29 17:10:07 +08:00
|
|
|
fi
|
2023-12-01 01:28:01 +08:00
|
|
|
|
2023-11-29 12:19:14 +08:00
|
|
|
# use toybox to protect *stat* access time reading
|
|
|
|
if [ "$(toybox cat /sys/fs/selinux/enforce)" == "0" ]; then
|
2023-11-25 09:13:22 +08:00
|
|
|
chmod 640 /sys/fs/selinux/enforce
|
|
|
|
chmod 440 /sys/fs/selinux/policy
|
|
|
|
fi
|
|
|
|
|
2024-02-07 18:48:47 +08:00
|
|
|
# must be set after boot_completed for various OEMs
|
|
|
|
until [ "$(getprop sys.boot_completed)" == "1" ]; do
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
|
|
|
|
# RootBeer, Microsoft
|
|
|
|
resetprop_if_diff ro.build.tags release-keys
|
|
|
|
|
|
|
|
# Samsung
|
|
|
|
resetprop_if_diff ro.boot.warranty_bit 0
|
|
|
|
resetprop_if_diff ro.vendor.boot.warranty_bit 0
|
|
|
|
resetprop_if_diff ro.vendor.warranty_bit 0
|
|
|
|
resetprop_if_diff ro.warranty_bit 0
|
|
|
|
|
|
|
|
# Xiaomi
|
|
|
|
resetprop_if_diff ro.secureboot.lockstate locked
|
|
|
|
|
|
|
|
# Realme
|
|
|
|
resetprop_if_diff ro.boot.realmebootstate green
|
|
|
|
|
|
|
|
# OnePlus
|
|
|
|
resetprop_if_diff ro.is_ever_orange 0
|
|
|
|
|
|
|
|
# Other
|
|
|
|
resetprop_if_diff ro.build.type user
|
|
|
|
resetprop_if_diff ro.debuggable 0
|
|
|
|
resetprop_if_diff ro.secure 1
|
2023-12-28 08:18:58 +08:00
|
|
|
|
2024-02-07 18:48:47 +08:00
|
|
|
# avoid breaking Realme fingerprint scanners
|
|
|
|
resetprop_if_diff ro.boot.flash.locked 1
|
|
|
|
resetprop_if_diff ro.boot.realme.lockstate 1
|
2024-01-12 20:32:32 +08:00
|
|
|
|
2024-02-07 18:48:47 +08:00
|
|
|
# avoid breaking Oppo fingerprint scanners
|
|
|
|
resetprop_if_diff ro.boot.vbmeta.device_state locked
|
2024-01-12 20:32:32 +08:00
|
|
|
|
2024-02-07 18:48:47 +08:00
|
|
|
# avoid breaking OnePlus display modes/fingerprint scanners
|
|
|
|
resetprop_if_diff vendor.boot.verifiedbootstate green
|
2024-01-12 20:32:32 +08:00
|
|
|
|
2024-02-07 18:48:47 +08:00
|
|
|
# avoid breaking OnePlus/Oppo display 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
|