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.
Files changed (51) hide show
  1. package/dist/Logger.d.ts +1 -0
  2. package/dist/Logger.d.ts.map +1 -0
  3. package/dist/Logger.js +1 -0
  4. package/dist/Logger.js.map +1 -0
  5. package/dist/factories/createQueryCacheInterceptor.d.ts +1 -0
  6. package/dist/factories/createQueryCacheInterceptor.d.ts.map +1 -0
  7. package/dist/factories/createQueryCacheInterceptor.js +1 -0
  8. package/dist/factories/createQueryCacheInterceptor.js.map +1 -0
  9. package/dist/factories/createQueryContext.d.ts +1 -0
  10. package/dist/factories/createQueryContext.d.ts.map +1 -0
  11. package/dist/factories/createQueryContext.js +1 -0
  12. package/dist/factories/createQueryContext.js.map +1 -0
  13. package/dist/factories/index.d.ts +1 -0
  14. package/dist/factories/index.d.ts.map +1 -0
  15. package/dist/factories/index.js +1 -0
  16. package/dist/factories/index.js.map +1 -0
  17. package/dist/index.d.ts +1 -0
  18. package/dist/index.d.ts.map +1 -0
  19. package/dist/index.js +1 -0
  20. package/dist/index.js.map +1 -0
  21. package/dist/utilities/extractCacheAttributes.d.ts +1 -0
  22. package/dist/utilities/extractCacheAttributes.d.ts.map +1 -0
  23. package/dist/utilities/extractCacheAttributes.js +1 -0
  24. package/dist/utilities/extractCacheAttributes.js.map +1 -0
  25. package/dist/utilities/extractCacheAttributes.test.d.ts +1 -0
  26. package/dist/utilities/extractCacheAttributes.test.d.ts.map +1 -0
  27. package/dist/utilities/extractCacheAttributes.test.js +1 -0
  28. package/dist/utilities/extractCacheAttributes.test.js.map +1 -0
  29. package/dist/utilities/index.d.ts +1 -0
  30. package/dist/utilities/index.d.ts.map +1 -0
  31. package/dist/utilities/index.js +1 -0
  32. package/dist/utilities/index.js.map +1 -0
  33. package/dist/utilities/normalizeCacheAttributes.d.ts +1 -0
  34. package/dist/utilities/normalizeCacheAttributes.d.ts.map +1 -0
  35. package/dist/utilities/normalizeCacheAttributes.js +1 -0
  36. package/dist/utilities/normalizeCacheAttributes.js.map +1 -0
  37. package/dist/utilities/normalizeCacheAttributes.test.d.ts +1 -0
  38. package/dist/utilities/normalizeCacheAttributes.test.d.ts.map +1 -0
  39. package/dist/utilities/normalizeCacheAttributes.test.js +1 -0
  40. package/dist/utilities/normalizeCacheAttributes.test.js.map +1 -0
  41. package/package.json +6 -6
  42. package/src/Logger.ts +5 -0
  43. package/src/factories/createQueryCacheInterceptor.ts +129 -0
  44. package/src/factories/createQueryContext.ts +16 -0
  45. package/src/factories/index.ts +1 -0
  46. package/src/index.ts +1 -0
  47. package/src/utilities/extractCacheAttributes.test.ts +92 -0
  48. package/src/utilities/extractCacheAttributes.ts +56 -0
  49. package/src/utilities/index.ts +2 -0
  50. package/src/utilities/normalizeCacheAttributes.test.ts +19 -0
  51. package/src/utilities/normalizeCacheAttributes.ts +14 -0
package/dist/Logger.d.ts CHANGED
@@ -1 +1,2 @@
1
1
  export declare const Logger: import("roarr").Logger<import("roarr/dist/types").JsonObject>;
2
+ //# sourceMappingURL=Logger.d.ts.map
@@ -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
@@ -5,3 +5,4 @@ const roarr_1 = require("roarr");
5
5
  exports.Logger = roarr_1.Roarr.child({
6
6
  package: 'slonik-interceptor-query-cache',
7
7
  });
8
+ //# sourceMappingURL=Logger.js.map
@@ -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"}
@@ -13,3 +13,4 @@ type ConfigurationInput = {
13
13
  };
14
14
  export declare const createQueryCacheInterceptor: (configurationInput: ConfigurationInput) => Interceptor;
15
15
  export {};
16
+ //# sourceMappingURL=createQueryCacheInterceptor.d.ts.map
@@ -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"}
@@ -62,3 +62,4 @@ const createQueryCacheInterceptor = (configurationInput) => {
62
62
  };
63
63
  };
64
64
  exports.createQueryCacheInterceptor = createQueryCacheInterceptor;
65
+ //# sourceMappingURL=createQueryCacheInterceptor.js.map
@@ -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"}
@@ -1,3 +1,4 @@
1
1
  import { type QueryContext } from 'slonik';
2
2
  declare const _default: () => QueryContext;
3
3
  export default _default;
4
+ //# sourceMappingURL=createQueryContext.d.ts.map
@@ -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"}
@@ -14,3 +14,4 @@ exports.default = () => {
14
14
  poolId: '1',
15
15
  };
16
16
  };
17
+ //# sourceMappingURL=createQueryContext.js.map
@@ -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"}
@@ -1 +1,2 @@
1
1
  export { createQueryCacheInterceptor } from './createQueryCacheInterceptor';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}
@@ -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
@@ -1 +1,2 @@
1
1
  export { createQueryCacheInterceptor } from './factories';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}
@@ -7,3 +7,4 @@ export type ExtractedCacheAttributes = {
7
7
  valueHash: string;
8
8
  };
9
9
  export declare const extractCacheAttributes: (subject: string, values: readonly PrimitiveValueExpression[]) => ExtractedCacheAttributes | null;
10
+ //# sourceMappingURL=extractCacheAttributes.d.ts.map
@@ -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"}
@@ -37,3 +37,4 @@ const extractCacheAttributes = (subject, values) => {
37
37
  return null;
38
38
  };
39
39
  exports.extractCacheAttributes = extractCacheAttributes;
40
+ //# sourceMappingURL=extractCacheAttributes.js.map
@@ -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"}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=extractCacheAttributes.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractCacheAttributes.test.d.ts","sourceRoot":"","sources":["../../src/utilities/extractCacheAttributes.test.ts"],"names":[],"mappings":""}
@@ -74,3 +74,4 @@ const ava_1 = __importDefault(require("ava"));
74
74
  valueHash: 'ec784925b52067bce01fd820',
75
75
  });
76
76
  });
77
+ //# sourceMappingURL=extractCacheAttributes.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractCacheAttributes.test.js","sourceRoot":"","sources":["../../src/utilities/extractCacheAttributes.test.ts"],"names":[],"mappings":"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"}
@@ -1,2 +1,3 @@
1
1
  export { extractCacheAttributes } from './extractCacheAttributes';
2
2
  export { normalizeCacheAttributes } from './normalizeCacheAttributes';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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"}
@@ -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"}
@@ -11,3 +11,4 @@ const normalizeCacheAttributes = (extractedCacheAttributes) => {
11
11
  };
12
12
  };
13
13
  exports.normalizeCacheAttributes = normalizeCacheAttributes;
14
+ //# sourceMappingURL=normalizeCacheAttributes.js.map
@@ -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"}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=normalizeCacheAttributes.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"normalizeCacheAttributes.test.d.ts","sourceRoot":"","sources":["../../src/utilities/normalizeCacheAttributes.test.ts"],"names":[],"mappings":""}
@@ -18,3 +18,4 @@ const ava_1 = __importDefault(require("ava"));
18
18
  ttl: 60,
19
19
  });
20
20
  });
21
+ //# sourceMappingURL=normalizeCacheAttributes.test.js.map
@@ -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/src/index.js",
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": "del-cli ./dist && tsc",
63
+ "build": "rm -fr ./dist && tsc --project tsconfig.build.json",
64
64
  "lint:eslint": "eslint .",
65
- "lint:tsc": "tsc --noEmit",
65
+ "lint:tsc": "tsc",
66
66
  "prepare": "husky install",
67
67
  "test:ava": "nyc ava --verbose --serial"
68
68
  },
69
- "typings": "./dist/src/index.d.ts",
70
- "version": "3.3.0"
69
+ "types": "./dist/index.d.ts",
70
+ "version": "3.3.2"
71
71
  }
package/src/Logger.ts ADDED
@@ -0,0 +1,5 @@
1
+ import { Roarr } from 'roarr';
2
+
3
+ export const Logger = Roarr.child({
4
+ package: 'slonik-interceptor-query-cache',
5
+ });
@@ -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,2 @@
1
+ export { extractCacheAttributes } from './extractCacheAttributes';
2
+ export { normalizeCacheAttributes } from './normalizeCacheAttributes';
@@ -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
+ };