@morojs/moro 1.6.2 → 1.6.3
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/core/http/http-server.js +12 -9
- package/dist/core/http/http-server.js.map +1 -1
- package/dist/core/http/uws-http-server.js +1 -1
- package/dist/core/http/uws-http-server.js.map +1 -1
- package/dist/core/middleware/built-in/auth/core.d.ts +78 -0
- package/dist/core/middleware/built-in/auth/core.js +358 -0
- package/dist/core/middleware/built-in/auth/core.js.map +1 -0
- package/dist/core/middleware/built-in/{auth-helpers.js → auth/helpers.js} +1 -1
- package/dist/core/middleware/built-in/auth/helpers.js.map +1 -0
- package/dist/core/middleware/built-in/auth/hook.d.ts +30 -0
- package/dist/core/middleware/built-in/auth/hook.js +99 -0
- package/dist/core/middleware/built-in/auth/hook.js.map +1 -0
- package/dist/core/middleware/built-in/auth/index.d.ts +7 -0
- package/dist/core/middleware/built-in/auth/index.js +15 -0
- package/dist/core/middleware/built-in/auth/index.js.map +1 -0
- package/dist/core/middleware/built-in/{jwt-helpers.js → auth/jwt-helpers.js} +1 -1
- package/dist/core/middleware/built-in/auth/jwt-helpers.js.map +1 -0
- package/dist/core/middleware/built-in/auth/middleware.d.ts +23 -0
- package/dist/core/middleware/built-in/auth/middleware.js +71 -0
- package/dist/core/middleware/built-in/auth/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/{auth-providers.d.ts → auth/providers.d.ts} +1 -1
- package/dist/core/middleware/built-in/{auth-providers.js → auth/providers.js} +1 -1
- package/dist/core/middleware/built-in/auth/providers.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/file.d.ts +1 -1
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/file.js +1 -1
- package/dist/core/middleware/built-in/cache/adapters/cache/file.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/index.d.ts +1 -1
- package/dist/core/middleware/built-in/cache/adapters/cache/index.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/memory.d.ts +1 -1
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/memory.js +1 -1
- package/dist/core/middleware/built-in/cache/adapters/cache/memory.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/redis.d.ts +1 -1
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/redis.js +2 -2
- package/dist/core/middleware/built-in/cache/adapters/cache/redis.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cache/adapters}/index.d.ts +0 -2
- package/{src/core/middleware/built-in/adapters/index.ts → dist/core/middleware/built-in/cache/adapters/index.js} +1 -3
- package/dist/core/middleware/built-in/cache/adapters/index.js.map +1 -0
- package/dist/core/middleware/built-in/cache/core.d.ts +37 -0
- package/dist/core/middleware/built-in/cache/core.js +87 -0
- package/dist/core/middleware/built-in/cache/core.js.map +1 -0
- package/dist/core/middleware/built-in/cache/hook.d.ts +20 -0
- package/dist/core/middleware/built-in/{cache.js → cache/hook.js} +22 -5
- package/dist/core/middleware/built-in/cache/hook.js.map +1 -0
- package/dist/core/middleware/built-in/cache/index.d.ts +3 -0
- package/dist/core/middleware/built-in/cache/index.js +9 -0
- package/dist/core/middleware/built-in/cache/index.js.map +1 -0
- package/dist/core/middleware/built-in/cache/middleware.d.ts +17 -0
- package/dist/core/middleware/built-in/cache/middleware.js +44 -0
- package/dist/core/middleware/built-in/cache/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/azure.d.ts +1 -1
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/azure.js +1 -1
- package/dist/core/middleware/built-in/cdn/adapters/cdn/azure.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/cloudflare.d.ts +1 -1
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/cloudflare.js +1 -1
- package/dist/core/middleware/built-in/cdn/adapters/cdn/cloudflare.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/cloudfront.d.ts +1 -1
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/cloudfront.js +2 -2
- package/dist/core/middleware/built-in/cdn/adapters/cdn/cloudfront.js.map +1 -0
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/index.d.ts +1 -1
- package/dist/core/middleware/built-in/cdn/adapters/cdn/index.js.map +1 -0
- package/dist/core/middleware/built-in/cdn/adapters/index.d.ts +2 -0
- package/dist/core/middleware/built-in/{adapters → cdn/adapters}/index.js +0 -2
- package/dist/core/middleware/built-in/cdn/adapters/index.js.map +1 -0
- package/dist/core/middleware/built-in/cdn/core.d.ts +43 -0
- package/dist/core/middleware/built-in/cdn/core.js +144 -0
- package/dist/core/middleware/built-in/cdn/core.js.map +1 -0
- package/dist/core/middleware/built-in/cdn/hook.d.ts +22 -0
- package/dist/core/middleware/built-in/cdn/hook.js +70 -0
- package/dist/core/middleware/built-in/cdn/hook.js.map +1 -0
- package/dist/core/middleware/built-in/cdn/index.d.ts +5 -0
- package/dist/core/middleware/built-in/cdn/index.js +11 -0
- package/dist/core/middleware/built-in/cdn/index.js.map +1 -0
- package/dist/core/middleware/built-in/cdn/middleware.d.ts +21 -0
- package/dist/core/middleware/built-in/cdn/middleware.js +52 -0
- package/dist/core/middleware/built-in/cdn/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/cookie/core.d.ts +37 -0
- package/dist/core/middleware/built-in/cookie/core.js +83 -0
- package/dist/core/middleware/built-in/cookie/core.js.map +1 -0
- package/dist/core/middleware/built-in/cookie/hook.d.ts +20 -0
- package/dist/core/middleware/built-in/cookie/hook.js +47 -0
- package/dist/core/middleware/built-in/cookie/hook.js.map +1 -0
- package/dist/core/middleware/built-in/cookie/index.d.ts +3 -0
- package/dist/core/middleware/built-in/cookie/index.js +9 -0
- package/dist/core/middleware/built-in/cookie/index.js.map +1 -0
- package/dist/core/middleware/built-in/cookie/middleware.d.ts +17 -0
- package/dist/core/middleware/built-in/cookie/middleware.js +36 -0
- package/dist/core/middleware/built-in/cookie/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/cors/core.d.ts +23 -0
- package/dist/core/middleware/built-in/cors/core.js +51 -0
- package/dist/core/middleware/built-in/cors/core.js.map +1 -0
- package/dist/core/middleware/built-in/cors/hook.d.ts +17 -0
- package/dist/core/middleware/built-in/cors/hook.js +37 -0
- package/dist/core/middleware/built-in/cors/hook.js.map +1 -0
- package/dist/core/middleware/built-in/cors/index.d.ts +3 -0
- package/dist/core/middleware/built-in/cors/index.js +9 -0
- package/dist/core/middleware/built-in/cors/index.js.map +1 -0
- package/dist/core/middleware/built-in/cors/middleware.d.ts +16 -0
- package/dist/core/middleware/built-in/cors/middleware.js +22 -0
- package/dist/core/middleware/built-in/cors/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/csp/core.d.ts +45 -0
- package/dist/core/middleware/built-in/csp/core.js +88 -0
- package/dist/core/middleware/built-in/csp/core.js.map +1 -0
- package/dist/core/middleware/built-in/csp/hook.d.ts +22 -0
- package/dist/core/middleware/built-in/csp/hook.js +47 -0
- package/dist/core/middleware/built-in/csp/hook.js.map +1 -0
- package/dist/core/middleware/built-in/csp/index.d.ts +3 -0
- package/dist/core/middleware/built-in/csp/index.js +9 -0
- package/dist/core/middleware/built-in/csp/index.js.map +1 -0
- package/dist/core/middleware/built-in/csp/middleware.d.ts +19 -0
- package/dist/core/middleware/built-in/csp/middleware.js +29 -0
- package/dist/core/middleware/built-in/csp/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/csrf/core.d.ts +28 -0
- package/dist/core/middleware/built-in/csrf/core.js +69 -0
- package/dist/core/middleware/built-in/csrf/core.js.map +1 -0
- package/dist/core/middleware/built-in/csrf/hook.d.ts +17 -0
- package/dist/core/middleware/built-in/csrf/hook.js +45 -0
- package/dist/core/middleware/built-in/csrf/hook.js.map +1 -0
- package/dist/core/middleware/built-in/csrf/index.d.ts +3 -0
- package/dist/core/middleware/built-in/csrf/index.js +9 -0
- package/dist/core/middleware/built-in/csrf/index.js.map +1 -0
- package/dist/core/middleware/built-in/csrf/middleware.d.ts +16 -0
- package/dist/core/middleware/built-in/csrf/middleware.js +34 -0
- package/dist/core/middleware/built-in/csrf/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/error-tracker/index.d.ts +1 -0
- package/dist/core/middleware/built-in/error-tracker/index.js +4 -0
- package/dist/core/middleware/built-in/error-tracker/index.js.map +1 -0
- package/dist/core/middleware/built-in/error-tracker/middleware.d.ts +12 -0
- package/dist/core/middleware/built-in/{error-tracker.js → error-tracker/middleware.js} +14 -3
- package/dist/core/middleware/built-in/error-tracker/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/index.d.ts +25 -59
- package/dist/core/middleware/built-in/index.js +31 -31
- package/dist/core/middleware/built-in/index.js.map +1 -1
- package/dist/core/middleware/built-in/performance-monitor/index.d.ts +1 -0
- package/dist/core/middleware/built-in/performance-monitor/index.js +4 -0
- package/dist/core/middleware/built-in/performance-monitor/index.js.map +1 -0
- package/dist/core/middleware/built-in/performance-monitor/middleware.d.ts +12 -0
- package/dist/core/middleware/built-in/{performance-monitor.js → performance-monitor/middleware.js} +14 -3
- package/dist/core/middleware/built-in/performance-monitor/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/rate-limit/core.d.ts +33 -0
- package/dist/core/middleware/built-in/rate-limit/core.js +86 -0
- package/dist/core/middleware/built-in/rate-limit/core.js.map +1 -0
- package/dist/core/middleware/built-in/rate-limit/hook.d.ts +20 -0
- package/dist/core/middleware/built-in/{rate-limit.js → rate-limit/hook.js} +22 -16
- package/dist/core/middleware/built-in/rate-limit/hook.js.map +1 -0
- package/dist/core/middleware/built-in/rate-limit/index.d.ts +3 -0
- package/dist/core/middleware/built-in/rate-limit/index.js +9 -0
- package/dist/core/middleware/built-in/rate-limit/index.js.map +1 -0
- package/dist/core/middleware/built-in/rate-limit/middleware.d.ts +16 -0
- package/dist/core/middleware/built-in/rate-limit/middleware.js +35 -0
- package/dist/core/middleware/built-in/rate-limit/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/request-logger/index.d.ts +1 -0
- package/dist/core/middleware/built-in/request-logger/index.js +4 -0
- package/dist/core/middleware/built-in/request-logger/index.js.map +1 -0
- package/dist/core/middleware/built-in/request-logger/middleware.d.ts +12 -0
- package/dist/core/middleware/built-in/{request-logger.js → request-logger/middleware.js} +14 -3
- package/dist/core/middleware/built-in/request-logger/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/session/core.d.ts +73 -0
- package/dist/core/middleware/built-in/session/core.js +227 -0
- package/dist/core/middleware/built-in/session/core.js.map +1 -0
- package/dist/core/middleware/built-in/session/hook.d.ts +17 -0
- package/dist/core/middleware/built-in/session/hook.js +53 -0
- package/dist/core/middleware/built-in/session/hook.js.map +1 -0
- package/dist/core/middleware/built-in/session/index.d.ts +3 -0
- package/dist/core/middleware/built-in/session/index.js +9 -0
- package/dist/core/middleware/built-in/session/index.js.map +1 -0
- package/dist/core/middleware/built-in/session/middleware.d.ts +17 -0
- package/dist/core/middleware/built-in/session/middleware.js +38 -0
- package/dist/core/middleware/built-in/session/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/sse/core.d.ts +44 -0
- package/dist/core/middleware/built-in/sse/core.js +117 -0
- package/dist/core/middleware/built-in/sse/core.js.map +1 -0
- package/dist/core/middleware/built-in/sse/hook.d.ts +18 -0
- package/dist/core/middleware/built-in/sse/hook.js +60 -0
- package/dist/core/middleware/built-in/sse/hook.js.map +1 -0
- package/dist/core/middleware/built-in/sse/index.d.ts +3 -0
- package/dist/core/middleware/built-in/sse/index.js +9 -0
- package/dist/core/middleware/built-in/sse/index.js.map +1 -0
- package/dist/core/middleware/built-in/sse/middleware.d.ts +18 -0
- package/dist/core/middleware/built-in/sse/middleware.js +43 -0
- package/dist/core/middleware/built-in/sse/middleware.js.map +1 -0
- package/dist/core/middleware/built-in/validation/core.d.ts +23 -0
- package/dist/core/middleware/built-in/validation/core.js +93 -0
- package/dist/core/middleware/built-in/validation/core.js.map +1 -0
- package/dist/core/middleware/built-in/validation/hook.d.ts +13 -0
- package/dist/core/middleware/built-in/{validation.js → validation/hook.js} +14 -3
- package/dist/core/middleware/built-in/validation/hook.js.map +1 -0
- package/dist/core/middleware/built-in/validation/index.d.ts +3 -0
- package/dist/core/middleware/built-in/validation/index.js +9 -0
- package/dist/core/middleware/built-in/validation/index.js.map +1 -0
- package/dist/core/middleware/built-in/validation/middleware.d.ts +16 -0
- package/dist/core/middleware/built-in/validation/middleware.js +27 -0
- package/dist/core/middleware/built-in/validation/middleware.js.map +1 -0
- package/dist/core/middleware/index.js +6 -0
- package/dist/core/middleware/index.js.map +1 -1
- package/dist/core/routing/unified-router.d.ts +4 -20
- package/dist/core/routing/unified-router.js +61 -106
- package/dist/core/routing/unified-router.js.map +1 -1
- package/dist/index.d.ts +3 -2
- package/dist/index.js +3 -2
- package/dist/index.js.map +1 -1
- package/dist/moro.js +12 -18
- package/dist/moro.js.map +1 -1
- package/dist/types/hooks.d.ts +3 -0
- package/package.json +2 -6
- package/dist/core/middleware/built-in/adapters/cache/file.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cache/index.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cache/memory.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cache/redis.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cdn/azure.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/cdn/index.js.map +0 -1
- package/dist/core/middleware/built-in/adapters/index.js.map +0 -1
- package/dist/core/middleware/built-in/auth-helpers.js.map +0 -1
- package/dist/core/middleware/built-in/auth-providers.js.map +0 -1
- package/dist/core/middleware/built-in/auth.d.ts +0 -30
- package/dist/core/middleware/built-in/auth.js +0 -348
- package/dist/core/middleware/built-in/auth.js.map +0 -1
- package/dist/core/middleware/built-in/cache.d.ts +0 -3
- package/dist/core/middleware/built-in/cache.js.map +0 -1
- package/dist/core/middleware/built-in/cdn.d.ts +0 -3
- package/dist/core/middleware/built-in/cdn.js +0 -109
- package/dist/core/middleware/built-in/cdn.js.map +0 -1
- package/dist/core/middleware/built-in/cookie.d.ts +0 -14
- package/dist/core/middleware/built-in/cookie.js +0 -64
- package/dist/core/middleware/built-in/cookie.js.map +0 -1
- package/dist/core/middleware/built-in/cors.d.ts +0 -2
- package/dist/core/middleware/built-in/cors.js +0 -25
- package/dist/core/middleware/built-in/cors.js.map +0 -1
- package/dist/core/middleware/built-in/csp.d.ts +0 -22
- package/dist/core/middleware/built-in/csp.js +0 -68
- package/dist/core/middleware/built-in/csp.js.map +0 -1
- package/dist/core/middleware/built-in/csrf.d.ts +0 -9
- package/dist/core/middleware/built-in/csrf.js +0 -60
- package/dist/core/middleware/built-in/csrf.js.map +0 -1
- package/dist/core/middleware/built-in/error-tracker.d.ts +0 -1
- package/dist/core/middleware/built-in/error-tracker.js.map +0 -1
- package/dist/core/middleware/built-in/jwt-helpers.js.map +0 -1
- package/dist/core/middleware/built-in/performance-monitor.d.ts +0 -1
- package/dist/core/middleware/built-in/performance-monitor.js.map +0 -1
- package/dist/core/middleware/built-in/rate-limit.d.ts +0 -6
- package/dist/core/middleware/built-in/rate-limit.js.map +0 -1
- package/dist/core/middleware/built-in/request-logger.d.ts +0 -1
- package/dist/core/middleware/built-in/request-logger.js.map +0 -1
- package/dist/core/middleware/built-in/session.d.ts +0 -41
- package/dist/core/middleware/built-in/session.js +0 -205
- package/dist/core/middleware/built-in/session.js.map +0 -1
- package/dist/core/middleware/built-in/sse.d.ts +0 -6
- package/dist/core/middleware/built-in/sse.js +0 -69
- package/dist/core/middleware/built-in/sse.js.map +0 -1
- package/dist/core/middleware/built-in/validation.d.ts +0 -2
- package/dist/core/middleware/built-in/validation.js.map +0 -1
- package/jest.config.mjs +0 -41
- package/src/core/auth/README.md +0 -339
- package/src/core/auth/morojs-adapter.ts +0 -415
- package/src/core/config/config-manager.ts +0 -133
- package/src/core/config/config-sources.ts +0 -600
- package/src/core/config/config-validator.ts +0 -1116
- package/src/core/config/file-loader.ts +0 -150
- package/src/core/config/index.ts +0 -109
- package/src/core/config/schema.ts +0 -164
- package/src/core/config/utils.ts +0 -244
- package/src/core/database/README.md +0 -238
- package/src/core/database/adapters/drizzle.ts +0 -415
- package/src/core/database/adapters/index.ts +0 -42
- package/src/core/database/adapters/mongodb.ts +0 -317
- package/src/core/database/adapters/mysql.ts +0 -235
- package/src/core/database/adapters/postgresql.ts +0 -226
- package/src/core/database/adapters/redis.ts +0 -379
- package/src/core/database/adapters/sqlite.ts +0 -263
- package/src/core/database/index.ts +0 -3
- package/src/core/docs/index.ts +0 -231
- package/src/core/docs/openapi-generator.ts +0 -576
- package/src/core/docs/schema-to-openapi.ts +0 -145
- package/src/core/docs/simple-docs.ts +0 -295
- package/src/core/docs/swagger-ui.ts +0 -354
- package/src/core/docs/zod-to-openapi.ts +0 -532
- package/src/core/events/event-bus.ts +0 -231
- package/src/core/events/index.ts +0 -12
- package/src/core/framework.ts +0 -885
- package/src/core/http/http-server.ts +0 -1847
- package/src/core/http/index.ts +0 -7
- package/src/core/http/uws-http-server.ts +0 -591
- package/src/core/logger/filters.ts +0 -153
- package/src/core/logger/index.ts +0 -21
- package/src/core/logger/logger.ts +0 -1033
- package/src/core/logger/outputs.ts +0 -132
- package/src/core/middleware/built-in/adapters/cache/file.ts +0 -104
- package/src/core/middleware/built-in/adapters/cache/index.ts +0 -23
- package/src/core/middleware/built-in/adapters/cache/memory.ts +0 -73
- package/src/core/middleware/built-in/adapters/cache/redis.ts +0 -114
- package/src/core/middleware/built-in/adapters/cdn/azure.ts +0 -60
- package/src/core/middleware/built-in/adapters/cdn/cloudflare.ts +0 -83
- package/src/core/middleware/built-in/adapters/cdn/cloudfront.ts +0 -94
- package/src/core/middleware/built-in/adapters/cdn/index.ts +0 -23
- package/src/core/middleware/built-in/auth-helpers.ts +0 -401
- package/src/core/middleware/built-in/auth-providers.ts +0 -480
- package/src/core/middleware/built-in/auth.ts +0 -410
- package/src/core/middleware/built-in/cache.ts +0 -213
- package/src/core/middleware/built-in/cdn.ts +0 -124
- package/src/core/middleware/built-in/cookie.ts +0 -85
- package/src/core/middleware/built-in/cors.ts +0 -38
- package/src/core/middleware/built-in/csp.ts +0 -101
- package/src/core/middleware/built-in/csrf.ts +0 -82
- package/src/core/middleware/built-in/error-tracker.ts +0 -16
- package/src/core/middleware/built-in/index.ts +0 -87
- package/src/core/middleware/built-in/jwt-helpers.ts +0 -243
- package/src/core/middleware/built-in/performance-monitor.ts +0 -25
- package/src/core/middleware/built-in/rate-limit.ts +0 -60
- package/src/core/middleware/built-in/request-logger.ts +0 -16
- package/src/core/middleware/built-in/session.ts +0 -287
- package/src/core/middleware/built-in/sse.ts +0 -88
- package/src/core/middleware/built-in/validation.ts +0 -33
- package/src/core/middleware/index.ts +0 -177
- package/src/core/modules/auto-discovery.ts +0 -726
- package/src/core/modules/index.ts +0 -3
- package/src/core/modules/modules.ts +0 -135
- package/src/core/networking/adapters/index.ts +0 -17
- package/src/core/networking/adapters/socketio-adapter.ts +0 -254
- package/src/core/networking/adapters/uws-adapter.ts +0 -619
- package/src/core/networking/adapters/ws-adapter.ts +0 -429
- package/src/core/networking/index.ts +0 -4
- package/src/core/networking/service-discovery.ts +0 -303
- package/src/core/networking/websocket-adapter.ts +0 -217
- package/src/core/networking/websocket-manager.ts +0 -308
- package/src/core/pooling/object-pool-manager.ts +0 -630
- package/src/core/routing/app-integration.ts +0 -164
- package/src/core/routing/index.ts +0 -261
- package/src/core/routing/path-matcher.ts +0 -222
- package/src/core/routing/router.ts +0 -97
- package/src/core/routing/unified-router.ts +0 -870
- package/src/core/runtime/aws-lambda-adapter.ts +0 -147
- package/src/core/runtime/base-adapter.ts +0 -130
- package/src/core/runtime/cloudflare-workers-adapter.ts +0 -152
- package/src/core/runtime/index.ts +0 -62
- package/src/core/runtime/node-adapter.ts +0 -202
- package/src/core/runtime/vercel-edge-adapter.ts +0 -114
- package/src/core/utilities/circuit-breaker.ts +0 -46
- package/src/core/utilities/container.ts +0 -736
- package/src/core/utilities/hooks.ts +0 -142
- package/src/core/utilities/index.ts +0 -17
- package/src/core/utilities/package-utils.ts +0 -59
- package/src/core/validation/adapters.ts +0 -147
- package/src/core/validation/index.ts +0 -258
- package/src/core/validation/schema-interface.ts +0 -100
- package/src/index.ts +0 -233
- package/src/moro.ts +0 -1728
- package/src/types/auth.ts +0 -440
- package/src/types/cache.ts +0 -38
- package/src/types/cdn.ts +0 -22
- package/src/types/config.ts +0 -229
- package/src/types/core.ts +0 -58
- package/src/types/database.ts +0 -32
- package/src/types/discovery.ts +0 -7
- package/src/types/events.ts +0 -82
- package/src/types/hooks.ts +0 -47
- package/src/types/http.ts +0 -89
- package/src/types/logger.ts +0 -102
- package/src/types/module.ts +0 -99
- package/src/types/runtime.ts +0 -76
- package/src/types/session.ts +0 -89
- package/tsconfig.json +0 -23
- /package/dist/core/middleware/built-in/{auth-helpers.d.ts → auth/helpers.d.ts} +0 -0
- /package/dist/core/middleware/built-in/{jwt-helpers.d.ts → auth/jwt-helpers.d.ts} +0 -0
- /package/dist/core/middleware/built-in/{adapters → cache/adapters}/cache/index.js +0 -0
- /package/dist/core/middleware/built-in/{adapters → cdn/adapters}/cdn/index.js +0 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { MiddlewareInterface } from '../../../../types/hooks.js';
|
|
2
|
+
import { type CSRFOptions } from './core.js';
|
|
3
|
+
/**
|
|
4
|
+
* CSRF hook for global usage
|
|
5
|
+
* Registers with the hooks system for application-wide CSRF protection
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```ts
|
|
9
|
+
* import { csrf } from '@/middleware/built-in/csrf';
|
|
10
|
+
*
|
|
11
|
+
* app.use(csrf({
|
|
12
|
+
* cookieName: '_csrf',
|
|
13
|
+
* ignoreMethods: ['GET', 'HEAD', 'OPTIONS']
|
|
14
|
+
* }));
|
|
15
|
+
* ```
|
|
16
|
+
*/
|
|
17
|
+
export declare const csrf: (options?: CSRFOptions) => MiddlewareInterface;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { createFrameworkLogger } from '../../../logger/index.js';
|
|
2
|
+
import { CSRFCore } from './core.js';
|
|
3
|
+
const logger = createFrameworkLogger('CSRFMiddleware');
|
|
4
|
+
/**
|
|
5
|
+
* CSRF hook for global usage
|
|
6
|
+
* Registers with the hooks system for application-wide CSRF protection
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```ts
|
|
10
|
+
* import { csrf } from '@/middleware/built-in/csrf';
|
|
11
|
+
*
|
|
12
|
+
* app.use(csrf({
|
|
13
|
+
* cookieName: '_csrf',
|
|
14
|
+
* ignoreMethods: ['GET', 'HEAD', 'OPTIONS']
|
|
15
|
+
* }));
|
|
16
|
+
* ```
|
|
17
|
+
*/
|
|
18
|
+
export const csrf = (options = {}) => ({
|
|
19
|
+
name: 'csrf',
|
|
20
|
+
version: '1.0.0',
|
|
21
|
+
metadata: {
|
|
22
|
+
name: 'csrf',
|
|
23
|
+
version: '1.0.0',
|
|
24
|
+
description: 'CSRF protection middleware with token generation and validation',
|
|
25
|
+
author: 'MoroJS Team',
|
|
26
|
+
},
|
|
27
|
+
install: async (hooks, middlewareOptions = {}) => {
|
|
28
|
+
logger.debug('Installing CSRF middleware', 'Installation');
|
|
29
|
+
const config = {
|
|
30
|
+
...options,
|
|
31
|
+
...middlewareOptions,
|
|
32
|
+
};
|
|
33
|
+
const csrfCore = new CSRFCore(config);
|
|
34
|
+
hooks.before('request', async (context) => {
|
|
35
|
+
const req = context.request;
|
|
36
|
+
const res = context.response;
|
|
37
|
+
// Add CSRF token generation method
|
|
38
|
+
req.csrfToken = () => csrfCore.attachToken(req, res);
|
|
39
|
+
// Validate token for non-safe methods
|
|
40
|
+
await csrfCore.validateToken(req);
|
|
41
|
+
});
|
|
42
|
+
logger.info('CSRF middleware installed', 'Installation');
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
//# sourceMappingURL=hook.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hook.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/csrf/hook.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAoB,MAAM,WAAW,CAAC;AAEvD,MAAM,MAAM,GAAG,qBAAqB,CAAC,gBAAgB,CAAC,CAAC;AAEvD;;;;;;;;;;;;;GAaG;AACH,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,UAAuB,EAAE,EAAuB,EAAE,CAAC,CAAC;IACvE,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,OAAO;IAChB,QAAQ,EAAE;QACR,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,OAAO;QAChB,WAAW,EAAE,iEAAiE;QAC9E,MAAM,EAAE,aAAa;KACtB;IAED,OAAO,EAAE,KAAK,EAAE,KAAU,EAAE,oBAAyB,EAAE,EAAE,EAAE;QACzD,MAAM,CAAC,KAAK,CAAC,4BAA4B,EAAE,cAAc,CAAC,CAAC;QAE3D,MAAM,MAAM,GAAgB;YAC1B,GAAG,OAAO;YACV,GAAG,iBAAiB;SACrB,CAAC;QAEF,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC;QAEtC,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,KAAK,EAAE,OAAoB,EAAE,EAAE;YACrD,MAAM,GAAG,GAAG,OAAO,CAAC,OAAc,CAAC;YACnC,MAAM,GAAG,GAAG,OAAO,CAAC,QAAe,CAAC;YAEpC,mCAAmC;YACnC,GAAG,CAAC,SAAS,GAAG,GAAG,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;YAErD,sCAAsC;YACtC,MAAM,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,IAAI,CAAC,2BAA2B,EAAE,cAAc,CAAC,CAAC;IAC3D,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// CSRF - Main entry point
|
|
2
|
+
// Re-exports all public APIs for the CSRF built-in
|
|
3
|
+
// Core (for direct use by router and custom implementations)
|
|
4
|
+
export { CSRFCore } from './core.js';
|
|
5
|
+
// Middleware (for middleware chains)
|
|
6
|
+
export { createCSRFMiddleware } from './middleware.js';
|
|
7
|
+
// Hook (for global registration)
|
|
8
|
+
export { csrf } from './hook.js';
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/csrf/index.ts"],"names":[],"mappings":"AAAA,0BAA0B;AAC1B,mDAAmD;AAEnD,6DAA6D;AAC7D,OAAO,EAAE,QAAQ,EAAoB,MAAM,WAAW,CAAC;AAEvD,qCAAqC;AACrC,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AAEvD,iCAAiC;AACjC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { StandardMiddleware } from '../../../../types/hooks.js';
|
|
2
|
+
import { type CSRFOptions } from './core.js';
|
|
3
|
+
/**
|
|
4
|
+
* Create CSRF middleware for use in middleware chains
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```ts
|
|
8
|
+
* const csrfMw = createCSRFMiddleware({
|
|
9
|
+
* cookieName: '_csrf',
|
|
10
|
+
* headerName: 'x-csrf-token'
|
|
11
|
+
* });
|
|
12
|
+
*
|
|
13
|
+
* app.use(csrfMw);
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
export declare function createCSRFMiddleware(options?: CSRFOptions): StandardMiddleware;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { createFrameworkLogger } from '../../../logger/index.js';
|
|
2
|
+
import { CSRFCore } from './core.js';
|
|
3
|
+
const logger = createFrameworkLogger('CSRFMiddleware');
|
|
4
|
+
/**
|
|
5
|
+
* Create CSRF middleware for use in middleware chains
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```ts
|
|
9
|
+
* const csrfMw = createCSRFMiddleware({
|
|
10
|
+
* cookieName: '_csrf',
|
|
11
|
+
* headerName: 'x-csrf-token'
|
|
12
|
+
* });
|
|
13
|
+
*
|
|
14
|
+
* app.use(csrfMw);
|
|
15
|
+
* ```
|
|
16
|
+
*/
|
|
17
|
+
export function createCSRFMiddleware(options = {}) {
|
|
18
|
+
const csrfCore = new CSRFCore(options);
|
|
19
|
+
return async (req, res, next) => {
|
|
20
|
+
try {
|
|
21
|
+
// Add CSRF token generation method
|
|
22
|
+
req.csrfToken = () => csrfCore.attachToken(req, res);
|
|
23
|
+
// Validate token for non-safe methods
|
|
24
|
+
await csrfCore.validateToken(req);
|
|
25
|
+
// Execute next middleware
|
|
26
|
+
await next();
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
logger.error('CSRF middleware error', 'CSRFError', { error });
|
|
30
|
+
throw error;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/csrf/middleware.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,OAAO,EAAE,QAAQ,EAAoB,MAAM,WAAW,CAAC;AAEvD,MAAM,MAAM,GAAG,qBAAqB,CAAC,gBAAgB,CAAC,CAAC;AAEvD;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,oBAAoB,CAAC,UAAuB,EAAE;IAC5D,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAC;IAEvC,OAAO,KAAK,EAAE,GAAgB,EAAE,GAAiB,EAAE,IAAyB,EAAE,EAAE;QAC9E,IAAI,CAAC;YACH,mCAAmC;YAClC,GAAW,CAAC,SAAS,GAAG,GAAG,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;YAE9D,sCAAsC;YACtC,MAAM,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAElC,0BAA0B;YAC1B,MAAM,IAAI,EAAE,CAAC;QACf,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,uBAAuB,EAAE,WAAW,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YAC9D,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { errorTracker } from './middleware.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/error-tracker/index.ts"],"names":[],"mappings":"AAAA,mCAAmC;AACnC,0CAA0C;AAE1C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Error tracking middleware
|
|
3
|
+
* Captures and logs errors that occur during request processing
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ```ts
|
|
7
|
+
* import { errorTracker } from '@/middleware/built-in/error-tracker';
|
|
8
|
+
*
|
|
9
|
+
* app.use(errorTracker);
|
|
10
|
+
* ```
|
|
11
|
+
*/
|
|
12
|
+
export declare const errorTracker: (context: any) => Promise<void>;
|
|
@@ -1,6 +1,17 @@
|
|
|
1
|
-
// Error
|
|
2
|
-
import { createFrameworkLogger } from '
|
|
1
|
+
// Error Tracker Middleware
|
|
2
|
+
import { createFrameworkLogger } from '../../../logger/index.js';
|
|
3
3
|
const logger = createFrameworkLogger('ErrorTracker');
|
|
4
|
+
/**
|
|
5
|
+
* Error tracking middleware
|
|
6
|
+
* Captures and logs errors that occur during request processing
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```ts
|
|
10
|
+
* import { errorTracker } from '@/middleware/built-in/error-tracker';
|
|
11
|
+
*
|
|
12
|
+
* app.use(errorTracker);
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
4
15
|
export const errorTracker = async (context) => {
|
|
5
16
|
context.onError = (error) => {
|
|
6
17
|
logger.error('Request error', 'ErrorTracking', {
|
|
@@ -12,4 +23,4 @@ export const errorTracker = async (context) => {
|
|
|
12
23
|
});
|
|
13
24
|
};
|
|
14
25
|
};
|
|
15
|
-
//# sourceMappingURL=
|
|
26
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/error-tracker/middleware.ts"],"names":[],"mappings":"AAAA,2BAA2B;AAC3B,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,MAAM,MAAM,GAAG,qBAAqB,CAAC,cAAc,CAAC,CAAC;AAErD;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAAE,OAAY,EAAiB,EAAE;IAChE,OAAO,CAAC,OAAO,GAAG,CAAC,KAAY,EAAE,EAAE;QACjC,MAAM,CAAC,KAAK,CAAC,eAAe,EAAE,eAAe,EAAE;YAC7C,KAAK,EAAE,KAAK,CAAC,OAAO;YACpB,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,GAAG,EAAE,OAAO,CAAC,OAAO,EAAE,GAAG;YACzB,MAAM,EAAE,OAAO,CAAC,OAAO,EAAE,MAAM;YAC/B,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,70 +1,36 @@
|
|
|
1
|
-
export { auth } from './auth.js';
|
|
2
|
-
export { rateLimit } from './rate-limit.js';
|
|
3
|
-
export { cors } from './cors.js';
|
|
4
|
-
export { validation } from './validation.js';
|
|
5
|
-
export { requestLogger } from './request-logger.js';
|
|
6
|
-
export { performanceMonitor } from './performance-monitor.js';
|
|
7
|
-
export { errorTracker } from './error-tracker.js';
|
|
8
|
-
export { cookie } from './cookie.js';
|
|
9
|
-
export { csrf } from './csrf.js';
|
|
10
|
-
export { csp } from './csp.js';
|
|
11
|
-
export { sse } from './sse.js';
|
|
12
|
-
export { session } from './session.js';
|
|
13
|
-
export { cache } from './cache.js';
|
|
14
|
-
export { cdn } from './cdn.js';
|
|
15
|
-
export { requireAuth, requireRole, requirePermission, requireAdmin, guestOnly, optionalAuth, withAuth, protectedRoute, authUtils, authResponses, sessionHelpers, } from './auth
|
|
16
|
-
export { safeVerifyJWT, extractJWTFromHeader, createAuthErrorResponse, type JWTVerificationResult, } from './jwt-helpers.js';
|
|
17
|
-
export { extendedProviders, enterpriseProviders, createCustomOAuthProvider, createCustomOIDCProvider, } from './auth
|
|
1
|
+
export { auth } from './auth/index.js';
|
|
2
|
+
export { rateLimit } from './rate-limit/index.js';
|
|
3
|
+
export { cors } from './cors/index.js';
|
|
4
|
+
export { validation } from './validation/index.js';
|
|
5
|
+
export { requestLogger } from './request-logger/index.js';
|
|
6
|
+
export { performanceMonitor } from './performance-monitor/index.js';
|
|
7
|
+
export { errorTracker } from './error-tracker/index.js';
|
|
8
|
+
export { cookie } from './cookie/index.js';
|
|
9
|
+
export { csrf } from './csrf/index.js';
|
|
10
|
+
export { csp } from './csp/index.js';
|
|
11
|
+
export { sse } from './sse/index.js';
|
|
12
|
+
export { session } from './session/index.js';
|
|
13
|
+
export { cache } from './cache/index.js';
|
|
14
|
+
export { cdn } from './cdn/index.js';
|
|
15
|
+
export { requireAuth, requireRole, requirePermission, requireAdmin, guestOnly, optionalAuth, withAuth, protectedRoute, authUtils, authResponses, sessionHelpers, } from './auth/helpers.js';
|
|
16
|
+
export { safeVerifyJWT, extractJWTFromHeader, createAuthErrorResponse, type JWTVerificationResult, } from './auth/jwt-helpers.js';
|
|
17
|
+
export { extendedProviders, enterpriseProviders, createCustomOAuthProvider, createCustomOIDCProvider, } from './auth/providers.js';
|
|
18
18
|
export declare const builtInMiddleware: {
|
|
19
|
-
auth: (options: import("
|
|
19
|
+
auth: (options: import("./auth/index.js").AuthOptions) => import("../index.js").MiddlewareInterface;
|
|
20
20
|
rateLimit: (options?: {
|
|
21
21
|
windowMs?: number;
|
|
22
22
|
max?: number;
|
|
23
23
|
message?: string;
|
|
24
24
|
}) => import("../index.js").MiddlewareInterface;
|
|
25
|
-
cors: (options?:
|
|
25
|
+
cors: (options?: import("./cors/core.js").CORSOptions) => import("../index.js").MiddlewareInterface;
|
|
26
26
|
validation: () => import("../index.js").MiddlewareInterface;
|
|
27
|
-
cookie: (
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
secret?: string;
|
|
33
|
-
tokenLength?: number;
|
|
34
|
-
cookieName?: string;
|
|
35
|
-
headerName?: string;
|
|
36
|
-
ignoreMethods?: string[];
|
|
37
|
-
sameSite?: boolean;
|
|
38
|
-
}) => import("../index.js").MiddlewareInterface;
|
|
39
|
-
csp: (options?: {
|
|
40
|
-
directives?: {
|
|
41
|
-
defaultSrc?: string[];
|
|
42
|
-
scriptSrc?: string[];
|
|
43
|
-
styleSrc?: string[];
|
|
44
|
-
imgSrc?: string[];
|
|
45
|
-
connectSrc?: string[];
|
|
46
|
-
fontSrc?: string[];
|
|
47
|
-
objectSrc?: string[];
|
|
48
|
-
mediaSrc?: string[];
|
|
49
|
-
frameSrc?: string[];
|
|
50
|
-
childSrc?: string[];
|
|
51
|
-
workerSrc?: string[];
|
|
52
|
-
formAction?: string[];
|
|
53
|
-
upgradeInsecureRequests?: boolean;
|
|
54
|
-
blockAllMixedContent?: boolean;
|
|
55
|
-
};
|
|
56
|
-
reportOnly?: boolean;
|
|
57
|
-
reportUri?: string;
|
|
58
|
-
nonce?: boolean;
|
|
59
|
-
}) => import("../index.js").MiddlewareInterface;
|
|
60
|
-
sse: (options?: {
|
|
61
|
-
heartbeat?: number;
|
|
62
|
-
retry?: number;
|
|
63
|
-
cors?: boolean;
|
|
64
|
-
}) => import("../index.js").MiddlewareInterface;
|
|
65
|
-
session: (options?: import("./session.js").SessionOptions) => import("../index.js").MiddlewareInterface;
|
|
27
|
+
cookie: (config?: import("./cookie/hook.js").CookieConfig) => import("../index.js").MiddlewareInterface;
|
|
28
|
+
csrf: (options?: import("./csrf/core.js").CSRFOptions) => import("../index.js").MiddlewareInterface;
|
|
29
|
+
csp: (options?: import("./csp/core.js").CSPOptions) => import("../index.js").MiddlewareInterface;
|
|
30
|
+
sse: (options?: import("./sse/core.js").SSEOptions) => import("../index.js").MiddlewareInterface;
|
|
31
|
+
session: (options?: import("./session/core.js").SessionOptions) => import("../index.js").MiddlewareInterface;
|
|
66
32
|
cache: (options?: import("../../../index.js").CacheOptions) => import("../index.js").MiddlewareInterface;
|
|
67
|
-
cdn: (options?: import("
|
|
33
|
+
cdn: (options?: import("./cdn/index.js").CDNOptions) => import("../index.js").MiddlewareInterface;
|
|
68
34
|
};
|
|
69
35
|
export declare const simpleMiddleware: {
|
|
70
36
|
requestLogger: (context: any) => Promise<void>;
|
|
@@ -1,40 +1,40 @@
|
|
|
1
1
|
// Built-in Middleware Exports
|
|
2
|
-
export { auth } from './auth.js';
|
|
3
|
-
export { rateLimit } from './rate-limit.js';
|
|
4
|
-
export { cors } from './cors.js';
|
|
5
|
-
export { validation } from './validation.js';
|
|
6
|
-
export { requestLogger } from './request-logger.js';
|
|
7
|
-
export { performanceMonitor } from './performance-monitor.js';
|
|
8
|
-
export { errorTracker } from './error-tracker.js';
|
|
2
|
+
export { auth } from './auth/index.js';
|
|
3
|
+
export { rateLimit } from './rate-limit/index.js';
|
|
4
|
+
export { cors } from './cors/index.js';
|
|
5
|
+
export { validation } from './validation/index.js';
|
|
6
|
+
export { requestLogger } from './request-logger/index.js';
|
|
7
|
+
export { performanceMonitor } from './performance-monitor/index.js';
|
|
8
|
+
export { errorTracker } from './error-tracker/index.js';
|
|
9
9
|
// Advanced Security & Performance Middleware
|
|
10
|
-
export { cookie } from './cookie.js';
|
|
11
|
-
export { csrf } from './csrf.js';
|
|
12
|
-
export { csp } from './csp.js';
|
|
13
|
-
export { sse } from './sse.js';
|
|
14
|
-
export { session } from './session.js';
|
|
10
|
+
export { cookie } from './cookie/index.js';
|
|
11
|
+
export { csrf } from './csrf/index.js';
|
|
12
|
+
export { csp } from './csp/index.js';
|
|
13
|
+
export { sse } from './sse/index.js';
|
|
14
|
+
export { session } from './session/index.js';
|
|
15
15
|
// Clean Architecture Middleware
|
|
16
|
-
export { cache } from './cache.js';
|
|
17
|
-
export { cdn } from './cdn.js';
|
|
16
|
+
export { cache } from './cache/index.js';
|
|
17
|
+
export { cdn } from './cdn/index.js';
|
|
18
18
|
// Auth Helpers and Extended Providers
|
|
19
|
-
export { requireAuth, requireRole, requirePermission, requireAdmin, guestOnly, optionalAuth, withAuth, protectedRoute, authUtils, authResponses, sessionHelpers, } from './auth
|
|
19
|
+
export { requireAuth, requireRole, requirePermission, requireAdmin, guestOnly, optionalAuth, withAuth, protectedRoute, authUtils, authResponses, sessionHelpers, } from './auth/helpers.js';
|
|
20
20
|
// JWT Utilities for Custom Middleware
|
|
21
|
-
export { safeVerifyJWT, extractJWTFromHeader, createAuthErrorResponse, } from './jwt-helpers.js';
|
|
22
|
-
export { extendedProviders, enterpriseProviders, createCustomOAuthProvider, createCustomOIDCProvider, } from './auth
|
|
21
|
+
export { safeVerifyJWT, extractJWTFromHeader, createAuthErrorResponse, } from './auth/jwt-helpers.js';
|
|
22
|
+
export { extendedProviders, enterpriseProviders, createCustomOAuthProvider, createCustomOIDCProvider, } from './auth/providers.js';
|
|
23
23
|
// Import for collections
|
|
24
|
-
import { auth } from './auth.js';
|
|
25
|
-
import { rateLimit } from './rate-limit.js';
|
|
26
|
-
import { cors } from './cors.js';
|
|
27
|
-
import { validation } from './validation.js';
|
|
28
|
-
import { requestLogger } from './request-logger.js';
|
|
29
|
-
import { performanceMonitor } from './performance-monitor.js';
|
|
30
|
-
import { errorTracker } from './error-tracker.js';
|
|
31
|
-
import { cookie } from './cookie.js';
|
|
32
|
-
import { csrf } from './csrf.js';
|
|
33
|
-
import { csp } from './csp.js';
|
|
34
|
-
import { sse } from './sse.js';
|
|
35
|
-
import { session } from './session.js';
|
|
36
|
-
import { cache } from './cache.js';
|
|
37
|
-
import { cdn } from './cdn.js';
|
|
24
|
+
import { auth } from './auth/index.js';
|
|
25
|
+
import { rateLimit } from './rate-limit/index.js';
|
|
26
|
+
import { cors } from './cors/index.js';
|
|
27
|
+
import { validation } from './validation/index.js';
|
|
28
|
+
import { requestLogger } from './request-logger/index.js';
|
|
29
|
+
import { performanceMonitor } from './performance-monitor/index.js';
|
|
30
|
+
import { errorTracker } from './error-tracker/index.js';
|
|
31
|
+
import { cookie } from './cookie/index.js';
|
|
32
|
+
import { csrf } from './csrf/index.js';
|
|
33
|
+
import { csp } from './csp/index.js';
|
|
34
|
+
import { sse } from './sse/index.js';
|
|
35
|
+
import { session } from './session/index.js';
|
|
36
|
+
import { cache } from './cache/index.js';
|
|
37
|
+
import { cdn } from './cdn/index.js';
|
|
38
38
|
export const builtInMiddleware = {
|
|
39
39
|
auth,
|
|
40
40
|
rateLimit,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/middleware/built-in/index.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/middleware/built-in/index.ts"],"names":[],"mappings":"AAAA,8BAA8B;AAC9B,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,6CAA6C;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAE7C,gCAAgC;AAChC,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAErC,sCAAsC;AACtC,OAAO,EACL,WAAW,EACX,WAAW,EACX,iBAAiB,EACjB,YAAY,EACZ,SAAS,EACT,YAAY,EACZ,QAAQ,EACR,cAAc,EACd,SAAS,EACT,aAAa,EACb,cAAc,GACf,MAAM,mBAAmB,CAAC;AAE3B,sCAAsC;AACtC,OAAO,EACL,aAAa,EACb,oBAAoB,EACpB,uBAAuB,GAExB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,qBAAqB,CAAC;AAE7B,yBAAyB;AACzB,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AACvC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAErC,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,IAAI;IACJ,SAAS;IACT,IAAI;IACJ,UAAU;IACV,sBAAsB;IACtB,MAAM;IACN,IAAI;IACJ,GAAG;IACH,GAAG;IACH,OAAO;IACP,gCAAgC;IAChC,KAAK;IACL,GAAG;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,aAAa;IACb,kBAAkB;IAClB,YAAY;CACb,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { performanceMonitor } from './middleware.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/performance-monitor/index.ts"],"names":[],"mappings":"AAAA,yCAAyC;AACzC,gDAAgD;AAEhD,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Performance monitoring middleware
|
|
3
|
+
* Tracks request duration and logs warnings for slow requests
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* ```ts
|
|
7
|
+
* import { performanceMonitor } from '@/middleware/built-in/performance-monitor';
|
|
8
|
+
*
|
|
9
|
+
* app.use(performanceMonitor);
|
|
10
|
+
* ```
|
|
11
|
+
*/
|
|
12
|
+
export declare const performanceMonitor: (context: any) => Promise<void>;
|
package/dist/core/middleware/built-in/{performance-monitor.js → performance-monitor/middleware.js}
RENAMED
|
@@ -1,6 +1,17 @@
|
|
|
1
|
-
// Performance
|
|
2
|
-
import { createFrameworkLogger } from '
|
|
1
|
+
// Performance Monitor Middleware
|
|
2
|
+
import { createFrameworkLogger } from '../../../logger/index.js';
|
|
3
3
|
const logger = createFrameworkLogger('PerformanceMonitor');
|
|
4
|
+
/**
|
|
5
|
+
* Performance monitoring middleware
|
|
6
|
+
* Tracks request duration and logs warnings for slow requests
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```ts
|
|
10
|
+
* import { performanceMonitor } from '@/middleware/built-in/performance-monitor';
|
|
11
|
+
*
|
|
12
|
+
* app.use(performanceMonitor);
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
4
15
|
export const performanceMonitor = async (context) => {
|
|
5
16
|
const startTime = Date.now();
|
|
6
17
|
context.onComplete = () => {
|
|
@@ -15,4 +26,4 @@ export const performanceMonitor = async (context) => {
|
|
|
15
26
|
}
|
|
16
27
|
};
|
|
17
28
|
};
|
|
18
|
-
//# sourceMappingURL=
|
|
29
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/performance-monitor/middleware.ts"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,MAAM,MAAM,GAAG,qBAAqB,CAAC,oBAAoB,CAAC,CAAC;AAE3D;;;;;;;;;;GAUG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EAAE,OAAY,EAAiB,EAAE;IACtE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAE7B,OAAO,CAAC,UAAU,GAAG,GAAG,EAAE;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;QAExC,oBAAoB;QACpB,IAAI,QAAQ,GAAG,IAAI,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CACT,0BAA0B,OAAO,CAAC,OAAO,EAAE,IAAI,SAAS,QAAQ,IAAI,EACpE,aAAa,EACb;gBACE,IAAI,EAAE,OAAO,CAAC,OAAO,EAAE,IAAI;gBAC3B,MAAM,EAAE,OAAO,CAAC,OAAO,EAAE,MAAM;gBAC/B,QAAQ;aACT,CACF,CAAC;QACJ,CAAC;IACH,CAAC,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { HttpRequest, HttpResponse } from '../../../../types/http.js';
|
|
2
|
+
export interface RateLimitConfig {
|
|
3
|
+
requests: number;
|
|
4
|
+
window: number;
|
|
5
|
+
skipSuccessfulRequests?: boolean;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* RateLimitCore - Core rate limiting logic
|
|
9
|
+
* Used directly by the router for route-based rate limiting
|
|
10
|
+
* Can be instantiated for use in middleware or hooks
|
|
11
|
+
*/
|
|
12
|
+
export declare class RateLimitCore {
|
|
13
|
+
private store;
|
|
14
|
+
/**
|
|
15
|
+
* High-level check for router use: checkLimit(req, res, config)
|
|
16
|
+
* Sends response if rate limit exceeded
|
|
17
|
+
*/
|
|
18
|
+
checkLimit(req: HttpRequest, res: HttpResponse, config: RateLimitConfig): Promise<void>;
|
|
19
|
+
/**
|
|
20
|
+
* Low-level check method
|
|
21
|
+
* Returns true if request is allowed, false if rate limit exceeded
|
|
22
|
+
*/
|
|
23
|
+
check(clientId: string, routeKey: string, requests: number, window: number): boolean;
|
|
24
|
+
/**
|
|
25
|
+
* Get retry-after time in seconds for a rate-limited client
|
|
26
|
+
*/
|
|
27
|
+
getRetryAfter(clientId: string, routeKey: string): number;
|
|
28
|
+
/**
|
|
29
|
+
* Clear all rate limit data
|
|
30
|
+
*/
|
|
31
|
+
clear(): void;
|
|
32
|
+
}
|
|
33
|
+
export declare const sharedRateLimitCore: RateLimitCore;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
// Rate Limit Core - Reusable rate limiting logic
|
|
2
|
+
import { createFrameworkLogger } from '../../../logger/index.js';
|
|
3
|
+
const logger = createFrameworkLogger('RateLimitCore');
|
|
4
|
+
// ===== Core Logic =====
|
|
5
|
+
/**
|
|
6
|
+
* RateLimitCore - Core rate limiting logic
|
|
7
|
+
* Used directly by the router for route-based rate limiting
|
|
8
|
+
* Can be instantiated for use in middleware or hooks
|
|
9
|
+
*/
|
|
10
|
+
export class RateLimitCore {
|
|
11
|
+
store = new Map();
|
|
12
|
+
/**
|
|
13
|
+
* High-level check for router use: checkLimit(req, res, config)
|
|
14
|
+
* Sends response if rate limit exceeded
|
|
15
|
+
*/
|
|
16
|
+
async checkLimit(req, res, config) {
|
|
17
|
+
// Don't send response if headers already sent
|
|
18
|
+
if (res.headersSent) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const clientId = req.ip || req.connection?.remoteAddress || 'unknown';
|
|
22
|
+
const routeKey = `${req.method}:${req.path}`;
|
|
23
|
+
const allowed = this.check(clientId, routeKey, config.requests, config.window);
|
|
24
|
+
if (!allowed) {
|
|
25
|
+
const retryAfter = this.getRetryAfter(clientId, routeKey);
|
|
26
|
+
res.status(429).json({
|
|
27
|
+
success: false,
|
|
28
|
+
error: 'Rate limit exceeded',
|
|
29
|
+
retryAfter,
|
|
30
|
+
});
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Low-level check method
|
|
36
|
+
* Returns true if request is allowed, false if rate limit exceeded
|
|
37
|
+
*/
|
|
38
|
+
check(clientId, routeKey, requests, window) {
|
|
39
|
+
const key = `${routeKey}:${clientId}`;
|
|
40
|
+
const now = Date.now();
|
|
41
|
+
if (!this.store.has(key)) {
|
|
42
|
+
this.store.set(key, { count: 1, resetTime: now + window });
|
|
43
|
+
return true;
|
|
44
|
+
}
|
|
45
|
+
const limitData = this.store.get(key);
|
|
46
|
+
if (!limitData) {
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
if (now > limitData.resetTime) {
|
|
50
|
+
limitData.count = 1;
|
|
51
|
+
limitData.resetTime = now + window;
|
|
52
|
+
return true;
|
|
53
|
+
}
|
|
54
|
+
limitData.count++;
|
|
55
|
+
if (limitData.count > requests) {
|
|
56
|
+
logger.warn('Rate limit exceeded', 'RateLimit', {
|
|
57
|
+
clientId,
|
|
58
|
+
route: routeKey,
|
|
59
|
+
count: limitData.count,
|
|
60
|
+
limit: requests,
|
|
61
|
+
});
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
return true;
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Get retry-after time in seconds for a rate-limited client
|
|
68
|
+
*/
|
|
69
|
+
getRetryAfter(clientId, routeKey) {
|
|
70
|
+
const key = `${routeKey}:${clientId}`;
|
|
71
|
+
const limitData = this.store.get(key);
|
|
72
|
+
if (limitData) {
|
|
73
|
+
return Math.ceil((limitData.resetTime - Date.now()) / 1000);
|
|
74
|
+
}
|
|
75
|
+
return 0;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Clear all rate limit data
|
|
79
|
+
*/
|
|
80
|
+
clear() {
|
|
81
|
+
this.store.clear();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
// Shared instance for route-based rate limiting
|
|
85
|
+
export const sharedRateLimitCore = new RateLimitCore();
|
|
86
|
+
//# sourceMappingURL=core.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core.js","sourceRoot":"","sources":["../../../../../src/core/middleware/built-in/rate-limit/core.ts"],"names":[],"mappings":"AAAA,iDAAiD;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAGjE,MAAM,MAAM,GAAG,qBAAqB,CAAC,eAAe,CAAC,CAAC;AAetD,yBAAyB;AAEzB;;;;GAIG;AACH,MAAM,OAAO,aAAa;IAChB,KAAK,GAAG,IAAI,GAAG,EAA0B,CAAC;IAElD;;;OAGG;IACH,KAAK,CAAC,UAAU,CAAC,GAAgB,EAAE,GAAiB,EAAE,MAAuB;QAC3E,8CAA8C;QAC9C,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;YACpB,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,GAAG,CAAC,EAAE,IAAK,GAAG,CAAC,UAAkB,EAAE,aAAa,IAAI,SAAS,CAAC;QAC/E,MAAM,QAAQ,GAAG,GAAG,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,IAAI,EAAE,CAAC;QAE7C,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QAE/E,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;YAC1D,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;gBACnB,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,qBAAqB;gBAC5B,UAAU;aACX,CAAC,CAAC;YACH,OAAO;QACT,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,QAAgB,EAAE,QAAgB,EAAE,QAAgB,EAAE,MAAc;QACxE,MAAM,GAAG,GAAG,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAEvB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,SAAS,EAAE,GAAG,GAAG,MAAM,EAAE,CAAC,CAAC;YAC3D,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,GAAG,GAAG,SAAS,CAAC,SAAS,EAAE,CAAC;YAC9B,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC;YACpB,SAAS,CAAC,SAAS,GAAG,GAAG,GAAG,MAAM,CAAC;YACnC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,SAAS,CAAC,KAAK,EAAE,CAAC;QAElB,IAAI,SAAS,CAAC,KAAK,GAAG,QAAQ,EAAE,CAAC;YAC/B,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE,WAAW,EAAE;gBAC9C,QAAQ;gBACR,KAAK,EAAE,QAAQ;gBACf,KAAK,EAAE,SAAS,CAAC,KAAK;gBACtB,KAAK,EAAE,QAAQ;aAChB,CAAC,CAAC;YACH,OAAO,KAAK,CAAC;QACf,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,QAAgB,EAAE,QAAgB;QAC9C,MAAM,GAAG,GAAG,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC;QACtC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;QAC9D,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAED;;OAEG;IACH,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF;AAED,gDAAgD;AAChD,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,aAAa,EAAE,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { MiddlewareInterface } from '../../../../types/hooks.js';
|
|
2
|
+
/**
|
|
3
|
+
* Rate limit hook for global usage
|
|
4
|
+
* Registers with the hooks system for application-wide rate limiting
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```ts
|
|
8
|
+
* import { rateLimit } from '@/middleware/built-in/rate-limit';
|
|
9
|
+
*
|
|
10
|
+
* app.use(rateLimit({
|
|
11
|
+
* windowMs: 60000, // 1 minute
|
|
12
|
+
* max: 100 // 100 requests per window
|
|
13
|
+
* }));
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
export declare const rateLimit: (options?: {
|
|
17
|
+
windowMs?: number;
|
|
18
|
+
max?: number;
|
|
19
|
+
message?: string;
|
|
20
|
+
}) => MiddlewareInterface;
|