@anatix/runtime 1.0.1 → 1.0.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/contracts/service-options.d.ts +0 -5
- package/dist/contracts/service-options.d.ts.map +1 -1
- package/dist/decorators/filters/exception-filter.config.d.ts +7 -0
- package/dist/decorators/filters/exception-filter.config.d.ts.map +1 -0
- package/dist/decorators/filters/exception-filter.config.js +9 -0
- package/dist/decorators/filters/exception-filter.config.js.map +1 -0
- package/dist/decorators/filters/global-exception.filter.d.ts +3 -2
- package/dist/decorators/filters/global-exception.filter.d.ts.map +1 -1
- package/dist/decorators/filters/global-exception.filter.js +14 -5
- package/dist/decorators/filters/global-exception.filter.js.map +1 -1
- package/dist/decorators/filters/index.d.ts +1 -0
- package/dist/decorators/filters/index.d.ts.map +1 -1
- package/dist/decorators/filters/index.js +1 -0
- package/dist/decorators/filters/index.js.map +1 -1
- package/dist/dtos/error-response.dto.d.ts +20 -0
- package/dist/dtos/error-response.dto.d.ts.map +1 -0
- package/dist/dtos/error-response.dto.js +42 -0
- package/dist/dtos/error-response.dto.js.map +1 -0
- package/dist/dtos/index.d.ts +3 -0
- package/dist/dtos/index.d.ts.map +1 -0
- package/dist/dtos/index.js +13 -0
- package/dist/dtos/index.js.map +1 -0
- package/dist/dtos/paginated-response.dto.d.ts +16 -0
- package/dist/dtos/paginated-response.dto.d.ts.map +1 -0
- package/dist/dtos/paginated-response.dto.js +31 -0
- package/dist/dtos/paginated-response.dto.js.map +1 -0
- package/dist/envelope/repositories/outbox.repository.d.ts.map +1 -1
- package/dist/envelope/repositories/outbox.repository.js +1 -1
- package/dist/envelope/repositories/outbox.repository.js.map +1 -1
- package/dist/envelope/services/inbox-retry.service.d.ts +3 -2
- package/dist/envelope/services/inbox-retry.service.d.ts.map +1 -1
- package/dist/envelope/services/inbox-retry.service.js +4 -0
- package/dist/envelope/services/inbox-retry.service.js.map +1 -1
- package/dist/envelope/services/outbox-dispatcher.service.d.ts +5 -2
- package/dist/envelope/services/outbox-dispatcher.service.d.ts.map +1 -1
- package/dist/envelope/services/outbox-dispatcher.service.js +61 -24
- package/dist/envelope/services/outbox-dispatcher.service.js.map +1 -1
- package/dist/envelope/tx-manager.d.ts +1 -1
- package/dist/envelope/tx-manager.d.ts.map +1 -1
- package/dist/event-bus/adapters/index.d.ts +4 -0
- package/dist/event-bus/adapters/index.d.ts.map +1 -0
- package/dist/event-bus/adapters/index.js +20 -0
- package/dist/event-bus/adapters/index.js.map +1 -0
- package/dist/event-bus/adapters/kafka.adapter.d.ts +28 -0
- package/dist/event-bus/adapters/kafka.adapter.d.ts.map +1 -0
- package/dist/event-bus/adapters/kafka.adapter.js +263 -0
- package/dist/event-bus/adapters/kafka.adapter.js.map +1 -0
- package/dist/event-bus/adapters/message-broker.interface.d.ts +39 -0
- package/dist/event-bus/adapters/message-broker.interface.d.ts.map +1 -0
- package/dist/event-bus/adapters/message-broker.interface.js +3 -0
- package/dist/event-bus/adapters/message-broker.interface.js.map +1 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.d.ts +21 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.d.ts.map +1 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.js +232 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.js.map +1 -0
- package/dist/event-bus/config/adapter.config.d.ts +65 -0
- package/dist/event-bus/config/adapter.config.d.ts.map +1 -0
- package/dist/event-bus/config/adapter.config.js +6 -0
- package/dist/event-bus/config/adapter.config.js.map +1 -0
- package/dist/event-bus/config/index.d.ts +2 -0
- package/dist/event-bus/config/index.d.ts.map +1 -0
- package/dist/event-bus/config/index.js +18 -0
- package/dist/event-bus/config/index.js.map +1 -0
- package/dist/event-bus/event-bus.config.d.ts +19 -0
- package/dist/event-bus/event-bus.config.d.ts.map +1 -1
- package/dist/event-bus/event-bus.config.js.map +1 -1
- package/dist/event-bus/services/event-bus.service.d.ts +7 -6
- package/dist/event-bus/services/event-bus.service.d.ts.map +1 -1
- package/dist/event-bus/services/event-bus.service.js +96 -210
- package/dist/event-bus/services/event-bus.service.js.map +1 -1
- package/dist/event-bus/types/event-bus-adapter.interface.d.ts +43 -0
- package/dist/event-bus/types/event-bus-adapter.interface.d.ts.map +1 -0
- package/dist/event-bus/types/event-bus-adapter.interface.js +3 -0
- package/dist/event-bus/types/event-bus-adapter.interface.js.map +1 -0
- package/dist/health/health.service.d.ts +1 -0
- package/dist/health/health.service.d.ts.map +1 -1
- package/dist/health/health.service.js +12 -3
- package/dist/health/health.service.js.map +1 -1
- package/dist/index.d.ts +7 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +61 -2
- package/dist/index.js.map +1 -1
- package/dist/monitoring/index.d.ts +2 -0
- package/dist/monitoring/index.d.ts.map +1 -0
- package/dist/monitoring/index.js +18 -0
- package/dist/monitoring/index.js.map +1 -0
- package/dist/proxy/config/proxy.config.d.ts +6 -2
- package/dist/proxy/config/proxy.config.d.ts.map +1 -1
- package/dist/proxy/config/proxy.config.js +6 -3
- package/dist/proxy/config/proxy.config.js.map +1 -1
- package/dist/proxy/methods/proxy-delete.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-delete.js +2 -2
- package/dist/proxy/methods/proxy-delete.js.map +1 -1
- package/dist/proxy/methods/proxy-get.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-get.js +2 -2
- package/dist/proxy/methods/proxy-get.js.map +1 -1
- package/dist/proxy/methods/proxy-patch.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-patch.js +2 -2
- package/dist/proxy/methods/proxy-patch.js.map +1 -1
- package/dist/proxy/methods/proxy-post.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-post.js +2 -2
- package/dist/proxy/methods/proxy-post.js.map +1 -1
- package/dist/proxy/methods/proxy-put.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-put.js +2 -2
- package/dist/proxy/methods/proxy-put.js.map +1 -1
- package/dist/repository/bulk.d.ts +12 -0
- package/dist/repository/bulk.d.ts.map +1 -0
- package/dist/repository/bulk.js +107 -0
- package/dist/repository/bulk.js.map +1 -0
- package/dist/repository/cursor.d.ts +12 -5
- package/dist/repository/cursor.d.ts.map +1 -1
- package/dist/repository/cursor.js +57 -29
- package/dist/repository/cursor.js.map +1 -1
- package/dist/repository/index.d.ts +6 -1
- package/dist/repository/index.d.ts.map +1 -1
- package/dist/repository/index.js +22 -15
- package/dist/repository/index.js.map +1 -1
- package/dist/repository/lock.d.ts +8 -0
- package/dist/repository/lock.d.ts.map +1 -0
- package/dist/repository/lock.js +35 -0
- package/dist/repository/lock.js.map +1 -0
- package/dist/repository/retry.d.ts +7 -0
- package/dist/repository/retry.d.ts.map +1 -0
- package/dist/repository/retry.js +43 -0
- package/dist/repository/retry.js.map +1 -0
- package/dist/repository/scope.d.ts +8 -0
- package/dist/repository/scope.d.ts.map +1 -0
- package/dist/repository/scope.js +16 -0
- package/dist/repository/scope.js.map +1 -0
- package/dist/result/index.d.ts +2 -0
- package/dist/result/index.d.ts.map +1 -0
- package/dist/result/index.js +16 -0
- package/dist/result/index.js.map +1 -0
- package/dist/result/result.d.ts +26 -0
- package/dist/result/result.d.ts.map +1 -0
- package/dist/result/result.js +73 -0
- package/dist/result/result.js.map +1 -0
- package/dist/security/bcrypt.adapter.d.ts +3 -0
- package/dist/security/bcrypt.adapter.d.ts.map +1 -1
- package/dist/security/bcrypt.adapter.js +6 -1
- package/dist/security/bcrypt.adapter.js.map +1 -1
- package/dist/security/index.d.ts +1 -0
- package/dist/security/index.d.ts.map +1 -1
- package/dist/security/index.js +1 -0
- package/dist/security/index.js.map +1 -1
- package/dist/security/security.config.d.ts +6 -0
- package/dist/security/security.config.d.ts.map +1 -0
- package/dist/security/security.config.js +8 -0
- package/dist/security/security.config.js.map +1 -0
- package/dist/service/cache.d.ts +11 -0
- package/dist/service/cache.d.ts.map +1 -0
- package/dist/service/cache.js +45 -0
- package/dist/service/cache.js.map +1 -0
- package/dist/service/circuit-breaker.d.ts +19 -0
- package/dist/service/circuit-breaker.d.ts.map +1 -0
- package/dist/service/circuit-breaker.js +73 -0
- package/dist/service/circuit-breaker.js.map +1 -0
- package/dist/service/enrichment.d.ts +8 -0
- package/dist/service/enrichment.d.ts.map +1 -0
- package/dist/service/enrichment.js +40 -0
- package/dist/service/enrichment.js.map +1 -0
- package/dist/service/idempotency.d.ts +8 -0
- package/dist/service/idempotency.d.ts.map +1 -0
- package/dist/service/idempotency.js +28 -0
- package/dist/service/idempotency.js.map +1 -0
- package/dist/service/index.d.ts +10 -0
- package/dist/service/index.d.ts.map +1 -0
- package/dist/service/index.js +45 -0
- package/dist/service/index.js.map +1 -0
- package/dist/service/projection.d.ts +14 -0
- package/dist/service/projection.d.ts.map +1 -0
- package/dist/service/projection.js +59 -0
- package/dist/service/projection.js.map +1 -0
- package/dist/service/rate-limit.d.ts +10 -0
- package/dist/service/rate-limit.d.ts.map +1 -0
- package/dist/service/rate-limit.js +42 -0
- package/dist/service/rate-limit.js.map +1 -0
- package/dist/service/retry.d.ts +8 -0
- package/dist/service/retry.d.ts.map +1 -0
- package/dist/service/retry.js +62 -0
- package/dist/service/retry.js.map +1 -0
- package/dist/service/timeout.d.ts +7 -0
- package/dist/service/timeout.d.ts.map +1 -0
- package/dist/service/timeout.js +39 -0
- package/dist/service/timeout.js.map +1 -0
- package/dist/service/transaction.d.ts +12 -0
- package/dist/service/transaction.d.ts.map +1 -0
- package/dist/service/transaction.js +17 -0
- package/dist/service/transaction.js.map +1 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/retry.d.ts +7 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +27 -0
- package/dist/utils/retry.js.map +1 -0
- package/package.json +25 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bcrypt.adapter.d.ts","sourceRoot":"","sources":["../../src/security/bcrypt.adapter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"bcrypt.adapter.d.ts","sourceRoot":"","sources":["../../src/security/bcrypt.adapter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAyB,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAG/E,qBAAa,aAAc,YAAW,cAAc;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,GAAE,cAAsC;IAErE,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAK1C,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;CAGjC"}
|
|
@@ -35,9 +35,14 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
35
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
36
|
exports.BcryptAdapter = void 0;
|
|
37
37
|
const bcrypt = __importStar(require("bcryptjs"));
|
|
38
|
+
const security_config_1 = require("./security.config");
|
|
38
39
|
class BcryptAdapter {
|
|
40
|
+
config;
|
|
41
|
+
constructor(config = security_config_1.defaultSecurityConfig) {
|
|
42
|
+
this.config = config;
|
|
43
|
+
}
|
|
39
44
|
async hash(plain) {
|
|
40
|
-
const rounds =
|
|
45
|
+
const rounds = this.config.hashSaltRounds ?? security_config_1.defaultSecurityConfig.hashSaltRounds;
|
|
41
46
|
return bcrypt.hash(plain, rounds);
|
|
42
47
|
}
|
|
43
48
|
isHashed(value) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bcrypt.adapter.js","sourceRoot":"","sources":["../../src/security/bcrypt.adapter.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAmC;
|
|
1
|
+
{"version":3,"file":"bcrypt.adapter.js","sourceRoot":"","sources":["../../src/security/bcrypt.adapter.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAmC;AAEnC,uDAA+E;AAG/E,MAAa,aAAa;IACK;IAA7B,YAA6B,SAAyB,uCAAqB;QAA9C,WAAM,GAAN,MAAM,CAAwC;IAAG,CAAC;IAE/E,KAAK,CAAC,IAAI,CAAC,KAAa;QACtB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,uCAAqB,CAAC,cAAe,CAAC;QACnF,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,QAAQ,CAAC,KAAa;QACpB,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChE,CAAC;CACF;AAXD,sCAWC"}
|
package/dist/security/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/security/index.ts"],"names":[],"mappings":"AACA,cAAc,cAAc,CAAC;AAG7B,cAAc,UAAU,CAAC;AAGzB,cAAc,kBAAkB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/security/index.ts"],"names":[],"mappings":"AACA,cAAc,cAAc,CAAC;AAG7B,cAAc,UAAU,CAAC;AAGzB,cAAc,mBAAmB,CAAC;AAGlC,cAAc,kBAAkB,CAAC"}
|
package/dist/security/index.js
CHANGED
|
@@ -16,5 +16,6 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./interfaces"), exports);
|
|
18
18
|
__exportStar(require("./tokens"), exports);
|
|
19
|
+
__exportStar(require("./security.config"), exports);
|
|
19
20
|
__exportStar(require("./bcrypt.adapter"), exports);
|
|
20
21
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/security/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,+CAA6B;AAG7B,2CAAyB;AAGzB,mDAAiC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/security/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,+CAA6B;AAG7B,2CAAyB;AAGzB,oDAAkC;AAGlC,mDAAiC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.config.d.ts","sourceRoot":"","sources":["../../src/security/security.config.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,cAAc;IAC7B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAGD,eAAO,MAAM,eAAe,oBAAoB,CAAC;AAGjD,eAAO,MAAM,qBAAqB,EAAE,cAEnC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.defaultSecurityConfig = exports.SECURITY_CONFIG = void 0;
|
|
4
|
+
exports.SECURITY_CONFIG = 'SECURITY_CONFIG';
|
|
5
|
+
exports.defaultSecurityConfig = {
|
|
6
|
+
hashSaltRounds: 12,
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=security.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.config.js","sourceRoot":"","sources":["../../src/security/security.config.ts"],"names":[],"mappings":";;;AAMa,QAAA,eAAe,GAAG,iBAAiB,CAAC;AAGpC,QAAA,qBAAqB,GAAmB;IACnD,cAAc,EAAE,EAAE;CACnB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface CacheAdapter {
|
|
2
|
+
get(key: string): Promise<any | null>;
|
|
3
|
+
set(key: string, value: any, ttlMs?: number): Promise<void>;
|
|
4
|
+
invalidate?(pattern?: string): Promise<void>;
|
|
5
|
+
}
|
|
6
|
+
export declare function withCacheReadThrough<T>(cache: CacheAdapter | undefined, key: string, loader: () => Promise<T>, ttlMs?: number): Promise<T>;
|
|
7
|
+
export declare function withCacheWriteThrough<T>(cache: CacheAdapter | undefined, key: string, value: T, writer: (value: T) => Promise<T>, ttlMs?: number): Promise<T>;
|
|
8
|
+
export declare function invalidateCache(cache: CacheAdapter | undefined, pattern?: string): Promise<void>;
|
|
9
|
+
export declare function cacheKey(...parts: (string | number | undefined)[]): string;
|
|
10
|
+
export declare function withCacheTags<T>(cache: CacheAdapter | undefined, key: string, _tags: string[], loader: () => Promise<T>, ttlMs?: number): Promise<T>;
|
|
11
|
+
//# sourceMappingURL=cache.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../src/service/cache.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,YAAY;IAE3B,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;IAEtC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5D,UAAU,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9C;AAsBD,wBAAsB,oBAAoB,CAAC,CAAC,EAC1C,KAAK,EAAE,YAAY,GAAG,SAAS,EAC/B,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACxB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,CAAC,CAAC,CAqBZ;AAwBD,wBAAsB,qBAAqB,CAAC,CAAC,EAC3C,KAAK,EAAE,YAAY,GAAG,SAAS,EAC/B,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,CAAC,EACR,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EAChC,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,CAAC,CAAC,CAYZ;AAoBD,wBAAsB,eAAe,CACnC,KAAK,EAAE,YAAY,GAAG,SAAS,EAC/B,OAAO,CAAC,EAAE,MAAM,GACf,OAAO,CAAC,IAAI,CAAC,CAUf;AAaD,wBAAgB,QAAQ,CAAC,GAAG,KAAK,EAAE,CAAC,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC,EAAE,GAAG,MAAM,CAE1E;AAwBD,wBAAsB,aAAa,CAAC,CAAC,EACnC,KAAK,EAAE,YAAY,GAAG,SAAS,EAC/B,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EAAE,EACf,MAAM,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACxB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,CAAC,CAAC,CAIZ"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.withCacheReadThrough = withCacheReadThrough;
|
|
4
|
+
exports.withCacheWriteThrough = withCacheWriteThrough;
|
|
5
|
+
exports.invalidateCache = invalidateCache;
|
|
6
|
+
exports.cacheKey = cacheKey;
|
|
7
|
+
exports.withCacheTags = withCacheTags;
|
|
8
|
+
async function withCacheReadThrough(cache, key, loader, ttlMs) {
|
|
9
|
+
if (!cache) {
|
|
10
|
+
return await loader();
|
|
11
|
+
}
|
|
12
|
+
const cached = await cache.get(key);
|
|
13
|
+
if (cached !== null && cached !== undefined) {
|
|
14
|
+
return cached;
|
|
15
|
+
}
|
|
16
|
+
const value = await loader();
|
|
17
|
+
cache.set(key, value, ttlMs).catch(() => {
|
|
18
|
+
});
|
|
19
|
+
return value;
|
|
20
|
+
}
|
|
21
|
+
async function withCacheWriteThrough(cache, key, value, writer, ttlMs) {
|
|
22
|
+
const result = await writer(value);
|
|
23
|
+
if (cache) {
|
|
24
|
+
cache.set(key, result, ttlMs).catch(() => {
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return result;
|
|
28
|
+
}
|
|
29
|
+
async function invalidateCache(cache, pattern) {
|
|
30
|
+
if (!cache?.invalidate) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
await cache.invalidate(pattern);
|
|
35
|
+
}
|
|
36
|
+
catch {
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function cacheKey(...parts) {
|
|
40
|
+
return parts.filter(p => p !== undefined && p !== null).join(':');
|
|
41
|
+
}
|
|
42
|
+
async function withCacheTags(cache, key, _tags, loader, ttlMs) {
|
|
43
|
+
return withCacheReadThrough(cache, key, loader, ttlMs);
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/service/cache.ts"],"names":[],"mappings":";;AAwCA,oDA0BC;AAwBD,sDAkBC;AAoBD,0CAaC;AAaD,4BAEC;AAwBD,sCAUC;AAtJM,KAAK,UAAU,oBAAoB,CACxC,KAA+B,EAC/B,GAAW,EACX,MAAwB,EACxB,KAAc;IAGd,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,MAAM,MAAM,EAAE,CAAC;IACxB,CAAC;IAGD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACpC,IAAI,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS,EAAE,CAAC;QAC5C,OAAO,MAAM,CAAC;IAChB,CAAC;IAGD,MAAM,KAAK,GAAG,MAAM,MAAM,EAAE,CAAC;IAG7B,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;IAExC,CAAC,CAAC,CAAC;IAEH,OAAO,KAAK,CAAC;AACf,CAAC;AAwBM,KAAK,UAAU,qBAAqB,CACzC,KAA+B,EAC/B,GAAW,EACX,KAAQ,EACR,MAAgC,EAChC,KAAc;IAGd,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC,CAAC;IAGnC,IAAI,KAAK,EAAE,CAAC;QACV,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;QAEzC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAoBM,KAAK,UAAU,eAAe,CACnC,KAA+B,EAC/B,OAAgB;IAEhB,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,CAAC;QACvB,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QACH,MAAM,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAAC,MAAM,CAAC;IAET,CAAC;AACH,CAAC;AAaD,SAAgB,QAAQ,CAAC,GAAG,KAAsC;IAChE,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACpE,CAAC;AAwBM,KAAK,UAAU,aAAa,CACjC,KAA+B,EAC/B,GAAW,EACX,KAAe,EACf,MAAwB,EACxB,KAAc;IAId,OAAO,oBAAoB,CAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AACzD,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export interface CircuitBreaker {
|
|
2
|
+
exec<T>(name: string, fn: () => Promise<T>, config?: CircuitBreakerConfig): Promise<T>;
|
|
3
|
+
}
|
|
4
|
+
export interface CircuitBreakerConfig {
|
|
5
|
+
threshold?: number;
|
|
6
|
+
timeout?: number;
|
|
7
|
+
resetCount?: number;
|
|
8
|
+
isFailure?: (error: any) => boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare class CircuitOpenError extends Error {
|
|
11
|
+
constructor(circuitName: string);
|
|
12
|
+
}
|
|
13
|
+
export declare function withCircuitBreaker<T>(circuit: CircuitBreaker | undefined, name: string, config: CircuitBreakerConfig, fn: () => Promise<T>): Promise<T>;
|
|
14
|
+
export declare function createCircuitBreakerWrapper<TArgs extends any[], TResult>(circuit: CircuitBreaker, name: string, config: CircuitBreakerConfig, fn: (...args: TArgs) => Promise<TResult>): (...args: TArgs) => Promise<TResult>;
|
|
15
|
+
export declare class SimpleCircuitBreaker implements CircuitBreaker {
|
|
16
|
+
private circuits;
|
|
17
|
+
exec<T>(name: string, fn: () => Promise<T>, config?: CircuitBreakerConfig): Promise<T>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=circuit-breaker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circuit-breaker.d.ts","sourceRoot":"","sources":["../../src/service/circuit-breaker.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,cAAc;IAQ7B,IAAI,CAAC,CAAC,EACJ,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,MAAM,CAAC,EAAE,oBAAoB,GAC5B,OAAO,CAAC,CAAC,CAAC,CAAC;CACf;AAKD,MAAM,WAAW,oBAAoB;IAEnC,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,OAAO,CAAC;CACrC;AAKD,qBAAa,gBAAiB,SAAQ,KAAK;gBAC7B,WAAW,EAAE,MAAM;CAIhC;AAsBD,wBAAsB,kBAAkB,CAAC,CAAC,EACxC,OAAO,EAAE,cAAc,GAAG,SAAS,EACnC,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,oBAAoB,EAC5B,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACnB,OAAO,CAAC,CAAC,CAAC,CAOZ;AAuBD,wBAAgB,2BAA2B,CAAC,KAAK,SAAS,GAAG,EAAE,EAAE,OAAO,EACtE,OAAO,EAAE,cAAc,EACvB,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,oBAAoB,EAC5B,EAAE,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,OAAO,CAAC,GACvC,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,OAAO,CAAC,CAItC;AAMD,qBAAa,oBAAqB,YAAW,cAAc;IACzD,OAAO,CAAC,QAAQ,CAQZ;IAEE,IAAI,CAAC,CAAC,EACV,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,MAAM,CAAC,EAAE,oBAAoB,GAC5B,OAAO,CAAC,CAAC,CAAC;CA2Dd"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SimpleCircuitBreaker = exports.CircuitOpenError = void 0;
|
|
4
|
+
exports.withCircuitBreaker = withCircuitBreaker;
|
|
5
|
+
exports.createCircuitBreakerWrapper = createCircuitBreakerWrapper;
|
|
6
|
+
class CircuitOpenError extends Error {
|
|
7
|
+
constructor(circuitName) {
|
|
8
|
+
super(`Circuit breaker "${circuitName}" is open`);
|
|
9
|
+
this.name = 'CircuitOpenError';
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.CircuitOpenError = CircuitOpenError;
|
|
13
|
+
async function withCircuitBreaker(circuit, name, config, fn) {
|
|
14
|
+
if (!circuit) {
|
|
15
|
+
return fn();
|
|
16
|
+
}
|
|
17
|
+
return circuit.exec(name, fn, config);
|
|
18
|
+
}
|
|
19
|
+
function createCircuitBreakerWrapper(circuit, name, config, fn) {
|
|
20
|
+
return async (...args) => {
|
|
21
|
+
return withCircuitBreaker(circuit, name, config, () => fn(...args));
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
class SimpleCircuitBreaker {
|
|
25
|
+
circuits = new Map();
|
|
26
|
+
async exec(name, fn, config) {
|
|
27
|
+
const threshold = config?.threshold ?? 5;
|
|
28
|
+
const timeout = config?.timeout ?? 60000;
|
|
29
|
+
const resetCount = config?.resetCount ?? 2;
|
|
30
|
+
const isFailure = config?.isFailure ?? (() => true);
|
|
31
|
+
let state = this.circuits.get(name);
|
|
32
|
+
if (!state) {
|
|
33
|
+
state = { state: 'closed', failures: 0, successes: 0 };
|
|
34
|
+
this.circuits.set(name, state);
|
|
35
|
+
}
|
|
36
|
+
if (state.state === 'open' && state.lastFailureTime) {
|
|
37
|
+
if (Date.now() - state.lastFailureTime >= timeout) {
|
|
38
|
+
state.state = 'half-open';
|
|
39
|
+
state.successes = 0;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if (state.state === 'open') {
|
|
43
|
+
throw new CircuitOpenError(name);
|
|
44
|
+
}
|
|
45
|
+
try {
|
|
46
|
+
const result = await fn();
|
|
47
|
+
if (state.state === 'half-open') {
|
|
48
|
+
state.successes++;
|
|
49
|
+
if (state.successes >= resetCount) {
|
|
50
|
+
state.state = 'closed';
|
|
51
|
+
state.failures = 0;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
state.failures = 0;
|
|
56
|
+
}
|
|
57
|
+
return result;
|
|
58
|
+
}
|
|
59
|
+
catch (error) {
|
|
60
|
+
if (!isFailure(error)) {
|
|
61
|
+
throw error;
|
|
62
|
+
}
|
|
63
|
+
state.failures++;
|
|
64
|
+
state.lastFailureTime = Date.now();
|
|
65
|
+
if (state.failures >= threshold) {
|
|
66
|
+
state.state = 'open';
|
|
67
|
+
}
|
|
68
|
+
throw error;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
exports.SimpleCircuitBreaker = SimpleCircuitBreaker;
|
|
73
|
+
//# sourceMappingURL=circuit-breaker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"circuit-breaker.js","sourceRoot":"","sources":["../../src/service/circuit-breaker.ts"],"names":[],"mappings":";;;AAsEA,gDAYC;AAuBD,kEASC;AAvED,MAAa,gBAAiB,SAAQ,KAAK;IACzC,YAAY,WAAmB;QAC7B,KAAK,CAAC,oBAAoB,WAAW,WAAW,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC;IACjC,CAAC;CACF;AALD,4CAKC;AAsBM,KAAK,UAAU,kBAAkB,CACtC,OAAmC,EACnC,IAAY,EACZ,MAA4B,EAC5B,EAAoB;IAGpB,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,EAAE,CAAC;IACd,CAAC;IAED,OAAO,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;AACxC,CAAC;AAuBD,SAAgB,2BAA2B,CACzC,OAAuB,EACvB,IAAY,EACZ,MAA4B,EAC5B,EAAwC;IAExC,OAAO,KAAK,EAAE,GAAG,IAAW,EAAE,EAAE;QAC9B,OAAO,kBAAkB,CAAC,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;IACtE,CAAC,CAAC;AACJ,CAAC;AAMD,MAAa,oBAAoB;IACvB,QAAQ,GAAG,IAAI,GAAG,EAQvB,CAAC;IAEJ,KAAK,CAAC,IAAI,CACR,IAAY,EACZ,EAAoB,EACpB,MAA6B;QAE7B,MAAM,SAAS,GAAG,MAAM,EAAE,SAAS,IAAI,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,MAAM,EAAE,OAAO,IAAI,KAAK,CAAC;QACzC,MAAM,UAAU,GAAG,MAAM,EAAE,UAAU,IAAI,CAAC,CAAC;QAC3C,MAAM,SAAS,GAAG,MAAM,EAAE,SAAS,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;QAGpD,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,KAAK,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC;YACvD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACjC,CAAC;QAGD,IAAI,KAAK,CAAC,KAAK,KAAK,MAAM,IAAI,KAAK,CAAC,eAAe,EAAE,CAAC;YACpD,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,eAAe,IAAI,OAAO,EAAE,CAAC;gBAClD,KAAK,CAAC,KAAK,GAAG,WAAW,CAAC;gBAC1B,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC;YACtB,CAAC;QACH,CAAC;QAGD,IAAI,KAAK,CAAC,KAAK,KAAK,MAAM,EAAE,CAAC;YAC3B,MAAM,IAAI,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;QAED,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,EAAE,EAAE,CAAC;YAG1B,IAAI,KAAK,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;gBAChC,KAAK,CAAC,SAAS,EAAE,CAAC;gBAClB,IAAI,KAAK,CAAC,SAAS,IAAI,UAAU,EAAE,CAAC;oBAClC,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC;oBACvB,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC;gBACrB,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,CAAC;YAED,OAAO,MAAM,CAAC;QAChB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAEf,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;gBACtB,MAAM,KAAK,CAAC;YACd,CAAC;YAGD,KAAK,CAAC,QAAQ,EAAE,CAAC;YACjB,KAAK,CAAC,eAAe,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YAGnC,IAAI,KAAK,CAAC,QAAQ,IAAI,SAAS,EAAE,CAAC;gBAChC,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC;YACvB,CAAC;YAED,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;CACF;AA1ED,oDA0EC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export type EnrichmentResolver = (entity: any) => Promise<any> | any;
|
|
2
|
+
export interface EnrichmentResolvers {
|
|
3
|
+
[fieldName: string]: EnrichmentResolver;
|
|
4
|
+
}
|
|
5
|
+
export declare function enrichFields<T>(data: T | T[], include: string[], resolvers: EnrichmentResolvers): Promise<T | T[]>;
|
|
6
|
+
export declare function fromQuery<T, R>(queryFn: (entity: T) => Promise<R>): EnrichmentResolver;
|
|
7
|
+
export declare function fromComputed<T, R>(computeFn: (entity: T) => R): EnrichmentResolver;
|
|
8
|
+
//# sourceMappingURL=enrichment.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enrichment.d.ts","sourceRoot":"","sources":["../../src/service/enrichment.ts"],"names":[],"mappings":"AAWA,MAAM,MAAM,kBAAkB,GAAG,CAAC,MAAM,EAAE,GAAG,KAAK,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;AAKrE,MAAM,WAAW,mBAAmB;IAClC,CAAC,SAAS,EAAE,MAAM,GAAG,kBAAkB,CAAC;CACzC;AAuED,wBAAsB,YAAY,CAAC,CAAC,EAClC,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,EACb,OAAO,EAAE,MAAM,EAAE,EACjB,SAAS,EAAE,mBAAmB,GAC7B,OAAO,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CA0BlB;AAqBD,wBAAgB,SAAS,CAAC,CAAC,EAAE,CAAC,EAC5B,OAAO,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,GACjC,kBAAkB,CAIpB;AAkBD,wBAAgB,YAAY,CAAC,CAAC,EAAE,CAAC,EAC/B,SAAS,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,GAC1B,kBAAkB,CAEpB"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.enrichFields = enrichFields;
|
|
4
|
+
exports.fromQuery = fromQuery;
|
|
5
|
+
exports.fromComputed = fromComputed;
|
|
6
|
+
async function enrichEntity(entity, include, resolvers) {
|
|
7
|
+
const enriched = { ...entity };
|
|
8
|
+
await Promise.all(include.map(async (fieldName) => {
|
|
9
|
+
const resolver = resolvers[fieldName];
|
|
10
|
+
if (typeof resolver === 'function') {
|
|
11
|
+
enriched[fieldName] = await resolver(entity);
|
|
12
|
+
}
|
|
13
|
+
}));
|
|
14
|
+
return enriched;
|
|
15
|
+
}
|
|
16
|
+
async function enrichFields(data, include, resolvers) {
|
|
17
|
+
if (!include || include.length === 0) {
|
|
18
|
+
return data;
|
|
19
|
+
}
|
|
20
|
+
if (!resolvers || Object.keys(resolvers).length === 0) {
|
|
21
|
+
return data;
|
|
22
|
+
}
|
|
23
|
+
const validFields = include.filter(field => typeof resolvers[field] === 'function');
|
|
24
|
+
if (validFields.length === 0) {
|
|
25
|
+
return data;
|
|
26
|
+
}
|
|
27
|
+
if (Array.isArray(data)) {
|
|
28
|
+
return await Promise.all(data.map(entity => enrichEntity(entity, validFields, resolvers)));
|
|
29
|
+
}
|
|
30
|
+
return await enrichEntity(data, validFields, resolvers);
|
|
31
|
+
}
|
|
32
|
+
function fromQuery(queryFn) {
|
|
33
|
+
return async (entity) => {
|
|
34
|
+
return await queryFn(entity);
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
function fromComputed(computeFn) {
|
|
38
|
+
return (entity) => computeFn(entity);
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=enrichment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enrichment.js","sourceRoot":"","sources":["../../src/service/enrichment.ts"],"names":[],"mappings":";;AAyFA,oCA8BC;AAqBD,8BAMC;AAkBD,oCAIC;AA/HD,KAAK,UAAU,YAAY,CACzB,MAAS,EACT,OAAiB,EACjB,SAA8B;IAE9B,MAAM,QAAQ,GAAQ,EAAE,GAAG,MAAM,EAAE,CAAC;IAEpC,MAAM,OAAO,CAAC,GAAG,CACf,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;QAC9B,MAAM,QAAQ,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;QACtC,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;YACnC,QAAQ,CAAC,SAAS,CAAC,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC,CAAC,CACH,CAAC;IAEF,OAAO,QAAQ,CAAC;AAClB,CAAC;AA+BM,KAAK,UAAU,YAAY,CAChC,IAAa,EACb,OAAiB,EACjB,SAA8B;IAG9B,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACrC,OAAO,IAAI,CAAC;IACd,CAAC;IAGD,IAAI,CAAC,SAAS,IAAI,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACtD,OAAO,IAAI,CAAC;IACd,CAAC;IAGD,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,SAAS,CAAC,KAAK,CAAC,KAAK,UAAU,CAAC,CAAC;IACpF,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,OAAO,IAAI,CAAC;IACd,CAAC;IAGD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,MAAM,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC,CACjE,CAAC;IACJ,CAAC;IAGD,OAAO,MAAM,YAAY,CAAC,IAAI,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;AAC1D,CAAC;AAqBD,SAAgB,SAAS,CACvB,OAAkC;IAElC,OAAO,KAAK,EAAE,MAAS,EAAE,EAAE;QACzB,OAAO,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC,CAAC;AACJ,CAAC;AAkBD,SAAgB,YAAY,CAC1B,SAA2B;IAE3B,OAAO,CAAC,MAAS,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface IdempotencyStore {
|
|
2
|
+
get(key: string): Promise<any | null>;
|
|
3
|
+
set(key: string, value: any, ttlMs?: number): Promise<void>;
|
|
4
|
+
}
|
|
5
|
+
export declare function checkIdempotency<T>(store: IdempotencyStore | undefined, key: string | undefined): Promise<T | null>;
|
|
6
|
+
export declare function storeIdempotentResult<T>(store: IdempotencyStore | undefined, key: string | undefined, value: T, ttlMs?: number): Promise<void>;
|
|
7
|
+
export declare function withIdempotency<T>(store: IdempotencyStore | undefined, key: string | undefined, fn: () => Promise<T>, ttlMs?: number): Promise<T>;
|
|
8
|
+
//# sourceMappingURL=idempotency.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idempotency.d.ts","sourceRoot":"","sources":["../../src/service/idempotency.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,gBAAgB;IAE/B,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;IAEtC,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7D;AAkBD,wBAAsB,gBAAgB,CAAC,CAAC,EACtC,KAAK,EAAE,gBAAgB,GAAG,SAAS,EACnC,GAAG,EAAE,MAAM,GAAG,SAAS,GACtB,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAOnB;AAsBD,wBAAsB,qBAAqB,CAAC,CAAC,EAC3C,KAAK,EAAE,gBAAgB,GAAG,SAAS,EACnC,GAAG,EAAE,MAAM,GAAG,SAAS,EACvB,KAAK,EAAE,CAAC,EACR,KAAK,GAAE,MAAiB,GACvB,OAAO,CAAC,IAAI,CAAC,CAMf;AAuBD,wBAAsB,eAAe,CAAC,CAAC,EACrC,KAAK,EAAE,gBAAgB,GAAG,SAAS,EACnC,GAAG,EAAE,MAAM,GAAG,SAAS,EACvB,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,CAAC,CAAC,CAcZ"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.checkIdempotency = checkIdempotency;
|
|
4
|
+
exports.storeIdempotentResult = storeIdempotentResult;
|
|
5
|
+
exports.withIdempotency = withIdempotency;
|
|
6
|
+
async function checkIdempotency(store, key) {
|
|
7
|
+
if (!key || !store) {
|
|
8
|
+
return null;
|
|
9
|
+
}
|
|
10
|
+
const cached = await store.get(key);
|
|
11
|
+
return cached ?? null;
|
|
12
|
+
}
|
|
13
|
+
async function storeIdempotentResult(store, key, value, ttlMs = 86400000) {
|
|
14
|
+
if (!key || !store) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
await store.set(key, value, ttlMs);
|
|
18
|
+
}
|
|
19
|
+
async function withIdempotency(store, key, fn, ttlMs) {
|
|
20
|
+
const cached = await checkIdempotency(store, key);
|
|
21
|
+
if (cached !== null) {
|
|
22
|
+
return cached;
|
|
23
|
+
}
|
|
24
|
+
const result = await fn();
|
|
25
|
+
await storeIdempotentResult(store, key, result, ttlMs);
|
|
26
|
+
return result;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=idempotency.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"idempotency.js","sourceRoot":"","sources":["../../src/service/idempotency.ts"],"names":[],"mappings":";;AAkCA,4CAUC;AAsBD,sDAWC;AAuBD,0CAmBC;AArFM,KAAK,UAAU,gBAAgB,CACpC,KAAmC,EACnC,GAAuB;IAEvB,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QACnB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACpC,OAAO,MAAM,IAAI,IAAI,CAAC;AACxB,CAAC;AAsBM,KAAK,UAAU,qBAAqB,CACzC,KAAmC,EACnC,GAAuB,EACvB,KAAQ,EACR,QAAgB,QAAQ;IAExB,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QACnB,OAAO;IACT,CAAC;IAED,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AACrC,CAAC;AAuBM,KAAK,UAAU,eAAe,CACnC,KAAmC,EACnC,GAAuB,EACvB,EAAoB,EACpB,KAAc;IAGd,MAAM,MAAM,GAAG,MAAM,gBAAgB,CAAI,KAAK,EAAE,GAAG,CAAC,CAAC;IACrD,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,OAAO,MAAM,CAAC;IAChB,CAAC;IAGD,MAAM,MAAM,GAAG,MAAM,EAAE,EAAE,CAAC;IAG1B,MAAM,qBAAqB,CAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;IAEvD,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export { withTransaction, withOptionalTransaction, type TxManager, type IsolationLevel, type TransactionOptions } from './transaction';
|
|
2
|
+
export { checkIdempotency, storeIdempotentResult, withIdempotency, type IdempotencyStore } from './idempotency';
|
|
3
|
+
export { withCacheReadThrough, withCacheWriteThrough, invalidateCache, cacheKey, withCacheTags, type CacheAdapter } from './cache';
|
|
4
|
+
export { enrichFields, fromQuery, fromComputed, type EnrichmentResolver, type EnrichmentResolvers } from './enrichment';
|
|
5
|
+
export { pick, omit, projectFields, createProjectionResolver, ProjectionResolver, type ProjectionPresets } from './projection';
|
|
6
|
+
export { withRetry, withRetryIf, type RetryConfig } from './retry';
|
|
7
|
+
export { withTimeout, withOptionalTimeout, createTimeoutWrapper, TimeoutError } from './timeout';
|
|
8
|
+
export { withRateLimit, withOptionalRateLimit, createRateLimitedWrapper, RateLimitError, type RateLimiter } from './rate-limit';
|
|
9
|
+
export { withCircuitBreaker, createCircuitBreakerWrapper, SimpleCircuitBreaker, CircuitOpenError, type CircuitBreaker, type CircuitBreakerConfig } from './circuit-breaker';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/service/index.ts"],"names":[],"mappings":"AAQA,OAAO,EACL,eAAe,EACf,uBAAuB,EACvB,KAAK,SAAS,EACd,KAAK,cAAc,EACnB,KAAK,kBAAkB,EACxB,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,gBAAgB,EAChB,qBAAqB,EACrB,eAAe,EACf,KAAK,gBAAgB,EACtB,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,eAAe,EACf,QAAQ,EACR,aAAa,EACb,KAAK,YAAY,EAClB,MAAM,SAAS,CAAC;AAGjB,OAAO,EACL,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,KAAK,kBAAkB,EACvB,KAAK,mBAAmB,EACzB,MAAM,cAAc,CAAC;AAGtB,OAAO,EACL,IAAI,EACJ,IAAI,EACJ,aAAa,EACb,wBAAwB,EACxB,kBAAkB,EAClB,KAAK,iBAAiB,EACvB,MAAM,cAAc,CAAC;AAGtB,OAAO,EACL,SAAS,EACT,WAAW,EACX,KAAK,WAAW,EACjB,MAAM,SAAS,CAAC;AAGjB,OAAO,EACL,WAAW,EACX,mBAAmB,EACnB,oBAAoB,EACpB,YAAY,EACb,MAAM,WAAW,CAAC;AAGnB,OAAO,EACL,aAAa,EACb,qBAAqB,EACrB,wBAAwB,EACxB,cAAc,EACd,KAAK,WAAW,EACjB,MAAM,cAAc,CAAC;AAGtB,OAAO,EACL,kBAAkB,EAClB,2BAA2B,EAC3B,oBAAoB,EACpB,gBAAgB,EAChB,KAAK,cAAc,EACnB,KAAK,oBAAoB,EAC1B,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CircuitOpenError = exports.SimpleCircuitBreaker = exports.createCircuitBreakerWrapper = exports.withCircuitBreaker = exports.RateLimitError = exports.createRateLimitedWrapper = exports.withOptionalRateLimit = exports.withRateLimit = exports.TimeoutError = exports.createTimeoutWrapper = exports.withOptionalTimeout = exports.withTimeout = exports.withRetryIf = exports.withRetry = exports.ProjectionResolver = exports.createProjectionResolver = exports.projectFields = exports.omit = exports.pick = exports.fromComputed = exports.fromQuery = exports.enrichFields = exports.withCacheTags = exports.cacheKey = exports.invalidateCache = exports.withCacheWriteThrough = exports.withCacheReadThrough = exports.withIdempotency = exports.storeIdempotentResult = exports.checkIdempotency = exports.withOptionalTransaction = exports.withTransaction = void 0;
|
|
4
|
+
var transaction_1 = require("./transaction");
|
|
5
|
+
Object.defineProperty(exports, "withTransaction", { enumerable: true, get: function () { return transaction_1.withTransaction; } });
|
|
6
|
+
Object.defineProperty(exports, "withOptionalTransaction", { enumerable: true, get: function () { return transaction_1.withOptionalTransaction; } });
|
|
7
|
+
var idempotency_1 = require("./idempotency");
|
|
8
|
+
Object.defineProperty(exports, "checkIdempotency", { enumerable: true, get: function () { return idempotency_1.checkIdempotency; } });
|
|
9
|
+
Object.defineProperty(exports, "storeIdempotentResult", { enumerable: true, get: function () { return idempotency_1.storeIdempotentResult; } });
|
|
10
|
+
Object.defineProperty(exports, "withIdempotency", { enumerable: true, get: function () { return idempotency_1.withIdempotency; } });
|
|
11
|
+
var cache_1 = require("./cache");
|
|
12
|
+
Object.defineProperty(exports, "withCacheReadThrough", { enumerable: true, get: function () { return cache_1.withCacheReadThrough; } });
|
|
13
|
+
Object.defineProperty(exports, "withCacheWriteThrough", { enumerable: true, get: function () { return cache_1.withCacheWriteThrough; } });
|
|
14
|
+
Object.defineProperty(exports, "invalidateCache", { enumerable: true, get: function () { return cache_1.invalidateCache; } });
|
|
15
|
+
Object.defineProperty(exports, "cacheKey", { enumerable: true, get: function () { return cache_1.cacheKey; } });
|
|
16
|
+
Object.defineProperty(exports, "withCacheTags", { enumerable: true, get: function () { return cache_1.withCacheTags; } });
|
|
17
|
+
var enrichment_1 = require("./enrichment");
|
|
18
|
+
Object.defineProperty(exports, "enrichFields", { enumerable: true, get: function () { return enrichment_1.enrichFields; } });
|
|
19
|
+
Object.defineProperty(exports, "fromQuery", { enumerable: true, get: function () { return enrichment_1.fromQuery; } });
|
|
20
|
+
Object.defineProperty(exports, "fromComputed", { enumerable: true, get: function () { return enrichment_1.fromComputed; } });
|
|
21
|
+
var projection_1 = require("./projection");
|
|
22
|
+
Object.defineProperty(exports, "pick", { enumerable: true, get: function () { return projection_1.pick; } });
|
|
23
|
+
Object.defineProperty(exports, "omit", { enumerable: true, get: function () { return projection_1.omit; } });
|
|
24
|
+
Object.defineProperty(exports, "projectFields", { enumerable: true, get: function () { return projection_1.projectFields; } });
|
|
25
|
+
Object.defineProperty(exports, "createProjectionResolver", { enumerable: true, get: function () { return projection_1.createProjectionResolver; } });
|
|
26
|
+
Object.defineProperty(exports, "ProjectionResolver", { enumerable: true, get: function () { return projection_1.ProjectionResolver; } });
|
|
27
|
+
var retry_1 = require("./retry");
|
|
28
|
+
Object.defineProperty(exports, "withRetry", { enumerable: true, get: function () { return retry_1.withRetry; } });
|
|
29
|
+
Object.defineProperty(exports, "withRetryIf", { enumerable: true, get: function () { return retry_1.withRetryIf; } });
|
|
30
|
+
var timeout_1 = require("./timeout");
|
|
31
|
+
Object.defineProperty(exports, "withTimeout", { enumerable: true, get: function () { return timeout_1.withTimeout; } });
|
|
32
|
+
Object.defineProperty(exports, "withOptionalTimeout", { enumerable: true, get: function () { return timeout_1.withOptionalTimeout; } });
|
|
33
|
+
Object.defineProperty(exports, "createTimeoutWrapper", { enumerable: true, get: function () { return timeout_1.createTimeoutWrapper; } });
|
|
34
|
+
Object.defineProperty(exports, "TimeoutError", { enumerable: true, get: function () { return timeout_1.TimeoutError; } });
|
|
35
|
+
var rate_limit_1 = require("./rate-limit");
|
|
36
|
+
Object.defineProperty(exports, "withRateLimit", { enumerable: true, get: function () { return rate_limit_1.withRateLimit; } });
|
|
37
|
+
Object.defineProperty(exports, "withOptionalRateLimit", { enumerable: true, get: function () { return rate_limit_1.withOptionalRateLimit; } });
|
|
38
|
+
Object.defineProperty(exports, "createRateLimitedWrapper", { enumerable: true, get: function () { return rate_limit_1.createRateLimitedWrapper; } });
|
|
39
|
+
Object.defineProperty(exports, "RateLimitError", { enumerable: true, get: function () { return rate_limit_1.RateLimitError; } });
|
|
40
|
+
var circuit_breaker_1 = require("./circuit-breaker");
|
|
41
|
+
Object.defineProperty(exports, "withCircuitBreaker", { enumerable: true, get: function () { return circuit_breaker_1.withCircuitBreaker; } });
|
|
42
|
+
Object.defineProperty(exports, "createCircuitBreakerWrapper", { enumerable: true, get: function () { return circuit_breaker_1.createCircuitBreakerWrapper; } });
|
|
43
|
+
Object.defineProperty(exports, "SimpleCircuitBreaker", { enumerable: true, get: function () { return circuit_breaker_1.SimpleCircuitBreaker; } });
|
|
44
|
+
Object.defineProperty(exports, "CircuitOpenError", { enumerable: true, get: function () { return circuit_breaker_1.CircuitOpenError; } });
|
|
45
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/service/index.ts"],"names":[],"mappings":";;;AAQA,6CAMuB;AALrB,8GAAA,eAAe,OAAA;AACf,sHAAA,uBAAuB,OAAA;AAOzB,6CAKuB;AAJrB,+GAAA,gBAAgB,OAAA;AAChB,oHAAA,qBAAqB,OAAA;AACrB,8GAAA,eAAe,OAAA;AAKjB,iCAOiB;AANf,6GAAA,oBAAoB,OAAA;AACpB,8GAAA,qBAAqB,OAAA;AACrB,wGAAA,eAAe,OAAA;AACf,iGAAA,QAAQ,OAAA;AACR,sGAAA,aAAa,OAAA;AAKf,2CAMsB;AALpB,0GAAA,YAAY,OAAA;AACZ,uGAAA,SAAS,OAAA;AACT,0GAAA,YAAY,OAAA;AAMd,2CAOsB;AANpB,kGAAA,IAAI,OAAA;AACJ,kGAAA,IAAI,OAAA;AACJ,2GAAA,aAAa,OAAA;AACb,sHAAA,wBAAwB,OAAA;AACxB,gHAAA,kBAAkB,OAAA;AAKpB,iCAIiB;AAHf,kGAAA,SAAS,OAAA;AACT,oGAAA,WAAW,OAAA;AAKb,qCAKmB;AAJjB,sGAAA,WAAW,OAAA;AACX,8GAAA,mBAAmB,OAAA;AACnB,+GAAA,oBAAoB,OAAA;AACpB,uGAAA,YAAY,OAAA;AAId,2CAMsB;AALpB,2GAAA,aAAa,OAAA;AACb,mHAAA,qBAAqB,OAAA;AACrB,sHAAA,wBAAwB,OAAA;AACxB,4GAAA,cAAc,OAAA;AAKhB,qDAO2B;AANzB,qHAAA,kBAAkB,OAAA;AAClB,8HAAA,2BAA2B,OAAA;AAC3B,uHAAA,oBAAoB,OAAA;AACpB,mHAAA,gBAAgB,OAAA"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export declare function pick<T extends object>(obj: T, keys: string[]): Partial<T>;
|
|
2
|
+
export declare function omit<T extends object>(obj: T, keys: string[]): Partial<T>;
|
|
3
|
+
export declare function projectFields<T extends object>(data: T | T[], fields: string[]): Partial<T> | Partial<T>[];
|
|
4
|
+
export interface ProjectionPresets {
|
|
5
|
+
[presetName: string]: string[];
|
|
6
|
+
}
|
|
7
|
+
export declare class ProjectionResolver {
|
|
8
|
+
private presets;
|
|
9
|
+
constructor(presets: ProjectionPresets);
|
|
10
|
+
resolve(projection?: string | string[]): string[] | undefined;
|
|
11
|
+
apply<T extends object>(data: T | T[], projection?: string | string[]): Partial<T> | Partial<T>[] | T | T[];
|
|
12
|
+
}
|
|
13
|
+
export declare function createProjectionResolver(presets: ProjectionPresets): ProjectionResolver;
|
|
14
|
+
//# sourceMappingURL=projection.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projection.d.ts","sourceRoot":"","sources":["../../src/service/projection.ts"],"names":[],"mappings":"AAqBA,wBAAgB,IAAI,CAAC,CAAC,SAAS,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAUzE;AAgBD,wBAAgB,IAAI,CAAC,CAAC,SAAS,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,CAQzE;AAyBD,wBAAgB,aAAa,CAAC,CAAC,SAAS,MAAM,EAC5C,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,EACb,MAAM,EAAE,MAAM,EAAE,GACf,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,CAU3B;AAMD,MAAM,WAAW,iBAAiB;IAChC,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;CAChC;AAMD,qBAAa,kBAAkB;IACjB,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,iBAAiB;IAmB9C,OAAO,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,EAAE,GAAG,SAAS;IAqB7D,KAAK,CAAC,CAAC,SAAS,MAAM,EACpB,IAAI,EAAE,CAAC,GAAG,CAAC,EAAE,EACb,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,GAC7B,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE;CASvC;AAmBD,wBAAgB,wBAAwB,CACtC,OAAO,EAAE,iBAAiB,GACzB,kBAAkB,CAEpB"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProjectionResolver = void 0;
|
|
4
|
+
exports.pick = pick;
|
|
5
|
+
exports.omit = omit;
|
|
6
|
+
exports.projectFields = projectFields;
|
|
7
|
+
exports.createProjectionResolver = createProjectionResolver;
|
|
8
|
+
function pick(obj, keys) {
|
|
9
|
+
const result = {};
|
|
10
|
+
for (const key of keys) {
|
|
11
|
+
if (key in obj) {
|
|
12
|
+
result[key] = obj[key];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
return result;
|
|
16
|
+
}
|
|
17
|
+
function omit(obj, keys) {
|
|
18
|
+
const result = { ...obj };
|
|
19
|
+
for (const key of keys) {
|
|
20
|
+
delete result[key];
|
|
21
|
+
}
|
|
22
|
+
return result;
|
|
23
|
+
}
|
|
24
|
+
function projectFields(data, fields) {
|
|
25
|
+
if (!fields || fields.length === 0) {
|
|
26
|
+
return data;
|
|
27
|
+
}
|
|
28
|
+
if (Array.isArray(data)) {
|
|
29
|
+
return data.map(item => pick(item, fields));
|
|
30
|
+
}
|
|
31
|
+
return pick(data, fields);
|
|
32
|
+
}
|
|
33
|
+
class ProjectionResolver {
|
|
34
|
+
presets;
|
|
35
|
+
constructor(presets) {
|
|
36
|
+
this.presets = presets;
|
|
37
|
+
}
|
|
38
|
+
resolve(projection) {
|
|
39
|
+
if (!projection) {
|
|
40
|
+
return undefined;
|
|
41
|
+
}
|
|
42
|
+
if (Array.isArray(projection)) {
|
|
43
|
+
return projection;
|
|
44
|
+
}
|
|
45
|
+
return this.presets[projection];
|
|
46
|
+
}
|
|
47
|
+
apply(data, projection) {
|
|
48
|
+
const fields = this.resolve(projection);
|
|
49
|
+
if (!fields) {
|
|
50
|
+
return data;
|
|
51
|
+
}
|
|
52
|
+
return projectFields(data, fields);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
exports.ProjectionResolver = ProjectionResolver;
|
|
56
|
+
function createProjectionResolver(presets) {
|
|
57
|
+
return new ProjectionResolver(presets);
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=projection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"projection.js","sourceRoot":"","sources":["../../src/service/projection.ts"],"names":[],"mappings":";;;AAqBA,oBAUC;AAgBD,oBAQC;AAyBD,sCAaC;AAsFD,4DAIC;AAlKD,SAAgB,IAAI,CAAmB,GAAM,EAAE,IAAc;IAC3D,MAAM,MAAM,GAAQ,EAAE,CAAC;IAEvB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;YACf,MAAM,CAAC,GAAG,CAAC,GAAI,GAAW,CAAC,GAAG,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAgBD,SAAgB,IAAI,CAAmB,GAAM,EAAE,IAAc;IAC3D,MAAM,MAAM,GAAQ,EAAE,GAAG,GAAG,EAAE,CAAC;IAE/B,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAyBD,SAAgB,aAAa,CAC3B,IAAa,EACb,MAAgB;IAEhB,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACxB,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;IAC9C,CAAC;IAED,OAAO,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AAC5B,CAAC;AAcD,MAAa,kBAAkB;IACT;IAApB,YAAoB,OAA0B;QAA1B,YAAO,GAAP,OAAO,CAAmB;IAAG,CAAC;IAmBlD,OAAO,CAAC,UAA8B;QACpC,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,OAAO,SAAS,CAAC;QACnB,CAAC;QAGD,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,CAAC;YAC9B,OAAO,UAAU,CAAC;QACpB,CAAC;QAGD,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IASD,KAAK,CACH,IAAa,EACb,UAA8B;QAE9B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAExC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,aAAa,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IACrC,CAAC;CACF;AArDD,gDAqDC;AAmBD,SAAgB,wBAAwB,CACtC,OAA0B;IAE1B,OAAO,IAAI,kBAAkB,CAAC,OAAO,CAAC,CAAC;AACzC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export interface RateLimiter {
|
|
2
|
+
consume(key: string, tokens?: number): Promise<boolean>;
|
|
3
|
+
}
|
|
4
|
+
export declare class RateLimitError extends Error {
|
|
5
|
+
constructor(key: string, tokens?: number);
|
|
6
|
+
}
|
|
7
|
+
export declare function withRateLimit<T>(limiter: RateLimiter | undefined, key: string, tokens: number | undefined, fn: () => Promise<T>): Promise<T>;
|
|
8
|
+
export declare function withOptionalRateLimit<T>(limiter: RateLimiter | undefined, key: string, tokens: number | undefined, fn: () => Promise<T>): Promise<T | undefined>;
|
|
9
|
+
export declare function createRateLimitedWrapper<TArgs extends any[], TResult>(limiter: RateLimiter, key: string | ((...args: TArgs) => string), tokens: number, fn: (...args: TArgs) => Promise<TResult>): (...args: TArgs) => Promise<TResult>;
|
|
10
|
+
//# sourceMappingURL=rate-limit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limit.d.ts","sourceRoot":"","sources":["../../src/service/rate-limit.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,WAAW;IAO1B,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACzD;AAKD,qBAAa,cAAe,SAAQ,KAAK;gBAC3B,GAAG,EAAE,MAAM,EAAE,MAAM,GAAE,MAAU;CAI5C;AAsBD,wBAAsB,aAAa,CAAC,CAAC,EACnC,OAAO,EAAE,WAAW,GAAG,SAAS,EAChC,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,MAAM,GAAG,SAAS,EAC1B,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACnB,OAAO,CAAC,CAAC,CAAC,CAiBZ;AAyBD,wBAAsB,qBAAqB,CAAC,CAAC,EAC3C,OAAO,EAAE,WAAW,GAAG,SAAS,EAChC,GAAG,EAAE,MAAM,EACX,MAAM,EAAE,MAAM,GAAG,SAAS,EAC1B,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACnB,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC,CASxB;AAuBD,wBAAgB,wBAAwB,CAAC,KAAK,SAAS,GAAG,EAAE,EAAE,OAAO,EACnE,OAAO,EAAE,WAAW,EACpB,GAAG,EAAE,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,MAAM,CAAC,EAC1C,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,OAAO,CAAC,GACvC,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,OAAO,CAAC,CAKtC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RateLimitError = void 0;
|
|
4
|
+
exports.withRateLimit = withRateLimit;
|
|
5
|
+
exports.withOptionalRateLimit = withOptionalRateLimit;
|
|
6
|
+
exports.createRateLimitedWrapper = createRateLimitedWrapper;
|
|
7
|
+
class RateLimitError extends Error {
|
|
8
|
+
constructor(key, tokens = 1) {
|
|
9
|
+
super(`Rate limit exceeded for key: ${key} (requested ${tokens} tokens)`);
|
|
10
|
+
this.name = 'RateLimitError';
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.RateLimitError = RateLimitError;
|
|
14
|
+
async function withRateLimit(limiter, key, tokens, fn) {
|
|
15
|
+
if (!limiter) {
|
|
16
|
+
return fn();
|
|
17
|
+
}
|
|
18
|
+
const tokensToConsume = tokens ?? 1;
|
|
19
|
+
const allowed = await limiter.consume(key, tokensToConsume);
|
|
20
|
+
if (!allowed) {
|
|
21
|
+
throw new RateLimitError(key, tokensToConsume);
|
|
22
|
+
}
|
|
23
|
+
return fn();
|
|
24
|
+
}
|
|
25
|
+
async function withOptionalRateLimit(limiter, key, tokens, fn) {
|
|
26
|
+
try {
|
|
27
|
+
return await withRateLimit(limiter, key, tokens, fn);
|
|
28
|
+
}
|
|
29
|
+
catch (error) {
|
|
30
|
+
if (error instanceof RateLimitError) {
|
|
31
|
+
return undefined;
|
|
32
|
+
}
|
|
33
|
+
throw error;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
function createRateLimitedWrapper(limiter, key, tokens, fn) {
|
|
37
|
+
return async (...args) => {
|
|
38
|
+
const rateLimitKey = typeof key === 'function' ? key(...args) : key;
|
|
39
|
+
return withRateLimit(limiter, rateLimitKey, tokens, () => fn(...args));
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=rate-limit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limit.js","sourceRoot":"","sources":["../../src/service/rate-limit.ts"],"names":[],"mappings":";;;AAmDA,sCAsBC;AAyBD,sDAcC;AAuBD,4DAUC;AAzHD,MAAa,cAAe,SAAQ,KAAK;IACvC,YAAY,GAAW,EAAE,SAAiB,CAAC;QACzC,KAAK,CAAC,gCAAgC,GAAG,eAAe,MAAM,UAAU,CAAC,CAAC;QAC1E,IAAI,CAAC,IAAI,GAAG,gBAAgB,CAAC;IAC/B,CAAC;CACF;AALD,wCAKC;AAsBM,KAAK,UAAU,aAAa,CACjC,OAAgC,EAChC,GAAW,EACX,MAA0B,EAC1B,EAAoB;IAGpB,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,EAAE,CAAC;IACd,CAAC;IAED,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,CAAC;IAGpC,MAAM,OAAO,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC;IAE5D,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,cAAc,CAAC,GAAG,EAAE,eAAe,CAAC,CAAC;IACjD,CAAC;IAGD,OAAO,EAAE,EAAE,CAAC;AACd,CAAC;AAyBM,KAAK,UAAU,qBAAqB,CACzC,OAAgC,EAChC,GAAW,EACX,MAA0B,EAC1B,EAAoB;IAEpB,IAAI,CAAC;QACH,OAAO,MAAM,aAAa,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IACvD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,cAAc,EAAE,CAAC;YACpC,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC;AAuBD,SAAgB,wBAAwB,CACtC,OAAoB,EACpB,GAA0C,EAC1C,MAAc,EACd,EAAwC;IAExC,OAAO,KAAK,EAAE,GAAG,IAAW,EAAE,EAAE;QAC9B,MAAM,YAAY,GAAG,OAAO,GAAG,KAAK,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QACpE,OAAO,aAAa,CAAC,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;IACzE,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface RetryConfig {
|
|
2
|
+
max?: number;
|
|
3
|
+
backoffMs?: number;
|
|
4
|
+
jitter?: number | boolean;
|
|
5
|
+
}
|
|
6
|
+
export declare function withRetry<T>(fn: () => Promise<T>, config?: RetryConfig): Promise<T>;
|
|
7
|
+
export declare function withRetryIf<T>(fn: () => Promise<T>, shouldRetry: (error: any) => boolean, config?: RetryConfig): Promise<T>;
|
|
8
|
+
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/service/retry.ts"],"names":[],"mappings":"AAUA,MAAM,WAAW,WAAW;IAE1B,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,SAAS,CAAC,EAAE,MAAM,CAAC;IAMnB,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;CAC3B;AA+BD,wBAAsB,SAAS,CAAC,CAAC,EAC/B,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,CAAC,CAAC,CAsCZ;AAoBD,wBAAsB,WAAW,CAAC,CAAC,EACjC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,WAAW,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,OAAO,EACpC,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,CAAC,CAAC,CAqCZ"}
|