X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=fai%2Fconfig%2Fclass%2F50-host-classes;h=adb878913476b9fe09bfdda7fd0e82c22418d817;hp=266024652fabc5cbba1b5ea90833fd0c8af40262;hb=05e47f6734e5a9354a3243686ae55fe4ab2b72c7;hpb=d3d495af167adba91b190e8dcb95649c34fa04c7 diff --git a/fai/config/class/50-host-classes b/fai/config/class/50-host-classes index 2660246..adb8789 100755 --- a/fai/config/class/50-host-classes +++ b/fai/config/class/50-host-classes @@ -1,40 +1,109 @@ -#! /bin/bash +#!/bin/bash -l # assign classes to hosts based on their hostname # do not use this if a menu will be presented [ "$flag_menu" ] && exit 0 -# use a list of classes for our demo machine -case $HOSTNAME in - demohost) - echo "FAIBASE DEBIAN DESKTOP STABLE" ;; - x2) - echo "FAIBASE DEBIAN DESKTOP STABLE PARTITION_PROMPT" ;; - tp) - echo "FAIBASE DEBIAN DESKTOP STABLE PARTITION_PROMPT" ;; - frodo) - echo "FAIBASE DEBIAN DESKTOP STABLE PARTITION_PROMPT" ;; - # faiserver) - # echo "FAIBASE DEBIAN DEMO FAISERVER" ;; - # xfcehost) - # echo "FAIBASE DEBIAN DEMO XORG XFCE LVM";; - # gnomehost) - # echo "FAIBASE DEBIAN DEMO XORG GNOME";; - # centos) - # echo "FAIBASE CENTOS" # you may want to add class XORG here - # ifclass I386 && echo CENTOS6_32 # AFAIK there's no 32bit C7 - # ifclass AMD64 && echo CENTOS7_64 - # exit 0 ;; # CentOS does not use the GRUB class - # slchost) - # # Scientific Linux Cern, is very similar to CentOS. SLC should alsways use the class CENTOS - # echo "FAIBASE CENTOS SLC" # you may want to add class XORG here - # ifclass I386 && echo SLC7_32 - # ifclass AMD64 && echo SLC7_64 - # exit 0 ;; # CentOS/SLC does not use the GRUB class - *) - echo "FAIBASE DEBIAN DESKTOP" ;; -esac + +# For multi-boot system. +# We check that we aren't in a pxe boot environment. +# There is probably a better way to do this. +# 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. + +# +# +# Each host defines following: +# The base distro: +# UBUNTU, DEBIAN +# +# 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, FLIDAS64X +# +# 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. +# +# The apt sources files we want, +# STRETCH_FREE, STRETCH_NONFREE, TESTING_FREE, TESTING_NONFREE, +# XENIAL_FREE, FLIDAS, BELENOS, 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. +# +# +# Other notable classes: +# +# 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. +# +# PARTITION_PROMPT: If we don't see partitions to reuuse, prompt +# to make sure we really want to repartition and use a completely +# fresh install. I use this in case our repartition check has +# a bug in it, or I accidentally set REPARTITION. +# +# ROTATIONAL: in a system with ssd and hdd, install to the hdd +# instead of the default ssd. +# +# RAID0: Use raid 0 even if there are >= 4 disks with boot partititions. +# +# +# 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 +fi + +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 +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.