@anatix/runtime 1.0.0 → 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/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/{configs → contracts}/index.js +1 -2
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/service-options.d.ts +15 -0
- package/dist/contracts/service-options.d.ts.map +1 -0
- package/dist/{configs/service-runtime.js → contracts/service-options.js} +1 -1
- package/dist/contracts/service-options.js.map +1 -0
- 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/envelope.config.d.ts +17 -0
- package/dist/envelope/envelope.config.d.ts.map +1 -0
- package/dist/envelope/envelope.config.js +5 -0
- package/dist/envelope/envelope.config.js.map +1 -0
- package/dist/envelope/index.d.ts +2 -0
- package/dist/envelope/index.d.ts.map +1 -1
- package/dist/envelope/index.js +2 -0
- package/dist/envelope/index.js.map +1 -1
- 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 +6 -3
- package/dist/envelope/services/inbox-retry.service.d.ts.map +1 -1
- package/dist/envelope/services/inbox-retry.service.js +20 -7
- package/dist/envelope/services/inbox-retry.service.js.map +1 -1
- package/dist/envelope/services/index.d.ts +1 -0
- package/dist/envelope/services/index.d.ts.map +1 -1
- package/dist/envelope/services/index.js +1 -0
- package/dist/envelope/services/index.js.map +1 -1
- package/dist/envelope/services/outbox-dispatcher.service.d.ts +8 -4
- package/dist/envelope/services/outbox-dispatcher.service.d.ts.map +1 -1
- package/dist/envelope/services/outbox-dispatcher.service.js +82 -22
- package/dist/envelope/services/outbox-dispatcher.service.js.map +1 -1
- package/dist/envelope/tx-manager.d.ts +14 -0
- package/dist/envelope/tx-manager.d.ts.map +1 -0
- package/dist/envelope/tx-manager.js +20 -0
- package/dist/envelope/tx-manager.js.map +1 -0
- 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/{configs/service-repo-configs.js → event-bus/adapters/message-broker.interface.js} +1 -1
- 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 +36 -0
- package/dist/event-bus/event-bus.config.d.ts.map +1 -0
- package/dist/event-bus/event-bus.config.js +17 -0
- package/dist/event-bus/event-bus.config.js.map +1 -0
- package/dist/event-bus/index.d.ts +1 -0
- package/dist/event-bus/index.d.ts.map +1 -1
- package/dist/event-bus/index.js +1 -0
- package/dist/event-bus/index.js.map +1 -1
- package/dist/event-bus/modules/event-bus.module.d.ts.map +1 -1
- package/dist/event-bus/modules/event-bus.module.js +9 -2
- package/dist/event-bus/modules/event-bus.module.js.map +1 -1
- package/dist/event-bus/services/event-bus.service.d.ts +10 -5
- package/dist/event-bus/services/event-bus.service.d.ts.map +1 -1
- package/dist/event-bus/services/event-bus.service.js +110 -185
- 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/guards/base/index.d.ts +0 -1
- package/dist/guards/base/index.d.ts.map +1 -1
- package/dist/guards/base/index.js +0 -1
- package/dist/guards/base/index.js.map +1 -1
- package/dist/guards/base/jwt-auth.guard.d.ts +6 -1
- package/dist/guards/base/jwt-auth.guard.d.ts.map +1 -1
- package/dist/guards/base/jwt-auth.guard.js +32 -20
- package/dist/guards/base/jwt-auth.guard.js.map +1 -1
- package/dist/guards/base/permissions.guard.d.ts +1 -0
- package/dist/guards/base/permissions.guard.d.ts.map +1 -1
- package/dist/guards/base/permissions.guard.js +6 -2
- package/dist/guards/base/permissions.guard.js.map +1 -1
- package/dist/guards/types/base-roles.enum.d.ts +6 -0
- package/dist/guards/types/base-roles.enum.d.ts.map +1 -0
- package/dist/guards/types/base-roles.enum.js +10 -0
- package/dist/guards/types/base-roles.enum.js.map +1 -0
- package/dist/guards/types/index.d.ts +2 -0
- package/dist/guards/types/index.d.ts.map +1 -1
- package/dist/guards/types/index.js +2 -0
- package/dist/guards/types/index.js.map +1 -1
- package/dist/guards/types/tokens.constant.d.ts +5 -0
- package/dist/guards/types/tokens.constant.d.ts.map +1 -0
- package/dist/guards/types/tokens.constant.js +7 -0
- package/dist/guards/types/tokens.constant.js.map +1 -0
- package/dist/guards/utils/token.util.d.ts.map +1 -1
- package/dist/guards/utils/token.util.js +14 -9
- package/dist/guards/utils/token.util.js.map +1 -1
- 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/health/index.d.ts +2 -0
- package/dist/health/index.d.ts.map +1 -0
- package/dist/health/index.js +18 -0
- package/dist/health/index.js.map +1 -0
- package/dist/index.d.ts +8 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +62 -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 +13 -0
- package/dist/repository/cursor.d.ts.map +1 -0
- package/dist/repository/cursor.js +73 -0
- package/dist/repository/cursor.js.map +1 -0
- package/dist/repository/index.d.ts +7 -0
- package/dist/repository/index.d.ts.map +1 -0
- package/dist/repository/index.js +25 -0
- package/dist/repository/index.js.map +1 -0
- 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 +9 -0
- package/dist/security/bcrypt.adapter.d.ts.map +1 -0
- package/dist/security/bcrypt.adapter.js +53 -0
- package/dist/security/bcrypt.adapter.js.map +1 -0
- package/dist/security/index.d.ts +2 -0
- package/dist/security/index.d.ts.map +1 -1
- package/dist/security/index.js +2 -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 +52 -15
- package/dist/configs/env-validation.d.ts +0 -2
- package/dist/configs/env-validation.d.ts.map +0 -1
- package/dist/configs/env-validation.js +0 -49
- package/dist/configs/env-validation.js.map +0 -1
- package/dist/configs/index.d.ts +0 -3
- package/dist/configs/index.d.ts.map +0 -1
- package/dist/configs/index.js.map +0 -1
- package/dist/configs/service-repo-configs.d.ts +0 -13
- package/dist/configs/service-repo-configs.d.ts.map +0 -1
- package/dist/configs/service-repo-configs.js.map +0 -1
- package/dist/configs/service-runtime.d.ts +0 -19
- package/dist/configs/service-runtime.d.ts.map +0 -1
- package/dist/configs/service-runtime.js.map +0 -1
- package/dist/guards/base/roles.guard.d.ts +0 -10
- package/dist/guards/base/roles.guard.d.ts.map +0 -1
- package/dist/guards/base/roles.guard.js +0 -58
- package/dist/guards/base/roles.guard.js.map +0 -1
|
@@ -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"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.withRetry = withRetry;
|
|
4
|
+
exports.withRetryIf = withRetryIf;
|
|
5
|
+
async function withRetry(fn, config) {
|
|
6
|
+
const max = Math.max(1, config?.max ?? 3);
|
|
7
|
+
const base = Math.max(0, config?.backoffMs ?? 100);
|
|
8
|
+
const jitterAmp = typeof config?.jitter === 'number'
|
|
9
|
+
? Math.max(0, config.jitter)
|
|
10
|
+
: config?.jitter
|
|
11
|
+
? base
|
|
12
|
+
: 0;
|
|
13
|
+
let lastErr;
|
|
14
|
+
for (let i = 0; i < max; i++) {
|
|
15
|
+
try {
|
|
16
|
+
return await fn();
|
|
17
|
+
}
|
|
18
|
+
catch (e) {
|
|
19
|
+
lastErr = e;
|
|
20
|
+
if (i < max - 1) {
|
|
21
|
+
const backoff = base * i;
|
|
22
|
+
const jitter = jitterAmp > 0 ? Math.floor(Math.random() * jitterAmp) : 0;
|
|
23
|
+
const delay = backoff + jitter;
|
|
24
|
+
if (delay > 0) {
|
|
25
|
+
await new Promise(resolve => setTimeout(resolve, delay));
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
throw lastErr;
|
|
31
|
+
}
|
|
32
|
+
async function withRetryIf(fn, shouldRetry, config) {
|
|
33
|
+
const max = Math.max(1, config?.max ?? 3);
|
|
34
|
+
const base = Math.max(0, config?.backoffMs ?? 100);
|
|
35
|
+
const jitterAmp = typeof config?.jitter === 'number'
|
|
36
|
+
? Math.max(0, config.jitter)
|
|
37
|
+
: config?.jitter
|
|
38
|
+
? base
|
|
39
|
+
: 0;
|
|
40
|
+
let lastErr;
|
|
41
|
+
for (let i = 0; i < max; i++) {
|
|
42
|
+
try {
|
|
43
|
+
return await fn();
|
|
44
|
+
}
|
|
45
|
+
catch (e) {
|
|
46
|
+
lastErr = e;
|
|
47
|
+
if (!shouldRetry(e)) {
|
|
48
|
+
throw e;
|
|
49
|
+
}
|
|
50
|
+
if (i < max - 1) {
|
|
51
|
+
const backoff = base * i;
|
|
52
|
+
const jitter = jitterAmp > 0 ? Math.floor(Math.random() * jitterAmp) : 0;
|
|
53
|
+
const delay = backoff + jitter;
|
|
54
|
+
if (delay > 0) {
|
|
55
|
+
await new Promise(resolve => setTimeout(resolve, delay));
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
throw lastErr;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=retry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.js","sourceRoot":"","sources":["../../src/service/retry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare class TimeoutError extends Error {
|
|
2
|
+
constructor(timeoutMs: number);
|
|
3
|
+
}
|
|
4
|
+
export declare function withTimeout<T>(fn: () => Promise<T>, timeoutMs?: number): Promise<T>;
|
|
5
|
+
export declare function withOptionalTimeout<T>(fn: () => Promise<T>, timeoutMs?: number): Promise<T | undefined>;
|
|
6
|
+
export declare function createTimeoutWrapper<TArgs extends any[], TResult>(fn: (...args: TArgs) => Promise<TResult>, timeoutMs: number): (...args: TArgs) => Promise<TResult>;
|
|
7
|
+
//# sourceMappingURL=timeout.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timeout.d.ts","sourceRoot":"","sources":["../../src/service/timeout.ts"],"names":[],"mappings":"AAUA,qBAAa,YAAa,SAAQ,KAAK;gBACzB,SAAS,EAAE,MAAM;CAI9B;AAwBD,wBAAsB,WAAW,CAAC,CAAC,EACjC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,CAAC,CAAC,CAYZ;AAqBD,wBAAsB,mBAAmB,CAAC,CAAC,EACzC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC,CASxB;AAoBD,wBAAgB,oBAAoB,CAAC,KAAK,SAAS,GAAG,EAAE,EAAE,OAAO,EAC/D,EAAE,EAAE,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,OAAO,CAAC,EACxC,SAAS,EAAE,MAAM,GAChB,CAAC,GAAG,IAAI,EAAE,KAAK,KAAK,OAAO,CAAC,OAAO,CAAC,CAItC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TimeoutError = void 0;
|
|
4
|
+
exports.withTimeout = withTimeout;
|
|
5
|
+
exports.withOptionalTimeout = withOptionalTimeout;
|
|
6
|
+
exports.createTimeoutWrapper = createTimeoutWrapper;
|
|
7
|
+
class TimeoutError extends Error {
|
|
8
|
+
constructor(timeoutMs) {
|
|
9
|
+
super(`Operation timed out after ${timeoutMs}ms`);
|
|
10
|
+
this.name = 'TimeoutError';
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.TimeoutError = TimeoutError;
|
|
14
|
+
async function withTimeout(fn, timeoutMs) {
|
|
15
|
+
if (!timeoutMs || timeoutMs <= 0) {
|
|
16
|
+
return fn();
|
|
17
|
+
}
|
|
18
|
+
return await Promise.race([
|
|
19
|
+
fn(),
|
|
20
|
+
new Promise((_, reject) => setTimeout(() => reject(new TimeoutError(timeoutMs)), timeoutMs))
|
|
21
|
+
]);
|
|
22
|
+
}
|
|
23
|
+
async function withOptionalTimeout(fn, timeoutMs) {
|
|
24
|
+
try {
|
|
25
|
+
return await withTimeout(fn, timeoutMs);
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
if (error instanceof TimeoutError) {
|
|
29
|
+
return undefined;
|
|
30
|
+
}
|
|
31
|
+
throw error;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function createTimeoutWrapper(fn, timeoutMs) {
|
|
35
|
+
return async (...args) => {
|
|
36
|
+
return withTimeout(() => fn(...args), timeoutMs);
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=timeout.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timeout.js","sourceRoot":"","sources":["../../src/service/timeout.ts"],"names":[],"mappings":";;;AAuCA,kCAeC;AAqBD,kDAYC;AAoBD,oDAOC;AAxGD,MAAa,YAAa,SAAQ,KAAK;IACrC,YAAY,SAAiB;QAC3B,KAAK,CAAC,6BAA6B,SAAS,IAAI,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC;IAC7B,CAAC;CACF;AALD,oCAKC;AAwBM,KAAK,UAAU,WAAW,CAC/B,EAAoB,EACpB,SAAkB;IAGlB,IAAI,CAAC,SAAS,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QACjC,OAAO,EAAE,EAAE,CAAC;IACd,CAAC;IAED,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC;QACxB,EAAE,EAAE;QACJ,IAAI,OAAO,CAAQ,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,CAC/B,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CACjE;KACF,CAAC,CAAC;AACL,CAAC;AAqBM,KAAK,UAAU,mBAAmB,CACvC,EAAoB,EACpB,SAAkB;IAElB,IAAI,CAAC;QACH,OAAO,MAAM,WAAW,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;IAC1C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,YAAY,EAAE,CAAC;YAClC,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC;AAoBD,SAAgB,oBAAoB,CAClC,EAAwC,EACxC,SAAiB;IAEjB,OAAO,KAAK,EAAE,GAAG,IAAW,EAAE,EAAE;QAC9B,OAAO,WAAW,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,SAAS,CAAC,CAAC;IACnD,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface TxManager<R> {
|
|
2
|
+
transaction<T>(fn: (repo: R) => Promise<T>, options?: {
|
|
3
|
+
isolation?: string;
|
|
4
|
+
}): Promise<T>;
|
|
5
|
+
}
|
|
6
|
+
export type IsolationLevel = 'READ UNCOMMITTED' | 'READ COMMITTED' | 'REPEATABLE READ' | 'SERIALIZABLE';
|
|
7
|
+
export interface TransactionOptions {
|
|
8
|
+
isolation?: IsolationLevel | string;
|
|
9
|
+
}
|
|
10
|
+
export declare function withTransaction<T, R>(tm: TxManager<R> | undefined, fn: (repo: R) => Promise<T>, options?: TransactionOptions): Promise<T>;
|
|
11
|
+
export declare function withOptionalTransaction<T, R>(tm: TxManager<R> | undefined, repo: R, fn: (repo: R) => Promise<T>, options?: TransactionOptions): Promise<T>;
|
|
12
|
+
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/service/transaction.ts"],"names":[],"mappings":"AAWA,MAAM,WAAW,SAAS,CAAC,CAAC;IAC1B,WAAW,CAAC,CAAC,EACX,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EAC3B,OAAO,CAAC,EAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,GAC/B,OAAO,CAAC,CAAC,CAAC,CAAC;CACf;AAKD,MAAM,MAAM,cAAc,GACtB,kBAAkB,GAClB,gBAAgB,GAChB,iBAAiB,GACjB,cAAc,CAAC;AAKnB,MAAM,WAAW,kBAAkB;IAEjC,SAAS,CAAC,EAAE,cAAc,GAAG,MAAM,CAAC;CACrC;AAsBD,wBAAsB,eAAe,CAAC,CAAC,EAAE,CAAC,EACxC,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,EAC5B,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EAC3B,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC,CAAC,CAAC,CAMZ;AAqBD,wBAAsB,uBAAuB,CAAC,CAAC,EAAE,CAAC,EAChD,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,EAC5B,IAAI,EAAE,CAAC,EACP,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EAC3B,OAAO,CAAC,EAAE,kBAAkB,GAC3B,OAAO,CAAC,CAAC,CAAC,CAMZ"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.withTransaction = withTransaction;
|
|
4
|
+
exports.withOptionalTransaction = withOptionalTransaction;
|
|
5
|
+
async function withTransaction(tm, fn, options) {
|
|
6
|
+
if (!tm?.transaction) {
|
|
7
|
+
throw new Error('Transaction manager not available');
|
|
8
|
+
}
|
|
9
|
+
return await tm.transaction(fn, options);
|
|
10
|
+
}
|
|
11
|
+
async function withOptionalTransaction(tm, repo, fn, options) {
|
|
12
|
+
if (tm?.transaction) {
|
|
13
|
+
return await tm.transaction(fn, options);
|
|
14
|
+
}
|
|
15
|
+
return await fn(repo);
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=transaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../src/service/transaction.ts"],"names":[],"mappings":";;AAuDA,0CAUC;AAqBD,0DAWC;AA1CM,KAAK,UAAU,eAAe,CACnC,EAA4B,EAC5B,EAA2B,EAC3B,OAA4B;IAE5B,IAAI,CAAC,EAAE,EAAE,WAAW,EAAE,CAAC;QACrB,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;IACvD,CAAC;IAED,OAAO,MAAM,EAAE,CAAC,WAAW,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;AAC3C,CAAC;AAqBM,KAAK,UAAU,uBAAuB,CAC3C,EAA4B,EAC5B,IAAO,EACP,EAA2B,EAC3B,OAA4B;IAE5B,IAAI,EAAE,EAAE,WAAW,EAAE,CAAC;QACpB,OAAO,MAAM,EAAE,CAAC,WAAW,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;IAC3C,CAAC;IAED,OAAO,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC;AACxB,CAAC"}
|
package/dist/utils/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AACA,cAAc,SAAS,CAAC;AAGxB,cAAc,WAAW,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AACA,cAAc,SAAS,CAAC;AAGxB,cAAc,WAAW,CAAC;AAE1B,cAAc,SAAS,CAAC"}
|
package/dist/utils/index.js
CHANGED
|
@@ -16,4 +16,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./dates"), exports);
|
|
18
18
|
__exportStar(require("./filters"), exports);
|
|
19
|
+
__exportStar(require("./retry"), exports);
|
|
19
20
|
//# sourceMappingURL=index.js.map
|
package/dist/utils/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,0CAAwB;AAGxB,4CAA0B"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AACA,0CAAwB;AAGxB,4CAA0B;AAE1B,0CAAwB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/utils/retry.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG;IACxB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,wBAAsB,YAAY,CAAC,CAAC,EAClC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EACpB,GAAG,CAAC,EAAE,WAAW,GAChB,OAAO,CAAC,CAAC,CAAC,CA0BZ"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.runWithRetry = runWithRetry;
|
|
4
|
+
async function runWithRetry(fn, cfg) {
|
|
5
|
+
const max = cfg?.max ?? 0;
|
|
6
|
+
const backoffMs = cfg?.backoffMs ?? 100;
|
|
7
|
+
const jitter = cfg?.jitter ?? false;
|
|
8
|
+
let attempt = 0;
|
|
9
|
+
while (true) {
|
|
10
|
+
try {
|
|
11
|
+
return await fn();
|
|
12
|
+
}
|
|
13
|
+
catch (err) {
|
|
14
|
+
if (attempt >= max) {
|
|
15
|
+
throw err;
|
|
16
|
+
}
|
|
17
|
+
attempt++;
|
|
18
|
+
let delay = backoffMs * attempt;
|
|
19
|
+
if (jitter) {
|
|
20
|
+
const delta = Math.floor(Math.random() * backoffMs);
|
|
21
|
+
delay += delta;
|
|
22
|
+
}
|
|
23
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=retry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.js","sourceRoot":"","sources":["../../src/utils/retry.ts"],"names":[],"mappings":";;AAMA,oCA6BC;AA7BM,KAAK,UAAU,YAAY,CAChC,EAAoB,EACpB,GAAiB;IAEjB,MAAM,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;IAC1B,MAAM,SAAS,GAAG,GAAG,EAAE,SAAS,IAAI,GAAG,CAAC;IACxC,MAAM,MAAM,GAAG,GAAG,EAAE,MAAM,IAAI,KAAK,CAAC;IAEpC,IAAI,OAAO,GAAG,CAAC,CAAC;IAEhB,OAAO,IAAI,EAAE,CAAC;QACZ,IAAI,CAAC;YACH,OAAO,MAAM,EAAE,EAAE,CAAC;QACpB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,OAAO,IAAI,GAAG,EAAE,CAAC;gBACnB,MAAM,GAAG,CAAC;YACZ,CAAC;YAED,OAAO,EAAE,CAAC;YAEV,IAAI,KAAK,GAAG,SAAS,GAAG,OAAO,CAAC;YAChC,IAAI,MAAM,EAAE,CAAC;gBACX,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,SAAS,CAAC,CAAC;gBACpD,KAAK,IAAI,KAAK,CAAC;YACjB,CAAC;YAED,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;AACH,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@anatix/runtime",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.2",
|
|
4
4
|
"description": "Runtime infrastructure for Anatix-generated microservices",
|
|
5
5
|
"author": "Anatix Team",
|
|
6
6
|
"license": "MIT",
|
|
@@ -15,9 +15,13 @@
|
|
|
15
15
|
"types": "./dist/index.d.ts",
|
|
16
16
|
"default": "./dist/index.js"
|
|
17
17
|
},
|
|
18
|
-
"./
|
|
19
|
-
"types": "./dist/
|
|
20
|
-
"default": "./dist/
|
|
18
|
+
"./contracts": {
|
|
19
|
+
"types": "./dist/contracts/index.d.ts",
|
|
20
|
+
"default": "./dist/contracts/index.js"
|
|
21
|
+
},
|
|
22
|
+
"./decorators": {
|
|
23
|
+
"types": "./dist/decorators/index.d.ts",
|
|
24
|
+
"default": "./dist/decorators/index.js"
|
|
21
25
|
},
|
|
22
26
|
"./envelope": {
|
|
23
27
|
"types": "./dist/envelope/index.d.ts",
|
|
@@ -27,21 +31,49 @@
|
|
|
27
31
|
"types": "./dist/event-bus/index.d.ts",
|
|
28
32
|
"default": "./dist/event-bus/index.js"
|
|
29
33
|
},
|
|
34
|
+
"./guards": {
|
|
35
|
+
"types": "./dist/guards/index.d.ts",
|
|
36
|
+
"default": "./dist/guards/index.js"
|
|
37
|
+
},
|
|
38
|
+
"./health": {
|
|
39
|
+
"types": "./dist/health/index.d.ts",
|
|
40
|
+
"default": "./dist/health/index.js"
|
|
41
|
+
},
|
|
30
42
|
"./logger": {
|
|
31
43
|
"types": "./dist/logger/index.d.ts",
|
|
32
44
|
"default": "./dist/logger/index.js"
|
|
33
45
|
},
|
|
46
|
+
"./monitoring": {
|
|
47
|
+
"types": "./dist/monitoring/index.d.ts",
|
|
48
|
+
"default": "./dist/monitoring/index.js"
|
|
49
|
+
},
|
|
50
|
+
"./naming": {
|
|
51
|
+
"types": "./dist/naming/index.d.ts",
|
|
52
|
+
"default": "./dist/naming/index.js"
|
|
53
|
+
},
|
|
34
54
|
"./proxy": {
|
|
35
55
|
"types": "./dist/proxy/index.d.ts",
|
|
36
56
|
"default": "./dist/proxy/index.js"
|
|
37
57
|
},
|
|
58
|
+
"./repository": {
|
|
59
|
+
"types": "./dist/repository/index.d.ts",
|
|
60
|
+
"default": "./dist/repository/index.js"
|
|
61
|
+
},
|
|
38
62
|
"./security": {
|
|
39
63
|
"types": "./dist/security/index.d.ts",
|
|
40
64
|
"default": "./dist/security/index.js"
|
|
41
65
|
},
|
|
42
|
-
"./
|
|
43
|
-
"types": "./dist/
|
|
44
|
-
"default": "./dist/
|
|
66
|
+
"./service": {
|
|
67
|
+
"types": "./dist/service/index.d.ts",
|
|
68
|
+
"default": "./dist/service/index.js"
|
|
69
|
+
},
|
|
70
|
+
"./result": {
|
|
71
|
+
"types": "./dist/result/index.d.ts",
|
|
72
|
+
"default": "./dist/result/index.js"
|
|
73
|
+
},
|
|
74
|
+
"./dtos": {
|
|
75
|
+
"types": "./dist/dtos/index.d.ts",
|
|
76
|
+
"default": "./dist/dtos/index.js"
|
|
45
77
|
},
|
|
46
78
|
"./configs": {
|
|
47
79
|
"types": "./dist/configs/index.d.ts",
|
|
@@ -50,10 +82,6 @@
|
|
|
50
82
|
"./utils": {
|
|
51
83
|
"types": "./dist/utils/index.d.ts",
|
|
52
84
|
"default": "./dist/utils/index.js"
|
|
53
|
-
},
|
|
54
|
-
"./decorators": {
|
|
55
|
-
"types": "./dist/decorators/index.d.ts",
|
|
56
|
-
"default": "./dist/decorators/index.js"
|
|
57
85
|
}
|
|
58
86
|
},
|
|
59
87
|
"scripts": {
|
|
@@ -61,9 +89,10 @@
|
|
|
61
89
|
"build": "tsc -p tsconfig.build.json",
|
|
62
90
|
"prepublishOnly": "npm run clean && npm run build",
|
|
63
91
|
"dev": "tsc -p tsconfig.build.json --watch",
|
|
64
|
-
"type-check": "tsc --noEmit"
|
|
92
|
+
"type-check": "tsc --noEmit",
|
|
93
|
+
"publish": "npm publish --access public"
|
|
65
94
|
},
|
|
66
|
-
|
|
95
|
+
"publishConfig": {
|
|
67
96
|
"access": "public"
|
|
68
97
|
},
|
|
69
98
|
"peerDependencies": {
|
|
@@ -73,11 +102,12 @@
|
|
|
73
102
|
"@nestjs/swagger": "^11.0.0",
|
|
74
103
|
"amqplib": "^0.10.5",
|
|
75
104
|
"axios": "^1.7.9",
|
|
76
|
-
"bcryptjs": "^
|
|
105
|
+
"bcryptjs": "^2.4.3",
|
|
77
106
|
"class-transformer": "^0.5.1",
|
|
78
107
|
"class-validator": "^0.14.1",
|
|
79
108
|
"express": "^4.21.0",
|
|
80
109
|
"jsonwebtoken": "^9.0.2",
|
|
110
|
+
"prom-client": "^14.0.0 || ^15.0.0",
|
|
81
111
|
"reflect-metadata": "^0.2.2",
|
|
82
112
|
"rxjs": "^7.8.1",
|
|
83
113
|
"typeorm": "^0.3.20",
|
|
@@ -92,6 +122,12 @@
|
|
|
92
122
|
},
|
|
93
123
|
"class-transformer": {
|
|
94
124
|
"optional": true
|
|
125
|
+
},
|
|
126
|
+
"bcryptjs": {
|
|
127
|
+
"optional": true
|
|
128
|
+
},
|
|
129
|
+
"prom-client": {
|
|
130
|
+
"optional": true
|
|
95
131
|
}
|
|
96
132
|
},
|
|
97
133
|
"devDependencies": {
|
|
@@ -111,6 +147,7 @@
|
|
|
111
147
|
"class-validator": "^0.14.1",
|
|
112
148
|
"express": "^4.21.2",
|
|
113
149
|
"jsonwebtoken": "^9.0.2",
|
|
150
|
+
"prom-client": "^15.1.3",
|
|
114
151
|
"reflect-metadata": "^0.2.2",
|
|
115
152
|
"rimraf": "^6.0.1",
|
|
116
153
|
"rxjs": "^7.8.1",
|
|
@@ -146,6 +183,6 @@
|
|
|
146
183
|
},
|
|
147
184
|
"homepage": "https://github.com/anatix/anatix-runtime#readme",
|
|
148
185
|
"dependencies": {
|
|
149
|
-
"
|
|
186
|
+
"kafkajs": "^2.2.4"
|
|
150
187
|
}
|
|
151
188
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"env-validation.d.ts","sourceRoot":"","sources":["../../src/configs/env-validation.ts"],"names":[],"mappings":"AAOA,wBAAgB,WAAW,IAAI,IAAI,CA8DlC"}
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.validateEnv = validateEnv;
|
|
4
|
-
const common_1 = require("@nestjs/common");
|
|
5
|
-
const logger = new common_1.Logger('EnvValidation');
|
|
6
|
-
function validateEnv() {
|
|
7
|
-
const required = {
|
|
8
|
-
DB_HOST: process.env.DB_HOST,
|
|
9
|
-
DB_PORT: process.env.DB_PORT,
|
|
10
|
-
DB_NAME: process.env.DB_NAME,
|
|
11
|
-
DB_USER: process.env.DB_USER,
|
|
12
|
-
DB_PASSWORD: process.env.DB_PASSWORD,
|
|
13
|
-
RABBITMQ_URL: process.env.RABBITMQ_URL,
|
|
14
|
-
AUTH_JWT_SECRET: process.env.AUTH_JWT_SECRET,
|
|
15
|
-
AUTH_JWT_ALGORITHM: process.env.AUTH_JWT_ALGORITHM || 'HS256'
|
|
16
|
-
};
|
|
17
|
-
const missing = [];
|
|
18
|
-
const warnings = [];
|
|
19
|
-
for (const [key, value] of Object.entries(required)) {
|
|
20
|
-
if (!value || value.trim() === '') {
|
|
21
|
-
missing.push(key);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
const algorithm = process.env.AUTH_JWT_ALGORITHM || 'HS256';
|
|
25
|
-
const isHmac = algorithm.startsWith('HS');
|
|
26
|
-
const isAsymmetric = ['RS', 'ES', 'PS'].some(prefix => algorithm.startsWith(prefix));
|
|
27
|
-
if (isHmac && !process.env.AUTH_JWT_SECRET) {
|
|
28
|
-
missing.push('AUTH_JWT_SECRET (required for HMAC algorithms)');
|
|
29
|
-
}
|
|
30
|
-
if (isAsymmetric && !process.env.AUTH_JWT_PUBLIC_KEY) {
|
|
31
|
-
missing.push('AUTH_JWT_PUBLIC_KEY (required for asymmetric algorithms)');
|
|
32
|
-
}
|
|
33
|
-
if (!process.env.NODE_ENV) {
|
|
34
|
-
warnings.push('NODE_ENV not set (defaulting to development)');
|
|
35
|
-
}
|
|
36
|
-
if (!process.env.LOG_ERRORS || process.env.LOG_ERRORS === 'true') {
|
|
37
|
-
logger.log('Error logging is enabled');
|
|
38
|
-
}
|
|
39
|
-
if (warnings.length > 0) {
|
|
40
|
-
warnings.forEach(w => logger.warn(`⚠️ ${w}`));
|
|
41
|
-
}
|
|
42
|
-
if (missing.length > 0) {
|
|
43
|
-
logger.error('❌ Missing required environment variables:');
|
|
44
|
-
missing.forEach(m => logger.error(` - ${m}`));
|
|
45
|
-
throw new Error('Missing required environment variables');
|
|
46
|
-
}
|
|
47
|
-
logger.log('✅ Environment variables validated');
|
|
48
|
-
}
|
|
49
|
-
//# sourceMappingURL=env-validation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"env-validation.js","sourceRoot":"","sources":["../../src/configs/env-validation.ts"],"names":[],"mappings":";;AAOA,kCA8DC;AArED,2CAAwC;AAExC,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,eAAe,CAAC,CAAC;AAK3C,SAAgB,WAAW;IACzB,MAAM,QAAQ,GAAG;QAEf,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO;QAC5B,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO;QAC5B,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO;QAC5B,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO;QAC5B,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,WAAW;QAGpC,YAAY,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY;QAGtC,eAAe,EAAE,OAAO,CAAC,GAAG,CAAC,eAAe;QAC5C,kBAAkB,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,OAAO;KAC9D,CAAC;IAEF,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,MAAM,QAAQ,GAAa,EAAE,CAAC;IAG9B,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QACpD,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;YAClC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAGD,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,OAAO,CAAC;IAC5D,MAAM,MAAM,GAAG,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAC1C,MAAM,YAAY,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IAErF,IAAI,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC;QAC3C,OAAO,CAAC,IAAI,CAAC,gDAAgD,CAAC,CAAC;IACjE,CAAC;IAED,IAAI,YAAY,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,CAAC;QACrD,OAAO,CAAC,IAAI,CAAC,0DAA0D,CAAC,CAAC;IAC3E,CAAC;IAGD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;QAC1B,QAAQ,CAAC,IAAI,CAAC,8CAA8C,CAAC,CAAC;IAChE,CAAC;IAED,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,OAAO,CAAC,GAAG,CAAC,UAAU,KAAK,MAAM,EAAE,CAAC;QACjE,MAAM,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;IACzC,CAAC;IAGD,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxB,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAGD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvB,MAAM,CAAC,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC1D,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/C,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;IAC5D,CAAC;IAED,MAAM,CAAC,GAAG,CAAC,mCAAmC,CAAC,CAAC;AAClD,CAAC"}
|
package/dist/configs/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/configs/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/configs/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yDAAuC;AACvC,oDAAkC"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export type OrderDir = 'ASC' | 'DESC';
|
|
2
|
-
export interface RepoListOptions {
|
|
3
|
-
limit?: number;
|
|
4
|
-
offset?: number;
|
|
5
|
-
cursor?: string;
|
|
6
|
-
orderBy?: string;
|
|
7
|
-
orderDir?: OrderDir;
|
|
8
|
-
projection?: string | string[];
|
|
9
|
-
}
|
|
10
|
-
export interface RepoQueryOptions extends RepoListOptions {
|
|
11
|
-
search?: string;
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=service-repo-configs.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service-repo-configs.d.ts","sourceRoot":"","sources":["../../src/configs/service-repo-configs.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;AAoBtC,MAAM,WAAW,eAAe;IAI9B,KAAK,CAAC,EAAE,MAAM,CAAC;IAKf,MAAM,CAAC,EAAE,MAAM,CAAC;IAMhB,MAAM,CAAC,EAAE,MAAM,CAAC;IAMhB,OAAO,CAAC,EAAE,MAAM,CAAC;IAKjB,QAAQ,CAAC,EAAE,QAAQ,CAAC;IAUpB,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;CAChC;AAkBD,MAAM,WAAW,gBAAiB,SAAQ,eAAe;IAKvD,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service-repo-configs.js","sourceRoot":"","sources":["../../src/configs/service-repo-configs.ts"],"names":[],"mappings":""}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import type { OrderDir } from './service-repo-configs';
|
|
2
|
-
export interface ServiceListOptions {
|
|
3
|
-
limit?: number;
|
|
4
|
-
cursor?: string;
|
|
5
|
-
offset?: number;
|
|
6
|
-
orderBy?: string;
|
|
7
|
-
orderDir?: OrderDir;
|
|
8
|
-
include?: string | string[];
|
|
9
|
-
projection?: string | string[];
|
|
10
|
-
}
|
|
11
|
-
export interface ServiceQueryOptions extends ServiceListOptions {
|
|
12
|
-
search?: string;
|
|
13
|
-
}
|
|
14
|
-
export interface TxManager<R> {
|
|
15
|
-
transaction?<T>(fn: (repo: R) => Promise<T>, options?: {
|
|
16
|
-
isolation?: 'READ COMMITTED' | 'REPEATABLE READ' | 'SERIALIZABLE';
|
|
17
|
-
}): Promise<T>;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=service-runtime.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service-runtime.d.ts","sourceRoot":"","sources":["../../src/configs/service-runtime.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAoBvD,MAAM,WAAW,kBAAkB;IAIjC,KAAK,CAAC,EAAE,MAAM,CAAC;IAKf,MAAM,CAAC,EAAE,MAAM,CAAC;IAKhB,MAAM,CAAC,EAAE,MAAM,CAAC;IAKhB,OAAO,CAAC,EAAE,MAAM,CAAC;IAKjB,QAAQ,CAAC,EAAE,QAAQ,CAAC;IASpB,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAS5B,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;CAChC;AAkBD,MAAM,WAAW,mBAAoB,SAAQ,kBAAkB;IAI7D,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AA4BD,MAAM,WAAW,SAAS,CAAC,CAAC;IAU1B,WAAW,CAAC,CAAC,CAAC,EACZ,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EAC3B,OAAO,CAAC,EAAE;QAER,SAAS,CAAC,EAAE,gBAAgB,GAAG,iBAAiB,GAAG,cAAc,CAAC;KACnE,GACA,OAAO,CAAC,CAAC,CAAC,CAAC;CACf"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"service-runtime.js","sourceRoot":"","sources":["../../src/configs/service-runtime.ts"],"names":[],"mappings":""}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
|
2
|
-
import { Reflector } from '@nestjs/core';
|
|
3
|
-
import type { RolesExtractor } from '../types';
|
|
4
|
-
export declare class RolesGuard implements CanActivate {
|
|
5
|
-
private readonly reflector;
|
|
6
|
-
private readonly extractRoles;
|
|
7
|
-
constructor(reflector: Reflector, extractRoles: RolesExtractor);
|
|
8
|
-
canActivate(context: ExecutionContext): boolean;
|
|
9
|
-
}
|
|
10
|
-
//# sourceMappingURL=roles.guard.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"roles.guard.d.ts","sourceRoot":"","sources":["../../../src/guards/base/roles.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,gBAAgB,EAIjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAIzC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AA6B/C,qBACa,UAAW,YAAW,WAAW;IAE1C,OAAO,CAAC,QAAQ,CAAC,SAAS;IACA,OAAO,CAAC,QAAQ,CAAC,YAAY;gBADtC,SAAS,EAAE,SAAS,EACM,YAAY,EAAE,cAAc;IAGzE,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;CA0ChD"}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
-
};
|
|
11
|
-
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
-
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
-
};
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.RolesGuard = void 0;
|
|
16
|
-
const common_1 = require("@nestjs/common");
|
|
17
|
-
const core_1 = require("@nestjs/core");
|
|
18
|
-
const roles_decorator_1 = require("../decorators/roles.decorator");
|
|
19
|
-
const public_decorator_1 = require("../decorators/public.decorator");
|
|
20
|
-
let RolesGuard = class RolesGuard {
|
|
21
|
-
reflector;
|
|
22
|
-
extractRoles;
|
|
23
|
-
constructor(reflector, extractRoles) {
|
|
24
|
-
this.reflector = reflector;
|
|
25
|
-
this.extractRoles = extractRoles;
|
|
26
|
-
}
|
|
27
|
-
canActivate(context) {
|
|
28
|
-
const isPublic = this.reflector.getAllAndOverride(public_decorator_1.IS_PUBLIC_KEY, [
|
|
29
|
-
context.getHandler(),
|
|
30
|
-
context.getClass(),
|
|
31
|
-
]);
|
|
32
|
-
if (isPublic) {
|
|
33
|
-
return true;
|
|
34
|
-
}
|
|
35
|
-
const requiredRoles = this.reflector.getAllAndOverride(roles_decorator_1.ROLES_META_KEY, [context.getHandler(), context.getClass()]);
|
|
36
|
-
if (!requiredRoles || requiredRoles.length === 0) {
|
|
37
|
-
return true;
|
|
38
|
-
}
|
|
39
|
-
const request = context.switchToHttp().getRequest();
|
|
40
|
-
const user = request?.user;
|
|
41
|
-
if (!user) {
|
|
42
|
-
throw new common_1.ForbiddenException('Authentication required');
|
|
43
|
-
}
|
|
44
|
-
const userRoles = this.extractRoles(user);
|
|
45
|
-
const hasRole = requiredRoles.some((role) => userRoles.includes(role));
|
|
46
|
-
if (!hasRole) {
|
|
47
|
-
throw new common_1.ForbiddenException('Insufficient role');
|
|
48
|
-
}
|
|
49
|
-
return true;
|
|
50
|
-
}
|
|
51
|
-
};
|
|
52
|
-
exports.RolesGuard = RolesGuard;
|
|
53
|
-
exports.RolesGuard = RolesGuard = __decorate([
|
|
54
|
-
(0, common_1.Injectable)(),
|
|
55
|
-
__param(1, (0, common_1.Inject)('RolesExtractor')),
|
|
56
|
-
__metadata("design:paramtypes", [core_1.Reflector, Function])
|
|
57
|
-
], RolesGuard);
|
|
58
|
-
//# sourceMappingURL=roles.guard.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"roles.guard.js","sourceRoot":"","sources":["../../../src/guards/base/roles.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAMwB;AACxB,uCAAyC;AAEzC,mEAA+D;AAC/D,qEAA+D;AA+BxD,IAAM,UAAU,GAAhB,MAAM,UAAU;IAEF;IAC0B;IAF7C,YACmB,SAAoB,EACM,YAA4B;QADtD,cAAS,GAAT,SAAS,CAAW;QACM,iBAAY,GAAZ,YAAY,CAAgB;IACtE,CAAC;IAEJ,WAAW,CAAC,OAAyB;QAEnC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAU,gCAAa,EAAE;YACxE,OAAO,CAAC,UAAU,EAAE;YACpB,OAAO,CAAC,QAAQ,EAAE;SACnB,CAAC,CAAC;QAEH,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,IAAI,CAAC;QACd,CAAC;QAGD,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CACpD,gCAAc,EACd,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAC3C,CAAC;QAGF,IAAI,CAAC,aAAa,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACjD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAW,CAAC;QAC7D,MAAM,IAAI,GAAI,OAAe,EAAE,IAAI,CAAC;QAGpC,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,2BAAkB,CAAC,yBAAyB,CAAC,CAAC;QAC1D,CAAC;QAGD,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAG1C,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;QAEvE,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,2BAAkB,CAAC,mBAAmB,CAAC,CAAC;QACpD,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AAhDY,gCAAU;qBAAV,UAAU;IADtB,IAAA,mBAAU,GAAE;IAIR,WAAA,IAAA,eAAM,EAAC,gBAAgB,CAAC,CAAA;qCADG,gBAAS;GAF5B,UAAU,CAgDtB"}
|