X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=fai%2Fconfig%2Fclass%2F50-host-classes;h=076323b14577f93795d58508c2d4c310c01a08f4;hb=ab68265ccb7857baff11c0cc216e0c5e9bf4d629;hp=161a5de3289fc55b4a05f64a8a21344fec942c19;hpb=c47175685b348735b3440e16851dde2cc39b6f3f;p=automated-distro-installer diff --git a/fai/config/class/50-host-classes b/fai/config/class/50-host-classes index 161a5de..076323b 100755 --- a/fai/config/class/50-host-classes +++ b/fai/config/class/50-host-classes @@ -1,10 +1,13 @@ -#!/bin/bash -l +#!/bin/bash # assign classes to hosts based on their hostname # do not use this if a menu will be presented [ "$flag_menu" ] && exit 0 +# set these early so they are lowest priority. +echo FAIBASE STANDARD DEBIAN + # For multi-boot system. # We check that we aren't in a pxe boot environment. @@ -17,26 +20,34 @@ # # Each host defines following: # The base distro: -# UBUNTU, DEBIAN +# UBUNTU or nothing. DEBIAN is always defined as a base. # # 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, XENIAL64, BELENOS64, FLIDAS64, FLIDAS64BIG +# +# STRETCH64, BUSTER64, BULLSEYE64, +# FLIDAS64, FLIDAS64BIG, ETIONA64, +# XENIAL64, BIONIC64, FOCAL64, # # 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 +# VOL_TESTING, VOL_STRETCH, VOL_BUSTER, VOL_BULLSEYE, +# VOL_FLIDAS, VOL_ETIONA +# VOL_XENIAL, VOL_BIONIC VOL_FOCAL +# 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. +# STRETCH_FREE, STRETCH_NONFREE, +# BUSTER_FREE, BUSTER_NONFREE, +# BULLSEYE_FREE, BULLSEYE_NONFREE +# TESTING_FREE, TESTING_NONFREE, +# XENIAL_FREE, BIONIC, FOCAL, 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 and rms has upgraded. +# simpler. # # # Other notable classes: @@ -65,54 +76,69 @@ # # 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 ###### # -# Code in 51-multi-boot, with reasonable combinations of above -# uncommented for easier editing, and runs as a noop until -# we replace _ with host names. -if [[ ! -e /a/bin/fai/fai-wrapper ]]; then - case $HOSTNAME in - # stretch based minimal recovery / bootstraping os: - _) echo DEBIAN STRETCH64 VOL_STRETCH_BOOTSTRAP STRETCH_NONFREE ;; - # flidas - _) echo UBUNTU FLIDAS64 VOL_FLIDAS FLIDAS ;; - # stretch - _) echo DEBIAN STRETCH64 VOL_STRETCH STRETCH_NONFREE ;; - # testing - _) echo DEBIAN STRETCH64 VOL_TESTING TESTING_NONFREE ;; - # belenos - _) echo UBUNTU BELENOS64 VOL_BELENOS BELENOS ;; - # xenial - _) echo UBUNTU XENIAL64 VOL_XENIAL XENIAL_FREE ;; - esac +# 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 STRETCH64 VOL_STRETCH_BOOTSTRAP STRETCH_FREE ;; + # flidas + _) echo UBUNTU FLIDAS64 VOL_FLIDAS FLIDAS ;; + # etiona + _) echo UBUNTU ETIONA64 VOL_ETIONA ETIONA ;; + # stretch + _) echo STRETCH64 VOL_STRETCH STRETCH_FREE ;; + # buster + _) echo BUSTER64 VOL_BUSTER BUSTER_FREE ;; + # testing + _) echo STRETCH64 VOL_TESTING TESTING_FREE ;; + # xenial + _) echo UBUNTU XENIAL64 VOL_XENIAL XENIAL_FREE ;; + # bionic + _) echo UBUNTU BIONIC64 VOL_BIONIC BIONIC ;; + # focal + _) echo UBUNTU FOCAL64 VOL_FOCAL FOCAL ;; + 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 - echo "DEBIAN" - fi - if isdebian-stable; then - echo "STRETCH" - case $HOSTNAME in - li|lj) echo "STRETCH_LINODE" ;; - *) - # nonfree repo is not going away any time soon due to - # gcc-doc being in nonfree - echo "STRETCH_NONFREE" - ;; - esac - elif isdebian-testing; then - echo "TESTING_NONFREE" - fi + source /a/bin/distro-functions/src/identify-distros + if isdeb; then + codename=$(debian-codename) + echo ${codename^^} + distro=$(distro-name) + case $distro in + debian) + echo ${distro^^} + # nonfree repo is not going away any time soon due to + # gcc-doc being in nonfree + echo ${codename^^}_NONFREE + ;; + trisquel) + # easier to stay with fai example config if we just call it ubuntu + echo UBUNTU + ;; + esac + fi + case $HOSTNAME in + li|lj) echo "LINODE" ;; + bk|je) echo "NOCRYPT" ;; + esac fi -echo "FAIBASE" #echo "PARTITION_PROMPT" #echo REPARTITION if grep ^52:54:00: /sys/class/net/eth0/address &>/dev/null; then - # if our eth0 mac is in the kvm range, we are a vm. - echo "VM" + # if our eth0 mac is in the kvm range, we are a vm. + echo "VM" fi