|
| 1 | +#!/usr/bin/env bash |
| 2 | +# |
| 3 | +# Needed to work around the initrd `rootfs` / filesystem not being a valid |
| 4 | +# mount to pivot out of. For reference, see: |
| 5 | +# - https://github.com/torvalds/linux/blob/26bc672134241a080a83b2ab9aa8abede8d30e1c/fs/namespace.c#L3605 |
| 6 | +# - https://gist.github.com/jlebon/fb6e7c6dcc3ce17d3e2a86f5938ec033 |
| 7 | +set -euo pipefail |
| 8 | + |
| 9 | +TMP_CHROOT_DIR="" |
| 10 | + |
| 11 | +main() { |
| 12 | + setup_chroot_tmpdir |
| 13 | + run_chrooted_bwrap "$@" |
| 14 | +} |
| 15 | + |
| 16 | +setup_chroot_tmpdir() { |
| 17 | + TMP_CHROOT_DIR=$(mktemp --directory --tmpdir=/mnt '.coreos-sysroot-bwrap.tmp.XXXXXXXXXX') |
| 18 | + mount --bind / "${TMP_CHROOT_DIR}" |
| 19 | + mount --make-private "${TMP_CHROOT_DIR}" |
| 20 | + mount --bind "${TMP_CHROOT_DIR}" "${TMP_CHROOT_DIR}" |
| 21 | + for mnt in proc sys dev; do |
| 22 | + mount --bind /$mnt "${TMP_CHROOT_DIR}"/$mnt |
| 23 | + done |
| 24 | + touch "${TMP_CHROOT_DIR}"/run/ostree-booted |
| 25 | + mount --bind /sysroot "${TMP_CHROOT_DIR}"/sysroot |
| 26 | +} |
| 27 | + |
| 28 | +run_chrooted_bwrap() { |
| 29 | + chroot "${TMP_CHROOT_DIR}" \ |
| 30 | + /usr/bin/env --chdir /sysroot \ |
| 31 | + bwrap \ |
| 32 | + --unshare-pid --unshare-uts --unshare-ipc --unshare-net \ |
| 33 | + --unshare-cgroup-try --dev /dev --proc /proc --chdir / \ |
| 34 | + --ro-bind usr /usr --bind etc /etc --dir /tmp --tmpfs /var/tmp \ |
| 35 | + --tmpfs /run --ro-bind /run/ostree-booted /run/ostree-booted \ |
| 36 | + --symlink usr/lib /lib \ |
| 37 | + --symlink usr/lib64 /lib64 \ |
| 38 | + --symlink usr/bin /bin \ |
| 39 | + --symlink usr/sbin /sbin -- "$@" |
| 40 | +} |
| 41 | + |
| 42 | +cleanup() { |
| 43 | + if test -z "${TMP_CHROOT_DIR}"; then |
| 44 | + return |
| 45 | + fi |
| 46 | + |
| 47 | + umount --lazy --recursive "${TMP_CHROOT_DIR}" |
| 48 | + umount --recursive "${TMP_CHROOT_DIR}" |
| 49 | + rmdir "${TMP_CHROOT_DIR}" |
| 50 | +} |
| 51 | + |
| 52 | +trap cleanup EXIT |
| 53 | +main "$@" |
0 commit comments