From 5340ca84e57ef8313655d79ed84d8c9b9dc546a5 Mon Sep 17 00:00:00 2001 From: the-djmaze <> Date: Tue, 30 Aug 2022 22:25:09 +0200 Subject: [PATCH] #505 Try iconv() when \mb_convert_encoding() will not work. --- .../0.0.0/app/libraries/MailSo/Base/Utils.php | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/snappymail/v/0.0.0/app/libraries/MailSo/Base/Utils.php b/snappymail/v/0.0.0/app/libraries/MailSo/Base/Utils.php index 6239edf0f..80697c0ac 100644 --- a/snappymail/v/0.0.0/app/libraries/MailSo/Base/Utils.php +++ b/snappymail/v/0.0.0/app/libraries/MailSo/Base/Utils.php @@ -59,10 +59,7 @@ abstract class Utils return 'iso-8859-8'; } - $sEncoding = \preg_replace('/^cp-([\d])/', 'cp$1', $sEncoding); - $sEncoding = \preg_replace('/^windows?12/', 'windows-12', $sEncoding); - - return $sEncoding; + return \preg_replace('/^(cp-?|windows?)(12[\d])/', 'windows-$1', $sEncoding); } public static function NormalizeCharsetByValue(string $sCharset, string $sValue) : string @@ -159,14 +156,13 @@ abstract class Utils $sInputFromEncoding = static::$RenameEncoding[$sInputFromEncoding]; } if (!static::MbSupportedEncoding($sInputFromEncoding)) { + if (\function_exists('iconv')) { + $sResult = \iconv($sInputFromEncoding, "{$sInputToEncoding}//IGNORE", $sInputString); + return (false !== $sResult) ? $sResult : $sInputString; + } \error_log("Unsupported encoding {$sInputFromEncoding}"); $sInputFromEncoding = null; // return $sInputString; -/* - if (\function_exists('iconv')) { - return \iconv($sInputFromEncoding, $sInputToEncoding, $sInputString); - } -*/ } } @@ -179,12 +175,10 @@ abstract class Utils public static function ConvertEncoding(string $sInputString, string $sInputFromEncoding, string $sInputToEncoding) : string { - $sResult = $sInputString; - $sFromEncoding = static::NormalizeCharset($sInputFromEncoding); $sToEncoding = static::NormalizeCharset($sInputToEncoding); - if ('' === \trim($sResult) || ($sFromEncoding === $sToEncoding && Enumerations\Charset::UTF_8 !== $sFromEncoding)) + if ('' === \trim($sInputString) || ($sFromEncoding === $sToEncoding && Enumerations\Charset::UTF_8 !== $sFromEncoding)) { return $sInputString; }