HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/cache/
Upload File :
Current File : /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/cache/XCacheCache.php
<?php

/**
 * @file classes/cache/XCacheCache.php
 *
 * Copyright (c) 2014-2021 Simon Fraser University
 * Copyright (c) 2000-2021 John Willinsky
 * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
 *
 * @class XCacheCache
 *
 * @ingroup cache
 *
 * @see GenericCache
 *
 * @brief Provides caching based on XCache's variable store.
 */

namespace PKP\cache;

class XCacheCache extends GenericCache
{
    /**
     * Flush the cache.
     */
    public function flush()
    {
        $prefix = INDEX_FILE_LOCATION . ':' . $this->getContext() . ':' . $this->getCacheId();
        if (function_exists('xcache_unset_by_prefix')) {
            // If possible, just flush the context
            xcache_unset_by_prefix(prefix);
        } else {
            // Otherwise, we need to do this manually
            for ($i = 0; $i < xcache_count(XC_TYPE_VAR); $i++) {
                $cache = xcache_list(XC_TYPE_VAR, $i);
                foreach ($cache['cache_list'] as $entry) {
                    if (substr($entry['name'], 0, strlen($prefix)) == $prefix) {
                        xcache_unset($entry['name']);
                    }
                }
            }
        }
    }

    /**
     * Get an object from the cache.
     *
     * @param string $id
     */
    public function getCache($id)
    {
        $key = INDEX_FILE_LOCATION . ':' . $this->getContext() . ':' . $this->getCacheId() . ':' . $id;
        if (!xcache_isset($key)) {
            return $this->cacheMiss;
        }
        $returner = unserialize(xcache_get($key));
        return $returner;
    }

    /**
     * Set an object in the cache. This function should be overridden
     * by subclasses.
     *
     * @param string $id
     */
    public function setCache($id, $value)
    {
        return (xcache_set(INDEX_FILE_LOCATION . ':' . $this->getContext() . ':' . $this->getCacheId() . ':' . $id, serialize($value)));
    }

    /**
     * Get the time at which the data was cached.
     * Not implemented in this type of cache.
     */
    public function getCacheTime()
    {
        return null;
    }

    /**
     * Set the entire contents of the cache.
     * WARNING: THIS DOES NOT FLUSH THE CACHE FIRST!
     */
    public function setEntireCache($contents)
    {
        foreach ($contents as $id => $value) {
            $this->setCache($id, $value);
        }
    }
}