Legacy-iOS-Kit/resources/blobs.sh

80 lines
3.0 KiB
Bash
Raw Normal View History

#!/bin/bash
SaveOTABlobs() {
local APNonce=$1
2021-07-12 07:39:48 +02:00
local ExtraArgs
2022-07-18 13:53:45 +02: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) && -z $APNonce ]]; then
2022-07-21 01:45:13 +02:00
SHSH=$(ls saved/shsh/$SHSHChk)
Log "Found existing saved $OSVer blobs: $SHSH"
2022-07-18 13:53:45 +02:00
return
fi
Log "Saving iOS $OSVer blobs with tsschecker..."
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 07:39:48 +02:00
$tsschecker $ExtraArgs
SHSH=$(ls $SHSHChk)
2022-07-18 13:53:45 +02:00
if [[ -n $SHSH ]]; then
mkdir -p saved/shsh 2>/dev/null
if [[ -n $APNonce ]]; then
mv "$SHSH" tmp/
SHSH=$(ls tmp/$SHSHChk)
else
mv "$SHSH" saved/shsh/
SHSH=$(ls saved/shsh/$SHSHChk)
fi
Log "Successfully saved $OSVer blobs: $SHSH"
2022-07-18 13:53:45 +02:00
else
Error "Saving $OSVer blobs failed. Please run the script again" \
"It is also possible that $OSVer for $ProductType is no longer signed"
fi
}
Save712Blobs() {
local SHSHChk=${UniqueChipID}_${ProductType}_7.1.2-11D257_*.shsh2
2022-07-18 13:53:45 +02:00
BuildManifest="saved/$ProductType/BuildManifest.plist"
SHSH="saved/shsh/${UniqueChipID}-${ProductType}-7.1.2.shsh"
2022-07-18 13:53:45 +02:00
if [[ -e $SHSH ]]; then
Log "Found existing saved 7.1.2 blobs: $SHSH"
2022-07-18 13:53:45 +02:00
return
fi
if [[ ! -e $BuildManifest ]]; then
if [[ -e $IPSW7.ipsw ]]; then
Log "Extracting BuildManifest from 7.1.2 IPSW..."
unzip -o -j $IPSW7.ipsw BuildManifest.plist -d .
else
Log "Downloading BuildManifest for 7.1.2..."
$partialzip $BasebandURL BuildManifest.plist BuildManifest.plist
fi
2022-07-18 13:53:45 +02:00
mkdir -p saved/$ProductType 2>/dev/null
mv BuildManifest.plist $BuildManifest
fi
Log "Saving 7.1.2 blobs with tsschecker..."
$tsschecker -d $ProductType -i 7.1.2 -e $UniqueChipID -m $BuildManifest -s -b
SHSHChk=$(ls $SHSHChk)
2022-09-24 15:16:41 +02:00
[[ -z $SHSHChk ]] && Error "Saving 7.1.2 blobs failed. Please run the script again"
mkdir -p saved/shsh 2>/dev/null
2022-05-30 16:17:56 +02:00
mv $SHSHChk $SHSH
Log "Successfully saved 7.1.2 blobs: $SHSH"
}
SaveLatestBlobs() {
local APNonce=$($irecovery -q | grep "NONC" | cut -c 7-)
local SHSHChk=${UniqueChipID}_${ProductType}_${LatestVer}-${LatestBuildVer}_*.shsh2
SHSH="shsh/${UniqueChipID}-${ProductType}-${LatestVer}.shsh"
Log "Saving $LatestVer blobs with tsschecker..."
mkdir -p saved/$ProductType shsh 2>/dev/null
cp -f $IPSWRestore/BuildManifest.plist saved/$ProductType/
$tsschecker -d $ProductType -i $LatestVer -e $UniqueChipID -m saved/$ProductType/BuildManifest.plist -s -b --apnonce $($irecovery -q | grep "NONC" | cut -c 7-)
SHSHChk=$(ls $SHSHChk)
[[ -z $SHSHChk ]] && Error "Saving $LatestVer blobs failed. Please run the script again"
mv $SHSHChk $SHSH
Log "Successfully saved $LatestVer blobs: $SHSH"
}