Legacy-iOS-Kit/resources/depends.sh

326 lines
15 KiB
Bash
Raw Normal View History

#!/bin/bash
SetToolPaths() {
local Detect="Detected libimobiledevice and libirecovery installed from "
MPath="./resources/libimobiledevice_"
cherrymac="./resources/ch3rryflower/Tools/macos/UNTETHERED"
if [[ $OSTYPE == "linux"* ]]; then
. /etc/os-release 2>/dev/null
platform="linux"
platformver="$PRETTY_NAME"
MPath+="$platform"
bspatch="$(which bspatch)"
cherry="./resources/ch3rryflower/Tools/ubuntu/UNTETHERED"
futurerestore="./resources/tools/futurerestore_linux"
python="$(which python3)"
elif [[ $OSTYPE == "darwin"* ]]; then
platform="macos"
platformver="${1:-$(sw_vers -productVersion)}"
if [[ $(echo $platformver | cut -c -2) == 10 ]]; then
local macver=$(echo $platformver | cut -c 4-)
macver=${macver%.*}
if (( macver < 13 )); then
Error "Your macOS version ($platformver) is not supported." \
"You need to be on macOS 10.13 or newer to continue."
fi
fi
MPath+="$platform"
if [[ -e /usr/local/bin/idevicedate && -e /usr/local/bin/irecovery ]]; then
Detect+="Homebrew (Intel Mac)"
MPath="/usr/local/bin"
elif [[ -e /opt/homebrew/bin/idevicedate && -e /opt/homebrew/bin/irecovery ]]; then
Detect+="Homebrew (Apple Silicon)"
MPath="/opt/homebrew/bin"
elif [[ -e /opt/local/bin/idevicedate && -e /opt/local/bin/irecovery ]]; then
Detect+="MacPorts"
MPath="/opt/local/bin"
else
Detect=
fi
2021-11-17 07:37:02 +01:00
[[ -n $Detect ]] && Log "$Detect"
bspatch="/usr/bin/bspatch"
cherry="$cherrymac"
futurerestore="./resources/tools/futurerestore_macos_$(uname -m)"
[[ ! -e $futurerestore ]] && futurerestore="./resources/tools/futurerestore_macos_arm64"
ipwnder32="./resources/tools/ipwnder32_macos"
ipwnder_lite="./resources/tools/ipwnder_macos"
python="/usr/bin/python"
elif [[ $OSTYPE == "msys" ]]; then
platform="win"
platformver="$(uname)"
MPath+="$platform"
bspatch="./resources/tools/bspatch_win"
futurerestore="./resources/tools/futurerestore_win"
python=/
fi
2022-06-29 04:48:17 +02:00
cherrybin="../$cherry/cherry"
hfsplus="../resources/tools/hfsplus_$platform"
ideviceenterrecovery="$MPath/ideviceenterrecovery"
ideviceinfo="$MPath/ideviceinfo"
idevicerestore="./resources/tools/idevicerestore_$platform"
idevicererestore="./resources/tools/idevicererestore_$platform"
iproxy="$MPath/iproxy"
2022-05-28 12:21:26 +02:00
ipsw="../resources/tools/ipsw_$platform"
ipwndfu="$python ipwndfu"
irecoverychk="$MPath/irecovery"
irecovery="$irecoverychk"
jq="./resources/tools/jq_$platform"
2021-06-01 09:21:37 +02:00
partialzip="./resources/tools/partialzip_$platform"
2022-05-28 12:21:26 +02:00
ping="ping -c1"
2022-07-20 12:21:30 +02:00
powdersn0w="../resources/tools/powdersn0w_$platform"
pwnedDFU="./resources/tools/pwnedDFU_$platform"
python2="$(which python2 2>/dev/null)"
rmsigchks="$python rmsigchks.py"
sha1sum="$(which sha1sum 2>/dev/null)"
sha256sum="$(which sha256sum 2>/dev/null)"
SimpleHTTPServer="$python -m SimpleHTTPServer 8888"
SSH="-F ./resources/ssh_config"
SCP="$(which scp) $SSH"
SSH="$(which ssh) $SSH"
2021-05-30 05:03:39 +02:00
tsschecker="./resources/tools/tsschecker_$platform"
xmlstarlet="./resources/tools/xmlstarlet_$platform"
2022-06-29 07:00:32 +02:00
xpwntool="../resources/tools/xpwntool_$platform"
zenity="./resources/tools/zenity_$platform"
if [[ $platform == "linux" ]]; then
2022-07-02 05:48:25 +02:00
irecovery="env LD_LIBRARY_PATH=./resources/lib $irecovery"
2022-06-29 07:00:32 +02:00
opensslver=$(openssl version | awk '{print $2}' | cut -c -3)
if [[ $opensslver == "3"* ]]; then
cherrybin="env LD_LIBRARY_PATH=../resources/lib $cherrybin"
idevicerestore="env LD_LIBRARY_PATH=../resources/lib $idevicerestore"
2022-06-29 07:00:32 +02:00
fi
ipwndfu="$python2 ipwndfu"
jq="$(which jq)"
rmsigchks="$python2 rmsigchks.py"
SimpleHTTPServer="$python -m http.server 8888"
xmlstarlet="$(which xmlstarlet)"
zenity="$(which zenity)"
#if [[ $(uname -m) == "a"* ]]; then
2022-12-24 04:49:22 +01:00
if [[ $(uname -m) == "a"* && $(getconf LONG_BIT) != 64 ]]; then
LinuxARMType="arm"
2022-12-24 04:49:22 +01:00
# these still need sudo even with the udev rule for some reason
futurerestore="${futurerestore}_arm"
idevicerestore="${idevicerestore}_arm"
idevicererestore="${idevicererestore}_arm"
2022-12-24 04:49:22 +01:00
irecovery="sudo ${irecovery}_arm"
pwnedDFU="sudo ${pwnedDFU}_arm"
hfsplus="${hfsplus}_arm"
2022-12-24 04:49:22 +01:00
ideviceenterrecovery="${ideviceenterrecovery}_arm"
ideviceinfo="${ideviceinfo}_arm"
iproxy="${iproxy}_arm"
ipsw="${ipsw}_arm"
2022-12-24 05:22:27 +01:00
irecoverychk="${irecoverychk}_arm"
2022-12-24 04:49:22 +01:00
partialzip="${partialzip}_arm"
powdersn0w="${powdersn0w}_arm"
tsschecker="${tsschecker}_arm"
xpwntool="${xpwntool}_arm"
: '
if [[ $(getconf LONG_BIT) == 64 ]]; then
LinuxARMType="arm64"
futurerestore="${futurerestore}64"
hfsplus="${hfsplus}64"
idevicerestore="${idevicerestore}64"
idevicererestore="${idevicererestore}64"
irecovery="${irecovery}64"
pwnedDFU="${pwnedDFU}64"
ideviceenterrecovery="${ideviceenterrecovery}_arm"
ideviceinfo="${ideviceinfo}64"
iproxy="${iproxy}64"
ipsw="${ipsw}64"
irecoverychk="${irecoverychk}64"
partialzip="${partialzip}64"
powdersn0w="${powdersn0w}64"
tsschecker="${tsschecker}64"
xpwntool="${xpwntool}64"
fi
'
futurerestore="sudo LD_LIBRARY_PATH=./resources/lib/$LinuxARMType $futurerestore"
idevicerestore="sudo LD_LIBRARY_PATH=./resources/lib/$LinuxARMType $idevicerestore"
idevicererestore="sudo LD_LIBRARY_PATH=./resources/lib/$LinuxARMType $idevicererestore"
2022-12-24 04:49:22 +01:00
fi
2022-06-29 04:48:17 +02:00
elif [[ $platform == "macos" ]]; then
sha1sum="$(which shasum)"
sha256sum="$sha1sum -a 256"
2022-07-01 13:22:10 +02:00
if (( ${platformver:0:2} > 11 )); then
# for macOS 12 and newer
python="/usr/bin/python3"
ipwndfu="$python2 ipwndfu"
rmsigchks="$python2 rmsigchks.py"
SimpleHTTPServer="$python -m http.server 8888"
fi
elif [[ $platform == "win" ]]; then
ping="ping -n 1"
2022-12-22 06:02:03 +01:00
Log "WARNING - Using iOS-OTA-Downgrader on Windows is not recommended."
Echo "* Please use it on Linux or macOS instead."
2022-12-22 06:02:03 +01:00
Echo "* You may still continue, but you might encounter issues with restoring the device."
Input "Press Enter/Return to continue anyway (or press Ctrl+C to cancel)"
read -s
fi
Log "Running on platform: $platform ($platformver)"
}
SaveExternal() {
2022-07-07 08:21:53 +02:00
local Link
local Name
local SHA1
if [[ $1 == "ipwndfu" ]]; then
Link=https://github.com/LukeZGD/ipwndfu/archive/6e67c9e28a5f7f63f179dea670f7f858712350a0.zip
Name=ipwndfu
SHA1=61333249eb58faebbb380c4709384034ce0e019a
elif [[ $1 == "ch3rryflower" ]]; then
Link=https://web.archive.org/web/20210529174714if_/https://codeload.github.com/dora2-iOS/ch3rryflower/zip/316d2cdc5351c918e9db9650247b91632af3f11f
Name=ch3rryflower
SHA1=790d56db354151b9740c929e52c097ba57f2929d
elif [[ $1 == "powdersn0w" ]]; then
2023-01-04 09:25:18 +01:00
Link=https://web.archive.org/web/20220802230119if_/https://dora2ios.github.io/download/konayuki/powdersn0w_v2.0b3.zip
Name=powdersn0w
SHA1=c733aac4a0833558ef9f5517f2a11ca547110b6e
2022-07-07 08:21:53 +02:00
fi
if [[ -d ./resources/$Name ]]; then
return
fi
cd tmp
2022-07-07 08:21:53 +02:00
SaveFile $Link $Name.zip $SHA1
cd ../resources
2022-07-07 08:21:53 +02:00
unzip -q ../tmp/$Name.zip -d .
mv $Name*/ $Name/
cd ..
}
SaveFile() {
Log "Downloading $2..."
curl -L $1 -o $2
local SHA1=$($sha1sum $2 | awk '{print $1}')
2021-09-29 11:26:04 +02:00
if [[ $SHA1 != $3 ]]; then
Error "Verifying $2 failed. The downloaded file may be corrupted or incomplete. Please run the script again" \
"SHA1sum mismatch. Expected $3, got $SHA1"
fi
}
InstallDepends() {
local libimobiledevice
mkdir resources/lib tmp 2>/dev/null
cd resources
cp lib/*.so.1.1 ../tmp/ 2>/dev/null
2022-07-07 08:21:53 +02:00
rm -rf lib/*
2022-07-04 12:24:13 +02:00
cp ../tmp/*.so.1.1 lib/ 2>/dev/null
cd ../tmp
Log "Installing dependencies..."
2021-08-20 03:58:17 +02:00
if [[ $platform == "linux" ]]; then
Echo "* iOS-OTA-Downgrader will be installing dependencies from your distribution's package manager"
Echo "* Enter your user password when prompted"
2021-08-20 03:58:17 +02:00
Input "Press Enter/Return to continue (or press Ctrl+C to cancel)"
read -s
2022-12-24 05:05:01 +01:00
elif [[ $platform == "win" ]]; then
Echo "* iOS-OTA-Downgrader will be installing dependencies from MSYS2"
Echo "* Note that you may have to run the script more than once"
Input "Press Enter/Return to continue (or press Ctrl+C to cancel)"
read -s
2021-08-20 03:58:17 +02:00
fi
if [[ -e /etc/debian_version ]]; then
DebianVer=$(cat /etc/debian_version)
if [[ $DebianVer == *"sid" ]]; then
DebianVer="sid"
else
DebianVer="$(echo $DebianVer | cut -c -2)"
fi
fi
if [[ $ID == "arch" || $ID_LIKE == "arch" || $ID == "artix" ]]; then
2022-09-24 11:01:48 +02:00
Echo "* Arch Linux repos do not ship python2, which is needed for ipwndfu"
Echo "* If you need to use ipwndfu, python2 can be installed from the AUR"
sudo pacman -Sy --noconfirm --needed base-devel bsdiff curl jq libimobiledevice openssh python udev unzip usbmuxd usbutils vim xmlstarlet zenity zip
2022-12-24 04:49:22 +01:00
elif [[ $ID == "gentoo" || $ID_LIKE == "gentoo" || $ID == "pentoo" ]]; then
2022-10-03 06:32:40 +02:00
Echo "* Gentoo repos do not ship python2, which is needed for ipwndfu"
Echo "* If you need to use ipwndfu, python2 can be installed from the official site"
sudo emerge -av bsdiff net-misc/curl jq libimobiledevice openssh python udev unzip usbmuxd usbutils vim xmlstarlet zenity zip
2022-12-24 04:49:22 +01:00
2021-11-17 07:37:02 +01:00
elif [[ -n $UBUNTU_CODENAME && $VERSION_ID == "2"* ]] ||
(( DebianVer >= 11 )) || [[ $DebianVer == "sid" ]]; then
[[ -n $UBUNTU_CODENAME ]] && sudo add-apt-repository -y universe
sudo apt update
2023-01-04 09:25:18 +01:00
sudo apt install -y bsdiff curl jq libimobiledevice6 openssh-client python3 unzip usbmuxd usbutils xmlstarlet xxd zenity zip
[[ $DebianVer != "sid" ]] && sudo apt install -y python2
2022-07-02 05:48:25 +02:00
sudo systemctl enable --now udev systemd-udevd usbmuxd 2>/dev/null
2022-11-26 14:38:37 +01:00
elif [[ $ID == "fedora" || $ID == "nobara" ]] && (( VERSION_ID >= 36 )); then
ln -sf /usr/lib64/libbz2.so.1.* ../resources/lib/libbz2.so.1.0
sudo dnf install -y bsdiff ca-certificates jq libimobiledevice openssl python2 python3 systemd udev usbmuxd vim-common xmlstarlet zenity zip
2022-07-02 05:48:25 +02:00
sudo ln -sf /etc/pki/tls/certs/ca-bundle.crt /etc/pki/tls/certs/ca-certificates.crt
2022-06-29 04:48:17 +02:00
elif [[ $ID == "opensuse-tumbleweed" || $PRETTY_NAME == *"Leap 15.4" ]]; then
[[ $ID == "opensuse-leap" ]] && ln -sf /lib64/libreadline.so.7 ../resources/lib/libreadline.so.8
sudo zypper -n in bsdiff curl jq libimobiledevice-1_0-6 openssl python-base python3 usbmuxd unzip vim xmlstarlet zenity zip
elif [[ $platform == "macos" ]]; then
xcode-select --install
2022-05-28 12:21:26 +02:00
libimobiledevice=("https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/libimobiledevice_macos.zip" "66a49e4f69757a3d9dc51109a8e4651020bfacb8")
Echo "* iOS-OTA-Downgrader provides a copy of libimobiledevice and libirecovery by default"
2022-07-07 08:21:53 +02:00
Echo "* In case that problems occur, try installing them from Homebrew or MacPorts"
Echo "* The script will detect this automatically and will use the Homebrew/MacPorts versions of the tools"
elif [[ $platform == "win" ]]; then
cd ..
rm -r tmp
pacman -Syu --noconfirm --needed ca-certificates curl libcurl libopenssl openssh openssl unzip zip
mkdir tmp
cd tmp
libimobiledevice=("https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/libimobiledevice_win.zip" "75ae3af3347b89107f0f6b7e41fde42e6ccdd404")
2022-07-04 13:58:45 +02:00
if [[ ! $(ls ../resources/tools/*win*) ]]; then
SaveFile https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/tools_win.zip tools_win.zip fcaa14e420885c7a0e854aad3119e8a29362813b
2022-07-04 13:58:45 +02:00
Log "Extracting Windows tools..."
unzip -oq tools_win.zip -d ../resources
fi
else
Error "Distro not detected/supported by the install script." "See the repo README for supported OS versions/distros"
fi
if [[ $platform == "linux" ]]; then
2022-04-29 10:16:31 +02:00
libimobiledevice=("https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/libimobiledevice_linux.zip" "fc5e714adf6fa72328d3e1ddea4e633f370559a4")
2022-07-02 05:48:25 +02:00
# from linux_fix script by Cryptiiiic
sudo systemctl enable --now systemd-udevd usbmuxd 2>/dev/null
echo "QUNUSU9OPT0iYWRkIiwgU1VCU1lTVEVNPT0idXNiIiwgQVRUUntpZFZlbmRvcn09PSIwNWFjIiwgQVRUUntpZFByb2R1Y3R9PT0iMTIyWzI3XXwxMjhbMC0zXSIsIE9XTkVSPSJyb290IiwgR1JPVVA9InVzYm11eGQiLCBNT0RFPSIwNjYwIiwgVEFHKz0idWFjY2VzcyIKCkFDVElPTj09ImFkZCIsIFNVQlNZU1RFTT09InVzYiIsIEFUVFJ7aWRWZW5kb3J9PT0iMDVhYyIsIEFUVFJ7aWRQcm9kdWN0fT09IjEzMzgiLCBPV05FUj0icm9vdCIsIEdST1VQPSJ1c2JtdXhkIiwgTU9ERT0iMDY2MCIsIFRBRys9InVhY2Nlc3MiCgoK" | base64 -d | sudo tee /etc/udev/rules.d/39-libirecovery.rules >/dev/null 2>/dev/null
sudo chown root:root /etc/udev/rules.d/39-libirecovery.rules
sudo chmod 0644 /etc/udev/rules.d/39-libirecovery.rules
2022-07-02 05:48:25 +02:00
sudo udevadm control --reload-rules
fi
if [[ ! -d ../resources/libimobiledevice_$platform && $MPath == "./resources"* ]]; then
SaveFile ${libimobiledevice[0]} libimobiledevice.zip ${libimobiledevice[1]}
mkdir ../resources/libimobiledevice_$platform
Log "Extracting libimobiledevice..."
unzip -q libimobiledevice.zip -d ../resources/libimobiledevice_$platform
chmod +x ../resources/libimobiledevice_$platform/*
elif [[ $MPath != "./resources"* ]]; then
mkdir ../resources/libimobiledevice_$platform
fi
2022-12-24 04:49:22 +01:00
if [[ $platform == "linux" && $(uname -m) == "a"* && ! $(ls ../resources/tools/*linux_arm*) ]]; then
SaveFile https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/tools_linux_arm.zip tools_linux_arm.zip 59c16f684310bde75e12d4719bb918d448d47630
2022-12-24 04:49:22 +01:00
Log "Extracting Linux ARM tools..."
unzip -oq tools_linux_arm.zip -d ../resources
#SaveFile https://github.com/LukeZGD/iOS-OTA-Downgrader-Keys/releases/download/tools/tools_linux_arm64.zip tools_linux_arm64.zip b95b2bc1589ff1fe1e16ab7ac43e9d88d9880296
#Log "Extracting Linux ARM64 tools..."
#unzip -oq tools_linux_arm64.zip -d ../resources
2022-12-24 04:49:22 +01:00
fi
touch ../resources/first_run
Log "Install script done! Please run the script again to proceed"
2022-07-02 05:48:25 +02:00
Log "If your iOS device is plugged in, unplug and replug your device"
2022-07-18 13:53:45 +02:00
ExitWin 0
}