2019-11-19 10:29:33 +00:00
|
|
|
<?php
|
|
|
|
|
2019-11-19 14:12:11 +00:00
|
|
|
namespace Cite;
|
|
|
|
|
|
|
|
use Html;
|
|
|
|
use Language;
|
2020-01-28 16:40:27 +00:00
|
|
|
use Message;
|
2019-11-19 14:12:11 +00:00
|
|
|
use Parser;
|
|
|
|
use Sanitizer;
|
|
|
|
|
2019-11-19 10:29:33 +00:00
|
|
|
/**
|
|
|
|
* @license GPL-2.0-or-later
|
|
|
|
*/
|
2019-12-09 16:08:57 +00:00
|
|
|
class ErrorReporter {
|
2019-11-19 10:29:33 +00:00
|
|
|
|
2023-06-05 14:36:03 +00:00
|
|
|
private ReferenceMessageLocalizer $messageLocalizer;
|
|
|
|
private ?Language $cachedInterfaceLanguage = null;
|
2019-12-06 03:20:20 +00:00
|
|
|
|
2020-01-28 16:40:27 +00:00
|
|
|
public function __construct( ReferenceMessageLocalizer $messageLocalizer ) {
|
2019-12-06 03:20:20 +00:00
|
|
|
$this->messageLocalizer = $messageLocalizer;
|
2019-11-19 10:29:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-12-11 15:05:19 +00:00
|
|
|
* @param Parser $parser
|
2019-11-19 10:29:33 +00:00
|
|
|
* @param string $key Message name of the error or warning
|
|
|
|
* @param mixed ...$params
|
|
|
|
*
|
2019-11-22 10:43:09 +00:00
|
|
|
* @return string Half-parsed wikitext with extension's tags already being expanded
|
2019-11-19 10:29:33 +00:00
|
|
|
*/
|
2021-07-22 05:44:15 +00:00
|
|
|
public function halfParsed( Parser $parser, string $key, ...$params ): string {
|
2020-01-28 16:40:27 +00:00
|
|
|
$msg = $this->msg( $parser, $key, ...$params );
|
|
|
|
$wikitext = $parser->recursiveTagParse( $msg->plain() );
|
|
|
|
return $this->wrapInHtmlContainer( $wikitext, $key, $msg->getLanguage() );
|
2019-11-19 10:29:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-12-11 15:05:19 +00:00
|
|
|
* @param Parser $parser
|
2019-11-19 10:29:33 +00:00
|
|
|
* @param string $key Message name of the error or warning
|
|
|
|
* @param mixed ...$params
|
|
|
|
*
|
2019-11-22 10:43:09 +00:00
|
|
|
* @return string Plain, unparsed wikitext
|
2019-11-19 10:29:33 +00:00
|
|
|
* @return-taint tainted
|
|
|
|
*/
|
2021-07-22 05:44:15 +00:00
|
|
|
public function plain( Parser $parser, string $key, ...$params ): string {
|
2020-01-28 16:40:27 +00:00
|
|
|
$msg = $this->msg( $parser, $key, ...$params );
|
|
|
|
$wikitext = $msg->plain();
|
|
|
|
return $this->wrapInHtmlContainer( $wikitext, $key, $msg->getLanguage() );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Parser $parser
|
|
|
|
* @param string $key
|
|
|
|
* @param mixed ...$params
|
|
|
|
*
|
|
|
|
* @return Message
|
|
|
|
*/
|
2021-07-22 05:44:15 +00:00
|
|
|
private function msg( Parser $parser, string $key, ...$params ): Message {
|
2020-01-28 16:40:27 +00:00
|
|
|
$language = $this->getInterfaceLanguageAndSplitCache( $parser );
|
|
|
|
$msg = $this->messageLocalizer->msg( $key, ...$params )->inLanguage( $language );
|
2019-11-19 10:29:33 +00:00
|
|
|
|
2022-06-01 08:34:57 +00:00
|
|
|
[ $type ] = $this->parseTypeAndIdFromMessageKey( $msg->getKey() );
|
2019-11-19 10:29:33 +00:00
|
|
|
|
2020-01-28 16:40:27 +00:00
|
|
|
if ( $type === 'error' ) {
|
2019-11-19 10:29:33 +00:00
|
|
|
// Take care; this is a sideeffect that might not belong to this class.
|
2019-12-11 15:05:19 +00:00
|
|
|
$parser->addTrackingCategory( 'cite-tracking-category-cite-error' );
|
2019-11-19 10:29:33 +00:00
|
|
|
}
|
|
|
|
|
2020-01-28 16:40:27 +00:00
|
|
|
// Messages: cite_error, cite_warning
|
|
|
|
return $this->messageLocalizer->msg( "cite_$type", $msg->plain() )->inLanguage( $language );
|
2019-11-19 10:29:33 +00:00
|
|
|
}
|
|
|
|
|
2019-12-06 03:20:20 +00:00
|
|
|
/**
|
|
|
|
* Note the startling side effect of splitting ParserCache by user interface language!
|
|
|
|
*
|
2019-12-11 15:05:19 +00:00
|
|
|
* @param Parser $parser
|
2020-01-09 10:50:32 +00:00
|
|
|
*
|
2019-12-06 03:20:20 +00:00
|
|
|
* @return Language
|
|
|
|
*/
|
2021-07-22 05:44:15 +00:00
|
|
|
private function getInterfaceLanguageAndSplitCache( Parser $parser ): Language {
|
2019-12-12 15:42:53 +00:00
|
|
|
if ( !$this->cachedInterfaceLanguage ) {
|
2019-12-11 15:05:19 +00:00
|
|
|
$this->cachedInterfaceLanguage = $parser->getOptions()->getUserLangObj();
|
2019-12-06 03:20:20 +00:00
|
|
|
}
|
|
|
|
return $this->cachedInterfaceLanguage;
|
|
|
|
}
|
|
|
|
|
2020-01-28 16:40:27 +00:00
|
|
|
/**
|
|
|
|
* @param string $wikitext
|
|
|
|
* @param string $key
|
|
|
|
* @param Language $language
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
private function wrapInHtmlContainer(
|
|
|
|
string $wikitext,
|
|
|
|
string $key,
|
|
|
|
Language $language
|
2021-07-22 05:44:15 +00:00
|
|
|
): string {
|
2020-01-28 16:40:27 +00:00
|
|
|
[ $type, $id ] = $this->parseTypeAndIdFromMessageKey( $key );
|
|
|
|
$extraClass = $type === 'warning'
|
|
|
|
? ' mw-ext-cite-warning-' . Sanitizer::escapeClass( $id )
|
|
|
|
: '';
|
|
|
|
|
|
|
|
return Html::rawElement(
|
|
|
|
'span',
|
|
|
|
[
|
|
|
|
'class' => "$type mw-ext-cite-$type" . $extraClass,
|
|
|
|
'lang' => $language->getHtmlCode(),
|
|
|
|
'dir' => $language->getDir(),
|
|
|
|
],
|
|
|
|
$wikitext
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $messageKey Expected to be a message key like "cite_error_ref_too_many_keys"
|
|
|
|
*
|
2022-06-01 08:34:57 +00:00
|
|
|
* @return string[] Two elements, e.g. "error" and "ref_too_many_keys"
|
2020-01-28 16:40:27 +00:00
|
|
|
*/
|
2021-07-22 05:44:15 +00:00
|
|
|
private function parseTypeAndIdFromMessageKey( string $messageKey ): array {
|
2022-06-01 08:34:57 +00:00
|
|
|
return array_slice( explode( '_', str_replace( '-', '_', $messageKey ), 3 ), 1 );
|
2020-01-28 16:40:27 +00:00
|
|
|
}
|
|
|
|
|
2019-11-19 10:29:33 +00:00
|
|
|
}
|