2019-11-22 11:48:41 +01:00
#!/bin/bash
2020-07-23 02:47:36 +02:00
trap 'Clean; exit' INT TERM EXIT
2019-11-22 11:48:41 +01:00
2020-07-23 02:47:36 +02:00
function Clean {
rm -rf iP*/ tmp/ $( ls *_${ ProductType } _${ OSVer } -*.shsh2 2>/dev/null) $( ls *_${ ProductType } _${ OSVer } -*.shsh 2>/dev/null) $( ls *.im4p 2>/dev/null) $( ls *.bbfw 2>/dev/null) BuildManifest.plist
2020-03-09 02:30:19 +01:00
}
2020-07-23 02:47:36 +02:00
function Error {
2020-07-30 17:09:34 +02:00
echo -e " \n[Error] $1 "
2020-07-23 02:47:36 +02:00
[ [ ! -z $2 ] ] && echo " * $2 "
2020-07-30 17:09:34 +02:00
echo
2020-07-23 02:47:36 +02:00
exit
2020-03-09 02:30:19 +01:00
}
2020-04-01 04:49:55 +02:00
function Log {
2020-04-16 12:29:11 +02:00
echo " [Log] $1 "
2020-04-01 04:49:55 +02:00
}
2020-07-23 02:47:36 +02:00
function Main {
clear
echo "******* iOS-OTA-Downgrader *******"
echo " Downgrader script by LukeZGD "
echo
2020-07-27 15:42:41 +02:00
2020-08-14 05:57:20 +02:00
if [ [ $OSTYPE = = "linux-gnu" ] ] ; then
platform = 'linux'
bspatch = "bspatch"
ideviceenterrecovery = "ideviceenterrecovery"
ideviceinfo = "ideviceinfo"
iproxy = "iproxy"
irecovery = "sudo LD_LIBRARY_PATH=/usr/local/lib irecovery"
lsusb = "lsusb"
python = "python2"
2020-08-16 09:09:55 +02:00
futurerestore1 = "sudo LD_PRELOAD=resources/lib/libcurl.so.3 LD_LIBRARY_PATH=resources/lib resources/tools/futurerestore1_linux"
futurerestore2 = "sudo LD_LIBRARY_PATH=resources/lib resources/tools/futurerestore2_linux"
tsschecker = "env LD_LIBRARY_PATH=resources/lib resources/tools/tsschecker_linux"
2020-08-14 10:07:14 +02:00
if [ [ $UBUNTU_CODENAME = = "bionic" ] ] ; then
futurerestore2 = " ${ futurerestore2 } _bionic "
tsschecker = " ${ tsschecker } _bionic "
fi
2020-08-14 05:57:20 +02:00
elif [ [ $OSTYPE = = "darwin" * ] ] ; then
platform = 'macos'
bspatch = "resources/tools/bspatch_macos"
ideviceenterrecovery = "resources/libimobiledevice/ideviceenterrecovery"
ideviceinfo = "resources/libimobiledevice/ideviceinfo"
iproxy = "resources/libimobiledevice/iproxy"
irecovery = "resources/tools/irecovery_macos"
2020-08-14 19:10:52 +02:00
lsusb = "system_profiler SPUSBDataType 2>/dev/null"
2020-08-14 05:57:20 +02:00
python = "python"
2020-08-14 10:07:14 +02:00
futurerestore1 = "resources/tools/futurerestore1_macos"
futurerestore2 = "resources/tools/futurerestore2_macos"
2020-08-17 08:14:08 +02:00
tsschecker = "resources/tools/tsschecker_macos"
2020-08-14 05:57:20 +02:00
fi
2020-08-16 13:25:32 +02:00
partialzip = " resources/tools/partialzip_ $platform "
2020-07-27 13:27:46 +02:00
2020-08-14 05:57:20 +02:00
[ [ ! $platform ] ] && Error "OSTYPE unknown/not supported." "Supports Linux and macOS only"
[ [ ! $( ping -c1 google.com 2>/dev/null) ] ] && Error "Please check your Internet connection before proceeding."
[ [ $( uname -m) != 'x86_64' ] ] && Error "Only x86_64 distributions are supported. Use a 64-bit distro and try again"
DFUDevice = $( $lsusb | grep -c '1227' )
RecoveryDevice = $( $lsusb | grep -c '1281' )
if [ [ $1 = = Install ] ] || [ ! $( which $bspatch ) ] || [ ! $( which $ideviceinfo ) ] ||
2020-08-14 06:43:30 +02:00
[ ! $( which git) ] || [ ! $( which ssh) ] || [ ! $( which $python ) ] ; then
2020-07-23 02:47:36 +02:00
InstallDependencies
elif [ $DFUDevice = = 1 ] || [ $RecoveryDevice = = 1 ] ; then
2020-08-16 09:09:55 +02:00
ProductType = $( sudo LD_LIBRARY_PATH = resources/lib resources/tools/igetnonce_$platform 2>/dev/null)
2020-07-23 14:08:16 +02:00
[ ! $ProductType ] && read -p "[Input] Enter ProductType (eg. iPad2,1): " ProductType
2020-07-27 13:27:46 +02:00
UniqueChipID = $( $irecovery -q | grep 'ECID' | cut -c 7-)
2020-07-23 04:08:46 +02:00
ProductVer = 'Unknown'
2020-07-23 02:47:36 +02:00
else
2020-08-14 05:57:20 +02:00
ideviceinfo2 = $( $ideviceinfo -s)
HWModel = $( echo " $ideviceinfo2 " | grep 'HardwareModel' | cut -c 16- | tr '[:upper:]' '[:lower:]' | sed 's/.\{2\}$//' )
ProductType = $( echo " $ideviceinfo2 " | grep 'ProductType' | cut -c 14-)
[ ! $ProductType ] && ProductType = $( $ideviceinfo | grep 'ProductType' | cut -c 14-)
ProductVer = $( echo " $ideviceinfo2 " | grep 'ProductVer' | cut -c 17-)
2020-07-23 02:47:36 +02:00
VersionDetect = $( echo $ProductVer | cut -c 1)
2020-08-14 05:57:20 +02:00
UniqueChipID = $( echo " $ideviceinfo2 " | grep 'UniqueChipID' | cut -c 15-)
UniqueDeviceID = $( echo " $ideviceinfo2 " | grep 'UniqueDeviceID' | cut -c 17-)
2020-07-23 02:47:36 +02:00
fi
2020-07-27 15:42:41 +02:00
[ ! $ProductType ] && ProductType = 0
2020-08-14 06:27:55 +02:00
SaveExternal iOS-OTA-Downgrader-Keys
SaveExternal ipwndfu
2020-07-23 04:08:46 +02:00
BasebandDetect
2020-07-27 15:42:41 +02:00
Clean
mkdir tmp
2020-07-30 17:09:34 +02:00
chmod +x resources/tools/*
2020-07-23 02:47:36 +02:00
2020-07-30 17:09:34 +02:00
if [ [ $DFUDevice = = 1 ] ] && [ [ $A7Device != 1 ] ] ; then
2020-08-16 06:23:07 +02:00
DFUManual = 1
2020-08-12 16:05:51 +02:00
Mode = 'Downgrade'
Log "32-bit device in DFU mode detected."
2020-08-16 06:23:07 +02:00
echo "* Advanced options menu - use at your own risk"
echo "* Warning: A6 devices won't have activation error workaround yet when using this method"
2020-08-12 16:05:51 +02:00
echo "[Input] This device is in:"
2020-08-16 06:23:07 +02:00
select opt in "kDFU mode" "DFU mode (ipwndfu A6)" "pwnDFU mode (checkm8 A5)" "(Any other key to exit)" ; do
2020-08-12 16:05:51 +02:00
case $opt in
"kDFU mode" ) Log " Downgrading $ProductType in kDFU mode... " ; break; ;
2020-08-16 06:23:07 +02:00
"DFU mode (ipwndfu A6)" ) CheckM8; break; ;
"pwnDFU mode (checkm8 A5)" ) kDFU iBSS; break; ;
2020-08-12 16:05:51 +02:00
* ) exit; ;
esac
done
SelectVersion
2020-07-30 17:09:34 +02:00
elif [ [ $RecoveryDevice = = 1 ] ] && [ [ $A7Device != 1 ] ] ; then
2020-08-13 06:57:31 +02:00
Error "32-bit device detected in recovery mode. Please put the device in normal mode and jailbroken before proceeding" "For usage of 32-bit ipwndfu, put the device in DFU mode (A6) or pwnDFU mode (A5 using Arduino)"
2020-03-05 12:48:41 +01:00
fi
2020-03-10 03:55:04 +01:00
2020-07-30 17:09:34 +02:00
echo " * Platform: $platform "
2020-07-23 02:47:36 +02:00
echo " * HardwareModel: ${ HWModel } ap "
echo " * ProductType: $ProductType "
echo " * ProductVersion: $ProductVer "
echo " * UniqueChipID (ECID): $UniqueChipID "
2020-03-05 12:48:41 +01:00
echo
2020-07-23 04:08:46 +02:00
if [ [ $1 ] ] ; then
Mode = " $1 "
else
Selection = ( "Downgrade device" )
[ [ $A7Device != 1 ] ] && Selection += ( "Save OTA blobs" "Just put device in kDFU mode" )
Selection += ( "(Re-)Install Dependencies" "(Any other key to exit)" )
echo "*** Main Menu ***"
echo "[Input] Select an option:"
select opt in " ${ Selection [@] } " ; do
case $opt in
"Downgrade device" ) Mode = 'Downgrade' ; break; ;
"Save OTA blobs" ) Mode = 'SaveOTABlobs' ; break; ;
"Just put device in kDFU mode" ) Mode = 'kDFU' ; break; ;
2020-07-30 17:09:34 +02:00
"(Re-)Install Dependencies" ) InstallDependencies; ;
2020-07-23 04:08:46 +02:00
* ) exit; ;
esac
done
fi
2020-03-31 07:46:59 +02:00
SelectVersion
2020-03-05 12:48:41 +01:00
}
function SelectVersion {
2020-07-23 02:47:36 +02:00
if [ [ $ProductType = = iPad4* ] ] || [ [ $ProductType = = iPhone6* ] ] ; then
OSVer = '10.3.3'
BuildVer = '14G60'
2020-06-14 07:39:26 +02:00
Action
2020-07-27 14:07:21 +02:00
elif [ [ $Mode = = 'kDFU' ] ] ; then
Action
2020-07-23 02:47:36 +02:00
fi
Selection = ( "iOS 8.4.1" )
if [ $ProductType = = iPad2,1 ] || [ $ProductType = = iPad2,2 ] ||
[ $ProductType = = iPad2,3 ] || [ $ProductType = = iPhone4,1 ] ; then
2020-04-01 04:16:29 +02:00
Selection += ( "iOS 6.1.3" )
2020-03-05 12:48:41 +01:00
fi
2020-04-01 04:16:29 +02:00
[ [ $Mode = = 'Downgrade' ] ] && Selection += ( "Other" )
2020-07-27 13:27:46 +02:00
Selection += ( "(Any other key to exit)" )
2020-04-01 04:16:29 +02:00
echo "[Input] Select iOS version:"
select opt in " ${ Selection [@] } " ; do
case $opt in
2020-06-14 07:39:26 +02:00
"iOS 8.4.1" ) OSVer = '8.4.1' ; BuildVer = '12H321' ; break; ;
"iOS 6.1.3" ) OSVer = '6.1.3' ; BuildVer = '10B329' ; break; ;
"Other" ) OSVer = 'Other' ; break; ;
2020-07-23 02:47:36 +02:00
*) exit; ;
2020-04-01 04:16:29 +02:00
esac
done
2020-03-05 12:48:41 +01:00
Action
}
2020-06-14 07:39:26 +02:00
function Action {
2020-07-07 05:50:26 +02:00
Log " Option: $Mode "
if [ [ $OSVer = = 'Other' ] ] ; then
2020-07-23 02:47:36 +02:00
echo "* Move/copy the IPSW and SHSH to the directory where the script is located"
2020-07-27 15:42:41 +02:00
echo "* Reminder to create a backup of the SHSH"
2020-06-14 07:39:26 +02:00
read -p "[Input] Path to IPSW (drag IPSW to terminal window): " IPSW
2020-07-13 15:27:43 +02:00
IPSW = " $( basename $IPSW .ipsw) "
2020-06-14 07:39:26 +02:00
read -p "[Input] Path to SHSH (drag SHSH to terminal window): " SHSH
2020-07-23 04:08:46 +02:00
elif [ [ $A7Device = = 1 ] ] && [ [ $pwnDFUDevice != 1 ] ] ; then
2020-07-30 17:09:34 +02:00
[ [ $DFUDevice = = 1 ] ] && CheckM8 || Recovery
2020-06-14 07:39:26 +02:00
fi
2020-07-23 02:47:36 +02:00
if [ $ProductType = = iPod5,1 ] ; then
2020-07-30 13:31:55 +02:00
iBSS = " ${ HWModel } ap "
2020-07-06 14:19:35 +02:00
iBSSBuildVer = '10B329'
2020-07-23 02:47:36 +02:00
elif [ $ProductType = = iPad3,1 ] ; then
2020-07-30 13:31:55 +02:00
iBSS = " ${ HWModel } ap "
2020-07-06 14:19:35 +02:00
iBSSBuildVer = '11D257'
2020-07-23 02:47:36 +02:00
elif [ $ProductType = = iPhone6,1 ] || [ $ProductType = = iPhone6,2 ] ; then
2020-07-30 13:31:55 +02:00
iBSS = "iphone6"
2020-07-23 02:47:36 +02:00
elif [ $ProductType = = iPad4,1 ] || [ $ProductType = = iPad4,2 ] || [ $ProductType = = iPad4,3 ] ; then
2020-07-30 13:31:55 +02:00
iBSS = "ipad4"
2020-07-23 02:47:36 +02:00
elif [ $ProductType = = iPad4,4 ] || [ $ProductType = = iPad4,5 ] ; then
2020-07-30 13:31:55 +02:00
iBSS = "ipad4b"
2020-07-06 12:16:48 +02:00
else
2020-07-30 13:31:55 +02:00
iBSS = " $HWModel "
2020-07-06 14:19:35 +02:00
iBSSBuildVer = '12H321'
2020-07-06 12:16:48 +02:00
fi
2020-07-30 13:31:55 +02:00
iBEC = " iBEC. $iBSS .RELEASE "
iBSS = " iBSS. $iBSS .RELEASE "
2020-07-06 12:16:48 +02:00
2020-07-27 15:42:41 +02:00
[ [ $Mode = = 'Downgrade' ] ] && Downgrade
[ [ $Mode = = 'SaveOTABlobs' ] ] && SaveOTABlobs
[ [ $Mode = = 'kDFU' ] ] && kDFU
2020-04-01 05:17:19 +02:00
exit
2019-11-22 11:48:41 +01:00
}
2019-11-23 05:15:35 +01:00
function SaveOTABlobs {
2020-05-05 09:05:49 +02:00
Log " Saving $OSVer blobs with tsschecker... "
2020-07-23 02:47:36 +02:00
BuildManifest = " resources/manifests/BuildManifest_ ${ ProductType } _ ${ OSVer } .plist "
2020-07-25 05:23:31 +02:00
if [ [ $A7Device = = 1 ] ] ; then
2020-07-27 13:27:46 +02:00
APNonce = $( $irecovery -q | grep 'NONC' | cut -c 7-)
2020-07-23 02:47:36 +02:00
echo " * APNonce: $APNonce "
2020-07-27 13:27:46 +02:00
$tsschecker -d $ProductType -B ${ HWModel } ap -i $OSVer -e $UniqueChipID -m $BuildManifest --apnonce $APNonce -o -s
2020-07-31 03:06:21 +02:00
SHSH = $( ls *_${ ProductType } _${ HWModel } ap_${ OSVer } -*.shsh)
2020-07-23 02:47:36 +02:00
else
2020-07-27 13:27:46 +02:00
$tsschecker -d $ProductType -i $OSVer -e $UniqueChipID -m $BuildManifest -o -s
2020-07-23 02:47:36 +02:00
SHSH = $( ls *_${ ProductType } _${ OSVer } -*.shsh2)
fi
[ ! $SHSH ] && Error " Saving $OSVer blobs failed. Please run the script again " " It is also possible that $OSVer for $ProductType is no longer signed "
2020-03-29 05:53:53 +02:00
mkdir -p saved/shsh 2>/dev/null
cp " $SHSH " saved/shsh
2020-05-05 09:05:49 +02:00
Log " Successfully saved $OSVer blobs. "
2019-11-23 05:15:35 +01:00
}
2020-03-05 12:48:41 +01:00
function kDFU {
2020-03-29 07:05:45 +02:00
if [ ! -e saved/$ProductType /$iBSS .dfu ] ; then
2020-04-01 04:49:55 +02:00
Log "Downloading iBSS..."
2020-08-16 13:25:32 +02:00
$partialzip $( cat $Firmware /$iBSSBuildVer /url) Firmware/dfu/$iBSS .dfu $iBSS .dfu
2020-03-29 05:53:53 +02:00
mkdir -p saved/$ProductType 2>/dev/null
mv $iBSS .dfu saved/$ProductType
2020-03-10 03:55:04 +01:00
fi
2020-08-05 05:07:28 +02:00
[ [ ! -e saved/$ProductType /$iBSS .dfu ] ] && Error "Failed to save iBSS. Please run the script again"
2020-04-01 04:49:55 +02:00
Log "Patching iBSS..."
2020-08-14 05:57:20 +02:00
$bspatch saved/$ProductType /$iBSS .dfu tmp/pwnediBSS resources/patches/$iBSS .patch
2020-03-13 05:12:49 +01:00
2020-08-12 16:05:51 +02:00
if [ [ $1 = = iBSS ] ] ; then
cd resources/ipwndfu 2>/dev/null
Log "Booting iBSS..."
2020-08-14 05:57:20 +02:00
sudo $python ipwndfu -l ../../tmp/pwnediBSS
2020-08-12 16:08:14 +02:00
cd ../..
2020-08-12 16:05:51 +02:00
return $?
fi
2020-07-30 17:09:34 +02:00
[ [ $VersionDetect = = 1 ] ] && kloader = 'kloader_hgsp'
[ [ $VersionDetect = = 5 ] ] && kloader = 'kloader5'
[ [ ! $kloader ] ] && kloader = 'kloader'
2020-07-31 12:04:16 +02:00
2020-08-14 07:34:48 +02:00
[ ! $( which $iproxy ) ] && Error "iproxy cannot be found. Please re-install dependencies and try again" "./restore.sh Install"
2020-08-14 06:05:43 +02:00
$iproxy 2222 22 &
2020-07-31 03:06:21 +02:00
iproxyPID = $!
2020-08-14 05:57:20 +02:00
WifiAddr = $( echo " $ideviceinfo2 " | grep 'WiFiAddress' | cut -c 14-)
2020-07-31 12:04:16 +02:00
WifiAddrDecr = $( echo $( printf "%x\n" $( expr $( printf "%d\n" 0x$( echo " ${ WifiAddr } " | tr -d ':' ) ) - 1) ) | sed 's/\(..\)/\1:/g;s/:$//' )
echo '#!/bin/bash' > tmp/pwn.sh
echo " nvram wifiaddr= $WifiAddrDecr " >> tmp/pwn.sh
chmod +x tmp/pwn.sh
echo "* Make sure OpenSSH/Dropbear is installed on the device!"
2020-07-31 03:06:21 +02:00
Log "Copying stuff to device via SSH..."
echo "* (Enter root password of your iOS device when prompted, default is 'alpine')"
2020-07-31 12:04:16 +02:00
scp -P 2222 resources/tools/$kloader tmp/pwnediBSS tmp/pwn.sh root@127.0.0.1:/
2020-07-31 03:06:21 +02:00
[ $? = = 1 ] && Error "Cannot connect to device via SSH." "Please check your ~/.ssh/known_hosts file and try again"
Log "Entering kDFU mode..."
2020-07-31 12:04:16 +02:00
if [ [ $VersionDetect = = 1 ] ] ; then
ssh -p 2222 root@127.0.0.1 " /pwn.sh; / $kloader /pwnediBSS " &
else
ssh -p 2222 root@127.0.0.1 " / $kloader /pwnediBSS " &
fi
2020-01-08 00:17:00 +01:00
echo
2020-07-27 15:42:41 +02:00
echo "* Press POWER or HOME button when screen goes black on the device"
2020-05-08 03:46:30 +02:00
2020-04-01 04:49:55 +02:00
Log "Finding device in DFU mode..."
2019-12-15 04:52:10 +01:00
while [ [ $DFUDevice != 1 ] ] ; do
2020-08-14 05:57:20 +02:00
DFUDevice = $( $lsusb | grep -c '1227' )
2019-11-22 11:48:41 +01:00
sleep 2
done
2020-04-01 04:49:55 +02:00
Log "Found device in DFU mode."
2020-07-31 03:06:21 +02:00
kill $iproxyPID
2019-11-22 11:48:41 +01:00
}
2020-07-23 02:47:36 +02:00
function Recovery {
2020-08-14 05:57:20 +02:00
RecoveryDevice = $( $lsusb | grep -c '1281' )
2020-07-23 02:47:36 +02:00
if [ [ $RecoveryDevice != 1 ] ] ; then
Log "Entering recovery mode..."
2020-08-14 06:05:43 +02:00
$ideviceenterrecovery $UniqueDeviceID >/dev/null
2020-07-23 02:47:36 +02:00
while [ [ $RecoveryDevice != 1 ] ] ; do
2020-08-14 05:57:20 +02:00
RecoveryDevice = $( $lsusb | grep -c '1281' )
2020-07-23 02:47:36 +02:00
sleep 2
done
fi
Log "A7 device in recovery mode detected. Get ready to enter DFU mode"
read -p "[Input] Select Y to continue, N to exit recovery (Y/n) " RecoveryDFU
if [ [ $RecoveryDFU = = n ] ] || [ [ $RecoveryDFU = = N ] ] ; then
Log "Exiting recovery mode."
2020-07-27 13:27:46 +02:00
$irecovery -n
2020-07-23 02:47:36 +02:00
exit
fi
echo "* Hold POWER and HOME button for 10 seconds."
for i in { 10..01} ; do
echo -n " $i "
sleep 1
done
echo -e "\n* Release POWER and hold HOME button for 10 seconds."
for i in { 10..01} ; do
echo -n " $i "
2020-08-14 05:57:20 +02:00
DFUDevice = $( $lsusb | grep -c '1227' )
2020-07-27 15:42:41 +02:00
[ [ $DFUDevice = = 1 ] ] && CheckM8
2020-07-23 02:47:36 +02:00
sleep 1
done
2020-07-30 17:09:34 +02:00
Error "Failed to detect device in DFU mode. Please run the script again"
2020-07-23 02:47:36 +02:00
}
function CheckM8 {
2020-08-16 06:23:07 +02:00
DFUManual = 1
2020-08-12 16:05:51 +02:00
[ [ $A7Device = = 1 ] ] && echo -e "\n[Log] Device in DFU mode detected."
2020-07-23 02:47:36 +02:00
Log "Entering pwnDFU mode with ipwndfu..."
cd resources/ipwndfu
2020-08-14 05:57:20 +02:00
sudo $python ipwndfu -p
pwnDFUDevice = $( sudo $lsusb -v -d 05ac:1227 2>/dev/null | grep -c 'checkm8' )
2020-07-23 02:47:36 +02:00
if [ $pwnDFUDevice = = 1 ] ; then
2020-08-12 16:05:51 +02:00
Log "Device in pwnDFU mode detected."
if [ [ $A7Device = = 1 ] ] ; then
Log "Running rmsigchks.py..."
2020-08-14 05:57:20 +02:00
sudo $python rmsigchks.py
2020-08-12 16:05:51 +02:00
cd ../..
else
kDFU iBSS
fi
2020-07-23 02:47:36 +02:00
Log " Downgrading device $ProductType in pwnDFU mode... "
Mode = 'Downgrade'
SelectVersion
else
2020-08-01 07:31:37 +02:00
Error "Failed to detect device in pwnDFU mode. Please run the script again" "./restore.sh Downgrade"
2020-07-23 02:47:36 +02:00
fi
}
2020-03-31 08:05:29 +02:00
function Downgrade {
2020-07-23 02:47:36 +02:00
if [ [ $OSVer != 'Other' ] ] ; then
2020-07-30 17:09:34 +02:00
[ [ $ProductType = = iPad4* ] ] && IPSW = "iPad_64bit"
[ [ $ProductType = = iPhone6* ] ] && IPSW = "iPhone_64bit"
[ [ ! $IPSW ] ] && IPSW = " $ProductType " && SaveOTABlobs
2020-07-23 02:47:36 +02:00
IPSW = " ${ IPSW } _ ${ OSVer } _ ${ BuildVer } _Restore "
IPSWCustom = " ${ ProductType } _ ${ OSVer } _ ${ BuildVer } _Custom "
if [ ! -e $IPSW .ipsw ] ; then
2020-08-10 16:08:15 +02:00
Log " iOS $OSVer IPSW cannot be found. "
echo "* If you already downloaded the IPSW, did you put it in the same directory as the script?"
echo "* Do NOT rename the IPSW as the script will fail to detect it"
Log "Downloading IPSW... (Press Ctrl+C to cancel)"
2020-05-05 09:05:49 +02:00
curl -L $( cat $Firmware /$BuildVer /url) -o tmp/$IPSW .ipsw
2020-03-13 05:12:49 +01:00
mv tmp/$IPSW .ipsw .
2020-03-05 12:48:41 +01:00
fi
2020-07-23 02:47:36 +02:00
if [ ! -e $IPSWCustom .ipsw ] ; then
Log "Verifying IPSW..."
IPSWSHA1 = $( cat $Firmware /$BuildVer /sha1sum)
2020-08-11 02:57:18 +02:00
IPSWSHA1L = $( shasum $IPSW .ipsw | awk '{print $1}' )
2020-07-23 02:47:36 +02:00
[ [ $IPSWSHA1L != $IPSWSHA1 ] ] && Error "Verifying IPSW failed. Delete/replace the IPSW and run the script again"
else
IPSW = $IPSWCustom
fi
2020-07-25 05:23:31 +02:00
if [ ! $DFUManual ] && [ [ $iBSSBuildVer = = $BuildVer ] ] ; then
2020-04-08 14:01:21 +02:00
Log "Extracting iBSS from IPSW..."
mkdir -p saved/$ProductType 2>/dev/null
2020-07-23 02:47:36 +02:00
unzip -o -j $IPSW .ipsw Firmware/dfu/$iBSS .dfu -d saved/$ProductType
2020-04-08 14:01:21 +02:00
fi
2019-11-22 11:48:41 +01:00
fi
2020-03-05 12:48:41 +01:00
2020-07-23 02:47:36 +02:00
[ ! $DFUManual ] && kDFU
2020-03-05 12:48:41 +01:00
2020-04-01 04:49:55 +02:00
Log "Extracting IPSW..."
2020-07-23 02:47:36 +02:00
unzip -q $IPSW .ipsw -d $IPSW /
2020-07-25 05:23:31 +02:00
if [ [ $A7Device = = 1 ] ] ; then
2020-07-23 02:47:36 +02:00
if [ ! -e $IPSWCustom .ipsw ] ; then
Log "Preparing custom IPSW..."
cp $IPSW /Firmware/all_flash/$SEP .
2020-08-14 05:57:20 +02:00
$bspatch $IPSW /Firmware/dfu/$iBSS .im4p $iBSS .im4p resources/patches/$iBSS .patch
$bspatch $IPSW /Firmware/dfu/$iBEC .im4p $iBEC .im4p resources/patches/$iBEC .patch
2020-07-23 02:47:36 +02:00
cp -f $iBSS .im4p $iBEC .im4p $IPSW /Firmware/dfu
cd $IPSW
2020-07-27 13:27:46 +02:00
zip ../$IPSWCustom .ipsw -rq0 *
2020-07-23 02:47:36 +02:00
cd ..
mv $IPSW $IPSWCustom
IPSW = $IPSWCustom
else
cp $IPSW /Firmware/dfu/$iBSS .im4p .
cp $IPSW /Firmware/dfu/$iBEC .im4p .
cp $IPSW /Firmware/all_flash/$SEP .
fi
2020-08-01 07:31:37 +02:00
Log "Entering pwnREC mode..."
2020-07-27 13:27:46 +02:00
$irecovery -f $iBSS .im4p
$irecovery -f $iBEC .im4p
2020-07-23 02:47:36 +02:00
sleep 5
2020-08-14 05:57:20 +02:00
RecoveryDevice = $( $lsusb | grep -c '1281' )
2020-08-01 07:31:37 +02:00
if [ [ $RecoveryDevice != 1 ] ] ; then
echo "[Error] Failed to detect device in pwnREC mode."
echo "* If you device has backlight turned on, you may try re-plugging in your device and attempt to continue"
echo "* Press ENTER to continue (or press Ctrl+C to cancel)"
2020-08-04 11:48:10 +02:00
read -s
Log "Finding device in pwnREC mode..."
while [ [ $RecoveryDevice != 1 ] ] ; do
2020-08-14 05:57:20 +02:00
RecoveryDevice = $( $lsusb | grep -c '1281' )
2020-08-04 11:48:10 +02:00
sleep 2
done
2020-08-01 07:31:37 +02:00
fi
2020-08-04 11:48:10 +02:00
Log "Found device in pwnREC mode."
2020-07-23 02:47:36 +02:00
SaveOTABlobs
fi
2020-03-10 03:55:04 +01:00
2020-06-14 07:39:26 +02:00
Log "Preparing for futurerestore... (Enter root password of your PC/Mac when prompted)"
2020-03-05 12:48:41 +01:00
cd resources
2020-08-14 05:57:20 +02:00
sudo bash -c " $python -m SimpleHTTPServer 80 & "
2020-03-05 12:48:41 +01:00
cd ..
2020-03-29 05:53:53 +02:00
if [ $Baseband = = 0 ] ; then
2020-04-01 04:49:55 +02:00
Log " Device $ProductType has no baseband "
Log "Proceeding to futurerestore..."
2020-07-25 05:23:31 +02:00
if [ [ $A7Device = = 1 ] ] ; then
2020-07-30 17:09:34 +02:00
$futurerestore2 -t $SHSH -s $SEP -m $BuildManifest --no-baseband $IPSW .ipsw
2020-07-23 02:47:36 +02:00
else
2020-07-30 17:09:34 +02:00
$futurerestore1 -t $SHSH --no-baseband --use-pwndfu $IPSW .ipsw
2020-07-23 02:47:36 +02:00
fi
2020-03-29 05:53:53 +02:00
else
2020-07-25 05:23:31 +02:00
if [ [ $A7Device = = 1 ] ] ; then
2020-07-23 02:47:36 +02:00
cp $IPSW /Firmware/$Baseband .
2020-07-25 07:19:19 +02:00
elif [ ! -e saved/$ProductType /*.bbfw ] ; then
2020-04-01 04:49:55 +02:00
Log "Downloading baseband..."
2020-08-16 13:25:32 +02:00
$partialzip $BasebandURL Firmware/$Baseband $Baseband
$partialzip $BasebandURL BuildManifest.plist BuildManifest.plist
2020-03-29 05:53:53 +02:00
mkdir -p saved/$ProductType 2>/dev/null
2020-07-23 02:47:36 +02:00
cp $Baseband BuildManifest.plist saved/$ProductType
2020-03-05 12:48:41 +01:00
else
2020-03-29 05:53:53 +02:00
cp saved/$ProductType /*.bbfw saved/$ProductType /BuildManifest.plist .
2020-03-05 12:48:41 +01:00
fi
2020-08-11 02:57:18 +02:00
BasebandSHA1L = $( shasum $Baseband | awk '{print $1}' )
2020-07-27 13:27:46 +02:00
Log "Proceeding to futurerestore..."
2020-07-25 07:19:19 +02:00
if [ ! -e *.bbfw ] || [ [ $BasebandSHA1L != $BasebandSHA1 ] ] ; then
2020-07-23 02:47:36 +02:00
rm -f saved/$ProductType /*.bbfw saved/$ProductType /BuildManifest.plist
2020-05-08 03:46:30 +02:00
echo "[Error] Downloading/verifying baseband failed."
2020-07-23 02:47:36 +02:00
echo "* Your device is still in kDFU mode and you may run the script again"
echo "* You can also continue and futurerestore can attempt to download the baseband again"
2020-08-01 07:31:37 +02:00
echo "* Press ENTER to continue (or press Ctrl+C to cancel)"
2020-08-04 11:48:10 +02:00
read -s
2020-07-25 05:23:31 +02:00
if [ [ $A7Device = = 1 ] ] ; then
2020-07-30 17:09:34 +02:00
$futurerestore2 -t $SHSH -s $SEP -m $BuildManifest --latest-baseband $IPSW .ipsw
2020-07-23 02:47:36 +02:00
else
2020-07-30 17:09:34 +02:00
$futurerestore1 -t $SHSH --latest-baseband --use-pwndfu $IPSW .ipsw
2020-07-23 02:47:36 +02:00
fi
2020-07-25 05:23:31 +02:00
elif [ [ $A7Device = = 1 ] ] ; then
2020-07-30 17:09:34 +02:00
$futurerestore2 -t $SHSH -s $SEP -m $BuildManifest -b $Baseband -p $BuildManifest $IPSW .ipsw
2020-06-14 07:39:26 +02:00
else
2020-07-30 17:09:34 +02:00
$futurerestore1 -t $SHSH -b $Baseband -p BuildManifest.plist --use-pwndfu $IPSW .ipsw
2020-03-29 05:53:53 +02:00
fi
fi
echo
2020-04-01 04:49:55 +02:00
Log "futurerestore done!"
2020-06-14 07:39:26 +02:00
Log "Stopping local server... (Enter root password of your PC/Mac when prompted)"
2020-08-14 05:57:20 +02:00
ps aux | awk '/python/ {print "sudo kill -9 "$2" 2>/dev/null"}' | bash
2020-04-01 04:49:55 +02:00
Log "Downgrade script done!"
2020-03-05 12:48:41 +01:00
}
2020-01-08 00:17:00 +01:00
function InstallDependencies {
echo "Install Dependencies"
2020-03-09 02:30:19 +01:00
. /etc/os-release 2>/dev/null
2020-07-29 12:41:01 +02:00
mkdir tmp 2>/dev/null
2020-07-23 02:47:36 +02:00
cd tmp
2020-05-08 03:46:30 +02:00
2020-07-23 02:47:36 +02:00
Log "Installing dependencies..."
2020-07-23 16:35:52 +02:00
if [ [ $ID = = "arch" ] ] || [ [ $ID_LIKE = = "arch" ] ] ; then
2020-05-08 03:46:30 +02:00
# Arch Linux
2020-08-14 05:57:20 +02:00
sudo pacman -Sy --noconfirm --needed bsdiff curl libcurl-compat libpng12 libimobiledevice libusbmuxd libzip openssh openssl-1.0 python2 unzip usbmuxd usbutils
2020-08-16 09:09:55 +02:00
ln -sf /usr/lib/libcurl.so.3 ../resources/lib/libcurl.so.3
ln -sf /usr/lib/libzip.so.5 ../resources/lib/libzip.so.4
2020-07-06 10:08:13 +02:00
2020-08-14 10:07:14 +02:00
elif [ [ $UBUNTU_CODENAME = = "bionic" ] ] || [ [ $UBUNTU_CODENAME = = "focal" ] ] ; then
2020-08-16 09:09:55 +02:00
# Ubuntu Bionic and Focal
2020-07-23 16:35:52 +02:00
sudo add-apt-repository universe
2020-05-08 03:46:30 +02:00
sudo apt update
2020-08-14 10:07:14 +02:00
sudo apt install -y autoconf automake binutils bsdiff build-essential checkinstall curl git libglib2.0-dev libimobiledevice-utils libplist3 libreadline-dev libtool-bin libusb-1.0-0-dev libusbmuxd-tools openssh-client usbmuxd usbutils
2020-08-11 02:57:18 +02:00
SavePkg
2020-08-14 10:07:14 +02:00
if [ [ $UBUNTU_CODENAME = = "bionic" ] ] ; then
sudo apt install -y libzip4 python
sudo dpkg -i libusbmuxd6.deb libpng12_bionic.deb libzip5.deb
2020-08-16 09:09:55 +02:00
SaveFile https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/tools_linux_bionic.zip tools_linux_bionic.zip 685b422cae3ae3d15d6deda397d38ccc8fbcd5b2
2020-08-14 10:07:14 +02:00
unzip tools_linux_bionic.zip -d ../resources/tools
else
sudo apt install -y libusbmuxd6 libzip5 python2
sudo dpkg -i libssl1.0.0.deb libpng12.deb libzip4.deb
2020-08-16 09:09:55 +02:00
ln -sf /usr/lib/x86_64-linux-gnu/libimobiledevice.so.6 ../resources/lib/libimobiledevice-1.0.so.6
ln -sf /usr/lib/x86_64-linux-gnu/libplist.so.3 ../resources/lib/libplist-2.0.so.3
ln -sf /usr/lib/x86_64-linux-gnu/libusbmuxd.so.6 ../resources/lib/libusbmuxd-2.0.so.6
2020-08-14 10:07:14 +02:00
fi
2020-06-29 03:31:06 +02:00
ar x libcurl3.deb data.tar.xz
tar xf data.tar.xz
2020-08-16 09:09:55 +02:00
cp usr/lib/x86_64-linux-gnu/libcurl.so.4.* ../resources/lib/libcurl.so.3
2020-07-23 02:47:36 +02:00
2020-07-23 16:35:52 +02:00
elif [ [ $ID = = "fedora" ] ] ; then
2020-08-16 09:09:55 +02:00
# Fedora 32
2020-08-14 05:57:20 +02:00
sudo dnf install -y automake bsdiff git libimobiledevice-utils libpng12 libtool libusb-devel libusbmuxd-utils libzip make perl-Digest-SHA python2 readline-devel
2020-08-11 02:57:18 +02:00
SavePkg
2020-07-06 10:08:13 +02:00
rpm2cpio openssl-1.0.0.rpm | cpio -idmv
2020-08-16 09:09:55 +02:00
cp usr/lib64/libcrypto.so.1.0.0 usr/lib64/libssl.so.1.0.0 ../resources/lib
ln -sf /usr/lib64/libimobiledevice.so.6 ../resources/lib/libimobiledevice-1.0.so.6
ln -sf /usr/lib64/libplist.so.3 ../resources/lib/libplist-2.0.so.3
ln -sf /usr/lib64/libusbmuxd.so.6 ../resources/lib/libusbmuxd-2.0.so.6
ln -sf /usr/lib64/libzip.so.5 ../resources/lib/libzip.so.4
2020-05-08 03:46:30 +02:00
elif [ [ $OSTYPE = = "darwin" * ] ] ; then
# macOS
2020-08-16 13:25:32 +02:00
xcode-select --install
2020-08-14 10:07:14 +02:00
SaveFile https://github.com/libimobiledevice-win32/imobiledevice-net/releases/download/v1.3.4/libimobiledevice.1.2.1-r1079-osx-x64.zip libimobiledevice.zip 2812e01fc7c09b5980b46b97236b2981dbec7307
2020-08-14 05:57:20 +02:00
rm -rf ../resources/libimobiledevice
mkdir ../resources/libimobiledevice
unzip libimobiledevice.zip -d ../resources/libimobiledevice
chmod +x ../resources/libimobiledevice/*
2020-05-08 03:46:30 +02:00
2020-04-27 07:16:07 +02:00
else
2020-08-10 16:08:15 +02:00
Error "Distro not detected/supported by the install script." "See the repo README for supported OS versions/distros"
2020-04-27 07:16:07 +02:00
fi
2020-08-17 14:31:15 +02:00
if [ [ $platform = = linux ] ] ; then
Compile libimobiledevice libirecovery
ln -sf /usr/local/lib/libirecovery-1.0.so.3 ../resources/lib/libirecovery-1.0.so.3
fi
2020-07-23 02:47:36 +02:00
2020-05-08 03:46:30 +02:00
Log "Install script done! Please run the script again to proceed"
2020-07-23 02:47:36 +02:00
exit
2020-01-08 00:17:00 +01:00
}
2020-07-23 02:47:36 +02:00
function Compile {
2020-07-23 16:35:52 +02:00
git clone --depth 1 https://github.com/$1 /$2 .git
2020-07-23 02:47:36 +02:00
cd $2
./autogen.sh
sudo make install
cd ..
sudo rm -rf $2
}
2020-02-04 16:33:45 +01:00
2020-07-23 02:47:36 +02:00
function SaveExternal {
2020-07-30 13:31:55 +02:00
ExternalURL = " https://github.com/LukeZGD/ $1 .git "
External = $1
[ [ $1 = = "iOS-OTA-Downgrader-Keys" ] ] && External = "firmware"
if [ [ ! -d resources/$External ] ] || [ [ ! -d resources/$External /.git ] ] ; then
Log " Downloading $External ... "
2020-08-04 17:49:55 +02:00
cd resources
rm -rf $External
git clone $ExternalURL $External
2020-07-30 13:31:55 +02:00
else
Log " Updating $External ... "
cd resources/$External
2020-08-04 17:49:55 +02:00
git pull 2>/dev/null
2020-07-30 13:31:55 +02:00
cd ..
2020-07-23 02:47:36 +02:00
fi
2020-08-04 17:49:55 +02:00
if [ [ ! -e $External /README.md ] ] || [ [ ! -d $External /.git ] ] ; then
Error " Downloading/updating $1 failed. Please run the script again "
fi
2020-07-30 13:31:55 +02:00
cd ..
2020-07-23 02:47:36 +02:00
}
2020-03-04 16:19:01 +01:00
2020-08-14 10:07:14 +02:00
function SaveFile {
curl -L $1 -o $2
if [ [ $( shasum $2 | awk '{print $1}' ) != $3 ] ] ; then
Error "Verifying failed. Please run the script again" "./restore.sh Install"
fi
}
2020-07-24 14:58:09 +02:00
function SavePkg {
2020-08-11 02:57:18 +02:00
if [ [ ! -d ../saved/pkg ] ] ; then
Log "Downloading packages..."
2020-08-14 10:07:14 +02:00
SaveFile https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/depends_linux.zip depends_linux.zip c61825bdb41e34ee995ef183c7aca8183d76f8eb
2020-08-11 02:57:18 +02:00
mkdir -p ../saved/pkg
unzip depends_linux.zip -d ../saved/pkg
2020-07-24 14:58:09 +02:00
fi
2020-08-11 02:57:18 +02:00
cp ../saved/pkg/* .
2020-07-24 05:00:32 +02:00
}
2020-07-23 02:47:36 +02:00
function BasebandDetect {
Firmware = resources/firmware/$ProductType
BasebandURL = $( cat $Firmware /13G37/url 2>/dev/null) # iOS 9.3.6
2020-07-23 14:08:16 +02:00
Baseband = 0
2020-07-23 02:47:36 +02:00
if [ $ProductType = = iPad2,2 ] ; then
BasebandURL = $( cat $Firmware /13G36/url) # iOS 9.3.5
Baseband = ICE3_04.12.09_BOOT_02.13.Release.bbfw
BasebandSHA1 = e6f54acc5d5652d39a0ef9af5589681df39e0aca
elif [ $ProductType = = iPad2,3 ] ; then
Baseband = Phoenix-3.6.03.Release.bbfw
BasebandSHA1 = 8d4efb2214344ea8e7c9305392068ab0a7168ba4
elif [ $ProductType = = iPad2,6 ] || [ $ProductType = = iPad2,7 ] ; then
Baseband = Mav5-11.80.00.Release.bbfw
BasebandSHA1 = aa52cf75b82fc686f94772e216008345b6a2a750
elif [ $ProductType = = iPad3,2 ] || [ $ProductType = = iPad3,3 ] ; then
Baseband = Mav4-6.7.00.Release.bbfw
BasebandSHA1 = a5d6978ecead8d9c056250ad4622db4d6c71d15e
elif [ $ProductType = = iPhone4,1 ] ; then
Baseband = Trek-6.7.00.Release.bbfw
BasebandSHA1 = 22a35425a3cdf8fa1458b5116cfb199448eecf49
elif [ $ProductType = = iPad3,5 ] || [ $ProductType = = iPad3,6 ] ||
[ $ProductType = = iPhone5,1 ] || [ $ProductType = = iPhone5,2 ] ; then
BasebandURL = $( cat $Firmware /14G61/url) # iOS 10.3.4
Baseband = Mav5-11.80.00.Release.bbfw
BasebandSHA1 = 8951cf09f16029c5c0533e951eb4c06609d0ba7f
elif [ $ProductType = = iPad4,2 ] || [ $ProductType = = iPad4,3 ] || [ $ProductType = = iPad4,5 ] ||
[ $ProductType = = iPhone6,1 ] || [ $ProductType = = iPhone6,2 ] ; then
BasebandURL = $( cat $Firmware /14G60/url)
Baseband = Mav7Mav8-7.60.00.Release.bbfw
BasebandSHA1 = f397724367f6bed459cf8f3d523553c13e8ae12c
A7Device = 1
2020-07-23 14:08:16 +02:00
elif [ $ProductType = = iPad4,1 ] || [ $ProductType = = iPad4,4 ] ; then
A7Device = 1
2020-07-27 15:42:41 +02:00
elif [ $ProductType = = 0 ] ; then
2020-07-23 14:08:16 +02:00
Error "Please put the device in normal mode (and jailbroken for 32-bit) before proceeding." "Recovery or DFU mode is also applicable for A7 devices"
elif [ $ProductType != iPad2,1 ] && [ $ProductType != iPad2,4 ] && [ $ProductType != iPad2,5 ] &&
2020-08-05 05:07:28 +02:00
[ $ProductType != iPad3,1 ] && [ $ProductType != iPad3,4 ] && [ $ProductType != iPod5,1 ] &&
[ $ProductType != iPhone5,3 ] && [ $ProductType != iPhone5,4 ] ; then
2020-07-23 14:08:16 +02:00
Error " Your device $ProductType is not supported. "
2020-07-23 02:47:36 +02:00
fi
[ $ProductType = = iPhone6,1 ] && HWModel = n51
[ $ProductType = = iPhone6,2 ] && HWModel = n53
[ $ProductType = = iPad4,1 ] && HWModel = j71
[ $ProductType = = iPad4,2 ] && HWModel = j72
[ $ProductType = = iPad4,3 ] && HWModel = j73
[ $ProductType = = iPad4,4 ] && HWModel = j85
[ $ProductType = = iPad4,5 ] && HWModel = j86
SEP = sep-firmware.$HWModel .RELEASE.im4p
}
2020-07-23 04:08:46 +02:00
Main $1