wiki.techinc.nl/includes/api/ApiChangeContentModel.php
Bartosz Dziewoński 2361889b78 Use the edited page's title for magic words in action=edit error messages
Allow specifying the title used for rendering error messages in
ApiErrorFormatter.

Then, specify one in ApiEditPage (and a few similar modules that deal
with single pages) once we've figured out which page is being edited.

Bug: T247661
Change-Id: Ic3d70efc23744ef6e90abc445f3babebf45c4697
2021-05-21 18:00:36 +02:00

157 lines
3.8 KiB
PHP

<?php
use MediaWiki\Content\IContentHandlerFactory;
use MediaWiki\Page\ContentModelChangeFactory;
/**
* Api module to change the content model of existing pages
*
* For new pages, use the edit api and specify the desired content model and format.
*
* @since 1.35
* @ingroup API
* @author DannyS712
*/
class ApiChangeContentModel extends ApiBase {
/** @var IContentHandlerFactory */
private $contentHandlerFactory;
/** @var ContentModelChangeFactory */
private $contentModelChangeFactory;
/**
* @param ApiMain $main
* @param string $action
* @param IContentHandlerFactory $contentHandlerFactory
* @param ContentModelChangeFactory $contentModelChangeFactory
*/
public function __construct(
ApiMain $main,
$action,
IContentHandlerFactory $contentHandlerFactory,
ContentModelChangeFactory $contentModelChangeFactory
) {
parent::__construct( $main, $action );
$this->contentHandlerFactory = $contentHandlerFactory;
$this->contentModelChangeFactory = $contentModelChangeFactory;
}
/**
* A lot of this code is based on SpecialChangeContentModel
*/
public function execute() {
$params = $this->extractRequestParams();
$wikiPage = $this->getTitleOrPageId( $params );
$title = $wikiPage->getTitle();
$this->getErrorFormatter()->setContextTitle( $title );
if ( !$title->exists() ) {
$this->dieWithError( 'apierror-changecontentmodel-missingtitle' );
}
$newModel = $params['model'];
$this->checkUserRightsAny( 'editcontentmodel' );
$changer = $this->contentModelChangeFactory->newContentModelChange(
$this->getAuthority(),
$wikiPage,
$newModel
);
// Status messages should be apierror-*
$changer->setMessagePrefix( 'apierror-' );
$permissionStatus = $changer->authorizeChange();
if ( !$permissionStatus->isGood() ) {
$this->dieStatus( $permissionStatus );
}
if ( $params['tags'] ) {
$tagStatus = $changer->setTags( $params['tags'] );
if ( !$tagStatus->isGood() ) {
$this->dieStatus( $tagStatus );
}
}
// Everything passed, make the conversion
try {
$status = $changer->doContentModelChange(
$this->getContext(),
$params['summary'],
$params['bot']
);
} catch ( ThrottledError $te ) {
$this->dieWithError( 'apierror-ratelimited' );
}
if ( !$status->isGood() ) {
// Failed
$this->dieStatus( $status );
}
$logid = $status->getValue()['logid'];
$result = [
'result' => 'Success',
'title' => $title->getPrefixedText(),
'pageid' => $title->getArticleID(),
'contentmodel' => $title->getContentModel( Title::READ_LATEST ),
'logid' => $logid,
'revid' => $title->getLatestRevID( Title::READ_LATEST ),
];
$this->getResult()->addValue( null, $this->getModuleName(), $result );
}
public function getAllowedParams() {
$models = $this->contentHandlerFactory->getContentModels();
$modelOptions = [];
foreach ( $models as $model ) {
$handler = $this->contentHandlerFactory->getContentHandler( $model );
if ( !$handler->supportsDirectEditing() ) {
continue;
}
$modelOptions[] = $model;
}
return [
'title' => [
ApiBase::PARAM_TYPE => 'string',
],
'pageid' => [
ApiBase::PARAM_TYPE => 'integer',
],
'summary' => null,
'tags' => [
ApiBase::PARAM_TYPE => 'tags',
ApiBase::PARAM_ISMULTI => true,
],
'model' => [
ApiBase::PARAM_TYPE => $modelOptions,
ApiBase::PARAM_REQUIRED => true,
],
'bot' => false,
];
}
public function mustBePosted() {
return true;
}
public function isWriteMode() {
return true;
}
public function needsToken() {
return 'csrf';
}
public function getHelpUrls() {
return 'https://www.mediawiki.org/wiki/Special:MyLanguage/Help:ChangeContentModel';
}
protected function getExamplesMessages() {
return [
'action=changecontentmodel&title=Main Page&model=text&token=123ABC'
=> 'apihelp-changecontentmodel-example'
];
}
}