From 1388fc395ec01cb0acad5d779de0c24d5b7989e1 Mon Sep 17 00:00:00 2001 From: Didgeridoohan Date: Thu, 19 Apr 2018 05:13:40 +0200 Subject: [PATCH] v2.1.0-v8 --- README.md | 25 +++++--- common/post-fs-data.sh | 36 +++++++----- common/prints.sh | 2 + common/propsconf_late | 11 ++-- common/util_functions.sh | 46 ++++++++++++--- config.sh | 2 +- module.prop | 4 +- system/binpath/props | 124 +++++++++++++++++++++------------------ 8 files changed, 157 insertions(+), 93 deletions(-) diff --git a/README.md b/README.md index 1297e9c..3cc9369 100644 --- a/README.md +++ b/README.md @@ -20,7 +20,7 @@ props You can also run the command with options. Use -h for details. -## Spoofing device's fingerprint +## Spoofing device's fingerprint to pass the ctsProfile check If your device can't pass SafetyNet fully, the CTS profile check fails while basic integrity passes, that means MagiskHide is working on your device but Google doesn't recognise your device as being certified. This might be because your device simply hasn't been certified or that the ROM you are using on your device isn't recognised by Google (because it's a custom ROM). @@ -47,9 +47,9 @@ Google Nexus 6=google/shamu/shamu:7.1.1/N8I11B/4171878:user/release-keys ## Current fingerprints list version The fingerprints list will update without the need to update the entire module. Keep an eye on the [module support thread](https://forum.xda-developers.com/apps/magisk/module-magiskhide-props-config-simple-t3765199) for info. -Just run the `props` command and the list will be updated automatically. Use the -nw option to disable or disable it completely in the script settings (see below). +Just run the `props` command and the list will be updated automatically. Use the -nw option to disable or disable it completely in the script settings (see below). If you've disabled the this setting you can update the list manually in the `Edit device fingerprint` menu. -**_Current fingerprints list version - v7_** +**_Current fingerprints list version - v8_** ## Improved root hiding - Editing build.prop and default.prop @@ -72,7 +72,7 @@ It's quite easy to change prop values with Magisk. With this module it's even ea ## Prop script settings -There are a couple of persistent options that you can set for the `props` script. These are currently "Colour" and "Fingerprints list check". The colour option disables or enables colours for the script, and the fingerprints list check option disables or enables automatic updating of the fingerprints list when the script starts. If the fingerprints list check is disabled, the list can be manually updated from within the script, under the "Device fingerprint" menu. +There are a couple of persistent options that you can set for the `props` script. These are currently "Colour" and "Fingerprints list check". The colour option disables or enables colours for the script, and the fingerprints list check option disables or enables automatic updating of the fingerprints list when the script starts. If the fingerprints list check is disabled, the list can be manually updated from within the script, under the `Edit device fingerprint` menu. ## Configuration file @@ -87,7 +87,7 @@ Place a file named `reset_mhpc` in /cache (or /data/cache on A/B devices) and re It is possible to use this in combination with the configuration file described above to keep device fingerprint or any other settings intact past the reset. Just make sure to remove any custom props that might have been causing issues from the configuration file. -## Certifying your device +## Keeping your device "certified" If you're using a custom ROM, the chances of it being [perceived as uncertified by Google](https://www.xda-developers.com/google-blocks-gapps-uncertified-devices-custom-rom-whitelist/) are pretty high. If your ROM has a build date later than March 16 2018, this might mean that you can't even log into your Google account or use Gapps without [whitelisting your device with Google](https://www.google.com/android/uncertified/) first. Magisk, and this module, can help with that. @@ -107,7 +107,7 @@ But first: have you tried turning it off and on again? Toggling MagiskHide off a If you have questions, suggestions or are experiencing some kind of issue, visit the [module support thread](https://forum.xda-developers.com/apps/magisk/module-magiskhide-props-config-simple-t3765199) @ XDA. ### Logs, etc -In case of issues, please provide the logs, saved in /cache, "propsconf.log" and "propsconf_last.log", together with a detailed description of your problem. Providing the output from terminal might also be useful. +In case of issues, please provide the logs, saved in /cache, "magisk.log", "propsconf.log" and "propsconf_last.log", together with a detailed description of your problem. Providing the output from terminal might also be useful. ## Source @@ -116,10 +116,17 @@ In case of issues, please provide the logs, saved in /cache, "propsconf.log" and ## Credits @topjohnwu @ XDA Developers, for Magisk -@Zackptg5, @veez21 and @jenslody @ XDA Developers, for inspiration +@Zackptg5, @veez21 and @jenslody @ XDA Developers, for help and inspiration ## Changelog +### v2.1.0 +- "Improved hiding" will now also mask the device fingerprint in build.prop. Please disable and reapply to set. +- Fixed colour code issues if running the script with ADB Shell. Huge shout-out to @veez21 over at XDA Developers. +- Fixed typo in A/B device detection. Thank you to @JayminSuthar over at XDA Developers. +- New fingerprints (Samsung Galaxy S4 and Sony Xperia Z3 Tablet Compact), list v8. +- Minor fixes and improvements. + ### v2.0.0 - Added a function for setting your own custom prop values. - Added a function for setting values by configuration file. Useful if you want to make a ROM pass the ctsProfile check out of the box. @@ -150,7 +157,7 @@ In case of issues, please provide the logs, saved in /cache, "propsconf.log" and ## Current fingerprints list -### List v7   +### List v8   - Google Nexus 6 (7.1.1) - Google Pixel (8.1.0) - Google Pixel 2 (P DP1) @@ -168,6 +175,7 @@ In case of issues, please provide the logs, saved in /cache, "propsconf.log" and - Samsung Galaxy Note 3 (7.1.1) - Samsung Galaxy Note 4 (6.0.1) - Samsung Galaxy Note 5 (7.0) +- Samsung Galaxy S4 (5.0.1) - Samsung Galaxy S6 (5.0.2) - Samsung Galaxy S7 (7.0) - Samsung Galaxy S7 Edge (7.0) @@ -177,6 +185,7 @@ In case of issues, please provide the logs, saved in /cache, "propsconf.log" and - Sony Xperia XZ (8.0.0) - Sony Xperia XZ1 Compact (8.0.0) - Sony Xperia Z3 (6.0.1) +- Sony Xperia Z3 Tablet Compact (6.0.1) - Sony Xperia Z5 (7.1.1) - Sony Xperia Z5 Compact (7.1.1) - Sony Xperia Z5 Dual (7.1.1) diff --git a/common/post-fs-data.sh b/common/post-fs-data.sh index f1d31e8..0247cac 100644 --- a/common/post-fs-data.sh +++ b/common/post-fs-data.sh @@ -15,6 +15,10 @@ IMGPATH=$(dirname "$MODPATH") # Load functions . $MODPATH/util_functions.sh +# Clears out the script check file +rm -f $RUNFILE +touch $RUNFILE + # Saves the previous log (if available) and creates a new one if [ -f "$LOGFILE" ]; then mv -f $LOGFILE $LASTLOGFILE @@ -24,7 +28,7 @@ echo "***************************************************" >> $LOGFILE echo "******** MagiskHide Props Config $MODVERSION ********" >> $LOGFILE echo "**************** By Didgeridoohan ***************" >> $LOGFILE echo "***************************************************" >> $LOGFILE -log_handler "Log start." +log_script_chk "Log start." # Check for boot scripts and restore backup if deleted, or if the resetfile is present if [ ! -f "$LATEFILE" ] || [ -f "$RESETFILE" ]; then @@ -124,33 +128,37 @@ if [ "$(get_file_value $LATEFILE "FILESAFE=")" == 0 ]; then log_handler "Stock build.prop copied from /system." # Edits the module copy of build.prop - MODULETYPE=$(get_file_value $LATEFILE "MODULETYPE=") - MODULETAGS=$(get_file_value $LATEFILE "MODULETAGS=") - MODULESELINUX=$(get_file_value $LATEFILE "MODULESELINUX=") + module_values log_handler "Editing build.prop." if [ "$MODULETYPE" ]; then - SEDTYPE=$MODULETYPE + SEDTYPE="$MODULETYPE" else - SEDTYPE=user + SEDTYPE="user" fi if [ "$(get_file_value $LATEFILE "SETTYPE=")" == "true" ]; then - sed -i "s/ro.build.type=$FILETYPE/ro.build.type=$SEDTYPE/" $MODPATH/system/build.prop && log_handler "ro.build.type" + sed -i "s/ro.build.type=$FILETYPE/ro.build.type=$SEDTYPE/" $MODPATH/system/build.prop && log_handler "ro.build.type=$SEDTYPE" fi if [ "$MODULETAGS" ]; then - SEDTAGS=$MODULETAGS + SEDTAGS="$MODULETAGS" else - SEDTAGS=release-keys + SEDTAGS="release-keys" fi if [ "$(get_file_value $LATEFILE "SETTAGS=")" == "true" ]; then - sed -i "s/ro.build.tags=$FILETAGS/ro.build.tags=$SEDTAGS/" $MODPATH/system/build.prop && log_handler "ro.build.tags" + sed -i "s/ro.build.tags=$FILETAGS/ro.build.tags=$SEDTAGS/" $MODPATH/system/build.prop && log_handler "ro.build.tags=$SEDTAGS" fi if [ "$MODULESELINUX" ]; then - SEDSELINUX=$MODULESELINUX + SEDSELINUX="$MODULESELINUX" else - SEDSELINUX=0 + SEDSELINUX="0" fi if [ "$(get_file_value $LATEFILE "SETSELINUX=")" == "true" ]; then - sed -i "s/ro.build.selinux=$FILESELINUX/ro.build.selinux=$SEDSELINUX/" $MODPATH/system/build.prop && log_handler "ro.build.selinux" + sed -i "s/ro.build.selinux=$FILESELINUX/ro.build.selinux=$SEDSELINUX/" $MODPATH/system/build.prop && log_handler "ro.build.selinux=$SEDSELINUX" + fi + if [ "$(get_file_value $LATEFILE "SETFINGERPRINT=")" == "true" ] && [ "$MODULEFINGERPRINT" ]; then + PRINTSTMP="$(cat /system/build.prop | grep "$CURRFINGERPRINT")" + for ITEM in $PRINTSTMP; do + sed -i "s@${ITEM}@$(get_eq_left $ITEM)=${MODULEFINGERPRINT}@" $MODPATH/system/build.prop && log_handler "$(get_eq_left $ITEM)=$MODULEFINGERPRINT" + done fi else rm -f $MODPATH/system/build.prop @@ -161,4 +169,4 @@ else log_handler "Prop file editing disabled. All values ok." fi -log_handler "post-fs-data.sh finished.\n\n====================" +log_script_chk "post-fs-data.sh finished.\n\n====================" diff --git a/common/prints.sh b/common/prints.sh index 9daaf4c..c42372c 100644 --- a/common/prints.sh +++ b/common/prints.sh @@ -27,6 +27,7 @@ Samsung Galaxy Grand Prime (5.0.2)=samsung/fortuna3gdtvvj/fortuna3gdtv:5.0.2/LRX Samsung Galaxy Note 3 (7.1.1)=samsung/greatltexx/greatlte:7.1.1/NMF26X/N950FXXU1AQHA:user/release-keys Samsung Galaxy Note 4 (6.0.1)=samsung/trltexx/trlte:6.0.1/MMB29M/N910FXXS1DQH9:user/release-keys Samsung Galaxy Note 5 (7.0)=samsung/nobleltejv/noblelte:7.0/NRD90M/N920CXXU3CQH6:user/release-keys +Samsung Galaxy S4 (5.0.1)=samsung/jfltexx/jflte:5.0.1/LRX22C/I9505XXUHPF4:user/release-keys Samsung Galaxy S6 (5.0.2)=samsung/zerofltexx/zeroflte:5.0.2/LRX22G/G920FXXU1AOD4:user/release-keys Samsung Galaxy S7 (7.0)=samsung/heroltexx/herolte:7.0/NRD90M/G930FXXU2DRB6:user/release-keys Samsung Galaxy S7 Edge (7.0)=samsung/hero2ltexx/hero2lte:7.0/NRD90M/G935FXXU2DRB6:user/release-keys @@ -36,6 +37,7 @@ Sony Xperia X Performance (8.0.0)=Sony/F8131/F8131:8.0.0/41.3.A.2.99/1455830589: Sony Xperia XZ (8.0.0)=Sony/F8331/F8331:8.0.0/41.3.A.2.99/1455830589:user/release-keys Sony Xperia XZ1 Compact (8.0.0)=Sony/G8441/G8441:8.0.0/47.1.A.12.119/1601781803:user/release-keys Sony Xperia Z3 (6.0.1)=Sony/D6633/D6633:6.0.1/23.5.A.1.291/2769308465:user/release-keys +Sony Xperia Z3 Tablet Compact (6.0.1)=Sony/SGP621/SGP621:6.0.1/23.5.A.1.291/3706784398:user/release-keys Sony Xperia Z5 (7.1.1)=Sony/E6603/E6603:7.1.1/32.4.A.1.54/3761073091:user/release-keys Sony Xperia Z5 Compact (7.1.1)=Sony/E5823/E5823:7.1.1/32.4.A.1.54/3761073091:user/release-keys Sony Xperia Z5 Dual (7.1.1)=Sony/E6633/E6633:7.1.1/32.4.A.1.54/3761073091:user/release-keys diff --git a/common/propsconf_late b/common/propsconf_late index 9fad973..7315191 100644 --- a/common/propsconf_late +++ b/common/propsconf_late @@ -9,7 +9,7 @@ # In that case, feel free to delete it. # Script version -SCRIPTV=2 +SCRIPTV=3 SETTRANSF=1 # Variables @@ -50,7 +50,7 @@ if [ -d "$MODPATH" ]; then # Load functions . $MODPATH/util_functions.sh - log_handler "Running boot script." + log_script_chk "Running boot script." if [ -f "$MODPATH/disable" ]; then log_handler "Module disabled." @@ -97,6 +97,7 @@ if [ -d "$MODPATH" ]; then SETTYPE=false SETTAGS=false SETSELINUX=false + SETFINGERPRINT=false # ---Setting/Changing props--- # Set/change MagiskHide sensitive props @@ -145,7 +146,7 @@ if [ -d "$MODPATH" ]; then SEDDEBUGGABLE="0" fi if [ "$SETDEBUGGABLE" == "true" ]; then - sed -i "s/ro.debuggable=$FILEDEBUGGABLE/ro.debuggable=$SEDDEBUGGABLE/" /default.prop && log_handler "ro.debuggable" + sed -i "s/ro.debuggable=$FILEDEBUGGABLE/ro.debuggable=$SEDDEBUGGABLE/" /default.prop && log_handler "ro.debuggable=$SEDDEBUGGABLE" fi if [ "$MODULESECURE" ]; then SEDSECURE="$MODULESECURE" @@ -153,14 +154,14 @@ if [ -d "$MODPATH" ]; then SEDSECURE="1" fi if [ "$SETSECURE" == "true" ]; then - sed -i "s/ro.secure=$FILESECURE/ro.secure=$SEDSECURE/" /default.prop && log_handler "ro.secure" + sed -i "s/ro.secure=$FILESECURE/ro.secure=$SEDSECURE/" /default.prop && log_handler "ro.secure=$SEDSECURE" fi mount -ro remount rootfs / else log_handler "Default.prop editing disabled." fi fi - log_handler "Boot script finished.\n\n==================" + log_script_chk "Boot script finished.\n\n==================" fi else # Cleanup diff --git a/common/util_functions.sh b/common/util_functions.sh index cc367ac..a448221 100644 --- a/common/util_functions.sh +++ b/common/util_functions.sh @@ -8,6 +8,7 @@ MODVERSION=VER_PLACEHOLDER POSTFILE=$IMGPATH/.core/post-fs-data.d/propsconf_post LATEFILE=$IMGPATH/.core/service.d/propsconf_late CACHELOC=CACHE_PLACEHOLDER +RUNFILE=$MODPATH/script_check LOGFILE=$CACHELOC/propsconf.log LASTLOGFILE=$CACHELOC/propsconf_last.log CONFFILE=$CACHELOC/propsconf_conf @@ -55,12 +56,19 @@ log_print() { echo "$1" log_handler "$1" } +log_script_chk() { + log_handler "$1" + echo -e "$(date +"%m-%d-%Y %H:%M:%S") - $1" >> $RUNFILE +} #Divider DIVIDER="${Y}=====================================${N}" # Header menu_header() { + if [ -z "$LOGNAME" ]; then + clear + fi if [ "$MODVERSION" == "VER_PLACEHOLDER" ]; then VERSIONTXT="" else @@ -126,6 +134,17 @@ orig_check() { done } +script_ran_check() { + POSTCHECK=0 + if [ "$(cat $RUNFILE | grep "post-fs-data.sh finished")" ]; then + POSTCHECK=1 + fi + LATECHECK=0 + if [ "$(cat $RUNFILE | grep "Boot script finished")" ]; then + LATECHECK=1 + fi +} + # Currently set values curr_values() { CURRDEBUGGABLE=$(resetprop ro.debuggable) @@ -339,7 +358,9 @@ config_file() { # ======================== Fingerprint functions ======================== # Checks and updates the prints list download_prints() { - clear + if [ -z "$LOGNAME" ]; then + clear + fi menu_header "Updating fingerprints list" echo "" log_print "Checking list version." @@ -366,6 +387,8 @@ download_prints() { fi if [ "$1" == "manual" ]; then sleep 2 + else + sleep 0.5 fi } @@ -408,17 +431,19 @@ change_print() { reset_prop_files() { log_handler "Resetting prop files$3." - # Changes file + # Changes files for PROPTYPE in $PROPSLIST; do log_handler "Disabling prop file editing for '$PROPTYPTE'." PROP=$(get_prop_type $PROPTYPE) FILEPROP=$(echo "FILE$PROP" | tr '[:lower:]' '[:upper:]') SETPROP=$(echo "SET$PROP" | tr '[:lower:]' '[:upper:]') - sed -i "s/$SETPROP=true/$SETPROP=false/" $LATEFILE - sed -i 's/BUILDEDIT=1/BUILDEDIT=0/' $LATEFILE - sed -i 's/DEFAULTEDIT=1/DEFAULTEDIT=0/' $LATEFILE done + # Change fingerprint + sed -i "s/SETFINGERPRINT=true/SETFINGERPRINT=false/" $LATEFILE + # Edit settings variables + sed -i 's/BUILDEDIT=1/BUILDEDIT=0/' $LATEFILE + sed -i 's/DEFAULTEDIT=1/DEFAULTEDIT=0/' $LATEFILE if [ "$1" != "file" ]; then after_change_file "$1" "$2" @@ -436,6 +461,13 @@ edit_prop_files() { ro.debuggable ro.secure " + else + # Checking if the device fingerprint is set by the module + if [ "$(get_file_value $LATEFILE "FINGERPRINTENB=")" == 1 ] && [ "$(get_file_value $LATEFILE "PRINTEDIT=")" == 1 ]; then + if [ "$(cat /system/build.prop | grep "$ORIGFINGERPRINT")" ]; then + sed -i "s/SETFINGERPRINT=false/SETFINGERPRINT=true/" $LATEFILE + fi + fi fi for PROPTYPE in $PROPSLIST; do @@ -467,9 +499,9 @@ edit_prop_files() { else log_handler "Couldn't check safe value for '$PROPTYPE'." fi - sed -i 's/DEFAULTEDIT=0/DEFAULTEDIT=1/' $LATEFILE - sed -i 's/BUILDEDIT=0/BUILDEDIT=1/' $LATEFILE done + sed -i 's/DEFAULTEDIT=0/DEFAULTEDIT=1/' $LATEFILE + sed -i 's/BUILDEDIT=0/BUILDEDIT=1/' $LATEFILE if [ "$1" != "file" ]; then after_change_file "$1" "$2" diff --git a/config.sh b/config.sh index 3785e56..6dc7da6 100644 --- a/config.sh +++ b/config.sh @@ -275,7 +275,7 @@ ab_check() { if [ -z $SLOT ]; then CACHELOC=/cache else - CACHELOC/data/cache + CACHELOC=/data/cache fi } diff --git a/module.prop b/module.prop index edead7f..01bc94c 100644 --- a/module.prop +++ b/module.prop @@ -1,7 +1,7 @@ id=MagiskHidePropsConf name=MagiskHide Props Config -version=v2.0.0-v7 -versionCode=5 +version=v2.1.0-v8 +versionCode=6 author=Didgeridoohan description=Change your device's fingerprint, to pass SafetyNet's CTS Profile check. Edit prop files for better root hiding. Set/reset prop values set by MagiskHide. Change any prop values easily. minMagisk=1500 diff --git a/system/binpath/props b/system/binpath/props index 361e008..c112767 100644 --- a/system/binpath/props +++ b/system/binpath/props @@ -11,7 +11,7 @@ IMGPATH=IMG_PLACEHOLDER MODPATH=$IMGPATH/MagiskHidePropsConf # Colours -if [ "$(cat $IMGPATH/.core/service.d/propsconf_late | grep "OPTIONCOLOUR=" | sed 's/.*=//' | sed 's/\"//g')" == 0 ]; then +if [ "$(cat $IMGPATH/.core/service.d/propsconf_late | grep "OPTIONCOLOUR=" | sed 's/.*=//' | sed 's/\"//g')" == 0 ] || [ "$LOGNAME" ]; then COLOURCHK="nc" else COLOURCHK="$1" @@ -92,7 +92,6 @@ reboot_fn() { else REBOOTTXT="Reboot - " fi - clear menu_header "$REBOOTTXT${C}$1${N}" echo "" if [ "$2" != "reset-script" ] && [ "$2" != "reboot" ]; then @@ -147,7 +146,6 @@ reboot_fn() { } exit_fn() { - clear menu_header "${C}Bye bye.${N}" echo "" log_handler "Exiting... Bye bye." @@ -161,7 +159,6 @@ menu_change_fingerprint() { while true do if [ -z "$INPUT2" ]; then - clear menu_header "${C}$1${N}" echo "" if [ "$(get_file_value $LATEFILE "FINGERPRINTENB=")" == 0 ]; then @@ -202,6 +199,9 @@ menu_change_fingerprint() { fi echo "${G}b${N} - Go back." echo "" + echo "See the module readme or the" + echo "support thread @ XDA for details." + echo "" echo -n "Enter '${G}e${N}' to exit: " read -r INPUT2 fi @@ -249,7 +249,6 @@ menu_pick_print() { TMPOEMLIST=$(echo $(printf '%s\n' $OEMLIST | sort -u)) OEMLIST="$TMPOEMLIST" ITEMCOUNT=1 - clear menu_header "${C}$1${N}\n List version - v$(get_file_value $PRINTSLOC "PRINTSV=")\n Select an option below." echo "" for ITEM in $OEMLIST; do @@ -288,7 +287,6 @@ menu_pick_print_sub() { do if [ -z "$INPUT4" ]; then ITEMCOUNT=1 - clear menu_header "${C}$1${N}\n List version - v$(get_file_value $PRINTSLOC "PRINTSV=")\n Select an option below." echo "" SAVEIFS=$IFS @@ -337,7 +335,6 @@ menu_new_print() { while true do if [ -z "$INPUT5" ]; then - clear menu_header "${C}$1${N}" echo "" echo "You are about to use the following as your device's fingerprint." @@ -374,7 +371,6 @@ menu_reset_print() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}" echo "" echo "This will reset the device" @@ -408,7 +404,6 @@ menu_update_print() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}\n List version - v$(get_file_value $PRINTSLOC "PRINTSV=")" echo "" echo "Do you want to check online if there" @@ -442,7 +437,6 @@ menu_edit_prop_files() { while true do if [ -z "$INPUT2" ]; then - clear menu_header "${C}$1${N}" echo "" # Checks if file values are "safe" @@ -486,6 +480,15 @@ menu_edit_prop_files() { echo "" fi echo "Do you want to continue?" + if [ "$(get_file_value $LATEFILE "BUILDEDIT=")" == 1 ] || [ "$(get_file_value $LATEFILE "DEFAULTEDIT=")" == 1 ]; then + echo "" + echo "Enter ${G}r${N} to re-apply the settings." + echo "This option is only useful if there's been" + echo "an update to the \"Improved hiding\" feature." + fi + echo "" + echo "See the module readme or the" + echo "support thread @ XDA for details." echo "" if [ "$2" == "p" ]; then echo -n "Enter ${G}y${N}(es) or ${G}n${N}(o): " @@ -518,6 +521,13 @@ menu_edit_prop_files() { break fi ;; + r) + if [ "$(get_file_value $LATEFILE "BUILDEDIT=")" == 1 ] || [ "$(get_file_value $LATEFILE "DEFAULTEDIT=")" == 1 ]; then + edit_prop_files "$1" "$2" "$LOGTXT" + else + invalid_input $INV1 $INV2 + fi + ;; e) if [ "$2" == "p" ]; then invalid_input $INV1 $INV2 @@ -559,9 +569,10 @@ menu_magiskhide_props() { if [ "$(get_file_value $LATEFILE "RESELINUX=")" == "true" ]; then SELINUXTXT=$ACTIVE fi - clear menu_header "${C}$1${N}\n Select an option below:" echo "" + echo "Change the sensitive props set by MagiskHide." + echo "" echo "${G}1${N} - ro.debuggable${DEBUGGABLETXT}" echo "${G}2${N} - ro.secure${SECURETXT}" echo "${G}3${N} - ro.build.type${TYPETXT}" @@ -572,6 +583,9 @@ menu_magiskhide_props() { fi echo "${G}b${N} - Go back to main menu" echo "" + echo "See the module readme or the" + echo "support thread @ XDA for details." + echo "" echo -n "Enter '${G}e${N}' to exit: " read -r INPUT2 fi @@ -613,7 +627,6 @@ menu_change_prop() { if [ -z "$INPUT3" ]; then PROP=$(get_prop_type "$1") REPROP=$(echo "RE${PROP}" | tr '[:lower:]' '[:upper:]') - clear menu_header "${C}$1${N}" echo "" # Checks if the prop exists @@ -676,7 +689,6 @@ menu_reset_prop_all() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}" echo "" echo "This will reset all prop" @@ -710,7 +722,6 @@ menu_reset_prop() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}" echo "" echo "This will reset $2" @@ -746,9 +757,10 @@ menu_custom_props() { do if [ -z "$INPUT2" ]; then ITEMCOUNT=1 - clear menu_header "${C}$1${N}\n Select an option below:" echo "" + echo "Set or edit custom prop values for your device." + echo "" if [ "$CUSTOMPROPS" ]; then for ITEM in $CUSTOMPROPS; do echo "${G}$ITEMCOUNT${N} - $(get_eq_left $ITEM)" @@ -766,6 +778,9 @@ menu_custom_props() { fi echo "${G}b${N} - Go back to main menu" echo "" + echo "See the module readme or the" + echo "support thread @ XDA for details." + echo "" echo -n "Enter '${G}e${N}' to exit: " read -r INPUT2 fi @@ -810,7 +825,6 @@ menu_edit_custprop() { break fi done - clear menu_header "${C}$1${N}" echo "" echo "The current value for ${C}'$1'${N} is:" @@ -865,7 +879,6 @@ menu_new_custprop() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}" echo "" echo "Enter the prop to set," @@ -899,7 +912,6 @@ menu_reset_all_custprop() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}" echo "" echo "This will reset all" @@ -934,7 +946,6 @@ menu_magiskhide_custprop() { while true do if [ -z "$INPUT4" ]; then - clear menu_header "${C}$1${N}" echo "" echo "That prop, ${C}$1${N}, is one of" @@ -966,7 +977,6 @@ menu_set_new_custprop() { while true do if [ -z "$INPUT4" ]; then - clear menu_header "${C}$1${N}" echo "" echo "Enter the value to set ${C}$1${N} to," @@ -1007,7 +1017,6 @@ menu_reset_custprop() { while true do if [ -z "$INPUT4" ]; then - clear menu_header "${C}$1${N}" echo "" echo "This will reset ${C}$1${N}" @@ -1043,7 +1052,6 @@ menu_set_custprop() { while true do if [ -z "$INPUT5" ]; then - clear menu_header "${C}$1${N}" echo "" echo "This will set ${C}$1${N} to:" @@ -1097,23 +1105,25 @@ menu_options() { PRINTSCHKTXT="disabled" CP=${R} fi - clear menu_header "${C}$1${N}\n Select an option below:" echo "" - echo "${G}1${N} - Colour ${CC}(${COLOURTXT})${N}" + echo "${G}1${N} - Script colours ${CC}(${COLOURTXT})${N}" echo "${G}2${N} - Fingerprints list check ${CP}(${PRINTSCHKTXT})${N}" - echo "${G}r${N} - Reset all options" + echo "${G}r${N} - Reset all settings" echo "${G}b${N} - Go back to main menu" echo "" + echo "See the module readme or the" + echo "support thread @ XDA for details." + echo "" echo -n "Enter '${G}e${N}' to exit: " read -r INPUT2 fi case "$INPUT2" in - 1) menu_options_colour "Colour" "$COLOURTXT" + 1) menu_options_colour "Script colours" "$COLOURTXT" ;; 2) menu_options_printschk "Fingerprints list check" "$PRINTSCHKTXT" ;; - r) menu_options_reset "Reset all options" + r) menu_options_reset "Reset all settings" ;; b) INPUT="" @@ -1142,12 +1152,11 @@ menu_options_colour() { OPTCURR=0 OPTNEW=1 fi - clear menu_header "${C}$1${N}" echo "" - echo "Colour is currently ${G}$2${N}." + echo "Script colours are currently ${G}$2${N}d." echo "" - echo "Do you want to ${C}$TMPTXT${N} it?" + echo "Do you want to ${C}$TMPTXT${N} them?" echo "" echo -n "Enter ${G}y${N}(es), ${G}n${N}(o) or ${G}e${N}(xit): " read -r INPUT3 @@ -1186,7 +1195,6 @@ menu_options_printschk() { OPTCURR=0 OPTNEW=1 fi - clear menu_header "${C}$1${N}" echo "" echo "Automatic updating of the fingerprints" @@ -1222,10 +1230,9 @@ menu_options_reset() { while true do if [ -z "$INPUT3" ]; then - clear menu_header "${C}$1${N}" echo "" - echo "This will reset all script options" + echo "This will reset all script settings" echo "to their default values." echo "" echo "Do you want to continue?" @@ -1235,7 +1242,7 @@ menu_options_reset() { fi case "$INPUT3" in y) - log_handler "Resetting all script options." + log_handler "Resetting all script settings." OPTCCURR=$(get_file_value $LATEFILE "OPTIONCOLOUR=") OPTWCURR=$(get_file_value $LATEFILE "OPTIONWEB=") sed -i "s@OPTIONCOLOUR=$OPTCCURR@OPTIONCOLOUR=1@" $LATEFILE @@ -1255,18 +1262,17 @@ menu_options_reset() { done } -# ======================== Reset all settings ======================== -# Second menu level - Reset all settings +# ======================== Reset all options and settings ======================== +# Second menu level - Reset all options and settings reset_everything() { INPUT2="" while true do if [ -z "$INPUT2" ]; then - clear menu_header "${C}$1${N}" echo "" - echo "All module settings will be" - echo "reset to initial values." + echo "All module options and settings" + echo "will be reset to the default values." echo "" echo "Do you want to continue?" echo "" @@ -1316,7 +1322,6 @@ reset_everything() { # ==================================================== if [ $(id -u) != 0 ] ; then - clear menu_header "${C}This script must be run with\n superuser access. Try again.${N}" echo "" exit 0 @@ -1337,6 +1342,16 @@ if [ "$ORIGLOAD" == 0 ]; then reboot_fn "The original prop values are not loaded,\n possibly due to a full reset of the module.\n\n Please reboot your device to reset." "reset-script" fi +script_ran_check +if [ "$POSTCHECK" == 0 ]; then + log_handler "The post-fs-data script did not run during boot." + reboot_fn "The post-fs-data boot script does not appear to have run during boot.\n\n That means the module won't work.\n\n Please reboot your device and see if\n it does run. If it doesn't, please\n report the issue, ${R}with logs${N}." "reset-script" +fi +if [ "$LATECHECK" == 0 ]; then + log_handler "The settings boot script did not run during boot." + reboot_fn "The settings boot script does not\n appear to have run during boot.\n\n That means the module won't work.\n\n Please reboot your device and see if\n it does run. If it doesn't, please\n report the issue, ${R}with logs${N}." "reset-script" +fi + # ================================================== # ================ Find used values ================ # ================================================== @@ -1349,7 +1364,6 @@ all_values case "$1" in -h) - clear menu_header "${C}Help${N}" echo "" echo $(echo $(get_file_value $MODPATH/module.prop "description=") | sed 's/, /,\\n/g' | sed 's/\. /\.\\n/g') @@ -1358,10 +1372,10 @@ case "$1" in echo "" echo "Options:" echo " -h Show this message." - echo " -nw Turn off fingerprint startup check." echo " -nc Turn off colours." - echo " -p Edit prop files." - echo " -r Reset all settings." + echo " -nw Turn off fingerprint startup check." + echo " -p Improved hiding (edit prop files)." + echo " -r Reset all options/settings." echo "" echo "See the module readme or the" echo "support thread @ XDA for details." @@ -1396,7 +1410,6 @@ if [ "$1" ]; then *h*|*nw*|*nc*|*p*|*r*) # Do nothing ;; *) - clear menu_header "${C}Help${N}" echo "" echo "${R}Invalid option.${N}" @@ -1446,19 +1459,18 @@ do if [ "$(get_file_value $LATEFILE "CUSTOMEDIT=")" == 1 ]; then CUSTTXT=$ACTIVE fi - clear menu_header "Select an option below." echo "" - echo "${G}1${N} - Device fingerprint${PRINTTXT}" - echo "${G}2${N} - Edit prop files${FILETXT}" - echo "${G}3${N} - MagiskHide props${PROPTXT}" - echo "${G}4${N} - Custom props${CUSTTXT}" - echo "${G}5${N} - Options" - echo "${G}r${N} - Reset all settings" + echo "${G}1${N} - Edit device fingerprint${PRINTTXT}" + echo "${G}2${N} - Improved hiding${FILETXT}" + echo "${G}3${N} - Edit MagiskHide props${PROPTXT}" + echo "${G}4${N} - Add/edit custom props${CUSTTXT}" + echo "${G}5${N} - Script settings" + echo "${G}r${N} - Reset all options/settings" echo "${G}b${N} - Reboot device" echo "" if [ "$(get_file_value $LATEFILE "REBOOTCHK=")" == 1 ]; then - echo "${R}Some settings have been changed.${N}" + echo "${R}Some options/settings have been changed.${N}" echo "${R}Please reboot for them to take affect.${N}" echo "" fi @@ -1471,15 +1483,15 @@ do case "$INPUT" in 1) menu_change_fingerprint "ro.build.fingerprint${PRINTTXT}" $CURRFINGERPRINT $ORIGFINGERPRINT $MODULEFINGERPRINT ;; - 2) menu_edit_prop_files "Edit prop files${FILETXT}" + 2) menu_edit_prop_files "Improved hiding${FILETXT}" ;; 3) menu_magiskhide_props "MagiskHide props${PROPTXT}" ;; 4) menu_custom_props "Custom props${CUSTTXT}" ;; - 5) menu_options "Options" + 5) menu_options "Script settings" ;; - r) reset_everything "Reset all settings" + r) reset_everything "Reset all options/settings" ;; b) reboot_fn "Reboot device" "reboot" ;;