the whole shebang
This commit is contained in:
		
							
								
								
									
										2
									
								
								vendor/doctrine/cache/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								vendor/doctrine/cache/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| vendor/ | ||||
| phpunit.xml | ||||
							
								
								
									
										9
									
								
								vendor/doctrine/cache/.travis.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								vendor/doctrine/cache/.travis.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| language: php | ||||
|  | ||||
| php: | ||||
|   - 5.3 | ||||
|   - 5.4 | ||||
|   - 5.5 | ||||
|  | ||||
| before_script: | ||||
|     - composer --prefer-source --dev install | ||||
							
								
								
									
										19
									
								
								vendor/doctrine/cache/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								vendor/doctrine/cache/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | ||||
| Copyright (c) 2006-2012 Doctrine Project | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of | ||||
| this software and associated documentation files (the "Software"), to deal in | ||||
| the Software without restriction, including without limitation the rights to | ||||
| use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies | ||||
| of the Software, and to permit persons to whom the Software is furnished to do | ||||
| so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
							
								
								
									
										9
									
								
								vendor/doctrine/cache/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								vendor/doctrine/cache/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| # Doctrine Cache | ||||
|  | ||||
| Cache component extracted from the Doctrine Common project. | ||||
|  | ||||
| ## Changelog | ||||
|  | ||||
| ### v1.1 | ||||
|  | ||||
| * Added support for MongoDB as Cache Provider | ||||
							
								
								
									
										29
									
								
								vendor/doctrine/cache/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/doctrine/cache/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| { | ||||
|     "name": "doctrine/cache", | ||||
|     "type": "library", | ||||
|     "description": "Caching library offering an object-oriented API for many cache backends", | ||||
|     "keywords": ["cache", "caching"], | ||||
|     "homepage": "http://www.doctrine-project.org", | ||||
|     "license": "MIT", | ||||
|     "authors": [ | ||||
|         {"name": "Guilherme Blanco", "email": "guilhermeblanco@gmail.com"}, | ||||
|         {"name": "Roman Borschel", "email": "roman@code-factory.org"}, | ||||
|         {"name": "Benjamin Eberlei", "email": "kontakt@beberlei.de"}, | ||||
|         {"name": "Jonathan Wage", "email": "jonwage@gmail.com"}, | ||||
|         {"name": "Johannes Schmitt", "email": "schmittjoh@gmail.com"} | ||||
|     ], | ||||
|     "require": { | ||||
|         "php": ">=5.3.2" | ||||
|     }, | ||||
|     "conflict": { | ||||
|         "doctrine/common": ">2.2,<2.4" | ||||
|     }, | ||||
|     "autoload": { | ||||
|         "psr-0": { "Doctrine\\Common\\Cache\\": "lib/" } | ||||
|     }, | ||||
|     "extra": { | ||||
|         "branch-alias": { | ||||
|             "dev-master": "1.0.x-dev" | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										91
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/ApcCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * APC cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author David Abdemoulaie <dave@hobodave.com> | ||||
|  */ | ||||
| class ApcCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return apc_fetch($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return apc_exists($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         return (bool) apc_store($id, $data, (int) $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return apc_delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         return apc_clear_cache() && apc_clear_cache('user'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $info = apc_cache_info(); | ||||
|         $sma  = apc_sma_info(); | ||||
|  | ||||
|         return array( | ||||
|             Cache::STATS_HITS             => $info['num_hits'], | ||||
|             Cache::STATS_MISSES           => $info['num_misses'], | ||||
|             Cache::STATS_UPTIME           => $info['start_time'], | ||||
|             Cache::STATS_MEMORY_USAGE     => $info['mem_size'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE => $sma['avail_mem'], | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										93
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/ArrayCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/ArrayCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,93 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Array cache driver. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author David Abdemoulaie <dave@hobodave.com> | ||||
|  */ | ||||
| class ArrayCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * @var array $data | ||||
|      */ | ||||
|     private $data = array(); | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return (isset($this->data[$id])) ? $this->data[$id] : false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return isset($this->data[$id]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         $this->data[$id] = $data; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         unset($this->data[$id]); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         $this->data = array(); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										111
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/Cache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/Cache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Interface for cache drivers. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  */ | ||||
| interface Cache | ||||
| { | ||||
|     const STATS_HITS             = 'hits'; | ||||
|     const STATS_MISSES           = 'misses'; | ||||
|     const STATS_UPTIME           = 'uptime'; | ||||
|     const STATS_MEMORY_USAGE     = 'memory_usage'; | ||||
|     const STATS_MEMORY_AVAILABLE = 'memory_available'; | ||||
|     /** | ||||
|      * Only for backward compatibility (may be removed in next major release) | ||||
|      * | ||||
|      * @deprecated | ||||
|      */ | ||||
|     const STATS_MEMORY_AVAILIABLE = 'memory_available'; | ||||
|  | ||||
|     /** | ||||
|      * Fetches an entry from the cache. | ||||
|      * | ||||
|      * @param string $id The id of the cache entry to fetch. | ||||
|      * | ||||
|      * @return mixed The cached data or FALSE, if no cache entry exists for the given id. | ||||
|      */ | ||||
|     function fetch($id); | ||||
|  | ||||
|     /** | ||||
|      * Tests if an entry exists in the cache. | ||||
|      * | ||||
|      * @param string $id The cache id of the entry to check for. | ||||
|      * | ||||
|      * @return boolean TRUE if a cache entry exists for the given cache id, FALSE otherwise. | ||||
|      */ | ||||
|     function contains($id); | ||||
|  | ||||
|     /** | ||||
|      * Puts data into the cache. | ||||
|      * | ||||
|      * @param string $id       The cache id. | ||||
|      * @param mixed  $data     The cache entry/data. | ||||
|      * @param int    $lifeTime The cache lifetime. | ||||
|      *                         If != 0, sets a specific lifetime for this cache entry (0 => infinite lifeTime). | ||||
|      * | ||||
|      * @return boolean TRUE if the entry was successfully stored in the cache, FALSE otherwise. | ||||
|      */ | ||||
|     function save($id, $data, $lifeTime = 0); | ||||
|  | ||||
|     /** | ||||
|      * Deletes a cache entry. | ||||
|      * | ||||
|      * @param string $id The cache id. | ||||
|      * | ||||
|      * @return boolean TRUE if the cache entry was successfully deleted, FALSE otherwise. | ||||
|      */ | ||||
|     function delete($id); | ||||
|  | ||||
|     /** | ||||
|      * Retrieves cached information from the data store. | ||||
|      * | ||||
|      * The server's statistics array has the following values: | ||||
|      * | ||||
|      * - <b>hits</b> | ||||
|      * Number of keys that have been requested and found present. | ||||
|      * | ||||
|      * - <b>misses</b> | ||||
|      * Number of items that have been requested and not found. | ||||
|      * | ||||
|      * - <b>uptime</b> | ||||
|      * Time that the server is running. | ||||
|      * | ||||
|      * - <b>memory_usage</b> | ||||
|      * Memory used by this server to store items. | ||||
|      * | ||||
|      * - <b>memory_available</b> | ||||
|      * Memory allowed to use for storage. | ||||
|      * | ||||
|      * @since 2.2 | ||||
|      * | ||||
|      * @return array|null An associative array with server's statistics if available, NULL otherwise. | ||||
|      */ | ||||
|     function getStats(); | ||||
| } | ||||
							
								
								
									
										240
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										240
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/CacheProvider.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,240 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Base class for cache provider implementations. | ||||
|  * | ||||
|  * @since  2.2 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  */ | ||||
| abstract class CacheProvider implements Cache | ||||
| { | ||||
|     const DOCTRINE_NAMESPACE_CACHEKEY = 'DoctrineNamespaceCacheKey[%s]'; | ||||
|  | ||||
|     /** | ||||
|      * The namespace to prefix all cache ids with. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $namespace = ''; | ||||
|  | ||||
|     /** | ||||
|      * The namespace version. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $namespaceVersion; | ||||
|  | ||||
|     /** | ||||
|      * Sets the namespace to prefix all cache ids with. | ||||
|      * | ||||
|      * @param string $namespace | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setNamespace($namespace) | ||||
|     { | ||||
|         $this->namespace = (string) $namespace; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Retrieves the namespace that prefixes all cache ids. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getNamespace() | ||||
|     { | ||||
|         return $this->namespace; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($id) | ||||
|     { | ||||
|         return $this->doFetch($this->getNamespacedId($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function contains($id) | ||||
|     { | ||||
|         return $this->doContains($this->getNamespacedId($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function save($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         return $this->doSave($this->getNamespacedId($id), $data, $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function delete($id) | ||||
|     { | ||||
|         return $this->doDelete($this->getNamespacedId($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getStats() | ||||
|     { | ||||
|         return $this->doGetStats(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Flushes all cache entries. | ||||
|      * | ||||
|      * @return boolean TRUE if the cache entries were successfully flushed, FALSE otherwise. | ||||
|      */ | ||||
|     public function flushAll() | ||||
|     { | ||||
|         return $this->doFlush(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Deletes all cache entries. | ||||
|      * | ||||
|      * @return boolean TRUE if the cache entries were successfully deleted, FALSE otherwise. | ||||
|      */ | ||||
|     public function deleteAll() | ||||
|     { | ||||
|         $namespaceCacheKey = $this->getNamespaceCacheKey(); | ||||
|         $namespaceVersion  = $this->getNamespaceVersion() + 1; | ||||
|  | ||||
|         $this->namespaceVersion = $namespaceVersion; | ||||
|  | ||||
|         return $this->doSave($namespaceCacheKey, $namespaceVersion); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Prefixes the passed id with the configured namespace value. | ||||
|      * | ||||
|      * @param string $id The id to namespace. | ||||
|      * | ||||
|      * @return string The namespaced id. | ||||
|      */ | ||||
|     private function getNamespacedId($id) | ||||
|     { | ||||
|         $namespaceVersion  = $this->getNamespaceVersion(); | ||||
|  | ||||
|         return sprintf('%s[%s][%s]', $this->namespace, $id, $namespaceVersion); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the namespace cache key. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private function getNamespaceCacheKey() | ||||
|     { | ||||
|         return sprintf(self::DOCTRINE_NAMESPACE_CACHEKEY, $this->namespace); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the namespace version. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private function getNamespaceVersion() | ||||
|     { | ||||
|         if (null !== $this->namespaceVersion) { | ||||
|             return $this->namespaceVersion; | ||||
|         } | ||||
|  | ||||
|         $namespaceCacheKey = $this->getNamespaceCacheKey(); | ||||
|         $namespaceVersion = $this->doFetch($namespaceCacheKey); | ||||
|  | ||||
|         if (false === $namespaceVersion) { | ||||
|             $namespaceVersion = 1; | ||||
|  | ||||
|             $this->doSave($namespaceCacheKey, $namespaceVersion); | ||||
|         } | ||||
|  | ||||
|         $this->namespaceVersion = $namespaceVersion; | ||||
|  | ||||
|         return $this->namespaceVersion; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Fetches an entry from the cache. | ||||
|      * | ||||
|      * @param string $id The id of the cache entry to fetch. | ||||
|      * | ||||
|      * @return string|bool The cached data or FALSE, if no cache entry exists for the given id. | ||||
|      */ | ||||
|     abstract protected function doFetch($id); | ||||
|  | ||||
|     /** | ||||
|      * Tests if an entry exists in the cache. | ||||
|      * | ||||
|      * @param string $id The cache id of the entry to check for. | ||||
|      * | ||||
|      * @return boolean TRUE if a cache entry exists for the given cache id, FALSE otherwise. | ||||
|      */ | ||||
|     abstract protected function doContains($id); | ||||
|  | ||||
|     /** | ||||
|      * Puts data into the cache. | ||||
|      * | ||||
|      * @param string $id       The cache id. | ||||
|      * @param string $data     The cache entry/data. | ||||
|      * @param int    $lifeTime The lifetime. If != 0, sets a specific lifetime for this | ||||
|      *                           cache entry (0 => infinite lifeTime). | ||||
|      * | ||||
|      * @return boolean TRUE if the entry was successfully stored in the cache, FALSE otherwise. | ||||
|      */ | ||||
|     abstract protected function doSave($id, $data, $lifeTime = 0); | ||||
|  | ||||
|     /** | ||||
|      * Deletes a cache entry. | ||||
|      * | ||||
|      * @param string $id The cache id. | ||||
|      * | ||||
|      * @return boolean TRUE if the cache entry was successfully deleted, FALSE otherwise. | ||||
|      */ | ||||
|     abstract protected function doDelete($id); | ||||
|  | ||||
|     /** | ||||
|      * Flushes all cache entries. | ||||
|      * | ||||
|      * @return boolean TRUE if the cache entry was successfully deleted, FALSE otherwise. | ||||
|      */ | ||||
|     abstract protected function doFlush(); | ||||
|  | ||||
|     /** | ||||
|      * Retrieves cached information from the data store. | ||||
|      * | ||||
|      * @since 2.2 | ||||
|      * | ||||
|      * @return array|null An associative array with server's statistics if available, NULL otherwise. | ||||
|      */ | ||||
|     abstract protected function doGetStats(); | ||||
| } | ||||
							
								
								
									
										121
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/CouchbaseCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,121 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| use \Couchbase; | ||||
|  | ||||
| /** | ||||
|  * Couchbase cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.4 | ||||
|  * @author Michael Nitschinger <michael@nitschinger.at> | ||||
|  */ | ||||
| class CouchbaseCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * @var Couchbase|null | ||||
|      */ | ||||
|     private $couchbase; | ||||
|  | ||||
|     /** | ||||
|      * Sets the Couchbase instance to use. | ||||
|      * | ||||
|      * @param Couchbase $couchbase | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setCouchbase(Couchbase $couchbase) | ||||
|     { | ||||
|         $this->couchbase = $couchbase; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the Couchbase instance used by the cache. | ||||
|      * | ||||
|      * @return Couchbase|null | ||||
|      */ | ||||
|     public function getCouchbase() | ||||
|     { | ||||
|         return $this->couchbase; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return $this->couchbase->get($id) ?: false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return (null !== $this->couchbase->get($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         if ($lifeTime > 30 * 24 * 3600) { | ||||
|             $lifeTime = time() + $lifeTime; | ||||
|         } | ||||
|         return $this->couchbase->set($id, $data, (int) $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return $this->couchbase->delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         return $this->couchbase->flush(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $stats   = $this->couchbase->getStats(); | ||||
|         $servers = $this->couchbase->getServers(); | ||||
|         $server  = explode(":", $servers[0]); | ||||
|         $key     = $server[0] . ":" . "11210"; | ||||
|         $stats   = $stats[$key]; | ||||
|         return array( | ||||
|             Cache::STATS_HITS   => $stats['get_hits'], | ||||
|             Cache::STATS_MISSES => $stats['get_misses'], | ||||
|             Cache::STATS_UPTIME => $stats['uptime'], | ||||
|             Cache::STATS_MEMORY_USAGE     => $stats['bytes'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'], | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										158
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/FileCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/FileCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Base file cache driver. | ||||
|  * | ||||
|  * @since  2.3 | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  */ | ||||
| abstract class FileCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * The cache directory. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $directory; | ||||
|  | ||||
|     /** | ||||
|      * The cache file extension. | ||||
|      * | ||||
|      * @var string|null | ||||
|      */ | ||||
|     protected $extension; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param string      $directory The cache directory. | ||||
|      * @param string|null $extension The cache file extension. | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function __construct($directory, $extension = null) | ||||
|     { | ||||
|         if ( ! is_dir($directory) && ! @mkdir($directory, 0777, true)) { | ||||
|             throw new \InvalidArgumentException(sprintf( | ||||
|                 'The directory "%s" does not exist and could not be created.', | ||||
|                 $directory | ||||
|             )); | ||||
|         } | ||||
|  | ||||
|         if ( ! is_writable($directory)) { | ||||
|             throw new \InvalidArgumentException(sprintf( | ||||
|                 'The directory "%s" is not writable.', | ||||
|                 $directory | ||||
|             )); | ||||
|         } | ||||
|  | ||||
|         $this->directory = realpath($directory); | ||||
|         $this->extension = $extension ?: $this->extension; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the cache directory. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getDirectory() | ||||
|     { | ||||
|         return $this->directory; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the cache file extension. | ||||
|      * | ||||
|      * @return string|null | ||||
|      */ | ||||
|     public function getExtension() | ||||
|     { | ||||
|         return $this->extension; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $id | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     protected function getFilename($id) | ||||
|     { | ||||
|         $hash = hash('sha256', $id); | ||||
|         $path = implode(str_split($hash, 16), DIRECTORY_SEPARATOR); | ||||
|         $path = $this->directory . DIRECTORY_SEPARATOR . $path; | ||||
|         $id   = preg_replace('@[\\\/:"*?<>|]+@', '', $id); | ||||
|  | ||||
|         return $path . DIRECTORY_SEPARATOR . $id . $this->extension; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return @unlink($this->getFilename($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         foreach ($this->getIterator() as $name => $file) { | ||||
|             @unlink($name); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $usage = 0; | ||||
|         foreach ($this->getIterator() as $name => $file) { | ||||
|             $usage += $file->getSize(); | ||||
|         } | ||||
|  | ||||
|         $free = disk_free_space($this->directory); | ||||
|  | ||||
|         return array( | ||||
|             Cache::STATS_HITS               => null, | ||||
|             Cache::STATS_MISSES             => null, | ||||
|             Cache::STATS_UPTIME             => null, | ||||
|             Cache::STATS_MEMORY_USAGE       => $usage, | ||||
|             Cache::STATS_MEMORY_AVAILABLE   => $free, | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Iterator | ||||
|      */ | ||||
|     private function getIterator() | ||||
|     { | ||||
|         $pattern = '/^.+\\' . $this->extension . '$/i'; | ||||
|         $iterator = new \RecursiveDirectoryIterator($this->directory); | ||||
|         $iterator = new \RecursiveIteratorIterator($iterator); | ||||
|         return new \RegexIterator($iterator, $pattern); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										113
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/FilesystemCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/FilesystemCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Filesystem cache driver. | ||||
|  * | ||||
|  * @since  2.3 | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  */ | ||||
| class FilesystemCache extends FileCache | ||||
| { | ||||
|     const EXTENSION = '.doctrinecache.data'; | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected $extension = self::EXTENSION; | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         $data     = ''; | ||||
|         $lifetime = -1; | ||||
|         $filename = $this->getFilename($id); | ||||
|  | ||||
|         if ( ! is_file($filename)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $resource = fopen($filename, "r"); | ||||
|  | ||||
|         if (false !== ($line = fgets($resource))) { | ||||
|             $lifetime = (integer) $line; | ||||
|         } | ||||
|  | ||||
|         if ($lifetime !== 0 && $lifetime < time()) { | ||||
|             fclose($resource); | ||||
|  | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         while (false !== ($line = fgets($resource))) { | ||||
|             $data .= $line; | ||||
|         } | ||||
|  | ||||
|         fclose($resource); | ||||
|  | ||||
|         return unserialize($data); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         $lifetime = -1; | ||||
|         $filename = $this->getFilename($id); | ||||
|  | ||||
|         if ( ! is_file($filename)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $resource = fopen($filename, "r"); | ||||
|  | ||||
|         if (false !== ($line = fgets($resource))) { | ||||
|             $lifetime = (integer) $line; | ||||
|         } | ||||
|  | ||||
|         fclose($resource); | ||||
|  | ||||
|         return $lifetime === 0 || $lifetime > time(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         if ($lifeTime > 0) { | ||||
|             $lifeTime = time() + $lifeTime; | ||||
|         } | ||||
|  | ||||
|         $data       = serialize($data); | ||||
|         $filename   = $this->getFilename($id); | ||||
|         $filepath   = pathinfo($filename, PATHINFO_DIRNAME); | ||||
|  | ||||
|         if ( ! is_dir($filepath)) { | ||||
|             mkdir($filepath, 0777, true); | ||||
|         } | ||||
|  | ||||
|         return file_put_contents($filename, $lifeTime . PHP_EOL . $data); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										121
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcacheCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcacheCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,121 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| use \Memcache; | ||||
|  | ||||
| /** | ||||
|  * Memcache cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author David Abdemoulaie <dave@hobodave.com> | ||||
|  */ | ||||
| class MemcacheCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * @var Memcache|null | ||||
|      */ | ||||
|     private $memcache; | ||||
|  | ||||
|     /** | ||||
|      * Sets the memcache instance to use. | ||||
|      * | ||||
|      * @param Memcache $memcache | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setMemcache(Memcache $memcache) | ||||
|     { | ||||
|         $this->memcache = $memcache; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the memcache instance used by the cache. | ||||
|      * | ||||
|      * @return Memcache|null | ||||
|      */ | ||||
|     public function getMemcache() | ||||
|     { | ||||
|         return $this->memcache; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return $this->memcache->get($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return (bool) $this->memcache->get($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         if ($lifeTime > 30 * 24 * 3600) { | ||||
|             $lifeTime = time() + $lifeTime; | ||||
|         } | ||||
|         return $this->memcache->set($id, $data, 0, (int) $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return $this->memcache->delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         return $this->memcache->flush(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $stats = $this->memcache->getStats(); | ||||
|         return array( | ||||
|             Cache::STATS_HITS   => $stats['get_hits'], | ||||
|             Cache::STATS_MISSES => $stats['get_misses'], | ||||
|             Cache::STATS_UPTIME => $stats['uptime'], | ||||
|             Cache::STATS_MEMORY_USAGE     => $stats['bytes'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'], | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										124
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcachedCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/MemcachedCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,124 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| use \Memcached; | ||||
|  | ||||
| /** | ||||
|  * Memcached cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author David Abdemoulaie <dave@hobodave.com> | ||||
|  */ | ||||
| class MemcachedCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * @var Memcached|null | ||||
|      */ | ||||
|     private $memcached; | ||||
|  | ||||
|     /** | ||||
|      * Sets the memcache instance to use. | ||||
|      * | ||||
|      * @param Memcached $memcached | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setMemcached(Memcached $memcached) | ||||
|     { | ||||
|         $this->memcached = $memcached; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the memcached instance used by the cache. | ||||
|      * | ||||
|      * @return Memcached|null | ||||
|      */ | ||||
|     public function getMemcached() | ||||
|     { | ||||
|         return $this->memcached; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return $this->memcached->get($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return (false !== $this->memcached->get($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         if ($lifeTime > 30 * 24 * 3600) { | ||||
|             $lifeTime = time() + $lifeTime; | ||||
|         } | ||||
|         return $this->memcached->set($id, $data, (int) $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return $this->memcached->delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         return $this->memcached->flush(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $stats   = $this->memcached->getStats(); | ||||
|         $servers = $this->memcached->getServerList(); | ||||
|         $key     = $servers[0]['host'] . ':' . $servers[0]['port']; | ||||
|         $stats   = $stats[$key]; | ||||
|         return array( | ||||
|             Cache::STATS_HITS   => $stats['get_hits'], | ||||
|             Cache::STATS_MISSES => $stats['get_misses'], | ||||
|             Cache::STATS_UPTIME => $stats['uptime'], | ||||
|             Cache::STATS_MEMORY_USAGE     => $stats['bytes'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE => $stats['limit_maxbytes'], | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										107
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/PhpFileCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/PhpFileCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Php file cache driver. | ||||
|  * | ||||
|  * @since  2.3 | ||||
|  * @author Fabio B. Silva <fabio.bat.silva@gmail.com> | ||||
|  */ | ||||
| class PhpFileCache extends FileCache | ||||
| { | ||||
|     const EXTENSION = '.doctrinecache.php'; | ||||
|  | ||||
|      /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected $extension = self::EXTENSION; | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         $filename = $this->getFilename($id); | ||||
|  | ||||
|         if ( ! is_file($filename)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $value = include $filename; | ||||
|  | ||||
|         if ($value['lifetime'] !== 0 && $value['lifetime'] < time()) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return $value['data']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         $filename = $this->getFilename($id); | ||||
|  | ||||
|         if ( ! is_file($filename)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $value = include $filename; | ||||
|  | ||||
|         return $value['lifetime'] === 0 || $value['lifetime'] > time(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         if ($lifeTime > 0) { | ||||
|             $lifeTime = time() + $lifeTime; | ||||
|         } | ||||
|  | ||||
|         if (is_object($data) && ! method_exists($data, '__set_state')) { | ||||
|             throw new \InvalidArgumentException( | ||||
|                 "Invalid argument given, PhpFileCache only allows objects that implement __set_state() " . | ||||
|                 "and fully support var_export(). You can use the FilesystemCache to save arbitrary object " . | ||||
|                 "graphs using serialize()/deserialize()." | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         $filename   = $this->getFilename($id); | ||||
|         $filepath   = pathinfo($filename, PATHINFO_DIRNAME); | ||||
|  | ||||
|         if ( ! is_dir($filepath)) { | ||||
|             mkdir($filepath, 0777, true); | ||||
|         } | ||||
|  | ||||
|         $value = array( | ||||
|             'lifetime'  => $lifeTime, | ||||
|             'data'      => $data | ||||
|         ); | ||||
|  | ||||
|         $value  = var_export($value, true); | ||||
|         $code   = sprintf('<?php return %s;', $value); | ||||
|  | ||||
|         return file_put_contents($filename, $code); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										130
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/RedisCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/RedisCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,130 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| use Redis; | ||||
|  | ||||
| /** | ||||
|  * Redis cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Osman Ungur <osmanungur@gmail.com> | ||||
|  */ | ||||
| class RedisCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * @var Redis|null | ||||
|      */ | ||||
|     private $redis; | ||||
|  | ||||
|     /** | ||||
|      * Sets the redis instance to use. | ||||
|      * | ||||
|      * @param Redis $redis | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setRedis(Redis $redis) | ||||
|     { | ||||
|         $redis->setOption(Redis::OPT_SERIALIZER, $this->getSerializerValue()); | ||||
|         $this->redis = $redis; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the redis instance used by the cache. | ||||
|      * | ||||
|      * @return Redis|null | ||||
|      */ | ||||
|     public function getRedis() | ||||
|     { | ||||
|         return $this->redis; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return $this->redis->get($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return $this->redis->exists($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         if ($lifeTime > 0) { | ||||
|             return $this->redis->setex($id, $lifeTime, $data); | ||||
|         } | ||||
|         return $this->redis->set($id, $data); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return $this->redis->delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         return $this->redis->flushDB(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $info = $this->redis->info(); | ||||
|         return array( | ||||
|             Cache::STATS_HITS   => false, | ||||
|             Cache::STATS_MISSES => false, | ||||
|             Cache::STATS_UPTIME => $info['uptime_in_seconds'], | ||||
|             Cache::STATS_MEMORY_USAGE      => $info['used_memory'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE  => false | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the serializer constant to use. If Redis is compiled with | ||||
|      * igbinary support, that is used. Otherwise the default PHP serializer is | ||||
|      * used. | ||||
|      * | ||||
|      * @return integer One of the Redis::SERIALIZER_* constants | ||||
|      */ | ||||
|     protected function getSerializerValue() | ||||
|     { | ||||
|         return defined('Redis::SERIALIZER_IGBINARY') ? Redis::SERIALIZER_IGBINARY : Redis::SERIALIZER_PHP; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										250
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/RiakCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										250
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/RiakCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,250 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| use Riak\Bucket; | ||||
| use Riak\Connection; | ||||
| use Riak\Input; | ||||
| use Riak\Exception; | ||||
| use Riak\Object; | ||||
|  | ||||
| /** | ||||
|  * Riak cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  1.1 | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  */ | ||||
| class RiakCache extends CacheProvider | ||||
| { | ||||
|     const EXPIRES_HEADER = 'X-Riak-Meta-Expires'; | ||||
|  | ||||
|     /** | ||||
|      * @var \Riak\Bucket | ||||
|      */ | ||||
|     private $bucket; | ||||
|  | ||||
|     /** | ||||
|      * Sets the riak bucket instance to use. | ||||
|      * | ||||
|      * @param \Riak\Bucket $bucket | ||||
|      */ | ||||
|     public function __construct(Bucket $bucket) | ||||
|     { | ||||
|         $this->bucket = $bucket; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         try { | ||||
|             $response = $this->bucket->get(urlencode($id)); | ||||
|  | ||||
|             // No objects found | ||||
|             if ( ! $response->hasObject()) { | ||||
|                 return false; | ||||
|             } | ||||
|  | ||||
|             // Check for attempted siblings | ||||
|             $object = ($response->hasSiblings()) | ||||
|                 ? $this->resolveConflict($id, $response->getVClock(), $response->getObjectList()) | ||||
|                 : $response->getFirstObject(); | ||||
|  | ||||
|             // Check for expired object | ||||
|             if ($this->isExpired($object)) { | ||||
|                 $this->bucket->delete($object); | ||||
|  | ||||
|                 return false; | ||||
|             } | ||||
|  | ||||
|             return unserialize($object->getContent()); | ||||
|         } catch (Exception\RiakException $e) { | ||||
|             // Covers: | ||||
|             // - Riak\ConnectionException | ||||
|             // - Riak\CommunicationException | ||||
|             // - Riak\UnexpectedResponseException | ||||
|             // - Riak\NotFoundException | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         try { | ||||
|             // We only need the HEAD, not the entire object | ||||
|             $input = new Input\GetInput(); | ||||
|  | ||||
|             $input->setReturnHead(true); | ||||
|  | ||||
|             $response = $this->bucket->get(urlencode($id), $input); | ||||
|  | ||||
|             // No objects found | ||||
|             if ( ! $response->hasObject()) { | ||||
|                 return false; | ||||
|             } | ||||
|  | ||||
|             $object = $response->getFirstObject(); | ||||
|  | ||||
|             // Check for expired object | ||||
|             if ($this->isExpired($object)) { | ||||
|                 $this->bucket->delete($object); | ||||
|  | ||||
|                 return false; | ||||
|             } | ||||
|  | ||||
|             return true; | ||||
|         } catch (Exception\RiakException $e) { | ||||
|             // Do nothing | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         try { | ||||
|             $object = new Object(urlencode($id)); | ||||
|  | ||||
|             $object->setContent(serialize($data)); | ||||
|  | ||||
|             if ($lifeTime > 0) { | ||||
|                 $object->addMetadata(self::EXPIRES_HEADER, (string) (time() + $lifeTime)); | ||||
|             } | ||||
|  | ||||
|             $this->bucket->put($object); | ||||
|  | ||||
|             return true; | ||||
|         } catch (Exception\RiakException $e) { | ||||
|             // Do nothing | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         try { | ||||
|             $this->bucket->delete(urlencode($id)); | ||||
|  | ||||
|             return true; | ||||
|         } catch (Exception\BadArgumentsException $e) { | ||||
|             // Key did not exist on cluster already | ||||
|         } catch (Exception\RiakException $e) { | ||||
|             // Covers: | ||||
|             // - Riak\Exception\ConnectionException | ||||
|             // - Riak\Exception\CommunicationException | ||||
|             // - Riak\Exception\UnexpectedResponseException | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         try { | ||||
|             $keyList = $this->bucket->getKeyList(); | ||||
|  | ||||
|             foreach ($keyList as $key) { | ||||
|                 $this->bucket->delete($key); | ||||
|             } | ||||
|  | ||||
|             return true; | ||||
|         } catch (Exception\RiakException $e) { | ||||
|             // Do nothing | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         // Only exposed through HTTP stats API, not Protocol Buffers API | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Check if a given Riak Object have expired. | ||||
|      * | ||||
|      * @param \Riak\Object $object | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     private function isExpired(Object $object) | ||||
|     { | ||||
|         $metadataMap = $object->getMetadataMap(); | ||||
|  | ||||
|         return isset($metadataMap[self::EXPIRES_HEADER]) | ||||
|             && $metadataMap[self::EXPIRES_HEADER] < time(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * On-read conflict resolution. Applied approach here is last write wins. | ||||
|      * Specific needs may override this method to apply alternate conflict resolutions. | ||||
|      * | ||||
|      * {@internal Riak does not attempt to resolve a write conflict, and store | ||||
|      * it as sibling of conflicted one. By following this approach, it is up to | ||||
|      * the next read to resolve the conflict. When this happens, your fetched | ||||
|      * object will have a list of siblings (read as a list of objects). | ||||
|      * In our specific case, we do not care about the intermediate ones since | ||||
|      * they are all the same read from storage, and we do apply a last sibling | ||||
|      * (last write) wins logic. | ||||
|      * If by any means our resolution generates another conflict, it'll up to | ||||
|      * next read to properly solve it.} | ||||
|      * | ||||
|      * @param string $id | ||||
|      * @param string $vClock | ||||
|      * @param array  $objectList | ||||
|      * | ||||
|      * @return \Riak\Object | ||||
|      */ | ||||
|     protected function resolveConflict($id, $vClock, array $objectList) | ||||
|     { | ||||
|         // Our approach here is last-write wins | ||||
|         $winner = $objectList[count($objectList)]; | ||||
|  | ||||
|         $putInput = new Input\PutInput(); | ||||
|         $putInput->setVClock($vClock); | ||||
|  | ||||
|         $mergedObject = new Object(urlencode($id)); | ||||
|         $mergedObject->setContent($winner->getContent()); | ||||
|  | ||||
|         $this->bucket->put($mergedObject, $putInput); | ||||
|  | ||||
|         return $mergedObject; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										91
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/WinCacheCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/WinCacheCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * WinCache cache provider. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author David Abdemoulaie <dave@hobodave.com> | ||||
|  */ | ||||
| class WinCacheCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return wincache_ucache_get($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return wincache_ucache_exists($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         return (bool) wincache_ucache_set($id, $data, (int) $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return wincache_ucache_delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         return wincache_ucache_clear(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $info    = wincache_ucache_info(); | ||||
|         $meminfo = wincache_ucache_meminfo(); | ||||
|  | ||||
|         return array( | ||||
|             Cache::STATS_HITS             => $info['total_hit_count'], | ||||
|             Cache::STATS_MISSES           => $info['total_miss_count'], | ||||
|             Cache::STATS_UPTIME           => $info['total_cache_uptime'], | ||||
|             Cache::STATS_MEMORY_USAGE     => $meminfo['memory_total'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE => $meminfo['memory_free'], | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										109
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/XcacheCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										109
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/XcacheCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,109 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Xcache cache driver. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @author David Abdemoulaie <dave@hobodave.com> | ||||
|  */ | ||||
| class XcacheCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return $this->doContains($id) ? unserialize(xcache_get($id)) : false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return xcache_isset($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         return xcache_set($id, serialize($data), (int) $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return xcache_unset($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         $this->checkAuthorization(); | ||||
|  | ||||
|         xcache_clear_cache(XC_TYPE_VAR, 0); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Checks that xcache.admin.enable_auth is Off. | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @throws \BadMethodCallException When xcache.admin.enable_auth is On. | ||||
|      */ | ||||
|     protected function checkAuthorization() | ||||
|     { | ||||
|         if (ini_get('xcache.admin.enable_auth')) { | ||||
|             throw new \BadMethodCallException('To use all features of \Doctrine\Common\Cache\XcacheCache, you must set "xcache.admin.enable_auth" to "Off" in your php.ini.'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         $this->checkAuthorization(); | ||||
|  | ||||
|         $info = xcache_info(XC_TYPE_VAR, 0); | ||||
|         return array( | ||||
|             Cache::STATS_HITS   => $info['hits'], | ||||
|             Cache::STATS_MISSES => $info['misses'], | ||||
|             Cache::STATS_UPTIME => null, | ||||
|             Cache::STATS_MEMORY_USAGE      => $info['size'], | ||||
|             Cache::STATS_MEMORY_AVAILABLE  => $info['avail'], | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										83
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/ZendDataCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								vendor/doctrine/cache/lib/Doctrine/Common/Cache/ZendDataCache.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * Zend Data Cache cache driver. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Ralph Schindler <ralph.schindler@zend.com> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  */ | ||||
| class ZendDataCache extends CacheProvider | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFetch($id) | ||||
|     { | ||||
|         return zend_shm_cache_fetch($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doContains($id) | ||||
|     { | ||||
|         return (false !== zend_shm_cache_fetch($id)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doSave($id, $data, $lifeTime = 0) | ||||
|     { | ||||
|         return zend_shm_cache_store($id, $data, $lifeTime); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doDelete($id) | ||||
|     { | ||||
|         return zend_shm_cache_delete($id); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doFlush() | ||||
|     { | ||||
|         $namespace = $this->getNamespace(); | ||||
|         if (empty($namespace)) { | ||||
|             return zend_shm_cache_clear(); | ||||
|         } | ||||
|         return zend_shm_cache_clear($namespace); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     protected function doGetStats() | ||||
|     { | ||||
|         return null; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/cache/phpunit.xml.dist
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/cache/phpunit.xml.dist
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
|  | ||||
| <phpunit backupGlobals="false" | ||||
|          backupStaticAttributes="false" | ||||
|          colors="true" | ||||
|          convertErrorsToExceptions="true" | ||||
|          convertNoticesToExceptions="true" | ||||
|          convertWarningsToExceptions="true" | ||||
|          processIsolation="false" | ||||
|          stopOnFailure="false" | ||||
|          syntaxCheck="false" | ||||
|          bootstrap="./tests/Doctrine/Tests/TestInit.php" | ||||
| > | ||||
|     <testsuites> | ||||
|         <testsuite name="Doctrine Cache Test Suite"> | ||||
|             <directory>./tests/Doctrine/</directory> | ||||
|         </testsuite> | ||||
|     </testsuites> | ||||
|  | ||||
|     <filter> | ||||
|         <whitelist> | ||||
|             <directory>./lib/Doctrine/</directory> | ||||
|         </whitelist> | ||||
|     </filter> | ||||
|      | ||||
|     <groups> | ||||
|         <exclude> | ||||
|             <group>performance</group> | ||||
|         </exclude> | ||||
|     </groups> | ||||
| </phpunit> | ||||
							
								
								
									
										20
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ApcCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ApcCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\ApcCache; | ||||
|  | ||||
| class ApcCacheTest extends CacheTest | ||||
| { | ||||
|     public function setUp() | ||||
|     { | ||||
|         if ( ! extension_loaded('apc') || false === @apc_cache_info()) { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of APC'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         return new ApcCache(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										21
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ArrayCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ArrayCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\ArrayCache; | ||||
|  | ||||
| class ArrayCacheTest extends CacheTest | ||||
| { | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         return new ArrayCache(); | ||||
|     } | ||||
|  | ||||
|     public function testGetStats() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $stats = $cache->getStats(); | ||||
|  | ||||
|         $this->assertNull($stats); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										103
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\Cache; | ||||
|  | ||||
| abstract class CacheTest extends \Doctrine\Tests\DoctrineTestCase | ||||
| { | ||||
|     public function testBasics() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|  | ||||
|         // Test save | ||||
|         $cache->save('test_key', 'testing this out'); | ||||
|  | ||||
|         // Test contains to test that save() worked | ||||
|         $this->assertTrue($cache->contains('test_key')); | ||||
|  | ||||
|         // Test fetch | ||||
|         $this->assertEquals('testing this out', $cache->fetch('test_key')); | ||||
|  | ||||
|         // Test delete | ||||
|         $cache->save('test_key2', 'test2'); | ||||
|         $cache->delete('test_key2'); | ||||
|         $this->assertFalse($cache->contains('test_key2')); | ||||
|     } | ||||
|  | ||||
|     public function testObjects() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|  | ||||
|         // Fetch/save test with objects (Is cache driver serializes/unserializes objects correctly ?) | ||||
|         $cache->save('test_object_key', new \ArrayObject()); | ||||
|         $this->assertTrue($cache->fetch('test_object_key') instanceof \ArrayObject); | ||||
|     } | ||||
|  | ||||
|     public function testDeleteAll() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('test_key1', '1'); | ||||
|         $cache->save('test_key2', '2'); | ||||
|         $cache->deleteAll(); | ||||
|  | ||||
|         $this->assertFalse($cache->contains('test_key1')); | ||||
|         $this->assertFalse($cache->contains('test_key2')); | ||||
|     } | ||||
|  | ||||
|     public function testFlushAll() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('test_key1', '1'); | ||||
|         $cache->save('test_key2', '2'); | ||||
|         $cache->flushAll(); | ||||
|  | ||||
|         $this->assertFalse($cache->contains('test_key1')); | ||||
|         $this->assertFalse($cache->contains('test_key2')); | ||||
|     } | ||||
|  | ||||
|     public function testNamespace() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->setNamespace('test_'); | ||||
|         $cache->save('key1', 'test'); | ||||
|  | ||||
|         $this->assertTrue($cache->contains('key1')); | ||||
|  | ||||
|         $cache->setNamespace('test2_'); | ||||
|  | ||||
|         $this->assertFalse($cache->contains('key1')); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @group DCOM-43 | ||||
|      */ | ||||
|     public function testGetStats() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $stats = $cache->getStats(); | ||||
|  | ||||
|         $this->assertArrayHasKey(Cache::STATS_HITS,   $stats); | ||||
|         $this->assertArrayHasKey(Cache::STATS_MISSES, $stats); | ||||
|         $this->assertArrayHasKey(Cache::STATS_UPTIME, $stats); | ||||
|         $this->assertArrayHasKey(Cache::STATS_MEMORY_USAGE, $stats); | ||||
|         $this->assertArrayHasKey(Cache::STATS_MEMORY_AVAILABLE, $stats); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Make sure that all supported caches return "false" instead of "null" to be compatible | ||||
|      * with ORM integration. | ||||
|      */ | ||||
|     public function testFalseOnFailedFetch() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $result = $cache->fetch('nonexistent_key'); | ||||
|         $this->assertFalse($result); | ||||
|         $this->assertNotNull($result); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\Common\Cache\CacheProvider | ||||
|      */ | ||||
|     abstract protected function _getCacheDriver(); | ||||
| } | ||||
							
								
								
									
										47
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CouchbaseCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/CouchbaseCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Couchbase; | ||||
| use Doctrine\Common\Cache\CouchbaseCache; | ||||
|  | ||||
| class CouchbaseCacheTest extends CacheTest | ||||
| { | ||||
|     private $couchbase; | ||||
|  | ||||
|     public function setUp() | ||||
|     { | ||||
|         if (extension_loaded('couchbase')) { | ||||
|             try { | ||||
|                 $this->couchbase = new Couchbase('127.0.0.1', 'Administrator', 'password', 'default'); | ||||
|             } catch(Exception $ex) { | ||||
|                  $this->markTestSkipped('Could not instantiate the Couchbase cache because of: ' . $ex);    | ||||
|             } | ||||
|         } else { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of the couchbase extension'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function testNoExpire()  | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('noexpire', 'value', 0); | ||||
|         sleep(1); | ||||
|         $this->assertTrue($cache->contains('noexpire'), 'Couchbase provider should support no-expire'); | ||||
|     } | ||||
|  | ||||
|     public function testLongLifetime() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('key', 'value', 30 * 24 * 3600 + 1); | ||||
|  | ||||
|         $this->assertTrue($cache->contains('key'), 'Couchbase provider should support TTL > 30 days'); | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         $driver = new CouchbaseCache(); | ||||
|         $driver->setCouchbase($this->couchbase); | ||||
|         return $driver; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										107
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/FileCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/FileCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| /** | ||||
|  * @group DCOM-101 | ||||
|  */ | ||||
| class FileCacheTest extends \Doctrine\Tests\DoctrineTestCase | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\Common\Cache\FileCache | ||||
|      */ | ||||
|     private $driver; | ||||
|  | ||||
|     protected function setUp() | ||||
|     { | ||||
|         $this->driver = $this->getMock( | ||||
|             'Doctrine\Common\Cache\FileCache', | ||||
|             array('doFetch', 'doContains', 'doSave'), | ||||
|             array(), '', false | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     public function getProviderFileName() | ||||
|     { | ||||
|          return array( | ||||
|             //The characters :\/<>"*?| are not valid in Windows filenames. | ||||
|             array('key:1', 'key1'), | ||||
|             array('key\2', 'key2'), | ||||
|             array('key/3', 'key3'), | ||||
|             array('key<4', 'key4'), | ||||
|             array('key>5', 'key5'), | ||||
|             array('key"6', 'key6'), | ||||
|             array('key*7', 'key7'), | ||||
|             array('key?8', 'key8'), | ||||
|             array('key|9', 'key9'), | ||||
|             array('key[0]','key[0]'), | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @dataProvider getProviderFileName | ||||
|      */ | ||||
|     public function testInvalidFilename($key, $expected) | ||||
|     { | ||||
|         $cache  = $this->driver; | ||||
|         $method = new \ReflectionMethod($cache, 'getFilename'); | ||||
|  | ||||
|         $method->setAccessible(true); | ||||
|  | ||||
|         $value  = $method->invoke($cache, $key); | ||||
|         $actual = pathinfo($value, PATHINFO_FILENAME); | ||||
|  | ||||
|         $this->assertEquals($expected, $actual); | ||||
|     } | ||||
|  | ||||
|     public function testFilenameCollision() | ||||
|     { | ||||
|         $data['key:0']  = 'key0'; | ||||
|         $data['key\0']  = 'key0'; | ||||
|         $data['key/0']  = 'key0'; | ||||
|         $data['key<0']  = 'key0'; | ||||
|         $data['key>0']  = 'key0'; | ||||
|         $data['key"0']  = 'key0'; | ||||
|         $data['key*0']  = 'key0'; | ||||
|         $data['key?0']  = 'key0'; | ||||
|         $data['key|0']  = 'key0'; | ||||
|  | ||||
|         $paths  = array(); | ||||
|         $cache  = $this->driver; | ||||
|         $method = new \ReflectionMethod($cache, 'getFilename'); | ||||
|  | ||||
|         $method->setAccessible(true); | ||||
|  | ||||
|         foreach ($data as $key => $expected) { | ||||
|             $path   = $method->invoke($cache, $key); | ||||
|             $actual = pathinfo($path, PATHINFO_FILENAME); | ||||
|  | ||||
|             $this->assertNotContains($path, $paths); | ||||
|             $this->assertEquals($expected, $actual); | ||||
|  | ||||
|             $paths[] = $path; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function testFilenameShouldCreateThePathWithFourSubDirectories() | ||||
|     { | ||||
|         $cache          = $this->driver; | ||||
|         $method         = new \ReflectionMethod($cache, 'getFilename'); | ||||
|         $key            = 'item-key'; | ||||
|         $expectedDir[]  = '84e0e2e893febb73'; | ||||
|         $expectedDir[]  = '7a0fee0c89d53f4b'; | ||||
|         $expectedDir[]  = 'b7fcb44c57cdf3d3'; | ||||
|         $expectedDir[]  = '2ce7363f5d597760'; | ||||
|         $expectedDir    = implode(DIRECTORY_SEPARATOR, $expectedDir); | ||||
|  | ||||
|         $method->setAccessible(true); | ||||
|  | ||||
|         $path       = $method->invoke($cache, $key); | ||||
|         $filename   = pathinfo($path, PATHINFO_FILENAME); | ||||
|         $dirname    = pathinfo($path, PATHINFO_DIRNAME); | ||||
|  | ||||
|         $this->assertEquals('item-key', $filename); | ||||
|         $this->assertEquals(DIRECTORY_SEPARATOR . $expectedDir, $dirname); | ||||
|         $this->assertEquals(DIRECTORY_SEPARATOR . $expectedDir . DIRECTORY_SEPARATOR . $key, $path); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										102
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/FilesystemCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/FilesystemCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\Cache; | ||||
| use Doctrine\Common\Cache\FilesystemCache; | ||||
|  | ||||
| /** | ||||
|  * @group DCOM-101 | ||||
|  */ | ||||
| class FilesystemCacheTest extends CacheTest | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\Common\Cache\FilesystemCache | ||||
|      */ | ||||
|     private $driver; | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         $dir = sys_get_temp_dir() . "/doctrine_cache_". uniqid(); | ||||
|         $this->assertFalse(is_dir($dir)); | ||||
|  | ||||
|         $this->driver = new FilesystemCache($dir); | ||||
|         $this->assertTrue(is_dir($dir)); | ||||
|  | ||||
|         return $this->driver; | ||||
|     } | ||||
|  | ||||
|     public function testLifetime() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|  | ||||
|         // Test save | ||||
|         $cache->save('test_key', 'testing this out', 10); | ||||
|  | ||||
|         // Test contains to test that save() worked | ||||
|         $this->assertTrue($cache->contains('test_key')); | ||||
|  | ||||
|         // Test fetch | ||||
|         $this->assertEquals('testing this out', $cache->fetch('test_key')); | ||||
|  | ||||
|         // access private methods | ||||
|         $getFilename        = new \ReflectionMethod($cache, 'getFilename'); | ||||
|         $getNamespacedId    = new \ReflectionMethod($cache, 'getNamespacedId'); | ||||
|  | ||||
|         $getFilename->setAccessible(true); | ||||
|         $getNamespacedId->setAccessible(true); | ||||
|  | ||||
|         $id         = $getNamespacedId->invoke($cache, 'test_key'); | ||||
|         $filename   = $getFilename->invoke($cache, $id); | ||||
|  | ||||
|         $data       = ''; | ||||
|         $lifetime   = 0; | ||||
|         $resource   = fopen($filename, "r"); | ||||
|  | ||||
|         if (false !== ($line = fgets($resource))) { | ||||
|             $lifetime = (integer) $line; | ||||
|         } | ||||
|  | ||||
|         while (false !== ($line = fgets($resource))) { | ||||
|             $data .= $line; | ||||
|         } | ||||
|  | ||||
|         $this->assertNotEquals(0, $lifetime, "previous lifetime could not be loaded"); | ||||
|  | ||||
|         // update lifetime | ||||
|         $lifetime = $lifetime - 20; | ||||
|         file_put_contents($filename, $lifetime . PHP_EOL . $data); | ||||
|  | ||||
|         // test expired data | ||||
|         $this->assertFalse($cache->contains('test_key')); | ||||
|         $this->assertFalse($cache->fetch('test_key')); | ||||
|     } | ||||
|  | ||||
|     public function testGetStats() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $stats = $cache->getStats(); | ||||
|  | ||||
|         $this->assertNull($stats[Cache::STATS_HITS]); | ||||
|         $this->assertNull($stats[Cache::STATS_MISSES]); | ||||
|         $this->assertNull($stats[Cache::STATS_UPTIME]); | ||||
|         $this->assertEquals(0, $stats[Cache::STATS_MEMORY_USAGE]); | ||||
|         $this->assertGreaterThan(0, $stats[Cache::STATS_MEMORY_AVAILABLE]); | ||||
|     } | ||||
|  | ||||
|     public function tearDown() | ||||
|     { | ||||
|         $dir        = $this->driver->getDirectory(); | ||||
|         $ext        = $this->driver->getExtension(); | ||||
|         $iterator   = new \RecursiveDirectoryIterator($dir); | ||||
|  | ||||
|         foreach (new \RecursiveIteratorIterator($iterator, \RecursiveIteratorIterator::CHILD_FIRST) as $file) { | ||||
|             if ($file->isFile()) { | ||||
|                 @unlink($file->getRealPath()); | ||||
|             } else { | ||||
|                 @rmdir($file->getRealPath()); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										45
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MemcacheCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MemcacheCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,45 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\MemcacheCache; | ||||
|  | ||||
| class MemcacheCacheTest extends CacheTest | ||||
| { | ||||
|     private $_memcache; | ||||
|  | ||||
|     public function setUp() | ||||
|     { | ||||
|         if (extension_loaded('memcache')) { | ||||
|             $this->_memcache = new \Memcache; | ||||
|             $ok = @$this->_memcache->connect('localhost', 11211); | ||||
|             if (!$ok) { | ||||
|                 $this->markTestSkipped('The ' . __CLASS__ .' requires the use of memcache'); | ||||
|             } | ||||
|         } else { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of memcache'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function testNoExpire() { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('noexpire', 'value', 0); | ||||
|         sleep(1); | ||||
|         $this->assertTrue($cache->contains('noexpire'), 'Memcache provider should support no-expire'); | ||||
|     } | ||||
|  | ||||
|     public function testLongLifetime() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('key', 'value', 30 * 24 * 3600 + 1); | ||||
|         $this->assertTrue($cache->contains('key'), 'Memcache provider should support TTL > 30 days'); | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         $driver = new MemcacheCache(); | ||||
|         $driver->setMemcache($this->_memcache); | ||||
|         return $driver; | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										48
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MemcachedCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/MemcachedCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\MemcachedCache; | ||||
|  | ||||
| class MemcachedCacheTest extends CacheTest | ||||
| { | ||||
|     private $memcached; | ||||
|  | ||||
|     public function setUp() | ||||
|     { | ||||
|         if (extension_loaded('memcached')) { | ||||
|             $this->memcached = new \Memcached(); | ||||
|             $this->memcached->setOption(\Memcached::OPT_COMPRESSION, false); | ||||
|             $this->memcached->addServer('127.0.0.1', 11211); | ||||
|  | ||||
|             $fh = @fsockopen('127.0.0.1', 11211); | ||||
|             if (!$fh) { | ||||
|                 $this->markTestSkipped('The ' . __CLASS__ .' requires the use of memcache'); | ||||
|             } | ||||
|         } else { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of memcache'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function testNoExpire() { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('noexpire', 'value', 0); | ||||
|         sleep(1); | ||||
|         $this->assertTrue($cache->contains('noexpire'), 'Memcache provider should support no-expire'); | ||||
|     } | ||||
|  | ||||
|     public function testLongLifetime() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $cache->save('key', 'value', 30 * 24 * 3600 + 1); | ||||
|  | ||||
|         $this->assertTrue($cache->contains('key'), 'Memcached provider should support TTL > 30 days'); | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         $driver = new MemcachedCache(); | ||||
|         $driver->setMemcached($this->memcached); | ||||
|         return $driver; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										154
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/PhpFileCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/PhpFileCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,154 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\Cache; | ||||
| use Doctrine\Common\Cache\PhpFileCache; | ||||
|  | ||||
| /** | ||||
|  * @group DCOM-101 | ||||
|  */ | ||||
| class PhpFileCacheTest extends CacheTest | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\Common\Cache\PhpFileCache | ||||
|      */ | ||||
|     private $driver; | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         $dir = sys_get_temp_dir() . "/doctrine_cache_". uniqid(); | ||||
|         $this->assertFalse(is_dir($dir)); | ||||
|  | ||||
|         $this->driver = new PhpFileCache($dir); | ||||
|         $this->assertTrue(is_dir($dir)); | ||||
|  | ||||
|         return $this->driver; | ||||
|     } | ||||
|  | ||||
|     public function testObjects() | ||||
|     { | ||||
|         $this->markTestSkipped('PhpFileCache does not support saving objects that dont implement __set_state()'); | ||||
|     } | ||||
|  | ||||
|     public function testLifetime() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|  | ||||
|         // Test save | ||||
|         $cache->save('test_key', 'testing this out', 10); | ||||
|  | ||||
|         // Test contains to test that save() worked | ||||
|         $this->assertTrue($cache->contains('test_key')); | ||||
|  | ||||
|         // Test fetch | ||||
|         $this->assertEquals('testing this out', $cache->fetch('test_key')); | ||||
|  | ||||
|         // access private methods | ||||
|         $getFilename        = new \ReflectionMethod($cache, 'getFilename'); | ||||
|         $getNamespacedId    = new \ReflectionMethod($cache, 'getNamespacedId'); | ||||
|  | ||||
|         $getFilename->setAccessible(true); | ||||
|         $getNamespacedId->setAccessible(true); | ||||
|  | ||||
|         $id     = $getNamespacedId->invoke($cache, 'test_key'); | ||||
|         $path   = $getFilename->invoke($cache, $id); | ||||
|         $value  = include $path; | ||||
|  | ||||
|         // update lifetime | ||||
|         $value['lifetime'] = $value['lifetime'] - 20; | ||||
|         file_put_contents($path, '<?php return unserialize(' . var_export(serialize($value), true) . ');'); | ||||
|  | ||||
|         // test expired data | ||||
|         $this->assertFalse($cache->contains('test_key')); | ||||
|         $this->assertFalse($cache->fetch('test_key')); | ||||
|     } | ||||
|  | ||||
|     public function testImplementsSetState() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|  | ||||
|         // Test save | ||||
|         $cache->save('test_set_state', new SetStateClass(array(1,2,3))); | ||||
|  | ||||
|         //Test __set_state call | ||||
|         $this->assertCount(0, SetStateClass::$values); | ||||
|  | ||||
|         // Test fetch | ||||
|         $value = $cache->fetch('test_set_state'); | ||||
|         $this->assertInstanceOf('Doctrine\Tests\Common\Cache\SetStateClass', $value); | ||||
|         $this->assertEquals(array(1,2,3), $value->getValue()); | ||||
|  | ||||
|         //Test __set_state call | ||||
|         $this->assertCount(1, SetStateClass::$values); | ||||
|  | ||||
|         // Test contains | ||||
|         $this->assertTrue($cache->contains('test_set_state')); | ||||
|     } | ||||
|  | ||||
|     public function testNotImplementsSetState() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|  | ||||
|         $this->setExpectedException('InvalidArgumentException'); | ||||
|         $cache->save('test_not_set_state', new NotSetStateClass(array(1,2,3))); | ||||
|     } | ||||
|  | ||||
|     public function testGetStats() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $stats = $cache->getStats(); | ||||
|  | ||||
|         $this->assertNull($stats[Cache::STATS_HITS]); | ||||
|         $this->assertNull($stats[Cache::STATS_MISSES]); | ||||
|         $this->assertNull($stats[Cache::STATS_UPTIME]); | ||||
|         $this->assertEquals(0, $stats[Cache::STATS_MEMORY_USAGE]); | ||||
|         $this->assertGreaterThan(0, $stats[Cache::STATS_MEMORY_AVAILABLE]); | ||||
|     } | ||||
|  | ||||
|     public function tearDown() | ||||
|     { | ||||
|         if (!$this->driver) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         $dir        = $this->driver->getDirectory(); | ||||
|         $ext        = $this->driver->getExtension(); | ||||
|         $iterator   = new \RecursiveDirectoryIterator($dir); | ||||
|  | ||||
|         foreach (new \RecursiveIteratorIterator($iterator, \RecursiveIteratorIterator::CHILD_FIRST) as $file) { | ||||
|             if ($file->isFile()) { | ||||
|                 @unlink($file->getRealPath()); | ||||
|             } else { | ||||
|                 @rmdir($file->getRealPath()); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| class NotSetStateClass | ||||
| { | ||||
|     private $value; | ||||
|  | ||||
|     public function __construct($value) | ||||
|     { | ||||
|         $this->value = $value; | ||||
|     } | ||||
|  | ||||
|     public function getValue() | ||||
|     { | ||||
|         return $this->value; | ||||
|     } | ||||
| } | ||||
|  | ||||
| class SetStateClass extends NotSetStateClass | ||||
| { | ||||
|     public static $values = array(); | ||||
|  | ||||
|     public static function __set_state($data) | ||||
|     { | ||||
|         self::$values = $data; | ||||
|         return new self($data['value']); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										30
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/RedisCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/RedisCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\RedisCache; | ||||
|  | ||||
| class RedisCacheTest extends CacheTest | ||||
| { | ||||
|     private $_redis; | ||||
|  | ||||
|     public function setUp() | ||||
|     { | ||||
|         if (extension_loaded('redis')) { | ||||
|             $this->_redis = new \Redis(); | ||||
|             $ok = @$this->_redis->connect('127.0.0.1'); | ||||
|             if (!$ok) { | ||||
|                 $this->markTestSkipped('The ' . __CLASS__ .' requires the use of redis'); | ||||
|             } | ||||
|         } else { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of redis'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         $driver = new RedisCache(); | ||||
|         $driver->setRedis($this->_redis); | ||||
|         return $driver; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										64
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/RiakCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/RiakCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Riak\Bucket; | ||||
| use Riak\Connection; | ||||
| use Riak\Exception; | ||||
| use Doctrine\Common\Cache\RiakCache; | ||||
|  | ||||
| /** | ||||
|  * RiakCache test | ||||
|  * | ||||
|  * @group Riak | ||||
|  */ | ||||
| class RiakCacheTest extends CacheTest | ||||
| { | ||||
|     /** | ||||
|      * @var \Riak\Connection | ||||
|      */ | ||||
|     private $connection; | ||||
|  | ||||
|     /** | ||||
|      * @var \Riak\Bucket | ||||
|      */ | ||||
|     private $bucket; | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setUp() | ||||
|     { | ||||
|         if ( ! extension_loaded('riak')) { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of Riak'); | ||||
|         } | ||||
|  | ||||
|         try { | ||||
|             $this->connection = new Connection('127.0.0.1', 8087); | ||||
|             $this->bucket     = new Bucket($this->connection, 'test'); | ||||
|         } catch (Exception\RiakException $e) { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of Riak'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function testGetStats() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $stats = $cache->getStats(); | ||||
|  | ||||
|         $this->assertNull($stats); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Retrieve RiakCache instance. | ||||
|      * | ||||
|      * @return \Doctrine\Common\Cache\RiakCache | ||||
|      */ | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         return new RiakCache($this->bucket); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										20
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/WinCacheCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/WinCacheCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\WincacheCache; | ||||
|  | ||||
| class WincacheCacheTest extends CacheTest | ||||
| { | ||||
|     public function setUp() | ||||
|     { | ||||
|         if ( ! extension_loaded('wincache') || ! function_exists('wincache_ucache_info')) { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of Wincache'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         return new WincacheCache(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										20
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/XcacheCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/XcacheCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\XcacheCache; | ||||
|  | ||||
| class XcacheCacheTest extends CacheTest | ||||
| { | ||||
|     public function setUp() | ||||
|     { | ||||
|         if ( ! extension_loaded('xcache')) { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of xcache'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         return new XcacheCache(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										28
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ZendDataCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/Common/Cache/ZendDataCacheTest.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\ZendDataCache; | ||||
|  | ||||
| class ZendDataCacheTest extends CacheTest | ||||
| { | ||||
|     public function setUp() | ||||
|     { | ||||
|         if (!function_exists('zend_shm_cache_fetch') || (php_sapi_name() != 'apache2handler')) { | ||||
|             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of Zend Data Cache which only works in apache2handler SAPI'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function testGetStats() | ||||
|     { | ||||
|         $cache = $this->_getCacheDriver(); | ||||
|         $stats = $cache->getStats(); | ||||
|  | ||||
|         $this->assertNull($stats); | ||||
|     } | ||||
|  | ||||
|     protected function _getCacheDriver() | ||||
|     { | ||||
|         return new ZendDataCache(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										10
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/DoctrineTestCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/DoctrineTestCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests; | ||||
|  | ||||
| /** | ||||
|  * Base testcase class for all Doctrine testcases. | ||||
|  */ | ||||
| abstract class DoctrineTestCase extends \PHPUnit_Framework_TestCase | ||||
| { | ||||
| } | ||||
							
								
								
									
										23
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/TestInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								vendor/doctrine/cache/tests/Doctrine/Tests/TestInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | ||||
| <?php | ||||
| /* | ||||
|  * This file bootstraps the test environment. | ||||
|  */ | ||||
| namespace Doctrine\Tests; | ||||
|  | ||||
| error_reporting(E_ALL | E_STRICT); | ||||
|  | ||||
| // register silently failing autoloader | ||||
| spl_autoload_register(function($class) | ||||
| { | ||||
|     if (0 === strpos($class, 'Doctrine\Tests\\')) { | ||||
|         $path = __DIR__.'/../../'.strtr($class, '\\', '/').'.php'; | ||||
|         if (is_file($path) && is_readable($path)) { | ||||
|             require_once $path; | ||||
|  | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
| }); | ||||
|  | ||||
| require_once __DIR__ . "/../../../vendor/autoload.php"; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user