node-cache-plus
is a wrapper around the popular library node-cache
with additional features such as tag-based invalidation, factory functions, and other helpers for in-memory caching in Node.js applications.
Sorry 🦖, this is an ESM-only package.
To install node-cache-plus
, use your preferred package manager:
npm install node-cache-plus
node-cache-plus
is a drop-in replacement for node-cache
. It provides the same API as node-cache
with additional features. Refer to the node-cache
documentation for more information on the basic usage and initialisation options.
TypeDoc reference is available here.
import { Cache } from "node-cache-plus";
const cache = new Cache();
// Set a value with a TTL of 60 seconds
cache.set("key", "value", 60);
// Get the value
const value = cache.get("key");
console.log(value); // Output: "value"
// Delete the value
cache.del("key");
invalidateTag
method invalidates all keys with a specific tag.
// Set values with tags
cache.set("key1", "value1", 60, ["tag1"]);
cache.set("key2", "value2", 60, ["tag2"]);
cache.set("key3", "value3", 60, ["tag1", "tag2"]);
// Invalidate all keys with a specific tag
cache.invalidateTag("tag1"); // i.e. Invalidates keys "key1" and "key3"
cache.get("key1"); // Output: undefined
cache.get("key2"); // Output: "value2"
cache.get("key3"); // Output: undefined
invalidateTagsIntersection
method invalidates keys that have all specified tags.
// Set values with tags
cache.set("key1", "value1", 60, ["tag1"]);
cache.set("key2", "value2", 60, ["tag2"]);
cache.set("key3", "value3", 60, ["tag1", "tag2"]);
// Invalidate keys that have all specified tags
cache.invalidateTagsIntersection(["tag1", "tag2"]); // i.e. Invalidates key "key3"
cache.get("key1"); // Output: "value1"
cache.get("key2"); // Output: "value2"
cache.get("key3"); // Output: undefined
invalidateTagsUnion
method invalidates keys that have at least one of the specified tags.
// Set values with tags
cache.set("key1", "value1", 60, ["tag1"]);
cache.set("key2", "value2", 60, ["tag2"]);
cache.set("key3", "value3", 60, ["tag1", "tag2"]);
// Invalidate keys that have at least one of the specified tags
cache.invalidateTagsUnion(["tag1", "tag2"]); // i.e. Invalidates all keys
cache.get("key1"); // Output: undefined
cache.get("key2"); // Output: undefined
cache.get("key3"); // Output: undefined
import { withCache } from "node-cache-plus";
async function fetchData(param: string): Promise<string> {
return new Promise((resolve) => {
setTimeout(() => {
resolve(`data_${param}`);
}, 500);
});
}
const cachedFetchData = withCache(fetchData, { ttl: 600, tags: ["data"] });
const data = await cachedFetchData("param1");
console.log(data); // Output: "data_param1"
Note: This function uses the default cache, see details in the Configuring Default Cache section below. You can also pass a custom cache instance as a prop to the withCache
helper
import { cachedCall } from "node-cache-plus";
async function fetchData(param: string): Promise<string> {
return new Promise((resolve) => {
setTimeout(() => {
resolve(`data_${param}`);
}, 500);
});
}
const data = await cachedCall(
fetchData,
{ ttl: 600, tags: ["data"] },
"param1"
);
console.log(data); // Output: "data_param1"
Note: This function uses the default cache, see details in the Configuring Default Cache section below. You can also pass a custom cache instance as a prop to the cachedCall
helper
The helper functions withCache
and cachedCall
use a default cache instance. You can configure the default cache instance by using theconfigureDefaultCache
function.
import { configureDefaultCache, getDefaultCache } from "node-cache-plus";
// Configure the default cache with custom options
configureDefaultCache({ stdTTL: 100, checkperiod: 120 });
// Get the default cache instance
const defaultCache = getDefaultCache();
// Use the default cache instance
defaultCache.set("key", "value", 60);
const value = defaultCache.get("key");
console.log(value); // Output: "value"