A memoize library for refreshing and cache token values.
$ npm install memoize-token --save
const memoizeToken = require('memoize-token')
let value = -1
const values = ['foo', 'bar']
const fn = memoizeToken(
() => values[++value],
{ max: 2, key: 'test', cache }
)
;(async () => {
await fn() // => 'foo'
await fn() // => 'foo'
await fn() // max excedeed, refresh the token => 'bar'
await fn() // => 'bar'
})()
Required
Type: Function
Function to be memoized and used for refreshing the token.
Required
Type: Number
Maximum numbers of calls after refresh the token.
Required
Type: String
The base key to use into the cache.
Type: Number
Time in milliseconds to consider a token as expired.
Type: Object
Default: new Map()
Use a different cache storage.
Must implement the following methods: .get(key)
and .set(key, value)
, Check keyv
to see database connectors.
- bottleneck – Job scheduler and rate limiter.
- limiter – Provides a generic rate limiter and token bucket for Node.js.
memoize-token © microlink.io, released under the MIT License.
Authored and maintained by Kiko Beats with help from contributors.
microlink.io · GitHub microlink.io · Twitter @microlinkhq