Fix encoding of addreses containin comma & unicode

Email addresses that contain both unicode and commas will not be
correctly encoded by mime_encode_header if the comma precedes the
unicode. In this scenario we have to quote the encoded address.

Refs #10763
This commit is contained in:
mark_story 2017-06-12 10:57:35 -04:00
parent 910d04584f
commit 738b20a19b
2 changed files with 31 additions and 5 deletions

View file

@ -830,7 +830,10 @@ class CakeEmail {
$return[] = $email;
} else {
$encoded = $this->_encode($alias);
if ($encoded === $alias && preg_match('/[^a-z0-9 ]/i', $encoded)) {
if (
$encoded === $alias && preg_match('/[^a-z0-9 ]/i', $encoded) ||
strpos($encoded, ',') !== false
) {
$encoded = '"' . str_replace('"', '\"', $encoded) . '"';
}
$return[] = sprintf('%s <%s>', $encoded, $email);

View file

@ -450,10 +450,6 @@ class CakeEmailTest extends CakeTestCase {
$expected = array('CakePHP <cake@cakephp.org>', 'Cake <php@cakephp.org>');
$this->assertSame($expected, $result);
$result = $this->CakeEmail->formatAddress(array('me@example.com' => 'Last, First'));
$expected = array('"Last, First" <me@example.com>');
$this->assertSame($expected, $result);
$result = $this->CakeEmail->formatAddress(array('me@example.com' => '"Last" First'));
$expected = array('"\"Last\" First" <me@example.com>');
$this->assertSame($expected, $result);
@ -471,6 +467,33 @@ class CakeEmailTest extends CakeTestCase {
$this->assertSame($expected, $result);
}
/**
* Test that addresses are quoted correctly when they contain unicode and
* commas
*
* @return void
*/
public function testFormatAddressEncodeAndEscape()
{
$result = $this->CakeEmail->formatAddress(array(
'test@example.com' => 'Website, ascii'
));
$expected = array('"Website, ascii" <test@example.com>');
$this->assertSame($expected, $result);
$result = $this->CakeEmail->formatAddress(array(
'test@example.com' => 'Wébsite, unicode'
));
$expected = array('=?UTF-8?B?V8OpYnNpdGUsIHVuaWNvZGU=?= <test@example.com>');
$this->assertSame($expected, $result);
$result = $this->CakeEmail->formatAddress(array(
'test@example.com' => 'Website, électric'
));
$expected = array('"Website, =?UTF-8?B?w6lsZWN0cmlj?=" <test@example.com>');
$this->assertSame($expected, $result);
}
/**
* testFormatAddressJapanese
*