CHANGELOG | ●●●●● patch | view | raw | blame | history | |
program/include/rcube_string_replacer.php | ●●●●● patch | view | raw | blame | history | |
program/steps/mail/func.inc | ●●●●● patch | view | raw | blame | history | |
tests/Framework/StringReplacer.php | ●●●●● patch | view | raw | blame | history |
CHANGELOG
@@ -1,6 +1,7 @@ CHANGELOG Roundcube Webmail =========================== - Fix handling of URLs with asterisk characters (#1488759) - Remove automatic to-lowercase conversion of usernames (#1488715) - Fix scrolling quirk in email preview frame using Opera 12 (#1488763) - Fix displaying of multipart/alternative messages with empty parts (#1488750) program/include/rcube_string_replacer.php
@@ -37,16 +37,16 @@ { // Simplified domain expression for UTF8 characters handling // Support unicode/punycode in top-level domain part $utf_domain = '[^?&@"\'\\/()\s\r\t\n]+\\.([^\\x00-\\x2f\\x3b-\\x40\\x5b-\\x60\\x7b-\\x7f]{2,}|xn--[a-z0-9]{2,})'; $utf_domain = '[^?&@"\'\\/()\s\r\t\n]+\\.([^\\x00-\\x2f\\x3b-\\x40\\x5b-\\x60\\x7b-\\x7f]{2,}|xn--[a-zA-Z0-9]{2,})'; $url1 = '.:;,'; $url2 = 'a-z0-9%=#@+?!&\\/_~\\[\\]{}-'; $url2 = 'a-zA-Z0-9%=#$@+?!&\\/_~\\[\\]{}\*-'; $this->link_pattern = "/([\w]+:\/\/|\Wwww\.)($utf_domain([$url1]?[$url2]+)*)/i"; $this->link_pattern = "/([\w]+:\/\/|\W[Ww][Ww][Ww]\.|^[Ww][Ww][Ww]\.)($utf_domain([$url1]?[$url2]+)*)/"; $this->mailto_pattern = "/(" ."[-\w!\#\$%&\'*+~\/^`|{}=]+(?:\.[-\w!\#\$%&\'*+~\/^`|{}=]+)*" // local-part ."@$utf_domain" // domain-part ."(\?[$url1$url2]+)?" // e.g. ?subject=test... .")/i"; .")/"; } /** @@ -81,11 +81,11 @@ $i = -1; $scheme = strtolower($matches[1]); if (preg_match('!^(http|ftp|file)s?://!', $scheme)) { if (preg_match('!^(http|ftp|file)s?://!i', $scheme)) { $url = $matches[1] . $matches[2]; } else if (preg_match('/^(\W)www\.$/', $matches[1], $m)) { $url = 'www.' . $matches[2]; else if (preg_match('/^(\W*)(www\.)$/i', $matches[1], $m)) { $url = $m[2] . $matches[2]; $url_prefix = 'http://'; $prefix = $m[1]; } @@ -134,6 +134,22 @@ } /** * Replace all defined (link|mailto) patterns with replacement string * * @param string $str Text * * @return string Text */ public function replace($str) { // search for patterns like links and e-mail addresses $str = preg_replace_callback($this->link_pattern, array($this, 'link_callback'), $str); $str = preg_replace_callback($this->mailto_pattern, array($this, 'mailto_callback'), $str); return $str; } /** * Replace substituted strings with original values */ public function resolve($str) program/steps/mail/func.inc
@@ -786,9 +786,8 @@ // make links and email-addresses clickable $replacer = new rcube_string_replacer; // search for patterns like links and e-mail addresses $body = preg_replace_callback($replacer->link_pattern, array($replacer, 'link_callback'), $body); $body = preg_replace_callback($replacer->mailto_pattern, array($replacer, 'mailto_callback'), $body); // search for patterns like links and e-mail addresses and replace with tokens $body = $replacer->replace($body); // split body into single lines $body = preg_split('/\r?\n/', $body); tests/Framework/StringReplacer.php
@@ -17,4 +17,28 @@ $this->assertInstanceOf('rcube_string_replacer', $sr, "Class constructor"); } /** * Data for test_replace() */ function data_replace() { return array( array('http://domain.tld/path*path2', '<a href="http://domain.tld/path*path2" target="_blank">http://domain.tld/path*path2</a>'), array('www.domain.tld', '<a href="http://www.domain.tld" target="_blank">www.domain.tld</a>'), array('WWW.DOMAIN.TLD', '<a href="http://WWW.DOMAIN.TLD" target="_blank">WWW.DOMAIN.TLD</a>'), ); } /** * @dataProvider data_replace */ function test_replace($input, $output) { $replacer = new rcube_string_replacer; $result = $replacer->replace($input); $result = $replacer->resolve($result); $this->assertEquals($output, $result); } }