2016-12-30 19:06:44 +00:00
|
|
|
#! /bin/bash
|
2016-06-14 11:16:11 +00:00
|
|
|
|
2016-12-30 19:06:44 +00:00
|
|
|
DATABASE=${DATABASE:-/tmp/docker-mailserver/postfix-accounts.cf}
|
2016-06-14 11:16:11 +00:00
|
|
|
|
2016-12-30 19:06:44 +00:00
|
|
|
USER="$1"
|
2018-04-08 14:12:41 +00:00
|
|
|
shift
|
|
|
|
PASSWD="$@"
|
2016-12-30 19:06:44 +00:00
|
|
|
|
|
|
|
usage() {
|
|
|
|
echo "Usage: addmailuser <user@domain> [<password>]"
|
|
|
|
}
|
|
|
|
|
|
|
|
errex() {
|
|
|
|
echo "$@" 1>&2
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
escape() {
|
|
|
|
echo "${1//./\\.}"
|
2016-06-14 11:16:11 +00:00
|
|
|
}
|
|
|
|
|
2016-12-30 19:06:44 +00:00
|
|
|
[ -z "$USER" ] && { usage; errex "no username specified"; }
|
2018-04-04 16:59:28 +00:00
|
|
|
expr index "$USER" "@" >/dev/null || { usage; errex "username must include the domain"; }
|
2016-12-30 19:06:44 +00:00
|
|
|
|
2019-08-01 17:39:25 +00:00
|
|
|
# Protect config file with lock to avoid race conditions
|
|
|
|
touch $DATABASE
|
|
|
|
(
|
|
|
|
flock -e 200
|
|
|
|
|
|
|
|
grep -qi "^$(escape "$USER")|" $DATABASE 2>/dev/null &&
|
|
|
|
errex "User \"$USER\" already exists"
|
|
|
|
|
|
|
|
if [ -z "$PASSWD" ]; then
|
|
|
|
read -s -p "Enter Password: " PASSWD
|
|
|
|
echo
|
|
|
|
[ -z "$PASSWD" ] && errex "Password must not be empty"
|
|
|
|
fi
|
|
|
|
|
|
|
|
HASH="$(doveadm pw -s SHA512-CRYPT -u "$USER" -p "$PASSWD")"
|
|
|
|
echo "$USER|$HASH" >> $DATABASE
|
|
|
|
) 200<$DATABASE
|