@alacard-project/shared 1.1.2 → 1.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/constants/microservices.constants.d.ts +4 -0
  2. package/dist/constants/microservices.constants.js +4 -0
  3. package/dist/constants/microservices.constants.js.map +1 -1
  4. package/dist/contracts/card.contract.d.ts +98 -0
  5. package/dist/contracts/card.contract.js +3 -0
  6. package/dist/contracts/card.contract.js.map +1 -0
  7. package/dist/contracts/index.d.ts +3 -1
  8. package/dist/contracts/index.js +3 -0
  9. package/dist/contracts/index.js.map +1 -1
  10. package/dist/contracts/transaction.contract.d.ts +63 -0
  11. package/dist/contracts/transaction.contract.js +3 -0
  12. package/dist/contracts/transaction.contract.js.map +1 -0
  13. package/dist/dto/auth.dto.d.ts +3 -1
  14. package/dist/dto/auth.dto.js +11 -0
  15. package/dist/dto/auth.dto.js.map +1 -1
  16. package/dist/filters/global-exception.filter.d.ts +12 -0
  17. package/dist/filters/global-exception.filter.js +156 -0
  18. package/dist/filters/global-exception.filter.js.map +1 -0
  19. package/dist/filters/index.d.ts +1 -0
  20. package/dist/filters/index.js +18 -0
  21. package/dist/filters/index.js.map +1 -0
  22. package/dist/index.d.ts +8 -0
  23. package/dist/index.js +8 -0
  24. package/dist/index.js.map +1 -1
  25. package/dist/middleware/index.d.ts +2 -0
  26. package/dist/middleware/index.js +19 -0
  27. package/dist/middleware/index.js.map +1 -0
  28. package/dist/middleware/prisma-logging.middleware.d.ts +3 -0
  29. package/dist/middleware/prisma-logging.middleware.js +52 -0
  30. package/dist/middleware/prisma-logging.middleware.js.map +1 -0
  31. package/dist/middleware/tracing.middleware.d.ts +8 -0
  32. package/dist/middleware/tracing.middleware.js +33 -0
  33. package/dist/middleware/tracing.middleware.js.map +1 -0
  34. package/dist/resilience/circuit-breaker.service.d.ts +1 -1
  35. package/dist/resilience/circuit-breaker.service.js +2 -2
  36. package/dist/resilience/circuit-breaker.service.js.map +1 -1
  37. package/dist/tsconfig.tsbuildinfo +1 -1
  38. package/dist/types/logger.interface.d.ts +6 -0
  39. package/dist/types/logger.interface.js +3 -0
  40. package/dist/types/logger.interface.js.map +1 -0
  41. package/dist/utils/app-logger.d.ts +11 -0
  42. package/dist/utils/app-logger.js +65 -0
  43. package/dist/utils/app-logger.js.map +1 -0
  44. package/dist/utils/app.utils.d.ts +10 -1
  45. package/dist/utils/app.utils.js +26 -2
  46. package/dist/utils/app.utils.js.map +1 -1
  47. package/dist/utils/bootstrap.utils.d.ts +15 -0
  48. package/dist/utils/bootstrap.utils.js +70 -0
  49. package/dist/utils/bootstrap.utils.js.map +1 -0
  50. package/dist/utils/grpc-tracing-server.interceptor.d.ts +8 -0
  51. package/dist/utils/grpc-tracing-server.interceptor.js +48 -0
  52. package/dist/utils/grpc-tracing-server.interceptor.js.map +1 -0
  53. package/dist/utils/grpc-tracing.interceptor.d.ts +8 -0
  54. package/dist/utils/grpc-tracing.interceptor.js +35 -0
  55. package/dist/utils/grpc-tracing.interceptor.js.map +1 -0
  56. package/dist/utils/http-tracing.interceptor.d.ts +8 -0
  57. package/dist/utils/http-tracing.interceptor.js +35 -0
  58. package/dist/utils/http-tracing.interceptor.js.map +1 -0
  59. package/dist/utils/proto-path.js +1 -1
  60. package/dist/utils/proto-path.js.map +1 -1
  61. package/dist/utils/standard-health.module.d.ts +10 -0
  62. package/dist/utils/standard-health.module.js +59 -0
  63. package/dist/utils/standard-health.module.js.map +1 -0
  64. package/dist/utils/tracing.module.d.ts +2 -0
  65. package/dist/utils/tracing.module.js +22 -0
  66. package/dist/utils/tracing.module.js.map +1 -0
  67. package/dist/utils/tracing.service.d.ts +10 -0
  68. package/dist/utils/tracing.service.js +43 -0
  69. package/dist/utils/tracing.service.js.map +1 -0
  70. package/package.json +49 -45
@@ -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,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=logger.interface.js.map
@@ -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,18 @@
1
1
  import { INestApplication } from '@nestjs/common';
2
2
  export interface AppSetupOptions {
3
- corsOrigins?: string[];
3
+ corsOrigins?: string | string[];
4
4
  apiPrefix?: string;
5
5
  helmet?: boolean;
6
6
  validation?: boolean;
7
7
  shutdownHooks?: boolean;
8
+ enableTelemetry?: boolean;
9
+ remoteLogger?: any;
10
+ logger?: any;
11
+ swagger?: {
12
+ title: string;
13
+ description: string;
14
+ version: string;
15
+ path?: string;
16
+ };
8
17
  }
9
18
  export declare function setupStandardApp(app: INestApplication, options?: AppSetupOptions): void;
@@ -4,8 +4,13 @@ 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");
8
+ const swagger_1 = require("@nestjs/swagger");
7
9
  function setupStandardApp(app, options = {}) {
8
- const { corsOrigins = ['*'], apiPrefix = http_constants_1.API_PREFIX.V1, helmet: useHelmet = true, validation = true, shutdownHooks = true, } = options;
10
+ const { corsOrigins = ['*'], apiPrefix = http_constants_1.API_PREFIX.V1, helmet: useHelmet = true, validation = true, shutdownHooks = true, enableTelemetry = true, remoteLogger, logger, swagger, } = options;
11
+ if (logger) {
12
+ app.useLogger(logger);
13
+ }
9
14
  if (shutdownHooks) {
10
15
  app.enableShutdownHooks();
11
16
  }
@@ -13,7 +18,9 @@ function setupStandardApp(app, options = {}) {
13
18
  origin: corsOrigins,
14
19
  credentials: true,
15
20
  });
16
- app.setGlobalPrefix(apiPrefix);
21
+ app.setGlobalPrefix(apiPrefix, {
22
+ exclude: ['metrics', 'health/live', 'health/ready', 'health/info'],
23
+ });
17
24
  if (useHelmet) {
18
25
  app.use((0, helmet_1.default)());
19
26
  }
@@ -27,5 +34,22 @@ function setupStandardApp(app, options = {}) {
27
34
  },
28
35
  }));
29
36
  }
37
+ if (enableTelemetry) {
38
+ app.useGlobalFilters(new filters_1.GlobalExceptionFilter(remoteLogger));
39
+ }
40
+ if (process.env.NODE_ENV !== 'production' || swagger) {
41
+ const title = swagger?.title || 'Alacard Microservice API';
42
+ const description = swagger?.description || 'Alacard v5 Monorepo Service';
43
+ const version = swagger?.version || '1.0.0';
44
+ const path = swagger?.path || 'docs';
45
+ const config = new swagger_1.DocumentBuilder()
46
+ .setTitle(title)
47
+ .setDescription(description)
48
+ .setVersion(version)
49
+ .addBearerAuth()
50
+ .build();
51
+ const document = swagger_1.SwaggerModule.createDocument(app, config);
52
+ swagger_1.SwaggerModule.setup(path, app, document);
53
+ }
30
54
  }
31
55
  //# sourceMappingURL=app.utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"app.utils.js","sourceRoot":"","sources":["../../src/utils/app.utils.ts"],"names":[],"mappings":";;AAYA,4CAuCC;AAnDD,2CAAkE;AAClE,gEAAyD;AACzD,mCAA4B;AAU5B,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,GACvB,GAAG,OAAO,CAAC;IAEZ,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;AACL,CAAC"}
1
+ {"version":3,"file":"app.utils.js","sourceRoot":"","sources":["../../src/utils/app.utils.ts"],"names":[],"mappings":";;AAwBA,4CAwEC;AAhGD,2CAAkE;AAClE,gEAAyD;AACzD,mCAA4B;AAC5B,wCAAmD;AAEnD,6CAAiE;AAmBjE,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,EACN,OAAO,GACV,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,EAAE;QAC3B,OAAO,EAAE,CAAC,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,aAAa,CAAC;KACrE,CAAC,CAAC;IAEH,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;IAGD,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,IAAI,OAAO,EAAE,CAAC;QACnD,MAAM,KAAK,GAAG,OAAO,EAAE,KAAK,IAAI,0BAA0B,CAAC;QAC3D,MAAM,WAAW,GAAG,OAAO,EAAE,WAAW,IAAI,6BAA6B,CAAC;QAC1E,MAAM,OAAO,GAAG,OAAO,EAAE,OAAO,IAAI,OAAO,CAAC;QAC5C,MAAM,IAAI,GAAG,OAAO,EAAE,IAAI,IAAI,MAAM,CAAC;QAErC,MAAM,MAAM,GAAG,IAAI,yBAAe,EAAE;aAC/B,QAAQ,CAAC,KAAK,CAAC;aACf,cAAc,CAAC,WAAW,CAAC;aAC3B,UAAU,CAAC,OAAO,CAAC;aACnB,aAAa,EAAE;aACf,KAAK,EAAE,CAAC;QAEb,MAAM,QAAQ,GAAG,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC3D,uBAAa,CAAC,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC;IAC7C,CAAC;AACL,CAAC"}
@@ -0,0 +1,15 @@
1
+ export interface BootstrapOptions {
2
+ serviceName: string;
3
+ apiPrefix: string;
4
+ grpcPackage?: string;
5
+ port?: number;
6
+ grpcPort?: number;
7
+ corsOrigins?: string | string[];
8
+ kafka?: {
9
+ brokers?: string[];
10
+ groupId?: string;
11
+ };
12
+ }
13
+ export declare class StandardBootstrap {
14
+ static run(appModule: any, options: BootstrapOptions): Promise<import("@nestjs/common").INestApplication<any>>;
15
+ }
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StandardBootstrap = void 0;
4
+ const core_1 = require("@nestjs/core");
5
+ const microservices_1 = require("@nestjs/microservices");
6
+ const config_sdk_1 = require("@alacard-project/config-sdk");
7
+ const logging_sdk_1 = require("@alacard-project/logging-sdk");
8
+ const app_utils_1 = require("./app.utils");
9
+ const tracing_utils_1 = require("./tracing.utils");
10
+ const proto_path_1 = require("./proto-path");
11
+ class StandardBootstrap {
12
+ static async run(appModule, options) {
13
+ const environment = process.env.NODE_ENV || 'development';
14
+ const configServiceUrl = process.env.CONFIG_SERVICE_URL || 'config-microservice:50055';
15
+ const internalKey = process.env.INTERNAL_CONFIG_KEY;
16
+ (0, tracing_utils_1.initTracing)(options.serviceName);
17
+ await config_sdk_1.ConfigClient.initialize({
18
+ serviceName: options.serviceName,
19
+ environment,
20
+ grpcUrl: configServiceUrl,
21
+ internalKey,
22
+ });
23
+ const app = await core_1.NestFactory.create(appModule, {
24
+ bufferLogs: true,
25
+ });
26
+ const remoteLogger = app.get(logging_sdk_1.RemoteLogger);
27
+ app.useLogger(remoteLogger);
28
+ (0, app_utils_1.setupStandardApp)(app, {
29
+ apiPrefix: options.apiPrefix,
30
+ remoteLogger,
31
+ corsOrigins: options.corsOrigins,
32
+ });
33
+ if (options.grpcPackage) {
34
+ const finalGrpcPort = options.grpcPort || 50051;
35
+ app.connectMicroservice({
36
+ transport: microservices_1.Transport.GRPC,
37
+ options: {
38
+ package: options.grpcPackage,
39
+ protoPath: (0, proto_path_1.getProtoPath)(options.grpcPackage),
40
+ url: `0.0.0.0:${finalGrpcPort}`,
41
+ },
42
+ });
43
+ }
44
+ if (options.kafka) {
45
+ app.connectMicroservice({
46
+ transport: microservices_1.Transport.KAFKA,
47
+ options: {
48
+ client: {
49
+ brokers: options.kafka.brokers || (process.env.KAFKA_BROKERS || 'kafka:29092').split(','),
50
+ },
51
+ consumer: {
52
+ groupId: options.kafka.groupId || `${options.serviceName}-consumer`,
53
+ },
54
+ },
55
+ });
56
+ }
57
+ if (options.grpcPackage || options.kafka) {
58
+ await app.startAllMicroservices();
59
+ }
60
+ const finalPort = options.port || 3000;
61
+ await app.listen(finalPort, '0.0.0.0');
62
+ console.log(`🚀 ${options.serviceName} is running on: http://localhost:${finalPort}`);
63
+ if (options.grpcPackage) {
64
+ console.log(`📊 gRPC is running on: 0.0.0.0:${options.grpcPort || 50051}`);
65
+ }
66
+ return app;
67
+ }
68
+ }
69
+ exports.StandardBootstrap = StandardBootstrap;
70
+ //# sourceMappingURL=bootstrap.utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bootstrap.utils.js","sourceRoot":"","sources":["../../src/utils/bootstrap.utils.ts"],"names":[],"mappings":";;;AAAA,uCAA2C;AAC3C,yDAAuE;AACvE,4DAA2D;AAC3D,8DAA4D;AAC5D,2CAA+C;AAC/C,mDAA8C;AAC9C,6CAA4C;AAgB5C,MAAa,iBAAiB;IACnB,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,SAAc,EAAE,OAAyB;QAC7D,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,aAAa,CAAC;QAC1D,MAAM,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,2BAA2B,CAAC;QACvF,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC;QAGpD,IAAA,2BAAW,EAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAGjC,MAAM,yBAAY,CAAC,UAAU,CAAC;YAC1B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,WAAW;YACX,OAAO,EAAE,gBAAgB;YACzB,WAAW;SACd,CAAC,CAAC;QAGH,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,SAAS,EAAE;YAC5C,UAAU,EAAE,IAAI;SACnB,CAAC,CAAC;QAGH,MAAM,YAAY,GAAG,GAAG,CAAC,GAAG,CAAC,0BAAY,CAAC,CAAC;QAC3C,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAG5B,IAAA,4BAAgB,EAAC,GAAU,EAAE;YACzB,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,YAAY;YACZ,WAAW,EAAE,OAAO,CAAC,WAAW;SACnC,CAAC,CAAC;QAGH,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,IAAI,KAAK,CAAC;YAChD,GAAG,CAAC,mBAAmB,CAAsB;gBACzC,SAAS,EAAE,yBAAS,CAAC,IAAI;gBACzB,OAAO,EAAE;oBACL,OAAO,EAAE,OAAO,CAAC,WAAW;oBAC5B,SAAS,EAAE,IAAA,yBAAY,EAAC,OAAO,CAAC,WAAW,CAAC;oBAC5C,GAAG,EAAE,WAAW,aAAa,EAAE;iBAClC;aACJ,CAAC,CAAC;QACP,CAAC;QAED,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAChB,GAAG,CAAC,mBAAmB,CAAsB;gBACzC,SAAS,EAAE,yBAAS,CAAC,KAAK;gBAC1B,OAAO,EAAE;oBACL,MAAM,EAAE;wBACJ,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,aAAa,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC;qBAC5F;oBACD,QAAQ,EAAE;wBACN,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,IAAI,GAAG,OAAO,CAAC,WAAW,WAAW;qBACtE;iBACJ;aACJ,CAAC,CAAC;QACP,CAAC;QAED,IAAI,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YACvC,MAAM,GAAG,CAAC,qBAAqB,EAAE,CAAC;QACtC,CAAC;QAGD,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC;QACvC,MAAM,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QAEvC,OAAO,CAAC,GAAG,CAAC,MAAM,OAAO,CAAC,WAAW,oCAAoC,SAAS,EAAE,CAAC,CAAC;QACtF,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,kCAAkC,OAAO,CAAC,QAAQ,IAAI,KAAK,EAAE,CAAC,CAAC;QAC/E,CAAC;QAED,OAAO,GAAG,CAAC;IACf,CAAC;CACJ;AA3ED,8CA2EC"}
@@ -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"}
@@ -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,YAAY,CAAC;IAGrC,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"}
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"}
@@ -0,0 +1,10 @@
1
+ import { HealthCheckService, HealthCheckResult, MemoryHealthIndicator } from '@nestjs/terminus';
2
+ export declare class StandardHealthController {
3
+ private health;
4
+ private memory;
5
+ constructor(health: HealthCheckService, memory: MemoryHealthIndicator);
6
+ checkLiveness(): Promise<HealthCheckResult>;
7
+ checkReadiness(): Promise<HealthCheckResult>;
8
+ }
9
+ export declare class StandardHealthModule {
10
+ }
@@ -0,0 +1,59 @@
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.StandardHealthModule = exports.StandardHealthController = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const terminus_1 = require("@nestjs/terminus");
15
+ let StandardHealthController = class StandardHealthController {
16
+ constructor(health, memory) {
17
+ this.health = health;
18
+ this.memory = memory;
19
+ }
20
+ async checkLiveness() {
21
+ return this.health.check([]);
22
+ }
23
+ async checkReadiness() {
24
+ return this.health.check([
25
+ () => this.memory.checkHeap('memory_heap', 150 * 1024 * 1024),
26
+ ]);
27
+ }
28
+ };
29
+ exports.StandardHealthController = StandardHealthController;
30
+ __decorate([
31
+ (0, common_1.Get)('live'),
32
+ (0, terminus_1.HealthCheck)(),
33
+ __metadata("design:type", Function),
34
+ __metadata("design:paramtypes", []),
35
+ __metadata("design:returntype", Promise)
36
+ ], StandardHealthController.prototype, "checkLiveness", null);
37
+ __decorate([
38
+ (0, common_1.Get)('ready'),
39
+ (0, terminus_1.HealthCheck)(),
40
+ __metadata("design:type", Function),
41
+ __metadata("design:paramtypes", []),
42
+ __metadata("design:returntype", Promise)
43
+ ], StandardHealthController.prototype, "checkReadiness", null);
44
+ exports.StandardHealthController = StandardHealthController = __decorate([
45
+ (0, common_1.Controller)('health'),
46
+ __metadata("design:paramtypes", [terminus_1.HealthCheckService,
47
+ terminus_1.MemoryHealthIndicator])
48
+ ], StandardHealthController);
49
+ let StandardHealthModule = class StandardHealthModule {
50
+ };
51
+ exports.StandardHealthModule = StandardHealthModule;
52
+ exports.StandardHealthModule = StandardHealthModule = __decorate([
53
+ (0, common_1.Module)({
54
+ imports: [terminus_1.TerminusModule],
55
+ controllers: [StandardHealthController],
56
+ exports: [terminus_1.TerminusModule],
57
+ })
58
+ ], StandardHealthModule);
59
+ //# sourceMappingURL=standard-health.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"standard-health.module.js","sourceRoot":"","sources":["../../src/utils/standard-health.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAyD;AACzD,+CAA6H;AAGtH,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IACjC,YACY,MAA0B,EAC1B,MAA6B;QAD7B,WAAM,GAAN,MAAM,CAAoB;QAC1B,WAAM,GAAN,MAAM,CAAuB;IACrC,CAAC;IAIC,AAAN,KAAK,CAAC,aAAa;QACf,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IACjC,CAAC;IAIK,AAAN,KAAK,CAAC,cAAc;QAGhB,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YACrB,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,aAAa,EAAE,GAAG,GAAG,IAAI,GAAG,IAAI,CAAC;SAChE,CAAC,CAAC;IACP,CAAC;CACJ,CAAA;AArBY,4DAAwB;AAQ3B;IAFL,IAAA,YAAG,EAAC,MAAM,CAAC;IACX,IAAA,sBAAW,GAAE;;;;6DAGb;AAIK;IAFL,IAAA,YAAG,EAAC,OAAO,CAAC;IACZ,IAAA,sBAAW,GAAE;;;;8DAOb;mCApBQ,wBAAwB;IADpC,IAAA,mBAAU,EAAC,QAAQ,CAAC;qCAGG,6BAAkB;QAClB,gCAAqB;GAHhC,wBAAwB,CAqBpC;AAOM,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;CAAI,CAAA;AAAxB,oDAAoB;+BAApB,oBAAoB;IALhC,IAAA,eAAM,EAAC;QACJ,OAAO,EAAE,CAAC,yBAAc,CAAC;QACzB,WAAW,EAAE,CAAC,wBAAwB,CAAC;QACvC,OAAO,EAAE,CAAC,yBAAc,CAAC;KAC5B,CAAC;GACW,oBAAoB,CAAI"}
@@ -0,0 +1,2 @@
1
+ export declare class TracingModule {
2
+ }
@@ -0,0 +1,22 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.TracingModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const tracing_service_1 = require("./tracing.service");
12
+ let TracingModule = class TracingModule {
13
+ };
14
+ exports.TracingModule = TracingModule;
15
+ exports.TracingModule = TracingModule = __decorate([
16
+ (0, common_1.Global)(),
17
+ (0, common_1.Module)({
18
+ providers: [tracing_service_1.TracingService],
19
+ exports: [tracing_service_1.TracingService],
20
+ })
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"}