bootifyjs 0.1.0 → 1.0.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/dist/api.d.ts +8 -27
- package/dist/api.d.ts.map +1 -0
- package/dist/api.js +68 -134
- package/dist/api.js.map +1 -1
- package/dist/cache/bootstrap.d.ts +6 -0
- package/dist/cache/bootstrap.d.ts.map +1 -0
- package/dist/cache/bootstrap.js +23 -0
- package/dist/cache/bootstrap.js.map +1 -0
- package/dist/cache/cache.service.d.ts +9 -0
- package/dist/cache/cache.service.d.ts.map +1 -0
- package/dist/cache/cache.service.js +40 -0
- package/dist/cache/cache.service.js.map +1 -0
- package/dist/cache/cache.types.d.ts +14 -0
- package/dist/cache/cache.types.d.ts.map +1 -0
- package/dist/cache/cache.types.js +8 -0
- package/dist/cache/cache.types.js.map +1 -0
- package/dist/cache/decorators.d.ts +12 -0
- package/dist/cache/decorators.d.ts.map +1 -0
- package/dist/cache/decorators.js +53 -0
- package/dist/cache/decorators.js.map +1 -0
- package/dist/cache/in-memory-cache.store.d.ts +8 -0
- package/dist/cache/in-memory-cache.store.d.ts.map +1 -0
- package/dist/cache/in-memory-cache.store.js +39 -0
- package/dist/cache/in-memory-cache.store.js.map +1 -0
- package/dist/cache/index.d.ts +5 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +21 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/core/component-registry.d.ts +7 -0
- package/dist/core/component-registry.d.ts.map +1 -0
- package/dist/core/component-registry.js +9 -0
- package/dist/core/component-registry.js.map +1 -0
- package/dist/core/decorators.d.ts +38 -22
- package/dist/core/decorators.d.ts.map +1 -0
- package/dist/core/decorators.js +155 -174
- package/dist/core/decorators.js.map +1 -1
- package/dist/core/di-container.d.ts +31 -0
- package/dist/core/di-container.d.ts.map +1 -0
- package/dist/core/di-container.js +219 -0
- package/dist/core/di-container.js.map +1 -0
- package/dist/core/index.d.ts +5 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +21 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/request-context.service.d.ts +24 -0
- package/dist/core/request-context.service.d.ts.map +1 -0
- package/dist/core/request-context.service.js +52 -0
- package/dist/core/request-context.service.js.map +1 -0
- package/dist/core/router.d.ts +4 -32
- package/dist/core/router.d.ts.map +1 -0
- package/dist/core/router.js +81 -258
- package/dist/core/router.js.map +1 -1
- package/dist/events/bootstrap.d.ts +8 -0
- package/dist/events/bootstrap.d.ts.map +1 -0
- package/dist/events/bootstrap.js +37 -0
- package/dist/events/bootstrap.js.map +1 -0
- package/dist/events/decorators.d.ts +16 -0
- package/dist/events/decorators.d.ts.map +1 -0
- package/dist/events/decorators.js +37 -0
- package/dist/events/decorators.js.map +1 -0
- package/dist/events/event-bus.service.d.ts +21 -0
- package/dist/events/event-bus.service.d.ts.map +1 -0
- package/dist/events/event-bus.service.js +78 -0
- package/dist/events/event-bus.service.js.map +1 -0
- package/dist/events/event.types.d.ts +17 -0
- package/dist/events/event.types.d.ts.map +1 -0
- package/dist/events/event.types.js.map +1 -0
- package/dist/events/index.d.ts +5 -13
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +4 -54
- package/dist/events/index.js.map +1 -1
- package/dist/examples/controllers/health.controller.d.ts +7 -0
- package/dist/examples/controllers/health.controller.d.ts.map +1 -0
- package/dist/{events/examples/system.events.js → examples/controllers/health.controller.js} +16 -15
- package/dist/examples/controllers/health.controller.js.map +1 -0
- package/dist/examples/controllers/todo.controller.d.ts +31 -0
- package/dist/examples/controllers/todo.controller.d.ts.map +1 -0
- package/dist/examples/controllers/todo.controller.js +102 -0
- package/dist/examples/controllers/todo.controller.js.map +1 -0
- package/dist/examples/events/TodoEventHandler.d.ts +2 -0
- package/dist/examples/events/TodoEventHandler.d.ts.map +1 -0
- package/dist/examples/events/TodoEventHandler.js +31 -0
- package/dist/examples/events/TodoEventHandler.js.map +1 -0
- package/dist/examples/events/todo.events.d.ts +16 -0
- package/dist/examples/events/todo.events.d.ts.map +1 -0
- package/dist/examples/events/todo.events.js +13 -0
- package/dist/examples/events/todo.events.js.map +1 -0
- package/dist/examples/index.d.ts +2 -0
- package/dist/examples/index.d.ts.map +1 -0
- package/dist/examples/index.js +35 -0
- package/dist/examples/index.js.map +1 -0
- package/dist/examples/repositories/todo.repository.d.ts +20 -0
- package/dist/examples/repositories/todo.repository.d.ts.map +1 -0
- package/dist/examples/repositories/todo.repository.js +33 -0
- package/dist/examples/repositories/todo.repository.js.map +1 -0
- package/dist/examples/services/todo.service.d.ts +33 -0
- package/dist/examples/services/todo.service.d.ts.map +1 -0
- package/dist/examples/services/todo.service.js +80 -0
- package/dist/examples/services/todo.service.js.map +1 -0
- package/dist/examples/todos/schema.d.ts +54 -0
- package/dist/examples/todos/schema.d.ts.map +1 -0
- package/dist/examples/todos/schema.js +20 -0
- package/dist/examples/todos/schema.js.map +1 -0
- package/dist/index.d.ts +7 -17
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -95
- package/dist/index.js.map +1 -1
- package/dist/logging/config/logging.config.d.ts +31 -3
- package/dist/logging/config/logging.config.d.ts.map +1 -0
- package/dist/logging/config/logging.config.js +43 -93
- package/dist/logging/config/logging.config.js.map +1 -1
- package/dist/logging/core/decorators.d.ts +16 -0
- package/dist/logging/core/decorators.d.ts.map +1 -0
- package/dist/logging/core/decorators.js +74 -0
- package/dist/logging/core/decorators.js.map +1 -0
- package/dist/logging/core/logger.provider.d.ts +4 -0
- package/dist/logging/core/logger.provider.d.ts.map +1 -0
- package/dist/logging/core/logger.provider.js +68 -0
- package/dist/logging/core/logger.provider.js.map +1 -0
- package/dist/logging/core/logger.service.d.ts +9 -27
- package/dist/logging/core/logger.service.d.ts.map +1 -0
- package/dist/logging/core/logger.service.js +34 -164
- package/dist/logging/core/logger.service.js.map +1 -1
- package/dist/logging/core/{startup-logger.service.d.ts → startup.logger.d.ts} +4 -6
- package/dist/logging/core/startup.logger.d.ts.map +1 -0
- package/dist/logging/core/{startup-logger.service.js → startup.logger.js} +36 -42
- package/dist/logging/core/startup.logger.js.map +1 -0
- package/dist/logging/index.d.ts +7 -14
- package/dist/logging/index.d.ts.map +1 -0
- package/dist/logging/index.js +17 -28
- package/dist/logging/index.js.map +1 -1
- package/dist/middleware/auth.middleware.d.ts +3 -0
- package/dist/middleware/auth.middleware.d.ts.map +1 -0
- package/dist/middleware/auth.middleware.js +18 -0
- package/dist/middleware/auth.middleware.js.map +1 -0
- package/dist/middleware/context.middleware.d.ts +7 -0
- package/dist/middleware/context.middleware.d.ts.map +1 -0
- package/dist/middleware/context.middleware.js +25 -0
- package/dist/middleware/context.middleware.js.map +1 -0
- package/dist/middleware/index.d.ts +4 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +20 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/request-logger.middleware.d.ts +4 -0
- package/dist/middleware/request-logger.middleware.d.ts.map +1 -0
- package/dist/middleware/request-logger.middleware.js +18 -0
- package/dist/middleware/request-logger.middleware.js.map +1 -0
- package/package.json +52 -47
- package/LICENSE +0 -21
- package/README.md +0 -173
- package/dist/config/app.config.d.ts +0 -29
- package/dist/config/app.config.js +0 -55
- package/dist/config/app.config.js.map +0 -1
- package/dist/controllers/config.controller.d.ts +0 -16
- package/dist/controllers/config.controller.js +0 -66
- package/dist/controllers/config.controller.js.map +0 -1
- package/dist/controllers/events.controller.d.ts +0 -66
- package/dist/controllers/events.controller.js +0 -145
- package/dist/controllers/events.controller.js.map +0 -1
- package/dist/controllers/health.controller.d.ts +0 -20
- package/dist/controllers/health.controller.js +0 -92
- package/dist/controllers/health.controller.js.map +0 -1
- package/dist/controllers/user.controller.d.ts +0 -13
- package/dist/controllers/user.controller.js +0 -209
- package/dist/controllers/user.controller.js.map +0 -1
- package/dist/core/application.d.ts +0 -21
- package/dist/core/application.js +0 -90
- package/dist/core/application.js.map +0 -1
- package/dist/core/config.d.ts +0 -3
- package/dist/core/config.js +0 -78
- package/dist/core/config.js.map +0 -1
- package/dist/core/container.d.ts +0 -17
- package/dist/core/container.js +0 -92
- package/dist/core/container.js.map +0 -1
- package/dist/core/errors.d.ts +0 -18
- package/dist/core/errors.js +0 -74
- package/dist/core/errors.js.map +0 -1
- package/dist/core/middleware.d.ts +0 -8
- package/dist/core/middleware.js +0 -23
- package/dist/core/middleware.js.map +0 -1
- package/dist/core/openapi.d.ts +0 -80
- package/dist/core/openapi.js +0 -189
- package/dist/core/openapi.js.map +0 -1
- package/dist/core/utils.d.ts +0 -7
- package/dist/core/utils.js +0 -75
- package/dist/core/utils.js.map +0 -1
- package/dist/core/validation.d.ts +0 -15
- package/dist/core/validation.js +0 -161
- package/dist/core/validation.js.map +0 -1
- package/dist/events/core/event-bus.d.ts +0 -26
- package/dist/events/core/event-bus.js +0 -253
- package/dist/events/core/event-bus.js.map +0 -1
- package/dist/events/core/event-registry.d.ts +0 -31
- package/dist/events/core/event-registry.js +0 -170
- package/dist/events/core/event-registry.js.map +0 -1
- package/dist/events/decorators/event.decorators.d.ts +0 -11
- package/dist/events/decorators/event.decorators.js +0 -123
- package/dist/events/decorators/event.decorators.js.map +0 -1
- package/dist/events/examples/system.events.d.ts +0 -15
- package/dist/events/examples/system.events.js.map +0 -1
- package/dist/events/examples/user.events.d.ts +0 -68
- package/dist/events/examples/user.events.js +0 -73
- package/dist/events/examples/user.events.js.map +0 -1
- package/dist/events/examples/user.handlers.d.ts +0 -20
- package/dist/events/examples/user.handlers.js +0 -157
- package/dist/events/examples/user.handlers.js.map +0 -1
- package/dist/events/middleware/logging.middleware.d.ts +0 -7
- package/dist/events/middleware/logging.middleware.js +0 -44
- package/dist/events/middleware/logging.middleware.js.map +0 -1
- package/dist/events/middleware/metrics.middleware.d.ts +0 -11
- package/dist/events/middleware/metrics.middleware.js +0 -87
- package/dist/events/middleware/metrics.middleware.js.map +0 -1
- package/dist/events/middleware/validation.middleware.d.ts +0 -8
- package/dist/events/middleware/validation.middleware.js +0 -63
- package/dist/events/middleware/validation.middleware.js.map +0 -1
- package/dist/events/store/memory-event-store.d.ts +0 -21
- package/dist/events/store/memory-event-store.js +0 -81
- package/dist/events/store/memory-event-store.js.map +0 -1
- package/dist/events/types/event.types.d.ts +0 -57
- package/dist/events/types/event.types.js.map +0 -1
- package/dist/examples/basic-api.d.ts +0 -1
- package/dist/examples/basic-api.js +0 -120
- package/dist/examples/basic-api.js.map +0 -1
- package/dist/logging/core/log-context.service.d.ts +0 -11
- package/dist/logging/core/log-context.service.js +0 -40
- package/dist/logging/core/log-context.service.js.map +0 -1
- package/dist/logging/core/startup-logger.service.js.map +0 -1
- package/dist/logging/decorators/log.decorator.d.ts +0 -11
- package/dist/logging/decorators/log.decorator.js +0 -80
- package/dist/logging/decorators/log.decorator.js.map +0 -1
- package/dist/logging/middleware/context.middleware.d.ts +0 -2
- package/dist/logging/middleware/context.middleware.js +0 -29
- package/dist/logging/middleware/context.middleware.js.map +0 -1
- package/dist/logging/middleware/request-logging.middleware.d.ts +0 -3
- package/dist/logging/middleware/request-logging.middleware.js +0 -78
- package/dist/logging/middleware/request-logging.middleware.js.map +0 -1
- package/dist/logging/types/logging.types.d.ts +0 -79
- package/dist/logging/types/logging.types.js +0 -3
- package/dist/logging/types/logging.types.js.map +0 -1
- package/dist/middlewares/auth.middleware.d.ts +0 -2
- package/dist/middlewares/auth.middleware.js +0 -20
- package/dist/middlewares/auth.middleware.js.map +0 -1
- package/dist/middlewares/cors.middleware.d.ts +0 -2
- package/dist/middlewares/cors.middleware.js +0 -16
- package/dist/middlewares/cors.middleware.js.map +0 -1
- package/dist/middlewares/swagger.middleware.d.ts +0 -6
- package/dist/middlewares/swagger.middleware.js +0 -84
- package/dist/middlewares/swagger.middleware.js.map +0 -1
- package/dist/repositories/user.repository.d.ts +0 -16
- package/dist/repositories/user.repository.js +0 -110
- package/dist/repositories/user.repository.js.map +0 -1
- package/dist/schemas/user.schemas.d.ts +0 -214
- package/dist/schemas/user.schemas.js +0 -71
- package/dist/schemas/user.schemas.js.map +0 -1
- package/dist/services/config-demo.service.d.ts +0 -10
- package/dist/services/config-demo.service.js +0 -88
- package/dist/services/config-demo.service.js.map +0 -1
- package/dist/services/user.service.d.ts +0 -21
- package/dist/services/user.service.js +0 -201
- package/dist/services/user.service.js.map +0 -1
- /package/dist/events/{types/event.types.js → event.types.js} +0 -0
@@ -1,81 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.MemoryEventStore = void 0;
|
4
|
-
const logging_1 = require("../../logging");
|
5
|
-
class MemoryEventStore {
|
6
|
-
constructor() {
|
7
|
-
this.events = [];
|
8
|
-
this.eventsByAggregate = new Map();
|
9
|
-
this.logger = logging_1.LoggerService.getInstance();
|
10
|
-
}
|
11
|
-
async save(event) {
|
12
|
-
// Store in main events array
|
13
|
-
this.events.push(event);
|
14
|
-
// Store by aggregate if it's a domain event
|
15
|
-
if ('aggregateId' in event) {
|
16
|
-
const aggregateId = event.aggregateId;
|
17
|
-
if (!this.eventsByAggregate.has(aggregateId)) {
|
18
|
-
this.eventsByAggregate.set(aggregateId, []);
|
19
|
-
}
|
20
|
-
this.eventsByAggregate.get(aggregateId).push(event);
|
21
|
-
}
|
22
|
-
this.logger.debug('Event saved to store', {
|
23
|
-
component: 'EventStore',
|
24
|
-
eventType: event.type,
|
25
|
-
eventId: event.id,
|
26
|
-
totalEvents: this.events.length
|
27
|
-
});
|
28
|
-
}
|
29
|
-
async getEvents(aggregateId, fromVersion) {
|
30
|
-
const aggregateEvents = this.eventsByAggregate.get(aggregateId) || [];
|
31
|
-
if (fromVersion !== undefined) {
|
32
|
-
return aggregateEvents.filter(event => 'aggregateVersion' in event && event.aggregateVersion >= fromVersion);
|
33
|
-
}
|
34
|
-
return [...aggregateEvents];
|
35
|
-
}
|
36
|
-
async getAllEvents(eventType, fromTimestamp) {
|
37
|
-
let filteredEvents = [...this.events];
|
38
|
-
if (eventType) {
|
39
|
-
filteredEvents = filteredEvents.filter(event => event.type === eventType);
|
40
|
-
}
|
41
|
-
if (fromTimestamp) {
|
42
|
-
filteredEvents = filteredEvents.filter(event => event.timestamp >= fromTimestamp);
|
43
|
-
}
|
44
|
-
return filteredEvents.sort((a, b) => a.timestamp.getTime() - b.timestamp.getTime());
|
45
|
-
}
|
46
|
-
// Additional utility methods
|
47
|
-
async getEventCount() {
|
48
|
-
return this.events.length;
|
49
|
-
}
|
50
|
-
async getEventTypes() {
|
51
|
-
const types = new Set(this.events.map(event => event.type));
|
52
|
-
return Array.from(types);
|
53
|
-
}
|
54
|
-
async getEventsByTimeRange(startTime, endTime) {
|
55
|
-
return this.events.filter(event => event.timestamp >= startTime && event.timestamp <= endTime);
|
56
|
-
}
|
57
|
-
async clear() {
|
58
|
-
this.events = [];
|
59
|
-
this.eventsByAggregate.clear();
|
60
|
-
this.logger.info('Event store cleared', {
|
61
|
-
component: 'EventStore'
|
62
|
-
});
|
63
|
-
}
|
64
|
-
// Get statistics
|
65
|
-
getStatistics() {
|
66
|
-
const eventsByType = {};
|
67
|
-
this.events.forEach(event => {
|
68
|
-
eventsByType[event.type] = (eventsByType[event.type] || 0) + 1;
|
69
|
-
});
|
70
|
-
const timestamps = this.events.map(e => e.timestamp).sort((a, b) => a.getTime() - b.getTime());
|
71
|
-
return {
|
72
|
-
totalEvents: this.events.length,
|
73
|
-
eventsByType,
|
74
|
-
aggregateCount: this.eventsByAggregate.size,
|
75
|
-
oldestEvent: timestamps[0],
|
76
|
-
newestEvent: timestamps[timestamps.length - 1]
|
77
|
-
};
|
78
|
-
}
|
79
|
-
}
|
80
|
-
exports.MemoryEventStore = MemoryEventStore;
|
81
|
-
//# sourceMappingURL=memory-event-store.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"memory-event-store.js","sourceRoot":"","sources":["../../../src/events/store/memory-event-store.ts"],"names":[],"mappings":"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"}
|
@@ -1,57 +0,0 @@
|
|
1
|
-
export interface BaseEvent {
|
2
|
-
id: string;
|
3
|
-
type: string;
|
4
|
-
timestamp: Date;
|
5
|
-
version: number;
|
6
|
-
correlationId?: string;
|
7
|
-
causationId?: string;
|
8
|
-
metadata?: Record<string, any>;
|
9
|
-
}
|
10
|
-
export interface DomainEvent extends BaseEvent {
|
11
|
-
aggregateId: string;
|
12
|
-
aggregateType: string;
|
13
|
-
aggregateVersion: number;
|
14
|
-
}
|
15
|
-
export interface SystemEvent extends BaseEvent {
|
16
|
-
source: string;
|
17
|
-
severity: 'low' | 'medium' | 'high' | 'critical';
|
18
|
-
}
|
19
|
-
export interface DeadLetterEvent extends BaseEvent {
|
20
|
-
failedEventData: string;
|
21
|
-
error: string;
|
22
|
-
subscriptionId: string;
|
23
|
-
}
|
24
|
-
export interface EventHandler<T extends BaseEvent = BaseEvent> {
|
25
|
-
handle(event: T): Promise<void> | void;
|
26
|
-
}
|
27
|
-
export interface EventSubscription {
|
28
|
-
id: string;
|
29
|
-
eventType: string;
|
30
|
-
handler: EventHandler;
|
31
|
-
priority: number;
|
32
|
-
active: boolean;
|
33
|
-
metadata?: Record<string, any>;
|
34
|
-
}
|
35
|
-
export interface EventBusOptions {
|
36
|
-
enableLogging?: boolean;
|
37
|
-
enableMetrics?: boolean;
|
38
|
-
maxRetries?: number;
|
39
|
-
retryDelay?: number;
|
40
|
-
enableDeadLetterQueue?: boolean;
|
41
|
-
}
|
42
|
-
export interface EventMiddleware {
|
43
|
-
name: string;
|
44
|
-
execute(event: BaseEvent, next: () => Promise<void>): Promise<void>;
|
45
|
-
}
|
46
|
-
export interface EventStore {
|
47
|
-
save(event: BaseEvent): Promise<void>;
|
48
|
-
getEvents(aggregateId: string, fromVersion?: number): Promise<BaseEvent[]>;
|
49
|
-
getAllEvents(eventType?: string, fromTimestamp?: Date): Promise<BaseEvent[]>;
|
50
|
-
}
|
51
|
-
export interface EventMetrics {
|
52
|
-
totalEvents: number;
|
53
|
-
eventsByType: Record<string, number>;
|
54
|
-
failedEvents: number;
|
55
|
-
averageProcessingTime: number;
|
56
|
-
lastEventTimestamp?: Date;
|
57
|
-
}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"event.types.js","sourceRoot":"","sources":["../../../src/events/types/event.types.ts"],"names":[],"mappings":""}
|
@@ -1 +0,0 @@
|
|
1
|
-
export {};
|
@@ -1,120 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
7
|
-
};
|
8
|
-
var __metadata = (this && this.__metadata) || function (k, v) {
|
9
|
-
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
10
|
-
};
|
11
|
-
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
12
|
-
return function (target, key) { decorator(target, key, paramIndex); }
|
13
|
-
};
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
15
|
-
const api_1 = require("../api");
|
16
|
-
const decorators_1 = require("../core/decorators");
|
17
|
-
const logging_1 = require("../logging");
|
18
|
-
// Define a simple repository
|
19
|
-
let TodoRepository = class TodoRepository {
|
20
|
-
constructor() {
|
21
|
-
this.todos = [];
|
22
|
-
}
|
23
|
-
findAll() {
|
24
|
-
return this.todos;
|
25
|
-
}
|
26
|
-
findById(id) {
|
27
|
-
return this.todos.find(todo => todo.id === id);
|
28
|
-
}
|
29
|
-
create(text) {
|
30
|
-
const todo = {
|
31
|
-
id: Date.now().toString(),
|
32
|
-
text,
|
33
|
-
completed: false
|
34
|
-
};
|
35
|
-
this.todos.push(todo);
|
36
|
-
return todo;
|
37
|
-
}
|
38
|
-
update(id, updates) {
|
39
|
-
const todo = this.findById(id);
|
40
|
-
if (!todo)
|
41
|
-
return null;
|
42
|
-
Object.assign(todo, updates);
|
43
|
-
return todo;
|
44
|
-
}
|
45
|
-
delete(id) {
|
46
|
-
const index = this.todos.findIndex(todo => todo.id === id);
|
47
|
-
if (index === -1)
|
48
|
-
return false;
|
49
|
-
this.todos.splice(index, 1);
|
50
|
-
return true;
|
51
|
-
}
|
52
|
-
};
|
53
|
-
TodoRepository = __decorate([
|
54
|
-
(0, decorators_1.Repository)(),
|
55
|
-
(0, logging_1.Logger)('TodoRepository')
|
56
|
-
], TodoRepository);
|
57
|
-
// Define a service
|
58
|
-
let TodoService = class TodoService {
|
59
|
-
constructor(repository) {
|
60
|
-
this.repository = repository;
|
61
|
-
}
|
62
|
-
getAllTodos() {
|
63
|
-
this.logger.info('Getting all todos');
|
64
|
-
return this.repository.findAll();
|
65
|
-
}
|
66
|
-
createTodo(text) {
|
67
|
-
this.logger.info('Creating new todo', { text });
|
68
|
-
return this.repository.create(text);
|
69
|
-
}
|
70
|
-
};
|
71
|
-
TodoService = __decorate([
|
72
|
-
(0, decorators_1.Service)(),
|
73
|
-
(0, logging_1.Logger)('TodoService'),
|
74
|
-
__metadata("design:paramtypes", [TodoRepository])
|
75
|
-
], TodoService);
|
76
|
-
// Define a controller
|
77
|
-
let TodoController = class TodoController {
|
78
|
-
constructor(todoService) {
|
79
|
-
this.todoService = todoService;
|
80
|
-
}
|
81
|
-
getAllTodos() {
|
82
|
-
return this.todoService.getAllTodos();
|
83
|
-
}
|
84
|
-
createTodo(body) {
|
85
|
-
return this.todoService.createTodo(body.text);
|
86
|
-
}
|
87
|
-
};
|
88
|
-
__decorate([
|
89
|
-
(0, decorators_1.Get)('/'),
|
90
|
-
__metadata("design:type", Function),
|
91
|
-
__metadata("design:paramtypes", []),
|
92
|
-
__metadata("design:returntype", void 0)
|
93
|
-
], TodoController.prototype, "getAllTodos", null);
|
94
|
-
__decorate([
|
95
|
-
(0, decorators_1.Post)('/'),
|
96
|
-
__param(0, (0, decorators_1.Body)()),
|
97
|
-
__metadata("design:type", Function),
|
98
|
-
__metadata("design:paramtypes", [Object]),
|
99
|
-
__metadata("design:returntype", void 0)
|
100
|
-
], TodoController.prototype, "createTodo", null);
|
101
|
-
TodoController = __decorate([
|
102
|
-
(0, decorators_1.Controller)('/todos'),
|
103
|
-
__metadata("design:paramtypes", [TodoService])
|
104
|
-
], TodoController);
|
105
|
-
// Start the application
|
106
|
-
async function main() {
|
107
|
-
const { start } = await (0, api_1.createBootifyApp)({
|
108
|
-
port: 3000,
|
109
|
-
controllers: [TodoController],
|
110
|
-
enableSwagger: true
|
111
|
-
});
|
112
|
-
await start();
|
113
|
-
console.log('Todo API is running on http://localhost:3000');
|
114
|
-
console.log('API docs available at http://localhost:3000/api-docs');
|
115
|
-
}
|
116
|
-
// Run if this file is executed directly
|
117
|
-
if (require.main === module) {
|
118
|
-
main().catch(console.error);
|
119
|
-
}
|
120
|
-
//# sourceMappingURL=basic-api.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"basic-api.js","sourceRoot":"","sources":["../../src/examples/basic-api.ts"],"names":[],"mappings":"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"}
|
@@ -1,11 +0,0 @@
|
|
1
|
-
import { LogContext } from '../types/logging.types';
|
2
|
-
export declare class LogContextService {
|
3
|
-
private static readonly asyncLocalStorage;
|
4
|
-
static generateRequestId(): string;
|
5
|
-
static generateTraceId(): string;
|
6
|
-
static generateSpanId(): string;
|
7
|
-
static run<T>(context: LogContext, callback: () => T): T;
|
8
|
-
static getContext(): LogContext | undefined;
|
9
|
-
static updateContext(updates: Partial<LogContext>): void;
|
10
|
-
static addToAdditionalContext(key: string, value: any): void;
|
11
|
-
}
|
@@ -1,40 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.LogContextService = void 0;
|
4
|
-
const async_hooks_1 = require("async_hooks");
|
5
|
-
const crypto_1 = require("crypto");
|
6
|
-
class LogContextService {
|
7
|
-
static generateRequestId() {
|
8
|
-
return (0, crypto_1.randomBytes)(16).toString('hex');
|
9
|
-
}
|
10
|
-
static generateTraceId() {
|
11
|
-
return (0, crypto_1.randomBytes)(16).toString('hex');
|
12
|
-
}
|
13
|
-
static generateSpanId() {
|
14
|
-
return (0, crypto_1.randomBytes)(8).toString('hex');
|
15
|
-
}
|
16
|
-
static run(context, callback) {
|
17
|
-
return this.asyncLocalStorage.run(context, callback);
|
18
|
-
}
|
19
|
-
static getContext() {
|
20
|
-
return this.asyncLocalStorage.getStore();
|
21
|
-
}
|
22
|
-
static updateContext(updates) {
|
23
|
-
const current = this.getContext();
|
24
|
-
if (current) {
|
25
|
-
Object.assign(current, updates);
|
26
|
-
}
|
27
|
-
}
|
28
|
-
static addToAdditionalContext(key, value) {
|
29
|
-
const current = this.getContext();
|
30
|
-
if (current) {
|
31
|
-
if (!current.additionalContext) {
|
32
|
-
current.additionalContext = {};
|
33
|
-
}
|
34
|
-
current.additionalContext[key] = value;
|
35
|
-
}
|
36
|
-
}
|
37
|
-
}
|
38
|
-
exports.LogContextService = LogContextService;
|
39
|
-
LogContextService.asyncLocalStorage = new async_hooks_1.AsyncLocalStorage();
|
40
|
-
//# sourceMappingURL=log-context.service.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"log-context.service.js","sourceRoot":"","sources":["../../../src/logging/core/log-context.service.ts"],"names":[],"mappings":";;;AAAA,6CAAgD;AAChD,mCAAqC;AAGrC,MAAa,iBAAiB;IAG5B,MAAM,CAAC,iBAAiB;QACtB,OAAO,IAAA,oBAAW,EAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,MAAM,CAAC,eAAe;QACpB,OAAO,IAAA,oBAAW,EAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,MAAM,CAAC,cAAc;QACnB,OAAO,IAAA,oBAAW,EAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,CAAC,GAAG,CAAI,OAAmB,EAAE,QAAiB;QAClD,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;IACvD,CAAC;IAED,MAAM,CAAC,UAAU;QACf,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,CAAC;IAC3C,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,OAA4B;QAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,MAAM,CAAC,sBAAsB,CAAC,GAAW,EAAE,KAAU;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;gBAC/B,OAAO,CAAC,iBAAiB,GAAG,EAAE,CAAC;YACjC,CAAC;YACD,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACzC,CAAC;IACH,CAAC;;AAtCH,8CAuCC;AAtCyB,mCAAiB,GAAG,IAAI,+BAAiB,EAAc,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"startup-logger.service.js","sourceRoot":"","sources":["../../../src/logging/core/startup-logger.service.ts"],"names":[],"mappings":"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"}
|
@@ -1,11 +0,0 @@
|
|
1
|
-
export interface LogOptions {
|
2
|
-
level?: 'trace' | 'debug' | 'info' | 'warn' | 'error';
|
3
|
-
logArgs?: boolean;
|
4
|
-
logResult?: boolean;
|
5
|
-
logDuration?: boolean;
|
6
|
-
message?: string;
|
7
|
-
skipIf?: (args: any[]) => boolean;
|
8
|
-
component?: string;
|
9
|
-
}
|
10
|
-
export declare function Log(options?: LogOptions): MethodDecorator;
|
11
|
-
export declare function Logger(name?: string): ClassDecorator;
|
@@ -1,80 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.Log = Log;
|
4
|
-
exports.Logger = Logger;
|
5
|
-
const logger_service_1 = require("../core/logger.service");
|
6
|
-
function Log(options = {}) {
|
7
|
-
return function (target, propertyKey, descriptor) {
|
8
|
-
const originalMethod = descriptor.value;
|
9
|
-
const className = target.constructor.name;
|
10
|
-
const methodName = String(propertyKey);
|
11
|
-
descriptor.value = async function (...args) {
|
12
|
-
const logger = logger_service_1.LoggerService.getInstance();
|
13
|
-
const startTime = Date.now();
|
14
|
-
// Skip logging if condition is met
|
15
|
-
if (options.skipIf && options.skipIf(args)) {
|
16
|
-
return originalMethod.apply(this, args);
|
17
|
-
}
|
18
|
-
const logData = {
|
19
|
-
component: options.component || className,
|
20
|
-
class: className,
|
21
|
-
method: methodName
|
22
|
-
};
|
23
|
-
if (options.logArgs && logger.getConfig().enableComponentLogs) {
|
24
|
-
logData.arguments = args;
|
25
|
-
}
|
26
|
-
const message = options.message || `${className}.${methodName} called`;
|
27
|
-
try {
|
28
|
-
logger[options.level || 'debug'](`${message} - started`, logData);
|
29
|
-
const result = await originalMethod.apply(this, args);
|
30
|
-
const duration = Date.now() - startTime;
|
31
|
-
const successData = { ...logData };
|
32
|
-
if (options.logResult && logger.getConfig().enableComponentLogs) {
|
33
|
-
successData.result = result;
|
34
|
-
}
|
35
|
-
if (options.logDuration) {
|
36
|
-
successData.duration = duration;
|
37
|
-
}
|
38
|
-
logger[options.level || 'debug'](`${message} - completed`, successData);
|
39
|
-
// Log performance if enabled and method is slow
|
40
|
-
if (logger.getConfig().enablePerformanceLogs && duration > (logger.getConfig().performance?.slowThreshold || 1000)) {
|
41
|
-
logger.performance({
|
42
|
-
operation: `${className}.${methodName}`,
|
43
|
-
duration,
|
44
|
-
metadata: { slow: true }
|
45
|
-
});
|
46
|
-
}
|
47
|
-
return result;
|
48
|
-
}
|
49
|
-
catch (error) {
|
50
|
-
const duration = Date.now() - startTime;
|
51
|
-
logger.error(`${message} - failed`, error, {
|
52
|
-
...logData,
|
53
|
-
duration,
|
54
|
-
error: error instanceof Error ? error.message : String(error)
|
55
|
-
});
|
56
|
-
throw error;
|
57
|
-
}
|
58
|
-
};
|
59
|
-
return descriptor;
|
60
|
-
};
|
61
|
-
}
|
62
|
-
// Class-level logger injection
|
63
|
-
function Logger(name) {
|
64
|
-
return function (target) {
|
65
|
-
const loggerName = name || target.name;
|
66
|
-
// Add lazy logger property to the class
|
67
|
-
Object.defineProperty(target.prototype, 'logger', {
|
68
|
-
get: function () {
|
69
|
-
// Lazy initialization - only create logger when first accessed
|
70
|
-
if (!this._logger) {
|
71
|
-
this._logger = logger_service_1.LoggerService.getInstance().child({ component: loggerName });
|
72
|
-
}
|
73
|
-
return this._logger;
|
74
|
-
},
|
75
|
-
enumerable: false,
|
76
|
-
configurable: false
|
77
|
-
});
|
78
|
-
};
|
79
|
-
}
|
80
|
-
//# sourceMappingURL=log.decorator.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"log.decorator.js","sourceRoot":"","sources":["../../../src/logging/decorators/log.decorator.ts"],"names":[],"mappings":"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"}
|
@@ -1,29 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
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"}
|
@@ -1,78 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"request-logging.middleware.js","sourceRoot":"","sources":["../../../src/logging/middleware/request-logging.middleware.ts"],"names":[],"mappings":"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"}
|
@@ -1,79 +0,0 @@
|
|
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
|
-
}
|