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.
- package/LICENSE +21 -0
- package/README.md +423 -0
- package/dist/app.controller.d.ts +6 -0
- package/dist/app.controller.js +43 -0
- package/dist/app.controller.js.map +1 -0
- package/dist/app.module.d.ts +4 -0
- package/dist/app.module.js +31 -0
- package/dist/app.module.js.map +1 -0
- package/dist/app.service.d.ts +5 -0
- package/dist/app.service.js +28 -0
- package/dist/app.service.js.map +1 -0
- package/dist/common/common.module.d.ts +2 -0
- package/dist/common/common.module.js +58 -0
- package/dist/common/common.module.js.map +1 -0
- package/dist/common/config/env.validation.d.ts +2 -0
- package/dist/common/config/env.validation.js +93 -0
- package/dist/common/config/env.validation.js.map +1 -0
- package/dist/common/config/firebase.config.d.ts +2 -0
- package/dist/common/config/firebase.config.js +9 -0
- package/dist/common/config/firebase.config.js.map +1 -0
- package/dist/common/config/index.d.ts +1 -0
- package/dist/common/config/index.js +18 -0
- package/dist/common/config/index.js.map +1 -0
- package/dist/common/database/database.module.d.ts +2 -0
- package/dist/common/database/database.module.js +54 -0
- package/dist/common/database/database.module.js.map +1 -0
- package/dist/common/database/database.service.d.ts +25 -0
- package/dist/common/database/database.service.js +91 -0
- package/dist/common/database/database.service.js.map +1 -0
- package/dist/common/decorators/api-performance.decorator.d.ts +1 -0
- package/dist/common/decorators/api-performance.decorator.js +42 -0
- package/dist/common/decorators/api-performance.decorator.js.map +1 -0
- package/dist/common/decorators/index.d.ts +1 -0
- package/dist/common/decorators/index.js +18 -0
- package/dist/common/decorators/index.js.map +1 -0
- package/dist/common/filters/all-exceptions.filter.d.ts +5 -0
- package/dist/common/filters/all-exceptions.filter.js +38 -0
- package/dist/common/filters/all-exceptions.filter.js.map +1 -0
- package/dist/common/firebase/firebase.controller.d.ts +35 -0
- package/dist/common/firebase/firebase.controller.js +115 -0
- package/dist/common/firebase/firebase.controller.js.map +1 -0
- package/dist/common/firebase/firebase.module.d.ts +3 -0
- package/dist/common/firebase/firebase.module.js +83 -0
- package/dist/common/firebase/firebase.module.js.map +1 -0
- package/dist/common/firebase/firebase.service.d.ts +17 -0
- package/dist/common/firebase/firebase.service.js +127 -0
- package/dist/common/firebase/firebase.service.js.map +1 -0
- package/dist/common/firebase/firebase.types.d.ts +22 -0
- package/dist/common/firebase/firebase.types.js +3 -0
- package/dist/common/firebase/firebase.types.js.map +1 -0
- package/dist/common/interceptors/logging.interceptor.d.ts +10 -0
- package/dist/common/interceptors/logging.interceptor.js +108 -0
- package/dist/common/interceptors/logging.interceptor.js.map +1 -0
- package/dist/common/interceptors/performance.interceptor.d.ts +7 -0
- package/dist/common/interceptors/performance.interceptor.js +58 -0
- package/dist/common/interceptors/performance.interceptor.js.map +1 -0
- package/dist/common/middleware/logger.middleware.d.ts +19 -0
- package/dist/common/middleware/logger.middleware.js +231 -0
- package/dist/common/middleware/logger.middleware.js.map +1 -0
- package/dist/common/redis/redis.module.d.ts +2 -0
- package/dist/common/redis/redis.module.js +21 -0
- package/dist/common/redis/redis.module.js.map +1 -0
- package/dist/common/redis/redis.service.d.ts +11 -0
- package/dist/common/redis/redis.service.js +52 -0
- package/dist/common/redis/redis.service.js.map +1 -0
- package/dist/common/sqs/sqs.consumer.d.ts +20 -0
- package/dist/common/sqs/sqs.consumer.js +140 -0
- package/dist/common/sqs/sqs.consumer.js.map +1 -0
- package/dist/common/sqs/sqs.controller.d.ts +21 -0
- package/dist/common/sqs/sqs.controller.js +70 -0
- package/dist/common/sqs/sqs.controller.js.map +1 -0
- package/dist/common/sqs/sqs.example.service.d.ts +27 -0
- package/dist/common/sqs/sqs.example.service.js +206 -0
- package/dist/common/sqs/sqs.example.service.js.map +1 -0
- package/dist/common/sqs/sqs.module.d.ts +2 -0
- package/dist/common/sqs/sqs.module.js +24 -0
- package/dist/common/sqs/sqs.module.js.map +1 -0
- package/dist/common/sqs/sqs.producer.d.ts +13 -0
- package/dist/common/sqs/sqs.producer.js +197 -0
- package/dist/common/sqs/sqs.producer.js.map +1 -0
- package/dist/common/websocket/websocket.gateway.d.ts +9 -0
- package/dist/common/websocket/websocket.gateway.js +41 -0
- package/dist/common/websocket/websocket.gateway.js.map +1 -0
- package/dist/common/websocket/websocket.module.d.ts +2 -0
- package/dist/common/websocket/websocket.module.js +22 -0
- package/dist/common/websocket/websocket.module.js.map +1 -0
- package/dist/common/websocket/websocket.service.d.ts +25 -0
- package/dist/common/websocket/websocket.service.js +248 -0
- package/dist/common/websocket/websocket.service.js.map +1 -0
- package/dist/data/data.d.ts +10 -0
- package/dist/data/data.js +10 -0
- package/dist/data/data.js.map +1 -0
- package/dist/main.d.ts +1 -0
- package/dist/main.js +48 -0
- package/dist/main.js.map +1 -0
- package/dist/products/entities/product.entity.d.ts +56 -0
- package/dist/products/entities/product.entity.js +80 -0
- package/dist/products/entities/product.entity.js.map +1 -0
- package/dist/products/products.controller.d.ts +35 -0
- package/dist/products/products.controller.js +98 -0
- package/dist/products/products.controller.js.map +1 -0
- package/dist/products/products.module.d.ts +2 -0
- package/dist/products/products.module.js +27 -0
- package/dist/products/products.module.js.map +1 -0
- package/dist/products/products.service.d.ts +36 -0
- package/dist/products/products.service.example.d.ts +1 -0
- package/dist/products/products.service.example.js +3 -0
- package/dist/products/products.service.example.js.map +1 -0
- package/dist/products/products.service.js +74 -0
- package/dist/products/products.service.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- 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 @@
|
|
|
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
|
+
}
|