[ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 <?php 2 3 /** 4 * SimplePie 5 * 6 * A PHP-Based RSS and Atom Feed Framework. 7 * Takes the hard work out of managing a complete RSS/Atom solution. 8 * 9 * Copyright (c) 2004-2022, Ryan Parman, Sam Sneddon, Ryan McCue, and contributors 10 * All rights reserved. 11 * 12 * Redistribution and use in source and binary forms, with or without modification, are 13 * permitted provided that the following conditions are met: 14 * 15 * * Redistributions of source code must retain the above copyright notice, this list of 16 * conditions and the following disclaimer. 17 * 18 * * Redistributions in binary form must reproduce the above copyright notice, this list 19 * of conditions and the following disclaimer in the documentation and/or other materials 20 * provided with the distribution. 21 * 22 * * Neither the name of the SimplePie Team nor the names of its contributors may be used 23 * to endorse or promote products derived from this software without specific prior 24 * written permission. 25 * 26 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS 27 * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY 28 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS 29 * AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 31 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 32 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 33 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 34 * POSSIBILITY OF SUCH DAMAGE. 35 * 36 * @package SimplePie 37 * @copyright 2004-2022 Ryan Parman, Sam Sneddon, Ryan McCue 38 * @author Ryan Parman 39 * @author Sam Sneddon 40 * @author Ryan McCue 41 * @link http://simplepie.org/ SimplePie 42 * @license http://www.opensource.org/licenses/bsd-license.php BSD License 43 */ 44 45 namespace SimplePie\Cache; 46 47 use InvalidArgumentException; 48 49 /** 50 * Adapter for deprecated \SimplePie\Cache\Base implementations 51 * 52 * @package SimplePie 53 * @subpackage Caching 54 * @internal 55 */ 56 final class BaseDataCache implements DataCache 57 { 58 /** 59 * @var Base 60 */ 61 private $cache; 62 63 public function __construct(Base $cache) 64 { 65 $this->cache = $cache; 66 } 67 68 /** 69 * Fetches a value from the cache. 70 * 71 * Equivalent to \Psr\SimpleCache\CacheInterface::get() 72 * <code> 73 * public function get(string $key, mixed $default = null): mixed; 74 * </code> 75 * 76 * @param string $key The unique key of this item in the cache. 77 * @param mixed $default Default value to return if the key does not exist. 78 * 79 * @return array|mixed The value of the item from the cache, or $default in case of cache miss. 80 * 81 * @throws InvalidArgumentException 82 * MUST be thrown if the $key string is not a legal value. 83 */ 84 public function get_data(string $key, $default = null) 85 { 86 $data = $this->cache->load(); 87 88 if (!is_array($data)) { 89 return $default; 90 } 91 92 // ignore data if internal cache expiration time is not set 93 if (!array_key_exists('__cache_expiration_time', $data)) { 94 return $default; 95 } 96 97 // ignore data if internal cache expiration time is expired 98 if ($data['__cache_expiration_time'] < time()) { 99 return $default; 100 } 101 102 // remove internal cache expiration time 103 unset($data['__cache_expiration_time']); 104 105 return $data; 106 } 107 108 /** 109 * Persists data in the cache, uniquely referenced by a key with an optional expiration TTL time. 110 * 111 * Equivalent to \Psr\SimpleCache\CacheInterface::set() 112 * <code> 113 * public function set(string $key, mixed $value, null|int|\DateInterval $ttl = null): bool; 114 * </code> 115 * 116 * @param string $key The key of the item to store. 117 * @param array $value The value of the item to store, must be serializable. 118 * @param null|int $ttl Optional. The TTL value of this item. If no value is sent and 119 * the driver supports TTL then the library may set a default value 120 * for it or let the driver take care of that. 121 * 122 * @return bool True on success and false on failure. 123 * 124 * @throws InvalidArgumentException 125 * MUST be thrown if the $key string is not a legal value. 126 */ 127 public function set_data(string $key, array $value, ?int $ttl = null): bool 128 { 129 if ($ttl === null) { 130 $ttl = 3600; 131 } 132 133 // place internal cache expiration time 134 $value['__cache_expiration_time'] = time() + $ttl; 135 136 return $this->cache->save($value); 137 } 138 139 /** 140 * Delete an item from the cache by its unique key. 141 * 142 * Equivalent to \Psr\SimpleCache\CacheInterface::delete() 143 * <code> 144 * public function delete(string $key): bool; 145 * </code> 146 * 147 * @param string $key The unique cache key of the item to delete. 148 * 149 * @return bool True if the item was successfully removed. False if there was an error. 150 * 151 * @throws InvalidArgumentException 152 * MUST be thrown if the $key string is not a legal value. 153 */ 154 public function delete_data(string $key): bool 155 { 156 return $this->cache->unlink(); 157 } 158 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated : Sat Dec 21 08:20:01 2024 | Cross-referenced by PHPXref |