107 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			107 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| # Copyright (c) 2021-2025 community-scripts ORG
 | |
| # Author: bvdberg01
 | |
| # License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
 | |
| # Source: https://docs.part-db.de/
 | |
| 
 | |
| source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
 | |
| color
 | |
| verb_ip6
 | |
| catch_errors
 | |
| setting_up_container
 | |
| network_check
 | |
| update_os
 | |
| 
 | |
| msg_info "Installing Dependencies"
 | |
| $STD apt-get install -y \
 | |
|   ca-certificates \
 | |
|   software-properties-common \
 | |
|   apt-transport-https \
 | |
|   lsb-release \
 | |
|   php-{opcache,curl,gd,mbstring,xml,bcmath,intl,zip,xsl,pgsql} \
 | |
|   libapache2-mod-php \
 | |
|   composer
 | |
| msg_ok "Installed Dependencies"
 | |
| 
 | |
| NODE_VERSION="22" NODE_MODULE="yarn@latest" setup_nodejs
 | |
| PG_VERSION="16" setup_postgresql
 | |
| 
 | |
| msg_info "Setting up PHP"
 | |
| PHPVER=$(php -r 'echo PHP_MAJOR_VERSION . "." . PHP_MINOR_VERSION . "\n";')
 | |
| sed -i "s@post_max_size = 8M@post_max_size = 100M@g" /etc/php/${PHPVER}/apache2/php.ini
 | |
| sed -i "s@upload_max_filesize = 2M@upload_max_filesize = 100M@g" /etc/php/${PHPVER}/apache2/php.ini
 | |
| msg_ok "Setting up PHP"
 | |
| 
 | |
| msg_info "Setting up PostgreSQL"
 | |
| DB_NAME=partdb
 | |
| DB_USER=partdb
 | |
| DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)
 | |
| $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 TEMPLATE template0;"
 | |
| {
 | |
|   echo "Part-DB Credentials"
 | |
|   echo "Part-DB Database User: $DB_USER"
 | |
|   echo "Part-DB Database Password: $DB_PASS"
 | |
|   echo "Part-DB Database Name: $DB_NAME"
 | |
| } >>~/partdb.creds
 | |
| msg_ok "Set up PostgreSQL"
 | |
| 
 | |
| msg_info "Installing Part-DB (Patience)"
 | |
| cd /opt
 | |
| RELEASE=$(curl -fsSL https://api.github.com/repos/Part-DB/Part-DB-server/releases/latest | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
 | |
| curl -fsSL "https://github.com/Part-DB/Part-DB-server/archive/refs/tags/v${RELEASE}.zip" -o "/opt/v${RELEASE}.zip"
 | |
| $STD unzip "v${RELEASE}.zip"
 | |
| mv /opt/Part-DB-server-${RELEASE}/ /opt/partdb
 | |
| 
 | |
| cd /opt/partdb/
 | |
| cp .env .env.local
 | |
| sed -i "s|DATABASE_URL=\"sqlite:///%kernel.project_dir%/var/app.db\"|DATABASE_URL=\"postgresql://${DB_USER}:${DB_PASS}@127.0.0.1:5432/${DB_NAME}?serverVersion=12.19&charset=utf8\"|" .env.local
 | |
| 
 | |
| export COMPOSER_ALLOW_SUPERUSER=1
 | |
| $STD composer install --no-dev -o --no-interaction
 | |
| $STD yarn install
 | |
| $STD yarn build
 | |
| $STD php bin/console cache:clear
 | |
| php bin/console doctrine:migrations:migrate -n >~/database-migration-output
 | |
| chown -R www-data:www-data /opt/partdb
 | |
| ADMIN_PASS=$(grep -oP 'The initial password for the "admin" user is: \K\w+' ~/database-migration-output)
 | |
| {
 | |
|   echo ""
 | |
|   echo "Part-DB Admin User: admin"
 | |
|   echo "Part-DB Admin Password: $ADMIN_PASS"
 | |
| } >>~/partdb.creds
 | |
| echo "${RELEASE}" >/opt/${APPLICATION}_version.txt
 | |
| msg_ok "Installed Part-DB"
 | |
| 
 | |
| msg_info "Creating Service"
 | |
| cat <<EOF >/etc/apache2/sites-available/partdb.conf
 | |
| <VirtualHost *:80>
 | |
|     ServerName partdb
 | |
|     DocumentRoot /opt/partdb/public
 | |
|     <Directory /opt/partdb/public>
 | |
|         Options FollowSymLinks
 | |
|         AllowOverride All
 | |
|         Require all granted
 | |
|     </Directory>
 | |
| 
 | |
|     ErrorLog /var/log/apache2/partdb_error.log
 | |
|     CustomLog /var/log/apache2/partdb_access.log combined
 | |
| </VirtualHost>
 | |
| EOF
 | |
| $STD a2ensite partdb
 | |
| $STD a2enmod rewrite
 | |
| $STD a2dissite 000-default.conf
 | |
| $STD systemctl reload apache2
 | |
| msg_ok "Created Service"
 | |
| 
 | |
| motd_ssh
 | |
| customize
 | |
| 
 | |
| msg_info "Cleaning up"
 | |
| rm -rf ~/database-migration-output
 | |
| rm -rf "/opt/v${RELEASE}.zip"
 | |
| $STD apt-get -y autoremove
 | |
| $STD apt-get -y autoclean
 | |
| msg_ok "Cleaned"
 | 
