From 32421afe3508f03e8f6b4d967765452828dd2c64 Mon Sep 17 00:00:00 2001 From: Anmol Date: Sun, 2 Jul 2017 02:17:48 +0530 Subject: [PATCH] changes in the install script --- script/install | 110 ------------------------------------------------- script/remove | 34 --------------- 2 files changed, 144 deletions(-) delete mode 100755 script/install delete mode 100755 script/remove diff --git a/script/install b/script/install deleted file mode 100755 index d780484..0000000 --- a/script/install +++ /dev/null @@ -1,110 +0,0 @@ -#!/bin/bash - -# Exit on command errors and treat unset variables as an error -set -eu - -# This is a multi-instance app, meaning it can be installed several times independently -# The id of the app as stated in the manifest is available as $YNH_APP_ID -# The instance number is available as $YNH_APP_INSTANCE_NUMBER (equals "1", "2", ...) -# The app instance name is available as $YNH_APP_INSTANCE_NAME -# - the first time the app is installed, YNH_APP_INSTANCE_NAME = ynhexample -# - the second time the app is installed, YNH_APP_INSTANCE_NAME = ynhexample__2 -# - ynhexample__{N} for the subsequent installations, with N=3,4, ... -# The app instance name is probably what you are interested the most, since this is -# guaranteed to be unique. This is a good unique identifier to define installation path, -# db names, ... -app=$YNH_APP_INSTANCE_NAME - -# Retrieve arguments -domain=$YNH_APP_ARG_DOMAIN -path_url=$YNH_APP_ARG_PATH -is_public=$YNH_APP_ARG_IS_PUBLIC -admin_username=$YNH_APP_ARG_USERNAME -admin_name=$YNH_APP_ARG_NAME -admin_email=$YNH_APP_ARG_EMAIL -password=$YNH_APP_ARG_PASSWORD - -admin_password=openssl passwd -1 -salt xyz $password - -# Source YunoHost helpers -source /usr/share/yunohost/helpers - -# Save app settings -ynh_app_setting_set "$app" is_public "$is_public" - - -# Check domain/path availability -sudo yunohost app checkurl "${domain}${path_url}" -a "$app" \ - || ynh_die "Path not available: ${domain}${path_url}" - -# Check password strength -[[ ${#admin_password} -gt 6 ]] || ynh_die \ -"The password is too weak, it must be longer than 6 characters" - - -# Copy source files -src_path=/var/www/$app -sudo mkdir -p $src_path -sudo cp -a ../sources/. $src_path - -# Set permissions to app files -# you may need to make some file and/or directory writeable by www-data (nginx user) -sudo chown -R root: $src_path - -### MySQL (can be removed if not used) ### -# If your app use a MySQL database you can use these lines to bootstrap -# a database, an associated user and save the password in app settings. -# -# # Generate MySQL password and create database - dbuser=$app - dbname=$app - dbpass=$(ynh_string_random 12) - ynh_app_setting_set "$app" mysqlpwd "$dbpass" - ynh_mysql_create_db "$dbname" "$dbuser" "$dbpass" - -# Adding the details of the database to the config file -sed -i "s@__dbuser__@$dbuser@g" ../conf/config.ini.php -sed -i "s@__dbpass__@$dbpass@g" ../conf/config.ini.php -sed -i "s@__dbname__@$dbname@g" ../conf/config.ini.php - -# Copy the config file to the src_path -sudo cp ../conf/config.ini.php $src_path/data/. - - - -# # Load initial SQL into the new database - ynh_mysql_connect_as "$dbuser" "$dbpass" "$dbname" \ - < "../sources/sql/webtrees.sql" - - - -# Replace variables in sql scripts -ynh_replace_string "__USER_NAME__" "$admin_username" ../conf/sql/admin.sql -ynh_replace_string "__NAME__" "$admin_name" ../conf/sql/admin.sql -ynh_replace_string "__USER_EMAIL__" "$admin_email" ../conf/sql/admin.sql -ynh_replace_string "__PASSWORD__" "$admin_password" ../conf/sql/admin.sql - -ynh_mysql_connect_as $db_name $db_pwd $db_name < ../conf/sql/admin.sql - -### MySQL end ### - -# Modify Nginx configuration file and copy it to Nginx conf directory -nginx_conf=../conf/nginx.conf -sed -i "s@YNH_WWW_PATH@$path_url@g" $nginx_conf -sed -i "s@YNH_WWW_ALIAS@$src_path/@g" $nginx_conf -# If a dedicated php-fpm process is used: -# Don't forget to modify ../conf/nginx.conf accordingly or your app will not work! -# sed -i "s@YNH_WWW_APP@$app@g" $nginx_conf -sudo cp $nginx_conf /etc/nginx/conf.d/$domain.d/$app.conf - - -# If app is public, add url to SSOWat conf as skipped_uris -if [[ $is_public -eq 1 ]]; then - # unprotected_uris allows SSO credentials to be passed anyway. - ynh_app_setting_set "$app" unprotected_uris "/" -fi - -sudo chmod -R 777 $src_path/data - -# Reload services -sudo service nginx reload diff --git a/script/remove b/script/remove deleted file mode 100755 index bc8bbd9..0000000 --- a/script/remove +++ /dev/null @@ -1,34 +0,0 @@ -#!/bin/bash - -# See comments in install script -app=$YNH_APP_INSTANCE_NAME - -# Source YunoHost helpers -source /usr/share/yunohost/helpers - -# Retrieve app settings -domain=$(ynh_app_setting_get "$app" domain) - -# Remove sources -sudo rm -rf /var/www/$app - -# Remove nginx configuration file -sudo rm -f /etc/nginx/conf.d/$domain.d/$app.conf - -### PHP (remove if not used) ### -# If a dedicated php-fpm process is used: -# sudo rm -f /etc/php5/fpm/pool.d/$app.conf -# sudo service php5-fpm reload -### PHP end ### - -### MySQL (remove if not used) ### -# If a MySQL database is used: -# # Drop MySQL database and user -dbname=$app -dbuser=$app -ynh_mysql_drop_db "$dbname" || true -ynh_mysql_drop_user "$dbuser" || true -### MySQL end ### - -# Reload nginx service -sudo service nginx reload