From 8384d6a299ab236218c5498719b7a73dbc755e16 Mon Sep 17 00:00:00 2001 From: ztimson Date: Sat, 28 Sep 2024 09:56:09 -0400 Subject: [PATCH] Added new cache object --- package-lock.json | 4 +-- package.json | 2 +- src/cache.ts | 73 +++++++++++++++++++++++++++++++++++++++++++++++ src/index.ts | 1 + 4 files changed, 77 insertions(+), 3 deletions(-) create mode 100644 src/cache.ts diff --git a/package-lock.json b/package-lock.json index b51b27e..5481710 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@ztimson/utils", - "version": "0.15.6", + "version": "0.16.3", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "@ztimson/utils", - "version": "0.15.6", + "version": "0.16.3", "license": "MIT", "devDependencies": { "@types/jest": "^29.5.12", diff --git a/package.json b/package.json index fc3c916..208a6ff 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@ztimson/utils", - "version": "0.16.2", + "version": "0.16.3", "description": "Utility library", "author": "Zak Timson", "license": "MIT", diff --git a/src/cache.ts b/src/cache.ts new file mode 100644 index 0000000..f617cf9 --- /dev/null +++ b/src/cache.ts @@ -0,0 +1,73 @@ +/** + * Map of data which tracks whether it is a complete collection & offers optional expiry of cached values + */ +export class Cache extends Map { + + /** Whether cache is complete */ + complete = false; + + /** + * Create new cache + * + * @param {keyof T} key Default property to use as primary key + * @param {number} ttl Default expiry in milliseconds + */ + constructor(public readonly key: keyof T, public ttl?: number) { + super(); + } + + private getKey(value: T): K { + return value[this.key]; + } + + /** + * Get all cached items + * + * @return {T[]} Array of items + */ + all() { + return Array.from(this.values()); + } + + /** + * Add a new item to the cache. Like set, but finds key automatically + * + * @param {T} value Item to add to cache + * @param {number | undefined} ttl Override default expiry + * @return {this} + */ + add(value: T, ttl = this.ttl): this { + const key = this.getKey(value); + this.set(key, value, ttl); + return this; + } + + /** + * Add several rows to the cache + * + * @param {T[]} rows Several items that will be cached using the default key + * @param complete Mark cache as complete & reliable, defaults to true + * @return {this} + */ + addAll(rows: T[], complete = true): this { + rows.forEach(r => this.add(r)); + this.complete = complete; + return this; + } + + /** + * Add an item to the cache manually specifying the key + * @param {K} key Key item will be cached under + * @param {T} value Item to cache + * @param {number | undefined} ttl Override default expiry + * @return {this} + */ + set(key: K, value: T, ttl = this.ttl): this { + super.set(key, value); + if(ttl) setTimeout(() => { + this.complete = false; + super.delete(key) + }, ttl); + return this; + } +} diff --git a/src/index.ts b/src/index.ts index 30d4124..b83a6ba 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,5 +1,6 @@ export * from './array'; export * from './aset'; +export * from './cache'; export * from './csv'; export * from './files'; export * from './emitter';