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
38 lines
934 B
PHP
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 );
|
|
}
|
|
}
|