/usr/share/php/Horde/Cache/Storage/Hashtable.php is in php-horde-cache 2.5.4-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 | <?php
/**
* Copyright 2013-2016 Horde LLC (http://www.horde.org/)
*
* See the enclosed file COPYING for license information (LGPL). If you
* did not receive this file, see http://www.horde.org/licenses/lgpl21.
*
* @category Horde
* @copyright 2013-2016 Horde LLC
* @license http://www.horde.org/licenses/lgpl21 LGPL 2.1
* @package Cache
*/
/**
* Cache storage using the Horde_HashTable interface.
*
* @author Michael Slusarz <slusarz@horde.org>
* @category Horde
* @copyright 2013-2016 Horde LLC
* @license http://www.horde.org/licenses/lgpl21 LGPL 2.1
* @package Cache
* @since 2.2.0
*/
class Horde_Cache_Storage_Hashtable extends Horde_Cache_Storage_Base
{
/**
* HashTable object.
*
* @var Horde_HashTable
*/
protected $_hash;
/**
* @param array $params Additional parameters:
* <pre>
* - hashtable: (Horde_HashTable) [REQUIRED] A Horde_HashTable object.
* - prefix: (string) The prefix to use for the cache keys.
* DEFAULT: ''
* </pre>
*/
public function __construct(array $params = array())
{
if (!isset($params['hashtable'])) {
throw new InvalidArgumentException('Missing hashtable parameter.');
}
parent::__construct(array_merge(array(
'prefix' => ''
), $params));
}
/**
*/
protected function _initOb()
{
$this->_hash = $this->_params['hashtable'];
}
/**
*/
public function get($key, $lifetime = 0)
{
$dkey = $this->_getKey($key);
$query = array($dkey);
if ($lifetime) {
$query[] = $lkey = $this->_getKey($key, true);
}
$res = $this->_hash->get($query);
if ($lifetime &&
(!$res[$lkey] || (($lifetime + $res[$lkey]) < time()))) {
return false;
}
return $res[$dkey];
}
/**
*/
public function set($key, $data, $lifetime = 0)
{
$opts = array_filter(array(
'expire' => $lifetime
));
$this->_hash->set($this->_getKey($key), $data, $opts);
$this->_hash->set($this->_getKey($key, true), time(), $opts);
}
/**
*/
public function exists($key, $lifetime = 0)
{
return ($this->get($key, $lifetime) !== false);
}
/**
*/
public function expire($key)
{
$this->_hash->delete(array(
$this->_getKey($key),
$this->_getKey($key, true)
));
}
/**
*/
public function clear()
{
$this->_hash->clear();
}
/**
* Return the hashtable key.
*
* @param string $key Object ID.
* @param boolean $ts Return the timestamp key?
*
* @return string Hashtable key ID.
*/
protected function _getKey($key, $ts = false)
{
return $this->_params['prefix'] . $key . ($ts ? '_t' : '');
}
}
|