[SOGo] Check if master, only run DB prep if master, use correct syslog-ng config if not master
This commit is contained in:
		
							parent
							
								
									b889c70db8
								
							
						
					
					
						commit
						6898e6c8f9
					
				| @ -42,11 +42,15 @@ RUN echo "Building from repository $SOGO_DEBIAN_REPOSITORY" \ | ||||
| 
 | ||||
| COPY ./bootstrap-sogo.sh /bootstrap-sogo.sh | ||||
| COPY syslog-ng.conf /etc/syslog-ng/syslog-ng.conf | ||||
| COPY syslog-ng-redis_slave.conf /etc/syslog-ng/syslog-ng-redis_slave.conf | ||||
| COPY supervisord.conf /etc/supervisor/supervisord.conf | ||||
| COPY acl.diff /acl.diff | ||||
| COPY stop-supervisor.sh /usr/local/sbin/stop-supervisor.sh | ||||
| COPY docker-entrypoint.sh / | ||||
| 
 | ||||
| RUN chmod +x /bootstrap-sogo.sh \ | ||||
|   /usr/local/sbin/stop-supervisor.sh | ||||
| 
 | ||||
| ENTRYPOINT ["/docker-entrypoint.sh"] | ||||
| 
 | ||||
| CMD exec /usr/bin/supervisord -c /etc/supervisor/supervisord.conf | ||||
|  | ||||
| @ -26,8 +26,8 @@ echo "DB schema is ${DBV_NOW}" | ||||
| 
 | ||||
| # Recreate view | ||||
| if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then | ||||
|   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" | ||||
| 
 | ||||
|   while [[ ${VIEW_OK} != 'OK' ]]; do | ||||
|     mysql --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  | ||||
| @ -79,6 +79,7 @@ fi | ||||
| 
 | ||||
| # Wait for static view table if missing after update and update content | ||||
| if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then | ||||
|   echo "We are master, preparing _sogo_static_view..." | ||||
|   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 | ||||
|       STATIC_VIEW_OK=OK | ||||
| @ -86,7 +87,7 @@ if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then | ||||
|       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')" | ||||
|     else | ||||
|       echo "Waiting for database initialization by master..." | ||||
|       echo "Waiting for database initialization..." | ||||
|       sleep 3 | ||||
|     fi | ||||
|   done | ||||
| @ -101,11 +102,12 @@ else | ||||
|   done | ||||
| fi | ||||
| 
 | ||||
| 
 | ||||
| # Recreate password update trigger | ||||
| 
 | ||||
| mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} -e "DROP TRIGGER IF EXISTS sogo_update_password" | ||||
| 
 | ||||
| while [[ ${TRIGGER_OK} != 'OK' ]]; do | ||||
| if [[ "${MASTER}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then | ||||
|   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" | ||||
|   while [[ ${TRIGGER_OK} != 'OK' ]]; do | ||||
|   mysql --socket=/var/run/mysqld/mysqld.sock -u ${DBUSER} -p${DBPASS} ${DBNAME} << EOF | ||||
| DELIMITER - | ||||
| CREATE TRIGGER sogo_update_password AFTER UPDATE ON _sogo_static_view | ||||
| @ -122,8 +124,8 @@ EOF | ||||
|       echo "Will retry to setup SOGo password update trigger in 3s" | ||||
|       sleep 3 | ||||
|     fi | ||||
| done | ||||
| 
 | ||||
|   done | ||||
| fi | ||||
| 
 | ||||
| if [[ "${ALLOW_ADMIN_EMAIL_LOGIN}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then | ||||
|   TRUST_PROXY="YES" | ||||
|  | ||||
							
								
								
									
										7
									
								
								data/Dockerfiles/sogo/docker-entrypoint.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										7
									
								
								data/Dockerfiles/sogo/docker-entrypoint.sh
									
									
									
									
									
										Executable file
									
								
							| @ -0,0 +1,7 @@ | ||||
| #!/bin/bash | ||||
| 
 | ||||
| if [[ ! -z ${REDIS_SLAVEOF_IP} ]]; then | ||||
|   cp /etc/syslog-ng/syslog-ng-redis_slave.conf /etc/syslog-ng/syslog-ng.conf | ||||
| fi | ||||
| 
 | ||||
| exec "$@" | ||||
							
								
								
									
										45
									
								
								data/Dockerfiles/sogo/syslog-ng-redis_slave.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								data/Dockerfiles/sogo/syslog-ng-redis_slave.conf
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| @version: 3.19 | ||||
| @include "scl.conf" | ||||
| options { | ||||
|   chain_hostnames(off); | ||||
|   flush_lines(0); | ||||
|   use_dns(no); | ||||
|   use_fqdn(no); | ||||
|   owner("root"); group("adm"); perm(0640); | ||||
|   stats_freq(0); | ||||
|   bad_hostname("^gconfd$"); | ||||
| }; | ||||
| source s_src { | ||||
|   unix-stream("/dev/log"); | ||||
|   internal(); | ||||
| }; | ||||
| source s_sogo { | ||||
|   pipe("/dev/sogo_log" owner(sogo) group(sogo)); | ||||
| }; | ||||
| destination d_stdout { pipe("/dev/stdout"); }; | ||||
| destination d_redis_ui_log { | ||||
|   redis( | ||||
|     host("`REDIS_SLAVEOF_IP`") | ||||
|     persist-name("redis1") | ||||
|     port(`REDIS_SLAVEOF_PORT`) | ||||
|     command("LPUSH" "SOGO_LOG" "$(format-json time=\"$S_UNIXTIME\" priority=\"$PRIORITY\" program=\"$PROGRAM\" message=\"$MESSAGE\")\n") | ||||
|   ); | ||||
| }; | ||||
| destination d_redis_f2b_channel { | ||||
|   redis( | ||||
|     host("`REDIS_SLAVEOF_IP`") | ||||
|     persist-name("redis2") | ||||
|     port(`REDIS_SLAVEOF_PORT`) | ||||
|     command("PUBLISH" "F2B_CHANNEL" "$MESSAGE") | ||||
|   ); | ||||
| }; | ||||
| log { | ||||
|   source(s_sogo); | ||||
|   destination(d_redis_ui_log); | ||||
|   destination(d_redis_f2b_channel); | ||||
| }; | ||||
| log { | ||||
|   source(s_sogo); | ||||
|   source(s_src); | ||||
|   destination(d_stdout); | ||||
| }; | ||||
| @ -1,4 +1,4 @@ | ||||
| @version: 3.8 | ||||
| @version: 3.19 | ||||
| @include "scl.conf" | ||||
| options { | ||||
|   chain_hostnames(off); | ||||
|  | ||||
							
								
								
									
										45
									
								
								data/Dockerfiles/sogo/syslog-ng.conf_
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								data/Dockerfiles/sogo/syslog-ng.conf_
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| @version: 3.8 | ||||
| @include "scl.conf" | ||||
| options { | ||||
|   chain_hostnames(off); | ||||
|   flush_lines(0); | ||||
|   use_dns(no); | ||||
|   use_fqdn(no); | ||||
|   owner("root"); group("adm"); perm(0640); | ||||
|   stats_freq(0); | ||||
|   bad_hostname("^gconfd$"); | ||||
| }; | ||||
| source s_src { | ||||
|   unix-stream("/dev/log"); | ||||
|   internal(); | ||||
| }; | ||||
| source s_sogo { | ||||
|   pipe("/dev/sogo_log" owner(sogo) group(sogo)); | ||||
| }; | ||||
| destination d_stdout { pipe("/dev/stdout"); }; | ||||
| destination d_redis_ui_log { | ||||
|   redis( | ||||
|     host("redis-mailcow") | ||||
|     persist-name("redis1") | ||||
|     port(6379) | ||||
|     command("LPUSH" "SOGO_LOG" "$(format-json time=\"$S_UNIXTIME\" priority=\"$PRIORITY\" program=\"$PROGRAM\" message=\"$MESSAGE\")\n") | ||||
|   ); | ||||
| }; | ||||
| destination d_redis_f2b_channel { | ||||
|   redis( | ||||
|     host("redis-mailcow") | ||||
|     persist-name("redis2") | ||||
|     port(6379) | ||||
|     command("PUBLISH" "F2B_CHANNEL" "$MESSAGE") | ||||
|   ); | ||||
| }; | ||||
| log { | ||||
|   source(s_sogo); | ||||
|   destination(d_redis_ui_log); | ||||
|   destination(d_redis_f2b_channel); | ||||
| }; | ||||
| log { | ||||
|   source(s_sogo); | ||||
|   source(s_src); | ||||
|   destination(d_stdout); | ||||
| }; | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 andryyy
						andryyy