diff --git a/restore.sh b/restore.sh index f664dfc..b3d6105 100755 --- a/restore.sh +++ b/restore.sh @@ -1360,10 +1360,14 @@ ipsw_verify() { local ipsw_dl="$1" local build_id="$2" log "Verifying $ipsw_dl.ipsw..." - local IPSWSHA1=$(cat "$device_fw_dir/$build_id/sha1sum") + local IPSWSHA1=$(cat "$device_fw_dir/$build_id/sha1sum" 2>/dev/null) + if [[ -z $IPSWSHA1 ]]; then + IPSWSHA1="$(curl https://api.ipsw.me/v2.1/$device_type/$build_id/sha1sum)" + fi local IPSWSHA1L=$($sha1sum "$ipsw_dl.ipsw" | awk '{print $1}') if [[ $IPSWSHA1L != "$IPSWSHA1" ]]; then if [[ -z $3 ]]; then + log "SHA1sum mismatch. Expected $IPSWSHA1, got $IPSWSHA1L" warn "Verifying IPSW failed. Your IPSW may be corrupted or incomplete. Make sure to download and select the correct IPSW." pause fi @@ -1523,6 +1527,9 @@ ipsw_prepare_32bit_keys() { fi ;; esac + if [[ $comp == "KernelCache" && $vers == "5"* ]]; then + return + fi echo -e "Decrypt" >> $NewPlist } @@ -2964,21 +2971,18 @@ menu_ipsw_browse() { pause return fi + ipsw_verify "$newpath" "$device_base_build" ipsw_base_path="$newpath" return ;; esac - if [[ -z $versionc ]]; then - ipsw_path="$newpath" - return - fi - if [[ $device_target_vers != "$versionc" ]]; then + if [[ -n $versionc && $device_target_vers != "$versionc" ]]; then log "Selected IPSW ($device_target_vers) does not match target version ($versionc)." pause return fi ipsw_verify "$newpath" "$device_target_build" - if [[ $? != 0 ]]; then + if [[ -n $versionc && $? != 0 ]]; then return fi ipsw_path="$newpath"