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)
|
2018-09-04 23:08:42 +02:00
|
|
|
[ -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
|
|
|
|
2018-09-05 18:44:53 +02:00
|
|
|
PATH=${PATH}:/usr/sbin
|
2015-09-13 15:29:22 +02:00
|
|
|
|
2018-09-05 18:44:53 +02:00
|
|
|
WHO=$(LC_ALL=C who -m)
|
|
|
|
USER=$(echo ${WHO} | cut -d" " -f1)
|
2018-09-05 00:03:16 +02:00
|
|
|
IP=$(echo ${WHO} | cut -d" " -f6 | sed -e "s/^(// ; s/)$//")
|
|
|
|
BEGIN_DATE=$(echo ${WHO} | cut -d" " -f3,4,5)
|
|
|
|
BEGIN_YEAR=$(date "+%Y")
|
|
|
|
|
2018-09-05 18:45:08 +02:00
|
|
|
# "date --iso8601" is not available everywhere
|
|
|
|
NOW=$(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
|
|
|
|
|
2018-09-04 23:08:42 +02:00
|
|
|
if [ "${TEXTE}" = "" ]; then
|
2015-09-13 15:29:22 +02:00
|
|
|
echo "no value..."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# recapitulatif
|
2018-09-04 23:08:42 +02:00
|
|
|
echo "hostname = ${HOSTNAME}"
|
2018-09-04 23:35:21 +02:00
|
|
|
echo "user = ${USER}"
|
2018-09-04 23:08:42 +02:00
|
|
|
echo "IP = ${IP}"
|
|
|
|
echo "begin date = ${BEGIN_YEAR} ${BEGIN_DATE}"
|
|
|
|
echo "details = ${TEXTE}"
|
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
|
2018-09-04 23:08:42 +02:00
|
|
|
LOG_TEXTE=$(echo "${TEXTE}" | sed 's/"/\\\"/g')
|
2018-09-04 22:50:25 +02:00
|
|
|
|
2018-09-04 23:35:21 +02:00
|
|
|
echo "${NOW} hostname=\"${HOSTNAME}\" user=\"${USER}\" ip=\"${IP}\" begin_date=\"${BEGIN_YEAR} ${BEGIN_DATE}\" message=\"${LOG_TEXTE}\"" >> "${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 .
|
2018-09-04 23:35:21 +02:00
|
|
|
${GIT_BIN} commit --all --message "${LOG_TEXTE}" --author="${USER} <${USER}@evolix.net>" --quiet
|
2015-12-02 16:20:42 +01:00
|
|
|
fi
|
|
|
|
|
2018-09-04 22:50:25 +02:00
|
|
|
# insert into PG
|
2018-09-04 23:08:42 +02:00
|
|
|
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)
|
2018-09-04 23:35:21 +02:00
|
|
|
VALUES ('${HOSTNAME}','${USER}','${IP}','${BEGIN_YEAR} ${BEGIN_DATE}',now(),'${SQL_TEXTE}') " | \
|
2018-09-04 23:08:42 +02:00
|
|
|
psql ${PGDB} ${PGTABLE} -h ${PGHOST}
|
2015-09-13 15:29:22 +02:00
|
|
|
|
2018-09-04 22:50:25 +02:00
|
|
|
# send mail
|
2018-09-04 23:08:42 +02:00
|
|
|
SENDMAIL=$(command -v sendmail)
|
|
|
|
|
2015-09-13 15:29:22 +02:00
|
|
|
cat /usr/share/scripts/evomaintenance.tpl | \
|
2018-09-04 23:35:21 +02:00
|
|
|
sed -e "s/__TO__/${EVOMAINTMAIL}/ ; s/__HOSTNAME__/${HOSTNAME}/ ; s/__USER__/${USER}/ ; s/__BEGIN_DATE__/${BEGIN_YEAR} ${BEGIN_DATE}/ ; s/__TEXTE__/${TEXTE}/ ; s/__IP__/${IP}/ ; s/__FULLFROM__/${FULLFROM}/ ; s/__FROM__/${FROM}/ ; s/__URGENCYFROM__/${URGENCYFROM}/ ; s/__URGENCYTEL__/${URGENCYTEL}/" | \
|
2018-09-04 23:08:42 +02:00
|
|
|
${SENDMAIL} -oi -t -f ${FROM}
|