From 83221cebaf1d38b09d2211eaed834cce01aa466b Mon Sep 17 00:00:00 2001 From: Anmol Date: Sat, 1 Jul 2017 23:24:37 +0530 Subject: [PATCH] renamed script to scripts --- scripts/install | 110 ++++++++++++++++++++++++++++++++++++++++++++++++ scripts/remove | 34 +++++++++++++++ 2 files changed, 144 insertions(+) create mode 100755 scripts/install create mode 100755 scripts/remove diff --git a/scripts/install b/scripts/install new file mode 100755 index 0000000..d780484 --- /dev/null +++ b/scripts/install @@ -0,0 +1,110 @@ +#!/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/scripts/remove b/scripts/remove new file mode 100755 index 0000000..bc8bbd9 --- /dev/null +++ b/scripts/remove @@ -0,0 +1,34 @@ +#!/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