TBK 2017-05-28 23:28:41 +02:00
parent 95c30e8791
commit e151e32730
1 changed files with 17 additions and 16 deletions

View File

@ -10,7 +10,7 @@ while ! mysqladmin ping --host mysql --silent; do
sleep 2 sleep 2
done done
until [ $(redis-cli -h redis-mailcow PING) == "PONG" ]; do until [ "$(redis-cli -h redis-mailcow PING)" == "PONG" ]; do
sleep 2 sleep 2
done done
@ -18,14 +18,14 @@ done
declare -a DOMAIN_ARR declare -a DOMAIN_ARR
redis-cli -h redis-mailcow DEL DOMAIN_MAP redis-cli -h redis-mailcow DEL DOMAIN_MAP
while read line while read -r line
do do
DOMAIN_ARR+=("$line") DOMAIN_ARR+=("$line")
done < <(mysql -h mysql-mailcow -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT domain FROM domain" -Bs) done < <(mysql -h mysql-mailcow -u "${DBUSER}" -p"${DBPASS}" "${DBNAME}" -e "SELECT domain FROM domain" -Bs)
if [[ ! -z ${DOMAIN_ARR} ]]; then if [[ ! -z ${DOMAIN_ARR} ]]; then
for domain in "${DOMAIN_ARR[@]}"; do for domain in "${DOMAIN_ARR[@]}"; do
redis-cli -h redis-mailcow HSET DOMAIN_MAP ${domain} 1 redis-cli -h redis-mailcow HSET DOMAIN_MAP "${domain}" 1
done done
fi fi
@ -33,50 +33,51 @@ fi
declare -a SUBJ_TAG_ARR declare -a SUBJ_TAG_ARR
redis-cli -h redis-mailcow DEL SUBJ_TAG_ARR redis-cli -h redis-mailcow DEL SUBJ_TAG_ARR
while read line while read -r line
do do
SUBJ_TAG_ARR+=("$line") SUBJ_TAG_ARR+=("$line")
done < <(mysql -h mysql-mailcow -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT username FROM mailbox WHERE wants_tagged_subject='1'" -Bs) done < <(mysql -h mysql-mailcow -u "${DBUSER}" -p"${DBPASS}" "${DBNAME}" -e "SELECT username FROM mailbox WHERE wants_tagged_subject='1'" -Bs)
if [[ ! -z ${SUBJ_TAG_ARR} ]]; then if [[ ! -z ${SUBJ_TAG_ARR} ]]; then
for user in "${SUBJ_TAG_ARR[@]}"; do for user in "${SUBJ_TAG_ARR[@]}"; do
redis-cli -h redis-mailcow HSET RCPT_WANTS_SUBJECT_TAG ${user} 1 redis-cli -h redis-mailcow HSET RCPT_WANTS_SUBJECT_TAG "${user}" 1
mysql -h mysql-mailcow -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "UPDATE mailbox SET wants_tagged_subject='2' WHERE username = '${user}'" mysql -h mysql-mailcow -u "${DBUSER}" -p"${DBPASS}" "${DBNAME}" -e "UPDATE mailbox SET wants_tagged_subject='2' WHERE username = '${user}'"
done done
fi fi
# Migrate DKIM keys # Migrate DKIM keys
for file in $(ls /data/dkim/keys/); do for file in /data/dkim/keys/*; do
[[ -e $file ]] || break # handle the case of no files
domain=${file%.dkim} domain=${file%.dkim}
if [[ -f /data/dkim/txt/${file} ]]; then if [[ -f /data/dkim/txt/${file} ]]; then
redis-cli -h redis-mailcow HSET DKIM_PUB_KEYS "${domain}" "$(cat /data/dkim/txt/${file})" redis-cli -h redis-mailcow HSET DKIM_PUB_KEYS "${domain}" "$(cat /data/dkim/txt/${file})"
redis-cli -h redis-mailcow HSET DKIM_PRIV_KEYS "dkim.${domain}" "$(cat /data/dkim/keys/${file})" redis-cli -h redis-mailcow HSET DKIM_PRIV_KEYS "dkim.${domain}" "$(cat /data/dkim/keys/${file})"
redis-cli -h redis-mailcow HSET DKIM_SELECTORS "${domain}" "dkim" redis-cli -h redis-mailcow HSET DKIM_SELECTORS "${domain}" "dkim"
fi fi
rm /data/dkim/{keys,txt}/${file} rm /data/dkim/{keys,txt}/"${file}"
done done
# Fix DKIM keys # Fix DKIM keys
# Fetch domains # Fetch domains
declare -a DOMAIN_ARRAY declare -a DOMAIN_ARRAY
while read line while read -r line
do do
DOMAIN_ARRAY+=("$line") DOMAIN_ARRAY+=("$line")
done < <(mysql -h mysql-mailcow -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT domain FROM domain" -Bs) done < <(mysql -h mysql-mailcow -u "${DBUSER}" -p"${DBPASS}" "${DBNAME}" -e "SELECT domain FROM domain" -Bs)
while read line while read -r line
do do
DOMAIN_ARRAY+=("$line") DOMAIN_ARRAY+=("$line")
done < <(mysql -h mysql-mailcow -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT alias_domain FROM alias_domain" -Bs) done < <(mysql -h mysql-mailcow -u "${DBUSER}" -p"${DBPASS}" "${DBNAME}" -e "SELECT alias_domain FROM alias_domain" -Bs)
# Loop through array and fix keys # Loop through array and fix keys
if [[ ! -z ${DOMAIN_ARRAY} ]]; then if [[ ! -z ${DOMAIN_ARRAY} ]]; then
for domain in "${DOMAIN_ARRAY[@]}"; do for domain in "${DOMAIN_ARRAY[@]}"; do
WRONG_KEY=$(redis-cli -h redis-mailcow HGET DKIM_PRIV_KEYS ${domain} | tr -d \") WRONG_KEY=$(redis-cli -h redis-mailcow HGET DKIM_PRIV_KEYS "${domain}" | tr -d \")
if [[ ! -z ${WRONG_KEY} ]]; then if [[ ! -z ${WRONG_KEY} ]]; then
echo "Migrating defect key for domain ${domain}" echo "Migrating defect key for domain ${domain}"
redis-cli -h redis-mailcow HSET DKIM_PRIV_KEYS "dkim.${domain}" ${WRONG_KEY} redis-cli -h redis-mailcow HSET DKIM_PRIV_KEYS "dkim.${domain}" "${WRONG_KEY}"
redis-cli -h redis-mailcow HDEL DKIM_PRIV_KEYS "${domain}" redis-cli -h redis-mailcow HDEL DKIM_PRIV_KEYS "${domain}"
fi fi
done done