#!/bin/bash # Exit on command errors and treat unset variables as an error set -eu app=$YNH_APP_INSTANCE_NAME version='1.2.0' # Source YunoHost helpers source /usr/share/yunohost/helpers # Retrieve app settings domain=$(ynh_app_setting_get "$app" domain) path=$(ynh_app_setting_get "$app" path) dbuser=$app dbname=$app dbpass=$(ynh_app_setting_get "$app" mysqlpwd) # Correct path: puts a / at the start and nothing at the end if [ "${path:0:1}" != "/" ]; then path="/$path" fi if [ "${path:${#path}-1}" == "/" ] && [ ${#path} -gt 1 ]; then path="${path:0:${#path}-1}" fi # Copy source files sudo mkdir -p $src_path sudo unzip -qq ../sources/humhub-$version.zip sudo cp -a humhub-$version/. $src_path # Conf app_conf=../conf/common.php sed -i "s@DBNAME_TO_CHANGE@$dbname@g" $app_conf sed -i "s@DBUSER_TO_CHANGE@$dbuser@g" $app_conf sed -i "s@DBPASS_TO_CHANGE@$dbpass@g" $app_conf sudo cp $app_conf $src_path/protected/config/common.php # Hotfixes # Fix LDAP email. See https://github.com/humhub/humhub/issues/1949 sudo cp -a ../sources/fix/AuthClientHelpers.php $src_path/protected/humhub/modules/user/authclient/AuthClientHelpers.php # Fix to allow passwordless LDAP login sudo cp -a ../sources/fix/ZendLdapClient.php $src_path/protected/humhub/modules/user/authclient/ZendLdapClient.php # Set permissions to app files sudo chown -R www-data: $src_path # Cron echo "30 * * * * $src_path/protected/yii cron hourly >/dev/null 2>&1" > cron echo "00 18 * * * $src_path/protected/yii cron daily >/dev/null 2>&1" > cron sudo mv cron /etc/cron.d/${app} sudo chown root /etc/cron.d/${app} # Modify Nginx configuration file and copy it to Nginx conf directory nginx_conf=../conf/nginx.conf sed -i "s@YNH_WWW_PATH@${path:-/}@g" $nginx_conf sed -i "s@YNH_WWW_ALIAS@$src_path/@g" $nginx_conf sudo cp $nginx_conf /etc/nginx/conf.d/$domain.d/$app.conf # Reload nginx service sudo service php5-fpm reload sudo service nginx reload