2021-03-08 13:23:48 +00:00
# OSX Serial Generator
![Running mac osx in a docker container ](/running-mac-inside-docker-qemu.png?raw=true "OSX KVM DOCKER" )
2021-06-15 13:49:22 +00:00
Generate macOS valid serials, uuids, and board serials for good-faith Security Research & Apple Bug Bounty Research.
2021-03-08 13:23:48 +00:00
2021-03-08 13:57:49 +00:00
This project provides two tools for generating serial numbers for Hackintosh, [OpenCore ](https://github.com/acidanthera/OpenCorePkg ), [Docker-OSX ](https://github.com/sickcodes/Docker-OSX ) and [OSX-KVM ](https://github.com/kholia/OSX-KVM ).
2021-03-08 13:23:48 +00:00
2021-06-15 13:49:22 +00:00
Author: Sick.Codes https://github.com/sickcodes | https://sick.codes | https://twitter.com/sickcodes
2021-03-08 13:23:48 +00:00
2021-03-08 14:13:42 +00:00
### Follow @sickcodes on Twitter for updates! [https://twitter.com/sickcodes](https://twitter.com/sickcodes)
2021-06-15 13:49:22 +00:00
Terms & Conditions: Manipulation of serial numbers are an important aspect of conducting Cyber Security Research into the iMessage & Facetime frameworks. Finding and reporting vulnerabilities in Apple software before Threat Actors do is important. To use this project to find & discover vulnerabilities in said protocols, you should agree to [Apple's Security Bounty program ](https://developer.apple.com/security-bounty/requirements/ ).
2021-03-08 13:57:49 +00:00
2021-03-22 14:54:38 +00:00
### Upstream Thanks
2021-06-15 13:49:22 +00:00
This project was created for use with [Docker-OSX ](https://github.com/sickcodes/Docker-OSX ) and uses `config.plist` files from [@Kholia ](https://github.com/kholia )'s project https://github.com/kholia/OSX-KVM.
2021-03-22 14:54:38 +00:00
2021-06-15 13:49:22 +00:00
The `config.plist` files are also curated and maintained upstream by [@thenickdude ](https://github.com/thenickdude ) and we thank both of them for their excellent work. Upstream KVM changes are made at: [https://github.com/thenickdude/KVM-Opencore ](https://github.com/thenickdude/KVM-Opencore )
This project is a wrapper for the [OpenCore project ](https://dortania.github.io/getting-started/ ) bootloader's fantastic tool called [macserial ](https://github.com/acidanthera/OpenCorePkg/tree/master/Utilities/macserial ).
Many thanks to the [OpenCore Project ](https://dortania.github.io/getting-started/ ) for providing `macserial` .
2021-03-22 14:54:38 +00:00
See the project which drives Hackintosh: [https://github.com/acidanthera/OpenCorePkg ](https://github.com/acidanthera/OpenCorePkg )
2021-06-15 13:49:22 +00:00
As seen on Vice: [Open-Source App Lets Anyone Create a Virtual Army of Hackintoshes ](https://www.vice.com/en/article/akdmb8/open-source-app-lets-anyone-create-a-virtual-army-of-hackintoshes )
2021-03-22 14:54:38 +00:00
2021-03-08 13:23:48 +00:00
### PR & Contributor Credits
https://github.com/sickcodes/osx-serial-generator/blob/master/CREDITS.md
## Related
- [Docker-OSX ](https://github.com/sickcodes/Docker-OSX )
- [OSX-KVM ](https://github.com/kholia/OSX-KVM )
2021-06-15 13:49:22 +00:00
- [KVM-Opencore ](https://github.com/thenickdude/KVM-Opencore )
2021-03-08 13:23:48 +00:00
- [OpenCore ](https://github.com/acidanthera/OpenCorePkg )
- [Hackintosh ](https://www.reddit.com/r/hackintosh/ )
# Purpose
2021-06-15 13:49:22 +00:00
These shell scripts were written by [@sickcodes ](https://github.com/sickcodes ) [https://twitter.com/sickcodes ](https://twitter.com/sickcodes ) and were created for automating the generation of unique & valid values at runtime in [Docker-OSX ](https://github.com/sickcodes/Docker-OSX ).
2021-03-08 13:23:48 +00:00
This is for generating sets of serial numbers that simply work.
2021-06-15 13:49:22 +00:00
If this is your first time, just `bash ./generate-unique-machine-values.sh` and you will be given 1 complete serial number set.
2021-03-08 13:23:48 +00:00
2021-03-08 14:13:42 +00:00
With your new serial numbers, you can:
- put them in your existing `config.plist` and reboot
- tell the script to make a new `OpenCore.qcow2`
- output as TSV and CSV, and more!
2021-06-15 13:49:22 +00:00
- use `--help` to see all available goodies
2021-03-08 14:13:42 +00:00
2021-03-08 13:23:48 +00:00
Used at runtime in [Docker-OSX ](https://github.com/sickcodes/Docker-OSX ).
- [https://github.com/kholia/OSX-KVM ](https://github.com/kholia/OSX-KVM ): "Run macOS on QEMU/KVM. With OpenCore + Big Sur support now! Only commercial (paid) support is available."
- [https://github.com/sickcodes/Docker-OSX ](https://github.com/sickcodes/Docker-OSX ): "Run Mac in a Docker! Run near native OSX-KVM in Docker! X11 Forwarding! CI/CD for OS X!"
2021-06-15 13:49:22 +00:00
- [https://github.com/thenickdude/KVM-Opencore ](https://github.com/thenickdude/KVM-Opencore ): "OpenCore disk image for Proxmox/QEMU"
2021-03-08 13:23:48 +00:00
# Requirements
```bash
2021-03-09 11:30:16 +00:00
# Ubuntu, Debian, Pop
2021-03-08 14:24:00 +00:00
sudo apt update -y
2021-03-08 14:27:14 +00:00
sudo apt install libguestfs-tools build-essential wget git linux-generic sudo -y
2021-03-08 13:23:48 +00:00
# Fedora, RHEL, CentOS
2021-03-08 14:27:14 +00:00
sudo yum install libguestfs libguestfs-tools wget git kernel-devel sudo -y
2021-03-08 13:23:48 +00:00
sudo yum groupinstall 'Development Tools' -y
# Arch, Manjaro
2021-03-08 14:27:14 +00:00
sudo pacman -Sy libguestfs wget git base-devel linux sudo
2021-03-08 13:23:48 +00:00
```
# Generating New Unique Serial Numbers
Example
2021-03-08 13:38:52 +00:00
2021-03-08 13:23:48 +00:00
```bash
2021-03-08 13:38:52 +00:00
# make 1 full serial set
2021-03-08 14:13:42 +00:00
./generate-unique-machine-values.sh \
-c 1 \
--model="iMacPro1,1"
2021-03-08 13:38:52 +00:00
```
Done!
2021-03-08 14:29:02 +00:00
CSV file and TSV file should be saved in your current working directory.
2021-03-08 13:38:52 +00:00
Slip those values into your config.plist and reboot!
2021-03-08 14:13:42 +00:00
## Extended options - Automation?
2021-03-08 13:38:52 +00:00
### Need more serials?
2021-03-08 13:23:48 +00:00
2021-03-08 13:38:52 +00:00
```bash
2021-03-08 13:23:48 +00:00
# make 100 serial sets
2021-03-08 14:13:42 +00:00
./generate-unique-machine-values.sh \
-c 100 \
--model="iMacPro1,1"
2021-03-08 13:38:52 +00:00
```
2021-03-08 14:29:02 +00:00
### Want to make 50 OpenCore bootdisks AND 50 output plists?
2021-03-08 13:23:48 +00:00
2021-03-08 13:38:52 +00:00
```bash
2021-03-08 14:13:42 +00:00
# make 5 serial sets
# but also make config.plist for each set
# and OpenCore-nopicker.qcow2 for each serial set.
./generate-unique-machine-values.sh \
2021-03-08 14:29:02 +00:00
-c 50 \
2021-03-08 14:13:42 +00:00
--create-plists \
--create-bootdisks
2021-03-08 13:23:48 +00:00
```
## Already have your own `config.plist`?
If you want to automate creating the qcow bootdisk each time, you can use placeholders and let this script build the image each time you change anything.
2021-03-08 14:13:42 +00:00
If you want to use placeholders, you can supply that to either of the scripts in this repo and use:
`--custom-plist=./my_config.plist`
2021-03-08 13:23:48 +00:00
```bash
2021-03-08 14:13:42 +00:00
# make 5 serial sets
# but also use my config.plist for each set
# AND make qcow2 image for each set!
./generate-unique-machine-values.sh \
-c 5 \
--custom-plist=./my_config.plist \
--create-bootdisks
2021-03-08 13:23:48 +00:00
```
2021-03-08 14:13:42 +00:00
You can also use an URL for the input plist using:
`--master-plist-url` .
2021-03-08 13:38:52 +00:00
2021-03-08 13:23:48 +00:00
Or you can manually enter the values generated above:
```xml
2021-03-08 14:13:42 +00:00
< key > MLB< / key >
< string > {{BOARD_SERIAL}}< / string >
< key > ROM< / key >
< data > {{ROM}}< / data >
< key > SpoofVendor< / key >
< true / >
< key > SystemProductName< / key >
< string > {{DEVICE_MODEL}}< / string >
< key > SystemSerialNumber< / key >
< string > {{SERIAL}}< / string >
< key > SystemUUID< / key >
< string > {{UUID}}< / string >
...
...
...
< key > Resolution< / key >
< string > {{WIDTH}}x{{HEIGHT}}@32< / string >
< key > SanitiseClearScreen< / key >
2021-03-08 13:23:48 +00:00
```
```
{{DEVICE_MODEL}}, {{SERIAL}}, {{BOARD_SERIAL}},
{{UUID}}, {{ROM}}, {{WIDTH}}, {{HEIGHT}}
```
```bash
General options:
--count, -n, -c < count > Number of serials to generate
--model, -m < model > Device model, e.g. 'iMacPro1,1'
--csv < filename > Optionally change the CSV output filename
--tsv < filename > Optionally change the TSV output filename
--output-dir < directory > Optionally change the script output location
--width < string > Resolution x axis length in px, default 1920
--height < string > Resolution y axis length in px, default 1080
--master-plist-url < url > Specify an alternative master plist, via URL
--master-plist < filename > Optionally change the input plist
--custom-plist < filename > Same as --master-plist
--output-bootdisk < filename > Optionally change the bootdisk filename
--envs Create all corresponding sourcable envs
--plists Create all corresponding config.plists
--bootdisks Create all corresponding bootdisks [SLOW]
--help, -h, help Display this help and exit
Additional options only if you are creating ONE serial set:
--output-bootdisk < filename > Optionally change the bootdisk filename
--output-env < filename > Optionally change the serials env filename
Custom plist placeholders:
{{DEVICE_MODEL}}, {{SERIAL}}, {{BOARD_SERIAL}},
{{UUID}}, {{ROM}}, {{WIDTH}}, {{HEIGHT}}
Example:
./generate-unique-machine-values.sh --count 1 --plists --bootdisks --envs
Defaults:
- One serial, for 'iMacPro1,1', in the current working directory
- CSV and TSV output
- plists in ./plists/ & bootdisks in ./bootdisks/ & envs in ./envs
- if you set --bootdisk name, --bootdisks is assumed
- if you set --custom-plist, --plists is assumed
- if you set --output-env, --envs is assumed
```
# Generating A Bootdisk Using Specific Serial Numbers
If you already know the serial numbers, or you've generated them above in the past, then you can use this script:
```bash
Required options:
--model < string > Device model, e.g. 'iMacPro1,1'
--serial < string > Device Serial number
--board-serial < string > Main Logic Board Serial number (MLB)
--uuid < string > SMBIOS UUID (SmUUID)
--mac-address < string > Used for both the MAC address and to set ROM
ROM is lowercased sans any colons
Optional options:
--width < integer > Resolution x axis length in px, default 1920
--height < integer > Resolution y axis length in px, default 1080
--master-plist-url < url > Specify an alternative master plist, via URL
--custom-plist < filename >
|| --master-plist < filename > Optionally change the input plist.
--output-bootdisk < filename > Optionally change the bootdisk filename
--output-plist < filename > Optionally change the output plist filename
--help, -h, help Display this help and exit
Placeholders: {{DEVICE_MODEL}}, {{SERIAL}}, {{BOARD_SERIAL}}, {{UUID}},
{{ROM}}, {{WIDTH}}, {{HEIGHT}}
2021-03-08 14:13:42 +00:00
```
2021-03-08 13:23:48 +00:00
2021-03-08 14:13:42 +00:00
Example using your serials generated earlier:
2021-03-08 13:23:48 +00:00
2021-03-08 14:13:42 +00:00
```bash
CUSTOM_PLIST=https://raw.githubusercontent.com/sickcodes/osx-serial-generator/master/config-nopicker-custom.plist
./generate-specific-bootdisk.sh \
--input-plist-url="${CUSTOM_PLIST}" \
--model iMacPro1,1 \
--serial C02TW0WAHX87 \
--board-serial C027251024NJG36UE \
--uuid 5CCB366D-9118-4C61-A00A-E5BAF3BED451 \
--mac-address A8:5C:2C:9A:46:2F \
--output-bootdisk ./OpenCore-nopicker.qcow2 \
--width 1920 \
--height 1080
2021-03-08 13:23:48 +00:00
```
# Examples from Docker-OSX
In the case example of why these scripts were written is:
`GENERATE_UNIQUE` is used as a Docker argument to randomly generate 1 set at runtime, for every new container.
`GENERATE_SPECIFIC` is used to specify an already known model, serial, board-serial, uuid and MAC address.
```bash
[[ "${GENERATE_UNIQUE}" == true ]] & & { \
./Docker-OSX/custom/generate-unique-machine-values.sh \
--master-plist-url="${MASTER_PLIST_URL}" \
--count 1 \
--tsv ./serial.tsv \
--bootdisks \
--width "${WIDTH:-1920}" \
--height "${HEIGHT:-1080}" \
--output-bootdisk "${BOOTDISK:=/home/arch/OSX-KVM/OpenCore-Catalina/OpenCore.qcow2}" \
--output-env "${ENV:=/env}" \
; } \
; [[ "${GENERATE_SPECIFIC}" == true ]] & & { \
source "${ENV:=/env}" 2>/dev/null \
; ./Docker-OSX/custom/generate-specific-bootdisk.sh \
--master-plist-url="${MASTER_PLIST_URL}" \
--model "${DEVICE_MODEL}" \
--serial "${SERIAL}" \
--board-serial "${BOARD_SERIAL}" \
--uuid "${UUID}" \
--mac-address "${MAC_ADDRESS}" \
--width "${WIDTH:-1920}" \
--height "${HEIGHT:-1080}" \
--output-bootdisk "${BOOTDISK:=/home/arch/OSX-KVM/OpenCore-Catalina/OpenCore.qcow2}"
```
2021-06-15 13:49:22 +00:00
# Special Update Notes
-----------------
2021-05-04 - On May 4th 2021 we updated from v11 to v12 via [@thenickdude ](https://github.com/thenickdude )'s upstream `config.plist` files from [KVM-Opencore ](https://github.com/thenickdude/KVM-Opencore ).
As seen in a PR to OSX-KVM upstream: [https://github.com/kholia/OSX-KVM/pull/173 ](https://github.com/kholia/OSX-KVM/pull/173 )
```bash
wget https://github.com/thenickdude/KVM-Opencore/compare/v11...v12.patch
patch -F 10 -p1 --verbose config-nopicker-custom.plist v11...v12.patch
patch -F 10 -p1 --verbose config-custom.plist v11...v12.patch
```
Rejected patch lines:
```patch
--- EFI/OC/config.plist
+++ EFI/OC/config.plist
@@ -224,17 +344,17 @@
< / dict >
< dict >
< key > Base< / key >
- < string ></ string >
+ < string > \_SB.PCI0.LPCB.HPET</ string >
< key > BaseSkip< / key >
< integer > 0< / integer >
< key > Comment< / key >
- < string > _Q12 to XQ12</ string >
+ < string > HPET _CRS to XCRS< / string >
< key > Count< / key >
< integer > 1< / integer >
< key > Enabled< / key >
< false / >
< key > Find< / key >
- < data > X1ExMg==</ data >
+ < data > X0NSUw==< / data >
< key > Limit< / key >
< integer > 0< / integer >
< key > Mask< / key >
@@ -1056,9 +1302,9 @@
< key > AppleEvent< / key >
< string > Builtin< / string >
< key > CustomDelays< / key >
- < string > Auto</ string >
+ < false / >
< key > KeyInitialDelay< / key >
- < integer > 0</ integer >
+ < integer > 50< / integer >
< key > KeySubsequentDelay< / key >
< integer > 5< / integer >
< key > PointerSpeedDiv< / key >
--- src/OpenCorePkg
+++ src/OpenCorePkg
@@ -1 +1 @@
-Subproject commit 5cd223f03dd555c2ad0c6f45181808a5105bb605
+Subproject commit 5668fb62b50e8141d93ae6fce3e3fe238822f6ef
```
Replaced
```xml
< key > Comment< / key >
< string > _Q12 to XQ12< / string >
```
with
```xml
< key > Base< / key >
< string > \_SB.PCI0.LPCB.HPET</ string >
< key > BaseSkip< / key >
< integer > 0< / integer >
< key > Comment< / key >
< string > HPET _CRS to XCRS< / string >
```
and
```diff
- < data > X1ExMg==</ data >
+ < data > X0NSUw==< / data >
```
Ignored:
```diff
@@ -1056,9 +1302,9 @@
< key > AppleEvent< / key >
< string > Builtin< / string >
< key > CustomDelays< / key >
- < string > Auto</ string >
+ < false / >
< key > KeyInitialDelay< / key >
- < integer > 0</ integer >
+ < integer > 50< / integer >
< key > KeySubsequentDelay< / key >
< integer > 5< / integer >
< key > PointerSpeedDiv< / key >
```
-----------------