Headline
CVE-2018-25065: SECURITY: Parse tag function input as wikitext to prevent XSS · wikimedia/mediawiki-extensions-I18nTags@b4bc3cb
A vulnerability was found in Wikimedia mediawiki-extensions-I18nTags and classified as problematic. This issue affects some unknown processing of the file I18nTags_body.php of the component Unlike Parser. The manipulation leads to cross site scripting. The attack may be initiated remotely. The name of the patch is b4bc3cbbb099eab50cf2b544cf577116f1867b94. It is recommended to apply a patch to fix this issue. The identifier VDB-217445 was assigned to this vulnerability.
@@ -9,20 +9,22 @@ public static function onParserFirstCallInit( Parser $parser ) { $parser->setFunctionHook( 'languagename’, [ __CLASS__, ‘languageName’ ] ); }
public static function formatNumber( $data, $params, $parser ) { public static function formatNumber( $data, $params, $parser, $frame ) { $lang = self::languageObject( $params );
return $lang->formatNum( $data ); $text = $lang->formatNum( $data ); return $parser->recursiveTagParse( $text, $frame ); }
public static function grammar( $data, $params, $parser ) { public static function grammar( $data, $params, $parser, $frame ) { $case = isset( $params[‘case’] ) ? $params[‘case’] : '’; $lang = self::languageObject( $params );
return $lang->convertGrammar( $data, $case ); $text = $lang->convertGrammar( $data, $case ); return $parser->recursiveTagParse( $text, $frame ); }
public static function plural( $data, $params, $parser ) { public static function plural( $data, $params, $parser, $frame ) { list( $from, $to ) = self::getRange( isset( $params[‘n’] ) ? $params[‘n’] : ‘’ ); $args = explode( '|’, $data ); $lang = self::languageObject( $params ); @@ -41,10 +43,10 @@ public static function plural( $data, $params, $parser ) { ); }
return $s; return $parser->recursiveTagParse( $s, $frame ); }
public static function linktrail( $data, $params, $parser ) { public static function linktrail( $data, $params, $parser, $frame ) { $lang = self::languageObject( $params ); $regex = $lang->linkTrail();
@@ -60,7 +62,8 @@ public static function linktrail( $data, $params, $parser ) { } $predata = isset( $predata[2] ) ? $predata[2] : isset( $predata[1] ) ? $predata[1] : $predata[0];
return "<strong>$predata$inside</strong>$data"; $text = "<strong>$predata$inside</strong>$data"; return $parser->recursiveTagParse( $text, $frame ); }
public static function languageName( &$parser, $code = '’, $outputLanguage = ‘’ ) {