mirror of
https://github.com/YunoHost-Apps/movim_ynh.git
synced 2024-09-03 19:46:19 +02:00
[enh] Make use of YunoHost helpers coming with v2.4
This commit is contained in:
parent
33be7722bf
commit
115b7cb7fb
4 changed files with 95 additions and 93 deletions
|
@ -17,6 +17,9 @@
|
||||||
"mysql",
|
"mysql",
|
||||||
"metronome"
|
"metronome"
|
||||||
],
|
],
|
||||||
|
"requirements": {
|
||||||
|
"yunohost": ">= 2.4.0"
|
||||||
|
},
|
||||||
"multi_instance": "false",
|
"multi_instance": "false",
|
||||||
"arguments": {
|
"arguments": {
|
||||||
"install" : [
|
"install" : [
|
||||||
|
|
|
@ -1,9 +1,13 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
|
||||||
|
# Exit on command errors and treat unset variables as an error
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
app="movim"
|
||||||
|
|
||||||
# Retrieve arguments
|
# Retrieve arguments
|
||||||
domain=$1
|
domain=$1
|
||||||
path=$2
|
path=${2:-/}
|
||||||
admin=$3
|
admin=$3
|
||||||
password=$4
|
password=$4
|
||||||
language=$5
|
language=$5
|
||||||
|
@ -11,73 +15,60 @@ ssoenabled=$6
|
||||||
port=$7
|
port=$7
|
||||||
timezone=`cat /etc/timezone`
|
timezone=`cat /etc/timezone`
|
||||||
|
|
||||||
|
# Source YunoHost helpers
|
||||||
|
source /usr/share/yunohost/helpers
|
||||||
|
|
||||||
# Check domain/path availability
|
# Check domain/path availability
|
||||||
sudo yunohost app checkurl $domain$path -a movim
|
sudo yunohost app checkurl "${domain}${path}" -a "$app" \
|
||||||
if [[ ! $? -eq 0 ]]; then
|
|| exit 1
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check port availability
|
# Check port availability
|
||||||
sudo yunohost app checkport $port
|
sudo yunohost app checkport "$port" \
|
||||||
if [[ ! $? -eq 0 ]]; then
|
|| exit 1
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check user availability
|
# Check user availability
|
||||||
sudo yunohost user info $admin
|
ynh_user_exists "$admin" \
|
||||||
if [[ ! $? -eq 0 ]]; then
|
|| ynh_die "The chosen admin user does not exist."
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check password not empty
|
# Check password not empty
|
||||||
if [[ -z "$password" ]]; then
|
[[ -n "$password" ]] \
|
||||||
printf "Error empty admin password, installation aborted"
|
|| ynh_die "You must set an admin password."
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check timezone
|
# Check timezone
|
||||||
if [[ -z "$timezone" ]]; then
|
[[ -n "$timezone" ]] \
|
||||||
printf "Could not detect Timezone, please check /etc/timezone. Installation aborted"
|
|| ynh_die "Could not detect timezone, please check /etc/timezone." \
|
||||||
exit 1
|
&& echo "Detected timezone: $timezone"
|
||||||
else
|
|
||||||
printf "Detected Timezone $timezone \n"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check path not empty
|
# Save app settings
|
||||||
if [[ -z "$path" ]]; then
|
ynh_app_setting_set "$app" admin "$admin"
|
||||||
printf "Error path is empty, installation aborted"
|
ynh_app_setting_set "$app" ssoenabled "$ssoenabled"
|
||||||
exit 1
|
ynh_app_setting_set "$app" port "$port"
|
||||||
fi
|
ynh_app_setting_set "$app" path "$path"
|
||||||
|
|
||||||
# Save parameters
|
# Generate and save random MySQL password
|
||||||
sudo yunohost app setting movim admin -v $admin
|
db_pwd=$(ynh_string_random 12)
|
||||||
sudo yunohost app setting movim ssoenabled -v $ssoenabled
|
ynh_app_setting_set "$app" mysqlpwd "$db_pwd"
|
||||||
sudo yunohost app setting movim port -v $port
|
|
||||||
sudo yunohost app setting movim path -v $path
|
|
||||||
|
|
||||||
# Generate random password
|
|
||||||
db_pwd=$(dd if=/dev/urandom bs=1 count=30 2> /dev/null | tr -c -d '[[:alnum:]]')
|
|
||||||
|
|
||||||
# Use 'movim' as database name and user
|
# Use 'movim' as database name and user
|
||||||
db_user=movim
|
db_user=movim
|
||||||
|
db_name=movim
|
||||||
|
|
||||||
# Initialize database and store mysql password for upgrade
|
# Create MySQL database
|
||||||
sudo yunohost app initdb $db_user -p $db_pwd
|
ynh_mysql_create_db "$db_name" "$db_user" "$db_pwd"
|
||||||
sudo yunohost app setting movim mysqlpwd -v $db_pwd
|
|
||||||
|
|
||||||
# Install packages
|
# Install packages
|
||||||
sudo apt-get install php5-gd php5-curl php5-imagick php5-cli -y
|
ynh_package_install php5-gd php5-curl php5-imagick php5-cli
|
||||||
|
|
||||||
# Install Movim files
|
# Copy Movim source files
|
||||||
final_path=/var/www/movim
|
final_path=/var/www/movim
|
||||||
sudo mkdir -p $final_path
|
sudo cp -a ../sources "$final_path"
|
||||||
sudo cp -a ../sources/* $final_path
|
sudo cp "${final_path}/config/"{db.example.inc.php,db.inc.php}
|
||||||
sudo cp $final_path/config/db.example.inc.php $final_path/config/db.inc.php
|
|
||||||
|
|
||||||
# Create movim system user and set permissions
|
# Create movim system user and set permissions
|
||||||
sudo useradd -d /var/www/movim -s /bin/sh movim
|
sudo useradd -d /var/www/movim -s /bin/sh movim
|
||||||
sudo chown -R movim:www-data $final_path
|
sudo chown -R movim:www-data "$final_path"
|
||||||
sudo chmod -R 750 $final_path
|
sudo find "${final_path}/" -type f -print0 | sudo xargs -0 chmod 0640
|
||||||
|
sudo find "${final_path}/" -type d -print0 | sudo xargs -0 chmod 0750
|
||||||
|
|
||||||
# Install PHP dependencies
|
# Install PHP dependencies
|
||||||
sudo su -c "curl -sS https://getcomposer.org/installer | php -- --install-dir=$final_path" movim
|
sudo su -c "curl -sS https://getcomposer.org/installer | php -- --install-dir=$final_path" movim
|
||||||
|
@ -126,14 +117,12 @@ sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/movim.conf
|
||||||
# SSOwat Configuration
|
# SSOwat Configuration
|
||||||
if [ $ssoenabled = "No" ];
|
if [ $ssoenabled = "No" ];
|
||||||
then
|
then
|
||||||
sudo yunohost app setting movim skipped_uris -v "/"
|
ynh_app_setting_set "$app" skipped_uris "/"
|
||||||
sudo yunohost app ssowatconf
|
|
||||||
sudo su -c "cd $final_path && php mud.php config --xmppwhitelist=$domain" movim
|
sudo su -c "cd $final_path && php mud.php config --xmppwhitelist=$domain" movim
|
||||||
else
|
else
|
||||||
sudo yunohost app setting movim unprotected_uris -v "/"
|
ynh_app_setting_set "$app" unprotected_uris "/"
|
||||||
# Next line is to avoid SSO to auto-connect just after disconnect
|
# Next line is to avoid SSO to auto-connect just after disconnect
|
||||||
sudo sed -i "s@redirect('login')@redirect('')@g" $final_path/app/controllers/DisconnectController.php
|
sudo sed -i "s@redirect('login')@redirect('')@g" $final_path/app/controllers/DisconnectController.php
|
||||||
sudo yunohost app ssowatconf
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Start Movim
|
# Start Movim
|
||||||
|
|
|
@ -1,10 +1,14 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
db_user=movim
|
app="movim"
|
||||||
db_name=movim
|
|
||||||
root_pwd=$(sudo cat /etc/yunohost/mysql)
|
|
||||||
|
|
||||||
#Stop service and remove init
|
# Source YunoHost helpers
|
||||||
|
source /usr/share/yunohost/helpers
|
||||||
|
|
||||||
|
# Retrieve app settings
|
||||||
|
domain=$(ynh_app_setting_get "$app" domain)
|
||||||
|
|
||||||
|
# Stop service and remove init
|
||||||
sudo service php5-fpm stop
|
sudo service php5-fpm stop
|
||||||
sudo /etc/init.d/movim stop
|
sudo /etc/init.d/movim stop
|
||||||
sudo systemctl stop movim.service
|
sudo systemctl stop movim.service
|
||||||
|
@ -13,13 +17,20 @@ sudo update-rc.d -f movim remove
|
||||||
sudo rm -f /etc/init.d/movim
|
sudo rm -f /etc/init.d/movim
|
||||||
sudo rm -f /lib/systemd/system/movim.service
|
sudo rm -f /lib/systemd/system/movim.service
|
||||||
|
|
||||||
#Drop database, movim files and user.
|
# Drop MySQL database and user
|
||||||
mysql -u root -p$root_pwd -e "DROP DATABASE $db_name ; DROP USER $db_user@localhost ;"
|
db_user=movim
|
||||||
sudo userdel movim
|
db_name=movim
|
||||||
|
ynh_mysql_drop_db "$db_name" || true
|
||||||
|
ynh_mysql_drop_user "$db_user" || true
|
||||||
|
|
||||||
|
# Remove Movim files and user
|
||||||
|
ynh_system_user_exists movim \
|
||||||
|
&& sudo userdel movim
|
||||||
sudo rm -rf /var/www/movim
|
sudo rm -rf /var/www/movim
|
||||||
domain=$(sudo yunohost app setting movim domain)
|
|
||||||
|
# Remove nginx and php-fpm configuration files
|
||||||
sudo rm -f /etc/nginx/conf.d/$domain.d/movim.conf
|
sudo rm -f /etc/nginx/conf.d/$domain.d/movim.conf
|
||||||
sudo rm /etc/php5/fpm/pool.d/movim.conf
|
sudo rm -f /etc/php5/fpm/pool.d/movim.conf
|
||||||
|
|
||||||
# Restarting services
|
# Restarting services
|
||||||
sudo service nginx reload
|
sudo service nginx reload
|
||||||
|
|
|
@ -1,35 +1,36 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
|
||||||
|
|
||||||
# Retrieve arguments
|
# Exit on command errors and treat unset variables as an error
|
||||||
path=$(sudo yunohost app setting movim path)
|
set -eu
|
||||||
domain=$(sudo yunohost app setting movim domain)
|
|
||||||
port=$(sudo yunohost app setting movim port)
|
app="movim"
|
||||||
public_site=$(sudo yunohost app setting movim public_site)
|
|
||||||
ssoenabled=$(sudo yunohost app setting movim ssoenabled)
|
# 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)
|
||||||
|
port=$(ynh_app_setting_get "$app" port)
|
||||||
|
ssoenabled=$(ynh_app_setting_get "$app" ssoenabled)
|
||||||
|
public_site=$(ynh_app_setting_get "$app" public_site)
|
||||||
timezone=`cat /etc/timezone`
|
timezone=`cat /etc/timezone`
|
||||||
|
|
||||||
# Check timezone
|
# Check timezone
|
||||||
if [[ -z "$timezone" ]]; then
|
[[ -n "$timezone" ]] \
|
||||||
printf "Could not detect Timezone, please check /etc/timezone. Installation aborted"
|
|| ynh_die "Could not detect timezone, please check /etc/timezone." \
|
||||||
exit 1
|
&& echo "Detected timezone: $timezone"
|
||||||
else
|
|
||||||
printf "Detected Timezone $timezone \n"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Install Movim files
|
# Copy Movim source files
|
||||||
final_path=/var/www/movim
|
final_path=/var/www/movim
|
||||||
sudo cp -a ../sources/* $final_path
|
sudo cp -a ../sources "$final_path"
|
||||||
|
|
||||||
# Create movim user if not exists and set permissions
|
# Create movim user if not exists and set permissions
|
||||||
if grep -q movim /etc/passwd; then
|
ynh_system_user_exists movim \
|
||||||
sudo chown -R movim:www-data $final_path
|
|| sudo useradd -d /var/www/movim -s /bin/sh movim
|
||||||
sudo chmod -R 750 $final_path
|
sudo chown -R movim:www-data "$final_path"
|
||||||
else
|
sudo find "${final_path}/" -type f -print0 | sudo xargs -0 chmod 0640
|
||||||
sudo useradd -s /bin/sh -d $final_path movim
|
sudo find "${final_path}/" -type d -print0 | sudo xargs -0 chmod 0750
|
||||||
sudo chown -R movim:www-data $final_path
|
|
||||||
sudo chmod -R 750 $final_path
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Update PHP dependencies
|
# Update PHP dependencies
|
||||||
sudo su -c "cd $final_path && php composer.phar config --global discard-changes true" movim
|
sudo su -c "cd $final_path && php composer.phar config --global discard-changes true" movim
|
||||||
|
@ -42,32 +43,30 @@ sudo sed -i "s@/ws/@$path/ws/@g" $final_path/app/assets/js/movim_websocket.js
|
||||||
sudo su -c "cd $final_path && php mud.php db --set" movim
|
sudo su -c "cd $final_path && php mud.php db --set" movim
|
||||||
|
|
||||||
# Reset SSO parameters
|
# Reset SSO parameters
|
||||||
sudo yunohost app setting movim protected_uris -d
|
ynh_app_setting_delete "$app" protected_uris
|
||||||
sudo yunohost app setting movim skipped_uris -d
|
ynh_app_setting_delete "$app" skipped_uris
|
||||||
sudo yunohost app clearaccess movim
|
sudo yunohost app clearaccess movim
|
||||||
|
|
||||||
# Replace old public_site variable (if exists) by ssoenabled
|
# Replace old public_site variable (if exists) by ssoenabled
|
||||||
if [ ! -z "$public_site" ] && [ $public_site = "Yes" ];
|
if [ ! -z "$public_site" ] && [ $public_site = "Yes" ];
|
||||||
then
|
then
|
||||||
sudo yunohost app setting movim public_site -d
|
ynh_app_setting_delete "$app" public_site
|
||||||
sudo yunohost app setting movim ssoenabled -v "No"
|
ynh_app_setting_set "$app" ssoenabled "No"
|
||||||
elif [ ! -z "$public_site" ] && [ $public_site = "No" ];
|
elif [ ! -z "$public_site" ] && [ $public_site = "No" ];
|
||||||
then
|
then
|
||||||
sudo yunohost app setting movim public_site -d
|
ynh_app_setting_delete "$app" public_site
|
||||||
sudo yunohost app setting movim ssoenabled -v "Yes"
|
ynh_app_setting_set "$app" ssoenabled "Yes"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# SSOwat Configuration
|
# SSOwat Configuration
|
||||||
if [ $ssoenabled = "No" ];
|
if [ $ssoenabled = "No" ];
|
||||||
then
|
then
|
||||||
sudo yunohost app setting movim skipped_uris -v "/"
|
ynh_app_setting_set "$app" skipped_uris "/"
|
||||||
sudo yunohost app ssowatconf
|
|
||||||
sudo su -c "cd $final_path && php mud.php config --xmppwhitelist=$domain" movim
|
sudo su -c "cd $final_path && php mud.php config --xmppwhitelist=$domain" movim
|
||||||
else
|
else
|
||||||
sudo yunohost app setting movim unprotected_uris -v "/"
|
ynh_app_setting_set "$app" unprotected_uris "/"
|
||||||
# Next line is to avoid SSO to auto-connect just after disconnect
|
# Next line is to avoid SSO to auto-connect just after disconnect
|
||||||
sudo sed -i "s@redirect('login')@redirect('')@g" $final_path/app/controllers/DisconnectController.php
|
sudo sed -i "s@redirect('login')@redirect('')@g" $final_path/app/controllers/DisconnectController.php
|
||||||
sudo yunohost app ssowatconf
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Update init scripts
|
# Update init scripts
|
||||||
|
|
Loading…
Add table
Reference in a new issue