47 lines
1.4 KiB
PHP
47 lines
1.4 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] ?? self::$cache[$key] = $resource->isFresh($timestamp);
|
||
|
}
|
||
|
}
|