66 lines
1.7 KiB
PHP
66 lines
1.7 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\Contracts\Cache;
|
||
|
|
||
|
use Psr\Cache\CacheException;
|
||
|
use Psr\Cache\CacheItemInterface;
|
||
|
use Psr\Cache\InvalidArgumentException;
|
||
|
|
||
|
/**
|
||
|
* Augments PSR-6's CacheItemInterface with support for tags and metadata.
|
||
|
*
|
||
|
* @author Nicolas Grekas <p@tchwork.com>
|
||
|
*/
|
||
|
interface ItemInterface extends CacheItemInterface
|
||
|
{
|
||
|
/**
|
||
|
* References the Unix timestamp stating when the item will expire.
|
||
|
*/
|
||
|
const METADATA_EXPIRY = 'expiry';
|
||
|
|
||
|
/**
|
||
|
* References the time the item took to be created, in milliseconds.
|
||
|
*/
|
||
|
const METADATA_CTIME = 'ctime';
|
||
|
|
||
|
/**
|
||
|
* References the list of tags that were assigned to the item, as string[].
|
||
|
*/
|
||
|
const METADATA_TAGS = 'tags';
|
||
|
|
||
|
/**
|
||
|
* Reserved characters that cannot be used in a key or tag.
|
||
|
*/
|
||
|
const RESERVED_CHARACTERS = '{}()/\@:';
|
||
|
|
||
|
/**
|
||
|
* Adds a tag to a cache item.
|
||
|
*
|
||
|
* Tags are strings that follow the same validation rules as keys.
|
||
|
*
|
||
|
* @param string|string[] $tags A tag or array of tags
|
||
|
*
|
||
|
* @return $this
|
||
|
*
|
||
|
* @throws InvalidArgumentException When $tag is not valid
|
||
|
* @throws CacheException When the item comes from a pool that is not tag-aware
|
||
|
*/
|
||
|
public function tag($tags): self;
|
||
|
|
||
|
/**
|
||
|
* Returns a list of metadata info that were saved alongside with the cached value.
|
||
|
*
|
||
|
* See ItemInterface::METADATA_* consts for keys potentially found in the returned array.
|
||
|
*/
|
||
|
public function getMetadata(): array;
|
||
|
}
|