Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 | 2x 2x 40x 40x 40x 30x 30x 14x 16x 16x 16x 6x 6x 10x 25x 25x 4x 8x 25x 25x 25x | import { CacheEntry, CacheKey, DEFAULT_CACHE_LIFE, DEFAULT_NOW_PROVIDER, ICache, WrappedCacheEntry } from './shared'
/**
* Wraps a cache implementation and adds expiration logic
* */
export class CacheManager {
readonly nowProvider: () => number | Promise<number>
constructor(
private cache: ICache,
private cacheTime: number = DEFAULT_CACHE_LIFE,
nowProvider?: () => number | Promise<number>
) {
this.nowProvider = nowProvider || DEFAULT_NOW_PROVIDER
}
/**
* It gets a cache entry from the cache, and if it's expired, it removes it from the cache
* @param cacheKey - CacheKey<TExtended>
* @returns A promise that resolves to a cache entry or undefined.
*/
async get<TExtended extends boolean>(cacheKey: CacheKey<TExtended>): Promise<CacheEntry<TExtended> | undefined> {
const wrappedEntry = await this.cache.get<WrappedCacheEntry<TExtended>>(cacheKey.toKey())
if (!wrappedEntry) {
return
}
const now = await this.nowProvider()
const nowSeconds = Math.floor(now / 1000)
if (wrappedEntry.expiresAt < nowSeconds) {
await this.cache.remove(cacheKey.toKey())
return
}
return wrappedEntry.body
}
/**
* It takes a cache key and a cache entry, wraps the cache entry, and then sets the wrapped cache entry in the cache
* @param cacheKey - CacheKey<TExtended>
* @param {CacheEntry} entry - The cache entry to be stored.
*/
async set<TExtended extends boolean>(cacheKey: CacheKey<TExtended>, entry: CacheEntry): Promise<void> {
const wrappedEntry = await this.wrapCacheEntry(entry)
await this.cache.set(cacheKey.toKey(), wrappedEntry)
}
/**
* It gets all the keys in the cache, and then removes them all
*/
async clearCache() {
const keys = await this.cache.allKeys()
await Promise.all(keys.map((key) => this.cache.remove(key)))
}
private async wrapCacheEntry(entry: CacheEntry): Promise<WrappedCacheEntry> {
const now = await this.nowProvider()
const expiresInTime = Math.floor(now / 1000) + this.cacheTime
return {
body: entry,
expiresAt: expiresInTime,
}
}
}
|