mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-18 18:46:17 +00:00
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:
parent
910d04584f
commit
738b20a19b
2 changed files with 31 additions and 5 deletions
|
@ -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);
|
||||
|
|
|
@ -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
|
||||
*
|
||||
|
|
Loading…
Add table
Reference in a new issue