mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 02:56:15 +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;
|
$return[] = $email;
|
||||||
} else {
|
} else {
|
||||||
$encoded = $this->_encode($alias);
|
$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) . '"';
|
$encoded = '"' . str_replace('"', '\"', $encoded) . '"';
|
||||||
}
|
}
|
||||||
$return[] = sprintf('%s <%s>', $encoded, $email);
|
$return[] = sprintf('%s <%s>', $encoded, $email);
|
||||||
|
|
|
@ -450,10 +450,6 @@ class CakeEmailTest extends CakeTestCase {
|
||||||
$expected = array('CakePHP <cake@cakephp.org>', 'Cake <php@cakephp.org>');
|
$expected = array('CakePHP <cake@cakephp.org>', 'Cake <php@cakephp.org>');
|
||||||
$this->assertSame($expected, $result);
|
$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'));
|
$result = $this->CakeEmail->formatAddress(array('me@example.com' => '"Last" First'));
|
||||||
$expected = array('"\"Last\" First" <me@example.com>');
|
$expected = array('"\"Last\" First" <me@example.com>');
|
||||||
$this->assertSame($expected, $result);
|
$this->assertSame($expected, $result);
|
||||||
|
@ -471,6 +467,33 @@ class CakeEmailTest extends CakeTestCase {
|
||||||
$this->assertSame($expected, $result);
|
$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
|
* testFormatAddressJapanese
|
||||||
*
|
*
|
||||||
|
|
Loading…
Add table
Reference in a new issue