You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

67 lines
1.3 KiB
Bash

7 years ago
#!/bin/bash
set -e
apt-get -y install mdadm btrfs-tools cryptsetup
7 years ago
# returns /dev/md0 as root device
# returns /dev/md1 as boot device
"./hardware/${1}/parted.sh" "$2"
7 years ago
# encrypt and unlock root device
echo -n 'Enter luks password: '
7 years ago
read -s md0pwd
echo -n $md0pwd | cryptsetup -q luksFormat /dev/md0
echo -n $md0pwd | cryptsetup open --type luks /dev/md0 md0-unlocked
unset md0pwd
# format
chroot=/mnt/md0-unlocked
# root device
7 years ago
mkfs.btrfs -f /dev/mapper/md0-unlocked
7 years ago
mkdir /mnt/md0-unlocked
mount /dev/mapper/md0-unlocked /mnt/md0-unlocked
# boot device
7 years ago
mkfs.btrfs -f /dev/md1
7 years ago
mkdir "$chroot/boot"
mount /dev/md1 "$chroot/boot"
# debootstrap
debootstrap --variant=minbase --arch=amd64 stretch "$chroot" https://deb.debian.org/debian/
mount -t proc none "$chroot/proc"
mount -t sysfs none "$chroot/sys"
mount -o bind /dev "$chroot/dev"
7 years ago
# copy fstab, crypttab, ...
7 years ago
cd config
7 years ago
cp -a * "$chroot"
cd ..
7 years ago
# copy parted.sh, grub.sh, ...
cd "hardware/${1}"
cp -a * "$chroot"
cd ../..
# copy a couple of other files
7 years ago
cp -a docker.key \
post-debootstrap-installer.sh \
authorized_keys \
7 years ago
"$chroot"
7 years ago
# set hostname
echo "$2" > "$chroot/etc/hostname"
chroot "$chroot" /post-debootstrap-installer.sh
rm -r "$chroot/docker.key" \
"$chroot/post-debootstrap-installer.sh" \
"$chroot/authorized_keys"