mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Echo
synced 2024-11-27 17:20:40 +00:00
a0ca1d89c6
Changes to the use statements done automatically via script Addition of missing use statements done manually Change-Id: Iad87245bf8082193be72f7e482f29e9f1bad11fc
62 lines
1.6 KiB
PHP
62 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\Notifications;
|
|
|
|
use MediaWiki\Title\Title;
|
|
use MediaWiki\User\User;
|
|
|
|
class SummaryParser {
|
|
/** @var callable */
|
|
private $userLookup;
|
|
|
|
/**
|
|
* @param callable|null $userLookup Function that receives User object and returns its id
|
|
* or 0 if the user doesn't exist. Passing null to this parameter will result in default
|
|
* implementation being used.
|
|
*/
|
|
public function __construct( callable $userLookup = null ) {
|
|
$this->userLookup = $userLookup;
|
|
if ( !$this->userLookup ) {
|
|
$this->userLookup = static function ( User $user ) {
|
|
return $user->getId();
|
|
};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns a list of registered users linked in an edit summary
|
|
*
|
|
* @param string $summary
|
|
* @return User[] Array of username => User object
|
|
*/
|
|
public function parse( $summary ) {
|
|
// Remove section autocomments. Replace with characters that can't be in titles,
|
|
// to prevent fun stuff like "[[foo /* section */ bar]]".
|
|
$summary = preg_replace( '#/\*.*?\*/#', ' [] ', $summary );
|
|
|
|
$users = [];
|
|
$regex = '/\[\[([' . Title::legalChars() . ']++)(?:\|.*?)?\]\]/';
|
|
if ( preg_match_all( $regex, $summary, $matches ) ) {
|
|
foreach ( $matches[1] as $match ) {
|
|
if ( $match[0] === ':' ) {
|
|
continue;
|
|
}
|
|
|
|
$title = Title::newFromText( $match );
|
|
if ( $title
|
|
&& $title->isLocal()
|
|
&& $title->getNamespace() === NS_USER
|
|
) {
|
|
$user = User::newFromName( $title->getText() );
|
|
$lookup = $this->userLookup;
|
|
if ( $user && $lookup( $user ) > 0 ) {
|
|
$users[$user->getName()] = $user;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return $users;
|
|
}
|
|
}
|