1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/agendav_ynh.git synced 2024-09-03 20:36:12 +02:00
agendav_ynh/scripts/install
2014-05-31 14:56:15 +02:00

91 lines
3.1 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
echo "Error : $domain$path is not available"
exit 1
fi
sudo yunohost app list --json | grep -q '"id": "radicale"'
if [[ ! $? -eq 0 ]]; then
echo "Error : Radicale app is not installed"
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/yunohost/sso"
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
timezone=$(cat /etc/timezone)
sed -i "s@YNH_TIMEZONE@$timezone@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
nginxconf=/etc/nginx/conf.d/$domain.d/agendav.conf
sudo cp ../conf/nginx.conf $nginxconf
sudo chown root: $nginxconf
sudo chmod 600 $nginxconf
# Reload Nginx and regenerate SSOwat conf
sudo service nginx reload
sudo yunohost app ssowatconf