#!/bin/sh
#
# 2011 Nico Schottelius (nico-cdist at schottelius.org)
#
# This file is part of cdist.
#
# cdist is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# cdist is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
#
#
# Deploy configuration to many hosts
#

. cdist-config
[ $# -ge 1 ] || __cdist_usage "[-p] <target host> [target host ]"
set -u

# trap __cdist_tmp_removal EXIT
trap killandclean EXIT

killandclean()
{
   # i may have been altered outside, just use the current offset
   while [ "$i" -gt 0 ]; do
      eval pid=\$pid_$i
      kill "$pid"
      i=$((i-1))
   done

   # Ensure tmp stuff is being removed
   __cdist_tmp_removal
}


filter()
{
   awk -v host=$1 '{ print "[" host "] " $0 }'
}

parallel=""
if [ "$1" = "-p" ]; then
   parallel=yes
   shift
fi

i=0
while [ $# -gt 0 ]; do
   if [ "$parallel" ]; then
      cdist-deploy-to "$1" | filter "$1" &
      # Record pid and host for use later
      i=$((i+1))
      eval pid_$i=$!
      eval host_$i=\$1
   else
      cdist-deploy-to "$1" | filter "$1"
   fi
   shift
done

e=0
if [ "$parallel" ]; then
   __cdist_echo info "Waiting for cdist-deploy-to jobs to finish"
   while [ "$i" -gt 0 ]; do
      eval pid=\$pid_$i
      wait "$pid"
      if [ $? -ne 0 ]; then
         e=$((e+1))
         eval e_host_$e=\$host_$i
      fi
      i=$((i-1))
   done
fi

# Display all failed hosts after all runs are done, so the sysadmin gets them
while [ "$e" -gt 0 ]; do
   eval host=\$host_$e
   __cdist_echo error "Configuration of host $host failed."
   e=$((e-1))
done