X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=faiserver-setup;h=544d3db08521b9ae0489fe9fef45d9703e3ef7f2;hb=34839ddd0fbddfe203a3aa5b3387186a273e31df;hp=f1ede11628990d3b920787981bb6f2f6756a0a2d;hpb=ba2a6b887fe5a9ed627e9f0947265b37abbcf7aa;p=automated-distro-installer diff --git a/faiserver-setup b/faiserver-setup index f1ede11..544d3db 100755 --- a/faiserver-setup +++ b/faiserver-setup @@ -1,5 +1,5 @@ #!/bin/bash -# Copyright (C) 2016 Ian Kelling +# Copyright (C) 2018 Ian Kelling # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License @@ -85,14 +85,14 @@ elif grep -xFq 'VERSION="8 (jessie)"' /etc/os-release; then cat >/etc/apt/sources.list.d/fai.list <<'EOF' deb http://fai-project.org/download jessie koeln EOF -elif grep -xFq 'VERSION="9 (stretch)"' /etc/os-release; then - gpg -a --recv-keys 2BF8D9FE074BCDE4; gpg -a --export 2BF8D9FE074BCDE4 | apt-key add - +elif grep -xFq 'VERSION="9 (stretch)"' /etc/os-release || grep -iE 'flidas|xenail' /etc/os-release ; then + # fai on ubuntu only has official support using the universe repo, but newer + # tends to have less bugs. + gpg --keyserver hkp://pool.sks-keyservers.net -a --recv-keys 2BF8D9FE074BCDE4; gpg -a --export 2BF8D9FE074BCDE4 | apt-key add - cat >/etc/apt/sources.list.d/fai.list <<'EOF' deb http://fai-project.org/download stretch koeln EOF -elif grep -iE 'flidas|xenail' /etc/os-release; then - add-apt-repository -y ppa:fai/ppa else rm -f /etc/apt/sources.list.d/fai.list fi @@ -103,7 +103,9 @@ apt-get update # I especially do not wait isc-dhcp-server or an inetd. Also excludes # nfs-kernel-server. On an android chroot, we don\'t have nfs in the # kernel, or the ability to install it. -pkgs=(fai-doc tftpd-hpa tar reprepro squashfs-tools binutils) +# xorriso is for running fai-cd -a, not strictly need for fai-server +# perl-tk is for fai-monitor-gui +pkgs=(fai-doc tftpd-hpa tar reprepro squashfs-tools binutils xorriso) if modprobe nfsd &>/dev/null; then pkgs+=(nfs-kernel-server) else @@ -112,7 +114,9 @@ fi apt-get install -y ${pkgs[@]} -apt-get install --no-install-recommends -y fai-server +# confnew since we edit /etc/fai/NFSROOT in an automated way +# fai-client is already a fai-server dependency, but make sure it gets upgraded +apt-get install --no-install-recommends -y -o Dpkg::Options::="--force-confnew" fai-server fai-client r=http://http.us.debian.org/debian # like default, but scrap httpredir, and nonfree. @@ -164,6 +168,9 @@ s,^( *FAI_DEBOOTSTRAP=).*,\1"$base $r", EOF $sed 's/#LOGUSER/LOGUSER/' /etc/fai/fai.conf +$sed -i '/^FAI_FLAGS=/d' /etc/fai/fai.conf +echo "FAI_FLAGS=verbose" >>/etc/fai/fai.conf + # from man fai-make-nfsroot, # figured out after partitioning ignored my crypt partition @@ -204,7 +211,10 @@ if armhf; then rm -f $NFSROOT/boot/*.bak mkdir -p $TFTPROOT/pxelinux.cfg - chmod a+r $NFSROOT/boot/initrd.img-* || die 9 "No initrd was created. Check the package name of the linux-image package in /etc/fai/NFSROOT." + if ! chmod a+r $NFSROOT/boot/initrd.img-*; then + echo "$0: error: No initrd was created. Check the package name of the linux-image package in /etc/fai/NFSROOT." + exit 1 + fi cp -p $v $NFSROOT/boot/vmlinu?-* $NFSROOT/boot/initrd.img-* $TFTPROOT cp -u $pxebin $TFTPROOT if [ -f $NFSROOT/usr/lib/syslinux/modules/bios/ldlinux.c32 ]; then @@ -229,6 +239,14 @@ else # not armhf # note, this copies the -B arg to # /srv/fai/nfsroot/var/tmp/base.tar.xz e fai-setup -evf -B /a/bin/fai-basefiles/basefiles/STRETCH64.tar.xz + # fai-setup expert mode avoids writing to /var/log/fai/variables + # at least config_src is needed for autodiscover + $sed '/^FAI_CONFIGDIR|^FAI_CONFIG_SRC|^LOGUSER/d' /var/log/fai/variables + tee -a /var/log/fai/variables <<'EOF' +LOGUSER=fai +FAI_CONFIGDIR=/srv/fai/config +FAI_CONFIG_SRC=nfs://faiserver/srv/fai/config +EOF # make the faiserver also the apt proxy server apt-get -y install apt-cacher-ng fi