mirror of
https://github.com/moodle/moodle.git
synced 2025-08-07 01:46:45 +02:00
MDL-33007 add workaround for broken iconv //IGNORE
This patch adds mbstring utf-8 cleanup fallback and admin warning if no utf-8 cleanup possible in user submitted data.
This commit is contained in:
parent
3681e78429
commit
0aff15c2c9
6 changed files with 48 additions and 15 deletions
|
@ -1127,15 +1127,39 @@ function fix_utf8($value) {
|
|||
// shortcut
|
||||
return $value;
|
||||
}
|
||||
// lower error reporting because glibc throws bogus notices
|
||||
|
||||
// Lower error reporting because glibc throws bogus notices.
|
||||
$olderror = error_reporting();
|
||||
if ($olderror & E_NOTICE) {
|
||||
error_reporting($olderror ^ E_NOTICE);
|
||||
}
|
||||
$result = iconv('UTF-8', 'UTF-8//IGNORE', $value);
|
||||
|
||||
// Note: this duplicates min_fix_utf8() intentionally.
|
||||
static $buggyiconv = null;
|
||||
if ($buggyiconv === null) {
|
||||
$buggyiconv = (!function_exists('iconv') or iconv('UTF-8', 'UTF-8//IGNORE', '100'.chr(130).'€') !== '100€');
|
||||
}
|
||||
|
||||
if ($buggyiconv) {
|
||||
if (function_exists('mb_convert_encoding')) {
|
||||
$subst = mb_substitute_character();
|
||||
mb_substitute_character('');
|
||||
$result = mb_convert_encoding($value, 'utf-8', 'utf-8');
|
||||
mb_substitute_character($subst);
|
||||
|
||||
} else {
|
||||
// Warn admins on admin/index.php page.
|
||||
$result = $value;
|
||||
}
|
||||
|
||||
} else {
|
||||
$result = iconv('UTF-8', 'UTF-8//IGNORE', $value);
|
||||
}
|
||||
|
||||
if ($olderror & E_NOTICE) {
|
||||
error_reporting($olderror);
|
||||
}
|
||||
|
||||
return $result;
|
||||
|
||||
} else if (is_array($value)) {
|
||||
|
|
|
@ -301,6 +301,7 @@ class moodlelib_testcase extends advanced_testcase {
|
|||
$this->assertSame(1.1, fix_utf8(1.1));
|
||||
$this->assertSame(true, fix_utf8(true));
|
||||
$this->assertSame('', fix_utf8(''));
|
||||
$this->assertSame('abc', fix_utf8('abc'));
|
||||
$array = array('do', 're', 'mi');
|
||||
$this->assertSame($array, fix_utf8($array));
|
||||
$object = new stdClass();
|
||||
|
@ -312,7 +313,7 @@ class moodlelib_testcase extends advanced_testcase {
|
|||
$this->assertSame("žlutý koníček přeskočil potůček \n\t\r\0", fix_utf8("žlutý koníček přeskočil potůček \n\t\r\0"));
|
||||
|
||||
// invalid utf8 string
|
||||
$this->assertSame('aaabbb', fix_utf8('aaa'.chr(130).'bbb'));
|
||||
$this->assertSame('aš', fix_utf8('a'.chr(130).'š'), 'This fails with buggy iconv() when mbstring extenstion is not available as fallback.');
|
||||
}
|
||||
|
||||
function test_optional_param() {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue