Skip to content

A simple TypeScript caching library with ttl support and SQL-inspired syntax

License

Notifications You must be signed in to change notification settings

jamesbontempo/type-cache

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

typecache

Version Coverage License

typecache is a simple TypeScript caching library with ttl support and SQL-inspired syntax.

Install

npm install @jamesbontempo/typecache

Test

npm test

Usage

const { TypeCache } = require("@jamesbontempo/typecache");

const cache = new TypeCache();

cache.ttl = 15 * 60 * 1000; // 15 minutes
cache.on("delete", item => { console.log(item); });

cache.insert("key", "value");
cache.update("key", ["new value 1", "new value 2"]);

console.log(cache.keys()); // ["key"]
console.log(cache.select("key")); // ["new value 1", "new value 2"]
console.log(cache.exists("non-existent key")); // false

cache.delete("key"); // removes & emits "delete" event for the item w/a key of "key"
cache.clear(); // removes & emits delete events for any remaining items

Contents

Constructor

Creates a new TypeCache instance. By default, there is no ttl (actually, it's set to Infinity) & all items persist until deleted, or until the cache itself is cleared or destroyed.

Cache properties

count

The number of items in the cache.

ttl

The default ttl in milliseconds for items inserted into the cache. You can "get" or "set" this value. Values less than or equal to zero are ignored.

Cache methods

keys()

Returns an array of the cache keys.

clear()

Removes all items from the cache.

Cache item methods

insert(key, value [, ttl, force])

Inserts an item into the cache. If no ttl is provided the default cache-level ttl is used. If a ttl value less than or equal to zero is provided it's ignored. If an item already exists for the given key and force is true the item will effectively be overwritten (both its value and its ttl); otherwise, no changes will be made.

select(key)

Returns the value of the item with the given key.

exists(key)

Returns true if an item with the given key exists in the cache, false otherwise. This can be particularly helpful for determining if an item really exists since a call to select for a non-existent key will return undefined.

update(key, value)

Updates the value of the item in the cache.

remaining(key)

Returns the remaining ttl time for the item; that is, how much longer before the item is removed from the cache. If there is no ttl it will return Infinity.

extend(key [, ttl])

Extends the ttl of the item by a number of milliseconds. If no ttl is provided the default cache-level ttl is used (allowing you to basically "bump" the item). If a ttl of Infinity is provided, the ttl is effectively removed.

shorten(key, ttl)

Shortens the ttl of the item by a number of milliseconds. Values less than or equal to zero are ignored. If the current ttl is less than the value provided no changes are made because the item would be deleted before the shortened time anyway. If the current ttl is Infinity, the ttl is set to the value provided.

delete(key)

Deletes the item from the cache.

Cache events

The cache emits events when the insert, update, and delete methods are called. The events have the same corresponding names: insert, update, and delete. They emit objects with information about the related cache items:

{
    key: key name,
    value: key value,
    ttl: key ttl,
    added: when the key was added,
    modified: when the key value was last modified,
    deleted: when the key was deleted
}

insert

Emits information about the item inserted.

update

Emits information about an update to an item, including before and after objects allowing for comparison.

delete

Emits information about the item deleted; potentially useful for "listening" for ttl expirations.

This allows you to do things like:

cache.on("insert", item => { verify(item); });

cache.on("update", item => { compare(item.before, item.after); });

cache.on("delete", item => { log(item); });

About

A simple TypeScript caching library with ttl support and SQL-inspired syntax

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published