Files
iTop/lib/symfony/config/Resource/SelfCheckingResourceChecker.php
bdalsass 27ce51ab07 N°6934 - Symfony 6.4 - upgrade Symfony bundles to 6.4 (#580)
* Update Symfony lib to version ~6.4.0
* Update code missing return type
* Add an iTop general configuration entry to store application secret (Symfony mandatory parameter)
* Use dependency injection in ExceptionListener & UserProvider classes
2023-12-05 13:56:56 +01:00

47 lines
1.3 KiB
PHP

<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Config\Resource;
use Symfony\Component\Config\ResourceCheckerInterface;
/**
* Resource checker for instances of SelfCheckingResourceInterface.
*
* As these resources perform the actual check themselves, we can provide
* this class as a standard way of validating them.
*
* @author Matthias Pigulla <mp@webfactory.de>
*/
class SelfCheckingResourceChecker implements ResourceCheckerInterface
{
// Common shared cache, because this checker can be used in different
// situations. For example, when using the full stack framework, the router
// and the container have their own cache. But they may check the very same
// resources
private static array $cache = [];
public function supports(ResourceInterface $metadata): bool
{
return $metadata instanceof SelfCheckingResourceInterface;
}
/**
* @param SelfCheckingResourceInterface $resource
*/
public function isFresh(ResourceInterface $resource, int $timestamp): bool
{
$key = "$resource:$timestamp";
return self::$cache[$key] ??= $resource->isFresh($timestamp);
}
}