2021-01-24 20:47:19 +08:00
#!/usr/bin/docker
# ____ __ ____ ______ __
# / __ \____ _____/ /_____ _____/ __ \/ ___/ |/ /
# / / / / __ \/ ___/ //_/ _ \/ ___/ / / /\__ \| /
# / /_/ / /_/ / /__/ ,< / __/ / / /_/ /___/ / |
2021-03-04 21:22:13 +08:00
# /_____/\____/\___/_/|_|\___/_/ \____//____/_/|_| :AUTO
2021-01-24 20:47:19 +08:00
#
2021-03-04 21:22:13 +08:00
# Title: Docker-OSX (Mac on Docker)
# Author: Sick.Codes https://twitter.com/sickcodes
2021-03-25 05:16:03 +08:00
# Version: 4.3
2021-01-24 20:47:19 +08:00
# License: GPLv3+
# Repository: https://github.com/sickcodes/Docker-OSX
2021-03-04 21:22:13 +08:00
# Website: https://sick.codes
2021-01-24 20:47:19 +08:00
#
# This Dockerfile is a pre-installed naked installation of Docker-OSX!
#
# Default username: user
# Default password: alpine
#
# Take screenshots in the Arch container and display in terminal: scrotcat
# readme:
# timezone: UTC/GMT
#
# Future versions will navigate the installation process, inside the Dockerfile.
#
#
# Build:
#
# docker build -t docker-osx:auto -f Dockerfile.auto .
#
# Run:
#
# docker run -it --device /dev/kvm -p 50922:10022 -v ${PWD}/mac_hdd_ng_auto.img:/image docker-osx-auto:latest
#
# SSH:
# From inside the container:
# ssh -i ~/.ssh/id_docker_osx user@127.0.0.1 -p 10022
#
# From outside the container:
# ssh localhost user@127.0.0.1 -p 50922
# docker exec -it containerid ssh -i ~/.ssh/id_docker_osx user@127.0.0.1 -p 10022
FROM sickcodes/docker-osx:latest
MAINTAINER 'https://twitter.com/sickcodes' <https://sick.codes>
USER root
WORKDIR /root
2021-02-03 10:04:22 +08:00
# For taking screenshots of the Xfvb screen, useful during development.
ARG SCROT
2021-01-24 20:47:19 +08:00
# OPTIONAL: Arch Linux server mirrors for super fast builds
# set RANKMIRRORS to any value other that nothing, e.g. -e RANKMIRRORS=true
ARG RANKMIRRORS
ARG MIRROR_COUNTRY = US
ARG MIRROR_COUNT = 10
2021-02-03 10:04:22 +08:00
RUN if [ [ " ${ RANKMIRRORS } " ] ] ; then \
{ pacman -Sy wget --noconfirm || pacman -Syu wget --noconfirm ; } \
; wget -O ./rankmirrors "https://raw.githubusercontent.com/sickcodes/Docker-OSX/master/rankmirrors" \
; wget -O- " https://www.archlinux.org/mirrorlist/?country= ${ MIRROR_COUNTRY :- US } &protocol=https&use_mirror_status=on " \
| sed -e 's/^#Server/Server/' -e '/^#/d' \
| head -n " $(( ${ MIRROR_COUNT :- 10 } + 1 )) " \
| bash ./rankmirrors --verbose --max-time 5 - > /etc/pacman.d/mirrorlist \
&& tee -a /etc/pacman.d/mirrorlist <<< 'Server = http://mirrors.evowise.com/archlinux/$repo/os/$arch' \
&& tee -a /etc/pacman.d/mirrorlist <<< 'Server = http://mirror.rackspace.com/archlinux/$repo/os/$arch' \
&& tee -a /etc/pacman.d/mirrorlist <<< 'Server = https://mirror.rackspace.com/archlinux/$repo/os/$arch' \
&& cat /etc/pacman.d/mirrorlist \
; fi \
; yes | pacman -Scc
2021-02-21 14:38:27 +08:00
# TEMP-FIX for pacman issue
RUN patched_glibc = glibc-linux4-2.33-4-x86_64.pkg.tar.zst \
&& curl -LO " https://raw.githubusercontent.com/sickcodes/Docker-OSX/master/ ${ patched_glibc } " \
&& bsdtar -C / -xvf " ${ patched_glibc } " || echo "Everything is fine."
# TEMP-FIX for pacman issue
2021-02-03 10:04:22 +08:00
RUN pacman -Syu xorg-server-xvfb wget xterm xorg-xhost xorg-xrandr sshpass --noconfirm \
&& if [ [ " ${ SCROT } " ] ] ; then \
pacman -Syu scrot base-devel --noconfirm \
2021-03-10 00:55:18 +08:00
&& git clone --recurse-submodules --depth 1 https://github.com/stolk/imcat.git \
2021-02-03 10:04:22 +08:00
&& cd imcat \
&& make \
&& sudo cp imcat /usr/bin/imcat \
&& touch /usr/bin/scrotcat \
&& tee -a /usr/bin/scrotcat <<< '/usr/bin/imcat <(scrot -o /dev/stdout)' \
&& chmod +x /usr/bin/scrotcat \
; else \
touch /usr/bin/scrotcat \
&& echo echo >> /usr/bin/scrotcat \
&& chmod +x /usr/bin/scrotcat \
; fi \
; yes | pacman -Scc
2021-01-24 20:47:19 +08:00
2021-02-21 14:38:27 +08:00
# TEMP-FIX for pacman issue
RUN patched_glibc = glibc-linux4-2.33-4-x86_64.pkg.tar.zst \
&& curl -LO " https://raw.githubusercontent.com/sickcodes/Docker-OSX/master/ ${ patched_glibc } " \
&& bsdtar -C / -xvf " ${ patched_glibc } " || echo "Everything is fine."
# TEMP-FIX for pacman issue
2021-01-24 20:47:19 +08:00
USER arch
2021-02-08 08:58:07 +08:00
WORKDIR /home/arch/OSX-KVM
2021-01-24 20:47:19 +08:00
RUN mkdir -p ~/.ssh \
&& touch ~/.ssh/authorized_keys \
&& touch ~/.ssh/config \
&& chmod 700 ~/.ssh \
&& chmod 600 ~/.ssh/config \
&& chmod 600 ~/.ssh/authorized_keys \
&& tee -a ~/.ssh/config <<< 'Host *' \
&& tee -a ~/.ssh/config <<< ' StrictHostKeyChecking no' \
&& tee -a ~/.ssh/config <<< ' UserKnownHostsFile=/dev/null'
2021-01-25 00:27:17 +08:00
ARG COMPLETE = true
2021-01-24 20:47:19 +08:00
# use the COMPLETE arg, for a complete image, ready to boot.
# otherwise use your own image: -v "$PWD/disk.img":/image
2021-02-26 11:46:58 +08:00
ARG WGET_OPTIONS =
# ARG WGET_OPTIONS='--no-verbose'
2021-03-24 21:40:16 +08:00
# Feel free to take a copy of this image and then host it internally
ARG IMAGE_URL = 'https://images.sick.codes/mac_hdd_ng_auto.img'
# ARG IMAGE_URL='https://images.sick.codes/mac_hdd_ng_auto_big_sur.img'
2021-01-24 20:47:19 +08:00
RUN if [ [ " ${ COMPLETE } " ] ] ; then \
2021-03-24 21:40:16 +08:00
echo "Downloading 20GB image... This step might take a while... Press Ctrl+C if you want to abort." \
2021-02-03 10:04:22 +08:00
; rm -f /home/arch/OSX-KVM/mac_hdd_ng.img \
2021-02-26 11:46:58 +08:00
&& wget ${ WGET_OPTIONS } -O /home/arch/OSX-KVM/mac_hdd_ng.img " ${ IMAGE_URL } " \
2021-01-24 20:47:19 +08:00
; fi
2021-03-24 21:40:16 +08:00
#### SPECIAL RUNTIME ARGUMENTS BELOW
ENV ADDITIONAL_PORTS =
2021-03-07 03:25:26 +08:00
ENV BOOTDISK =
2021-01-24 20:47:19 +08:00
ENV DISPLAY = :99
2021-03-07 01:59:03 +08:00
ENV HEADLESS = false
2021-02-26 02:16:24 +08:00
ENV ENV = /env
2021-03-24 21:40:16 +08:00
# Boolean for generating a bootdisk with new random serials.
ENV GENERATE_UNIQUE = false
# Boolean for generating a bootdisk with specific serials.
ENV GENERATE_SPECIFIC = false
2021-01-24 20:47:19 +08:00
ENV IMAGE_PATH = /home/arch/OSX-KVM/mac_hdd_ng.img
2021-03-24 21:40:16 +08:00
ENV IMAGE_FORMAT = qcow2
ENV KVM = 'accel=kvm:tcg'
# ENV MASTER_PLIST_URL="https://raw.githubusercontent.com/sickcodes/osx-serial-generator/master/config-custom.plist"
# ENV NETWORKING=e1000-82545em
ENV NETWORKING = vmxnet3
2021-01-24 20:47:19 +08:00
2021-02-21 19:02:41 +08:00
ENV NOPICKER = true
2021-03-24 21:40:16 +08:00
# dynamic RAM options for runtime
ENV RAM = 3
# ENV RAM=max
# ENV RAM=half
# The x and y coordinates for resolution.
# Must be used with either -e GENERATE_UNIQUE=true or -e GENERATE_SPECIFIC=true.
ENV WIDTH = 1920
ENV HEIGHT = 1080
2021-01-24 20:47:19 +08:00
ENV TERMS_OF_USE = i_agree
ENV BOILERPLATE = "By using this Dockerfile, you hereby agree that you are a security reseacher or developer and agree to use this Dockerfile to make the world a safer place. Examples include: making your apps safer, finding your mobile phone, compiling security products, etc. You understand that Docker-OSX is an Open Source project, which is released to the public under the GNU Pulic License version 3 and above. You acknowledge that the Open Source project is absolutely unaffiliated with any third party, in any form whatsoever. Any trademarks or intelectual property which happen to be mentioned anywhere in or around the project are owned by their respective owners. By using this Dockerfile, you agree to agree to the EULA of each piece of upstream or downstream software. The following code is released for the sole purpose of security research, under the GNU Public License version 3. If you are concerned about the licensing, please note that this project is not AGPL. A copy of the license is available online: https://github.com/sickcodes/Docker-OSX/blob/master/LICENSE. In order to use the following Dockerfile you must read and understand the terms. Once you have read the terms, use the -e TERMS_OF_USE=i_agree or -e TERMS_OF_USE=i_disagree"
CMD echo " ${ BOILERPLATE } " \
2021-02-26 14:42:57 +08:00
; [ [ " ${ TERMS_OF_USE } " = i_agree ] ] || exit 1 \
2021-02-26 13:26:35 +08:00
; echo "Disk is being copied between layers... Please wait a minute..." \
2021-03-10 04:34:09 +08:00
; sudo touch /dev/kvm /dev/snd " ${ IMAGE_PATH } " " ${ BOOTDISK } " " ${ ENV } " || true \
; sudo chown -R $( id -u) :$( id -g) /dev/kvm /dev/snd " ${ IMAGE_PATH } " " ${ BOOTDISK } " " ${ ENV } " || true \
2021-02-26 13:49:40 +08:00
; [ [ " ${ NOPICKER } " = = true ] ] && { \
sed -i '/^.*InstallMedia.*/d' Launch.sh \
2021-03-07 03:18:23 +08:00
&& export BOOTDISK = " ${ BOOTDISK : =/home/arch/OSX-KVM/OpenCore-Catalina/OpenCore-nopicker.qcow2 } " \
2021-02-26 13:49:40 +08:00
; } \
2021-03-07 03:18:23 +08:00
|| export BOOTDISK = " ${ BOOTDISK : =/home/arch/OSX-KVM/OpenCore-Catalina/OpenCore.qcow2 } " \
2021-02-26 13:26:35 +08:00
; [ [ " ${ GENERATE_UNIQUE } " = = true ] ] && { \
2021-03-10 00:55:18 +08:00
./Docker-OSX/osx-serial-generator/generate-unique-machine-values.sh \
2021-03-04 17:52:45 +08:00
--master-plist-url= " ${ MASTER_PLIST_URL } " \
2021-03-04 17:12:50 +08:00
--count 1 \
--tsv ./serial.tsv \
--bootdisks \
--width " ${ WIDTH :- 1920 } " \
--height " ${ HEIGHT :- 1080 } " \
--output-bootdisk " ${ BOOTDISK :- /home/arch/OSX-KVM/OpenCore-Catalina/OpenCore.qcow2 } " \
2021-03-04 20:05:41 +08:00
--output-env " ${ ENV : =/env } " \
2021-02-26 13:26:35 +08:00
; } \
; [ [ " ${ GENERATE_SPECIFIC } " = = true ] ] && { \
2021-03-04 19:57:52 +08:00
source " ${ ENV : =/env } " 2>/dev/null \
2021-03-10 00:55:18 +08:00
; ./Docker-OSX/osx-serial-generator/generate-specific-bootdisk.sh \
2021-03-04 17:52:45 +08:00
--master-plist-url= " ${ MASTER_PLIST_URL } " \
2021-02-25 22:03:06 +08:00
--model " ${ DEVICE_MODEL } " \
--serial " ${ SERIAL } " \
--board-serial " ${ BOARD_SERIAL } " \
--uuid " ${ UUID } " \
--mac-address " ${ MAC_ADDRESS } " \
2021-03-04 17:12:50 +08:00
--width " ${ WIDTH :- 1920 } " \
--height " ${ HEIGHT :- 1080 } " \
2021-03-04 20:05:41 +08:00
--output-bootdisk " ${ BOOTDISK :- /home/arch/OSX-KVM/OpenCore-Catalina/OpenCore.qcow2 } " \
2021-02-26 13:26:35 +08:00
; } \
2021-03-07 01:59:03 +08:00
; { [ [ " ${ DISPLAY } " = ':99' ] ] || [ [ " ${ HEADLESS } " = = true ] ] ; } && { \
2021-02-03 10:04:22 +08:00
nohup Xvfb :99 -screen 0 1920x1080x16 \
2021-03-07 01:59:03 +08:00
& until [ [ " $( xrandr --query 2>/dev/null) " ] ] ; do sleep 1 ; done \
2021-02-03 10:04:22 +08:00
; } \
2021-01-24 20:47:19 +08:00
; stat " ${ IMAGE_PATH } " \
; echo "Large image is being copied between layers, please wait a minute..." \
; ./enable-ssh.sh \
2021-01-28 03:02:10 +08:00
; [ [ -e ~/.ssh/id_docker_osx ] ] || { \
/usr/bin/ssh-keygen -t rsa -f ~/.ssh/id_docker_osx -q -N "" \
&& chmod 600 ~/.ssh/id_docker_osx \
; } \
2021-03-28 18:17:47 +08:00
; /bin/bash -c ./Launch.sh \
2021-01-24 20:47:19 +08:00
& echo "Booting Docker-OSX in the background. Please wait..." \
; until [ [ " $( sshpass -palpine ssh-copy-id -f -i ~/.ssh/id_docker_osx.pub -p 10022 user@127.0.0.1) " ] ] ; do \
2021-01-28 03:02:10 +08:00
echo "Disk is being copied between layers. Repeating until able to copy SSH key into OSX..." \
2021-01-24 20:47:19 +08:00
; sleep 1 \
; done \
2021-01-28 03:02:10 +08:00
; grep id_docker_osx ~/.ssh/config || { \
tee -a ~/.ssh/config <<< 'Host 127.0.0.1' \
; tee -a ~/.ssh/config <<< ' User user' \
; tee -a ~/.ssh/config <<< ' Port 10022' \
; tee -a ~/.ssh/config <<< ' IdentityFile ~/.ssh/id_docker_osx' \
; tee -a ~/.ssh/config <<< ' StrictHostKeyChecking no' \
; tee -a ~/.ssh/config <<< ' UserKnownHostsFile=/dev/null' \
; } \
&& echo 'Default username: user' \
&& echo 'Default password: alpine' \
&& echo 'Change it immediately using the command: passwd' \
&& ssh -i ~/.ssh/id_docker_osx user@127.0.0.1 -p 10022 " ${ OSX_COMMANDS } "
2021-01-24 20:47:19 +08:00
# username: user
# password: alpine
# screenshot: docker exec -it containerid scrotcat
# readme: https://github.com/sickcodes/Docker-OSX
# timezone: UTC/GMT
# Future case option when supplying IMAGE_PATH:
# Zstandard*) zstd -d /image && export IMAGE_PATH=/image;; \