Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Module for memoizing an individual function or a pair of inverse functions to persistent storage
This module is for memoizing to localStorage a single asynchronous function or a pair of inverse asynchronous functions.
This module exports the BiMapCache class, which must be instantiated with new
and has several public methods.
When constructing a BiMapCache instance, you must pass an object with key
,
getAfromB
, and getBfromA
properties. The rest of the properties are
optional.
key
is the name of the property on localStorage (or the object passed as the
storage
parameter) to use to store the cached data in.
getAfromB
and getBfromA
are the functions you want to cache. These functions
are expected to be inverses of each other, though if you only want to cache one
function then you could supply it as getAfromB
and supply an error-throwing
function as getBfromA
. Each function only gets called when the same-named
method on the BiMapCache instance is called. Each function must return a Promise
if it is to be used. The inputs and (resolved) outputs of these functions must
work as the keys of Maps and be JSONifiable, so it's recommended that they be
numbers or strings.
saveThrottle
is an optional property specifying a number of milliseconds to
throttle saves to the storage by. This defaults to 3000 (or 3 seconds).
maxLimit
is an optional property specifying the maximum number of entries to
keep in the persistent cache. Old entries will be removed first if this limit is
exceeded. This defaults to 1000.
maxAge
is an optional property specifying the maximum age in milliseconds for
cache entries. Cache entries that haven't been set or retrieved within this time
will be removed. This defaults to one year.
Calling either of these methods on the instance will cause the cache to be checked first. If no result is found in the cache, then the matching callback given in the constructor will be called. If the promise from the given callback resolves successfully, its result will be cached.
These methods allow a value to be removed from the cache. If the corresponding
getAfromB(input)
/ getBfromA(input)
function was previously called and its
returned Promise has not yet resolved, then its final result will not be cached.
Both TypeScript and Flow type definitions for this module are included! The type definitions won't require any configuration to use.
2.0.0 (2019-01-15)
Map
and Promise
globals are now required to be present. If you're targeting old browsers without these, then you must use a polyfill.removeAfromCache
and removeBfromCache
methods.FAQs
Module for memoizing an individual function or a pair of inverse functions to persistent storage
We found that bimapcache demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.