2017-04-07 23:28:30 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# GENERIC STARTING
|
|
|
|
#=================================================
|
|
|
|
# IMPORT GENERIC HELPERS
|
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
source _common.sh
|
2017-04-07 23:28:30 +02:00
|
|
|
source /usr/share/yunohost/helpers
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# MANAGE FAILURE OF THE SCRIPT
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
ynh_abort_if_errors # Active trap pour arrêter le script si une erreur est détectée.
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# RETRIEVE ARGUMENTS FROM THE MANIFEST
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
domain=$YNH_APP_ARG_DOMAIN
|
|
|
|
is_public=$YNH_APP_ARG_IS_PUBLIC
|
2017-07-23 17:46:25 +02:00
|
|
|
path_url=$YNH_APP_ARG_PATH
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
app=$YNH_APP_INSTANCE_NAME
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# CHECK IF THE APP CAN BE INSTALLED WITH THIS ARGS
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
if sudo yunohost domain list | grep -q $domain # Vérifie la liste des domaines
|
|
|
|
then # Si le domaine existe dans Yunohost
|
|
|
|
if sudo yunohost app map | grep -q $domain # Vérifie la liste des apps par domaine
|
|
|
|
then # Si une app est installée sur ce domaine.
|
2017-07-23 17:46:25 +02:00
|
|
|
WARNING echo "An app is already installed on the domain $domain. cryptpad needs a whole domain or subdomain to himself."
|
2017-04-07 23:28:30 +02:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2017-07-30 21:33:17 +02:00
|
|
|
path_url=$(ynh_normalize_url_path $path_url) # Check and normalize path
|
2017-04-07 23:28:30 +02:00
|
|
|
CHECK_DOMAINPATH # Vérifie la disponibilité du path et du domaine.
|
|
|
|
CHECK_FINALPATH # Vérifie que le dossier de destination n'est pas déjà utilisé.
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# STORE SETTINGS FROM MANIFEST
|
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
ynh_app_setting_set $app domain "$domain"
|
|
|
|
ynh_app_setting_set $app is_public "$is_public"
|
|
|
|
ynh_app_setting_set $app path_url "$path_url"
|
2017-07-25 00:26:36 +02:00
|
|
|
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
# STANDARD MODIFICATIONS
|
|
|
|
#=================================================
|
|
|
|
# FIND AND OPEN A PORT
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
port=$(ynh_find_port 3000) # Cherche un port libre.
|
|
|
|
ynh_app_setting_set $app port $port
|
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
# INSTALL NODEJS
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
2017-07-25 00:26:36 +02:00
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
ynh_install_nodejs $NODEJS_VERSION
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
# CREATE DEDICATED USER
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
ynh_system_user_create $app
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
# SPECIFIC SETUP
|
|
|
|
#=================================================
|
|
|
|
# HANDLE LOG FILES AND LOGROTATE
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
# Créer le dossier de log
|
|
|
|
sudo mkdir -p /var/log/$app
|
|
|
|
sudo touch /var/log/$app/$app.log
|
|
|
|
sudo chown $app -R /var/log/$app
|
2017-04-07 23:28:30 +02:00
|
|
|
|
2017-07-30 21:33:17 +02:00
|
|
|
# Setup logrotate
|
2017-07-23 17:46:25 +02:00
|
|
|
ynh_use_logrotate
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
# DOWNLOAD, CHECK AND UNPACK SOURCE
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
final_path=/var/www/$app
|
|
|
|
ynh_app_setting_set $app final_path $final_path
|
2017-07-23 22:53:29 +02:00
|
|
|
ynh_setup_source $final_path
|
2017-04-07 23:28:30 +02:00
|
|
|
|
2017-07-25 08:25:22 +02:00
|
|
|
# Set files ownership during installation
|
2017-07-23 17:46:25 +02:00
|
|
|
sudo chown $app: $final_path -R
|
|
|
|
sudo chmod 755 $final_path -R
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
# Modify Nginx configuration file and copy it to Nginx conf directory
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
|
|
|
|
ynh_nginx_config
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# ADD SYSTEMD SERVICE
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
ynh_replace_string "__NODE__" "$nodejs_path" "../conf/systemd.service"
|
2017-07-25 00:26:36 +02:00
|
|
|
ynh_replace_string "__NODEJS__" "$nodejs_use_version" "../conf/systemd.service"
|
|
|
|
ynh_replace_string "__ENV_PATH__" "$PATH" "../conf/systemd.service"
|
2017-07-23 17:46:25 +02:00
|
|
|
ynh_systemd_config
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 00:14:35 +02:00
|
|
|
# INSTALL CRYPTPAD
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
|
|
|
script_dir="$PWD"
|
2017-07-23 17:46:25 +02:00
|
|
|
pushd "$final_path"
|
|
|
|
sudo chown -R $app: $final_path
|
|
|
|
sudo_path npm install
|
|
|
|
sudo_path npm install -g bower
|
|
|
|
sudo su -l $app -s /bin/bash -c "cd $final_path && env PATH=$PATH bower install"
|
2017-04-08 00:38:52 +02:00
|
|
|
popd
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
2017-04-08 00:00:54 +02:00
|
|
|
# CONFIGURE SERVER.JS
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
2017-08-01 22:19:08 +02:00
|
|
|
# Copy default configuration file
|
|
|
|
sudo mv "$final_path/config.example.js" "$final_path/config.js"
|
|
|
|
|
|
|
|
# Set service port
|
|
|
|
ynh_replace_string "httpPort: 3000" "httpPort: $port" "$final_path/config.js"
|
|
|
|
# Tune CSP to allow for YunoHost tile
|
|
|
|
ynh_replace_string "\"script-src 'self'\"" "\"script-src 'self' 'unsafe-eval'\"" "$final_path/config.js"
|
|
|
|
# Remove donate button
|
|
|
|
ynh_replace_string "removeDonateButton: false" "removeDonateButton: true" "$final_path/config.js"
|
|
|
|
# Disable analytics unsolicited communications
|
|
|
|
ynh_replace_string "adminEmail: 'i.did.not.read.my.config@cryptpad.fr'" "adminEmail: false" "$final_path/config.js"
|
|
|
|
|
|
|
|
# Store file checksum to detected user modifications on upgrade
|
|
|
|
ynh_store_file_checksum "$final_path/config.js"
|
2017-04-08 00:00:54 +02:00
|
|
|
|
2017-07-25 08:25:22 +02:00
|
|
|
#=================================================
|
|
|
|
# SET FILES OWNERSHIP
|
|
|
|
#=================================================
|
|
|
|
|
2017-07-25 14:23:58 +02:00
|
|
|
sudo chown -R root: $final_path
|
|
|
|
sudo mkdir $final_path/datastore $final_path/pins $final_path/blob $final_path/blobstage
|
|
|
|
sudo chown -R $app: $final_path/datastore $final_path/pins $final_path/blob $final_path/blobstage
|
2017-07-25 08:25:22 +02:00
|
|
|
|
2017-04-08 00:00:54 +02:00
|
|
|
#=================================================
|
|
|
|
# INSTALL MODULES FOR CRYPTPAD
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
#npm install cryptpad-level-store;
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# ENABLE SERVICE IN ADMIN PANEL
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
# Ajoute le service au monitoring de Yunohost.
|
2017-07-23 17:46:25 +02:00
|
|
|
sudo yunohost service add $app --log "/var/log/$app/$app.log"
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
# START CRYPTPAD IN BACKGROUND
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
sudo systemctl start $app
|
2017-04-07 23:28:30 +02:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# SETUP SSOWAT
|
|
|
|
#=================================================
|
|
|
|
|
2017-07-23 17:46:25 +02:00
|
|
|
if [ $is_public -eq 1 ];
|
2017-04-07 23:28:30 +02:00
|
|
|
then
|
|
|
|
ynh_app_setting_set "$app" unprotected_uris "/"
|
|
|
|
fi
|
|
|
|
|
2018-04-16 20:20:35 +02:00
|
|
|
#=================================================
|
|
|
|
# App need to sleep
|
|
|
|
#=================================================
|
|
|
|
|
|
|
|
sleep 30
|
|
|
|
|
2017-04-07 23:28:30 +02:00
|
|
|
#=================================================
|
|
|
|
# RELOAD NGINX
|
|
|
|
#=================================================
|
2017-07-23 17:46:25 +02:00
|
|
|
|
2018-04-16 20:21:45 +02:00
|
|
|
systemctl reload nginx
|
|
|
|
systemctl cryptpad status
|