trucostars-core-module 0.0.1

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 (112) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +423 -0
  3. package/dist/app.controller.d.ts +6 -0
  4. package/dist/app.controller.js +43 -0
  5. package/dist/app.controller.js.map +1 -0
  6. package/dist/app.module.d.ts +4 -0
  7. package/dist/app.module.js +31 -0
  8. package/dist/app.module.js.map +1 -0
  9. package/dist/app.service.d.ts +5 -0
  10. package/dist/app.service.js +28 -0
  11. package/dist/app.service.js.map +1 -0
  12. package/dist/common/common.module.d.ts +2 -0
  13. package/dist/common/common.module.js +58 -0
  14. package/dist/common/common.module.js.map +1 -0
  15. package/dist/common/config/env.validation.d.ts +2 -0
  16. package/dist/common/config/env.validation.js +93 -0
  17. package/dist/common/config/env.validation.js.map +1 -0
  18. package/dist/common/config/firebase.config.d.ts +2 -0
  19. package/dist/common/config/firebase.config.js +9 -0
  20. package/dist/common/config/firebase.config.js.map +1 -0
  21. package/dist/common/config/index.d.ts +1 -0
  22. package/dist/common/config/index.js +18 -0
  23. package/dist/common/config/index.js.map +1 -0
  24. package/dist/common/database/database.module.d.ts +2 -0
  25. package/dist/common/database/database.module.js +54 -0
  26. package/dist/common/database/database.module.js.map +1 -0
  27. package/dist/common/database/database.service.d.ts +25 -0
  28. package/dist/common/database/database.service.js +91 -0
  29. package/dist/common/database/database.service.js.map +1 -0
  30. package/dist/common/decorators/api-performance.decorator.d.ts +1 -0
  31. package/dist/common/decorators/api-performance.decorator.js +42 -0
  32. package/dist/common/decorators/api-performance.decorator.js.map +1 -0
  33. package/dist/common/decorators/index.d.ts +1 -0
  34. package/dist/common/decorators/index.js +18 -0
  35. package/dist/common/decorators/index.js.map +1 -0
  36. package/dist/common/filters/all-exceptions.filter.d.ts +5 -0
  37. package/dist/common/filters/all-exceptions.filter.js +38 -0
  38. package/dist/common/filters/all-exceptions.filter.js.map +1 -0
  39. package/dist/common/firebase/firebase.controller.d.ts +35 -0
  40. package/dist/common/firebase/firebase.controller.js +115 -0
  41. package/dist/common/firebase/firebase.controller.js.map +1 -0
  42. package/dist/common/firebase/firebase.module.d.ts +3 -0
  43. package/dist/common/firebase/firebase.module.js +83 -0
  44. package/dist/common/firebase/firebase.module.js.map +1 -0
  45. package/dist/common/firebase/firebase.service.d.ts +17 -0
  46. package/dist/common/firebase/firebase.service.js +127 -0
  47. package/dist/common/firebase/firebase.service.js.map +1 -0
  48. package/dist/common/firebase/firebase.types.d.ts +22 -0
  49. package/dist/common/firebase/firebase.types.js +3 -0
  50. package/dist/common/firebase/firebase.types.js.map +1 -0
  51. package/dist/common/interceptors/logging.interceptor.d.ts +10 -0
  52. package/dist/common/interceptors/logging.interceptor.js +108 -0
  53. package/dist/common/interceptors/logging.interceptor.js.map +1 -0
  54. package/dist/common/interceptors/performance.interceptor.d.ts +7 -0
  55. package/dist/common/interceptors/performance.interceptor.js +58 -0
  56. package/dist/common/interceptors/performance.interceptor.js.map +1 -0
  57. package/dist/common/middleware/logger.middleware.d.ts +19 -0
  58. package/dist/common/middleware/logger.middleware.js +231 -0
  59. package/dist/common/middleware/logger.middleware.js.map +1 -0
  60. package/dist/common/redis/redis.module.d.ts +2 -0
  61. package/dist/common/redis/redis.module.js +21 -0
  62. package/dist/common/redis/redis.module.js.map +1 -0
  63. package/dist/common/redis/redis.service.d.ts +11 -0
  64. package/dist/common/redis/redis.service.js +52 -0
  65. package/dist/common/redis/redis.service.js.map +1 -0
  66. package/dist/common/sqs/sqs.consumer.d.ts +20 -0
  67. package/dist/common/sqs/sqs.consumer.js +140 -0
  68. package/dist/common/sqs/sqs.consumer.js.map +1 -0
  69. package/dist/common/sqs/sqs.controller.d.ts +21 -0
  70. package/dist/common/sqs/sqs.controller.js +70 -0
  71. package/dist/common/sqs/sqs.controller.js.map +1 -0
  72. package/dist/common/sqs/sqs.example.service.d.ts +27 -0
  73. package/dist/common/sqs/sqs.example.service.js +206 -0
  74. package/dist/common/sqs/sqs.example.service.js.map +1 -0
  75. package/dist/common/sqs/sqs.module.d.ts +2 -0
  76. package/dist/common/sqs/sqs.module.js +24 -0
  77. package/dist/common/sqs/sqs.module.js.map +1 -0
  78. package/dist/common/sqs/sqs.producer.d.ts +13 -0
  79. package/dist/common/sqs/sqs.producer.js +197 -0
  80. package/dist/common/sqs/sqs.producer.js.map +1 -0
  81. package/dist/common/websocket/websocket.gateway.d.ts +9 -0
  82. package/dist/common/websocket/websocket.gateway.js +41 -0
  83. package/dist/common/websocket/websocket.gateway.js.map +1 -0
  84. package/dist/common/websocket/websocket.module.d.ts +2 -0
  85. package/dist/common/websocket/websocket.module.js +22 -0
  86. package/dist/common/websocket/websocket.module.js.map +1 -0
  87. package/dist/common/websocket/websocket.service.d.ts +25 -0
  88. package/dist/common/websocket/websocket.service.js +248 -0
  89. package/dist/common/websocket/websocket.service.js.map +1 -0
  90. package/dist/data/data.d.ts +10 -0
  91. package/dist/data/data.js +10 -0
  92. package/dist/data/data.js.map +1 -0
  93. package/dist/main.d.ts +1 -0
  94. package/dist/main.js +48 -0
  95. package/dist/main.js.map +1 -0
  96. package/dist/products/entities/product.entity.d.ts +56 -0
  97. package/dist/products/entities/product.entity.js +80 -0
  98. package/dist/products/entities/product.entity.js.map +1 -0
  99. package/dist/products/products.controller.d.ts +35 -0
  100. package/dist/products/products.controller.js +98 -0
  101. package/dist/products/products.controller.js.map +1 -0
  102. package/dist/products/products.module.d.ts +2 -0
  103. package/dist/products/products.module.js +27 -0
  104. package/dist/products/products.module.js.map +1 -0
  105. package/dist/products/products.service.d.ts +36 -0
  106. package/dist/products/products.service.example.d.ts +1 -0
  107. package/dist/products/products.service.example.js +3 -0
  108. package/dist/products/products.service.example.js.map +1 -0
  109. package/dist/products/products.service.js +74 -0
  110. package/dist/products/products.service.js.map +1 -0
  111. package/dist/tsconfig.build.tsbuildinfo +1 -0
  112. package/package.json +106 -0
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
19
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
20
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
21
+ 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;
22
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
23
+ };
24
+ var __importStar = (this && this.__importStar) || (function () {
25
+ var ownKeys = function(o) {
26
+ ownKeys = Object.getOwnPropertyNames || function (o) {
27
+ var ar = [];
28
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
29
+ return ar;
30
+ };
31
+ return ownKeys(o);
32
+ };
33
+ return function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ })();
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.FirebaseModule = exports.FIREBASE_APP = void 0;
43
+ const common_1 = require("@nestjs/common");
44
+ const config_1 = require("@nestjs/config");
45
+ const firebase_service_1 = require("./firebase.service");
46
+ const admin = __importStar(require("firebase-admin"));
47
+ const firebase_controller_1 = require("./firebase.controller");
48
+ exports.FIREBASE_APP = 'FIREBASE_APP';
49
+ const firebaseProvider = {
50
+ provide: exports.FIREBASE_APP,
51
+ inject: [config_1.ConfigService],
52
+ useFactory: (configService) => {
53
+ const firebaseConfig = {
54
+ type: configService.get('FIREBASE_TYPE'),
55
+ project_id: configService.get('FIREBASE_PROJECT_ID'),
56
+ private_key_id: configService.get('FIREBASE_PRIVATE_KEY_ID'),
57
+ private_key: configService.get('FIREBASE_PRIVATE_KEY'),
58
+ client_email: configService.get('FIREBASE_CLIENT_EMAIL'),
59
+ client_id: configService.get('FIREBASE_CLIENT_ID'),
60
+ auth_uri: configService.get('FIREBASE_AUTH_URI'),
61
+ token_uri: configService.get('FIREBASE_TOKEN_URI'),
62
+ auth_provider_x509_cert_url: configService.get('FIREBASE_AUTH_PROVIDER_X509_CERT_URL'),
63
+ client_x509_cert_url: configService.get('FIREBASE_CLIENT_X509_CERT_URL'),
64
+ universe_domain: configService.get('FIREBASE_UNIVERSE_DOMAIN'),
65
+ };
66
+ return admin.initializeApp({
67
+ credential: admin.credential.cert(firebaseConfig),
68
+ databaseURL: `https://${firebaseConfig.projectId}.firebaseio.com`,
69
+ storageBucket: `${firebaseConfig.projectId}.appspot.com`,
70
+ });
71
+ },
72
+ };
73
+ let FirebaseModule = class FirebaseModule {
74
+ };
75
+ exports.FirebaseModule = FirebaseModule;
76
+ exports.FirebaseModule = FirebaseModule = __decorate([
77
+ (0, common_1.Module)({
78
+ providers: [firebaseProvider, firebase_service_1.FirebaseService],
79
+ controllers: [firebase_controller_1.FirebaseController],
80
+ exports: [firebase_service_1.FirebaseService],
81
+ })
82
+ ], FirebaseModule);
83
+ //# sourceMappingURL=firebase.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firebase.module.js","sourceRoot":"","sources":["../../../src/common/firebase/firebase.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAAwC;AACxC,2CAA+C;AAC/C,yDAAqD;AACrD,sDAAwC;AACxC,+DAA2D;AAE9C,QAAA,YAAY,GAAG,cAAc,CAAC;AAE3C,MAAM,gBAAgB,GAAG;IACvB,OAAO,EAAE,oBAAY;IACrB,MAAM,EAAE,CAAC,sBAAa,CAAC;IACvB,UAAU,EAAE,CAAC,aAA4B,EAAE,EAAE;QAC3C,MAAM,cAAc,GAAG;YACrB,IAAI,EAAE,aAAa,CAAC,GAAG,CAAS,eAAe,CAAC;YAChD,UAAU,EAAE,aAAa,CAAC,GAAG,CAAS,qBAAqB,CAAC;YAC5D,cAAc,EAAE,aAAa,CAAC,GAAG,CAAS,yBAAyB,CAAC;YACpE,WAAW,EAAE,aAAa,CAAC,GAAG,CAAS,sBAAsB,CAAC;YAC9D,YAAY,EAAE,aAAa,CAAC,GAAG,CAAS,uBAAuB,CAAC;YAChE,SAAS,EAAE,aAAa,CAAC,GAAG,CAAS,oBAAoB,CAAC;YAC1D,QAAQ,EAAE,aAAa,CAAC,GAAG,CAAS,mBAAmB,CAAC;YACxD,SAAS,EAAE,aAAa,CAAC,GAAG,CAAS,oBAAoB,CAAC;YAC1D,2BAA2B,EAAE,aAAa,CAAC,GAAG,CAC5C,sCAAsC,CACvC;YACD,oBAAoB,EAAE,aAAa,CAAC,GAAG,CACrC,+BAA+B,CAChC;YACD,eAAe,EAAE,aAAa,CAAC,GAAG,CAAS,0BAA0B,CAAC;SAC/C,CAAC;QAE1B,OAAO,KAAK,CAAC,aAAa,CAAC;YACzB,UAAU,EAAE,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC;YACjD,WAAW,EAAE,WAAW,cAAc,CAAC,SAAS,iBAAiB;YACjE,aAAa,EAAE,GAAG,cAAc,CAAC,SAAS,cAAc;SACzD,CAAC,CAAC;IACL,CAAC;CACF,CAAC;AAOK,IAAM,cAAc,GAApB,MAAM,cAAc;CAAG,CAAA;AAAjB,wCAAc;yBAAd,cAAc;IAL1B,IAAA,eAAM,EAAC;QACN,SAAS,EAAE,CAAC,gBAAgB,EAAE,kCAAe,CAAC;QAC9C,WAAW,EAAE,CAAC,wCAAkB,CAAC;QACjC,OAAO,EAAE,CAAC,kCAAe,CAAC;KAC3B,CAAC;GACW,cAAc,CAAG"}
@@ -0,0 +1,17 @@
1
+ import { app } from 'firebase-admin';
2
+ import { PushNotificationPayload } from './firebase.types';
3
+ export declare class FirebaseService {
4
+ private firebaseApp;
5
+ private readonly logger;
6
+ private messaging;
7
+ constructor(firebaseApp: app.App);
8
+ sendToDevice(deviceToken: string, payload: PushNotificationPayload): Promise<string>;
9
+ sendToMultipleDevices(deviceTokens: string[], payload: PushNotificationPayload): Promise<{
10
+ successCount: number;
11
+ failureCount: number;
12
+ }>;
13
+ sendToTopic(topic: string, payload: PushNotificationPayload): Promise<string>;
14
+ subscribeToTopic(deviceToken: string, topic: string): Promise<void>;
15
+ unsubscribeFromTopic(deviceToken: string, topic: string): Promise<void>;
16
+ private buildMessage;
17
+ }
@@ -0,0 +1,127 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var FirebaseService_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.FirebaseService = void 0;
17
+ const common_1 = require("@nestjs/common");
18
+ const firebase_admin_1 = require("firebase-admin");
19
+ let FirebaseService = FirebaseService_1 = class FirebaseService {
20
+ firebaseApp;
21
+ logger = new common_1.Logger(FirebaseService_1.name);
22
+ messaging;
23
+ constructor(firebaseApp) {
24
+ this.firebaseApp = firebaseApp;
25
+ this.messaging = this.firebaseApp.messaging();
26
+ }
27
+ async sendToDevice(deviceToken, payload) {
28
+ try {
29
+ const message = this.buildMessage(deviceToken, payload);
30
+ const messageId = await this.messaging.send(message);
31
+ this.logger.log(`📱 Notificación enviada al dispositivo: ${messageId}`);
32
+ return messageId;
33
+ }
34
+ catch (error) {
35
+ this.logger.error(`Error enviando notificación a dispositivo: ${error}`);
36
+ throw error;
37
+ }
38
+ }
39
+ async sendToMultipleDevices(deviceTokens, payload) {
40
+ try {
41
+ const messages = deviceTokens.map((token) => this.buildMessage(token, payload, false));
42
+ let successCount = 0;
43
+ let failureCount = 0;
44
+ for (const message of messages) {
45
+ try {
46
+ await this.messaging.send(message);
47
+ successCount++;
48
+ }
49
+ catch (error) {
50
+ failureCount++;
51
+ this.logger.warn(`Error enviando a dispositivo: ${error}`);
52
+ }
53
+ }
54
+ this.logger.log(`📱 Notificaciones enviadas: ${successCount}/${deviceTokens.length} exitosas`);
55
+ return { successCount, failureCount };
56
+ }
57
+ catch (error) {
58
+ this.logger.error(`Error enviando notificaciones múltiples: ${error}`);
59
+ throw error;
60
+ }
61
+ }
62
+ async sendToTopic(topic, payload) {
63
+ try {
64
+ const message = this.buildMessage(topic, payload, true);
65
+ const messageId = await this.messaging.send(message);
66
+ this.logger.log(`📢 Notificación enviada al tema "${topic}": ${messageId}`);
67
+ return messageId;
68
+ }
69
+ catch (error) {
70
+ this.logger.error(`Error enviando notificación al tema: ${error}`);
71
+ throw error;
72
+ }
73
+ }
74
+ async subscribeToTopic(deviceToken, topic) {
75
+ try {
76
+ await this.messaging.subscribeToTopic(deviceToken, topic);
77
+ this.logger.log(`✅ Dispositivo suscrito al tema: ${topic}`);
78
+ }
79
+ catch (error) {
80
+ this.logger.error(`Error suscribiendo a tema: ${error}`);
81
+ throw error;
82
+ }
83
+ }
84
+ async unsubscribeFromTopic(deviceToken, topic) {
85
+ try {
86
+ await this.messaging.unsubscribeFromTopic(deviceToken, topic);
87
+ this.logger.log(`❌ Dispositivo desuscrito del tema: ${topic}`);
88
+ }
89
+ catch (error) {
90
+ this.logger.error(`Error desuscribiendo de tema: ${error}`);
91
+ throw error;
92
+ }
93
+ }
94
+ buildMessage(target, payload, isTopic = false) {
95
+ const baseMessage = {
96
+ notification: {
97
+ title: payload.title,
98
+ body: payload.body,
99
+ ...(payload.icon && { imageUrl: payload.icon }),
100
+ },
101
+ data: payload.data || {},
102
+ webpush: payload.webpush,
103
+ android: payload.android,
104
+ };
105
+ let message;
106
+ if (isTopic) {
107
+ message = {
108
+ ...baseMessage,
109
+ topic: target,
110
+ };
111
+ }
112
+ else {
113
+ message = {
114
+ ...baseMessage,
115
+ token: target,
116
+ };
117
+ }
118
+ return message;
119
+ }
120
+ };
121
+ exports.FirebaseService = FirebaseService;
122
+ exports.FirebaseService = FirebaseService = FirebaseService_1 = __decorate([
123
+ (0, common_1.Injectable)(),
124
+ __param(0, (0, common_1.Inject)('FIREBASE_APP')),
125
+ __metadata("design:paramtypes", [Object])
126
+ ], FirebaseService);
127
+ //# sourceMappingURL=firebase.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firebase.service.js","sourceRoot":"","sources":["../../../src/common/firebase/firebase.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ export interface PushNotificationPayload {
2
+ title: string;
3
+ body: string;
4
+ icon?: string;
5
+ image?: string;
6
+ badge?: string;
7
+ data?: Record<string, string>;
8
+ webpush?: {
9
+ headers?: Record<string, string>;
10
+ data?: Record<string, string>;
11
+ notification?: Record<string, string>;
12
+ fcmOptions?: Record<string, string>;
13
+ };
14
+ android?: {
15
+ priority?: 'high' | 'normal';
16
+ notification?: Record<string, string>;
17
+ };
18
+ apns?: {
19
+ headers?: Record<string, string>;
20
+ payload?: Record<string, any>;
21
+ };
22
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=firebase.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"firebase.types.js","sourceRoot":"","sources":["../../../src/common/firebase/firebase.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,10 @@
1
+ import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
+ import { Observable } from 'rxjs';
3
+ export declare class LoggingInterceptor implements NestInterceptor {
4
+ private readonly logger;
5
+ private readonly isEnabled;
6
+ intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
7
+ private formatJson;
8
+ private formatDuration;
9
+ private getPerformanceIcon;
10
+ }
@@ -0,0 +1,108 @@
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.LoggingInterceptor = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const operators_1 = require("rxjs/operators");
12
+ let LoggingInterceptor = class LoggingInterceptor {
13
+ logger = new common_1.Logger('API');
14
+ isEnabled = process.env.ENABLE_API_LOGGING !== 'false';
15
+ intercept(context, next) {
16
+ if (!this.isEnabled) {
17
+ return next.handle();
18
+ }
19
+ const request = context.switchToHttp().getRequest();
20
+ const { method, url, body, query, params } = request;
21
+ const now = Date.now();
22
+ const contextType = context.getType();
23
+ const handler = context.getHandler().name;
24
+ const controller = context.getClass().name;
25
+ const hasBody = body && Object.keys(body).length > 0;
26
+ const hasQuery = query && Object.keys(query).length > 0;
27
+ const hasParams = params && Object.keys(params).length > 0;
28
+ const entryLog = [
29
+ `\n${'▶'.repeat(40)}`,
30
+ `🎯 Controller: ${controller}`,
31
+ `🔧 Handler: ${handler}`,
32
+ `📍 Route: ${method} ${url}`,
33
+ ];
34
+ if (hasBody) {
35
+ entryLog.push(`📦 Body: ${this.formatJson(body)}`);
36
+ }
37
+ if (hasQuery) {
38
+ entryLog.push(`🔍 Query: ${this.formatJson(query)}`);
39
+ }
40
+ if (hasParams) {
41
+ entryLog.push(`🏷️ Params: ${this.formatJson(params)}`);
42
+ }
43
+ entryLog.push(`${'▼'.repeat(40)}`);
44
+ this.logger.debug(entryLog.join('\n'));
45
+ return next.handle().pipe((0, operators_1.tap)({
46
+ next: (data) => {
47
+ const responseTime = Date.now() - now;
48
+ const performanceIcon = this.getPerformanceIcon(responseTime);
49
+ const successLog = [
50
+ `${'◀'.repeat(40)}`,
51
+ `✨ ${controller}.${handler}`,
52
+ `${performanceIcon} Completed: ${this.formatDuration(responseTime)}`,
53
+ ];
54
+ if (process.env.LOG_LEVEL === 'debug' || process.env.NODE_ENV === 'development') {
55
+ if (data !== undefined && data !== null) {
56
+ successLog.push(`📤 Response: ${this.formatJson(data)}`);
57
+ }
58
+ }
59
+ successLog.push(`${'▲'.repeat(40)}\n`);
60
+ this.logger.log(successLog.join('\n'));
61
+ },
62
+ error: (error) => {
63
+ const responseTime = Date.now() - now;
64
+ const errorLog = [
65
+ `${'⚠'.repeat(40)}`,
66
+ `💥 ERROR in ${controller}.${handler}`,
67
+ `⏱️ Duration: ${this.formatDuration(responseTime)}`,
68
+ `❌ Message: ${error.message}`,
69
+ `📍 Stack: ${error.stack?.split('\n')[1]?.trim() || 'N/A'}`,
70
+ `${'⚠'.repeat(40)}\n`,
71
+ ].join('\n');
72
+ this.logger.error(errorLog);
73
+ },
74
+ }));
75
+ }
76
+ formatJson(obj) {
77
+ try {
78
+ const str = JSON.stringify(obj);
79
+ return str.length > 100 ? str.substring(0, 97) + '...' : str;
80
+ }
81
+ catch {
82
+ return '[Circular]';
83
+ }
84
+ }
85
+ formatDuration(ms) {
86
+ if (ms < 100)
87
+ return `${ms}ms ⚡`;
88
+ if (ms < 500)
89
+ return `${ms}ms ✓`;
90
+ if (ms < 1000)
91
+ return `${ms}ms ⏱️`;
92
+ return `${(ms / 1000).toFixed(2)}s 🐌`;
93
+ }
94
+ getPerformanceIcon(ms) {
95
+ if (ms < 100)
96
+ return '⚡';
97
+ if (ms < 500)
98
+ return '✅';
99
+ if (ms < 1000)
100
+ return '⚠️';
101
+ return '🐌';
102
+ }
103
+ };
104
+ exports.LoggingInterceptor = LoggingInterceptor;
105
+ exports.LoggingInterceptor = LoggingInterceptor = __decorate([
106
+ (0, common_1.Injectable)()
107
+ ], LoggingInterceptor);
108
+ //# sourceMappingURL=logging.interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.interceptor.js","sourceRoot":"","sources":["../../../src/common/interceptors/logging.interceptor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { NestInterceptor, ExecutionContext, CallHandler } from '@nestjs/common';
2
+ import { Observable } from 'rxjs';
3
+ export declare class PerformanceInterceptor implements NestInterceptor {
4
+ private readonly logger;
5
+ intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
6
+ private calculatePayloadSize;
7
+ }
@@ -0,0 +1,58 @@
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.PerformanceInterceptor = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const operators_1 = require("rxjs/operators");
12
+ let PerformanceInterceptor = class PerformanceInterceptor {
13
+ logger = new common_1.Logger('Performance');
14
+ intercept(context, next) {
15
+ const ctx = context.switchToHttp();
16
+ const request = ctx.getRequest();
17
+ const response = ctx.getResponse();
18
+ const startTime = Date.now();
19
+ const requestPayloadSize = this.calculatePayloadSize(request.body);
20
+ return next.handle().pipe((0, operators_1.tap)({
21
+ next: (data) => {
22
+ const responseTime = Date.now() - startTime;
23
+ const responsePayloadSize = this.calculatePayloadSize(data);
24
+ response.setHeader('X-Response-Time', `${responseTime}ms`);
25
+ response.setHeader('X-Response-Size', `${responsePayloadSize.toFixed(4)}MB`);
26
+ response.setHeader('X-Request-Size', `${requestPayloadSize.toFixed(4)}MB`);
27
+ response.setHeader('X-Timestamp', new Date().toISOString());
28
+ if (process.env.LOG_PERFORMANCE === 'true') {
29
+ this.logger.debug(`[${request.method}] ${request.url} - Time: ${responseTime}ms, Request: ${requestPayloadSize.toFixed(4)}MB, Response: ${responsePayloadSize.toFixed(4)}MB`);
30
+ }
31
+ },
32
+ error: (error) => {
33
+ const responseTime = Date.now() - startTime;
34
+ response.setHeader('X-Response-Time', `${responseTime}ms`);
35
+ response.setHeader('X-Error', 'true');
36
+ },
37
+ }));
38
+ }
39
+ calculatePayloadSize(payload) {
40
+ if (!payload)
41
+ return 0;
42
+ try {
43
+ const jsonString = JSON.stringify(payload);
44
+ const sizeInBytes = new Blob([jsonString]).size;
45
+ const sizeInMB = sizeInBytes / (1024 * 1024);
46
+ return sizeInMB;
47
+ }
48
+ catch (error) {
49
+ this.logger.warn('Error calculating payload size', error);
50
+ return 0;
51
+ }
52
+ }
53
+ };
54
+ exports.PerformanceInterceptor = PerformanceInterceptor;
55
+ exports.PerformanceInterceptor = PerformanceInterceptor = __decorate([
56
+ (0, common_1.Injectable)()
57
+ ], PerformanceInterceptor);
58
+ //# sourceMappingURL=performance.interceptor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"performance.interceptor.js","sourceRoot":"","sources":["../../../src/common/interceptors/performance.interceptor.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAMwB;AAExB,8CAAqC;AAI9B,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAChB,MAAM,GAAG,IAAI,eAAM,CAAC,aAAa,CAAC,CAAC;IAEpD,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACpD,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;QACnC,MAAM,OAAO,GAAG,GAAG,CAAC,UAAU,EAAW,CAAC;QAC1C,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,EAAY,CAAC;QAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAG7B,MAAM,kBAAkB,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEnE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CACvB,IAAA,eAAG,EAAC;YACF,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE;gBACb,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC5C,MAAM,mBAAmB,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;gBAG5D,QAAQ,CAAC,SAAS,CAAC,iBAAiB,EAAE,GAAG,YAAY,IAAI,CAAC,CAAC;gBAC3D,QAAQ,CAAC,SAAS,CAAC,iBAAiB,EAAE,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBAC7E,QAAQ,CAAC,SAAS,CAAC,gBAAgB,EAAE,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBAC3E,QAAQ,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;gBAG5D,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,MAAM,EAAE,CAAC;oBAC3C,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,IAAI,OAAO,CAAC,MAAM,KAAK,OAAO,CAAC,GAAG,YAAY,YAAY,gBAAgB,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,iBAAiB,mBAAmB,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAC3J,CAAC;gBACJ,CAAC;YACH,CAAC;YACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACf,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC5C,QAAQ,CAAC,SAAS,CAAC,iBAAiB,EAAE,GAAG,YAAY,IAAI,CAAC,CAAC;gBAC3D,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;YACxC,CAAC;SACF,CAAC,CACH,CAAC;IACJ,CAAC;IAOO,oBAAoB,CAAC,OAAY;QACvC,IAAI,CAAC,OAAO;YAAE,OAAO,CAAC,CAAC;QAEvB,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAC3C,MAAM,WAAW,GAAG,IAAI,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC;YAChD,MAAM,QAAQ,GAAG,WAAW,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;YAC7C,OAAO,QAAQ,CAAC;QAClB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAC;YAC1D,OAAO,CAAC,CAAC;QACX,CAAC;IACH,CAAC;CACF,CAAA;AA1DY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;GACA,sBAAsB,CA0DlC"}
@@ -0,0 +1,19 @@
1
+ import { NestMiddleware } from '@nestjs/common';
2
+ import { Request, Response, NextFunction } from 'express';
3
+ export declare class LoggerMiddleware implements NestMiddleware {
4
+ private logger;
5
+ private isEnabled;
6
+ private static concurrentRequests;
7
+ use(req: Request, res: Response, next: NextFunction): void;
8
+ private colorizeMethod;
9
+ private getStatusEmoji;
10
+ private getStatusColor;
11
+ private getStatusText;
12
+ private formatResponseTime;
13
+ private getPerformanceLevel;
14
+ private formatBytes;
15
+ private truncateUserAgent;
16
+ private formatMemory;
17
+ private formatMemoryDelta;
18
+ private getConcurrentLevel;
19
+ }