Date: Wed, 5 May 2021 11:47:47 GMT From: Torsten Zuehlsdorff <tz@FreeBSD.org> To: ports-committers@FreeBSD.org, dev-commits-ports-all@FreeBSD.org, dev-commits-ports-branches@FreeBSD.org Subject: git: 60f4fa9eedcf - 2021Q2 - databases/php80-pdo_pgsql: Apply patch for PHP Bug 81002 Message-ID: <202105051147.145BllcS097852@gitrepo.freebsd.org>
next in thread | raw e-mail | index | archive | help
The branch 2021Q2 has been updated by tz: URL: https://cgit.FreeBSD.org/ports/commit/?id=60f4fa9eedcf0ef826deb4a4cac2745f8f2141f5 commit 60f4fa9eedcf0ef826deb4a4cac2745f8f2141f5 Author: Torsten Zuehlsdorff <tz@FreeBSD.org> AuthorDate: 2021-05-05 08:34:30 +0000 Commit: Torsten Zuehlsdorff <tz@FreeBSD.org> CommitDate: 2021-05-05 11:47:40 +0000 databases/php80-pdo_pgsql: Apply patch for PHP Bug 81002 The last release introduces a bug, which causes BOOL values inserted into PostgreSQL converted to INT. This causes exceptions when tried. Since this is a serious issue, we apply the upstream patch until it gets official released Reported by: madpilot Sponsored by: Bounce Experts Differential Revision: https://reviews.freebsd.org/D30117 (cherry picked from commit 31d2c89e27153edab594d72399316a237bcaf689) --- databases/php80-pdo_pgsql/Makefile | 2 + .../php80-pdo_pgsql/files/patch-pgsql__statement.c | 42 ++++++++++++ .../files/patch-tests_bug__80892.phpt | 80 ++++++++++++++++++++++ 3 files changed, 124 insertions(+) diff --git a/databases/php80-pdo_pgsql/Makefile b/databases/php80-pdo_pgsql/Makefile index a102871ece58..93373ba0b849 100644 --- a/databases/php80-pdo_pgsql/Makefile +++ b/databases/php80-pdo_pgsql/Makefile @@ -1,6 +1,8 @@ CATEGORIES= databases +PORTREVISION= 1 + MASTERDIR= ${.CURDIR}/../../lang/php80 PKGNAMESUFFIX= -pdo_pgsql diff --git a/databases/php80-pdo_pgsql/files/patch-pgsql__statement.c b/databases/php80-pdo_pgsql/files/patch-pgsql__statement.c new file mode 100644 index 000000000000..44a5391cd2a4 --- /dev/null +++ b/databases/php80-pdo_pgsql/files/patch-pgsql__statement.c @@ -0,0 +1,42 @@ +--- pgsql_statement.c.orig 2021-05-05 08:26:44 UTC ++++ pgsql_statement.c +@@ -52,21 +52,6 @@ + #define VARCHARLABEL "varchar" + #define VARCHAROID 1043 + +-#define PG_INT32_MIN (-0x7FFFFFFF-1) +-#define PG_INT32_MAX (0x7FFFFFFF) +- +-#if defined(_MSC_VER) +-# define strtoll(s, f, b) _atoi64(s) +-#elif !defined(HAVE_STRTOLL) +-# if defined(HAVE_ATOLL) +-# define strtoll(s, f, b) atoll(s) +-# else +-# define strtoll(s, f, b) strtol(s, f, b) +-# endif +-#endif +- +- +- + static int pgsql_stmt_dtor(pdo_stmt_t *stmt) + { + pdo_pgsql_stmt *S = (pdo_pgsql_stmt*)stmt->driver_data; +@@ -401,16 +386,7 @@ static int pgsql_stmt_param_hook(pdo_stmt_t *stmt, str + S->param_formats[param->paramno] = 0; + } + +- if (PDO_PARAM_TYPE(param->param_type) == PDO_PARAM_INT) { +- /* we need to check if the number requires bigints */ +- long long val = strtoll(Z_STRVAL_P(parameter), NULL, 10); +- +- if (val > PG_INT32_MAX || val < PG_INT32_MIN) { +- S->param_types[param->paramno] = INT8OID; +- } else { +- S->param_types[param->paramno] = INT4OID; +- } +- } else if (PDO_PARAM_TYPE(param->param_type) == PDO_PARAM_LOB) { ++ if (PDO_PARAM_TYPE(param->param_type) == PDO_PARAM_LOB) { + S->param_types[param->paramno] = 0; + S->param_formats[param->paramno] = 1; + } else { diff --git a/databases/php80-pdo_pgsql/files/patch-tests_bug__80892.phpt b/databases/php80-pdo_pgsql/files/patch-tests_bug__80892.phpt new file mode 100644 index 000000000000..75fd17a53b94 --- /dev/null +++ b/databases/php80-pdo_pgsql/files/patch-tests_bug__80892.phpt @@ -0,0 +1,80 @@ +--- tests/bug_80892.phpt.orig 2021-05-05 08:30:53 UTC ++++ tests/bug_80892.phpt +@@ -1,77 +0,0 @@ +---TEST-- +-Bug #80892 PDO::PARAM_INT is treated the same as PDO::PARAM_STR +---SKIPIF-- +-<?php +-if (!extension_loaded('pdo') || !extension_loaded('pdo_pgsql')) die('skip not loaded'); +-require __DIR__ . '/config.inc'; +-require __DIR__ . '/../../../ext/pdo/tests/pdo_test.inc'; +-PDOTest::skip(); +-?> +---FILE-- +-<?php +-require __DIR__ . '/../../../ext/pdo/tests/pdo_test.inc'; +- +-/** @var PDO $db */ +-$db = PDOTest::test_factory(__DIR__ . '/common.phpt'); +-$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); +-$db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); +- +-$db->exec("CREATE OR REPLACE FUNCTION bug80892 (x bigint) RETURNS varchar AS $$ SELECT 'bigint' $$ LANGUAGE sql"); +-$db->exec("CREATE OR REPLACE FUNCTION bug80892 (x int) RETURNS varchar AS $$ SELECT 'int' $$ LANGUAGE sql"); +-$db->exec("CREATE OR REPLACE FUNCTION bug80892 (x text) RETURNS varchar AS $$ SELECT 'text' $$ LANGUAGE sql"); +- +-// Sanity check +-var_dump($db->query("SELECT bug80892(2147483648)")->fetchColumn()); +-var_dump($db->query("SELECT bug80892(1)")->fetchColumn()); +-var_dump($db->query("SELECT bug80892('1')")->fetchColumn()); +- +-// No binding +-$stmt = $db->prepare("SELECT bug80892(?)"); +-$stmt->execute([1]); +-var_dump($stmt->fetchColumn()); +- +-// Bind int value as string +-$stmt = $db->prepare("SELECT bug80892(?)"); +-$stmt->bindValue(1, 1, PDO::PARAM_STR); +-$stmt->execute(); +-var_dump($stmt->fetchColumn()); +- +-// Bind int value as int +-$stmt = $db->prepare("SELECT bug80892(?)"); +-$stmt->bindValue(1, 1, PDO::PARAM_INT); +-$stmt->execute(); +-var_dump($stmt->fetchColumn()); +- +-// Bind string value as int +-$stmt = $db->prepare("SELECT bug80892(?)"); +-$stmt->bindValue(1, '1', PDO::PARAM_INT); +-$stmt->execute(); +-var_dump($stmt->fetchColumn()); +- +-// Bind bigint string value as int +-$stmt = $db->prepare("SELECT bug80892(?)"); +-$stmt->bindValue(1, '2147483648', PDO::PARAM_INT); +-$stmt->execute(); +-var_dump($stmt->fetchColumn()); +- +-// Bind negative bigint (string on 32bit) as int +-$stmt = $db->prepare("SELECT bug80892(?)"); +-$stmt->bindValue(1, PHP_INT_SIZE == 4 ? '-33333333333' : -33333333333, PDO::PARAM_INT); +-$stmt->execute(); +-var_dump($stmt->fetchColumn()); +- +-$db->exec("DROP FUNCTION bug80892 (bigint)"); +-$db->exec("DROP FUNCTION bug80892 (int)"); +-$db->exec("DROP FUNCTION bug80892 (text)"); +- +-?> +---EXPECT-- +-string(6) "bigint" +-string(3) "int" +-string(4) "text" +-string(4) "text" +-string(4) "text" +-string(3) "int" +-string(3) "int" +-string(6) "bigint" +-string(6) "bigint"
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202105051147.145BllcS097852>