wiki.techinc.nl/includes/logging/MoveLogFormatter.php
Lucas Werkmeister fb760c66c5 MoveLogFormatter::getPreloadTitles: Handle bad titles
If the namespace configuration changed, it’s possible that the title in
the params can no longer be parsed. In that case, we shouldn’t return a
null entry, but just an empty array instead. (I haven’t tried it out
locally, but the test suggests that the actual formatting of the row
works without issue, with the title being shown as Special:BadTitle.)

Bug: T370396
Change-Id: I6335e12efa518332f7cd2268a833f8b60b8e6abe
2024-07-18 11:49:33 +02:00

124 lines
3.5 KiB
PHP

<?php
/**
* Formatter for move log entries.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
* @author Niklas Laxström
* @license GPL-2.0-or-later
* @since 1.22
*/
use MediaWiki\Message\Message;
use MediaWiki\SpecialPage\SpecialPage;
use MediaWiki\Title\Title;
/**
* This class formats move log entries.
*
* @since 1.19
*/
class MoveLogFormatter extends LogFormatter {
public function getPreloadTitles() {
$params = $this->extractParameters();
$title = Title::newFromText( $params[3] );
if ( $title !== null ) {
return [ $title ];
} else {
// namespace configuration may have changed to make $params[3] invalid (T370396);
// nothing to preload in this case
return [];
}
}
protected function getMessageKey() {
$key = parent::getMessageKey();
$params = $this->extractParameters();
if ( isset( $params[4] ) && $params[4] === '1' ) {
// Messages: logentry-move-move-noredirect, logentry-move-move_redir-noredirect
$key .= '-noredirect';
}
return $key;
}
protected function getMessageParameters() {
$params = parent::getMessageParameters();
$oldname = $this->makePageLink( $this->entry->getTarget(), [ 'redirect' => 'no' ] );
$newname = $this->makePageLink( Title::newFromText( $params[3] ) );
$params[2] = Message::rawParam( $oldname );
$params[3] = Message::rawParam( $newname );
unset( $params[4] ); // handled in getMessageKey
return $params;
}
public function getActionLinks() {
if ( $this->entry->isDeleted( LogPage::DELETED_ACTION ) // Action is hidden
|| $this->entry->getSubtype() !== 'move'
|| !$this->context->getAuthority()->isAllowed( 'move' )
) {
return '';
}
$params = $this->extractParameters();
$destTitle = Title::newFromText( $params[3] );
if ( !$destTitle || !$destTitle->exists() ) {
return '';
}
$revert = $this->getLinkRenderer()->makeKnownLink(
SpecialPage::getTitleFor( 'Movepage' ),
$this->msg( 'revertmove' )->text(),
[],
[
'wpOldTitle' => $destTitle->getPrefixedDBkey(),
'wpNewTitle' => $this->entry->getTarget()->getPrefixedDBkey(),
'wpReason' => $this->msg( 'revertmove-summary' )->inContentLanguage()->text(),
'wpMovetalk' => 0
]
);
return $this->msg( 'parentheses' )->rawParams( $revert )->escaped();
}
protected function getParametersForApi() {
$entry = $this->entry;
$params = $entry->getParameters();
static $map = [
'4:title:target',
'5:bool:suppressredirect',
'4::target' => '4:title:target',
'5::noredir' => '5:bool:suppressredirect',
];
foreach ( $map as $index => $key ) {
if ( isset( $params[$index] ) ) {
$params[$key] = $params[$index];
unset( $params[$index] );
}
}
if ( !isset( $params['5:bool:suppressredirect'] ) ) {
$params['5:bool:suppressredirect'] = false;
}
return $params;
}
}