|
| 1 | +#!/usr/bin/env bash |
| 2 | + |
| 3 | +# Copyright (c) 2021-2025 community-scripts ORG |
| 4 | +# Author: bvdberg01 |
| 5 | +# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE |
| 6 | + |
| 7 | +source /dev/stdin <<< "$FUNCTIONS_FILE_PATH" |
| 8 | +color |
| 9 | +verb_ip6 |
| 10 | +catch_errors |
| 11 | +setting_up_container |
| 12 | +network_check |
| 13 | +update_os |
| 14 | + |
| 15 | +msg_info "Installing Dependencies" |
| 16 | +$STD apt-get install -y \ |
| 17 | + curl \ |
| 18 | + sudo \ |
| 19 | + mc \ |
| 20 | + postgresql \ |
| 21 | + apache2 \ |
| 22 | + libapache2-mod-php \ |
| 23 | + php-{pgsql,dom} |
| 24 | +msg_ok "Installed Dependencies" |
| 25 | + |
| 26 | +msg_info "Setting up PostgreSQL" |
| 27 | +DB_NAME=baikal |
| 28 | +DB_USER=baikal |
| 29 | +DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13) |
| 30 | +$STD sudo -u postgres psql -c "CREATE ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';" |
| 31 | +$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER TEMPLATE template0;" |
| 32 | +{ |
| 33 | +echo "Baikal Credentials" |
| 34 | +echo "Baikal Database User: $DB_USER" |
| 35 | +echo "Baikal Database Password: $DB_PASS" |
| 36 | +echo "Baikal Database Name: $DB_NAME" |
| 37 | +} >> ~/baikal.creds |
| 38 | +msg_ok "Set up PostgreSQL" |
| 39 | + |
| 40 | +msg_info "Installing Baikal" |
| 41 | +RELEASE=$(curl -s https://api.github.com/repos/sabre-io/Baikal/releases/latest | grep "tag_name" | awk '{print substr($2, 2, length($2)-3) }') |
| 42 | +cd /opt |
| 43 | +wget -q "https://github.com/sabre-io/baikal/releases/download/${RELEASE}/baikal-${RELEASE}.zip" |
| 44 | +unzip -q "baikal-${RELEASE}.zip" |
| 45 | +cat <<EOF >/opt/baikal/config/baikal.yaml |
| 46 | +database: |
| 47 | + backend: pgsql |
| 48 | + pgsql_host: localhost |
| 49 | + pgsql_dbname: $DB_NAME |
| 50 | + pgsql_username: $DB_USER |
| 51 | + pgsql_password: $DB_PASS |
| 52 | +EOF |
| 53 | +chown -R www-data:www-data /opt/baikal/ |
| 54 | +chmod -R 755 /opt/baikal/ |
| 55 | +echo "${RELEASE}" >/opt/${APPLICATION}_version.txt |
| 56 | +msg_ok "Installed Baikal" |
| 57 | + |
| 58 | +msg_info "Creating Service" |
| 59 | +cat <<EOF > /etc/apache2/sites-available/baikal.conf |
| 60 | +<VirtualHost *:80> |
| 61 | + ServerName baikal |
| 62 | + DocumentRoot /opt/baikal/html |
| 63 | +
|
| 64 | + RewriteEngine on |
| 65 | + RewriteRule /.well-known/carddav /dav.php [R=308,L] |
| 66 | + RewriteRule /.well-known/caldav /dav.php [R=308,L] |
| 67 | + RewriteCond %{REQUEST_URI} ^/dav.php$ [NC] |
| 68 | + RewriteRule ^(.*)$ /dav.php/ [R=301,L] |
| 69 | + |
| 70 | + <Directory /opt/baikal/html> |
| 71 | + Options FollowSymLinks |
| 72 | + AllowOverride All |
| 73 | + Require all granted |
| 74 | + </Directory> |
| 75 | +
|
| 76 | + <IfModule mod_expires.c> |
| 77 | + ExpiresActive Off |
| 78 | + </IfModule> |
| 79 | +
|
| 80 | + ErrorLog /var/log/apache2/baikal_error.log |
| 81 | + CustomLog /var/log/apache2/baikal_access.log combined |
| 82 | +</VirtualHost> |
| 83 | +EOF |
| 84 | +$STD a2ensite baikal |
| 85 | +$STD a2enmod rewrite |
| 86 | +$STD a2dissite 000-default.conf |
| 87 | +$STD systemctl reload apache2 |
| 88 | +msg_ok "Created Service" |
| 89 | + |
| 90 | +motd_ssh |
| 91 | +customize |
| 92 | + |
| 93 | +msg_info "Cleaning up" |
| 94 | +rm -rf "/opt/baikal-${RELEASE}.zip" |
| 95 | +$STD apt-get -y autoremove |
| 96 | +$STD apt-get -y autoclean |
| 97 | +msg_ok "Cleaned" |
0 commit comments