From d07b4af99f0f22e7bf208339c317c7c46d47c885 Mon Sep 17 00:00:00 2001 From: "Alexander A. Klimov" Date: Thu, 26 Oct 2023 12:38:45 +0200 Subject: [PATCH 1/2] Bump base image version Omitting virtual php8.2-json, that extension is always there since PHP 8. --- Dockerfile | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Dockerfile b/Dockerfile index ebaa8f8..bcb41a6 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,6 +1,6 @@ # Icinga Web 2 Docker image | (c) 2020 Icinga GmbH | GPLv2+ -FROM golang:bullseye as entrypoint +FROM golang:bookworm as entrypoint COPY entrypoint /entrypoint @@ -25,9 +25,9 @@ COPY --from=icingaweb2-git . /icingaweb2-src/.git RUN git -C /icingaweb2-src archive --prefix=icingaweb2/ HEAD |tar -x -FROM debian:bullseye-slim +FROM debian:bookworm-slim -RUN ["bash", "-exo", "pipefail", "-c", "export DEBIAN_FRONTEND=noninteractive; apt-get update; apt-get install --no-install-{recommends,suggests} -y apache2 ca-certificates libapache2-mod-php7.4 libldap-common locales-all php-{imagick,redis} php7.4-{bcmath,bz2,common,curl,dba,enchant,gd,gmp,imap,interbase,intl,json,ldap,mbstring,mysql,odbc,opcache,pgsql,pspell,readline,snmp,soap,sqlite3,sybase,tidy,xml,xmlrpc,xsl,zip}; apt-get clean; rm -vrf /var/lib/apt/lists/*"] +RUN ["bash", "-exo", "pipefail", "-c", "export DEBIAN_FRONTEND=noninteractive; apt-get update; apt-get install --no-install-{recommends,suggests} -y apache2 ca-certificates libapache2-mod-php8.2 libldap-common locales-all php-{imagick,redis} php8.2-{bcmath,bz2,common,curl,dba,enchant,gd,gmp,imap,interbase,intl,ldap,mbstring,mysql,odbc,opcache,pgsql,pspell,readline,snmp,soap,sqlite3,sybase,tidy,xml,xmlrpc,xsl,zip}; apt-get clean; rm -vrf /var/lib/apt/lists/*"] COPY --from=entrypoint /entrypoint/entrypoint /entrypoint COPY entrypoint/db-init /entrypoint-db-init @@ -51,7 +51,7 @@ RUN ["install", "-o", "www-data", "-g", "www-data", "-d", "/data"] ENTRYPOINT ["/entrypoint"] COPY --from=usr-share /usr-share/. /usr/share/ -COPY php.ini /etc/php/7.4/cli/conf.d/99-docker.ini +COPY php.ini /etc/php/8.2/cli/conf.d/99-docker.ini RUN ["ln", "-vs", "/usr/share/icingaweb2/bin/icingacli", "/usr/local/bin/"] RUN ["icingacli", "setup", "config", "webserver", "apache", "--path=/", "--file=/etc/apache2/conf-enabled/icingaweb2.conf"] From 15489dfcc98d7cb58a89da17b7b63b90cd1043b9 Mon Sep 17 00:00:00 2001 From: "Alexander A. Klimov" Date: Thu, 26 Oct 2023 13:37:51 +0200 Subject: [PATCH 2/2] DbCommand: support PHP 8.2 by not creating dynamic properties. --- .../db-init/application/clicommands/DbCommand.php | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/entrypoint/db-init/application/clicommands/DbCommand.php b/entrypoint/db-init/application/clicommands/DbCommand.php index 855036b..54443e3 100644 --- a/entrypoint/db-init/application/clicommands/DbCommand.php +++ b/entrypoint/db-init/application/clicommands/DbCommand.php @@ -47,16 +47,16 @@ class DbCommand extends Command public function initializedAction() { - echo (int) (array_search('icingaweb_group', $this->getDb()->listTables(), true) !== false); + echo (int) (array_search('icingaweb_group', $this->getDb()->conn->listTables(), true) !== false); } public function initAction() { $db = $this->getDb(); - $db->import( + $db->conn->import( Config::module('setup') - ->get('schema', 'path', Icinga::app()->getBaseDir('schema')) . "/{$db->dbType}.schema.sql" + ->get('schema', 'path', Icinga::app()->getBaseDir('schema')) . "/{$db->type}.schema.sql" ); } @@ -78,7 +78,7 @@ class DbCommand extends Command } /** - * @return DbTool + * @return \stdClass */ protected function getDb() { @@ -111,7 +111,10 @@ class DbCommand extends Command $db = new DbTool($config); $db->connectToDb(); - $db->dbType = $type; - return $db; + + return (object) [ + 'conn' => $db, + 'type' => $type + ]; } }