@engjts/nexus 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +164 -0
- package/dist/advanced/cache/InMemoryCacheStore.d.ts +18 -0
- package/dist/advanced/cache/InMemoryCacheStore.d.ts.map +1 -0
- package/dist/advanced/cache/InMemoryCacheStore.js +60 -0
- package/dist/advanced/cache/InMemoryCacheStore.js.map +1 -0
- package/dist/advanced/cache/MultiTierCache.d.ts +55 -0
- package/dist/advanced/cache/MultiTierCache.d.ts.map +1 -0
- package/dist/advanced/cache/MultiTierCache.js +159 -0
- package/dist/advanced/cache/MultiTierCache.js.map +1 -0
- package/dist/advanced/cache/RedisCacheStore.d.ts +153 -0
- package/dist/advanced/cache/RedisCacheStore.d.ts.map +1 -0
- package/dist/advanced/cache/RedisCacheStore.js +247 -0
- package/dist/advanced/cache/RedisCacheStore.js.map +1 -0
- package/dist/advanced/cache/index.d.ts +6 -0
- package/dist/advanced/cache/index.d.ts.map +1 -0
- package/dist/advanced/cache/index.js +26 -0
- package/dist/advanced/cache/index.js.map +1 -0
- package/dist/advanced/cache/types.d.ts +35 -0
- package/dist/advanced/cache/types.d.ts.map +1 -0
- package/dist/advanced/cache/types.js +3 -0
- package/dist/advanced/cache/types.js.map +1 -0
- package/dist/advanced/graphql/SimpleDataLoader.d.ts +8 -0
- package/dist/advanced/graphql/SimpleDataLoader.d.ts.map +1 -0
- package/dist/advanced/graphql/SimpleDataLoader.js +43 -0
- package/dist/advanced/graphql/SimpleDataLoader.js.map +1 -0
- package/dist/advanced/graphql/index.d.ts +15 -0
- package/dist/advanced/graphql/index.d.ts.map +1 -0
- package/dist/advanced/graphql/index.js +19 -0
- package/dist/advanced/graphql/index.js.map +1 -0
- package/dist/advanced/graphql/server.d.ts +23 -0
- package/dist/advanced/graphql/server.d.ts.map +1 -0
- package/dist/advanced/graphql/server.js +208 -0
- package/dist/advanced/graphql/server.js.map +1 -0
- package/dist/advanced/graphql/types.d.ts +45 -0
- package/dist/advanced/graphql/types.d.ts.map +1 -0
- package/dist/advanced/graphql/types.js +3 -0
- package/dist/advanced/graphql/types.js.map +1 -0
- package/dist/advanced/jobs/InMemoryQueueStore.d.ts +14 -0
- package/dist/advanced/jobs/InMemoryQueueStore.d.ts.map +1 -0
- package/dist/advanced/jobs/InMemoryQueueStore.js +59 -0
- package/dist/advanced/jobs/InMemoryQueueStore.js.map +1 -0
- package/dist/advanced/jobs/JobQueue.d.ts +178 -0
- package/dist/advanced/jobs/JobQueue.d.ts.map +1 -0
- package/dist/advanced/jobs/JobQueue.js +440 -0
- package/dist/advanced/jobs/JobQueue.js.map +1 -0
- package/dist/advanced/jobs/RedisQueueStore.d.ts +157 -0
- package/dist/advanced/jobs/RedisQueueStore.d.ts.map +1 -0
- package/dist/advanced/jobs/RedisQueueStore.js +264 -0
- package/dist/advanced/jobs/RedisQueueStore.js.map +1 -0
- package/dist/advanced/jobs/index.d.ts +6 -0
- package/dist/advanced/jobs/index.d.ts.map +1 -0
- package/dist/advanced/jobs/index.js +26 -0
- package/dist/advanced/jobs/index.js.map +1 -0
- package/dist/advanced/jobs/types.d.ts +64 -0
- package/dist/advanced/jobs/types.d.ts.map +1 -0
- package/dist/advanced/jobs/types.js +3 -0
- package/dist/advanced/jobs/types.js.map +1 -0
- package/dist/advanced/observability/APMManager.d.ts +64 -0
- package/dist/advanced/observability/APMManager.d.ts.map +1 -0
- package/dist/advanced/observability/APMManager.js +150 -0
- package/dist/advanced/observability/APMManager.js.map +1 -0
- package/dist/advanced/observability/AlertManager.d.ts +30 -0
- package/dist/advanced/observability/AlertManager.d.ts.map +1 -0
- package/dist/advanced/observability/AlertManager.js +98 -0
- package/dist/advanced/observability/AlertManager.js.map +1 -0
- package/dist/advanced/observability/MetricRegistry.d.ts +37 -0
- package/dist/advanced/observability/MetricRegistry.d.ts.map +1 -0
- package/dist/advanced/observability/MetricRegistry.js +129 -0
- package/dist/advanced/observability/MetricRegistry.js.map +1 -0
- package/dist/advanced/observability/ObservabilityCenter.d.ts +113 -0
- package/dist/advanced/observability/ObservabilityCenter.d.ts.map +1 -0
- package/dist/advanced/observability/ObservabilityCenter.js +266 -0
- package/dist/advanced/observability/ObservabilityCenter.js.map +1 -0
- package/dist/advanced/observability/StructuredLogger.d.ts +25 -0
- package/dist/advanced/observability/StructuredLogger.d.ts.map +1 -0
- package/dist/advanced/observability/StructuredLogger.js +137 -0
- package/dist/advanced/observability/StructuredLogger.js.map +1 -0
- package/dist/advanced/observability/TracingManager.d.ts +31 -0
- package/dist/advanced/observability/TracingManager.d.ts.map +1 -0
- package/dist/advanced/observability/TracingManager.js +105 -0
- package/dist/advanced/observability/TracingManager.js.map +1 -0
- package/dist/advanced/observability/adapters.d.ts +134 -0
- package/dist/advanced/observability/adapters.d.ts.map +1 -0
- package/dist/advanced/observability/adapters.js +257 -0
- package/dist/advanced/observability/adapters.js.map +1 -0
- package/dist/advanced/observability/createObservabilityMiddleware.d.ts +8 -0
- package/dist/advanced/observability/createObservabilityMiddleware.d.ts.map +1 -0
- package/dist/advanced/observability/createObservabilityMiddleware.js +46 -0
- package/dist/advanced/observability/createObservabilityMiddleware.js.map +1 -0
- package/dist/advanced/observability/index.d.ts +2 -0
- package/dist/advanced/observability/index.d.ts.map +1 -0
- package/dist/advanced/observability/index.js +13 -0
- package/dist/advanced/observability/index.js.map +1 -0
- package/dist/advanced/observability/types.d.ts +182 -0
- package/dist/advanced/observability/types.d.ts.map +1 -0
- package/dist/advanced/observability/types.js +3 -0
- package/dist/advanced/observability/types.js.map +1 -0
- package/dist/advanced/playground/extractPathParams.d.ts +4 -0
- package/dist/advanced/playground/extractPathParams.d.ts.map +1 -0
- package/dist/advanced/playground/extractPathParams.js +8 -0
- package/dist/advanced/playground/extractPathParams.js.map +1 -0
- package/dist/advanced/playground/generateFieldExample.d.ts +2 -0
- package/dist/advanced/playground/generateFieldExample.d.ts.map +1 -0
- package/dist/advanced/playground/generateFieldExample.js +40 -0
- package/dist/advanced/playground/generateFieldExample.js.map +1 -0
- package/dist/advanced/playground/generatePlaygroundHTML.d.ts +3 -0
- package/dist/advanced/playground/generatePlaygroundHTML.d.ts.map +1 -0
- package/dist/advanced/playground/generatePlaygroundHTML.js +1848 -0
- package/dist/advanced/playground/generatePlaygroundHTML.js.map +1 -0
- package/dist/advanced/playground/generateSummary.d.ts +3 -0
- package/dist/advanced/playground/generateSummary.d.ts.map +1 -0
- package/dist/advanced/playground/generateSummary.js +19 -0
- package/dist/advanced/playground/generateSummary.js.map +1 -0
- package/dist/advanced/playground/getTagFromPath.d.ts +2 -0
- package/dist/advanced/playground/getTagFromPath.d.ts.map +1 -0
- package/dist/advanced/playground/getTagFromPath.js +11 -0
- package/dist/advanced/playground/getTagFromPath.js.map +1 -0
- package/dist/advanced/playground/index.d.ts +7 -0
- package/dist/advanced/playground/index.d.ts.map +1 -0
- package/dist/advanced/playground/index.js +10 -0
- package/dist/advanced/playground/index.js.map +1 -0
- package/dist/advanced/playground/playground.d.ts +4 -0
- package/dist/advanced/playground/playground.d.ts.map +1 -0
- package/dist/advanced/playground/playground.js +139 -0
- package/dist/advanced/playground/playground.js.map +1 -0
- package/dist/advanced/playground/types.d.ts +18 -0
- package/dist/advanced/playground/types.d.ts.map +1 -0
- package/dist/advanced/playground/types.js +3 -0
- package/dist/advanced/playground/types.js.map +1 -0
- package/dist/advanced/playground/zodToExample.d.ts +2 -0
- package/dist/advanced/playground/zodToExample.d.ts.map +1 -0
- package/dist/advanced/playground/zodToExample.js +22 -0
- package/dist/advanced/playground/zodToExample.js.map +1 -0
- package/dist/advanced/playground/zodToParams.d.ts +5 -0
- package/dist/advanced/playground/zodToParams.d.ts.map +1 -0
- package/dist/advanced/playground/zodToParams.js +18 -0
- package/dist/advanced/playground/zodToParams.js.map +1 -0
- package/dist/advanced/postman/buildAuth.d.ts +3 -0
- package/dist/advanced/postman/buildAuth.d.ts.map +1 -0
- package/dist/advanced/postman/buildAuth.js +32 -0
- package/dist/advanced/postman/buildAuth.js.map +1 -0
- package/dist/advanced/postman/buildBody.d.ts +3 -0
- package/dist/advanced/postman/buildBody.d.ts.map +1 -0
- package/dist/advanced/postman/buildBody.js +15 -0
- package/dist/advanced/postman/buildBody.js.map +1 -0
- package/dist/advanced/postman/buildQueryParams.d.ts +3 -0
- package/dist/advanced/postman/buildQueryParams.d.ts.map +1 -0
- package/dist/advanced/postman/buildQueryParams.js +26 -0
- package/dist/advanced/postman/buildQueryParams.js.map +1 -0
- package/dist/advanced/postman/buildRequestItem.d.ts +3 -0
- package/dist/advanced/postman/buildRequestItem.d.ts.map +1 -0
- package/dist/advanced/postman/buildRequestItem.js +33 -0
- package/dist/advanced/postman/buildRequestItem.js.map +1 -0
- package/dist/advanced/postman/buildResponses.d.ts +3 -0
- package/dist/advanced/postman/buildResponses.d.ts.map +1 -0
- package/dist/advanced/postman/buildResponses.js +12 -0
- package/dist/advanced/postman/buildResponses.js.map +1 -0
- package/dist/advanced/postman/buildUrl.d.ts +3 -0
- package/dist/advanced/postman/buildUrl.d.ts.map +1 -0
- package/dist/advanced/postman/buildUrl.js +30 -0
- package/dist/advanced/postman/buildUrl.js.map +1 -0
- package/dist/advanced/postman/capitalize.d.ts +2 -0
- package/dist/advanced/postman/capitalize.d.ts.map +1 -0
- package/dist/advanced/postman/capitalize.js +7 -0
- package/dist/advanced/postman/capitalize.js.map +1 -0
- package/dist/advanced/postman/generateCollection.d.ts +3 -0
- package/dist/advanced/postman/generateCollection.d.ts.map +1 -0
- package/dist/advanced/postman/generateCollection.js +50 -0
- package/dist/advanced/postman/generateCollection.js.map +1 -0
- package/dist/advanced/postman/generateEnvironment.d.ts +3 -0
- package/dist/advanced/postman/generateEnvironment.d.ts.map +1 -0
- package/dist/advanced/postman/generateEnvironment.js +33 -0
- package/dist/advanced/postman/generateEnvironment.js.map +1 -0
- package/dist/advanced/postman/generateExampleFromZod.d.ts +2 -0
- package/dist/advanced/postman/generateExampleFromZod.d.ts.map +1 -0
- package/dist/advanced/postman/generateExampleFromZod.js +22 -0
- package/dist/advanced/postman/generateExampleFromZod.js.map +1 -0
- package/dist/advanced/postman/generateFieldExample.d.ts +2 -0
- package/dist/advanced/postman/generateFieldExample.d.ts.map +1 -0
- package/dist/advanced/postman/generateFieldExample.js +55 -0
- package/dist/advanced/postman/generateFieldExample.js.map +1 -0
- package/dist/advanced/postman/generateName.d.ts +3 -0
- package/dist/advanced/postman/generateName.d.ts.map +1 -0
- package/dist/advanced/postman/generateName.js +19 -0
- package/dist/advanced/postman/generateName.js.map +1 -0
- package/dist/advanced/postman/generateUUID.d.ts +2 -0
- package/dist/advanced/postman/generateUUID.d.ts.map +1 -0
- package/dist/advanced/postman/generateUUID.js +14 -0
- package/dist/advanced/postman/generateUUID.js.map +1 -0
- package/dist/advanced/postman/getTagFromPath.d.ts +2 -0
- package/dist/advanced/postman/getTagFromPath.d.ts.map +1 -0
- package/dist/advanced/postman/getTagFromPath.js +12 -0
- package/dist/advanced/postman/getTagFromPath.js.map +1 -0
- package/dist/advanced/postman/index.d.ts +28 -0
- package/dist/advanced/postman/index.d.ts.map +1 -0
- package/dist/advanced/postman/index.js +30 -0
- package/dist/advanced/postman/index.js.map +1 -0
- package/dist/advanced/postman/postman.d.ts +7 -0
- package/dist/advanced/postman/postman.d.ts.map +1 -0
- package/dist/advanced/postman/postman.js +138 -0
- package/dist/advanced/postman/postman.js.map +1 -0
- package/dist/advanced/postman/slugify.d.ts +2 -0
- package/dist/advanced/postman/slugify.d.ts.map +1 -0
- package/dist/advanced/postman/slugify.js +10 -0
- package/dist/advanced/postman/slugify.js.map +1 -0
- package/dist/advanced/postman/types.d.ts +133 -0
- package/dist/advanced/postman/types.d.ts.map +1 -0
- package/dist/advanced/postman/types.js +3 -0
- package/dist/advanced/postman/types.js.map +1 -0
- package/dist/advanced/realtime/index.d.ts +13 -0
- package/dist/advanced/realtime/index.d.ts.map +1 -0
- package/dist/advanced/realtime/index.js +17 -0
- package/dist/advanced/realtime/index.js.map +1 -0
- package/dist/advanced/realtime/websocket.d.ts +60 -0
- package/dist/advanced/realtime/websocket.d.ts.map +1 -0
- package/dist/advanced/realtime/websocket.js +197 -0
- package/dist/advanced/realtime/websocket.js.map +1 -0
- package/dist/advanced/sentry/index.d.ts +287 -0
- package/dist/advanced/sentry/index.d.ts.map +1 -0
- package/dist/advanced/sentry/index.js +1002 -0
- package/dist/advanced/sentry/index.js.map +1 -0
- package/dist/advanced/sentry/types.d.ts +298 -0
- package/dist/advanced/sentry/types.d.ts.map +1 -0
- package/dist/advanced/sentry/types.js +6 -0
- package/dist/advanced/sentry/types.js.map +1 -0
- package/dist/advanced/static/generateDirectoryListing.d.ts +5 -0
- package/dist/advanced/static/generateDirectoryListing.d.ts.map +1 -0
- package/dist/advanced/static/generateDirectoryListing.js +44 -0
- package/dist/advanced/static/generateDirectoryListing.js.map +1 -0
- package/dist/advanced/static/generateETag.d.ts +8 -0
- package/dist/advanced/static/generateETag.d.ts.map +1 -0
- package/dist/advanced/static/generateETag.js +10 -0
- package/dist/advanced/static/generateETag.js.map +1 -0
- package/dist/advanced/static/getMimeType.d.ts +5 -0
- package/dist/advanced/static/getMimeType.d.ts.map +1 -0
- package/dist/advanced/static/getMimeType.js +11 -0
- package/dist/advanced/static/getMimeType.js.map +1 -0
- package/dist/advanced/static/index.d.ts +30 -0
- package/dist/advanced/static/index.d.ts.map +1 -0
- package/dist/advanced/static/index.js +33 -0
- package/dist/advanced/static/index.js.map +1 -0
- package/dist/advanced/static/isSafePath.d.ts +5 -0
- package/dist/advanced/static/isSafePath.d.ts.map +1 -0
- package/dist/advanced/static/isSafePath.js +14 -0
- package/dist/advanced/static/isSafePath.js.map +1 -0
- package/dist/advanced/static/publicDir.d.ts +12 -0
- package/dist/advanced/static/publicDir.d.ts.map +1 -0
- package/dist/advanced/static/publicDir.js +22 -0
- package/dist/advanced/static/publicDir.js.map +1 -0
- package/dist/advanced/static/serveStatic.d.ts +7 -0
- package/dist/advanced/static/serveStatic.d.ts.map +1 -0
- package/dist/advanced/static/serveStatic.js +198 -0
- package/dist/advanced/static/serveStatic.js.map +1 -0
- package/dist/advanced/static/spa.d.ts +14 -0
- package/dist/advanced/static/spa.d.ts.map +1 -0
- package/dist/advanced/static/spa.js +23 -0
- package/dist/advanced/static/spa.js.map +1 -0
- package/dist/advanced/static/types.d.ts +78 -0
- package/dist/advanced/static/types.d.ts.map +1 -0
- package/dist/advanced/static/types.js +67 -0
- package/dist/advanced/static/types.js.map +1 -0
- package/dist/advanced/swagger/SwaggerGenerator.d.ts +19 -0
- package/dist/advanced/swagger/SwaggerGenerator.d.ts.map +1 -0
- package/dist/advanced/swagger/SwaggerGenerator.js +59 -0
- package/dist/advanced/swagger/SwaggerGenerator.js.map +1 -0
- package/dist/advanced/swagger/buildOperation.d.ts +6 -0
- package/dist/advanced/swagger/buildOperation.d.ts.map +1 -0
- package/dist/advanced/swagger/buildOperation.js +54 -0
- package/dist/advanced/swagger/buildOperation.js.map +1 -0
- package/dist/advanced/swagger/buildParameters.d.ts +6 -0
- package/dist/advanced/swagger/buildParameters.d.ts.map +1 -0
- package/dist/advanced/swagger/buildParameters.js +57 -0
- package/dist/advanced/swagger/buildParameters.js.map +1 -0
- package/dist/advanced/swagger/buildRequestBody.d.ts +7 -0
- package/dist/advanced/swagger/buildRequestBody.d.ts.map +1 -0
- package/dist/advanced/swagger/buildRequestBody.js +19 -0
- package/dist/advanced/swagger/buildRequestBody.js.map +1 -0
- package/dist/advanced/swagger/buildResponses.d.ts +7 -0
- package/dist/advanced/swagger/buildResponses.d.ts.map +1 -0
- package/dist/advanced/swagger/buildResponses.js +48 -0
- package/dist/advanced/swagger/buildResponses.js.map +1 -0
- package/dist/advanced/swagger/capitalize.d.ts +2 -0
- package/dist/advanced/swagger/capitalize.d.ts.map +1 -0
- package/dist/advanced/swagger/capitalize.js +7 -0
- package/dist/advanced/swagger/capitalize.js.map +1 -0
- package/dist/advanced/swagger/convertPath.d.ts +6 -0
- package/dist/advanced/swagger/convertPath.d.ts.map +1 -0
- package/dist/advanced/swagger/convertPath.js +11 -0
- package/dist/advanced/swagger/convertPath.js.map +1 -0
- package/dist/advanced/swagger/createSwagger.d.ts +8 -0
- package/dist/advanced/swagger/createSwagger.d.ts.map +1 -0
- package/dist/advanced/swagger/createSwagger.js +12 -0
- package/dist/advanced/swagger/createSwagger.js.map +1 -0
- package/dist/advanced/swagger/generateOperationId.d.ts +6 -0
- package/dist/advanced/swagger/generateOperationId.d.ts.map +1 -0
- package/dist/advanced/swagger/generateOperationId.js +20 -0
- package/dist/advanced/swagger/generateOperationId.js.map +1 -0
- package/dist/advanced/swagger/generateSpec.d.ts +6 -0
- package/dist/advanced/swagger/generateSpec.d.ts.map +1 -0
- package/dist/advanced/swagger/generateSpec.js +85 -0
- package/dist/advanced/swagger/generateSpec.js.map +1 -0
- package/dist/advanced/swagger/generateSummary.d.ts +6 -0
- package/dist/advanced/swagger/generateSummary.d.ts.map +1 -0
- package/dist/advanced/swagger/generateSummary.js +22 -0
- package/dist/advanced/swagger/generateSummary.js.map +1 -0
- package/dist/advanced/swagger/generateSwaggerUI.d.ts +6 -0
- package/dist/advanced/swagger/generateSwaggerUI.d.ts.map +1 -0
- package/dist/advanced/swagger/generateSwaggerUI.js +69 -0
- package/dist/advanced/swagger/generateSwaggerUI.js.map +1 -0
- package/dist/advanced/swagger/generateThemeCss.d.ts +6 -0
- package/dist/advanced/swagger/generateThemeCss.d.ts.map +1 -0
- package/dist/advanced/swagger/generateThemeCss.js +53 -0
- package/dist/advanced/swagger/generateThemeCss.js.map +1 -0
- package/dist/advanced/swagger/index.d.ts +23 -0
- package/dist/advanced/swagger/index.d.ts.map +1 -0
- package/dist/advanced/swagger/index.js +26 -0
- package/dist/advanced/swagger/index.js.map +1 -0
- package/dist/advanced/swagger/swagger.d.ts +36 -0
- package/dist/advanced/swagger/swagger.d.ts.map +1 -0
- package/dist/advanced/swagger/swagger.js +198 -0
- package/dist/advanced/swagger/swagger.js.map +1 -0
- package/dist/advanced/swagger/types.d.ts +210 -0
- package/dist/advanced/swagger/types.d.ts.map +1 -0
- package/dist/advanced/swagger/types.js +3 -0
- package/dist/advanced/swagger/types.js.map +1 -0
- package/dist/advanced/swagger/zodFieldToOpenAPI.d.ts +6 -0
- package/dist/advanced/swagger/zodFieldToOpenAPI.d.ts.map +1 -0
- package/dist/advanced/swagger/zodFieldToOpenAPI.js +86 -0
- package/dist/advanced/swagger/zodFieldToOpenAPI.js.map +1 -0
- package/dist/advanced/swagger/zodSchemaToOpenAPI.d.ts +6 -0
- package/dist/advanced/swagger/zodSchemaToOpenAPI.d.ts.map +1 -0
- package/dist/advanced/swagger/zodSchemaToOpenAPI.js +44 -0
- package/dist/advanced/swagger/zodSchemaToOpenAPI.js.map +1 -0
- package/dist/advanced/swagger/zodToOpenAPI.d.ts +6 -0
- package/dist/advanced/swagger/zodToOpenAPI.d.ts.map +1 -0
- package/dist/advanced/swagger/zodToOpenAPI.js +22 -0
- package/dist/advanced/swagger/zodToOpenAPI.js.map +1 -0
- package/dist/advanced/testing/factory.d.ts +206 -0
- package/dist/advanced/testing/factory.d.ts.map +1 -0
- package/dist/advanced/testing/factory.js +433 -0
- package/dist/advanced/testing/factory.js.map +1 -0
- package/dist/advanced/testing/harness.d.ts +181 -0
- package/dist/advanced/testing/harness.d.ts.map +1 -0
- package/dist/advanced/testing/harness.js +481 -0
- package/dist/advanced/testing/harness.js.map +1 -0
- package/dist/advanced/testing/index.d.ts +235 -0
- package/dist/advanced/testing/index.d.ts.map +1 -0
- package/dist/advanced/testing/index.js +306 -0
- package/dist/advanced/testing/index.js.map +1 -0
- package/dist/advanced/testing/load-test.d.ts +148 -0
- package/dist/advanced/testing/load-test.d.ts.map +1 -0
- package/dist/advanced/testing/load-test.js +490 -0
- package/dist/advanced/testing/load-test.js.map +1 -0
- package/dist/advanced/testing/mock-server.d.ts +166 -0
- package/dist/advanced/testing/mock-server.d.ts.map +1 -0
- package/dist/advanced/testing/mock-server.js +424 -0
- package/dist/advanced/testing/mock-server.js.map +1 -0
- package/dist/advanced/testing/mock.d.ts +248 -0
- package/dist/advanced/testing/mock.d.ts.map +1 -0
- package/dist/advanced/testing/mock.js +549 -0
- package/dist/advanced/testing/mock.js.map +1 -0
- package/dist/cli/bin.d.ts +3 -0
- package/dist/cli/bin.d.ts.map +1 -0
- package/dist/cli/bin.js +10 -0
- package/dist/cli/bin.js.map +1 -0
- package/dist/cli/cli.d.ts +24 -0
- package/dist/cli/cli.d.ts.map +1 -0
- package/dist/cli/cli.js +131 -0
- package/dist/cli/cli.js.map +1 -0
- package/dist/cli/commands/build.d.ts +20 -0
- package/dist/cli/commands/build.d.ts.map +1 -0
- package/dist/cli/commands/build.js +63 -0
- package/dist/cli/commands/build.js.map +1 -0
- package/dist/cli/commands/create.d.ts +13 -0
- package/dist/cli/commands/create.d.ts.map +1 -0
- package/dist/cli/commands/create.js +142 -0
- package/dist/cli/commands/create.js.map +1 -0
- package/dist/cli/commands/dev.d.ts +15 -0
- package/dist/cli/commands/dev.d.ts.map +1 -0
- package/dist/cli/commands/dev.js +77 -0
- package/dist/cli/commands/dev.js.map +1 -0
- package/dist/cli/commands/generate.d.ts +13 -0
- package/dist/cli/commands/generate.d.ts.map +1 -0
- package/dist/cli/commands/generate.js +80 -0
- package/dist/cli/commands/generate.js.map +1 -0
- package/dist/cli/commands/help.d.ts +13 -0
- package/dist/cli/commands/help.d.ts.map +1 -0
- package/dist/cli/commands/help.js +83 -0
- package/dist/cli/commands/help.js.map +1 -0
- package/dist/cli/commands/init.d.ts +11 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +76 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/version.d.ts +9 -0
- package/dist/cli/commands/version.d.ts.map +1 -0
- package/dist/cli/commands/version.js +35 -0
- package/dist/cli/commands/version.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +7 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/templates/generators.d.ts +22 -0
- package/dist/cli/templates/generators.d.ts.map +1 -0
- package/dist/cli/templates/generators.js +282 -0
- package/dist/cli/templates/generators.js.map +1 -0
- package/dist/cli/templates/index.d.ts +27 -0
- package/dist/cli/templates/index.d.ts.map +1 -0
- package/dist/cli/templates/index.js +651 -0
- package/dist/cli/templates/index.js.map +1 -0
- package/dist/cli/utils/exec.d.ts +12 -0
- package/dist/cli/utils/exec.d.ts.map +1 -0
- package/dist/cli/utils/exec.js +37 -0
- package/dist/cli/utils/exec.js.map +1 -0
- package/dist/cli/utils/file-system.d.ts +15 -0
- package/dist/cli/utils/file-system.d.ts.map +1 -0
- package/dist/cli/utils/file-system.js +105 -0
- package/dist/cli/utils/file-system.js.map +1 -0
- package/dist/cli/utils/logger.d.ts +40 -0
- package/dist/cli/utils/logger.d.ts.map +1 -0
- package/dist/cli/utils/logger.js +100 -0
- package/dist/cli/utils/logger.js.map +1 -0
- package/dist/core/adapter.d.ts +73 -0
- package/dist/core/adapter.d.ts.map +1 -0
- package/dist/core/adapter.js +27 -0
- package/dist/core/adapter.js.map +1 -0
- package/dist/core/application.d.ts +540 -0
- package/dist/core/application.d.ts.map +1 -0
- package/dist/core/application.js +1111 -0
- package/dist/core/application.js.map +1 -0
- package/dist/core/context-pool.d.ts +52 -0
- package/dist/core/context-pool.d.ts.map +1 -0
- package/dist/core/context-pool.js +111 -0
- package/dist/core/context-pool.js.map +1 -0
- package/dist/core/context.d.ts +148 -0
- package/dist/core/context.d.ts.map +1 -0
- package/dist/core/context.js +367 -0
- package/dist/core/context.js.map +1 -0
- package/dist/core/index.d.ts +23 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +77 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/middleware.d.ts +49 -0
- package/dist/core/middleware.d.ts.map +1 -0
- package/dist/core/middleware.js +215 -0
- package/dist/core/middleware.js.map +1 -0
- package/dist/core/performance/buffer-pool.d.ts +47 -0
- package/dist/core/performance/buffer-pool.d.ts.map +1 -0
- package/dist/core/performance/buffer-pool.js +97 -0
- package/dist/core/performance/buffer-pool.js.map +1 -0
- package/dist/core/performance/jit-compiler.d.ts +73 -0
- package/dist/core/performance/jit-compiler.d.ts.map +1 -0
- package/dist/core/performance/jit-compiler.js +145 -0
- package/dist/core/performance/jit-compiler.js.map +1 -0
- package/dist/core/performance/middleware-optimizer.d.ts +73 -0
- package/dist/core/performance/middleware-optimizer.d.ts.map +1 -0
- package/dist/core/performance/middleware-optimizer.js +138 -0
- package/dist/core/performance/middleware-optimizer.js.map +1 -0
- package/dist/core/plugin/PluginManager.d.ts +93 -0
- package/dist/core/plugin/PluginManager.d.ts.map +1 -0
- package/dist/core/plugin/PluginManager.js +351 -0
- package/dist/core/plugin/PluginManager.js.map +1 -0
- package/dist/core/plugin/builder.d.ts +192 -0
- package/dist/core/plugin/builder.d.ts.map +1 -0
- package/dist/core/plugin/builder.js +319 -0
- package/dist/core/plugin/builder.js.map +1 -0
- package/dist/core/plugin/index.d.ts +31 -0
- package/dist/core/plugin/index.d.ts.map +1 -0
- package/dist/core/plugin/index.js +41 -0
- package/dist/core/plugin/index.js.map +1 -0
- package/dist/core/plugin/types.d.ts +184 -0
- package/dist/core/plugin/types.d.ts.map +1 -0
- package/dist/core/plugin/types.js +17 -0
- package/dist/core/plugin/types.js.map +1 -0
- package/dist/core/router/file-router.d.ts +173 -0
- package/dist/core/router/file-router.d.ts.map +1 -0
- package/dist/core/router/file-router.js +498 -0
- package/dist/core/router/file-router.js.map +1 -0
- package/dist/core/router/index.d.ts +44 -0
- package/dist/core/router/index.d.ts.map +1 -0
- package/dist/core/router/index.js +145 -0
- package/dist/core/router/index.js.map +1 -0
- package/dist/core/router/radix-tree.d.ts +69 -0
- package/dist/core/router/radix-tree.d.ts.map +1 -0
- package/dist/core/router/radix-tree.js +196 -0
- package/dist/core/router/radix-tree.js.map +1 -0
- package/dist/core/store/index.d.ts +15 -0
- package/dist/core/store/index.d.ts.map +1 -0
- package/dist/core/store/index.js +23 -0
- package/dist/core/store/index.js.map +1 -0
- package/dist/core/store/registry.d.ts +80 -0
- package/dist/core/store/registry.d.ts.map +1 -0
- package/dist/core/store/registry.js +156 -0
- package/dist/core/store/registry.js.map +1 -0
- package/dist/core/store/request-store.d.ts +138 -0
- package/dist/core/store/request-store.d.ts.map +1 -0
- package/dist/core/store/request-store.js +209 -0
- package/dist/core/store/request-store.js.map +1 -0
- package/dist/core/store/types.d.ts +140 -0
- package/dist/core/store/types.d.ts.map +1 -0
- package/dist/core/store/types.js +176 -0
- package/dist/core/store/types.js.map +1 -0
- package/dist/core/types.d.ts +470 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +106 -0
- package/dist/core/types.js.map +1 -0
- package/dist/database/adapter.d.ts +32 -0
- package/dist/database/adapter.d.ts.map +1 -0
- package/dist/database/adapter.js +3 -0
- package/dist/database/adapter.js.map +1 -0
- package/dist/database/adapters/index.d.ts +2 -0
- package/dist/database/adapters/index.d.ts.map +1 -0
- package/dist/database/adapters/index.js +18 -0
- package/dist/database/adapters/index.js.map +1 -0
- package/dist/database/adapters/mysql.d.ts +160 -0
- package/dist/database/adapters/mysql.d.ts.map +1 -0
- package/dist/database/adapters/mysql.js +501 -0
- package/dist/database/adapters/mysql.js.map +1 -0
- package/dist/database/database.d.ts +27 -0
- package/dist/database/database.d.ts.map +1 -0
- package/dist/database/database.js +59 -0
- package/dist/database/database.js.map +1 -0
- package/dist/database/dialect.d.ts +110 -0
- package/dist/database/dialect.d.ts.map +1 -0
- package/dist/database/dialect.js +269 -0
- package/dist/database/dialect.js.map +1 -0
- package/dist/database/index.d.ts +12 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js +28 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/migrations.d.ts +22 -0
- package/dist/database/migrations.d.ts.map +1 -0
- package/dist/database/migrations.js +73 -0
- package/dist/database/migrations.js.map +1 -0
- package/dist/database/optimizer.d.ts +25 -0
- package/dist/database/optimizer.d.ts.map +1 -0
- package/dist/database/optimizer.js +97 -0
- package/dist/database/optimizer.js.map +1 -0
- package/dist/database/query-builder.d.ts +49 -0
- package/dist/database/query-builder.d.ts.map +1 -0
- package/dist/database/query-builder.js +319 -0
- package/dist/database/query-builder.js.map +1 -0
- package/dist/database/realtime.d.ts +24 -0
- package/dist/database/realtime.d.ts.map +1 -0
- package/dist/database/realtime.js +38 -0
- package/dist/database/realtime.js.map +1 -0
- package/dist/database/schema.d.ts +27 -0
- package/dist/database/schema.d.ts.map +1 -0
- package/dist/database/schema.js +47 -0
- package/dist/database/schema.js.map +1 -0
- package/dist/database/transactions.d.ts +13 -0
- package/dist/database/transactions.d.ts.map +1 -0
- package/dist/database/transactions.js +51 -0
- package/dist/database/transactions.js.map +1 -0
- package/dist/database/types.d.ts +68 -0
- package/dist/database/types.d.ts.map +1 -0
- package/dist/database/types.js +3 -0
- package/dist/database/types.js.map +1 -0
- package/dist/deployment/cluster.d.ts +161 -0
- package/dist/deployment/cluster.d.ts.map +1 -0
- package/dist/deployment/cluster.js +336 -0
- package/dist/deployment/cluster.js.map +1 -0
- package/dist/deployment/config.d.ts +209 -0
- package/dist/deployment/config.d.ts.map +1 -0
- package/dist/deployment/config.js +263 -0
- package/dist/deployment/config.js.map +1 -0
- package/dist/deployment/docker.d.ts +168 -0
- package/dist/deployment/docker.d.ts.map +1 -0
- package/dist/deployment/docker.js +437 -0
- package/dist/deployment/docker.js.map +1 -0
- package/dist/deployment/graceful-shutdown.d.ts +130 -0
- package/dist/deployment/graceful-shutdown.d.ts.map +1 -0
- package/dist/deployment/graceful-shutdown.js +271 -0
- package/dist/deployment/graceful-shutdown.js.map +1 -0
- package/dist/deployment/index.d.ts +14 -0
- package/dist/deployment/index.d.ts.map +1 -0
- package/dist/deployment/index.js +33 -0
- package/dist/deployment/index.js.map +1 -0
- package/dist/index.d.ts +39 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +174 -0
- package/dist/index.js.map +1 -0
- package/dist/security/adapter.d.ts +144 -0
- package/dist/security/adapter.d.ts.map +1 -0
- package/dist/security/adapter.js +159 -0
- package/dist/security/adapter.js.map +1 -0
- package/dist/security/auth/JWTPlugin.d.ts +105 -0
- package/dist/security/auth/JWTPlugin.d.ts.map +1 -0
- package/dist/security/auth/JWTPlugin.js +146 -0
- package/dist/security/auth/JWTPlugin.js.map +1 -0
- package/dist/security/auth/JWTProvider.d.ts +104 -0
- package/dist/security/auth/JWTProvider.d.ts.map +1 -0
- package/dist/security/auth/JWTProvider.js +288 -0
- package/dist/security/auth/JWTProvider.js.map +1 -0
- package/dist/security/auth/adapter.d.ts +8 -0
- package/dist/security/auth/adapter.d.ts.map +1 -0
- package/dist/security/auth/adapter.js +29 -0
- package/dist/security/auth/adapter.js.map +1 -0
- package/dist/security/auth/jwt.d.ts +55 -0
- package/dist/security/auth/jwt.d.ts.map +1 -0
- package/dist/security/auth/jwt.js +198 -0
- package/dist/security/auth/jwt.js.map +1 -0
- package/dist/security/auth/middleware.d.ts +64 -0
- package/dist/security/auth/middleware.d.ts.map +1 -0
- package/dist/security/auth/middleware.js +161 -0
- package/dist/security/auth/middleware.js.map +1 -0
- package/dist/security/csrf.d.ts +41 -0
- package/dist/security/csrf.d.ts.map +1 -0
- package/dist/security/csrf.js +185 -0
- package/dist/security/csrf.js.map +1 -0
- package/dist/security/headers.d.ts +34 -0
- package/dist/security/headers.d.ts.map +1 -0
- package/dist/security/headers.js +95 -0
- package/dist/security/headers.js.map +1 -0
- package/dist/security/index.d.ts +19 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +65 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/rate-limit/adapter.d.ts +7 -0
- package/dist/security/rate-limit/adapter.d.ts.map +1 -0
- package/dist/security/rate-limit/adapter.js +8 -0
- package/dist/security/rate-limit/adapter.js.map +1 -0
- package/dist/security/rate-limit/memory.d.ts +28 -0
- package/dist/security/rate-limit/memory.d.ts.map +1 -0
- package/dist/security/rate-limit/memory.js +85 -0
- package/dist/security/rate-limit/memory.js.map +1 -0
- package/dist/security/rate-limit/middleware.d.ts +32 -0
- package/dist/security/rate-limit/middleware.d.ts.map +1 -0
- package/dist/security/rate-limit/middleware.js +159 -0
- package/dist/security/rate-limit/middleware.js.map +1 -0
- package/dist/security/sanitization.d.ts +29 -0
- package/dist/security/sanitization.d.ts.map +1 -0
- package/dist/security/sanitization.js +66 -0
- package/dist/security/sanitization.js.map +1 -0
- package/dist/security/types.d.ts +205 -0
- package/dist/security/types.d.ts.map +1 -0
- package/dist/security/types.js +8 -0
- package/dist/security/types.js.map +1 -0
- package/dist/security/utils.d.ts +19 -0
- package/dist/security/utils.d.ts.map +1 -0
- package/dist/security/utils.js +43 -0
- package/dist/security/utils.js.map +1 -0
- package/documentation/01-getting-started.md +240 -0
- package/documentation/02-context.md +335 -0
- package/documentation/03-routing.md +397 -0
- package/documentation/04-middleware.md +483 -0
- package/documentation/05-validation.md +514 -0
- package/documentation/06-error-handling.md +465 -0
- package/documentation/07-performance.md +364 -0
- package/documentation/08-adapters.md +470 -0
- package/documentation/09-api-reference.md +548 -0
- package/documentation/10-examples.md +582 -0
- package/documentation/11-deployment.md +477 -0
- package/documentation/12-sentry.md +620 -0
- package/documentation/13-sentry-data-storage.md +996 -0
- package/documentation/14-sentry-data-reference.md +457 -0
- package/documentation/15-sentry-summary.md +409 -0
- package/documentation/16-alerts-system.md +745 -0
- package/documentation/17-alert-adapters.md +696 -0
- package/documentation/18-alerts-implementation-summary.md +385 -0
- package/documentation/19-class-based-routing.md +840 -0
- package/documentation/20-websocket-realtime.md +813 -0
- package/documentation/21-cache-system.md +510 -0
- package/documentation/22-job-queue.md +772 -0
- package/documentation/23-sentry-plugin.md +551 -0
- package/documentation/24-testing-utilities.md +1287 -0
- package/documentation/25-api-versioning.md +533 -0
- package/documentation/26-context-store.md +607 -0
- package/documentation/27-dependency-injection.md +329 -0
- package/documentation/28-lifecycle-hooks.md +521 -0
- package/documentation/29-package-structure.md +196 -0
- package/documentation/30-plugin-system.md +414 -0
- package/documentation/31-jwt-authentication.md +597 -0
- package/documentation/32-cli.md +268 -0
- package/documentation/ALERTS-COMPLETE-SUMMARY.md +429 -0
- package/documentation/ALERTS-INDEX.md +330 -0
- package/documentation/ALERTS-QUICK-REFERENCE.md +286 -0
- package/documentation/README.md +178 -0
- package/documentation/index.html +34 -0
- package/modern_framework_paper.md +1870 -0
- package/package.json +178 -0
- package/public/css/style.css +87 -0
- package/public/index.html +34 -0
- package/public/js/app.js +27 -0
- package/src/advanced/cache/InMemoryCacheStore.ts +68 -0
- package/src/advanced/cache/MultiTierCache.ts +194 -0
- package/src/advanced/cache/RedisCacheStore.ts +341 -0
- package/src/advanced/cache/index.ts +5 -0
- package/src/advanced/cache/types.ts +40 -0
- package/src/advanced/graphql/SimpleDataLoader.ts +42 -0
- package/src/advanced/graphql/index.ts +22 -0
- package/src/advanced/graphql/server.ts +252 -0
- package/src/advanced/graphql/types.ts +42 -0
- package/src/advanced/jobs/InMemoryQueueStore.ts +68 -0
- package/src/advanced/jobs/JobQueue.ts +556 -0
- package/src/advanced/jobs/RedisQueueStore.ts +367 -0
- package/src/advanced/jobs/index.ts +5 -0
- package/src/advanced/jobs/types.ts +70 -0
- package/src/advanced/observability/APMManager.ts +163 -0
- package/src/advanced/observability/AlertManager.ts +109 -0
- package/src/advanced/observability/MetricRegistry.ts +151 -0
- package/src/advanced/observability/ObservabilityCenter.ts +304 -0
- package/src/advanced/observability/StructuredLogger.ts +154 -0
- package/src/advanced/observability/TracingManager.ts +117 -0
- package/src/advanced/observability/adapters.ts +304 -0
- package/src/advanced/observability/createObservabilityMiddleware.ts +63 -0
- package/src/advanced/observability/index.ts +11 -0
- package/src/advanced/observability/types.ts +174 -0
- package/src/advanced/playground/extractPathParams.ts +6 -0
- package/src/advanced/playground/generateFieldExample.ts +31 -0
- package/src/advanced/playground/generatePlaygroundHTML.ts +1849 -0
- package/src/advanced/playground/generateSummary.ts +19 -0
- package/src/advanced/playground/getTagFromPath.ts +9 -0
- package/src/advanced/playground/index.ts +8 -0
- package/src/advanced/playground/playground.ts +170 -0
- package/src/advanced/playground/types.ts +20 -0
- package/src/advanced/playground/zodToExample.ts +16 -0
- package/src/advanced/playground/zodToParams.ts +15 -0
- package/src/advanced/postman/buildAuth.ts +31 -0
- package/src/advanced/postman/buildBody.ts +15 -0
- package/src/advanced/postman/buildQueryParams.ts +27 -0
- package/src/advanced/postman/buildRequestItem.ts +36 -0
- package/src/advanced/postman/buildResponses.ts +11 -0
- package/src/advanced/postman/buildUrl.ts +33 -0
- package/src/advanced/postman/capitalize.ts +4 -0
- package/src/advanced/postman/generateCollection.ts +59 -0
- package/src/advanced/postman/generateEnvironment.ts +34 -0
- package/src/advanced/postman/generateExampleFromZod.ts +21 -0
- package/src/advanced/postman/generateFieldExample.ts +45 -0
- package/src/advanced/postman/generateName.ts +20 -0
- package/src/advanced/postman/generateUUID.ts +11 -0
- package/src/advanced/postman/getTagFromPath.ts +10 -0
- package/src/advanced/postman/index.ts +28 -0
- package/src/advanced/postman/postman.ts +156 -0
- package/src/advanced/postman/slugify.ts +7 -0
- package/src/advanced/postman/types.ts +140 -0
- package/src/advanced/realtime/index.ts +18 -0
- package/src/advanced/realtime/websocket.ts +211 -0
- package/src/advanced/sentry/index.ts +1236 -0
- package/src/advanced/sentry/types.ts +355 -0
- package/src/advanced/static/generateDirectoryListing.ts +47 -0
- package/src/advanced/static/generateETag.ts +7 -0
- package/src/advanced/static/getMimeType.ts +9 -0
- package/src/advanced/static/index.ts +32 -0
- package/src/advanced/static/isSafePath.ts +13 -0
- package/src/advanced/static/publicDir.ts +21 -0
- package/src/advanced/static/serveStatic.ts +225 -0
- package/src/advanced/static/spa.ts +24 -0
- package/src/advanced/static/types.ts +159 -0
- package/src/advanced/swagger/SwaggerGenerator.ts +66 -0
- package/src/advanced/swagger/buildOperation.ts +61 -0
- package/src/advanced/swagger/buildParameters.ts +61 -0
- package/src/advanced/swagger/buildRequestBody.ts +21 -0
- package/src/advanced/swagger/buildResponses.ts +54 -0
- package/src/advanced/swagger/capitalize.ts +5 -0
- package/src/advanced/swagger/convertPath.ts +9 -0
- package/src/advanced/swagger/createSwagger.ts +12 -0
- package/src/advanced/swagger/generateOperationId.ts +21 -0
- package/src/advanced/swagger/generateSpec.ts +105 -0
- package/src/advanced/swagger/generateSummary.ts +24 -0
- package/src/advanced/swagger/generateSwaggerUI.ts +70 -0
- package/src/advanced/swagger/generateThemeCss.ts +53 -0
- package/src/advanced/swagger/index.ts +25 -0
- package/src/advanced/swagger/swagger.ts +237 -0
- package/src/advanced/swagger/types.ts +206 -0
- package/src/advanced/swagger/zodFieldToOpenAPI.ts +94 -0
- package/src/advanced/swagger/zodSchemaToOpenAPI.ts +50 -0
- package/src/advanced/swagger/zodToOpenAPI.ts +22 -0
- package/src/advanced/testing/factory.ts +509 -0
- package/src/advanced/testing/harness.ts +612 -0
- package/src/advanced/testing/index.ts +430 -0
- package/src/advanced/testing/load-test.ts +618 -0
- package/src/advanced/testing/mock-server.ts +498 -0
- package/src/advanced/testing/mock.ts +670 -0
- package/src/cli/bin.ts +9 -0
- package/src/cli/cli.ts +155 -0
- package/src/cli/commands/build.ts +73 -0
- package/src/cli/commands/create.ts +166 -0
- package/src/cli/commands/dev.ts +85 -0
- package/src/cli/commands/generate.ts +97 -0
- package/src/cli/commands/help.ts +95 -0
- package/src/cli/commands/init.ts +91 -0
- package/src/cli/commands/version.ts +38 -0
- package/src/cli/index.ts +6 -0
- package/src/cli/templates/generators.ts +309 -0
- package/src/cli/templates/index.ts +679 -0
- package/src/cli/utils/exec.ts +52 -0
- package/src/cli/utils/file-system.ts +78 -0
- package/src/cli/utils/logger.ts +111 -0
- package/src/core/adapter.ts +88 -0
- package/src/core/application.ts +1283 -0
- package/src/core/context-pool.ts +127 -0
- package/src/core/context.ts +412 -0
- package/src/core/index.ts +80 -0
- package/src/core/middleware.ts +262 -0
- package/src/core/performance/buffer-pool.ts +108 -0
- package/src/core/performance/middleware-optimizer.ts +162 -0
- package/src/core/plugin/PluginManager.ts +435 -0
- package/src/core/plugin/builder.ts +358 -0
- package/src/core/plugin/index.ts +50 -0
- package/src/core/plugin/types.ts +214 -0
- package/src/core/router/file-router.ts +594 -0
- package/src/core/router/index.ts +182 -0
- package/src/core/router/radix-tree.ts +226 -0
- package/src/core/store/index.ts +30 -0
- package/src/core/store/registry.ts +178 -0
- package/src/core/store/request-store.ts +240 -0
- package/src/core/store/types.ts +233 -0
- package/src/core/types.ts +574 -0
- package/src/database/adapter.ts +35 -0
- package/src/database/adapters/index.ts +1 -0
- package/src/database/adapters/mysql.ts +669 -0
- package/src/database/database.ts +70 -0
- package/src/database/dialect.ts +388 -0
- package/src/database/index.ts +12 -0
- package/src/database/migrations.ts +86 -0
- package/src/database/optimizer.ts +125 -0
- package/src/database/query-builder.ts +404 -0
- package/src/database/realtime.ts +53 -0
- package/src/database/schema.ts +71 -0
- package/src/database/transactions.ts +56 -0
- package/src/database/types.ts +87 -0
- package/src/deployment/cluster.ts +471 -0
- package/src/deployment/config.ts +454 -0
- package/src/deployment/docker.ts +599 -0
- package/src/deployment/graceful-shutdown.ts +373 -0
- package/src/deployment/index.ts +56 -0
- package/src/index.ts +264 -0
- package/src/security/adapter.ts +318 -0
- package/src/security/auth/JWTPlugin.ts +234 -0
- package/src/security/auth/JWTProvider.ts +316 -0
- package/src/security/auth/adapter.ts +12 -0
- package/src/security/auth/jwt.ts +234 -0
- package/src/security/auth/middleware.ts +188 -0
- package/src/security/csrf.ts +220 -0
- package/src/security/headers.ts +108 -0
- package/src/security/index.ts +60 -0
- package/src/security/rate-limit/adapter.ts +7 -0
- package/src/security/rate-limit/memory.ts +108 -0
- package/src/security/rate-limit/middleware.ts +181 -0
- package/src/security/sanitization.ts +75 -0
- package/src/security/types.ts +240 -0
- package/src/security/utils.ts +52 -0
- package/tsconfig.json +39 -0
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* JWT Authentication Adapter
|
|
4
|
+
*
|
|
5
|
+
* Implements JWT-based authentication
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.JWTAuthAdapter = void 0;
|
|
9
|
+
/**
|
|
10
|
+
* Simple JWT implementation (in production, use a library like jsonwebtoken)
|
|
11
|
+
* This is a basic implementation for demonstration
|
|
12
|
+
*/
|
|
13
|
+
class JWTAuthAdapter {
|
|
14
|
+
/**
|
|
15
|
+
* Verify JWT token and extract user
|
|
16
|
+
*/
|
|
17
|
+
async verify(ctx, config) {
|
|
18
|
+
const token = this.extractToken(ctx, config);
|
|
19
|
+
if (!token) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
try {
|
|
23
|
+
const payload = this.decodeToken(token, config.secret);
|
|
24
|
+
// Check expiration
|
|
25
|
+
if (payload.exp && payload.exp < Date.now() / 1000) {
|
|
26
|
+
return null;
|
|
27
|
+
}
|
|
28
|
+
// Extract user from payload
|
|
29
|
+
// Destructure known fields and spread the rest to preserve custom fields like 'type'
|
|
30
|
+
const { sub, id, email, username, roles, permissions, user: nestedUser, iat, exp, ...rest } = payload;
|
|
31
|
+
const user = {
|
|
32
|
+
id: sub || id,
|
|
33
|
+
email,
|
|
34
|
+
username,
|
|
35
|
+
roles,
|
|
36
|
+
permissions,
|
|
37
|
+
...nestedUser, // Spread nested user object if exists
|
|
38
|
+
...rest // Spread remaining custom fields (e.g., type)
|
|
39
|
+
};
|
|
40
|
+
return user;
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
return null;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Generate JWT token for user
|
|
48
|
+
*/
|
|
49
|
+
async generateToken(user, config) {
|
|
50
|
+
const payload = {
|
|
51
|
+
sub: user.id,
|
|
52
|
+
email: user.email,
|
|
53
|
+
username: user.username,
|
|
54
|
+
roles: user.roles,
|
|
55
|
+
permissions: user.permissions,
|
|
56
|
+
iat: Math.floor(Date.now() / 1000)
|
|
57
|
+
};
|
|
58
|
+
// Add expiration
|
|
59
|
+
if (config.expiresIn) {
|
|
60
|
+
const expiresIn = typeof config.expiresIn === 'string'
|
|
61
|
+
? this.parseExpiration(config.expiresIn)
|
|
62
|
+
: config.expiresIn;
|
|
63
|
+
payload.exp = payload.iat + expiresIn;
|
|
64
|
+
}
|
|
65
|
+
return this.encodeToken(payload, config.secret);
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Refresh JWT token (placeholder for future implementation)
|
|
69
|
+
*/
|
|
70
|
+
async refreshToken(token, config) {
|
|
71
|
+
if (!config.refresh?.enabled) {
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
try {
|
|
75
|
+
const payload = this.decodeToken(token, config.secret);
|
|
76
|
+
// Re-generate with new exp
|
|
77
|
+
const newPayload = {
|
|
78
|
+
...payload,
|
|
79
|
+
iat: Math.floor(Date.now() / 1000)
|
|
80
|
+
};
|
|
81
|
+
if (config.refresh.expiresIn) {
|
|
82
|
+
const expiresIn = typeof config.refresh.expiresIn === 'string'
|
|
83
|
+
? this.parseExpiration(config.refresh.expiresIn)
|
|
84
|
+
: config.refresh.expiresIn;
|
|
85
|
+
newPayload.exp = newPayload.iat + expiresIn;
|
|
86
|
+
}
|
|
87
|
+
return this.encodeToken(newPayload, config.secret);
|
|
88
|
+
}
|
|
89
|
+
catch (error) {
|
|
90
|
+
return null;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Extract token from request
|
|
95
|
+
*/
|
|
96
|
+
extractToken(ctx, config) {
|
|
97
|
+
// Use custom extractor if provided
|
|
98
|
+
if (config.getToken) {
|
|
99
|
+
return config.getToken(ctx);
|
|
100
|
+
}
|
|
101
|
+
// Try Authorization header
|
|
102
|
+
const authHeader = ctx.headers['authorization'] || ctx.headers['Authorization'];
|
|
103
|
+
if (authHeader) {
|
|
104
|
+
const headerValue = Array.isArray(authHeader) ? authHeader[0] : authHeader;
|
|
105
|
+
if (headerValue?.startsWith('Bearer ')) {
|
|
106
|
+
return headerValue.substring(7);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
// Try cookie
|
|
110
|
+
const cookieHeader = ctx.headers['cookie'] || ctx.headers['Cookie'];
|
|
111
|
+
if (cookieHeader) {
|
|
112
|
+
const cookieValue = Array.isArray(cookieHeader) ? cookieHeader[0] : cookieHeader;
|
|
113
|
+
if (cookieValue) {
|
|
114
|
+
const match = cookieValue.match(/token=([^;]+)/);
|
|
115
|
+
if (match) {
|
|
116
|
+
return match[1];
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
return null;
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Encode JWT token (simplified HMAC-SHA256)
|
|
124
|
+
*/
|
|
125
|
+
encodeToken(payload, secret) {
|
|
126
|
+
const header = { alg: 'HS256', typ: 'JWT' };
|
|
127
|
+
const encodedHeader = this.base64UrlEncode(JSON.stringify(header));
|
|
128
|
+
const encodedPayload = this.base64UrlEncode(JSON.stringify(payload));
|
|
129
|
+
const signature = this.sign(`${encodedHeader}.${encodedPayload}`, secret);
|
|
130
|
+
return `${encodedHeader}.${encodedPayload}.${signature}`;
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Decode and verify JWT token
|
|
134
|
+
*/
|
|
135
|
+
decodeToken(token, secret) {
|
|
136
|
+
const parts = token.split('.');
|
|
137
|
+
if (parts.length !== 3) {
|
|
138
|
+
throw new Error('Invalid token format');
|
|
139
|
+
}
|
|
140
|
+
const [encodedHeader, encodedPayload, signature] = parts;
|
|
141
|
+
// Verify signature
|
|
142
|
+
const expectedSignature = this.sign(`${encodedHeader}.${encodedPayload}`, secret);
|
|
143
|
+
if (signature !== expectedSignature) {
|
|
144
|
+
throw new Error('Invalid signature');
|
|
145
|
+
}
|
|
146
|
+
// Decode payload
|
|
147
|
+
const payload = JSON.parse(this.base64UrlDecode(encodedPayload));
|
|
148
|
+
return payload;
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Base64 URL encode
|
|
152
|
+
*/
|
|
153
|
+
base64UrlEncode(str) {
|
|
154
|
+
const base64 = Buffer.from(str).toString('base64');
|
|
155
|
+
return base64.replace(/\+/g, '-').replace(/\//g, '_').replace(/=/g, '');
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Base64 URL decode
|
|
159
|
+
*/
|
|
160
|
+
base64UrlDecode(str) {
|
|
161
|
+
let base64 = str.replace(/-/g, '+').replace(/_/g, '/');
|
|
162
|
+
// Add padding
|
|
163
|
+
while (base64.length % 4) {
|
|
164
|
+
base64 += '=';
|
|
165
|
+
}
|
|
166
|
+
return Buffer.from(base64, 'base64').toString('utf-8');
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Sign data with HMAC-SHA256
|
|
170
|
+
*/
|
|
171
|
+
sign(data, secret) {
|
|
172
|
+
const crypto = require('crypto');
|
|
173
|
+
const hmac = crypto.createHmac('sha256', secret);
|
|
174
|
+
hmac.update(data);
|
|
175
|
+
const signature = hmac.digest('base64');
|
|
176
|
+
return signature.replace(/\+/g, '-').replace(/\//g, '_').replace(/=/g, '');
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Parse expiration string to seconds
|
|
180
|
+
*/
|
|
181
|
+
parseExpiration(exp) {
|
|
182
|
+
const match = exp.match(/^(\d+)([smhd])$/);
|
|
183
|
+
if (!match) {
|
|
184
|
+
throw new Error('Invalid expiration format');
|
|
185
|
+
}
|
|
186
|
+
const value = parseInt(match[1]);
|
|
187
|
+
const unit = match[2];
|
|
188
|
+
const multipliers = {
|
|
189
|
+
s: 1,
|
|
190
|
+
m: 60,
|
|
191
|
+
h: 3600,
|
|
192
|
+
d: 86400
|
|
193
|
+
};
|
|
194
|
+
return value * multipliers[unit];
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
exports.JWTAuthAdapter = JWTAuthAdapter;
|
|
198
|
+
//# sourceMappingURL=jwt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jwt.js","sourceRoot":"","sources":["../../../src/security/auth/jwt.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
*
|
|
4
|
+
* Provides authentication and authorization middleware
|
|
5
|
+
*/
|
|
6
|
+
import type { Context, Middleware } from '../../core/types';
|
|
7
|
+
import type { AuthContext, AuthStrategies } from '../types';
|
|
8
|
+
import type { PermissionAdapter } from '../adapter';
|
|
9
|
+
/**
|
|
10
|
+
* Authentication middleware factory
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* // JWT authentication
|
|
15
|
+
* app.use(authenticate({
|
|
16
|
+
* jwt: {
|
|
17
|
+
* secret: process.env.JWT_SECRET,
|
|
18
|
+
* expiresIn: '15m'
|
|
19
|
+
* }
|
|
20
|
+
* }));
|
|
21
|
+
*
|
|
22
|
+
* // Optional authentication
|
|
23
|
+
* app.use(authenticate({ jwt: config }, { required: false }));
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export declare function authenticate(strategies: AuthStrategies, options?: {
|
|
27
|
+
required?: boolean;
|
|
28
|
+
strategies?: ('jwt' | 'oauth' | 'session')[];
|
|
29
|
+
}): Middleware<Context, AuthContext>;
|
|
30
|
+
/**
|
|
31
|
+
* Optional authentication - doesn't throw if no auth provided
|
|
32
|
+
*/
|
|
33
|
+
export declare function optionalAuth(strategies: AuthStrategies): Middleware<Context, Partial<AuthContext>>;
|
|
34
|
+
/**
|
|
35
|
+
* Require authentication - throws 401 if not authenticated
|
|
36
|
+
*/
|
|
37
|
+
export declare function requireAuth(strategies: AuthStrategies): Middleware<Context, AuthContext>;
|
|
38
|
+
/**
|
|
39
|
+
* Permission-based authorization middleware
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```ts
|
|
43
|
+
* app.post('/admin/users',
|
|
44
|
+
* authenticate({ jwt: config }),
|
|
45
|
+
* requirePermissions(['admin', 'write:users']),
|
|
46
|
+
* handler
|
|
47
|
+
* );
|
|
48
|
+
* ```
|
|
49
|
+
*/
|
|
50
|
+
export declare function requirePermissions(permissions: string[], adapter?: PermissionAdapter): Middleware<AuthContext, AuthContext>;
|
|
51
|
+
/**
|
|
52
|
+
* Role-based authorization middleware
|
|
53
|
+
*
|
|
54
|
+
* @example
|
|
55
|
+
* ```ts
|
|
56
|
+
* app.get('/admin/*',
|
|
57
|
+
* authenticate({ jwt: config }),
|
|
58
|
+
* requireRoles(['admin']),
|
|
59
|
+
* handler
|
|
60
|
+
* );
|
|
61
|
+
* ```
|
|
62
|
+
*/
|
|
63
|
+
export declare function requireRoles(roles: string[], adapter?: PermissionAdapter): Middleware<AuthContext, AuthContext>;
|
|
64
|
+
//# sourceMappingURL=middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.d.ts","sourceRoot":"","sources":["../../../src/security/auth/middleware.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAQ,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAClE,OAAO,KAAK,EAAQ,WAAW,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAClE,OAAO,KAAK,EAAe,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAIjE;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,YAAY,CACxB,UAAU,EAAE,cAAc,EAC1B,OAAO,GAAE;IACL,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,CAAC,KAAK,GAAG,OAAO,GAAG,SAAS,CAAC,EAAE,CAAC;CAC3C,GACP,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAgDlC;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,UAAU,EAAE,cAAc,GAAG,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC,CAElG;AAED;;GAEG;AACH,wBAAgB,WAAW,CAAC,UAAU,EAAE,cAAc,GAAG,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAExF;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,kBAAkB,CAC9B,WAAW,EAAE,MAAM,EAAE,EACrB,OAAO,CAAC,EAAE,iBAAiB,GAC5B,UAAU,CAAC,WAAW,EAAE,WAAW,CAAC,CA4BtC;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,YAAY,CACxB,KAAK,EAAE,MAAM,EAAE,EACf,OAAO,CAAC,EAAE,iBAAiB,GAC5B,UAAU,CAAC,WAAW,EAAE,WAAW,CAAC,CA4BtC"}
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Authentication Middleware
|
|
4
|
+
*
|
|
5
|
+
* Provides authentication and authorization middleware
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.authenticate = authenticate;
|
|
9
|
+
exports.optionalAuth = optionalAuth;
|
|
10
|
+
exports.requireAuth = requireAuth;
|
|
11
|
+
exports.requirePermissions = requirePermissions;
|
|
12
|
+
exports.requireRoles = requireRoles;
|
|
13
|
+
const adapter_1 = require("../adapter");
|
|
14
|
+
const jwt_1 = require("./jwt");
|
|
15
|
+
/**
|
|
16
|
+
* Authentication middleware factory
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```ts
|
|
20
|
+
* // JWT authentication
|
|
21
|
+
* app.use(authenticate({
|
|
22
|
+
* jwt: {
|
|
23
|
+
* secret: process.env.JWT_SECRET,
|
|
24
|
+
* expiresIn: '15m'
|
|
25
|
+
* }
|
|
26
|
+
* }));
|
|
27
|
+
*
|
|
28
|
+
* // Optional authentication
|
|
29
|
+
* app.use(authenticate({ jwt: config }, { required: false }));
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
function authenticate(strategies, options = {}) {
|
|
33
|
+
const adapters = new Map();
|
|
34
|
+
const required = options.required !== false;
|
|
35
|
+
const strategyOrder = options.strategies || ['jwt', 'oauth', 'session'];
|
|
36
|
+
// Initialize adapters
|
|
37
|
+
if (strategies.jwt) {
|
|
38
|
+
adapters.set('jwt', new jwt_1.JWTAuthAdapter());
|
|
39
|
+
}
|
|
40
|
+
// OAuth and Session will be added in future
|
|
41
|
+
// if (strategies.oauth) adapters.set('oauth', new OAuthAdapter());
|
|
42
|
+
// if (strategies.session) adapters.set('session', new SessionAdapter());
|
|
43
|
+
return (async (ctx, next, _deps) => {
|
|
44
|
+
let user = null;
|
|
45
|
+
// Try each strategy in order
|
|
46
|
+
for (const strategyName of strategyOrder) {
|
|
47
|
+
const adapter = adapters.get(strategyName);
|
|
48
|
+
const config = strategies[strategyName];
|
|
49
|
+
if (adapter && config) {
|
|
50
|
+
try {
|
|
51
|
+
user = await adapter.verify(ctx, config);
|
|
52
|
+
if (user) {
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
// Try next strategy
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
// If no user found and auth is required
|
|
63
|
+
if (!user && required) {
|
|
64
|
+
return {
|
|
65
|
+
statusCode: 401,
|
|
66
|
+
headers: { 'Content-Type': 'application/json' },
|
|
67
|
+
body: JSON.stringify({ error: 'Unauthorized' })
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
// Attach user to context
|
|
71
|
+
ctx.user = user;
|
|
72
|
+
return next(ctx);
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Optional authentication - doesn't throw if no auth provided
|
|
77
|
+
*/
|
|
78
|
+
function optionalAuth(strategies) {
|
|
79
|
+
return authenticate(strategies, { required: false });
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Require authentication - throws 401 if not authenticated
|
|
83
|
+
*/
|
|
84
|
+
function requireAuth(strategies) {
|
|
85
|
+
return authenticate(strategies, { required: true });
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Permission-based authorization middleware
|
|
89
|
+
*
|
|
90
|
+
* @example
|
|
91
|
+
* ```ts
|
|
92
|
+
* app.post('/admin/users',
|
|
93
|
+
* authenticate({ jwt: config }),
|
|
94
|
+
* requirePermissions(['admin', 'write:users']),
|
|
95
|
+
* handler
|
|
96
|
+
* );
|
|
97
|
+
* ```
|
|
98
|
+
*/
|
|
99
|
+
function requirePermissions(permissions, adapter) {
|
|
100
|
+
const permissionChecker = adapter || new adapter_1.DefaultPermissionAdapter();
|
|
101
|
+
return (async (ctx, next, _deps) => {
|
|
102
|
+
if (!ctx.user) {
|
|
103
|
+
return {
|
|
104
|
+
statusCode: 401,
|
|
105
|
+
headers: { 'Content-Type': 'application/json' },
|
|
106
|
+
body: JSON.stringify({ error: 'Unauthorized' })
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
const result = permissionChecker.checkPermissions(ctx.user, permissions);
|
|
110
|
+
if (!result.allowed) {
|
|
111
|
+
return {
|
|
112
|
+
statusCode: 403,
|
|
113
|
+
headers: { 'Content-Type': 'application/json' },
|
|
114
|
+
body: JSON.stringify({
|
|
115
|
+
error: 'Forbidden',
|
|
116
|
+
message: 'Insufficient permissions',
|
|
117
|
+
missing: result.missing
|
|
118
|
+
})
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
return next(ctx);
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Role-based authorization middleware
|
|
126
|
+
*
|
|
127
|
+
* @example
|
|
128
|
+
* ```ts
|
|
129
|
+
* app.get('/admin/*',
|
|
130
|
+
* authenticate({ jwt: config }),
|
|
131
|
+
* requireRoles(['admin']),
|
|
132
|
+
* handler
|
|
133
|
+
* );
|
|
134
|
+
* ```
|
|
135
|
+
*/
|
|
136
|
+
function requireRoles(roles, adapter) {
|
|
137
|
+
const permissionChecker = adapter || new adapter_1.DefaultPermissionAdapter();
|
|
138
|
+
return (async (ctx, next, _deps) => {
|
|
139
|
+
if (!ctx.user) {
|
|
140
|
+
return {
|
|
141
|
+
statusCode: 401,
|
|
142
|
+
headers: { 'Content-Type': 'application/json' },
|
|
143
|
+
body: JSON.stringify({ error: 'Unauthorized' })
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
const hasRole = permissionChecker.checkRoles(ctx.user, roles);
|
|
147
|
+
if (!hasRole) {
|
|
148
|
+
return {
|
|
149
|
+
statusCode: 403,
|
|
150
|
+
headers: { 'Content-Type': 'application/json' },
|
|
151
|
+
body: JSON.stringify({
|
|
152
|
+
error: 'Forbidden',
|
|
153
|
+
message: 'Insufficient roles',
|
|
154
|
+
required: roles
|
|
155
|
+
})
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
return next(ctx);
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
//# sourceMappingURL=middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/security/auth/middleware.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CSRF Protection Middleware
|
|
3
|
+
*
|
|
4
|
+
* Implements Cross-Site Request Forgery protection
|
|
5
|
+
*/
|
|
6
|
+
import type { Middleware } from '../core/types';
|
|
7
|
+
import type { CSRFConfig } from './types';
|
|
8
|
+
import type { CSRFAdapter } from './adapter';
|
|
9
|
+
/**
|
|
10
|
+
* CSRF protection middleware
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* app.use(csrf({
|
|
15
|
+
* cookie: { sameSite: 'strict' },
|
|
16
|
+
* excludeRoutes: ['/api/webhook/*']
|
|
17
|
+
* }));
|
|
18
|
+
* ```
|
|
19
|
+
*/
|
|
20
|
+
export declare function csrf(config?: CSRFConfig, adapter?: CSRFAdapter): Middleware;
|
|
21
|
+
/**
|
|
22
|
+
* Generate CSRF token middleware
|
|
23
|
+
* Attaches token to context and sets cookie
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```ts
|
|
27
|
+
* app.use(generateCSRFToken());
|
|
28
|
+
*
|
|
29
|
+
* // In handler
|
|
30
|
+
* app.get('/form', async (ctx) => {
|
|
31
|
+
* const token = ctx.csrfToken;
|
|
32
|
+
* return ctx.html(`<input type="hidden" name="_csrf" value="${token}">`);
|
|
33
|
+
* });
|
|
34
|
+
* ```
|
|
35
|
+
*/
|
|
36
|
+
export declare function generateCSRFToken(config?: CSRFConfig, adapter?: CSRFAdapter): Middleware;
|
|
37
|
+
/**
|
|
38
|
+
* Combined CSRF middleware - generates and validates tokens
|
|
39
|
+
*/
|
|
40
|
+
export declare function csrfProtection(config?: CSRFConfig): Middleware;
|
|
41
|
+
//# sourceMappingURL=csrf.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"csrf.d.ts","sourceRoot":"","sources":["../../src/security/csrf.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAiB,UAAU,EAAE,MAAM,eAAe,CAAC;AAC/D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AA+E7C;;;;;;;;;;GAUG;AACH,wBAAgB,IAAI,CAChB,MAAM,GAAE,UAAe,EACvB,OAAO,CAAC,EAAE,WAAW,GACtB,UAAU,CAiDZ;AAED;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,iBAAiB,CAC7B,MAAM,GAAE,UAAe,EACvB,OAAO,CAAC,EAAE,WAAW,GACtB,UAAU,CAiCZ;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,MAAM,GAAE,UAAe,GAAG,UAAU,CAWlE"}
|
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* CSRF Protection Middleware
|
|
4
|
+
*
|
|
5
|
+
* Implements Cross-Site Request Forgery protection
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.csrf = csrf;
|
|
9
|
+
exports.generateCSRFToken = generateCSRFToken;
|
|
10
|
+
exports.csrfProtection = csrfProtection;
|
|
11
|
+
/**
|
|
12
|
+
* Default CSRF token adapter
|
|
13
|
+
* Uses double-submit cookie pattern
|
|
14
|
+
*/
|
|
15
|
+
class DefaultCSRFAdapter {
|
|
16
|
+
tokenLength;
|
|
17
|
+
constructor(tokenLength = 32) {
|
|
18
|
+
this.tokenLength = tokenLength;
|
|
19
|
+
}
|
|
20
|
+
generateToken(_ctx) {
|
|
21
|
+
// Generate random token
|
|
22
|
+
const bytes = crypto.getRandomValues(new Uint8Array(this.tokenLength));
|
|
23
|
+
return Array.from(bytes)
|
|
24
|
+
.map(b => b.toString(16).padStart(2, '0'))
|
|
25
|
+
.join('');
|
|
26
|
+
}
|
|
27
|
+
validateToken(ctx, token) {
|
|
28
|
+
// In double-submit cookie pattern, token in cookie should match token in header/body
|
|
29
|
+
const cookieToken = this.extractTokenFromCookie(ctx);
|
|
30
|
+
if (!cookieToken) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
// Constant-time comparison to prevent timing attacks
|
|
34
|
+
return this.constantTimeCompare(token, cookieToken);
|
|
35
|
+
}
|
|
36
|
+
extractToken(ctx) {
|
|
37
|
+
// Try header first
|
|
38
|
+
const csrfHeader = ctx.headers['x-csrf-token'] || ctx.headers['X-CSRF-Token'];
|
|
39
|
+
if (csrfHeader) {
|
|
40
|
+
return Array.isArray(csrfHeader) ? csrfHeader[0] : csrfHeader;
|
|
41
|
+
}
|
|
42
|
+
const csrfTokenHeader = ctx.headers['csrf-token'] || ctx.headers['CSRF-Token'];
|
|
43
|
+
if (csrfTokenHeader) {
|
|
44
|
+
return Array.isArray(csrfTokenHeader) ? csrfTokenHeader[0] : csrfTokenHeader;
|
|
45
|
+
}
|
|
46
|
+
// Try body
|
|
47
|
+
if (ctx.body && typeof ctx.body === 'object') {
|
|
48
|
+
return ctx.body._csrf || ctx.body.csrf_token || null;
|
|
49
|
+
}
|
|
50
|
+
return null;
|
|
51
|
+
}
|
|
52
|
+
extractTokenFromCookie(ctx) {
|
|
53
|
+
const cookieHeaderRaw = ctx.headers['cookie'] || ctx.headers['Cookie'];
|
|
54
|
+
if (!cookieHeaderRaw) {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
const cookieHeader = Array.isArray(cookieHeaderRaw) ? cookieHeaderRaw[0] : cookieHeaderRaw;
|
|
58
|
+
const match = cookieHeader.match(/_csrf=([^;]+)/);
|
|
59
|
+
return match ? match[1] : null;
|
|
60
|
+
}
|
|
61
|
+
constantTimeCompare(a, b) {
|
|
62
|
+
if (a.length !== b.length) {
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
let result = 0;
|
|
66
|
+
for (let i = 0; i < a.length; i++) {
|
|
67
|
+
result |= a.charCodeAt(i) ^ b.charCodeAt(i);
|
|
68
|
+
}
|
|
69
|
+
return result === 0;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* CSRF protection middleware
|
|
74
|
+
*
|
|
75
|
+
* @example
|
|
76
|
+
* ```ts
|
|
77
|
+
* app.use(csrf({
|
|
78
|
+
* cookie: { sameSite: 'strict' },
|
|
79
|
+
* excludeRoutes: ['/api/webhook/*']
|
|
80
|
+
* }));
|
|
81
|
+
* ```
|
|
82
|
+
*/
|
|
83
|
+
function csrf(config = {}, adapter) {
|
|
84
|
+
const csrfAdapter = adapter || new DefaultCSRFAdapter(config.tokenLength);
|
|
85
|
+
const auto = config.auto !== false;
|
|
86
|
+
const excludeMethods = config.excludeMethods || ['GET', 'HEAD', 'OPTIONS'];
|
|
87
|
+
const excludeRoutes = config.excludeRoutes || [];
|
|
88
|
+
return async (ctx, next, _deps) => {
|
|
89
|
+
// Skip safe methods
|
|
90
|
+
if (excludeMethods.includes(ctx.method)) {
|
|
91
|
+
return next(ctx);
|
|
92
|
+
}
|
|
93
|
+
// Skip excluded routes
|
|
94
|
+
for (const pattern of excludeRoutes) {
|
|
95
|
+
const regex = new RegExp('^' + pattern.replace('*', '.*') + '$');
|
|
96
|
+
if (regex.test(ctx.path)) {
|
|
97
|
+
return next(ctx);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
// Validate CSRF token
|
|
101
|
+
if (auto) {
|
|
102
|
+
const token = csrfAdapter.extractToken(ctx);
|
|
103
|
+
if (!token) {
|
|
104
|
+
return {
|
|
105
|
+
statusCode: 403,
|
|
106
|
+
headers: { 'Content-Type': 'application/json' },
|
|
107
|
+
body: JSON.stringify({
|
|
108
|
+
error: 'CSRF token missing'
|
|
109
|
+
})
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
const valid = csrfAdapter.validateToken(ctx, token);
|
|
113
|
+
if (!valid) {
|
|
114
|
+
return {
|
|
115
|
+
statusCode: 403,
|
|
116
|
+
headers: { 'Content-Type': 'application/json' },
|
|
117
|
+
body: JSON.stringify({
|
|
118
|
+
error: 'CSRF token invalid'
|
|
119
|
+
})
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return next(ctx);
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Generate CSRF token middleware
|
|
128
|
+
* Attaches token to context and sets cookie
|
|
129
|
+
*
|
|
130
|
+
* @example
|
|
131
|
+
* ```ts
|
|
132
|
+
* app.use(generateCSRFToken());
|
|
133
|
+
*
|
|
134
|
+
* // In handler
|
|
135
|
+
* app.get('/form', async (ctx) => {
|
|
136
|
+
* const token = ctx.csrfToken;
|
|
137
|
+
* return ctx.html(`<input type="hidden" name="_csrf" value="${token}">`);
|
|
138
|
+
* });
|
|
139
|
+
* ```
|
|
140
|
+
*/
|
|
141
|
+
function generateCSRFToken(config = {}, adapter) {
|
|
142
|
+
const csrfAdapter = adapter || new DefaultCSRFAdapter(config.tokenLength);
|
|
143
|
+
const cookieName = config.cookie?.name || '_csrf';
|
|
144
|
+
const cookieOptions = {
|
|
145
|
+
sameSite: config.cookie?.sameSite || 'strict',
|
|
146
|
+
secure: config.cookie?.secure !== false,
|
|
147
|
+
httpOnly: config.cookie?.httpOnly !== false
|
|
148
|
+
};
|
|
149
|
+
return async (ctx, next, _deps) => {
|
|
150
|
+
// Generate token
|
|
151
|
+
const token = csrfAdapter.generateToken(ctx);
|
|
152
|
+
// Attach to context
|
|
153
|
+
ctx.csrfToken = token;
|
|
154
|
+
// Execute handler
|
|
155
|
+
const response = await next(ctx);
|
|
156
|
+
// Set cookie
|
|
157
|
+
const cookieValue = `${cookieName}=${token}; SameSite=${cookieOptions.sameSite}${cookieOptions.secure ? '; Secure' : ''}${cookieOptions.httpOnly ? '; HttpOnly' : ''}; Path=/`;
|
|
158
|
+
// Append cookie to response headers
|
|
159
|
+
if (!response.headers['Set-Cookie']) {
|
|
160
|
+
response.headers['Set-Cookie'] = cookieValue;
|
|
161
|
+
}
|
|
162
|
+
else if (Array.isArray(response.headers['Set-Cookie'])) {
|
|
163
|
+
response.headers['Set-Cookie'].push(cookieValue);
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
response.headers['Set-Cookie'] = [response.headers['Set-Cookie'], cookieValue];
|
|
167
|
+
}
|
|
168
|
+
return response;
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Combined CSRF middleware - generates and validates tokens
|
|
173
|
+
*/
|
|
174
|
+
function csrfProtection(config = {}) {
|
|
175
|
+
const generateMiddleware = generateCSRFToken(config);
|
|
176
|
+
const validateMiddleware = csrf(config);
|
|
177
|
+
return async (ctx, next, deps) => {
|
|
178
|
+
// First generate token
|
|
179
|
+
return generateMiddleware(ctx, async (ctxWithToken) => {
|
|
180
|
+
// Then validate on unsafe methods
|
|
181
|
+
return validateMiddleware(ctxWithToken, next, deps);
|
|
182
|
+
}, deps);
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
//# sourceMappingURL=csrf.js.map
|