Bash script to help build and run an offline installer in recovery.
- UnPlugged
- gibMacOS - or a .dmg/.pkg from the "older versions" linked here
- macrecovery.py (or gibMacRecovery)
- A 16+ GB USB drive
- Your EFI set up by following the Dortania guide
-
Download the same version of macOS via both
gibMacOS
andmacrecovery.py
◦ i.e. If you want to download Ventura, make sure you get Ventura from both
gibMacOS
andmacrecovery.py
◦ They just need to be the same major version (i.e. Ventura with Ventura), it does not need to be the exact same point release (i.e. 13.x.y and 13.x.y)
-
Format your USB with 2 partitions:
◦ A FAT32 partition of ~750MB to 1GB (enough to accommodate the EFI and com.apple.recovery.boot folders)
◦ An ExFAT partition of the remaining space (needs to be enough to accommodate the files downloaded from
gibMacOS
) -
Copy your EFI folder and the com.apple.recovery.boot folder over to the FAT32 partition
-
Copy the folder containing the files downloaded from gibMacOS to the ExFAT partition
◦ You'll be
cd
ing to this folder later - so it may make sense to label it something easy to type likemacOS
-
Copy
UnPlugged.command
to that same folder on the ExFAT partition -
Eject the USB drive - this ensures any pending cached writes are applied and can help prevent corrupt or incomplete file copies
-
Boot into the install environment
-
Open Disk Utility
-
Enable View -> Show All Devices
-
Format the target device (not the volume) for your macOS version
◦ Sierra and prior should be macOS Extended (Journaled) with a GUID Partition Map
◦ High Sierra and newer should be APFS with a GUID Parititon Map
-
Quit Disk Utility
-
Open Terminal
-
Type
cd /Volumes/[your ExFAT volume name]/macOS
◦ You can get a list of all volumes with
ls /Volumes
◦ Make sure to replace
macOS
with the name of the folder containing the gibMacOS files andUnPlugged.command
-
Type
./UnPlugged.command
to launch the script◦ If that does not work - you can type
bash UnPlugged.command
-
The script will assess available approaches for locating the
Install [macOS version].app
needed, and may prompt you to choose from a list of two or more of the following:◦
Fully expand InstallAssistant.pkg - slower, but no risk of app mismatch
- if leveraging InstallAssistant.pkg on a recovery env wherepkgutil
supports the--expand-full
switch (most do)◦
Extract the Install [macOS version].app from BaseSystem.dmg
- if a BaseSystem.dmg or RecoveryImage.dmg is detected next to InstallAssistant.pkg◦
Choose a locally discovered Install [macOS version].app
- if any installers were detected locally -
The script should auto-detect the required files - but if it does not, it will prompt for the path to them here
-
The script will then prompt asking for the target volume - this is the volume that you just created in Disk Utility. The one where you intend to install macOS
-
Then you'll be presented with a task list - and asked if you want to continue - type
y
and enter -
The script will build the full install app and launch it from the Terminal for you - continue the rest of the install as normal
◦ Make sure to leave the Terminal open - do not quit it, as doing so will also quit the installer.
It seems the Sonoma+ BaseSystem.dmg recovery environment does not allow mounting FAT32 or ExFAT volumes at all. To work around this using UnPlugged requires a couple extra steps.
You'll need to use an earlier BaseSystem.dmg|.chunklist downloaded via macrecovery.py
in your com.apple.recovery.boot folder (Monterey works fine with FAT32 and ExFAT volumes). You'll also need to download Sonoma's BaseSystem.dmg via macrecovery.py
and place that alongside the files downloaded with gibMacOS
if you don't intend to expand the InstallAsisstant.pkg directly. The end result should look something like the following:
USB Drive
|-> 800MB FAT32 Partition (named OPENCORE or similar)
| |-> EFI
| \-> com.apple.recovery.boot
| |-> BaseSystem.dmg (for Monterey)
| \-> BaseSystem.chunklist (for Monterey)
\-> 15+GB ExFAT Partition (named UnPlugged or similar)
|-> InstallAssistant.pkg (for Sonoma+)
|-> BaseSystem.dmg (for Sonoma+, if not expanding the .pkg directly)
\-> UnPlugged.command
When prompted to select where you would like to get the Install [macos Version].app
from, selecting Extract the Install [macOS version].app from BaseSystem.dmg
will leverage the provided BaseSystem.dmg.
The rest of the process should be the same as with prior OS versions.