mirror of
https://github.com/tommytran732/Pterodactyl-Script
synced 2024-11-22 02:21:33 -05:00
Code cleanup
Signed-off-by: Tommy <contact@tommytran.io>
This commit is contained in:
parent
b6e2d6bbef
commit
567d2371f7
29
epel9.asc
Normal file
29
epel9.asc
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||||
|
|
||||||
|
mQINBGE3mOsBEACsU+XwJWDJVkItBaugXhXIIkb9oe+7aadELuVo0kBmc3HXt/Yp
|
||||||
|
CJW9hHEiGZ6z2jwgPqyJjZhCvcAWvgzKcvqE+9i0NItV1rzfxrBe2BtUtZmVcuE6
|
||||||
|
2b+SPfxQ2Hr8llaawRjt8BCFX/ZzM4/1Qk+EzlfTcEcpkMf6wdO7kD6ulBk/tbsW
|
||||||
|
DHX2lNcxszTf+XP9HXHWJlA2xBfP+Dk4gl4DnO2Y1xR0OSywE/QtvEbN5cY94ieu
|
||||||
|
n7CBy29AleMhmbnx9pw3NyxcFIAsEZHJoU4ZW9ulAJ/ogttSyAWeacW7eJGW31/Z
|
||||||
|
39cS+I4KXJgeGRI20RmpqfH0tuT+X5Da59YpjYxkbhSK3HYBVnNPhoJFUc2j5iKy
|
||||||
|
XLgkapu1xRnEJhw05kr4LCbud0NTvfecqSqa+59kuVc+zWmfTnGTYc0PXZ6Oa3rK
|
||||||
|
44UOmE6eAT5zd/ToleDO0VesN+EO7CXfRsm7HWGpABF5wNK3vIEF2uRr2VJMvgqS
|
||||||
|
9eNwhJyOzoca4xFSwCkc6dACGGkV+CqhufdFBhmcAsUotSxe3zmrBjqA0B/nxIvH
|
||||||
|
DVgOAMnVCe+Lmv8T0mFgqZSJdIUdKjnOLu/GRFhjDKIak4jeMBMTYpVnU+HhMHLq
|
||||||
|
uDiZkNEvEEGhBQmZuI8J55F/a6UURnxUwT3piyi3Pmr2IFD7ahBxPzOBCQARAQAB
|
||||||
|
tCdGZWRvcmEgKGVwZWw5KSA8ZXBlbEBmZWRvcmFwcm9qZWN0Lm9yZz6JAk4EEwEI
|
||||||
|
ADgWIQT/itE0RZcQbs6BO5GKOHK/MihGfAUCYTeY6wIbDwULCQgHAgYVCgkICwIE
|
||||||
|
FgIDAQIeAQIXgAAKCRCKOHK/MihGfFX/EACBPWv20+ttYu1A5WvtHJPzwbj0U4yF
|
||||||
|
3zTQpBglQ2UfkRpYdipTlT3Ih6j5h2VmgRPtINCc/ZE28adrWpBoeFIS2YAKOCLC
|
||||||
|
nZYtHl2nCoLq1U7FSttUGsZ/t8uGCBgnugTfnIYcmlP1jKKA6RJAclK89evDQX5n
|
||||||
|
R9ZD+Cq3CBMlttvSTCht0qQVlwycedH8iWyYgP/mF0W35BIn7NuuZwWhgR00n/VG
|
||||||
|
4nbKPOzTWbsP45awcmivdrS74P6mL84WfkghipdmcoyVb1B8ZP4Y/Ke0RXOnLhNe
|
||||||
|
CfrXXvuW+Pvg2RTfwRDtehGQPAgXbmLmz2ZkV69RGIr54HJv84NDbqZovRTMr7gL
|
||||||
|
9k3ciCzXCiYQgM8yAyGHV0KEhFSQ1HV7gMnt9UmxbxBE2pGU7vu3CwjYga5DpwU7
|
||||||
|
w5wu1TmM5KgZtZvuWOTDnqDLf0cKoIbW8FeeCOn24elcj32bnQDuF9DPey1mqcvT
|
||||||
|
/yEo/Ushyz6CVYxN8DGgcy2M9JOsnmjDx02h6qgWGWDuKgb9jZrvRedpAQCeemEd
|
||||||
|
fhEs6ihqVxRFl16HxC4EVijybhAL76SsM2nbtIqW1apBQJQpXWtQwwdvgTVpdEtE
|
||||||
|
r4ArVJYX5LrswnWEQMOelugUG6S3ZjMfcyOa/O0364iY73vyVgaYK+2XtT2usMux
|
||||||
|
VL469Kj5m13T6w==
|
||||||
|
=Mjs/
|
||||||
|
-----END PGP PUBLIC KEY BLOCK-----
|
488
install.sh
488
install.sh
@ -4,111 +4,21 @@ output(){
|
|||||||
echo -e '\e[36m'$1'\e[0m';
|
echo -e '\e[36m'$1'\e[0m';
|
||||||
}
|
}
|
||||||
|
|
||||||
warn(){
|
|
||||||
echo -e '\e[31m'$1'\e[0m';
|
|
||||||
}
|
|
||||||
|
|
||||||
PANEL=latest
|
PANEL=latest
|
||||||
WINGS=latest
|
WINGS=latest
|
||||||
|
|
||||||
preflight(){
|
preflight(){
|
||||||
output "Pterodactyl Installation & Upgrade Script"
|
output "Pterodactyl Installation & Upgrade Script"
|
||||||
output "Copyright © 2021 Thien Tran <contact@tommytran.io>."
|
output "Copyright © 2018-2023 Thien Tran <contact@tommytran.io>."
|
||||||
output "Please join my Matrix for community support: https://matrix.to/#/#tommy:arcticfoxes.net"
|
output "Please join my Matrix for community support: https://matrix.to/#/#tommy:arcticfoxes.net"
|
||||||
output ""
|
output ""
|
||||||
|
output "Please note that this script is meant to do installations on a fresh OS."
|
||||||
output "Please note that this script is meant to be installed on a fresh OS. Installing it on a non-fresh OS may cause problems."
|
|
||||||
output "Automatic operating system detection initialized..."
|
|
||||||
|
|
||||||
os_check
|
|
||||||
|
|
||||||
if [ "$EUID" -ne 0 ]; then
|
if [ "$EUID" -ne 0 ]; then
|
||||||
output "Please run as root."
|
output "Please run as root."
|
||||||
exit 3
|
exit 3
|
||||||
fi
|
fi
|
||||||
|
|
||||||
output "Automatic architecture detection initialized..."
|
|
||||||
MACHINE_TYPE=`uname -m`
|
|
||||||
if [ "${MACHINE_TYPE}" == 'x86_64' ]; then
|
|
||||||
output "64-bit server detected! Good to go."
|
|
||||||
output ""
|
|
||||||
else
|
|
||||||
output "Unsupported architecture detected! Please switch to 64-bit (x86_64)."
|
|
||||||
exit 4
|
|
||||||
fi
|
|
||||||
|
|
||||||
output "Automatic virtualization detection initialized..."
|
|
||||||
if [ "$lsb_dist" = "ubuntu" ]; then
|
|
||||||
apt-get update --fix-missing
|
|
||||||
apt-get -y install software-properties-common
|
|
||||||
add-apt-repository -y universe
|
|
||||||
apt-get -y install virt-what curl
|
|
||||||
elif [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt update --fix-missing
|
|
||||||
apt-get -y install software-properties-common virt-what wget curl dnsutils
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
yum -y install virt-what wget bind-utils
|
|
||||||
fi
|
|
||||||
virt_serv=$(echo $(virt-what))
|
|
||||||
if [ "$virt_serv" = "" ]; then
|
|
||||||
output "Virtualization: Bare Metal detected."
|
|
||||||
elif [ "$virt_serv" = "openvz lxc" ]; then
|
|
||||||
output "Virtualization: OpenVZ 7 detected."
|
|
||||||
elif [ "$virt_serv" = "xen xen-hvm" ]; then
|
|
||||||
output "Virtualization: Xen-HVM detected."
|
|
||||||
elif [ "$virt_serv" = "xen xen-hvm aws" ]; then
|
|
||||||
output "Virtualization: Xen-HVM on AWS detected."
|
|
||||||
warn "When creating allocations for this node, please use the internal IP as Google Cloud uses NAT routing."
|
|
||||||
warn "Resuming in 10 seconds..."
|
|
||||||
sleep 10
|
|
||||||
else
|
|
||||||
output "Virtualization: $virt_serv detected."
|
|
||||||
fi
|
|
||||||
output ""
|
|
||||||
if [ "$virt_serv" != "" ] && [ "$virt_serv" != "kvm" ] && [ "$virt_serv" != "vmware" ] && [ "$virt_serv" != "hyperv" ] && [ "$virt_serv" != "openvz lxc" ] && [ "$virt_serv" != "xen xen-hvm" ] && [ "$virt_serv" != "xen xen-hvm aws" ]; then
|
|
||||||
warn "Unsupported type of virtualization detected. Please consult with your hosting provider whether your server can run Docker or not. Proceed at your own risk."
|
|
||||||
warn "No support would be given if your server breaks at any point in the future."
|
|
||||||
warn "Proceed?\n[1] Yes.\n[2] No."
|
|
||||||
read choice
|
|
||||||
case $choice in
|
|
||||||
1) output "Proceeding..."
|
|
||||||
;;
|
|
||||||
2) output "Cancelling installation..."
|
|
||||||
exit 5
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
output ""
|
|
||||||
fi
|
|
||||||
|
|
||||||
output "Kernel detection initialized..."
|
|
||||||
if echo $(uname -r) | grep -q xxxx; then
|
|
||||||
output "OVH kernel detected. This script will not work. Please reinstall your server using a generic/distribution kernel."
|
|
||||||
output "When you are reinstalling your server, click on 'custom installation' and click on 'use distribution' kernel after that."
|
|
||||||
output "You might also want to do custom partitioning, remove the /home partition and give / all the remaining space."
|
|
||||||
output "Please do not hesitate to contact us if you need help regarding this issue."
|
|
||||||
exit 6
|
|
||||||
elif echo $(uname -r) | grep -q pve; then
|
|
||||||
output "Proxmox LXE kernel detected. You have chosen to continue in the last step, therefore we are proceeding at your own risk."
|
|
||||||
output "Proceeding with a risky operation..."
|
|
||||||
elif echo $(uname -r) | grep -q stab; then
|
|
||||||
if echo $(uname -r) | grep -q 2.6; then
|
|
||||||
output "OpenVZ 6 detected. This server will definitely not work with Docker, regardless of what your provider might say. Exiting to avoid further damages."
|
|
||||||
exit 6
|
|
||||||
fi
|
|
||||||
elif echo $(uname -r) | grep -q gcp; then
|
|
||||||
output "Google Cloud Platform detected."
|
|
||||||
warn "Please make sure you have a static IP setup, otherwise the system will not work after a reboot."
|
|
||||||
warn "Please also make sure the GCP firewall allows the ports needed for the server to function normally."
|
|
||||||
warn "When creating allocations for this node, please use the internal IP as Google Cloud uses NAT routing."
|
|
||||||
warn "Resuming in 10 seconds..."
|
|
||||||
sleep 10
|
|
||||||
else
|
|
||||||
output "Did not detect any bad kernel. Moving forward..."
|
|
||||||
output ""
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
os_check(){
|
|
||||||
if [ -r /etc/os-release ]; then
|
if [ -r /etc/os-release ]; then
|
||||||
lsb_dist="$(. /etc/os-release && echo "$ID")"
|
lsb_dist="$(. /etc/os-release && echo "$ID")"
|
||||||
dist_version="$(. /etc/os-release && echo "$VERSION_ID")"
|
dist_version="$(. /etc/os-release && echo "$VERSION_ID")"
|
||||||
@ -119,52 +29,34 @@ os_check(){
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$lsb_dist" = "ubuntu" ]; then
|
if [ "$lsb_dist" = "rhel" ]; then
|
||||||
if [ "$dist_version" != "20.04" ]; then
|
if [ $dist_version != "9" ]; then
|
||||||
output "Unsupported Ubuntu version. Only Ubuntu 20.04 is supported."
|
output "Unsupported RHEL version. Only RHEL 9 is supported."
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
elif [ "$lsb_dist" = "debian" ]; then
|
|
||||||
if [ "$dist_version" != "11" ]; then
|
|
||||||
output "Unsupported Debian version. Only Debian 10 is supported."
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
elif [ "$lsb_dist" = "fedora" ]; then
|
|
||||||
if [ "$dist_version" != "35" ]; then
|
|
||||||
output "Unsupported Fedora version. Only Fedora 34 is supported."
|
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
elif [ "$lsb_dist" = "centos" ]; then
|
elif [ "$lsb_dist" = "centos" ]; then
|
||||||
if [ "$dist_version" != "8" ]; then
|
if [ "$dist_version" != "9" ]; then
|
||||||
output "Unsupported CentOS version. Only CentOS Stream 8 is supported."
|
output "Unsupported CentOS version. Only CentOS Stream 8 is supported."
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
elif [ "$lsb_dist" = "rhel" ]; then
|
|
||||||
if [ $dist_version != "8" ]; then
|
|
||||||
output "Unsupported RHEL version. Only RHEL 8 is supported."
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
elif [ "$lsb_dist" = "rocky" ]; then
|
elif [ "$lsb_dist" = "rocky" ]; then
|
||||||
if [ "$dist_version" != "8" ]; then
|
if [ "$dist_version" != "9" ]; then
|
||||||
output "Unsupported Rocky Linux version. Only Rocky Linux 8 is supported."
|
output "Unsupported Rocky Linux version. Only Rocky Linux 8 is supported."
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
elif [ "$lsb_dist" = "almalinux" ]; then
|
elif [ "$lsb_dist" = "almalinux" ]; then
|
||||||
if [ "$dist_version" != "8" ]; then
|
if [ "$dist_version" != "9" ]; then
|
||||||
output "Unsupported AlmaLinux version. Only AlmaLinux 8 is supported."
|
output "Unsupported AlmaLinux version. Only AlmaLinux 8 is supported."
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
elif [ "$lsb_dist" != "ubuntu" ] && [ "$lsb_dist" != "debian" ] && [ "$lsb_dist" != "fedora" ] && [ "$lsb_dist" != "centos" ] && [ "$lsb_dist" != "rhel" ] && [ "$lsb_dist" != "rocky" ] && [ "$lsb_dist" != "almalinux" ]; then
|
elif [ "$lsb_dist" != "rhel" ] && [ "$lsb_dist" != "centos" ] && [ "$lsb_dist" != "rocky" ] && [ "$lsb_dist" != "almalinux" ]; then
|
||||||
output "Unsupported operating system."
|
output "Unsupported operating system."
|
||||||
output ""
|
output ""
|
||||||
output "Supported OS:"
|
output "Supported OS:"
|
||||||
output "Ubuntu: 20.04"
|
output "RHEL: 9"
|
||||||
output "Debian: 11"
|
output "CentOS Stream: 9"
|
||||||
output "Fedora: 35"
|
output "Rocky Linux: 9"
|
||||||
output "CentOS Stream: 8"
|
output "AlmaLinux: 9"
|
||||||
output "Rocky Linux: 8"
|
|
||||||
output "AlmaLinux: 8"
|
|
||||||
output "RHEL: 8"
|
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@ -217,13 +109,12 @@ install_options(){
|
|||||||
required_infos() {
|
required_infos() {
|
||||||
output "Please enter the desired user email address:"
|
output "Please enter the desired user email address:"
|
||||||
read -r email
|
read -r email
|
||||||
dns_check
|
|
||||||
}
|
|
||||||
|
|
||||||
dns_check(){
|
|
||||||
output "Please enter your FQDN (panel.domain.tld):"
|
output "Please enter your FQDN (panel.domain.tld):"
|
||||||
read -r FQDN
|
read -r FQDN
|
||||||
|
|
||||||
|
timezone=$(timedatectl | grep "Time zone" | awk '{ print $3 }')
|
||||||
|
|
||||||
output "Resolving DNS..."
|
output "Resolving DNS..."
|
||||||
SERVER_IP=$(dig +short myip.opendns.com @resolver1.opendns.com -4)
|
SERVER_IP=$(dig +short myip.opendns.com @resolver1.opendns.com -4)
|
||||||
DOMAIN_RECORD=$(dig +short ${FQDN})
|
DOMAIN_RECORD=$(dig +short ${FQDN})
|
||||||
@ -239,80 +130,37 @@ dns_check(){
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
repositories_setup(){
|
|
||||||
output "Configuring your repositories..."
|
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt-get -y install sudo
|
|
||||||
apt-get -y install software-properties-common curl apt-transport-https ca-certificates gnupg
|
|
||||||
dpkg --remove-architecture i386
|
|
||||||
echo 'Acquire::ForceIPv4 "true";' | sudo tee /etc/apt/apt.conf.d/99force-ipv4
|
|
||||||
apt-get -y update
|
|
||||||
curl -sS https://downloads.mariadb.com/MariaDB/mariadb_repo_setup | sudo bash
|
|
||||||
if [ "$lsb_dist" = "ubuntu" ]; then
|
|
||||||
LC_ALL=C.UTF-8 add-apt-repository -y ppa:ondrej/php
|
|
||||||
apt -y install tuned dnsutils
|
|
||||||
tuned-adm profile latency-performance
|
|
||||||
elif [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt-get -y install ca-certificates apt-transport-https
|
|
||||||
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/php.list
|
|
||||||
apt -y install dirmngr
|
|
||||||
wget -q https://packages.sury.org/php/apt.gpg -O- | sudo apt-key add -
|
|
||||||
sudo apt-key adv --fetch-keys 'https://mariadb.org/mariadb_release_signing_key.asc'
|
|
||||||
apt -y install tuned
|
|
||||||
tuned-adm profile latency-performance
|
|
||||||
apt-get -y update
|
|
||||||
apt-get -y upgrade
|
|
||||||
apt-get -y autoremove
|
|
||||||
apt-get -y autoclean
|
|
||||||
apt-get -y install curl
|
|
||||||
fi
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install dnf-utils
|
|
||||||
if [ "$lsb_dist" = "fedora" ] ; then
|
|
||||||
dnf -y install http://rpms.remirepo.net/fedora/remi-release-35.rpm
|
|
||||||
else
|
|
||||||
dnf -y install https://dl.fedoraproject.org/pub/epel/epel-release-latest-8.noarch.rpm
|
|
||||||
dnf -y install http://rpms.remirepo.net/enterprise/remi-release-8.rpm
|
|
||||||
fi
|
|
||||||
dnf config-manager --set-enabled remi
|
|
||||||
dnf -y install tuned dnf-automatic
|
|
||||||
tuned-adm profile latency-performance
|
|
||||||
systemctl enable --now irqbalance
|
|
||||||
sed -i 's/apply_updates = no/apply_updates = yes/g' /etc/dnf/automatic.conf
|
|
||||||
systemctl enable --now dnf-automatic.timer
|
|
||||||
dnf -y upgrade
|
|
||||||
dnf -y autoremove
|
|
||||||
dnf -y clean packages
|
|
||||||
dnf -y install curl bind-utils cronie
|
|
||||||
fi
|
|
||||||
systemctl enable --now fstrim.timer
|
|
||||||
}
|
|
||||||
|
|
||||||
install_dependencies(){
|
install_dependencies(){
|
||||||
output "Installing dependencies..."
|
output "Installing dependencies..."
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt -y install php8.0 php8.0-{cli,gd,mysql,pdo,mbstring,tokenizer,bcmath,xml,fpm,curl,zip} nginx tar unzip git redis-server nginx git wget expect composer
|
#Adding upstream repo because RHEL's version is extremely oudated.
|
||||||
sh -c "DEBIAN_FRONTEND=noninteractive apt-get install -y --allow-unauthenticated mariadb-server"
|
curl -LsS https://r.mariadb.com/downloads/mariadb_repo_setup | sudo bash
|
||||||
|
|
||||||
|
if [ "$lsb_dist" != "rhel" ]; then
|
||||||
|
subscription-manager repos --enable codeready-builder-for-rhel-9-$(arch)-rpms
|
||||||
|
rpm --import https://raw.githubusercontent.com/tommytran732/Pterodactyl-Script/master/epel9.asc
|
||||||
|
dnf install -y https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm
|
||||||
|
elif [ "$lsb_dist" != "centos" ]; then
|
||||||
|
dnf config-manager --set-enabled crb
|
||||||
|
dnf install -y epel-release epel-next-release
|
||||||
else
|
else
|
||||||
dnf -y module install nginx:mainline/common
|
dnf config-manager --set-enabled crb
|
||||||
dnf -y module install php:remi-8.0/common
|
dnf install -y epel-release
|
||||||
dnf -y module install redis:remi-6.2/common
|
|
||||||
dnf -y module install mariadb:10.5/server
|
|
||||||
dnf -y install git policycoreutils-python-utils unzip wget expect jq php-mysql php-zip php-bcmath tar composer
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
output "Enabling Services..."
|
#Adding Remi's repo because RHEL 9 does not have php-sodium for php 8.1 yet. Also, it is unclear whether RHEL 9 will get php 8.2 and above modules later on or not.
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
rpm --import https://raw.githubusercontent.com/tommytran732/Pterodactyl-Script/master/remi9.asc
|
||||||
systemctl enable --now redis-server
|
dnf install -y https://rpms.remirepo.net/enterprise/remi-release-9.rpm
|
||||||
systemctl enable --now php8.0-fpm
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
systemctl enable --now redis
|
|
||||||
systemctl enable --now php-fpm
|
|
||||||
fi
|
|
||||||
|
|
||||||
systemctl enable --now cron
|
dnf install -y nginx redis mariadb-server composer tuned
|
||||||
systemctl enable --now mariadb
|
|
||||||
systemctl enable --now nginx
|
systemctl enable --now nginx
|
||||||
|
systemctl enable --now redis
|
||||||
|
systemctl enable --now mariadb
|
||||||
|
tune-adm profile latency-performance
|
||||||
|
|
||||||
|
dnf module install php:remi-8.1/common
|
||||||
|
dnf install -y php-bcmath php-gd php-mysqlnd php-pdo php-sodium
|
||||||
|
systemctl enable --now php-fpm
|
||||||
}
|
}
|
||||||
|
|
||||||
install_pterodactyl() {
|
install_pterodactyl() {
|
||||||
@ -334,46 +182,10 @@ install_pterodactyl() {
|
|||||||
mysql -u root -e "$SQL"
|
mysql -u root -e "$SQL"
|
||||||
|
|
||||||
output "Binding MariaDB/MySQL to 0.0.0.0"
|
output "Binding MariaDB/MySQL to 0.0.0.0"
|
||||||
if grep -Fqs "bind-address" /etc/mysql/mariadb.conf.d/50-server.cnf ; then
|
if grep -Fqs "bind-address" /etc/my.cnf.d/server.cnf ; then
|
||||||
sed -i -- '/bind-address/s/#//g' /etc/mysql/mariadb.conf.d/50-server.cnf
|
sed -i 's/#bind-address=0.0.0.0/bind-address=0.0.0.0/' /etc/my.cnf.d/server.cnf
|
||||||
sed -i -- '/bind-address/s/127.0.0.1/0.0.0.0/g' /etc/mysql/mariadb.conf.d/50-server.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-key=/etc/letsencrypt/live/'"${FQDN}"'/privkey.pem' /etc/mysql/mariadb.conf.d/50-server.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-ca=/etc/letsencrypt/live/'"${FQDN}"'/chain.pem' /etc/mysql/mariadb.conf.d/50-server.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-cert=/etc/letsencrypt/live/'"${FQDN}"'/cert.pem' /etc/mysql/mariadb.conf.d/50-server.cnf
|
|
||||||
output 'Restarting MariaDB process...'
|
output 'Restarting MariaDB process...'
|
||||||
service mariadb restart
|
systemctl restart mariadb
|
||||||
elif grep -Fqs "bind-address" /etc/mysql/my.cnf ; then
|
|
||||||
sed -i -- '/bind-address/s/#//g' /etc/mysql/my.cnf
|
|
||||||
sed -i -- '/bind-address/s/127.0.0.1/0.0.0.0/g' /etc/mysql/my.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-key=/etc/letsencrypt/live/'"${FQDN}"'/privkey.pem' /etc/mysql/my.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-ca=/etc/letsencrypt/live/'"${FQDN}"'/chain.pem' /etc/mysql/my.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-cert=/etc/letsencrypt/live/'"${FQDN}"'/cert.pem' /etc/mysql/my.cnf
|
|
||||||
output 'Restarting MariaDB process...'
|
|
||||||
service mariadb restart
|
|
||||||
elif grep -Fqs "bind-address" /etc/my.cnf ; then
|
|
||||||
sed -i -- '/bind-address/s/#//g' /etc/my.cnf
|
|
||||||
sed -i -- '/bind-address/s/127.0.0.1/0.0.0.0/g' /etc/my.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-key=/etc/letsencrypt/live/'"${FQDN}"'/privkey.pem' /etc/my.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-ca=/etc/letsencrypt/live/'"${FQDN}"'/chain.pem' /etc/my.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-cert=/etc/letsencrypt/live/'"${FQDN}"'/cert.pem' /etc/my.cnf
|
|
||||||
output 'Restarting MariaDB process...'
|
|
||||||
service mariadb restart
|
|
||||||
elif grep -Fqs "bind-address" /etc/mysql/my.conf.d/mysqld.cnf ; then
|
|
||||||
sed -i -- '/bind-address/s/#//g' /etc/mysql/my.conf.d/mysqld.cnf
|
|
||||||
sed -i -- '/bind-address/s/127.0.0.1/0.0.0.0/g' /etc/mysql/my.conf.d/mysqld.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-key=/etc/letsencrypt/live/'"${FQDN}"'/privkey.pem' /etc/mysql/my.conf.d/mysqld.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-ca=/etc/letsencrypt/live/'"${FQDN}"'/chain.pem' /etc/mysql/my.conf.d/mysqld.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-cert=/etc/letsencrypt/live/'"${FQDN}"'/cert.pem' /etc/mysql/my.conf.d/mysqld.cnf
|
|
||||||
output 'Restarting MariaDB process...'
|
|
||||||
service mariadb restart
|
|
||||||
elif grep -Fqs "bind-address" /etc/my.cnf.d/mariadb-server.cnf ; then
|
|
||||||
sed -i -- '/bind-address/s/#//g' /etc/my.cnf.d/mariadb-server.cnf
|
|
||||||
sed -i -- '/bind-address/s/127.0.0.1/0.0.0.0/g' /etc/my.cnf.d/mariadb-server.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-key=/etc/letsencrypt/live/'"${FQDN}"'/privkey.pem' /etc/my.cnf.d/mariadb-server.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-ca=/etc/letsencrypt/live/'"${FQDN}"'/chain.pem' /etc/my.cnf.d/mariadb-server.cnf
|
|
||||||
sed -i '/\[mysqld\]/a ssl-cert=/etc/letsencrypt/live/'"${FQDN}"'/cert.pem' /etc/my.cnf.d/mariadb-server.cnf
|
|
||||||
output 'Restarting MariaDB process...'
|
|
||||||
service mariadb restart
|
|
||||||
else
|
else
|
||||||
output 'A MariaDB configuration file could not be detected! Please contact support.'
|
output 'A MariaDB configuration file could not be detected! Please contact support.'
|
||||||
fi
|
fi
|
||||||
@ -396,47 +208,18 @@ install_pterodactyl() {
|
|||||||
composer install --no-dev --optimize-autoloader --no-interaction
|
composer install --no-dev --optimize-autoloader --no-interaction
|
||||||
|
|
||||||
php artisan key:generate --force
|
php artisan key:generate --force
|
||||||
php artisan p:environment:setup -n --author=$email --url=https://$FQDN --timezone=America/New_York --cache=redis --session=database --queue=redis --redis-host=127.0.0.1 --redis-pass= --redis-port=6379
|
php artisan p:environment:setup -n --author=$email --url=https://$FQDN --timezone=${timezone} --cache=redis --session=database --queue=redis --redis-host=127.0.0.1 --redis-pass= --redis-port=6379
|
||||||
php artisan p:environment:database --host=127.0.0.1 --port=3306 --database=panel --username=pterodactyl --password=$password
|
php artisan p:environment:database --host=127.0.0.1 --port=3306 --database=panel --username=pterodactyl --password=$password
|
||||||
output "To use PHP's internal mail sending, select [mail]. To use a custom SMTP server, select [smtp]. TLS Encryption is recommended."
|
output "To use PHP's internal mail sending, select [mail]. To use a custom SMTP server, select [smtp]. TLS Encryption is recommended."
|
||||||
php artisan p:environment:mail
|
php artisan p:environment:mail
|
||||||
php artisan migrate --seed --force
|
php artisan migrate --seed --force
|
||||||
php artisan p:user:make --email=$email --admin=1
|
php artisan p:user:make --email=$email --admin=1
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
chown -R www-data:www-data * /var/www/pterodactyl
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
chown -R nginx:nginx * /var/www/pterodactyl
|
chown -R nginx:nginx * /var/www/pterodactyl
|
||||||
semanage fcontext -a -t httpd_sys_rw_content_t "/var/www/pterodactyl/storage(/.*)?"
|
|
||||||
restorecon -R /var/www/pterodactyl
|
|
||||||
fi
|
|
||||||
|
|
||||||
output "Creating panel queue listeners..."
|
output "Creating panel queue listeners..."
|
||||||
(crontab -l ; echo "* * * * * php /var/www/pterodactyl/artisan schedule:run >> /dev/null 2>&1")| crontab -
|
(crontab -l ; echo "* * * * * php /var/www/pterodactyl/artisan schedule:run >> /dev/null 2>&1")| crontab -
|
||||||
|
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
cat > /etc/systemd/system/pteroq.service <<- 'EOF'
|
|
||||||
# Pterodactyl Queue Worker File
|
|
||||||
# ----------------------------------
|
|
||||||
|
|
||||||
[Unit]
|
|
||||||
Description=Pterodactyl Queue Worker
|
|
||||||
After=redis-server.service
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
# On some systems the user and group might be different.
|
|
||||||
# Some systems use `apache` or `nginx` as the user and group.
|
|
||||||
User=www-data
|
|
||||||
Group=www-data
|
|
||||||
Restart=always
|
|
||||||
ExecStart=/usr/bin/php /var/www/pterodactyl/artisan queue:work --queue=high,standard,low --sleep=3 --tries=3
|
|
||||||
StartLimitInterval=180
|
|
||||||
StartLimitBurst=30
|
|
||||||
RestartSec=5s
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
EOF
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
cat > /etc/systemd/system/pteroq.service <<- 'EOF'
|
cat > /etc/systemd/system/pteroq.service <<- 'EOF'
|
||||||
# Pterodactyl Queue Worker File
|
# Pterodactyl Queue Worker File
|
||||||
# ----------------------------------
|
# ----------------------------------
|
||||||
@ -462,97 +245,18 @@ EOF
|
|||||||
setsebool -P httpd_can_network_connect 1
|
setsebool -P httpd_can_network_connect 1
|
||||||
setsebool -P httpd_execmem 1
|
setsebool -P httpd_execmem 1
|
||||||
setsebool -P httpd_unified 1
|
setsebool -P httpd_unified 1
|
||||||
fi
|
|
||||||
sudo systemctl daemon-reload
|
sudo systemctl daemon-reload
|
||||||
systemctl enable --now pteroq.service
|
systemctl enable --now pteroq.service
|
||||||
}
|
}
|
||||||
|
|
||||||
upgrade_pterodactyl(){
|
upgrade_pterodactyl(){
|
||||||
cd /var/www/pterodactyl && php artisan p:upgrade
|
cd /var/www/pterodactyl && php artisan p:upgrade
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
chown -R www-data:www-data * /var/www/pterodactyl
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
chown -R nginx:nginx * /var/www/pterodactyl
|
chown -R nginx:nginx * /var/www/pterodactyl
|
||||||
restorecon -R /var/www/pterodactyl
|
restorecon -R /var/www/pterodactyl
|
||||||
fi
|
|
||||||
output "Your panel has successfully been updated to version ${PANEL}"
|
output "Your panel has successfully been updated to version ${PANEL}"
|
||||||
}
|
}
|
||||||
|
|
||||||
nginx_config() {
|
nginx_config(){
|
||||||
output "Disabling default configuration..."
|
|
||||||
rm -rf /etc/nginx/sites-enabled/default
|
|
||||||
output "Configuring Nginx Webserver..."
|
|
||||||
|
|
||||||
echo '
|
|
||||||
server {
|
|
||||||
listen 80 default_server;
|
|
||||||
listen [::]:80 default_server;
|
|
||||||
server_name '"$FQDN"';
|
|
||||||
return 301 https://$server_name$request_uri;
|
|
||||||
}
|
|
||||||
server {
|
|
||||||
listen 443 ssl http2 default_server;
|
|
||||||
listen [::]:443 ssl http2 default_server;
|
|
||||||
server_name '"$FQDN"';
|
|
||||||
|
|
||||||
root /var/www/pterodactyl/public;
|
|
||||||
index index.php;
|
|
||||||
|
|
||||||
access_log /var/log/nginx/pterodactyl.app-access.log;
|
|
||||||
error_log /var/log/nginx/pterodactyl.app-error.log error;
|
|
||||||
|
|
||||||
# allow larger file uploads and longer script runtimes
|
|
||||||
client_max_body_size 100m;
|
|
||||||
client_body_timeout 120s;
|
|
||||||
|
|
||||||
sendfile off;
|
|
||||||
|
|
||||||
# SSL Configuration
|
|
||||||
ssl_certificate /etc/letsencrypt/live/'"$FQDN"'/fullchain.pem;
|
|
||||||
ssl_certificate_key /etc/letsencrypt/live/'"$FQDN"'/privkey.pem;
|
|
||||||
ssl_session_cache shared:SSL:10m;
|
|
||||||
ssl_protocols TLSv1.2 TLSv1.3;
|
|
||||||
ssl_ciphers "ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384";
|
|
||||||
ssl_prefer_server_ciphers on;
|
|
||||||
|
|
||||||
add_header Strict-Transport-Security "max-age=15768000; includeSubdomains; preload;";
|
|
||||||
add_header X-Content-Type-Options nosniff;
|
|
||||||
add_header X-XSS-Protection "0";
|
|
||||||
add_header X-Robots-Tag none;
|
|
||||||
add_header Content-Security-Policy "upgrade-insecure-requests; block-all-mixed-content; frame-ancestors 'self'" always;
|
|
||||||
add_header Permissions-Policy "accelerometer=(), ambient-light-sensor=(), autoplay=(), battery=(), camera=(), clipboard-read=(), clipboard-write=(), display-capture=(), document-domain=(), encrypted-media=(), fullscreen=(), geolocation=(), gyroscope=(), hid=(), idle-detection=(), interest-cohort=(), magnetometer=(), microphone=(), midi=(), payment=(), picture-in-picture=(), publickey-credentials-get=(), screen-wake-lock=(), serial=(), sync-xhr=(), usb=(), xr-spatial-tracking=()" always;
|
|
||||||
add_header X-Frame-Options DENY;
|
|
||||||
add_header Referrer-Policy same-origin;
|
|
||||||
location / {
|
|
||||||
try_files $uri $uri/ /index.php?$query_string;
|
|
||||||
}
|
|
||||||
location ~ \.php$ {
|
|
||||||
fastcgi_split_path_info ^(.+\.php)(/.+)$;
|
|
||||||
fastcgi_pass unix:/run/php/php8.0-fpm.sock;
|
|
||||||
fastcgi_index index.php;
|
|
||||||
include fastcgi_params;
|
|
||||||
fastcgi_param PHP_VALUE "upload_max_filesize = 100M \n post_max_size=100M";
|
|
||||||
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
|
||||||
fastcgi_param HTTP_PROXY "";
|
|
||||||
fastcgi_intercept_errors off;
|
|
||||||
fastcgi_buffer_size 16k;
|
|
||||||
fastcgi_buffers 4 16k;
|
|
||||||
fastcgi_connect_timeout 300;
|
|
||||||
fastcgi_send_timeout 300;
|
|
||||||
fastcgi_read_timeout 300;
|
|
||||||
include /etc/nginx/fastcgi_params;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ /\.ht {
|
|
||||||
deny all;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
' | sudo -E tee /etc/nginx/sites-available/pterodactyl.conf >/dev/null 2>&1
|
|
||||||
ln -s /etc/nginx/sites-available/pterodactyl.conf /etc/nginx/sites-enabled/pterodactyl.conf
|
|
||||||
service nginx restart
|
|
||||||
}
|
|
||||||
|
|
||||||
nginx_config_redhat(){
|
|
||||||
output "Configuring Nginx web server..."
|
output "Configuring Nginx web server..."
|
||||||
|
|
||||||
echo '
|
echo '
|
||||||
@ -647,13 +351,9 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
webserver_config(){
|
webserver_config(){
|
||||||
if [ "$lsb_dist" = "debian" ] || [ "$lsb_dist" = "ubuntu" ]; then
|
|
||||||
nginx_config
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
php_config
|
php_config
|
||||||
nginx_config_redhat
|
nginx_config
|
||||||
chown -R nginx:nginx /var/lib/php/session
|
chown -R nginx:nginx /var/lib/php/session
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
setup_pterodactyl(){
|
setup_pterodactyl(){
|
||||||
@ -667,19 +367,10 @@ setup_pterodactyl(){
|
|||||||
install_wings() {
|
install_wings() {
|
||||||
cd /root || exit
|
cd /root || exit
|
||||||
output "Installing Pterodactyl Wings dependencies..."
|
output "Installing Pterodactyl Wings dependencies..."
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt-get -y install curl tar unzip
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install curl tar unzip
|
dnf -y install curl tar unzip
|
||||||
fi
|
|
||||||
|
|
||||||
output "Installing Docker"
|
output "Installing Docker"
|
||||||
if [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
|
|
||||||
dnf -y install docker-ce --allowerasing
|
|
||||||
else
|
|
||||||
curl -sSL https://get.docker.com/ | CHANNEL=stable bash
|
curl -sSL https://get.docker.com/ | CHANNEL=stable bash
|
||||||
fi
|
|
||||||
|
|
||||||
systemctl enable --now docker
|
systemctl enable --now docker
|
||||||
output "Installing the Pterodactyl wings..."
|
output "Installing the Pterodactyl wings..."
|
||||||
@ -740,17 +431,11 @@ upgrade_wings(){
|
|||||||
|
|
||||||
install_phpmyadmin(){
|
install_phpmyadmin(){
|
||||||
output "Installing phpMyAdmin..."
|
output "Installing phpMyAdmin..."
|
||||||
if [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install phpmyadmin
|
dnf -y install phpmyadmin
|
||||||
ln -s /usr/share/phpMyAdmin /var/www/pterodactyl/public/phpmyadmin
|
ln -s /usr/share/phpMyAdmin /var/www/pterodactyl/public/phpmyadmin
|
||||||
else
|
|
||||||
apt -y install phpmyadmin
|
|
||||||
ln -s /usr/share/phpmyadmin /var/www/pterodactyl/public/phpmyadmin
|
|
||||||
fi
|
|
||||||
cd /var/www/pterodactyl/public/phpmyadmin || exit
|
cd /var/www/pterodactyl/public/phpmyadmin || exit
|
||||||
SERVER_IP=$(dig +short myip.opendns.com @resolver1.opendns.com -4)
|
SERVER_IP=$(dig +short myip.opendns.com @resolver1.opendns.com -4)
|
||||||
BOWFISH=`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 34 | head -n 1`
|
BOWFISH=`cat /dev/urandom | tr -dc 'a-zA-Z0-9' | fold -w 34 | head -n 1`
|
||||||
if [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
bash -c 'cat > /etc/phpMyAdmin/config.inc.php' <<EOF
|
bash -c 'cat > /etc/phpMyAdmin/config.inc.php' <<EOF
|
||||||
<?php
|
<?php
|
||||||
/* Servers configuration */
|
/* Servers configuration */
|
||||||
@ -781,38 +466,6 @@ EOF
|
|||||||
chmod 644 /etc/phpMyAdmin/config.inc.php
|
chmod 644 /etc/phpMyAdmin/config.inc.php
|
||||||
chown -R nginx:nginx /var/www/pterodactyl
|
chown -R nginx:nginx /var/www/pterodactyl
|
||||||
chown -R nginx:nginx /var/lib/phpMyAdmin/temp
|
chown -R nginx:nginx /var/lib/phpMyAdmin/temp
|
||||||
elif [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
bash -c 'cat > /etc/phpmyadmin/config.inc.php' <<EOF
|
|
||||||
<?php
|
|
||||||
/* Servers configuration */
|
|
||||||
\$i = 0;
|
|
||||||
/* Server: MariaDB [1] */
|
|
||||||
\$i++;
|
|
||||||
\$cfg['Servers'][\$i]['verbose'] = 'MariaDB';
|
|
||||||
\$cfg['Servers'][\$i]['host'] = '${SERVER_IP}';
|
|
||||||
\$cfg['Servers'][\$i]['port'] = '3306';
|
|
||||||
\$cfg['Servers'][\$i]['socket'] = '';
|
|
||||||
\$cfg['Servers'][\$i]['auth_type'] = 'cookie';
|
|
||||||
\$cfg['Servers'][\$i]['user'] = 'root';
|
|
||||||
\$cfg['Servers'][\$i]['password'] = '';
|
|
||||||
\$cfg['Servers'][$i]['ssl'] = true;
|
|
||||||
\$cfg['ForceSSL'] = true;
|
|
||||||
/* End of servers configuration */
|
|
||||||
\$cfg['blowfish_secret'] = '${BOWFISH}';
|
|
||||||
\$cfg['DefaultLang'] = 'en';
|
|
||||||
\$cfg['ServerDefault'] = 1;
|
|
||||||
\$cfg['UploadDir'] = '/var/lib/phpmyadmin/upload';
|
|
||||||
\$cfg['SaveDir'] = '/var/lib/phpmyadmin/save';
|
|
||||||
\$cfg['CaptchaLoginPublicKey'] = '6LcJcjwUAAAAAO_Xqjrtj9wWufUpYRnK6BW8lnfn';
|
|
||||||
\$cfg['CaptchaLoginPrivateKey'] = '6LcJcjwUAAAAALOcDJqAEYKTDhwELCkzUkNDQ0J5';
|
|
||||||
\$cfg['AuthLog'] = syslog
|
|
||||||
?>
|
|
||||||
EOF
|
|
||||||
chmod 755 /etc/phpmyadmin
|
|
||||||
chmod 644 /etc/phpmyadmin/config.inc.php
|
|
||||||
chown -R www-data:www-data /var/www/pterodactyl
|
|
||||||
chown -R www-data:www-data /var/lib/phpmyadmin/temp
|
|
||||||
fi
|
|
||||||
|
|
||||||
bash -c 'cat > /etc/fail2ban/jail.local' <<-'EOF'
|
bash -c 'cat > /etc/fail2ban/jail.local' <<-'EOF'
|
||||||
[DEFAULT]
|
[DEFAULT]
|
||||||
@ -832,21 +485,16 @@ EOF
|
|||||||
ssl_certs(){
|
ssl_certs(){
|
||||||
output "Installing Let's Encrypt and creating an SSL certificate..."
|
output "Installing Let's Encrypt and creating an SSL certificate..."
|
||||||
cd /root || exit
|
cd /root || exit
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt-get -y install certbot
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install certbot
|
dnf -y install certbot
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$installoption" = "1" ] || [ "$installoption" = "3" ]; then
|
if [ "$installoption" = "1" ] || [ "$installoption" = "3" ]; then
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt-get -y install python3-certbot-nginx
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install python3-certbot-nginx
|
dnf -y install python3-certbot-nginx
|
||||||
fi
|
|
||||||
certbot --nginx --redirect --no-eff-email --email "$email" --agree-tos -d "$FQDN"
|
certbot --nginx --redirect --no-eff-email --email "$email" --agree-tos -d "$FQDN"
|
||||||
setfacl -Rdm u:mysql:rx /etc/letsencrypt
|
setfacl -Rdm u:mysql:rx /etc/letsencrypt
|
||||||
setfacl -Rm u:mysql:rx /etc/letsencrypt
|
setfacl -Rm u:mysql:rx /etc/letsencrypt
|
||||||
|
sed -i '/\[mysqld\]/a ssl-key=/etc/letsencrypt/live/'"${FQDN}"'/privkey.pem' /etc/my.cnf.d/server.cnf
|
||||||
|
sed -i '/\[mysqld\]/a ssl-ca=/etc/letsencrypt/live/'"${FQDN}"'/chain.pem' /etc/my.cnf.d/server.cnf
|
||||||
|
sed -i '/\[mysqld\]/a ssl-cert=/etc/letsencrypt/live/'"${FQDN}"'/cert.pem' /etc/my.cnf.d/server.cnf
|
||||||
systemctl restart mariadb
|
systemctl restart mariadb
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -858,11 +506,7 @@ ssl_certs(){
|
|||||||
|
|
||||||
firewall(){
|
firewall(){
|
||||||
output "Setting up Fail2Ban..."
|
output "Setting up Fail2Ban..."
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt -y install fail2ban
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install fail2ban
|
dnf -y install fail2ban
|
||||||
fi
|
|
||||||
systemctl enable fail2ban
|
systemctl enable fail2ban
|
||||||
bash -c 'cat > /etc/fail2ban/jail.local' <<-'EOF'
|
bash -c 'cat > /etc/fail2ban/jail.local' <<-'EOF'
|
||||||
[DEFAULT]
|
[DEFAULT]
|
||||||
@ -877,26 +521,6 @@ EOF
|
|||||||
service fail2ban restart
|
service fail2ban restart
|
||||||
|
|
||||||
output "Configuring your firewall..."
|
output "Configuring your firewall..."
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
apt-get -y install ufw
|
|
||||||
ufw allow 22
|
|
||||||
if [ "$installoption" = "1" ]; then
|
|
||||||
ufw allow 80
|
|
||||||
ufw allow 443
|
|
||||||
ufw allow 3306
|
|
||||||
elif [ "$installoption" = "2" ]; then
|
|
||||||
ufw allow 80
|
|
||||||
ufw allow 8080
|
|
||||||
ufw allow 2022
|
|
||||||
elif [ "$installoption" = "3" ]; then
|
|
||||||
ufw allow 80
|
|
||||||
ufw allow 443
|
|
||||||
ufw allow 8080
|
|
||||||
ufw allow 2022
|
|
||||||
ufw allow 3306
|
|
||||||
fi
|
|
||||||
yes | ufw enable
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
dnf -y install firewalld
|
dnf -y install firewalld
|
||||||
systemctl enable firewalld
|
systemctl enable firewalld
|
||||||
systemctl start firewalld
|
systemctl start firewalld
|
||||||
@ -919,7 +543,6 @@ EOF
|
|||||||
firewall-cmd --permanent --zone=trusted --change-interface=pterodactyl0
|
firewall-cmd --permanent --zone=trusted --change-interface=pterodactyl0
|
||||||
firewall-cmd --zone=trusted --add-masquerade --permanent
|
firewall-cmd --zone=trusted --add-masquerade --permanent
|
||||||
fi
|
fi
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
database_host_reset(){
|
database_host_reset(){
|
||||||
@ -945,11 +568,7 @@ broadcast(){
|
|||||||
output "FIREWALL INFORMATION"
|
output "FIREWALL INFORMATION"
|
||||||
output ""
|
output ""
|
||||||
output "All unnecessary ports are blocked by default."
|
output "All unnecessary ports are blocked by default."
|
||||||
if [ "$lsb_dist" = "ubuntu" ] || [ "$lsb_dist" = "debian" ]; then
|
|
||||||
output "Use 'ufw allow <port>' to enable your desired ports."
|
|
||||||
elif [ "$lsb_dist" = "fedora" ] || [ "$lsb_dist" = "centos" ] || [ "$lsb_dist" = "rhel" ] || [ "$lsb_dist" = "rocky" ] || [ "$lsb_dist" = "almalinux" ]; then
|
|
||||||
output "Use 'firewall-cmd --permanent --add-port=<port>/tcp' to enable your desired ports."
|
output "Use 'firewall-cmd --permanent --add-port=<port>/tcp' to enable your desired ports."
|
||||||
fi
|
|
||||||
output "------------------------------------------------------------------"
|
output "------------------------------------------------------------------"
|
||||||
output ""
|
output ""
|
||||||
}
|
}
|
||||||
@ -973,23 +592,20 @@ broadcast_database(){
|
|||||||
preflight
|
preflight
|
||||||
install_options
|
install_options
|
||||||
case $installoption in
|
case $installoption in
|
||||||
1) repositories_setup
|
1) required_infos
|
||||||
required_infos
|
|
||||||
firewall
|
firewall
|
||||||
setup_pterodactyl
|
setup_pterodactyl
|
||||||
broadcast
|
broadcast
|
||||||
broadcast_database
|
broadcast_database
|
||||||
;;
|
;;
|
||||||
2) repositories_setup
|
2) required_infos
|
||||||
required_infos
|
|
||||||
firewall
|
firewall
|
||||||
ssl_certs
|
ssl_certs
|
||||||
install_wings
|
install_wings
|
||||||
broadcast
|
broadcast
|
||||||
broadcast_database
|
broadcast_database
|
||||||
;;
|
;;
|
||||||
3) repositories_setup
|
3) required_infos
|
||||||
required_infos
|
|
||||||
firewall
|
firewall
|
||||||
setup_pterodactyl
|
setup_pterodactyl
|
||||||
install_wings
|
install_wings
|
||||||
|
52
remi9.asc
Normal file
52
remi9.asc
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
-----BEGIN PGP PUBLIC KEY BLOCK-----
|
||||||
|
|
||||||
|
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
|
||||||
|
=xAif
|
||||||
|
-----END PGP PUBLIC KEY BLOCK-----
|
Loading…
Reference in New Issue
Block a user