#!/bin/bash app="kanboard" # Source local helpers source ./_common.sh # Source app helpers source /usr/share/yunohost/helpers # Abort script if errors ynh_abort_if_errors # Retrieve arguments domain=$1 path=$2 admin=$3 is_public=$4 # TODO: Check domain/path availability with app helper yunohost app checkurl "${domain}${path}" -a "$app" \ || ynh_die "The path ${domain}${path} is not available for app installation." # Check user parameter ynh_user_exists "$admin" \ || ynh_die "The chosen admin user does not exist." ynh_app_setting_set $app admin_user $admin # Retrieve admin email email=$(yunohost user info $admin | grep mail: | sed "s/mail: //g") # Check destination directory DESTDIR="/var/www/$app" [[ -d $DESTDIR ]] && ynh_die \ "The destination directory '$DESTDIR' already exists.\ You should safely delete it before installing this app." # Generate random password dbpass=$(ynh_string_random) dbname=$app dbuser=$app # Initialize database and store mysql password for upgrade ynh_mysql_create_db "$dbname" "$dbuser" "$dbpass" ynh_app_setting_set $app mysqlpwd $dbpass ynh_app_setting_set $app adminusername $admin ynh_app_setting_set $app is_public $is_public ynh_setup_source "$DESTDIR" # Copy and edit config.php cp ../conf/config.php ${DESTDIR} sed -i "s/yuno_dbpdw/${dbpass}/g" ${DESTDIR}/config.php sed -i "s/yuno_dbuser/${dbuser}/g" ${DESTDIR}/config.php sed -i "s/yuno_admin/${admin}/g" ${DESTDIR}/config.php sed -i "s/yuno_email/${email}/g" ${DESTDIR}/config.php sed -i "s/yuno_domain/${domain}/g" ${DESTDIR}/config.php # Set permissions to kanboard and data directory chown -R root:root ${DESTDIR} chown -R www-data ${DESTDIR}/{data,plugins} # Copy and set php-fpm configuration phpfpm_conf="/etc/php5/fpm/pool.d/${app}.conf" sed -i "s@#POOLNAME#@${app}@g" ../conf/php-fpm.conf sed -i "s@#DESTDIR#@${DESTDIR}/@g" ../conf/php-fpm.conf cp ../conf/php-fpm.conf "$phpfpm_conf" chown root: $phpfpm_conf chmod 644 $phpfpm_conf finalnginxconf="/etc/nginx/conf.d/${domain}.d/${app}.conf" # Modify Nginx configuration file and copy it to Nginx conf directory sed -i "s@NAMETOCHANGE@${app}@g" ../conf/nginx.conf* sed -i "s@PATHTOCHANGE@${path}@g" ../conf/nginx.conf* sed -i "s@ALIASTOCHANGE@${DESTDIR}/@g" ../conf/nginx.conf* cp ../conf/nginx.conf "$finalnginxconf" if [ "$path" == "/" ] then # ynh panel is only comptable with non-root installation ynh_replace_string " include conf.d/" " #include conf.d/" "$finalnginxconf" fi # Make app public or private if [[ "$is_public" -eq 1 ]]; then yunohost app setting ${app} unprotected_uris -v "/" sed -i "s/define('LDAP_AUTH'.*$/define('LDAP_AUTH', true);/g" ${DESTDIR}/config.php sed -i "s/define('HIDE_LOGIN_FORM'.*$/define('HIDE_LOGIN_FORM', false);/g" ${DESTDIR}/config.php sed -i "s/define('REMEMBER_ME_AUTH'.*$/define('REMEMBER_ME_AUTH', true);/g" ${DESTDIR}/config.php sed -i "s/define('DISABLE_LOGOUT'.*$/define('DISABLE_LOGOUT', false);/g" ${DESTDIR}/config.php fi # Init database #chmod o+x ${DESTDIR} ${DESTDIR}/app/ ${DESTDIR}/app/Schema/ ${DESTDIR}/app/Schema/Sql ynh_mysql_connect_as "$dbuser" "$dbpass" "$dbname" < ${DESTDIR}/app/Schema/Sql/mysql.sql # Reload services service php5-fpm restart || true service nginx reload || true