2019-11-22 11:48:41 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
2020-03-19 14:04:06 +01:00
|
|
|
# 8.4.1 iBSS IV and Keys
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k93=781b9672a86ba1b41f8b7fa0af714c94 #iPad2,1
|
2019-12-08 10:53:44 +01:00
|
|
|
key_k93=bbd7bf676dbcc6ba93c76d496b7af39ae7772eaaad2ec9fb71dc1fd004827784
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k94=883c92ed915e4d2481570a062583495b #iPad2,2
|
2019-11-22 11:48:41 +01:00
|
|
|
key_k94=ccfadf3732904885d38f963cce035d7e03b387b67212d526503c85773b58e52f
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k95=460116385cca6d5596221c58ae122669 #iPad2,3
|
2019-11-22 11:48:41 +01:00
|
|
|
key_k95=7852f1fd93d9d49ebea44021081e8f1dffa336d0d3e9517374f8be451dd92eb7
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k93a=976aa656929ac699fff36715de96876d #iPad2,4
|
2019-11-22 11:48:41 +01:00
|
|
|
key_k93a=5fe5c47b5620c2b40b1ca2bd1764a92d568901a24e1caf8faf0cf0f84ae11b4e
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_p105=b21abc8689b0dea8f6e613f9f970e241 #iPad2,5
|
2019-12-08 10:53:44 +01:00
|
|
|
key_p105=b9ed63e4a31f5d9d4d7dddc527e65fd31d1ea48c70204e6b44551c1e6dfc52b5
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_p106=56231fd62c6296ed0c8c411bcef602e0 #iPad2,6
|
2019-12-08 10:53:44 +01:00
|
|
|
key_p106=cdb2142489e5e936fa8f3540bd036f62ed0f27ddb6fec96b9fbfec5a65bc5f17
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_p107=fa39c596b6569e572d90f0820e4e4357 #iPad2,7
|
2019-12-08 10:53:44 +01:00
|
|
|
key_p107=34b359fcc729a0f0d2853e786a78b245ed36a9212c8296aaab95dc0401cf07de
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_j1=c3ea87ed43788dfc3e268abdf1af27dd #iPad3,1
|
2019-11-22 11:48:41 +01:00
|
|
|
key_j1=cd3dd7eee07b9ce8b180d1526632cf86dc7fef7d52352d06af354598ab9cf2ef
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_j2=32fcd912cb9a472ef2a6db72596ae01c #iPad3,2
|
2019-11-22 11:48:41 +01:00
|
|
|
key_j2=076720d5a07e8011bdda6f6eafaf4845b40a441615cd1d7c1a9cca438ce7db17
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_j2a=e6b041970cd611c8a1561a4c210bc476 #iPad3,3
|
2019-11-22 11:48:41 +01:00
|
|
|
key_j2a=aec6a888d45bd26106ac620d7d4ec0c160ab80276deedc1b50ce8f5d99dcc9af
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_p101=a5892a58c90b6d3fb0e0b20db95070d7 #iPad3,4
|
2019-12-08 10:53:44 +01:00
|
|
|
key_p101=75612774968009e3f85545ac0088d0d0bb9cb4e2c2970e8f88489be0b9dfe103
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_p102=fba6d9aaec7237891c80390e6ffa88bf #iPad3,5
|
2019-12-08 10:53:44 +01:00
|
|
|
key_p102=92909dca9bfdb9193131f9ad9b628b1a4971b1cbab52c0ddd114a6253fad96c0
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_p103=1d99e780d96c32a25ca7e4b1c7fe14c0 #iPad3,6
|
2019-12-08 10:53:44 +01:00
|
|
|
key_p103=4e2c14927693d61e1da375e340061521c9376007163f6ab55afbe1a03b901fd3
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n94=147cdef921ed14a5c10631c5e6e02d1e #iPhone4,1
|
2019-11-22 11:48:41 +01:00
|
|
|
key_n94=6ea1eb62a9f403ee212c1f6b3039df093963b46739c6093407190fe3d750c69c
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n41=bd0c8b039a819604a30f0d39adf88572 #iPhone5,1
|
2019-11-22 11:48:41 +01:00
|
|
|
key_n41=baf05fe0282f78c18c2e3842be4f9021919d586b55594281f5b5abd0f6e61495
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n42=fdad2b7a35384fa2ffc7221213ca1082 #iPhone5,2
|
2019-11-22 11:48:41 +01:00
|
|
|
key_n42=74cd68729b800a20b1f8e8a3cb5517024a09f074eaa05b099db530fb5783275e
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n48=dbecd5f265e031835584e6bfbdb4c47f #iPhone5,3
|
2019-11-22 13:35:38 +01:00
|
|
|
key_n48=248f86d983626b75d26718fa52732eca64466ab73df048f278e034a272041f7e
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n49=039241f2b0212bb7c7b62ab4deec263f #iPhone5,4
|
2019-11-22 13:35:38 +01:00
|
|
|
key_n49=d0b49d366469ae2b1580d7d31b1bcf783d835e4fac13cfe9f9a160fa95010ac4
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n78=e0175b03bc29817adc312638884e0898 #iPod5,1
|
|
|
|
key_n78=0a0e0aedc8171669c9af6a229930a395959df55dcd8a3ee1fe0f4c009007df3c
|
2019-11-22 13:35:38 +01:00
|
|
|
|
2020-03-19 14:04:06 +01:00
|
|
|
# 6.1.3 iBSS IV and Keys
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k93_613=b69f753dccd09c9b98d345ec73bbf044 #iPad2,1
|
2019-11-22 13:35:38 +01:00
|
|
|
key_k93_613=6e4cce9ea6f2ec346cba0b279beab1b43e44a0680f1fde789a00f66a1e68ffab
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k94_613=bc3c9f168d7fb86aa219b7ad8039584b #iPad2,2
|
2019-11-22 13:35:38 +01:00
|
|
|
key_k94_613=b1bd1dc5e6076054392be054d50711ae70e8fcf31a47899fb90ab0ff3111b687
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_k95_613=56f964ee19bfd31f06e43e9d8fe93902 #iPad2,3
|
2019-11-22 13:35:38 +01:00
|
|
|
key_k95_613=0bb841b8f1922ae73d85ed9ed0d7a3583a10af909787857c15af2691b39bba30
|
2020-03-13 05:12:49 +01:00
|
|
|
iv_n94_613=d3fe01e99bd0967e80dccfc0739f93d5 #iPhone4,1
|
2019-12-08 10:53:44 +01:00
|
|
|
key_n94_613=35343d5139e0313c81ee59dbae292da26e739ed75b3da5db9da7d4d26046498c
|
2019-11-22 13:35:38 +01:00
|
|
|
|
2020-03-09 02:30:19 +01:00
|
|
|
function BasebandDetect {
|
2020-03-13 05:12:49 +01:00
|
|
|
# For Wi-Fi only devices
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ $ProductType == iPad2,1 ] || [ $ProductType == iPad2,4 ] || [ $ProductType == iPad2,5 ] ||
|
|
|
|
[ $ProductType == iPad3,1 ] || [ $ProductType == iPad3,4 ] || [ $ProductType == iPod5,1 ]; then
|
2020-03-09 02:30:19 +01:00
|
|
|
NoBaseband=1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function Clean {
|
2020-03-13 05:12:49 +01:00
|
|
|
# Clean up files (called on MainMenu and trap dependency)
|
2020-03-10 14:19:08 +01:00
|
|
|
rm -r iP*/ tmp/ $(ls ${UniqueChipID}_${ProductType}_${DowngradeVersion}-*.shsh2 2>/dev/null) 2>/dev/null
|
2020-03-09 02:30:19 +01:00
|
|
|
}
|
|
|
|
|
2020-03-05 12:48:41 +01:00
|
|
|
function MainMenu {
|
|
|
|
Clean
|
|
|
|
mkdir tmp
|
|
|
|
|
2020-03-13 05:12:49 +01:00
|
|
|
if [ $(lsusb | grep -c '1227') == 1 ]; then
|
|
|
|
read -p "[Input] Device in DFU mode detected. Is the device in kDFU mode? (y/N) " kDFUManual
|
2020-03-09 02:30:19 +01:00
|
|
|
if [[ $kDFUManual == y ]] || [[ $kDFUManual == Y ]]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
read -p "[Input] Enter ProductType (eg. iPad2,1): " ProductType
|
2020-03-13 05:12:49 +01:00
|
|
|
if [ $(which irecovery) ]; then
|
|
|
|
# Get ECID with irecovery (optional)
|
|
|
|
UniqueChipID=$(sudo irecovery -q | grep 'ECID:' | cut -c 7-)
|
|
|
|
else
|
|
|
|
read -p "[Input] Enter UniqueChipID (ECID): " UniqueChipID
|
|
|
|
fi
|
2020-03-09 02:30:19 +01:00
|
|
|
BasebandDetect
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Downgrading device $ProductType in kDFU mode..."
|
2020-03-09 02:30:19 +01:00
|
|
|
Mode='Downgrade'
|
|
|
|
SelectVersion
|
|
|
|
else
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Error] Please put the device in normal mode and jailbroken before proceeding"
|
2020-03-09 02:30:19 +01:00
|
|
|
exit
|
|
|
|
fi
|
|
|
|
elif [ ! $ProductType ]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Error] Please plug the device in and trust this computer before proceeding"
|
2020-03-05 12:48:41 +01:00
|
|
|
exit
|
|
|
|
fi
|
2020-03-10 03:55:04 +01:00
|
|
|
BasebandDetect
|
|
|
|
|
2020-03-05 12:48:41 +01:00
|
|
|
echo "Main Menu"
|
|
|
|
echo
|
|
|
|
echo "HardwareModel: $HardwareModel"
|
|
|
|
echo "ProductType: $ProductType"
|
|
|
|
echo "ProductVersion: $ProductVersion"
|
|
|
|
echo "UniqueChipID (ECID): $UniqueChipID"
|
|
|
|
echo
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Input] Select an option:"
|
2020-03-05 12:48:41 +01:00
|
|
|
select opt in "Downgrade device" "Save OTA blobs" "Just put device in kDFU mode" "(Re-)Install Dependencies" "Exit"; do
|
|
|
|
case $opt in
|
|
|
|
"Downgrade device" ) Mode='Downgrade'; SelectVersion; break;;
|
|
|
|
"Save OTA blobs" ) Mode='SaveOTABlobs'; SelectVersion; break;;
|
2020-03-10 03:55:04 +01:00
|
|
|
"Just put device in kDFU mode" ) Mode='kDFU'; Select841; break;;
|
2020-03-05 12:48:41 +01:00
|
|
|
"(Re-)Install Dependencies" ) InstallDependencies; break;;
|
|
|
|
"Exit" ) exit;;
|
|
|
|
*) MainMenu;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
function SelectVersion {
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ $ProductType == iPad2,1 ] || [ $ProductType == iPad2,2 ] ||
|
|
|
|
[ $ProductType == iPad2,3 ] || [ $ProductType == iPhone4,1 ]; then
|
|
|
|
echo "[Input] Select iOS version:"
|
2020-03-05 12:48:41 +01:00
|
|
|
if [[ $Mode == 'Downgrade' ]]; then
|
|
|
|
select opt in "iOS 8.4.1" "iOS 6.1.3" "Other" "Back"; do
|
|
|
|
case $opt in
|
|
|
|
"iOS 8.4.1" ) Select841; break;;
|
|
|
|
"iOS 6.1.3" ) Select613; break;;
|
|
|
|
"Other" ) SelectOther; break;;
|
|
|
|
"Back" ) MainMenu; break;;
|
|
|
|
*) SelectVersion;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
else
|
|
|
|
select opt in "iOS 8.4.1" "iOS 6.1.3" "Back"; do
|
|
|
|
case $opt in
|
|
|
|
"iOS 8.4.1" ) Select841; break;;
|
|
|
|
"iOS 6.1.3" ) Select613; break;;
|
|
|
|
"Back" ) MainMenu; break;;
|
|
|
|
*) SelectVersion;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
elif [[ $Mode == 'Downgrade' ]]; then
|
|
|
|
echo "Select iOS version:"
|
|
|
|
select opt in "iOS 8.4.1" "Other" "Back"; do
|
|
|
|
case $opt in
|
|
|
|
"iOS 8.4.1" ) Select841; break;;
|
|
|
|
"Other" ) SelectOther; break;;
|
|
|
|
"Back" ) MainMenu; break;;
|
|
|
|
*) SelectVersion;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
else
|
|
|
|
Select841
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
function Select841 {
|
|
|
|
echo "iOS 8.4.1 $Mode"
|
2019-11-22 11:48:41 +01:00
|
|
|
iBSS="iBSS.$HardwareModelLower.RELEASE"
|
|
|
|
DowngradeVersion="8.4.1"
|
|
|
|
DowngradeBuildVer="12H321"
|
2019-11-22 13:35:38 +01:00
|
|
|
iv=iv_$HardwareModelLower
|
|
|
|
key=key_$HardwareModelLower
|
2020-03-05 12:48:41 +01:00
|
|
|
Action
|
|
|
|
}
|
|
|
|
|
|
|
|
function Select613 {
|
|
|
|
echo "iOS 6.1.3 $Mode"
|
|
|
|
iBSS="iBSS.${HardwareModelLower}ap.RELEASE"
|
|
|
|
DowngradeVersion="6.1.3"
|
|
|
|
DowngradeBuildVer="10B329"
|
|
|
|
iv=iv_${HardwareModelLower}_613
|
|
|
|
key=key_${HardwareModelLower}_613
|
|
|
|
Action
|
|
|
|
}
|
|
|
|
|
|
|
|
function SelectOther {
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "Other $Mode"
|
2020-03-05 12:48:41 +01:00
|
|
|
iBSS="iBSS.$HardwareModelLower.RELEASE"
|
|
|
|
iv=iv_$HardwareModelLower
|
|
|
|
key=key_$HardwareModelLower
|
|
|
|
NotOTA=1
|
2020-03-10 03:55:04 +01:00
|
|
|
read -p "[Input] Path to IPSW (drag IPSW to terminal window): " IPSW
|
2020-03-10 14:19:08 +01:00
|
|
|
IPSW="$(basename "$IPSW" .ipsw)"
|
2020-03-10 03:55:04 +01:00
|
|
|
read -p "[Input] Path to SHSH (drag SHSH to terminal window): " SHSH
|
2020-01-08 00:17:00 +01:00
|
|
|
Downgrade
|
2019-11-22 11:48:41 +01:00
|
|
|
}
|
|
|
|
|
2020-03-05 12:48:41 +01:00
|
|
|
function Action {
|
|
|
|
if [[ $Mode == 'Downgrade' ]]; then
|
2020-01-08 00:17:00 +01:00
|
|
|
Downgrade
|
2020-03-05 12:48:41 +01:00
|
|
|
elif [[ $Mode == 'SaveOTABlobs' ]]; then
|
|
|
|
SaveOTABlobs
|
2020-03-10 03:55:04 +01:00
|
|
|
elif [[ $Mode == 'kDFU' ]]; then
|
|
|
|
kDFU
|
2019-11-22 11:48:41 +01:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2019-11-23 05:15:35 +01:00
|
|
|
function SaveOTABlobs {
|
2020-03-03 01:16:32 +01:00
|
|
|
BuildManifest="resources/manifests/BuildManifest_${ProductType}_${DowngradeVersion}.plist"
|
|
|
|
|
2020-03-13 05:12:49 +01:00
|
|
|
# ota.json is being downloaded now so tsschecker doesn't have to
|
2020-03-19 14:04:06 +01:00
|
|
|
# this is because tsschecker has an unforgiving timeout when downloading ota.json
|
2020-03-06 01:14:10 +01:00
|
|
|
if [ ! -e resources/ota.json ]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Downloading ota.json..."
|
2020-03-13 05:12:49 +01:00
|
|
|
curl -L https://api.ipsw.me/v2.1/ota.json/condensed -o tmp/ota.json
|
|
|
|
mv tmp/ota.json resources/
|
2019-12-04 08:11:24 +01:00
|
|
|
fi
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Copying ota.json to tmp..."
|
2019-12-15 04:52:10 +01:00
|
|
|
if [ $platform == macos ]; then
|
2020-03-05 12:54:46 +01:00
|
|
|
cp resources/ota.json $TMPDIR
|
2019-12-04 08:11:24 +01:00
|
|
|
else
|
2020-03-05 12:54:46 +01:00
|
|
|
cp resources/ota.json /tmp
|
2019-11-22 11:48:41 +01:00
|
|
|
fi
|
2019-12-15 04:52:10 +01:00
|
|
|
if [ ! -e /tmp/ota.json ] && [ ! -e $TMPDIR/ota.json ]; then
|
2020-03-13 05:12:49 +01:00
|
|
|
echo "[Error] Downloading/copying ota.json failed. Please run the script again"
|
2019-11-22 11:48:41 +01:00
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Saving $DowngradeVersion blobs with tsschecker..."
|
2020-03-02 11:40:42 +01:00
|
|
|
env "LD_PRELOAD=libcurl.so.3" resources/tools/tsschecker_$platform -d $ProductType -i $DowngradeVersion -o -s -e $UniqueChipID -m $BuildManifest
|
2020-03-13 05:12:49 +01:00
|
|
|
SHSH=$(ls ${UniqueChipID}_${ProductType}_${DowngradeVersion}-*.shsh2)
|
2020-03-10 14:19:08 +01:00
|
|
|
if [ ! -e "$SHSH" ]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Error] Saving $DowngradeVersion blobs failed. Please run the script again"
|
2019-11-22 11:48:41 +01:00
|
|
|
exit
|
|
|
|
fi
|
2020-03-10 14:19:08 +01:00
|
|
|
mkdir output 2>/dev/null
|
|
|
|
cp "$SHSH" output
|
2019-11-23 05:15:35 +01:00
|
|
|
}
|
|
|
|
|
2020-03-05 12:48:41 +01:00
|
|
|
function kDFU {
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ ! -e tmp/$iBSS.dfu ]; then
|
2020-03-13 05:12:49 +01:00
|
|
|
# Downloading 8.4.1 iBSS for "other" downgrades
|
|
|
|
# This is because this script only provides 8.4.1 iBSS IV and Keys
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Downloading iBSS..."
|
|
|
|
dllink=$(curl -I -Ls -o /dev/null -w %{url_effective} https://api.ipsw.me/v4/ipsw/download/${ProductType}/12H321)
|
2020-03-10 16:07:11 +01:00
|
|
|
resources/tools/pzb_$platform -g Firmware/dfu/${iBSS}.dfu -o $iBSS.dfu $dllink
|
2020-03-10 03:55:04 +01:00
|
|
|
mv $iBSS.dfu tmp/
|
|
|
|
fi
|
|
|
|
echo "[Log] Decrypting iBSS..."
|
2019-11-22 11:48:41 +01:00
|
|
|
echo "IV = ${!iv}"
|
|
|
|
echo "Key = ${!key}"
|
2020-03-02 08:20:47 +01:00
|
|
|
resources/tools/xpwntool_$platform "tmp/${iBSS}.dfu" tmp/iBSS.dec -k ${!key} -iv ${!iv} -decrypt
|
2019-11-22 11:48:41 +01:00
|
|
|
dd bs=64 skip=1 if=tmp/iBSS.dec of=tmp/iBSS.dec2
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Patching iBSS..."
|
2020-03-02 08:20:47 +01:00
|
|
|
bspatch tmp/iBSS.dec2 tmp/pwnediBSS resources/patches/$iBSS.patch
|
2020-03-13 05:12:49 +01:00
|
|
|
|
|
|
|
# Regular kloader only works on iOS 6 to 9, so other versions are provided for iOS 5 and 10
|
2019-12-15 04:52:10 +01:00
|
|
|
if [[ $VersionDetect == 1 ]]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
kloader='kloader_hgsp'
|
2019-12-15 04:52:10 +01:00
|
|
|
elif [[ $VersionDetect == 5 ]]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
kloader='kloader5'
|
2019-11-22 11:48:41 +01:00
|
|
|
else
|
2020-03-10 03:55:04 +01:00
|
|
|
kloader='kloader'
|
2019-11-22 11:48:41 +01:00
|
|
|
fi
|
|
|
|
|
2019-12-15 04:52:10 +01:00
|
|
|
if [[ $VersionDetect == 1 ]]; then
|
2020-03-13 05:12:49 +01:00
|
|
|
# SSH is unreliable/not working on iOS 10 devices, so ifuse+MTerminal is used instead
|
|
|
|
# It's less convenient, but it should work every time
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ ! $(which ifuse) ]; then
|
|
|
|
echo "[Error] ifuse not found. Please re-install dependencies and try again"
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "For macOS systems, install osxfuse and ifuse with brew"
|
2020-03-10 03:55:04 +01:00
|
|
|
exit
|
|
|
|
fi
|
2020-03-01 20:47:48 +01:00
|
|
|
WifiAddr=$(ideviceinfo -s | grep 'WiFiAddress' | cut -c 14-)
|
2019-11-22 11:48:41 +01:00
|
|
|
WifiAddrDecr=$(echo $(printf "%x\n" $(expr $(printf "%d\n" 0x$(echo "${WifiAddr}" | tr -d ':')) - 1)) | sed 's/\(..\)/\1:/g;s/:$//')
|
2020-01-08 00:28:11 +01:00
|
|
|
echo '#!/bin/bash' > tmp/pwn.sh
|
|
|
|
echo "nvram wifiaddr=$WifiAddrDecr
|
|
|
|
chmod 755 kloader_hgsp
|
|
|
|
./kloader_hgsp pwnediBSS" >> tmp/pwn.sh
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Mounting device with ifuse..."
|
2020-03-13 05:12:49 +01:00
|
|
|
mkdir mount
|
2020-03-08 11:59:22 +01:00
|
|
|
ifuse mount
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Copying stuff to device..."
|
2020-03-08 11:59:22 +01:00
|
|
|
cp "tmp/pwn.sh" "resources/tools/$kloader" "tmp/pwnediBSS" "mount/"
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Unmounting device..."
|
2020-03-08 11:59:22 +01:00
|
|
|
sudo umount mount
|
2019-11-22 11:48:41 +01:00
|
|
|
echo
|
2020-03-10 16:07:11 +01:00
|
|
|
echo "[Log] Open MTerminal and run these commands:"
|
2019-11-22 11:48:41 +01:00
|
|
|
echo
|
2020-01-08 00:17:00 +01:00
|
|
|
echo '$ su'
|
2019-11-22 11:48:41 +01:00
|
|
|
echo "(enter root password, default is 'alpine')"
|
2020-01-08 00:17:00 +01:00
|
|
|
echo "# cd Media"
|
2020-01-08 00:28:11 +01:00
|
|
|
echo "# chmod +x pwn.sh"
|
|
|
|
echo "# ./pwn.sh"
|
2019-11-22 11:48:41 +01:00
|
|
|
else
|
2020-03-13 05:12:49 +01:00
|
|
|
# SSH: Send kloader and pwnediBSS to device root and run kloader as root
|
2019-11-22 11:48:41 +01:00
|
|
|
echo "Make sure SSH is installed and working on the device!"
|
2020-03-05 12:48:41 +01:00
|
|
|
echo "Please enter Wi-Fi IP address of device for SSH connection"
|
2020-03-10 16:07:11 +01:00
|
|
|
read -p "[Input] IP Address: " IPAddress
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Coonecting to device via SSH... Please enter root password when prompted (default is 'alpine')"
|
|
|
|
echo "[Log] Copying stuff to device..."
|
2020-03-02 08:20:47 +01:00
|
|
|
scp resources/tools/$kloader tmp/pwnediBSS root@$IPAddress:/
|
2020-03-09 07:24:45 +01:00
|
|
|
if [ $? == 1 ]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Error] Cannot connect to device via SSH. Please check your ~/.ssh/known_hosts file and try again"
|
2020-03-09 07:24:45 +01:00
|
|
|
exit
|
|
|
|
fi
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Entering kDFU mode..."
|
2020-03-02 08:20:47 +01:00
|
|
|
ssh root@$IPAddress "chmod 755 /$kloader && /$kloader /pwnediBSS" &
|
2019-11-22 11:48:41 +01:00
|
|
|
fi
|
2020-01-08 00:17:00 +01:00
|
|
|
echo
|
2019-11-22 11:48:41 +01:00
|
|
|
echo "Press home/power button once when screen goes black on the device"
|
2019-12-15 04:52:10 +01:00
|
|
|
FindDFU
|
|
|
|
}
|
2019-11-22 11:48:41 +01:00
|
|
|
|
2019-12-15 04:52:10 +01:00
|
|
|
function FindDFU {
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Finding device in DFU mode..."
|
2019-12-15 04:52:10 +01:00
|
|
|
while [[ $DFUDevice != 1 ]]; do
|
|
|
|
DFUDevice=$(lsusb | grep -c "1227")
|
2019-11-22 11:48:41 +01:00
|
|
|
sleep 2
|
|
|
|
done
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Found device in DFU mode."
|
2019-11-22 11:48:41 +01:00
|
|
|
}
|
|
|
|
|
2020-03-05 12:48:41 +01:00
|
|
|
function Downgrade {
|
2020-03-22 01:37:31 +01:00
|
|
|
# These firmware keys are essential for some iPads and iPod5,1
|
2020-03-13 05:12:49 +01:00
|
|
|
# 8.4.1 KBAG keys for those devices are missing in firmware-keys.ipsw.me
|
2020-03-22 01:37:31 +01:00
|
|
|
rm -rf resources/firmware
|
|
|
|
echo "Downloading firmware keys..."
|
|
|
|
curl -L https://github.com/LukeZGD/32bit-OTA-Downgrader/archive/firmware.zip -o tmp/firmware.zip
|
|
|
|
unzip -q tmp/firmware.zip -d tmp
|
|
|
|
mkdir resources/firmware
|
|
|
|
mv tmp/32bit-OTA-Downgrader-firmware/firmware/* resources/firmware
|
2020-03-08 11:59:22 +01:00
|
|
|
|
2020-03-05 12:48:41 +01:00
|
|
|
if [ ! $NotOTA ]; then
|
|
|
|
SaveOTABlobs
|
|
|
|
IPSW="${ProductType}_${DowngradeVersion}_${DowngradeBuildVer}_Restore"
|
2020-03-10 14:19:08 +01:00
|
|
|
if [ ! -e "$IPSW.ipsw" ]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] iOS $DowngradeVersion IPSW is missing, downloading IPSW..."
|
2020-03-13 05:12:49 +01:00
|
|
|
curl -L https://api.ipsw.me/v4/ipsw/download/$ProductType/$DowngradeBuildVer -o tmp/$IPSW.ipsw
|
|
|
|
mv tmp/$IPSW.ipsw .
|
2020-03-05 12:48:41 +01:00
|
|
|
fi
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Verifying IPSW..."
|
|
|
|
SHA1IPSW=$(curl -L https://api.ipsw.me/v2.1/${ProductType}/${DowngradeBuildVer}/sha1sum)
|
|
|
|
SHA1IPSWL=$(sha1sum "$IPSW.ipsw" | awk '{print $1}')
|
|
|
|
if [ $SHA1IPSW != $SHA1IPSWL ]; then
|
|
|
|
echo "[Error] SHA1 of IPSW does not match!"
|
|
|
|
read -p "[Input] Continue anyway? (y/N)" Continue
|
|
|
|
if [[ $Continue != y ]] && [[ $Continue != Y ]]; then
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
echo "[Log] Extracting iBSS from IPSW..."
|
2020-03-10 14:19:08 +01:00
|
|
|
unzip -j "$IPSW.ipsw" Firmware/dfu/$iBSS.dfu -d tmp/
|
2019-11-22 11:48:41 +01:00
|
|
|
fi
|
2020-03-05 12:48:41 +01:00
|
|
|
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ ! $kDFUManual ]; then
|
2020-03-09 07:24:45 +01:00
|
|
|
kDFU
|
|
|
|
fi
|
2020-03-05 12:48:41 +01:00
|
|
|
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Extracting IPSW..."
|
2020-03-10 16:07:11 +01:00
|
|
|
unzip -q "$IPSW.ipsw" -d "$IPSW/"
|
2020-03-10 03:55:04 +01:00
|
|
|
|
|
|
|
echo "[Log] Preparing for futurerestore (starting local server)..."
|
2020-03-05 12:48:41 +01:00
|
|
|
cd resources
|
|
|
|
sudo python3 -m http.server 80 &
|
|
|
|
pythonPID=$!
|
|
|
|
cd ..
|
|
|
|
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Proceeding to futurerestore..."
|
2020-03-05 12:48:41 +01:00
|
|
|
while [[ $ScriptDone != 1 ]]; do
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ ! $NoBaseband ]; then
|
2020-03-10 14:19:08 +01:00
|
|
|
sudo env "LD_PRELOAD=libcurl.so.3" resources/tools/futurerestore_$platform -t "$SHSH" --latest-baseband --use-pwndfu "$IPSW.ipsw"
|
2020-03-05 12:48:41 +01:00
|
|
|
else
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Device $ProductType has no baseband"
|
2020-03-10 14:19:08 +01:00
|
|
|
sudo env "LD_PRELOAD=libcurl.so.3" resources/tools/futurerestore_$platform -t "$SHSH" --no-baseband --use-pwndfu "$IPSW.ipsw"
|
2020-03-05 12:48:41 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
echo
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] futurerestore done!"
|
|
|
|
# Downloading stuff sometimes fails causes futurerestore to halt, so I added the option to retry here
|
|
|
|
echo "You can choose to retry if futurerestore failed on downloading baseband or for some other reason"
|
2020-03-10 03:55:04 +01:00
|
|
|
read -p "[Input] Retry? (y/N) " Retry
|
2020-03-10 16:07:11 +01:00
|
|
|
if [[ $Retry != y ]] && [[ $Retry != Y ]]; then
|
2020-03-05 12:48:41 +01:00
|
|
|
ScriptDone=1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2020-03-10 16:07:11 +01:00
|
|
|
echo "[Log] Stopping local server (PID $pythonPID)..."
|
2020-03-05 12:48:41 +01:00
|
|
|
sudo kill $pythonPID
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Downgrade script done!"
|
2020-03-05 12:48:41 +01:00
|
|
|
exit
|
|
|
|
}
|
|
|
|
|
2020-01-08 00:17:00 +01:00
|
|
|
function InstallDependencies {
|
|
|
|
echo "Install Dependencies"
|
2019-12-04 08:11:24 +01:00
|
|
|
|
2020-03-09 02:30:19 +01:00
|
|
|
. /etc/os-release 2>/dev/null
|
2020-01-08 00:17:00 +01:00
|
|
|
if [[ $(which pacman) ]] || [[ $NAME == "Arch Linux" ]]; then
|
2020-02-04 16:33:45 +01:00
|
|
|
Arch
|
2020-01-08 00:17:00 +01:00
|
|
|
elif [[ $NAME == "Ubuntu" ]] && [[ $VERSION_ID == "16.04" ]]; then
|
2019-12-04 08:11:24 +01:00
|
|
|
Ubuntu
|
2020-01-08 00:17:00 +01:00
|
|
|
elif [[ $(which apt) ]] || [[ $NAME == "Ubuntu" ]] && [[ $VERSION_ID == "18.04" ]]; then
|
2019-12-04 08:11:24 +01:00
|
|
|
Ubuntu
|
|
|
|
Ubuntu1804
|
2020-01-08 00:17:00 +01:00
|
|
|
elif [[ $OSTYPE == "darwin"* ]]; then
|
2020-02-04 16:33:45 +01:00
|
|
|
macOS
|
2019-12-04 08:11:24 +01:00
|
|
|
else
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Input] Distro not detected/supported. Please select manually"
|
2020-02-04 16:33:45 +01:00
|
|
|
select opt in "Ubuntu Xenial" "Ubuntu Bionic" "Arch Linux" "macOS"; do
|
2019-12-04 08:11:24 +01:00
|
|
|
case $opt in
|
2020-02-04 16:33:45 +01:00
|
|
|
"Ubuntu Xenial" ) Ubuntu; break;;
|
|
|
|
"Ubuntu Bionic" ) Ubuntu; Ubuntu1804; break;;
|
|
|
|
"Arch Linux" ) Arch; break;;
|
|
|
|
"macOS" ) macOS; break;;
|
2019-12-04 08:11:24 +01:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
fi
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Log] Install script done! Please run the script again to proceed"
|
2020-01-08 00:17:00 +01:00
|
|
|
}
|
|
|
|
|
2020-02-04 16:33:45 +01:00
|
|
|
function Arch {
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Installing dependencies for Arch with pacman..."
|
2020-03-02 09:11:52 +01:00
|
|
|
sudo pacman -Sy --noconfirm bsdiff curl ifuse libcurl-compat libpng12 libzip openssh openssl-1.0 python unzip usbutils
|
2020-02-08 16:19:36 +01:00
|
|
|
sudo pacman -S --noconfirm libimobiledevice usbmuxd
|
2020-02-04 16:33:45 +01:00
|
|
|
sudo ln -sf /usr/lib/libzip.so.5 /usr/lib/libzip.so.4
|
|
|
|
}
|
|
|
|
|
|
|
|
function macOS {
|
2020-03-10 03:55:04 +01:00
|
|
|
read -p "[Input] Warning: macOS dependency install script is not fully tested and supported. Continue anyway? (y/N) " Continue
|
|
|
|
if [[ $Continue != y ]] && [[ $Continue != Y ]]; then
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Error] Please install these dependencies manually with brew to proceed:"
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "libimobiledevice, usbmuxd, libzip, lsusb, osxfuse, ifuse"
|
|
|
|
exit
|
|
|
|
fi
|
2020-02-04 16:33:45 +01:00
|
|
|
if [[ ! $(which brew) ]]; then
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Homebrew is not detected/installed, installing Homebrew..."
|
2020-03-05 12:48:41 +01:00
|
|
|
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)"
|
2020-02-04 16:33:45 +01:00
|
|
|
fi
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Installing dependencies for macOS with Homebrew..."
|
2020-02-04 16:33:45 +01:00
|
|
|
brew uninstall --ignore-dependencies usbmuxd
|
|
|
|
brew uninstall --ignore-dependencies libimobiledevice
|
|
|
|
brew install --HEAD usbmuxd
|
|
|
|
brew install --HEAD libimobiledevice
|
2020-03-06 00:46:08 +01:00
|
|
|
brew install libzip lsusb
|
|
|
|
brew cask install osxfuse
|
|
|
|
brew install ifuse
|
2020-02-04 16:33:45 +01:00
|
|
|
}
|
|
|
|
|
2020-01-08 00:17:00 +01:00
|
|
|
function Ubuntu {
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Running APT update..."
|
2020-01-08 00:17:00 +01:00
|
|
|
sudo apt update
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Installing dependencies for Ubuntu with APT..."
|
2020-03-02 09:11:52 +01:00
|
|
|
sudo apt -y install bsdiff curl ifuse libimobiledevice-utils libzip4 python3 usbmuxd
|
2020-01-08 00:17:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function Ubuntu1804 {
|
2020-03-19 14:04:06 +01:00
|
|
|
echo "[Log] Installing dependencies for Ubuntu 18.04 with APT..."
|
2020-01-08 00:17:00 +01:00
|
|
|
sudo apt -y install binutils
|
|
|
|
mkdir tmp
|
|
|
|
cd tmp
|
|
|
|
apt download -o=dir::cache=. libcurl3
|
|
|
|
ar x libcurl3* data.tar.xz
|
|
|
|
tar xf data.tar.xz
|
2020-03-15 03:43:07 +01:00
|
|
|
sudo cp usr/lib/x86_64-linux-gnu/libcurl.so.4.* /usr/lib/libcurl.so.3
|
|
|
|
curl -L http://mirrors.edge.kernel.org/ubuntu/pool/main/libp/libpng/libpng12-0_1.2.54-1ubuntu1.1_amd64.deb -o libpng12.deb
|
2020-01-08 00:17:00 +01:00
|
|
|
sudo dpkg -i libpng12.deb
|
|
|
|
cd ..
|
|
|
|
}
|
|
|
|
|
2020-03-13 05:12:49 +01:00
|
|
|
# --- MAIN SCRIPT STARTS HERE ---
|
2020-02-04 16:33:45 +01:00
|
|
|
|
2020-03-10 03:55:04 +01:00
|
|
|
trap Clean INT TERM EXIT
|
2020-02-24 15:52:46 +01:00
|
|
|
clear
|
|
|
|
echo "******* 32bit-OTA-Downgrader *******"
|
2020-03-05 12:48:41 +01:00
|
|
|
echo " Downgrade script by LukeZGD "
|
2020-02-24 15:52:46 +01:00
|
|
|
echo
|
|
|
|
|
|
|
|
if [[ $OSTYPE == "linux-gnu" ]]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
platform='linux'
|
2020-02-24 15:52:46 +01:00
|
|
|
elif [[ $OSTYPE == "darwin"* ]]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
platform='macos'
|
2020-02-24 15:52:46 +01:00
|
|
|
else
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Error] OSTYPE unknown/not supported"
|
|
|
|
echo "Supports Linux and macOS only"
|
2020-02-24 15:52:46 +01:00
|
|
|
exit
|
|
|
|
fi
|
2020-03-04 16:19:01 +01:00
|
|
|
if [[ ! $(ping -c1 google.com 2>/dev/null) ]]; then
|
2020-03-10 03:55:04 +01:00
|
|
|
echo "[Error] Please check your Internet connection before proceeding"
|
2020-03-04 16:19:01 +01:00
|
|
|
exit
|
|
|
|
fi
|
2020-03-15 03:43:07 +01:00
|
|
|
if [[ $(uname -m) != 'x86_64' ]]; then
|
|
|
|
echo "[Error] Only x86_64 distributions are supported. Use a 64-bit distro and try again"
|
|
|
|
exit
|
|
|
|
fi
|
2020-03-04 16:19:01 +01:00
|
|
|
|
2020-03-01 20:47:48 +01:00
|
|
|
HardwareModel=$(ideviceinfo -s | grep 'HardwareModel' | cut -c 16-)
|
2020-02-24 15:52:46 +01:00
|
|
|
HardwareModelLower=$(echo $HardwareModel | tr '[:upper:]' '[:lower:]' | sed 's/.\{2\}$//')
|
2020-03-01 20:47:48 +01:00
|
|
|
ProductType=$(ideviceinfo -s | grep 'ProductType' | cut -c 14-)
|
2020-03-02 11:08:15 +01:00
|
|
|
[ ! $ProductType ] && ProductType=$(ideviceinfo | grep 'ProductType' | cut -c 14-)
|
2020-03-01 20:47:48 +01:00
|
|
|
ProductVersion=$(ideviceinfo -s | grep 'ProductVersion' | cut -c 17-)
|
2020-02-24 15:52:46 +01:00
|
|
|
VersionDetect=$(echo $ProductVersion | cut -c 1)
|
2020-03-01 20:47:48 +01:00
|
|
|
UniqueChipID=$(ideviceinfo -s | grep 'UniqueChipID' | cut -c 15-)
|
2020-02-24 15:52:46 +01:00
|
|
|
|
2020-03-10 03:55:04 +01:00
|
|
|
if [ ! $(which bspatch) ] || [ ! $(which ideviceinfo) ] || [ ! $(which lsusb) ] || [ ! $(which ssh) ] || [ ! $(which python3) ]; then
|
2020-01-08 00:17:00 +01:00
|
|
|
InstallDependencies
|
2019-12-04 08:11:24 +01:00
|
|
|
else
|
2020-03-02 08:20:47 +01:00
|
|
|
chmod +x resources/tools/*
|
2019-12-04 08:11:24 +01:00
|
|
|
MainMenu
|
2019-12-08 10:53:44 +01:00
|
|
|
fi
|