Compare commits

...

29 Commits

Author SHA1 Message Date
6f8e364dbb Merge branch 'master' of git.oopen.de:script/admin-stuff 2025-04-21 09:30:53 +02:00
16ee308311 add_new_user.sh: change password for 'localadmin'. 2025-04-21 09:30:39 +02:00
71d974131e machine_poweroff.sh: fix error sending power-off e-mail. 2025-03-27 15:29:06 +01:00
2d1798ccd9 machine_poweroff.sh: finished script.. 2025-03-27 15:04:05 +01:00
c3dd3448b8 machine_poweroff.sh: support LXC Hostsystems. 2025-03-27 14:29:42 +01:00
3525154857 check-disc-usage.sh: minot change in script output. 2024-12-17 10:44:36 +01:00
051e8dc948 check-disc-usage.sh: change subject of warn message. 2024-12-16 22:12:02 +01:00
8914e5ba25 update_git_repositories.sh: add path '/root/crontab'. 2024-12-08 11:50:14 +01:00
e6b0a946f4 modified: u.a. add user 'marsupilami'. 2024-11-17 11:05:30 +01:00
62cf8ac515 change_munin_ip.sh: fix error in default vars. 2024-11-16 12:32:59 +01:00
8030091145 create_change_munin_ip.conf.sh: fix error concerning conf path. 2024-11-16 12:25:35 +01:00
7e88f94754 change_munin_ip.sh: Some minor changes.. 2024-11-15 20:10:40 +01:00
11d2ab22b6 Merge branch 'master' of https://git.oopen.de/script/admin-stuff 2024-11-15 19:50:08 +01:00
588b72f5a8 Add script 'create_change_munin_ip.conf.sh'. 2024-11-15 19:48:42 +01:00
003fac399e Add script 'change_munin_ip.sh'. 2024-11-15 19:48:07 +01:00
9658cf7c09 Add user nd-admin.. 2024-11-11 11:44:33 +01:00
0702feb22b add_new_user.sh: add users 'nd-web-prod' and 'nd-web-demo'. 2024-11-07 17:20:03 +01:00
67afd2d6d3 Add script 'create-rsyslogd-postfix.sh'. 2024-09-15 22:56:52 +02:00
2b541538b6 check-disc-usage.sh: remove development code. 2024-02-27 16:39:50 +01:00
526f32fab5 Rename 'check-disk-usage.sh' to 'check-disc-usage.sh'. 2024-02-27 15:47:21 +01:00
7209a56245 Add script 'check-disk-usage.sh'. 2024-02-27 14:35:14 +01:00
ca999897be Add script 'check-disk-usage.sh'. 2024-02-27 14:31:45 +01:00
eede408c92 add_new_user.sh: change passwort for wadmin. 2024-02-13 13:24:45 +01:00
581b5269ef add_new_user.sh: eris is sudo user. 2024-01-07 01:25:38 +01:00
3be0ec3310 add_new_user.sh: add some IL user. 2024-01-07 00:46:19 +01:00
bd3281890d add_new_user.sh: add user 'dolphin'. 2023-12-10 22:45:41 +01:00
7d304b4a97 add_new_user.sh: set default base home dir to '/home/' if DHOME is not set. 2023-12-09 12:03:28 +01:00
a80f530438 update ... 2023-12-08 12:43:50 +01:00
472a6698e8 update pass for jason. 2023-12-08 11:15:16 +01:00
18 changed files with 1699 additions and 42 deletions

View File

@ -20,22 +20,28 @@ templates_base_dir="${working_dir}/supported-files/user_templates"
templates_all_dir="${templates_base_dir}/all" templates_all_dir="${templates_base_dir}/all"
sudo_users=" sudo_users="
sysadm
localadmin
chris
erik
wadmin
ilker
ilker-sudo
ckubu
alex alex
alis alis
defa
init
marcus
xmatti
c3po c3po
chris
ckubu
defa
dolphin
eris
erik
hedwig
ilker
ilker-sudo
init
jason jason
jumpy
localadmin
marcus
marsupilami
nd-admin
sysadm
wadmin
xmatti
" "
@ -119,7 +125,11 @@ fi
if [[ -f "/etc/adduser.conf" ]]; then if [[ -f "/etc/adduser.conf" ]]; then
. /etc/adduser.conf . /etc/adduser.conf
if [[ -z "$DHOME" ]] ; then
home_base_dir=/home
else
home_base_dir="$DHOME" home_base_dir="$DHOME"
fi
min_uid=$FIRST_UID min_uid=$FIRST_UID
skel_dir="$SKEL" skel_dir="$SKEL"
else else
@ -155,6 +165,17 @@ if ! id -u "${user_name}" > /dev/null 2>&1 ; then
user_uid=1040 user_uid=1040
user_gid=1040 user_gid=1040
home_dir="/var/www" home_dir="/var/www"
elif [[ "$user_name" = 'nd-web-prod' ]]; then
user_uid=1041
user_gid=1041
home_dir="/var/www/nd-web-prod"
elif [[ "$user_name" = 'nd-web-demo' ]]; then
user_uid=1042
user_gid=1042
home_dir="/var/www/nd-web-demo"
elif [[ "$user_name" = 'nd-admin' ]]; then
user_uid=1045
user_gid=1045
elif [[ "$user_name" = 'sysadm' ]]; then elif [[ "$user_name" = 'sysadm' ]]; then
user_uid=1050 user_uid=1050
user_gid=1050 user_gid=1050
@ -164,6 +185,9 @@ if ! id -u "${user_name}" > /dev/null 2>&1 ; then
elif [[ "$user_name" = 'back' ]]; then elif [[ "$user_name" = 'back' ]]; then
user_uid=1060 user_uid=1060
user_gid=1060 user_gid=1060
elif [[ "$user_name" = 'borg' ]]; then
user_uid=1065
user_gid=1065
elif [[ "$user_name" = 'cryptpad' ]]; then elif [[ "$user_name" = 'cryptpad' ]]; then
user_uid=1033 user_uid=1033
user_gid=1033 user_gid=1033
@ -221,6 +245,21 @@ if $password_needed ; then
if [[ "$user_name" = 'webadmin' ]]; then if [[ "$user_name" = 'webadmin' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$P1UvKv/0\\\$0hWHiUXQTrNl5SFf52iAY1qDYsJFhjHaVC6F6BuvazcNXkzjAcnuX5PMml5DLh4tyFpqVdPpCyAyd92YypNbu/:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$P1UvKv/0\\\$0hWHiUXQTrNl5SFf52iAY1qDYsJFhjHaVC6F6BuvazcNXkzjAcnuX5PMml5DLh4tyFpqVdPpCyAyd92YypNbu/:\2#" /etc/shadow
# - nd-admin
# -
elif [[ "$user_name" = 'nd-admin' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$1YJwHY0qdLimgtdOKlTxR1\\\$/O9QWTpr0Y41TduR2GZ0FMCiIxFqOaXWSM9hmHRnv80:\2#" /etc/shadow
# - nd-web-prod
# -
elif [[ "$user_name" = 'nd-web-prod' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$boxWdtKmOp7AKHEAFj1.1/\\\$jlhYI62N5u6P.jRxAgmmDGVvGnfrPKTcKelYC3Z2sM4:\2#" /etc/shadow
# - nd-web-demo
# -
elif [[ "$user_name" = 'nd-web-demo' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$uqzyF.BYEZrgJlDnGTH/x/\\\$abn3RCkx5SAz.f9B5Iqvaw/LWRncoyS40Lx2uGj2xQ.:\2#" /etc/shadow
# - sysadm # - sysadm
# - # -
elif [[ "$user_name" = 'sysadm' ]]; then elif [[ "$user_name" = 'sysadm' ]]; then
@ -231,10 +270,15 @@ if $password_needed ; then
elif [[ "$user_name" = 'back' ]]; then elif [[ "$user_name" = 'back' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$okMvVb1lmERtmLDa0lAmM1\\\$Gkm9VHgv.IYijNpsTE3sOZ.pg7I0x7siuXPVFbwQc23:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$okMvVb1lmERtmLDa0lAmM1\\\$Gkm9VHgv.IYijNpsTE3sOZ.pg7I0x7siuXPVFbwQc23:\2#" /etc/shadow
# - borg
# -
elif [[ "$user_name" = 'borg' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$SZty9T8ZWbnyHR2S85xaG.\\\$GhxHOKG9fKErT9s5TAehXXyZJSkNaIcXY18Rg1iMyhC:\2#" /etc/shadow
# - localadmin # - localadmin
# - # -
elif [[ "$user_name" = 'localadmin' ]]; then elif [[ "$user_name" = 'localadmin' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$flo5afeu\\\$1Dn/tqIOJIFQbymCzpJk9BgGflQdy2Eg0nTiMBF7VefN7uY/Md1pV2yU0S47kZuH5aDjSdPfKzhHp8Aul/xx90:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$a7Pu7Km.0CEyBIz7FiDt91\\\$IdEIMclAswWIX6LMMlOgHSPBXaB226AcIYj6/4F2g35:\2#" /etc/shadow
# - axel # - axel
# - # -
@ -282,26 +326,51 @@ if $password_needed ; then
elif [[ "$user_name" = 'erik' ]]; then elif [[ "$user_name" = 'erik' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$GntX81EP\\\$O1GEmQF.BbOQfTMMw/m/BDKSXmANVpqmz0nyzw4O4R2/iK9huGOAjT/2eq8FVdMghvNOvdwrWtwohO.Mg4V9n.:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$GntX81EP\\\$O1GEmQF.BbOQfTMMw/m/BDKSXmANVpqmz0nyzw4O4R2/iK9huGOAjT/2eq8FVdMghvNOvdwrWtwohO.Mg4V9n.:\2#" /etc/shadow
# - eris
# -
elif [[ "$user_name" = 'eris' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$2k/ZZEdYqay2oIoW00eSn0\\\$u0E/KBTI07end/gRq31sJdf3A8hbqh42e7apGVMn9d1:\2#" /etc/shadow
# - c3po # - c3po
# - # -
elif [[ "$user_name" = 'c3po' ]]; then elif [[ "$user_name" = 'c3po' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$z0yywBoF\\\$VtusXNrSvL4s4kQSeCl/6rZoCcAOz0aSINm0ArntILNvLnurVDGk9nJz42ZMya/DFe8snlf5kLymeAmNRiyDK/:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$RE5/J41tiT9VGR1EEUG1v0\\\$b6vffdjY5qTHZAKAMh093ohujBUhV6rnVmzS/ctRl7D:\2#" /etc/shadow
# - hedwig
# -
elif [[ "$user_name" = 'hedwig' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$JtS8/Okj5I8yg8.kFTFA6.\\\$9RS.N9A8oVOhwyT0eILDRoKzqDjOCAYft9j0ofwqcqD:\2#" /etc/shadow
# - jumpy
# -
elif [[ "$user_name" = 'jumpy' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$fOtCqi5egKR9qvH0adBVs0\\\$8uiduG3.8nDk2lHmlRDK2.tCKg4yEU91S.xZgSONCL3:\2#" /etc/shadow
# - dolphin
# -
elif [[ "$user_name" = 'dolphin' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$4LaHObIvOTyXyoEEEljzP/\\\$Vjp2akP.EPg/LZmKPurvYbCOCOf7fP//oRU6EkcMvK6:\2#" /etc/shadow
# - xmatti
# - $y$j9T$z1Zz8bCDJro64/upmwFk..$nG9EDG1sk0Prf2cyj1ylnILFTbSrQJwfosHYSmssWd7
# -
elif [[ "$user_name" = 'xmatti' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$z1Zz8bCDJro64/upmwFk..\\\$nG9EDG1sk0Prf2cyj1ylnILFTbSrQJwfosHYSmssWd7:\2#" /etc/shadow
# - jason # - jason
# - # - $y$j9T$OXib1uJhr.zU/H9/XnLGd0$Bd4t8mBcQXQZ6K6U/IiarTCD1sbKhFnMWm/5JDnzTV/
# - 2Gw/FY6N-K.Ate-R # - 2Gw/FY6N-K.Ate-R
elif [[ "$user_name" = 'c3po' ]]; then elif [[ "$user_name" = 'jason' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$.L0YWnREcDrMep6Irp44e/\\\$NW1LV7tMssSJ.ot5if9wM5vm2XoulnlM9mETZldUuy.:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$OXib1uJhr.zU/H9/XnLGd0\\\$Bd4t8mBcQXQZ6K6U/IiarTCD1sbKhFnMWm/5JDnzTV/:\2#" /etc/shadow
# - chris # - chris
# - # -
elif [[ "$user_name" = 'chris' ]]; then elif [[ "$user_name" = 'chris' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$4tHDBpAXsLybUcR3EkGsN1\\\$FztD35vOLJ2wkdcMMyWVjx7H6vCYAXK2Sik9RVx6iF6:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$JPKlR6kIk7GJStSdmAQWq/\\\$e1vJER6KL/dk1diFNtC.COw9lu2uT6ZdrUgGcNVb912:\2#" /etc/shadow
# - ckubu # - ckubu
# - # -
elif [[ "$user_name" = 'ckubu' ]]; then elif [[ "$user_name" = 'ckubu' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$nmAWOQHZ\\\$PRx3FAGI4.X4ah7nmuTFJi0iFMwlWwTz.iM9B4yjLGcnQ/hg3K0O0lSDXOOn7yRJlhwRejVq2XSNvrmSGwJw//:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$rgPmWh7b8x1ROMjvKYjoi0\\\$KCAw3Bb6B7GH9Zm6yf7RS7DzKHniUfabYum1JGRwAWA:\2#" /etc/shadow
# - alex # - alex
# - # -
@ -333,7 +402,7 @@ if $password_needed ; then
# - wadmin # - wadmin
# - # -
elif [[ "$user_name" = 'wadmin' ]]; then elif [[ "$user_name" = 'wadmin' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$vaVNOPYp\\\$RbV6/phKDZRSa4TQGlJVOF/HQqyxAK7BeQmir8Kr8pwy7ATlHGvcPzJkuldNNp4O4t2q3EJRW2uVpjsng4ZhH1:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$YarN7tuuR4Q4iGCUundvp.\\\$Cj7hN5UAaigmXCZrNQbeIIq40MmYX66.Jiu0QmDYY6.:\2#" /etc/shadow
# - marcus Opferperspektive # - marcus Opferperspektive
@ -341,6 +410,12 @@ if $password_needed ; then
elif [[ "$user_name" = 'marcus' ]]; then elif [[ "$user_name" = 'marcus' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$SPnbZ2Gcf.4iHz93\\\$Vp7fg/xCGls4cPJIiLR5Ogxm2U38RPpPgHLaLIJiOe.PekJCuRsvRLBZLITec2JQhdVTvqpmKURUZrKdXs62z0:\2#" /etc/shadow perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$6\\\$SPnbZ2Gcf.4iHz93\\\$Vp7fg/xCGls4cPJIiLR5Ogxm2U38RPpPgHLaLIJiOe.PekJCuRsvRLBZLITec2JQhdVTvqpmKURUZrKdXs62z0:\2#" /etc/shadow
# - marsupilami (Torbsen IL)
# -
elif [[ "$user_name" = 'marsupilami' ]]; then
perl -i -n -p -e "s#^(${user_name}):[^:]+:(.+)#\1:\\\$y\\\$j9T\\\$guTT3egsLUFwxUGCnDJ0o0\\\$WCQt3gXcYIpArTxbn2BunvIWG6w7GZLx./fFGJYCsd/:\2#" /etc/shadow
# - root # - root
# - # -
elif [[ "$user_name" = 'root' ]]; then elif [[ "$user_name" = 'root' ]]; then

657
change_munin_ip.sh Executable file
View File

@ -0,0 +1,657 @@
#!/usr/bin/env bash
script_name="$(basename $(realpath $0))"
working_dir="$(dirname $(realpath $0))"
conf_file="${working_dir}/conf/${script_name%%.*}.conf"
LOCK_DIR="/tmp/${script_name%%.*}.LOCK"
log_file="${LOCK_DIR}/${script_name%%.*}.log"
# ----------
# Base Function(s)
# ----------
usage() {
[[ -n "$1" ]] && error "$1"
[[ $terminal ]] && echo -e "
\033[1mUsage:\033[m
$(basename $0) [-b]
\033[1mDescription\033[m
Script changes munin server ips (IPv4 and IPv6) in munin and in firewall configuration. All
parameters can be given interactivly if not running in batch mode.
\033[1mOptions\033[m
-b
script acts in batch mode. All required parameters must be given in configuration filer
-h
Prints this help.
\033[1mFiles\033[m
$conf_file: Configuration file
\033[1mExample:\033[m
Change munin server ip addresses.
\033[1m$(basename $0)\033[m
Same, but act in batch mode
\033[1m$(basename $0) -b\033[m
"
clean_up 1
}
clean_up() {
# Perform program exit housekeeping
rm -rf "$LOCK_DIR"
blank_line
exit $1
}
echononl(){
if $terminal ; then
echo X\\c > /tmp/shprompt$$
if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then
echo -e -n " $*\\c" 1>&2
else
echo -e -n " $*" 1>&2
fi
rm /tmp/shprompt$$
fi
}
fatal(){
echo ""
if $terminal ; then
echo -e " [ \033[31m\033[1mFatal\033[m ]: $*"
echo ""
echo -e " \033[31m\033[1mScript was interupted\033[m!"
else
echo " [ Fatal ]: $*"
echo ""
echo " Script was terminated...."
fi
echo ""
clean_up 1
}
error (){
echo ""
if $terminal ; then
echo -e " [ \033[31m\033[1mError\033[m ]: $*"
else
echo "[ Error ]: $*"
fi
echo ""
}
warn (){
echo ""
if $terminal ; then
echo -e " [ \033[33m\033[1mWarning\033[m ]: $*"
else
echo "[ Warning ]: $*"
fi
echo ""
}
warn_only_terminal () {
if $terminal ; then
echo ""
echo -e "\t[ \033[33m\033[1mWarning\033[m ]: $*"
echo ""
fi
}
info (){
if $terminal ; then
echo ""
echo -e " [ \033[32m\033[1mInfo\033[m ] $*"
echo ""
fi
}
ok (){
if $terminal ; then
echo ""
echo -e " [ \033[32m\033[1mOk\033[m ] $*"
echo ""
fi
}
echo_done() {
if $terminal ; then
echo -e "\033[75G[ \033[32mdone\033[m ]"
fi
}
echo_ok() {
if $terminal ; then
echo -e "\033[75G[ \033[32mok\033[m ]"
fi
}
echo_warn() {
if $terminal ; then
echo -e "\033[75G[ \033[33mwarn\033[m ]"
fi
}
echo_failed(){
if $terminal ; then
echo -e "\033[75G[ \033[1;31mfailed\033[m ]"
fi
}
echo_skipped() {
if $terminal ; then
echo -e "\033[75G[ \033[90m\033[1mskipped\033[m ]"
fi
}
echo_wait(){
if $terminal ; then
echo -en "\033[75G[ \033[5m\033[1m...\033[m ]"
fi
}
trim() {
local var="$*"
var="${var#"${var%%[![:space:]]*}"}" # remove leading whitespace characters
var="${var%"${var##*[![:space:]]}"}" # remove trailing whitespace characters
echo -n "$var"
}
blank_line() {
if $terminal ; then
echo ""
fi
}
containsElement () {
local e
for e in "${@:2}"; do [[ "$e" == "$1" ]] && return 0; done
return 1
}
is_number() {
return $(test ! -z "${1##*[!0-9]*}" > /dev/null 2>&1);
# - also possible
# -
#[[ ! -z "${1##*[!0-9]*}" ]] && return 0 || return 1
#return $([[ ! -z "${1##*[!0-9]*}" ]])
}
is_valid_ipv4() {
local -a octets=( ${1//\./ } )
local RETURNVALUE=0
# return an error if the IP doesn't have exactly 4 octets
[[ ${#octets[@]} -ne 4 ]] && return 1
for octet in ${octets[@]}
do
if [[ ${octet} =~ ^[0-9]{1,3}$ ]]
then # shift number by 8 bits, anything larger than 255 will be > 0
((RETURNVALUE += octet>>8 ))
else # octet wasn't numeric, return error
return 1
fi
done
return ${RETURNVALUE}
}
# - Test if given argument is a valid IPv6 Address
# -
#is_valid_ipv6() {
# local _ipv6=$1
#
# if [ "$1" != "${1#[0-9a-f]*:}" ] \
# && [ "$1" = "${1#*[^0-9a-f:]}" ] \
# && [ "${1#*[0-9A-Fa-f][0-9A-Fa-f][0-9A-Fa-f][0-9A-Fa-f][0-9A-Fa-f]}" = "${1#*:*:*:*:*:*:*:*:*:}" ]; then
# return 0
# else
# return 1
# fi
#}
is_valid_ipv6() {
local _ipv6="$1"
_regex_ipv6='^([0-9a-fA-F]{0,4}:){1,7}[0-9a-fA-F]{0,4}$'
if [[ "$_ipv6" =~ ${_regex_ipv6} ]]; then
return 0
else
return 1
fi
}
# ----------
# Some checks ..
# ----------
# - Running in a terminal?
# -
if [[ -t 1 ]] ; then
terminal=true
else
terminal=false
BATCH_MODE=true
fi
# ----------
# Default Values
# ----------
BATCH_MODE=false
DEFAULT_MUNIN_CONF_FILE='/etc/munin/munin-node.conf'
DEFAULT_IPT_FIREWALL_MAIN_IPV4_FILE='/etc/ipt-firewall/main_ipv4.conf'
DEFAULT_IPT_FIREWALL_MAIN_IPV6_FILE='/etc/ipt-firewall/main_ipv6.conf'
# ----------
# Read Configuration
# ----------
if [[ -f "$conf_file" ]]; then
source "$conf_file"
else
warn_only_terminal "No configuration file '$conf_file' present.\n
Loading default values.."
fi
# ----------
# Read commandline parameter
# ----------
while getopts bh opt ; do
case $opt in
b) BATCH_MODE=true
;;
h) usage
;;
\?) usage ;;
esac
done
if [[ -n "${IPv4_ADDRESS_OLD}" ]] ; then
_IPv4_ADDRESS_OLD="${IPv4_ADDRESS_OLD}"
fi
if [[ -n "${IPv6_ADDRESS_OLD}" ]] ; then
_IPv6_ADDRESS_OLD="${IPv6_ADDRESS_OLD}"
fi
if [[ -n "${IPv4_ADDRESS_NEW}" ]] ; then
_IPv4_ADDRESS_NEW="${IPv4_ADDRESS_NEW}"
fi
if [[ -n "${IPv6_ADDRESS_NEW}" ]] ; then
_IPv6_ADDRESS_NEW="${IPv6_ADDRESS_NEW}"
fi
if [[ -z "${MUNIN_CONF_FILE}" ]]; then
MUNIN_CONF_FILE="${DEFAULT_MUNIN_CONF_FILE}"
fi
if [[ -z "${IPT_FIREWALL_MAIN_IPV4_FILE}" ]]; then
IPT_FIREWALL_MAIN_IPV4_FILE="${DEFAULT_IPT_FIREWALL_MAIN_IPV4_FILE}"
fi
if [[ -z "${IPT_FIREWALL_MAIN_IPV6_FILE}" ]]; then
IPT_FIREWALL_MAIN_IPV6_FILE="${DEFAULT_IPT_FIREWALL_MAIN_IPV6_FILE}"
fi
if ${BATCH_MODE} && ( [[ -z "${IPv4_ADDRESS_OLD}" ]] || [[ -z "${IPv4_ADDRESS_NEW}" ]] \
|| [[ -z "${IPv6_ADDRESS_OLD}" ]] || [[ -z "${IPv6_ADDRESS_NEW}" ]] ) ; then
[[ -z "${IPv4_ADDRESS_OLD}" ]] && fatal "Variable 'IPv4_ADDRESS_OLD' is empty and we are in batch mode!"
[[ -z "${IPv4_ADDRESS_NEW}" ]] && fatal "Variable 'IPv4_ADDRESS_NEW' is empty and we are in batch mode!"
[[ -z "${IPv6_ADDRESS_OLD}" ]] && fatal "Variable 'IPv6_ADDRESS_OLD' is empty and we are in batch mode!"
[[ -z "${IPv6_ADDRESS_NEW}" ]] && fatal "Variable 'IPv6_ADDRESS_NEW' is empty and we are in batch mode!"
fatal "Something wired went wrong.."
fi
if ! ${BATCH_MODE} && ${terminal}; then
echo ""
echo -e "\033[32m--\033[m"
echo ""
echo "Insert IPv4-Address which do you want to change (old address)."
echo ""
echo -e "Type \"\033[33mNone\033[m\" if no IPv4 address should be changed."
echo ""
IPv4_ADDRESS_OLD=
_set_ipv4=true
while [ "X$IPv4_ADDRESS_OLD" = "X" ]; do
if [[ -z "${_IPv4_ADDRESS_OLD}" ]]; then
echononl "Old IPv4-Address: "
read IPv4_ADDRESS_OLD
## - To lower case
IPv4_ADDRESS_OLD=${IPv4_ADDRESS_OLD,,}
if [ "X$IPv4_ADDRESS_OLD" = "X" ]; then
echo -e "\n\t\033[33m\033[1mAn entry is required!\033[m\n"
IPv4_ADDRESS_OLD=""
continue
fi
else
echononl "Old IPv4-Address: [${_IPv4_ADDRESS_OLD}]: "
read IPv4_ADDRESS_OLD
## - To lower case
IPv4_ADDRESS_OLD=${IPv4_ADDRESS_OLD,,}
if [[ -z "$(trim ${IPv4_ADDRESS_OLD})" ]]; then
IPv4_ADDRESS_OLD=${_IPv4_ADDRESS_OLD}
fi
fi
if [ "${IPv4_ADDRESS_OLD,,}" = "none" ];then
_set_ipv4=false
break
fi
if ! is_valid_ipv4 $IPv4_ADDRESS_OLD ; then
echo -e "\n\t\033[33m\033[1m$IPv4_ADDRESS_OLD\033[m is NOT a valid IPv4 Address\n"
IPv4_ADDRESS_OLD=""
continue
fi
done
if $_set_ipv4 ; then
echo ""
echo -e "\033[32m--\033[m"
echo ""
echo "Insert IPv4-Address of the new munin server."
echo ""
IPv4_ADDRESS_NEW=
while [ "X$IPv4_ADDRESS_NEW" = "X" ]; do
if [[ -z "${_IPv4_ADDRESS_NEW}" ]]; then
echononl "New IPv4-Address: "
read IPv4_ADDRESS_NEW
## - To lower case
IPv4_ADDRESS_NEW=${IPv4_ADDRESS_NEW,,}
if [ "X$IPv4_ADDRESS_NEW" = "X" ]; then
echo -e "\n\t\033[33m\033[1mAn entry is required!\033[m\n"
IPv4_ADDRESS_NEW=""
continue
fi
else
echononl "New IPv4-Address [${_IPv4_ADDRESS_NEW}]: "
read IPv4_ADDRESS_NEW
## - To lower case
IPv4_ADDRESS_NEW=${IPv4_ADDRESS_NEW,,}
if [[ -z "$(trim ${IPv4_ADDRESS_NEW})" ]]; then
IPv4_ADDRESS_NEW=${_IPv4_ADDRESS_NEW}
fi
fi
if ! is_valid_ipv4 $IPv4_ADDRESS_NEW ; then
echo -e "\n\t\033[33m\033[1m$IPv4_ADDRESS_NEW\033[m is NOT a valid IPv4 Address\n"
IPv4_ADDRESS_NEW=""
continue
fi
done
fi
echo ""
echo -e "\033[32m--\033[m"
echo ""
echo "Insert IPv6-Address which do you want to change (old address)."
echo ""
echo -e "Type \"\033[33mnone\033[m\" if no IPv6 address should be changed."
echo ""
IPv6_ADDRESS_OLD=
_set_ipv6=true
while [ "X$IPv6_ADDRESS_OLD" = "X" ]; do
if [[ -z "${_IPv6_ADDRESS_OLD}" ]]; then
echononl "Old IPv6-Address: "
read IPv6_ADDRESS_OLD
## - To lower case
IPv6_ADDRESS_OLD=${IPv6_ADDRESS_OLD,,}
if [ "X$IPv6_ADDRESS_OLD" = "X" ]; then
echo -e "\n\t\033[33m\033[1mAn entry is required!\033[m\n"
IPv6_ADDRESS_OLD=""
continue
fi
else
echononl "Old IPv6-Address: [${_IPv6_ADDRESS_OLD}]: "
read IPv6_ADDRESS_OLD
## - To lower case
IPv6_ADDRESS_OLD=${IPv6_ADDRESS_OLD,,}
if [[ -z "$(trim ${IPv6_ADDRESS_OLD})" ]]; then
IPv6_ADDRESS_OLD=${_IPv6_ADDRESS_OLD}
fi
fi
if [ "${IPv6_ADDRESS_OLD,,}" = "none" ];then
_set_IPv6=false
break
fi
if ! is_valid_ipv6 $IPv6_ADDRESS_OLD ; then
echo -e "\n\tXX\033[33m\033[1m$IPv6_ADDRESS_OLD\033[mXX is NOT a valid IPv6 Address\n"
IPv6_ADDRESS_OLD=""
continue
fi
done
if $_set_ipv6 ; then
echo ""
echo -e "\033[32m--\033[m"
echo ""
echo "Insert IPv6-Address iof the new munin server"
echo ""
IPv6_ADDRESS_NEW=
while [ "X$IPv6_ADDRESS_NEW" = "X" ]; do
if [[ -z "${_IPv6_ADDRESS_NEW}" ]]; then
echononl "New IPv6-Address: "
read IPv6_ADDRESS_NEW
## - To lower case
IPv6_ADDRESS_NEW=${IPv6_ADDRESS_NEW,,}
if [ "X$IPv6_ADDRESS_NEW" = "X" ]; then
echo -e "\n\t\033[33m\033[1mAn entry is required!\033[m\n"
IPv6_ADDRESS_NEW=""
continue
fi
else
echononl "New IPv6-Address [${_IPv6_ADDRESS_NEW}]: "
read IPv6_ADDRESS_NEW
## - To lower case
IPv6_ADDRESS_NEW=${IPv6_ADDRESS_NEW,,}
if [[ -z "$(trim ${IPv6_ADDRESS_NEW})" ]]; then
IPv6_ADDRESS_NEW=${_IPv6_ADDRESS_NEW}
fi
fi
if ! is_valid_ipv6 $IPv6_ADDRESS_NEW ; then
echo -e "\n\t\033[33m\033[1m$IPv6_ADDRESS_NEW\033[m is NOT a valid IPv6 Address\n"
IPv6_ADDRESS_NEW=""
continue
fi
done
fi
fi
if ${terminal} ; then
clear
echo ""
echo ""
echo -e "\033[14G\033[32mReplace IP-Address(es) for munin server\033[m"
echo ""
if $_set_ipv4 ; then
echo " Old IPv4 Address...........................: $IPv4_ADDRESS_OLD"
echo " New IPv4 Address...........................: $IPv4_ADDRESS_NEW"
else
echo -e " IPv4 Address(es)...........................: \033[33mNone\033[m"
fi
echo ""
if $_set_ipv6 ; then
echo " Old IPv6 Address...........................: $IPv6_ADDRESS_OLD"
echo " New IPv6 Address...........................: $IPv6_ADDRESS_NEW"
else
echo -e " IPv6 Address(es)........................: \033[33mNone\033[m"
fi
echo ""
echo -e " Munin Node configuration file..............: \033[33m${MUNIN_CONF_FILE}\033[m"
echo -e " ipt firewall main IPv4 file................: \033[33m${IPT_FIREWALL_MAIN_IPV4_FILE}\033[m"
echo -e " ipt firewall main IPv6 file................: \033[33m${IPT_FIREWALL_MAIN_IPV6_FILE}\033[m"
if ! ${BATCH_MODE} ; then
blank_line
OK=
while [ "$OK" != "yes" -o "$OK" != "no" ] ; do
echononl "Parameters ok? [yes/no]: "
read OK
## - To lower case
OK=${OK,,}
if [ "X$OK" = "X" ]; then
echo -e "\n\t\033[33m\033[1mAn entry is required!\033[m\n"
OK=""
continue
fi
if [ "$OK" != "yes" -o "$OK" != "no" ] ; then
break
fi
echo -e "\n\t\033[33m\033[1mWrong entry!\033[m\n"
done
[[ $OK = "yes" ]] || fatal Repeat execution with different parameters
fi
fi
blank_line
blank_line
echononl " Replace ${IPv4_ADDRESS_OLD} in file '${MUNIN_CONF_FILE}'.."
if [[ -f "${MUNIN_CONF_FILE}" ]] ; then
if $(grep -q "${IPv4_ADDRESS_OLD}" "${MUNIN_CONF_FILE}" 2> /dev/null) ; then
perl -i -n -p -e "s#${IPv4_ADDRESS_OLD}#${IPv4_ADDRESS_NEW}#g" "${MUNIN_CONF_FILE}" > /dev/null 2>&1
if [[ $? -gt 0 ]]; then
echo_failed
else
echo_ok
fi
else
echo_skipped
fi
else
echo_skipped
fi
echononl " Replace ${IPv6_ADDRESS_OLD} in file '${MUNIN_CONF_FILE}'.."
if [[ -f "${MUNIN_CONF_FILE}" ]] ; then
if $(grep -q "${IPv6_ADDRESS_OLD}" "${MUNIN_CONF_FILE}" 2> /dev/null) ; then
perl -i -n -p -e "s#${IPv6_ADDRESS_OLD}#${IPv6_ADDRESS_NEW}#g" "${MUNIN_CONF_FILE}" > /dev/null 2>&1
if [[ $? -gt 0 ]]; then
echo_failed
else
echo_ok
fi
else
echo_skipped
fi
else
echo_skipped
fi
echononl " Replace ${IPv4_ADDRESS_OLD} in file '${IPT_FIREWALL_MAIN_IPV4_FILE}'.."
if [[ -f "${IPT_FIREWALL_MAIN_IPV4_FILE}" ]] ; then
if $(grep -q -E "munin_remote_ip=\"?${IPv4_ADDRESS_OLD}\"?" "${IPT_FIREWALL_MAIN_IPV4_FILE}" 2> /dev/null) ; then
perl -i -n -p -e "s#munin_remote_ip=\"?${IPv4_ADDRESS_OLD}\"?#munin_remote_ip=\"${IPv4_ADDRESS_NEW}\"#g" "${IPT_FIREWALL_MAIN_IPV4_FILE}" > /dev/null 2>&1
if [[ $? -gt 0 ]]; then
echo_failed
else
echo_ok
fi
else
echo_skipped
fi
else
echo_skipped
fi
echononl " Replace ${IPv6_ADDRESS_OLD} in file '${IPT_FIREWALL_MAIN_IPV6_FILE}'.."
if [[ -f "${IPT_FIREWALL_MAIN_IPV6_FILE}" ]] ; then
if $(grep -q -E "munin_remote_ip=\"?${IPv6_ADDRESS_OLD}\"?" "${IPT_FIREWALL_MAIN_IPV6_FILE}" 2> /dev/null) ; then
perl -i -n -p -e "s#munin_remote_ip=\"?${IPv6_ADDRESS_OLD}\"?#munin_remote_ip=\"${IPv6_ADDRESS_NEW}\"#g" "${IPT_FIREWALL_MAIN_IPV6_FILE}" > /dev/null 2>&1
if [[ $? -gt 0 ]]; then
echo_failed
else
echo_ok
fi
else
echo_skipped
fi
else
echo_skipped
fi
clean_up 0

415
check-disc-usage.sh Executable file
View File

@ -0,0 +1,415 @@
#!/usr/bin/env bash
# ----------
# - Some script variables (Default values other variables see below)
# ----------
script_name="$(basename $(realpath $0))"
working_dir="$(dirname $(realpath $0))"
conf_file="${working_dir}/conf/${script_name%%.*}.conf"
LOCK_DIR="/tmp/${script_name%%.*}.LOCK"
log_file="${LOCK_DIR}/${script_name%%.*}.log"
# ----------
# Base Function(s)
# ----------
usage() {
[[ -n "$1" ]] && error "$1"
[[ $terminal ]] && echo -e "
\033[1mUsage:\033[m
$(basename $0) [-c <integer>}
\033[1mDescription\033[m
Script wwarns if disk usage exceeds a given or default value (percent)
\033[1mOptions\033[m
-c <integer)
a critical value in percent. if disc usage reaches this value, a warn e-mail
to given e-mail adresse(s) will be send.
Default e-mail adresse(s):
${DEFAULT_ALERT_EMAIL_ADDRESSES}
-h
Prints this help.
\033[1mFiles\033[m
$conf_file: Configuration file
\033[1mExample:\033[m
warn if disc usage exceeds 80%
$(basename $0) -c 80
"
clean_up 1
}
clean_up() {
# Perform program exit housekeeping
rm -rf "$LOCK_DIR"
blank_line
exit $1
}
echononl(){
if $terminal ; then
echo X\\c > /tmp/shprompt$$
if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then
echo -e -n " $*\\c" 1>&2
else
echo -e -n " $*" 1>&2
fi
rm /tmp/shprompt$$
fi
}
fatal(){
echo ""
if $terminal ; then
echo -e " [ \033[31m\033[1mFatal\033[m ]: $*"
echo ""
echo -e " \033[31m\033[1mScript was interupted\033[m!"
else
echo " [ Fatal ]: $*"
echo ""
echo " Script was terminated...."
fi
echo ""
clean_up 1
}
error (){
echo ""
if $terminal ; then
echo -e " [ \033[31m\033[1mError\033[m ]: $*"
else
echo "[ Error ]: $*"
fi
echo ""
}
warn (){
echo ""
if $terminal ; then
echo -e " [ \033[33m\033[1mWarning\033[m ]: $*"
else
echo "[ Warning ]: $*"
fi
echo ""
}
warn_only_terminal () {
if $terminal ; then
echo ""
echo -e " [ \033[33m\033[1mWarning\033[m ]: $*"
echo ""
fi
}
info (){
if $terminal ; then
echo ""
echo -e " [ \033[32m\033[1mInfo\033[m ] $*"
echo ""
fi
}
ok (){
if $terminal ; then
echo ""
echo -e " [ \033[32m\033[1mOk\033[m ] $*"
echo ""
fi
}
echo_done() {
if $terminal ; then
echo -e "\033[75G[ \033[32mdone\033[m ]"
fi
}
echo_ok() {
if $terminal ; then
echo -e "\033[75G[ \033[32mok\033[m ]"
fi
}
echo_warn() {
if $terminal ; then
echo -e "\033[75G[ \033[33mwarn\033[m ]"
fi
}
echo_failed(){
if $terminal ; then
echo -e "\033[75G[ \033[1;31mfailed\033[m ]"
fi
}
echo_skipped() {
if $terminal ; then
echo -e "\033[75G[ \033[90m\033[1mskipped\033[m ]"
fi
}
echo_wait(){
if $terminal ; then
echo -en "\033[75G[ \033[5m\033[1m...\033[m ]"
fi
}
trim() {
local var="$*"
var="${var#"${var%%[![:space:]]*}"}" # remove leading whitespace characters
var="${var%"${var##*[![:space:]]}"}" # remove trailing whitespace characters
echo -n "$var"
}
blank_line() {
if $terminal ; then
echo ""
fi
}
is_number() {
return $(test ! -z "${1##*[!0-9]*}" > /dev/null 2>&1);
# - also possible
# -
i#[[ ! -z "${1##*[!0-9]*}" ]] && return 0 || return 1
#retuon $([[ ! -z "${1##*[!0-9]*}" ]])
}
# ----------
# - Some checks ..
# ----------
# - Running in a terminal?
# -
if [[ -t 1 ]] ; then
terminal=true
else
terminal=false
fi
# ==========
# - Begin Main Script
# ==========
# ----------
# - Headline
# ----------
if $terminal ; then
clear
echo ""
echo -e "\033[1m----------\033[m"
echo -e "\033[32m\033[1mRunning script \033[m\033[1m$script_name\033[32m .. \033[m"
echo -e "\033[1m----------\033[m"
fi
# ----------
# Read Configurations from $conf_file
# ----------
# - Give your default values here
# -
DEFAULT_ADMIN_EMAIL="argus@oopen.de"
DEFAULT_COMPANY="O.OPEN"
DEFAULT_CONTENT_TYPE='Content-Type: text/plain;\n charset="utf-8"'
DEFAULT_SENDER_ADDRESS="${script_name%%.*}@$(hostname -f)"
DEFAULT_ALERT_EMAIL_ADDRESSES="ckubu@oopen.de"
DEFAULT_WARN_VALUE=85%
# - Print help?
# -
if [[ "$(trim $*)" = "--help" ]] || [[ "$(trim $*)" = "-help" ]] || [[ "$(trim $*)" = "help" ]] ; then
usage
fi
if [[ -f "$conf_file" ]]; then
source "$conf_file"
else
warn_only_terminal "No configuration file '$conf_file' present.\n
Loading default values.."
fi
[[ -n "${WARN_VALUE}" ]] || WARN_VALUE="${DEFAULT_WARN_VALUE}"
[[ -n "${ADMIN_EMAIL}" ]] || ADMIN_EMAIL="${DEFAULT_ADMIN_EMAIL}"
[[ -n "${COMPANY}" ]] || COMPANY="${DEFAULT_COMPANY}"
[[ -n "${ALERT_EMAIL_ADDRESSES}" ]] || ALERT_EMAIL_ADDRESSES="${DEFAULT_ALERT_EMAIL_ADDRESSES}"
[[ -n "${CONTENT_TYPE}" ]] || CONTENT_TYPE="${DEFAULT_CONTENT_TYPE}"
[[ -n "${SENDER_ADDRESS}" ]] || SENDER_ADDRESS="${DEFAULT_SENDER_ADDRESS}"
WARN_VALUE="${WARN_VALUE%\%}"
if ! $(is_number ${WARN_VALUE}) ; then
fatal "Given value for \033[1mWARN_VALUE\033[m (\033[1m${WARN_VALUE}\033[m) isn't a number!"
fi
SUBJECT="[ Warning ] Hard disk storage on $(hostname -f) exceeds ${WARN_VALUE}%"
# ----------
# - Read commandline parameter
# ----------
while getopts c:h opt ; do
case $opt in
c) WARN_VALUE="${OPTARG}"
WARN_VALUE="${WARN_VALUE%\%}"
;;
h) usage
;;
\?) usage ;;
esac
done
# - Commandline parameter overwrites those given at configuration file
# -
if ! $(is_number ${WARN_VALUE}) ; then
fatal "Given value for \033[1mWARN_VALUE\033[m at commandline option \033[1m-c\033[m (\033[1m${WARN_VALUE}\033[m) isn't a number!"
fi
if [[ -n "$(trim ${ALERT_EMAIL_ADDRESSES})" ]] ; then
for _email in $ALERT_EMAIL_ADDRESSES ; do
alert_email_arr+=("$_email")
done
fi
# ----------
# - Jobhandling
# ----------
# - If job already runs, stop execution..
# -
if mkdir "$LOCK_DIR" 2> /dev/null ; then
## - Remove lockdir when the script finishes, or when it receives a signal
trap "clean_up 1" SIGHUP SIGINT SIGTERM
else
datum="$(date +"%d.%m.%Y %H:%M")"
msg="[ Error ]: A previos instance of \"`basename $0`\" seems already be running.\n\n Exiting now.."
echo ""
echo "[ Error ]: A previos instance of that script \"`basename $0`\" seems already be running."
echo ""
echo -e " Exiting now.."
echo ""
echo -e "To:${ADMIN_EMAIL}\n${CONTENT_TYPE}\nSubject:Error cronjob `basename $0` -- $datum\n${msg}\n" \
| sendmail -F "Error `hostname -f`" -f ${SENDER_ADDRESS} ${ADMIN_EMAIL}
exit 1
fi
blank_line
msg=""
found=false
while IFS='' read -r _line || [[ -n $_line ]] ; do
read -ra _addr <<< "$_line"
_device="${_addr[1]}"
_dir="${_addr[2]}"
_tmp_percent="${_addr[0]}"
declare -i _percent="${_tmp_percent%\%}"
if [[ ${_percent} -gt ${WARN_VALUE} ]] ; then
#echo -e "\033[3G${_device}\033[15G -> ${_dir}\033[25G ${_percent}%"
if [[ -z "${msg}" ]]; then
msg="\n The hard disk space on Device '${_device}' mounted at '${_dir}' is '${_percent}'% full!\n"
else
msg+="\n The hard disk space on Device '${_device}' mounted at '${_dir}' is '${_percent}'% full!\n"
fi
if ! ${found} && ${terminal} ; then
echo -e " Host: \033[1m$(hostname -f)\033[m"
fi
warn_only_terminal "The hard disk space on Device \033[1m${_device}\033[m mounted at \033[1m${_dir}\033[m is \033[1;31m${_percent}% full!\033[m"
found=true
fi
done < <(df -H | grep -vE '^Dateisystem|Filesystem|tmpfs|cdrom|loop|udev' | awk '{ print $5 " " $1 " " $6 }')
if $found ; then
if $(which lxc-ls > /dev/null) ; then
_guest_machines="$(lxc-ls)"
if [[ ${#_guest_machines} -gt 0 ]]; then
if ${terminal}; then
echo -e " LX Guest Systems:"
fi
msg_guests="LX Guest Systems:"
for _name in ${_guest_machines} ; do
_state="$(lxc-info -n ${_name} | grep -i 'State:' | awk '{print$2}')"
msg_guests="${msg_guests}\n (${_state}:) ${_name}"
if ${terminal}; then
echo -e " (${_state}:) ${_name}"
fi
done
fi # if [[ ${#_guest_machines} -gt 0 ]]
fi # if $(which lxc-ls > /dev/null)
SUBJECT="[ Warning ] Hard disk usage (${_percent}%) on $(hostname -f) exceeds ${WARN_VALUE}%"
SUBJECT_UTF8="$(echo "${SUBJECT}" | iconv -t UTF8)"
SUBJECT_UTF8_ENCODED="=?utf-8?B?$(echo ${SUBJECT_UTF8} | base64 --wrap=0)?="
for _email in ${alert_email_arr[@]} ; do
echo -e "To:${_email}\n${CONTENT_TYPE}\nSubject:${SUBJECT_UTF8_ENCODED}\n\nHost: $(hostname -f)\n${msg}\n${msg_guests}" | /usr/sbin/sendmail -F "${COMPANY} -- hard disk usage" -f ${SENDER_ADDRESS} ${_email}
done
else
info "Harddisk usage on host \033[1m$(hostname -f)\033[m is fine."
fi
clean_up 0

View File

@ -0,0 +1,56 @@
# -------------------------------------------
# - Settings for script check-connectivity.sh
# -------------------------------------------
# IPv4_ADDRESS_OLD
#
# Example:
# IPv4_ADDRESS_OLD=135.181.136.84
#
#IPv4_ADDRESS_OLD=
# IPv4_ADDRESS_NEW
#
# Example:
# IPv4_ADDRESS_NEW=37.27.121.227
#
#IPv4_ADDRESS_NEW=
# IPv6_ADDRESS_OLD
#
# Example:
# IPv6_ADDRESS_OLD='2a01:4f9:3a:1051::84'
#
# IPv6_ADDRESS_OLD
# IPv6_ADDRESS_NEW
#
# Example:
# IPv6_ADDRESS_NEW='2a01:4f9:3070:2bda::227'
#
#IPv6_ADDRESS_NEW=
# MUNIN_CONF_FILE
#
# Defaults to: /etc/munin/munin-node.conf
#
#MUNIN_CONF_FILE='/etc/munin/munin-node.conf'
# IPT_FIREWALL_MAIN_IPV4_FILE
#
# Defaults to: /etc/ipt-firewall/main_ipv4.conf
#
#IPT_FIREWALL_MAIN_IPV4_FILE='/etc/ipt-firewall/main_ipv4.conf'
# IPT_FIREWALL_MAIN_IPV6_FILE
#
#Defaults to: /etc/ipt-firewall/main_ipv6.conf
#
#IPT_FIREWALL_MAIN_IPV6_FILE='/etc/ipt-firewall/main_ipv6.conf'

View File

@ -0,0 +1,49 @@
# -----------------------------------------
# - Settings for script check-disk-usage.sh
# -----------------------------------------
# - WARN_VALUE
# -
# - warn if if the hard disk usage has reached this value.
# -
# - Defaults to: WARN_VALUE=80
# -
#WARN_VALUE=80
# - COMPANY
# -
# - Defaults to: COMPANY="O.OPEN"
# -
#COMPANY="O.OPEN"
# ---
# Alert E-Mail stuff
# ---
# - ADMIN_EMAIL
# -
# - Defaults to: ADMIN_EMAIL="argus@oopen.de"
# -
#ADMIN_EMAIL="argus@oopen.de"
# - ALERT_EMAIL_ADDRESSES
# -
# - Blank separated liost of e-mail adresses you want to inform
# - about to high disk usage
# -
# - Defaults to an empty string: ALERT_EMAIL_ADDRESSES="ckubu@oopen.de"
# -
#ALERT_EMAIL_ADDRESSES="ckubu@oopen.de"
# - CONTENT_TYPE
# -
# - Defaults to: CONTENT_TYPE='Content-Type: text/plain;\n charset="utf-8"'
# -
#CONTENT_TYPE='Content-Type: text/plain;\n charset="utf-8"'
# - SENDER_ADDRESS
# -
# - Defaults to: SENDER_ADDRESS="${script_name%%.*}@$(hostname -f)"
# -
#SENDER_ADDRESS="${script_name%%.*}@$(hostname -f)"

23
create-rsyslogd-postfix.sh Executable file
View File

@ -0,0 +1,23 @@
#!/usr/bin/env bash
if [[ -f "/etc/rsyslog.d/postfix.conf" ]] ; then
cat << EOF > /etc/rsyslog.d/postfix.conf
# Create an additional socket in postfix's chroot in order not to break
# mail logging when rsyslog is restarted. If the directory is missing,
# rsyslog will silently skip creating the socket.
\$AddUnixListenSocket /var/spool/postfix/dev/log
#
# Logging for the mail system. Split it up so that
# it is easy to write scripts to parse these files.
#
#mail.info -/var/log/mail.info
#mail.warn -/var/log/mail.warn
#mail.err /var/log/mail.err
mail.* -/var/log/mail.log
& stop
EOF
fi
exit 0

62
create_change_munin_ip.conf.sh Executable file
View File

@ -0,0 +1,62 @@
#!/usr/bin/env bash
cat <<EOF > /root/bin/admin-stuff/conf/change_munin_ip.conf
# -------------------------------------------
# - Settings for script check-connectivity.sh
# -------------------------------------------
# IPv4_ADDRESS_OLD
#
# Example:
# IPv4_ADDRESS_OLD=135.181.136.84
#
#IPv4_ADDRESS_OLD=
IPv4_ADDRESS_OLD=135.181.136.84
# IPv4_ADDRESS_NEW
#
# Example:
# IPv4_ADDRESS_NEW=37.27.121.227
#
#IPv4_ADDRESS_NEW=
IPv4_ADDRESS_NEW=37.27.121.227
# IPv6_ADDRESS_OLD
#
# Example:
# IPv6_ADDRESS_OLD='2a01:4f9:3a:1051::84'
#
# IPv6_ADDRESS_OLD
IPv6_ADDRESS_OLD='2a01:4f9:3a:1051::84'
# IPv6_ADDRESS_NEW
#
# Example:
# IPv6_ADDRESS_NEW='2a01:4f9:3070:2bda::227'
#
#IPv6_ADDRESS_NEW=
IPv6_ADDRESS_NEW='2a01:4f9:3070:2bda::227'
# MUNIN_CONF_FILE
#
# Defaults to: /etc/munin/munin-node.conf
#
#MUNIN_CONF_FILE='/etc/munin/munin-node.conf'
# IPT_FIREWALL_MAIN_IPV4_FILE
#
# Defaults to: /etc/ipt-firewall/main_ipv4.conf
#
#IPT_FIREWALL_MAIN_IPV4_FILE='/etc/ipt-firewall/main_ipv4.conf'
# IPT_FIREWALL_MAIN_IPV6_FILE
#
#Defaults to: /etc/ipt-firewall/main_ipv6.conf
#
#IPT_FIREWALL_MAIN_IPV6_FILE='/etc/ipt-firewall/main_ipv6.conf'
EOF

View File

@ -1,5 +1,174 @@
#!/usr/bin/env bash #!/usr/bin/env bash
script_name="$(basename $(realpath $0))"
working_dir="$(dirname $(realpath $0))"
conf_file="${working_dir}/conf/${script_name%%.*}.conf"
log_file="$(mktemp)"
random_prefix="$(head -c 300 /dev/urandom | tr -cd 'a-zA-Z0-9' | head -c 8)"
backup_date=$(date +%Y-%m-%d-%H%M)
# =============
# --- Some Variables
# =============
declare -a lx_container_arr=()
declare -a lx_running_container_arr=()
# =============
# --- Some Functions
# =============
clean_up() {
if [[ -f "$_backup_crontab_file" ]]; then
blank_line
echononl " (Re)Install Crontab from previously saved crontab file
'$_backup_crontab_file'.."
crontab $_backup_crontab_file >> $log_file 2>&1
if [[ $? -eq 0 ]]; then
echo_ok
else
echo_failed
error "$(cat $log_file)"
fi
fi
# Perform program exit housekeeping
rm -f $log_file
rm -rf /tmp/*.${random_prefix}
blank_line
exit $1
}
echononl(){
if $terminal ; then
echo X\\c > /tmp/shprompt$$
if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then
echo -e -n "[ \033[5m\033[1m....\033[m ]\033[13G$*\\c" 1>&2
else
echo -e -n "[ \033[5m\033[1m....\033[m ]\033[13G$*" 1>&2
fi
rm /tmp/shprompt$$
fi
}
echo_print_command() {
if $terminal ; then
echo X\\c > /tmp/shprompt$$
if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then
echo -e -n "\n\033[13G\033[1m$*\\c\033[m" 1>&2
else
echo -e -n "\n\033[13G\033[1m$*\033[m" 1>&2
fi
rm /tmp/shprompt$$
fi
}
echo_done() {
if $terminal ; then
echo -e "\033[1G[ \033[1;32mdone\033[m ]"
fi
}
echo_ok() {
if $terminal ; then
echo -e "\033[1G[ \033[1;32mok\033[m ]"
fi
}
echo_ignore() {
if $terminal ; then
echo -e "\033[1G[ \033[1;33mignore\033[m ]"
fi
}
echo_warning() {
if $terminal ; then
echo -e "\033[1G[ \033[1;33m\033[1mwarn\033[m ]"
fi
}
echo_failed(){
if $terminal ; then
echo -e "\033[1G[ \033[1;31mfail\033[m ]"
fi
}
echo_skipped() {
if $terminal ; then
echo -e "\033[1G[ \033[1;37mskip\033[m ]"
fi
}
echo_wait(){
if $terminal ; then
echo -en "\033[1G[ \033[5m\033[1m...\033[m ]"
fi
}
fatal (){
blank_line
if $terminal ; then
echo -e "[ \033[31m\033[1mFatal\033[m ] \033[13G\033[37m\033[1m$*\033[m"
echo ""
echo -e " \033[13G\033[31m\033[1mScript will be interrupted..\033[m\033[m"
else
echo "fatal: $*"
echo "Script will be interrupted.."
fi
clean_up 1
}
error(){
blank_line
if $terminal ; then
echo -e "[ \033[31m\033[1mFehler\033[m ]\033[13G$*"
else
echo ""
echo "[ Error ]: $*"
echo ""
fi
blank_line
}
warn (){
if $terminal ; then
echo ""
echo -e "[ \033[33m\033[1mWarning\033[m ]\033[13G$*"
echo ""
fi
}
info (){
if $terminal ; then
echo ""
echo -e "[ \033[32m\033[1mInfo\033[m ]\033[13G$*"
echo ""
fi
}
## - Check if a given array (parameter 2) contains a given string (parameter 1)
## -
containsElement () {
local e
for e in "${@:2}"; do [[ "$e" == "$1" ]] && return 0; done
return 1
}
trim() {
local var="$*"
var="${var#"${var%%[![:space:]]*}"}" # remove leading whitespace characters
var="${var%"${var##*[![:space:]]}"}" # remove trailing whitespace characters
echo -n "$var"
}
blank_line() {
if $terminal ; then
echo ""
fi
}
usage() { usage() {
if [ -n "$1" ];then if [ -n "$1" ];then
echo -e "\n [ Error ]: $1" echo -e "\n [ Error ]: $1"
@ -15,7 +184,7 @@ cat<<EOF
EOF EOF
exit 1 clean_up 1
} }
isValidDate() { isValidDate() {
@ -48,6 +217,31 @@ isValidDate() {
fi fi
} }
# =============
# --- Jobhandling
# =============
# - Run 'clean_up' for signals SIGHUP SIGINT SIGTERM
# -
trap clean_up SIGHUP SIGINT SIGTERM
# =============
# --- Some Checks
# =============
# - Running in a terminal?
# -
if [[ -t 1 ]] ; then
terminal=true
else
terminal=false
fi
[ $# -ne "1" ] && usage "Wrong number of arguments" [ $# -ne "1" ] && usage "Wrong number of arguments"
_date=$1 _date=$1
@ -62,6 +256,114 @@ if ! isValidDate "${__day}-${__month}-${__year}" ; then
usage "Invalid date: ${_date}" usage "Invalid date: ${_date}"
fi fi
[[ "$(/bin/date +%Y-%m-%d)" == "$_date" ]] && /sbin/poweroff
# ==========
# - Begin Main Script
# ==========
# ----------
# - Headline
# ----------
if $terminal ; then
echo ""
echo -e "\033[1m----------\033[m"
echo -e "\033[32m\033[1mRunning script \033[m\033[1m$script_name\033[32m .. \033[m"
echo -e "\033[1m----------\033[m"
echo ""
fi
if [[ "$(/bin/date +%Y-%m-%d)" != "$_date" ]] ; then
info "Shutdown Date \\033[1m${_date} \033[mis NOT today. So nothing to do.."
clean_up 1
fi
if $(dpkg -l 2> /dev/null | grep -q "lxc" 2> /dev/null) \
|| $(systemctl list-unit-files | grep -q "lxc"); then
echononl "Get List of \033[1mall existing\033[m LX Contaoner.."
_failed=false
for _container in $(lxc-ls) ; do
lx_container_arr+=("$_container")
[[ $? -gt 0 ]] && _falied=true
done
if $_failed ; then
echo_failed
fatal "Getting list of \033[1mall\033[m LX-Container failed!"
else
echo_done
fi
_failed=false
echononl "Get List of \033[1mrunning\033[m LX Contaoner.."
for _container in $(lxc-ls --running) ; do
lx_running_container_arr+=("$_container")
[[ $? -gt 0 ]] && _falied=true
done
if $_failed ; then
echo_failed
fatal "Getting list of \033[1mrunning\033[m LX-Container failed!"
else
echo_done
fi
if [[ ${#lx_container_arr[@]} -gt 0 ]]; then
for _lx_container in "${lx_container_arr[@]}" ; do
echononl "Stopping Container ${_lx_container}.."
if containsElement "$_lx_container" "${lx_running_container_arr[@]}" ; then
lxc-stop -n ${_lx_container} > $log_file 2>&1
if [[ $? -gt 0 ]]; then
echo_failed
fatal "$(cat $log_file)"
else
echo_done
fi
else
echo_skipped
fi
done
fi
else
info "NO LX Container on this Host"
fi
if $terminal ; then
echo ""
echo ""
echo -e "\033[13G\033[1mGoing to power off the system ..\033[m"
echo ""
else
from_address="power-off@$(hostname -f)"
to_address="root"
content_type='Content-Type: text/plain;\n charset="utf-8"'
subject="Power OFF System $(hostname -f).."
msg=" Going to power off system '$(hostname -f)' .."
echo -e "To:${to_address}\n${content_type}\nSubject:$subject\n\n${msg}\n" \
| /usr/sbin/sendmail -F "Webservice Monitor" -f $from_address $to_address
fi
/sbin/poweroff
exit 0 exit 0

View File

@ -1,8 +1,2 @@
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDinfnbnVooKT0iFpkZeRZMj8JpYJk+EkgGHyK2xhb0HNoYvDoG06Clckm0vauuRlSYnWkZC0dLIbqHlACA
+jbCKa2w/5yOjCXmJiJEO04YCMhkQH08It+wpWZb/Bx2O6DB3cY+3mHwPocp/la8caYW4NIE5+67AnHxIQifJLXM44TgkmFEhXSBMIZj8b8wL+MA0zKD0LXw
gEH9Wllcccq6D5lfsrUSLvTRHq362pE+ZtVXh2peVkS4r98HNtYVUjBMgOIIPEypopceUzXC0L+vB7s2SolAsh3CGjqyjYW8x3fWnAewlfa5TbgIC+11e+KJ
KFr5+tVfwSgHC+TtfuXDU5Ws80ETejbuwx2iRVfHG0fDcjPzaVUXGmY+j8OR4jACz5KY5+VMJgMuXJTbZBEf1C5O3lCTaEf/Pmw50SHrshT/bhdrMBUaS+AO
TFHrI3WOu+ujWMXJK3pRdROXDFDtPfc1afaJkMuKO5Uay/qwTEKd8NwXNoAGkXjowKBerNgJRy5JwhmbHMA6xsCDEjXMVy+yiMw+58JE76g5HVVu7dpyz0bj
XD3LrpB+lclQHRLxNajWAjVsAu/eI2zQDDS7YHi1IZVUGdYD0g0qXdeNQ//KA7FVr22VFUP8xtbseZfOZpKFGVEMVkIOcYHZoYhOYxZDVNNmvle13F4PU1zO
iQ== c3po@riseup.net
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDinfnbnVooKT0iFpkZeRZMj8JpYJk+EkgGHyK2xhb0HNoYvDoG06Clckm0vauuRlSYnWkZC0dLIbqHlACA+jbCKa2w/5yOjCXmJiJEO04YCMhkQH08It+wpWZb/Bx2O6DB3cY+3mHwPocp/la8caYW4NIE5+67AnHxIQifJLXM44TgkmFEhXSBMIZj8b8wL+MA0zKD0LXwgEH9Wllcccq6D5lfsrUSLvTRHq362pE+ZtVXh2peVkS4r98HNtYVUjBMgOIIPEypopceUzXC0L+vB7s2SolAsh3CGjqyjYW8x3fWnAewlfa5TbgIC+11e+KJKFr5+tVfwSgHC+TtfuXDU5Ws80ETejbuwx2iRVfHG0fDcjPzaVUXGmY+j8OR4jACz5KY5+VMJgMuXJTbZBEf1C5O3lCTaEf/Pmw50SHrshT/bhdrMBUaS+AOTFHrI3WOu+ujWMXJK3pRdROXDFDtPfc1afaJkMuKO5Uay/qwTEKd8NwXNoAGkXjowKBerNgJRy5JwhmbHMA6xsCDEjXMVy+yiMw+58JE76g5HVVu7dpyz0bjXD3LrpB+lclQHRLxNajWAjVsAu/eI2zQDDS7YHi1IZVUGdYD0g0qXdeNQ//KA7FVr22VFUP8xtbseZfOZpKFGVEMVkIOcYHZoYhOYxZDVNNmvle13F4PU1zOiQ== c3po@riseup.net

View File

@ -0,0 +1,2 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDqi25sXeJHJ/TtRTJwrApyJGmIKynlOvTo8idRHvzWkvfNoLaK4NCjikARfAQtCUyLlfRsz8QvYgx1Oj6eqsaHcJTMs3Gn0Ewnj1mb1U1jmTn8PAz6beULBevcS84z40gH9GoGy+a23tmboSTA2yxmze5oEuFtkqY7kQMQ62kmmSKAG4yWbXK7EWjhbd6PlWv4DnHivOOqI/9X1m8StAYqixgzetSk4kpvFrJaQV96mfL+2FBATD6ykBEsb/Pnd/VW6DBjqGW+SkmAZo6TPsTlGt4sqt8ukcX38g+0Hng4s7ykfLW3np9BsxJkiOZIjRj9odPPB6K9yhtg3qoX+o2qhrE+lf4+QaUJpzWnO4gux7SijHS2/hIIrUfUEQSc8bLBzHp/JsgyYWfPkZ8r/miSfLTAz3U8mTb51qkg06msQ/srPNYIOJqmVOKhXe/sL/pAeBxCQVT2V1pU1sWti91yyXYP3Uhjkx32jidk3PjWm/jIL+MzBdEzdc4yD4+rB82z4LOyooXRe0wcAOLLRgvoBH0RIvz9/Ixa6OPFGDS8NUuqMy0GMJ8WZ6inc6YsUm5IpH7HWgse66cY6pkhzOyug9uKYaXaBNyPbaDmiXYJi+yRs3YBSrt8rU6M7/IjD/5GVfpQ1ZXXLevqpupH+JtayBrvRVzJkQ/kOpeGQUXhww== dolphin

View File

@ -0,0 +1,2 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDrkNmAz0sS8nmVCsw12nZqr8z86sifGSVfR1skzdXoE+gHwiaB0vIuCEvcANqnAILe3de/CLnBz72xLAfGCMzlHZNXusaUUuGPC/VbF0FwIwYj2i6JA0fVYAx9cS2iQJGdc6Iwfr31P/5mrrZTN+L1zlFTPC82H/c22GC8CMvCm72wZLuinwTreKZ32bzk3zXijM1b2dFZfUyPKgzvRRiys7DQwnHfQYhf2qq9k6+GtBdKJCnru58v+B0lHNszJiRaHts5BsO1yPYgJ5cIFadmnhwnQ6XuXydjV8ooK6hdtURfI5BAzC/adQQK2i8eHX4X4u2sEz2MlmkxDUNdgzQVc2yyeNBkXRqYRKU8H8/ioyWj10FfhF/YPsWYWLyx40uO+73kgiSyHo1ZctMrFDfbDBVUuAf1OKixqSfCz+mETziONqUvkBngbMNAVkIwvvKmQtklhR4ogrQ665kZ2r9BaJK7eEJXWGB0m7aTgdLgeKF1HKzyjdWxtBjFicNAE0Af8Nu0kI7FNjx96srkxpWC8ZxSDmh1aGBlw4CcOLB+XHqr89wmI7RpkTrZfsLpuvD2u2G/3ONLN8jaw6sGuTP9lG0oScY+oZrDJsFvC6u1mTy7n4+QwkOR6ZnvlJ7CYVUlHMMccHfZI9pqXM9TZSDbgU3YHGPzpCJNkNucobM2pw== chemo@mailbox.org

View File

@ -0,0 +1,2 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-rsa AAAAB3NzaC1yc2EAAAABJQAAAgEAhXpLxU+TcMf/0ETcjQg/RqhqhEm0BivB/O1oN+7IVcmPjpBYBBySFgt48v+SGxhQ8Yh0vEmwx0QRHf/JtbA7dKI94rn1heQeXewMvLOAjOsElTNEMlO1f5VPMUUeDib7QPzHOym4COKMpjP2Gefwh2q9RKu61sJ/pRGMolzqgu5OJbMDWOtBwSiTZJrvHsp/mIlkEmXER5jLcJEWUab9tGtoddCKzg2z3gI0Zewy90+IJa72xVTbgAtDfV/htc+g4MhoiGadWWOIanrJtsZj1cAcYuPCfEKgGbK9ZK3+V/utliLxW5S8lLRO3UJcJ9XTxO0GV76rpiE68Tnu2L6fiju9ek3AOg3Sf3f5QnR1jIVyGEqFMk/RnDceHAgOGLpDHLy1W6r7ljmLk2HNvDhuo4lqbgrr6MAgBchHxne8G/jp33Dmzfac2qboWGaAth1jHsAcKe4Eo5TzjXUu0yL1me6K8LH+cRn0G3+CO+TR04ZIriDFUMcTFFiOjK0bRoPBX//a0UEDIjnoW2keqdImlQ7yTOc9t1XLLkGIfTcu3ik9hSTZwc5j+7njx47qQJcNdEjhM6gOBHNr2GJe4m8An1bsL+SWVVTjYKxW0BT/Scd1j8EJwHgPWcEVVYbqSd7T6kWC933HMDz3QySAMTX17iP1/FHDsN0UdZMPf5RAzlM= rsa-key-20211122

View File

@ -0,0 +1,2 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCV9TRyzQGa3xjoqmRVEAlotUr1RK7mm1eMilJxj/XkCPmluINvkdhlMhhrCuuJVgC0jzp+BNU/KPMYQnujDE7VAVSIXA/oTDo9Q+Q+RpLytPBGntwTcVc0wE95hXx9Zy5XMPjxxThuVGZ4MrBcI+iwaEoMCvWEd7SSyjit+EBJtW5YhV3uu9TNyHptwEcQ1ZsYV0n3j9XDdo8pqh5woUC8FXF5vyumsv4rijJgCUoamDbUFBFBa12Xpj0/uIha/TogLExz96sjP76MX8UEUM+prya4KCIVYReA5s0qNYfaP+WymZxYO111NC981YW4wIhGYX74W/BWP9kAXTsXT4OLAljOxr8us0rcWUTR0+EOOhNt9QMRBOXgDmsH37HJHjiP/Ns1+HBuk2JVMhRQr3kPlHGvpu2DHYjG2oPrzxf34LKHvV+2I1YuvGM0EE/ts9PmJUS8a4eY9PrfKlAIXnPH+cmLWHz8KgA0UfUmgfBNL1bHGw4Nbh+jBr6rcFpZ3kU=

View File

@ -0,0 +1,2 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIL4wVpkMrF4M5wKBxRAonR4gVngO9+yhBEAyhV03l6Is

View File

@ -0,0 +1,3 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOQHMUKlDh2ufno5pZOhUY5xFljC1R5zQ/GjOHDkS58D root@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKTjd4XFBdF/V9VdSZjy9G7nupBwaMqsrtQSP4Uctkrz org@rdsgn.de

View File

@ -0,0 +1,4 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOQHMUKlDh2ufno5pZOhUY5xFljC1R5zQ/GjOHDkS58D root@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKTjd4XFBdF/V9VdSZjy9G7nupBwaMqsrtQSP4Uctkrz org@rdsgn.de
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIMClTmBQGPp1FFKA3n+ANJ9XuEYfR/ALXcoBVclV3eVP datenlieferung@nd-online.de

View File

@ -0,0 +1,4 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIO90culn3sicU2chTHn40ytcTay0nUIHap0uF/5fVM6P chris@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOQHMUKlDh2ufno5pZOhUY5xFljC1R5zQ/GjOHDkS58D root@sol
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKTjd4XFBdF/V9VdSZjy9G7nupBwaMqsrtQSP4Uctkrz org@rdsgn.de
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJA+YbWWoJpn6w5wsyzy3/g91nyesWoHGw9+eFdB3V9p datenlieferung@nd-online.de

View File

@ -117,7 +117,7 @@ if [[ -f "$conf_file" ]]; then
source "$conf_file" source "$conf_file"
fi fi
[[ -z "$GIT_BASE_DIRECTORIES" ]] && GIT_BASE_DIRECTORIES="/usr/local/src /root/bin" [[ -z "$GIT_BASE_DIRECTORIES" ]] && GIT_BASE_DIRECTORIES="/usr/local/src /root/bin /root/crontab"
@ -131,6 +131,9 @@ fi
for _git_base_dir in $GIT_BASE_DIRECTORIES ; do for _git_base_dir in $GIT_BASE_DIRECTORIES ; do
blank_line blank_line
[[ ! -d "${_git_base_dir}" ]] && continue
for _dir in $(ls ${_git_base_dir}/) ; do for _dir in $(ls ${_git_base_dir}/) ; do
[[ ! -d "${_git_base_dir}/$_dir" ]] && continue [[ ! -d "${_git_base_dir}/$_dir" ]] && continue
[[ ! -d "${_git_base_dir}/${_dir}/.git" ]] && continue [[ ! -d "${_git_base_dir}/${_dir}/.git" ]] && continue
@ -151,17 +154,17 @@ for _git_base_dir in $GIT_BASE_DIRECTORIES ; do
done done
done done
if [[ -d "/root/crontab/backup-rcopy" ]]; then #if [[ -d "/root/crontab/backup-rcopy" ]]; then
blank_line # blank_line
echononl "Update Repository \033[1mbackup-rcopy\033[m.." # echononl "Update Repository \033[1mbackup-rcopy\033[m.."
git -C "/root/crontab/backup-rcopy" pull > $log_file 2>&1 # git -C "/root/crontab/backup-rcopy" pull > $log_file 2>&1
if [[ $? -eq 0 ]] ; then # if [[ $? -eq 0 ]] ; then
echo_done # echo_done
else # else
echo_failed # echo_failed
error "$(cat $log_file)" # error "$(cat $log_file)"
fi # fi
fi #fi
blank_line blank_line
clean_up clean_up