mirror of
https://github.com/YunoHost-Apps/agendav_ynh.git
synced 2024-09-03 20:36:12 +02:00
84 lines
2.8 KiB
Bash
84 lines
2.8 KiB
Bash
#!/bin/bash
|
|
|
|
# Retrieve arguments
|
|
domain=$1
|
|
path=$2
|
|
|
|
# Check domain/path availability
|
|
sudo yunohost app checkurl $domain$path -a agendav
|
|
if [[ ! $? -eq 0 ]]; then
|
|
exit 1
|
|
fi
|
|
|
|
sudo yunohost app list | python ../conf/list_installed_apps.py | grep radicale
|
|
if [[ ! $? -eq 0 ]]; then
|
|
exit 1
|
|
fi
|
|
|
|
# Generate random password
|
|
db_pwd=$(dd if=/dev/urandom bs=1 count=200 2> /dev/null | tr -c -d '[A-Za-z0-9]' | sed -n 's/\(.\{24\}\).*/\1/p')
|
|
|
|
# Use 'agendav' as database name and user
|
|
db_user=agendav
|
|
|
|
# Initialize database and store mysql password for upgrade
|
|
sudo yunohost app initdb $db_user -p $db_pwd -s $(readlink -e ../sources/sql/mysql.schema.sql)
|
|
sudo yunohost app setting agendav mysqlpwd -v $db_pwd
|
|
|
|
# Copy files to the right place
|
|
final_path=/var/www/agendav
|
|
sudo mkdir -p $final_path
|
|
sudo cp -r ../sources/* $final_path
|
|
|
|
sudo chown -R admin: $final_path
|
|
currentpath=$(pwd)
|
|
cd $final_path/web/application && ln -s ../config config && cd $currentpath
|
|
|
|
# caldav config
|
|
radicale_path=$(sudo yunohost app setting radicale path)
|
|
radicale_path=${radicale_path%/}
|
|
sed -i "s@YNH_DOMAIN@$domain@g" ../conf/caldav.php
|
|
sed -i "s@YNH_RADICALE_PATH@$radicale_path@g" ../conf/caldav.php
|
|
|
|
# database config
|
|
sed -i "s/YNH_DB_USER/$db_user/g" ../conf/database.php
|
|
sed -i "s/YNH_DB_PWD/$db_pwd/g" ../conf/database.php
|
|
sed -i "s/YNH_DB_NAME/$db_user/g" ../conf/database.php
|
|
|
|
# main config
|
|
sed -i "s@YNH_DOMAIN@$domain@g" ../conf/config.php
|
|
sed -i "s@YNH_WWW_PATH@$path@g" ../conf/config.php
|
|
logdir=/var/log/agendav
|
|
sudo mkdir -p $logdir
|
|
sudo chown www-data: $logdir
|
|
sudo chmod 755 $logdir
|
|
sed -i "s@YNH_LOG_PATH@$logdir@g" ../conf/config.php
|
|
encryptkey=$(dd if=/dev/urandom bs=1 count=200 2> /dev/null | tr -c -d 'A-Za-z0-9' | sed -n 's/\(.\{24\}\).*/\1/p')
|
|
sudo yunohost app setting agendav encryptkey -v $encryptkey
|
|
sed -i "s/YNH_ENCRYPT_KEY/$encryptkey/g" ../conf/config.php
|
|
sed -i "s@YNH_COOKIE_PREFIX@${path#/}@g" ../conf/config.php
|
|
sed -i "s/YNH_COOKIE_DOMAIN/$domain/g" ../conf/config.php
|
|
logout_redirect="https://$domain/ynhsso"
|
|
sed -i "s@YNH_LOGOUT_REDIRECT_TO@$logout_redirect@g" ../conf/config.php
|
|
lang=$(sudo bash -c "echo $LANG | cut -d '.' -f 1")
|
|
sed -i "s@YNH_LANG@$lang@g" ../conf/config.php
|
|
|
|
# copy config files
|
|
sudo cp ../conf/{config.php,database.php,caldav.php} $final_path/web/config/
|
|
|
|
# execute database shema update
|
|
sudo /var/www/agendav/bin/agendavcli dbupdate
|
|
|
|
# Set permissions to agendav directory
|
|
sudo chown -R root: $final_path
|
|
sudo find $final_path -type f | xargs sudo chmod 644
|
|
sudo find $final_path -type d | xargs sudo chmod 755
|
|
|
|
# Modify Nginx configuration file and copy it to Nginx conf directory
|
|
sed -i "s@YNH_WWW_PATH@$path@g" ../conf/nginx.conf
|
|
sed -i "s@YNH_ALIAS@$final_path/web/public@g" ../conf/nginx.conf
|
|
sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/agendav.conf
|
|
|
|
# Reload Nginx and regenerate SSOwat conf
|
|
sudo service nginx reload
|
|
sudo yunohost app ssowatconf
|