1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/rainloop_ynh.git synced 2024-09-03 20:16:18 +02:00

- mise a jour de l'install

- ajout nouveau sso
- install et activation du plugins ynh
This commit is contained in:
Djip007 2015-10-21 20:23:50 +02:00
parent 9fc87828fb
commit a7266f08d9
4 changed files with 85 additions and 25 deletions

View file

@ -1,9 +1,27 @@
<?php <?php
function arguments($argv) {
$_ARG = array();
foreach ($argv as $arg) {
if (ereg('--([^=]+)=(.*)',$arg,$reg)) {
$_ARG[$reg[1]] = $reg[2];
} elseif(ereg('^-([a-zA-Z0-9])',$arg,$reg)) {
$_ARG[$reg[1]] = 'true';
} else {
$_ARG['input'][]=$arg;
}
}
return $_ARG;
}
// get args:
$args = arguments($argv);
$_ENV['RAINLOOP_INCLUDE_AS_API'] = true; $_ENV['RAINLOOP_INCLUDE_AS_API'] = true;
include '/var/www/rainloop/app/index.php'; include $args['index'];
$oConfig = \RainLoop\Api::Config(); $oConfig = \RainLoop\Api::Config();
$oConfig->SetPassword('ADMINPASSWORD'); $oConfig->SetPassword($args['pwd']);
echo $oConfig->Save() ? 'Admin password updated' : 'Admin password not updated'; echo $oConfig->Save() ? 'Admin password updated' : 'Admin password not updated';
?> ?>

View file

@ -135,10 +135,10 @@ sign_me_auto = "DefaultOff"
[plugins] [plugins]
; Enable plugin support ; Enable plugin support
enable = Off enable = On
; List of enabled plugins ; List of enabled plugins
enabled_list = "" enabled_list = "ynh-login-mapping"
[defaults] [defaults]
; Editor mode used by default (Plain, Html, HtmlForced or PlainForced) ; Editor mode used by default (Plain, Html, HtmlForced or PlainForced)

View file

@ -41,7 +41,8 @@ sudo yunohost app setting rainloop mysqlpwd -v $db_pwd
# Copy files to the right place # Copy files to the right place
final_path=/var/www/$app final_path=/var/www/$app
rainloop_path=${final_path}/app #rainloop_path=${final_path}/app
rainloop_path=${final_path}
sudo rm -rf $final_path sudo rm -rf $final_path
sudo mkdir -p $final_path sudo mkdir -p $final_path
@ -54,54 +55,63 @@ sudo rm $rainloop_path/rainloop.zip
# Autoconfig # Autoconfig
sudo mkdir -p $rainloop_path/data/_data_/_default_/configs/ sudo mkdir -p $rainloop_path/data/_data_/_default_/configs/
sed -i "s@domain.tld@$domain@g" ../conf/data/configs/application.ini application_file=$rainloop_path/data/_data_/_default_/configs/application.ini
sed -i "s@MYSQLUSER@db_user@g" ../conf/data/configs/application.ini
sed -i "s@MYSQLPASSWORD@$db_pwd@g" ../conf/data/configs/application.ini
if [ $(echo $LANG | cut -c1-2) == "fr" ] if [ $(echo $LANG | cut -c1-2) == "fr" ]
then then
lang=fr lang=fr
else else
lang=en lang=en
fi fi
sed -i "s@LANGTOCHANGE@$lang@g" ../conf/data/configs/application.ini sudo cp ../conf/data/configs/application.ini $application_file
sudo cp ../conf/data/configs/application.ini $rainloop_path/data/_data_/_default_/configs/application.ini sudo sed -i "s@domain.tld@$domain@g" $application_file
sudo sed -i "s@MYSQLUSER@db_user@g" $application_file
sudo sed -i "s@MYSQLPASSWORD@$db_pwd@g" $application_file
sudo sed -i "s@LANGTOCHANGE@$lang@g" $application_file
# Set admin password # Set admin password
sed -i "s@ADMINPASSWORD@$password@g" ../conf/config.php sudo php ../conf/config.php --index="$rainloop_path/index.php" --password="$password"
sudo php ../conf/config.php
# Add default domain configs by looping through all the domains already added # Add default domain configs by looping through all the domains already added
sudo mkdir -p $rainloop_path/data/_data_/_default_/domains/ sudo mkdir -p $rainloop_path/data/_data_/_default_/domains/
sudo yunohost domain list | sed -e '1d' | while read -r line ; do sudo yunohost domain list | sed -e '1d' | while read -r line ; do
domain=${line//- } domain=${line//- }
sed -i "s@domain.tld@$domain@g" ../conf/data/domains/domain.tld.ini
sudo cp ../conf/data/domains/domain.tld.ini $rainloop_path/data/_data_/_default_/domains/$domain.ini sudo cp ../conf/data/domains/domain.tld.ini $rainloop_path/data/_data_/_default_/domains/$domain.ini
sed -i "s@$domain@domain.tld@g" ../conf/data/domains/domain.tld.ini sudo sed -i "s@domain.tld@$domain@g" $rainloop_path/data/_data_/_default_/domains/$domain.ini
done done
sudo cp ../conf/data/domains/disabled $rainloop_path/data/_data_/_default_/domains/disabled sudo cp ../conf/data/domains/disabled $rainloop_path/data/_data_/_default_/domains/disabled
# now install ynh plugins:
sudo mkdir -p $rainloop_path/data/_data_/_default_/plugins
sudo cp -rf ../sources/plugins/ynh-login-mapping $rainloop_path/data/_data_/_default_/plugins/.
# Hooks for domains are not implemented yet, so new domains will not be added automatically # Hooks for domains are not implemented yet, so new domains will not be added automatically
# SSO # SSO
sed -i "s@domain.tld@$domain@g" ../conf/sso.php #sudo cp ../conf/sso.php $final_path/index.php
sed -i "s@PATHTOCHANGE@$path@g" ../conf/sso.php sudo cp ../sources/sso/index.php $final_path/index.php
sudo cp ../conf/sso.php $final_path/index.php sudo cp ../sources/sso/index.php $final_path/index.php
sudo sed -i "s@domain.tld@$domain@g" $final_path/index.php
sudo sed -i "s@PATHTOCHANGE@$path@g" $final_path/index.php
# Set permissions to rainloop directory # Set permissions to rainloop directory
# sudo mkdir -p $final_path/logs # sudo mkdir -p $final_path/logs
sudo chown -R www-data:www-data $final_path sudo chown -R www-data:www-data $final_path
# Modify Nginx configuration file and copy it to Nginx conf directory # Modify Nginx configuration file and copy it to Nginx conf directory
sed -i "s@PATHTOCHANGE@$path@g" ../conf/nginx.conf nginx_conf_file=/etc/nginx/conf.d/$domain.d/$app.conf
sed -i "s@ALIASTOCHANGE@$final_path/@g" ../conf/nginx.conf sudo cp ../conf/nginx.conf $nginx_conf_file
sed -i "s@NAMETOCHANGE@$app@g" ../conf/nginx.conf sudo sed -i "s@PATHTOCHANGE@$path@g" $nginx_conf_file
sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/$app.conf sudo sed -i "s@ALIASTOCHANGE@$final_path/@g" $nginx_conf_file
sudo sed -i "s@NAMETOCHANGE@$app@g" $nginx_conf_file
sudo chown root: $nginx_conf_file
sudo chmod 644 $nginx_conf_file
sed -i "s@NAMETOCHANGE@$app@g" ../conf/php-fpm.conf
finalphpconf=/etc/php5/fpm/pool.d/$app.conf finalphpconf=/etc/php5/fpm/pool.d/$app.conf
sudo cp ../conf/php-fpm.conf $finalphpconf sudo cp ../conf/php-fpm.conf $finalphpconf
sudo chown root: $finalphpconf sudo sed -i "s@NAMETOCHANGE@$app@g" $finalphpconf
sudo chmod 644 $finalphpconf sudo chown root: $finalphpconf
sudo chmod 644 $finalphpconf
# Make app public if necessary # Make app public if necessary
sudo yunohost app setting $app is_public -v "$is_public" sudo yunohost app setting $app is_public -v "$is_public"

32
sources/sso/index.php Normal file
View file

@ -0,0 +1,32 @@
<?php
if (!defined('APP_VERSION')) {
define('APP_VERSION', '1.9.3.363');
define('APP_INDEX_ROOT_FILE', __FILE__);
define('APP_INDEX_ROOT_PATH', str_replace('\\', '/', rtrim(dirname(__FILE__), '\\/').'/'));
}
if(isset($_GET["auto_log"])) {
$_ENV['RAINLOOP_INCLUDE_AS_API'] = true;
}
if (file_exists(APP_INDEX_ROOT_PATH.'rainloop/v/'.APP_VERSION.'/include.php')) {
include APP_INDEX_ROOT_PATH.'rainloop/v/'.APP_VERSION.'/include.php';
} else {
echo '[105] Missing version directory';
exit(105);
}
if(isset($_GET["auto_log"])) {
if (isset($_SERVER['HTTP_EMAIL']) && isset($_SERVER['PHP_AUTH_PW'])) {
$email = $_SERVER['HTTP_EMAIL'];
$password = $_SERVER['PHP_AUTH_PW'];
$ssoHash = \RainLoop\Api::GetUserSsoHash($email, $password);
// redirect to webmail sso url
\header('Location: https://domain.tldPATHTOCHANGE/index.php?sso&hash='.$ssoHash);
}
exit();
}
?>