evomaintenance/evomaintenance.sh

77 lines
2.3 KiB
Bash
Raw Normal View History

2015-09-13 15:29:22 +02:00
#!/bin/sh
# EvoMaintenance script
2016-12-08 16:51:55 +01:00
# Dependencies (all OS): git postgresql-client
# Dependencies (Debian): sudo
2015-09-13 15:29:22 +02:00
2018-09-05 00:04:22 +02:00
# version 0.3
# Copyright 2007-2018 Gregory Colpart <reg@evolix.fr>, Jérémy Lecour <jlecour@evolix.fr>, Evolix <info@evolix.fr>
2016-12-08 16:32:35 +01:00
2015-09-13 15:29:22 +02:00
test -f /etc/evomaintenance.cf && . /etc/evomaintenance.cf
2018-09-05 18:44:16 +02:00
[ -n "${HOSTNAME}" ] || HOSTNAME=$(hostname)
[ -n "${EVOMAINTMAIL}" ] || EVOMAINTMAIL=evomaintenance-$(echo "${HOSTNAME}" | cut -d- -f1)@${REALM}
2018-09-05 18:44:16 +02:00
[ -n "${LOGFILE}" ] || LOGFILE=/var/log/evomaintenance.log
2015-09-13 15:29:22 +02:00
PATH=${PATH}:/usr/sbin
2015-09-13 15:29:22 +02:00
WHO=$(LC_ALL=C who -m)
USER=$(echo ${WHO} | cut -d" " -f1)
IP=$(echo ${WHO} | cut -d" " -f6 | sed -e "s/^(// ; s/)$//")
BEGIN_DATE="$(date "+%Y") $(echo ${WHO} | cut -d" " -f3,4,5)"
END_DATE=$(date +"%Y %b %d %H:%M")
# we can't use "date --iso8601" because this options is not available everywhere
NOW_ISO=$(date +"%Y-%m-%dT%H:%M:%S%z")
2015-09-13 15:29:22 +02:00
# details
echo "Please, enter details about your maintenance"
read TEXTE
if [ "${TEXTE}" = "" ]; then
2015-09-13 15:29:22 +02:00
echo "no value..."
exit 1
fi
# recapitulatif
BLOB=$(cat <<END
Host : $HOSTNAME
User : $USER
IP : $IP
Begin : $BEGIN_DATE
End : $END_DATE
Message : $TEXTE
END
)
echo "${BLOB}"
2015-09-13 15:29:22 +02:00
echo "To cancel, [Ctrl+C] else press [Enter]"
read enter
2018-09-04 22:50:25 +02:00
# write log
echo "---------- ${NOW_ISO} ----------" >> "${LOGFILE}"
echo "${BLOB}" >> "${LOGFILE}"
2018-09-04 22:50:25 +02:00
# git commit
2018-09-04 23:10:27 +02:00
GIT_BIN=$(command -v git)
if test -x "${GIT_BIN}"; then
export GIT_DIR=/etc/.git
${GIT_BIN} add .
${GIT_BIN} commit --all --message "${TEXTE}" --message "${BLOB}" --author="${USER} <${USER}@evolix.net>" --quiet
fi
2018-09-04 22:50:25 +02:00
# insert into PG
SQL_TEXTE=`echo "${TEXTE}" | sed "s/'/\\\\\\'/g ; s@/@\\\\\/@g ; s@\\&@et@g"`
2018-09-04 22:50:25 +02:00
2015-09-13 15:29:22 +02:00
echo "
INSERT INTO evomaint(hostname,userid,ipaddress,begin_date,end_date,details)
VALUES ('${HOSTNAME}','${USER}','${IP}','${BEGIN_DATE}',now(),'${SQL_TEXTE}') " | \
psql ${PGDB} ${PGTABLE} -h ${PGHOST}
2015-09-13 15:29:22 +02:00
2018-09-04 22:50:25 +02:00
# send mail
SENDMAIL=$(command -v sendmail)
2015-09-13 15:29:22 +02:00
cat /usr/share/scripts/evomaintenance.tpl | \
sed -e "s/__TO__/${EVOMAINTMAIL}/ ; s/__HOSTNAME__/${HOSTNAME}/ ; s/__USER__/${USER}/ ; s/__BEGIN_DATE__/${BEGIN_DATE}/ ; s/__TEXTE__/${TEXTE}/ ; s/__IP__/${IP}/ ; s/__FULLFROM__/${FULLFROM}/ ; s/__FROM__/${FROM}/ ; s/__URGENCYFROM__/${URGENCYFROM}/ ; s/__URGENCYTEL__/${URGENCYTEL}/" | \
${SENDMAIL} -oi -t -f ${FROM}