evomaintenance/evomaintenance.sh

92 lines
2.6 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
# version 0.2
# Copyright 2007-2008 Gregory Colpart <reg@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
[ -n "${HOSTNAME}" ] || HOSTNAME=$(hostname)
[ -n "${EVOMAINTMAIL}" ] || EVOMAINTMAIL=evomaintenance-$(echo "${HOSTNAME}" | cut -d- -f1)@${REALM}
2015-09-13 15:29:22 +02:00
2016-12-08 16:49:41 +01:00
SYSTEME=$(uname -s)
if [ "${SYSTEME}" = "Linux" ]; then
USER_TTY=$(tty | cut -d"/" -f3,4,5)
2018-09-04 23:33:16 +02:00
LOGFILE_PERMS="root:adm"
elif [ "${SYSTEME}" = "OpenBSD" ]; then
USER_TTY=$(tty | cut -d"/" -f3)
2018-09-04 23:33:16 +02:00
LOGFILE_PERMS="root:wheel"
2016-12-08 16:32:35 +01:00
else
echo "OS not detected!"
exit 1
2016-12-08 16:32:35 +01:00
fi
2015-09-13 15:29:22 +02:00
USER=$(logname)
WHO=$(LC_ALL=C who | grep ${USER_TTY} | tr -s ' ')
IP=$(echo ${WHO} | cut -d" " -f6 | sed -e "s/^(// ; s/)$//")
BEGIN_DATE=$(echo ${WHO} | cut -d" " -f3,4,5)
BEGIN_YEAR=$(date "+%Y")
PATH=${PATH}:/usr/sbin
2018-09-04 23:33:16 +02:00
# log file
LOGFILE=${LOGFILE:-/var/log/evomaintenance.log}
touch "${LOGFILE}"
chown "${LOGFILE_PERMS}" "${LOGFILE}"
2015-09-13 15:29:22 +02:00
# end_date
2018-09-04 22:50:25 +02:00
NOW=$(date -u +"%Y-%m-%dT%H:%M:%SZ")
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
echo "hostname = ${HOSTNAME}"
echo "user = ${USER}"
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
LOG_TEXTE=$(echo "${TEXTE}" | sed 's/"/\\\"/g')
2018-09-04 22:50:25 +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 .
${GIT_BIN} commit --all --message "${LOG_TEXTE}" --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_YEAR} ${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_YEAR} ${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}