# assign classes to hosts based on their hostname
-# NOTE:
-# 51-multi-boot should have something like this
-# for transient host configs which are not saved in
-# git (and make it executable):
-
-# if [[ ! -e /a/bin/fai/fai-wrapper ]]; then
-# case $HOSTNAME in
-# frodo) echo STABLE ;;
-# esac
-# fi
-
-
# do not use this if a menu will be presented
[ "$flag_menu" ] && exit 0
# 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 STABLE VOL_STABLE STABLE_FREE;;
-# # add more multi-boot hostnames here
-# esac
-# fi
+
+#
+#
+# Each host defines following:
+# The base distro:
+# UBUNTU, DEBIAN
#
-# 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.
+# The base disto version, which is also the basefile name if it exists.
+# Debian stable basefile gets built by faisetup and gets used otherwise,:
+# STRETCH64, XENIAL64, BELENOS64, FLIDAS64
+#
+# 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:
# 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 "STABLE"
+ echo "STRETCH"
case $HOSTNAME in
- li|lj) echo "STABLE_LINODE" ;;
+ li|lj) echo "STRETCH_LINODE" ;;
*)
# nonfree repo is not going away any time soon due to
# gcc-doc being in nonfree
- echo "STABLE_NONFREE"
+ echo "STRETCH_NONFREE"
;;
esac
elif isdebian-testing; then
fi
fi
-# use a list of classes for our demo machine
echo "FAIBASE"
-#echo "PARTITION_PROMPT"
+echo "PARTITION_PROMPT"
#echo REPARTITION