@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
|
@@ -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",
|
|
@@ -63,7 +63,18 @@
|
|
|
63
63
|
"types": "./dist/security/index.d.ts",
|
|
64
64
|
"default": "./dist/security/index.js"
|
|
65
65
|
},
|
|
66
|
-
|
|
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"
|
|
77
|
+
},
|
|
67
78
|
"./configs": {
|
|
68
79
|
"types": "./dist/configs/index.d.ts",
|
|
69
80
|
"default": "./dist/configs/index.js"
|
|
@@ -91,10 +102,12 @@
|
|
|
91
102
|
"@nestjs/swagger": "^11.0.0",
|
|
92
103
|
"amqplib": "^0.10.5",
|
|
93
104
|
"axios": "^1.7.9",
|
|
105
|
+
"bcryptjs": "^2.4.3",
|
|
94
106
|
"class-transformer": "^0.5.1",
|
|
95
107
|
"class-validator": "^0.14.1",
|
|
96
108
|
"express": "^4.21.0",
|
|
97
109
|
"jsonwebtoken": "^9.0.2",
|
|
110
|
+
"prom-client": "^14.0.0 || ^15.0.0",
|
|
98
111
|
"reflect-metadata": "^0.2.2",
|
|
99
112
|
"rxjs": "^7.8.1",
|
|
100
113
|
"typeorm": "^0.3.20",
|
|
@@ -109,6 +122,12 @@
|
|
|
109
122
|
},
|
|
110
123
|
"class-transformer": {
|
|
111
124
|
"optional": true
|
|
125
|
+
},
|
|
126
|
+
"bcryptjs": {
|
|
127
|
+
"optional": true
|
|
128
|
+
},
|
|
129
|
+
"prom-client": {
|
|
130
|
+
"optional": true
|
|
112
131
|
}
|
|
113
132
|
},
|
|
114
133
|
"devDependencies": {
|
|
@@ -117,15 +136,18 @@
|
|
|
117
136
|
"@nestjs/core": "^11.1.9",
|
|
118
137
|
"@nestjs/swagger": "^11.2.0",
|
|
119
138
|
"@types/amqplib": "^0.10.5",
|
|
139
|
+
"@types/bcryptjs": "^2.4.6",
|
|
120
140
|
"@types/express": "^5.0.0",
|
|
121
141
|
"@types/jsonwebtoken": "^9.0.7",
|
|
122
142
|
"@types/node": "^22.19.1",
|
|
123
143
|
"amqplib": "^0.10.5",
|
|
124
144
|
"axios": "^1.7.9",
|
|
145
|
+
"bcryptjs": "^3.0.3",
|
|
125
146
|
"class-transformer": "^0.5.1",
|
|
126
147
|
"class-validator": "^0.14.1",
|
|
127
148
|
"express": "^4.21.2",
|
|
128
149
|
"jsonwebtoken": "^9.0.2",
|
|
150
|
+
"prom-client": "^15.1.3",
|
|
129
151
|
"reflect-metadata": "^0.2.2",
|
|
130
152
|
"rimraf": "^6.0.1",
|
|
131
153
|
"rxjs": "^7.8.1",
|
|
@@ -161,7 +183,6 @@
|
|
|
161
183
|
},
|
|
162
184
|
"homepage": "https://github.com/anatix/anatix-runtime#readme",
|
|
163
185
|
"dependencies": {
|
|
164
|
-
"
|
|
165
|
-
"prom-client": "^15.1.3"
|
|
186
|
+
"kafkajs": "^2.2.4"
|
|
166
187
|
}
|
|
167
188
|
}
|