1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
<?php
/*
* This file is part of the ICanBoogie package.
*
* (c) Olivier Laviale <olivier.laviale@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace ICanBoogie\Storage;
/**
* A collection of {@link Cache} instances.
*
* @package ICanBoogie\Storage
*/
class CacheCollection implements Cache
{
/**
* @var Cache[]
*/
protected $collection = [];
public function __construct(array $collection)
{
$this->collection = $collection;
}
/**
* @inheritdoc
*/
public function exists($key)
{
foreach ($this->collection as $cache)
{
if ($cache->exists($key))
{
return true;
}
}
return false;
}
/**
* @inheritdoc
*/
public function retrieve($key)
{
foreach ($this->collection as $cache)
{
if ($cache->exists($key))
{
return $cache->retrieve($key);
}
}
return null;
}
/**
* @inheritdoc
*/
public function getIterator()
{
return reset($this->collection)->getIterator();
}
/**
* Finds a cache by type.
*
* @param string $type The class or interface of the storage to find.
*
* @return Cache|null The cache matching the specified type or `null` if none match.
*/
public function find_by_type($type)
{
foreach ($this->collection as $cache)
{
if ($cache instanceof $type)
{
return $cache;
}
}
return null;
}
}