the whole shebang
This commit is contained in:
		
							
								
								
									
										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; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user