Skip to content

Commit

Permalink
deprecate the access denied listener
Browse files Browse the repository at this point in the history
  • Loading branch information
xabbuh committed May 22, 2020
1 parent d1679b9 commit 0525474
Show file tree
Hide file tree
Showing 20 changed files with 347 additions and 1 deletion.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ CHANGELOG
in 3.0
* deprecated the following options:

* `fos_rest.access_denied_listener`
* `fos_rest.exception.exception_controller`
* `fos_rest.exception.exception_listener`
* `fos_rest.exception.service`
Expand All @@ -75,6 +76,7 @@ CHANGELOG
* `FOS\RestBundle\Controller\ExceptionController`
* `FOS\RestBundle\Controller\TemplatingExceptionController`
* `FOS\RestBundle\Controller\TwigExceptionController`
* `FOS\RestBundle\EventListener\AccessDeniedListener`
* `FOS\RestBundle\EventListener\ExceptionListener`
* `FOS\RestBundle\Inflector\DoctrineInflector`
* `FOS\RestBundle\Inflector\InflectorInterface`
Expand All @@ -92,6 +94,7 @@ CHANGELOG

* the following services and aliases are marked as `deprecated`, they will be removed in 3.0:

* `fos_rest.access_denied_listener`
* `fos_rest.exception_listener`
* `fos_rest.exception.controller`
* `fos_rest.exception.twig_controller`
Expand Down
1 change: 1 addition & 0 deletions DependencyInjection/Configuration.php
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ public function getConfigTreeBuilder(): TreeBuilder
->scalarNode('disable_csrf_role')->defaultNull()->end()
->arrayNode('access_denied_listener')
->canBeEnabled()
->setDeprecated('The "%path%.%node%" option is deprecated since FOSRestBundle 2.8.')
->beforeNormalization()
->ifArray()->then(function ($v) {
if (!empty($v) && empty($v['formats'])) {
Expand Down
2 changes: 2 additions & 0 deletions EventListener/AccessDeniedListener.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@

namespace FOS\RestBundle\EventListener;

@trigger_error(sprintf('The %s\AccessDeniedListener class is deprecated since FOSRestBundle 2.8.', __NAMESPACE__), E_USER_DEPRECATED);

use FOS\RestBundle\FOSRestBundle;
use Symfony\Component\HttpKernel\Event\ExceptionEvent;
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
Expand Down
1 change: 1 addition & 0 deletions Resources/config/access_denied_listener.xml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
<tag name="monolog.logger" channel="request" />
<argument type="collection" /> <!-- formats -->
<argument /> <!-- unauthorized challenge -->
<deprecated>The "%service_id%" service is deprecated since FOSRestBundle 2.8.</deprecated>
</service>

</services>
Expand Down
2 changes: 2 additions & 0 deletions Tests/EventListener/AccessDeniedListenerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,8 @@
/**
* AccessDeniedListenerTest.
*
* @group legacy
*
* @author Boris Guéry <[email protected]>
*/
class AccessDeniedListenerTest extends TestCase
Expand Down
82 changes: 82 additions & 0 deletions Tests/Functional/AbstractAuthenticatorTestCase.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
<?php

/*
* This file is part of the FOSRestBundle package.
*
* (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace FOS\RestBundle\Tests\Functional;

use Symfony\Component\ErrorHandler\ErrorRenderer\ErrorRendererInterface;

abstract class AbstractAuthenticatorTestCase extends WebTestCase
{
protected static $client;

public static function setUpBeforeClass()
{
if (!interface_exists(ErrorRendererInterface::class)) {
self::markTestSkipped();
}

parent::setUpBeforeClass();

self::$client = self::createClient(['test_case' => static::getTestCase()]);
}

public static function tearDownAfterClass()
{
self::deleteTmpDir(static::getTestCase());

parent::tearDownAfterClass();
}

public function testNoCredentialsGives401()
{
self::$client->request('POST', '/api/login', [], [], ['CONTENT_TYPE' => 'application/json']);
$response = self::$client->getResponse();

$this->assertEquals(401, $response->getStatusCode());
$this->assertEquals('application/json', $response->headers->get('Content-Type'));
}

public function testWrongCredentialsGives401()
{
$this->sendRequestContainingInvalidCredentials('/api/login');

$response = self::$client->getResponse();

$this->assertEquals(401, $response->getStatusCode());
$this->assertEquals('application/json', $response->headers->get('Content-Type'));
}

public function testSuccessfulLogin()
{
$this->sendRequestContainingValidCredentials('/api/login');

$response = self::$client->getResponse();

$this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('application/json', $response->headers->get('Content-Type'));
}

public function testAccessDeniedExceptionGives403()
{
$this->sendRequestContainingValidCredentials('/api/comments');

$response = self::$client->getResponse();

$this->assertEquals(403, $response->getStatusCode());
$this->assertEquals('application/json', $response->headers->get('Content-Type'));
}

abstract protected static function getTestCase(): string;

abstract protected function sendRequestContainingInvalidCredentials(string $path): void;

abstract protected function sendRequestContainingValidCredentials(string $path): void;
}
3 changes: 3 additions & 0 deletions Tests/Functional/AccessDeniedListenerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,9 @@

use Symfony\Component\ErrorHandler\ErrorRenderer\ErrorRendererInterface;

/**
* @group legacy
*/
class AccessDeniedListenerTest extends WebTestCase
{
private static $client;
Expand Down
36 changes: 36 additions & 0 deletions Tests/Functional/BasicAuthTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
<?php

/*
* This file is part of the FOSRestBundle package.
*
* (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace FOS\RestBundle\Tests\Functional;

class BasicAuthTest extends AbstractAuthenticatorTestCase
{
protected static function getTestCase(): string
{
return 'BasicAuth';
}

protected function sendRequestContainingInvalidCredentials(string $path): void
{
self::$client->request('POST', $path, [], [], [
'PHP_AUTH_USER' => 'restapi',
'PHP_AUTH_PW' => 'wrongpw',
]);
}

protected function sendRequestContainingValidCredentials(string $path): void
{
self::$client->request('POST', $path, [], [], [
'PHP_AUTH_USER' => 'restapi',
'PHP_AUTH_PW' => 'secretpw',
]);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ public function onAuthenticationSuccess(Request $request, TokenInterface $token,

public function onAuthenticationFailure(Request $request, AuthenticationException $exception): ?Response
{
throw new AuthenticationException('Token not valid');
return new JsonResponse(null, 401);
}

/**
Expand Down
30 changes: 30 additions & 0 deletions Tests/Functional/CustomGuardAuthenticatorTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
<?php

/*
* This file is part of the FOSRestBundle package.
*
* (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

namespace FOS\RestBundle\Tests\Functional;

class CustomGuardAuthenticatorTest extends AbstractAuthenticatorTestCase
{
protected static function getTestCase(): string
{
return 'CustomGuardAuthenticator';
}

protected function sendRequestContainingInvalidCredentials(string $path): void
{
self::$client->request('POST', $path, [], [], ['HTTP_X-FOO' => 'BAR', 'CONTENT_TYPE' => 'application/json']);
}

protected function sendRequestContainingValidCredentials(string $path): void
{
self::$client->request('POST', $path, [], [], ['HTTP_X-FOO' => 'FOOBAR', 'CONTENT_TYPE' => 'application/json']);
}
}
17 changes: 17 additions & 0 deletions Tests/Functional/app/BasicAuth/bundles.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
<?php

/*
* This file is part of the FOSRestBundle package.
*
* (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

return [
new \Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
new \Symfony\Bundle\SecurityBundle\SecurityBundle(),
new \FOS\RestBundle\FOSRestBundle(),
new \FOS\RestBundle\Tests\Functional\Bundle\TestBundle\TestBundle(),
];
17 changes: 17 additions & 0 deletions Tests/Functional/app/BasicAuth/config.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
imports:
- { resource: ../config/default.yml }
- { resource: security.php }

framework:
serializer:
enabled: true
router: { resource: "%kernel.project_dir%/BasicAuth/routing.yml" }

fos_rest:
body_listener: false
exception:
exception_listener: false
serialize_exceptions: false
routing_loader: false
zone:
- { path: ^/api/* }
11 changes: 11 additions & 0 deletions Tests/Functional/app/BasicAuth/routing.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
api:
path: /api/comments
defaults:
_controller: FOS\RestBundle\Tests\Functional\Bundle\TestBundle\Controller\Api\CommentController::getComments
_format: json

api_login:
path: /api/login
defaults:
_controller: FOS\RestBundle\Tests\Functional\Bundle\TestBundle\Controller\Api\CommentController::loginAction
_format: json
43 changes: 43 additions & 0 deletions Tests/Functional/app/BasicAuth/security.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
<?php

/*
* This file is part of the FOSRestBundle package.
*
* (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

use Symfony\Component\Security\Core\Security;
use Symfony\Component\Security\Http\Controller\UserValueResolver;

$defaultFirewall = [];
if (method_exists(Security::class, 'getUser') && !class_exists(UserValueResolver::class)) {
$defaultFirewall['logout_on_user_change'] = true;
}

$container->loadFromExtension('security', [
'encoders' => ['Symfony\Component\Security\Core\User\User' => 'plaintext'],
'providers' => [
'in_memory' => [
'memory' => [
'users' => [
'restapi' => ['password' => 'secretpw', 'roles' => ['ROLE_API']],
],
],
],
],
'firewalls' => [
'default' => array_merge($defaultFirewall, [
'provider' => 'in_memory',
'anonymous' => 'lazy',
'stateless' => true,
'http_basic' => null,
]),
],
'access_control' => [
['path' => '^/api/comments', 'roles' => 'ROLE_ADMIN'],
['path' => '^/api', 'roles' => 'ROLE_API'],
],
]);
17 changes: 17 additions & 0 deletions Tests/Functional/app/CustomGuardAuthenticator/bundles.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
<?php

/*
* This file is part of the FOSRestBundle package.
*
* (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/

return [
new \Symfony\Bundle\FrameworkBundle\FrameworkBundle(),
new \Symfony\Bundle\SecurityBundle\SecurityBundle(),
new \FOS\RestBundle\FOSRestBundle(),
new \FOS\RestBundle\Tests\Functional\Bundle\TestBundle\TestBundle(),
];
21 changes: 21 additions & 0 deletions Tests/Functional/app/CustomGuardAuthenticator/config.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
imports:
- { resource: ../config/default.yml }
- { resource: security.php }

framework:
serializer:
enabled: true
router: { resource: "%kernel.project_dir%/CustomGuardAuthenticator/routing.yml" }

fos_rest:
body_listener: false
exception:
exception_listener: false
serialize_exceptions: false
routing_loader: false
zone:
- { path: ^/api/* }

services:
api_token_authenticator:
class: FOS\RestBundle\Tests\Functional\Bundle\TestBundle\Security\ApiTokenAuthenticator
11 changes: 11 additions & 0 deletions Tests/Functional/app/CustomGuardAuthenticator/routing.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
api:
path: /api/comments
defaults:
_controller: FOS\RestBundle\Tests\Functional\Bundle\TestBundle\Controller\Api\CommentController::getComments
_format: json

api_login:
path: /api/login
defaults:
_controller: FOS\RestBundle\Tests\Functional\Bundle\TestBundle\Controller\Api\CommentController::loginAction
_format: json
Loading

0 comments on commit 0525474

Please sign in to comment.