@siriux/logging 1.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/dist/SiriuxLogger.d.ts +29 -0
- package/dist/SiriuxLogger.d.ts.map +1 -0
- package/dist/SiriuxLogger.js +235 -0
- package/dist/SiriuxLogger.js.map +1 -0
- package/dist/formatters/JsonFormatter.d.ts +5 -0
- package/dist/formatters/JsonFormatter.d.ts.map +1 -0
- package/dist/formatters/JsonFormatter.js +10 -0
- package/dist/formatters/JsonFormatter.js.map +1 -0
- package/dist/formatters/SimpleFormatter.d.ts +5 -0
- package/dist/formatters/SimpleFormatter.d.ts.map +1 -0
- package/dist/formatters/SimpleFormatter.js +30 -0
- package/dist/formatters/SimpleFormatter.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +33 -0
- package/dist/index.js.map +1 -0
- package/dist/mock/mockLogger.d.ts +69 -0
- package/dist/mock/mockLogger.d.ts.map +1 -0
- package/dist/mock/mockLogger.js +238 -0
- package/dist/mock/mockLogger.js.map +1 -0
- package/dist/types/index.d.ts +113 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +15 -0
- package/dist/types/index.js.map +1 -0
- package/package.json +45 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { LoggerConfig, Logger, LogMeta, CorrelationContext, PerformanceMetrics } from './types';
|
|
2
|
+
export declare class SiriuxLogger implements Logger {
|
|
3
|
+
private winston;
|
|
4
|
+
private config;
|
|
5
|
+
private correlationContext?;
|
|
6
|
+
constructor(config: LoggerConfig);
|
|
7
|
+
static create(config?: Partial<LoggerConfig>): SiriuxLogger;
|
|
8
|
+
error(message: string, meta?: LogMeta | Error): void;
|
|
9
|
+
warn(message: string, meta?: LogMeta): void;
|
|
10
|
+
info(message: string, meta?: LogMeta): void;
|
|
11
|
+
http(message: string, meta?: LogMeta): void;
|
|
12
|
+
verbose(message: string, meta?: LogMeta): void;
|
|
13
|
+
debug(message: string, meta?: LogMeta): void;
|
|
14
|
+
silly(message: string, meta?: LogMeta): void;
|
|
15
|
+
child(meta: LogMeta): Logger;
|
|
16
|
+
setCorrelationContext(context: Partial<CorrelationContext>): void;
|
|
17
|
+
getCorrelationContext(): CorrelationContext | undefined;
|
|
18
|
+
clearCorrelationContext(): void;
|
|
19
|
+
logPerformance(operation: string, metrics: PerformanceMetrics): void;
|
|
20
|
+
startTimer(operation: string): () => void;
|
|
21
|
+
expressMiddleware(): (req: any, res: any, next: any) => void;
|
|
22
|
+
private log;
|
|
23
|
+
private createWinstonLogger;
|
|
24
|
+
private serializeError;
|
|
25
|
+
}
|
|
26
|
+
export declare const logger: SiriuxLogger;
|
|
27
|
+
export declare function createLogger(config?: Partial<LoggerConfig>): SiriuxLogger;
|
|
28
|
+
export declare function withLogger(logger: SiriuxLogger): (target: any, propertyKey: string, descriptor: PropertyDescriptor) => PropertyDescriptor;
|
|
29
|
+
//# sourceMappingURL=SiriuxLogger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SiriuxLogger.d.ts","sourceRoot":"","sources":["../src/SiriuxLogger.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,YAAY,EACZ,MAAM,EACN,OAAO,EACP,kBAAkB,EAClB,kBAAkB,EACnB,MAAM,SAAS,CAAC;AAIjB,qBAAa,YAAa,YAAW,MAAM;IACzC,OAAO,CAAC,OAAO,CAAiB;IAChC,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,kBAAkB,CAAC,CAAqB;gBAEpC,MAAM,EAAE,YAAY;IAMhC,MAAM,CAAC,MAAM,CAAC,MAAM,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,YAAY;IAmB/D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,KAAK,GAAG,IAAI;IAQpD,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAI3C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAI3C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAI3C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAI9C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAI5C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,IAAI;IAK5C,KAAK,CAAC,IAAI,EAAE,OAAO,GAAG,MAAM;IAW5B,qBAAqB,CAAC,OAAO,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,IAAI;IAUjE,qBAAqB,IAAI,kBAAkB,GAAG,SAAS;IAIvD,uBAAuB,IAAI,IAAI;IAK/B,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,kBAAkB,GAAG,IAAI;IAWpE,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,IAAI;IAczC,iBAAiB,KACP,KAAK,GAAG,EAAE,KAAK,GAAG,EAAE,MAAM,GAAG;IA4CvC,OAAO,CAAC,GAAG;IA+BX,OAAO,CAAC,mBAAmB;IA0C3B,OAAO,CAAC,cAAc;CAQvB;AAGD,eAAO,MAAM,MAAM,cAAwB,CAAC;AAG5C,wBAAgB,YAAY,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,YAAY,CAEzE;AAED,wBAAgB,UAAU,CAAC,MAAM,EAAE,YAAY,IACrC,QAAQ,GAAG,EAAE,aAAa,MAAM,EAAE,YAAY,kBAAkB,wBAkBzE"}
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.logger = exports.SiriuxLogger = void 0;
|
|
7
|
+
exports.createLogger = createLogger;
|
|
8
|
+
exports.withLogger = withLogger;
|
|
9
|
+
const winston_1 = __importDefault(require("winston"));
|
|
10
|
+
const uuid_1 = require("uuid");
|
|
11
|
+
const types_1 = require("./types");
|
|
12
|
+
class SiriuxLogger {
|
|
13
|
+
constructor(config) {
|
|
14
|
+
this.config = config;
|
|
15
|
+
this.winston = this.createWinstonLogger(config);
|
|
16
|
+
}
|
|
17
|
+
// Static factory method
|
|
18
|
+
static create(config = {}) {
|
|
19
|
+
const defaultConfig = {
|
|
20
|
+
level: types_1.LogLevel.INFO,
|
|
21
|
+
service: 'siriux-app',
|
|
22
|
+
version: '1.0.0',
|
|
23
|
+
environment: process.env.NODE_ENV || 'development',
|
|
24
|
+
correlationIdHeader: 'x-correlation-id',
|
|
25
|
+
userIdHeader: 'x-user-id',
|
|
26
|
+
requestIdHeader: 'x-request-id',
|
|
27
|
+
enableConsole: true,
|
|
28
|
+
enableFile: false,
|
|
29
|
+
format: 'json',
|
|
30
|
+
metadata: {}
|
|
31
|
+
};
|
|
32
|
+
return new SiriuxLogger({ ...defaultConfig, ...config });
|
|
33
|
+
}
|
|
34
|
+
// Logging methods
|
|
35
|
+
error(message, meta) {
|
|
36
|
+
if (meta instanceof Error) {
|
|
37
|
+
this.log(types_1.LogLevel.ERROR, message, { error: this.serializeError(meta) });
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.log(types_1.LogLevel.ERROR, message, meta);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
warn(message, meta) {
|
|
44
|
+
this.log(types_1.LogLevel.WARN, message, meta);
|
|
45
|
+
}
|
|
46
|
+
info(message, meta) {
|
|
47
|
+
this.log(types_1.LogLevel.INFO, message, meta);
|
|
48
|
+
}
|
|
49
|
+
http(message, meta) {
|
|
50
|
+
this.log(types_1.LogLevel.HTTP, message, meta);
|
|
51
|
+
}
|
|
52
|
+
verbose(message, meta) {
|
|
53
|
+
this.log(types_1.LogLevel.VERBOSE, message, meta);
|
|
54
|
+
}
|
|
55
|
+
debug(message, meta) {
|
|
56
|
+
this.log(types_1.LogLevel.DEBUG, message, meta);
|
|
57
|
+
}
|
|
58
|
+
silly(message, meta) {
|
|
59
|
+
this.log(types_1.LogLevel.SILLY, message, meta);
|
|
60
|
+
}
|
|
61
|
+
// Create child logger with additional metadata
|
|
62
|
+
child(meta) {
|
|
63
|
+
const childConfig = { ...this.config };
|
|
64
|
+
childConfig.metadata = { ...this.config.metadata, ...meta };
|
|
65
|
+
const childLogger = new SiriuxLogger(childConfig);
|
|
66
|
+
childLogger.correlationContext = this.correlationContext;
|
|
67
|
+
return childLogger;
|
|
68
|
+
}
|
|
69
|
+
// Correlation context management
|
|
70
|
+
setCorrelationContext(context) {
|
|
71
|
+
this.correlationContext = {
|
|
72
|
+
correlationId: context.correlationId || (0, uuid_1.v4)(),
|
|
73
|
+
startTime: context.startTime || Date.now(),
|
|
74
|
+
userId: context.userId,
|
|
75
|
+
requestId: context.requestId,
|
|
76
|
+
metadata: context.metadata
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
getCorrelationContext() {
|
|
80
|
+
return this.correlationContext;
|
|
81
|
+
}
|
|
82
|
+
clearCorrelationContext() {
|
|
83
|
+
this.correlationContext = undefined;
|
|
84
|
+
}
|
|
85
|
+
// Performance logging
|
|
86
|
+
logPerformance(operation, metrics) {
|
|
87
|
+
this.info(`Performance: ${operation}`, {
|
|
88
|
+
duration: metrics.duration,
|
|
89
|
+
memoryUsage: metrics.memoryUsage,
|
|
90
|
+
cpuUsage: metrics.cpuUsage,
|
|
91
|
+
customMetrics: metrics.customMetrics,
|
|
92
|
+
type: 'performance'
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
// Timer functionality
|
|
96
|
+
startTimer(operation) {
|
|
97
|
+
const startTime = Date.now();
|
|
98
|
+
return () => {
|
|
99
|
+
const duration = Date.now() - startTime;
|
|
100
|
+
this.info(`Timer: ${operation}`, {
|
|
101
|
+
duration,
|
|
102
|
+
operation,
|
|
103
|
+
type: 'timer'
|
|
104
|
+
});
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
// Express middleware
|
|
108
|
+
expressMiddleware() {
|
|
109
|
+
return (req, res, next) => {
|
|
110
|
+
const correlationId = req.headers[this.config.correlationIdHeader] ||
|
|
111
|
+
req.headers['x-correlation-id'] ||
|
|
112
|
+
(0, uuid_1.v4)();
|
|
113
|
+
const userId = req.headers[this.config.userIdHeader] ||
|
|
114
|
+
req.headers['x-user-id'] ||
|
|
115
|
+
req.user?.id;
|
|
116
|
+
const requestId = req.headers[this.config.requestIdHeader] ||
|
|
117
|
+
req.headers['x-request-id'] ||
|
|
118
|
+
(0, uuid_1.v4)();
|
|
119
|
+
this.setCorrelationContext({
|
|
120
|
+
correlationId,
|
|
121
|
+
userId,
|
|
122
|
+
requestId
|
|
123
|
+
});
|
|
124
|
+
// Add correlation info to request
|
|
125
|
+
req.correlationId = correlationId;
|
|
126
|
+
req.logger = this;
|
|
127
|
+
const startTime = Date.now();
|
|
128
|
+
res.on('finish', () => {
|
|
129
|
+
const duration = Date.now() - startTime;
|
|
130
|
+
this.http(`${req.method} ${req.path}`, {
|
|
131
|
+
statusCode: res.statusCode,
|
|
132
|
+
duration,
|
|
133
|
+
userAgent: req.headers['user-agent'],
|
|
134
|
+
ipAddress: req.ip || req.connection.remoteAddress,
|
|
135
|
+
method: req.method,
|
|
136
|
+
path: req.path,
|
|
137
|
+
type: 'http'
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
next();
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
// Private methods
|
|
144
|
+
log(level, message, meta) {
|
|
145
|
+
const logEntry = {
|
|
146
|
+
level,
|
|
147
|
+
message,
|
|
148
|
+
timestamp: new Date().toISOString(),
|
|
149
|
+
service: this.config.service,
|
|
150
|
+
version: this.config.version,
|
|
151
|
+
environment: this.config.environment,
|
|
152
|
+
metadata: { ...this.config.metadata, ...meta }
|
|
153
|
+
};
|
|
154
|
+
// Add correlation context if available
|
|
155
|
+
if (this.correlationContext) {
|
|
156
|
+
logEntry.correlationId = this.correlationContext.correlationId;
|
|
157
|
+
logEntry.userId = this.correlationContext.userId;
|
|
158
|
+
logEntry.requestId = this.correlationContext.requestId;
|
|
159
|
+
// Calculate duration if we have start time
|
|
160
|
+
if (this.correlationContext.startTime) {
|
|
161
|
+
logEntry.duration = Date.now() - this.correlationContext.startTime;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
// Add any metadata from correlation context
|
|
165
|
+
if (this.correlationContext?.metadata) {
|
|
166
|
+
logEntry.metadata = { ...logEntry.metadata, ...this.correlationContext.metadata };
|
|
167
|
+
}
|
|
168
|
+
this.winston.log(level, message, logEntry);
|
|
169
|
+
}
|
|
170
|
+
createWinstonLogger(config) {
|
|
171
|
+
const transports = [];
|
|
172
|
+
// Console transport
|
|
173
|
+
if (config.enableConsole !== false) {
|
|
174
|
+
transports.push(new winston_1.default.transports.Console({
|
|
175
|
+
format: config.format === 'json' ?
|
|
176
|
+
winston_1.default.format.combine(winston_1.default.format.timestamp(), winston_1.default.format.json()) :
|
|
177
|
+
winston_1.default.format.combine(winston_1.default.format.timestamp(), winston_1.default.format.simple())
|
|
178
|
+
}));
|
|
179
|
+
}
|
|
180
|
+
// File transport
|
|
181
|
+
if (config.enableFile) {
|
|
182
|
+
transports.push(new winston_1.default.transports.File({
|
|
183
|
+
filename: config.filePath || 'app.log',
|
|
184
|
+
maxsize: Number(config.maxFileSize) || 5242880,
|
|
185
|
+
maxFiles: Number(config.maxFiles) || 5
|
|
186
|
+
}));
|
|
187
|
+
}
|
|
188
|
+
// Custom transports
|
|
189
|
+
if (config.transports) {
|
|
190
|
+
config.transports.forEach(transportConfig => {
|
|
191
|
+
// Add custom transports based on configuration
|
|
192
|
+
// This would be extended based on specific transport needs
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
return winston_1.default.createLogger({
|
|
196
|
+
level: config.level,
|
|
197
|
+
transports,
|
|
198
|
+
exitOnError: false
|
|
199
|
+
});
|
|
200
|
+
}
|
|
201
|
+
serializeError(error) {
|
|
202
|
+
return {
|
|
203
|
+
name: error.name,
|
|
204
|
+
message: error.message,
|
|
205
|
+
stack: error.stack,
|
|
206
|
+
code: error.code
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
exports.SiriuxLogger = SiriuxLogger;
|
|
211
|
+
// Default logger instance
|
|
212
|
+
exports.logger = SiriuxLogger.create();
|
|
213
|
+
// Utility functions
|
|
214
|
+
function createLogger(config) {
|
|
215
|
+
return SiriuxLogger.create(config);
|
|
216
|
+
}
|
|
217
|
+
function withLogger(logger) {
|
|
218
|
+
return (target, propertyKey, descriptor) => {
|
|
219
|
+
const originalMethod = descriptor.value;
|
|
220
|
+
descriptor.value = async function (...args) {
|
|
221
|
+
const timer = logger.startTimer(`${target.constructor.name}.${propertyKey}`);
|
|
222
|
+
try {
|
|
223
|
+
const result = await originalMethod.apply(this, args);
|
|
224
|
+
timer();
|
|
225
|
+
return result;
|
|
226
|
+
}
|
|
227
|
+
catch (error) {
|
|
228
|
+
logger.error(`Error in ${target.constructor.name}.${propertyKey}`, error);
|
|
229
|
+
throw error;
|
|
230
|
+
}
|
|
231
|
+
};
|
|
232
|
+
return descriptor;
|
|
233
|
+
};
|
|
234
|
+
}
|
|
235
|
+
//# sourceMappingURL=SiriuxLogger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SiriuxLogger.js","sourceRoot":"","sources":["../src/SiriuxLogger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JsonFormatter.d.ts","sourceRoot":"","sources":["../../src/formatters/JsonFormatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAE/C,qBAAa,aAAc,YAAW,SAAS;IAC7C,MAAM,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM;CAGhC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JsonFormatter = void 0;
|
|
4
|
+
class JsonFormatter {
|
|
5
|
+
format(entry) {
|
|
6
|
+
return JSON.stringify(entry);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.JsonFormatter = JsonFormatter;
|
|
10
|
+
//# sourceMappingURL=JsonFormatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JsonFormatter.js","sourceRoot":"","sources":["../../src/formatters/JsonFormatter.ts"],"names":[],"mappings":";;;AAEA,MAAa,aAAa;IACxB,MAAM,CAAC,KAAe;QACpB,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;CACF;AAJD,sCAIC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SimpleFormatter.d.ts","sourceRoot":"","sources":["../../src/formatters/SimpleFormatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAE/C,qBAAa,eAAgB,YAAW,SAAS;IAC/C,MAAM,CAAC,KAAK,EAAE,QAAQ,GAAG,MAAM;CA6BhC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SimpleFormatter = void 0;
|
|
4
|
+
class SimpleFormatter {
|
|
5
|
+
format(entry) {
|
|
6
|
+
const timestamp = new Date(entry.timestamp).toISOString();
|
|
7
|
+
const correlationId = entry.correlationId ? `[${entry.correlationId}]` : '';
|
|
8
|
+
const userId = entry.userId ? `[User:${entry.userId}]` : '';
|
|
9
|
+
const requestId = entry.requestId ? `[Req:${entry.requestId}]` : '';
|
|
10
|
+
let message = `${timestamp} ${correlationId}${userId}${requestId} [${entry.level.toUpperCase()}] ${entry.message}`;
|
|
11
|
+
if (entry.service) {
|
|
12
|
+
message += ` [${entry.service}]`;
|
|
13
|
+
}
|
|
14
|
+
if (entry.duration) {
|
|
15
|
+
message += ` (${entry.duration}ms)`;
|
|
16
|
+
}
|
|
17
|
+
if (entry.error) {
|
|
18
|
+
message += `\nError: ${entry.error.name} - ${entry.error.message}`;
|
|
19
|
+
if (entry.error.stack) {
|
|
20
|
+
message += `\nStack: ${entry.error.stack}`;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
if (entry.metadata && Object.keys(entry.metadata).length > 0) {
|
|
24
|
+
message += `\nMeta: ${JSON.stringify(entry.metadata)}`;
|
|
25
|
+
}
|
|
26
|
+
return message;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
exports.SimpleFormatter = SimpleFormatter;
|
|
30
|
+
//# sourceMappingURL=SimpleFormatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SimpleFormatter.js","sourceRoot":"","sources":["../../src/formatters/SimpleFormatter.ts"],"names":[],"mappings":";;;AAEA,MAAa,eAAe;IAC1B,MAAM,CAAC,KAAe;QACpB,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAC1D,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5E,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5D,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,KAAK,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAEpE,IAAI,OAAO,GAAG,GAAG,SAAS,IAAI,aAAa,GAAG,MAAM,GAAG,SAAS,KAAK,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,OAAO,EAAE,CAAC;QAEnH,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO,IAAI,KAAK,KAAK,CAAC,OAAO,GAAG,CAAC;QACnC,CAAC;QAED,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,OAAO,IAAI,KAAK,KAAK,CAAC,QAAQ,KAAK,CAAC;QACtC,CAAC;QAED,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,OAAO,IAAI,YAAY,KAAK,CAAC,KAAK,CAAC,IAAI,MAAM,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;YACnE,IAAI,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;gBACtB,OAAO,IAAI,YAAY,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YAC7C,CAAC;QACH,CAAC;QAED,IAAI,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7D,OAAO,IAAI,WAAW,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;QACzD,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;CACF;AA9BD,0CA8BC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export * from './types';
|
|
2
|
+
export { SiriuxLogger, logger, createLogger, withLogger } from './SiriuxLogger';
|
|
3
|
+
export { JsonFormatter } from './formatters/JsonFormatter';
|
|
4
|
+
export { SimpleFormatter } from './formatters/SimpleFormatter';
|
|
5
|
+
export declare const SIRIUX_LOGGING_VERSION = "1.0.0";
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,SAAS,CAAC;AAGxB,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGhF,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAG/D,eAAO,MAAM,sBAAsB,UAAU,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.SIRIUX_LOGGING_VERSION = exports.SimpleFormatter = exports.JsonFormatter = exports.withLogger = exports.createLogger = exports.logger = exports.SiriuxLogger = void 0;
|
|
18
|
+
// Core exports
|
|
19
|
+
__exportStar(require("./types"), exports);
|
|
20
|
+
// Main logger
|
|
21
|
+
var SiriuxLogger_1 = require("./SiriuxLogger");
|
|
22
|
+
Object.defineProperty(exports, "SiriuxLogger", { enumerable: true, get: function () { return SiriuxLogger_1.SiriuxLogger; } });
|
|
23
|
+
Object.defineProperty(exports, "logger", { enumerable: true, get: function () { return SiriuxLogger_1.logger; } });
|
|
24
|
+
Object.defineProperty(exports, "createLogger", { enumerable: true, get: function () { return SiriuxLogger_1.createLogger; } });
|
|
25
|
+
Object.defineProperty(exports, "withLogger", { enumerable: true, get: function () { return SiriuxLogger_1.withLogger; } });
|
|
26
|
+
// Formatters
|
|
27
|
+
var JsonFormatter_1 = require("./formatters/JsonFormatter");
|
|
28
|
+
Object.defineProperty(exports, "JsonFormatter", { enumerable: true, get: function () { return JsonFormatter_1.JsonFormatter; } });
|
|
29
|
+
var SimpleFormatter_1 = require("./formatters/SimpleFormatter");
|
|
30
|
+
Object.defineProperty(exports, "SimpleFormatter", { enumerable: true, get: function () { return SimpleFormatter_1.SimpleFormatter; } });
|
|
31
|
+
// Version information
|
|
32
|
+
exports.SIRIUX_LOGGING_VERSION = '1.0.0';
|
|
33
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,eAAe;AACf,0CAAwB;AAExB,cAAc;AACd,+CAAgF;AAAvE,4GAAA,YAAY,OAAA;AAAE,sGAAA,MAAM,OAAA;AAAE,4GAAA,YAAY,OAAA;AAAE,0GAAA,UAAU,OAAA;AAEvD,aAAa;AACb,4DAA2D;AAAlD,8GAAA,aAAa,OAAA;AACtB,gEAA+D;AAAtD,kHAAA,eAAe,OAAA;AAExB,sBAAsB;AACT,QAAA,sBAAsB,GAAG,OAAO,CAAC"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
export declare enum LogLevel {
|
|
2
|
+
DEBUG = "debug",
|
|
3
|
+
INFO = "info",
|
|
4
|
+
WARN = "warn",
|
|
5
|
+
ERROR = "error"
|
|
6
|
+
}
|
|
7
|
+
export declare enum LogOutput {
|
|
8
|
+
CONSOLE = "console",
|
|
9
|
+
FILE = "file",
|
|
10
|
+
DATABASE = "database",
|
|
11
|
+
CLOUD = "cloud"
|
|
12
|
+
}
|
|
13
|
+
export interface LogEntry {
|
|
14
|
+
id: string;
|
|
15
|
+
timestamp: string;
|
|
16
|
+
level: LogLevel;
|
|
17
|
+
message: string;
|
|
18
|
+
metadata?: Record<string, any>;
|
|
19
|
+
userId?: string;
|
|
20
|
+
requestId?: string;
|
|
21
|
+
service: string;
|
|
22
|
+
environment: string;
|
|
23
|
+
}
|
|
24
|
+
export interface MockLoggerConfig {
|
|
25
|
+
level: LogLevel;
|
|
26
|
+
outputs: LogOutput[];
|
|
27
|
+
service: string;
|
|
28
|
+
environment: string;
|
|
29
|
+
enableStructuredLogging: boolean;
|
|
30
|
+
enableMetrics: boolean;
|
|
31
|
+
}
|
|
32
|
+
export declare class MockLogger {
|
|
33
|
+
private config;
|
|
34
|
+
private logs;
|
|
35
|
+
private metrics;
|
|
36
|
+
constructor(config?: Partial<MockLoggerConfig>);
|
|
37
|
+
private createLogEntry;
|
|
38
|
+
private writeLog;
|
|
39
|
+
private writeToOutput;
|
|
40
|
+
private writeToConsole;
|
|
41
|
+
private writeToFile;
|
|
42
|
+
private writeToDatabase;
|
|
43
|
+
private writeToCloud;
|
|
44
|
+
debug(message: string, metadata?: Record<string, any>): Promise<void>;
|
|
45
|
+
info(message: string, metadata?: Record<string, any>): Promise<void>;
|
|
46
|
+
warn(message: string, metadata?: Record<string, any>): Promise<void>;
|
|
47
|
+
error(message: string, metadata?: Record<string, any>): Promise<void>;
|
|
48
|
+
logUserAction(userId: string, action: string, metadata?: Record<string, any>): Promise<void>;
|
|
49
|
+
logApiRequest(method: string, path: string, statusCode: number, duration: number, metadata?: Record<string, any>): Promise<void>;
|
|
50
|
+
logError(error: Error, context?: Record<string, any>): Promise<void>;
|
|
51
|
+
logPerformance(operation: string, duration: number, metadata?: Record<string, any>): Promise<void>;
|
|
52
|
+
getLogs(level?: LogLevel, limit?: number): Promise<LogEntry[]>;
|
|
53
|
+
getLogsByUser(userId: string, limit?: number): Promise<LogEntry[]>;
|
|
54
|
+
searchLogs(query: string, limit?: number): Promise<LogEntry[]>;
|
|
55
|
+
getMetrics(): Record<string, number>;
|
|
56
|
+
getLogStats(): Promise<{
|
|
57
|
+
total: number;
|
|
58
|
+
byLevel: Record<LogLevel, number>;
|
|
59
|
+
byHour: Record<string, number>;
|
|
60
|
+
topErrors: string[];
|
|
61
|
+
}>;
|
|
62
|
+
clearLogs(): void;
|
|
63
|
+
flush(): Promise<void>;
|
|
64
|
+
updateConfig(newConfig: Partial<MockLoggerConfig>): void;
|
|
65
|
+
getConfig(): MockLoggerConfig;
|
|
66
|
+
}
|
|
67
|
+
export declare const createMockLogger: (config?: Partial<MockLoggerConfig>) => MockLogger;
|
|
68
|
+
export declare const createEnvironmentLogger: () => MockLogger;
|
|
69
|
+
//# sourceMappingURL=mockLogger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mockLogger.d.ts","sourceRoot":"","sources":["../../src/mock/mockLogger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,238 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createEnvironmentLogger = exports.createMockLogger = exports.MockLogger = exports.LogOutput = exports.LogLevel = void 0;
|
|
4
|
+
// Mock logging system with multiple output options
|
|
5
|
+
var LogLevel;
|
|
6
|
+
(function (LogLevel) {
|
|
7
|
+
LogLevel["DEBUG"] = "debug";
|
|
8
|
+
LogLevel["INFO"] = "info";
|
|
9
|
+
LogLevel["WARN"] = "warn";
|
|
10
|
+
LogLevel["ERROR"] = "error";
|
|
11
|
+
})(LogLevel || (exports.LogLevel = LogLevel = {}));
|
|
12
|
+
var LogOutput;
|
|
13
|
+
(function (LogOutput) {
|
|
14
|
+
LogOutput["CONSOLE"] = "console";
|
|
15
|
+
LogOutput["FILE"] = "file";
|
|
16
|
+
LogOutput["DATABASE"] = "database";
|
|
17
|
+
LogOutput["CLOUD"] = "cloud";
|
|
18
|
+
})(LogOutput || (exports.LogOutput = LogOutput = {}));
|
|
19
|
+
class MockLogger {
|
|
20
|
+
constructor(config = {}) {
|
|
21
|
+
this.logs = [];
|
|
22
|
+
this.metrics = new Map();
|
|
23
|
+
this.config = {
|
|
24
|
+
level: LogLevel.INFO,
|
|
25
|
+
outputs: [LogOutput.CONSOLE],
|
|
26
|
+
service: 'siriux-app',
|
|
27
|
+
environment: process.env.NODE_ENV || 'development',
|
|
28
|
+
enableStructuredLogging: true,
|
|
29
|
+
enableMetrics: true,
|
|
30
|
+
...config
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
createLogEntry(level, message, metadata) {
|
|
34
|
+
return {
|
|
35
|
+
id: Date.now().toString() + Math.random().toString(36).substr(2, 9),
|
|
36
|
+
timestamp: new Date().toISOString(),
|
|
37
|
+
level,
|
|
38
|
+
message,
|
|
39
|
+
metadata,
|
|
40
|
+
service: this.config.service,
|
|
41
|
+
environment: this.config.environment
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
async writeLog(entry) {
|
|
45
|
+
// Store in memory
|
|
46
|
+
this.logs.push(entry);
|
|
47
|
+
// Keep only last 1000 logs to prevent memory issues
|
|
48
|
+
if (this.logs.length > 1000) {
|
|
49
|
+
this.logs = this.logs.slice(-1000);
|
|
50
|
+
}
|
|
51
|
+
// Update metrics
|
|
52
|
+
const metricKey = `logs_${entry.level}`;
|
|
53
|
+
this.metrics.set(metricKey, (this.metrics.get(metricKey) || 0) + 1);
|
|
54
|
+
// Write to configured outputs
|
|
55
|
+
for (const output of this.config.outputs) {
|
|
56
|
+
await this.writeToOutput(entry, output);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
async writeToOutput(entry, output) {
|
|
60
|
+
switch (output) {
|
|
61
|
+
case LogOutput.CONSOLE:
|
|
62
|
+
this.writeToConsole(entry);
|
|
63
|
+
break;
|
|
64
|
+
case LogOutput.FILE:
|
|
65
|
+
this.writeToFile(entry);
|
|
66
|
+
break;
|
|
67
|
+
case LogOutput.DATABASE:
|
|
68
|
+
this.writeToDatabase(entry);
|
|
69
|
+
break;
|
|
70
|
+
case LogOutput.CLOUD:
|
|
71
|
+
this.writeToCloud(entry);
|
|
72
|
+
break;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
writeToConsole(entry) {
|
|
76
|
+
const timestamp = new Date(entry.timestamp).toLocaleTimeString();
|
|
77
|
+
const prefix = `[${timestamp}] [${entry.level.toUpperCase()}] [${entry.service}]`;
|
|
78
|
+
if (this.config.enableStructuredLogging) {
|
|
79
|
+
console.log(prefix, entry.message, entry.metadata || {});
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
console.log(`${prefix} ${entry.message}`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
writeToFile(entry) {
|
|
86
|
+
// Mock file writing
|
|
87
|
+
console.log(`📁 Writing to log file: ${entry.id} - ${entry.message}`);
|
|
88
|
+
}
|
|
89
|
+
writeToDatabase(entry) {
|
|
90
|
+
// Mock database writing
|
|
91
|
+
console.log(`🗄️ Writing to database: ${entry.id} - ${entry.message}`);
|
|
92
|
+
}
|
|
93
|
+
writeToCloud(entry) {
|
|
94
|
+
// Mock cloud logging (e.g., CloudWatch, Datadog)
|
|
95
|
+
console.log(`☁️ Writing to cloud: ${entry.id} - ${entry.message}`);
|
|
96
|
+
}
|
|
97
|
+
// Public logging methods
|
|
98
|
+
async debug(message, metadata) {
|
|
99
|
+
const entry = this.createLogEntry(LogLevel.DEBUG, message, metadata);
|
|
100
|
+
await this.writeLog(entry);
|
|
101
|
+
}
|
|
102
|
+
async info(message, metadata) {
|
|
103
|
+
const entry = this.createLogEntry(LogLevel.INFO, message, metadata);
|
|
104
|
+
await this.writeLog(entry);
|
|
105
|
+
}
|
|
106
|
+
async warn(message, metadata) {
|
|
107
|
+
const entry = this.createLogEntry(LogLevel.WARN, message, metadata);
|
|
108
|
+
await this.writeLog(entry);
|
|
109
|
+
}
|
|
110
|
+
async error(message, metadata) {
|
|
111
|
+
const entry = this.createLogEntry(LogLevel.ERROR, message, metadata);
|
|
112
|
+
await this.writeLog(entry);
|
|
113
|
+
}
|
|
114
|
+
// Structured logging methods
|
|
115
|
+
async logUserAction(userId, action, metadata) {
|
|
116
|
+
await this.info(`User action: ${action}`, {
|
|
117
|
+
userId,
|
|
118
|
+
action,
|
|
119
|
+
category: 'user_action',
|
|
120
|
+
...metadata
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
async logApiRequest(method, path, statusCode, duration, metadata) {
|
|
124
|
+
await this.info(`API Request: ${method} ${path}`, {
|
|
125
|
+
method,
|
|
126
|
+
path,
|
|
127
|
+
statusCode,
|
|
128
|
+
duration,
|
|
129
|
+
category: 'api_request',
|
|
130
|
+
...metadata
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
async logError(error, context) {
|
|
134
|
+
await this.error(error.message, {
|
|
135
|
+
stack: error.stack,
|
|
136
|
+
name: error.name,
|
|
137
|
+
category: 'error',
|
|
138
|
+
...context
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
async logPerformance(operation, duration, metadata) {
|
|
142
|
+
await this.info(`Performance: ${operation}`, {
|
|
143
|
+
operation,
|
|
144
|
+
duration,
|
|
145
|
+
category: 'performance',
|
|
146
|
+
...metadata
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
// Query methods
|
|
150
|
+
async getLogs(level, limit = 100) {
|
|
151
|
+
let filteredLogs = this.logs;
|
|
152
|
+
if (level) {
|
|
153
|
+
filteredLogs = filteredLogs.filter(log => log.level === level);
|
|
154
|
+
}
|
|
155
|
+
return filteredLogs
|
|
156
|
+
.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime())
|
|
157
|
+
.slice(0, limit);
|
|
158
|
+
}
|
|
159
|
+
async getLogsByUser(userId, limit = 50) {
|
|
160
|
+
return this.logs
|
|
161
|
+
.filter(log => log.metadata?.userId === userId)
|
|
162
|
+
.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime())
|
|
163
|
+
.slice(0, limit);
|
|
164
|
+
}
|
|
165
|
+
async searchLogs(query, limit = 100) {
|
|
166
|
+
const lowerQuery = query.toLowerCase();
|
|
167
|
+
return this.logs
|
|
168
|
+
.filter(log => log.message.toLowerCase().includes(lowerQuery) ||
|
|
169
|
+
JSON.stringify(log.metadata || {}).toLowerCase().includes(lowerQuery))
|
|
170
|
+
.sort((a, b) => new Date(b.timestamp).getTime() - new Date(a.timestamp).getTime())
|
|
171
|
+
.slice(0, limit);
|
|
172
|
+
}
|
|
173
|
+
// Metrics methods
|
|
174
|
+
getMetrics() {
|
|
175
|
+
return Object.fromEntries(this.metrics);
|
|
176
|
+
}
|
|
177
|
+
async getLogStats() {
|
|
178
|
+
const byLevel = {
|
|
179
|
+
[LogLevel.DEBUG]: 0,
|
|
180
|
+
[LogLevel.INFO]: 0,
|
|
181
|
+
[LogLevel.WARN]: 0,
|
|
182
|
+
[LogLevel.ERROR]: 0
|
|
183
|
+
};
|
|
184
|
+
const byHour = {};
|
|
185
|
+
const errorMessages = [];
|
|
186
|
+
for (const log of this.logs) {
|
|
187
|
+
byLevel[log.level]++;
|
|
188
|
+
const hour = new Date(log.timestamp).getHours().toString();
|
|
189
|
+
byHour[hour] = (byHour[hour] || 0) + 1;
|
|
190
|
+
if (log.level === LogLevel.ERROR) {
|
|
191
|
+
errorMessages.push(log.message);
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
return {
|
|
195
|
+
total: this.logs.length,
|
|
196
|
+
byLevel,
|
|
197
|
+
byHour,
|
|
198
|
+
topErrors: errorMessages.slice(0, 10)
|
|
199
|
+
};
|
|
200
|
+
}
|
|
201
|
+
// Utility methods
|
|
202
|
+
clearLogs() {
|
|
203
|
+
this.logs = [];
|
|
204
|
+
this.metrics.clear();
|
|
205
|
+
}
|
|
206
|
+
async flush() {
|
|
207
|
+
// Mock flush operation
|
|
208
|
+
console.log('🔄 Flushing logs...');
|
|
209
|
+
for (const output of this.config.outputs) {
|
|
210
|
+
console.log(`✅ Flushed to ${output}`);
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
// Configuration methods
|
|
214
|
+
updateConfig(newConfig) {
|
|
215
|
+
this.config = { ...this.config, ...newConfig };
|
|
216
|
+
}
|
|
217
|
+
getConfig() {
|
|
218
|
+
return { ...this.config };
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
exports.MockLogger = MockLogger;
|
|
222
|
+
// Factory function
|
|
223
|
+
const createMockLogger = (config) => {
|
|
224
|
+
return new MockLogger(config);
|
|
225
|
+
};
|
|
226
|
+
exports.createMockLogger = createMockLogger;
|
|
227
|
+
// Environment-based logger
|
|
228
|
+
const createEnvironmentLogger = () => {
|
|
229
|
+
const config = {
|
|
230
|
+
level: process.env.LOG_LEVEL || LogLevel.INFO,
|
|
231
|
+
outputs: process.env.LOG_OUTPUTS?.split(',') || [LogOutput.CONSOLE],
|
|
232
|
+
service: process.env.SERVICE_NAME || 'siriux-app',
|
|
233
|
+
environment: process.env.NODE_ENV || 'development'
|
|
234
|
+
};
|
|
235
|
+
return new MockLogger(config);
|
|
236
|
+
};
|
|
237
|
+
exports.createEnvironmentLogger = createEnvironmentLogger;
|
|
238
|
+
//# sourceMappingURL=mockLogger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mockLogger.js","sourceRoot":"","sources":["../../src/mock/mockLogger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
export declare enum LogLevel {
|
|
2
|
+
ERROR = "error",
|
|
3
|
+
WARN = "warn",
|
|
4
|
+
INFO = "info",
|
|
5
|
+
HTTP = "http",
|
|
6
|
+
VERBOSE = "verbose",
|
|
7
|
+
DEBUG = "debug",
|
|
8
|
+
SILLY = "silly"
|
|
9
|
+
}
|
|
10
|
+
export interface LogEntry {
|
|
11
|
+
level: LogLevel;
|
|
12
|
+
message: string;
|
|
13
|
+
timestamp: string;
|
|
14
|
+
correlationId?: string;
|
|
15
|
+
userId?: string;
|
|
16
|
+
requestId?: string;
|
|
17
|
+
service?: string;
|
|
18
|
+
version?: string;
|
|
19
|
+
environment?: string;
|
|
20
|
+
metadata?: Record<string, any>;
|
|
21
|
+
error?: {
|
|
22
|
+
name: string;
|
|
23
|
+
message: string;
|
|
24
|
+
stack?: string;
|
|
25
|
+
code?: string | number;
|
|
26
|
+
};
|
|
27
|
+
tags?: string[];
|
|
28
|
+
duration?: number;
|
|
29
|
+
}
|
|
30
|
+
export interface LoggerConfig {
|
|
31
|
+
level: LogLevel;
|
|
32
|
+
service: string;
|
|
33
|
+
version?: string;
|
|
34
|
+
environment?: string;
|
|
35
|
+
correlationIdHeader?: string;
|
|
36
|
+
userIdHeader?: string;
|
|
37
|
+
requestIdHeader?: string;
|
|
38
|
+
enableConsole?: boolean;
|
|
39
|
+
enableFile?: boolean;
|
|
40
|
+
filePath?: string;
|
|
41
|
+
maxFileSize?: string;
|
|
42
|
+
maxFiles?: string;
|
|
43
|
+
datePattern?: string;
|
|
44
|
+
format?: 'json' | 'simple' | 'combined';
|
|
45
|
+
metadata?: Record<string, any>;
|
|
46
|
+
transports?: TransportConfig[];
|
|
47
|
+
}
|
|
48
|
+
export interface TransportConfig {
|
|
49
|
+
type: 'console' | 'file' | 'http' | 'database' | 'elasticsearch' | 'custom';
|
|
50
|
+
level?: LogLevel;
|
|
51
|
+
format?: 'json' | 'simple' | 'combined';
|
|
52
|
+
options?: Record<string, any>;
|
|
53
|
+
}
|
|
54
|
+
export interface Logger {
|
|
55
|
+
error(message: string, meta?: LogMeta): void;
|
|
56
|
+
error(message: string, error: Error, meta?: LogMeta): void;
|
|
57
|
+
warn(message: string, meta?: LogMeta): void;
|
|
58
|
+
info(message: string, meta?: LogMeta): void;
|
|
59
|
+
http(message: string, meta?: LogMeta): void;
|
|
60
|
+
verbose(message: string, meta?: LogMeta): void;
|
|
61
|
+
debug(message: string, meta?: LogMeta): void;
|
|
62
|
+
silly(message: string, meta?: LogMeta): void;
|
|
63
|
+
child(meta: LogMeta): Logger;
|
|
64
|
+
}
|
|
65
|
+
export interface LogMeta {
|
|
66
|
+
correlationId?: string;
|
|
67
|
+
userId?: string;
|
|
68
|
+
requestId?: string;
|
|
69
|
+
duration?: number;
|
|
70
|
+
[key: string]: any;
|
|
71
|
+
}
|
|
72
|
+
export interface Transport {
|
|
73
|
+
name: string;
|
|
74
|
+
log(entry: LogEntry): void | Promise<void>;
|
|
75
|
+
}
|
|
76
|
+
export interface Formatter {
|
|
77
|
+
format(entry: LogEntry): string;
|
|
78
|
+
}
|
|
79
|
+
export interface CorrelationContext {
|
|
80
|
+
correlationId: string;
|
|
81
|
+
userId?: string;
|
|
82
|
+
requestId?: string;
|
|
83
|
+
startTime: number;
|
|
84
|
+
metadata?: Record<string, any>;
|
|
85
|
+
}
|
|
86
|
+
export interface PerformanceMetrics {
|
|
87
|
+
duration: number;
|
|
88
|
+
memoryUsage?: NodeJS.MemoryUsage;
|
|
89
|
+
cpuUsage?: NodeJS.CpuUsage;
|
|
90
|
+
customMetrics?: Record<string, number>;
|
|
91
|
+
}
|
|
92
|
+
export interface AuditLogEntry extends LogEntry {
|
|
93
|
+
action: string;
|
|
94
|
+
resource: string;
|
|
95
|
+
userId: string;
|
|
96
|
+
ipAddress?: string;
|
|
97
|
+
userAgent?: string;
|
|
98
|
+
success: boolean;
|
|
99
|
+
errorCode?: string;
|
|
100
|
+
details?: Record<string, any>;
|
|
101
|
+
}
|
|
102
|
+
export interface HealthCheckResult {
|
|
103
|
+
status: 'healthy' | 'unhealthy' | 'degraded';
|
|
104
|
+
timestamp: string;
|
|
105
|
+
checks: Record<string, {
|
|
106
|
+
status: 'pass' | 'fail' | 'warn';
|
|
107
|
+
duration: number;
|
|
108
|
+
message?: string;
|
|
109
|
+
details?: Record<string, any>;
|
|
110
|
+
}>;
|
|
111
|
+
duration: number;
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LogLevel = void 0;
|
|
4
|
+
// Log levels
|
|
5
|
+
var LogLevel;
|
|
6
|
+
(function (LogLevel) {
|
|
7
|
+
LogLevel["ERROR"] = "error";
|
|
8
|
+
LogLevel["WARN"] = "warn";
|
|
9
|
+
LogLevel["INFO"] = "info";
|
|
10
|
+
LogLevel["HTTP"] = "http";
|
|
11
|
+
LogLevel["VERBOSE"] = "verbose";
|
|
12
|
+
LogLevel["DEBUG"] = "debug";
|
|
13
|
+
LogLevel["SILLY"] = "silly";
|
|
14
|
+
})(LogLevel || (exports.LogLevel = LogLevel = {}));
|
|
15
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":";;;AAAA,aAAa;AACb,IAAY,QAQX;AARD,WAAY,QAAQ;IAClB,2BAAe,CAAA;IACf,yBAAa,CAAA;IACb,yBAAa,CAAA;IACb,yBAAa,CAAA;IACb,+BAAmB,CAAA;IACnB,2BAAe,CAAA;IACf,2BAAe,CAAA;AACjB,CAAC,EARW,QAAQ,wBAAR,QAAQ,QAQnB"}
|
package/package.json
ADDED
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@siriux/logging",
|
|
3
|
+
"version": "1.0.1",
|
|
4
|
+
"description": "Siriux Logging - Structured logging with correlation IDs and multiple transports",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"build": "tsc",
|
|
9
|
+
"dev": "tsc --watch",
|
|
10
|
+
"test": "jest",
|
|
11
|
+
"clean": "rm -rf dist",
|
|
12
|
+
"prepublishOnly": "npm run clean && npm run build"
|
|
13
|
+
},
|
|
14
|
+
"keywords": [
|
|
15
|
+
"siriux",
|
|
16
|
+
"logging",
|
|
17
|
+
"winston",
|
|
18
|
+
"structured-logging",
|
|
19
|
+
"correlation-id",
|
|
20
|
+
"tracing",
|
|
21
|
+
"observability"
|
|
22
|
+
],
|
|
23
|
+
"author": "jawwad@alsirius.co.uk",
|
|
24
|
+
"license": "MIT",
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@siriux/core": "^2.0.0",
|
|
27
|
+
"uuid": "^9.0.1",
|
|
28
|
+
"winston": "^3.11.0",
|
|
29
|
+
"winston-daily-rotate-file": "^4.7.1"
|
|
30
|
+
},
|
|
31
|
+
"devDependencies": {
|
|
32
|
+
"@types/jest": "^29.5.8",
|
|
33
|
+
"@types/node": "^20.10.5",
|
|
34
|
+
"@types/uuid": "^9.0.7",
|
|
35
|
+
"jest": "^29.7.0",
|
|
36
|
+
"typescript": "^5.3.3"
|
|
37
|
+
},
|
|
38
|
+
"files": [
|
|
39
|
+
"dist/**/*"
|
|
40
|
+
],
|
|
41
|
+
"publishConfig": {
|
|
42
|
+
"access": "public"
|
|
43
|
+
},
|
|
44
|
+
"gitHead": "7a9592f8e9ed3f1301046046e1e05811cecc24be"
|
|
45
|
+
}
|