2018-03-31 16:18:09 +08:00
|
|
|
#!/bin/bash
|
2017-10-10 02:30:45 +08:00
|
|
|
[[ -f mailcow.conf ]] && source mailcow.conf
|
|
|
|
[[ -f ../mailcow.conf ]] && source ../mailcow.conf
|
|
|
|
|
|
|
|
if [[ -z ${DBUSER} ]] || [[ -z ${DBPASS} ]] || [[ -z ${DBNAME} ]]; then
|
|
|
|
echo "Cannot find mailcow.conf, make sure this script is run from within the mailcow folder."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo -n "Checking MySQL service... "
|
|
|
|
if [[ -z $(docker ps -qf name=mysql-mailcow) ]]; then
|
|
|
|
echo "failed"
|
|
|
|
echo "MySQL (mysql-mailcow) is not up and running, exiting..."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "OK"
|
|
|
|
read -r -p "Are you sure you want to reset the mailcow administrator account? [y/N] " response
|
|
|
|
response=${response,,} # tolower
|
|
|
|
if [[ "$response" =~ ^(yes|y)$ ]]; then
|
|
|
|
echo -e "\nWorking, please wait..."
|
|
|
|
docker exec -it $(docker ps -qf name=mysql-mailcow) mysql -u${DBUSER} -p${DBPASS} ${DBNAME} -e "DELETE FROM admin;"
|
|
|
|
docker exec -it $(docker ps -qf name=mysql-mailcow) mysql -u${DBUSER} -p${DBPASS} ${DBNAME} -e "INSERT INTO admin (username, password, superadmin, created, modified, active) VALUES ('admin', '{SSHA256}K8eVJ6YsZbQCfuJvSUbaQRLr0HPLz5rC9IAp0PAFl0tmNDBkMDc0NDAyOTAxN2Rk', 1, NOW(), NOW(), 1);"
|
|
|
|
docker exec -it $(docker ps -qf name=mysql-mailcow) mysql -u${DBUSER} -p${DBPASS} ${DBNAME} -e "DELETE FROM domain_admins WHERE username='admin';"
|
|
|
|
docker exec -it $(docker ps -qf name=mysql-mailcow) mysql -u${DBUSER} -p${DBPASS} ${DBNAME} -e "INSERT INTO domain_admins (username, domain, created, active) VALUES ('admin', 'ALL', NOW(), 1);"
|
|
|
|
docker exec -it $(docker ps -qf name=mysql-mailcow) mysql -u${DBUSER} -p${DBPASS} ${DBNAME} -e "DELETE FROM tfa WHERE username='admin';"
|
|
|
|
echo "
|
|
|
|
Reset credentials:
|
|
|
|
---
|
|
|
|
Username: admin
|
|
|
|
Password: moohoo
|
|
|
|
TFA: none
|
|
|
|
"
|
|
|
|
else
|
|
|
|
echo "Operation canceled."
|
|
|
|
fi
|