mirror of
https://github.com/pi-hole/pi-hole.git
synced 2025-01-12 06:54:53 +00:00
Merge pull request #2220 from rrobgill/installedphpcheck
Bugfix - Check version of installed php
This commit is contained in:
commit
0651f1bcd4
1 changed files with 22 additions and 6 deletions
|
@ -160,14 +160,30 @@ if command -v apt-get &> /dev/null; then
|
||||||
# use iproute
|
# use iproute
|
||||||
iproute_pkg="iproute"
|
iproute_pkg="iproute"
|
||||||
fi
|
fi
|
||||||
# We prefer the php metapackage if it's there
|
# Check for and determine version number (major and minor) of current php install
|
||||||
|
if command -v php &> /dev/null; then
|
||||||
|
phpInsVersion="$(php -v | head -n1 | grep -Po '(?<=PHP )[^ ]+')"
|
||||||
|
echo -e " ${INFO} Existing PHP installation detected : PHP version $phpInsVersion"
|
||||||
|
phpInsMajor="$(echo "$phpInsVersion" | cut -d\. -f1)"
|
||||||
|
phpInsMinor="$(echo "$phpInsVersion" | cut -d\. -f2)"
|
||||||
|
# Is installed php version 7.0 or greater
|
||||||
|
if [ "$(echo "$phpInsMajor.$phpInsMinor < 7.0" | bc )" == 0 ]; then
|
||||||
|
phpInsNewer=true
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
# Check if installed php is v 7.0, or newer to determine packages to install
|
||||||
|
if [[ "$phpInsNewer" != true ]]; then
|
||||||
|
# Prefer the php metapackage if it's there
|
||||||
if ${PKG_MANAGER} install --dry-run php > /dev/null 2>&1; then
|
if ${PKG_MANAGER} install --dry-run php > /dev/null 2>&1; then
|
||||||
phpVer="php"
|
phpVer="php"
|
||||||
# If not,
|
|
||||||
else
|
|
||||||
# fall back on the php5 packages
|
# fall back on the php5 packages
|
||||||
|
else
|
||||||
phpVer="php5"
|
phpVer="php5"
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
# Newer php is installed, its common, cgi & sqlite counterparts are deps
|
||||||
|
phpVer="php$phpInsMajor.$phpInsMinor"
|
||||||
|
fi
|
||||||
# We also need the correct version for `php-sqlite` (which differs across distros)
|
# We also need the correct version for `php-sqlite` (which differs across distros)
|
||||||
if ${PKG_MANAGER} install --dry-run ${phpVer}-sqlite3 > /dev/null 2>&1; then
|
if ${PKG_MANAGER} install --dry-run ${phpVer}-sqlite3 > /dev/null 2>&1; then
|
||||||
phpSqlite="sqlite3"
|
phpSqlite="sqlite3"
|
||||||
|
|
Loading…
Reference in a new issue