@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.
@@ -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,5 @@
1
+ import { Formatter, LogEntry } from '../types';
2
+ export declare class JsonFormatter implements Formatter {
3
+ format(entry: LogEntry): string;
4
+ }
5
+ //# sourceMappingURL=JsonFormatter.d.ts.map
@@ -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,5 @@
1
+ import { Formatter, LogEntry } from '../types';
2
+ export declare class SimpleFormatter implements Formatter {
3
+ format(entry: LogEntry): string;
4
+ }
5
+ //# sourceMappingURL=SimpleFormatter.d.ts.map
@@ -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"}
@@ -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
+ }