X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=fai%2Fconfig%2Fclass%2F50-host-classes;h=c7091f0b33dd46e123e1d512a677d13128ccdf36;hb=948ef49d2b4d7680da2355acf9da86f81ca75ecd;hp=8ac4a27d7fd7175d9bac221d2e8a0034411904f1;hpb=e499b43b888c951fd4c255b2853f0af2350400c4;p=automated-distro-installer diff --git a/fai/config/class/50-host-classes b/fai/config/class/50-host-classes index 8ac4a27..c7091f0 100755 --- a/fai/config/class/50-host-classes +++ b/fai/config/class/50-host-classes @@ -12,38 +12,44 @@ # We check the reverse condition in 51-multi-boot, # and set what os we are installing, but don't check it # into git since it changes regularly. -# It's code looks like this: -# if [[ ! -e /a/bin/fai/fai-wrapper ]]; then -# case $HOSTNAME in -# tp) DEBIAN STRETCH VOL_STRETCH STRETCH_FREE;; -# # add more multi-boot hostnames here -# esac -# fi + # # # Each host defines following: # The base distro: # UBUNTU, DEBIAN # -# The base disto version, which is also the basefile name if it exists: -# STRETCH64, XENIAL64, BELENOS64, FLIDAS64 +# The base disto version, only use so far is the basefile name if it exists. +# Debian stable basefile gets built by faisetup and gets used otherwise. +# With X suffix, means it has gone through the dirinstall process and has eXtra +# things installed, to speed up installation. +# STRETCH64, BUSTER64, XENIAL64, FLIDAS64, FLIDAS64BIG, ETIONA64 # # The distro subvol name, we can add as many of these as we want: -# VOL_TESTING, VOL_STRETCH, VOL_XENIAL, VOL_BELENOS, VOL_FLIDAS, VOL_STRETCH_BOOTSTRAP -# Using VOL_STRETCH_BOOTSTRAP sets up the install to act like a pxe rom if -# grub sets a specific var. +# VOL_TESTING, VOL_STRETCH, VOL_BUSTER, VOL_XENIAL, VOL_FLIDAS, +# VOL_ETIONA VOL_STRETCH_BOOTSTRAP. Using VOL_STRETCH_BOOTSTRAP sets up +# the install to act like a pxe rom if grub sets a specific var. # -# The apt sources files we want, -# STRETCH_FREE, STRETCH_NONFREE, TESTING_FREE, TESTING_NONFREE, -# XENIAL_FREE, FLIDAS, BELENOS, STRETCH_LINODE. +# The apt sources files we want, STRETCH_FREE, STRETCH_NONFREE, +# BUSTER_FREE, BUSTER_NONFREE, TESTING_FREE, TESTING_NONFREE, +# XENIAL_FREE, FLIDAS, ETIONA, STRETCH_LINODE. # # It's all a little redundant in some cases, but it keeps things -# simpler. Belenos is broken right now, planning to remove it once -# flidas is released. +# simpler. # # # Other notable classes: # +# INSTALL: for autodiscover iso, this is needed. We could also add it to +# the autodiscover grub, but then we have to burn a new iso if we want a +# non-install one. It sets the class for the corresponding INSTALL.var, +# which sets FAI_ACTION=INSTALL. I'm not sure if this variable overrides +# FAI_ACTION outside of autodiscover, todo: test it out, if it doesn't, +# make install be default in 51-multi-boot, and disable it if needed. +# +# DESKTOP: install a bunch of extra packages. For creating X suffix +# basefiles. See README. +# # REPARTITION: we try to reuse partitions/filesystems to install a new # os into a multi-os system, if we see some basic hueristics, like the # right amount of them. This overrides that. @@ -58,7 +64,34 @@ # # RAID0: Use raid 0 even if there are >= 4 disks with boot partititions. # +# LINODE: For running a vm on linode, especially one created with fai-cd. + +###### begin Template for 51-multi-boot ###### # +# It has reasonable combinations of above classes. +# It's a noop until we replace _ with host names. + +#!/bin/bash +if [[ ! -e /a/bin/fai/fai-wrapper || $FAI_ACTION == dirinstall ]]; then + case $HOSTNAME in + # stretch based minimal recovery / bootstraping os: + _) echo DEBIAN STRETCH64 VOL_STRETCH_BOOTSTRAP STRETCH_FREE ;; + # flidas + _) echo UBUNTU FLIDAS64 VOL_FLIDAS FLIDAS ;; + # etiona + _) echo UBUNTU ETIONA64 VOL_ETIONA ETIONA ;; + # stretch + _) echo DEBIAN STRETCH64 VOL_STRETCH STRETCH_FREE ;; + # buster + _) echo DEBIAN BUSTER64 VOL_BUSTER BUSTER_FREE ;; + # testing + _) echo DEBIAN STRETCH64 VOL_TESTING TESTING_FREE ;; + # xenial + _) echo UBUNTU XENIAL64 VOL_XENIAL XENIAL_FREE ;; + esac +fi +###### end Template for 51-multi-boot ###### + if [[ -e /a/bin/fai/fai-wrapper ]]; then source /a/bin/distro-functions/src/identify-distros if isdebian; then @@ -74,14 +107,12 @@ if [[ -e /a/bin/fai/fai-wrapper ]]; then echo "STRETCH_NONFREE" ;; esac - elif isdebian-testing; then - echo "TESTING_NONFREE" fi fi -echo "FAIBASE" +echo FAIBASE STANDARD -echo "PARTITION_PROMPT" +#echo "PARTITION_PROMPT" #echo REPARTITION