26use Psr\Log\LoggerAwareInterface;
27use Psr\Log\LoggerInterface;
174 'persisted' =>
false,
202 public function mergeMetadata( array $savedMetadata, array $providedMetadata ) {
203 foreach ( $providedMetadata as $k => $v ) {
204 if ( array_key_exists( $k, $savedMetadata ) && $savedMetadata[$k] !== $v ) {
207 'old_value' => $savedMetadata[$k],
213 return $providedMetadata;
376 throw new \BadMethodCallException(
377 __METHOD__ .
' must be implmented when canChangeUser() is false'
444 throw new \InvalidArgumentException(
'Backend\'s provider isn\'t $this' );
458 return static::class;
478 'sessionprovider-' . str_replace(
'\\',
'-', strtolower( static::class ) )
484 $msg->inLanguage(
$lang );
485 if ( $msg->isDisabled() ) {
486 $msg =
wfMessage(
'sessionprovider-generic', (
string)$this )->inLanguage(
$lang );
488 return $msg->plain();
509 if ( !is_string( $data ) ) {
510 throw new \InvalidArgumentException(
511 '$data must be a string, ' . gettype( $data ) .
' was passed'
514 if ( $key !==
null && !is_string( $key ) ) {
515 throw new \InvalidArgumentException(
516 '$key must be a string or null, ' . gettype( $key ) .
' was passed'
520 $hash = \MWCryptHash::hmac(
"$this\n$data", $key ?: $this->config->get(
'SecretKey' ),
false );
521 if ( strlen( $hash ) < 32 ) {
524 throw new \UnexpectedValueException(
'Hash fuction returned less than 128 bits' );
527 if ( strlen( $hash ) >= 40 ) {
528 $hash = \Wikimedia\base_convert( $hash, 16, 32, 32 );
530 return substr( $hash, -32 );
Internationalisation code.
The User object encapsulates all of the user-specific settings (user_id, name, rights,...
The WebRequest class encapsulates getting at data passed in the URL or via a POSTed form stripping il...
do that in ParserLimitReportFormat instead use this to modify the parameters of the image all existing parser cache entries will be invalid To avoid you ll need to handle that somehow(e.g. with the RejectParserCacheValue hook) because MediaWiki won 't do it for you. & $defaults also a ContextSource after deleting those rows but within the same transaction you ll probably need to make sure the header is varied on $request
either a unescaped string or a HtmlArmor object after in associative array form externallinks including delete and has completed for all link tables whether this was an auto creation default is conds Array Extra conditions for the No matching items in log is displayed if loglist is empty msgKey Array If you want a nice box with a set this to the key of the message First element is the message additional optional elements are parameters for the key that are processed with wfMessage() -> params() ->parseAsBlock() - offset Set to overwrite offset parameter in $wgRequest set to '' to unset offset - wrap String Wrap the message in html(usually something like "<div ...>$1</div>"). - flags Integer display flags(NO_ACTION_LINK, NO_EXTRA_USER_LINKS) 'LogException':Called before an exception(or PHP error) is logged. This is meant for integration with external error aggregation services
this hook is for auditing only or null if authentication failed before getting that far $username
processing should stop and the error should be shown to the user * false
returning false will NOT prevent logging $e
Interface for configuration instances.
if(!isset( $args[0])) $lang