wiki.techinc.nl/includes/Rest/BasicAccess/MWBasicRequestAuthorizer.php
Tim Starling 94c0baaa2f REST: basic read restrictions
Protect private wikis by providing basic read restrictions,
closely following the example of the action API.

The BasicAccess module provides a narrow interface for this
functionality, without exposing the whole session/user concept to the
router.

Also, add RouterTest and fix a bug in Router::getRelativePath() thus
discovered.

Change-Id: I82319d56f08b2eec4a585ff6dbd348ccdbadc5b5
2019-07-09 15:23:20 +10:00

38 lines
934 B
PHP

<?php
namespace MediaWiki\Rest\BasicAccess;
use User;
use MediaWiki\Permissions\PermissionManager;
use MediaWiki\Rest\Handler;
use MediaWiki\Rest\RequestInterface;
/**
* The concrete implementation of basic read restrictions in MediaWiki
*
* @internal
*/
class MWBasicRequestAuthorizer extends BasicRequestAuthorizer {
/** @var User */
private $user;
/** @var PermissionManager */
private $permissionManager;
public function __construct( RequestInterface $request, Handler $handler,
User $user, PermissionManager $permissionManager
) {
parent::__construct( $request, $handler );
$this->user = $user;
$this->permissionManager = $permissionManager;
}
protected function isReadAllowed() {
return $this->permissionManager->isEveryoneAllowed( 'read' )
|| $this->isAllowed( 'read' );
}
private function isAllowed( $action ) {
return $this->permissionManager->userHasRight( $this->user, $action );
}
}