mirror of
https://github.com/joglomedia/LEMPer.git
synced 2026-04-03 11:18:21 +00:00
923 lines
33 KiB
Bash
Executable File
923 lines
33 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# PHP Installer
|
|
# Min. Requirement : GNU/Linux Ubuntu 14.04 & 16.04
|
|
# Last Build : 05/11/2019
|
|
# Author : ESLabs.ID (eslabs.id@gmail.com)
|
|
# Since Version : 1.0.0
|
|
|
|
# Include helper functions.
|
|
if [ "$(type -t run)" != "function" ]; then
|
|
BASEDIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )
|
|
# shellchechk source=scripts/helper.sh
|
|
# shellcheck disable=SC1090
|
|
. "${BASEDIR}/helper.sh"
|
|
fi
|
|
|
|
# Make sure only root can run this installer script.
|
|
requires_root
|
|
|
|
##
|
|
# Add PHP repository.
|
|
#
|
|
function add_php_repo() {
|
|
echo "Add Ondrej's PHP repository..."
|
|
|
|
DISTRIB_NAME=${DISTRIB_NAME:-$(get_distrib_name)}
|
|
RELEASE_NAME=${RELEASE_NAME:-$(get_release_name)}
|
|
|
|
case ${DISTRIB_NAME} in
|
|
debian)
|
|
if [ ! -f "/etc/apt/sources.list.d/ondrej-php-${RELEASE_NAME}.list" ]; then
|
|
run touch "/etc/apt/sources.list.d/ondrej-php-${RELEASE_NAME}.list"
|
|
run bash -c "echo 'deb https://packages.sury.org/php/ ${RELEASE_NAME} main' > /etc/apt/sources.list.d/ondrej-php-${RELEASE_NAME}.list"
|
|
run bash -c "wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg"
|
|
run apt-get -qq update -y
|
|
else
|
|
warning "PHP repository already exists."
|
|
fi
|
|
;;
|
|
ubuntu)
|
|
# Fix for NO_PUBKEY key servers error.
|
|
run apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 4F4EA0AAE5267A6C
|
|
run add-apt-repository -y ppa:ondrej/php
|
|
run apt-get -qq update -y
|
|
;;
|
|
*)
|
|
fail "Unable to install PHP, this GNU/Linux distribution is not supported."
|
|
;;
|
|
esac
|
|
}
|
|
|
|
##
|
|
# Install PHP & FPM package.
|
|
#
|
|
function install_php_fpm() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
local PHP_PKGS=()
|
|
export PHP_IS_INSTALLED="no"
|
|
|
|
# Checking if php already installed.
|
|
if [[ -n $(command -v "php${PHPv}") ]]; then
|
|
PHP_IS_INSTALLED="yes"
|
|
warning "PHP${PHPv} & FPM package already installed..."
|
|
else
|
|
# Add repo first
|
|
add_php_repo
|
|
|
|
echo "Installing PHP${PHPv} & FPM..."
|
|
|
|
if hash apt-get 2>/dev/null; then
|
|
PHP_PKGS=("php${PHPv} php${PHPv}-bcmath php${PHPv}-cli php${PHPv}-common \
|
|
php${PHPv}-curl php${PHPv}-dev php${PHPv}-fpm php${PHPv}-mysql php${PHPv}-gd \
|
|
php${PHPv}-gmp php${PHPv}-imap php${PHPv}-intl php${PHPv}-json \
|
|
php${PHPv}-mbstring php${PHPv}-opcache php${PHPv}-pspell php${PHPv}-readline \
|
|
php${PHPv}-ldap php${PHPv}-snmp php${PHPv}-soap php${PHPv}-sqlite3 \
|
|
php${PHPv}-tidy php${PHPv}-xml php${PHPv}-xmlrpc php${PHPv}-xsl php${PHPv}-zip \
|
|
php-pear php-xml pkg-php-tools spawn-fcgi fcgiwrap" "${PHP_PKGS[@]}")
|
|
|
|
if [[ "${#PHP_PKGS[@]}" -gt 0 ]]; then
|
|
echo "Installing PHP${PHPv} & FPM packages..."
|
|
# shellcheck disable=SC2068
|
|
run apt-get -qq install -y ${PHP_PKGS[@]}
|
|
fi
|
|
|
|
if [[ -n $(command -v "php${PHPv}") ]]; then
|
|
status "PHP${PHPv} & FPM packages installed."
|
|
fi
|
|
|
|
# Install php geoip?
|
|
if "${AUTO_INSTALL}"; then
|
|
local INSTALL_PHPGEOIP="y"
|
|
else
|
|
while [[ "${INSTALL_PHPGEOIP}" != "y" && "${INSTALL_PHPGEOIP}" != "n" ]]; do
|
|
read -rp "Do you want to install PHP GeoIP for geolocation? [y/n]: " \
|
|
-i n -e INSTALL_PHPGEOIP
|
|
done
|
|
fi
|
|
if [[ ${INSTALL_PHPGEOIP} == Y* || ${INSTALL_PHPGEOIP} == y* ]]; then
|
|
echo "Installing PHP GeoIP module..."
|
|
|
|
if [ "${PHPv//.}" -lt "70" ]; then
|
|
#run mkdir -p /usr/lib/php/php-helper
|
|
run apt-get -qq install -y php-geoip
|
|
else
|
|
run pecl install geoip-1.1.1
|
|
|
|
# Enable GeoIP module.
|
|
echo "Updating PHP ini file with GeoIP module..."
|
|
|
|
[ ! -f "/etc/php/${PHPv}/mods-available/geoip.ini" ] && \
|
|
run touch "/etc/php/${PHPv}/mods-available/geoip.ini"
|
|
run bash -c "echo extension=geoip.so > /etc/php/${PHPv}/mods-available/geoip.ini"
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/cli/conf.d/20-geoip.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/geoip.ini" \
|
|
"/etc/php/${PHPv}/cli/conf.d/20-geoip.ini"
|
|
fi
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/fpm/conf.d/20-geoip.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/geoip.ini" \
|
|
"/etc/php/${PHPv}/fpm/conf.d/20-geoip.ini"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
# Install php mcrypt?
|
|
if "${AUTO_INSTALL}"; then
|
|
local INSTALL_PHPMCRYPT="y"
|
|
else
|
|
while [[ "${INSTALL_PHPMCRYPT}" != "y" && "${INSTALL_PHPMCRYPT}" != "n" ]]; do
|
|
read -rp "Do you want to install PHP Mcrypt for encryption/decryption? [y/n]: " \
|
|
-i n -e INSTALL_PHPMCRYPT
|
|
done
|
|
fi
|
|
if [[ ${INSTALL_PHPMCRYPT} == Y* || ${INSTALL_PHPMCRYPT} == y* ]]; then
|
|
echo "Installing PHP Mcrypt module..."
|
|
|
|
if [ "${PHPv//.}" -lt "72" ]; then
|
|
run apt-get -qq install -y "php${PHPv}-mcrypt"
|
|
elif [ "${PHPv}" == "7.2" ]; then
|
|
run apt-get -qq install -y gcc make autoconf libc-dev pkg-config \
|
|
libmcrypt-dev libreadline-dev && \
|
|
run pecl install mcrypt-1.0.1
|
|
|
|
# Enable Mcrypt module.
|
|
echo "Updating PHP ini file with Mcrypt module..."
|
|
|
|
[ ! -f "/etc/php/${PHPv}/mods-available/mcrypt.ini" ] && \
|
|
run touch "/etc/php/${PHPv}/mods-available/mcrypt.ini"
|
|
run bash -c "echo extension=mcrypt.so > /etc/php/${PHPv}/mods-available/mcrypt.ini"
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/cli/conf.d/20-mcrypt.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/mcrypt.ini" \
|
|
"/etc/php/${PHPv}/cli/conf.d/20-mcrypt.ini"
|
|
fi
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/fpm/conf.d/20-mcrypt.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/mcrypt.ini" \
|
|
"/etc/php/${PHPv}/fpm/conf.d/20-mcrypt.ini"
|
|
fi
|
|
else
|
|
run apt-get -qq install -y dh-php
|
|
|
|
# Use libsodium instead.
|
|
warning -n "Info: "
|
|
echo "Mcrypt module is deprecated for PHP ${PHPv} or greater, use Libsodium or OpenSSL for encryption."
|
|
fi
|
|
fi
|
|
elif hash yum 2>/dev/null; then
|
|
if [ "${VERSION_ID}" == "5" ]; then
|
|
yum -y update
|
|
#yum -y localinstall ${PHP_PKGS[@]} --nogpgcheck
|
|
else
|
|
yum -y update
|
|
#yum -y localinstall ${PHP_PKGS[@]}
|
|
fi
|
|
else
|
|
fail "Unable to install NGiNX, this GNU/Linux distribution is not supported."
|
|
fi
|
|
|
|
# Create PHP log dir.
|
|
if [ ! -d /var/log/php ]; then
|
|
mkdir -p /var/log/php
|
|
fi
|
|
fi
|
|
}
|
|
|
|
##
|
|
# Install ionCube Loader.
|
|
#
|
|
function install_ioncube() {
|
|
echo "Installing ionCube PHP loader..."
|
|
|
|
# Delete old loaders file.
|
|
if [ -d /usr/lib/php/loaders/ioncube ]; then
|
|
echo "Removing old/existing ionCube PHP loader..."
|
|
run rm -fr /usr/lib/php/loaders/ioncube
|
|
fi
|
|
|
|
local CURRENT_DIR && CURRENT_DIR=$(pwd)
|
|
run cd "${BUILD_DIR}"
|
|
|
|
ARCH=${ARCH:-$(uname -p)}
|
|
if [[ "${ARCH}" == "x86_64" ]]; then
|
|
run wget -q "http://downloads2.ioncube.com/loader_downloads/ioncube_loaders_lin_x86-64.tar.gz"
|
|
run tar -xzf ioncube_loaders_lin_x86-64.tar.gz
|
|
run rm -f ioncube_loaders_lin_x86-64.tar.gz
|
|
else
|
|
run wget -q "http://downloads2.ioncube.com/loader_downloads/ioncube_loaders_lin_x86.tar.gz"
|
|
run tar -xzf ioncube_loaders_lin_x86.tar.gz
|
|
run rm -f ioncube_loaders_lin_x86.tar.gz
|
|
fi
|
|
|
|
echo "Installing latest ionCube PHP loader..."
|
|
run mv -f ioncube /usr/lib/php/loaders/
|
|
run cd "${CURRENT_DIR}"
|
|
}
|
|
|
|
##
|
|
# Enable ionCube Loader.
|
|
#
|
|
function enable_ioncube() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Enabling ionCube PHP${PHPv} loader"
|
|
|
|
if "${DRYRUN}"; then
|
|
warning "ionCube PHP${PHPv} enabled in dryrun mode."
|
|
else
|
|
if [ -f "/usr/lib/php/loaders/ioncube/ioncube_loader_lin_${PHPv}.so" ]; then
|
|
cat > "/etc/php/${PHPv}/mods-available/ioncube.ini" <<EOL
|
|
[ioncube]
|
|
zend_extension=/usr/lib/php/loaders/ioncube/ioncube_loader_lin_${PHPv}.so
|
|
EOL
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/fpm/conf.d/05-ioncube.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/ioncube.ini" \
|
|
"/etc/php/${PHPv}/fpm/conf.d/05-ioncube.ini"
|
|
fi
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/cli/conf.d/05-ioncube.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/ioncube.ini" \
|
|
"/etc/php/${PHPv}/cli/conf.d/05-ioncube.ini"
|
|
fi
|
|
else
|
|
warning "Sorry, no ionCube loader found for PHP${PHPv}"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
##
|
|
# Disable ionCube Loader.
|
|
#
|
|
function disable_ioncube() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Disabling ionCube PHP${PHPv} loader"
|
|
|
|
run unlink "/etc/php/${PHPv}/fpm/conf.d/05-ioncube.ini"
|
|
run unlink "/etc/php/${PHPv}/cli/conf.d/05-ioncube.ini"
|
|
}
|
|
|
|
##
|
|
# Remove ionCube Loader.
|
|
#
|
|
function remove_ioncube() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Uninstalling ionCube PHP${PHPv} loader..."
|
|
|
|
if [[ -f "/etc/php/${PHPv}/fpm/conf.d/05-ioncube.ini" || \
|
|
-f "/etc/php/${PHPv}/cli/conf.d/05-ioncube.ini" ]]; then
|
|
disable_ioncube "${PHPv}"
|
|
fi
|
|
|
|
if [ -d /usr/lib/php/loaders/ioncube ]; then
|
|
run rm -fr /usr/lib/php/loaders/ioncube
|
|
status "ionCube PHP${PHPv} loader has been removed."
|
|
else
|
|
warning "ionCube PHP${PHPv} loader couldn't be found."
|
|
fi
|
|
}
|
|
|
|
##
|
|
# Install SourceGuardian Loader.
|
|
#
|
|
function install_sourceguardian() {
|
|
echo "Installing SourceGuardian PHP loader..."
|
|
|
|
# Delete old loaders file.
|
|
if [ -d /usr/lib/php/loaders/sourceguardian ]; then
|
|
echo "Removing old/existing loader..."
|
|
run rm -fr /usr/lib/php/loaders/sourceguardian
|
|
fi
|
|
|
|
if [ ! -d "${BUILD_DIR}/sourceguardian" ]; then
|
|
run mkdir -p "${BUILD_DIR}/sourceguardian"
|
|
fi
|
|
|
|
local CURRENT_DIR && CURRENT_DIR=$(pwd)
|
|
run cd "${BUILD_DIR}/sourceguardian"
|
|
|
|
ARCH=${ARCH:-$(uname -p)}
|
|
if [[ "${ARCH}" == "x86_64" ]]; then
|
|
run wget -q "http://www.sourceguardian.com/loaders/download/loaders.linux-x86_64.tar.gz"
|
|
run tar -xzf loaders.linux-x86_64.tar.gz
|
|
run rm -f loaders.linux-x86_64.tar.gz
|
|
else
|
|
run wget -q "http://www.sourceguardian.com/loaders/download/loaders.linux-x86.tar.gz"
|
|
run tar -xzf loaders.linux-x86.tar.gz
|
|
run rm -f loaders.linux-x86.tar.gz
|
|
fi
|
|
|
|
run cd "${CURRENT_DIR}"
|
|
|
|
echo "Installing latest SourceGuardian PHP loader..."
|
|
run mv -f "${BUILD_DIR}/sourceguardian" /usr/lib/php/loaders/
|
|
}
|
|
|
|
##
|
|
# Enable SourceGuardian Loader.
|
|
#
|
|
function enable_sourceguardian() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Enabling SourceGuardian PHP${PHPv} loader..."
|
|
|
|
if "${DRYRUN}"; then
|
|
warning "SourceGuardian PHP${PHPv} enabled in dryrun mode."
|
|
else
|
|
if [ -f "/usr/lib/php/loaders/sourceguardian/ixed.${PHPv}.lin" ]; then
|
|
cat > "/etc/php/${PHPv}/mods-available/sourceguardian.ini" <<EOL
|
|
[sourceguardian]
|
|
zend_extension=/usr/lib/php/loaders/sourceguardian/ixed.${PHPv}.lin
|
|
EOL
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/fpm/conf.d/05-sourceguardian.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/sourceguardian.ini" \
|
|
"/etc/php/${PHPv}/fpm/conf.d/05-sourceguardian.ini"
|
|
fi
|
|
|
|
if [ ! -f "/etc/php/${PHPv}/cli/conf.d/05-sourceguardian.ini" ]; then
|
|
run ln -s "/etc/php/${PHPv}/mods-available/sourceguardian.ini" \
|
|
"/etc/php/${PHPv}/cli/conf.d/05-sourceguardian.ini"
|
|
fi
|
|
else
|
|
warning "Sorry, no SourceGuardian loader found for PHP ${PHPv}"
|
|
fi
|
|
fi
|
|
}
|
|
|
|
##
|
|
# Disable SourceGuardian Loader.
|
|
#
|
|
function disable_sourceguardian() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Disabling SourceGuardian PHP${PHPv} loader"
|
|
|
|
run unlink "/etc/php/${PHPv}/fpm/conf.d/05-sourceguardian.ini"
|
|
run unlink "/etc/php/${PHPv}/cli/conf.d/05-sourceguardian.ini"
|
|
}
|
|
|
|
##
|
|
# Remove SourceGuardian Loader.
|
|
#
|
|
function remove_sourceguardian() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Uninstalling SourceGuardian PHP${PHPv} loader..."
|
|
|
|
if [[ -f "/etc/php/${PHPv}/fpm/conf.d/05-sourceguardian.ini" || \
|
|
-f "/etc/php/${PHPv}/cli/conf.d/05-sourceguardian.ini" ]]; then
|
|
disable_sourceguardian "${PHPv}"
|
|
fi
|
|
|
|
if [ -d /usr/lib/php/loaders/sourceguardian ]; then
|
|
run rm -fr /usr/lib/php/loaders/sourceguardian
|
|
status "SourceGuardian PHP${PHPv} loader has been removed."
|
|
else
|
|
warning "SourceGuardian PHP${PHPv} loader couldn't be found."
|
|
fi
|
|
}
|
|
|
|
##
|
|
# PHP & FPM Optimization.
|
|
#
|
|
function optimize_php_fpm() {
|
|
# PHP version.
|
|
local PHPv="${1}"
|
|
if [ -z "${PHPv}" ]; then
|
|
PHPv=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
|
|
echo "Optimizing PHP${PHPv} & FPM configuration..."
|
|
|
|
if [ ! -d "/etc/php/${PHPv}/fpm" ]; then
|
|
run mkdir -p "/etc/php/${PHPv}/fpm"
|
|
fi
|
|
|
|
# Copy the optimized-version of php.ini
|
|
if [ -f "etc/php/${PHPv}/fpm/php.ini" ]; then
|
|
run mv "/etc/php/${PHPv}/fpm/php.ini" "/etc/php/${PHPv}/fpm/php.ini~"
|
|
run cp -f "etc/php/${PHPv}/fpm/php.ini" "/etc/php/${PHPv}/fpm/"
|
|
else
|
|
if ! "${DRYRUN}"; then
|
|
cat >> "/etc/php/${PHPv}/fpm/php.ini" <<EOL
|
|
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
; Custom Optimization for LEMPer ;
|
|
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
|
|
[opcache]
|
|
opcache.enable=1
|
|
opcache.enable_cli=0
|
|
opcache.memory_consumption=128
|
|
opcache.interned_strings_buffer=8
|
|
opcache.max_accelerated_files=10000
|
|
opcache.max_wasted_percentage=5
|
|
opcache.validate_timestamps=1
|
|
opcache.revalidate_freq=1
|
|
opcache.save_comments=1
|
|
opcache.error_log="/var/log/php/php${PHPv}-opcache_error.log"
|
|
EOL
|
|
else
|
|
warning "PHP configuration optimized in dry run mode."
|
|
fi
|
|
fi
|
|
|
|
# Copy the optimized-version of php-fpm config file.
|
|
if [ -f "etc/php/${PHPv}/fpm/php-fpm.conf" ]; then
|
|
run mv "/etc/php/${PHPv}/fpm/php-fpm.conf" "/etc/php/${PHPv}/fpm/php-fpm.conf~"
|
|
run cp -f "etc/php/${PHPv}/fpm/php-fpm.conf" "/etc/php/${PHPv}/fpm/"
|
|
else
|
|
if grep -qwE "^error_log\ =\ \/var\/log\/php${PHPv}-fpm.log" "/etc/php/${PHPv}/fpm/php-fpm.conf"; then
|
|
run sed -i "s|^error_log\ =\ /var/log/php${PHPv}-fpm.log|error_log\ =\ /var/log/php/php${PHPv}-fpm.log/g" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
else
|
|
run sed -i "/^;error_log/a error_log\ =\ \/var\/log\/php\/php${PHPv}-fpm.log" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
fi
|
|
|
|
if grep -qwE "^emergency_restart_threshold\ =\ [0-9]*" "/etc/php/${PHPv}/fpm/php-fpm.conf"; then
|
|
run sed -i "s/^emergency_restart_threshold\ =\ [0-9]*/emergency_restart_threshold\ =\ 10/g" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
else
|
|
run sed -i "/^;emergency_restart_threshold/a emergency_restart_threshold\ =\ 10" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
fi
|
|
|
|
if grep -qwE "^emergency_restart_interval\ =\ [0-9]*" "/etc/php/${PHPv}/fpm/php-fpm.conf"; then
|
|
run sed -i "s/^emergency_restart_interval\ =\ [0-9]*/emergency_restart_interval\ =\ 60/g" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
else
|
|
run sed -i "/^;emergency_restart_interval/a emergency_restart_interval\ =\ 60" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
fi
|
|
|
|
if grep -qwE "^process_control_timeout\ =\ [0-9]*" "/etc/php/${PHPv}/fpm/php-fpm.conf"; then
|
|
run sed -i "s/^process_control_timeout\ =\ [0-9]*/process_control_timeout\ =\ 10/g" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
else
|
|
run sed -i "/^;process_control_timeout/a process_control_timeout\ =\ 10" \
|
|
"/etc/php/${PHPv}/fpm/php-fpm.conf"
|
|
fi
|
|
fi
|
|
|
|
if [ ! -d "/etc/php/${PHPv}/fpm/pool.d" ]; then
|
|
run mkdir -p "/etc/php/${PHPv}/fpm/pool.d"
|
|
fi
|
|
|
|
# Copy the optimized-version of php fpm default pool.
|
|
if [ -f "etc/php/${PHPv}/fpm/pool.d/www.conf" ]; then
|
|
run mv "/etc/php/${PHPv}/fpm/pool.d/www.conf" "/etc/php/${PHPv}/fpm/pool.d/www.conf~"
|
|
run cp -f "etc/php/${PHPv}/fpm/pool.d/www.conf" "/etc/php/${PHPv}/fpm/pool.d/"
|
|
|
|
# Update timezone.
|
|
run run sed -i "s|php_admin_value\[date\.timezone\]\ =\ UTC|php_admin_value\[date\.timezone\]\ =\ ${TIMEZONE}|g" \
|
|
"/etc/php/${PHPv}/fpm/pool.d/www.conf"
|
|
else
|
|
# Enable FPM ping service.
|
|
run sed -i "/^;ping.path\ =.*/a ping.path\ =\ \/ping" "/etc/php/${PHPv}/fpm/pool.d/www.conf"
|
|
|
|
# Enable FPM status.
|
|
run sed -i "/^;pm.status_path\ =.*/a pm.status_path\ =\ \/status" "/etc/php/${PHPv}/fpm/pool.d/www.conf"
|
|
|
|
# Enable chdir.
|
|
run sed -i "/^;chdir\ =.*/a chdir\ =\ \/usr\/share\/nginx\/html" "/etc/php/${PHPv}/fpm/pool.d/www.conf"
|
|
|
|
# Add custom php extension (ex .php70, .php71)
|
|
PHPExt=".php${PHPv//.}"
|
|
run sed -i "s/;\(security\.limit_extensions\s*=\s*\).*$/\1\.php\ $PHPExt/g" \
|
|
"/etc/php/${PHPv}/fpm/pool.d/www.conf"
|
|
|
|
# Customize php ini settings.
|
|
if ! "${DRYRUN}"; then
|
|
cat >> "/etc/php/${PHPv}/fpm/pool.d/www.conf" <<EOL
|
|
php_flag[display_errors] = On
|
|
;php_admin_value[error_reporting] = E_ALL & ~E_DEPRECATED & ~E_STRICT
|
|
;php_admin_value[disable_functions] = pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,exec,passthru,popen,proc_open,shell_exec,system
|
|
php_admin_flag[log_errors] = On
|
|
php_admin_value[error_log] = /var/log/php/php7.3-fpm.\$pool.log
|
|
php_admin_value[date.timezone] = UTC
|
|
php_admin_value[memory_limit] = 128M
|
|
php_admin_value[opcache.file_cache] = /usr/share/nginx/html/.lemper/php/opcache
|
|
php_admin_value[open_basedir] = /usr/share/nginx/html
|
|
php_admin_value[session.save_path] = /usr/share/nginx/html/.lemper/php/sessions
|
|
php_admin_value[sys_temp_dir] = /usr/share/nginx/html/.lemper/tmp
|
|
php_admin_value[upload_tmp_dir] = /usr/share/nginx/html/.lemper/tmp
|
|
php_admin_value[upload_max_filesize] = 20M
|
|
php_admin_value[post_max_size] = 20M
|
|
EOL
|
|
else
|
|
warning "Default FPM pool optimized in dry run mode."
|
|
fi
|
|
fi
|
|
|
|
# Copy the optimized-version of php fpm default lemper pool.
|
|
local POOLNAME=${LEMPER_USERNAME:-"lemper"}
|
|
if [[ -f "etc/php/${PHPv}/fpm/pool.d/lemper.conf" && ${POOLNAME} = "lemper" ]]; then
|
|
run cp -f "etc/php/${PHPv}/fpm/pool.d/lemper.conf" "/etc/php/${PHPv}/fpm/pool.d/${POOLNAME}.conf"
|
|
|
|
# Update timezone.
|
|
run sed -i "s|php_admin_value\[date\.timezone\]\ =\ UTC|php_admin_value\[date\.timezone\]\ =\ ${TIMEZONE}|g" \
|
|
"/etc/php/${PHPv}/fpm/pool.d/${POOLNAME}.conf"
|
|
else
|
|
if [[ -f "/etc/php/${PHPv}/fpm/pool.d/lemper.conf" && -z $(getent passwd "${POOLNAME}") ]]; then
|
|
run mv "/etc/php/${PHPv}/fpm/pool.d/lemper.conf" "/etc/php/${PHPv}/fpm/pool.d/lemper.conf~"
|
|
fi
|
|
|
|
# Create custom pool configuration.
|
|
if ! "${DRYRUN}"; then
|
|
touch "/etc/php/${PHPv}/fpm/pool.d/${POOLNAME}.conf"
|
|
cat > "/etc/php/${PHPv}/fpm/pool.d/${POOLNAME}.conf" <<EOL
|
|
[${POOLNAME}]
|
|
user = ${POOLNAME}
|
|
group = ${POOLNAME}
|
|
|
|
listen = /run/php/php${PHPv}-fpm.\$pool.sock
|
|
listen.owner = ${POOLNAME}
|
|
listen.group = ${POOLNAME}
|
|
listen.mode = 0666
|
|
;listen.allowed_clients = 127.1.0.1
|
|
|
|
; Custom PHP-FPM optimization
|
|
; adjust here to meet your needs.
|
|
pm = dynamic
|
|
pm.max_children = 5
|
|
pm.start_servers = 2
|
|
pm.min_spare_servers = 1
|
|
pm.max_spare_servers = 3
|
|
pm.process_idle_timeout = 30s
|
|
pm.max_requests = 500
|
|
|
|
pm.status_path = /status
|
|
ping.path = /ping
|
|
|
|
slowlog = /var/log/php/php${PHPv}-fpm_slow.\$pool.log
|
|
request_slowlog_timeout = 10s
|
|
|
|
;chroot = /home/lemper
|
|
chdir = /home/lemper
|
|
|
|
;catch_workers_output = yes
|
|
;decorate_workers_output = no
|
|
|
|
security.limit_extensions = .php .php5 .php7 .php${PHPv//./}
|
|
|
|
; Custom PHP ini settings.
|
|
php_flag[display_errors] = On
|
|
;php_admin_value[error_reporting] = E_ALL & ~E_DEPRECATED & ~E_STRICT
|
|
;php_admin_value[disable_functions] = pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,exec,passthru,popen,proc_open,shell_exec,system
|
|
php_admin_flag[log_errors] = On
|
|
php_admin_value[error_log] = /var/log/php/php${PHPv}-fpm.\$pool.log
|
|
php_admin_value[date.timezone] = ${TIMEZONE}
|
|
php_admin_value[memory_limit] = 128M
|
|
php_admin_value[opcache.file_cache] = /home/${POOLNAME}/.lemper/php/opcache
|
|
php_admin_value[open_basedir] = /home/${POOLNAME}
|
|
php_admin_value[session.save_path] = /home/${POOLNAME}/.lemper/php/sessions
|
|
php_admin_value[sys_temp_dir] = /home/${POOLNAME}/.lemper/tmp
|
|
php_admin_value[upload_tmp_dir] = /home/${POOLNAME}/.lemper/tmp
|
|
php_admin_value[upload_max_filesize] = 20M
|
|
php_admin_value[post_max_size] = 20M
|
|
EOL
|
|
else
|
|
warning "Custom FPM pool ${POOLNAME} created & optimized in dry run mode."
|
|
fi
|
|
fi
|
|
|
|
# Create default directories.
|
|
run mkdir -p "/home/${POOLNAME}/.lemper/tmp"
|
|
run mkdir -p "/home/${POOLNAME}/.lemper/opcache"
|
|
run chown -hR "${POOLNAME}:${POOLNAME}" "/home/${POOLNAME}"
|
|
|
|
# Fix cgi.fix_pathinfo (for PHP older than 5.3).
|
|
#sed -i "s/cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g" /etc/php/${PHPv}/fpm/php.ini
|
|
|
|
# Restart PHP-fpm server.
|
|
if "${DRYRUN}"; then
|
|
warning "PHP${PHPv}-FPM reloaded in dry run mode."
|
|
else
|
|
if [[ $(pgrep -c "php-fpm${PHPv}") -gt 0 ]]; then
|
|
run service "php${PHPv}-fpm" reload
|
|
status "PHP${PHPv}-FPM reloaded successfully."
|
|
elif [[ -n $(command -v "php${PHPv}") ]]; then
|
|
run service "php${PHPv}-fpm" start
|
|
|
|
if [[ $(pgrep -c "php-fpm${PHPv}") -gt 0 ]]; then
|
|
status "PHP${PHPv}-FPM started successfully."
|
|
else
|
|
error "Something goes wrong with PHP${PHPv} & FPM installation."
|
|
fi
|
|
fi
|
|
fi
|
|
}
|
|
|
|
##
|
|
# Install PHP Composer.
|
|
#
|
|
function install_php_composer() {
|
|
if "${AUTO_INSTALL}"; then
|
|
DO_INSTALL_COMPOSER="y"
|
|
else
|
|
while [[ "${DO_INSTALL_COMPOSER}" != "y" && "${DO_INSTALL_COMPOSER}" != "n" ]]; do
|
|
read -rp "Do you want to install PHP Composer? [y/n]: " -i n -e DO_INSTALL_COMPOSER
|
|
done
|
|
fi
|
|
|
|
if [[ ${DO_INSTALL_COMPOSER} == y* && ${INSTALL_PHPCOMPOSER} == true ]]; then
|
|
echo "Installing PHP Composer..."
|
|
|
|
local CURRENT_DIR && CURRENT_DIR=$(pwd)
|
|
run cd "${BUILD_DIR}"
|
|
|
|
PHPBIN=$(command -v php)
|
|
EXPECTED_SIGNATURE="$(wget -q -O - https://composer.github.io/installer.sig)"
|
|
run "${PHPBIN}" -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
|
|
ACTUAL_SIGNATURE="$(${PHPBIN} -r "echo hash_file('sha384', 'composer-setup.php');")"
|
|
|
|
if [[ "$EXPECTED_SIGNATURE" == "$ACTUAL_SIGNATURE" ]]; then
|
|
run "${PHPBIN}" composer-setup.php --filename=composer --install-dir=/usr/local/bin --quiet
|
|
|
|
# Fix chmod permission to executable.
|
|
[ -f /usr/local/bin/composer ] && run chmod ugo+x /usr/local/bin/composer
|
|
else
|
|
error 'Invalid PHP Composer installer signature.'
|
|
fi
|
|
|
|
#run rm composer-setup.php
|
|
run cd "${CURRENT_DIR}"
|
|
fi
|
|
}
|
|
|
|
##
|
|
# Initialize PHP & FPM Installation.
|
|
#
|
|
function init_php_fpm_install() {
|
|
if "${AUTO_INSTALL}"; then
|
|
local SELECTED_PHP="${1}"
|
|
if [ -z "${SELECTED_PHP}" ]; then
|
|
SELECTED_PHP=${PHP_VERSION:-"7.3"}
|
|
fi
|
|
else
|
|
echo "Which version of PHP to be installed?"
|
|
echo "Supported PHP version:"
|
|
echo " 1). PHP 5.6 (EOL)"
|
|
echo " 2). PHP 7.0 (EOL)"
|
|
echo " 3). PHP 7.1 (SFO)"
|
|
echo " 4). PHP 7.2 (Stable)"
|
|
echo " 5). PHP 7.3 (Latest stable)"
|
|
echo " 6). PHP 7.4 (Beta)"
|
|
echo " 7). All available versions"
|
|
echo "+--------------------------------------+"
|
|
|
|
while [[ ${SELECTED_PHP} != "1" && ${SELECTED_PHP} != "2" && ${SELECTED_PHP} != "3" && \
|
|
${SELECTED_PHP} != "4" && ${SELECTED_PHP} != "5" && ${SELECTED_PHP} != "6" && \
|
|
${SELECTED_PHP} != "7" && ${SELECTED_PHP} != "5.6" && ${SELECTED_PHP} != "7.0" && \
|
|
${SELECTED_PHP} != "7.1" && ${SELECTED_PHP} != "7.2" && ${SELECTED_PHP} != "7.3" && \
|
|
${SELECTED_PHP} != "7.4" && ${SELECTED_PHP} != "all" ]]; do
|
|
read -rp "Select a PHP version or an option [1-7]: " -i 5 -e SELECTED_PHP
|
|
done
|
|
fi
|
|
|
|
local PHPv
|
|
case ${SELECTED_PHP} in
|
|
1|"5.6")
|
|
PHPv="5.6"
|
|
install_php_fpm "${PHPv}"
|
|
;;
|
|
|
|
2|"7.0")
|
|
PHPv="7.0"
|
|
install_php_fpm "${PHPv}"
|
|
;;
|
|
|
|
3|"7.1")
|
|
PHPv="7.1"
|
|
install_php_fpm "${PHPv}"
|
|
;;
|
|
|
|
4|"7.2")
|
|
PHPv="7.2"
|
|
install_php_fpm "${PHPv}"
|
|
;;
|
|
|
|
5|"7.3")
|
|
PHPv="7.3"
|
|
install_php_fpm "${PHPv}"
|
|
;;
|
|
|
|
6|"7.4")
|
|
PHPv="7.4"
|
|
install_php_fpm "${PHPv}"
|
|
;;
|
|
|
|
7|"all")
|
|
# Install all PHP version (except EOL & Beta).
|
|
PHPv="all"
|
|
install_php_fpm "5.6"
|
|
install_php_fpm "7.0"
|
|
install_php_fpm "7.1"
|
|
install_php_fpm "7.2"
|
|
install_php_fpm "7.3"
|
|
install_php_fpm "7.4"
|
|
;;
|
|
|
|
*)
|
|
PHPv="unsupported"
|
|
error "Your selected PHP version ${SELECTED_PHP} is not supported yet."
|
|
;;
|
|
esac
|
|
|
|
# Install default PHP version used by LEMPer.
|
|
if [[ -z $(command -v php7.3) ]]; then
|
|
warning -e "\nLEMPer requires PHP 7.3 as default to run its administration tools."
|
|
echo "PHP 7.3 now being installed..."
|
|
install_php_fpm "7.3"
|
|
fi
|
|
|
|
# Install PHP loader.
|
|
if [[ "${PHPv}" != "unsupported" && "${PHP_IS_INSTALLED}" != "yes" ]]; then
|
|
if "${AUTO_INSTALL}"; then
|
|
if [[ -z "${PHP_LOADER}" || "${PHP_LOADER}" == "none" ]]; then
|
|
INSTALL_PHPLOADER="n"
|
|
else
|
|
INSTALL_PHPLOADER="y"
|
|
SELECTED_PHPLOADER=${PHP_LOADER}
|
|
fi
|
|
else
|
|
while [[ "${INSTALL_PHPLOADER}" != "y" && "${INSTALL_PHPLOADER}" != "n" ]]; do
|
|
read -rp "Do you want to install PHP Loaders? [y/n]: " -i n -e INSTALL_PHPLOADER
|
|
done
|
|
fi
|
|
|
|
if [[ ${INSTALL_PHPLOADER} == Y* || ${INSTALL_PHPLOADER} == y* ]]; then
|
|
echo ""
|
|
echo "Available PHP Loaders:"
|
|
echo " 1). ionCube Loader (latest stable)"
|
|
echo " 2). SourceGuardian (latest stable)"
|
|
echo " 3). All loaders (ionCube, SourceGuardian)"
|
|
echo "--------------------------------------------"
|
|
|
|
while [[ ${SELECTED_PHPLOADER} != "1" && ${SELECTED_PHPLOADER} != "2" && \
|
|
${SELECTED_PHPLOADER} != "3" && ${SELECTED_PHPLOADER} != "ioncube" && \
|
|
${SELECTED_PHPLOADER} != "sourceguardian" && ${SELECTED_PHPLOADER} != "all" ]]; do
|
|
read -rp "Select an option [1-3]: " -i "${PHP_LOADER}" -e SELECTED_PHPLOADER
|
|
done
|
|
|
|
# Create loaders directory
|
|
if [ ! -d /usr/lib/php/loaders ]; then
|
|
run mkdir -p /usr/lib/php/loaders
|
|
fi
|
|
|
|
case ${SELECTED_PHPLOADER} in
|
|
1|"ioncube")
|
|
install_ioncube
|
|
|
|
if [ "${PHPv}" != "all" ]; then
|
|
enable_ioncube "${PHPv}"
|
|
|
|
# Required for LEMPer default PHP.
|
|
if [[ "${PHPv}" != "7.3" && -n $(command -v php7.3) ]]; then
|
|
enable_ioncube "7.3"
|
|
fi
|
|
else
|
|
# Install all PHP version (except EOL & Beta).
|
|
enable_ioncube "5.6"
|
|
enable_ioncube "7.0"
|
|
enable_ioncube "7.1"
|
|
enable_ioncube "7.2"
|
|
enable_ioncube "7.3"
|
|
#enable_ioncube "7.4"
|
|
fi
|
|
;;
|
|
|
|
2|"sourceguardian")
|
|
install_sourceguardian
|
|
|
|
if [ "${PHPv}" != "all" ]; then
|
|
enable_sourceguardian "${PHPv}"
|
|
|
|
# Required for LEMPer default PHP.
|
|
if [[ "${PHPv}" != "7.3" && -n $(command -v php7.3) ]]; then
|
|
enable_sourceguardian "7.3"
|
|
fi
|
|
else
|
|
# Install all PHP version (except EOL & Beta).
|
|
enable_sourceguardian "5.6"
|
|
enable_sourceguardian "7.0"
|
|
enable_sourceguardian "7.1"
|
|
enable_sourceguardian "7.2"
|
|
enable_sourceguardian "7.3"
|
|
#enable_sourceguardian "7.4"
|
|
fi
|
|
;;
|
|
|
|
"all")
|
|
install_ioncube
|
|
install_sourceguardian
|
|
|
|
if [ "${PHPv}" != "all" ]; then
|
|
enable_ioncube "${PHPv}"
|
|
enable_sourceguardian "${PHPv}"
|
|
|
|
# Required for LEMPer default PHP
|
|
if [[ "${PHPv}" != "7.3" && -n $(command -v php7.3) ]]; then
|
|
enable_ioncube "7.3"
|
|
enable_sourceguardian "7.3"
|
|
fi
|
|
else
|
|
# Install all PHP version (except EOL & Beta).
|
|
enable_ioncube "5.6"
|
|
enable_ioncube "7.0"
|
|
enable_ioncube "7.1"
|
|
enable_ioncube "7.2"
|
|
enable_ioncube "7.3"
|
|
#enable_ioncube "7.4"
|
|
|
|
enable_sourceguardian "5.6"
|
|
enable_sourceguardian "7.0"
|
|
enable_sourceguardian "7.1"
|
|
enable_sourceguardian "7.2"
|
|
enable_sourceguardian "7.3"
|
|
#enable_sourceguardian "7.4"
|
|
fi
|
|
;;
|
|
|
|
*)
|
|
warning "Your selected PHP loader ${SELECTED_PHPLOADER} is not supported yet."
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
# Final optimization.
|
|
#if "${DRYRUN}"; then
|
|
# warning "PHP${PHPv} & FPM installed and optimized in dryrun mode."
|
|
#else
|
|
if [ "${PHPv}" != "all" ]; then
|
|
optimize_php_fpm "${PHPv}"
|
|
|
|
# Required for LEMPer default PHP
|
|
if [[ "${PHPv}" != "7.3" && -n $(command -v php7.3) ]]; then
|
|
optimize_php_fpm "7.3"
|
|
fi
|
|
else
|
|
# Install all PHP version (except EOL & Beta).
|
|
optimize_php_fpm "5.6"
|
|
optimize_php_fpm "7.0"
|
|
optimize_php_fpm "7.1"
|
|
optimize_php_fpm "7.2"
|
|
optimize_php_fpm "7.3"
|
|
optimize_php_fpm "7.4"
|
|
fi
|
|
#fi
|
|
fi
|
|
|
|
# Install PHP composer.
|
|
install_php_composer
|
|
}
|
|
|
|
echo "[PHP & FPM Packages Installation]"
|
|
|
|
# Start running things from a call at the end so if this script is executed
|
|
# after a partial download it doesn't do anything.
|
|
if [[ -n $(command -v php5.6) && \
|
|
-n $(command -v php7.0) && \
|
|
-n $(command -v php7.1) && \
|
|
-n $(command -v php7.2) && \
|
|
-n $(command -v php7.3) && \
|
|
-n $(command -v php7.4) ]]; then
|
|
warning "All available PHP version already exists. Installation skipped..."
|
|
else
|
|
init_php_fpm_install "$@"
|
|
fi
|