summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph M. Becker <cmbecker69@gmx.de>2020-10-10 23:25:43 +0200
committerChristoph M. Becker <cmbecker69@gmx.de>2020-10-10 23:26:12 +0200
commit7940fb42ce90173e285278b577e46cbab9b270a3 (patch)
tree3a4760aa6155561d8cf069d439a1ee0e1babaf39
parentb2b9e2e87e780d814ffc6ceeaf1b546a14e76799 (diff)
parent62a2387a8dc262ae75a6575fabddd6170b4bdb07 (diff)
downloadphp-git-7940fb42ce90173e285278b577e46cbab9b270a3.tar.gz
Merge branch 'PHP-7.3' into PHP-7.4
* PHP-7.3: Fix #80215: imap_mail_compose() may modify by-val parameters
-rw-r--r--NEWS1
-rw-r--r--ext/imap/php_imap.c9
-rw-r--r--ext/imap/tests/bug80215.phpt69
3 files changed, 78 insertions, 1 deletions
diff --git a/NEWS b/NEWS
index 7cd80de852..eec4fa4d90 100644
--- a/NEWS
+++ b/NEWS
@@ -15,6 +15,7 @@ PHP NEWS
- IMAP:
. Fixed bug #80213 (imap_mail_compose() segfaults on certain $bodies). (cmb)
+ . Fixed bug #80215 (imap_mail_compose() may modify by-val parameters). (cmb)
- MySQLnd:
. Fixed bug #80115 (mysqlnd.debug doesn't recognize absolute paths with
diff --git a/ext/imap/php_imap.c b/ext/imap/php_imap.c
index 3e708796f0..5c193c04f4 100644
--- a/ext/imap/php_imap.c
+++ b/ext/imap/php_imap.c
@@ -3556,7 +3556,7 @@ PHP_FUNCTION(imap_mail_compose)
int toppart = 0;
int first;
- if (zend_parse_parameters(ZEND_NUM_ARGS(), "aa", &envelope, &body) == FAILURE) {
+ if (zend_parse_parameters(ZEND_NUM_ARGS(), "a/a/", &envelope, &body) == FAILURE) {
return;
}
@@ -3614,6 +3614,7 @@ PHP_FUNCTION(imap_mail_compose)
if ((pvalue = zend_hash_str_find(Z_ARRVAL_P(envelope), "custom_headers", sizeof("custom_headers") - 1)) != NULL) {
if (Z_TYPE_P(pvalue) == IS_ARRAY) {
custom_headers_param = tmp_param = NULL;
+ SEPARATE_ARRAY(pvalue);
ZEND_HASH_FOREACH_VAL(Z_ARRVAL_P(pvalue), env_data) {
custom_headers_param = mail_newbody_parameter();
convert_to_string_ex(env_data);
@@ -3635,6 +3636,7 @@ PHP_FUNCTION(imap_mail_compose)
php_error_docref(NULL, E_WARNING, "body parameter must be a non-empty array");
RETURN_FALSE;
}
+ SEPARATE_ARRAY(data);
bod = mail_newbody();
topbod = bod;
@@ -3656,6 +3658,7 @@ PHP_FUNCTION(imap_mail_compose)
if ((pvalue = zend_hash_str_find(Z_ARRVAL_P(data), "type.parameters", sizeof("type.parameters") - 1)) != NULL) {
if(Z_TYPE_P(pvalue) == IS_ARRAY) {
disp_param = tmp_param = NULL;
+ SEPARATE_ARRAY(pvalue);
ZEND_HASH_FOREACH_STR_KEY_VAL(Z_ARRVAL_P(pvalue), key, disp_data) {
if (key == NULL) continue;
disp_param = mail_newbody_parameter();
@@ -3689,6 +3692,7 @@ PHP_FUNCTION(imap_mail_compose)
if ((pvalue = zend_hash_str_find(Z_ARRVAL_P(data), "disposition", sizeof("disposition") - 1)) != NULL) {
if (Z_TYPE_P(pvalue) == IS_ARRAY) {
disp_param = tmp_param = NULL;
+ SEPARATE_ARRAY(pvalue);
ZEND_HASH_FOREACH_STR_KEY_VAL(Z_ARRVAL_P(pvalue), key, disp_data) {
if (key == NULL) continue;
disp_param = mail_newbody_parameter();
@@ -3724,6 +3728,7 @@ PHP_FUNCTION(imap_mail_compose)
}
} else if (Z_TYPE_P(data) == IS_ARRAY) {
short type = -1;
+ SEPARATE_ARRAY(data);
if ((pvalue = zend_hash_str_find(Z_ARRVAL_P(data), "type", sizeof("type") - 1)) != NULL) {
type = (short) zval_get_long(pvalue);
}
@@ -3758,6 +3763,7 @@ PHP_FUNCTION(imap_mail_compose)
if ((pvalue = zend_hash_str_find(Z_ARRVAL_P(data), "type.parameters", sizeof("type.parameters") - 1)) != NULL) {
if (Z_TYPE_P(pvalue) == IS_ARRAY) {
disp_param = tmp_param = NULL;
+ SEPARATE_ARRAY(pvalue);
ZEND_HASH_FOREACH_STR_KEY_VAL(Z_ARRVAL_P(pvalue), key, disp_data) {
if (key == NULL) continue;
disp_param = mail_newbody_parameter();
@@ -3791,6 +3797,7 @@ PHP_FUNCTION(imap_mail_compose)
if ((pvalue = zend_hash_str_find(Z_ARRVAL_P(data), "disposition", sizeof("disposition") - 1)) != NULL) {
if (Z_TYPE_P(pvalue) == IS_ARRAY) {
disp_param = tmp_param = NULL;
+ SEPARATE_ARRAY(pvalue);
ZEND_HASH_FOREACH_STR_KEY_VAL(Z_ARRVAL_P(pvalue), key, disp_data) {
if (key == NULL) continue;
disp_param = mail_newbody_parameter();
diff --git a/ext/imap/tests/bug80215.phpt b/ext/imap/tests/bug80215.phpt
new file mode 100644
index 0000000000..b2d7c3ed09
--- /dev/null
+++ b/ext/imap/tests/bug80215.phpt
@@ -0,0 +1,69 @@
+--TEST--
+Bug #80215 (imap_mail_compose() may modify by-val parameters)
+--SKIPIF--
+<?php
+if (!extension_loaded('imap')) die('skip imap extension not available');
+?>
+--FILE--
+<?php
+$envelope = [
+ "from" => 1,
+ "to" => 2,
+ "custom_headers" => [3],
+];
+$body = [[
+ "contents.data" => 4,
+ "type.parameters" => ['foo' => 5],
+ "disposition" => ['bar' => 6],
+], [
+ "contents.data" => 7,
+ "type.parameters" => ['foo' => 8],
+ "disposition" => ['bar' => 9],
+]];
+imap_mail_compose($envelope, $body);
+var_dump($envelope, $body);
+?>
+--EXPECT--
+array(3) {
+ ["from"]=>
+ int(1)
+ ["to"]=>
+ int(2)
+ ["custom_headers"]=>
+ array(1) {
+ [0]=>
+ int(3)
+ }
+}
+array(2) {
+ [0]=>
+ array(3) {
+ ["contents.data"]=>
+ int(4)
+ ["type.parameters"]=>
+ array(1) {
+ ["foo"]=>
+ int(5)
+ }
+ ["disposition"]=>
+ array(1) {
+ ["bar"]=>
+ int(6)
+ }
+ }
+ [1]=>
+ array(3) {
+ ["contents.data"]=>
+ int(7)
+ ["type.parameters"]=>
+ array(1) {
+ ["foo"]=>
+ int(8)
+ }
+ ["disposition"]=>
+ array(1) {
+ ["bar"]=>
+ int(9)
+ }
+ }
+}