@morojs/moro 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/LICENSE +21 -0
- package/README.md +233 -0
- package/dist/core/config/index.d.ts +19 -0
- package/dist/core/config/index.js +59 -0
- package/dist/core/config/index.js.map +1 -0
- package/dist/core/config/loader.d.ts +6 -0
- package/dist/core/config/loader.js +288 -0
- package/dist/core/config/loader.js.map +1 -0
- package/dist/core/config/schema.d.ts +335 -0
- package/dist/core/config/schema.js +286 -0
- package/dist/core/config/schema.js.map +1 -0
- package/dist/core/config/utils.d.ts +50 -0
- package/dist/core/config/utils.js +185 -0
- package/dist/core/config/utils.js.map +1 -0
- package/dist/core/database/adapters/drizzle.d.ts +29 -0
- package/dist/core/database/adapters/drizzle.js +366 -0
- package/dist/core/database/adapters/drizzle.js.map +1 -0
- package/dist/core/database/adapters/index.d.ts +8 -0
- package/dist/core/database/adapters/index.js +48 -0
- package/dist/core/database/adapters/index.js.map +1 -0
- package/dist/core/database/adapters/mongodb.d.ts +35 -0
- package/dist/core/database/adapters/mongodb.js +215 -0
- package/dist/core/database/adapters/mongodb.js.map +1 -0
- package/dist/core/database/adapters/mysql.d.ts +23 -0
- package/dist/core/database/adapters/mysql.js +149 -0
- package/dist/core/database/adapters/mysql.js.map +1 -0
- package/dist/core/database/adapters/postgresql.d.ts +24 -0
- package/dist/core/database/adapters/postgresql.js +160 -0
- package/dist/core/database/adapters/postgresql.js.map +1 -0
- package/dist/core/database/adapters/redis.d.ts +50 -0
- package/dist/core/database/adapters/redis.js +266 -0
- package/dist/core/database/adapters/redis.js.map +1 -0
- package/dist/core/database/adapters/sqlite.d.ts +23 -0
- package/dist/core/database/adapters/sqlite.js +194 -0
- package/dist/core/database/adapters/sqlite.js.map +1 -0
- package/dist/core/database/index.d.ts +2 -0
- package/dist/core/database/index.js +20 -0
- package/dist/core/database/index.js.map +1 -0
- package/dist/core/docs/index.d.ts +63 -0
- package/dist/core/docs/index.js +170 -0
- package/dist/core/docs/index.js.map +1 -0
- package/dist/core/docs/openapi-generator.d.ts +124 -0
- package/dist/core/docs/openapi-generator.js +413 -0
- package/dist/core/docs/openapi-generator.js.map +1 -0
- package/dist/core/docs/simple-docs.d.ts +21 -0
- package/dist/core/docs/simple-docs.js +268 -0
- package/dist/core/docs/simple-docs.js.map +1 -0
- package/dist/core/docs/swagger-ui.d.ts +28 -0
- package/dist/core/docs/swagger-ui.js +317 -0
- package/dist/core/docs/swagger-ui.js.map +1 -0
- package/dist/core/docs/zod-to-openapi.d.ts +29 -0
- package/dist/core/docs/zod-to-openapi.js +414 -0
- package/dist/core/docs/zod-to-openapi.js.map +1 -0
- package/dist/core/events/event-bus.d.ts +27 -0
- package/dist/core/events/event-bus.js +193 -0
- package/dist/core/events/event-bus.js.map +1 -0
- package/dist/core/events/index.d.ts +2 -0
- package/dist/core/events/index.js +7 -0
- package/dist/core/events/index.js.map +1 -0
- package/dist/core/framework.d.ts +57 -0
- package/dist/core/framework.js +432 -0
- package/dist/core/framework.js.map +1 -0
- package/dist/core/http/http-server.d.ts +114 -0
- package/dist/core/http/http-server.js +1154 -0
- package/dist/core/http/http-server.js.map +1 -0
- package/dist/core/http/index.d.ts +3 -0
- package/dist/core/http/index.js +10 -0
- package/dist/core/http/index.js.map +1 -0
- package/dist/core/http/router.d.ts +14 -0
- package/dist/core/http/router.js +113 -0
- package/dist/core/http/router.js.map +1 -0
- package/dist/core/logger/filters.d.ts +9 -0
- package/dist/core/logger/filters.js +134 -0
- package/dist/core/logger/filters.js.map +1 -0
- package/dist/core/logger/index.d.ts +3 -0
- package/dist/core/logger/index.js +26 -0
- package/dist/core/logger/index.js.map +1 -0
- package/dist/core/logger/logger.d.ts +49 -0
- package/dist/core/logger/logger.js +332 -0
- package/dist/core/logger/logger.js.map +1 -0
- package/dist/core/logger/outputs.d.ts +42 -0
- package/dist/core/logger/outputs.js +110 -0
- package/dist/core/logger/outputs.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cache/file.d.ts +15 -0
- package/dist/core/middleware/built-in/adapters/cache/file.js +128 -0
- package/dist/core/middleware/built-in/adapters/cache/file.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cache/index.d.ts +5 -0
- package/dist/core/middleware/built-in/adapters/cache/index.js +28 -0
- package/dist/core/middleware/built-in/adapters/cache/index.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cache/memory.d.ts +11 -0
- package/dist/core/middleware/built-in/adapters/cache/memory.js +65 -0
- package/dist/core/middleware/built-in/adapters/cache/memory.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cache/redis.d.ts +17 -0
- package/dist/core/middleware/built-in/adapters/cache/redis.js +91 -0
- package/dist/core/middleware/built-in/adapters/cache/redis.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cdn/azure.d.ts +21 -0
- package/dist/core/middleware/built-in/adapters/cdn/azure.js +40 -0
- package/dist/core/middleware/built-in/adapters/cdn/azure.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.d.ts +14 -0
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js +77 -0
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.d.ts +15 -0
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js +73 -0
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/cdn/index.d.ts +5 -0
- package/dist/core/middleware/built-in/adapters/cdn/index.js +28 -0
- package/dist/core/middleware/built-in/adapters/cdn/index.js.map +1 -0
- package/dist/core/middleware/built-in/adapters/index.d.ts +4 -0
- package/dist/core/middleware/built-in/adapters/index.js +26 -0
- package/dist/core/middleware/built-in/adapters/index.js.map +1 -0
- package/dist/core/middleware/built-in/auth.d.ts +2 -0
- package/dist/core/middleware/built-in/auth.js +38 -0
- package/dist/core/middleware/built-in/auth.js.map +1 -0
- package/dist/core/middleware/built-in/cache.d.ts +3 -0
- package/dist/core/middleware/built-in/cache.js +188 -0
- package/dist/core/middleware/built-in/cache.js.map +1 -0
- package/dist/core/middleware/built-in/cdn.d.ts +3 -0
- package/dist/core/middleware/built-in/cdn.js +115 -0
- package/dist/core/middleware/built-in/cdn.js.map +1 -0
- package/dist/core/middleware/built-in/cookie.d.ts +14 -0
- package/dist/core/middleware/built-in/cookie.js +68 -0
- package/dist/core/middleware/built-in/cookie.js.map +1 -0
- package/dist/core/middleware/built-in/cors.d.ts +2 -0
- package/dist/core/middleware/built-in/cors.js +29 -0
- package/dist/core/middleware/built-in/cors.js.map +1 -0
- package/dist/core/middleware/built-in/csp.d.ts +22 -0
- package/dist/core/middleware/built-in/csp.js +74 -0
- package/dist/core/middleware/built-in/csp.js.map +1 -0
- package/dist/core/middleware/built-in/csrf.d.ts +9 -0
- package/dist/core/middleware/built-in/csrf.js +66 -0
- package/dist/core/middleware/built-in/csrf.js.map +1 -0
- package/dist/core/middleware/built-in/error-tracker.d.ts +1 -0
- package/dist/core/middleware/built-in/error-tracker.js +19 -0
- package/dist/core/middleware/built-in/error-tracker.js.map +1 -0
- package/dist/core/middleware/built-in/index.d.ts +70 -0
- package/dist/core/middleware/built-in/index.js +70 -0
- package/dist/core/middleware/built-in/index.js.map +1 -0
- package/dist/core/middleware/built-in/performance-monitor.d.ts +1 -0
- package/dist/core/middleware/built-in/performance-monitor.js +22 -0
- package/dist/core/middleware/built-in/performance-monitor.js.map +1 -0
- package/dist/core/middleware/built-in/rate-limit.d.ts +6 -0
- package/dist/core/middleware/built-in/rate-limit.js +47 -0
- package/dist/core/middleware/built-in/rate-limit.js.map +1 -0
- package/dist/core/middleware/built-in/request-logger.d.ts +1 -0
- package/dist/core/middleware/built-in/request-logger.js +15 -0
- package/dist/core/middleware/built-in/request-logger.js.map +1 -0
- package/dist/core/middleware/built-in/session.d.ts +41 -0
- package/dist/core/middleware/built-in/session.js +209 -0
- package/dist/core/middleware/built-in/session.js.map +1 -0
- package/dist/core/middleware/built-in/sse.d.ts +6 -0
- package/dist/core/middleware/built-in/sse.js +73 -0
- package/dist/core/middleware/built-in/sse.js.map +1 -0
- package/dist/core/middleware/built-in/validation.d.ts +2 -0
- package/dist/core/middleware/built-in/validation.js +31 -0
- package/dist/core/middleware/built-in/validation.js.map +1 -0
- package/dist/core/middleware/index.d.ts +21 -0
- package/dist/core/middleware/index.js +152 -0
- package/dist/core/middleware/index.js.map +1 -0
- package/dist/core/modules/auto-discovery.d.ts +27 -0
- package/dist/core/modules/auto-discovery.js +255 -0
- package/dist/core/modules/auto-discovery.js.map +1 -0
- package/dist/core/modules/index.d.ts +2 -0
- package/dist/core/modules/index.js +11 -0
- package/dist/core/modules/index.js.map +1 -0
- package/dist/core/modules/modules.d.ts +10 -0
- package/dist/core/modules/modules.js +137 -0
- package/dist/core/modules/modules.js.map +1 -0
- package/dist/core/networking/index.d.ts +2 -0
- package/dist/core/networking/index.js +9 -0
- package/dist/core/networking/index.js.map +1 -0
- package/dist/core/networking/service-discovery.d.ts +38 -0
- package/dist/core/networking/service-discovery.js +233 -0
- package/dist/core/networking/service-discovery.js.map +1 -0
- package/dist/core/networking/websocket-manager.d.ts +27 -0
- package/dist/core/networking/websocket-manager.js +211 -0
- package/dist/core/networking/websocket-manager.js.map +1 -0
- package/dist/core/routing/app-integration.d.ts +42 -0
- package/dist/core/routing/app-integration.js +152 -0
- package/dist/core/routing/app-integration.js.map +1 -0
- package/dist/core/routing/index.d.ts +106 -0
- package/dist/core/routing/index.js +343 -0
- package/dist/core/routing/index.js.map +1 -0
- package/dist/core/runtime/aws-lambda-adapter.d.ts +43 -0
- package/dist/core/runtime/aws-lambda-adapter.js +108 -0
- package/dist/core/runtime/aws-lambda-adapter.js.map +1 -0
- package/dist/core/runtime/base-adapter.d.ts +16 -0
- package/dist/core/runtime/base-adapter.js +105 -0
- package/dist/core/runtime/base-adapter.js.map +1 -0
- package/dist/core/runtime/cloudflare-workers-adapter.d.ts +18 -0
- package/dist/core/runtime/cloudflare-workers-adapter.js +131 -0
- package/dist/core/runtime/cloudflare-workers-adapter.js.map +1 -0
- package/dist/core/runtime/index.d.ts +14 -0
- package/dist/core/runtime/index.js +56 -0
- package/dist/core/runtime/index.js.map +1 -0
- package/dist/core/runtime/node-adapter.d.ts +15 -0
- package/dist/core/runtime/node-adapter.js +204 -0
- package/dist/core/runtime/node-adapter.js.map +1 -0
- package/dist/core/runtime/vercel-edge-adapter.d.ts +10 -0
- package/dist/core/runtime/vercel-edge-adapter.js +106 -0
- package/dist/core/runtime/vercel-edge-adapter.js.map +1 -0
- package/dist/core/utilities/circuit-breaker.d.ts +14 -0
- package/dist/core/utilities/circuit-breaker.js +42 -0
- package/dist/core/utilities/circuit-breaker.js.map +1 -0
- package/dist/core/utilities/container.d.ts +116 -0
- package/dist/core/utilities/container.js +529 -0
- package/dist/core/utilities/container.js.map +1 -0
- package/dist/core/utilities/hooks.d.ts +24 -0
- package/dist/core/utilities/hooks.js +131 -0
- package/dist/core/utilities/hooks.js.map +1 -0
- package/dist/core/utilities/index.d.ts +4 -0
- package/dist/core/utilities/index.js +22 -0
- package/dist/core/utilities/index.js.map +1 -0
- package/dist/core/validation/index.d.ts +30 -0
- package/dist/core/validation/index.js +144 -0
- package/dist/core/validation/index.js.map +1 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.js +72 -0
- package/dist/index.js.map +1 -0
- package/dist/moro.d.ts +82 -0
- package/dist/moro.js +679 -0
- package/dist/moro.js.map +1 -0
- package/dist/types/cache.d.ts +34 -0
- package/dist/types/cache.js +3 -0
- package/dist/types/cache.js.map +1 -0
- package/dist/types/cdn.d.ts +19 -0
- package/dist/types/cdn.js +3 -0
- package/dist/types/cdn.js.map +1 -0
- package/dist/types/core.d.ts +13 -0
- package/dist/types/core.js +3 -0
- package/dist/types/core.js.map +1 -0
- package/dist/types/database.d.ts +29 -0
- package/dist/types/database.js +3 -0
- package/dist/types/database.js.map +1 -0
- package/dist/types/discovery.d.ts +6 -0
- package/dist/types/discovery.js +3 -0
- package/dist/types/discovery.js.map +1 -0
- package/dist/types/events.d.ts +116 -0
- package/dist/types/events.js +3 -0
- package/dist/types/events.js.map +1 -0
- package/dist/types/hooks.d.ts +38 -0
- package/dist/types/hooks.js +3 -0
- package/dist/types/hooks.js.map +1 -0
- package/dist/types/http.d.ts +51 -0
- package/dist/types/http.js +3 -0
- package/dist/types/http.js.map +1 -0
- package/dist/types/logger.d.ts +77 -0
- package/dist/types/logger.js +3 -0
- package/dist/types/logger.js.map +1 -0
- package/dist/types/module.d.ts +91 -0
- package/dist/types/module.js +3 -0
- package/dist/types/module.js.map +1 -0
- package/dist/types/runtime.d.ts +48 -0
- package/dist/types/runtime.js +3 -0
- package/dist/types/runtime.js.map +1 -0
- package/dist/types/session.d.ts +66 -0
- package/dist/types/session.js +3 -0
- package/dist/types/session.js.map +1 -0
- package/package.json +176 -0
- package/src/core/config/index.ts +47 -0
- package/src/core/config/loader.ts +366 -0
- package/src/core/config/schema.ts +346 -0
- package/src/core/config/utils.ts +220 -0
- package/src/core/database/README.md +228 -0
- package/src/core/database/adapters/drizzle.ts +425 -0
- package/src/core/database/adapters/index.ts +45 -0
- package/src/core/database/adapters/mongodb.ts +292 -0
- package/src/core/database/adapters/mysql.ts +217 -0
- package/src/core/database/adapters/postgresql.ts +211 -0
- package/src/core/database/adapters/redis.ts +331 -0
- package/src/core/database/adapters/sqlite.ts +255 -0
- package/src/core/database/index.ts +3 -0
- package/src/core/docs/index.ts +245 -0
- package/src/core/docs/openapi-generator.ts +588 -0
- package/src/core/docs/simple-docs.ts +305 -0
- package/src/core/docs/swagger-ui.ts +370 -0
- package/src/core/docs/zod-to-openapi.ts +532 -0
- package/src/core/events/event-bus.ts +249 -0
- package/src/core/events/index.ts +12 -0
- package/src/core/framework.ts +621 -0
- package/src/core/http/http-server.ts +1421 -0
- package/src/core/http/index.ts +11 -0
- package/src/core/http/router.ts +153 -0
- package/src/core/logger/filters.ts +148 -0
- package/src/core/logger/index.ts +20 -0
- package/src/core/logger/logger.ts +434 -0
- package/src/core/logger/outputs.ts +136 -0
- package/src/core/middleware/built-in/adapters/cache/file.ts +106 -0
- package/src/core/middleware/built-in/adapters/cache/index.ts +26 -0
- package/src/core/middleware/built-in/adapters/cache/memory.ts +73 -0
- package/src/core/middleware/built-in/adapters/cache/redis.ts +103 -0
- package/src/core/middleware/built-in/adapters/cdn/azure.ts +68 -0
- package/src/core/middleware/built-in/adapters/cdn/cloudflare.ts +100 -0
- package/src/core/middleware/built-in/adapters/cdn/cloudfront.ts +92 -0
- package/src/core/middleware/built-in/adapters/cdn/index.ts +23 -0
- package/src/core/middleware/built-in/adapters/index.ts +7 -0
- package/src/core/middleware/built-in/auth.ts +39 -0
- package/src/core/middleware/built-in/cache.ts +228 -0
- package/src/core/middleware/built-in/cdn.ts +151 -0
- package/src/core/middleware/built-in/cookie.ts +90 -0
- package/src/core/middleware/built-in/cors.ts +38 -0
- package/src/core/middleware/built-in/csp.ts +107 -0
- package/src/core/middleware/built-in/csrf.ts +87 -0
- package/src/core/middleware/built-in/error-tracker.ts +16 -0
- package/src/core/middleware/built-in/index.ts +57 -0
- package/src/core/middleware/built-in/performance-monitor.ts +25 -0
- package/src/core/middleware/built-in/rate-limit.ts +60 -0
- package/src/core/middleware/built-in/request-logger.ts +14 -0
- package/src/core/middleware/built-in/session.ts +311 -0
- package/src/core/middleware/built-in/sse.ts +91 -0
- package/src/core/middleware/built-in/validation.ts +33 -0
- package/src/core/middleware/index.ts +188 -0
- package/src/core/modules/auto-discovery.ts +265 -0
- package/src/core/modules/index.ts +6 -0
- package/src/core/modules/modules.ts +125 -0
- package/src/core/networking/index.ts +7 -0
- package/src/core/networking/service-discovery.ts +309 -0
- package/src/core/networking/websocket-manager.ts +259 -0
- package/src/core/routing/app-integration.ts +229 -0
- package/src/core/routing/index.ts +519 -0
- package/src/core/runtime/aws-lambda-adapter.ts +157 -0
- package/src/core/runtime/base-adapter.ts +140 -0
- package/src/core/runtime/cloudflare-workers-adapter.ts +166 -0
- package/src/core/runtime/index.ts +74 -0
- package/src/core/runtime/node-adapter.ts +210 -0
- package/src/core/runtime/vercel-edge-adapter.ts +125 -0
- package/src/core/utilities/circuit-breaker.ts +46 -0
- package/src/core/utilities/container.ts +760 -0
- package/src/core/utilities/hooks.ts +148 -0
- package/src/core/utilities/index.ts +16 -0
- package/src/core/validation/index.ts +216 -0
- package/src/index.ts +120 -0
- package/src/moro.ts +842 -0
- package/src/types/cache.ts +38 -0
- package/src/types/cdn.ts +22 -0
- package/src/types/core.ts +17 -0
- package/src/types/database.ts +40 -0
- package/src/types/discovery.ts +7 -0
- package/src/types/events.ts +90 -0
- package/src/types/hooks.ts +47 -0
- package/src/types/http.ts +70 -0
- package/src/types/logger.ts +109 -0
- package/src/types/module.ts +87 -0
- package/src/types/runtime.ts +91 -0
- package/src/types/session.ts +89 -0
- package/tsconfig.json +21 -0
|
@@ -0,0 +1,332 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createFrameworkLogger = exports.logger = exports.MoroLogger = void 0;
|
|
4
|
+
exports.configureGlobalLogger = configureGlobalLogger;
|
|
5
|
+
exports.applyLoggingConfiguration = applyLoggingConfiguration;
|
|
6
|
+
// Moro Logger - Beautiful, Fast, Feature-Rich
|
|
7
|
+
const perf_hooks_1 = require("perf_hooks");
|
|
8
|
+
class MoroLogger {
|
|
9
|
+
constructor(options = {}) {
|
|
10
|
+
this.level = "info";
|
|
11
|
+
this.outputs = new Map();
|
|
12
|
+
this.filters = new Map();
|
|
13
|
+
this.history = [];
|
|
14
|
+
this.timers = new Map();
|
|
15
|
+
this.metrics = {
|
|
16
|
+
totalLogs: 0,
|
|
17
|
+
logsByLevel: { debug: 0, info: 0, warn: 0, error: 0, fatal: 0 },
|
|
18
|
+
logsByContext: {},
|
|
19
|
+
averageLogRate: 0,
|
|
20
|
+
errorRate: 0,
|
|
21
|
+
memoryUsage: 0,
|
|
22
|
+
};
|
|
23
|
+
this.startTime = Date.now();
|
|
24
|
+
this.options = {
|
|
25
|
+
level: "info",
|
|
26
|
+
enableColors: true,
|
|
27
|
+
enableTimestamp: true,
|
|
28
|
+
enableContext: true,
|
|
29
|
+
enableMetadata: true,
|
|
30
|
+
enablePerformance: true,
|
|
31
|
+
format: "pretty",
|
|
32
|
+
outputs: [],
|
|
33
|
+
filters: [],
|
|
34
|
+
maxEntries: 1000,
|
|
35
|
+
...options,
|
|
36
|
+
};
|
|
37
|
+
this.level = this.options.level || "info";
|
|
38
|
+
// Add default console output
|
|
39
|
+
this.addOutput({
|
|
40
|
+
name: "console",
|
|
41
|
+
write: this.writeToConsole.bind(this),
|
|
42
|
+
format: this.options.format,
|
|
43
|
+
});
|
|
44
|
+
// Add custom outputs
|
|
45
|
+
this.options.outputs?.forEach((output) => this.addOutput(output));
|
|
46
|
+
this.options.filters?.forEach((filter) => this.addFilter(filter));
|
|
47
|
+
}
|
|
48
|
+
debug(message, context, metadata) {
|
|
49
|
+
this.log("debug", message, context, metadata);
|
|
50
|
+
}
|
|
51
|
+
info(message, context, metadata) {
|
|
52
|
+
this.log("info", message, context, metadata);
|
|
53
|
+
}
|
|
54
|
+
warn(message, context, metadata) {
|
|
55
|
+
this.log("warn", message, context, metadata);
|
|
56
|
+
}
|
|
57
|
+
error(message, context, metadata) {
|
|
58
|
+
const msg = message instanceof Error ? message.message : message;
|
|
59
|
+
const stack = message instanceof Error ? message.stack : undefined;
|
|
60
|
+
this.log("error", msg, context, { ...metadata, stack });
|
|
61
|
+
}
|
|
62
|
+
fatal(message, context, metadata) {
|
|
63
|
+
const msg = message instanceof Error ? message.message : message;
|
|
64
|
+
const stack = message instanceof Error ? message.stack : undefined;
|
|
65
|
+
this.log("fatal", msg, context, { ...metadata, stack });
|
|
66
|
+
}
|
|
67
|
+
time(label) {
|
|
68
|
+
this.timers.set(label, perf_hooks_1.performance.now());
|
|
69
|
+
}
|
|
70
|
+
timeEnd(label, context, metadata) {
|
|
71
|
+
const startTime = this.timers.get(label);
|
|
72
|
+
if (startTime !== undefined) {
|
|
73
|
+
const duration = perf_hooks_1.performance.now() - startTime;
|
|
74
|
+
this.timers.delete(label);
|
|
75
|
+
this.log("info", `Timer: ${label}`, context, {
|
|
76
|
+
...metadata,
|
|
77
|
+
performance: { duration: Math.round(duration * 100) / 100 },
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
child(context, metadata) {
|
|
82
|
+
const childLogger = new MoroLogger(this.options);
|
|
83
|
+
childLogger.contextPrefix = this.contextPrefix
|
|
84
|
+
? `${this.contextPrefix}:${context}`
|
|
85
|
+
: context;
|
|
86
|
+
childLogger.contextMetadata = { ...this.contextMetadata, ...metadata };
|
|
87
|
+
childLogger.outputs = this.outputs;
|
|
88
|
+
childLogger.filters = this.filters;
|
|
89
|
+
return childLogger;
|
|
90
|
+
}
|
|
91
|
+
setLevel(level) {
|
|
92
|
+
this.level = level;
|
|
93
|
+
}
|
|
94
|
+
addOutput(output) {
|
|
95
|
+
this.outputs.set(output.name, output);
|
|
96
|
+
}
|
|
97
|
+
removeOutput(name) {
|
|
98
|
+
this.outputs.delete(name);
|
|
99
|
+
}
|
|
100
|
+
addFilter(filter) {
|
|
101
|
+
this.filters.set(filter.name, filter);
|
|
102
|
+
}
|
|
103
|
+
removeFilter(name) {
|
|
104
|
+
this.filters.delete(name);
|
|
105
|
+
}
|
|
106
|
+
getHistory(count) {
|
|
107
|
+
const entries = [...this.history];
|
|
108
|
+
return count ? entries.slice(-count) : entries;
|
|
109
|
+
}
|
|
110
|
+
getMetrics() {
|
|
111
|
+
const now = Date.now();
|
|
112
|
+
const uptime = (now - this.startTime) / 1000; // seconds
|
|
113
|
+
const avgRate = uptime > 0 ? this.metrics.totalLogs / uptime : 0;
|
|
114
|
+
const errorCount = this.metrics.logsByLevel.error + this.metrics.logsByLevel.fatal;
|
|
115
|
+
const errorRate = this.metrics.totalLogs > 0
|
|
116
|
+
? (errorCount / this.metrics.totalLogs) * 100
|
|
117
|
+
: 0;
|
|
118
|
+
return {
|
|
119
|
+
...this.metrics,
|
|
120
|
+
averageLogRate: Math.round(avgRate * 100) / 100,
|
|
121
|
+
errorRate: Math.round(errorRate * 100) / 100,
|
|
122
|
+
memoryUsage: process.memoryUsage().heapUsed / 1024 / 1024, // MB
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
clear() {
|
|
126
|
+
this.history = [];
|
|
127
|
+
this.metrics = {
|
|
128
|
+
totalLogs: 0,
|
|
129
|
+
logsByLevel: { debug: 0, info: 0, warn: 0, error: 0, fatal: 0 },
|
|
130
|
+
logsByContext: {},
|
|
131
|
+
averageLogRate: 0,
|
|
132
|
+
errorRate: 0,
|
|
133
|
+
memoryUsage: 0,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
log(level, message, context, metadata) {
|
|
137
|
+
// Check level threshold
|
|
138
|
+
if (MoroLogger.LEVELS[level] < MoroLogger.LEVELS[this.level]) {
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
// Create log entry
|
|
142
|
+
const entry = {
|
|
143
|
+
timestamp: new Date(),
|
|
144
|
+
level,
|
|
145
|
+
message,
|
|
146
|
+
context: this.contextPrefix
|
|
147
|
+
? context
|
|
148
|
+
? `${this.contextPrefix}:${context}`
|
|
149
|
+
: this.contextPrefix
|
|
150
|
+
: context,
|
|
151
|
+
metadata: { ...this.contextMetadata, ...metadata },
|
|
152
|
+
performance: this.options.enablePerformance
|
|
153
|
+
? {
|
|
154
|
+
memory: process.memoryUsage().heapUsed / 1024 / 1024,
|
|
155
|
+
}
|
|
156
|
+
: undefined,
|
|
157
|
+
};
|
|
158
|
+
// Apply filters
|
|
159
|
+
for (const filter of this.filters.values()) {
|
|
160
|
+
if (!filter.filter(entry)) {
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
// Update metrics
|
|
165
|
+
this.updateMetrics(entry);
|
|
166
|
+
// Store in history
|
|
167
|
+
this.history.push(entry);
|
|
168
|
+
if (this.history.length > (this.options.maxEntries || 1000)) {
|
|
169
|
+
this.history.shift();
|
|
170
|
+
}
|
|
171
|
+
// Write to outputs
|
|
172
|
+
for (const output of this.outputs.values()) {
|
|
173
|
+
if (!output.level ||
|
|
174
|
+
MoroLogger.LEVELS[level] >= MoroLogger.LEVELS[output.level]) {
|
|
175
|
+
try {
|
|
176
|
+
output.write(entry);
|
|
177
|
+
}
|
|
178
|
+
catch (error) {
|
|
179
|
+
console.error("Logger output error:", error);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
updateMetrics(entry) {
|
|
185
|
+
this.metrics.totalLogs++;
|
|
186
|
+
this.metrics.logsByLevel[entry.level]++;
|
|
187
|
+
if (entry.context) {
|
|
188
|
+
this.metrics.logsByContext[entry.context] =
|
|
189
|
+
(this.metrics.logsByContext[entry.context] || 0) + 1;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
writeToConsole(entry) {
|
|
193
|
+
const format = this.options.format || "pretty";
|
|
194
|
+
if (format === "json") {
|
|
195
|
+
console.log(JSON.stringify(entry));
|
|
196
|
+
return;
|
|
197
|
+
}
|
|
198
|
+
if (format === "compact") {
|
|
199
|
+
const level = entry.level.toUpperCase().padEnd(5);
|
|
200
|
+
const context = entry.context ? `[${entry.context}] ` : "";
|
|
201
|
+
console.log(`${level} ${context}${entry.message}`);
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
// Pretty format (default)
|
|
205
|
+
this.writePrettyLog(entry);
|
|
206
|
+
}
|
|
207
|
+
writePrettyLog(entry) {
|
|
208
|
+
const colors = this.options.enableColors !== false;
|
|
209
|
+
const parts = [];
|
|
210
|
+
// Timestamp
|
|
211
|
+
if (this.options.enableTimestamp !== false) {
|
|
212
|
+
const timestamp = entry.timestamp
|
|
213
|
+
.toISOString()
|
|
214
|
+
.replace("T", " ")
|
|
215
|
+
.slice(0, 19);
|
|
216
|
+
parts.push(colors
|
|
217
|
+
? `${MoroLogger.COLORS.timestamp}${timestamp}${MoroLogger.RESET}`
|
|
218
|
+
: timestamp);
|
|
219
|
+
}
|
|
220
|
+
// Level with color (remove icons)
|
|
221
|
+
const levelColor = colors ? MoroLogger.COLORS[entry.level] : "";
|
|
222
|
+
const levelReset = colors ? MoroLogger.RESET : "";
|
|
223
|
+
const levelText = entry.level.toUpperCase();
|
|
224
|
+
parts.push(`${levelColor}${MoroLogger.BOLD}${levelText}${levelReset}`);
|
|
225
|
+
// Context
|
|
226
|
+
if (entry.context && this.options.enableContext !== false) {
|
|
227
|
+
const contextColor = colors ? MoroLogger.COLORS.context : "";
|
|
228
|
+
parts.push(`${contextColor}[${entry.context}]${levelReset}`);
|
|
229
|
+
}
|
|
230
|
+
// Message
|
|
231
|
+
parts.push(entry.message);
|
|
232
|
+
// Performance info
|
|
233
|
+
if (entry.performance && this.options.enablePerformance !== false) {
|
|
234
|
+
const perfColor = colors ? MoroLogger.COLORS.performance : "";
|
|
235
|
+
const perfParts = [];
|
|
236
|
+
if (entry.performance.duration !== undefined) {
|
|
237
|
+
perfParts.push(`${entry.performance.duration}ms`);
|
|
238
|
+
}
|
|
239
|
+
if (entry.performance.memory !== undefined) {
|
|
240
|
+
perfParts.push(`${Math.round(entry.performance.memory)}MB`);
|
|
241
|
+
}
|
|
242
|
+
if (perfParts.length > 0) {
|
|
243
|
+
parts.push(`${perfColor}(${perfParts.join(", ")})${levelReset}`);
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
// Metadata
|
|
247
|
+
if (entry.metadata &&
|
|
248
|
+
Object.keys(entry.metadata).length > 0 &&
|
|
249
|
+
this.options.enableMetadata !== false) {
|
|
250
|
+
const metaColor = colors ? MoroLogger.COLORS.metadata : "";
|
|
251
|
+
const cleanMetadata = { ...entry.metadata };
|
|
252
|
+
delete cleanMetadata.stack; // Handle stack separately
|
|
253
|
+
if (Object.keys(cleanMetadata).length > 0) {
|
|
254
|
+
parts.push(`${metaColor}${JSON.stringify(cleanMetadata)}${levelReset}`);
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
// Output main log line
|
|
258
|
+
console.log(parts.join(" "));
|
|
259
|
+
// Stack trace for errors
|
|
260
|
+
if (entry.metadata?.stack &&
|
|
261
|
+
(entry.level === "error" || entry.level === "fatal")) {
|
|
262
|
+
const stackColor = colors ? MoroLogger.COLORS.error : "";
|
|
263
|
+
console.log(`${stackColor}${entry.metadata.stack}${levelReset}`);
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
exports.MoroLogger = MoroLogger;
|
|
268
|
+
MoroLogger.LEVELS = {
|
|
269
|
+
debug: 0,
|
|
270
|
+
info: 1,
|
|
271
|
+
warn: 2,
|
|
272
|
+
error: 3,
|
|
273
|
+
fatal: 4,
|
|
274
|
+
};
|
|
275
|
+
MoroLogger.COLORS = {
|
|
276
|
+
debug: "\x1b[36m", // Cyan
|
|
277
|
+
info: "\x1b[32m", // Green
|
|
278
|
+
warn: "\x1b[33m", // Yellow
|
|
279
|
+
error: "\x1b[31m", // Red
|
|
280
|
+
fatal: "\x1b[35m", // Magenta
|
|
281
|
+
timestamp: "\x1b[90m", // Gray
|
|
282
|
+
context: "\x1b[34m", // Blue
|
|
283
|
+
metadata: "\x1b[37m", // White
|
|
284
|
+
performance: "\x1b[36m", // Cyan
|
|
285
|
+
};
|
|
286
|
+
MoroLogger.RESET = "\x1b[0m";
|
|
287
|
+
MoroLogger.BOLD = "\x1b[1m";
|
|
288
|
+
// Global logger instance
|
|
289
|
+
const initialLogLevel = process.env.LOG_LEVEL ||
|
|
290
|
+
process.env.MORO_LOG_LEVEL ||
|
|
291
|
+
(process.env.NODE_ENV === "production" ? "warn" : "debug");
|
|
292
|
+
exports.logger = new MoroLogger({
|
|
293
|
+
level: initialLogLevel,
|
|
294
|
+
enableColors: !process.env.NO_COLOR,
|
|
295
|
+
format: process.env.LOG_FORMAT || "pretty",
|
|
296
|
+
});
|
|
297
|
+
/**
|
|
298
|
+
* Configure the global logger with new settings
|
|
299
|
+
* This allows runtime configuration of the logger
|
|
300
|
+
*/
|
|
301
|
+
function configureGlobalLogger(options) {
|
|
302
|
+
if (options.level) {
|
|
303
|
+
exports.logger.setLevel(options.level);
|
|
304
|
+
}
|
|
305
|
+
// Additional configuration options can be added here as needed
|
|
306
|
+
// For now, focusing on level which is the most critical
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Apply logging configuration from the config system and/or createApp options
|
|
310
|
+
*/
|
|
311
|
+
function applyLoggingConfiguration(configLogging, appOptions) {
|
|
312
|
+
// First apply config system settings (from environment variables)
|
|
313
|
+
if (configLogging?.level) {
|
|
314
|
+
configureGlobalLogger({ level: configLogging.level });
|
|
315
|
+
}
|
|
316
|
+
// Then apply createApp options (these take precedence)
|
|
317
|
+
if (appOptions !== undefined) {
|
|
318
|
+
if (appOptions === false) {
|
|
319
|
+
// Disable logging by setting to fatal level
|
|
320
|
+
configureGlobalLogger({ level: "fatal" });
|
|
321
|
+
}
|
|
322
|
+
else if (typeof appOptions === "object") {
|
|
323
|
+
configureGlobalLogger(appOptions);
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
// Framework-specific logger
|
|
328
|
+
const createFrameworkLogger = (context) => {
|
|
329
|
+
return exports.logger.child("Moro", { framework: "moro", context });
|
|
330
|
+
};
|
|
331
|
+
exports.createFrameworkLogger = createFrameworkLogger;
|
|
332
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/core/logger/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { LogEntry, LogOutput } from "../../types/logger";
|
|
2
|
+
export declare class FileOutput implements LogOutput {
|
|
3
|
+
private filePath;
|
|
4
|
+
private options;
|
|
5
|
+
name: string;
|
|
6
|
+
constructor(filePath: string, options?: {
|
|
7
|
+
format?: "json" | "pretty";
|
|
8
|
+
maxSize?: number;
|
|
9
|
+
rotate?: boolean;
|
|
10
|
+
});
|
|
11
|
+
write(entry: LogEntry): Promise<void>;
|
|
12
|
+
private formatPretty;
|
|
13
|
+
}
|
|
14
|
+
export declare class WebhookOutput implements LogOutput {
|
|
15
|
+
private url;
|
|
16
|
+
private options;
|
|
17
|
+
name: string;
|
|
18
|
+
constructor(url: string, options?: {
|
|
19
|
+
headers?: Record<string, string>;
|
|
20
|
+
batch?: boolean;
|
|
21
|
+
batchSize?: number;
|
|
22
|
+
timeout?: number;
|
|
23
|
+
});
|
|
24
|
+
write(entry: LogEntry): Promise<void>;
|
|
25
|
+
}
|
|
26
|
+
export declare class MemoryOutput implements LogOutput {
|
|
27
|
+
private maxSize;
|
|
28
|
+
name: string;
|
|
29
|
+
private buffer;
|
|
30
|
+
constructor(maxSize?: number);
|
|
31
|
+
write(entry: LogEntry): void;
|
|
32
|
+
getEntries(): LogEntry[];
|
|
33
|
+
clear(): void;
|
|
34
|
+
}
|
|
35
|
+
export declare class StreamOutput implements LogOutput {
|
|
36
|
+
private stream;
|
|
37
|
+
name: string;
|
|
38
|
+
format?: "pretty" | "json" | "compact";
|
|
39
|
+
constructor(stream: NodeJS.WritableStream, format?: "json" | "pretty");
|
|
40
|
+
write(entry: LogEntry): void;
|
|
41
|
+
private formatPretty;
|
|
42
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StreamOutput = exports.MemoryOutput = exports.WebhookOutput = exports.FileOutput = void 0;
|
|
4
|
+
// Advanced Logger Outputs
|
|
5
|
+
const promises_1 = require("fs/promises");
|
|
6
|
+
const path_1 = require("path");
|
|
7
|
+
// File output for persistent logging
|
|
8
|
+
class FileOutput {
|
|
9
|
+
constructor(filePath, options = {}) {
|
|
10
|
+
this.filePath = filePath;
|
|
11
|
+
this.options = options;
|
|
12
|
+
this.name = "file";
|
|
13
|
+
}
|
|
14
|
+
async write(entry) {
|
|
15
|
+
try {
|
|
16
|
+
// Ensure directory exists
|
|
17
|
+
await (0, promises_1.mkdir)((0, path_1.dirname)(this.filePath), { recursive: true });
|
|
18
|
+
const format = this.options.format || "json";
|
|
19
|
+
const line = format === "json"
|
|
20
|
+
? JSON.stringify(entry) + "\n"
|
|
21
|
+
: this.formatPretty(entry) + "\n";
|
|
22
|
+
await (0, promises_1.appendFile)(this.filePath, line, "utf8");
|
|
23
|
+
// TODO: Implement log rotation if needed
|
|
24
|
+
}
|
|
25
|
+
catch (error) {
|
|
26
|
+
console.error("File logger error:", error);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
formatPretty(entry) {
|
|
30
|
+
const timestamp = entry.timestamp.toISOString();
|
|
31
|
+
const level = entry.level.toUpperCase().padEnd(5);
|
|
32
|
+
const context = entry.context ? `[${entry.context}] ` : "";
|
|
33
|
+
const metadata = entry.metadata && Object.keys(entry.metadata).length > 0
|
|
34
|
+
? ` ${JSON.stringify(entry.metadata)}`
|
|
35
|
+
: "";
|
|
36
|
+
return `${timestamp} ${level} ${context}${entry.message}${metadata}`;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.FileOutput = FileOutput;
|
|
40
|
+
// HTTP webhook output for external logging services
|
|
41
|
+
class WebhookOutput {
|
|
42
|
+
constructor(url, options = {}) {
|
|
43
|
+
this.url = url;
|
|
44
|
+
this.options = options;
|
|
45
|
+
this.name = "webhook";
|
|
46
|
+
}
|
|
47
|
+
async write(entry) {
|
|
48
|
+
try {
|
|
49
|
+
const response = await fetch(this.url, {
|
|
50
|
+
method: "POST",
|
|
51
|
+
headers: {
|
|
52
|
+
"Content-Type": "application/json",
|
|
53
|
+
...this.options.headers,
|
|
54
|
+
},
|
|
55
|
+
body: JSON.stringify(entry),
|
|
56
|
+
signal: AbortSignal.timeout(this.options.timeout || 5000),
|
|
57
|
+
});
|
|
58
|
+
if (!response.ok) {
|
|
59
|
+
throw new Error(`Webhook failed: ${response.status}`);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
console.error("Webhook logger error:", error);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
exports.WebhookOutput = WebhookOutput;
|
|
68
|
+
// Memory buffer output for testing and debugging
|
|
69
|
+
class MemoryOutput {
|
|
70
|
+
constructor(maxSize = 1000) {
|
|
71
|
+
this.maxSize = maxSize;
|
|
72
|
+
this.name = "memory";
|
|
73
|
+
this.buffer = [];
|
|
74
|
+
}
|
|
75
|
+
write(entry) {
|
|
76
|
+
this.buffer.push(entry);
|
|
77
|
+
if (this.buffer.length > this.maxSize) {
|
|
78
|
+
this.buffer.shift();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
getEntries() {
|
|
82
|
+
return [...this.buffer];
|
|
83
|
+
}
|
|
84
|
+
clear() {
|
|
85
|
+
this.buffer = [];
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
exports.MemoryOutput = MemoryOutput;
|
|
89
|
+
// Stream output for custom processing
|
|
90
|
+
class StreamOutput {
|
|
91
|
+
constructor(stream, format = "json") {
|
|
92
|
+
this.stream = stream;
|
|
93
|
+
this.name = "stream";
|
|
94
|
+
this.format = format;
|
|
95
|
+
}
|
|
96
|
+
write(entry) {
|
|
97
|
+
const data = this.format === "json"
|
|
98
|
+
? JSON.stringify(entry) + "\n"
|
|
99
|
+
: this.formatPretty(entry) + "\n";
|
|
100
|
+
this.stream.write(data);
|
|
101
|
+
}
|
|
102
|
+
formatPretty(entry) {
|
|
103
|
+
const timestamp = entry.timestamp.toISOString();
|
|
104
|
+
const level = entry.level.toUpperCase().padEnd(5);
|
|
105
|
+
const context = entry.context ? `[${entry.context}] ` : "";
|
|
106
|
+
return `${timestamp} ${level} ${context}${entry.message}`;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
exports.StreamOutput = StreamOutput;
|
|
110
|
+
//# sourceMappingURL=outputs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../../src/core/logger/outputs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { CacheAdapter } from "../../../../../types/cache";
|
|
2
|
+
export declare class FileCacheAdapter implements CacheAdapter {
|
|
3
|
+
private cacheDir;
|
|
4
|
+
constructor(options?: {
|
|
5
|
+
cacheDir?: string;
|
|
6
|
+
});
|
|
7
|
+
private ensureCacheDir;
|
|
8
|
+
private getFilePath;
|
|
9
|
+
get(key: string): Promise<any>;
|
|
10
|
+
set(key: string, value: any, ttl?: number): Promise<void>;
|
|
11
|
+
del(key: string): Promise<void>;
|
|
12
|
+
clear(): Promise<void>;
|
|
13
|
+
exists(key: string): Promise<boolean>;
|
|
14
|
+
ttl(key: string): Promise<number>;
|
|
15
|
+
}
|
|
@@ -0,0 +1,128 @@
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.FileCacheAdapter = void 0;
|
|
37
|
+
const logger_1 = require("../../../../logger");
|
|
38
|
+
const logger = (0, logger_1.createFrameworkLogger)("FileCacheAdapter");
|
|
39
|
+
class FileCacheAdapter {
|
|
40
|
+
constructor(options = {}) {
|
|
41
|
+
this.cacheDir = options.cacheDir || "./cache";
|
|
42
|
+
this.ensureCacheDir();
|
|
43
|
+
}
|
|
44
|
+
async ensureCacheDir() {
|
|
45
|
+
const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
|
|
46
|
+
try {
|
|
47
|
+
await fs.mkdir(this.cacheDir, { recursive: true });
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
logger.error("Failed to create cache directory", "FileCache", { error });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
getFilePath(key) {
|
|
54
|
+
const crypto = require("crypto");
|
|
55
|
+
const hash = crypto.createHash("md5").update(key).digest("hex");
|
|
56
|
+
return `${this.cacheDir}/${hash}.json`;
|
|
57
|
+
}
|
|
58
|
+
async get(key) {
|
|
59
|
+
try {
|
|
60
|
+
const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
|
|
61
|
+
const filePath = this.getFilePath(key);
|
|
62
|
+
const data = await fs.readFile(filePath, "utf-8");
|
|
63
|
+
const parsed = JSON.parse(data);
|
|
64
|
+
if (Date.now() > parsed.expires) {
|
|
65
|
+
await this.del(key);
|
|
66
|
+
return null;
|
|
67
|
+
}
|
|
68
|
+
return parsed.value;
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
async set(key, value, ttl = 3600) {
|
|
75
|
+
try {
|
|
76
|
+
const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
|
|
77
|
+
const filePath = this.getFilePath(key);
|
|
78
|
+
const expires = Date.now() + ttl * 1000;
|
|
79
|
+
const data = JSON.stringify({ value, expires });
|
|
80
|
+
await fs.writeFile(filePath, data);
|
|
81
|
+
logger.debug(`Cached item to file: ${key} (TTL: ${ttl}s)`, "FileCache");
|
|
82
|
+
}
|
|
83
|
+
catch (error) {
|
|
84
|
+
logger.error("File cache set error", "FileCache", { key, error });
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
async del(key) {
|
|
88
|
+
try {
|
|
89
|
+
const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
|
|
90
|
+
const filePath = this.getFilePath(key);
|
|
91
|
+
await fs.unlink(filePath);
|
|
92
|
+
logger.debug(`Deleted file cache item: ${key}`, "FileCache");
|
|
93
|
+
}
|
|
94
|
+
catch (error) {
|
|
95
|
+
// File might not exist, which is okay
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
async clear() {
|
|
99
|
+
try {
|
|
100
|
+
const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
|
|
101
|
+
const files = await fs.readdir(this.cacheDir);
|
|
102
|
+
await Promise.all(files.map((file) => fs.unlink(`${this.cacheDir}/${file}`)));
|
|
103
|
+
logger.debug("Cleared all file cache items", "FileCache");
|
|
104
|
+
}
|
|
105
|
+
catch (error) {
|
|
106
|
+
logger.error("File cache clear error", "FileCache", { error });
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
async exists(key) {
|
|
110
|
+
const value = await this.get(key);
|
|
111
|
+
return value !== null;
|
|
112
|
+
}
|
|
113
|
+
async ttl(key) {
|
|
114
|
+
try {
|
|
115
|
+
const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
|
|
116
|
+
const filePath = this.getFilePath(key);
|
|
117
|
+
const data = await fs.readFile(filePath, "utf-8");
|
|
118
|
+
const parsed = JSON.parse(data);
|
|
119
|
+
const remaining = Math.floor((parsed.expires - Date.now()) / 1000);
|
|
120
|
+
return remaining > 0 ? remaining : -1;
|
|
121
|
+
}
|
|
122
|
+
catch (error) {
|
|
123
|
+
return -1;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
exports.FileCacheAdapter = FileCacheAdapter;
|
|
128
|
+
//# sourceMappingURL=file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file.js","sourceRoot":"","sources":["../../../../../../src/core/middleware/built-in/adapters/cache/file.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { MemoryCacheAdapter } from "./memory";
|
|
2
|
+
export { RedisCacheAdapter } from "./redis";
|
|
3
|
+
export { FileCacheAdapter } from "./file";
|
|
4
|
+
import { CacheAdapter } from "../../../../../types/cache";
|
|
5
|
+
export declare function createCacheAdapter(type: string, options?: any): CacheAdapter;
|