Skip to content

Commit 29b8f48

Browse files
committed
Autoconfigure CacheTokenVerifier if possible
1 parent 7592a80 commit 29b8f48

File tree

4 files changed

+59
-3
lines changed

4 files changed

+59
-3
lines changed
Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
<?php
2+
3+
/*
4+
* This file is part of the Symfony package.
5+
*
6+
* (c) Fabien Potencier <fabien@symfony.com>
7+
*
8+
* For the full copyright and license information, please view the LICENSE
9+
* file that was distributed with this source code.
10+
*/
11+
12+
namespace Symfony\Bundle\SecurityBundle\DependencyInjection\Compiler;
13+
14+
use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
15+
use Symfony\Component\DependencyInjection\ContainerBuilder;
16+
17+
/**
18+
* Cleans up the remember me verifier cache if cache is missing.
19+
*
20+
* @author Jordi Boggiano <j.boggiano@seld.be>
21+
*/
22+
class CleanRememberMeVerifierPass implements CompilerPassInterface
23+
{
24+
/**
25+
* {@inheritdoc}
26+
*/
27+
public function process(ContainerBuilder $container)
28+
{
29+
if (!$container->hasDefinition('cache.system')) {
30+
$container->removeDefinition('cache.security_token_verifier');
31+
}
32+
}
33+
}

src/Symfony/Bundle/SecurityBundle/DependencyInjection/Security/Factory/RememberMeFactory.php

Lines changed: 19 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@
2323
use Symfony\Component\DependencyInjection\Loader\PhpFileLoader;
2424
use Symfony\Component\DependencyInjection\Reference;
2525
use Symfony\Component\HttpFoundation\Cookie;
26+
use Symfony\Component\Security\Core\Authentication\RememberMe\CacheTokenVerifier;
2627
use Symfony\Component\Security\Http\EventListener\RememberMeLogoutListener;
2728

2829
/**
@@ -116,12 +117,12 @@ public function createAuthenticator(ContainerBuilder $container, string $firewal
116117
->addTag('security.remember_me_handler', ['firewall' => $firewallName]);
117118
} elseif (isset($config['token_provider'])) {
118119
$tokenProviderId = $this->createTokenProvider($container, $firewallName, $config['token_provider']);
119-
$tokenVerifierId = $config['token_verifier'] ?? null;
120+
$tokenVerifier = $this->createTokenVerifier($container, $firewallName, $config['token_verifier'] ?? null);
120121
$container->setDefinition($rememberMeHandlerId, new ChildDefinition('security.authenticator.persistent_remember_me_handler'))
121122
->replaceArgument(0, new Reference($tokenProviderId))
122123
->replaceArgument(2, new Reference($userProviderId))
123124
->replaceArgument(4, $config)
124-
->replaceArgument(6, $tokenVerifierId ? new Reference($tokenVerifierId) : null)
125+
->replaceArgument(6, $tokenVerifier)
125126
->addTag('security.remember_me_handler', ['firewall' => $firewallName]);
126127
} else {
127128
$signatureHasherId = 'security.authenticator.remember_me_signature_hasher.'.$firewallName;
@@ -309,4 +310,20 @@ private function createTokenProvider(ContainerBuilder $container, string $firewa
309310

310311
return $tokenProviderId;
311312
}
313+
314+
private function createTokenVerifier(ContainerBuilder $container, string $firewallName, ?string $serviceId): string
315+
{
316+
if ($serviceId) {
317+
return new Reference($serviceId);
318+
}
319+
320+
$tokenVerifierId = 'security.remember_me.token_verifier.'.$firewallName;
321+
322+
$container->register($tokenVerifierId, CacheTokenVerifier::class)
323+
->addArgument(new Reference('cache.security_token_verifier', ContainterInterface::NULL_ON_INVALID_REFERENCE))
324+
->addArgument(60)
325+
->addArgument('rememberme-'.$firewallName.'-stale-');
326+
327+
return new Reference($tokenVerifierId, ContainterInterface::NULL_ON_INVALID_REFERENCE);
328+
}
312329
}

src/Symfony/Bundle/SecurityBundle/Resources/config/security_authenticator_remember_me.php

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -88,5 +88,11 @@
8888
service('logger')->nullOnInvalid(),
8989
])
9090
->tag('monolog.logger', ['channel' => 'security'])
91+
92+
// Cache
93+
->set('cache.security_token_verifier')
94+
->parent('cache.system')
95+
->private()
96+
->tag('cache.pool')
9197
;
9298
};

src/Symfony/Component/Security/Core/Authentication/RememberMe/CacheTokenVerifier.php

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ class CacheTokenVerifier implements TokenVerifierInterface
2828
* most refresh tokens. Increasing to more than that is not recommended,
2929
* but you may use a lower value.
3030
*/
31-
public function __construct(CacheItemPoolInterface $cache, int $outdatedTokenTtl = 60, string $cacheKeyPrefix = 'rememberme-')
31+
public function __construct(CacheItemPoolInterface $cache, int $outdatedTokenTtl = 60, string $cacheKeyPrefix = 'rememberme-stale-')
3232
{
3333
$this->cache = $cache;
3434
$this->outdatedTokenTtl = $outdatedTokenTtl;

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy