slonik-interceptor-query-cache 3.3.0 → 3.3.2
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/dist/Logger.d.ts +1 -0
- package/dist/Logger.d.ts.map +1 -0
- package/dist/Logger.js +1 -0
- package/dist/Logger.js.map +1 -0
- package/dist/factories/createQueryCacheInterceptor.d.ts +1 -0
- package/dist/factories/createQueryCacheInterceptor.d.ts.map +1 -0
- package/dist/factories/createQueryCacheInterceptor.js +1 -0
- package/dist/factories/createQueryCacheInterceptor.js.map +1 -0
- package/dist/factories/createQueryContext.d.ts +1 -0
- package/dist/factories/createQueryContext.d.ts.map +1 -0
- package/dist/factories/createQueryContext.js +1 -0
- package/dist/factories/createQueryContext.js.map +1 -0
- package/dist/factories/index.d.ts +1 -0
- package/dist/factories/index.d.ts.map +1 -0
- package/dist/factories/index.js +1 -0
- package/dist/factories/index.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -0
- package/dist/utilities/extractCacheAttributes.d.ts +1 -0
- package/dist/utilities/extractCacheAttributes.d.ts.map +1 -0
- package/dist/utilities/extractCacheAttributes.js +1 -0
- package/dist/utilities/extractCacheAttributes.js.map +1 -0
- package/dist/utilities/extractCacheAttributes.test.d.ts +1 -0
- package/dist/utilities/extractCacheAttributes.test.d.ts.map +1 -0
- package/dist/utilities/extractCacheAttributes.test.js +1 -0
- package/dist/utilities/extractCacheAttributes.test.js.map +1 -0
- package/dist/utilities/index.d.ts +1 -0
- package/dist/utilities/index.d.ts.map +1 -0
- package/dist/utilities/index.js +1 -0
- package/dist/utilities/index.js.map +1 -0
- package/dist/utilities/normalizeCacheAttributes.d.ts +1 -0
- package/dist/utilities/normalizeCacheAttributes.d.ts.map +1 -0
- package/dist/utilities/normalizeCacheAttributes.js +1 -0
- package/dist/utilities/normalizeCacheAttributes.js.map +1 -0
- package/dist/utilities/normalizeCacheAttributes.test.d.ts +1 -0
- package/dist/utilities/normalizeCacheAttributes.test.d.ts.map +1 -0
- package/dist/utilities/normalizeCacheAttributes.test.js +1 -0
- package/dist/utilities/normalizeCacheAttributes.test.js.map +1 -0
- package/package.json +6 -6
- package/src/Logger.ts +5 -0
- package/src/factories/createQueryCacheInterceptor.ts +129 -0
- package/src/factories/createQueryContext.ts +16 -0
- package/src/factories/index.ts +1 -0
- package/src/index.ts +1 -0
- package/src/utilities/extractCacheAttributes.test.ts +92 -0
- package/src/utilities/extractCacheAttributes.ts +56 -0
- package/src/utilities/index.ts +2 -0
- package/src/utilities/normalizeCacheAttributes.test.ts +19 -0
- package/src/utilities/normalizeCacheAttributes.ts +14 -0
package/dist/Logger.d.ts
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Logger.d.ts","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,+DAEjB,CAAC"}
|
package/dist/Logger.js
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Logger.js","sourceRoot":"","sources":["../src/Logger.ts"],"names":[],"mappings":";;;AAAA,iCAA8B;AAEjB,QAAA,MAAM,GAAG,aAAK,CAAC,KAAK,CAAC;IAChC,OAAO,EAAE,gCAAgC;CAC1C,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createQueryCacheInterceptor.d.ts","sourceRoot":"","sources":["../../src/factories/createQueryCacheInterceptor.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,KAAK,EACV,KAAK,WAAW,EAChB,KAAK,cAAc,EACpB,MAAM,QAAQ,CAAC;AAYhB,MAAM,MAAM,eAAe,GAAG;IAC5B,YAAY,EAAE,OAAO,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,KAAK,OAAO,GAAG;IACb,GAAG,EAAE,CACH,KAAK,EAAE,KAAK,EACZ,eAAe,EAAE,eAAe,KAC7B,OAAO,CAAC,WAAW,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,CAAC;IACjD,GAAG,EAAE,CACH,KAAK,EAAE,KAAK,EACZ,eAAe,EAAE,eAAe,EAChC,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,KACrC,OAAO,CAAC,IAAI,CAAC,CAAC;CACpB,CAAC;AAEF,KAAK,kBAAkB,GAAG;IACxB,OAAO,EAAE,OAAO,CAAC;CAClB,CAAC;AAMF,eAAO,MAAM,2BAA2B,uBAClB,kBAAkB,KACrC,WAiFF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createQueryCacheInterceptor.js","sourceRoot":"","sources":["../../src/factories/createQueryCacheInterceptor.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AACnC,4CAAgF;AAQhF,MAAM,GAAG,GAAG,eAAM,CAAC,KAAK,CAAC;IACvB,SAAS,EAAE,6BAA6B;CACzC,CAAC,CAAC;AAkCI,MAAM,2BAA2B,GAAG,CACzC,kBAAsC,EACzB,EAAE;IACf,MAAM,aAAa,GAAkB;QACnC,GAAG,kBAAkB;KACtB,CAAC;IAEF,OAAO;QACL,oBAAoB,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;YAC7C,IAAI,OAAO,CAAC,aAAa,EAAE;gBACzB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,eAAe,GAAI,OAAO,CAAC,OAAmB,CAAC,KAAK;gBACxD,EAAE,eAAe,CAAC;YAEpB,IAAI,CAAC,eAAe,EAAE;gBACpB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,WAAW,GAAG,MAAM,aAAa,CAAC,OAAO,CAAC,GAAG,CACjD,KAAK,EACL,eAAe,CAChB,CAAC;YAEF,IAAI,WAAW,EAAE;gBACf,GAAG,CAAC,KAAK,CACP;oBACE,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB,EACD,4BAA4B,CAC7B,CAAC;gBAEF,OAAO,WAAW,CAAC;aACpB;YAED,OAAO,IAAI,CAAC;QACd,CAAC;QACD,iBAAiB,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;YAClD,IAAI,OAAO,CAAC,aAAa,EAAE;gBACzB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,eAAe,GAAI,OAAO,CAAC,OAAmB,CAAC,KAAK;gBACxD,EAAE,eAAe,CAAC;YAEpB,IAAI,eAAe,EAAE;gBACnB,IAAI,eAAe,CAAC,YAAY,IAAI,MAAM,CAAC,QAAQ,KAAK,CAAC,EAAE;oBACzD,GAAG,CAAC,KAAK,CACP,wEAAwE,CACzE,CAAC;iBACH;qBAAM;oBACL,MAAM,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,eAAe,EAAE,MAAM,CAAC,CAAC;iBACjE;aACF;YAED,OAAO,IAAI,CAAC;QACd,CAAC;QACD,oBAAoB,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;YAC7C,IAAI,OAAO,CAAC,aAAa,EAAE;gBACzB,OAAO,IAAI,CAAC;aACb;YAED,MAAM,wBAAwB,GAAG,IAAA,kCAAsB,EACrD,KAAK,CAAC,GAAG,EACT,KAAK,CAAC,MAAM,CACb,CAAC;YAEF,IAAI,CAAC,wBAAwB,EAAE;gBAC7B,OAAO,IAAI,CAAC;aACb;YAED,MAAM,eAAe,GAAG,IAAA,oCAAwB,EAC9C,wBAAwB,CACzB,CAAC;YAEF,OAAO,CAAC,OAAO,CAAC,KAAK,GAAG;gBACtB,eAAe;aAChB,CAAC;YAEF,OAAO,IAAI,CAAC;QACd,CAAC;KACF,CAAC;AACJ,CAAC,CAAC;AAnFW,QAAA,2BAA2B,+BAmFtC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createQueryContext.d.ts","sourceRoot":"","sources":["../../src/factories/createQueryContext.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,QAAQ,CAAC;;AAE3C,wBAaE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createQueryContext.js","sourceRoot":"","sources":["../../src/factories/createQueryContext.ts"],"names":[],"mappings":";;AAEA,kBAAe,GAAG,EAAE;IAClB,OAAO;QACL,YAAY,EAAE,GAAG;QACjB,GAAG,EAAE;YACH,UAAU,EAAE,GAAG,EAAE;gBACf,OAAO;oBACL,YAAY,EAAE,GAAG;oBACjB,MAAM,EAAE,GAAG;iBACZ,CAAC;YACJ,CAAC;SACF;QACD,MAAM,EAAE,GAAG;KACe,CAAC;AAC/B,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/factories/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC"}
|
package/dist/factories/index.js
CHANGED
|
@@ -3,3 +3,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createQueryCacheInterceptor = void 0;
|
|
4
4
|
var createQueryCacheInterceptor_1 = require("./createQueryCacheInterceptor");
|
|
5
5
|
Object.defineProperty(exports, "createQueryCacheInterceptor", { enumerable: true, get: function () { return createQueryCacheInterceptor_1.createQueryCacheInterceptor; } });
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/factories/index.ts"],"names":[],"mappings":";;;AAAA,6EAA4E;AAAnE,0IAAA,2BAA2B,OAAA"}
|
package/dist/index.d.ts
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -3,3 +3,4 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createQueryCacheInterceptor = void 0;
|
|
4
4
|
var factories_1 = require("./factories");
|
|
5
5
|
Object.defineProperty(exports, "createQueryCacheInterceptor", { enumerable: true, get: function () { return factories_1.createQueryCacheInterceptor; } });
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,yCAA0D;AAAjD,wHAAA,2BAA2B,OAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractCacheAttributes.d.ts","sourceRoot":"","sources":["../../src/utilities/extractCacheAttributes.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,QAAQ,CAAC;AAWvD,MAAM,MAAM,wBAAwB,GAAG;IACrC,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,OAAO,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAGF,eAAO,MAAM,sBAAsB,YACxB,MAAM,UACP,SAAS,wBAAwB,EAAE,KAC1C,wBAAwB,GAAG,IA+B7B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractCacheAttributes.js","sourceRoot":"","sources":["../../src/utilities/extractCacheAttributes.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAyC;AAEzC,oEAA2C;AAE3C,MAAM,IAAI,GAAG,CAAC,OAAe,EAAE,EAAE;IAC/B,OAAO,IAAA,wBAAU,EAAC,UAAU,EAAE;QAC5B,YAAY,EAAE,EAAE;KACjB,CAAC;SACC,MAAM,CAAC,OAAO,CAAC;SACf,MAAM,CAAC,KAAK,CAAC,CAAC;AACnB,CAAC,CAAC;AAUF,sDAAsD;AAC/C,MAAM,sBAAsB,GAAG,CACpC,OAAe,EACf,MAA2C,EACV,EAAE;IACnC,MAAM,GAAG,GAAG,sBAAsB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAEtD,4DAA4D;IAC5D,MAAM,QAAQ,GAAG,IAAI,CACnB,IAAA,wBAAa,EAAC,OAAO,CAAC;SACnB,UAAU,CAAC,cAAc,EAAE,EAAE,CAAC;SAC9B,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC,CAC1B,CAAC;IAEF,MAAM,YAAY,GAChB,CAAC,uCAAuC,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC;QACvE,MAAM,CAAC;IAET,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IAE/C,IAAI,GAAG,EAAE;QACP,MAAM,GAAG,GACP,8BAA8B,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;YACjD,4BAA4B,CAAC;QAE/B,OAAO;YACL,QAAQ;YACR,YAAY;YACZ,GAAG;YACH,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC;YAChB,SAAS;SACV,CAAC;KACH;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAlCW,QAAA,sBAAsB,0BAkCjC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractCacheAttributes.test.d.ts","sourceRoot":"","sources":["../../src/utilities/extractCacheAttributes.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractCacheAttributes.test.js","sourceRoot":"","sources":["../../src/utilities/extractCacheAttributes.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utilities/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC"}
|
package/dist/utilities/index.js
CHANGED
|
@@ -5,3 +5,4 @@ var extractCacheAttributes_1 = require("./extractCacheAttributes");
|
|
|
5
5
|
Object.defineProperty(exports, "extractCacheAttributes", { enumerable: true, get: function () { return extractCacheAttributes_1.extractCacheAttributes; } });
|
|
6
6
|
var normalizeCacheAttributes_1 = require("./normalizeCacheAttributes");
|
|
7
7
|
Object.defineProperty(exports, "normalizeCacheAttributes", { enumerable: true, get: function () { return normalizeCacheAttributes_1.normalizeCacheAttributes; } });
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utilities/index.ts"],"names":[],"mappings":";;;AAAA,mEAAkE;AAAzD,gIAAA,sBAAsB,OAAA;AAC/B,uEAAsE;AAA7D,oIAAA,wBAAwB,OAAA"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import { type CacheAttributes } from '../factories/createQueryCacheInterceptor';
|
|
2
2
|
import { type ExtractedCacheAttributes } from './extractCacheAttributes';
|
|
3
3
|
export declare const normalizeCacheAttributes: (extractedCacheAttributes: ExtractedCacheAttributes) => CacheAttributes;
|
|
4
|
+
//# sourceMappingURL=normalizeCacheAttributes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalizeCacheAttributes.d.ts","sourceRoot":"","sources":["../../src/utilities/normalizeCacheAttributes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,KAAK,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AAEzE,eAAO,MAAM,wBAAwB,6BACT,wBAAwB,KACjD,eAQF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalizeCacheAttributes.js","sourceRoot":"","sources":["../../src/utilities/normalizeCacheAttributes.ts"],"names":[],"mappings":";;;AAGO,MAAM,wBAAwB,GAAG,CACtC,wBAAkD,EACjC,EAAE;IACnB,OAAO;QACL,YAAY,EAAE,wBAAwB,CAAC,YAAY;QACnD,GAAG,EAAE,wBAAwB,CAAC,GAAG;aAC9B,UAAU,CAAC,WAAW,EAAE,wBAAwB,CAAC,QAAQ,CAAC;aAC1D,UAAU,CAAC,YAAY,EAAE,wBAAwB,CAAC,SAAS,CAAC;QAC/D,GAAG,EAAE,wBAAwB,CAAC,GAAG;KAClC,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,wBAAwB,4BAUnC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalizeCacheAttributes.test.d.ts","sourceRoot":"","sources":["../../src/utilities/normalizeCacheAttributes.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"normalizeCacheAttributes.test.js","sourceRoot":"","sources":["../../src/utilities/normalizeCacheAttributes.test.ts"],"names":[],"mappings":";;;;;AAAA,yEAAsE;AACtE,8CAAuB;AAEvB,IAAA,aAAI,EAAC,mCAAmC,EAAE,CAAC,CAAC,EAAE,EAAE;IAC9C,CAAC,CAAC,SAAS,CACT,IAAA,mDAAwB,EAAC;QACvB,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,KAAK;QACnB,GAAG,EAAE,sBAAsB;QAC3B,GAAG,EAAE,EAAE;QACP,SAAS,EAAE,KAAK;KACjB,CAAC,EACF;QACE,YAAY,EAAE,KAAK;QACnB,GAAG,EAAE,SAAS;QACd,GAAG,EAAE,EAAE;KACR,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
package/package.json
CHANGED
|
@@ -27,7 +27,6 @@
|
|
|
27
27
|
"@semantic-release/npm": "^9.0.2",
|
|
28
28
|
"ava": "^3.15.0",
|
|
29
29
|
"coveralls": "^3.1.1",
|
|
30
|
-
"del-cli": "^4.0.1",
|
|
31
30
|
"eslint": "^8.39.0",
|
|
32
31
|
"eslint-config-canonical": "^41.0.3",
|
|
33
32
|
"husky": "^8.0.0",
|
|
@@ -42,6 +41,7 @@
|
|
|
42
41
|
"node": ">=16.0"
|
|
43
42
|
},
|
|
44
43
|
"files": [
|
|
44
|
+
"src",
|
|
45
45
|
"dist"
|
|
46
46
|
],
|
|
47
47
|
"keywords": [
|
|
@@ -50,7 +50,7 @@
|
|
|
50
50
|
"format"
|
|
51
51
|
],
|
|
52
52
|
"license": "BSD-3-Clause",
|
|
53
|
-
"main": "./dist/
|
|
53
|
+
"main": "./dist/index.js",
|
|
54
54
|
"name": "slonik-interceptor-query-cache",
|
|
55
55
|
"peerDependencies": {
|
|
56
56
|
"slonik": ">=27.0.0"
|
|
@@ -60,12 +60,12 @@
|
|
|
60
60
|
"url": "https://github.com/gajus/slonik-interceptor-query-cache"
|
|
61
61
|
},
|
|
62
62
|
"scripts": {
|
|
63
|
-
"build": "
|
|
63
|
+
"build": "rm -fr ./dist && tsc --project tsconfig.build.json",
|
|
64
64
|
"lint:eslint": "eslint .",
|
|
65
|
-
"lint:tsc": "tsc
|
|
65
|
+
"lint:tsc": "tsc",
|
|
66
66
|
"prepare": "husky install",
|
|
67
67
|
"test:ava": "nyc ava --verbose --serial"
|
|
68
68
|
},
|
|
69
|
-
"
|
|
70
|
-
"version": "3.3.
|
|
69
|
+
"types": "./dist/index.d.ts",
|
|
70
|
+
"version": "3.3.2"
|
|
71
71
|
}
|
package/src/Logger.ts
ADDED
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { Logger } from '../Logger';
|
|
2
|
+
import { extractCacheAttributes, normalizeCacheAttributes } from '../utilities';
|
|
3
|
+
import {
|
|
4
|
+
type Interceptor,
|
|
5
|
+
type Query,
|
|
6
|
+
type QueryResult,
|
|
7
|
+
type QueryResultRow,
|
|
8
|
+
} from 'slonik';
|
|
9
|
+
|
|
10
|
+
const log = Logger.child({
|
|
11
|
+
namespace: 'createQueryCacheInterceptor',
|
|
12
|
+
});
|
|
13
|
+
|
|
14
|
+
type Sandbox = {
|
|
15
|
+
cache: {
|
|
16
|
+
cacheAttributes: CacheAttributes;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export type CacheAttributes = {
|
|
21
|
+
discardEmpty: boolean;
|
|
22
|
+
key: string;
|
|
23
|
+
ttl: number;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
type Storage = {
|
|
27
|
+
get: (
|
|
28
|
+
query: Query,
|
|
29
|
+
cacheAttributes: CacheAttributes,
|
|
30
|
+
) => Promise<QueryResult<QueryResultRow> | null>;
|
|
31
|
+
set: (
|
|
32
|
+
query: Query,
|
|
33
|
+
cacheAttributes: CacheAttributes,
|
|
34
|
+
queryResult: QueryResult<QueryResultRow>,
|
|
35
|
+
) => Promise<void>;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
type ConfigurationInput = {
|
|
39
|
+
storage: Storage;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
type Configuration = {
|
|
43
|
+
storage: Storage;
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
export const createQueryCacheInterceptor = (
|
|
47
|
+
configurationInput: ConfigurationInput,
|
|
48
|
+
): Interceptor => {
|
|
49
|
+
const configuration: Configuration = {
|
|
50
|
+
...configurationInput,
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
return {
|
|
54
|
+
beforeQueryExecution: async (context, query) => {
|
|
55
|
+
if (context.transactionId) {
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const cacheAttributes = (context.sandbox as Sandbox).cache
|
|
60
|
+
?.cacheAttributes;
|
|
61
|
+
|
|
62
|
+
if (!cacheAttributes) {
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
const maybeResult = await configuration.storage.get(
|
|
67
|
+
query,
|
|
68
|
+
cacheAttributes,
|
|
69
|
+
);
|
|
70
|
+
|
|
71
|
+
if (maybeResult) {
|
|
72
|
+
log.debug(
|
|
73
|
+
{
|
|
74
|
+
queryId: context.queryId,
|
|
75
|
+
},
|
|
76
|
+
'query is served from cache',
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
return maybeResult;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
return null;
|
|
83
|
+
},
|
|
84
|
+
beforeQueryResult: async (context, query, result) => {
|
|
85
|
+
if (context.transactionId) {
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
const cacheAttributes = (context.sandbox as Sandbox).cache
|
|
90
|
+
?.cacheAttributes;
|
|
91
|
+
|
|
92
|
+
if (cacheAttributes) {
|
|
93
|
+
if (cacheAttributes.discardEmpty && result.rowCount === 0) {
|
|
94
|
+
log.debug(
|
|
95
|
+
'@cache-discard-empty is set and the query result is empty; not caching',
|
|
96
|
+
);
|
|
97
|
+
} else {
|
|
98
|
+
await configuration.storage.set(query, cacheAttributes, result);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
return null;
|
|
103
|
+
},
|
|
104
|
+
beforeTransformQuery: async (context, query) => {
|
|
105
|
+
if (context.transactionId) {
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
const extractedCacheAttributes = extractCacheAttributes(
|
|
110
|
+
query.sql,
|
|
111
|
+
query.values,
|
|
112
|
+
);
|
|
113
|
+
|
|
114
|
+
if (!extractedCacheAttributes) {
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
const cacheAttributes = normalizeCacheAttributes(
|
|
119
|
+
extractedCacheAttributes,
|
|
120
|
+
);
|
|
121
|
+
|
|
122
|
+
context.sandbox.cache = {
|
|
123
|
+
cacheAttributes,
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
return null;
|
|
127
|
+
},
|
|
128
|
+
};
|
|
129
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { type QueryContext } from 'slonik';
|
|
2
|
+
|
|
3
|
+
export default () => {
|
|
4
|
+
return {
|
|
5
|
+
connectionId: '1',
|
|
6
|
+
log: {
|
|
7
|
+
getContext: () => {
|
|
8
|
+
return {
|
|
9
|
+
connectionId: '1',
|
|
10
|
+
poolId: '1',
|
|
11
|
+
};
|
|
12
|
+
},
|
|
13
|
+
},
|
|
14
|
+
poolId: '1',
|
|
15
|
+
} as unknown as QueryContext;
|
|
16
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { createQueryCacheInterceptor } from './createQueryCacheInterceptor';
|
package/src/index.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { createQueryCacheInterceptor } from './factories';
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { extractCacheAttributes } from './extractCacheAttributes';
|
|
2
|
+
import test from 'ava';
|
|
3
|
+
|
|
4
|
+
test('returns null when query does not contain cache attributes', (t) => {
|
|
5
|
+
t.is(extractCacheAttributes('', []), null);
|
|
6
|
+
});
|
|
7
|
+
|
|
8
|
+
test('extracts @cache-ttl', (t) => {
|
|
9
|
+
t.deepEqual(extractCacheAttributes('-- @cache-ttl 60', []), {
|
|
10
|
+
bodyHash: '46b9dd2b0ba88d13233b3feb',
|
|
11
|
+
discardEmpty: false,
|
|
12
|
+
key: 'query:$bodyHash:$valueHash',
|
|
13
|
+
ttl: 60,
|
|
14
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
test('extracts @cache-discard-empty', (t) => {
|
|
19
|
+
t.deepEqual(
|
|
20
|
+
extractCacheAttributes(
|
|
21
|
+
'-- @cache-ttl 60\n-- @cache-discard-empty false',
|
|
22
|
+
[],
|
|
23
|
+
),
|
|
24
|
+
{
|
|
25
|
+
bodyHash: '46b9dd2b0ba88d13233b3feb',
|
|
26
|
+
discardEmpty: false,
|
|
27
|
+
key: 'query:$bodyHash:$valueHash',
|
|
28
|
+
ttl: 60,
|
|
29
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
30
|
+
},
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
t.deepEqual(
|
|
34
|
+
extractCacheAttributes(
|
|
35
|
+
'-- @cache-ttl 60\n-- @cache-discard-empty true',
|
|
36
|
+
[],
|
|
37
|
+
),
|
|
38
|
+
{
|
|
39
|
+
bodyHash: '46b9dd2b0ba88d13233b3feb',
|
|
40
|
+
discardEmpty: true,
|
|
41
|
+
key: 'query:$bodyHash:$valueHash',
|
|
42
|
+
ttl: 60,
|
|
43
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
44
|
+
},
|
|
45
|
+
);
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
test('computes the parameter value hash', (t) => {
|
|
49
|
+
t.deepEqual(extractCacheAttributes('-- @cache-ttl 60', [1]), {
|
|
50
|
+
bodyHash: '46b9dd2b0ba88d13233b3feb',
|
|
51
|
+
discardEmpty: false,
|
|
52
|
+
key: 'query:$bodyHash:$valueHash',
|
|
53
|
+
ttl: 60,
|
|
54
|
+
valueHash: '62eb54746ae2932850f8d6ff',
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
test('computes the body hash; white spaces do not affect the body hash', (t) => {
|
|
59
|
+
t.deepEqual(extractCacheAttributes('-- @cache-ttl 60\nSELECT 1', []), {
|
|
60
|
+
bodyHash: '553ebdb024592064ca4c2c3a',
|
|
61
|
+
discardEmpty: false,
|
|
62
|
+
key: 'query:$bodyHash:$valueHash',
|
|
63
|
+
ttl: 60,
|
|
64
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
t.deepEqual(extractCacheAttributes('-- @cache-ttl 60\n\nSELECT 1', []), {
|
|
68
|
+
bodyHash: '553ebdb024592064ca4c2c3a',
|
|
69
|
+
discardEmpty: false,
|
|
70
|
+
key: 'query:$bodyHash:$valueHash',
|
|
71
|
+
ttl: 60,
|
|
72
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
test('computes the body hash; comments do not affect the body hash', (t) => {
|
|
77
|
+
t.deepEqual(extractCacheAttributes('-- @cache-ttl 60\nSELECT 1', []), {
|
|
78
|
+
bodyHash: '553ebdb024592064ca4c2c3a',
|
|
79
|
+
discardEmpty: false,
|
|
80
|
+
key: 'query:$bodyHash:$valueHash',
|
|
81
|
+
ttl: 60,
|
|
82
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
t.deepEqual(extractCacheAttributes('-- @cache-ttl 120\nSELECT 1', []), {
|
|
86
|
+
bodyHash: '553ebdb024592064ca4c2c3a',
|
|
87
|
+
discardEmpty: false,
|
|
88
|
+
key: 'query:$bodyHash:$valueHash',
|
|
89
|
+
ttl: 120,
|
|
90
|
+
valueHash: 'ec784925b52067bce01fd820',
|
|
91
|
+
});
|
|
92
|
+
});
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { createHash } from 'node:crypto';
|
|
2
|
+
import { type PrimitiveValueExpression } from 'slonik';
|
|
3
|
+
import stripComments from 'strip-comments';
|
|
4
|
+
|
|
5
|
+
const hash = (subject: string) => {
|
|
6
|
+
return createHash('shake256', {
|
|
7
|
+
outputLength: 12,
|
|
8
|
+
})
|
|
9
|
+
.update(subject)
|
|
10
|
+
.digest('hex');
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export type ExtractedCacheAttributes = {
|
|
14
|
+
bodyHash: string;
|
|
15
|
+
discardEmpty: boolean;
|
|
16
|
+
key: string;
|
|
17
|
+
ttl: number;
|
|
18
|
+
valueHash: string;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
// TODO throw an error if an unknown attribute is used
|
|
22
|
+
export const extractCacheAttributes = (
|
|
23
|
+
subject: string,
|
|
24
|
+
values: readonly PrimitiveValueExpression[],
|
|
25
|
+
): ExtractedCacheAttributes | null => {
|
|
26
|
+
const ttl = /-- @cache-ttl (\d+)/u.exec(subject)?.[1];
|
|
27
|
+
|
|
28
|
+
// https://github.com/jonschlinkert/strip-comments/issues/71
|
|
29
|
+
const bodyHash = hash(
|
|
30
|
+
stripComments(subject)
|
|
31
|
+
.replaceAll(/^\s*--.*$/gmu, '')
|
|
32
|
+
.replaceAll(/\s/gu, ''),
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
const discardEmpty =
|
|
36
|
+
(/-- @cache-discard-empty (true|false)/u.exec(subject)?.[1] ?? 'false') ===
|
|
37
|
+
'true';
|
|
38
|
+
|
|
39
|
+
const valueHash = hash(JSON.stringify(values));
|
|
40
|
+
|
|
41
|
+
if (ttl) {
|
|
42
|
+
const key =
|
|
43
|
+
/-- @cache-key ([$\w\-:/]+)/iu.exec(subject)?.[1] ??
|
|
44
|
+
'query:$bodyHash:$valueHash';
|
|
45
|
+
|
|
46
|
+
return {
|
|
47
|
+
bodyHash,
|
|
48
|
+
discardEmpty,
|
|
49
|
+
key,
|
|
50
|
+
ttl: Number(ttl),
|
|
51
|
+
valueHash,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
return null;
|
|
56
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { normalizeCacheAttributes } from './normalizeCacheAttributes';
|
|
2
|
+
import test from 'ava';
|
|
3
|
+
|
|
4
|
+
test('replaces $bodyHash and $valueHash', (t) => {
|
|
5
|
+
t.deepEqual(
|
|
6
|
+
normalizeCacheAttributes({
|
|
7
|
+
bodyHash: 'foo',
|
|
8
|
+
discardEmpty: false,
|
|
9
|
+
key: '$bodyHash:$valueHash',
|
|
10
|
+
ttl: 60,
|
|
11
|
+
valueHash: 'bar',
|
|
12
|
+
}),
|
|
13
|
+
{
|
|
14
|
+
discardEmpty: false,
|
|
15
|
+
key: 'foo:bar',
|
|
16
|
+
ttl: 60,
|
|
17
|
+
},
|
|
18
|
+
);
|
|
19
|
+
});
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type CacheAttributes } from '../factories/createQueryCacheInterceptor';
|
|
2
|
+
import { type ExtractedCacheAttributes } from './extractCacheAttributes';
|
|
3
|
+
|
|
4
|
+
export const normalizeCacheAttributes = (
|
|
5
|
+
extractedCacheAttributes: ExtractedCacheAttributes,
|
|
6
|
+
): CacheAttributes => {
|
|
7
|
+
return {
|
|
8
|
+
discardEmpty: extractedCacheAttributes.discardEmpty,
|
|
9
|
+
key: extractedCacheAttributes.key
|
|
10
|
+
.replaceAll('$bodyHash', extractedCacheAttributes.bodyHash)
|
|
11
|
+
.replaceAll('$valueHash', extractedCacheAttributes.valueHash),
|
|
12
|
+
ttl: extractedCacheAttributes.ttl,
|
|
13
|
+
};
|
|
14
|
+
};
|