#!/usr/bin/env bash script_name="$(basename $(realpath $0))" script_dir="$(dirname $(realpath $0))" conf_file="${working_dir}/conf/${script_name%%.*}.conf" tmp_err_msg="$(mktemp)" _date="$(date +%Y-%m-%d-%H%M)" #--------------------------------------- #----------------------------- # Setting Defaults #----------------------------- #--------------------------------------- DEFAULT_db_type="pgsql" DEFAULT_db_name="postfix" DEFAULT_dovecot_enc_method="SHA512-CRYPT" DEFAULT_log_file="${script_dir}/log/${script_name%%.*}.log" #--------------------------------------- #----------------------------- # Base Function(s) #----------------------------- #--------------------------------------- function usage() { echo if [ -n "$1" ];then echo -e "Error: $1\n" fi echo -e "\nSets a (given) default password for all mailboxes of a (given) domain.\n" echo -e "\tusage: `basename $0` \n" clean_up 1 } trim() { local var="$*" var="${var#"${var%%[![:space:]]*}"}" # remove leading whitespace characters var="${var%"${var##*[![:space:]]}"}" # remove trailing whitespace characters echo -n "$var" } clean_up() { # Perform program exit housekeeping exit $1 } echononl(){ echo X\\c > /tmp/shprompt$$ if [ `wc -c /tmp/shprompt$$ | awk '{print $1}'` -eq 1 ]; then echo "$*\\c" 1>&2 else echo -e -n "$*" 1>&2 fi rm /tmp/shprompt$$ } warn (){ echo "" echo -e " [ \033[33m\033[1mWarning\033[m ]: $*" echo "" } error (){ echo "" echo -e " [ \033[31m\033[1mError\033[m ]: $*" echo "" } fatal(){ echo "" echo -e "[ \033[31m\033[1mFehler\033[m ]: $*" echo -e "\n Script was interupted!\n" echo clean_up 1 } echo_ok() { echo -e "\033[75G[ \033[32mok\033[m ]" } echo_failed() { echo -e "\033[75G[ \033[1;31mfailed\033[m ]" } echo_skipped() { echo -e "\033[75G[ \033[33m\033[1mskipped\033[m ]" } trap clean_up SIGHUP SIGINT SIGTERM clear echo "" echo -e "\033[32mRunning script \033[1m"$(basename $0)"\033[m .." [ $# -eq "0" -o $# -gt "3" ] && usage "wrong number of arguments" domain="$1" passwd="$2" echo "" echo "" echononl " Loading Configuration values from $(basename ${conf_file}).." if [[ ! -f "$conf_file" ]]; then echo_skipped else source "${conf_file}" > /dev/null 2>&1 if [[ $? -eq 0 ]]; then echo_ok else echo_failed fi fi [[ -n "$db_type" ]] || db_type="$DEFAULT_db_type" if [[ "$db_type" != "pgsql" ]] && [[ "$db_type" != "mysql" ]]; then fatal "Unknown Database Type '$db_type' for Password Database (Parameter db_type)" fi if [[ "$db_type" = "mysql" ]]; then if [[ -z "$mysql_credential_args" ]]; then if [[ -f "/etc/mysql/debian.cnf" ]]; then mysql_credential_args="--defaults-file=/etc/mysql/debian.cnf" elif [[ -f "/usr/local/mysql/sys-maint.cnf" ]] ; then mysql_credential_args="--defaults-file=/usr/local/mysql/sys-maint.cnf" else fatal "No credentials for access to MySQL is given!" fi fi fi [[ -n "$db_name" ]] || db_name="$DEFAULT_db_name" [[ -n "$log_file" ]] || log_file="$DEFAULT_log_file" [[ -n "$dovecot_enc_method" ]] || dovecot_enc_method="$DEFAULT_dovecot_enc_method" if [[ "$db_type" != "pgsql" ]] && [[ "$db_type" != "mysql" ]]; then fatal "Unknown Database Type '$db_type' for Password Database (Parameter db_type)" fi echo "" echo "" echo -e "\033[32mSettings for script \033[37m\033[1m${script_name}\033[m" echo "" echo " Domain................................................: $domain" echo " Password..............................................: $passwd" echo "" echo " Passsword scheme used for encryption..................: $dovecot_enc_method" echo "" if [[ "$db_type" = "pgsql" ]] ; then echo " Type of postfix databae...............................: PostgreSQL ($db_type)" echo " Database name for the postfix DB......................: $db_name" elif [[ "$db_type" = "mysql" ]] ; then echo " Type of postfix databae...............................: MySQL ($db_type)" echo " Database name for the postfix DB......................: $db_name" echo " MySQL credential args.................................: $mysql_credential_args" fi if [[ "$db_type" = "mysql" ]] ; then echo " Type of postfix databae...............................: MySQL ($db_type)" fi echo "" OK= while [ "$OK" != "yes" -o "$OK" != "no" ] ; do echononl "\033[1mParameters ok? [yes/no]:\033[m " 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." declare -A address_arr declare -a orders declare -a mbox_arr echo "" echononl " Create log directory '$(dirname "$log_file")'.." if [[ ! -d "$(dirname "$log_file")" ]] ; then mkdir "$(dirname "$log_file")" if [[ $? -eq 0 ]]; then echo_ok else echo_failed fi else echo_skipped fi echononl " Backup existing log file.." if [ -f "$log_file" ]; then mv "$log_file" "${log_file}.${_date}" if [ "$?" = "0" ]; then echo_ok else echo_failed fi else echo_skipped fi echononl " Create log file $log_file.." touch $log_file if [ "$?" = "0" ]; then echo_ok else echo_failed fi echo "" curdir=`pwd` cd /tmp echo "[ $_date ]: Sart running script '${script_name}'" >> $log_file echo "" >> $log_file echo "Parameters" >> $log_file echo "" >> $log_file echo " Domain................................................: $domain" >> $log_file echo " Password..............................................: $passwd" >> $log_file echo "" >> $log_file echo " Passsword scheme used for encryption..................: $dovecot_enc_method" >> $log_file echo "" >> $log_file if [[ "$db_type" = "pgsql" ]] ; then echo " Type of postfix databae...............................: PostgreSQL ($db_type)" >> $log_file echo " Database name for the postfix DB......................: $db_name" >> $log_file elif [[ "$db_type" = "mysql" ]] ; then echo " Type of postfix databae...............................: MySQL ($db_type)" >> $log_file echo " Database name for the postfix DB......................: $db_name" >> $log_file echo " MySQL credential args.................................: $mysql_credential_args" >> $log_file fi echo "" >> $log_file echo "" >> $log_file # - Get all dresses of mailboxes for the given domain # - if [[ "$db_type" = "mysql" ]]; then _addresses=$(mysql $mysql_credential_args "$db_name" -N -s -e "select username from mailbox where domain = '$domain' ORDER BY username") else _addresses=$(su - postgres -c"psql "$db_name" -t -q -c\"select username from mailbox where domain = '$domain' ORDER BY username\"") fi for _address in $_addresses ; do mbox_arr+=($_address) done for i in ${!mbox_arr[@]} ; do echononl " Change Passoert for address \"${mbox_arr[$i]}\".." if [[ "$db_type" = "pgsql" ]] ; then if [[ "$dovecot_enc_method" = "PLAIN" ]]; then sudo -u postgres psql $db_name -c "\ SET client_encoding to 'UTF8'; \ UPDATE mailbox SET password = '$passwd' WHERE username = '${mbox_arr[$i]}';" > $tmp_err_msg 2>&1 else sudo -u postgres psql $db_name -c "\ SET client_encoding to 'UTF8'; \ UPDATE mailbox SET password = '$(doveadm pw -s "$dovecot_enc_method" -p "$passwd")' \ WHERE username = '${mbox_arr[$i]}';" > $tmp_err_msg 2>&1 fi elif [[ "$db_type" = "mysql" ]] ; then if [[ "$dovecot_enc_method" = "PLAIN" ]]; then $(mysql "$mysql_credential_args" "$db_name" -N -s -e" SET NAMES utf8; UPDATE mailbox SET password = '$passwd' WHERE username = '${mbox_arr[$i]}';" > $tmp_err_msg 2>&1) else $(mysql "$mysql_credential_args" "$db_name" -N -s -e" SET NAMES utf8; UPDATE mailbox SET password = '$(doveadm pw -s "$dovecot_enc_method" -p "$passwd")' \ WHERE username = '${mbox_arr[$i]}';" > $tmp_err_msg 2>&1) fi else fatal "Database type '$db_type' is not supported." fi if [ "$?" = "0" ]; then echo_ok echo " [ ok ]: Password for mailbox '${mbox_arr[$i]}' changed to '$passwd'" >> $log_file else echo_failed error "$(cat "$tmp_err_msg")" echo " [ failed ]: Changing password for mailbox '${mbox_arr[$i]}' failed" >> $log_file continue fi done echo "" clean_up 0