148 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			148 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| # Copyright (c) 2021-2024 communtiy-scripts ORG
 | |
| # Author: MickLesk (Canbiz)
 | |
| # License: MIT
 | |
| # https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | |
| 
 | |
| source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | |
| color
 | |
| verb_ip6
 | |
| init_error_traps
 | |
| setting_up_container
 | |
| network_check
 | |
| update_os
 | |
| 
 | |
| PG_VERSION="16" setup_postgresql
 | |
| PHP_VERSION=8.3 PHP_MODULE="bcmath,bz2,cli,exif,common,curl,fpm,gd,imagick,intl,mbstring,pgsql,sqlite3,xml,xmlrpc,zip" setup_php
 | |
| NODE_VERSION=22 NODE_MODULE="yarn,npm@latest" setup_nodejs
 | |
| setup_composer
 | |
| 
 | |
| msg_info "Installing Dependencies (Patience)"
 | |
| $STD apt-get install -y \
 | |
|     nginx \
 | |
|     apt-transport-https \
 | |
|     lsb-release \
 | |
|     ffmpeg \
 | |
|     cron \
 | |
|     libapache2-mod-xsendfile \
 | |
|     libzip-dev \
 | |
|     locales \
 | |
|     libpng-dev \
 | |
|     libjpeg62-turbo-dev \
 | |
|     libpq-dev \
 | |
|     libwebp-dev
 | |
| msg_ok "Installed Dependencies"
 | |
| 
 | |
| # PG_VERSION="16" setup_postgresql
 | |
| # PHP_VERSION=8.3 PHP_MODULE="bcmath,bz2,cli,exif,common,curl,fpm,gd,imagick,intl,mbstring,pgsql,sqlite3,xml,xmlrpc,zip" setup_php
 | |
| # NODE_VERSION=22 NODE_MODULE="yarn,npm@latest" setup_nodejs
 | |
| # setup_composer
 | |
| 
 | |
| msg_info "Setting up PostgreSQL Database"
 | |
| DB_NAME=koel_db
 | |
| DB_USER=koel
 | |
| DB_PASS="$(openssl rand -base64 18 | cut -c1-13)"
 | |
| APP_SECRET=$(openssl rand -base64 32)
 | |
| $STD sudo -u postgres psql -c "CREATE ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';"
 | |
| $STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8' TEMPLATE template0;"
 | |
| $STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET client_encoding TO 'utf8';"
 | |
| $STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET default_transaction_isolation TO 'read committed';"
 | |
| $STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET timezone TO 'UTC'"
 | |
| {
 | |
|     echo "Koel-Credentials"
 | |
|     echo "Koel Database User: $DB_USER"
 | |
|     echo "Koel Database Password: $DB_PASS"
 | |
|     echo "Koel Database Name: $DB_NAME"
 | |
| } >>~/koel.creds
 | |
| msg_ok "Set up PostgreSQL Database"
 | |
| 
 | |
| msg_info "Installing Koel(Patience)"
 | |
| RELEASE=$(curl -fsSL https://github.com/koel/koel/releases/latest | grep "title>Release" | cut -d " " -f 4)
 | |
| mkdir -p /opt/koel_{media,sync}
 | |
| curl -fsSL https://github.com/koel/koel/releases/download/${RELEASE}/koel-${RELEASE}.zip -o /opt/koel.zip
 | |
| cd /opt
 | |
| unzip koel.zip
 | |
| cd /opt/koel
 | |
| mv .env.example .env
 | |
| $STD composer install --no-interaction
 | |
| sed -i -e "s/DB_CONNECTION=.*/DB_CONNECTION=pgsql/" \
 | |
|     -e "s/DB_HOST=.*/DB_HOST=localhost/" \
 | |
|     -e "s/DB_DATABASE=.*/DB_DATABASE=$DB_NAME/" \
 | |
|     -e "s/DB_PORT=.*/DB_PORT=5432/" \
 | |
|     -e "s|APP_KEY=.*|APP_KEY=$(openssl rand -base64 32 | tr -dc 'a-zA-Z0-9' | cut -c1-32)|" \
 | |
|     -e "s/DB_USERNAME=.*/DB_USERNAME=$DB_USER/" \
 | |
|     -e "s|DB_PASSWORD=.*|DB_PASSWORD=$DB_PASS|" \
 | |
|     -e "s|MEDIA_PATH=.*|MEDIA_PATH=/opt/koel_media|" \
 | |
|     -e "s|FFMPEG_PATH=/usr/local/bin/ffmpeg|FFMPEG_PATH=/usr/bin/ffmpeg|" /opt/koel/.env
 | |
| php artisan koel:init --no-assets
 | |
| chown -R :www-data /opt/*
 | |
| chmod -R g+r /opt/*
 | |
| chmod -R g+rw /opt/*
 | |
| chown -R www-data:www-data /opt/*
 | |
| chmod -R 755 /opt/*
 | |
| msg_ok "Installed Koel"
 | |
| 
 | |
| msg_info "Set up web services"
 | |
| cat <<EOF >/etc/nginx/sites-available/koel
 | |
| server {
 | |
|     listen          *:80;
 | |
|     server_name     koel.local;
 | |
|     root            /opt/koel/public;
 | |
|     index           index.php;
 | |
| 
 | |
|     gzip            on;
 | |
|     gzip_types      text/plain text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript application/json;
 | |
|     gzip_comp_level 9;
 | |
| 
 | |
|     send_timeout    3600;
 | |
|     client_max_body_size 200M;
 | |
| 
 | |
|     location / {
 | |
|         try_files \$uri \$uri/ /index.php?\$args;
 | |
|     }
 | |
| 
 | |
|     location /media/ {
 | |
|         alias /opt/koel_media;
 | |
|         autoindex on;
 | |
|         access_log /var/log/nginx/koel.access.log;
 | |
|         error_log  /var/log/nginx/koel.error.log;
 | |
|     }
 | |
| 
 | |
|     location ~ \.php$ {
 | |
|         try_files \$uri \$uri/ /index.php?\$args;
 | |
| 
 | |
|         fastcgi_param PATH_INFO \$fastcgi_path_info;
 | |
|         fastcgi_param PATH_TRANSLATED \$document_root\$fastcgi_path_info;
 | |
|         fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name;
 | |
| 
 | |
|         fastcgi_split_path_info ^(.+\.php)(/.+)$;
 | |
|         fastcgi_pass unix:/run/php/php8.3-fpm.sock;
 | |
|         fastcgi_index index.php;
 | |
|         include fastcgi_params;
 | |
| 
 | |
|     }
 | |
| }
 | |
| EOF
 | |
| ln -s /etc/nginx/sites-available/koel /etc/nginx/sites-enabled/koel
 | |
| systemctl restart php8.3-fpm
 | |
| systemctl reload nginx
 | |
| msg_ok "Created Services"
 | |
| 
 | |
| msg_info "Adding Cronjob (Daily Midnight)"
 | |
| cat <<EOF >/opt/koel_sync/koel_sync.cron
 | |
| 0 0 * * * cd /opt/koel/ && /usr/bin/php artisan koel:sync >/opt/koel_sync/koel_sync.log 2>&1
 | |
| EOF
 | |
| crontab /opt/koel_sync/koel_sync.cron
 | |
| 
 | |
| msg_ok "Cronjob successfully added"
 | |
| 
 | |
| motd_ssh
 | |
| customize
 | |
| 
 | |
| msg_info "Cleaning up"
 | |
| rm -rf /opt/koel.zip
 | |
| $STD apt-get autoremove
 | |
| $STD apt-get autoclean
 | |
| msg_ok "Cleaned"
 | 
