@xfilecom/core-sdk 1.3.23
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/README.md +664 -0
- package/dist/core.module.d.ts +39 -0
- package/dist/core.module.js +188 -0
- package/dist/core.module.js.map +1 -0
- package/dist/database/database.constants.d.ts +2 -0
- package/dist/database/database.constants.js +6 -0
- package/dist/database/database.constants.js.map +1 -0
- package/dist/database/database.module.d.ts +19 -0
- package/dist/database/database.module.js +56 -0
- package/dist/database/database.module.js.map +1 -0
- package/dist/database/database.query.d.ts +103 -0
- package/dist/database/database.query.example.d.ts +36 -0
- package/dist/database/database.query.example.js +148 -0
- package/dist/database/database.query.example.js.map +1 -0
- package/dist/database/database.query.js +369 -0
- package/dist/database/database.query.js.map +1 -0
- package/dist/database/database.service.d.ts +18 -0
- package/dist/database/database.service.js +110 -0
- package/dist/database/database.service.js.map +1 -0
- package/dist/database/example-usage.d.ts +0 -0
- package/dist/database/example-usage.js +1 -0
- package/dist/database/example-usage.js.map +1 -0
- package/dist/decorators/public.decorator.d.ts +2 -0
- package/dist/decorators/public.decorator.js +8 -0
- package/dist/decorators/public.decorator.js.map +1 -0
- package/dist/decorators/roles.decorator.d.ts +2 -0
- package/dist/decorators/roles.decorator.js +8 -0
- package/dist/decorators/roles.decorator.js.map +1 -0
- package/dist/decorators/user.decorator.d.ts +7 -0
- package/dist/decorators/user.decorator.js +10 -0
- package/dist/decorators/user.decorator.js.map +1 -0
- package/dist/filters/exception.filter.d.ts +36 -0
- package/dist/filters/exception.filter.js +201 -0
- package/dist/filters/exception.filter.js.map +1 -0
- package/dist/guards/jwt-auth.guard.d.ts +14 -0
- package/dist/guards/jwt-auth.guard.js +103 -0
- package/dist/guards/jwt-auth.guard.js.map +1 -0
- package/dist/guards/roles.guard.d.ts +7 -0
- package/dist/guards/roles.guard.js +47 -0
- package/dist/guards/roles.guard.js.map +1 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.js +91 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptors/database-check.interceptor.d.ts +12 -0
- package/dist/interceptors/database-check.interceptor.js +60 -0
- package/dist/interceptors/database-check.interceptor.js.map +1 -0
- package/dist/interceptors/error-handling.interceptor.d.ts +8 -0
- package/dist/interceptors/error-handling.interceptor.js +33 -0
- package/dist/interceptors/error-handling.interceptor.js.map +1 -0
- package/dist/interceptors/logging.interceptor.d.ts +21 -0
- package/dist/interceptors/logging.interceptor.js +167 -0
- package/dist/interceptors/logging.interceptor.js.map +1 -0
- package/dist/interceptors/response-transform.interceptor.d.ts +5 -0
- package/dist/interceptors/response-transform.interceptor.js +30 -0
- package/dist/interceptors/response-transform.interceptor.js.map +1 -0
- package/dist/utils/auth.helpers.d.ts +19 -0
- package/dist/utils/auth.helpers.js +77 -0
- package/dist/utils/auth.helpers.js.map +1 -0
- package/dist/utils/config-loader.utils.d.ts +22 -0
- package/dist/utils/config-loader.utils.js +77 -0
- package/dist/utils/config-loader.utils.js.map +1 -0
- package/dist/utils/config.validator.d.ts +13 -0
- package/dist/utils/config.validator.js +82 -0
- package/dist/utils/config.validator.js.map +1 -0
- package/dist/utils/controller.helpers.d.ts +58 -0
- package/dist/utils/controller.helpers.js +104 -0
- package/dist/utils/controller.helpers.js.map +1 -0
- package/dist/utils/crypto.utils.d.ts +12 -0
- package/dist/utils/crypto.utils.js +53 -0
- package/dist/utils/crypto.utils.js.map +1 -0
- package/dist/utils/email-hash.utils.d.ts +7 -0
- package/dist/utils/email-hash.utils.js +42 -0
- package/dist/utils/email-hash.utils.js.map +1 -0
- package/dist/utils/env.utils.d.ts +8 -0
- package/dist/utils/env.utils.js +27 -0
- package/dist/utils/env.utils.js.map +1 -0
- package/dist/utils/error.utils.d.ts +6 -0
- package/dist/utils/error.utils.js +65 -0
- package/dist/utils/error.utils.js.map +1 -0
- package/dist/utils/hash-verification.utils.d.ts +35 -0
- package/dist/utils/hash-verification.utils.js +133 -0
- package/dist/utils/hash-verification.utils.js.map +1 -0
- package/dist/utils/logger.helpers.d.ts +71 -0
- package/dist/utils/logger.helpers.js +293 -0
- package/dist/utils/logger.helpers.js.map +1 -0
- package/dist/utils/logging.config.d.ts +6 -0
- package/dist/utils/logging.config.js +42 -0
- package/dist/utils/logging.config.js.map +1 -0
- package/dist/utils/service.helpers.d.ts +22 -0
- package/dist/utils/service.helpers.js +73 -0
- package/dist/utils/service.helpers.js.map +1 -0
- package/dist/utils/yaml-config.loader.d.ts +15 -0
- package/dist/utils/yaml-config.loader.js +219 -0
- package/dist/utils/yaml-config.loader.js.map +1 -0
- package/package.json +47 -0
- package/scripts/publish-to-gitlab.mjs +209 -0
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { LoggerService } from '@nestjs/common';
|
|
2
|
+
export interface LogContext {
|
|
3
|
+
userId?: number | string;
|
|
4
|
+
requestId?: string;
|
|
5
|
+
ipAddress?: string;
|
|
6
|
+
userAgent?: string;
|
|
7
|
+
method?: string;
|
|
8
|
+
url?: string;
|
|
9
|
+
[key: string]: any;
|
|
10
|
+
}
|
|
11
|
+
export declare enum LogLevel {
|
|
12
|
+
ERROR = "error",
|
|
13
|
+
WARN = "warn",
|
|
14
|
+
LOG = "log",
|
|
15
|
+
DEBUG = "debug",
|
|
16
|
+
VERBOSE = "verbose"
|
|
17
|
+
}
|
|
18
|
+
export declare const LOG_LEVEL_ORDER: Record<string, number>;
|
|
19
|
+
export type LogLevelName = keyof typeof LOG_LEVEL_ORDER;
|
|
20
|
+
export declare function isLevelEnabled(messageLevel: LogLevelName | string, minLevel: LogLevelName | string): boolean;
|
|
21
|
+
export interface ILogWriter {
|
|
22
|
+
write(level: 'log' | 'warn' | 'error' | 'debug' | 'verbose', message: string, context?: string): void;
|
|
23
|
+
}
|
|
24
|
+
export declare class ConsoleLogWriter implements ILogWriter {
|
|
25
|
+
private logger;
|
|
26
|
+
constructor(context?: string);
|
|
27
|
+
write(level: 'log' | 'warn' | 'error' | 'debug' | 'verbose', message: string, context?: string): void;
|
|
28
|
+
setContext(context: string): void;
|
|
29
|
+
}
|
|
30
|
+
export interface FileLogWriterOptions {
|
|
31
|
+
logDir?: string;
|
|
32
|
+
fileLogLevel?: 'log' | 'warn' | 'error';
|
|
33
|
+
}
|
|
34
|
+
export declare class FileLogWriter implements ILogWriter {
|
|
35
|
+
private logDir;
|
|
36
|
+
private fileLogLevel;
|
|
37
|
+
constructor(options?: FileLogWriterOptions);
|
|
38
|
+
private ensureLogDirectory;
|
|
39
|
+
private getLogFilePath;
|
|
40
|
+
write(level: 'log' | 'warn' | 'error' | 'debug' | 'verbose', message: string, context?: string): void;
|
|
41
|
+
}
|
|
42
|
+
export interface LoggerOptions {
|
|
43
|
+
logLevel?: LogLevelName;
|
|
44
|
+
enableFileLogging?: boolean;
|
|
45
|
+
logDir?: string;
|
|
46
|
+
fileLogLevel?: 'log' | 'warn' | 'error';
|
|
47
|
+
enableConsoleLogging?: boolean;
|
|
48
|
+
}
|
|
49
|
+
export declare class LoggerHelpers implements LoggerService {
|
|
50
|
+
private contextName;
|
|
51
|
+
private consoleWriter?;
|
|
52
|
+
private fileWriter?;
|
|
53
|
+
private minLevel;
|
|
54
|
+
constructor(context?: string, consoleWriter?: ILogWriter, fileWriter?: ILogWriter, options?: LoggerOptions);
|
|
55
|
+
isLevelEnabled(level: LogLevelName): boolean;
|
|
56
|
+
setContext(context: string): void;
|
|
57
|
+
log(message: string, context?: LogContext): void;
|
|
58
|
+
error(message: string, trace?: string | Error, context?: LogContext): void;
|
|
59
|
+
warn(message: string, context?: LogContext): void;
|
|
60
|
+
debug(message: string, context?: LogContext): void;
|
|
61
|
+
verbose(message: string, context?: LogContext): void;
|
|
62
|
+
logRequest(method: string, url: string, context?: LogContext): void;
|
|
63
|
+
logResponse(method: string, url: string, statusCode: number, duration?: number, context?: LogContext): void;
|
|
64
|
+
logQuery(query: string, params?: any[], context?: LogContext): void;
|
|
65
|
+
logBusiness(action: string, details?: any, context?: LogContext): void;
|
|
66
|
+
logSecurity(event: string, details?: any, context?: LogContext): void;
|
|
67
|
+
logPerformance(operation: string, duration: number, context?: LogContext): void;
|
|
68
|
+
private formatMessage;
|
|
69
|
+
logStructured(level: LogLevel, message: string, data?: any, context?: LogContext): void;
|
|
70
|
+
}
|
|
71
|
+
export declare function createLogger(context: string, options?: LoggerOptions): LoggerHelpers;
|
|
@@ -0,0 +1,293 @@
|
|
|
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 LoggerHelpers_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.LoggerHelpers = exports.FileLogWriter = exports.ConsoleLogWriter = exports.LOG_LEVEL_ORDER = exports.LogLevel = void 0;
|
|
17
|
+
exports.isLevelEnabled = isLevelEnabled;
|
|
18
|
+
exports.createLogger = createLogger;
|
|
19
|
+
const common_1 = require("@nestjs/common");
|
|
20
|
+
const fs = require("fs");
|
|
21
|
+
const path = require("path");
|
|
22
|
+
var LogLevel;
|
|
23
|
+
(function (LogLevel) {
|
|
24
|
+
LogLevel["ERROR"] = "error";
|
|
25
|
+
LogLevel["WARN"] = "warn";
|
|
26
|
+
LogLevel["LOG"] = "log";
|
|
27
|
+
LogLevel["DEBUG"] = "debug";
|
|
28
|
+
LogLevel["VERBOSE"] = "verbose";
|
|
29
|
+
})(LogLevel || (exports.LogLevel = LogLevel = {}));
|
|
30
|
+
exports.LOG_LEVEL_ORDER = {
|
|
31
|
+
error: 0,
|
|
32
|
+
warn: 1,
|
|
33
|
+
log: 2,
|
|
34
|
+
debug: 3,
|
|
35
|
+
verbose: 4,
|
|
36
|
+
};
|
|
37
|
+
function isLevelEnabled(messageLevel, minLevel) {
|
|
38
|
+
const a = exports.LOG_LEVEL_ORDER[String(messageLevel).toLowerCase()] ?? 999;
|
|
39
|
+
const b = exports.LOG_LEVEL_ORDER[String(minLevel).toLowerCase()] ?? 0;
|
|
40
|
+
return a <= b;
|
|
41
|
+
}
|
|
42
|
+
let ConsoleLogWriter = class ConsoleLogWriter {
|
|
43
|
+
constructor(context) {
|
|
44
|
+
this.logger = new common_1.Logger(context || 'App');
|
|
45
|
+
}
|
|
46
|
+
write(level, message, context) {
|
|
47
|
+
const logMessage = context ? `[${context}] ${message}` : message;
|
|
48
|
+
switch (level) {
|
|
49
|
+
case 'error':
|
|
50
|
+
this.logger.error(logMessage);
|
|
51
|
+
break;
|
|
52
|
+
case 'warn':
|
|
53
|
+
this.logger.warn(logMessage);
|
|
54
|
+
break;
|
|
55
|
+
case 'debug':
|
|
56
|
+
this.logger.debug(logMessage);
|
|
57
|
+
break;
|
|
58
|
+
case 'verbose':
|
|
59
|
+
this.logger.verbose(logMessage);
|
|
60
|
+
break;
|
|
61
|
+
default:
|
|
62
|
+
this.logger.log(logMessage);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
setContext(context) {
|
|
66
|
+
this.logger = new common_1.Logger(context);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
exports.ConsoleLogWriter = ConsoleLogWriter;
|
|
70
|
+
exports.ConsoleLogWriter = ConsoleLogWriter = __decorate([
|
|
71
|
+
(0, common_1.Injectable)(),
|
|
72
|
+
__metadata("design:paramtypes", [String])
|
|
73
|
+
], ConsoleLogWriter);
|
|
74
|
+
let FileLogWriter = class FileLogWriter {
|
|
75
|
+
constructor(options) {
|
|
76
|
+
this.logDir = path.resolve(options?.logDir ?? './logs');
|
|
77
|
+
this.fileLogLevel = options?.fileLogLevel ?? 'log';
|
|
78
|
+
this.ensureLogDirectory();
|
|
79
|
+
}
|
|
80
|
+
ensureLogDirectory() {
|
|
81
|
+
try {
|
|
82
|
+
if (!fs.existsSync(this.logDir)) {
|
|
83
|
+
fs.mkdirSync(this.logDir, { recursive: true });
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
console.error(`Failed to create log directory: ${this.logDir}`, error);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
getLogFilePath(level) {
|
|
91
|
+
const today = new Date().toISOString().split('T')[0];
|
|
92
|
+
const filename = `${today}-${level}.log`;
|
|
93
|
+
return path.join(this.logDir, filename);
|
|
94
|
+
}
|
|
95
|
+
write(level, message, context) {
|
|
96
|
+
if (level === 'debug' || level === 'verbose') {
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
const shouldLog = (this.fileLogLevel === 'log') ||
|
|
100
|
+
(this.fileLogLevel === 'warn' && (level === 'warn' || level === 'error')) ||
|
|
101
|
+
(this.fileLogLevel === 'error' && level === 'error');
|
|
102
|
+
if (!shouldLog) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
try {
|
|
106
|
+
const filePath = this.getLogFilePath(level);
|
|
107
|
+
const timestamp = new Date().toISOString();
|
|
108
|
+
const logEntry = `[${timestamp}] ${context ? `[${context}] ` : ''}[${level.toUpperCase()}] ${message}\n`;
|
|
109
|
+
fs.appendFileSync(filePath, logEntry, { encoding: 'utf8' });
|
|
110
|
+
}
|
|
111
|
+
catch (error) {
|
|
112
|
+
console.error(`Failed to write log to file: ${error}`);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
exports.FileLogWriter = FileLogWriter;
|
|
117
|
+
exports.FileLogWriter = FileLogWriter = __decorate([
|
|
118
|
+
(0, common_1.Injectable)(),
|
|
119
|
+
__metadata("design:paramtypes", [Object])
|
|
120
|
+
], FileLogWriter);
|
|
121
|
+
let LoggerHelpers = LoggerHelpers_1 = class LoggerHelpers {
|
|
122
|
+
constructor(context, consoleWriter, fileWriter, options) {
|
|
123
|
+
this.contextName = context || LoggerHelpers_1.name;
|
|
124
|
+
this.minLevel = options?.logLevel ?? 'log';
|
|
125
|
+
if (consoleWriter) {
|
|
126
|
+
this.consoleWriter = consoleWriter;
|
|
127
|
+
}
|
|
128
|
+
else if (options?.enableConsoleLogging !== false) {
|
|
129
|
+
this.consoleWriter = new ConsoleLogWriter(this.contextName);
|
|
130
|
+
}
|
|
131
|
+
if (fileWriter) {
|
|
132
|
+
this.fileWriter = fileWriter;
|
|
133
|
+
}
|
|
134
|
+
else if (options?.enableFileLogging !== false) {
|
|
135
|
+
this.fileWriter = new FileLogWriter({
|
|
136
|
+
logDir: options?.logDir,
|
|
137
|
+
fileLogLevel: options?.fileLogLevel,
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
isLevelEnabled(level) {
|
|
142
|
+
return isLevelEnabled(level, this.minLevel);
|
|
143
|
+
}
|
|
144
|
+
setContext(context) {
|
|
145
|
+
this.contextName = context;
|
|
146
|
+
if (this.consoleWriter instanceof ConsoleLogWriter) {
|
|
147
|
+
this.consoleWriter.setContext(context);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
log(message, context) {
|
|
151
|
+
if (!isLevelEnabled('log', this.minLevel))
|
|
152
|
+
return;
|
|
153
|
+
const logMessage = this.formatMessage(message, context);
|
|
154
|
+
this.consoleWriter?.write('log', logMessage, this.contextName);
|
|
155
|
+
this.fileWriter?.write('log', logMessage, this.contextName);
|
|
156
|
+
}
|
|
157
|
+
error(message, trace, context) {
|
|
158
|
+
if (!isLevelEnabled('error', this.minLevel))
|
|
159
|
+
return;
|
|
160
|
+
const logMessage = this.formatMessage(message, context);
|
|
161
|
+
const errorTrace = trace instanceof Error ? trace.stack : trace;
|
|
162
|
+
const fullMessage = errorTrace ? `${logMessage}\n${errorTrace}` : logMessage;
|
|
163
|
+
this.consoleWriter?.write('error', fullMessage, this.contextName);
|
|
164
|
+
this.fileWriter?.write('error', fullMessage, this.contextName);
|
|
165
|
+
}
|
|
166
|
+
warn(message, context) {
|
|
167
|
+
if (!isLevelEnabled('warn', this.minLevel))
|
|
168
|
+
return;
|
|
169
|
+
const logMessage = this.formatMessage(message, context);
|
|
170
|
+
this.consoleWriter?.write('warn', logMessage, this.contextName);
|
|
171
|
+
this.fileWriter?.write('warn', logMessage, this.contextName);
|
|
172
|
+
}
|
|
173
|
+
debug(message, context) {
|
|
174
|
+
if (!isLevelEnabled('debug', this.minLevel))
|
|
175
|
+
return;
|
|
176
|
+
const logMessage = this.formatMessage(message, context);
|
|
177
|
+
this.consoleWriter?.write('debug', logMessage, this.contextName);
|
|
178
|
+
}
|
|
179
|
+
verbose(message, context) {
|
|
180
|
+
if (!isLevelEnabled('verbose', this.minLevel))
|
|
181
|
+
return;
|
|
182
|
+
const logMessage = this.formatMessage(message, context);
|
|
183
|
+
this.consoleWriter?.write('verbose', logMessage, this.contextName);
|
|
184
|
+
}
|
|
185
|
+
logRequest(method, url, context) {
|
|
186
|
+
this.log(`[${method}] ${url}`, {
|
|
187
|
+
...context,
|
|
188
|
+
method,
|
|
189
|
+
url,
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
logResponse(method, url, statusCode, duration, context) {
|
|
193
|
+
const durationStr = duration ? `${duration}ms` : '';
|
|
194
|
+
this.log(`[${method}] ${url} - ${statusCode} ${durationStr}`, {
|
|
195
|
+
...context,
|
|
196
|
+
method,
|
|
197
|
+
url,
|
|
198
|
+
statusCode,
|
|
199
|
+
duration,
|
|
200
|
+
});
|
|
201
|
+
}
|
|
202
|
+
logQuery(query, params, context) {
|
|
203
|
+
this.debug(`Query: ${query}`, {
|
|
204
|
+
...context,
|
|
205
|
+
query,
|
|
206
|
+
params,
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
logBusiness(action, details, context) {
|
|
210
|
+
this.log(`[Business] ${action}`, {
|
|
211
|
+
...context,
|
|
212
|
+
action,
|
|
213
|
+
details,
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
logSecurity(event, details, context) {
|
|
217
|
+
this.warn(`[Security] ${event}`, {
|
|
218
|
+
...context,
|
|
219
|
+
event,
|
|
220
|
+
details,
|
|
221
|
+
});
|
|
222
|
+
}
|
|
223
|
+
logPerformance(operation, duration, context) {
|
|
224
|
+
const level = duration > 1000 ? 'warn' : 'log';
|
|
225
|
+
const message = `[Performance] ${operation} took ${duration}ms`;
|
|
226
|
+
if (level === 'warn') {
|
|
227
|
+
this.warn(message, {
|
|
228
|
+
...context,
|
|
229
|
+
operation,
|
|
230
|
+
duration,
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
this.log(message, {
|
|
235
|
+
...context,
|
|
236
|
+
operation,
|
|
237
|
+
duration,
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
formatMessage(message, context) {
|
|
242
|
+
if (!context || Object.keys(context).length === 0) {
|
|
243
|
+
return message;
|
|
244
|
+
}
|
|
245
|
+
const contextStr = Object.entries(context)
|
|
246
|
+
.filter(([_, value]) => value !== undefined && value !== null)
|
|
247
|
+
.map(([key, value]) => {
|
|
248
|
+
if (typeof value === 'object') {
|
|
249
|
+
return `${key}=${JSON.stringify(value)}`;
|
|
250
|
+
}
|
|
251
|
+
return `${key}=${value}`;
|
|
252
|
+
})
|
|
253
|
+
.join(' ');
|
|
254
|
+
return contextStr ? `${message} | ${contextStr}` : message;
|
|
255
|
+
}
|
|
256
|
+
logStructured(level, message, data, context) {
|
|
257
|
+
const logData = {
|
|
258
|
+
timestamp: new Date().toISOString(),
|
|
259
|
+
level,
|
|
260
|
+
message,
|
|
261
|
+
...context,
|
|
262
|
+
...(data && { data }),
|
|
263
|
+
};
|
|
264
|
+
const logMessage = JSON.stringify(logData);
|
|
265
|
+
switch (level) {
|
|
266
|
+
case LogLevel.ERROR:
|
|
267
|
+
this.error(logMessage);
|
|
268
|
+
break;
|
|
269
|
+
case LogLevel.WARN:
|
|
270
|
+
this.warn(logMessage);
|
|
271
|
+
break;
|
|
272
|
+
case LogLevel.DEBUG:
|
|
273
|
+
this.debug(logMessage);
|
|
274
|
+
break;
|
|
275
|
+
case LogLevel.VERBOSE:
|
|
276
|
+
this.verbose(logMessage);
|
|
277
|
+
break;
|
|
278
|
+
default:
|
|
279
|
+
this.log(logMessage);
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
};
|
|
283
|
+
exports.LoggerHelpers = LoggerHelpers;
|
|
284
|
+
exports.LoggerHelpers = LoggerHelpers = LoggerHelpers_1 = __decorate([
|
|
285
|
+
(0, common_1.Injectable)(),
|
|
286
|
+
__param(1, (0, common_1.Optional)()),
|
|
287
|
+
__param(2, (0, common_1.Optional)()),
|
|
288
|
+
__metadata("design:paramtypes", [String, Object, Object, Object])
|
|
289
|
+
], LoggerHelpers);
|
|
290
|
+
function createLogger(context, options) {
|
|
291
|
+
return new LoggerHelpers(context, undefined, undefined, options);
|
|
292
|
+
}
|
|
293
|
+
//# sourceMappingURL=logger.helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.helpers.js","sourceRoot":"","sources":["../../src/utils/logger.helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { LoggingInterceptorOptions } from '../interceptors/logging.interceptor';
|
|
2
|
+
import { LoggerOptions } from './logger.helpers';
|
|
3
|
+
export declare function getLoggingConfigFromEnv(): {
|
|
4
|
+
loggerOptions: LoggerOptions;
|
|
5
|
+
interceptorOptions: LoggingInterceptorOptions;
|
|
6
|
+
};
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getLoggingConfigFromEnv = getLoggingConfigFromEnv;
|
|
4
|
+
const path = require("path");
|
|
5
|
+
function getLoggingConfigFromEnv() {
|
|
6
|
+
const logDir = process.env.LOG_DIR
|
|
7
|
+
? path.resolve(process.env.LOG_DIR)
|
|
8
|
+
: './logs';
|
|
9
|
+
const enableFileLogging = process.env.ENABLE_FILE_LOGGING !== 'false';
|
|
10
|
+
const fileLogLevel = process.env.FILE_LOG_LEVEL || 'log';
|
|
11
|
+
const logLevel = process.env.LOG_LEVEL?.toLowerCase() || 'log';
|
|
12
|
+
const loggerOptions = {
|
|
13
|
+
logLevel,
|
|
14
|
+
enableFileLogging,
|
|
15
|
+
logDir,
|
|
16
|
+
fileLogLevel,
|
|
17
|
+
enableConsoleLogging: true,
|
|
18
|
+
};
|
|
19
|
+
const interceptorLogLevel = process.env.INTERCEPTOR_LOG_LEVEL?.toLowerCase();
|
|
20
|
+
const logRequestBody = process.env.LOG_REQUEST_BODY === 'true';
|
|
21
|
+
const logResponseBody = process.env.LOG_RESPONSE_BODY === 'true';
|
|
22
|
+
const excludeFieldsStr = process.env.LOG_EXCLUDE_FIELDS || 'password,token,secret,privateKey,private_key';
|
|
23
|
+
const excludeFields = excludeFieldsStr
|
|
24
|
+
.split(',')
|
|
25
|
+
.map(f => f.trim())
|
|
26
|
+
.filter(f => f.length > 0);
|
|
27
|
+
const maxBodyLength = parseInt(process.env.LOG_MAX_BODY_LENGTH || '2000', 10);
|
|
28
|
+
const interceptorOptions = {
|
|
29
|
+
logLevel: interceptorLogLevel === 'none'
|
|
30
|
+
? 'none'
|
|
31
|
+
: interceptorLogLevel || 'log',
|
|
32
|
+
logRequestBody,
|
|
33
|
+
logResponseBody,
|
|
34
|
+
excludeFields,
|
|
35
|
+
maxBodyLength,
|
|
36
|
+
};
|
|
37
|
+
return {
|
|
38
|
+
loggerOptions,
|
|
39
|
+
interceptorOptions,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=logging.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logging.config.js","sourceRoot":"","sources":["../../src/utils/logging.config.ts"],"names":[],"mappings":";;AAOA,0DAgDC;AAvDD,6BAA6B;AAO7B,SAAgB,uBAAuB;IAKrC,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,OAAO;QAChC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;QACnC,CAAC,CAAC,QAAQ,CAAC;IAEb,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,KAAK,OAAO,CAAC;IACtE,MAAM,YAAY,GAAI,OAAO,CAAC,GAAG,CAAC,cAA2C,IAAI,KAAK,CAAC;IACvF,MAAM,QAAQ,GAAI,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,WAAW,EAAmB,IAAI,KAAK,CAAC;IAEjF,MAAM,aAAa,GAAkB;QACnC,QAAQ;QACR,iBAAiB;QACjB,MAAM;QACN,YAAY;QACZ,oBAAoB,EAAE,IAAI;KAC3B,CAAC;IAGF,MAAM,mBAAmB,GAAG,OAAO,CAAC,GAAG,CAAC,qBAAqB,EAAE,WAAW,EAAE,CAAC;IAC7E,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB,KAAK,MAAM,CAAC;IAC/D,MAAM,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,KAAK,MAAM,CAAC;IAEjE,MAAM,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,8CAA8C,CAAC;IAC1G,MAAM,aAAa,GAAG,gBAAgB;SACnC,KAAK,CAAC,GAAG,CAAC;SACV,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;SAClB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAE7B,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,MAAM,EAAE,EAAE,CAAC,CAAC;IAE9E,MAAM,kBAAkB,GAA8B;QACpD,QAAQ,EAAE,mBAAmB,KAAK,MAAM;YACtC,CAAC,CAAC,MAAM;YACR,CAAC,CAAE,mBAAoC,IAAI,KAAK;QAClD,cAAc;QACd,eAAe;QACf,aAAa;QACb,aAAa;KACd,CAAC;IAEF,OAAO;QACL,aAAa;QACb,kBAAkB;KACnB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { DatabaseService } from '../database/database.service';
|
|
2
|
+
export interface PaginationResult<T> {
|
|
3
|
+
data: T[];
|
|
4
|
+
pagination: {
|
|
5
|
+
total: number;
|
|
6
|
+
page: number;
|
|
7
|
+
limit: number;
|
|
8
|
+
totalPages: number;
|
|
9
|
+
hasNext: boolean;
|
|
10
|
+
hasPrev: boolean;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export declare class ServiceHelpers {
|
|
14
|
+
private readonly databaseService?;
|
|
15
|
+
private readonly logger;
|
|
16
|
+
constructor(databaseService?: DatabaseService);
|
|
17
|
+
ensureDatabase(): DatabaseService;
|
|
18
|
+
getDb(): any;
|
|
19
|
+
isDatabaseAvailable(): boolean;
|
|
20
|
+
createPaginationResult<T>(data: T[], total: number, page: number, limit: number): PaginationResult<T>;
|
|
21
|
+
withTransaction<T>(callback: (db: any) => Promise<T>): Promise<T>;
|
|
22
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
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 ServiceHelpers_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.ServiceHelpers = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const database_service_1 = require("../database/database.service");
|
|
19
|
+
let ServiceHelpers = ServiceHelpers_1 = class ServiceHelpers {
|
|
20
|
+
constructor(databaseService) {
|
|
21
|
+
this.databaseService = databaseService;
|
|
22
|
+
this.logger = new common_1.Logger(ServiceHelpers_1.name);
|
|
23
|
+
}
|
|
24
|
+
ensureDatabase() {
|
|
25
|
+
if (!this.databaseService) {
|
|
26
|
+
throw new Error('Database service is not available. Please configure database in CoreModule.');
|
|
27
|
+
}
|
|
28
|
+
if (!this.databaseService.isConnected()) {
|
|
29
|
+
throw new Error('Database service is not connected. Please check your database configuration.');
|
|
30
|
+
}
|
|
31
|
+
return this.databaseService;
|
|
32
|
+
}
|
|
33
|
+
getDb() {
|
|
34
|
+
const db = this.ensureDatabase();
|
|
35
|
+
return db.db;
|
|
36
|
+
}
|
|
37
|
+
isDatabaseAvailable() {
|
|
38
|
+
return this.databaseService?.isConnected() ?? false;
|
|
39
|
+
}
|
|
40
|
+
createPaginationResult(data, total, page, limit) {
|
|
41
|
+
return {
|
|
42
|
+
data,
|
|
43
|
+
pagination: {
|
|
44
|
+
total,
|
|
45
|
+
page,
|
|
46
|
+
limit,
|
|
47
|
+
totalPages: Math.ceil(total / limit),
|
|
48
|
+
hasNext: page * limit < total,
|
|
49
|
+
hasPrev: page > 1,
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
async withTransaction(callback) {
|
|
54
|
+
const dbService = this.ensureDatabase();
|
|
55
|
+
const db = dbService.db;
|
|
56
|
+
return db.transaction(async (tx) => {
|
|
57
|
+
try {
|
|
58
|
+
return await callback(tx);
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
this.logger.error('Transaction failed, rolling back', error);
|
|
62
|
+
throw error;
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
exports.ServiceHelpers = ServiceHelpers;
|
|
68
|
+
exports.ServiceHelpers = ServiceHelpers = ServiceHelpers_1 = __decorate([
|
|
69
|
+
(0, common_1.Injectable)(),
|
|
70
|
+
__param(0, (0, common_1.Optional)()),
|
|
71
|
+
__metadata("design:paramtypes", [database_service_1.DatabaseService])
|
|
72
|
+
], ServiceHelpers);
|
|
73
|
+
//# sourceMappingURL=service.helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service.helpers.js","sourceRoot":"","sources":["../../src/utils/service.helpers.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAsE;AACtE,mEAA+D;AAuBxD,IAAM,cAAc,sBAApB,MAAM,cAAc;IAGzB,YACc,eAAkD;QAAjC,oBAAe,GAAf,eAAe,CAAkB;QAH/C,WAAM,GAAG,IAAI,eAAM,CAAC,gBAAc,CAAC,IAAI,CAAC,CAAC;IAIvD,CAAC;IAMJ,cAAc;QACZ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;QACjG,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,EAAE,CAAC;YACxC,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAC;QAClG,CAAC;QACD,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAMD,KAAK;QACH,MAAM,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACjC,OAAO,EAAE,CAAC,EAAE,CAAC;IACf,CAAC;IAKD,mBAAmB;QACjB,OAAO,IAAI,CAAC,eAAe,EAAE,WAAW,EAAE,IAAI,KAAK,CAAC;IACtD,CAAC;IAKD,sBAAsB,CACpB,IAAS,EACT,KAAa,EACb,IAAY,EACZ,KAAa;QAEb,OAAO;YACL,IAAI;YACJ,UAAU,EAAE;gBACV,KAAK;gBACL,IAAI;gBACJ,KAAK;gBACL,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACpC,OAAO,EAAE,IAAI,GAAG,KAAK,GAAG,KAAK;gBAC7B,OAAO,EAAE,IAAI,GAAG,CAAC;aAClB;SACF,CAAC;IACJ,CAAC;IAkBD,KAAK,CAAC,eAAe,CACnB,QAAiC;QAEjC,MAAM,SAAS,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACxC,MAAM,EAAE,GAAG,SAAS,CAAC,EAAE,CAAC;QAIxB,OAAO,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE;YACjC,IAAI,CAAC;gBACH,OAAO,MAAM,QAAQ,CAAC,EAAE,CAAC,CAAC;YAC5B,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;gBAC7D,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AA5FY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;IAKR,WAAA,IAAA,iBAAQ,GAAE,CAAA;qCAAoC,kCAAe;GAJrD,cAAc,CA4F1B"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare const DEFAULT_CONFIG_FILENAMES: readonly ["application.yml", "application.yaml"];
|
|
2
|
+
export declare const ENV_CONFIG_FILENAME_PATTERN: "application-{env}.yml";
|
|
3
|
+
export type ConfigSource = 'yaml' | 'env' | 'yamlWithEnvOverrides';
|
|
4
|
+
export declare const CONFIG_SOURCE_ENV_KEY = "CONFIG_SOURCE";
|
|
5
|
+
export interface LoadApplicationYamlOptions {
|
|
6
|
+
rootDir?: string;
|
|
7
|
+
env?: string;
|
|
8
|
+
encoding?: BufferEncoding;
|
|
9
|
+
configSource?: ConfigSource;
|
|
10
|
+
syncEnvKeys?: Record<string, string>;
|
|
11
|
+
}
|
|
12
|
+
export declare function loadApplicationYaml(options?: LoadApplicationYamlOptions): Promise<Record<string, any>>;
|
|
13
|
+
export declare function loadApplicationYamlSync(options?: Omit<LoadApplicationYamlOptions, 'encoding'> & {
|
|
14
|
+
encoding?: BufferEncoding;
|
|
15
|
+
}): Record<string, any>;
|