summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2019-09-09 10:10:41 +0200
committerNikita Popov <nikita.ppv@gmail.com>2019-09-09 10:10:41 +0200
commit645b0372e3cdf65f060d749ad4f6dfdd7e0252fb (patch)
treef48c5b064030a2b304e684120f0ffb0e06958c64
parentf5dfea60a2564fe56dd321582371667dfbbd486a (diff)
downloadphp-git-645b0372e3cdf65f060d749ad4f6dfdd7e0252fb.tar.gz
Fix double free of DSN credentials
-rw-r--r--ext/pdo_dblib/dblib_driver.c4
-rw-r--r--ext/pdo_firebird/firebird_driver.c4
-rw-r--r--ext/pdo_mysql/mysql_driver.c4
-rw-r--r--ext/pdo_oci/oci_driver.c4
4 files changed, 8 insertions, 8 deletions
diff --git a/ext/pdo_dblib/dblib_driver.c b/ext/pdo_dblib/dblib_driver.c
index 7f2b7ebe3c..03bdaa1f48 100644
--- a/ext/pdo_dblib/dblib_driver.c
+++ b/ext/pdo_dblib/dblib_driver.c
@@ -522,7 +522,7 @@ static int pdo_dblib_handle_factory(pdo_dbh_t *dbh, zval *driver_options)
}
if (!dbh->username && vars[6].optval) {
- dbh->username = vars[6].optval;
+ dbh->username = pestrdup(vars[6].optval, dbh->is_persistent);
}
if (dbh->username) {
@@ -532,7 +532,7 @@ static int pdo_dblib_handle_factory(pdo_dbh_t *dbh, zval *driver_options)
}
if (!dbh->password && vars[7].optval) {
- dbh->password = vars[7].optval;
+ dbh->password = pestrdrup(vars[7].optval, dbh->is_persistent);
}
if (dbh->password) {
diff --git a/ext/pdo_firebird/firebird_driver.c b/ext/pdo_firebird/firebird_driver.c
index e1b03a4601..8b2a128963 100644
--- a/ext/pdo_firebird/firebird_driver.c
+++ b/ext/pdo_firebird/firebird_driver.c
@@ -635,11 +635,11 @@ static int pdo_firebird_handle_factory(pdo_dbh_t *dbh, zval *driver_options) /*
php_pdo_parse_data_source(dbh->data_source, dbh->data_source_len, vars, 5);
if (!dbh->username && vars[3].optval) {
- dbh->username = vars[3].optval;
+ dbh->username = pestrdup(vars[3].optval, dbh->is_persistent);
}
if (!dbh->password && vars[4].optval) {
- dbh->password = vars[4].optval;
+ dbh->password = pestrdup(vars[4].optval, dbh->is_persistent);
}
do {
diff --git a/ext/pdo_mysql/mysql_driver.c b/ext/pdo_mysql/mysql_driver.c
index 6910582ba5..2f85d8dbb7 100644
--- a/ext/pdo_mysql/mysql_driver.c
+++ b/ext/pdo_mysql/mysql_driver.c
@@ -811,11 +811,11 @@ static int pdo_mysql_handle_factory(pdo_dbh_t *dbh, zval *driver_options)
}
if (!dbh->username && vars[5].optval) {
- dbh->username = vars[5].optval;
+ dbh->username = pestrdup(vars[5].optval, dbh->is_persistent);
}
if (!dbh->password && vars[6].optval) {
- dbh->password = vars[6].optval;
+ dbh->password = pestrdup(vars[6].optval, dbh->is_persistent);
}
/* TODO: - Check zval cache + ZTS */
diff --git a/ext/pdo_oci/oci_driver.c b/ext/pdo_oci/oci_driver.c
index 3ee02657c3..386789e069 100644
--- a/ext/pdo_oci/oci_driver.c
+++ b/ext/pdo_oci/oci_driver.c
@@ -748,7 +748,7 @@ static int pdo_oci_handle_factory(pdo_dbh_t *dbh, zval *driver_options) /* {{{ *
/* username */
if (!dbh->username && vars[2].optval) {
- dbh->username = vars[2].optval;
+ dbh->username = pestrdup(vars[2].optval, dbh->is_persistent);
}
if (dbh->username) {
@@ -763,7 +763,7 @@ static int pdo_oci_handle_factory(pdo_dbh_t *dbh, zval *driver_options) /* {{{ *
/* password */
if (!dbh->password && vars[3].optval) {
- dbh->password = vars[3].optval;
+ dbh->password = pestrdup(vars[3].optval, dbh->is_persistent);
}
if (dbh->password) {