@alacard-project/shared 1.1.1 → 1.1.4
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/constants/microservices.constants.d.ts +4 -0
- package/dist/constants/microservices.constants.js +4 -0
- package/dist/constants/microservices.constants.js.map +1 -1
- package/dist/contracts/card.contract.d.ts +98 -0
- package/dist/contracts/card.contract.js +3 -0
- package/dist/contracts/card.contract.js.map +1 -0
- package/dist/contracts/index.d.ts +3 -1
- package/dist/contracts/index.js +3 -0
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/transaction.contract.d.ts +63 -0
- package/dist/contracts/transaction.contract.js +3 -0
- package/dist/contracts/transaction.contract.js.map +1 -0
- package/dist/dto/auth.dto.d.ts +3 -1
- package/dist/dto/auth.dto.js +11 -0
- package/dist/dto/auth.dto.js.map +1 -1
- package/dist/dto/index.d.ts +1 -0
- package/dist/dto/index.js +1 -0
- package/dist/dto/index.js.map +1 -1
- package/dist/dto/invoice.dto.d.ts +12 -0
- package/dist/dto/invoice.dto.js +62 -0
- package/dist/dto/invoice.dto.js.map +1 -0
- package/dist/enums/auth.enum.d.ts +2 -3
- package/dist/enums/auth.enum.js +2 -3
- package/dist/enums/auth.enum.js.map +1 -1
- package/dist/filters/global-exception.filter.d.ts +12 -0
- package/dist/filters/global-exception.filter.js +152 -0
- package/dist/filters/global-exception.filter.js.map +1 -0
- package/dist/filters/index.d.ts +1 -1
- package/dist/filters/index.js +1 -1
- package/dist/filters/index.js.map +1 -1
- package/dist/index.d.ts +14 -4
- package/dist/index.js +14 -4
- package/dist/index.js.map +1 -1
- package/dist/middleware/index.d.ts +2 -0
- package/dist/{interceptors → middleware}/index.js +2 -2
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/prisma-logging.middleware.d.ts +3 -0
- package/dist/middleware/prisma-logging.middleware.js +52 -0
- package/dist/middleware/prisma-logging.middleware.js.map +1 -0
- package/dist/middleware/tracing.middleware.d.ts +8 -0
- package/dist/middleware/tracing.middleware.js +33 -0
- package/dist/middleware/tracing.middleware.js.map +1 -0
- package/dist/resilience/circuit-breaker.service.d.ts +2 -3
- package/dist/resilience/circuit-breaker.service.js +10 -16
- package/dist/resilience/circuit-breaker.service.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types/logger.interface.d.ts +6 -0
- package/dist/types/logger.interface.js +3 -0
- package/dist/types/logger.interface.js.map +1 -0
- package/dist/utils/app-logger.d.ts +11 -0
- package/dist/utils/app-logger.js +65 -0
- package/dist/utils/app-logger.js.map +1 -0
- package/dist/utils/app.utils.d.ts +4 -0
- package/dist/utils/app.utils.js +8 -1
- package/dist/utils/app.utils.js.map +1 -1
- package/dist/{filters/http-exception.filter.js → utils/filters.js} +3 -12
- package/dist/utils/filters.js.map +1 -0
- package/dist/utils/grpc-tracing-server.interceptor.d.ts +8 -0
- package/dist/utils/grpc-tracing-server.interceptor.js +48 -0
- package/dist/utils/grpc-tracing-server.interceptor.js.map +1 -0
- package/dist/utils/grpc-tracing.interceptor.d.ts +8 -0
- package/dist/utils/grpc-tracing.interceptor.js +35 -0
- package/dist/utils/grpc-tracing.interceptor.js.map +1 -0
- package/dist/utils/http-tracing.interceptor.d.ts +8 -0
- package/dist/utils/http-tracing.interceptor.js +35 -0
- package/dist/utils/http-tracing.interceptor.js.map +1 -0
- package/dist/{interceptors/transform.interceptor.d.ts → utils/interceptors.d.ts} +0 -1
- package/dist/{interceptors/transform.interceptor.js → utils/interceptors.js} +3 -3
- package/dist/utils/interceptors.js.map +1 -0
- package/dist/utils/proto-path.js +1 -1
- package/dist/utils/proto-path.js.map +1 -1
- package/dist/utils/tracing.module.d.ts +2 -0
- package/dist/{observability/metrics/metrics.module.js → utils/tracing.module.js} +10 -16
- package/dist/utils/tracing.module.js.map +1 -0
- package/dist/utils/tracing.service.d.ts +10 -0
- package/dist/utils/tracing.service.js +43 -0
- package/dist/utils/tracing.service.js.map +1 -0
- package/dist/utils/tracing.utils.js +7 -0
- package/dist/utils/tracing.utils.js.map +1 -0
- package/package.json +48 -46
- package/dist/config/base-config.service.d.ts +0 -25
- package/dist/config/base-config.service.js +0 -87
- package/dist/config/base-config.service.js.map +0 -1
- package/dist/constants/logging.constants.d.ts +0 -24
- package/dist/constants/logging.constants.js +0 -28
- package/dist/constants/logging.constants.js.map +0 -1
- package/dist/constants/monitoring.constants.d.ts +0 -51
- package/dist/constants/monitoring.constants.js +0 -55
- package/dist/constants/monitoring.constants.js.map +0 -1
- package/dist/constants/tokens.constants.d.ts +0 -6
- package/dist/constants/tokens.constants.js +0 -10
- package/dist/constants/tokens.constants.js.map +0 -1
- package/dist/filters/http-exception.filter.js.map +0 -1
- package/dist/interceptors/http-logging.interceptor.d.ts +0 -10
- package/dist/interceptors/http-logging.interceptor.js +0 -74
- package/dist/interceptors/http-logging.interceptor.js.map +0 -1
- package/dist/interceptors/index.d.ts +0 -2
- package/dist/interceptors/index.js.map +0 -1
- package/dist/interceptors/logging.interceptor.d.ts +0 -6
- package/dist/interceptors/logging.interceptor.js +0 -41
- package/dist/interceptors/logging.interceptor.js.map +0 -1
- package/dist/interceptors/transform.interceptor.js.map +0 -1
- package/dist/observability/index.d.ts +0 -2
- package/dist/observability/index.js +0 -19
- package/dist/observability/index.js.map +0 -1
- package/dist/observability/metrics/metrics.module.d.ts +0 -2
- package/dist/observability/metrics/metrics.module.js.map +0 -1
- package/dist/observability/tracing.js +0 -28
- package/dist/observability/tracing.js.map +0 -1
- package/dist/utils/logging-client.d.ts +0 -9
- package/dist/utils/logging-client.js +0 -58
- package/dist/utils/logging-client.js.map +0 -1
- package/dist/utils/prometheus.utils.d.ts +0 -9
- package/dist/utils/prometheus.utils.js +0 -66
- package/dist/utils/prometheus.utils.js.map +0 -1
- package/proto/auth.proto +0 -123
- package/proto/card.proto +0 -43
- package/proto/client.proto +0 -45
- package/proto/config.proto +0 -39
- package/proto/dbf.proto +0 -183
- package/proto/logging.proto +0 -143
- package/proto/partner.proto +0 -18
- package/proto/terminal.proto +0 -18
- package/proto/transaction.proto +0 -45
- package/proto/user.proto +0 -122
- package/src/constants/auth-config.constants.ts +0 -16
- package/src/constants/auth.constants.ts +0 -50
- package/src/constants/common.constants.ts +0 -16
- package/src/constants/env.constants.ts +0 -49
- package/src/constants/error-messages.ts +0 -10
- package/src/constants/grpc.constants.ts +0 -43
- package/src/constants/http.constants.ts +0 -11
- package/src/constants/index.ts +0 -11
- package/src/constants/logging-messages.constants.ts +0 -60
- package/src/constants/microservices.constants.ts +0 -62
- package/src/constants/queue.constants.ts +0 -8
- package/src/constants/routes.constants.ts +0 -21
- package/src/contracts/auth.contract.ts +0 -146
- package/src/contracts/config.contract.ts +0 -14
- package/src/contracts/index.ts +0 -14
- package/src/contracts/logging.contract.ts +0 -115
- package/src/contracts/token.contract.ts +0 -47
- package/src/decorators/index.ts +0 -3
- package/src/decorators/permissions.decorator.ts +0 -5
- package/src/decorators/roles.decorator.ts +0 -5
- package/src/decorators/scopes.decorator.ts +0 -4
- package/src/dto/account.dto.ts +0 -28
- package/src/dto/auth.dto.ts +0 -233
- package/src/dto/card.dto.ts +0 -64
- package/src/dto/client.dto.ts +0 -137
- package/src/dto/index.ts +0 -8
- package/src/dto/logging.dto.ts +0 -101
- package/src/dto/partner.dto.ts +0 -18
- package/src/dto/transaction.dto.ts +0 -52
- package/src/dto/user.dto.ts +0 -28
- package/src/enums/auth.enum.ts +0 -13
- package/src/enums/env.enum.ts +0 -7
- package/src/enums/error.enum.ts +0 -28
- package/src/enums/events.enum.ts +0 -22
- package/src/enums/health.enum.ts +0 -7
- package/src/enums/iam.enum.ts +0 -28
- package/src/enums/index.ts +0 -10
- package/src/enums/logging.enum.ts +0 -7
- package/src/enums/notification.enum.ts +0 -5
- package/src/enums/permission.enum.ts +0 -31
- package/src/enums/user.enum.ts +0 -27
- package/src/errors/app.error.ts +0 -33
- package/src/errors/error-map.ts +0 -105
- package/src/filters/http-exception.filter.ts +0 -49
- package/src/filters/index.ts +0 -2
- package/src/index.ts +0 -17
- package/src/interceptors/index.ts +0 -3
- package/src/interceptors/logging.interceptor.ts +0 -37
- package/src/interceptors/transform.interceptor.ts +0 -21
- package/src/observability/index.ts +0 -3
- package/src/observability/metrics/metrics.module.ts +0 -16
- package/src/observability/tracing.ts +0 -33
- package/src/resilience/circuit-breaker.service.ts +0 -46
- package/src/resilience/resilience.module.ts +0 -9
- package/src/types/auth.types.ts +0 -38
- package/src/types/common.types.ts +0 -18
- package/src/types/config.types.ts +0 -32
- package/src/types/iam.types.ts +0 -78
- package/src/types/index.ts +0 -6
- package/src/types/monitoring.types.ts +0 -77
- package/src/types/user.types.ts +0 -11
- package/src/utils/app.utils.ts +0 -52
- package/src/utils/health.utils.ts +0 -24
- package/src/utils/proto-path.ts +0 -21
- package/src/utils/user.utils.ts +0 -3
- package/tsconfig.json +0 -28
- /package/dist/{filters/http-exception.filter.d.ts → utils/filters.d.ts} +0 -0
- /package/dist/{observability/tracing.d.ts → utils/tracing.utils.d.ts} +0 -0
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export interface IRemoteLogger {
|
|
2
|
+
log(message: unknown, context?: string, metadata?: Record<string, unknown>): void;
|
|
3
|
+
error(message: unknown, context?: string, metadata?: Record<string, unknown>): void;
|
|
4
|
+
warn(message: unknown, context?: string, metadata?: Record<string, unknown>): void;
|
|
5
|
+
debug(message: unknown, context?: string, metadata?: Record<string, unknown>): void;
|
|
6
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.interface.js","sourceRoot":"","sources":["../../src/types/logger.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ConsoleLogger } from '@nestjs/common';
|
|
2
|
+
export declare class AppLogger extends ConsoleLogger {
|
|
3
|
+
constructor(context?: string);
|
|
4
|
+
log(message: any, context?: string): void;
|
|
5
|
+
error(message: any, stack?: string, context?: string): void;
|
|
6
|
+
warn(message: any, context?: string): void;
|
|
7
|
+
debug(message: any, context?: string): void;
|
|
8
|
+
verbose(message: any, context?: string): void;
|
|
9
|
+
private getTraceId;
|
|
10
|
+
private formatMsgWithTraceId;
|
|
11
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AppLogger = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const tracing_service_1 = require("./tracing.service");
|
|
15
|
+
let AppLogger = class AppLogger extends common_1.ConsoleLogger {
|
|
16
|
+
constructor(context) {
|
|
17
|
+
super(context || 'App');
|
|
18
|
+
}
|
|
19
|
+
log(message, context) {
|
|
20
|
+
const traceId = this.getTraceId();
|
|
21
|
+
super.log(this.formatMsgWithTraceId(message, traceId), context || this.context);
|
|
22
|
+
}
|
|
23
|
+
error(message, stack, context) {
|
|
24
|
+
const traceId = this.getTraceId();
|
|
25
|
+
super.error(this.formatMsgWithTraceId(message, traceId), stack, context || this.context);
|
|
26
|
+
}
|
|
27
|
+
warn(message, context) {
|
|
28
|
+
const traceId = this.getTraceId();
|
|
29
|
+
super.warn(this.formatMsgWithTraceId(message, traceId), context || this.context);
|
|
30
|
+
}
|
|
31
|
+
debug(message, context) {
|
|
32
|
+
const traceId = this.getTraceId();
|
|
33
|
+
super.debug(this.formatMsgWithTraceId(message, traceId), context || this.context);
|
|
34
|
+
}
|
|
35
|
+
verbose(message, context) {
|
|
36
|
+
const traceId = this.getTraceId();
|
|
37
|
+
super.verbose(this.formatMsgWithTraceId(message, traceId), context || this.context);
|
|
38
|
+
}
|
|
39
|
+
getTraceId() {
|
|
40
|
+
try {
|
|
41
|
+
return tracing_service_1.TracingService.getTraceId();
|
|
42
|
+
}
|
|
43
|
+
catch {
|
|
44
|
+
return 'no-trace-id';
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
formatMsgWithTraceId(message, traceId) {
|
|
48
|
+
const prefix = traceId && traceId !== 'no-trace-id' ? `[${traceId}] ` : '';
|
|
49
|
+
if (typeof message === 'object') {
|
|
50
|
+
try {
|
|
51
|
+
return `${prefix}${JSON.stringify(message)}`;
|
|
52
|
+
}
|
|
53
|
+
catch {
|
|
54
|
+
return `${prefix}${String(message)}`;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
return `${prefix}${String(message)}`;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
exports.AppLogger = AppLogger;
|
|
61
|
+
exports.AppLogger = AppLogger = __decorate([
|
|
62
|
+
(0, common_1.Injectable)(),
|
|
63
|
+
__metadata("design:paramtypes", [String])
|
|
64
|
+
], AppLogger);
|
|
65
|
+
//# sourceMappingURL=app-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app-logger.js","sourceRoot":"","sources":["../../src/utils/app-logger.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAqE;AACrE,uDAAmD;AAG5C,IAAM,SAAS,GAAf,MAAM,SAAU,SAAQ,sBAAa;IACxC,YAAY,OAAgB;QACxB,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,GAAG,CAAC,OAAY,EAAE,OAAgB;QAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IACpF,CAAC;IAED,KAAK,CAAC,OAAY,EAAE,KAAc,EAAE,OAAgB;QAChD,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,KAAK,EAAE,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7F,CAAC;IAED,IAAI,CAAC,OAAY,EAAE,OAAgB;QAC/B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IACrF,CAAC;IAED,KAAK,CAAC,OAAY,EAAE,OAAgB;QAChC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IACtF,CAAC;IAED,OAAO,CAAC,OAAY,EAAE,OAAgB;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IACxF,CAAC;IAEO,UAAU;QACd,IAAI,CAAC;YACD,OAAO,gCAAc,CAAC,UAAU,EAAE,CAAC;QACvC,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,aAAa,CAAC;QACzB,CAAC;IACL,CAAC;IAEO,oBAAoB,CAAC,OAAY,EAAE,OAAe;QACtD,MAAM,MAAM,GAAG,OAAO,IAAI,OAAO,KAAK,aAAa,CAAC,CAAC,CAAC,IAAI,OAAO,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3E,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAC9B,IAAI,CAAC;gBACD,OAAO,GAAG,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;YACjD,CAAC;YAAC,MAAM,CAAC;gBACL,OAAO,GAAG,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;YACzC,CAAC;QACL,CAAC;QACD,OAAO,GAAG,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;IACzC,CAAC;CACJ,CAAA;AAjDY,8BAAS;oBAAT,SAAS;IADrB,IAAA,mBAAU,GAAE;;GACA,SAAS,CAiDrB"}
|
|
@@ -1,9 +1,13 @@
|
|
|
1
1
|
import { INestApplication } from '@nestjs/common';
|
|
2
|
+
import { IRemoteLogger } from '../types/logger.interface';
|
|
2
3
|
export interface AppSetupOptions {
|
|
3
4
|
corsOrigins?: string[];
|
|
4
5
|
apiPrefix?: string;
|
|
5
6
|
helmet?: boolean;
|
|
6
7
|
validation?: boolean;
|
|
7
8
|
shutdownHooks?: boolean;
|
|
9
|
+
enableTelemetry?: boolean;
|
|
10
|
+
remoteLogger?: IRemoteLogger;
|
|
11
|
+
logger?: any;
|
|
8
12
|
}
|
|
9
13
|
export declare function setupStandardApp(app: INestApplication, options?: AppSetupOptions): void;
|
package/dist/utils/app.utils.js
CHANGED
|
@@ -4,8 +4,12 @@ exports.setupStandardApp = setupStandardApp;
|
|
|
4
4
|
const common_1 = require("@nestjs/common");
|
|
5
5
|
const http_constants_1 = require("../constants/http.constants");
|
|
6
6
|
const helmet_1 = require("helmet");
|
|
7
|
+
const filters_1 = require("../filters");
|
|
7
8
|
function setupStandardApp(app, options = {}) {
|
|
8
|
-
const { corsOrigins = ['*'], apiPrefix = http_constants_1.API_PREFIX.V1, helmet: useHelmet = true, validation = true, shutdownHooks = true, } = options;
|
|
9
|
+
const { corsOrigins = ['*'], apiPrefix = http_constants_1.API_PREFIX.V1, helmet: useHelmet = true, validation = true, shutdownHooks = true, enableTelemetry = true, remoteLogger, logger, } = options;
|
|
10
|
+
if (logger) {
|
|
11
|
+
app.useLogger(logger);
|
|
12
|
+
}
|
|
9
13
|
if (shutdownHooks) {
|
|
10
14
|
app.enableShutdownHooks();
|
|
11
15
|
}
|
|
@@ -27,5 +31,8 @@ function setupStandardApp(app, options = {}) {
|
|
|
27
31
|
},
|
|
28
32
|
}));
|
|
29
33
|
}
|
|
34
|
+
if (enableTelemetry) {
|
|
35
|
+
app.useGlobalFilters(new filters_1.GlobalExceptionFilter(remoteLogger));
|
|
36
|
+
}
|
|
30
37
|
}
|
|
31
38
|
//# sourceMappingURL=app.utils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.utils.js","sourceRoot":"","sources":["../../src/utils/app.utils.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"app.utils.js","sourceRoot":"","sources":["../../src/utils/app.utils.ts"],"names":[],"mappings":";;AAiBA,4CAmDC;AApED,2CAAkE;AAClE,gEAAyD;AACzD,mCAA4B;AAC5B,wCAAmD;AAcnD,SAAgB,gBAAgB,CAC5B,GAAqB,EACrB,UAA2B,EAAE;IAE7B,MAAM,EACF,WAAW,GAAG,CAAC,GAAG,CAAC,EACnB,SAAS,GAAG,2BAAU,CAAC,EAAE,EACzB,MAAM,EAAE,SAAS,GAAG,IAAI,EACxB,UAAU,GAAG,IAAI,EACjB,aAAa,GAAG,IAAI,EACpB,eAAe,GAAG,IAAI,EACtB,YAAY,EACZ,MAAM,GACT,GAAG,OAAO,CAAC;IAEZ,IAAI,MAAM,EAAE,CAAC;QACT,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAED,IAAI,aAAa,EAAE,CAAC;QAChB,GAAG,CAAC,mBAAmB,EAAE,CAAC;IAC9B,CAAC;IAED,GAAG,CAAC,UAAU,CAAC;QACX,MAAM,EAAE,WAAW;QACnB,WAAW,EAAE,IAAI;KACpB,CAAC,CAAC;IAEH,GAAG,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;IAE/B,IAAI,SAAS,EAAE,CAAC;QACZ,GAAG,CAAC,GAAG,CAAC,IAAA,gBAAM,GAAE,CAAC,CAAC;IACtB,CAAC;IAED,IAAI,UAAU,EAAE,CAAC;QACb,GAAG,CAAC,cAAc,CACd,IAAI,uBAAc,CAAC;YACf,SAAS,EAAE,IAAI;YACf,oBAAoB,EAAE,IAAI;YAC1B,SAAS,EAAE,IAAI;YACf,gBAAgB,EAAE;gBACd,wBAAwB,EAAE,IAAI;aACjC;SACJ,CAAC,CACL,CAAC;IACN,CAAC;IAED,IAAI,eAAe,EAAE,CAAC;QAElB,GAAG,CAAC,gBAAgB,CAAC,IAAI,+BAAqB,CAAC,YAAY,CAAC,CAAC,CAAC;IAClE,CAAC;AACL,CAAC"}
|
|
@@ -23,21 +23,12 @@ let HttpExceptionFilter = HttpExceptionFilter_1 = class HttpExceptionFilter {
|
|
|
23
23
|
const message = exception instanceof common_1.HttpException
|
|
24
24
|
? exception.getResponse()
|
|
25
25
|
: 'Internal server error';
|
|
26
|
-
|
|
27
|
-
? message
|
|
28
|
-
: message.message || message;
|
|
29
|
-
if (status >= 500) {
|
|
30
|
-
this.logger.error(`[${request.method}] ${request.url} - ${status} - ${JSON.stringify(errorMessage)}`, exception instanceof Error ? exception.stack : '');
|
|
31
|
-
}
|
|
32
|
-
else {
|
|
33
|
-
this.logger.warn(`[${request.method}] ${request.url} - ${status} - ${JSON.stringify(errorMessage)}`);
|
|
34
|
-
}
|
|
26
|
+
this.logger.error(`${request.method} ${request.url} ${status} error: ${JSON.stringify(message)}`, exception instanceof Error ? exception.stack : undefined);
|
|
35
27
|
response.status(status).json({
|
|
36
28
|
statusCode: status,
|
|
37
29
|
timestamp: new Date().toISOString(),
|
|
38
30
|
path: request.url,
|
|
39
|
-
|
|
40
|
-
error: errorMessage,
|
|
31
|
+
message: typeof message === 'object' ? message.message || message : message,
|
|
41
32
|
});
|
|
42
33
|
}
|
|
43
34
|
};
|
|
@@ -45,4 +36,4 @@ exports.HttpExceptionFilter = HttpExceptionFilter;
|
|
|
45
36
|
exports.HttpExceptionFilter = HttpExceptionFilter = HttpExceptionFilter_1 = __decorate([
|
|
46
37
|
(0, common_1.Catch)()
|
|
47
38
|
], HttpExceptionFilter);
|
|
48
|
-
//# sourceMappingURL=
|
|
39
|
+
//# sourceMappingURL=filters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filters.js","sourceRoot":"","sources":["../../src/utils/filters.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAOwB;AAIjB,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAAzB;QACc,WAAM,GAAG,IAAI,eAAM,CAAC,qBAAmB,CAAC,IAAI,CAAC,CAAC;IA6BnE,CAAC;IA3BG,KAAK,CAAC,SAAkB,EAAE,IAAmB;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAY,CAAC;QAC7C,MAAM,OAAO,GAAG,GAAG,CAAC,UAAU,EAAW,CAAC;QAE1C,MAAM,MAAM,GACR,SAAS,YAAY,sBAAa;YAC9B,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE;YACvB,CAAC,CAAC,mBAAU,CAAC,qBAAqB,CAAC;QAE3C,MAAM,OAAO,GACT,SAAS,YAAY,sBAAa;YAC9B,CAAC,CAAC,SAAS,CAAC,WAAW,EAAE;YACzB,CAAC,CAAC,uBAAuB,CAAC;QAElC,IAAI,CAAC,MAAM,CAAC,KAAK,CACb,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,IAAI,MAAM,WAAW,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,EAC9E,SAAS,YAAY,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAC3D,CAAC;QAEF,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC;YACzB,UAAU,EAAE,MAAM;YAClB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,IAAI,EAAE,OAAO,CAAC,GAAG;YACjB,OAAO,EAAE,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAE,OAAe,CAAC,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,OAAO;SACvF,CAAC,CAAC;IACP,CAAC;CACJ,CAAA;AA9BY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,cAAK,GAAE;GACK,mBAAmB,CA8B/B"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { TracingService } from './tracing.service';
|
|
4
|
+
export declare class GrpcTracingServerInterceptor implements NestInterceptor {
|
|
5
|
+
private readonly tracingService;
|
|
6
|
+
constructor(tracingService: TracingService);
|
|
7
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.GrpcTracingServerInterceptor = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const rxjs_1 = require("rxjs");
|
|
15
|
+
const tracing_service_1 = require("./tracing.service");
|
|
16
|
+
let GrpcTracingServerInterceptor = class GrpcTracingServerInterceptor {
|
|
17
|
+
constructor(tracingService) {
|
|
18
|
+
this.tracingService = tracingService;
|
|
19
|
+
}
|
|
20
|
+
intercept(context, next) {
|
|
21
|
+
if (context.getType() === 'rpc') {
|
|
22
|
+
const metadata = context.switchToRpc().getContext();
|
|
23
|
+
let traceId;
|
|
24
|
+
if (metadata && typeof metadata.get === 'function') {
|
|
25
|
+
const results = metadata.get('x-request-id');
|
|
26
|
+
if (results && results.length > 0) {
|
|
27
|
+
traceId = results[0];
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
if (!traceId) {
|
|
31
|
+
traceId = this.tracingService.generateTraceId();
|
|
32
|
+
}
|
|
33
|
+
return new rxjs_1.Observable((observer) => {
|
|
34
|
+
tracing_service_1.TracingService.getStorage().run(new Map(), () => {
|
|
35
|
+
tracing_service_1.TracingService.setTraceId(traceId);
|
|
36
|
+
next.handle().subscribe(observer);
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return next.handle();
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
exports.GrpcTracingServerInterceptor = GrpcTracingServerInterceptor;
|
|
44
|
+
exports.GrpcTracingServerInterceptor = GrpcTracingServerInterceptor = __decorate([
|
|
45
|
+
(0, common_1.Injectable)(),
|
|
46
|
+
__metadata("design:paramtypes", [tracing_service_1.TracingService])
|
|
47
|
+
], GrpcTracingServerInterceptor);
|
|
48
|
+
//# sourceMappingURL=grpc-tracing-server.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grpc-tracing-server.interceptor.js","sourceRoot":"","sources":["../../src/utils/grpc-tracing-server.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AACxB,+BAAkC;AAClC,uDAAmD;AAI5C,IAAM,4BAA4B,GAAlC,MAAM,4BAA4B;IACrC,YAA6B,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAE/D,SAAS,CAAC,OAAyB,EAAE,IAAiB;QAClD,IAAI,OAAO,CAAC,OAAO,EAAE,KAAK,KAAK,EAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,UAAU,EAAc,CAAC;YAChE,IAAI,OAA2B,CAAC;YAEhC,IAAI,QAAQ,IAAI,OAAO,QAAQ,CAAC,GAAG,KAAK,UAAU,EAAE,CAAC;gBACjD,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;gBAC7C,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAChC,OAAO,GAAG,OAAO,CAAC,CAAC,CAAW,CAAC;gBACnC,CAAC;YACL,CAAC;YAED,IAAI,CAAC,OAAO,EAAE,CAAC;gBACX,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,EAAE,CAAC;YACpD,CAAC;YAED,OAAO,IAAI,iBAAU,CAAC,CAAC,QAAQ,EAAE,EAAE;gBAC/B,gCAAc,CAAC,UAAU,EAAE,CAAC,GAAG,CAAC,IAAI,GAAG,EAAE,EAAE,GAAG,EAAE;oBAC7C,gCAAc,CAAC,UAAU,CAAC,OAAQ,CAAC,CAAC;oBACpC,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBACrC,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACzB,CAAC;CACJ,CAAA;AA5BY,oEAA4B;uCAA5B,4BAA4B;IADxC,IAAA,mBAAU,GAAE;qCAEoC,gCAAc;GADlD,4BAA4B,CA4BxC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { TracingService } from '../utils/tracing.service';
|
|
4
|
+
export declare class GrpcTracingInterceptor implements NestInterceptor {
|
|
5
|
+
private readonly tracingService;
|
|
6
|
+
constructor(tracingService: TracingService);
|
|
7
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.GrpcTracingInterceptor = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const tracing_service_1 = require("../utils/tracing.service");
|
|
15
|
+
let GrpcTracingInterceptor = class GrpcTracingInterceptor {
|
|
16
|
+
constructor(tracingService) {
|
|
17
|
+
this.tracingService = tracingService;
|
|
18
|
+
}
|
|
19
|
+
intercept(context, next) {
|
|
20
|
+
if (context.getType() === 'rpc') {
|
|
21
|
+
const traceId = this.tracingService.getTraceId();
|
|
22
|
+
const metadata = context.switchToRpc().getContext();
|
|
23
|
+
if (metadata && typeof metadata.set === 'function') {
|
|
24
|
+
metadata.set('x-request-id', traceId);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return next.handle();
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
exports.GrpcTracingInterceptor = GrpcTracingInterceptor;
|
|
31
|
+
exports.GrpcTracingInterceptor = GrpcTracingInterceptor = __decorate([
|
|
32
|
+
(0, common_1.Injectable)(),
|
|
33
|
+
__metadata("design:paramtypes", [tracing_service_1.TracingService])
|
|
34
|
+
], GrpcTracingInterceptor);
|
|
35
|
+
//# sourceMappingURL=grpc-tracing.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grpc-tracing.interceptor.js","sourceRoot":"","sources":["../../src/utils/grpc-tracing.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AAExB,8DAA0D;AAInD,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAC/B,YAA6B,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAE/D,SAAS,CAAC,OAAyB,EAAE,IAAiB;QAClD,IAAI,OAAO,CAAC,OAAO,EAAE,KAAK,KAAK,EAAE,CAAC;YAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,CAAC;YACjD,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,UAAU,EAAc,CAAC;YAChE,IAAI,QAAQ,IAAI,OAAO,QAAQ,CAAC,GAAG,KAAK,UAAU,EAAE,CAAC;gBACjD,QAAQ,CAAC,GAAG,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;YAC1C,CAAC;QACL,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACzB,CAAC;CACJ,CAAA;AAbY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;qCAEoC,gCAAc;GADlD,sBAAsB,CAalC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { TracingService } from '../utils/tracing.service';
|
|
4
|
+
export declare class HttpTracingInterceptor implements NestInterceptor {
|
|
5
|
+
private readonly tracingService;
|
|
6
|
+
constructor(tracingService: TracingService);
|
|
7
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.HttpTracingInterceptor = void 0;
|
|
13
|
+
const common_1 = require("@nestjs/common");
|
|
14
|
+
const tracing_service_1 = require("../utils/tracing.service");
|
|
15
|
+
let HttpTracingInterceptor = class HttpTracingInterceptor {
|
|
16
|
+
constructor(tracingService) {
|
|
17
|
+
this.tracingService = tracingService;
|
|
18
|
+
}
|
|
19
|
+
intercept(context, next) {
|
|
20
|
+
if (context.getType() === 'http') {
|
|
21
|
+
const request = context.switchToHttp().getRequest();
|
|
22
|
+
const traceId = this.tracingService.getTraceId();
|
|
23
|
+
if (request.headers) {
|
|
24
|
+
request.headers['x-request-id'] = traceId;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return next.handle();
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
exports.HttpTracingInterceptor = HttpTracingInterceptor;
|
|
31
|
+
exports.HttpTracingInterceptor = HttpTracingInterceptor = __decorate([
|
|
32
|
+
(0, common_1.Injectable)(),
|
|
33
|
+
__metadata("design:paramtypes", [tracing_service_1.TracingService])
|
|
34
|
+
], HttpTracingInterceptor);
|
|
35
|
+
//# sourceMappingURL=http-tracing.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-tracing.interceptor.js","sourceRoot":"","sources":["../../src/utils/http-tracing.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAKwB;AAExB,8DAA0D;AAGnD,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAC/B,YAA6B,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;IAAG,CAAC;IAE/D,SAAS,CAAC,OAAyB,EAAE,IAAiB;QAClD,IAAI,OAAO,CAAC,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;YAC/B,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;YACpD,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,CAAC;YACjD,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;gBAClB,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC;YAC9C,CAAC;QACL,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACzB,CAAC;CACJ,CAAA;AAbY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;qCAEoC,gCAAc;GADlD,sBAAsB,CAalC"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
|
|
2
2
|
import { Observable } from 'rxjs';
|
|
3
3
|
export interface Response<T> {
|
|
4
|
-
statusCode: number;
|
|
5
4
|
data: T;
|
|
6
5
|
}
|
|
7
6
|
export declare class TransformInterceptor<T> implements NestInterceptor<T, Response<T>> {
|
|
@@ -11,9 +11,9 @@ const common_1 = require("@nestjs/common");
|
|
|
11
11
|
const operators_1 = require("rxjs/operators");
|
|
12
12
|
let TransformInterceptor = class TransformInterceptor {
|
|
13
13
|
intercept(context, next) {
|
|
14
|
-
return next.handle().pipe((0, operators_1.map)(data => ({
|
|
15
|
-
statusCode: context.switchToHttp().getResponse().statusCode,
|
|
14
|
+
return next.handle().pipe((0, operators_1.map)((data) => ({
|
|
16
15
|
data,
|
|
16
|
+
timestamp: new Date().toISOString(),
|
|
17
17
|
})));
|
|
18
18
|
}
|
|
19
19
|
};
|
|
@@ -21,4 +21,4 @@ exports.TransformInterceptor = TransformInterceptor;
|
|
|
21
21
|
exports.TransformInterceptor = TransformInterceptor = __decorate([
|
|
22
22
|
(0, common_1.Injectable)()
|
|
23
23
|
], TransformInterceptor);
|
|
24
|
-
//# sourceMappingURL=
|
|
24
|
+
//# sourceMappingURL=interceptors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interceptors.js","sourceRoot":"","sources":["../../src/utils/interceptors.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAKwB;AAExB,8CAAqC;AAO9B,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAC7B,SAAS,CACL,OAAyB,EACzB,IAAiB;QAEjB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACrB,IAAA,eAAG,EAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACX,IAAI;YACJ,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACtC,CAAC,CAAC,CACN,CAAC;IACN,CAAC;CACJ,CAAA;AAZY,oDAAoB;+BAApB,oBAAoB;IADhC,IAAA,mBAAU,GAAE;GACA,oBAAoB,CAYhC"}
|
package/dist/utils/proto-path.js
CHANGED
|
@@ -6,7 +6,7 @@ function getProtoPath(serviceName) {
|
|
|
6
6
|
if (process.env.PROTO_PATH_OVERRIDE) {
|
|
7
7
|
return (0, path_1.join)(process.env.PROTO_PATH_OVERRIDE, `${serviceName}.proto`);
|
|
8
8
|
}
|
|
9
|
-
const dockerProtoPath = '/app/proto';
|
|
9
|
+
const dockerProtoPath = '/app/sdks/shared/proto';
|
|
10
10
|
if (process.platform === 'linux' || process.env.NODE_ENV === 'production' || process.env.KUBERNETES_SERVICE_HOST) {
|
|
11
11
|
return (0, path_1.join)(dockerProtoPath, `${serviceName}.proto`);
|
|
12
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"proto-path.js","sourceRoot":"","sources":["../../src/utils/proto-path.ts"],"names":[],"mappings":";;AAEA,oCAkBC;AApBD,+BAA4B;AAE5B,SAAgB,YAAY,CAAC,WAAmB;IAE5C,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,CAAC;QAClC,OAAO,IAAA,WAAI,EAAC,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,GAAG,WAAW,QAAQ,CAAC,CAAC;IACzE,CAAC;IAKD,MAAM,eAAe,GAAG,
|
|
1
|
+
{"version":3,"file":"proto-path.js","sourceRoot":"","sources":["../../src/utils/proto-path.ts"],"names":[],"mappings":";;AAEA,oCAkBC;AApBD,+BAA4B;AAE5B,SAAgB,YAAY,CAAC,WAAmB;IAE5C,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,CAAC;QAClC,OAAO,IAAA,WAAI,EAAC,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,GAAG,WAAW,QAAQ,CAAC,CAAC;IACzE,CAAC;IAKD,MAAM,eAAe,GAAG,wBAAwB,CAAC;IAGjD,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,IAAI,OAAO,CAAC,GAAG,CAAC,uBAAuB,EAAE,CAAC;QAC/G,OAAO,IAAA,WAAI,EAAC,eAAe,EAAE,GAAG,WAAW,QAAQ,CAAC,CAAC;IACzD,CAAC;IAGD,OAAO,IAAA,WAAI,EAAC,OAAO,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,GAAG,WAAW,QAAQ,CAAC,CAAC;AAChE,CAAC"}
|
|
@@ -6,23 +6,17 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
6
6
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
7
|
};
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.
|
|
9
|
+
exports.TracingModule = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
|
-
const
|
|
12
|
-
let
|
|
11
|
+
const tracing_service_1 = require("./tracing.service");
|
|
12
|
+
let TracingModule = class TracingModule {
|
|
13
13
|
};
|
|
14
|
-
exports.
|
|
15
|
-
exports.
|
|
14
|
+
exports.TracingModule = TracingModule;
|
|
15
|
+
exports.TracingModule = TracingModule = __decorate([
|
|
16
|
+
(0, common_1.Global)(),
|
|
16
17
|
(0, common_1.Module)({
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
path: '/metrics',
|
|
20
|
-
defaultMetrics: {
|
|
21
|
-
enabled: true,
|
|
22
|
-
},
|
|
23
|
-
}),
|
|
24
|
-
],
|
|
25
|
-
exports: [nestjs_prometheus_1.PrometheusModule],
|
|
18
|
+
providers: [tracing_service_1.TracingService],
|
|
19
|
+
exports: [tracing_service_1.TracingService],
|
|
26
20
|
})
|
|
27
|
-
],
|
|
28
|
-
//# sourceMappingURL=
|
|
21
|
+
], TracingModule);
|
|
22
|
+
//# sourceMappingURL=tracing.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tracing.module.js","sourceRoot":"","sources":["../../src/utils/tracing.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAgD;AAChD,uDAAmD;AAO5C,IAAM,aAAa,GAAnB,MAAM,aAAa;CAAG,CAAA;AAAhB,sCAAa;wBAAb,aAAa;IALzB,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACJ,SAAS,EAAE,CAAC,gCAAc,CAAC;QAC3B,OAAO,EAAE,CAAC,gCAAc,CAAC;KAC5B,CAAC;GACW,aAAa,CAAG"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'async_hooks';
|
|
2
|
+
export declare class TracingService {
|
|
3
|
+
private static readonly storage;
|
|
4
|
+
static getStorage(): AsyncLocalStorage<Map<string, string>>;
|
|
5
|
+
static setTraceId(traceId: string): void;
|
|
6
|
+
static getTraceId(): string;
|
|
7
|
+
setTraceId(traceId: string): void;
|
|
8
|
+
getTraceId(): string;
|
|
9
|
+
generateTraceId(): string;
|
|
10
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
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 TracingService_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.TracingService = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const async_hooks_1 = require("async_hooks");
|
|
13
|
+
const uuid_1 = require("uuid");
|
|
14
|
+
let TracingService = TracingService_1 = class TracingService {
|
|
15
|
+
static getStorage() {
|
|
16
|
+
return this.storage;
|
|
17
|
+
}
|
|
18
|
+
static setTraceId(traceId) {
|
|
19
|
+
const store = TracingService_1.storage.getStore();
|
|
20
|
+
if (store) {
|
|
21
|
+
store.set('traceId', traceId);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
static getTraceId() {
|
|
25
|
+
const store = TracingService_1.storage.getStore();
|
|
26
|
+
return store?.get('traceId') || 'no-trace-id';
|
|
27
|
+
}
|
|
28
|
+
setTraceId(traceId) {
|
|
29
|
+
TracingService_1.setTraceId(traceId);
|
|
30
|
+
}
|
|
31
|
+
getTraceId() {
|
|
32
|
+
return TracingService_1.getTraceId();
|
|
33
|
+
}
|
|
34
|
+
generateTraceId() {
|
|
35
|
+
return (0, uuid_1.v4)();
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
exports.TracingService = TracingService;
|
|
39
|
+
TracingService.storage = new async_hooks_1.AsyncLocalStorage();
|
|
40
|
+
exports.TracingService = TracingService = TracingService_1 = __decorate([
|
|
41
|
+
(0, common_1.Injectable)()
|
|
42
|
+
], TracingService);
|
|
43
|
+
//# sourceMappingURL=tracing.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tracing.service.js","sourceRoot":"","sources":["../../src/utils/tracing.service.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAgD;AAChD,+BAAoC;AAG7B,IAAM,cAAc,sBAApB,MAAM,cAAc;IAGvB,MAAM,CAAC,UAAU;QACb,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,MAAM,CAAC,UAAU,CAAC,OAAe;QAC7B,MAAM,KAAK,GAAG,gBAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QAChD,IAAI,KAAK,EAAE,CAAC;YACR,KAAK,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAClC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,UAAU;QACb,MAAM,KAAK,GAAG,gBAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QAChD,OAAO,KAAK,EAAE,GAAG,CAAC,SAAS,CAAC,IAAI,aAAa,CAAC;IAClD,CAAC;IAED,UAAU,CAAC,OAAe;QACtB,gBAAc,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAED,UAAU;QACN,OAAO,gBAAc,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC;IAED,eAAe;QACX,OAAO,IAAA,SAAM,GAAE,CAAC;IACpB,CAAC;;AA7BQ,wCAAc;AACC,sBAAO,GAAG,IAAI,+BAAiB,EAAuB,AAA/C,CAAgD;yBADtE,cAAc;IAD1B,IAAA,mBAAU,GAAE;GACA,cAAc,CA8B1B"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.initTracing = initTracing;
|
|
4
|
+
function initTracing(serviceName) {
|
|
5
|
+
console.log(`[Tracing] Initializing for ${serviceName} (No-op implementation)`);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=tracing.utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tracing.utils.js","sourceRoot":"","sources":["../../src/utils/tracing.utils.ts"],"names":[],"mappings":";;AAAA,kCAEC;AAFD,SAAgB,WAAW,CAAC,WAAmB;IAC3C,OAAO,CAAC,GAAG,CAAC,8BAA8B,WAAW,yBAAyB,CAAC,CAAC;AACpF,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,48 +1,50 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
"
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
2
|
+
"name": "@alacard-project/shared",
|
|
3
|
+
"version": "1.1.4",
|
|
4
|
+
"engines": {
|
|
5
|
+
"node": ">=22.0.0"
|
|
6
|
+
},
|
|
7
|
+
"description": "Pure types and constants for Alacard microservices",
|
|
8
|
+
"main": "dist/index.js",
|
|
9
|
+
"types": "dist/index.d.ts",
|
|
10
|
+
"exports": {
|
|
11
|
+
".": "./dist/index.js",
|
|
12
|
+
"./dist/*": "./dist/*",
|
|
13
|
+
"./*": "./dist/*.js"
|
|
14
|
+
},
|
|
15
|
+
"files": [
|
|
16
|
+
"dist",
|
|
17
|
+
"README.md"
|
|
18
|
+
],
|
|
19
|
+
"scripts": {
|
|
20
|
+
"build": "tsc",
|
|
21
|
+
"watch": "tsc -w"
|
|
22
|
+
},
|
|
23
|
+
"peerDependencies": {
|
|
24
|
+
"@nestjs/common": "10.4.15",
|
|
25
|
+
"@nestjs/core": "10.4.15",
|
|
26
|
+
"@nestjs/microservices": "10.4.15",
|
|
27
|
+
"reflect-metadata": "0.2.2",
|
|
28
|
+
"rxjs": "7.8.1"
|
|
29
|
+
},
|
|
30
|
+
"dependencies": {
|
|
31
|
+
"@types/opossum": "8.1.9",
|
|
32
|
+
"axios": "^1.7.9",
|
|
33
|
+
"class-transformer": "0.5.1",
|
|
34
|
+
"class-validator": "0.14.1",
|
|
35
|
+
"helmet": "8.1.0",
|
|
36
|
+
"opossum": "8.1.4",
|
|
37
|
+
"uuid": "^11.0.0"
|
|
38
|
+
},
|
|
39
|
+
"devDependencies": {
|
|
40
|
+
"@types/uuid": "^10.0.0",
|
|
41
|
+
"@nestjs/common": "10.4.15",
|
|
42
|
+
"@nestjs/config": "3.3.0",
|
|
43
|
+
"@nestjs/core": "10.4.15",
|
|
44
|
+
"@nestjs/microservices": "10.4.15",
|
|
45
|
+
"@types/node": "22.10.10",
|
|
46
|
+
"reflect-metadata": "0.2.2",
|
|
47
|
+
"rxjs": "7.8.1",
|
|
48
|
+
"typescript": "~5.9.3"
|
|
49
|
+
}
|
|
48
50
|
}
|