3 then echo "Please run as root"
7 then echo "need arg $1 for chroot to make"
11 echo "creating chroot '$chrootdir'"
12 # Setup fstab mount points
13 cat <<EOF >> /etc/fstab
14 /dev /opt/chroot/$chrootdir/dev none bind 0 0
15 /dev/pts /opt/chroot/$chrootdir/dev/pts none bind 0 0
16 /proc /opt/chroot/$chrootdir/proc none bind 0 0
17 /sys /opt/chroot/$chrootdir/sys none bind 0 0
18 /tmp /opt/chroot/$chrootdir/tmp none bind 0 0
21 # Create coriolis chroot dir in /opt
22 mkdir
-p /opt
/chroot
/$chrootdir
23 # Install debootstrap and schroot via apt
24 apt
install -y debootstrap schroot
25 # Install debian/buster chroot using debootstrap
26 /usr
/sbin
/debootstrap buster
/opt
/chroot
/$chrootdir \
27 http
://ftp.uk.debian.org
/debian
28 # Mount all chroot mount points from fstab
29 mount
/opt
/chroot
/$chrootdir/dev
30 mount
/opt
/chroot
/$chrootdir/dev
/pts
31 mount
/opt
/chroot
/$chrootdir/proc
32 mount
/opt
/chroot
/$chrootdir/sys
33 mount
/opt
/chroot
/$chrootdir/tmp
34 echo "$chrootdir" > /opt
/chroot
/$chrootdir/etc
/debian_chroot
36 # Install apt dependencies in the chroot
37 chroot
/opt
/chroot
/$chrootdir /bin
/bash
<< EOF
38 echo Installing necessary apt dependencies in the chroot
41 apt-get install -y automake binutils-dev build-essential \
42 ccache cmake gcc git \
49 python3-setuptools python3-dev
51 # yeah systemd in a chroot? not very funny joke.
52 apt-get remove -y systemd
54 # add sudo no password
55 echo '$SUDO_USER ALL=NOPASSWD: ALL' >> /etc/sudoers.d/$chrootdir
57 # Create user with same UID in the chroot
58 useradd -m -p `python3 -c 'import crypt; print (crypt.crypt("1234","Fx"))'` \
59 -s /bin/bash $SUDO_USER -k /etc/skel
61 Added user ${SUDO_USER} with \e[1;91mpassword: 1234\e[0m"
63 # add deb-src to sources
64 echo deb-src http://ftp.debian.org/debian buster main > \
65 /etc/apt/sources.list.d/bustersrc.list
68 \e[1;91mPlease use command 'passwd ${SUDO_USER}' to change this immediately after this script is run for security purposes.\e[0m
71 # Add convenience variable to chroot user .bash_profile
72 echo -e 'export PATH=/usr/lib/ccache:"\044PATH"\nexport DISPLAY=:0.0\n' > /home/$SUDO_USER/.bash_profile
73 chown $SUDO_USER /home/$SUDO_USER/.bash_profile
74 chgrp $SUDO_USER /home/$SUDO_USER/.bash_profile
76 echo -e "Added 'export PATH=/usr/lib/ccache:\"\044PATH\"\nexport DISPLAY=:0.0' to /home/$SUDO_USER/.bash_profile to speed up rebuilds"
79 # Add chroot config to schroot.conf
80 cat <<EOF >>/etc/schroot/schroot.conf
82 description=Debian Buster for $chrootdir
83 directory=/opt/chroot/$chrootdir
84 groups=sbuild-security,$SUDO_USER,users
87 echo "Adding the following $chrootdir section to /etc/schroot/schroot.conf:
90 description=Debian Buster for $chrootdir
91 directory=/opt/chroot/$chrootdir
92 groups=sbuild-security,$SUDO_USER,users
94 This enables you to chroot into $chrootdir as an unprivileged user by running
95 'schroot -c $chrootdir /bin/bash'