2021-05-29 19:26:08 +08:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
SaveOTABlobs() {
|
2022-05-29 22:57:53 +08:00
|
|
|
local APNonce=$1
|
2021-07-12 13:39:48 +08:00
|
|
|
local ExtraArgs
|
2022-07-18 19:53:45 +08:00
|
|
|
local SHSHChk=${UniqueChipID}_${ProductType}_${HWModel}ap_${OSVer}-${BuildVer}*.shsh*
|
|
|
|
BuildManifest="resources/manifests/BuildManifest_${ProductType}_${OSVer}.plist"
|
|
|
|
|
|
|
|
if [[ $(ls saved/shsh/$SHSHChk 2>/dev/null) ]]; then
|
|
|
|
Log "Found existing saved $OSVer blobs."
|
|
|
|
return
|
|
|
|
fi
|
2021-11-18 18:33:15 +08:00
|
|
|
|
|
|
|
Log "Saving iOS $OSVer blobs with tsschecker..."
|
2022-05-29 22:57:53 +08:00
|
|
|
ExtraArgs="-d $ProductType -i $OSVer -e $UniqueChipID -m $BuildManifest -o -s -B ${HWModel}ap -b "
|
|
|
|
[[ -n $APNonce ]] && ExtraArgs+="--apnonce $APNonce" || ExtraArgs+="-g 0x1111111111111111"
|
2021-07-12 13:39:48 +08:00
|
|
|
$tsschecker $ExtraArgs
|
2021-05-29 19:26:08 +08:00
|
|
|
SHSH=$(ls $SHSHChk)
|
2022-07-18 19:53:45 +08:00
|
|
|
if [[ -n $SHSH ]]; then
|
2021-05-29 19:26:08 +08:00
|
|
|
mkdir -p saved/shsh 2>/dev/null
|
2022-05-29 22:57:53 +08:00
|
|
|
[[ -z $APNonce ]] && cp "$SHSH" saved/shsh
|
2021-05-29 19:26:08 +08:00
|
|
|
Log "Successfully saved $OSVer blobs."
|
2022-07-18 19:53:45 +08:00
|
|
|
else
|
|
|
|
Error "Saving $OSVer blobs failed. Please run the script again" \
|
|
|
|
"It is also possible that $OSVer for $ProductType is no longer signed"
|
2021-05-29 19:26:08 +08:00
|
|
|
fi
|
|
|
|
}
|
2022-05-28 18:56:10 +08:00
|
|
|
|
|
|
|
Save712Blobs() {
|
|
|
|
local SHSHChk
|
2022-07-18 19:53:45 +08:00
|
|
|
BuildManifest="saved/$ProductType/BuildManifest.plist"
|
2022-06-08 23:04:56 +08:00
|
|
|
SHSH="saved/shsh/${UniqueChipID}-${ProductType}-7.1.2.shsh"
|
2022-05-28 18:56:10 +08:00
|
|
|
|
2022-07-18 19:53:45 +08:00
|
|
|
if [[ -e $SHSH ]]; then
|
|
|
|
Log "Found existing saved 7.1.2 blobs."
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ ! -e $BuildManifest && -e $IPSW7.ipsw ]]; then
|
2022-05-28 18:56:10 +08:00
|
|
|
Log "Extracting BuildManifest from 7.1.2 IPSW..."
|
|
|
|
unzip -o -j $IPSW7.ipsw BuildManifest.plist -d .
|
2022-07-18 19:53:45 +08:00
|
|
|
mkdir -p saved/$ProductType 2>/dev/null
|
|
|
|
mv BuildManifest.plist $BuildManifest
|
|
|
|
elif [[ ! -e $BuildManifest ]]; then
|
|
|
|
Log "Downloading BuildManifest for 7.1.2..."
|
|
|
|
$partialzip $BasebandURL BuildManifest.plist BuildManifest.plist
|
|
|
|
mkdir -p saved/$ProductType 2>/dev/null
|
2022-06-08 23:04:56 +08:00
|
|
|
mv BuildManifest.plist $BuildManifest
|
2022-05-28 18:56:10 +08:00
|
|
|
fi
|
|
|
|
|
2022-05-29 22:57:53 +08:00
|
|
|
Log "Saving 7.1.2 blobs with tsschecker..."
|
2022-06-08 23:04:56 +08:00
|
|
|
$tsschecker -d $ProductType -i 7.1.2 -e $UniqueChipID -m $BuildManifest -s -b
|
2022-05-29 22:57:53 +08:00
|
|
|
SHSHChk=$(ls ${UniqueChipID}_${ProductType}_7.1.2-11D257_*.shsh2)
|
2022-07-18 19:53:45 +08:00
|
|
|
[[ -z $SHSHChk ]] && Error "Saving $OSVer blobs failed. Please run the script again"
|
2022-05-29 22:57:53 +08:00
|
|
|
mkdir saved/shsh 2>/dev/null
|
2022-05-30 22:17:56 +08:00
|
|
|
mv $SHSHChk $SHSH
|
2022-05-29 22:57:53 +08:00
|
|
|
Log "Successfully saved 7.1.2 blobs."
|
2022-05-28 18:56:10 +08:00
|
|
|
}
|