X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=faiserver-setup;h=724a09c7bce7e4182dd9d01658cb7169e9102f28;hp=617a3dc04d80c50fbd5168aa2b72c2da18012cc5;hb=23bf2f3666becf9d3c219af1eaea08b4cf843492;hpb=f74458d51ebaeba827307920c7a66ed2d69d6fbd diff --git a/faiserver-setup b/faiserver-setup index 617a3dc..724a09c 100755 --- a/faiserver-setup +++ b/faiserver-setup @@ -26,14 +26,24 @@ trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR [[ $EUID == 0 ]] || exec sudo "${BASH_SOURCE}" "$@" e() { echo "$@"; "$@"; } + +base=${1:-jessie} +sed="sed -ri --follow-symlinks" + + +if [[ $base == jessie ]]; then + wget -O - http://fai-project.org/download/074BCDE4.asc | apt-key add - + cat >/etc/apt/sources.list.d/fai.list <<'EOF' +deb http://fai-project.org/download jessie koeln +EOF +else + rm -f /etc/apt/sources.list.d/fai.list +fi + # for ubuntu: #add-apt-repository -y ppa:fai/ppa # for debian: -wget -O - http://fai-project.org/download/074BCDE4.asc | apt-key add - -cat >/etc/apt/sources.list.d/fai.list <<'EOF' -deb http://fai-project.org/download jessie koeln -EOF apt-get update # all the dependencies except the dhcp server @@ -43,28 +53,48 @@ to_install=() for pkg in $deps; do dpkg -s $pkg &>/dev/null && continue ||: to_install+=($pkg) - echo $pkg >>/etc/fai/fai-manually-installed-packages + # just so we have a record. + echo `date` $pkg >>/var/log/fai-manually-installed-packages.log done if [[ $to_install ]]; then apt-get -y install ${to_install[@]} fi -sed="sed -ri --follow-symlinks" -$sed 's/^#deb/deb/' /etc/fai/apt/sources.list +r=http://http.us.debian.org/debian +# like default, but scrap httpredir and add suggested newer pkgs in fai-project.org +dd of=/etc/fai/apt/sources.list </dev/null; then $sed '/^PACKAGES install$/a cryptsetup' /etc/fai/NFSROOT fi -fai-setup -vf +e fai-setup -vf { head -n 1 /srv/fai/nfsroot/root/.ssh/known_hosts | awk '{print $1}' \ - | tr '\n' ' '; ssh-keyscan localhost | grep -o "ecdsa-sha2-nistp256.*"; \ + | tr '\n' ' '; ssh-keyscan localhost | grep -o "ecdsa-sha2-nistp256.*"; \ } >>/srv/fai/nfsroot/root/.ssh/known_hosts # this does not alter the config on a new install $sed 's#^([[:space:]]*TFTP_DIRECTORY[[:space:]]*=).*#\1"/srv/tftp"#' \ - /etc/default/tftpd-hpa + /etc/default/tftpd-hpa service tftpd-hpa restart @@ -84,9 +114,9 @@ kernel=$(fai-chboot -L '^default$' | awk '{print $3}') type -t host &>/dev/null || apt-get -y install dnsutils # resolve host using gateway address my_ip=$(host faiserver $(route -n | sed -rn 's/^(0\.){3}0\s+(\S+).*/\2/p') | \ - sed -rn 's/^\S+ has address //p') + sed -rn 's/^\S+ has address //p') k_args=$(fai-chboot -L '^default$' | \ - sed -r "s/^(\S+\s+){3}(.*root=)(.*)/\2$my_ip:\3/") + sed -r "s/^(\S+\s+){3}(.*root=)(.*)/\2$my_ip:\3/") e fai-chboot -k "$k_args" -v -f verbose,sshd,createvt,reboot $std_arg $kernel default # make the faiserver also the apt proxy server