epcim
2/12/2016 - 8:02 AM

consul event shell template

consul event shell template


#!/bin/sh
    response=$(cat -)
    payload=$(echo $response | sed -e 's/^.*"Payload":"\([^"]*\)".*$/\1/')
    # action string "runme" == byte "cnVubWU=" , replace "runme" with your payload data

    if [ "$payload" == "cnVubWU=" ]; then
      sudo /bin/service stop mysql
    else
      logger skipping mysql stop, consul triggered by payload $payload
    fi

#!/bin/sh
#https://github.com/sequenceiq/docker-consul-watch-plugn/blob/master/consul-event-handler.sh

: ${LOGFILE:=/var/log/consul-watch/consul_handler.log}
: ${CONSUL_HOST:=127.0.0.1}
: ${CONSUL_HTTP_PORT:=8500}
: ${DEBUG:=1}

[[ "TRACE" ]] && set -x

debug(){
  [[ "$DEBUG" ]] && echo "[DEBUG] $(date) $*" >> $LOGFILE
}

error(){
  echo "[ERROR] $(date) $*" >> $LOGFILE
}

get_field() {
  declare json="$1"
  declare field="$2"

  echo "$json"|jq ".$field" -r
}

__envVars() {
  declare eventId=$1
  declare ltime=$2
  declare version=$3

  echo "EVENT_ID=$eventId \
    EVENT_LTIME=$ltime \
    EVENT_VERSION=$version \
    CONSUL_HOST=$CONSUL_HOST \
    CONSUL_HTTP_PORT=$CONSUL_HTTP_PORT \
    LOGFILE=$LOGFILE"
}

__executeScript() {
  declare envVars=$1
  declare eventSpecPayload=$2
  declare scriptFile=$(echo $eventSpecPayload | cut -d" " -f 1)

  debug "execute $scriptFile..."
  eval $envVars \
    PAYLOAD=\"$(echo $eventSpecPayload  | cut -d" " -f 2-)\" \
    $scriptFile
}

__downloadAndExecuteScript() {
  declare envVars=$1
  declare eventSpecPayload=$2
  declare url=$(echo $eventSpecPayload | cut -d" " -f 1)
  declare scriptfile="/tmp/consulevent-$RANDOM.sh"

  debug "execute script from $url url locally..."
  curl -Lko $scriptfile $url
  chmod +x $scripfile

  debug "execute downloaded script $scriptFile..."
  eval $envVars \
    PAYLOAD=\"$(echo $eventSpecPayload  | cut -d" " -f 2-)\" \
    $scriptFile
}
__updateState() {
  let tries=12
  while [ $tries != 0 ]; do
    tries=$((tries-1))
    curl -X PUT -d "$2" -f "http://$CONSUL_HOST:$CONSUL_HTTP_PORT/v1/kv/events/$1/$(__getHostName)"
    [[ $? == 0 ]] && break
    [[ $? != 0 ]] && [[ $tries != 0 ]] && sleep 5
  done
}
process_json() {
  while read json; do
    if [[ -z $json ]]; then
      debug "json is missing (processing)"
    fi

    event=$(get_field $json Name)
    id=$(get_field $json ID)
    payload=$(get_field $json Payload | base64 -d)
    ltime=$(get_field $json LTime)
    version=$(get_field $json Version)
    eventtype=$(echo $payload | cut -d" " -f 1)
    eventSpecPayload=$(echo $payload | cut -d" " -f 2-)
    cmdEnvVars=$(__envVars $id $ltime $version)

    debug "event=$event, id=$id, payload=$payload, eventtype=$eventtype, specPayload=$eventSpecPayload"
    if [[ -z $id ]]; then
      debug "eventid is missing, skip processing"
      continue
    fi

    __updateState $id 'ACCEPTED'

#    case "$eventtype" in
     # EXEC)
     #   __executeScript "$cmdEnvVars" "$eventSpecPayload" ;;
     # DOWNLOAD_AND_EXEC)
     #   __downloadAndExecuteScript "$cmdEnvVars" "$eventSpecPayload" ;;
     # EXEC_IN_CONTAINER)
     #   __executeScriptInContainer "$cmdEnvVars" "$eventSpecPayload" ;;
     # TRIGGER_PLUGN)
     #   __triggerPlugin "$cmdEnvVars" "$eventSpecPayload" ;;
     # TRIGGER_PLUGN_IN_CONTAINER)
     #   __triggerPluginInContainer "$cmdEnvVars" "$eventSpecPayload" ;;
#    esac

# DO THE JOB

    if [ $? -eq 0 ]; then
      debug "$eventtype finished successfully"
      __updateState $id 'FINISHED'
    else
      error "$eventtype failed to finish successfully"
      __updateState $id 'FAILED'
    fi
  done
}

main() {
  while read array; do
    [[ -n $array ]] && echo $array | jq .[] -c | process_json
  done
}

[[ "$0" == "$BASH_SOURCE" ]] && main "$@"