X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=fai%2Fconfig%2Fclass%2F50-host-classes;h=278bcce785df60383646fa068bbbd1281b26d2b7;hb=a018c3030b0ebd751d5667efd96c2fd32f2423e0;hp=6f3f8a885f729c9580d9aa49a3b59ce2bd05bd5b;hpb=f6b9ade60186b7be2ecf39266ced982ec7efc633;p=automated-distro-installer diff --git a/fai/config/class/50-host-classes b/fai/config/class/50-host-classes index 6f3f8a8..278bcce 100755 --- a/fai/config/class/50-host-classes +++ b/fai/config/class/50-host-classes @@ -19,37 +19,69 @@ # For multi-boot system. -# Check that we aren't in a pxe boot environment. +# 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 needs -# to have a class of either DEBIAN + STABLE or STRETCH64, -# or UBUNTU + XENIAL64. -# -# It's shell looks like this: +# 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 STABLE ;; +# tp) DEBIAN STABLE VOL_STABLE STABLE_FREE;; # # add more multi-boot hostnames here # esac # fi # -if [[ -e /a/bin/fai/fai-wrapper ]] && isdebian-stable; then - echo "STABLE" +# Each host defines the base distro: UBUNTU or DEBIAN. +# the disto version, also the basefile name if we aren't installing debian stable: +# STABLE, STRETCH64, XENIAL64, BELANOS64 +# the distro subvol name, we can add as many of these as we want: +# VOL_STABLE, VOL_STABLE_BOOTSTRAP, VOL_STRETCH, VOL_XENIAL, VOL_BELANOS +# and the class which defines the apt sources files we want, +# STABLE_FREE, STABLE_NONFREE, TESTING_FREE, TESTING_NONFREE, +# XENIAL_FREE (no XENIAL_NONFREE setup yet), BELANOS, STABLE_LINODE. +# This is a little redundant in some cases, but it keeps things +# simpler. +# +# +# Other notable classes: +# +# 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. +# +# +if [[ -e /a/bin/fai/fai-wrapper ]]; then + source /a/bin/distro-functions/src/identify-distros + if isdebian-stable; then + echo "STABLE" + fi fi # use a list of classes for our demo machine -echo "FAIBASE PARTITION_PROMPT" +echo "FAIBASE" + +#echo "PARTITION_PROMPT" +#echo REPARTITION + case $HOSTNAME in - x2|frodo|treetowl) - echo "DEBIAN_NON_FREE" + frodo|treetowl) if [[ -e /a/bin/fai/fai-wrapper ]] && isdebian-stable; then - echo "STABLE_NON_FREE" + echo "STABLE_NONFREE" fi ;; lj|lj) - echo "LINODESTABLE" ;; + echo "STABLE STABLE_LINODE" ;; esac if grep ^52:54:00: /sys/class/net/eth0/address &>/dev/null; then