2019-02-27 23:52:47 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# IMPORT GENERIC HELPERS
|
|
|
|
#=================================================
|
|
|
|
source _common.sh
|
|
|
|
source /usr/share/yunohost/helpers
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# MANAGE SCRIPT FAILURE
|
|
|
|
#=================================================
|
|
|
|
ynh_abort_if_errors
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# RETRIEVE ARGUMENTS FROM THE MANIFEST
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
app=$YNH_APP_INSTANCE_NAME
|
2019-02-27 23:52:47 +01:00
|
|
|
domain=$YNH_APP_ARG_DOMAIN
|
|
|
|
path_url=$YNH_APP_ARG_PATH
|
|
|
|
admin=$YNH_APP_ARG_ADMIN
|
2019-08-07 12:50:25 +02:00
|
|
|
admin_password=$YNH_APP_ARG_PASSWORD
|
2019-02-27 23:52:47 +01:00
|
|
|
is_public=$YNH_APP_ARG_IS_PUBLIC
|
|
|
|
language=$YNH_APP_ARG_LANGUAGE
|
|
|
|
password=$YNH_APP_ARG_PASSWORD
|
2019-07-27 22:09:37 +02:00
|
|
|
wiki_name=$YNH_APP_ARG_WIKI_NAME
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# CHECK IF THE APP CAN BE INSTALLED WITH THESE ARGS
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Validating installation parameters..." --weight=1
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
final_path=/var/www/$app
|
|
|
|
test ! -e "$final_path" || ynh_die "This path already contains a folder"
|
|
|
|
|
|
|
|
path_url=$(ynh_normalize_url_path $path_url)
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_webpath_register --app=$app --domain=$domain --path_url=$path_url
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
# GENERATE LDAP USER SETTINGS
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Generating dedicated LDAP user credentials..." --weight=2
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ldap_user="${app}_ldap"
|
|
|
|
ldap_password=$(ynh_string_random --length=8)
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
# STORE SETTINGS FROM MANIFEST
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Storing installation settings..." --weight=1
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=domain --value=$domain
|
|
|
|
ynh_app_setting_set --app=$app --key=path --value=$path_url
|
|
|
|
ynh_app_setting_set --app=$app --key=admin --value=$admin
|
2019-08-07 12:50:25 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=admin_password --value=$admin_password
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=is_public --value=$is_public
|
|
|
|
ynh_app_setting_set --app=$app --key=language --value=$language
|
|
|
|
ynh_app_setting_set --app=$app --key=wiki_name --value=$wiki_name
|
|
|
|
ynh_app_setting_set --app=$app --key=ldap_user --value=$ldap_user
|
|
|
|
ynh_app_setting_set --app=$app --key=ldap_password --value=$ldap_password
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# INSTALL DEPENDENCIES
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Installing dependencies..." --weight=10
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_install_app_dependencies $pkg_dependencies
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# CREATE A MYSQL DATABASE
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Creating a MySQL database..." --weight=3
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
db_name=$(ynh_sanitize_dbid $app)
|
2019-07-27 22:09:37 +02:00
|
|
|
db_user=$db_name
|
|
|
|
|
|
|
|
ynh_app_setting_set --app=$app --key=db_name --value=$db_name
|
|
|
|
ynh_app_setting_set --app=$app --key=db_user --value=$db_user
|
|
|
|
|
|
|
|
ynh_mysql_setup_db --db_user=$db_user --db_name=$db_name
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# DOWNLOAD, CHECK AND UNPACK SOURCE
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Setting up source files..." --weight=4
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=final_path --value=$final_path
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_setup_source --dest_dir="$final_path"
|
|
|
|
ynh_setup_source --dest_dir="$final_path/extensions/" --source_id="ldap_provider"
|
|
|
|
ynh_setup_source --dest_dir="$final_path/extensions/" --source_id="pluggable_auth"
|
|
|
|
ynh_setup_source --dest_dir="$final_path/extensions/" --source_id="ldap_authentication2"
|
|
|
|
|
|
|
|
# Note(decentral1se): Disabled and unused for now ...
|
|
|
|
# ynh_setup_source --dest_dir="$final_path/extensions/" --source_id="ldap_groups"
|
|
|
|
# ynh_setup_source --dest_dir="$final_path/extensions/" --source_id="ldap_userinfo"
|
|
|
|
# ynh_setup_source --dest_dir="$final_path/extensions/" --source_id="ldap_authorization"
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# NGINX CONFIGURATION
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Configuring nginx web server..." --weight=2
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
ynh_add_nginx_config
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# CREATE DEDICATED USER
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Configuring system user..." --weight=1
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
ynh_system_user_create $app
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# PHP-FPM CONFIGURATION
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Configuring PHP-FPM..." --weight=1
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
ynh_add_fpm_config
|
|
|
|
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
# CREATING DEDICATED LDAP USER
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Creating dedicated LDAP user..." --weight=20
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
yunohost user create $ldap_user --firstname "MediaWikiLdap" --lastname "MediaWikiLdap" --mail ${ldap_user}@$domain --password $ldap_password -q 0
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
# PUBLIC ACCESS HANDLING
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=skipped_uris --value="/"
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
if [ $is_public -eq 0 ]
|
|
|
|
then
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_app_setting_delete --app=$app --key=skipped_uris
|
2014-05-07 02:18:48 +02:00
|
|
|
fi
|
|
|
|
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
# RUN INSTALLATION OF MEDIAWIKI
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-02-28 22:45:05 +01:00
|
|
|
if [ "$path_url" = "/" ]; then
|
2019-07-27 22:09:37 +02:00
|
|
|
scriptpath=""
|
2019-02-28 22:45:05 +01:00
|
|
|
else
|
2019-07-27 22:09:37 +02:00
|
|
|
scriptpath=$path_url
|
2019-02-28 22:45:05 +01:00
|
|
|
fi
|
|
|
|
|
2019-02-27 23:52:47 +01:00
|
|
|
php $final_path/maintenance/install.php --conf $final_path \
|
2019-07-27 22:09:37 +02:00
|
|
|
--server "https://$domain" \
|
|
|
|
--scriptpath "$scriptpath" \
|
|
|
|
--dbuser $db_name \
|
|
|
|
--dbpass $db_pwd \
|
|
|
|
--dbname $db_name \
|
|
|
|
--dbprefix "mdk_" \
|
|
|
|
--lang $language \
|
2019-08-07 12:50:25 +02:00
|
|
|
--pass $admin_password \
|
2019-07-27 22:09:37 +02:00
|
|
|
$wiki_name $admin
|
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# REPLACE CONFIGURATION SETTINGS
|
|
|
|
#=================================================
|
|
|
|
cp ../conf/LocalSettings.php $final_path/LocalSettings.php
|
|
|
|
|
|
|
|
ynh_replace_string --match_string="__WIKI_NAME__" --replace_string="$wiki_name" --target_file="$final_path/LocalSettings.php"
|
|
|
|
ynh_replace_string --match_string="__ADMIN__" --replace_string="$admin" --target_file="$final_path/LocalSettings.php"
|
|
|
|
|
|
|
|
if [ $path_url = "/" ]; then
|
|
|
|
# MediaWiki expects a "" for the root URL which is typically assumed to be
|
|
|
|
# "/" by other application packages. Therefore, we assume end-users will do
|
|
|
|
# this as well and make sure to ensure an "" in all cases where "/" is
|
|
|
|
# specified
|
|
|
|
ynh_replace_string --match_string="__PATH__" --replace_string="" --target_file="$final_path/LocalSettings.php"
|
|
|
|
else
|
|
|
|
ynh_replace_string --match_string="__PATH__" --replace_string="$path_url" --target_file="$final_path/LocalSettings.php"
|
|
|
|
fi
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_replace_string --match_string="__DOMAIN__" --replace_string="$domain" --target_file="$final_path/LocalSettings.php"
|
|
|
|
ynh_replace_string --match_string="__DB_NAME__" --replace_string="$db_name" --target_file="$final_path/LocalSettings.php"
|
|
|
|
ynh_replace_string --match_string="__DB_USER__" --replace_string="$db_name" --target_file="$final_path/LocalSettings.php"
|
|
|
|
ynh_replace_string --match_string="__DB_PWD__" --replace_string="$db_pwd" --target_file="$final_path/LocalSettings.php"
|
|
|
|
ynh_replace_string --match_string="__LANGUAGE__" --replace_string="$language" --target_file="$final_path/LocalSettings.php"
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
secret=$(ynh_string_random 64)
|
|
|
|
ynh_app_setting_set $app secret $secret
|
|
|
|
ynh_replace_string --match_string="__SECRET__" --replace_string="$secret" --target_file="$final_path/LocalSettings.php"
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_replace_string --match_string="__LDAP_USER__" --replace_string="$ldap_user" --target_file="$final_path/LocalSettings.php"
|
|
|
|
ynh_replace_string --match_string="__LDAP_PASSWORD__" --replace_string="$ldap_password" --target_file="$final_path/LocalSettings.php"
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
php $final_path/maintenance/update.php
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
# SECURE FILES AND DIRECTORIES AND SSOwat
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Configuring SSOwat..." --weight=1
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
chown -R $app:$app $final_path
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
if [ $is_public -eq 1 ]
|
|
|
|
then
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_app_setting_set --app=$app --key=unprotected_uris --value="/"
|
2014-05-09 03:39:33 +02:00
|
|
|
fi
|
|
|
|
|
2019-02-27 23:52:47 +01:00
|
|
|
#=================================================
|
|
|
|
# RELOAD NGINX
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Reloading nginx web server..." --weight=1
|
2019-02-27 23:52:47 +01:00
|
|
|
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_systemd_action --service_name=nginx --action=reload
|
2019-02-27 23:52:47 +01:00
|
|
|
|
|
|
|
#=================================================
|
|
|
|
# END OF SCRIPT
|
|
|
|
#=================================================
|
2019-07-27 22:09:37 +02:00
|
|
|
ynh_script_progression --message="Installation of $app completed" --last
|