@extra-memoize/memory-cache 0.2.9 → 0.2.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -0
- package/lib/es2015/caches/cache.d.ts +8 -0
- package/lib/es2015/caches/cache.js +28 -0
- package/lib/es2015/caches/cache.js.map +1 -0
- package/lib/es2015/caches/expirable-cache-with-stale-if-error.js +2 -2
- package/lib/es2015/caches/expirable-cache-with-stale-if-error.js.map +1 -1
- package/lib/es2015/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.js +3 -3
- package/lib/es2015/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.js.map +1 -1
- package/lib/es2015/caches/expirable-cache-with-stale-while-revalidate.js +3 -2
- package/lib/es2015/caches/expirable-cache-with-stale-while-revalidate.js.map +1 -1
- package/lib/es2015/caches/index.d.ts +1 -0
- package/lib/es2015/caches/index.js +1 -0
- package/lib/es2015/caches/index.js.map +1 -1
- package/lib/es2015/caches/tlru-cache-with-stale-if-error.js +2 -2
- package/lib/es2015/caches/tlru-cache-with-stale-if-error.js.map +1 -1
- package/lib/es2015/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.js +3 -3
- package/lib/es2015/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.js.map +1 -1
- package/lib/es2015/caches/tlru-cache-with-stale-while-revalidate.js +3 -2
- package/lib/es2015/caches/tlru-cache-with-stale-while-revalidate.js.map +1 -1
- package/lib/es2018/caches/cache.d.ts +8 -0
- package/lib/es2018/caches/cache.js +28 -0
- package/lib/es2018/caches/cache.js.map +1 -0
- package/lib/es2018/caches/expirable-cache-with-stale-if-error.js +2 -2
- package/lib/es2018/caches/expirable-cache-with-stale-if-error.js.map +1 -1
- package/lib/es2018/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.js +3 -3
- package/lib/es2018/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.js.map +1 -1
- package/lib/es2018/caches/expirable-cache-with-stale-while-revalidate.js +3 -2
- package/lib/es2018/caches/expirable-cache-with-stale-while-revalidate.js.map +1 -1
- package/lib/es2018/caches/index.d.ts +1 -0
- package/lib/es2018/caches/index.js +1 -0
- package/lib/es2018/caches/index.js.map +1 -1
- package/lib/es2018/caches/tlru-cache-with-stale-if-error.js +2 -2
- package/lib/es2018/caches/tlru-cache-with-stale-if-error.js.map +1 -1
- package/lib/es2018/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.js +3 -3
- package/lib/es2018/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.js.map +1 -1
- package/lib/es2018/caches/tlru-cache-with-stale-while-revalidate.js +3 -2
- package/lib/es2018/caches/tlru-cache-with-stale-while-revalidate.js.map +1 -1
- package/package.json +1 -1
- package/src/caches/cache.ts +25 -0
- package/src/caches/expirable-cache-with-stale-if-error.ts +2 -2
- package/src/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.ts +3 -3
- package/src/caches/expirable-cache-with-stale-while-revalidate.ts +3 -2
- package/src/caches/index.ts +2 -0
- package/src/caches/tlru-cache-with-stale-if-error.ts +2 -2
- package/src/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.ts +3 -3
- package/src/caches/tlru-cache-with-stale-while-revalidate.ts +3 -2
package/README.md
CHANGED
@@ -7,11 +7,19 @@ yarn add @extra-memoize/memory-cache
|
|
7
7
|
```
|
8
8
|
|
9
9
|
## API
|
10
|
+
### Cache
|
11
|
+
```ts
|
12
|
+
class Cache<T> implements ICache<T> {
|
13
|
+
clear(): void
|
14
|
+
}
|
15
|
+
```
|
16
|
+
|
10
17
|
### LRUCache
|
11
18
|
```ts
|
12
19
|
class LRUCache<T> implements ICache<T> {
|
13
20
|
constructor(limit: number)
|
14
21
|
|
22
|
+
delete(key: string): void
|
15
23
|
clear(): void
|
16
24
|
}
|
17
25
|
```
|
@@ -0,0 +1,28 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Cache = void 0;
|
4
|
+
const extra_memoize_1 = require("extra-memoize");
|
5
|
+
class Cache {
|
6
|
+
constructor() {
|
7
|
+
this.map = new Map();
|
8
|
+
}
|
9
|
+
set(key, value) {
|
10
|
+
this.map.set(key, value);
|
11
|
+
}
|
12
|
+
get(key) {
|
13
|
+
if (this.map.has(key)) {
|
14
|
+
return [extra_memoize_1.State.Hit, this.map.get(key)];
|
15
|
+
}
|
16
|
+
else {
|
17
|
+
return [extra_memoize_1.State.Miss];
|
18
|
+
}
|
19
|
+
}
|
20
|
+
delete(key) {
|
21
|
+
this.map.delete(key);
|
22
|
+
}
|
23
|
+
clear() {
|
24
|
+
this.map.clear();
|
25
|
+
}
|
26
|
+
}
|
27
|
+
exports.Cache = Cache;
|
28
|
+
//# sourceMappingURL=cache.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../../src/caches/cache.ts"],"names":[],"mappings":";;;AAAA,iDAA6C;AAE7C,MAAa,KAAK;IAAlB;QACU,QAAG,GAAG,IAAI,GAAG,EAAE,CAAA;IAqBzB,CAAC;IAnBC,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;IAC1B,CAAC;IAED,GAAG,CAAC,GAAW;QACb,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACrB,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;SACtC;aAAM;YACL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;IACH,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IACtB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAA;IAClB,CAAC;CACF;AAtBD,sBAsBC"}
|
@@ -22,10 +22,10 @@ class ExpirableCacheWithStaleIfError {
|
|
22
22
|
}
|
23
23
|
else {
|
24
24
|
const elapsed = Date.now() - record.updatedAt;
|
25
|
-
if (elapsed
|
25
|
+
if (elapsed < this.timeToLive) {
|
26
26
|
return [extra_memoize_1.State.Hit, record.value];
|
27
27
|
}
|
28
|
-
else if (elapsed
|
28
|
+
else if (elapsed < this.timeToLive + this.staleIfError) {
|
29
29
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
30
30
|
}
|
31
31
|
else {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"expirable-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAyD;AAOzD,MAAa,8BAA8B;IAGzC,YAAoB,UAAkB,EAAU,YAAoB;QAAhD,eAAU,GAAV,UAAU,CAAQ;QAAU,iBAAY,GAAZ,YAAY,CAAQ;QAClE,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,YAAY,CAAC,CAAA;IAC5D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"expirable-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAyD;AAOzD,MAAa,8BAA8B;IAGzC,YAAoB,UAAkB,EAAU,YAAoB;QAAhD,eAAU,GAAV,UAAU,CAAQ;QAAU,iBAAY,GAAZ,YAAY,CAAQ;QAClE,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,YAAY,CAAC,CAAA;IAC5D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE;gBACxD,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AA9BD,wEA8BC"}
|
@@ -23,13 +23,13 @@ class ExpirableCacheWithStaleWhileRevalidateAndStaleIfError {
|
|
23
23
|
}
|
24
24
|
else {
|
25
25
|
const elapsed = Date.now() - record.updatedAt;
|
26
|
-
if (elapsed
|
26
|
+
if (elapsed < this.timeToLive) {
|
27
27
|
return [extra_memoize_1.State.Hit, record.value];
|
28
28
|
}
|
29
|
-
else if (elapsed
|
29
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate) {
|
30
30
|
return [extra_memoize_1.State.StaleWhileRevalidate, record.value];
|
31
31
|
}
|
32
|
-
else if (elapsed
|
32
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate + this.staleIfError) {
|
33
33
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
34
34
|
}
|
35
35
|
else {
|
package/lib/es2015/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"expirable-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAgF;AAOhF,MAAa,qDAAqD;IAGhE,YACU,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACnF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"expirable-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAgF;AAOhF,MAAa,qDAAqD;IAGhE,YACU,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACnF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,EAAE;gBAChE,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,EAAE;gBACpF,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AA1CD,sHA0CC"}
|
@@ -30,8 +30,9 @@ class ExpirableCacheWithStaleWhileRevalidate {
|
|
30
30
|
}
|
31
31
|
}
|
32
32
|
isStaleWhileRevalidate(record) {
|
33
|
-
|
34
|
-
|
33
|
+
const timestamp = Date.now();
|
34
|
+
return record.updatedAt + this.timeToLive <= timestamp
|
35
|
+
&& record.updatedAt + this.timeToLive + this.staleWhileRevalidate > timestamp;
|
35
36
|
}
|
36
37
|
}
|
37
38
|
exports.ExpirableCacheWithStaleWhileRevalidate = ExpirableCacheWithStaleWhileRevalidate;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"expirable-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAiE;AAOjE,MAAa,sCAAsC;IAGjD,YAAoB,UAAkB,EAAU,oBAA4B;QAAxD,eAAU,GAAV,UAAU,CAAQ;QAAU,yBAAoB,GAApB,oBAAoB,CAAQ;QAC1E,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACpE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAEO,sBAAsB,CAAC,MAAkB;QAC/C,
|
1
|
+
{"version":3,"file":"expirable-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAiE;AAOjE,MAAa,sCAAsC;IAGjD,YAAoB,UAAkB,EAAU,oBAA4B;QAAxD,eAAU,GAAV,UAAU,CAAQ;QAAU,yBAAoB,GAApB,oBAAoB,CAAQ;QAC1E,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACpE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAEO,sBAAsB,CAAC,MAAkB;QAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAC5B,OAAO,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,IAAI,SAAS;eAC/C,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAA;IACnF,CAAC;CACF;AAhCD,wFAgCC"}
|
@@ -14,6 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./cache"), exports);
|
17
18
|
__exportStar(require("./lru-cache"), exports);
|
18
19
|
__exportStar(require("./expirable-cache"), exports);
|
19
20
|
__exportStar(require("./expirable-cache-with-stale-while-revalidate"), exports);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/caches/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA2B;AAE3B,oDAAiC;AACjC,gFAA6D;AAC7D,wEAAqD;AACrD,mGAAgF;AAEhF,+CAA4B;AAC5B,2EAAwD;AACxD,mEAAgD;AAChD,8FAA2E"}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/caches/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAuB;AAEvB,8CAA2B;AAE3B,oDAAiC;AACjC,gFAA6D;AAC7D,wEAAqD;AACrD,mGAAgF;AAEhF,+CAA4B;AAC5B,2EAAwD;AACxD,mEAAgD;AAChD,8FAA2E"}
|
@@ -22,10 +22,10 @@ class TLRUCacheWithStaleIfError {
|
|
22
22
|
}
|
23
23
|
else {
|
24
24
|
const elapsed = Date.now() - record.updatedAt;
|
25
|
-
if (elapsed
|
25
|
+
if (elapsed < this.timeToLive) {
|
26
26
|
return [extra_memoize_1.State.Hit, record.value];
|
27
27
|
}
|
28
|
-
else if (elapsed
|
28
|
+
else if (elapsed < this.timeToLive + this.staleIfError) {
|
29
29
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
30
30
|
}
|
31
31
|
else {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"tlru-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAyD;AAOzD,MAAa,yBAAyB;IAGpC,YACE,KAAa,EACL,UAAkB,EAClB,YAAoB;QADpB,eAAU,GAAV,UAAU,CAAQ;QAClB,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,CAAC,CAAA;IAC9D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"tlru-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAyD;AAOzD,MAAa,yBAAyB;IAGpC,YACE,KAAa,EACL,UAAkB,EAClB,YAAoB;QADpB,eAAU,GAAV,UAAU,CAAQ;QAClB,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,CAAC,CAAA;IAC9D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE;gBACxD,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AAlCD,8DAkCC"}
|
@@ -23,13 +23,13 @@ class TLRUCacheWithStaleWhileRevalidateAndStaleIfError {
|
|
23
23
|
}
|
24
24
|
else {
|
25
25
|
const elapsed = Date.now() - record.updatedAt;
|
26
|
-
if (elapsed
|
26
|
+
if (elapsed < this.timeToLive) {
|
27
27
|
return [extra_memoize_1.State.Hit, record.value];
|
28
28
|
}
|
29
|
-
else if (elapsed
|
29
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate) {
|
30
30
|
return [extra_memoize_1.State.StaleWhileRevalidate, record.value];
|
31
31
|
}
|
32
|
-
else if (elapsed
|
32
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate + this.staleIfError) {
|
33
33
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
34
34
|
}
|
35
35
|
else {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"tlru-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAgF;AAOhF,MAAa,gDAAgD;IAG3D,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACrF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"tlru-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAgF;AAOhF,MAAa,gDAAgD;IAG3D,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACrF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,EAAE;gBAChE,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,EAAE;gBACpF,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AA3CD,4GA2CC"}
|
@@ -30,8 +30,9 @@ class TLRUCacheWithStaleWhileRevalidate {
|
|
30
30
|
}
|
31
31
|
}
|
32
32
|
isStaleWhileRevalidate(record) {
|
33
|
-
|
34
|
-
|
33
|
+
const timestamp = Date.now();
|
34
|
+
return record.updatedAt + this.timeToLive <= timestamp
|
35
|
+
&& record.updatedAt + this.timeToLive + this.staleWhileRevalidate > timestamp;
|
35
36
|
}
|
36
37
|
}
|
37
38
|
exports.TLRUCacheWithStaleWhileRevalidate = TLRUCacheWithStaleWhileRevalidate;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"tlru-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAiE;AAOjE,MAAa,iCAAiC;IAG5C,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B;QAD5B,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAEpC,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACtE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAED,sBAAsB,CAAC,MAAkB;QACvC,
|
1
|
+
{"version":3,"file":"tlru-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAiE;AAOjE,MAAa,iCAAiC;IAG5C,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B;QAD5B,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAEpC,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACtE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAED,sBAAsB,CAAC,MAAkB;QACvC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAC5B,OAAO,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,IAAI,SAAS;eAC/C,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAA;IACnF,CAAC;CACF;AApCD,8EAoCC"}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Cache = void 0;
|
4
|
+
const extra_memoize_1 = require("extra-memoize");
|
5
|
+
class Cache {
|
6
|
+
constructor() {
|
7
|
+
this.map = new Map();
|
8
|
+
}
|
9
|
+
set(key, value) {
|
10
|
+
this.map.set(key, value);
|
11
|
+
}
|
12
|
+
get(key) {
|
13
|
+
if (this.map.has(key)) {
|
14
|
+
return [extra_memoize_1.State.Hit, this.map.get(key)];
|
15
|
+
}
|
16
|
+
else {
|
17
|
+
return [extra_memoize_1.State.Miss];
|
18
|
+
}
|
19
|
+
}
|
20
|
+
delete(key) {
|
21
|
+
this.map.delete(key);
|
22
|
+
}
|
23
|
+
clear() {
|
24
|
+
this.map.clear();
|
25
|
+
}
|
26
|
+
}
|
27
|
+
exports.Cache = Cache;
|
28
|
+
//# sourceMappingURL=cache.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../../src/caches/cache.ts"],"names":[],"mappings":";;;AAAA,iDAA6C;AAE7C,MAAa,KAAK;IAAlB;QACU,QAAG,GAAG,IAAI,GAAG,EAAE,CAAA;IAqBzB,CAAC;IAnBC,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;IAC1B,CAAC;IAED,GAAG,CAAC,GAAW;QACb,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YACrB,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;SACtC;aAAM;YACL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;IACH,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;IACtB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAA;IAClB,CAAC;CACF;AAtBD,sBAsBC"}
|
@@ -22,10 +22,10 @@ class ExpirableCacheWithStaleIfError {
|
|
22
22
|
}
|
23
23
|
else {
|
24
24
|
const elapsed = Date.now() - record.updatedAt;
|
25
|
-
if (elapsed
|
25
|
+
if (elapsed < this.timeToLive) {
|
26
26
|
return [extra_memoize_1.State.Hit, record.value];
|
27
27
|
}
|
28
|
-
else if (elapsed
|
28
|
+
else if (elapsed < this.timeToLive + this.staleIfError) {
|
29
29
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
30
30
|
}
|
31
31
|
else {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"expirable-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAyD;AAOzD,MAAa,8BAA8B;IAGzC,YAAoB,UAAkB,EAAU,YAAoB;QAAhD,eAAU,GAAV,UAAU,CAAQ;QAAU,iBAAY,GAAZ,YAAY,CAAQ;QAClE,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,YAAY,CAAC,CAAA;IAC5D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"expirable-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAyD;AAOzD,MAAa,8BAA8B;IAGzC,YAAoB,UAAkB,EAAU,YAAoB;QAAhD,eAAU,GAAV,UAAU,CAAQ;QAAU,iBAAY,GAAZ,YAAY,CAAQ;QAClE,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,YAAY,CAAC,CAAA;IAC5D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE;gBACxD,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AA9BD,wEA8BC"}
|
@@ -23,13 +23,13 @@ class ExpirableCacheWithStaleWhileRevalidateAndStaleIfError {
|
|
23
23
|
}
|
24
24
|
else {
|
25
25
|
const elapsed = Date.now() - record.updatedAt;
|
26
|
-
if (elapsed
|
26
|
+
if (elapsed < this.timeToLive) {
|
27
27
|
return [extra_memoize_1.State.Hit, record.value];
|
28
28
|
}
|
29
|
-
else if (elapsed
|
29
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate) {
|
30
30
|
return [extra_memoize_1.State.StaleWhileRevalidate, record.value];
|
31
31
|
}
|
32
|
-
else if (elapsed
|
32
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate + this.staleIfError) {
|
33
33
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
34
34
|
}
|
35
35
|
else {
|
package/lib/es2018/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"expirable-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAgF;AAOhF,MAAa,qDAAqD;IAGhE,YACU,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACnF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"expirable-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAgF;AAOhF,MAAa,qDAAqD;IAGhE,YACU,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACnF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,EAAE;gBAChE,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,EAAE;gBACpF,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AA1CD,sHA0CC"}
|
@@ -30,8 +30,9 @@ class ExpirableCacheWithStaleWhileRevalidate {
|
|
30
30
|
}
|
31
31
|
}
|
32
32
|
isStaleWhileRevalidate(record) {
|
33
|
-
|
34
|
-
|
33
|
+
const timestamp = Date.now();
|
34
|
+
return record.updatedAt + this.timeToLive <= timestamp
|
35
|
+
&& record.updatedAt + this.timeToLive + this.staleWhileRevalidate > timestamp;
|
35
36
|
}
|
36
37
|
}
|
37
38
|
exports.ExpirableCacheWithStaleWhileRevalidate = ExpirableCacheWithStaleWhileRevalidate;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"expirable-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAiE;AAOjE,MAAa,sCAAsC;IAGjD,YAAoB,UAAkB,EAAU,oBAA4B;QAAxD,eAAU,GAAV,UAAU,CAAQ;QAAU,yBAAoB,GAApB,oBAAoB,CAAQ;QAC1E,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACpE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAEO,sBAAsB,CAAC,MAAkB;QAC/C,
|
1
|
+
{"version":3,"file":"expirable-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/expirable-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,uDAAkD;AAClD,iDAAiE;AAOjE,MAAa,sCAAsC;IAGjD,YAAoB,UAAkB,EAAU,oBAA4B;QAAxD,eAAU,GAAV,UAAU,CAAQ;QAAU,yBAAoB,GAApB,oBAAoB,CAAQ;QAC1E,IAAI,CAAC,KAAK,GAAG,IAAI,gCAAc,CAAC,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACpE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAEO,sBAAsB,CAAC,MAAkB;QAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAC5B,OAAO,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,IAAI,SAAS;eAC/C,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAA;IACnF,CAAC;CACF;AAhCD,wFAgCC"}
|
@@ -14,6 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./cache"), exports);
|
17
18
|
__exportStar(require("./lru-cache"), exports);
|
18
19
|
__exportStar(require("./expirable-cache"), exports);
|
19
20
|
__exportStar(require("./expirable-cache-with-stale-while-revalidate"), exports);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/caches/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA2B;AAE3B,oDAAiC;AACjC,gFAA6D;AAC7D,wEAAqD;AACrD,mGAAgF;AAEhF,+CAA4B;AAC5B,2EAAwD;AACxD,mEAAgD;AAChD,8FAA2E"}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/caches/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0CAAuB;AAEvB,8CAA2B;AAE3B,oDAAiC;AACjC,gFAA6D;AAC7D,wEAAqD;AACrD,mGAAgF;AAEhF,+CAA4B;AAC5B,2EAAwD;AACxD,mEAAgD;AAChD,8FAA2E"}
|
@@ -22,10 +22,10 @@ class TLRUCacheWithStaleIfError {
|
|
22
22
|
}
|
23
23
|
else {
|
24
24
|
const elapsed = Date.now() - record.updatedAt;
|
25
|
-
if (elapsed
|
25
|
+
if (elapsed < this.timeToLive) {
|
26
26
|
return [extra_memoize_1.State.Hit, record.value];
|
27
27
|
}
|
28
|
-
else if (elapsed
|
28
|
+
else if (elapsed < this.timeToLive + this.staleIfError) {
|
29
29
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
30
30
|
}
|
31
31
|
else {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"tlru-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAyD;AAOzD,MAAa,yBAAyB;IAGpC,YACE,KAAa,EACL,UAAkB,EAClB,YAAoB;QADpB,eAAU,GAAV,UAAU,CAAQ;QAClB,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,CAAC,CAAA;IAC9D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"tlru-cache-with-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAyD;AAOzD,MAAa,yBAAyB;IAGpC,YACE,KAAa,EACL,UAAkB,EAClB,YAAoB;QADpB,eAAU,GAAV,UAAU,CAAQ;QAClB,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,YAAY,CAAC,CAAA;IAC9D,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,EAAE;gBACxD,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AAlCD,8DAkCC"}
|
@@ -23,13 +23,13 @@ class TLRUCacheWithStaleWhileRevalidateAndStaleIfError {
|
|
23
23
|
}
|
24
24
|
else {
|
25
25
|
const elapsed = Date.now() - record.updatedAt;
|
26
|
-
if (elapsed
|
26
|
+
if (elapsed < this.timeToLive) {
|
27
27
|
return [extra_memoize_1.State.Hit, record.value];
|
28
28
|
}
|
29
|
-
else if (elapsed
|
29
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate) {
|
30
30
|
return [extra_memoize_1.State.StaleWhileRevalidate, record.value];
|
31
31
|
}
|
32
|
-
else if (elapsed
|
32
|
+
else if (elapsed < this.timeToLive + this.staleWhileRevalidate + this.staleIfError) {
|
33
33
|
return [extra_memoize_1.State.StaleIfError, record.value];
|
34
34
|
}
|
35
35
|
else {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"tlru-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAgF;AAOhF,MAAa,gDAAgD;IAG3D,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACrF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,
|
1
|
+
{"version":3,"file":"tlru-cache-with-stale-while-revalidate-and-stale-if-error.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate-and-stale-if-error.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAgF;AAOhF,MAAa,gDAAgD;IAG3D,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B,EAC5B,YAAoB;QAFpB,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAC5B,iBAAY,GAAZ,YAAY,CAAQ;QAE5B,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,GAAG,YAAY,CAAC,CAAA;IACrF,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QAOb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,SAAS,CAAA;YAC7C,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE;gBAC7B,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,EAAE;gBAChE,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,EAAE;gBACpF,OAAO,CAAC,qBAAK,CAAC,YAAY,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAC1C;iBAAM;gBAEL,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;aACpB;SACF;IACH,CAAC;CACF;AA3CD,4GA2CC"}
|
@@ -30,8 +30,9 @@ class TLRUCacheWithStaleWhileRevalidate {
|
|
30
30
|
}
|
31
31
|
}
|
32
32
|
isStaleWhileRevalidate(record) {
|
33
|
-
|
34
|
-
|
33
|
+
const timestamp = Date.now();
|
34
|
+
return record.updatedAt + this.timeToLive <= timestamp
|
35
|
+
&& record.updatedAt + this.timeToLive + this.staleWhileRevalidate > timestamp;
|
35
36
|
}
|
36
37
|
}
|
37
38
|
exports.TLRUCacheWithStaleWhileRevalidate = TLRUCacheWithStaleWhileRevalidate;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"tlru-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAiE;AAOjE,MAAa,iCAAiC;IAG5C,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B;QAD5B,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAEpC,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACtE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAED,sBAAsB,CAAC,MAAkB;QACvC,
|
1
|
+
{"version":3,"file":"tlru-cache-with-stale-while-revalidate.js","sourceRoot":"","sources":["../../../src/caches/tlru-cache-with-stale-while-revalidate.ts"],"names":[],"mappings":";;;AAAA,6CAAwC;AACxC,iDAAiE;AAOjE,MAAa,iCAAiC;IAG5C,YACE,KAAa,EACL,UAAkB,EAClB,oBAA4B;QAD5B,eAAU,GAAV,UAAU,CAAQ;QAClB,yBAAoB,GAApB,oBAAoB,CAAQ;QAEpC,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAS,CAAC,KAAK,EAAE,UAAU,GAAG,oBAAoB,CAAC,CAAA;IACtE,CAAC;IAED,GAAG,CAAC,GAAW,EAAE,KAAQ;QACvB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE;YAClB,KAAK;YACL,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAA;IACJ,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,KAAK,KAAK,qBAAK,CAAC,IAAI,EAAE;YACxB,OAAO,CAAC,qBAAK,CAAC,IAAI,CAAC,CAAA;SACpB;aAAM;YACL,IAAI,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAE;gBACvC,OAAO,CAAC,qBAAK,CAAC,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aAClD;iBAAM;gBACL,OAAO,CAAC,qBAAK,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;aACjC;SACF;IACH,CAAC;IAED,sBAAsB,CAAC,MAAkB;QACvC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAC5B,OAAO,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,IAAI,SAAS;eAC/C,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAA;IACnF,CAAC;CACF;AApCD,8EAoCC"}
|
package/package.json
CHANGED
@@ -0,0 +1,25 @@
|
|
1
|
+
import { ICache, State } from 'extra-memoize'
|
2
|
+
|
3
|
+
export class Cache<T> implements ICache<T> {
|
4
|
+
private map = new Map()
|
5
|
+
|
6
|
+
set(key: string, value: T): void {
|
7
|
+
this.map.set(key, value)
|
8
|
+
}
|
9
|
+
|
10
|
+
get(key: string): [State.Miss] | [State.Hit, T] {
|
11
|
+
if (this.map.has(key)) {
|
12
|
+
return [State.Hit, this.map.get(key)]
|
13
|
+
} else {
|
14
|
+
return [State.Miss]
|
15
|
+
}
|
16
|
+
}
|
17
|
+
|
18
|
+
delete(key: string): void {
|
19
|
+
this.map.delete(key)
|
20
|
+
}
|
21
|
+
|
22
|
+
clear(): void {
|
23
|
+
this.map.clear()
|
24
|
+
}
|
25
|
+
}
|
@@ -26,9 +26,9 @@ export class ExpirableCacheWithStaleIfError<T> implements IStaleIfErrorCache<T>
|
|
26
26
|
return [State.Miss]
|
27
27
|
} else {
|
28
28
|
const elapsed = Date.now() - record.updatedAt
|
29
|
-
if (elapsed
|
29
|
+
if (elapsed < this.timeToLive) {
|
30
30
|
return [State.Hit, record.value]
|
31
|
-
} else if (elapsed
|
31
|
+
} else if (elapsed < this.timeToLive + this.staleIfError) {
|
32
32
|
return [State.StaleIfError, record.value]
|
33
33
|
} else {
|
34
34
|
// just in case
|
@@ -36,11 +36,11 @@ export class ExpirableCacheWithStaleWhileRevalidateAndStaleIfError<T> implements
|
|
36
36
|
return [State.Miss]
|
37
37
|
} else {
|
38
38
|
const elapsed = Date.now() - record.updatedAt
|
39
|
-
if (elapsed
|
39
|
+
if (elapsed < this.timeToLive) {
|
40
40
|
return [State.Hit, record.value]
|
41
|
-
} else if (elapsed
|
41
|
+
} else if (elapsed < this.timeToLive + this.staleWhileRevalidate) {
|
42
42
|
return [State.StaleWhileRevalidate, record.value]
|
43
|
-
} else if (elapsed
|
43
|
+
} else if (elapsed < this.timeToLive + this.staleWhileRevalidate + this.staleIfError) {
|
44
44
|
return [State.StaleIfError, record.value]
|
45
45
|
} else {
|
46
46
|
// just in case
|
@@ -34,7 +34,8 @@ export class ExpirableCacheWithStaleWhileRevalidate<T> implements IStaleWhileRev
|
|
34
34
|
}
|
35
35
|
|
36
36
|
private isStaleWhileRevalidate(record: IRecord<T>): boolean {
|
37
|
-
|
38
|
-
|
37
|
+
const timestamp = Date.now()
|
38
|
+
return record.updatedAt + this.timeToLive <= timestamp
|
39
|
+
&& record.updatedAt + this.timeToLive + this.staleWhileRevalidate > timestamp
|
39
40
|
}
|
40
41
|
}
|
package/src/caches/index.ts
CHANGED
@@ -30,9 +30,9 @@ export class TLRUCacheWithStaleIfError<T> implements IStaleIfErrorCache<T> {
|
|
30
30
|
return [State.Miss]
|
31
31
|
} else {
|
32
32
|
const elapsed = Date.now() - record.updatedAt
|
33
|
-
if (elapsed
|
33
|
+
if (elapsed < this.timeToLive) {
|
34
34
|
return [State.Hit, record.value]
|
35
|
-
} else if (elapsed
|
35
|
+
} else if (elapsed < this.timeToLive + this.staleIfError) {
|
36
36
|
return [State.StaleIfError, record.value]
|
37
37
|
} else {
|
38
38
|
// just in case
|
@@ -37,11 +37,11 @@ export class TLRUCacheWithStaleWhileRevalidateAndStaleIfError<T> implements ISta
|
|
37
37
|
return [State.Miss]
|
38
38
|
} else {
|
39
39
|
const elapsed = Date.now() - record.updatedAt
|
40
|
-
if (elapsed
|
40
|
+
if (elapsed < this.timeToLive) {
|
41
41
|
return [State.Hit, record.value]
|
42
|
-
} else if (elapsed
|
42
|
+
} else if (elapsed < this.timeToLive + this.staleWhileRevalidate) {
|
43
43
|
return [State.StaleWhileRevalidate, record.value]
|
44
|
-
} else if (elapsed
|
44
|
+
} else if (elapsed < this.timeToLive + this.staleWhileRevalidate + this.staleIfError) {
|
45
45
|
return [State.StaleIfError, record.value]
|
46
46
|
} else {
|
47
47
|
// just in case
|
@@ -38,7 +38,8 @@ export class TLRUCacheWithStaleWhileRevalidate<T> implements IStaleWhileRevalida
|
|
38
38
|
}
|
39
39
|
|
40
40
|
isStaleWhileRevalidate(record: IRecord<T>): boolean {
|
41
|
-
|
42
|
-
|
41
|
+
const timestamp = Date.now()
|
42
|
+
return record.updatedAt + this.timeToLive <= timestamp
|
43
|
+
&& record.updatedAt + this.timeToLive + this.staleWhileRevalidate > timestamp
|
43
44
|
}
|
44
45
|
}
|