xcally-nest-library 0.0.26 → 0.0.28

Sign up to get free protection for your applications and to get access to all the features.
Files changed (76) hide show
  1. package/dist/index.d.ts +0 -8
  2. package/dist/index.js +0 -8
  3. package/dist/index.js.map +1 -1
  4. package/dist/src/modules/logger/pino/logger.module.js +3 -1
  5. package/dist/src/modules/logger/pino/logger.module.js.map +1 -1
  6. package/dist/src/modules/logger/pino/logger.service.js +0 -13
  7. package/dist/src/modules/logger/pino/logger.service.js.map +1 -1
  8. package/dist/tsconfig.tsbuildinfo +1 -1
  9. package/index.ts +0 -8
  10. package/package.json +16 -66
  11. package/src/modules/logger/pino/logger.module.ts +3 -1
  12. package/src/modules/logger/pino/logger.service.ts +0 -13
  13. package/dist/src/config/env.validation.d.ts +0 -22
  14. package/dist/src/config/env.validation.js +0 -82
  15. package/dist/src/config/env.validation.js.map +0 -1
  16. package/dist/src/decorators/utils.decorators.d.ts +0 -2
  17. package/dist/src/decorators/utils.decorators.js +0 -15
  18. package/dist/src/decorators/utils.decorators.js.map +0 -1
  19. package/dist/src/interceptors/log-request.interceptor.d.ts +0 -8
  20. package/dist/src/interceptors/log-request.interceptor.js +0 -44
  21. package/dist/src/interceptors/log-request.interceptor.js.map +0 -1
  22. package/dist/src/interceptors/serialize.interceptor.d.ts +0 -12
  23. package/dist/src/interceptors/serialize.interceptor.js +0 -24
  24. package/dist/src/interceptors/serialize.interceptor.js.map +0 -1
  25. package/dist/src/modules/logger/consoleTransport.strategy.d.ts +0 -5
  26. package/dist/src/modules/logger/consoleTransport.strategy.js +0 -16
  27. package/dist/src/modules/logger/consoleTransport.strategy.js.map +0 -1
  28. package/dist/src/modules/logger/datadogTransport.strategy.d.ts +0 -5
  29. package/dist/src/modules/logger/datadogTransport.strategy.js +0 -18
  30. package/dist/src/modules/logger/datadogTransport.strategy.js.map +0 -1
  31. package/dist/src/modules/logger/elasticsearchTransport.strategy.d.ts +0 -6
  32. package/dist/src/modules/logger/elasticsearchTransport.strategy.js +0 -13
  33. package/dist/src/modules/logger/elasticsearchTransport.strategy.js.map +0 -1
  34. package/dist/src/modules/logger/fileTransport.strategy.d.ts +0 -7
  35. package/dist/src/modules/logger/fileTransport.strategy.js +0 -17
  36. package/dist/src/modules/logger/fileTransport.strategy.js.map +0 -1
  37. package/dist/src/modules/logger/strategy.interface.d.ts +0 -6
  38. package/dist/src/modules/logger/strategy.interface.js +0 -3
  39. package/dist/src/modules/logger/strategy.interface.js.map +0 -1
  40. package/dist/src/modules/logger/winston.interface.d.ts +0 -21
  41. package/dist/src/modules/logger/winston.interface.js +0 -3
  42. package/dist/src/modules/logger/winston.interface.js.map +0 -1
  43. package/dist/src/modules/logger/winston.module.d.ts +0 -4
  44. package/dist/src/modules/logger/winston.module.js +0 -74
  45. package/dist/src/modules/logger/winston.module.js.map +0 -1
  46. package/dist/src/modules/logger/winston.service.d.ts +0 -18
  47. package/dist/src/modules/logger/winston.service.js +0 -43
  48. package/dist/src/modules/logger/winston.service.js.map +0 -1
  49. package/dist/src/modules/tracer/tracer.middleware.d.ts +0 -22
  50. package/dist/src/modules/tracer/tracer.middleware.js +0 -41
  51. package/dist/src/modules/tracer/tracer.middleware.js.map +0 -1
  52. package/dist/src/modules/tracer/tracer.module.d.ts +0 -7
  53. package/dist/src/modules/tracer/tracer.module.js +0 -36
  54. package/dist/src/modules/tracer/tracer.module.js.map +0 -1
  55. package/dist/src/types/auth.d.ts +0 -31
  56. package/dist/src/types/auth.js +0 -10
  57. package/dist/src/types/auth.js.map +0 -1
  58. package/dist/src/types/index.d.ts +0 -1
  59. package/dist/src/types/index.js +0 -18
  60. package/dist/src/types/index.js.map +0 -1
  61. package/src/config/env.validation.ts +0 -61
  62. package/src/decorators/utils.decorators.ts +0 -28
  63. package/src/interceptors/log-request.interceptor.ts +0 -32
  64. package/src/interceptors/serialize.interceptor.ts +0 -27
  65. package/src/modules/logger/consoleTransport.strategy.ts +0 -22
  66. package/src/modules/logger/datadogTransport.strategy.ts +0 -17
  67. package/src/modules/logger/elasticsearchTransport.strategy.ts +0 -12
  68. package/src/modules/logger/fileTransport.strategy.ts +0 -17
  69. package/src/modules/logger/strategy.interface.ts +0 -9
  70. package/src/modules/logger/winston.interface.ts +0 -22
  71. package/src/modules/logger/winston.module.ts +0 -63
  72. package/src/modules/logger/winston.service.ts +0 -53
  73. package/src/modules/tracer/tracer.middleware.ts +0 -38
  74. package/src/modules/tracer/tracer.module.ts +0 -18
  75. package/src/types/auth.ts +0 -37
  76. package/src/types/index.ts +0 -1
package/index.ts CHANGED
@@ -1,11 +1,3 @@
1
- export * from './src/types';
2
- export * from './src/interceptors/log-request.interceptor';
3
- export * from './src/interceptors/serialize.interceptor';
4
- export * from './src/modules/logger/winston.service';
5
- export * from './src/modules/logger/winston.module';
6
- export * from './src/modules/tracer/tracer.module';
7
- export * from './src/decorators/utils.decorators';
8
- export * from './src/config/env.validation';
9
1
  export * from './src/modules/logger/pino/logger.service';
10
2
  export * from './src/modules/logger/pino/logger.module';
11
3
  export * from './src/modules/logger/pino/logger.default';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "xcally-nest-library",
3
- "version": "0.0.26",
3
+ "version": "0.0.28",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -19,77 +19,27 @@
19
19
  "start:debug": "nest start --debug --watch",
20
20
  "start:prod": "node dist/main",
21
21
  "lint": "eslint \"{src,apps,libs,test}/**/*.ts\" --fix",
22
- "test": "jest",
23
- "test:watch": "jest --watch",
24
- "test:cov": "jest --coverage",
25
- "test:debug": "node --inspect-brk -r tsconfig-paths/register -r ts-node/register node_modules/.bin/jest --runInBand",
26
- "test:e2e": "jest --config ./test/jest-e2e.json",
27
22
  "lib:link": "pnpm link --global",
28
23
  "lib:unlink": "pnpm unlink xcally-nest-libs --global"
29
24
  },
30
25
  "dependencies": {
31
- "@nestjs/axios": "^3.0.2",
32
- "@nestjs/common": "^10.3.7",
33
- "@nestjs/config": "^3.2.2",
34
- "@nestjs/core": "^10.3.7",
35
- "@nestjs/microservices": "^10.3.7",
36
- "@nestjs/platform-express": "^10.3.7",
37
- "@opentelemetry/api": "^1.9.0",
38
- "axios": "^1.6.8",
39
- "class-transformer": "^0.5.1",
40
- "class-validator": "^0.14.1",
41
- "datadog-winston": "^1.6.0",
42
- "nest-winston": "^1.9.4",
43
- "nestjs-grpc-exceptions": "^0.2.2",
44
- "nestjs-pino": "^4.1.0",
45
- "pino": "^9.4.0",
46
- "pino-pretty": "^11.2.2",
47
- "reflect-metadata": "^0.2.2",
48
- "rxjs": "^7.8.1",
49
- "typeorm": "^0.3.20",
50
- "winston": "^3.13.0",
51
- "winston-elasticsearch": "^0.18.0"
26
+ "@nestjs/common": "^11.0.7",
27
+ "@nestjs/config": "^4.0.0",
28
+ "@nestjs/core": "^11.0.7",
29
+ "nestjs-pino": "^4.3.0"
52
30
  },
53
31
  "devDependencies": {
54
- "@nestjs/cli": "^10.3.2",
55
- "@nestjs/schematics": "^10.1.1",
56
- "@nestjs/testing": "^10.3.7",
57
- "@types/express": "^4.17.21",
58
- "@types/jest": "^29.5.12",
59
- "@types/node": "^20.12.7",
60
- "@types/supertest": "^6.0.2",
61
- "@typescript-eslint/eslint-plugin": "^7.6.0",
62
- "@typescript-eslint/parser": "^7.6.0",
63
- "eslint": "^8.57.0",
64
- "eslint-config-prettier": "^9.1.0",
65
- "eslint-plugin-prettier": "^5.1.3",
66
- "jest": "^29.7.0",
67
- "prettier": "^3.2.5",
68
- "rimraf": "^5.0.5",
69
- "source-map-support": "^0.5.21",
70
- "supertest": "^6.3.4",
71
- "ts-jest": "^29.1.2",
72
- "ts-loader": "^9.5.1",
32
+ "@nestjs/cli": "^11.0.2",
33
+ "@nestjs/schematics": "^11.0.0",
34
+ "@typescript-eslint/eslint-plugin": "^8.23.0",
35
+ "@typescript-eslint/parser": "^8.23.0",
36
+ "eslint": "^9.19.0",
37
+ "eslint-config-prettier": "^10.0.1",
38
+ "eslint-plugin-prettier": "^5.2.3",
39
+ "prettier": "^3.4.2",
40
+ "rimraf": "^6.0.1",
73
41
  "ts-node": "^10.9.2",
74
- "tsc-watch": "^6.2.0",
75
- "tsconfig-paths": "^4.2.0",
76
- "typescript": "^5.4.5"
77
- },
78
- "jest": {
79
- "moduleFileExtensions": [
80
- "js",
81
- "json",
82
- "ts"
83
- ],
84
- "rootDir": "src",
85
- "testRegex": ".*\\.spec\\.ts$",
86
- "transform": {
87
- "^.+\\.(t|j)s$": "ts-jest"
88
- },
89
- "collectCoverageFrom": [
90
- "**/*.(t|j)s"
91
- ],
92
- "coverageDirectory": "../coverage",
93
- "testEnvironment": "node"
42
+ "tsc-watch": "^6.2.1",
43
+ "typescript": "^5.7.3"
94
44
  }
95
45
  }
@@ -54,7 +54,9 @@ import { LoggerService } from './logger.service';
54
54
  level: config.get('LOG_LEVEL') || 'info',
55
55
  target: 'pino/file',
56
56
  options: {
57
- destination: process.env.LOG_OUT_DIR + `${projectName}.log` || `./logs/${projectName}.log`,
57
+ destination: process.env.LOG_OUT_DIR
58
+ ? process.env.LOG_OUT_DIR + `${projectName}.log`
59
+ : `./logs/${projectName}.log`,
58
60
  mkdir: true,
59
61
  append: process.env.NODE_ENV !== 'production' ? false : true,
60
62
  },
@@ -1,6 +1,5 @@
1
1
  import { Injectable } from '@nestjs/common';
2
2
  import { PinoLogger } from 'nestjs-pino';
3
- import api from '@opentelemetry/api';
4
3
  /**
5
4
  * @interface LoggerMeta
6
5
  * @description Interface representing metadata for logging purposes.
@@ -16,30 +15,20 @@ export class LoggerService {
16
15
  constructor(private readonly logger: PinoLogger) {}
17
16
 
18
17
  debug(msg: string, meta?: LoggerMeta): void {
19
- const activeSpan = api.trace.getSpan(api.context.active());
20
- activeSpan.addEvent(msg);
21
18
  this.logger.debug({ meta }, msg);
22
19
  }
23
20
  warn(msg: string, meta?: LoggerMeta): void {
24
- const activeSpan = api.trace.getSpan(api.context.active());
25
- activeSpan.addEvent(msg);
26
21
  this.logger.warn({ meta }, msg);
27
22
  }
28
23
  error(msg: string, meta?: LoggerMeta): void {
29
- const activeSpan = api.trace.getSpan(api.context.active());
30
- activeSpan.addEvent(msg);
31
24
  this.logger.error({ meta }, msg);
32
25
  }
33
26
  fatal(msg: string, meta?: LoggerMeta): void {
34
- const activeSpan = api.trace.getSpan(api.context.active());
35
- activeSpan.addEvent(msg);
36
27
  this.logger.fatal({ meta }, msg);
37
28
  }
38
29
 
39
30
  info(msg: string, meta?: LoggerMeta): void {
40
31
  // LOG EVENTS
41
- const activeSpan = api.trace.getSpan(api.context.active());
42
- activeSpan.addEvent(msg);
43
32
 
44
33
  // // LOG CORRELATION -- You can see correlation between spans and logs
45
34
  // const tracer = api.trace.getTracer(process.env.npm_package_name, process.env.npm_package_version);
@@ -52,8 +41,6 @@ export class LoggerService {
52
41
  }
53
42
 
54
43
  trace(msg: string, meta?: LoggerMeta): void {
55
- const activeSpan = api.trace.getSpan(api.context.active());
56
- activeSpan.addEvent(msg);
57
44
  this.logger.trace({ meta }, msg);
58
45
  }
59
46
  }
@@ -1,22 +0,0 @@
1
- declare enum EnvironmentType {
2
- Dev = "development",
3
- Prod = "production",
4
- Test = "test",
5
- Staging = "staging",
6
- E2E = "e2e"
7
- }
8
- declare class EnvironmentVariables {
9
- NODE_ENV: EnvironmentType;
10
- MYSQL_HOST: string;
11
- MYSQL_PORT: number;
12
- MYSQL_DATABASE: string;
13
- MYSQL_USERNAME: string;
14
- MYSQL_PASSWORD: string;
15
- MYSQL_SYNCHRONIZE: boolean;
16
- HTTP_TIMEOUT: number;
17
- HTTP_MAX_REDIRECTS: number;
18
- BASE_MOTION_URL: string;
19
- ACTOR_SERVICE_URL: string;
20
- }
21
- export declare function validate(configuration: Record<string, unknown>): EnvironmentVariables;
22
- export {};
@@ -1,82 +0,0 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var __metadata = (this && this.__metadata) || function (k, v) {
9
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.validate = void 0;
13
- const class_transformer_1 = require("class-transformer");
14
- const class_validator_1 = require("class-validator");
15
- var EnvironmentType;
16
- (function (EnvironmentType) {
17
- EnvironmentType["Dev"] = "development";
18
- EnvironmentType["Prod"] = "production";
19
- EnvironmentType["Test"] = "test";
20
- EnvironmentType["Staging"] = "staging";
21
- EnvironmentType["E2E"] = "e2e";
22
- })(EnvironmentType || (EnvironmentType = {}));
23
- class EnvironmentVariables {
24
- }
25
- __decorate([
26
- (0, class_validator_1.IsDefined)(),
27
- (0, class_validator_1.IsEnum)(EnvironmentType),
28
- __metadata("design:type", String)
29
- ], EnvironmentVariables.prototype, "NODE_ENV", void 0);
30
- __decorate([
31
- (0, class_validator_1.IsString)(),
32
- __metadata("design:type", String)
33
- ], EnvironmentVariables.prototype, "MYSQL_HOST", void 0);
34
- __decorate([
35
- (0, class_validator_1.IsNumber)(),
36
- __metadata("design:type", Number)
37
- ], EnvironmentVariables.prototype, "MYSQL_PORT", void 0);
38
- __decorate([
39
- (0, class_validator_1.IsString)(),
40
- (0, class_validator_1.NotContains)(' '),
41
- __metadata("design:type", String)
42
- ], EnvironmentVariables.prototype, "MYSQL_DATABASE", void 0);
43
- __decorate([
44
- (0, class_validator_1.IsString)(),
45
- __metadata("design:type", String)
46
- ], EnvironmentVariables.prototype, "MYSQL_USERNAME", void 0);
47
- __decorate([
48
- (0, class_validator_1.IsString)(),
49
- __metadata("design:type", String)
50
- ], EnvironmentVariables.prototype, "MYSQL_PASSWORD", void 0);
51
- __decorate([
52
- (0, class_validator_1.IsBoolean)(),
53
- __metadata("design:type", Boolean)
54
- ], EnvironmentVariables.prototype, "MYSQL_SYNCHRONIZE", void 0);
55
- __decorate([
56
- (0, class_validator_1.IsNumber)(),
57
- __metadata("design:type", Number)
58
- ], EnvironmentVariables.prototype, "HTTP_TIMEOUT", void 0);
59
- __decorate([
60
- (0, class_validator_1.IsNumber)(),
61
- __metadata("design:type", Number)
62
- ], EnvironmentVariables.prototype, "HTTP_MAX_REDIRECTS", void 0);
63
- __decorate([
64
- (0, class_validator_1.IsString)(),
65
- __metadata("design:type", String)
66
- ], EnvironmentVariables.prototype, "BASE_MOTION_URL", void 0);
67
- __decorate([
68
- (0, class_validator_1.IsString)(),
69
- __metadata("design:type", String)
70
- ], EnvironmentVariables.prototype, "ACTOR_SERVICE_URL", void 0);
71
- function validate(configuration) {
72
- const finalConfig = (0, class_transformer_1.plainToClass)(EnvironmentVariables, configuration, {
73
- enableImplicitConversion: true,
74
- });
75
- const errors = (0, class_validator_1.validateSync)(finalConfig, { skipMissingProperties: true });
76
- if (errors.length > 0) {
77
- throw new Error(errors.toString());
78
- }
79
- return finalConfig;
80
- }
81
- exports.validate = validate;
82
- //# sourceMappingURL=env.validation.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"env.validation.js","sourceRoot":"","sources":["../../../src/config/env.validation.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAiD;AACjD,qDAA8G;AAE9G,IAAK,eAMJ;AAND,WAAK,eAAe;IAClB,sCAAmB,CAAA;IACnB,sCAAmB,CAAA;IACnB,gCAAa,CAAA;IACb,sCAAmB,CAAA;IACnB,8BAAW,CAAA;AACb,CAAC,EANI,eAAe,KAAf,eAAe,QAMnB;AAED,MAAM,oBAAoB;CAmCzB;AAhCC;IAFC,IAAA,2BAAS,GAAE;IACX,IAAA,wBAAM,EAAC,eAAe,CAAC;;sDACE;AAG1B;IADC,IAAA,0BAAQ,GAAE;;wDACQ;AAGnB;IADC,IAAA,0BAAQ,GAAE;;wDACQ;AAInB;IAFC,IAAA,0BAAQ,GAAE;IACV,IAAA,6BAAW,EAAC,GAAG,CAAC;;4DACM;AAGvB;IADC,IAAA,0BAAQ,GAAE;;4DACY;AAGvB;IADC,IAAA,0BAAQ,GAAE;;4DACY;AAGvB;IADC,IAAA,2BAAS,GAAE;;+DACe;AAG3B;IADC,IAAA,0BAAQ,GAAE;;0DACU;AAGrB;IADC,IAAA,0BAAQ,GAAE;;gEACgB;AAG3B;IADC,IAAA,0BAAQ,GAAE;;6DACa;AAGxB;IADC,IAAA,0BAAQ,GAAE;;+DACe;AAG5B,SAAgB,QAAQ,CAAC,aAAsC;IAC7D,MAAM,WAAW,GAAG,IAAA,gCAAY,EAAC,oBAAoB,EAAE,aAAa,EAAE;QACpE,wBAAwB,EAAE,IAAI;KAC/B,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,IAAA,8BAAY,EAAC,WAAW,EAAE,EAAE,qBAAqB,EAAE,IAAI,EAAE,CAAC,CAAC;IAE1E,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACtB,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;IACrC,CAAC;IAED,OAAO,WAAW,CAAC;AACrB,CAAC;AAZD,4BAYC"}
@@ -1,2 +0,0 @@
1
- export declare const GetMeta: (...dataOrPipes: unknown[]) => ParameterDecorator;
2
- export declare const GetTraceId: (...dataOrPipes: unknown[]) => ParameterDecorator;
@@ -1,15 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.GetTraceId = exports.GetMeta = void 0;
4
- const common_1 = require("@nestjs/common");
5
- exports.GetMeta = (0, common_1.createParamDecorator)((data, ctx) => {
6
- const context = ctx.switchToRpc();
7
- return context.getContext();
8
- });
9
- exports.GetTraceId = (0, common_1.createParamDecorator)((data, ctx) => {
10
- const context = ctx.switchToRpc();
11
- const metadata = context.getContext();
12
- const traceId = metadata.get('traceId')[0];
13
- return traceId;
14
- });
15
- //# sourceMappingURL=utils.decorators.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.decorators.js","sourceRoot":"","sources":["../../../src/decorators/utils.decorators.ts"],"names":[],"mappings":";;;AAAA,2CAAwE;AAS3D,QAAA,OAAO,GAAG,IAAA,6BAAoB,EAAC,CAAC,IAAa,EAAE,GAAqB,EAAE,EAAE;IACnF,MAAM,OAAO,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;IAClC,OAAO,OAAO,CAAC,UAAU,EAAE,CAAC;AAC9B,CAAC,CAAC,CAAC;AAUU,QAAA,UAAU,GAAG,IAAA,6BAAoB,EAAC,CAAC,IAAa,EAAE,GAAqB,EAAE,EAAE;IACtF,MAAM,OAAO,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;IAClC,MAAM,QAAQ,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IACtC,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3C,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC,CAAC"}
@@ -1,8 +0,0 @@
1
- import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
- import { Observable } from 'rxjs';
3
- import { WinstonLoggerService } from '../modules/logger/winston.service';
4
- export declare class LogRequestInterceptor implements NestInterceptor {
5
- private readonly logger;
6
- constructor(logger: WinstonLoggerService);
7
- intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
8
- }
@@ -1,44 +0,0 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- var __metadata = (this && this.__metadata) || function (k, v) {
9
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.LogRequestInterceptor = void 0;
13
- const common_1 = require("@nestjs/common");
14
- const operators_1 = require("rxjs/operators");
15
- const winston_service_1 = require("../modules/logger/winston.service");
16
- let LogRequestInterceptor = class LogRequestInterceptor {
17
- constructor(logger) {
18
- this.logger = logger;
19
- }
20
- intercept(context, next) {
21
- const req = context.switchToHttp().getRequest();
22
- this.logger.info('Before Middleware...', {
23
- traceId: req?.local?.traceId,
24
- className: this.constructor.name,
25
- methodName: 'intercept',
26
- });
27
- const now = Date.now();
28
- if (req) {
29
- const method = req.method;
30
- const url = req.url;
31
- return next.handle().pipe((0, operators_1.tap)(() => this.logger.info(`After Middleware... ${method} ${url} ${Date.now() - now}ms`, {
32
- traceId: req?.local?.traceId,
33
- className: 'LogRequestInterceptor',
34
- methodName: 'intercept',
35
- })));
36
- }
37
- }
38
- };
39
- exports.LogRequestInterceptor = LogRequestInterceptor;
40
- exports.LogRequestInterceptor = LogRequestInterceptor = __decorate([
41
- (0, common_1.Injectable)(),
42
- __metadata("design:paramtypes", [winston_service_1.WinstonLoggerService])
43
- ], LogRequestInterceptor);
44
- //# sourceMappingURL=log-request.interceptor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"log-request.interceptor.js","sourceRoot":"","sources":["../../../src/interceptors/log-request.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4F;AAE5F,8CAAqC;AACrC,uEAAyE;AAGlE,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IAChC,YAA6B,MAA4B;QAA5B,WAAM,GAAN,MAAM,CAAsB;IAAG,CAAC;IAC7D,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACpD,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;QAChD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;YACvC,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO;YAC5B,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;YAChC,UAAU,EAAE,WAAW;SACxB,CAAC,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvB,IAAI,GAAG,EAAE,CAAC;YACR,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;YAC1B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC;YACpB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACvB,IAAA,eAAG,EAAC,GAAG,EAAE,CACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,GAAG,IAAI,EAAE;gBAC7E,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO;gBAC5B,SAAS,EAAE,uBAAuB;gBAClC,UAAU,EAAE,WAAW;aACxB,CAAC,CACH,CACF,CAAC;QACJ,CAAC;IACH,CAAC;CACF,CAAA;AAzBY,sDAAqB;gCAArB,qBAAqB;IADjC,IAAA,mBAAU,GAAE;qCAE0B,sCAAoB;GAD9C,qBAAqB,CAyBjC"}
@@ -1,12 +0,0 @@
1
- import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
- import { Observable } from 'rxjs';
3
- interface ClassConstructor {
4
- new (...args: any[]): {};
5
- }
6
- export declare function Serialize(dto: ClassConstructor): MethodDecorator & ClassDecorator;
7
- export declare class SerializeInterceptor implements NestInterceptor {
8
- private dto;
9
- constructor(dto: any);
10
- intercept(context: ExecutionContext, handler: CallHandler): Observable<any>;
11
- }
12
- export {};
@@ -1,24 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SerializeInterceptor = exports.Serialize = void 0;
4
- const common_1 = require("@nestjs/common");
5
- const operators_1 = require("rxjs/operators");
6
- const class_transformer_1 = require("class-transformer");
7
- function Serialize(dto) {
8
- return (0, common_1.UseInterceptors)(new SerializeInterceptor(dto));
9
- }
10
- exports.Serialize = Serialize;
11
- class SerializeInterceptor {
12
- constructor(dto) {
13
- this.dto = dto;
14
- }
15
- intercept(context, handler) {
16
- return handler.handle().pipe((0, operators_1.map)((data) => {
17
- return (0, class_transformer_1.plainToInstance)(this.dto, data, {
18
- excludeExtraneousValues: true,
19
- });
20
- }));
21
- }
22
- }
23
- exports.SerializeInterceptor = SerializeInterceptor;
24
- //# sourceMappingURL=serialize.interceptor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"serialize.interceptor.js","sourceRoot":"","sources":["../../../src/interceptors/serialize.interceptor.ts"],"names":[],"mappings":";;;AAAA,2CAAiG;AAEjG,8CAAqC;AACrC,yDAAoD;AAOpD,SAAgB,SAAS,CAAC,GAAqB;IAC7C,OAAO,IAAA,wBAAe,EAAC,IAAI,oBAAoB,CAAC,GAAG,CAAC,CAAC,CAAC;AACxD,CAAC;AAFD,8BAEC;AAED,MAAa,oBAAoB;IAC/B,YAAoB,GAAQ;QAAR,QAAG,GAAH,GAAG,CAAK;IAAG,CAAC;IAEhC,SAAS,CAAC,OAAyB,EAAE,OAAoB;QACvD,OAAO,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAC1B,IAAA,eAAG,EAAC,CAAC,IAAS,EAAE,EAAE;YAChB,OAAO,IAAA,mCAAe,EAAC,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE;gBACrC,uBAAuB,EAAE,IAAI;aAC9B,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CACF;AAZD,oDAYC"}
@@ -1,5 +0,0 @@
1
- import { transports } from 'winston';
2
- import { TransportStrategy } from './strategy.interface';
3
- export declare class ConsoleTransportStrategy implements TransportStrategy {
4
- createTransport(): transports.ConsoleTransportInstance;
5
- }
@@ -1,16 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ConsoleTransportStrategy = void 0;
4
- const winston_1 = require("winston");
5
- const myFormat = winston_1.format.printf(({ level = 'info', message, timestamp, err, ...metadata }) => {
6
- return `${timestamp} [${level}]: ${message} ${err ? err.stack : ''} ${JSON.stringify(metadata)} `;
7
- });
8
- class ConsoleTransportStrategy {
9
- createTransport() {
10
- return new winston_1.transports.Console({
11
- format: winston_1.format.combine(winston_1.format.colorize(), winston_1.format.splat(), winston_1.format.errors({ stack: true }), winston_1.format.json(), winston_1.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss:ms' }), myFormat),
12
- });
13
- }
14
- }
15
- exports.ConsoleTransportStrategy = ConsoleTransportStrategy;
16
- //# sourceMappingURL=consoleTransport.strategy.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"consoleTransport.strategy.js","sourceRoot":"","sources":["../../../../src/modules/logger/consoleTransport.strategy.ts"],"names":[],"mappings":";;;AAAA,qCAA6C;AAG7C,MAAM,QAAQ,GAAG,gBAAM,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,GAAG,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,QAAQ,EAAE,EAAE,EAAE;IAC1F,OAAO,GAAG,SAAS,KAAK,KAAK,MAAM,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC;AACpG,CAAC,CAAC,CAAC;AAGH,MAAa,wBAAwB;IACnC,eAAe;QACb,OAAO,IAAI,oBAAU,CAAC,OAAO,CAAC;YAC5B,MAAM,EAAE,gBAAM,CAAC,OAAO,CACpB,gBAAM,CAAC,QAAQ,EAAE,EACjB,gBAAM,CAAC,KAAK,EAAE,EACd,gBAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAC9B,gBAAM,CAAC,IAAI,EAAE,EACb,gBAAM,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,wBAAwB,EAAE,CAAC,EACtD,QAAQ,CACT;SACF,CAAC,CAAC;IACL,CAAC;CACF;AAbD,4DAaC"}
@@ -1,5 +0,0 @@
1
- import { ConfigService } from '@nestjs/config';
2
- import { TransportStrategy } from './strategy.interface';
3
- export declare class DatadogTransportStrategy implements TransportStrategy {
4
- createTransport(configService: ConfigService): any;
5
- }
@@ -1,18 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DatadogTransportStrategy = void 0;
4
- const DatadogWinston = require("datadog-winston");
5
- class DatadogTransportStrategy {
6
- createTransport(configService) {
7
- return new DatadogWinston({
8
- apiKey: configService.getOrThrow('DATADOG_APIKEY'),
9
- hostname: configService.getOrThrow('DATADOG_HOSTNAME'),
10
- service: configService.getOrThrow('DATADOG_SERVICE'),
11
- ddsource: configService.getOrThrow('DATADOG_DDSOURCE'),
12
- ddtags: configService.getOrThrow('DATADOG_DDTAGS'),
13
- intakeRegion: configService.getOrThrow('DATADOG_INTAKEREGION'),
14
- });
15
- }
16
- }
17
- exports.DatadogTransportStrategy = DatadogTransportStrategy;
18
- //# sourceMappingURL=datadogTransport.strategy.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"datadogTransport.strategy.js","sourceRoot":"","sources":["../../../../src/modules/logger/datadogTransport.strategy.ts"],"names":[],"mappings":";;;AACA,kDAAmD;AAInD,MAAa,wBAAwB;IACnC,eAAe,CAAC,aAA4B;QAC1C,OAAO,IAAI,cAAc,CAAC;YACxB,MAAM,EAAE,aAAa,CAAC,UAAU,CAAS,gBAAgB,CAAC;YAC1D,QAAQ,EAAE,aAAa,CAAC,UAAU,CAAS,kBAAkB,CAAC;YAC9D,OAAO,EAAE,aAAa,CAAC,UAAU,CAAS,iBAAiB,CAAC;YAC5D,QAAQ,EAAE,aAAa,CAAC,UAAU,CAAS,kBAAkB,CAAC;YAC9D,MAAM,EAAE,aAAa,CAAC,UAAU,CAAS,gBAAgB,CAAC;YAC1D,YAAY,EAAE,aAAa,CAAC,UAAU,CAAS,sBAAsB,CAAC;SACvE,CAAC,CAAC;IACL,CAAC;CACF;AAXD,4DAWC"}
@@ -1,6 +0,0 @@
1
- import { ConfigService } from '@nestjs/config';
2
- import { ElasticsearchTransport } from 'winston-elasticsearch';
3
- import { TransportStrategy } from './strategy.interface';
4
- export declare class ElasticsearchTransportStrategy implements TransportStrategy {
5
- createTransport(configService: ConfigService): ElasticsearchTransport;
6
- }
@@ -1,13 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ElasticsearchTransportStrategy = void 0;
4
- const winston_elasticsearch_1 = require("winston-elasticsearch");
5
- class ElasticsearchTransportStrategy {
6
- createTransport(configService) {
7
- return new winston_elasticsearch_1.ElasticsearchTransport({
8
- clientOpts: { node: configService.getOrThrow('ELASTICSEARCH_URL') },
9
- });
10
- }
11
- }
12
- exports.ElasticsearchTransportStrategy = ElasticsearchTransportStrategy;
13
- //# sourceMappingURL=elasticsearchTransport.strategy.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"elasticsearchTransport.strategy.js","sourceRoot":"","sources":["../../../../src/modules/logger/elasticsearchTransport.strategy.ts"],"names":[],"mappings":";;;AACA,iEAA+D;AAI/D,MAAa,8BAA8B;IACzC,eAAe,CAAC,aAA4B;QAC1C,OAAO,IAAI,8CAAsB,CAAC;YAChC,UAAU,EAAE,EAAE,IAAI,EAAE,aAAa,CAAC,UAAU,CAAS,mBAAmB,CAAC,EAAE;SAC5E,CAAC,CAAC;IACL,CAAC;CACF;AAND,wEAMC"}
@@ -1,7 +0,0 @@
1
- import { transports } from 'winston';
2
- import { TransportStrategy } from './strategy.interface';
3
- export declare class FileTransportStrategy implements TransportStrategy {
4
- name: string;
5
- constructor(name: string);
6
- createTransport(): transports.FileTransportInstance;
7
- }
@@ -1,17 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FileTransportStrategy = void 0;
4
- const winston_1 = require("winston");
5
- class FileTransportStrategy {
6
- constructor(name) {
7
- this.name = name;
8
- }
9
- createTransport() {
10
- return new winston_1.transports.File({
11
- filename: `logs/${this.name}.log`,
12
- format: winston_1.format.combine(winston_1.format.timestamp({ format: 'YYYY-MM-DD HH:mm:ss:ms' }), winston_1.format.json()),
13
- });
14
- }
15
- }
16
- exports.FileTransportStrategy = FileTransportStrategy;
17
- //# sourceMappingURL=fileTransport.strategy.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"fileTransport.strategy.js","sourceRoot":"","sources":["../../../../src/modules/logger/fileTransport.strategy.ts"],"names":[],"mappings":";;;AAAA,qCAA6C;AAI7C,MAAa,qBAAqB;IAEhC,YAAY,IAAY;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,eAAe;QACb,OAAO,IAAI,oBAAU,CAAC,IAAI,CAAC;YACzB,QAAQ,EAAE,QAAQ,IAAI,CAAC,IAAI,MAAM;YACjC,MAAM,EAAE,gBAAM,CAAC,OAAO,CAAC,gBAAM,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,wBAAwB,EAAE,CAAC,EAAE,gBAAM,CAAC,IAAI,EAAE,CAAC;SAC9F,CAAC,CAAC;IACL,CAAC;CACF;AAZD,sDAYC"}
@@ -1,6 +0,0 @@
1
- import { ConfigService } from '@nestjs/config';
2
- import { transports } from 'winston';
3
- import { ElasticsearchTransport } from 'winston-elasticsearch';
4
- export interface TransportStrategy {
5
- createTransport(configService: ConfigService): ElasticsearchTransport | transports.ConsoleTransportInstance | transports.FileTransportInstance;
6
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=strategy.interface.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"strategy.interface.js","sourceRoot":"","sources":["../../../../src/modules/logger/strategy.interface.ts"],"names":[],"mappings":""}
@@ -1,21 +0,0 @@
1
- import { ElasticsearchTransportOptions } from 'winston-elasticsearch';
2
- import { DatadogTransportOptions } from 'datadog-winston';
3
- export interface IWinstonLogger {
4
- info(message: string, meta?: Record<string, any>): void;
5
- error(message: string, meta?: Record<string, any>): void;
6
- warn(message: string, meta?: Record<string, any>): void;
7
- help(message: string, meta?: Record<string, any>): void;
8
- data(message: string, meta?: Record<string, any>): void;
9
- debug(message: string, meta?: Record<string, any>): void;
10
- prompt(message: string, meta?: Record<string, any>): void;
11
- http(message: string, meta?: Record<string, any>): void;
12
- verbose(message: string, meta?: Record<string, any>): void;
13
- input(message: string, meta?: Record<string, any>): void;
14
- silly(message: string, meta?: Record<string, any>): void;
15
- }
16
- export interface WinstonLoggerModuleOptions {
17
- transportFile?: boolean;
18
- transportConsole?: boolean;
19
- transportElasticsearch?: ElasticsearchTransportOptions;
20
- transportDatadog?: DatadogTransportOptions;
21
- }
@@ -1,3 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=winston.interface.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"winston.interface.js","sourceRoot":"","sources":["../../../../src/modules/logger/winston.interface.ts"],"names":[],"mappings":""}
@@ -1,4 +0,0 @@
1
- import { DynamicModule } from '@nestjs/common';
2
- export declare class WinstonModule {
3
- static forRoot(): DynamicModule;
4
- }