bootifyjs 0.0.3 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +116 -510
- package/dist/api.d.ts +32 -0
- package/dist/api.js +149 -0
- package/dist/api.js.map +1 -0
- package/dist/config/app.config.d.ts +29 -0
- package/dist/config/app.config.js +55 -0
- package/dist/config/app.config.js.map +1 -0
- package/dist/controllers/config.controller.d.ts +16 -0
- package/dist/controllers/config.controller.js +66 -0
- package/dist/controllers/config.controller.js.map +1 -0
- package/dist/controllers/events.controller.d.ts +66 -0
- package/dist/controllers/events.controller.js +145 -0
- package/dist/controllers/events.controller.js.map +1 -0
- package/dist/controllers/health.controller.d.ts +20 -0
- package/dist/controllers/health.controller.js +92 -0
- package/dist/controllers/health.controller.js.map +1 -0
- package/dist/controllers/user.controller.d.ts +13 -0
- package/dist/controllers/user.controller.js +209 -0
- package/dist/controllers/user.controller.js.map +1 -0
- package/dist/core/application.d.ts +21 -0
- package/dist/core/application.js +90 -0
- package/dist/core/application.js.map +1 -0
- package/dist/core/config.d.ts +3 -0
- package/dist/core/config.js +78 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/container.d.ts +17 -0
- package/dist/core/container.js +92 -0
- package/dist/core/container.js.map +1 -0
- package/dist/core/decorators.d.ts +28 -0
- package/dist/core/decorators.js +204 -0
- package/dist/core/decorators.js.map +1 -0
- package/dist/core/errors.d.ts +18 -0
- package/dist/core/errors.js +74 -0
- package/dist/core/errors.js.map +1 -0
- package/dist/core/middleware.d.ts +8 -0
- package/dist/core/middleware.js +23 -0
- package/dist/core/middleware.js.map +1 -0
- package/dist/core/openapi.d.ts +80 -0
- package/dist/core/openapi.js +189 -0
- package/dist/core/openapi.js.map +1 -0
- package/dist/core/router.d.ts +32 -0
- package/dist/core/router.js +266 -0
- package/dist/core/router.js.map +1 -0
- package/dist/core/utils.d.ts +7 -0
- package/dist/core/utils.js +75 -0
- package/dist/core/utils.js.map +1 -0
- package/dist/core/validation.d.ts +15 -0
- package/dist/core/validation.js +161 -0
- package/dist/core/validation.js.map +1 -0
- package/dist/events/core/event-bus.d.ts +26 -0
- package/dist/events/core/event-bus.js +253 -0
- package/dist/events/core/event-bus.js.map +1 -0
- package/dist/events/core/event-registry.d.ts +31 -0
- package/dist/events/core/event-registry.js +170 -0
- package/dist/events/core/event-registry.js.map +1 -0
- package/dist/events/decorators/event.decorators.d.ts +11 -0
- package/dist/events/decorators/event.decorators.js +123 -0
- package/dist/events/decorators/event.decorators.js.map +1 -0
- package/dist/events/examples/system.events.d.ts +15 -0
- package/dist/events/examples/system.events.js +28 -0
- package/dist/events/examples/system.events.js.map +1 -0
- package/dist/events/examples/user.events.d.ts +68 -0
- package/dist/events/examples/user.events.js +73 -0
- package/dist/events/examples/user.events.js.map +1 -0
- package/dist/events/examples/user.handlers.d.ts +20 -0
- package/dist/events/examples/user.handlers.js +157 -0
- package/dist/events/examples/user.handlers.js.map +1 -0
- package/dist/events/index.d.ts +13 -0
- package/dist/events/index.js +71 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/middleware/logging.middleware.d.ts +7 -0
- package/dist/events/middleware/logging.middleware.js +44 -0
- package/dist/events/middleware/logging.middleware.js.map +1 -0
- package/dist/events/middleware/metrics.middleware.d.ts +11 -0
- package/dist/events/middleware/metrics.middleware.js +87 -0
- package/dist/events/middleware/metrics.middleware.js.map +1 -0
- package/dist/events/middleware/validation.middleware.d.ts +8 -0
- package/dist/events/middleware/validation.middleware.js +63 -0
- package/dist/events/middleware/validation.middleware.js.map +1 -0
- package/dist/events/store/memory-event-store.d.ts +21 -0
- package/dist/events/store/memory-event-store.js +81 -0
- package/dist/events/store/memory-event-store.js.map +1 -0
- package/dist/events/types/event.types.d.ts +57 -0
- package/dist/{decorators/cache/ICacheClient.js → events/types/event.types.js} +1 -1
- package/dist/events/types/event.types.js.map +1 -0
- package/dist/examples/basic-api.d.ts +1 -0
- package/dist/examples/basic-api.js +120 -0
- package/dist/examples/basic-api.js.map +1 -0
- package/dist/index.d.ts +17 -11
- package/dist/index.js +95 -31
- package/dist/index.js.map +1 -1
- package/dist/logging/config/logging.config.d.ts +5 -0
- package/dist/logging/config/logging.config.js +101 -0
- package/dist/logging/config/logging.config.js.map +1 -0
- package/dist/logging/core/log-context.service.d.ts +11 -0
- package/dist/logging/core/log-context.service.js +40 -0
- package/dist/logging/core/log-context.service.js.map +1 -0
- package/dist/logging/core/logger.service.d.ts +29 -0
- package/dist/logging/core/logger.service.js +178 -0
- package/dist/logging/core/logger.service.js.map +1 -0
- package/dist/logging/core/startup-logger.service.d.ts +17 -0
- package/dist/logging/core/startup-logger.service.js +156 -0
- package/dist/logging/core/startup-logger.service.js.map +1 -0
- package/dist/logging/decorators/log.decorator.d.ts +11 -0
- package/dist/logging/decorators/log.decorator.js +80 -0
- package/dist/logging/decorators/log.decorator.js.map +1 -0
- package/dist/logging/index.d.ts +15 -0
- package/dist/logging/index.js +46 -0
- package/dist/logging/index.js.map +1 -0
- package/dist/logging/middleware/context.middleware.d.ts +2 -0
- package/dist/logging/middleware/context.middleware.js +29 -0
- package/dist/logging/middleware/context.middleware.js.map +1 -0
- package/dist/logging/middleware/request-logging.middleware.d.ts +3 -0
- package/dist/logging/middleware/request-logging.middleware.js +78 -0
- package/dist/logging/middleware/request-logging.middleware.js.map +1 -0
- package/dist/logging/types/logging.types.d.ts +79 -0
- package/dist/{decorators/transaction/IDatabaseClient.js → logging/types/logging.types.js} +1 -1
- package/dist/logging/types/logging.types.js.map +1 -0
- package/dist/middlewares/auth.middleware.d.ts +2 -0
- package/dist/middlewares/auth.middleware.js +20 -0
- package/dist/middlewares/auth.middleware.js.map +1 -0
- package/dist/middlewares/cors.middleware.d.ts +2 -0
- package/dist/middlewares/cors.middleware.js +16 -0
- package/dist/middlewares/cors.middleware.js.map +1 -0
- package/dist/middlewares/swagger.middleware.d.ts +6 -0
- package/dist/middlewares/swagger.middleware.js +84 -0
- package/dist/middlewares/swagger.middleware.js.map +1 -0
- package/dist/repositories/user.repository.d.ts +16 -0
- package/dist/repositories/user.repository.js +110 -0
- package/dist/repositories/user.repository.js.map +1 -0
- package/dist/schemas/user.schemas.d.ts +214 -0
- package/dist/schemas/user.schemas.js +71 -0
- package/dist/schemas/user.schemas.js.map +1 -0
- package/dist/services/config-demo.service.d.ts +10 -0
- package/dist/services/config-demo.service.js +88 -0
- package/dist/services/config-demo.service.js.map +1 -0
- package/dist/services/user.service.d.ts +21 -0
- package/dist/services/user.service.js +201 -0
- package/dist/services/user.service.js.map +1 -0
- package/package.json +49 -14
- package/dist/application/Application.d.ts +0 -43
- package/dist/application/Application.d.ts.map +0 -1
- package/dist/application/Application.js +0 -283
- package/dist/application/Application.js.map +0 -1
- package/dist/container/container.d.ts +0 -9
- package/dist/container/container.d.ts.map +0 -1
- package/dist/container/container.js +0 -23
- package/dist/container/container.js.map +0 -1
- package/dist/decorators/cache/ICacheClient.d.ts +0 -6
- package/dist/decorators/cache/ICacheClient.d.ts.map +0 -1
- package/dist/decorators/cache/ICacheClient.js.map +0 -1
- package/dist/decorators/cache/cache.decorator.d.ts +0 -2
- package/dist/decorators/cache/cache.decorator.d.ts.map +0 -1
- package/dist/decorators/cache/cache.decorator.js +0 -38
- package/dist/decorators/cache/cache.decorator.js.map +0 -1
- package/dist/decorators/controller.decorator.d.ts +0 -9
- package/dist/decorators/controller.decorator.d.ts.map +0 -1
- package/dist/decorators/controller.decorator.js +0 -99
- package/dist/decorators/controller.decorator.js.map +0 -1
- package/dist/decorators/http.decorator.d.ts +0 -7
- package/dist/decorators/http.decorator.d.ts.map +0 -1
- package/dist/decorators/http.decorator.js +0 -26
- package/dist/decorators/http.decorator.js.map +0 -1
- package/dist/decorators/timing.decorator.d.ts +0 -2
- package/dist/decorators/timing.decorator.d.ts.map +0 -1
- package/dist/decorators/timing.decorator.js +0 -26
- package/dist/decorators/timing.decorator.js.map +0 -1
- package/dist/decorators/transaction/IDatabaseClient.d.ts +0 -9
- package/dist/decorators/transaction/IDatabaseClient.d.ts.map +0 -1
- package/dist/decorators/transaction/IDatabaseClient.js.map +0 -1
- package/dist/decorators/transaction/transactional.decorator.d.ts +0 -2
- package/dist/decorators/transaction/transactional.decorator.d.ts.map +0 -1
- package/dist/decorators/transaction/transactional.decorator.js +0 -27
- package/dist/decorators/transaction/transactional.decorator.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/logger/Logger.d.ts +0 -37
- package/dist/logger/Logger.d.ts.map +0 -1
- package/dist/logger/Logger.js +0 -142
- package/dist/logger/Logger.js.map +0 -1
- package/dist/middleware/http.d.ts +0 -2
- package/dist/middleware/http.d.ts.map +0 -1
- package/dist/middleware/http.js +0 -80
- package/dist/middleware/http.js.map +0 -1
- package/dist/middleware/requestcontext.d.ts +0 -12
- package/dist/middleware/requestcontext.d.ts.map +0 -1
- package/dist/middleware/requestcontext.js +0 -6
- package/dist/middleware/requestcontext.js.map +0 -1
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"log.decorator.js","sourceRoot":"","sources":["../../../src/logging/decorators/log.decorator.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
export { LoggerService } from './core/logger.service';
|
2
|
+
export { LogContextService } from './core/log-context.service';
|
3
|
+
export { StartupLoggerService } from './core/startup-logger.service';
|
4
|
+
export { LoggingConfigService } from './config/logging.config';
|
5
|
+
export { contextMiddleware } from './middleware/context.middleware';
|
6
|
+
export { createRequestLoggingMiddleware } from './middleware/request-logging.middleware';
|
7
|
+
export { Log, Logger } from './decorators/log.decorator';
|
8
|
+
export * from './types/logging.types';
|
9
|
+
import { LoggerService } from './core/logger.service';
|
10
|
+
import { StartupLoggerService } from './core/startup-logger.service';
|
11
|
+
export declare function configureLogging(): {
|
12
|
+
logger: LoggerService;
|
13
|
+
startupLogger: StartupLoggerService;
|
14
|
+
config: import("./types/logging.types").LoggingConfig;
|
15
|
+
};
|
@@ -0,0 +1,46 @@
|
|
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.Logger = exports.Log = exports.createRequestLoggingMiddleware = exports.contextMiddleware = exports.LoggingConfigService = exports.StartupLoggerService = exports.LogContextService = exports.LoggerService = void 0;
|
18
|
+
exports.configureLogging = configureLogging;
|
19
|
+
var logger_service_1 = require("./core/logger.service");
|
20
|
+
Object.defineProperty(exports, "LoggerService", { enumerable: true, get: function () { return logger_service_1.LoggerService; } });
|
21
|
+
var log_context_service_1 = require("./core/log-context.service");
|
22
|
+
Object.defineProperty(exports, "LogContextService", { enumerable: true, get: function () { return log_context_service_1.LogContextService; } });
|
23
|
+
var startup_logger_service_1 = require("./core/startup-logger.service");
|
24
|
+
Object.defineProperty(exports, "StartupLoggerService", { enumerable: true, get: function () { return startup_logger_service_1.StartupLoggerService; } });
|
25
|
+
var logging_config_1 = require("./config/logging.config");
|
26
|
+
Object.defineProperty(exports, "LoggingConfigService", { enumerable: true, get: function () { return logging_config_1.LoggingConfigService; } });
|
27
|
+
var context_middleware_1 = require("./middleware/context.middleware");
|
28
|
+
Object.defineProperty(exports, "contextMiddleware", { enumerable: true, get: function () { return context_middleware_1.contextMiddleware; } });
|
29
|
+
var request_logging_middleware_1 = require("./middleware/request-logging.middleware");
|
30
|
+
Object.defineProperty(exports, "createRequestLoggingMiddleware", { enumerable: true, get: function () { return request_logging_middleware_1.createRequestLoggingMiddleware; } });
|
31
|
+
var log_decorator_1 = require("./decorators/log.decorator");
|
32
|
+
Object.defineProperty(exports, "Log", { enumerable: true, get: function () { return log_decorator_1.Log; } });
|
33
|
+
Object.defineProperty(exports, "Logger", { enumerable: true, get: function () { return log_decorator_1.Logger; } });
|
34
|
+
__exportStar(require("./types/logging.types"), exports);
|
35
|
+
// Import the classes for use in configureLogging
|
36
|
+
const logging_config_2 = require("./config/logging.config");
|
37
|
+
const logger_service_2 = require("./core/logger.service");
|
38
|
+
const startup_logger_service_2 = require("./core/startup-logger.service");
|
39
|
+
// Auto-configure logging
|
40
|
+
function configureLogging() {
|
41
|
+
const config = logging_config_2.LoggingConfigService.createConfig();
|
42
|
+
const logger = logger_service_2.LoggerService.getInstance(config);
|
43
|
+
const startupLogger = startup_logger_service_2.StartupLoggerService.getInstance(logger);
|
44
|
+
return { logger, startupLogger, config };
|
45
|
+
}
|
46
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/logging/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAeA,4CAMC;AArBD,wDAAsD;AAA7C,+GAAA,aAAa,OAAA;AACtB,kEAA+D;AAAtD,wHAAA,iBAAiB,OAAA;AAC1B,wEAAqE;AAA5D,8HAAA,oBAAoB,OAAA;AAC7B,0DAA+D;AAAtD,sHAAA,oBAAoB,OAAA;AAC7B,sEAAoE;AAA3D,uHAAA,iBAAiB,OAAA;AAC1B,sFAAyF;AAAhF,4IAAA,8BAA8B,OAAA;AACvC,4DAAyD;AAAhD,oGAAA,GAAG,OAAA;AAAE,uGAAA,MAAM,OAAA;AACpB,wDAAsC;AAEtC,iDAAiD;AACjD,4DAA+D;AAC/D,0DAAsD;AACtD,0EAAqE;AAErE,yBAAyB;AACzB,SAAgB,gBAAgB;IAC9B,MAAM,MAAM,GAAG,qCAAoB,CAAC,YAAY,EAAE,CAAC;IACnD,MAAM,MAAM,GAAG,8BAAa,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IACjD,MAAM,aAAa,GAAG,6CAAoB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAE/D,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,CAAC;AAC3C,CAAC"}
|
@@ -0,0 +1,29 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.contextMiddleware = void 0;
|
4
|
+
const log_context_service_1 = require("../core/log-context.service");
|
5
|
+
const contextMiddleware = async (req, res, next) => {
|
6
|
+
const requestId = log_context_service_1.LogContextService.generateRequestId();
|
7
|
+
const traceId = log_context_service_1.LogContextService.generateTraceId();
|
8
|
+
// Set response header
|
9
|
+
res.setHeader('x-request-id', requestId);
|
10
|
+
// Extract user info if available (from auth middleware)
|
11
|
+
const user = req.user;
|
12
|
+
const context = {
|
13
|
+
requestId,
|
14
|
+
traceId,
|
15
|
+
spanId: log_context_service_1.LogContextService.generateSpanId(),
|
16
|
+
userId: user?.id,
|
17
|
+
username: user?.username,
|
18
|
+
userAgent: req.headers['user-agent'],
|
19
|
+
ip: req.headers['x-forwarded-for'] || req.socket.remoteAddress,
|
20
|
+
method: req.method,
|
21
|
+
url: req.url,
|
22
|
+
startTime: Date.now()
|
23
|
+
};
|
24
|
+
log_context_service_1.LogContextService.run(context, async () => {
|
25
|
+
await next();
|
26
|
+
});
|
27
|
+
};
|
28
|
+
exports.contextMiddleware = contextMiddleware;
|
29
|
+
//# sourceMappingURL=context.middleware.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"context.middleware.js","sourceRoot":"","sources":["../../../src/logging/middleware/context.middleware.ts"],"names":[],"mappings":";;;AACA,qEAAgE;AAGzD,MAAM,iBAAiB,GAAe,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACpE,MAAM,SAAS,GAAG,uCAAiB,CAAC,iBAAiB,EAAE,CAAC;IACxD,MAAM,OAAO,GAAG,uCAAiB,CAAC,eAAe,EAAE,CAAC;IAEpD,sBAAsB;IACtB,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC;IAEzC,wDAAwD;IACxD,MAAM,IAAI,GAAI,GAAW,CAAC,IAAI,CAAC;IAE/B,MAAM,OAAO,GAAe;QAC1B,SAAS;QACT,OAAO;QACP,MAAM,EAAE,uCAAiB,CAAC,cAAc,EAAE;QAC1C,MAAM,EAAE,IAAI,EAAE,EAAE;QAChB,QAAQ,EAAE,IAAI,EAAE,QAAQ;QACxB,SAAS,EAAE,GAAG,CAAC,OAAO,CAAC,YAAY,CAAC;QACpC,EAAE,EAAE,GAAG,CAAC,OAAO,CAAC,iBAAiB,CAAW,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa;QACxE,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,GAAG,EAAE,GAAG,CAAC,GAAG;QACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;KACtB,CAAC;IAEF,uCAAiB,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,IAAI,EAAE,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AA1BW,QAAA,iBAAiB,qBA0B5B"}
|
@@ -0,0 +1,78 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.createRequestLoggingMiddleware = void 0;
|
4
|
+
const logger_service_1 = require("../core/logger.service");
|
5
|
+
const log_context_service_1 = require("../core/log-context.service");
|
6
|
+
const createRequestLoggingMiddleware = (options = {}) => {
|
7
|
+
return async (req, res, next) => {
|
8
|
+
const logger = logger_service_1.LoggerService.getInstance();
|
9
|
+
const startTime = Date.now();
|
10
|
+
const context = log_context_service_1.LogContextService.getContext();
|
11
|
+
// Skip logging for certain paths
|
12
|
+
if (options.skipPaths?.some(path => req.url?.startsWith(path))) {
|
13
|
+
await next();
|
14
|
+
return;
|
15
|
+
}
|
16
|
+
const requestData = {
|
17
|
+
component: 'HTTP',
|
18
|
+
method: req.method,
|
19
|
+
url: req.url,
|
20
|
+
userAgent: req.headers['user-agent'],
|
21
|
+
ip: req.headers['x-forwarded-for'] || req.socket.remoteAddress
|
22
|
+
};
|
23
|
+
if (options.logHeaders && logger.getConfig().logHeaders) {
|
24
|
+
requestData.headers = req.headers;
|
25
|
+
}
|
26
|
+
if (options.logQuery && req.url?.includes('?')) {
|
27
|
+
try {
|
28
|
+
const url = new URL(req.url, `http://${req.headers.host}`);
|
29
|
+
requestData.query = Object.fromEntries(url.searchParams);
|
30
|
+
}
|
31
|
+
catch (error) {
|
32
|
+
// Ignore URL parsing errors
|
33
|
+
}
|
34
|
+
}
|
35
|
+
logger.debug('HTTP Request started', requestData);
|
36
|
+
// Override res.end to log response
|
37
|
+
const originalEnd = res.end;
|
38
|
+
res.end = function (chunk, encoding) {
|
39
|
+
const duration = Date.now() - startTime;
|
40
|
+
const responseData = {
|
41
|
+
component: 'HTTP',
|
42
|
+
statusCode: res.statusCode,
|
43
|
+
duration,
|
44
|
+
contentLength: res.getHeader('content-length')
|
45
|
+
};
|
46
|
+
// Log slow requests
|
47
|
+
if (options.slowThreshold && duration > options.slowThreshold) {
|
48
|
+
logger.warn('Slow HTTP Request', {
|
49
|
+
...requestData,
|
50
|
+
...responseData,
|
51
|
+
slow: true
|
52
|
+
});
|
53
|
+
}
|
54
|
+
else {
|
55
|
+
const level = res.statusCode >= 400 ? 'warn' : 'info';
|
56
|
+
logger[level]('HTTP Request completed', {
|
57
|
+
...requestData,
|
58
|
+
...responseData
|
59
|
+
});
|
60
|
+
}
|
61
|
+
// Log performance metrics
|
62
|
+
if (context && logger.getConfig().enablePerformanceLogs) {
|
63
|
+
logger.performance({
|
64
|
+
operation: `${req.method} ${req.url}`,
|
65
|
+
duration,
|
66
|
+
metadata: {
|
67
|
+
statusCode: res.statusCode,
|
68
|
+
contentLength: res.getHeader('content-length')
|
69
|
+
}
|
70
|
+
});
|
71
|
+
}
|
72
|
+
return originalEnd.call(this, chunk, encoding);
|
73
|
+
};
|
74
|
+
await next();
|
75
|
+
};
|
76
|
+
};
|
77
|
+
exports.createRequestLoggingMiddleware = createRequestLoggingMiddleware;
|
78
|
+
//# sourceMappingURL=request-logging.middleware.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"request-logging.middleware.js","sourceRoot":"","sources":["../../../src/logging/middleware/request-logging.middleware.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,79 @@
|
|
1
|
+
export interface LogContext {
|
2
|
+
requestId: string;
|
3
|
+
userId?: string;
|
4
|
+
username?: string;
|
5
|
+
traceId?: string;
|
6
|
+
spanId?: string;
|
7
|
+
correlationId?: string;
|
8
|
+
sessionId?: string;
|
9
|
+
userAgent?: string;
|
10
|
+
ip?: string;
|
11
|
+
method?: string;
|
12
|
+
url?: string;
|
13
|
+
startTime?: number;
|
14
|
+
additionalContext?: Record<string, any>;
|
15
|
+
}
|
16
|
+
export interface LogPayload {
|
17
|
+
message: string;
|
18
|
+
[key: string]: any;
|
19
|
+
}
|
20
|
+
export interface AuditLogPayload {
|
21
|
+
action: string;
|
22
|
+
resource: string;
|
23
|
+
resourceId?: string;
|
24
|
+
oldValues?: Record<string, any>;
|
25
|
+
newValues?: Record<string, any>;
|
26
|
+
metadata?: Record<string, any>;
|
27
|
+
}
|
28
|
+
export interface EventLogPayload {
|
29
|
+
eventName: string;
|
30
|
+
eventType: 'business' | 'system' | 'security' | 'performance';
|
31
|
+
status: 'success' | 'failure' | 'pending' | 'cancelled';
|
32
|
+
duration?: number;
|
33
|
+
metadata?: Record<string, any>;
|
34
|
+
}
|
35
|
+
export interface PerformanceLogPayload {
|
36
|
+
operation: string;
|
37
|
+
duration: number;
|
38
|
+
memoryUsage?: NodeJS.MemoryUsage;
|
39
|
+
metadata?: Record<string, any>;
|
40
|
+
}
|
41
|
+
export interface StartupLogPayload {
|
42
|
+
component: string;
|
43
|
+
phase: 'starting' | 'completed' | 'failed';
|
44
|
+
duration?: number;
|
45
|
+
details?: Record<string, any>;
|
46
|
+
}
|
47
|
+
export interface LoggingConfig {
|
48
|
+
level: 'trace' | 'debug' | 'info' | 'warn' | 'error' | 'fatal';
|
49
|
+
serviceName: string;
|
50
|
+
serviceVersion: string;
|
51
|
+
environment: string;
|
52
|
+
logHeaders: boolean;
|
53
|
+
logStackTrace: boolean;
|
54
|
+
enableStartupLogs: boolean;
|
55
|
+
enableComponentLogs: boolean;
|
56
|
+
enablePerformanceLogs: boolean;
|
57
|
+
transports?: any[];
|
58
|
+
rotation?: {
|
59
|
+
enabled: boolean;
|
60
|
+
maxFiles: number;
|
61
|
+
maxSize: string;
|
62
|
+
datePattern: string;
|
63
|
+
};
|
64
|
+
correlation?: {
|
65
|
+
enabled: boolean;
|
66
|
+
headerName: string;
|
67
|
+
};
|
68
|
+
performance?: {
|
69
|
+
enabled: boolean;
|
70
|
+
slowThreshold: number;
|
71
|
+
};
|
72
|
+
}
|
73
|
+
export interface RequestLoggingOptions {
|
74
|
+
logBody?: boolean;
|
75
|
+
logHeaders?: boolean;
|
76
|
+
logQuery?: boolean;
|
77
|
+
skipPaths?: string[];
|
78
|
+
slowThreshold?: number;
|
79
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"logging.types.js","sourceRoot":"","sources":["../../../src/logging/types/logging.types.ts"],"names":[],"mappings":""}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.authMiddleware = void 0;
|
4
|
+
const errors_1 = require("../core/errors");
|
5
|
+
const authMiddleware = async (req, res, next) => {
|
6
|
+
const authHeader = req.headers.authorization;
|
7
|
+
if (!authHeader || !authHeader.startsWith('Bearer ')) {
|
8
|
+
throw new errors_1.UnauthorizedError('Authorization header is required');
|
9
|
+
}
|
10
|
+
const token = authHeader.substring(7); // Remove 'Bearer ' prefix
|
11
|
+
// Simple token validation (in real app, verify JWT)
|
12
|
+
if (token !== 'valid-token') {
|
13
|
+
throw new errors_1.UnauthorizedError('Invalid token');
|
14
|
+
}
|
15
|
+
// Add user info to request (in real app, decode from JWT)
|
16
|
+
req.user = { id: '1', email: 'john@example.com' };
|
17
|
+
await next();
|
18
|
+
};
|
19
|
+
exports.authMiddleware = authMiddleware;
|
20
|
+
//# sourceMappingURL=auth.middleware.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"auth.middleware.js","sourceRoot":"","sources":["../../src/middlewares/auth.middleware.ts"],"names":[],"mappings":";;;AACA,2CAAmD;AAE5C,MAAM,cAAc,GAAe,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACjE,MAAM,UAAU,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;IAE7C,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QACrD,MAAM,IAAI,0BAAiB,CAAC,kCAAkC,CAAC,CAAC;IAClE,CAAC;IAED,MAAM,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,0BAA0B;IAEjE,oDAAoD;IACpD,IAAI,KAAK,KAAK,aAAa,EAAE,CAAC;QAC5B,MAAM,IAAI,0BAAiB,CAAC,eAAe,CAAC,CAAC;IAC/C,CAAC;IAED,0DAA0D;IACzD,GAAW,CAAC,IAAI,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAE3D,MAAM,IAAI,EAAE,CAAC;AACf,CAAC,CAAC;AAlBW,QAAA,cAAc,kBAkBzB"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.corsMiddleware = void 0;
|
4
|
+
const corsMiddleware = async (req, res, next) => {
|
5
|
+
res.setHeader('Access-Control-Allow-Origin', '*');
|
6
|
+
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
|
7
|
+
res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');
|
8
|
+
if (req.method === 'OPTIONS') {
|
9
|
+
res.writeHead(200);
|
10
|
+
res.end();
|
11
|
+
return;
|
12
|
+
}
|
13
|
+
await next();
|
14
|
+
};
|
15
|
+
exports.corsMiddleware = corsMiddleware;
|
16
|
+
//# sourceMappingURL=cors.middleware.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"cors.middleware.js","sourceRoot":"","sources":["../../src/middlewares/cors.middleware.ts"],"names":[],"mappings":";;;AAEO,MAAM,cAAc,GAAe,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;IACjE,GAAG,CAAC,SAAS,CAAC,6BAA6B,EAAE,GAAG,CAAC,CAAC;IAClD,GAAG,CAAC,SAAS,CAAC,8BAA8B,EAAE,iCAAiC,CAAC,CAAC;IACjF,GAAG,CAAC,SAAS,CAAC,8BAA8B,EAAE,6BAA6B,CAAC,CAAC;IAE7E,IAAI,GAAG,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QAC7B,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACnB,GAAG,CAAC,GAAG,EAAE,CAAC;QACV,OAAO;IACT,CAAC;IAED,MAAM,IAAI,EAAE,CAAC;AACf,CAAC,CAAC;AAZW,QAAA,cAAc,kBAYzB"}
|
@@ -0,0 +1,84 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.swaggerMiddleware = void 0;
|
4
|
+
const swaggerMiddleware = (spec, options = {}) => {
|
5
|
+
const swaggerPath = options.path || '/api-docs';
|
6
|
+
const title = options.title || 'API Documentation';
|
7
|
+
return async (req, res, next) => {
|
8
|
+
const url = req.url || '';
|
9
|
+
if (url === swaggerPath) {
|
10
|
+
// Serve Swagger UI HTML
|
11
|
+
const html = generateSwaggerHTML(swaggerPath, title);
|
12
|
+
res.writeHead(200, { 'Content-Type': 'text/html' });
|
13
|
+
res.end(html);
|
14
|
+
return;
|
15
|
+
}
|
16
|
+
if (url === `${swaggerPath}/swagger.json`) {
|
17
|
+
// Serve OpenAPI spec JSON
|
18
|
+
res.writeHead(200, { 'Content-Type': 'application/json' });
|
19
|
+
res.end(JSON.stringify(spec, null, 2));
|
20
|
+
return;
|
21
|
+
}
|
22
|
+
await next();
|
23
|
+
};
|
24
|
+
};
|
25
|
+
exports.swaggerMiddleware = swaggerMiddleware;
|
26
|
+
function generateSwaggerHTML(swaggerPath, title) {
|
27
|
+
return `
|
28
|
+
<!DOCTYPE html>
|
29
|
+
<html lang="en">
|
30
|
+
<head>
|
31
|
+
<meta charset="UTF-8">
|
32
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
33
|
+
<title>${title}</title>
|
34
|
+
<link rel="stylesheet" type="text/css" href="https://unpkg.com/swagger-ui-dist@4.15.5/swagger-ui.css" />
|
35
|
+
<style>
|
36
|
+
html {
|
37
|
+
box-sizing: border-box;
|
38
|
+
overflow: -moz-scrollbars-vertical;
|
39
|
+
overflow-y: scroll;
|
40
|
+
}
|
41
|
+
*, *:before, *:after {
|
42
|
+
box-sizing: inherit;
|
43
|
+
}
|
44
|
+
body {
|
45
|
+
margin:0;
|
46
|
+
background: #fafafa;
|
47
|
+
}
|
48
|
+
</style>
|
49
|
+
</head>
|
50
|
+
<body>
|
51
|
+
<div id="swagger-ui"></div>
|
52
|
+
<script src="https://unpkg.com/swagger-ui-dist@4.15.5/swagger-ui-bundle.js"></script>
|
53
|
+
<script src="https://unpkg.com/swagger-ui-dist@4.15.5/swagger-ui-standalone-preset.js"></script>
|
54
|
+
<script>
|
55
|
+
window.onload = function() {
|
56
|
+
const ui = SwaggerUIBundle({
|
57
|
+
url: '${swaggerPath}/swagger.json',
|
58
|
+
dom_id: '#swagger-ui',
|
59
|
+
deepLinking: true,
|
60
|
+
presets: [
|
61
|
+
SwaggerUIBundle.presets.apis,
|
62
|
+
SwaggerUIStandalonePreset
|
63
|
+
],
|
64
|
+
plugins: [
|
65
|
+
SwaggerUIBundle.plugins.DownloadUrl
|
66
|
+
],
|
67
|
+
layout: "StandaloneLayout",
|
68
|
+
validatorUrl: null,
|
69
|
+
tryItOutEnabled: true,
|
70
|
+
supportedSubmitMethods: ['get', 'post', 'put', 'delete', 'patch'],
|
71
|
+
onComplete: function() {
|
72
|
+
console.log('Swagger UI loaded successfully');
|
73
|
+
},
|
74
|
+
onFailure: function(data) {
|
75
|
+
console.error('Failed to load Swagger UI:', data);
|
76
|
+
}
|
77
|
+
});
|
78
|
+
};
|
79
|
+
</script>
|
80
|
+
</body>
|
81
|
+
</html>
|
82
|
+
`;
|
83
|
+
}
|
84
|
+
//# sourceMappingURL=swagger.middleware.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"swagger.middleware.js","sourceRoot":"","sources":["../../src/middlewares/swagger.middleware.ts"],"names":[],"mappings":";;;AAGO,MAAM,iBAAiB,GAAG,CAAC,IAAiB,EAAE,UAGjD,EAAE,EAAc,EAAE;IACpB,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,IAAI,WAAW,CAAC;IAChD,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,mBAAmB,CAAC;IAEnD,OAAO,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAC9B,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,IAAI,EAAE,CAAC;QAE1B,IAAI,GAAG,KAAK,WAAW,EAAE,CAAC;YACxB,wBAAwB;YACxB,MAAM,IAAI,GAAG,mBAAmB,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC;YACrD,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,WAAW,EAAE,CAAC,CAAC;YACpD,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACd,OAAO;QACT,CAAC;QAED,IAAI,GAAG,KAAK,GAAG,WAAW,eAAe,EAAE,CAAC;YAC1C,0BAA0B;YAC1B,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE,CAAC,CAAC;YAC3D,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YACvC,OAAO;QACT,CAAC;QAED,MAAM,IAAI,EAAE,CAAC;IACf,CAAC,CAAC;AACJ,CAAC,CAAC;AA3BW,QAAA,iBAAiB,qBA2B5B;AAEF,SAAS,mBAAmB,CAAC,WAAmB,EAAE,KAAa;IAC7D,OAAO;;;;;;WAME,KAAK;;;;;;;;;;;;;;;;;;;;;;;;gBAwBA,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;GAyBxB,CAAC;AACJ,CAAC"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
export interface User {
|
2
|
+
id: string;
|
3
|
+
email: string;
|
4
|
+
name: string;
|
5
|
+
createdAt: Date;
|
6
|
+
}
|
7
|
+
export declare class UserRepository {
|
8
|
+
private logger;
|
9
|
+
private users;
|
10
|
+
findAll(): User[];
|
11
|
+
findById(id: string): User | undefined;
|
12
|
+
findByEmail(email: string): User | undefined;
|
13
|
+
create(userData: Omit<User, 'id' | 'createdAt'>): User;
|
14
|
+
update(id: string, userData: Partial<Omit<User, 'id' | 'createdAt'>>): User | undefined;
|
15
|
+
delete(id: string): boolean;
|
16
|
+
}
|
@@ -0,0 +1,110 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
12
|
+
exports.UserRepository = void 0;
|
13
|
+
const decorators_1 = require("../core/decorators");
|
14
|
+
const logging_1 = require("../logging");
|
15
|
+
let UserRepository = class UserRepository {
|
16
|
+
constructor() {
|
17
|
+
this.users = [
|
18
|
+
{
|
19
|
+
id: '1',
|
20
|
+
email: 'john@example.com',
|
21
|
+
name: 'John Doe',
|
22
|
+
createdAt: new Date('2023-01-01')
|
23
|
+
},
|
24
|
+
{
|
25
|
+
id: '2',
|
26
|
+
email: 'jane@example.com',
|
27
|
+
name: 'Jane Smith',
|
28
|
+
createdAt: new Date('2023-01-02')
|
29
|
+
}
|
30
|
+
];
|
31
|
+
}
|
32
|
+
findAll() {
|
33
|
+
this.logger.debug('Fetching all users', { count: this.users.length });
|
34
|
+
return this.users;
|
35
|
+
}
|
36
|
+
findById(id) {
|
37
|
+
return this.users.find(user => user.id === id);
|
38
|
+
}
|
39
|
+
findByEmail(email) {
|
40
|
+
return this.users.find(user => user.email === email);
|
41
|
+
}
|
42
|
+
create(userData) {
|
43
|
+
const newUser = {
|
44
|
+
id: Date.now().toString(),
|
45
|
+
createdAt: new Date(),
|
46
|
+
...userData
|
47
|
+
};
|
48
|
+
this.users.push(newUser);
|
49
|
+
this.logger.debug('User created in repository', { userId: newUser.id });
|
50
|
+
return newUser;
|
51
|
+
}
|
52
|
+
update(id, userData) {
|
53
|
+
const userIndex = this.users.findIndex(user => user.id === id);
|
54
|
+
if (userIndex === -1)
|
55
|
+
return undefined;
|
56
|
+
this.users[userIndex] = { ...this.users[userIndex], ...userData };
|
57
|
+
this.logger.debug('User updated in repository', { userId: id });
|
58
|
+
return this.users[userIndex];
|
59
|
+
}
|
60
|
+
delete(id) {
|
61
|
+
const userIndex = this.users.findIndex(user => user.id === id);
|
62
|
+
if (userIndex === -1)
|
63
|
+
return false;
|
64
|
+
this.users.splice(userIndex, 1);
|
65
|
+
this.logger.debug('User deleted from repository', { userId: id });
|
66
|
+
return true;
|
67
|
+
}
|
68
|
+
};
|
69
|
+
exports.UserRepository = UserRepository;
|
70
|
+
__decorate([
|
71
|
+
(0, logging_1.Log)({ logDuration: true, level: 'debug' }),
|
72
|
+
__metadata("design:type", Function),
|
73
|
+
__metadata("design:paramtypes", []),
|
74
|
+
__metadata("design:returntype", Array)
|
75
|
+
], UserRepository.prototype, "findAll", null);
|
76
|
+
__decorate([
|
77
|
+
(0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
|
78
|
+
__metadata("design:type", Function),
|
79
|
+
__metadata("design:paramtypes", [String]),
|
80
|
+
__metadata("design:returntype", Object)
|
81
|
+
], UserRepository.prototype, "findById", null);
|
82
|
+
__decorate([
|
83
|
+
(0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
|
84
|
+
__metadata("design:type", Function),
|
85
|
+
__metadata("design:paramtypes", [String]),
|
86
|
+
__metadata("design:returntype", Object)
|
87
|
+
], UserRepository.prototype, "findByEmail", null);
|
88
|
+
__decorate([
|
89
|
+
(0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
|
90
|
+
__metadata("design:type", Function),
|
91
|
+
__metadata("design:paramtypes", [Object]),
|
92
|
+
__metadata("design:returntype", Object)
|
93
|
+
], UserRepository.prototype, "create", null);
|
94
|
+
__decorate([
|
95
|
+
(0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
|
96
|
+
__metadata("design:type", Function),
|
97
|
+
__metadata("design:paramtypes", [String, Object]),
|
98
|
+
__metadata("design:returntype", Object)
|
99
|
+
], UserRepository.prototype, "update", null);
|
100
|
+
__decorate([
|
101
|
+
(0, logging_1.Log)({ logArgs: true, logDuration: true, level: 'debug' }),
|
102
|
+
__metadata("design:type", Function),
|
103
|
+
__metadata("design:paramtypes", [String]),
|
104
|
+
__metadata("design:returntype", Boolean)
|
105
|
+
], UserRepository.prototype, "delete", null);
|
106
|
+
exports.UserRepository = UserRepository = __decorate([
|
107
|
+
(0, decorators_1.Repository)(),
|
108
|
+
(0, logging_1.Logger)('UserRepository')
|
109
|
+
], UserRepository);
|
110
|
+
//# sourceMappingURL=user.repository.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"user.repository.js","sourceRoot":"","sources":["../../src/repositories/user.repository.ts"],"names":[],"mappings":"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"}
|