@koopjs/cache-memory
Version:
An in-memory cache for KOop
87 lines (69 loc) • 2.56 kB
Markdown
//raw.githubusercontent.com/koopjs/koop/master/packages/cache-memory/coverage.svg)
This is a LRU cache with ttl (time to live) expiry. It expects cache items to be GeoJSON feature collections. It is based on [quick-lru](https://github.com/sindresorhus/quick-lru).
Cache eviction occurs in two ways:
1. if the cache grows to a number of items greater than the cache's defined size, the least recently inserted or accessed item is evicted
2. if a item is accessed and it has gone past its ttl period, it is evicted
## Usage
### Stand-alone instantiation:
```js
const Cache = require('@koopjs/cache-memory');
const cache = new Cache({ size: 1000 });
```
This is the default cache for [Koop](https://github.com/koopjs/koop) so you won't need to instantiate it yourself. If you really wanted to, it would look like this:
```js
const Koop = require('koop')
const koop = new Koop()
const cache = require('@koopjs/cache-memory')
koop.register(cache, { size: 1000 })
```
`size`: the maximum number of items to store in the queue before evicting the least recently used item.
The cache is a JavaScript object that lives in-memory. It is used to store geojson features.
Insert geojson into the cache.
```js
const geojson = {
type: 'FeatureCollection',
features: [],
metadata: {
name: 'Example GeoJSON',
description: 'This is geojson that will be stored in the cache'
}
}
const options = {
ttl: 1000 // The TTL option is measured in seconds, it will be used to set the `maxAge` property in the LRU cache
}
cache.insert('key', geojson, options, err => {
// This function will call back with an error if one occurs
})
```
Retrieve a cached feature collection.
```js
const options = {
pick: [] // an array of keys used to return a subset of the feature collections root level properties
omit
}
cache.retrieve('key', options, (err, geojson) => {
/* This function will callback with an error or the data cached with the passed key. It will return undefined if not found or expired.
{
type: 'FeatureCollection',
features: [],
metadata: {}
}
*/
})
```
Remove a feature collection from the cache
```js
cache.delete('key', err => {
// This function will call back with an error if one occurs
})
```
[ ]: https://img.shields.io/npm/v/@koopjs/cache-memory.svg?style=flat-square
[ ]: https://www.npmjs.com/package/@koopjs/cache-memory
[![npm version][npm-img]][npm-url]
![coverage](https: