function FileResourceTestBase::setUpAuthorization

Same name and namespace in other branches
  1. 9 core/modules/file/tests/src/Functional/Rest/FileResourceTestBase.php \Drupal\Tests\file\Functional\Rest\FileResourceTestBase::setUpAuthorization()
  2. 8.9.x core/modules/file/tests/src/Functional/Rest/FileResourceTestBase.php \Drupal\Tests\file\Functional\Rest\FileResourceTestBase::setUpAuthorization()
  3. 11.x core/modules/file/tests/src/Functional/Rest/FileResourceTestBase.php \Drupal\Tests\file\Functional\Rest\FileResourceTestBase::setUpAuthorization()

Sets up the necessary authorization.

In case of a test verifying publicly accessible REST resources: grant permissions to the anonymous user role.

In case of a test verifying behavior when using a particular authentication provider: create a user with a particular set of permissions.

Because of the $method parameter, it's possible to first set up authentication for only GET, then add POST, et cetera. This then also allows for verifying a 403 in case of missing authorization.

Parameters

string $method: The HTTP method for which to set up authentication.

Overrides ResourceTestBase::setUpAuthorization

File

core/modules/file/tests/src/Functional/Rest/FileResourceTestBase.php, line 64

Class

FileResourceTestBase

Namespace

Drupal\Tests\file\Functional\Rest

Code

protected function setUpAuthorization($method) {
    switch ($method) {
        case 'GET':
            $this->grantPermissionsToTestedRole([
                'access content',
            ]);
            break;
        case 'PATCH':
            // \Drupal\file\FileAccessControlHandler::checkAccess() grants 'update'
            // access only to the user that owns the file. So there is no permission
            // to grant: instead, the file owner must be changed from its default
            // (user 1) to the current user.
            $this->makeCurrentUserFileOwner();
            return;
        case 'DELETE':
            $this->grantPermissionsToTestedRole([
                'delete any file',
            ]);
            break;
    }
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.