@morojs/moro 1.6.0 → 1.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +256 -74
- package/dist/core/auth/morojs-adapter.js +20 -20
- package/dist/core/auth/morojs-adapter.js.map +1 -1
- package/dist/core/config/file-loader.d.ts +6 -1
- package/dist/core/config/file-loader.js +249 -19
- package/dist/core/config/file-loader.js.map +1 -1
- package/dist/core/config/index.d.ts +12 -41
- package/dist/core/config/index.js +54 -65
- package/dist/core/config/index.js.map +1 -1
- package/dist/core/config/loader.d.ts +7 -0
- package/dist/core/config/loader.js +269 -0
- package/dist/core/config/loader.js.map +1 -0
- package/dist/core/config/schema.d.ts +2 -2
- package/dist/core/config/schema.js +44 -52
- package/dist/core/config/schema.js.map +1 -1
- package/dist/core/config/utils.d.ts +3 -10
- package/dist/core/config/utils.js +58 -31
- package/dist/core/config/utils.js.map +1 -1
- package/dist/core/config/validation.d.ts +17 -0
- package/dist/core/config/validation.js +131 -0
- package/dist/core/config/validation.js.map +1 -0
- package/dist/core/database/adapters/drizzle.d.ts +1 -1
- package/dist/core/database/adapters/drizzle.js +11 -18
- package/dist/core/database/adapters/drizzle.js.map +1 -1
- package/dist/core/database/adapters/index.d.ts +7 -7
- package/dist/core/database/adapters/index.js +29 -19
- package/dist/core/database/adapters/index.js.map +1 -1
- package/dist/core/database/adapters/mongodb.d.ts +1 -13
- package/dist/core/database/adapters/mongodb.js +10 -46
- package/dist/core/database/adapters/mongodb.js.map +1 -1
- package/dist/core/database/adapters/mysql.d.ts +1 -14
- package/dist/core/database/adapters/mysql.js +9 -19
- package/dist/core/database/adapters/mysql.js.map +1 -1
- package/dist/core/database/adapters/postgresql.d.ts +2 -12
- package/dist/core/database/adapters/postgresql.js +9 -19
- package/dist/core/database/adapters/postgresql.js.map +1 -1
- package/dist/core/database/adapters/redis.d.ts +1 -12
- package/dist/core/database/adapters/redis.js +13 -48
- package/dist/core/database/adapters/redis.js.map +1 -1
- package/dist/core/database/adapters/sqlite.d.ts +1 -3
- package/dist/core/database/adapters/sqlite.js +8 -19
- package/dist/core/database/adapters/sqlite.js.map +1 -1
- package/dist/core/database/index.d.ts +2 -2
- package/dist/core/database/index.js +18 -2
- package/dist/core/database/index.js.map +1 -1
- package/dist/core/docs/index.d.ts +9 -9
- package/dist/core/docs/index.js +35 -14
- package/dist/core/docs/index.js.map +1 -1
- package/dist/core/docs/openapi-generator.d.ts +2 -2
- package/dist/core/docs/openapi-generator.js +16 -11
- package/dist/core/docs/openapi-generator.js.map +1 -1
- package/dist/core/docs/schema-to-openapi.d.ts +2 -2
- package/dist/core/docs/schema-to-openapi.js +11 -5
- package/dist/core/docs/schema-to-openapi.js.map +1 -1
- package/dist/core/docs/simple-docs.d.ts +1 -1
- package/dist/core/docs/simple-docs.js +9 -4
- package/dist/core/docs/simple-docs.js.map +1 -1
- package/dist/core/docs/swagger-ui.d.ts +2 -2
- package/dist/core/docs/swagger-ui.js +29 -26
- package/dist/core/docs/swagger-ui.js.map +1 -1
- package/dist/core/docs/zod-to-openapi.js +28 -31
- package/dist/core/docs/zod-to-openapi.js.map +1 -1
- package/dist/core/events/event-bus.d.ts +1 -1
- package/dist/core/events/event-bus.js +10 -6
- package/dist/core/events/event-bus.js.map +1 -1
- package/dist/core/events/index.d.ts +2 -2
- package/dist/core/events/index.js +5 -1
- package/dist/core/events/index.js.map +1 -1
- package/dist/core/framework.d.ts +12 -19
- package/dist/core/framework.js +100 -277
- package/dist/core/framework.js.map +1 -1
- package/dist/core/http/http-server.d.ts +1 -13
- package/dist/core/http/http-server.js +85 -175
- package/dist/core/http/http-server.js.map +1 -1
- package/dist/core/http/index.d.ts +3 -4
- package/dist/core/http/index.js +8 -3
- package/dist/core/http/index.js.map +1 -1
- package/dist/core/http/router.d.ts +1 -13
- package/dist/core/http/router.js +43 -117
- package/dist/core/http/router.js.map +1 -1
- package/dist/core/logger/filters.d.ts +1 -1
- package/dist/core/logger/filters.js +23 -20
- package/dist/core/logger/filters.js.map +1 -1
- package/dist/core/logger/index.d.ts +3 -3
- package/dist/core/logger/index.js +24 -2
- package/dist/core/logger/index.js.map +1 -1
- package/dist/core/logger/logger.d.ts +14 -30
- package/dist/core/logger/logger.js +223 -398
- package/dist/core/logger/logger.js.map +1 -1
- package/dist/core/logger/outputs.d.ts +1 -1
- package/dist/core/logger/outputs.js +17 -8
- package/dist/core/logger/outputs.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cache/file.d.ts +1 -1
- package/dist/core/middleware/built-in/adapters/cache/file.js +47 -10
- package/dist/core/middleware/built-in/adapters/cache/file.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cache/index.d.ts +4 -4
- package/dist/core/middleware/built-in/adapters/cache/index.js +17 -10
- package/dist/core/middleware/built-in/adapters/cache/index.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cache/memory.d.ts +1 -1
- package/dist/core/middleware/built-in/adapters/cache/memory.js +7 -3
- package/dist/core/middleware/built-in/adapters/cache/memory.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cache/redis.d.ts +1 -3
- package/dist/core/middleware/built-in/adapters/cache/redis.js +9 -11
- package/dist/core/middleware/built-in/adapters/cache/redis.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cdn/azure.d.ts +1 -1
- package/dist/core/middleware/built-in/adapters/cdn/azure.js +7 -3
- package/dist/core/middleware/built-in/adapters/cdn/azure.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.d.ts +1 -1
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js +7 -3
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.d.ts +1 -3
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js +10 -12
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/cdn/index.d.ts +4 -4
- package/dist/core/middleware/built-in/adapters/cdn/index.js +17 -10
- package/dist/core/middleware/built-in/adapters/cdn/index.js.map +1 -1
- package/dist/core/middleware/built-in/adapters/index.d.ts +4 -4
- package/dist/core/middleware/built-in/adapters/index.js +23 -4
- package/dist/core/middleware/built-in/adapters/index.js.map +1 -1
- package/dist/core/middleware/built-in/auth-helpers.js +22 -11
- package/dist/core/middleware/built-in/auth-helpers.js.map +1 -1
- package/dist/core/middleware/built-in/auth-providers.d.ts +1 -1
- package/dist/core/middleware/built-in/auth-providers.js +9 -4
- package/dist/core/middleware/built-in/auth-providers.js.map +1 -1
- package/dist/core/middleware/built-in/auth.d.ts +2 -2
- package/dist/core/middleware/built-in/auth.js +26 -93
- package/dist/core/middleware/built-in/auth.js.map +1 -1
- package/dist/core/middleware/built-in/cache.d.ts +2 -2
- package/dist/core/middleware/built-in/cache.js +12 -11
- package/dist/core/middleware/built-in/cache.js.map +1 -1
- package/dist/core/middleware/built-in/cdn.d.ts +2 -2
- package/dist/core/middleware/built-in/cdn.js +9 -5
- package/dist/core/middleware/built-in/cdn.js.map +1 -1
- package/dist/core/middleware/built-in/cookie.d.ts +1 -1
- package/dist/core/middleware/built-in/cookie.js +7 -3
- package/dist/core/middleware/built-in/cookie.js.map +1 -1
- package/dist/core/middleware/built-in/cors.d.ts +1 -1
- package/dist/core/middleware/built-in/cors.js +7 -3
- package/dist/core/middleware/built-in/cors.js.map +1 -1
- package/dist/core/middleware/built-in/csp.d.ts +1 -1
- package/dist/core/middleware/built-in/csp.js +8 -5
- package/dist/core/middleware/built-in/csp.js.map +1 -1
- package/dist/core/middleware/built-in/csrf.d.ts +1 -1
- package/dist/core/middleware/built-in/csrf.js +8 -5
- package/dist/core/middleware/built-in/csrf.js.map +1 -1
- package/dist/core/middleware/built-in/error-tracker.js +7 -3
- package/dist/core/middleware/built-in/error-tracker.js.map +1 -1
- package/dist/core/middleware/built-in/index.d.ts +27 -28
- package/dist/core/middleware/built-in/index.js +78 -48
- package/dist/core/middleware/built-in/index.js.map +1 -1
- package/dist/core/middleware/built-in/performance-monitor.js +7 -3
- package/dist/core/middleware/built-in/performance-monitor.js.map +1 -1
- package/dist/core/middleware/built-in/rate-limit.d.ts +1 -1
- package/dist/core/middleware/built-in/rate-limit.js +7 -3
- package/dist/core/middleware/built-in/rate-limit.js.map +1 -1
- package/dist/core/middleware/built-in/request-logger.js +8 -5
- package/dist/core/middleware/built-in/request-logger.js.map +1 -1
- package/dist/core/middleware/built-in/session.d.ts +2 -2
- package/dist/core/middleware/built-in/session.js +15 -11
- package/dist/core/middleware/built-in/session.js.map +1 -1
- package/dist/core/middleware/built-in/sse.d.ts +1 -1
- package/dist/core/middleware/built-in/sse.js +14 -12
- package/dist/core/middleware/built-in/sse.js.map +1 -1
- package/dist/core/middleware/built-in/validation.d.ts +1 -1
- package/dist/core/middleware/built-in/validation.js +7 -3
- package/dist/core/middleware/built-in/validation.js.map +1 -1
- package/dist/core/middleware/index.d.ts +4 -4
- package/dist/core/middleware/index.js +28 -8
- package/dist/core/middleware/index.js.map +1 -1
- package/dist/core/modules/auto-discovery.d.ts +2 -19
- package/dist/core/modules/auto-discovery.js +74 -391
- package/dist/core/modules/auto-discovery.js.map +1 -1
- package/dist/core/modules/index.d.ts +2 -2
- package/dist/core/modules/index.js +9 -2
- package/dist/core/modules/index.js.map +1 -1
- package/dist/core/modules/modules.d.ts +3 -3
- package/dist/core/modules/modules.js +54 -23
- package/dist/core/modules/modules.js.map +1 -1
- package/dist/core/networking/adapters/index.d.ts +3 -4
- package/dist/core/networking/adapters/index.js +7 -3
- package/dist/core/networking/adapters/index.js.map +1 -1
- package/dist/core/networking/adapters/socketio-adapter.d.ts +1 -1
- package/dist/core/networking/adapters/socketio-adapter.js +40 -5
- package/dist/core/networking/adapters/socketio-adapter.js.map +1 -1
- package/dist/core/networking/adapters/ws-adapter.d.ts +2 -2
- package/dist/core/networking/adapters/ws-adapter.js +43 -8
- package/dist/core/networking/adapters/ws-adapter.js.map +1 -1
- package/dist/core/networking/index.d.ts +2 -3
- package/dist/core/networking/index.js +7 -2
- package/dist/core/networking/index.js.map +1 -1
- package/dist/core/networking/service-discovery.js +12 -8
- package/dist/core/networking/service-discovery.js.map +1 -1
- package/dist/core/networking/websocket-adapter.js +2 -1
- package/dist/core/networking/websocket-adapter.js.map +1 -1
- package/dist/core/networking/websocket-manager.d.ts +3 -3
- package/dist/core/networking/websocket-manager.js +11 -9
- package/dist/core/networking/websocket-manager.js.map +1 -1
- package/dist/core/routing/app-integration.d.ts +2 -2
- package/dist/core/routing/app-integration.js +12 -7
- package/dist/core/routing/app-integration.js.map +1 -1
- package/dist/core/routing/index.d.ts +2 -22
- package/dist/core/routing/index.js +27 -185
- package/dist/core/routing/index.js.map +1 -1
- package/dist/core/runtime/aws-lambda-adapter.d.ts +3 -3
- package/dist/core/runtime/aws-lambda-adapter.js +6 -2
- package/dist/core/runtime/aws-lambda-adapter.js.map +1 -1
- package/dist/core/runtime/base-adapter.d.ts +2 -2
- package/dist/core/runtime/base-adapter.js +7 -3
- package/dist/core/runtime/base-adapter.js.map +1 -1
- package/dist/core/runtime/cloudflare-workers-adapter.d.ts +3 -3
- package/dist/core/runtime/cloudflare-workers-adapter.js +6 -2
- package/dist/core/runtime/cloudflare-workers-adapter.js.map +1 -1
- package/dist/core/runtime/index.d.ts +12 -12
- package/dist/core/runtime/index.js +35 -22
- package/dist/core/runtime/index.js.map +1 -1
- package/dist/core/runtime/node-adapter.d.ts +4 -4
- package/dist/core/runtime/node-adapter.js +49 -18
- package/dist/core/runtime/node-adapter.js.map +1 -1
- package/dist/core/runtime/vercel-edge-adapter.d.ts +3 -3
- package/dist/core/runtime/vercel-edge-adapter.js +6 -2
- package/dist/core/runtime/vercel-edge-adapter.js.map +1 -1
- package/dist/core/utilities/circuit-breaker.js +5 -1
- package/dist/core/utilities/circuit-breaker.js.map +1 -1
- package/dist/core/utilities/container.js +22 -12
- package/dist/core/utilities/container.js.map +1 -1
- package/dist/core/utilities/hooks.d.ts +2 -2
- package/dist/core/utilities/hooks.js +12 -7
- package/dist/core/utilities/hooks.js.map +1 -1
- package/dist/core/utilities/index.d.ts +4 -5
- package/dist/core/utilities/index.js +19 -5
- package/dist/core/utilities/index.js.map +1 -1
- package/dist/core/validation/adapters.d.ts +1 -1
- package/dist/core/validation/adapters.js +26 -15
- package/dist/core/validation/adapters.js.map +1 -1
- package/dist/core/validation/index.d.ts +4 -6
- package/dist/core/validation/index.js +28 -57
- package/dist/core/validation/index.js.map +1 -1
- package/dist/core/validation/schema-interface.js +9 -3
- package/dist/core/validation/schema-interface.js.map +1 -1
- package/dist/index.d.ts +52 -51
- package/dist/index.js +132 -23
- package/dist/index.js.map +1 -1
- package/dist/moro.d.ts +10 -61
- package/dist/moro.js +237 -575
- package/dist/moro.js.map +1 -1
- package/dist/types/auth.js +9 -3
- package/dist/types/auth.js.map +1 -1
- package/dist/types/cache.js +2 -1
- package/dist/types/cdn.js +2 -1
- package/dist/types/config.d.ts +2 -70
- package/dist/types/config.js +2 -1
- package/dist/types/config.js.map +1 -1
- package/dist/types/core.d.ts +42 -36
- package/dist/types/core.js +2 -1
- package/dist/types/database.js +2 -1
- package/dist/types/discovery.js +2 -1
- package/dist/types/events.js +2 -1
- package/dist/types/hooks.d.ts +1 -1
- package/dist/types/hooks.js +2 -1
- package/dist/types/http.d.ts +1 -16
- package/dist/types/http.js +2 -1
- package/dist/types/logger.d.ts +0 -7
- package/dist/types/logger.js +2 -1
- package/dist/types/module.d.ts +0 -11
- package/dist/types/module.js +2 -1
- package/dist/types/runtime.d.ts +1 -1
- package/dist/types/runtime.js +2 -1
- package/dist/types/session.js +2 -1
- package/package.json +52 -19
- package/src/core/auth/morojs-adapter.ts +13 -18
- package/src/core/config/file-loader.ts +273 -13
- package/src/core/config/index.ts +34 -83
- package/src/core/config/loader.ts +633 -0
- package/src/core/config/schema.ts +33 -44
- package/src/core/config/utils.ts +31 -24
- package/src/core/config/validation.ts +140 -0
- package/src/core/database/README.md +16 -26
- package/src/core/database/adapters/drizzle.ts +6 -18
- package/src/core/database/adapters/index.ts +13 -13
- package/src/core/database/adapters/mongodb.ts +5 -53
- package/src/core/database/adapters/mysql.ts +4 -32
- package/src/core/database/adapters/postgresql.ts +5 -30
- package/src/core/database/adapters/redis.ts +8 -61
- package/src/core/database/adapters/sqlite.ts +3 -19
- package/src/core/database/index.ts +2 -2
- package/src/core/docs/index.ts +8 -8
- package/src/core/docs/openapi-generator.ts +4 -4
- package/src/core/docs/schema-to-openapi.ts +6 -3
- package/src/core/docs/simple-docs.ts +2 -2
- package/src/core/docs/swagger-ui.ts +16 -19
- package/src/core/docs/zod-to-openapi.ts +34 -34
- package/src/core/events/event-bus.ts +2 -2
- package/src/core/events/index.ts +2 -2
- package/src/core/framework.ts +67 -311
- package/src/core/http/http-server.ts +45 -190
- package/src/core/http/index.ts +3 -4
- package/src/core/http/router.ts +40 -129
- package/src/core/logger/filters.ts +5 -13
- package/src/core/logger/index.ts +3 -4
- package/src/core/logger/logger.ts +216 -435
- package/src/core/logger/outputs.ts +3 -1
- package/src/core/middleware/built-in/adapters/cache/file.ts +3 -3
- package/src/core/middleware/built-in/adapters/cache/index.ts +7 -7
- package/src/core/middleware/built-in/adapters/cache/memory.ts +2 -2
- package/src/core/middleware/built-in/adapters/cache/redis.ts +4 -18
- package/src/core/middleware/built-in/adapters/cdn/azure.ts +2 -2
- package/src/core/middleware/built-in/adapters/cdn/cloudflare.ts +2 -2
- package/src/core/middleware/built-in/adapters/cdn/cloudfront.ts +5 -16
- package/src/core/middleware/built-in/adapters/cdn/index.ts +7 -7
- package/src/core/middleware/built-in/adapters/index.ts +4 -4
- package/src/core/middleware/built-in/auth-helpers.ts +1 -1
- package/src/core/middleware/built-in/auth-providers.ts +1 -1
- package/src/core/middleware/built-in/auth.ts +21 -102
- package/src/core/middleware/built-in/cache.ts +6 -8
- package/src/core/middleware/built-in/cdn.ts +4 -4
- package/src/core/middleware/built-in/cookie.ts +2 -2
- package/src/core/middleware/built-in/cors.ts +2 -2
- package/src/core/middleware/built-in/csp.ts +3 -3
- package/src/core/middleware/built-in/csrf.ts +3 -3
- package/src/core/middleware/built-in/error-tracker.ts +1 -1
- package/src/core/middleware/built-in/index.ts +30 -38
- package/src/core/middleware/built-in/performance-monitor.ts +1 -1
- package/src/core/middleware/built-in/rate-limit.ts +2 -2
- package/src/core/middleware/built-in/request-logger.ts +1 -3
- package/src/core/middleware/built-in/session.ts +8 -7
- package/src/core/middleware/built-in/sse.ts +9 -11
- package/src/core/middleware/built-in/validation.ts +2 -2
- package/src/core/middleware/index.ts +6 -6
- package/src/core/modules/auto-discovery.ts +15 -478
- package/src/core/modules/index.ts +2 -2
- package/src/core/modules/modules.ts +12 -23
- package/src/core/networking/adapters/index.ts +3 -4
- package/src/core/networking/adapters/socketio-adapter.ts +3 -5
- package/src/core/networking/adapters/ws-adapter.ts +9 -8
- package/src/core/networking/index.ts +2 -3
- package/src/core/networking/service-discovery.ts +7 -6
- package/src/core/networking/websocket-manager.ts +7 -7
- package/src/core/routing/app-integration.ts +3 -3
- package/src/core/routing/index.ts +17 -201
- package/src/core/runtime/aws-lambda-adapter.ts +3 -3
- package/src/core/runtime/base-adapter.ts +2 -2
- package/src/core/runtime/cloudflare-workers-adapter.ts +3 -3
- package/src/core/runtime/index.ts +13 -13
- package/src/core/runtime/node-adapter.ts +10 -16
- package/src/core/runtime/vercel-edge-adapter.ts +3 -3
- package/src/core/utilities/hooks.ts +3 -3
- package/src/core/utilities/index.ts +4 -5
- package/src/core/validation/adapters.ts +1 -1
- package/src/core/validation/index.ts +16 -68
- package/src/index.ts +66 -73
- package/src/moro.ts +204 -685
- package/src/types/config.ts +2 -71
- package/src/types/core.ts +47 -49
- package/src/types/hooks.ts +1 -1
- package/src/types/http.ts +1 -23
- package/src/types/logger.ts +0 -9
- package/src/types/module.ts +0 -12
- package/src/types/runtime.ts +1 -1
- package/tsconfig.json +2 -4
- package/dist/core/config/config-manager.d.ts +0 -44
- package/dist/core/config/config-manager.js +0 -104
- package/dist/core/config/config-manager.js.map +0 -1
- package/dist/core/config/config-sources.d.ts +0 -21
- package/dist/core/config/config-sources.js +0 -499
- package/dist/core/config/config-sources.js.map +0 -1
- package/dist/core/config/config-validator.d.ts +0 -21
- package/dist/core/config/config-validator.js +0 -788
- package/dist/core/config/config-validator.js.map +0 -1
- package/dist/core/http/uws-http-server.d.ts +0 -64
- package/dist/core/http/uws-http-server.js +0 -688
- package/dist/core/http/uws-http-server.js.map +0 -1
- package/dist/core/middleware/built-in/jwt-helpers.d.ts +0 -118
- package/dist/core/middleware/built-in/jwt-helpers.js +0 -218
- package/dist/core/middleware/built-in/jwt-helpers.js.map +0 -1
- package/dist/core/networking/adapters/uws-adapter.d.ts +0 -44
- package/dist/core/networking/adapters/uws-adapter.js +0 -513
- package/dist/core/networking/adapters/uws-adapter.js.map +0 -1
- package/dist/core/utilities/package-utils.d.ts +0 -38
- package/dist/core/utilities/package-utils.js +0 -57
- package/dist/core/utilities/package-utils.js.map +0 -1
- package/jest.config.mjs +0 -41
- package/src/core/config/config-manager.ts +0 -133
- package/src/core/config/config-sources.ts +0 -596
- package/src/core/config/config-validator.ts +0 -1113
- package/src/core/http/uws-http-server.ts +0 -794
- package/src/core/middleware/built-in/jwt-helpers.ts +0 -243
- package/src/core/networking/adapters/uws-adapter.ts +0 -619
- package/src/core/utilities/package-utils.ts +0 -59
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// Advanced Logger Outputs
|
|
2
2
|
import { writeFile, appendFile, mkdir } from 'fs/promises';
|
|
3
3
|
import { join, dirname } from 'path';
|
|
4
|
-
import { LogEntry, LogOutput } from '../../types/logger
|
|
4
|
+
import { LogEntry, LogOutput } from '../../types/logger';
|
|
5
5
|
|
|
6
6
|
// File output for persistent logging
|
|
7
7
|
export class FileOutput implements LogOutput {
|
|
@@ -29,6 +29,7 @@ export class FileOutput implements LogOutput {
|
|
|
29
29
|
|
|
30
30
|
// TODO: Implement log rotation if needed
|
|
31
31
|
} catch (error) {
|
|
32
|
+
// Use console.error as fallback since this is the logger itself
|
|
32
33
|
console.error('File logger error:', error);
|
|
33
34
|
}
|
|
34
35
|
}
|
|
@@ -76,6 +77,7 @@ export class WebhookOutput implements LogOutput {
|
|
|
76
77
|
throw new Error(`Webhook failed: ${response.status}`);
|
|
77
78
|
}
|
|
78
79
|
} catch (error) {
|
|
80
|
+
// Use console.error as fallback since this is the logger itself
|
|
79
81
|
console.error('Webhook logger error:', error);
|
|
80
82
|
}
|
|
81
83
|
}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
// File System Cache Adapter
|
|
2
|
-
import { CacheAdapter } from '../../../../../types/cache
|
|
3
|
-
import { createFrameworkLogger } from '../../../../logger
|
|
4
|
-
import crypto from 'crypto';
|
|
2
|
+
import { CacheAdapter } from '../../../../../types/cache';
|
|
3
|
+
import { createFrameworkLogger } from '../../../../logger';
|
|
5
4
|
|
|
6
5
|
const logger = createFrameworkLogger('FileCacheAdapter');
|
|
7
6
|
|
|
@@ -23,6 +22,7 @@ export class FileCacheAdapter implements CacheAdapter {
|
|
|
23
22
|
}
|
|
24
23
|
|
|
25
24
|
private getFilePath(key: string): string {
|
|
25
|
+
const crypto = require('crypto');
|
|
26
26
|
const hash = crypto.createHash('md5').update(key).digest('hex');
|
|
27
27
|
return `${this.cacheDir}/${hash}.json`;
|
|
28
28
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
// Cache Adapters
|
|
2
|
-
export { MemoryCacheAdapter } from './memory
|
|
3
|
-
export { RedisCacheAdapter } from './redis
|
|
4
|
-
export { FileCacheAdapter } from './file
|
|
2
|
+
export { MemoryCacheAdapter } from './memory';
|
|
3
|
+
export { RedisCacheAdapter } from './redis';
|
|
4
|
+
export { FileCacheAdapter } from './file';
|
|
5
5
|
|
|
6
|
-
import { MemoryCacheAdapter } from './memory
|
|
7
|
-
import { RedisCacheAdapter } from './redis
|
|
8
|
-
import { FileCacheAdapter } from './file
|
|
9
|
-
import { CacheAdapter } from '../../../../../types/cache
|
|
6
|
+
import { MemoryCacheAdapter } from './memory';
|
|
7
|
+
import { RedisCacheAdapter } from './redis';
|
|
8
|
+
import { FileCacheAdapter } from './file';
|
|
9
|
+
import { CacheAdapter } from '../../../../../types/cache';
|
|
10
10
|
|
|
11
11
|
// Adapter factory function for auto-loading
|
|
12
12
|
export function createCacheAdapter(type: string, options: any = {}): CacheAdapter {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// Memory Cache Adapter
|
|
2
|
-
import { CacheAdapter } from '../../../../../types/cache
|
|
3
|
-
import { createFrameworkLogger } from '../../../../logger
|
|
2
|
+
import { CacheAdapter } from '../../../../../types/cache';
|
|
3
|
+
import { createFrameworkLogger } from '../../../../logger';
|
|
4
4
|
|
|
5
5
|
const logger = createFrameworkLogger('MemoryCacheAdapter');
|
|
6
6
|
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
// Redis Cache Adapter
|
|
2
|
-
import { CacheAdapter } from '../../../../../types/cache
|
|
3
|
-
import { createFrameworkLogger } from '../../../../logger
|
|
4
|
-
import { resolveUserPackage } from '../../../../utilities/package-utils.js';
|
|
2
|
+
import { CacheAdapter } from '../../../../../types/cache';
|
|
3
|
+
import { createFrameworkLogger } from '../../../../logger';
|
|
5
4
|
|
|
6
5
|
const logger = createFrameworkLogger('RedisCacheAdapter');
|
|
7
6
|
|
|
@@ -17,22 +16,9 @@ export class RedisCacheAdapter implements CacheAdapter {
|
|
|
17
16
|
keyPrefix?: string;
|
|
18
17
|
} = {}
|
|
19
18
|
) {
|
|
20
|
-
this.initPromise = this.initialize(options);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
private initPromise: Promise<void>;
|
|
24
|
-
|
|
25
|
-
private async initialize(options: {
|
|
26
|
-
host?: string;
|
|
27
|
-
port?: number;
|
|
28
|
-
password?: string;
|
|
29
|
-
db?: number;
|
|
30
|
-
keyPrefix?: string;
|
|
31
|
-
}): Promise<void> {
|
|
32
19
|
try {
|
|
33
|
-
const
|
|
34
|
-
|
|
35
|
-
this.client = redis.default.createClient({
|
|
20
|
+
const redis = require('redis');
|
|
21
|
+
this.client = redis.createClient({
|
|
36
22
|
host: options.host || 'localhost',
|
|
37
23
|
port: options.port || 6379,
|
|
38
24
|
password: options.password,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// Azure CDN Adapter
|
|
2
|
-
import { CDNAdapter } from '../../../../../types/cdn
|
|
3
|
-
import { createFrameworkLogger } from '../../../../logger
|
|
2
|
+
import { CDNAdapter } from '../../../../../types/cdn';
|
|
3
|
+
import { createFrameworkLogger } from '../../../../logger';
|
|
4
4
|
|
|
5
5
|
const logger = createFrameworkLogger('AzureCDNAdapter');
|
|
6
6
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// Cloudflare CDN Adapter
|
|
2
|
-
import { CDNAdapter } from '../../../../../types/cdn
|
|
3
|
-
import { createFrameworkLogger } from '../../../../logger
|
|
2
|
+
import { CDNAdapter } from '../../../../../types/cdn';
|
|
3
|
+
import { createFrameworkLogger } from '../../../../logger';
|
|
4
4
|
|
|
5
5
|
const logger = createFrameworkLogger('CloudflareCDNAdapter');
|
|
6
6
|
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
// AWS CloudFront CDN Adapter
|
|
2
|
-
import { CDNAdapter } from '../../../../../types/cdn
|
|
3
|
-
import { createFrameworkLogger } from '../../../../logger
|
|
4
|
-
import { resolveUserPackage } from '../../../../utilities/package-utils.js';
|
|
2
|
+
import { CDNAdapter } from '../../../../../types/cdn';
|
|
3
|
+
import { createFrameworkLogger } from '../../../../logger';
|
|
5
4
|
|
|
6
5
|
const logger = createFrameworkLogger('CloudFrontCDNAdapter');
|
|
7
6
|
|
|
@@ -16,26 +15,16 @@ export class CloudFrontCDNAdapter implements CDNAdapter {
|
|
|
16
15
|
distributionId: string;
|
|
17
16
|
}) {
|
|
18
17
|
this.distributionId = options.distributionId;
|
|
19
|
-
this.initPromise = this.initialize(options);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
private initPromise: Promise<void>;
|
|
23
18
|
|
|
24
|
-
private async initialize(options: {
|
|
25
|
-
accessKeyId: string;
|
|
26
|
-
secretAccessKey: string;
|
|
27
|
-
region: string;
|
|
28
|
-
}): Promise<void> {
|
|
29
19
|
try {
|
|
30
|
-
const
|
|
31
|
-
|
|
32
|
-
AWS.default.config.update({
|
|
20
|
+
const AWS = require('aws-sdk');
|
|
21
|
+
AWS.config.update({
|
|
33
22
|
accessKeyId: options.accessKeyId,
|
|
34
23
|
secretAccessKey: options.secretAccessKey,
|
|
35
24
|
region: options.region,
|
|
36
25
|
});
|
|
37
26
|
|
|
38
|
-
this.cloudfront = new AWS.
|
|
27
|
+
this.cloudfront = new AWS.CloudFront();
|
|
39
28
|
logger.info('CloudFront CDN adapter initialized', 'CloudFront');
|
|
40
29
|
} catch (error) {
|
|
41
30
|
logger.error('AWS SDK not available', 'CloudFront');
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
// CDN Adapters
|
|
2
|
-
export { CloudflareCDNAdapter } from './cloudflare
|
|
3
|
-
export { CloudFrontCDNAdapter } from './cloudfront
|
|
4
|
-
export { AzureCDNAdapter } from './azure
|
|
2
|
+
export { CloudflareCDNAdapter } from './cloudflare';
|
|
3
|
+
export { CloudFrontCDNAdapter } from './cloudfront';
|
|
4
|
+
export { AzureCDNAdapter } from './azure';
|
|
5
5
|
|
|
6
|
-
import { CloudflareCDNAdapter } from './cloudflare
|
|
7
|
-
import { CloudFrontCDNAdapter } from './cloudfront
|
|
8
|
-
import { AzureCDNAdapter } from './azure
|
|
9
|
-
import { CDNAdapter } from '../../../../../types/cdn
|
|
6
|
+
import { CloudflareCDNAdapter } from './cloudflare';
|
|
7
|
+
import { CloudFrontCDNAdapter } from './cloudfront';
|
|
8
|
+
import { AzureCDNAdapter } from './azure';
|
|
9
|
+
import { CDNAdapter } from '../../../../../types/cdn';
|
|
10
10
|
|
|
11
11
|
// Adapter factory function for auto-loading
|
|
12
12
|
export function createCDNAdapter(type: string, options: any = {}): CDNAdapter {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
// Adapters Index
|
|
2
|
-
export * from './cache
|
|
3
|
-
export * from './cdn
|
|
2
|
+
export * from './cache';
|
|
3
|
+
export * from './cdn';
|
|
4
4
|
|
|
5
5
|
// Re-export factory functions for convenience
|
|
6
|
-
export { createCacheAdapter } from './cache
|
|
7
|
-
export { createCDNAdapter } from './cdn
|
|
6
|
+
export { createCacheAdapter } from './cache';
|
|
7
|
+
export { createCDNAdapter } from './cdn';
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
// Auth.js Authentication Middleware
|
|
2
2
|
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import { createFrameworkLogger } from '../../logger/index.js';
|
|
3
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
4
|
+
import { createFrameworkLogger } from '../../logger';
|
|
6
5
|
import {
|
|
7
6
|
AuthOptions,
|
|
8
7
|
AuthProvider,
|
|
@@ -12,8 +11,7 @@ import {
|
|
|
12
11
|
OAuthProvider,
|
|
13
12
|
CredentialsProvider,
|
|
14
13
|
EmailProvider,
|
|
15
|
-
} from '../../../types/auth
|
|
16
|
-
import { safeVerifyJWT, createAuthErrorResponse } from './jwt-helpers.js';
|
|
14
|
+
} from '../../../types/auth';
|
|
17
15
|
|
|
18
16
|
const logger = createFrameworkLogger('AuthMiddleware');
|
|
19
17
|
|
|
@@ -153,15 +151,7 @@ export const auth = (options: AuthOptions): MiddlewareInterface => ({
|
|
|
153
151
|
return authInstance.getSession({ req });
|
|
154
152
|
},
|
|
155
153
|
getToken: async () => {
|
|
156
|
-
|
|
157
|
-
return authInstance.verifyJWT(authRequest.token || '');
|
|
158
|
-
} catch (error: any) {
|
|
159
|
-
// Handle JWT errors gracefully in getToken method
|
|
160
|
-
logger.debug('Failed to verify token in getToken', 'TokenValidation', {
|
|
161
|
-
error: error.message,
|
|
162
|
-
});
|
|
163
|
-
return null;
|
|
164
|
-
}
|
|
154
|
+
return authInstance.verifyJWT(authRequest.token || '');
|
|
165
155
|
},
|
|
166
156
|
getCsrfToken: async () => {
|
|
167
157
|
return authInstance.getCsrfToken();
|
|
@@ -187,60 +177,8 @@ export const auth = (options: AuthOptions): MiddlewareInterface => ({
|
|
|
187
177
|
if (decoded) {
|
|
188
178
|
session = await authInstance.getSession({ req: { ...req, token } });
|
|
189
179
|
}
|
|
190
|
-
} catch (error
|
|
191
|
-
|
|
192
|
-
if (error.name === 'TokenExpiredError') {
|
|
193
|
-
logger.debug('JWT token expired', 'TokenValidation', {
|
|
194
|
-
message: error.message,
|
|
195
|
-
expiredAt: error.expiredAt,
|
|
196
|
-
});
|
|
197
|
-
|
|
198
|
-
// If this is a protected route request, return a proper 401 response
|
|
199
|
-
if (req.headers.accept?.includes('application/json')) {
|
|
200
|
-
return res.status(401).json(
|
|
201
|
-
createAuthErrorResponse({
|
|
202
|
-
type: 'expired',
|
|
203
|
-
message: error.message,
|
|
204
|
-
expiredAt: error.expiredAt,
|
|
205
|
-
})
|
|
206
|
-
);
|
|
207
|
-
}
|
|
208
|
-
} else if (error.name === 'JsonWebTokenError') {
|
|
209
|
-
logger.debug('Invalid JWT token format', 'TokenValidation', {
|
|
210
|
-
message: error.message,
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
// If this is a protected route request, return a proper 401 response
|
|
214
|
-
if (req.headers.accept?.includes('application/json')) {
|
|
215
|
-
return res.status(401).json(
|
|
216
|
-
createAuthErrorResponse({
|
|
217
|
-
type: 'invalid',
|
|
218
|
-
message: error.message,
|
|
219
|
-
})
|
|
220
|
-
);
|
|
221
|
-
}
|
|
222
|
-
} else if (error.name === 'NotBeforeError') {
|
|
223
|
-
logger.debug('JWT token not active yet', 'TokenValidation', {
|
|
224
|
-
message: error.message,
|
|
225
|
-
date: error.date,
|
|
226
|
-
});
|
|
227
|
-
|
|
228
|
-
// If this is a protected route request, return a proper 401 response
|
|
229
|
-
if (req.headers.accept?.includes('application/json')) {
|
|
230
|
-
return res.status(401).json(
|
|
231
|
-
createAuthErrorResponse({
|
|
232
|
-
type: 'malformed',
|
|
233
|
-
message: error.message,
|
|
234
|
-
date: error.date,
|
|
235
|
-
})
|
|
236
|
-
);
|
|
237
|
-
}
|
|
238
|
-
} else {
|
|
239
|
-
logger.debug('JWT token validation failed', 'TokenValidation', {
|
|
240
|
-
error: error.message || error,
|
|
241
|
-
});
|
|
242
|
-
}
|
|
243
|
-
// Continue with unauthenticated state for non-API requests
|
|
180
|
+
} catch (error) {
|
|
181
|
+
logger.debug('Invalid JWT token', 'TokenValidation', { error });
|
|
244
182
|
}
|
|
245
183
|
}
|
|
246
184
|
|
|
@@ -291,11 +229,11 @@ export const auth = (options: AuthOptions): MiddlewareInterface => ({
|
|
|
291
229
|
},
|
|
292
230
|
});
|
|
293
231
|
|
|
294
|
-
// Auth.js implementation with
|
|
232
|
+
// Mock Auth.js implementation (would be replaced with actual Auth.js)
|
|
295
233
|
async function initializeAuthJS(config: AuthOptions): Promise<any> {
|
|
296
234
|
return {
|
|
297
235
|
handler: async (req: any, res: any) => {
|
|
298
|
-
//
|
|
236
|
+
// Mock Auth.js request handler
|
|
299
237
|
const path = req.url.replace(config.basePath!, '');
|
|
300
238
|
|
|
301
239
|
if (path.startsWith('/signin')) {
|
|
@@ -316,7 +254,7 @@ async function initializeAuthJS(config: AuthOptions): Promise<any> {
|
|
|
316
254
|
},
|
|
317
255
|
|
|
318
256
|
getSession: async ({ req }: { req: any }) => {
|
|
319
|
-
//
|
|
257
|
+
// Mock session retrieval
|
|
320
258
|
const sessionId =
|
|
321
259
|
req.cookies?.['next-auth.session-token'] ||
|
|
322
260
|
req.cookies?.['__Secure-next-auth.session-token'];
|
|
@@ -332,53 +270,34 @@ async function initializeAuthJS(config: AuthOptions): Promise<any> {
|
|
|
332
270
|
},
|
|
333
271
|
|
|
334
272
|
verifyJWT: async (token: string) => {
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
const customError = new Error(result.error?.message || 'JWT verification failed');
|
|
343
|
-
|
|
344
|
-
// Add the error type information for upstream handling
|
|
345
|
-
(customError as any).jwtErrorType = result.error?.type;
|
|
346
|
-
(customError as any).jwtErrorDetails = result.error;
|
|
347
|
-
|
|
348
|
-
// Map the safe error types back to standard JWT error names for compatibility
|
|
349
|
-
if (result.error?.type === 'expired') {
|
|
350
|
-
customError.name = 'TokenExpiredError';
|
|
351
|
-
(customError as any).expiredAt = result.error.expiredAt;
|
|
352
|
-
} else if (result.error?.type === 'invalid') {
|
|
353
|
-
customError.name = 'JsonWebTokenError';
|
|
354
|
-
} else if (result.error?.type === 'malformed') {
|
|
355
|
-
customError.name = 'NotBeforeError';
|
|
356
|
-
(customError as any).date = result.error.date;
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
throw customError;
|
|
273
|
+
// Mock JWT verification
|
|
274
|
+
try {
|
|
275
|
+
// In real implementation, use jose or jsonwebtoken
|
|
276
|
+
const payload = JSON.parse(Buffer.from(token.split('.')[1], 'base64').toString());
|
|
277
|
+
return payload;
|
|
278
|
+
} catch {
|
|
279
|
+
return null;
|
|
360
280
|
}
|
|
361
|
-
|
|
362
|
-
return result.payload;
|
|
363
281
|
},
|
|
364
282
|
|
|
365
283
|
signIn: async (provider?: string, options?: any) => {
|
|
366
|
-
//
|
|
284
|
+
// Mock sign in
|
|
367
285
|
return { url: `${config.basePath}/signin${provider ? `/${provider}` : ''}` };
|
|
368
286
|
},
|
|
369
287
|
|
|
370
288
|
signOut: async (options?: any) => {
|
|
371
|
-
//
|
|
289
|
+
// Mock sign out
|
|
372
290
|
return { url: `${config.basePath}/signout` };
|
|
373
291
|
},
|
|
374
292
|
|
|
375
293
|
updateSession: async (session: any) => {
|
|
376
|
-
//
|
|
294
|
+
// Mock session update
|
|
377
295
|
return session;
|
|
378
296
|
},
|
|
379
297
|
|
|
380
298
|
getCsrfToken: async () => {
|
|
381
|
-
//
|
|
299
|
+
// Mock CSRF token generation
|
|
300
|
+
const crypto = require('crypto');
|
|
382
301
|
return crypto.randomBytes(32).toString('hex');
|
|
383
302
|
},
|
|
384
303
|
};
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
// Built-in Cache Middleware
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { createCacheAdapter } from './adapters/cache/index.js';
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { CacheAdapter, CacheOptions, CachedResponse } from '../../../types/cache';
|
|
4
|
+
import { createFrameworkLogger } from '../../logger';
|
|
5
|
+
import { createCacheAdapter } from './adapters/cache';
|
|
7
6
|
|
|
8
7
|
const logger = createFrameworkLogger('CacheMiddleware');
|
|
9
8
|
|
|
@@ -189,15 +188,14 @@ export const cache = (options: CacheOptions = {}): MiddlewareInterface => ({
|
|
|
189
188
|
parts.push(`stale-while-revalidate=${directives.staleWhileRevalidate}`);
|
|
190
189
|
}
|
|
191
190
|
|
|
192
|
-
|
|
193
|
-
res.setHeader('Cache-Control', parts.join(', '));
|
|
194
|
-
}
|
|
191
|
+
res.setHeader('Cache-Control', parts.join(', '));
|
|
195
192
|
return res;
|
|
196
193
|
};
|
|
197
194
|
|
|
198
195
|
// Add ETag generation
|
|
199
196
|
if (options.etag !== false) {
|
|
200
197
|
res.generateETag = (content: string | Buffer) => {
|
|
198
|
+
const crypto = require('crypto');
|
|
201
199
|
const hash = crypto.createHash('md5').update(content).digest('hex');
|
|
202
200
|
const prefix = options.etag === 'weak' ? 'W/' : '';
|
|
203
201
|
return `${prefix}"${hash}"`;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
// Built-in CDN Middleware
|
|
2
|
-
import { MiddlewareInterface, HookContext } from '../../../types/hooks
|
|
3
|
-
import { CDNAdapter, CDNOptions } from '../../../types/cdn
|
|
4
|
-
import { createFrameworkLogger } from '../../logger
|
|
5
|
-
import { createCDNAdapter } from './adapters/cdn
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { CDNAdapter, CDNOptions } from '../../../types/cdn';
|
|
4
|
+
import { createFrameworkLogger } from '../../logger';
|
|
5
|
+
import { createCDNAdapter } from './adapters/cdn';
|
|
6
6
|
|
|
7
7
|
const logger = createFrameworkLogger('CDNMiddleware');
|
|
8
8
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// Cookie Middleware
|
|
2
|
-
import { MiddlewareInterface, HookContext } from '../../../types/hooks
|
|
3
|
-
import { createFrameworkLogger } from '../../logger
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { createFrameworkLogger } from '../../logger';
|
|
4
4
|
|
|
5
5
|
const logger = createFrameworkLogger('CookieMiddleware');
|
|
6
6
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// CORS Middleware
|
|
2
|
-
import { MiddlewareInterface, HookContext } from '../../../types/hooks
|
|
3
|
-
import { createFrameworkLogger } from '../../logger
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { createFrameworkLogger } from '../../logger';
|
|
4
4
|
|
|
5
5
|
const logger = createFrameworkLogger('CorsMiddleware');
|
|
6
6
|
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
// Content Security Policy Middleware
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import { createFrameworkLogger } from '../../logger/index.js';
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { createFrameworkLogger } from '../../logger';
|
|
5
4
|
|
|
6
5
|
const logger = createFrameworkLogger('CSPMiddleware');
|
|
7
6
|
|
|
@@ -59,6 +58,7 @@ export const csp = (
|
|
|
59
58
|
// Generate nonce if requested
|
|
60
59
|
let nonce: string | undefined;
|
|
61
60
|
if (options.nonce) {
|
|
61
|
+
const crypto = require('crypto');
|
|
62
62
|
nonce = crypto.randomBytes(16).toString('base64');
|
|
63
63
|
req.cspNonce = nonce;
|
|
64
64
|
}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
// CSRF Protection Middleware
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import { createFrameworkLogger } from '../../logger/index.js';
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { createFrameworkLogger } from '../../logger';
|
|
5
4
|
|
|
6
5
|
const logger = createFrameworkLogger('CSRFMiddleware');
|
|
7
6
|
|
|
@@ -34,6 +33,7 @@ export const csrf = (
|
|
|
34
33
|
const ignoreMethods = options.ignoreMethods || ['GET', 'HEAD', 'OPTIONS'];
|
|
35
34
|
|
|
36
35
|
const generateToken = () => {
|
|
36
|
+
const crypto = require('crypto');
|
|
37
37
|
return crypto.randomBytes(tokenLength).toString('hex');
|
|
38
38
|
};
|
|
39
39
|
|
|
@@ -1,22 +1,22 @@
|
|
|
1
1
|
// Built-in Middleware Exports
|
|
2
|
-
export { auth } from './auth
|
|
3
|
-
export { rateLimit } from './rate-limit
|
|
4
|
-
export { cors } from './cors
|
|
5
|
-
export { validation } from './validation
|
|
6
|
-
export { requestLogger } from './request-logger
|
|
7
|
-
export { performanceMonitor } from './performance-monitor
|
|
8
|
-
export { errorTracker } from './error-tracker
|
|
2
|
+
export { auth } from './auth';
|
|
3
|
+
export { rateLimit } from './rate-limit';
|
|
4
|
+
export { cors } from './cors';
|
|
5
|
+
export { validation } from './validation';
|
|
6
|
+
export { requestLogger } from './request-logger';
|
|
7
|
+
export { performanceMonitor } from './performance-monitor';
|
|
8
|
+
export { errorTracker } from './error-tracker';
|
|
9
9
|
|
|
10
10
|
// Advanced Security & Performance Middleware
|
|
11
|
-
export { cookie } from './cookie
|
|
12
|
-
export { csrf } from './csrf
|
|
13
|
-
export { csp } from './csp
|
|
14
|
-
export { sse } from './sse
|
|
15
|
-
export { session } from './session
|
|
11
|
+
export { cookie } from './cookie';
|
|
12
|
+
export { csrf } from './csrf';
|
|
13
|
+
export { csp } from './csp';
|
|
14
|
+
export { sse } from './sse';
|
|
15
|
+
export { session } from './session';
|
|
16
16
|
|
|
17
17
|
// Clean Architecture Middleware
|
|
18
|
-
export { cache } from './cache
|
|
19
|
-
export { cdn } from './cdn
|
|
18
|
+
export { cache } from './cache';
|
|
19
|
+
export { cdn } from './cdn';
|
|
20
20
|
|
|
21
21
|
// Auth Helpers and Extended Providers
|
|
22
22
|
export {
|
|
@@ -31,38 +31,30 @@ export {
|
|
|
31
31
|
authUtils,
|
|
32
32
|
authResponses,
|
|
33
33
|
sessionHelpers,
|
|
34
|
-
} from './auth-helpers
|
|
35
|
-
|
|
36
|
-
// JWT Utilities for Custom Middleware
|
|
37
|
-
export {
|
|
38
|
-
safeVerifyJWT,
|
|
39
|
-
extractJWTFromHeader,
|
|
40
|
-
createAuthErrorResponse,
|
|
41
|
-
type JWTVerificationResult,
|
|
42
|
-
} from './jwt-helpers.js';
|
|
34
|
+
} from './auth-helpers';
|
|
43
35
|
|
|
44
36
|
export {
|
|
45
37
|
extendedProviders,
|
|
46
38
|
enterpriseProviders,
|
|
47
39
|
createCustomOAuthProvider,
|
|
48
40
|
createCustomOIDCProvider,
|
|
49
|
-
} from './auth-providers
|
|
41
|
+
} from './auth-providers';
|
|
50
42
|
|
|
51
43
|
// Import for collections
|
|
52
|
-
import { auth } from './auth
|
|
53
|
-
import { rateLimit } from './rate-limit
|
|
54
|
-
import { cors } from './cors
|
|
55
|
-
import { validation } from './validation
|
|
56
|
-
import { requestLogger } from './request-logger
|
|
57
|
-
import { performanceMonitor } from './performance-monitor
|
|
58
|
-
import { errorTracker } from './error-tracker
|
|
59
|
-
import { cookie } from './cookie
|
|
60
|
-
import { csrf } from './csrf
|
|
61
|
-
import { csp } from './csp
|
|
62
|
-
import { sse } from './sse
|
|
63
|
-
import { session } from './session
|
|
64
|
-
import { cache } from './cache
|
|
65
|
-
import { cdn } from './cdn
|
|
44
|
+
import { auth } from './auth';
|
|
45
|
+
import { rateLimit } from './rate-limit';
|
|
46
|
+
import { cors } from './cors';
|
|
47
|
+
import { validation } from './validation';
|
|
48
|
+
import { requestLogger } from './request-logger';
|
|
49
|
+
import { performanceMonitor } from './performance-monitor';
|
|
50
|
+
import { errorTracker } from './error-tracker';
|
|
51
|
+
import { cookie } from './cookie';
|
|
52
|
+
import { csrf } from './csrf';
|
|
53
|
+
import { csp } from './csp';
|
|
54
|
+
import { sse } from './sse';
|
|
55
|
+
import { session } from './session';
|
|
56
|
+
import { cache } from './cache';
|
|
57
|
+
import { cdn } from './cdn';
|
|
66
58
|
|
|
67
59
|
export const builtInMiddleware = {
|
|
68
60
|
auth,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
// Rate Limiting Middleware
|
|
2
|
-
import { MiddlewareInterface, HookContext } from '../../../types/hooks
|
|
3
|
-
import { createFrameworkLogger } from '../../logger
|
|
2
|
+
import { MiddlewareInterface, HookContext } from '../../../types/hooks';
|
|
3
|
+
import { createFrameworkLogger } from '../../logger';
|
|
4
4
|
|
|
5
5
|
const logger = createFrameworkLogger('RateLimitMiddleware');
|
|
6
6
|
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
// Simple request logging middleware
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
const logger = createFrameworkLogger('RequestLogger');
|
|
2
|
+
import { logger } from '../../logger';
|
|
5
3
|
|
|
6
4
|
export const requestLogger = async (context: any): Promise<void> => {
|
|
7
5
|
const startTime = Date.now();
|