mirror of
				https://github.com/mail-in-a-box/mailinabox.git
				synced 2025-10-25 18:00:54 +00:00 
			
		
		
		
	Merge pull request #12 from kiekerjan/master
Merge master into development branch
This commit is contained in:
		
						commit
						f0f3c7a442
					
				| @ -138,7 +138,7 @@ def check_service(i, service, env): | ||||
| 
 | ||||
| 			# IPv4 ok but IPv6 failed. Try the PRIVATE_IPV6 address to see if the service is bound to the interface. | ||||
| 			elif service["port"] != 53 and try_connect(env["PRIVATE_IPV6"]): | ||||
| 				output.print_error("%s is running (and available over IPv4 and the local IPv6 address), but it is not publicly accessible at %s:%d." % (service['name'], env['PUBLIC_IP'], service['port'])) | ||||
| 				output.print_error("%s is running (and available over IPv4 and the local IPv6 address), but it is not publicly accessible at %s:%d." % (service['name'], env['PUBLIC_IPV6'], service['port'])) | ||||
| 			else: | ||||
| 				output.print_error("%s is running and available over IPv4 but is not accessible over IPv6 at %s port %d." % (service['name'], env['PUBLIC_IPV6'], service['port'])) | ||||
| 
 | ||||
| @ -678,7 +678,7 @@ def check_dnssec(domain, env, output, dns_zonefiles, is_checking_primary=False): | ||||
| 	if len(ds) > 0: | ||||
| 		output.print_line("") | ||||
| 		output.print_line("The DS record is currently set to:") | ||||
| 		for rr in ds: | ||||
| 		for rr in sorted(ds): | ||||
| 			output.print_line("Key Tag: {0}, Algorithm: {1}, Digest Type: {2}, Digest: {3}".format(*rr)) | ||||
| 
 | ||||
| def check_mail_domain(domain, env, output): | ||||
|  | ||||
| @ -120,9 +120,6 @@ tools/editconf.py /etc/postfix/main.cf \ | ||||
| # We need to explicitly enable the opendmarc service, or it will not start | ||||
| hide_output systemctl enable opendmarc | ||||
| 
 | ||||
| # There is a fault in the dkim code for Ubuntu 20.04, let's fix it. Not necessary for Ubuntu 21.04 or newer | ||||
| sed -i 's/return b""\.join(r\.items\[0\]\.strings)/return b""\.join(list(r\.items)\[0\]\.strings)/' /usr/lib/python3/dist-packages/dkim/dnsplug.py | ||||
| 
 | ||||
| # Restart services. | ||||
| restart_service dkimpy-milter | ||||
| restart_service opendmarc | ||||
|  | ||||
| @ -17,7 +17,7 @@ source /etc/mailinabox.conf # load global vars | ||||
| 
 | ||||
| echo "Installing fts-xapian..." | ||||
| 
 | ||||
| apt_install libxapian30 | ||||
| apt_install dovecot-fts-xapian | ||||
| 
 | ||||
| # Update the dovecot plugin configuration | ||||
| # | ||||
| @ -35,7 +35,7 @@ if [ ! -f /usr/lib/dovecot/decode2text.sh ]; then | ||||
| 	cp -f /usr/share/doc/dovecot-core/examples/decode2text.sh /usr/lib/dovecot | ||||
| fi | ||||
| 
 | ||||
| cp -f lib/lib21_fts_xapian_plugin.so /usr/lib/dovecot/modules/ | ||||
| #cp -f lib/lib21_fts_xapian_plugin.so /usr/lib/dovecot/modules/ | ||||
| 
 | ||||
| # Create configuration file | ||||
| cat > /etc/dovecot/conf.d/90-plugin-fts.conf << EOF; | ||||
|  | ||||
| @ -21,8 +21,8 @@ echo "Installing Nextcloud (contacts/calendar)..." | ||||
| #   we automatically install intermediate versions as needed. | ||||
| # * The hash is the SHA1 hash of the ZIP package, which you can find by just running this script and | ||||
| #   copying it from the error message when it doesn't match what is below. | ||||
| nextcloud_ver=23.0.2 | ||||
| nextcloud_hash=645cba42cab57029ebe29fb93906f58f7abea5f8 | ||||
| nextcloud_ver=24.0.0 | ||||
| nextcloud_hash=f072f5863a15cefe577b47f72bb3e41d2a339335 | ||||
| 
 | ||||
| # Nextcloud apps | ||||
| # -------------- | ||||
| @ -34,11 +34,11 @@ nextcloud_hash=645cba42cab57029ebe29fb93906f58f7abea5f8 | ||||
| # * The hash is the SHA1 hash of the ZIP package, which you can find by just running this script and | ||||
| #   copying it from the error message when it doesn't match what is below. | ||||
| contacts_ver=4.0.8 | ||||
| contacts_hash=9f368bb2be98c5555b7118648f4cc9fa51e8cb30 | ||||
| contacts_hash=fc626ec02732da13a4c600baae64ab40557afdca | ||||
| calendar_ver=3.0.6 | ||||
| calendar_hash=ca49bb1ce23f20e10911e39055fd59d7f7a84c30 | ||||
| calendar_hash=e40d919b4b7988b46671a78cb32a43d8c7cba332 | ||||
| user_external_ver=3.0.0 | ||||
| user_external_hash=6e5afe7f36f398f864bfdce9cad72200e70322aa | ||||
| user_external_hash=9e7aaf7288032bd463c480bc368ff91869122950 | ||||
| 
 | ||||
| # Clear prior packages and install dependencies from apt. | ||||
| 
 | ||||
| @ -46,7 +46,7 @@ apt-get purge -qq -y owncloud* # we used to use the package manager | ||||
| 
 | ||||
| apt_install php php-fpm \ | ||||
| 	php-cli php-sqlite3 php-gd php-imap php-curl php-pear curl \ | ||||
| 	php-dev php-gd php-xml php-mbstring php-zip php-apcu php-json \ | ||||
| 	php-dev php-xml php-mbstring php-zip php-apcu php-json \ | ||||
| 	php-intl php-imagick php-gmp php-bcmath | ||||
| 
 | ||||
| # Enable apc is required before installing nextcloud | ||||
| @ -54,8 +54,6 @@ tools/editconf.py /etc/php/$(php_version)/mods-available/apcu.ini -c ';' \ | ||||
|     apc.enabled=1 \ | ||||
|     apc.enable_cli=1 | ||||
| 
 | ||||
| restart_service php$(php_version)-fpm | ||||
| 
 | ||||
| InstallNextcloud() { | ||||
| 
 | ||||
| 	version=$1 | ||||
| @ -89,23 +87,20 @@ InstallNextcloud() { | ||||
| 	# their github repositories. | ||||
| 	mkdir -p /usr/local/lib/owncloud/apps | ||||
| 
 | ||||
| 	wget_verify https://github.com/nextcloud-releases/contacts/releases/download/v$version_contacts/contacts-v$version_contacts.tar.gz $hash_contacts /tmp/contacts.tgz | ||||
| 	wget_verify https://github.com/nextcloud-releases/contacts/archive/refs/tags/v$version_contacts.tar.gz $hash_contacts /tmp/contacts.tgz | ||||
| 	tar xf /tmp/contacts.tgz -C /usr/local/lib/owncloud/apps/ | ||||
| 	rm /tmp/contacts.tgz | ||||
| 
 | ||||
| 	wget_verify https://github.com/nextcloud-releases/calendar/releases/download/v$version_calendar/calendar-v$version_calendar.tar.gz $hash_calendar /tmp/calendar.tgz | ||||
| 	wget_verify https://github.com/nextcloud-releases/calendar/archive/refs/tags/v$version_calendar.tar.gz $hash_calendar /tmp/calendar.tgz | ||||
| 	tar xf /tmp/calendar.tgz -C /usr/local/lib/owncloud/apps/ | ||||
| 	rm /tmp/calendar.tgz | ||||
| 
 | ||||
| 	# Starting with Nextcloud 15, the app user_external is no longer included in Nextcloud core, | ||||
| 	# we will install from their github repository. | ||||
| 	if [ -n "$version_user_external" ]; then | ||||
| 		wget_verify https://github.com/nextcloud/user_external/releases/download/v$version_user_external/user_external-$version_user_external.tar.gz $hash_user_external /tmp/user_external.tgz | ||||
| 		wget_verify https://github.com/nextcloud/user_external/archive/refs/tags/v$version_user_external.tar.gz $hash_user_external /tmp/user_external.tgz | ||||
| 		tar -xf /tmp/user_external.tgz -C /usr/local/lib/owncloud/apps/ | ||||
| 		rm /tmp/user_external.tgz | ||||
| 		 | ||||
| 		# (Temporary?) workaround to get user_external working with Nextcloud 23 (see https://github.com/nextcloud/user_external/issues/186) | ||||
| 		# sed -i "s/nextcloud min-version=\"21\" max-version=\"22\"/nextcloud min-version=\"21\" max-version=\"23\"/g" /usr/local/lib/owncloud/apps/user_external/appinfo/info.xml | ||||
| 	fi | ||||
| 
 | ||||
| 	# Fix weird permissions. | ||||
| @ -196,23 +191,23 @@ if [ ! -d /usr/local/lib/owncloud/ ] || [[ ! ${CURRENT_NEXTCLOUD_VER} =~ ^$nextc | ||||
| 			# During the upgrade from Nextcloud 14 to 15, user_external may cause the upgrade to fail. | ||||
| 			# We will disable it here before the upgrade and install it again after the upgrade. | ||||
| 			hide_output sudo -u www-data php /usr/local/lib/owncloud/console.php app:disable user_external | ||||
| 			InstallNextcloud 15.0.8 4129d8d4021c435f2e86876225fb7f15adf764a3 3.3.0 e55d0357c6785d3b1f3b5f21780cb6d41d32443a 2.0.3 9d9717b29337613b72c74e9914c69b74b346c466 0.7.0 555a94811daaf5bdd336c5e48a78aa8567b86437 | ||||
| 			InstallNextcloud 15.0.8 4129d8d4021c435f2e86876225fb7f15adf764a3 3.3.0 e55d0357c6785d3b1f3b5f21780cb6d41d32443a 2.0.3 a1f3835c752929e3598eb94f22300516867ac6ab 0.7.0 555a94811daaf5bdd336c5e48a78aa8567b86437 | ||||
| 			CURRENT_NEXTCLOUD_VER="15.0.8" | ||||
| 		fi | ||||
| 		if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^15 ]]; then | ||||
| 			InstallNextcloud 16.0.6 0bb3098455ec89f5af77a652aad553ad40a88819 3.3.0 e55d0357c6785d3b1f3b5f21780cb6d41d32443a 2.0.3 9d9717b29337613b72c74e9914c69b74b346c466 0.7.0 555a94811daaf5bdd336c5e48a78aa8567b86437 | ||||
| 			CURRENT_NEXTCLOUD_VER="16.0.6" | ||||
| 		fi | ||||
|         if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^16 ]]; then | ||||
| 		if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^16 ]]; then | ||||
| 			InstallNextcloud 17.0.6 50b98d2c2f18510b9530e558ced9ab51eb4f11b0 3.3.0 e55d0357c6785d3b1f3b5f21780cb6d41d32443a 2.0.3 9d9717b29337613b72c74e9914c69b74b346c466 0.7.0 555a94811daaf5bdd336c5e48a78aa8567b86437 | ||||
| 			CURRENT_NEXTCLOUD_VER="17.0.6" | ||||
|         fi | ||||
|         if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^17 ]]; then | ||||
|         	# Don't exit the install if this column already exists (see #2076) | ||||
| 		fi | ||||
| 		if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^17 ]]; then | ||||
| 			# Don't exit the install if this column already exists (see #2076) | ||||
| 			(echo "ALTER TABLE oc_flow_operations ADD COLUMN entity VARCHAR;" | sqlite3 $STORAGE_ROOT/owncloud/owncloud.db 2>/dev/null) || true | ||||
|             InstallNextcloud 18.0.10 39c0021a8b8477c3f1733fddefacfa5ebf921c68 3.4.1 aee680a75e95f26d9285efd3c1e25cf7f3bfd27e 2.0.3 9d9717b29337613b72c74e9914c69b74b346c466 1.0.0 3bf2609061d7214e7f0f69dd8883e55c4ec8f50a | ||||
|             CURRENT_NEXTCLOUD_VER="18.0.10" | ||||
| 	    fi | ||||
| 			InstallNextcloud 18.0.10 39c0021a8b8477c3f1733fddefacfa5ebf921c68 3.4.1 aee680a75e95f26d9285efd3c1e25cf7f3bfd27e 2.0.3 9d9717b29337613b72c74e9914c69b74b346c466 1.0.0 3bf2609061d7214e7f0f69dd8883e55c4ec8f50a | ||||
| 			CURRENT_NEXTCLOUD_VER="18.0.10" | ||||
| 		fi | ||||
| 		if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^18 ]]; then | ||||
| 			InstallNextcloud 19.0.4 01e98791ba12f4860d3d4047b9803f97a1b55c60 3.4.1 aee680a75e95f26d9285efd3c1e25cf7f3bfd27e 2.0.3 9d9717b29337613b72c74e9914c69b74b346c466 1.0.0 3bf2609061d7214e7f0f69dd8883e55c4ec8f50a | ||||
| 			CURRENT_NEXTCLOUD_VER="19.0.4" | ||||
| @ -232,6 +227,10 @@ if [ ! -d /usr/local/lib/owncloud/ ] || [[ ! ${CURRENT_NEXTCLOUD_VER} =~ ^$nextc | ||||
| 			InstallNextcloud 22.2.3 58d2d897ba22a057aa03d29c762c5306211fefd2 4.0.7 8ab31d205408e4f12067d8a4daa3595d46b513e3 3.0.4 6fb1e998d307c53245faf1c37a96eb982bbee8ba 2.1.0 6e5afe7f36f398f864bfdce9cad72200e70322aa | ||||
| 			CURRENT_NEXTCLOUD_VER="22.2.3" | ||||
| 		fi | ||||
| 		if [[ ${CURRENT_NEXTCLOUD_VER} =~ ^22 ]]; then | ||||
| 			InstallNextcloud 23.0.2 645cba42cab57029ebe29fb93906f58f7abea5f8 4.0.8 9f368bb2be98c5555b7118648f4cc9fa51e8cb30 3.0.6 ca49bb1ce23f20e10911e39055fd59d7f7a84c30 3.0.0 9e7aaf7288032bd463c480bc368ff91869122950 | ||||
| 			CURRENT_NEXTCLOUD_VER="23.0.2" | ||||
| 		fi | ||||
| 	fi | ||||
| 
 | ||||
| 	InstallNextcloud $nextcloud_ver $nextcloud_hash $contacts_ver $contacts_hash $calendar_ver $calendar_hash $user_external_ver $user_external_hash | ||||
| @ -338,7 +337,7 @@ include("$STORAGE_ROOT/owncloud/config.php"); | ||||
| 
 | ||||
| \$CONFIG['mail_domain'] = '$PRIMARY_HOSTNAME'; | ||||
| 
 | ||||
| \$CONFIG['user_backends'] = array(array('class' => 'OC_User_IMAP','arguments' => array('127.0.0.1', 143, null),),); | ||||
| \$CONFIG['user_backends'] = array(array('class' => '\OCA\UserExternal\IMAP','arguments' => array('127.0.0.1', 143, null),),); | ||||
| 
 | ||||
| echo "<?php\n\\\$CONFIG = "; | ||||
| var_export(\$CONFIG); | ||||
|  | ||||
| @ -40,6 +40,9 @@ apt_install openssl | ||||
| 
 | ||||
| mkdir -p $STORAGE_ROOT/ssl | ||||
| 
 | ||||
| # make directory readable | ||||
| chmod 755 $STORAGE_ROOT/ssl | ||||
| 
 | ||||
| # Generate a new private key. | ||||
| # | ||||
| # The key is only as good as the entropy available to openssl so that it | ||||
|  | ||||
| @ -251,18 +251,14 @@ EOF | ||||
| 
 | ||||
| # Adjust apt update and upgrade timers such that they're always before daily status | ||||
| # checks and thus never report upgrades unless user intervention is necessary. | ||||
| if [ ! -d /etc/systemd/system/apt-daily.timer.d ]; then | ||||
| 	mkdir /etc/systemd/system/apt-daily.timer.d | ||||
| fi | ||||
| mkdir -p /etc/systemd/system/apt-daily.timer.d | ||||
| cat > /etc/systemd/system/apt-daily.timer.d/override.conf <<EOF; | ||||
| [Timer] | ||||
| RandomizedDelaySec=5h | ||||
| EOF | ||||
| 
 | ||||
| if [ ! -d /etc/systemd/system/apt-daily-upgrade.timer.d ]; then | ||||
| 	mkdir /etc/systemd/system/apt-daily-upgrade.timer.d | ||||
| fi | ||||
| cat /etc/systemd/system/apt-daily-upgrade.timer.d/override.conf <<EOF; | ||||
| mkdir -p /etc/systemd/system/apt-daily-upgrade.timer.d | ||||
| cat > /etc/systemd/system/apt-daily-upgrade.timer.d/override.conf <<EOF; | ||||
| [Timer] | ||||
| OnCalendar= | ||||
| OnCalendar=*-*-* 23:30 | ||||
| @ -342,9 +338,7 @@ apt_install unbound python3-unbound bind9-dnsutils | ||||
| # Configure unbound | ||||
| cp -f conf/unbound.conf /etc/unbound/unbound.conf.d/miabunbound.conf | ||||
| 
 | ||||
| if [ -d /etc/unbound/lists.d ]; then | ||||
| 	mkdir /etc/unbound/lists.d | ||||
| fi | ||||
| mkdir -p /etc/unbound/lists.d | ||||
| 
 | ||||
| systemctl restart unbound | ||||
| 
 | ||||
|  | ||||
| @ -23,7 +23,7 @@ echo "Installing Roundcube (webmail)..." | ||||
| apt_install \ | ||||
| 	dbconfig-common \ | ||||
| 	php-cli php-sqlite3 php-intl php-json php-common php-curl php-ldap \ | ||||
| 	php-gd php-pspell tinymce libjs-jquery libjs-jquery-mousewheel libmagic1 php-mbstring | ||||
| 	php-gd php-pspell libjs-jquery libjs-jquery-mousewheel libmagic1 php-mbstring | ||||
| 
 | ||||
| # Install Roundcube from source if it is not already present or if it is out of date. | ||||
| # Combine the Roundcube version number with the commit hash of plugins to track | ||||
| @ -156,16 +156,16 @@ EOF | ||||
| cat > ${RCM_PLUGIN_DIR}/carddav/config.inc.php <<EOF; | ||||
| <?php | ||||
| /* Do not edit. Written by Mail-in-a-Box. Regenerated on updates. */ | ||||
| \$prefs['_GLOBAL']['hide_preferences'] = true; | ||||
| \$prefs['_GLOBAL']['hide_preferences'] = false; | ||||
| \$prefs['_GLOBAL']['suppress_version_warning'] = true; | ||||
| \$prefs['ownCloud'] = array( | ||||
| 	 'name'         =>  'ownCloud', | ||||
| 	 'username'     =>  '%u', // login username | ||||
| 	 'password'     =>  '%p', // login password | ||||
| 	 'url'          =>  'https://${PRIMARY_HOSTNAME}/cloud/remote.php/dav/addressbooks/users/%u/contacts', | ||||
| 	 'url'          =>  'https://${PRIMARY_HOSTNAME}/cloud/remote.php/dav/addressbooks/users/%u/contacts/', | ||||
| 	 'active'       =>  true, | ||||
| 	 'readonly'     =>  false, | ||||
| 	 'refresh_time' => '02:00:00', | ||||
| 	 'refresh_time' => '00:30:00', | ||||
| 	 'fixed'        =>  array('username'), | ||||
| 	 'preemptive_auth' => '1', | ||||
| 	 'hide'        =>  false, | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user