|
@@ -14,11 +14,11 @@ do
|
|
done
|
|
done
|
|
|
|
|
|
# Wait for updated schema
|
|
# Wait for updated schema
|
|
-DBV_NOW=$(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT version FROM versions WHERE application = 'db_schema';" -BN)
|
|
|
|
|
|
+DBV_NOW=$(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT version FROM versions WHERE application = 'db_schema';" -BN)
|
|
DBV_NEW=$(grep -oE '\$db_version = .*;' init_db.inc.php | sed 's/$db_version = //g;s/;//g' | cut -d \" -f2)
|
|
DBV_NEW=$(grep -oE '\$db_version = .*;' init_db.inc.php | sed 's/$db_version = //g;s/;//g' | cut -d \" -f2)
|
|
while [[ "${DBV_NOW}" != "${DBV_NEW}" ]]; do
|
|
while [[ "${DBV_NOW}" != "${DBV_NEW}" ]]; do
|
|
echo "Waiting for schema update..."
|
|
echo "Waiting for schema update..."
|
|
- DBV_NOW=$(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT version FROM versions WHERE application = 'db_schema';" -BN)
|
|
|
|
|
|
+ DBV_NOW=$(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT version FROM versions WHERE application = 'db_schema';" -BN)
|
|
DBV_NEW=$(grep -oE '\$db_version = .*;' init_db.inc.php | sed 's/$db_version = //g;s/;//g' | cut -d \" -f2)
|
|
DBV_NEW=$(grep -oE '\$db_version = .*;' init_db.inc.php | sed 's/$db_version = //g;s/;//g' | cut -d \" -f2)
|
|
sleep 5
|
|
sleep 5
|
|
done
|
|
done
|
|
@@ -27,9 +27,9 @@ echo "DB schema is ${DBV_NOW}"
|
|
# Recreate view
|
|
# Recreate view
|
|
if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
echo "We are master, preparing sogo_view..."
|
|
echo "We are master, preparing sogo_view..."
|
|
- mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "DROP VIEW IF EXISTS sogo_view"
|
|
|
|
|
|
+ mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "DROP VIEW IF EXISTS sogo_view"
|
|
while [[ ${VIEW_OK} != 'OK' ]]; do
|
|
while [[ ${VIEW_OK} != 'OK' ]]; do
|
|
- mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} << EOF
|
|
|
|
|
|
+ mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} << EOF
|
|
CREATE VIEW sogo_view (c_uid, domain, c_name, c_password, c_cn, mail, aliases, ad_aliases, ext_acl, kind, multiple_bookings) AS
|
|
CREATE VIEW sogo_view (c_uid, domain, c_name, c_password, c_cn, mail, aliases, ad_aliases, ext_acl, kind, multiple_bookings) AS
|
|
SELECT
|
|
SELECT
|
|
mailbox.username,
|
|
mailbox.username,
|
|
@@ -59,7 +59,7 @@ WHERE
|
|
GROUP BY
|
|
GROUP BY
|
|
mailbox.username;
|
|
mailbox.username;
|
|
EOF
|
|
EOF
|
|
- if [[ ! -z $(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'sogo_view'") ]]; then
|
|
|
|
|
|
+ if [[ ! -z $(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'sogo_view'") ]]; then
|
|
VIEW_OK=OK
|
|
VIEW_OK=OK
|
|
else
|
|
else
|
|
echo "Will retry to setup SOGo view in 3s..."
|
|
echo "Will retry to setup SOGo view in 3s..."
|
|
@@ -68,7 +68,7 @@ EOF
|
|
done
|
|
done
|
|
else
|
|
else
|
|
while [[ ${VIEW_OK} != 'OK' ]]; do
|
|
while [[ ${VIEW_OK} != 'OK' ]]; do
|
|
- if [[ ! -z $(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'sogo_view'") ]]; then
|
|
|
|
|
|
+ if [[ ! -z $(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = 'sogo_view'") ]]; then
|
|
VIEW_OK=OK
|
|
VIEW_OK=OK
|
|
else
|
|
else
|
|
echo "Waiting for SOGo view to be created by master..."
|
|
echo "Waiting for SOGo view to be created by master..."
|
|
@@ -81,12 +81,12 @@ fi
|
|
if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
echo "We are master, preparing _sogo_static_view..."
|
|
echo "We are master, preparing _sogo_static_view..."
|
|
while [[ ${STATIC_VIEW_OK} != 'OK' ]]; do
|
|
while [[ ${STATIC_VIEW_OK} != 'OK' ]]; do
|
|
- if [[ ! -z $(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = '_sogo_static_view'") ]]; then
|
|
|
|
|
|
+ if [[ ! -z $(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = '_sogo_static_view'") ]]; then
|
|
STATIC_VIEW_OK=OK
|
|
STATIC_VIEW_OK=OK
|
|
echo "Updating _sogo_static_view content..."
|
|
echo "Updating _sogo_static_view content..."
|
|
# If changed, also update init_db.inc.php
|
|
# If changed, also update init_db.inc.php
|
|
- mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "REPLACE INTO _sogo_static_view (c_uid, domain, c_name, c_password, c_cn, mail, aliases, ad_aliases, ext_acl, kind, multiple_bookings) SELECT c_uid, domain, c_name, c_password, c_cn, mail, aliases, ad_aliases, ext_acl, kind, multiple_bookings from sogo_view;"
|
|
|
|
- mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "DELETE FROM _sogo_static_view WHERE c_uid NOT IN (SELECT username FROM mailbox WHERE active = '1')"
|
|
|
|
|
|
+ mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "REPLACE INTO _sogo_static_view (c_uid, domain, c_name, c_password, c_cn, mail, aliases, ad_aliases, ext_acl, kind, multiple_bookings) SELECT c_uid, domain, c_name, c_password, c_cn, mail, aliases, ad_aliases, ext_acl, kind, multiple_bookings from sogo_view;"
|
|
|
|
+ mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "DELETE FROM _sogo_static_view WHERE c_uid NOT IN (SELECT username FROM mailbox WHERE active = '1')"
|
|
else
|
|
else
|
|
echo "Waiting for database initialization..."
|
|
echo "Waiting for database initialization..."
|
|
sleep 3
|
|
sleep 3
|
|
@@ -94,7 +94,7 @@ if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
done
|
|
done
|
|
else
|
|
else
|
|
while [[ ${STATIC_VIEW_OK} != 'OK' ]]; do
|
|
while [[ ${STATIC_VIEW_OK} != 'OK' ]]; do
|
|
- if [[ ! -z $(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = '_sogo_static_view'") ]]; then
|
|
|
|
|
|
+ if [[ ! -z $(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME = '_sogo_static_view'") ]]; then
|
|
STATIC_VIEW_OK=OK
|
|
STATIC_VIEW_OK=OK
|
|
else
|
|
else
|
|
echo "Waiting for database initialization by master..."
|
|
echo "Waiting for database initialization by master..."
|
|
@@ -107,9 +107,9 @@ fi
|
|
# Recreate password update trigger
|
|
# Recreate password update trigger
|
|
if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
echo "We are master, preparing update trigger..."
|
|
echo "We are master, preparing update trigger..."
|
|
- mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "DROP TRIGGER IF EXISTS sogo_update_password"
|
|
|
|
|
|
+ mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "DROP TRIGGER IF EXISTS sogo_update_password"
|
|
while [[ ${TRIGGER_OK} != 'OK' ]]; do
|
|
while [[ ${TRIGGER_OK} != 'OK' ]]; do
|
|
- mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} << EOF
|
|
|
|
|
|
+ mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} << EOF
|
|
DELIMITER -
|
|
DELIMITER -
|
|
CREATE TRIGGER sogo_update_password AFTER UPDATE ON _sogo_static_view
|
|
CREATE TRIGGER sogo_update_password AFTER UPDATE ON _sogo_static_view
|
|
FOR EACH ROW
|
|
FOR EACH ROW
|
|
@@ -119,7 +119,7 @@ END;
|
|
-
|
|
-
|
|
DELIMITER ;
|
|
DELIMITER ;
|
|
EOF
|
|
EOF
|
|
- if [[ ! -z $(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TRIGGERS WHERE TRIGGER_NAME = 'sogo_update_password'") ]]; then
|
|
|
|
|
|
+ if [[ ! -z $(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -B -e "SELECT 'OK' FROM INFORMATION_SCHEMA.TRIGGERS WHERE TRIGGER_NAME = 'sogo_update_password'") ]]; then
|
|
TRIGGER_OK=OK
|
|
TRIGGER_OK=OK
|
|
else
|
|
else
|
|
echo "Will retry to setup SOGo password update trigger in 3s"
|
|
echo "Will retry to setup SOGo password update trigger in 3s"
|
|
@@ -216,7 +216,7 @@ while read -r line gal
|
|
line=${line} envsubst < /etc/sogo/plist_ldap >> /var/lib/sogo/GNUstep/Defaults/sogod.plist
|
|
line=${line} envsubst < /etc/sogo/plist_ldap >> /var/lib/sogo/GNUstep/Defaults/sogod.plist
|
|
echo " </array>
|
|
echo " </array>
|
|
</dict>" >> /var/lib/sogo/GNUstep/Defaults/sogod.plist
|
|
</dict>" >> /var/lib/sogo/GNUstep/Defaults/sogod.plist
|
|
-done < <(mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT domain, CASE gal WHEN '1' THEN 'YES' ELSE 'NO' END AS gal FROM domain;" -B -N)
|
|
|
|
|
|
+done < <(mariadb --skip-ssl --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "SELECT domain, CASE gal WHEN '1' THEN 'YES' ELSE 'NO' END AS gal FROM domain;" -B -N)
|
|
|
|
|
|
# Generate footer
|
|
# Generate footer
|
|
echo ' </dict>
|
|
echo ' </dict>
|