# Generator for Oktopus boot media # Copyright (C) 2018 Hochschule für Technik und Wirtschaft Berlin # written by Paul Hänsch # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see . .FORCE: BOOTSTRAP = http://raspbian.raspberrypi.org/raspbian define SOURCES = deb http://raspbian.raspberrypi.org/raspbian stretch main non-free firmware rpi\n\ deb http://archive.raspberrypi.org/debian stretch main\n endef PACKAGES := apt bluez bluez-firmware bluez-tools btrfs-tools busybox-static bzip2 ca-certificates cron debian-archive-keyring deborphan firmware-brcm80211 firmware-linux-free firmware-misc-nonfree gzip htop ifupdown init iputils-ping irqbalance isc-dhcp-client less libraspberrypi-bin libraspberrypi0 make net-tools nmap ntpdate openssh-client openssh-server pi-bluetooth raspberrypi-bootloader raspberrypi-kernel rsync ssh sshfs sudo systemd traceroute unzip vim wget wireless-tools wpasupplicant xz-utils zip # Do not change, only override in config.mk WIFI-SSID = WIFI-PASS = config.mk: config.example cp -n "$<" "$@" .PHONY: imgfile imgmount root_copy norecommends apt_keys IMGFILE = raspi.img include config.mk include *.mk raspi_root: btrfs subvolume create "$@" || mkdir "$@" mkdir -p "$@/usr/bin" chmod 755 -R "$@/" cp -p "/usr/bin/qemu-arm-static" "$@/usr/bin/" debootstrap --keyring=./raspbian-archive-keyring.gpg \ --arch=armhf --variant=minbase \ stretch "$@/" "${BOOTSTRAP}" norecommends: raspi_root/etc/apt/apt.conf.d/10norecommends raspi_root/etc/apt/apt.conf.d/10norecommends: raspi_root mkdir -p "$"$@" chmod 644 "$@" apt_keys: -chroot "$@" apt-key add - <./raspbian-archive-keyring.gpg -chroot "$@" apt-key add - <./raspberrypi-archive-keyring.gpg -chroot "$@" apt-key add - <./debian-archive-stretch-stable.gpg raspi_root/: raspi_root norecommends apt_keys .FORCE printf '${SOURCES}' >$@/etc/apt/sources.list -cp /etc/resolv.conf "$@etc/" -chroot "$@" sh -c 'apt-mark showmanual |xargs apt-mark auto' -chroot "$@" apt-get update chroot "$@" ln -sf /bin/true /usr/local/sbin/invoke-rc.d chroot "$@" apt-get --yes install ${PACKAGES} chroot "$@" apt-get --yes --auto-remove purge chroot "$@" apt-get --yes --auto-remove upgrade chroot "$@" apt-get clean chroot "$@" rm /usr/local/sbin/invoke-rc.d touch "$@" id_rsa.pub: ssh-keygen -b 2048 -t rsa -N '' -f id_rsa files/etc/network/interfaces.d/wifi: wifi.tmpl sed 's;#WIFI-SSID#;${WIFI-SSID};; s;#WIFI-PASS#;${WIFI-PASS};;' <'$<' >'$@' chmod 644 '$@' files/root/.ssh/authorized_keys: id_rsa.pub mkdir -p files/root/.ssh/ cat '$<' >>'$@' chmod 700 files/root/ files/root/.ssh/ chmod 600 '$@' imgfile: raspi_root/ # do not set up image file before chroot imgfile: partitions dd bs=1M count=0 seek=1280 of="${IMGFILE}" # set up sparse file sfdisk "${IMGFILE}"