mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2025-07-05 05:27:39 +00:00
* 'Add new script' * Update itsm-ng-install.sh * Update itsm-ng-install.sh --------- Co-authored-by: push-app-to-main[bot] <203845782+push-app-to-main[bot]@users.noreply.github.com> Co-authored-by: Slaviša Arežina <58952836+tremor021@users.noreply.github.com>
69 lines
2.4 KiB
Bash
69 lines
2.4 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
# Copyright (c) 2021-2025 community-scripts ORG
|
|
# Author: Florianb63
|
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
|
# Source: https://itsm-ng.com/
|
|
|
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
|
color
|
|
verb_ip6
|
|
catch_errors
|
|
setting_up_container
|
|
network_check
|
|
update_os
|
|
|
|
setup_mariadb
|
|
|
|
msg_info "Setting up database"
|
|
DB_NAME=itsmng_db
|
|
DB_USER=itsmng
|
|
DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c13)
|
|
mariadb-tzinfo-to-sql /usr/share/zoneinfo | mariadb mysql
|
|
mariadb -u root -e "CREATE DATABASE $DB_NAME;"
|
|
mariadb -u root -e "CREATE USER '$DB_USER'@'localhost' IDENTIFIED BY '$DB_PASS';"
|
|
mariadb -u root -e "GRANT ALL PRIVILEGES ON $DB_NAME.* TO '$DB_USER'@'localhost';"
|
|
mariadb -u root -e "GRANT SELECT ON \`mysql\`.\`time_zone_name\` TO '$DB_USER'@'localhost'; FLUSH PRIVILEGES;"
|
|
{
|
|
echo "ITSM-NG Database Credentials"
|
|
echo "Database: $DB_NAME"
|
|
echo "Username: $DB_USER"
|
|
echo "Password: $DB_PASS"
|
|
} >>~/itsmng_db.creds
|
|
msg_ok "Set up database"
|
|
|
|
msg_info "Setup ITSM-NG Repository"
|
|
curl -fsSL http://deb.itsm-ng.org/pubkey.gpg | gpg --dearmor -o /etc/apt/trusted.gpg.d/itsm-ng-keyring.gpg
|
|
echo "deb http://deb.itsm-ng.org/$(. /etc/os-release && echo "$ID")/ $(. /etc/os-release && echo "$VERSION_CODENAME") main" >/etc/apt/sources.list.d/itsm-ng.list
|
|
$STD apt-get update
|
|
msg_ok "Setup ITSM-NG Repository"
|
|
|
|
msg_info "Installing ITSM-NG"
|
|
$STD apt install -y itsm-ng
|
|
cd /usr/share/itsm-ng
|
|
$STD php bin/console db:install --db-name=$DB_NAME --db-user=$DB_USER --db-password=$DB_PASS --no-interaction
|
|
$STD a2dissite 000-default.conf
|
|
echo "* * * * * php /usr/share/itsm-ng/front/cron.php" | crontab -
|
|
msg_ok "Installed ITSM-NG"
|
|
|
|
msg_info "Configuring PHP"
|
|
PHP_VERSION=$(ls /etc/php/ | grep -E '^[0-9]+\.[0-9]+$' | head -n 1)
|
|
PHP_INI="/etc/php/$PHP_VERSION/apache2/php.ini"
|
|
sed -i 's/^upload_max_filesize = .*/upload_max_filesize = 20M/' $PHP_INI
|
|
sed -i 's/^post_max_size = .*/post_max_size = 20M/' $PHP_INI
|
|
sed -i 's/^max_execution_time = .*/max_execution_time = 60/' $PHP_INI
|
|
sed -i 's/^[;]*max_input_vars *=.*/max_input_vars = 5000/' "$PHP_INI"
|
|
sed -i 's/^memory_limit = .*/memory_limit = 256M/' $PHP_INI
|
|
sed -i 's/^;\?\s*session.cookie_httponly\s*=.*/session.cookie_httponly = On/' $PHP_INI
|
|
systemctl restart apache2
|
|
msg_ok "Configured PHP"
|
|
|
|
motd_ssh
|
|
customize
|
|
|
|
msg_info "Cleaning up"
|
|
rm -rf /usr/share/itsm-ng/install
|
|
$STD apt-get -y autoremove
|
|
$STD apt-get -y autoclean
|
|
msg_ok "Cleaned"
|