[ Index ]

PHP Cross Reference of WordPress Trunk (Updated Daily)

Search

title

Body

[close]

/wp-includes/SimplePie/src/Cache/ -> DataCache.php (source)

   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   * Subset of PSR-16 Cache client for caching data arrays
  51   *
  52   * Only get(), set() and delete() methods are used,
  53   * but not has(), getMultiple(), setMultiple() or deleteMultiple().
  54   *
  55   * The methods names must be different, but should be compatible to the
  56   * methods of \Psr\SimpleCache\CacheInterface.
  57   *
  58   * @package SimplePie
  59   * @subpackage Caching
  60   * @internal
  61   */
  62  interface DataCache
  63  {
  64      /**
  65       * Fetches a value from the cache.
  66       *
  67       * Equivalent to \Psr\SimpleCache\CacheInterface::get()
  68       * <code>
  69       * public function get(string $key, mixed $default = null): mixed;
  70       * </code>
  71       *
  72       * @param string   $key     The unique key of this item in the cache.
  73       * @param mixed    $default Default value to return if the key does not exist.
  74       *
  75       * @return array|mixed The value of the item from the cache, or $default in case of cache miss.
  76       *
  77       * @throws InvalidArgumentException
  78       *   MUST be thrown if the $key string is not a legal value.
  79       */
  80      public function get_data(string $key, $default = null);
  81  
  82      /**
  83       * Persists data in the cache, uniquely referenced by a key with an optional expiration TTL time.
  84       *
  85       * Equivalent to \Psr\SimpleCache\CacheInterface::set()
  86       * <code>
  87       * public function set(string $key, mixed $value, null|int|\DateInterval $ttl = null): bool;
  88       * </code>
  89       *
  90       * @param string   $key   The key of the item to store.
  91       * @param array    $value The value of the item to store, must be serializable.
  92       * @param null|int $ttl   Optional. The TTL value of this item. If no value is sent and
  93       *                                      the driver supports TTL then the library may set a default value
  94       *                                      for it or let the driver take care of that.
  95       *
  96       * @return bool True on success and false on failure.
  97       *
  98       * @throws InvalidArgumentException
  99       *   MUST be thrown if the $key string is not a legal value.
 100       */
 101      public function set_data(string $key, array $value, ?int $ttl = null): bool;
 102  
 103      /**
 104       * Delete an item from the cache by its unique key.
 105       *
 106       * Equivalent to \Psr\SimpleCache\CacheInterface::delete()
 107       * <code>
 108       * public function delete(string $key): bool;
 109       * </code>
 110       *
 111       * @param string $key The unique cache key of the item to delete.
 112       *
 113       * @return bool True if the item was successfully removed. False if there was an error.
 114       *
 115       * @throws InvalidArgumentException
 116       *   MUST be thrown if the $key string is not a legal value.
 117       */
 118      public function delete_data(string $key): bool;
 119  }


Generated : Thu Oct 24 08:20:01 2024 Cross-referenced by PHPXref