Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Problem with php7-mod-mysqli package #6893

Closed
alexander154 opened this issue Aug 28, 2018 · 3 comments
Closed

Problem with php7-mod-mysqli package #6893

alexander154 opened this issue Aug 28, 2018 · 3 comments
Assignees

Comments

@alexander154
Copy link

Hi!

My OpenWRT device is:

Model: TP-Link Archer C20 v1
Architecture: MediaTek MT7620A ver:2 eco:6
Firmware Version: OpenWrt 18.06.0 r7188-b0b5c64c22 / LuCI openwrt-18.06 branch (git-18.210.69179-6df9a57)
Kernel Version 4.14.54

I have installed next packages:

php7 php7-cli php7-mod-msyqli php7-mod-mysqlnd php7-mod-hash

When I run a test script, it show me next:

root@LEDE:~# php-cli 1.php
PHP Warning:  PHP Startup: Unable to load dynamic library 'mysqlnd.so' (tried: /usr/lib/php/mysqlnd.so (Error relocating /usr/lib/php/mysqlnd.so: RSA_size: symbol not found), /usr/lib/php/mysqlnd.so.so (Error loading shared library /usr/lib/php/mysqlnd.so.so: No such file or directory)) in Unknown on line 0
PHP Warning:  PHP Startup: Unable to load dynamic library 'mysqli.so' (tried: /usr/lib/php/mysqli.so (Error relocating /usr/lib/php/mysqli.so: mysqlnd_reverse_api_register_api: symbol not found), /usr/lib/php/mysqli.so.so (Error loading shared library /usr/lib/php/mysqli.so.so: No such file or directory)) in Unknown on line 0

Fatal error: Uncaught Error: Class 'mysqli' not found in /root/1.php:2
Stack trace:
#0 {main}
  thrown in /root/1.php on line 2

@alexander154
Copy link
Author

Temporary fix solution found here:

https://forum.openwrt.org/t/problem-with-php7-mod-mysqli-package/20075/2

@mhei mhei self-assigned this Aug 28, 2018
@mhei
Copy link
Member

mhei commented Aug 28, 2018

Yeah, already noticed this problem, but did not yet manage to free a time slot to code a proper fix and test the result :-)

@mhei mhei closed this as completed in 5afeb3f Sep 2, 2018
@82kg
Copy link

82kg commented Oct 9, 2018

Rename 20_mysqli.ini to 30_mysqli.ini, or delete 20_mysqli.ini if both exist. If you also have 20_openssl.ini there, rename that to 10_openssl.ini.

mhei added a commit to mhei/packages that referenced this issue Mar 26, 2019
This orders loading of openssl extension before extensions
which require openssl functions.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit 5afeb3f)
mhei added a commit to mhei/packages that referenced this issue Sep 9, 2021
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
mhei added a commit to mhei/packages that referenced this issue Sep 15, 2021
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit e51a049)
utoni pushed a commit to utoni/openwrt-packages that referenced this issue Jan 21, 2022
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
graysky2 pushed a commit to graysky2/packages that referenced this issue Feb 3, 2022
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
graysky2 pushed a commit to graysky2/packages that referenced this issue Feb 6, 2022
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
utoni pushed a commit to utoni/openwrt-packages that referenced this issue May 30, 2022
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
paper42 pushed a commit to paper42/packages that referenced this issue Jun 21, 2022
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit e51a049)
paper42 pushed a commit to paper42/packages that referenced this issue Jun 21, 2022
The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit e51a049)
paper42 pushed a commit to paper42/packages that referenced this issue Jun 23, 2022
php7: major upgrade to 7.4.1

- remove obsolete patches and update other ones
- filter support is now available as an extension module
- php7-mod-hash: this extension is now part of the core binary
  and cannot be built as an extension module anymore
- php7-mod-gd:
  - do not use bundled libgd, but rely on external one
  - this also obsoletes dependencies and configuration options
- php7-mod-zip: requires external libzip now

Signed-off-by: Michael Heimpold <[email protected]>

php7: update the gd module to depend on libgd-full

The php7-mod-gd package requires that freetype support exist in libgd. The
libgd-full package provides this, whereas the libgd package does only
if explicitly configured.

Ref: openwrt#10944
Signed-off-by: W. Michael Petullo <[email protected]>
Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.2

This fixes:
  - CVE-2020-7059
  - CVE-2020-7060

Signed-off-by: Michael Heimpold <[email protected]>

php7: fix dependencies for mysqlnd (fixes openwrt#11113)

When during the build the openssl extension is also selected, then
the mysqlnd extension depends on it, too.

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.3

This fixes:
  - CVE-2020-7061
  - CVE-2020-7062
  - CVE-2020-7063

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.4

This fixes:
  - CVE-2020-7064
  - CVE-2020-7065
  - CVE-2020-7066

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.5

This fixes:
  - CVE-2020-7067

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.6

This fixes:
  - CVE-2019-11048

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.7

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.8

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.9

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.10

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.11

This fixes:
  - CVE-2020-7069
  - CVE-2020-7070

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.12

Signed-off-by: Michael Heimpold <[email protected]>

php7: fix for icu 68.1

openwrt#13883
php/php-src@8eaaabd

Signed-off-by: Hirokazu MORIKAWA <[email protected]>

php7: update to 7.4.13

Signed-off-by: Michael Heimpold <[email protected]>

php7: remove obsolete patch for ICU 68.1

Signed-off-by: Michael Heimpold <[email protected]>

php7: add CI test script

This adds basic checks for php7 core and module packages.

Signed-off-by: Michael Heimpold <[email protected]>

php7: fix some whitespace nitpicks

Align some lines with the rest, no functional change.

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.14

This fixes:
    - CVE-2020-7071

Signed-off-by: Michael Heimpold <[email protected]>

lang/php7: Don't run phpize7 with QUILT

Allows targets such as prepare, refresh, or update to be run without
building dependencies for easier patch maintenance.

Signed-off-by: Ilya Lipnitskiy <[email protected]>

php7: update to 7.4.15

This fixes:
    - CVE-2021-21702

Signed-off-by: Michael Heimpold <[email protected]>

php7: fix pecl build with QUILT

Commit d741a64 ("lang/php7: Don't run phpize7 with QUILT") changed
pecl.mk to not run phpize7 during Package/prepare if QUILT is set.  The
intention was to allow prepare, refresh and update targets to run
without building dependencies.

As a side-effect, Package/configure and Package/compile fail when QUILT
is defined because they can't find ./configure or a Makefile.  It also
impacts the github tests run with pull requests, because QUILT is
defined there.

To avoid that failure and still keep the prepare, refresh, and update
speedup, call phpize7 before Package/Configure if QUILT is defined.

Signed-off-by: Eneas U de Queiroz <[email protected]>
(cherry picked from commit 3476816)

php7: fix build with QUILT

When building with QUILT, unlike the regular build, Build/Prepare does
not apply the patches.  So when buildconf is called with QUILT on, at
the end of Build/Prepare, it will not have the patched sources, and
build will fail.

To fix the problem, run buildconf in Build/Prepare only when QUILT is
off, and do it in Build/Configure otherwise.

Signed-off-by: Eneas U de Queiroz <[email protected]>
(cherry picked from commit d4979cf)

php7: update to 7.4.16

Also refresh patch.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit 87e852f)

php7: update to 7.4.18

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit aaaeef8)

php7: update to 7.4.19

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit 4e39d9f)

php7: update to 7.4.22

This fixes:
    - CVE-2021-21704
    - CVE-2021-21705

Signed-off-by: Michael Heimpold <[email protected]>

(cherry picked from commits
  - 555d0c9
  - f15aba8
  - 741d6d6)

php7: update to 7.4.23

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit fb9e056)

php7: fix config file upgrade issue (fixes openwrt#14623)

The addressed issue is related to openwrt#6893 as its resolution
is actually causing the problem.

When changing the priority of the config file it happens
that after a sysupgrade the previous file is restored
and the new file is added, ending up in a situation
like this:

/etc/php7/15_openssl.ini
/etc/php7/20_openssl.ini

Causing a double extension=openssl.so to be parsed,
which is not appropriate and leads to error message.

The same problem might also occur for mysqli since there
was also a priority change - let's take care about this
at the same time.

The solution is to remove one of the files. Since it is
a configuration file, the user might have adjusted it, so
lets just use the previous version to replace the new
installed version.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit e51a049)

php7: fix module loading with glibc (refs openwrt#16642)

Without -ldl linker flag .so extensions are not loaded
when glibc is used. Fix it by providing adjusted LDFLAGS
for this case.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit d153c61)

php7: update to 7.4.24

This fixes:
    - CVE-2021-21706

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit 96a04ad)

php7: update to 7.4.25

This fixes:
    - CVE-2021-21703

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit 1df333b)

php7: Support for icu 70.1

This PR prepares PHP for a few minor changes that cause PHP builds to fail when using --enable-intl with ICU 70.1.

Change UBool to bool for equality operators in ICU >= 70.1

php/php-src#7596

Signed-off-by: Hirokazu MORIKAWA <[email protected]>
Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit bc13112)

php7: Clean up and update distributed php.ini for php 7.4.25

Details:
- Cleaned up whitespace and removed comments (refer to official PHP documentation for that)
- Removed directives that no longer exist as of PHP 7.4.25
- Added '~E_DEPRECATED' to 'error_reporting'

Directives removed that no longer exist as of PHP 7.4.25:
- zend.ze1_compatibility_mode
- y2k_compliance
- register_globals
- register_long_arrays
- magic_quotes_gpc
- magic_quotes_runtime
- magic_quotes_sybase
- always_populate_raw_post_data

Signed-off-by: Giovanni Giacobbi <[email protected]>

php7: update to 7.4.26

This fixes:
    - CVE-2021-21707

Also drop upstream patch which is included in the release now.

Signed-off-by: Michael Heimpold <[email protected]>
(cherry picked from commit c6f2767)

php7: update to 7.4.27

Signed-off-by: Michael Heimpold <[email protected]>

php7: update to 7.4.28

This fixes:
    - CVE-2021-21708

Signed-off-by: Michael Heimpold <[email protected]>

php7: fix dep on libgd

php7: refresh patches

php7: update to 7.4.30
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants