Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vectorface/vpci
A lightweight caching interface
https://github.com/vectorface/vpci
archived deprecated
Last synced: 3 months ago
JSON representation
A lightweight caching interface
- Host: GitHub
- URL: https://github.com/vectorface/vpci
- Owner: Vectorface
- Created: 2014-05-06T20:41:50.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2023-01-11T15:02:15.000Z (about 2 years ago)
- Last Synced: 2024-03-27T12:49:23.146Z (10 months ago)
- Topics: archived, deprecated
- Language: PHP
- Homepage:
- Size: 67.4 KB
- Stars: 5
- Watchers: 14
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# VPCI (Vectorface PHP Caching Interface) [![Build Status](https://secure.travis-ci.org/Vectorface/vpci.png?branch=master)](http://travis-ci.org/Vectorface/vpci)
*****Archived Project**
This project is no longer maintained.
***
VPCI is a lightweight, straight forward cache interface that employs a strategy pattern to allow users to use multiple types of cache with a single unified interface. It has optional built in write through caching to handle information retrieval with a simple, single function call.
Using VPCI allows developers to manage information retrieval and caching without having to worry about imlpementation.
***
## Contents
1. [Currently Supported Cache Types](#currently-supported-cache-types)
1. [Configurability](#configurability)
1. [Use](#use)
2. [Getting a Cache Object](#getting-a-cache-object)
2. [Get](#get)
3.[Write-Through](#write-through)
2. [Set](#set)
2. [Clean](#clean)
2. [Flush](#flush)
2. [Delete](#delete)
1. [Prefix](#prefix)***
## Currently Supported Cache Types:
* APC User Cache (for both PHP 5.4 and PHP 5.5)
* Memcache
* TempFileCache (A caching system that uses temporary files)***
[Top](#vpci-vectorface-php-caching-interface) - [Contents](#contents)
***## Configurability
VPCI comes with a easy to set-up configuration system. Its default behavior is to select the "best" (ordered as in the [Currently Supported](#currently-supported-cache-types) section) caching system. The retrieval of the cache is done with a singleton, meaning that you will not loose your reference to your cache once it has been created. Instead, simply call CacheSingleton::GetCache() whenever the reference is needed.
***
[Top](#vpci-vectorface-php-caching-interface) - [Contents](#contents)
***## Use
### Getting a Cache Object
VPCI has a singleton/factory that will chose the best available caching mechanism and return a cache object.
```php
$cache = CacheSingleton::getCache();
```VPCI is designed to run entirely on four commands: `get()`, `set()`, `clean()` and `flush()`.
### Get
The get function takes a single `$key` parameter. This is the key of the item in the cache. It returns the value stored with the given key.
```php
$key = "cache_item";
$cachedData = $cache->get(key);
```#### Write-Through
VPCI has an optional write-through cache feature built into the `use()` method. [Above](#get) ignores the write-through functionality, using VPCI as a standard caching interface. The `use()` method can actually take three parameters and is defined as `use($key, $callableArray = [], $ttl = -1)`. The parameters do the following:
1. `$key` - The key used to retrieve the cached item
1. `$callableArray` - An array with optional callable object("function") and argument array("args") that will be called if no item exists in the cache. The result will be returned
1. `$ttl` - The amount of time to store the item in the cache, if the callable is called. If this is not set, the result will be returned but not stored in the cache.```php
// Will return data if it is in the cache
// Otherwise it will return false
$cachedData = $cache->get("key");// Will return data if it is in the cache
// Otherwise will return result of callable
// Cache will not be updated
$cachedData = $cache->get("key", ["function" => "callable", "args" => []]);// Will return data if it is in the cache
// Otherwise will return result of callable
// The result of the callable will be stored in the cache with key = "key" and ttl=3600
$cachedData = $cache->get("key", ["function" => "callable", "args" => []], 3600);
```### Set
The set function is used to store data in the cache. It takes 3 parameters:
1. `$key` the key used to retrieve the cached item later
1. `$data` the data to be stored in the cache
1. `$ttl` the time to live of the cache item (the amount of time that the item should remain valid)```php
$key = "cache_item";
$data = "This will be stored in the cache"
$ttl = 3600 //This cache item will expire in one hour
$cache->set($key, $data, $ttl);
```### Clean
The clean function is used to clear any expired items out of the cache. Note that for many caching implementations this might not be necessary. Some cache implementations such as APC and Memcache clean themselves automatically.
$cache->clean();
### Flush
The flush function deletes all items in the cache.
$cache->flush();
### Delete
The delete function takes an array of keys. It will delete any item from the cache who's key is in the array.
$cache->delete(["oneKey", "anotherKey", "aThirdKey"]);
***
[Top](#vpci-vectorface-php-caching-interface) - [Contents](#contents)
***## Prefix
VPCI allows its users to define a cache prefix to use on every cache entry. This feature allows to create unique keys that will (hopefully) not conflict with any other process sharing the same cache.
The prefix can be setup in one of two ways. Either by modifying the program's [configuration](#configurability) or by calling a `setPrefix($prefix)` method.
*NOTE:* Prefixes set with the `setPrefix($prefix)` method are volatile, meaning they are not retained after the program terminates.
#### Prefix Example
If you set the prefix variable to `"vpci"`, for example:
```json
{
"cachePrefix": "vpci"
}
```If you then set a cached item:
```php
$key = "key";
$data = "example data";
$ttl = 3600;$cache->set($key, $data, $ttl);
```
This item would be stored within the cache with a key of `"vpci_key"`. However, to retrieve it with the prefix still set, you would simply call:```php
$data = $cache->get("key");
```***
[Top](#vpci-vectorface-php-caching-interface) - [Contents](#contents)
***