X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=faiserver-setup;h=d8489eda2c0a1e31b8998ce6a9c41f25100ca7fd;hp=2348db02a4c08d26cc2c84c3e95edd44bb0cff72;hb=45578de750fb07f7a7f64181e6b3b749ef727725;hpb=15da839e14b07b30de9c3f7559bd17213e4f193d diff --git a/faiserver-setup b/faiserver-setup index 2348db0..d8489ed 100755 --- a/faiserver-setup +++ b/faiserver-setup @@ -21,16 +21,18 @@ x="$(readlink -f "$BASH_SOURCE")"; source "${x%/*}/bash-trace" usage() { cat <&2 + exit 1 +fi + +if [[ ! -d $BASEFILE_DIR ]]; then + printf "%s\n" "$0: error BASEFILE_DIR=$BASEFILE_DIR does not exist" >&2 exit 1 fi @@ -62,42 +69,28 @@ armhf() { [[ $(dpkg --print-architecture) == armhf ]] } -if armhf; then - if apt-cache policy | grep o=Debian,a=testing,n=stretch &>/dev/null; then - cat >/etc/apt/sources.list.d/testing.list <<'EOF' -deb http://http.us.debian.org/debian testing main contrib non-free -deb-src http://http.us.debian.org/debian testing main contrib non-free - -deb http://security.debian.org/ testing/updates main contrib non-free -deb-src http://security.debian.org/ testing/updates main contrib non-free - -deb http://http.us.debian.org/debian testing-updates main contrib non-free -deb-src http://http.us.debian.org/debian testing-updates main contrib non-free -EOF - - cat >/etc/apt/preferences.d/fai <<'EOF' -Package: fai-server fai-client fai-doc -Pin: release a=testing -Pin-Priority: 500 - -Package: * -Pin: release a=testing -Pin-Priority: -10 -EOF - fi -elif grep -xFq 'VERSION="8 (jessie)"' /etc/os-release; then +if grep -xFq 'VERSION="8 (jessie)"' /etc/os-release; then gpg -a --recv-keys 2BF8D9FE074BCDE4; gpg -a --export 2BF8D9FE074BCDE4 | apt-key add - cat >/etc/apt/sources.list.d/fai.list <<'EOF' deb https://fai-project.org/download jessie koeln EOF -elif grep -xFq 'VERSION="9 (stretch)"' /etc/os-release || grep -iE 'flidas|xenail' /etc/os-release ; then +elif grep -iE 'VERSION=.*(stretch|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' + case $base in + stretch) + cat >/etc/apt/sources.list.d/fai.list <<'EOF' deb https://fai-project.org/download stretch koeln EOF + ;; + buster) + cat >/etc/apt/sources.list.d/fai.list <<'EOF' +deb https://fai-project.org/download buster koeln +EOF + ;; + esac else rm -f /etc/apt/sources.list.d/fai.list fi @@ -118,10 +111,10 @@ else fi -apt-get install -y ${pkgs[@]} +e apt-get install -y ${pkgs[@]} # 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 +e 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. @@ -134,7 +127,7 @@ EOF case $base in - jessie|stretch) + jessie|stretch|buster) cat >>/etc/fai/apt/sources.list <>/etc/fai/fai.conf +# note if this isnt set, the user isnt created +echo "LOGUSER=fai" >>/etc/fai/fai.conf # from man fai-make-nfsroot, # figured out after partitioning ignored my crypt partition @@ -190,8 +184,8 @@ fi if armhf; then cd /srv/fai - rm -rf nfsroot - tar Jxf $BASEFILE_DIR/STRETCH64.tar.xz + e rm -rf nfsroot + e tar Jxf $basefile # background: Can't build the nfsroot on my arm system now. First, # fai-make-nfsroot won't work out of the box. One idea to make it work # is by installing qemu-user-static, then copying qemu-x86_64-static @@ -214,7 +208,7 @@ if armhf; then if [ -f $NFSROOT/usr/lib/PXELINUX/pxelinux.0 ]; then pxebin=$NFSROOT/usr/lib/PXELINUX/pxelinux.0 else - # jessie/stretch path + # jessie+ path pxebin=$NFSROOT/usr/lib/syslinux/pxelinux.0 fi @@ -237,17 +231,17 @@ if armhf; then type setup_tftp EOF ) - setup_tftp + e setup_tftp # -g causes skipping set_root_pw() in fai-make-nfsroot, -ag # is the only way to make it run without chrooting. the options # seem contradictory, but it works. - fai-setup -evag + e fai-setup -evag else # not armhf # note, this copies the -B arg to # /srv/fai/nfsroot/var/tmp/base.tar.xz - e fai-setup -evf -B $BASEFILE_DIR/STRETCH64.tar.gz + e fai-setup -evf -B $basefile # 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