raffel 0.1.2
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 +485 -0
- package/dist/adapters/grpc.d.ts +56 -0
- package/dist/adapters/grpc.d.ts.map +1 -0
- package/dist/adapters/grpc.int.test.d.ts +5 -0
- package/dist/adapters/grpc.int.test.d.ts.map +1 -0
- package/dist/adapters/grpc.int.test.js +168 -0
- package/dist/adapters/grpc.int.test.js.map +1 -0
- package/dist/adapters/grpc.js +434 -0
- package/dist/adapters/grpc.js.map +1 -0
- package/dist/adapters/http.d.ts +62 -0
- package/dist/adapters/http.d.ts.map +1 -0
- package/dist/adapters/http.int.test.d.ts +5 -0
- package/dist/adapters/http.int.test.d.ts.map +1 -0
- package/dist/adapters/http.int.test.js +396 -0
- package/dist/adapters/http.int.test.js.map +1 -0
- package/dist/adapters/http.js +606 -0
- package/dist/adapters/http.js.map +1 -0
- package/dist/adapters/index.d.ts +13 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +13 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/jsonrpc.d.ts +86 -0
- package/dist/adapters/jsonrpc.d.ts.map +1 -0
- package/dist/adapters/jsonrpc.int.test.d.ts +5 -0
- package/dist/adapters/jsonrpc.int.test.d.ts.map +1 -0
- package/dist/adapters/jsonrpc.int.test.js +640 -0
- package/dist/adapters/jsonrpc.int.test.js.map +1 -0
- package/dist/adapters/jsonrpc.js +338 -0
- package/dist/adapters/jsonrpc.js.map +1 -0
- package/dist/adapters/s3db/adapter.d.ts +105 -0
- package/dist/adapters/s3db/adapter.d.ts.map +1 -0
- package/dist/adapters/s3db/adapter.js +539 -0
- package/dist/adapters/s3db/adapter.js.map +1 -0
- package/dist/adapters/s3db/index.d.ts +20 -0
- package/dist/adapters/s3db/index.d.ts.map +1 -0
- package/dist/adapters/s3db/index.js +25 -0
- package/dist/adapters/s3db/index.js.map +1 -0
- package/dist/adapters/s3db/s3db.int.test.d.ts +5 -0
- package/dist/adapters/s3db/s3db.int.test.d.ts.map +1 -0
- package/dist/adapters/s3db/s3db.int.test.js +472 -0
- package/dist/adapters/s3db/s3db.int.test.js.map +1 -0
- package/dist/adapters/s3db/types.d.ts +277 -0
- package/dist/adapters/s3db/types.d.ts.map +1 -0
- package/dist/adapters/s3db/types.js +7 -0
- package/dist/adapters/s3db/types.js.map +1 -0
- package/dist/adapters/s3db/utils/etag.d.ts +65 -0
- package/dist/adapters/s3db/utils/etag.d.ts.map +1 -0
- package/dist/adapters/s3db/utils/etag.js +99 -0
- package/dist/adapters/s3db/utils/etag.js.map +1 -0
- package/dist/adapters/s3db/utils/guards.d.ts +121 -0
- package/dist/adapters/s3db/utils/guards.d.ts.map +1 -0
- package/dist/adapters/s3db/utils/guards.js +169 -0
- package/dist/adapters/s3db/utils/guards.js.map +1 -0
- package/dist/adapters/s3db/utils/index.d.ts +9 -0
- package/dist/adapters/s3db/utils/index.d.ts.map +1 -0
- package/dist/adapters/s3db/utils/index.js +10 -0
- package/dist/adapters/s3db/utils/index.js.map +1 -0
- package/dist/adapters/s3db/utils/populate.d.ts +89 -0
- package/dist/adapters/s3db/utils/populate.d.ts.map +1 -0
- package/dist/adapters/s3db/utils/populate.js +165 -0
- package/dist/adapters/s3db/utils/populate.js.map +1 -0
- package/dist/adapters/tcp.d.ts +59 -0
- package/dist/adapters/tcp.d.ts.map +1 -0
- package/dist/adapters/tcp.int.test.d.ts +5 -0
- package/dist/adapters/tcp.int.test.d.ts.map +1 -0
- package/dist/adapters/tcp.int.test.js +379 -0
- package/dist/adapters/tcp.int.test.js.map +1 -0
- package/dist/adapters/tcp.js +400 -0
- package/dist/adapters/tcp.js.map +1 -0
- package/dist/adapters/websocket.d.ts +75 -0
- package/dist/adapters/websocket.d.ts.map +1 -0
- package/dist/adapters/websocket.int.test.d.ts +5 -0
- package/dist/adapters/websocket.int.test.d.ts.map +1 -0
- package/dist/adapters/websocket.int.test.js +383 -0
- package/dist/adapters/websocket.int.test.js.map +1 -0
- package/dist/adapters/websocket.js +393 -0
- package/dist/adapters/websocket.js.map +1 -0
- package/dist/cache/drivers/file.d.ts +77 -0
- package/dist/cache/drivers/file.d.ts.map +1 -0
- package/dist/cache/drivers/file.js +329 -0
- package/dist/cache/drivers/file.js.map +1 -0
- package/dist/cache/drivers/index.d.ts +10 -0
- package/dist/cache/drivers/index.d.ts.map +1 -0
- package/dist/cache/drivers/index.js +10 -0
- package/dist/cache/drivers/index.js.map +1 -0
- package/dist/cache/drivers/memory.d.ts +138 -0
- package/dist/cache/drivers/memory.d.ts.map +1 -0
- package/dist/cache/drivers/memory.int.test.d.ts +5 -0
- package/dist/cache/drivers/memory.int.test.d.ts.map +1 -0
- package/dist/cache/drivers/memory.int.test.js +241 -0
- package/dist/cache/drivers/memory.int.test.js.map +1 -0
- package/dist/cache/drivers/memory.js +659 -0
- package/dist/cache/drivers/memory.js.map +1 -0
- package/dist/cache/drivers/redis.d.ts +84 -0
- package/dist/cache/drivers/redis.d.ts.map +1 -0
- package/dist/cache/drivers/redis.js +243 -0
- package/dist/cache/drivers/redis.js.map +1 -0
- package/dist/cache/drivers/s3db.d.ts +78 -0
- package/dist/cache/drivers/s3db.d.ts.map +1 -0
- package/dist/cache/drivers/s3db.js +216 -0
- package/dist/cache/drivers/s3db.js.map +1 -0
- package/dist/cache/factory.d.ts +77 -0
- package/dist/cache/factory.d.ts.map +1 -0
- package/dist/cache/factory.js +130 -0
- package/dist/cache/factory.js.map +1 -0
- package/dist/cache/index.d.ts +62 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +63 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cache/types.d.ts +328 -0
- package/dist/cache/types.d.ts.map +1 -0
- package/dist/cache/types.js +8 -0
- package/dist/cache/types.js.map +1 -0
- package/dist/channels/channel-manager.d.ts +39 -0
- package/dist/channels/channel-manager.d.ts.map +1 -0
- package/dist/channels/channel-manager.int.test.d.ts +5 -0
- package/dist/channels/channel-manager.int.test.d.ts.map +1 -0
- package/dist/channels/channel-manager.int.test.js +378 -0
- package/dist/channels/channel-manager.int.test.js.map +1 -0
- package/dist/channels/channel-manager.js +274 -0
- package/dist/channels/channel-manager.js.map +1 -0
- package/dist/channels/index.d.ts +47 -0
- package/dist/channels/index.d.ts.map +1 -0
- package/dist/channels/index.js +48 -0
- package/dist/channels/index.js.map +1 -0
- package/dist/channels/types.d.ts +265 -0
- package/dist/channels/types.d.ts.map +1 -0
- package/dist/channels/types.js +39 -0
- package/dist/channels/types.js.map +1 -0
- package/dist/core/ctx-call.int.test.d.ts +7 -0
- package/dist/core/ctx-call.int.test.d.ts.map +1 -0
- package/dist/core/ctx-call.int.test.js +263 -0
- package/dist/core/ctx-call.int.test.js.map +1 -0
- package/dist/core/event-delivery.d.ts +38 -0
- package/dist/core/event-delivery.d.ts.map +1 -0
- package/dist/core/event-delivery.js +131 -0
- package/dist/core/event-delivery.js.map +1 -0
- package/dist/core/index.d.ts +7 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +7 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/registry.d.ts +93 -0
- package/dist/core/registry.d.ts.map +1 -0
- package/dist/core/registry.js +107 -0
- package/dist/core/registry.js.map +1 -0
- package/dist/core/registry.unit.test.d.ts +2 -0
- package/dist/core/registry.unit.test.d.ts.map +1 -0
- package/dist/core/registry.unit.test.js +133 -0
- package/dist/core/registry.unit.test.js.map +1 -0
- package/dist/core/router.d.ts +70 -0
- package/dist/core/router.d.ts.map +1 -0
- package/dist/core/router.int.test.d.ts +2 -0
- package/dist/core/router.int.test.d.ts.map +1 -0
- package/dist/core/router.int.test.js +368 -0
- package/dist/core/router.int.test.js.map +1 -0
- package/dist/core/router.js +308 -0
- package/dist/core/router.js.map +1 -0
- package/dist/docs/generators/content-types.d.ts +10 -0
- package/dist/docs/generators/content-types.d.ts.map +1 -0
- package/dist/docs/generators/content-types.js +18 -0
- package/dist/docs/generators/content-types.js.map +1 -0
- package/dist/docs/generators/errors-types.d.ts +409 -0
- package/dist/docs/generators/errors-types.d.ts.map +1 -0
- package/dist/docs/generators/errors-types.js +224 -0
- package/dist/docs/generators/errors-types.js.map +1 -0
- package/dist/docs/generators/errors.d.ts +88 -0
- package/dist/docs/generators/errors.d.ts.map +1 -0
- package/dist/docs/generators/errors.js +224 -0
- package/dist/docs/generators/errors.js.map +1 -0
- package/dist/docs/generators/generators.int.test.d.ts +2 -0
- package/dist/docs/generators/generators.int.test.d.ts.map +1 -0
- package/dist/docs/generators/generators.int.test.js +105 -0
- package/dist/docs/generators/generators.int.test.js.map +1 -0
- package/dist/docs/generators/grpc-generator.d.ts +53 -0
- package/dist/docs/generators/grpc-generator.d.ts.map +1 -0
- package/dist/docs/generators/grpc-generator.js +109 -0
- package/dist/docs/generators/grpc-generator.js.map +1 -0
- package/dist/docs/generators/http-generator.d.ts +49 -0
- package/dist/docs/generators/http-generator.d.ts.map +1 -0
- package/dist/docs/generators/http-generator.js +561 -0
- package/dist/docs/generators/http-generator.js.map +1 -0
- package/dist/docs/generators/index.d.ts +17 -0
- package/dist/docs/generators/index.d.ts.map +1 -0
- package/dist/docs/generators/index.js +30 -0
- package/dist/docs/generators/index.js.map +1 -0
- package/dist/docs/generators/jsonrpc-generator.d.ts +53 -0
- package/dist/docs/generators/jsonrpc-generator.d.ts.map +1 -0
- package/dist/docs/generators/jsonrpc-generator.js +111 -0
- package/dist/docs/generators/jsonrpc-generator.js.map +1 -0
- package/dist/docs/generators/schema-converter.d.ts +117 -0
- package/dist/docs/generators/schema-converter.d.ts.map +1 -0
- package/dist/docs/generators/schema-converter.js +370 -0
- package/dist/docs/generators/schema-converter.js.map +1 -0
- package/dist/docs/generators/streams-generator.d.ts +85 -0
- package/dist/docs/generators/streams-generator.d.ts.map +1 -0
- package/dist/docs/generators/streams-generator.js +282 -0
- package/dist/docs/generators/streams-generator.js.map +1 -0
- package/dist/docs/generators/tcp-generator.d.ts +133 -0
- package/dist/docs/generators/tcp-generator.d.ts.map +1 -0
- package/dist/docs/generators/tcp-generator.js +227 -0
- package/dist/docs/generators/tcp-generator.js.map +1 -0
- package/dist/docs/generators/udp-generator.d.ts +119 -0
- package/dist/docs/generators/udp-generator.d.ts.map +1 -0
- package/dist/docs/generators/udp-generator.js +241 -0
- package/dist/docs/generators/udp-generator.js.map +1 -0
- package/dist/docs/generators/usd-generator.d.ts +182 -0
- package/dist/docs/generators/usd-generator.d.ts.map +1 -0
- package/dist/docs/generators/usd-generator.js +473 -0
- package/dist/docs/generators/usd-generator.js.map +1 -0
- package/dist/docs/generators/websocket-generator.d.ts +49 -0
- package/dist/docs/generators/websocket-generator.d.ts.map +1 -0
- package/dist/docs/generators/websocket-generator.js +319 -0
- package/dist/docs/generators/websocket-generator.js.map +1 -0
- package/dist/docs/index.d.ts +31 -0
- package/dist/docs/index.d.ts.map +1 -0
- package/dist/docs/index.js +56 -0
- package/dist/docs/index.js.map +1 -0
- package/dist/docs/openapi/generator.d.ts +164 -0
- package/dist/docs/openapi/generator.d.ts.map +1 -0
- package/dist/docs/openapi/generator.int.test.d.ts +5 -0
- package/dist/docs/openapi/generator.int.test.d.ts.map +1 -0
- package/dist/docs/openapi/generator.int.test.js +260 -0
- package/dist/docs/openapi/generator.int.test.js.map +1 -0
- package/dist/docs/openapi/generator.js +690 -0
- package/dist/docs/openapi/generator.js.map +1 -0
- package/dist/docs/openapi/index.d.ts +7 -0
- package/dist/docs/openapi/index.d.ts.map +1 -0
- package/dist/docs/openapi/index.js +7 -0
- package/dist/docs/openapi/index.js.map +1 -0
- package/dist/docs/ui/html-builder.d.ts +19 -0
- package/dist/docs/ui/html-builder.d.ts.map +1 -0
- package/dist/docs/ui/html-builder.js +3065 -0
- package/dist/docs/ui/html-builder.js.map +1 -0
- package/dist/docs/ui/index.d.ts +8 -0
- package/dist/docs/ui/index.d.ts.map +1 -0
- package/dist/docs/ui/index.js +7 -0
- package/dist/docs/ui/index.js.map +1 -0
- package/dist/docs/ui/styles.d.ts +14 -0
- package/dist/docs/ui/styles.d.ts.map +1 -0
- package/dist/docs/ui/styles.js +2228 -0
- package/dist/docs/ui/styles.js.map +1 -0
- package/dist/docs/ui/types.d.ts +68 -0
- package/dist/docs/ui/types.d.ts.map +1 -0
- package/dist/docs/ui/types.js +7 -0
- package/dist/docs/ui/types.js.map +1 -0
- package/dist/docs/ui/utils.d.ts +24 -0
- package/dist/docs/ui/utils.d.ts.map +1 -0
- package/dist/docs/ui/utils.js +55 -0
- package/dist/docs/ui/utils.js.map +1 -0
- package/dist/docs/usd-middleware.d.ts +157 -0
- package/dist/docs/usd-middleware.d.ts.map +1 -0
- package/dist/docs/usd-middleware.js +118 -0
- package/dist/docs/usd-middleware.js.map +1 -0
- package/dist/dx/health/health.int.test.d.ts +5 -0
- package/dist/dx/health/health.int.test.d.ts.map +1 -0
- package/dist/dx/health/health.int.test.js +249 -0
- package/dist/dx/health/health.int.test.js.map +1 -0
- package/dist/dx/health/index.d.ts +82 -0
- package/dist/dx/health/index.d.ts.map +1 -0
- package/dist/dx/health/index.js +260 -0
- package/dist/dx/health/index.js.map +1 -0
- package/dist/dx/health/types.d.ts +104 -0
- package/dist/dx/health/types.d.ts.map +1 -0
- package/dist/dx/health/types.js +7 -0
- package/dist/dx/health/types.js.map +1 -0
- package/dist/dx/index.d.ts +12 -0
- package/dist/dx/index.d.ts.map +1 -0
- package/dist/dx/index.js +15 -0
- package/dist/dx/index.js.map +1 -0
- package/dist/dx/logging/formats.d.ts +46 -0
- package/dist/dx/logging/formats.d.ts.map +1 -0
- package/dist/dx/logging/formats.js +225 -0
- package/dist/dx/logging/formats.js.map +1 -0
- package/dist/dx/logging/http-logging.int.test.d.ts +5 -0
- package/dist/dx/logging/http-logging.int.test.d.ts.map +1 -0
- package/dist/dx/logging/http-logging.int.test.js +319 -0
- package/dist/dx/logging/http-logging.int.test.js.map +1 -0
- package/dist/dx/logging/index.d.ts +84 -0
- package/dist/dx/logging/index.d.ts.map +1 -0
- package/dist/dx/logging/index.js +164 -0
- package/dist/dx/logging/index.js.map +1 -0
- package/dist/dx/logging/types.d.ts +76 -0
- package/dist/dx/logging/types.d.ts.map +1 -0
- package/dist/dx/logging/types.js +7 -0
- package/dist/dx/logging/types.js.map +1 -0
- package/dist/errors/codes.d.ts +239 -0
- package/dist/errors/codes.d.ts.map +1 -0
- package/dist/errors/codes.js +286 -0
- package/dist/errors/codes.js.map +1 -0
- package/dist/errors/factories.d.ts +142 -0
- package/dist/errors/factories.d.ts.map +1 -0
- package/dist/errors/factories.js +201 -0
- package/dist/errors/factories.js.map +1 -0
- package/dist/errors/factories.unit.test.d.ts +7 -0
- package/dist/errors/factories.unit.test.d.ts.map +1 -0
- package/dist/errors/factories.unit.test.js +358 -0
- package/dist/errors/factories.unit.test.js.map +1 -0
- package/dist/errors/index.d.ts +9 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +11 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/graphql/adapter.d.ts +28 -0
- package/dist/graphql/adapter.d.ts.map +1 -0
- package/dist/graphql/adapter.js +624 -0
- package/dist/graphql/adapter.js.map +1 -0
- package/dist/graphql/index.d.ts +35 -0
- package/dist/graphql/index.d.ts.map +1 -0
- package/dist/graphql/index.js +35 -0
- package/dist/graphql/index.js.map +1 -0
- package/dist/graphql/schema-generator.d.ts +23 -0
- package/dist/graphql/schema-generator.d.ts.map +1 -0
- package/dist/graphql/schema-generator.int.test.d.ts +5 -0
- package/dist/graphql/schema-generator.int.test.d.ts.map +1 -0
- package/dist/graphql/schema-generator.int.test.js +51 -0
- package/dist/graphql/schema-generator.int.test.js.map +1 -0
- package/dist/graphql/schema-generator.js +502 -0
- package/dist/graphql/schema-generator.js.map +1 -0
- package/dist/graphql/types.d.ts +172 -0
- package/dist/graphql/types.d.ts.map +1 -0
- package/dist/graphql/types.js +7 -0
- package/dist/graphql/types.js.map +1 -0
- package/dist/http/app.d.ts +156 -0
- package/dist/http/app.d.ts.map +1 -0
- package/dist/http/app.js +421 -0
- package/dist/http/app.js.map +1 -0
- package/dist/http/auth.d.ts +617 -0
- package/dist/http/auth.d.ts.map +1 -0
- package/dist/http/auth.js +913 -0
- package/dist/http/auth.js.map +1 -0
- package/dist/http/banner.d.ts +118 -0
- package/dist/http/banner.d.ts.map +1 -0
- package/dist/http/banner.js +187 -0
- package/dist/http/banner.js.map +1 -0
- package/dist/http/body-limit.d.ts +80 -0
- package/dist/http/body-limit.d.ts.map +1 -0
- package/dist/http/body-limit.js +187 -0
- package/dist/http/body-limit.js.map +1 -0
- package/dist/http/compress.d.ts +67 -0
- package/dist/http/compress.d.ts.map +1 -0
- package/dist/http/compress.js +226 -0
- package/dist/http/compress.js.map +1 -0
- package/dist/http/context-helpers.d.ts +171 -0
- package/dist/http/context-helpers.d.ts.map +1 -0
- package/dist/http/context-helpers.js +325 -0
- package/dist/http/context-helpers.js.map +1 -0
- package/dist/http/context.d.ts +157 -0
- package/dist/http/context.d.ts.map +1 -0
- package/dist/http/context.js +217 -0
- package/dist/http/context.js.map +1 -0
- package/dist/http/cookie.d.ts +291 -0
- package/dist/http/cookie.d.ts.map +1 -0
- package/dist/http/cookie.js +585 -0
- package/dist/http/cookie.js.map +1 -0
- package/dist/http/cors.d.ts +95 -0
- package/dist/http/cors.d.ts.map +1 -0
- package/dist/http/cors.js +177 -0
- package/dist/http/cors.js.map +1 -0
- package/dist/http/errors.d.ts +286 -0
- package/dist/http/errors.d.ts.map +1 -0
- package/dist/http/errors.js +487 -0
- package/dist/http/errors.js.map +1 -0
- package/dist/http/events.d.ts +251 -0
- package/dist/http/events.d.ts.map +1 -0
- package/dist/http/events.js +321 -0
- package/dist/http/events.js.map +1 -0
- package/dist/http/failban.d.ts +230 -0
- package/dist/http/failban.d.ts.map +1 -0
- package/dist/http/failban.js +351 -0
- package/dist/http/failban.js.map +1 -0
- package/dist/http/guards.d.ts +210 -0
- package/dist/http/guards.d.ts.map +1 -0
- package/dist/http/guards.js +327 -0
- package/dist/http/guards.js.map +1 -0
- package/dist/http/health.d.ts +197 -0
- package/dist/http/health.d.ts.map +1 -0
- package/dist/http/health.js +255 -0
- package/dist/http/health.js.map +1 -0
- package/dist/http/index.d.ts +64 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +130 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/oauth2.d.ts +280 -0
- package/dist/http/oauth2.d.ts.map +1 -0
- package/dist/http/oauth2.js +503 -0
- package/dist/http/oauth2.js.map +1 -0
- package/dist/http/oidc.d.ts +310 -0
- package/dist/http/oidc.d.ts.map +1 -0
- package/dist/http/oidc.js +470 -0
- package/dist/http/oidc.js.map +1 -0
- package/dist/http/rate-limit.d.ts +312 -0
- package/dist/http/rate-limit.d.ts.map +1 -0
- package/dist/http/rate-limit.js +522 -0
- package/dist/http/rate-limit.js.map +1 -0
- package/dist/http/response.d.ts +239 -0
- package/dist/http/response.d.ts.map +1 -0
- package/dist/http/response.js +352 -0
- package/dist/http/response.js.map +1 -0
- package/dist/http/security.d.ts +233 -0
- package/dist/http/security.d.ts.map +1 -0
- package/dist/http/security.js +230 -0
- package/dist/http/security.js.map +1 -0
- package/dist/http/serve.d.ts +72 -0
- package/dist/http/serve.d.ts.map +1 -0
- package/dist/http/serve.js +200 -0
- package/dist/http/serve.js.map +1 -0
- package/dist/http/session.d.ts +279 -0
- package/dist/http/session.d.ts.map +1 -0
- package/dist/http/session.js +354 -0
- package/dist/http/session.js.map +1 -0
- package/dist/http/static-s3.d.ts +176 -0
- package/dist/http/static-s3.d.ts.map +1 -0
- package/dist/http/static-s3.js +282 -0
- package/dist/http/static-s3.js.map +1 -0
- package/dist/http/static.d.ts +111 -0
- package/dist/http/static.d.ts.map +1 -0
- package/dist/http/static.js +373 -0
- package/dist/http/static.js.map +1 -0
- package/dist/http/stream-auth.d.ts +312 -0
- package/dist/http/stream-auth.d.ts.map +1 -0
- package/dist/http/stream-auth.js +404 -0
- package/dist/http/stream-auth.js.map +1 -0
- package/dist/http/templates.d.ts +262 -0
- package/dist/http/templates.d.ts.map +1 -0
- package/dist/http/templates.js +457 -0
- package/dist/http/templates.js.map +1 -0
- package/dist/http/types.d.ts +97 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +59 -0
- package/dist/http/types.js.map +1 -0
- package/dist/http/validate.d.ts +197 -0
- package/dist/http/validate.d.ts.map +1 -0
- package/dist/http/validate.js +437 -0
- package/dist/http/validate.js.map +1 -0
- package/dist/http/web-types.d.ts +38 -0
- package/dist/http/web-types.d.ts.map +1 -0
- package/dist/http/web-types.js +9 -0
- package/dist/http/web-types.js.map +1 -0
- package/dist/index.d.ts +45 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +96 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/cli.d.ts +18 -0
- package/dist/mcp/cli.d.ts.map +1 -0
- package/dist/mcp/cli.js +185 -0
- package/dist/mcp/cli.js.map +1 -0
- package/dist/mcp/docs/adapters.d.ts +10 -0
- package/dist/mcp/docs/adapters.d.ts.map +1 -0
- package/dist/mcp/docs/adapters.js +891 -0
- package/dist/mcp/docs/adapters.js.map +1 -0
- package/dist/mcp/docs/errors.d.ts +11 -0
- package/dist/mcp/docs/errors.d.ts.map +1 -0
- package/dist/mcp/docs/errors.js +549 -0
- package/dist/mcp/docs/errors.js.map +1 -0
- package/dist/mcp/docs/index.d.ts +38 -0
- package/dist/mcp/docs/index.d.ts.map +1 -0
- package/dist/mcp/docs/index.js +94 -0
- package/dist/mcp/docs/index.js.map +1 -0
- package/dist/mcp/docs/interceptors.d.ts +18 -0
- package/dist/mcp/docs/interceptors.d.ts.map +1 -0
- package/dist/mcp/docs/interceptors.js +872 -0
- package/dist/mcp/docs/interceptors.js.map +1 -0
- package/dist/mcp/docs/patterns.d.ts +12 -0
- package/dist/mcp/docs/patterns.d.ts.map +1 -0
- package/dist/mcp/docs/patterns.js +1099 -0
- package/dist/mcp/docs/patterns.js.map +1 -0
- package/dist/mcp/docs/quickstart.d.ts +52 -0
- package/dist/mcp/docs/quickstart.d.ts.map +1 -0
- package/dist/mcp/docs/quickstart.js +682 -0
- package/dist/mcp/docs/quickstart.js.map +1 -0
- package/dist/mcp/index.d.ts +14 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +18 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/prompts/index.d.ts +11 -0
- package/dist/mcp/prompts/index.d.ts.map +1 -0
- package/dist/mcp/prompts/index.js +596 -0
- package/dist/mcp/prompts/index.js.map +1 -0
- package/dist/mcp/resources/index.d.ts +10 -0
- package/dist/mcp/resources/index.d.ts.map +1 -0
- package/dist/mcp/resources/index.js +262 -0
- package/dist/mcp/resources/index.js.map +1 -0
- package/dist/mcp/server.d.ts +35 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +452 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/definitions.d.ts +15 -0
- package/dist/mcp/tools/definitions.d.ts.map +1 -0
- package/dist/mcp/tools/definitions.js +395 -0
- package/dist/mcp/tools/definitions.js.map +1 -0
- package/dist/mcp/tools/handlers.d.ts +8 -0
- package/dist/mcp/tools/handlers.d.ts.map +1 -0
- package/dist/mcp/tools/handlers.js +883 -0
- package/dist/mcp/tools/handlers.js.map +1 -0
- package/dist/mcp/tools/index.d.ts +8 -0
- package/dist/mcp/tools/index.d.ts.map +1 -0
- package/dist/mcp/tools/index.js +8 -0
- package/dist/mcp/tools/index.js.map +1 -0
- package/dist/mcp/types.d.ts +248 -0
- package/dist/mcp/types.d.ts.map +1 -0
- package/dist/mcp/types.js +13 -0
- package/dist/mcp/types.js.map +1 -0
- package/dist/metrics/exporters.d.ts +20 -0
- package/dist/metrics/exporters.d.ts.map +1 -0
- package/dist/metrics/exporters.js +122 -0
- package/dist/metrics/exporters.js.map +1 -0
- package/dist/metrics/index.d.ts +11 -0
- package/dist/metrics/index.d.ts.map +1 -0
- package/dist/metrics/index.js +10 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/metrics/interceptor.d.ts +29 -0
- package/dist/metrics/interceptor.d.ts.map +1 -0
- package/dist/metrics/interceptor.js +146 -0
- package/dist/metrics/interceptor.js.map +1 -0
- package/dist/metrics/metrics.int.test.d.ts +5 -0
- package/dist/metrics/metrics.int.test.d.ts.map +1 -0
- package/dist/metrics/metrics.int.test.js +288 -0
- package/dist/metrics/metrics.int.test.js.map +1 -0
- package/dist/metrics/registry.d.ts +11 -0
- package/dist/metrics/registry.d.ts.map +1 -0
- package/dist/metrics/registry.js +178 -0
- package/dist/metrics/registry.js.map +1 -0
- package/dist/metrics/types.d.ts +107 -0
- package/dist/metrics/types.d.ts.map +1 -0
- package/dist/metrics/types.js +21 -0
- package/dist/metrics/types.js.map +1 -0
- package/dist/middleware/auth.d.ts +231 -0
- package/dist/middleware/auth.d.ts.map +1 -0
- package/dist/middleware/auth.int.test.d.ts +5 -0
- package/dist/middleware/auth.int.test.d.ts.map +1 -0
- package/dist/middleware/auth.int.test.js +366 -0
- package/dist/middleware/auth.int.test.js.map +1 -0
- package/dist/middleware/auth.js +413 -0
- package/dist/middleware/auth.js.map +1 -0
- package/dist/middleware/compose.d.ts +102 -0
- package/dist/middleware/compose.d.ts.map +1 -0
- package/dist/middleware/compose.int.test.d.ts +7 -0
- package/dist/middleware/compose.int.test.d.ts.map +1 -0
- package/dist/middleware/compose.int.test.js +238 -0
- package/dist/middleware/compose.int.test.js.map +1 -0
- package/dist/middleware/compose.js +152 -0
- package/dist/middleware/compose.js.map +1 -0
- package/dist/middleware/http/compression.d.ts +92 -0
- package/dist/middleware/http/compression.d.ts.map +1 -0
- package/dist/middleware/http/compression.js +264 -0
- package/dist/middleware/http/compression.js.map +1 -0
- package/dist/middleware/http/index.d.ts +10 -0
- package/dist/middleware/http/index.d.ts.map +1 -0
- package/dist/middleware/http/index.js +11 -0
- package/dist/middleware/http/index.js.map +1 -0
- package/dist/middleware/http/security.d.ts +71 -0
- package/dist/middleware/http/security.d.ts.map +1 -0
- package/dist/middleware/http/security.js +263 -0
- package/dist/middleware/http/security.js.map +1 -0
- package/dist/middleware/index.d.ts +28 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +58 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/interceptors/bulkhead.d.ts +104 -0
- package/dist/middleware/interceptors/bulkhead.d.ts.map +1 -0
- package/dist/middleware/interceptors/bulkhead.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/bulkhead.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/bulkhead.int.test.js +263 -0
- package/dist/middleware/interceptors/bulkhead.int.test.js.map +1 -0
- package/dist/middleware/interceptors/bulkhead.js +260 -0
- package/dist/middleware/interceptors/bulkhead.js.map +1 -0
- package/dist/middleware/interceptors/cache.d.ts +218 -0
- package/dist/middleware/interceptors/cache.d.ts.map +1 -0
- package/dist/middleware/interceptors/cache.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/cache.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/cache.int.test.js +470 -0
- package/dist/middleware/interceptors/cache.int.test.js.map +1 -0
- package/dist/middleware/interceptors/cache.js +505 -0
- package/dist/middleware/interceptors/cache.js.map +1 -0
- package/dist/middleware/interceptors/circuit-breaker.d.ts +72 -0
- package/dist/middleware/interceptors/circuit-breaker.d.ts.map +1 -0
- package/dist/middleware/interceptors/circuit-breaker.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/circuit-breaker.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/circuit-breaker.int.test.js +253 -0
- package/dist/middleware/interceptors/circuit-breaker.int.test.js.map +1 -0
- package/dist/middleware/interceptors/circuit-breaker.js +268 -0
- package/dist/middleware/interceptors/circuit-breaker.js.map +1 -0
- package/dist/middleware/interceptors/dedup.d.ts +105 -0
- package/dist/middleware/interceptors/dedup.d.ts.map +1 -0
- package/dist/middleware/interceptors/dedup.js +219 -0
- package/dist/middleware/interceptors/dedup.js.map +1 -0
- package/dist/middleware/interceptors/fallback.d.ts +94 -0
- package/dist/middleware/interceptors/fallback.d.ts.map +1 -0
- package/dist/middleware/interceptors/fallback.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/fallback.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/fallback.int.test.js +211 -0
- package/dist/middleware/interceptors/fallback.int.test.js.map +1 -0
- package/dist/middleware/interceptors/fallback.js +161 -0
- package/dist/middleware/interceptors/fallback.js.map +1 -0
- package/dist/middleware/interceptors/index.d.ts +24 -0
- package/dist/middleware/interceptors/index.d.ts.map +1 -0
- package/dist/middleware/interceptors/index.js +28 -0
- package/dist/middleware/interceptors/index.js.map +1 -0
- package/dist/middleware/interceptors/logging.d.ts +62 -0
- package/dist/middleware/interceptors/logging.d.ts.map +1 -0
- package/dist/middleware/interceptors/logging.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/logging.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/logging.int.test.js +144 -0
- package/dist/middleware/interceptors/logging.int.test.js.map +1 -0
- package/dist/middleware/interceptors/logging.js +294 -0
- package/dist/middleware/interceptors/logging.js.map +1 -0
- package/dist/middleware/interceptors/rate-limit.d.ts +147 -0
- package/dist/middleware/interceptors/rate-limit.d.ts.map +1 -0
- package/dist/middleware/interceptors/rate-limit.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/rate-limit.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/rate-limit.int.test.js +221 -0
- package/dist/middleware/interceptors/rate-limit.int.test.js.map +1 -0
- package/dist/middleware/interceptors/rate-limit.js +376 -0
- package/dist/middleware/interceptors/rate-limit.js.map +1 -0
- package/dist/middleware/interceptors/request-id.d.ts +63 -0
- package/dist/middleware/interceptors/request-id.d.ts.map +1 -0
- package/dist/middleware/interceptors/request-id.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/request-id.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/request-id.int.test.js +136 -0
- package/dist/middleware/interceptors/request-id.int.test.js.map +1 -0
- package/dist/middleware/interceptors/request-id.js +119 -0
- package/dist/middleware/interceptors/request-id.js.map +1 -0
- package/dist/middleware/interceptors/retry.d.ts +80 -0
- package/dist/middleware/interceptors/retry.d.ts.map +1 -0
- package/dist/middleware/interceptors/retry.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/retry.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/retry.int.test.js +534 -0
- package/dist/middleware/interceptors/retry.int.test.js.map +1 -0
- package/dist/middleware/interceptors/retry.js +275 -0
- package/dist/middleware/interceptors/retry.js.map +1 -0
- package/dist/middleware/interceptors/size-limit.d.ts +145 -0
- package/dist/middleware/interceptors/size-limit.d.ts.map +1 -0
- package/dist/middleware/interceptors/size-limit.js +231 -0
- package/dist/middleware/interceptors/size-limit.js.map +1 -0
- package/dist/middleware/interceptors/timeout.d.ts +121 -0
- package/dist/middleware/interceptors/timeout.d.ts.map +1 -0
- package/dist/middleware/interceptors/timeout.int.test.d.ts +5 -0
- package/dist/middleware/interceptors/timeout.int.test.d.ts.map +1 -0
- package/dist/middleware/interceptors/timeout.int.test.js +228 -0
- package/dist/middleware/interceptors/timeout.int.test.js.map +1 -0
- package/dist/middleware/interceptors/timeout.js +253 -0
- package/dist/middleware/interceptors/timeout.js.map +1 -0
- package/dist/middleware/presets.d.ts +214 -0
- package/dist/middleware/presets.d.ts.map +1 -0
- package/dist/middleware/presets.js +329 -0
- package/dist/middleware/presets.js.map +1 -0
- package/dist/middleware/rate-limit.d.ts +105 -0
- package/dist/middleware/rate-limit.d.ts.map +1 -0
- package/dist/middleware/rate-limit.int.test.d.ts +5 -0
- package/dist/middleware/rate-limit.int.test.d.ts.map +1 -0
- package/dist/middleware/rate-limit.int.test.js +350 -0
- package/dist/middleware/rate-limit.int.test.js.map +1 -0
- package/dist/middleware/rate-limit.js +206 -0
- package/dist/middleware/rate-limit.js.map +1 -0
- package/dist/middleware/types.d.ts +371 -0
- package/dist/middleware/types.d.ts.map +1 -0
- package/dist/middleware/types.js +7 -0
- package/dist/middleware/types.js.map +1 -0
- package/dist/openapi/index.d.ts +9 -0
- package/dist/openapi/index.d.ts.map +1 -0
- package/dist/openapi/index.js +9 -0
- package/dist/openapi/index.js.map +1 -0
- package/dist/rate-limit/drivers/filesystem.d.ts +17 -0
- package/dist/rate-limit/drivers/filesystem.d.ts.map +1 -0
- package/dist/rate-limit/drivers/filesystem.js +85 -0
- package/dist/rate-limit/drivers/filesystem.js.map +1 -0
- package/dist/rate-limit/drivers/memory.d.ts +15 -0
- package/dist/rate-limit/drivers/memory.d.ts.map +1 -0
- package/dist/rate-limit/drivers/memory.js +55 -0
- package/dist/rate-limit/drivers/memory.js.map +1 -0
- package/dist/rate-limit/drivers/redis.d.ts +12 -0
- package/dist/rate-limit/drivers/redis.d.ts.map +1 -0
- package/dist/rate-limit/drivers/redis.js +46 -0
- package/dist/rate-limit/drivers/redis.js.map +1 -0
- package/dist/rate-limit/factory.d.ts +11 -0
- package/dist/rate-limit/factory.d.ts.map +1 -0
- package/dist/rate-limit/factory.js +33 -0
- package/dist/rate-limit/factory.js.map +1 -0
- package/dist/rate-limit/index.d.ts +6 -0
- package/dist/rate-limit/index.d.ts.map +1 -0
- package/dist/rate-limit/index.js +5 -0
- package/dist/rate-limit/index.js.map +1 -0
- package/dist/rate-limit/types.d.ts +51 -0
- package/dist/rate-limit/types.d.ts.map +1 -0
- package/dist/rate-limit/types.js +7 -0
- package/dist/rate-limit/types.js.map +1 -0
- package/dist/server/builder.d.ts +11 -0
- package/dist/server/builder.d.ts.map +1 -0
- package/dist/server/builder.int.test.d.ts +7 -0
- package/dist/server/builder.int.test.d.ts.map +1 -0
- package/dist/server/builder.int.test.js +414 -0
- package/dist/server/builder.int.test.js.map +1 -0
- package/dist/server/builder.js +1682 -0
- package/dist/server/builder.js.map +1 -0
- package/dist/server/channel-utils.d.ts +34 -0
- package/dist/server/channel-utils.d.ts.map +1 -0
- package/dist/server/channel-utils.js +131 -0
- package/dist/server/channel-utils.js.map +1 -0
- package/dist/server/discovery-utils.d.ts +32 -0
- package/dist/server/discovery-utils.d.ts.map +1 -0
- package/dist/server/discovery-utils.js +118 -0
- package/dist/server/discovery-utils.js.map +1 -0
- package/dist/server/errors.d.ts +186 -0
- package/dist/server/errors.d.ts.map +1 -0
- package/dist/server/errors.js +397 -0
- package/dist/server/errors.js.map +1 -0
- package/dist/server/fs-routes/index.d.ts +66 -0
- package/dist/server/fs-routes/index.d.ts.map +1 -0
- package/dist/server/fs-routes/index.js +66 -0
- package/dist/server/fs-routes/index.js.map +1 -0
- package/dist/server/fs-routes/loader.d.ts +28 -0
- package/dist/server/fs-routes/loader.d.ts.map +1 -0
- package/dist/server/fs-routes/loader.int.test.d.ts +5 -0
- package/dist/server/fs-routes/loader.int.test.d.ts.map +1 -0
- package/dist/server/fs-routes/loader.int.test.js +48 -0
- package/dist/server/fs-routes/loader.int.test.js.map +1 -0
- package/dist/server/fs-routes/loader.js +586 -0
- package/dist/server/fs-routes/loader.js.map +1 -0
- package/dist/server/fs-routes/middleware-processor.d.ts +19 -0
- package/dist/server/fs-routes/middleware-processor.d.ts.map +1 -0
- package/dist/server/fs-routes/middleware-processor.js +232 -0
- package/dist/server/fs-routes/middleware-processor.js.map +1 -0
- package/dist/server/fs-routes/resources/index.d.ts +8 -0
- package/dist/server/fs-routes/resources/index.d.ts.map +1 -0
- package/dist/server/fs-routes/resources/index.js +8 -0
- package/dist/server/fs-routes/resources/index.js.map +1 -0
- package/dist/server/fs-routes/resources/loader.d.ts +16 -0
- package/dist/server/fs-routes/resources/loader.d.ts.map +1 -0
- package/dist/server/fs-routes/resources/loader.js +431 -0
- package/dist/server/fs-routes/resources/loader.js.map +1 -0
- package/dist/server/fs-routes/resources/types.d.ts +256 -0
- package/dist/server/fs-routes/resources/types.d.ts.map +1 -0
- package/dist/server/fs-routes/resources/types.js +8 -0
- package/dist/server/fs-routes/resources/types.js.map +1 -0
- package/dist/server/fs-routes/rest/index.d.ts +8 -0
- package/dist/server/fs-routes/rest/index.d.ts.map +1 -0
- package/dist/server/fs-routes/rest/index.js +8 -0
- package/dist/server/fs-routes/rest/index.js.map +1 -0
- package/dist/server/fs-routes/rest/loader.d.ts +11 -0
- package/dist/server/fs-routes/rest/loader.d.ts.map +1 -0
- package/dist/server/fs-routes/rest/loader.js +595 -0
- package/dist/server/fs-routes/rest/loader.js.map +1 -0
- package/dist/server/fs-routes/rest/types.d.ts +288 -0
- package/dist/server/fs-routes/rest/types.d.ts.map +1 -0
- package/dist/server/fs-routes/rest/types.js +50 -0
- package/dist/server/fs-routes/rest/types.js.map +1 -0
- package/dist/server/fs-routes/tcp/index.d.ts +8 -0
- package/dist/server/fs-routes/tcp/index.d.ts.map +1 -0
- package/dist/server/fs-routes/tcp/index.js +8 -0
- package/dist/server/fs-routes/tcp/index.js.map +1 -0
- package/dist/server/fs-routes/tcp/loader.d.ts +15 -0
- package/dist/server/fs-routes/tcp/loader.d.ts.map +1 -0
- package/dist/server/fs-routes/tcp/loader.js +402 -0
- package/dist/server/fs-routes/tcp/loader.js.map +1 -0
- package/dist/server/fs-routes/tcp/types.d.ts +215 -0
- package/dist/server/fs-routes/tcp/types.d.ts.map +1 -0
- package/dist/server/fs-routes/tcp/types.js +7 -0
- package/dist/server/fs-routes/tcp/types.js.map +1 -0
- package/dist/server/fs-routes/types.d.ts +437 -0
- package/dist/server/fs-routes/types.d.ts.map +1 -0
- package/dist/server/fs-routes/types.js +7 -0
- package/dist/server/fs-routes/types.js.map +1 -0
- package/dist/server/fs-routes/udp/index.d.ts +8 -0
- package/dist/server/fs-routes/udp/index.d.ts.map +1 -0
- package/dist/server/fs-routes/udp/index.js +8 -0
- package/dist/server/fs-routes/udp/index.js.map +1 -0
- package/dist/server/fs-routes/udp/loader.d.ts +15 -0
- package/dist/server/fs-routes/udp/loader.d.ts.map +1 -0
- package/dist/server/fs-routes/udp/loader.js +282 -0
- package/dist/server/fs-routes/udp/loader.js.map +1 -0
- package/dist/server/fs-routes/udp/types.d.ts +164 -0
- package/dist/server/fs-routes/udp/types.d.ts.map +1 -0
- package/dist/server/fs-routes/udp/types.js +7 -0
- package/dist/server/fs-routes/udp/types.js.map +1 -0
- package/dist/server/fs-routes/watcher.d.ts +34 -0
- package/dist/server/fs-routes/watcher.d.ts.map +1 -0
- package/dist/server/fs-routes/watcher.js +158 -0
- package/dist/server/fs-routes/watcher.js.map +1 -0
- package/dist/server/handler-builders.d.ts +44 -0
- package/dist/server/handler-builders.d.ts.map +1 -0
- package/dist/server/handler-builders.js +297 -0
- package/dist/server/handler-builders.js.map +1 -0
- package/dist/server/hooks.int.test.d.ts +7 -0
- package/dist/server/hooks.int.test.d.ts.map +1 -0
- package/dist/server/hooks.int.test.js +564 -0
- package/dist/server/hooks.int.test.js.map +1 -0
- package/dist/server/index.d.ts +18 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +37 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/protocol-config.d.ts +22 -0
- package/dist/server/protocol-config.d.ts.map +1 -0
- package/dist/server/protocol-config.js +61 -0
- package/dist/server/protocol-config.js.map +1 -0
- package/dist/server/resource-builder.d.ts +175 -0
- package/dist/server/resource-builder.d.ts.map +1 -0
- package/dist/server/resource-builder.js +212 -0
- package/dist/server/resource-builder.js.map +1 -0
- package/dist/server/rest-middleware.d.ts +45 -0
- package/dist/server/rest-middleware.d.ts.map +1 -0
- package/dist/server/rest-middleware.js +368 -0
- package/dist/server/rest-middleware.js.map +1 -0
- package/dist/server/route-discovery.d.ts +54 -0
- package/dist/server/route-discovery.d.ts.map +1 -0
- package/dist/server/route-discovery.int.test.d.ts +5 -0
- package/dist/server/route-discovery.int.test.d.ts.map +1 -0
- package/dist/server/route-discovery.int.test.js +49 -0
- package/dist/server/route-discovery.int.test.js.map +1 -0
- package/dist/server/route-discovery.js +154 -0
- package/dist/server/route-discovery.js.map +1 -0
- package/dist/server/router-module.d.ts +50 -0
- package/dist/server/router-module.d.ts.map +1 -0
- package/dist/server/router-module.js +250 -0
- package/dist/server/router-module.js.map +1 -0
- package/dist/server/shared-context.d.ts +140 -0
- package/dist/server/shared-context.d.ts.map +1 -0
- package/dist/server/shared-context.js +258 -0
- package/dist/server/shared-context.js.map +1 -0
- package/dist/server/types.d.ts +2160 -0
- package/dist/server/types.d.ts.map +1 -0
- package/dist/server/types.js +7 -0
- package/dist/server/types.js.map +1 -0
- package/dist/stream/index.d.ts +3 -0
- package/dist/stream/index.d.ts.map +1 -0
- package/dist/stream/index.js +2 -0
- package/dist/stream/index.js.map +1 -0
- package/dist/stream/raffel-stream.d.ts +17 -0
- package/dist/stream/raffel-stream.d.ts.map +1 -0
- package/dist/stream/raffel-stream.int.test.d.ts +2 -0
- package/dist/stream/raffel-stream.int.test.d.ts.map +1 -0
- package/dist/stream/raffel-stream.int.test.js +265 -0
- package/dist/stream/raffel-stream.int.test.js.map +1 -0
- package/dist/stream/raffel-stream.js +205 -0
- package/dist/stream/raffel-stream.js.map +1 -0
- package/dist/tracing/exporters.d.ts +47 -0
- package/dist/tracing/exporters.d.ts.map +1 -0
- package/dist/tracing/exporters.js +173 -0
- package/dist/tracing/exporters.js.map +1 -0
- package/dist/tracing/index.d.ts +43 -0
- package/dist/tracing/index.d.ts.map +1 -0
- package/dist/tracing/index.js +46 -0
- package/dist/tracing/index.js.map +1 -0
- package/dist/tracing/interceptor.d.ts +20 -0
- package/dist/tracing/interceptor.d.ts.map +1 -0
- package/dist/tracing/interceptor.js +90 -0
- package/dist/tracing/interceptor.js.map +1 -0
- package/dist/tracing/sampler.d.ts +32 -0
- package/dist/tracing/sampler.d.ts.map +1 -0
- package/dist/tracing/sampler.js +111 -0
- package/dist/tracing/sampler.js.map +1 -0
- package/dist/tracing/span.d.ts +32 -0
- package/dist/tracing/span.d.ts.map +1 -0
- package/dist/tracing/span.js +139 -0
- package/dist/tracing/span.js.map +1 -0
- package/dist/tracing/tracer.d.ts +11 -0
- package/dist/tracing/tracer.d.ts.map +1 -0
- package/dist/tracing/tracer.js +149 -0
- package/dist/tracing/tracer.js.map +1 -0
- package/dist/tracing/tracing.int.test.d.ts +5 -0
- package/dist/tracing/tracing.int.test.d.ts.map +1 -0
- package/dist/tracing/tracing.int.test.js +412 -0
- package/dist/tracing/tracing.int.test.js.map +1 -0
- package/dist/tracing/types.d.ts +175 -0
- package/dist/tracing/types.d.ts.map +1 -0
- package/dist/tracing/types.js +16 -0
- package/dist/tracing/types.js.map +1 -0
- package/dist/types/context.d.ts +96 -0
- package/dist/types/context.d.ts.map +1 -0
- package/dist/types/context.js +55 -0
- package/dist/types/context.js.map +1 -0
- package/dist/types/envelope.d.ts +57 -0
- package/dist/types/envelope.d.ts.map +1 -0
- package/dist/types/envelope.js +39 -0
- package/dist/types/envelope.js.map +1 -0
- package/dist/types/handlers.d.ts +142 -0
- package/dist/types/handlers.d.ts.map +1 -0
- package/dist/types/handlers.js +7 -0
- package/dist/types/handlers.js.map +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/stream.d.ts +69 -0
- package/dist/types/stream.d.ts.map +1 -0
- package/dist/types/stream.js +7 -0
- package/dist/types/stream.js.map +1 -0
- package/dist/ui/core/event-delivery.d.ts +38 -0
- package/dist/ui/core/event-delivery.d.ts.map +1 -0
- package/dist/ui/core/registry.d.ts +93 -0
- package/dist/ui/core/registry.d.ts.map +1 -0
- package/dist/ui/core/router.d.ts +70 -0
- package/dist/ui/core/router.d.ts.map +1 -0
- package/dist/ui/docs/openapi/generator.d.ts +164 -0
- package/dist/ui/docs/openapi/generator.d.ts.map +1 -0
- package/dist/ui/docs/openapi/index.d.ts +7 -0
- package/dist/ui/docs/openapi/index.d.ts.map +1 -0
- package/dist/ui/docs/ui/html-builder.d.ts +19 -0
- package/dist/ui/docs/ui/html-builder.d.ts.map +1 -0
- package/dist/ui/docs/ui/index.d.ts +8 -0
- package/dist/ui/docs/ui/index.d.ts.map +1 -0
- package/dist/ui/docs/ui/styles.d.ts +14 -0
- package/dist/ui/docs/ui/styles.d.ts.map +1 -0
- package/dist/ui/docs/ui/types.d.ts +68 -0
- package/dist/ui/docs/ui/types.d.ts.map +1 -0
- package/dist/ui/docs/ui/utils.d.ts +24 -0
- package/dist/ui/docs/ui/utils.d.ts.map +1 -0
- package/dist/ui/errors/codes.d.ts +239 -0
- package/dist/ui/errors/codes.d.ts.map +1 -0
- package/dist/ui/types/context.d.ts +96 -0
- package/dist/ui/types/context.d.ts.map +1 -0
- package/dist/ui/types/envelope.d.ts +57 -0
- package/dist/ui/types/envelope.d.ts.map +1 -0
- package/dist/ui/types/handlers.d.ts +142 -0
- package/dist/ui/types/handlers.d.ts.map +1 -0
- package/dist/ui/types/index.d.ts +7 -0
- package/dist/ui/types/index.d.ts.map +1 -0
- package/dist/ui/types/stream.d.ts +69 -0
- package/dist/ui/types/stream.d.ts.map +1 -0
- package/dist/ui/usd/builder/document.d.ts +190 -0
- package/dist/ui/usd/builder/document.d.ts.map +1 -0
- package/dist/ui/usd/builder/grpc.d.ts +119 -0
- package/dist/ui/usd/builder/grpc.d.ts.map +1 -0
- package/dist/ui/usd/builder/http.d.ts +131 -0
- package/dist/ui/usd/builder/http.d.ts.map +1 -0
- package/dist/ui/usd/builder/index.d.ts +15 -0
- package/dist/ui/usd/builder/index.d.ts.map +1 -0
- package/dist/ui/usd/builder/jsonrpc.d.ts +96 -0
- package/dist/ui/usd/builder/jsonrpc.d.ts.map +1 -0
- package/dist/ui/usd/builder/schema.d.ts +143 -0
- package/dist/ui/usd/builder/schema.d.ts.map +1 -0
- package/dist/ui/usd/builder/streams.d.ts +71 -0
- package/dist/ui/usd/builder/streams.d.ts.map +1 -0
- package/dist/ui/usd/builder/tcp.d.ts +61 -0
- package/dist/ui/usd/builder/tcp.d.ts.map +1 -0
- package/dist/ui/usd/builder/udp.d.ts +64 -0
- package/dist/ui/usd/builder/udp.d.ts.map +1 -0
- package/dist/ui/usd/builder/websocket.d.ts +131 -0
- package/dist/ui/usd/builder/websocket.d.ts.map +1 -0
- package/dist/ui/usd/export/index.d.ts +8 -0
- package/dist/ui/usd/export/index.d.ts.map +1 -0
- package/dist/ui/usd/export/openapi.d.ts +75 -0
- package/dist/ui/usd/export/openapi.d.ts.map +1 -0
- package/dist/ui/usd/index.d.ts +58 -0
- package/dist/ui/usd/index.d.ts.map +1 -0
- package/dist/ui/usd/parser/index.d.ts +93 -0
- package/dist/ui/usd/parser/index.d.ts.map +1 -0
- package/dist/ui/usd/parser/json.d.ts +34 -0
- package/dist/ui/usd/parser/json.d.ts.map +1 -0
- package/dist/ui/usd/parser/normalize.d.ts +20 -0
- package/dist/ui/usd/parser/normalize.d.ts.map +1 -0
- package/dist/ui/usd/parser/yaml.d.ts +41 -0
- package/dist/ui/usd/parser/yaml.d.ts.map +1 -0
- package/dist/ui/usd/spec/defaults.d.ts +121 -0
- package/dist/ui/usd/spec/defaults.d.ts.map +1 -0
- package/dist/ui/usd/spec/types.d.ts +704 -0
- package/dist/ui/usd/spec/types.d.ts.map +1 -0
- package/dist/ui/usd/utils/index.d.ts +6 -0
- package/dist/ui/usd/utils/index.d.ts.map +1 -0
- package/dist/ui/usd/utils/merge.d.ts +29 -0
- package/dist/ui/usd/utils/merge.d.ts.map +1 -0
- package/dist/ui/usd/utils/refs.d.ts +46 -0
- package/dist/ui/usd/utils/refs.d.ts.map +1 -0
- package/dist/ui/usd/validator/errors.d.ts +66 -0
- package/dist/ui/usd/validator/errors.d.ts.map +1 -0
- package/dist/ui/usd/validator/index.d.ts +68 -0
- package/dist/ui/usd/validator/index.d.ts.map +1 -0
- package/dist/ui/usd/validator/schema.d.ts +905 -0
- package/dist/ui/usd/validator/schema.d.ts.map +1 -0
- package/dist/ui/usd/validator/semantic.d.ts +15 -0
- package/dist/ui/usd/validator/semantic.d.ts.map +1 -0
- package/dist/ui/utils/id/alphabets.d.ts +68 -0
- package/dist/ui/utils/id/alphabets.d.ts.map +1 -0
- package/dist/ui/utils/id/entropy.d.ts +45 -0
- package/dist/ui/utils/id/entropy.d.ts.map +1 -0
- package/dist/ui/utils/id/index.d.ts +15 -0
- package/dist/ui/utils/id/index.d.ts.map +1 -0
- package/dist/ui/utils/id/sid.d.ts +86 -0
- package/dist/ui/utils/id/sid.d.ts.map +1 -0
- package/dist/ui/validation/adapters/ajv.d.ts +59 -0
- package/dist/ui/validation/adapters/ajv.d.ts.map +1 -0
- package/dist/ui/validation/adapters/fastest.d.ts +52 -0
- package/dist/ui/validation/adapters/fastest.d.ts.map +1 -0
- package/dist/ui/validation/adapters/index.d.ts +19 -0
- package/dist/ui/validation/adapters/index.d.ts.map +1 -0
- package/dist/ui/validation/adapters/joi.d.ts +51 -0
- package/dist/ui/validation/adapters/joi.d.ts.map +1 -0
- package/dist/ui/validation/adapters/yup.d.ts +53 -0
- package/dist/ui/validation/adapters/yup.d.ts.map +1 -0
- package/dist/ui/validation/adapters/zod.d.ts +52 -0
- package/dist/ui/validation/adapters/zod.d.ts.map +1 -0
- package/dist/ui/validation/index.d.ts +26 -0
- package/dist/ui/validation/index.d.ts.map +1 -0
- package/dist/ui/validation/schema.d.ts +150 -0
- package/dist/ui/validation/schema.d.ts.map +1 -0
- package/dist/ui/validation/types.d.ts +72 -0
- package/dist/ui/validation/types.d.ts.map +1 -0
- package/dist/usd/builder/document.d.ts +190 -0
- package/dist/usd/builder/document.d.ts.map +1 -0
- package/dist/usd/builder/document.js +418 -0
- package/dist/usd/builder/document.js.map +1 -0
- package/dist/usd/builder/grpc.d.ts +119 -0
- package/dist/usd/builder/grpc.d.ts.map +1 -0
- package/dist/usd/builder/grpc.js +220 -0
- package/dist/usd/builder/grpc.js.map +1 -0
- package/dist/usd/builder/http.d.ts +131 -0
- package/dist/usd/builder/http.d.ts.map +1 -0
- package/dist/usd/builder/http.js +248 -0
- package/dist/usd/builder/http.js.map +1 -0
- package/dist/usd/builder/index.d.ts +15 -0
- package/dist/usd/builder/index.d.ts.map +1 -0
- package/dist/usd/builder/index.js +18 -0
- package/dist/usd/builder/index.js.map +1 -0
- package/dist/usd/builder/jsonrpc.d.ts +96 -0
- package/dist/usd/builder/jsonrpc.d.ts.map +1 -0
- package/dist/usd/builder/jsonrpc.js +167 -0
- package/dist/usd/builder/jsonrpc.js.map +1 -0
- package/dist/usd/builder/schema.d.ts +143 -0
- package/dist/usd/builder/schema.d.ts.map +1 -0
- package/dist/usd/builder/schema.js +171 -0
- package/dist/usd/builder/schema.js.map +1 -0
- package/dist/usd/builder/streams.d.ts +71 -0
- package/dist/usd/builder/streams.d.ts.map +1 -0
- package/dist/usd/builder/streams.js +146 -0
- package/dist/usd/builder/streams.js.map +1 -0
- package/dist/usd/builder/tcp.d.ts +61 -0
- package/dist/usd/builder/tcp.d.ts.map +1 -0
- package/dist/usd/builder/tcp.js +150 -0
- package/dist/usd/builder/tcp.js.map +1 -0
- package/dist/usd/builder/udp.d.ts +64 -0
- package/dist/usd/builder/udp.d.ts.map +1 -0
- package/dist/usd/builder/udp.js +166 -0
- package/dist/usd/builder/udp.js.map +1 -0
- package/dist/usd/builder/websocket.d.ts +131 -0
- package/dist/usd/builder/websocket.d.ts.map +1 -0
- package/dist/usd/builder/websocket.js +218 -0
- package/dist/usd/builder/websocket.js.map +1 -0
- package/dist/usd/export/index.d.ts +8 -0
- package/dist/usd/export/index.d.ts.map +1 -0
- package/dist/usd/export/index.js +10 -0
- package/dist/usd/export/index.js.map +1 -0
- package/dist/usd/export/openapi.d.ts +75 -0
- package/dist/usd/export/openapi.d.ts.map +1 -0
- package/dist/usd/export/openapi.js +296 -0
- package/dist/usd/export/openapi.js.map +1 -0
- package/dist/usd/index.d.ts +58 -0
- package/dist/usd/index.d.ts.map +1 -0
- package/dist/usd/index.js +61 -0
- package/dist/usd/index.js.map +1 -0
- package/dist/usd/parser/index.d.ts +93 -0
- package/dist/usd/parser/index.d.ts.map +1 -0
- package/dist/usd/parser/index.js +137 -0
- package/dist/usd/parser/index.js.map +1 -0
- package/dist/usd/parser/json.d.ts +34 -0
- package/dist/usd/parser/json.d.ts.map +1 -0
- package/dist/usd/parser/json.js +68 -0
- package/dist/usd/parser/json.js.map +1 -0
- package/dist/usd/parser/normalize.d.ts +20 -0
- package/dist/usd/parser/normalize.d.ts.map +1 -0
- package/dist/usd/parser/normalize.js +271 -0
- package/dist/usd/parser/normalize.js.map +1 -0
- package/dist/usd/parser/yaml.d.ts +41 -0
- package/dist/usd/parser/yaml.d.ts.map +1 -0
- package/dist/usd/parser/yaml.js +66 -0
- package/dist/usd/parser/yaml.js.map +1 -0
- package/dist/usd/spec/defaults.d.ts +121 -0
- package/dist/usd/spec/defaults.d.ts.map +1 -0
- package/dist/usd/spec/defaults.js +204 -0
- package/dist/usd/spec/defaults.js.map +1 -0
- package/dist/usd/spec/index.d.ts +6 -0
- package/dist/usd/spec/index.d.ts.map +1 -0
- package/dist/usd/spec/index.js +6 -0
- package/dist/usd/spec/index.js.map +1 -0
- package/dist/usd/spec/types.d.ts +698 -0
- package/dist/usd/spec/types.d.ts.map +1 -0
- package/dist/usd/spec/types.js +33 -0
- package/dist/usd/spec/types.js.map +1 -0
- package/dist/usd/utils/index.d.ts +6 -0
- package/dist/usd/utils/index.d.ts.map +1 -0
- package/dist/usd/utils/index.js +6 -0
- package/dist/usd/utils/index.js.map +1 -0
- package/dist/usd/utils/merge.d.ts +29 -0
- package/dist/usd/utils/merge.d.ts.map +1 -0
- package/dist/usd/utils/merge.js +92 -0
- package/dist/usd/utils/merge.js.map +1 -0
- package/dist/usd/utils/refs.d.ts +46 -0
- package/dist/usd/utils/refs.d.ts.map +1 -0
- package/dist/usd/utils/refs.js +102 -0
- package/dist/usd/utils/refs.js.map +1 -0
- package/dist/usd/validator/errors.d.ts +66 -0
- package/dist/usd/validator/errors.d.ts.map +1 -0
- package/dist/usd/validator/errors.js +132 -0
- package/dist/usd/validator/errors.js.map +1 -0
- package/dist/usd/validator/index.d.ts +68 -0
- package/dist/usd/validator/index.d.ts.map +1 -0
- package/dist/usd/validator/index.js +92 -0
- package/dist/usd/validator/index.js.map +1 -0
- package/dist/usd/validator/schema.d.ts +905 -0
- package/dist/usd/validator/schema.d.ts.map +1 -0
- package/dist/usd/validator/schema.js +539 -0
- package/dist/usd/validator/schema.js.map +1 -0
- package/dist/usd/validator/semantic.d.ts +15 -0
- package/dist/usd/validator/semantic.d.ts.map +1 -0
- package/dist/usd/validator/semantic.js +452 -0
- package/dist/usd/validator/semantic.js.map +1 -0
- package/dist/utils/content-codecs.d.ts +14 -0
- package/dist/utils/content-codecs.d.ts.map +1 -0
- package/dist/utils/content-codecs.js +201 -0
- package/dist/utils/content-codecs.js.map +1 -0
- package/dist/utils/header-metadata.d.ts +6 -0
- package/dist/utils/header-metadata.d.ts.map +1 -0
- package/dist/utils/header-metadata.js +78 -0
- package/dist/utils/header-metadata.js.map +1 -0
- package/dist/utils/id/alphabets.d.ts +68 -0
- package/dist/utils/id/alphabets.d.ts.map +1 -0
- package/dist/utils/id/alphabets.js +90 -0
- package/dist/utils/id/alphabets.js.map +1 -0
- package/dist/utils/id/entropy.d.ts +45 -0
- package/dist/utils/id/entropy.d.ts.map +1 -0
- package/dist/utils/id/entropy.js +154 -0
- package/dist/utils/id/entropy.js.map +1 -0
- package/dist/utils/id/index.d.ts +15 -0
- package/dist/utils/id/index.d.ts.map +1 -0
- package/dist/utils/id/index.js +13 -0
- package/dist/utils/id/index.js.map +1 -0
- package/dist/utils/id/sid.d.ts +86 -0
- package/dist/utils/id/sid.d.ts.map +1 -0
- package/dist/utils/id/sid.js +109 -0
- package/dist/utils/id/sid.js.map +1 -0
- package/dist/utils/index.d.ts +7 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +8 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/logger.d.ts +15 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +36 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/validation/adapters/ajv.d.ts +59 -0
- package/dist/validation/adapters/ajv.d.ts.map +1 -0
- package/dist/validation/adapters/ajv.js +136 -0
- package/dist/validation/adapters/ajv.js.map +1 -0
- package/dist/validation/adapters/fastest.d.ts +52 -0
- package/dist/validation/adapters/fastest.d.ts.map +1 -0
- package/dist/validation/adapters/fastest.js +215 -0
- package/dist/validation/adapters/fastest.js.map +1 -0
- package/dist/validation/adapters/index.d.ts +19 -0
- package/dist/validation/adapters/index.d.ts.map +1 -0
- package/dist/validation/adapters/index.js +19 -0
- package/dist/validation/adapters/index.js.map +1 -0
- package/dist/validation/adapters/joi.d.ts +51 -0
- package/dist/validation/adapters/joi.d.ts.map +1 -0
- package/dist/validation/adapters/joi.js +267 -0
- package/dist/validation/adapters/joi.js.map +1 -0
- package/dist/validation/adapters/yup.d.ts +53 -0
- package/dist/validation/adapters/yup.d.ts.map +1 -0
- package/dist/validation/adapters/yup.js +267 -0
- package/dist/validation/adapters/yup.js.map +1 -0
- package/dist/validation/adapters/zod.d.ts +52 -0
- package/dist/validation/adapters/zod.d.ts.map +1 -0
- package/dist/validation/adapters/zod.js +107 -0
- package/dist/validation/adapters/zod.js.map +1 -0
- package/dist/validation/index.d.ts +26 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +48 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/multi-validator.int.test.d.ts +7 -0
- package/dist/validation/multi-validator.int.test.d.ts.map +1 -0
- package/dist/validation/multi-validator.int.test.js +808 -0
- package/dist/validation/multi-validator.int.test.js.map +1 -0
- package/dist/validation/schema.d.ts +150 -0
- package/dist/validation/schema.d.ts.map +1 -0
- package/dist/validation/schema.int.test.d.ts +5 -0
- package/dist/validation/schema.int.test.d.ts.map +1 -0
- package/dist/validation/schema.int.test.js +340 -0
- package/dist/validation/schema.int.test.js.map +1 -0
- package/dist/validation/schema.js +271 -0
- package/dist/validation/schema.js.map +1 -0
- package/dist/validation/types.d.ts +72 -0
- package/dist/validation/types.d.ts.map +1 -0
- package/dist/validation/types.js +14 -0
- package/dist/validation/types.js.map +1 -0
- package/package.json +222 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
export class RedisRateLimitDriver {
|
|
2
|
+
name = 'redis';
|
|
3
|
+
client;
|
|
4
|
+
prefix;
|
|
5
|
+
constructor(options) {
|
|
6
|
+
if (!options.client) {
|
|
7
|
+
throw new Error('[RedisRateLimitDriver] Redis client is required');
|
|
8
|
+
}
|
|
9
|
+
this.client = options.client;
|
|
10
|
+
this.prefix = options.prefix ?? 'raffel:rate-limit:';
|
|
11
|
+
}
|
|
12
|
+
async increment(key, windowMs) {
|
|
13
|
+
const fullKey = this.getFullKey(key);
|
|
14
|
+
const count = await this.client.incr(fullKey);
|
|
15
|
+
if (count === 1) {
|
|
16
|
+
if (this.client.pexpire) {
|
|
17
|
+
await this.client.pexpire(fullKey, windowMs);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
let ttlMs = windowMs;
|
|
21
|
+
if (this.client.pttl) {
|
|
22
|
+
const ttl = await this.client.pttl(fullKey);
|
|
23
|
+
if (ttl > 0) {
|
|
24
|
+
ttlMs = ttl;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
const resetAt = Date.now() + ttlMs;
|
|
28
|
+
return { count, resetAt };
|
|
29
|
+
}
|
|
30
|
+
async decrement(key) {
|
|
31
|
+
if (!this.client.decr)
|
|
32
|
+
return;
|
|
33
|
+
const fullKey = this.getFullKey(key);
|
|
34
|
+
await this.client.decr(fullKey);
|
|
35
|
+
}
|
|
36
|
+
async reset(key) {
|
|
37
|
+
if (!this.client.del)
|
|
38
|
+
return;
|
|
39
|
+
const fullKey = this.getFullKey(key);
|
|
40
|
+
await this.client.del(fullKey);
|
|
41
|
+
}
|
|
42
|
+
getFullKey(key) {
|
|
43
|
+
return `${this.prefix}${key}`;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=redis.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.js","sourceRoot":"","sources":["../../../src/rate-limit/drivers/redis.ts"],"names":[],"mappings":"AAEA,MAAM,OAAO,oBAAoB;IACtB,IAAI,GAAG,OAAO,CAAA;IAEN,MAAM,CAAuC;IAC7C,MAAM,CAAQ;IAE/B,YAAY,OAAoC;QAC9C,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAA;QACpE,CAAC;QAED,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAA;QAC5B,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,oBAAoB,CAAA;IACtD,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAW,EAAE,QAAgB;QAC3C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;QACpC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAE7C,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;YAChB,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBACxB,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;YAC9C,CAAC;QACH,CAAC;QAED,IAAI,KAAK,GAAG,QAAQ,CAAA;QACpB,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACrB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YAC3C,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;gBACZ,KAAK,GAAG,GAAG,CAAA;YACb,CAAC;QACH,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAA;QAClC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,CAAA;IAC3B,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAW;QACzB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI;YAAE,OAAM;QAC7B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;QACpC,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;IACjC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,GAAW;QACrB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG;YAAE,OAAM;QAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;QACpC,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;IAChC,CAAC;IAEO,UAAU,CAAC,GAAW;QAC5B,OAAO,GAAG,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,CAAA;IAC/B,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rate Limit Driver Factory
|
|
3
|
+
*
|
|
4
|
+
* Creates rate-limit drivers with a cache-like configuration.
|
|
5
|
+
*/
|
|
6
|
+
import type { RateLimitDriver, RateLimitDriverConfig, MemoryRateLimitDriverOptions, FilesystemRateLimitDriverOptions, RedisRateLimitDriverOptions } from './types.js';
|
|
7
|
+
export declare function createDriver(type: 'memory', options?: MemoryRateLimitDriverOptions): RateLimitDriver;
|
|
8
|
+
export declare function createDriver(type: 'filesystem', options?: FilesystemRateLimitDriverOptions): RateLimitDriver;
|
|
9
|
+
export declare function createDriver(type: 'redis', options: RedisRateLimitDriverOptions): RateLimitDriver;
|
|
10
|
+
export declare function createDriverFromConfig(config: RateLimitDriverConfig): RateLimitDriver;
|
|
11
|
+
//# sourceMappingURL=factory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/rate-limit/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EACV,eAAe,EAEf,qBAAqB,EACrB,4BAA4B,EAC5B,gCAAgC,EAChC,2BAA2B,EAC5B,MAAM,YAAY,CAAA;AAKnB,wBAAgB,YAAY,CAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,4BAA4B,GAAG,eAAe,CAAA;AACrG,wBAAgB,YAAY,CAAC,IAAI,EAAE,YAAY,EAAE,OAAO,CAAC,EAAE,gCAAgC,GAAG,eAAe,CAAA;AAC7G,wBAAgB,YAAY,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,2BAA2B,GAAG,eAAe,CAAA;AAiBlG,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,qBAAqB,GAAG,eAAe,CAWrF"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rate Limit Driver Factory
|
|
3
|
+
*
|
|
4
|
+
* Creates rate-limit drivers with a cache-like configuration.
|
|
5
|
+
*/
|
|
6
|
+
import { MemoryRateLimitDriver } from './drivers/memory.js';
|
|
7
|
+
import { FilesystemRateLimitDriver } from './drivers/filesystem.js';
|
|
8
|
+
import { RedisRateLimitDriver } from './drivers/redis.js';
|
|
9
|
+
export function createDriver(type, options) {
|
|
10
|
+
switch (type) {
|
|
11
|
+
case 'memory':
|
|
12
|
+
return new MemoryRateLimitDriver(options);
|
|
13
|
+
case 'filesystem':
|
|
14
|
+
return new FilesystemRateLimitDriver(options);
|
|
15
|
+
case 'redis':
|
|
16
|
+
return new RedisRateLimitDriver(options);
|
|
17
|
+
default:
|
|
18
|
+
throw new Error(`Unknown rate limit driver type: ${type}`);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
export function createDriverFromConfig(config) {
|
|
22
|
+
switch (config.driver) {
|
|
23
|
+
case 'memory':
|
|
24
|
+
return createDriver('memory', config.options);
|
|
25
|
+
case 'filesystem':
|
|
26
|
+
return createDriver('filesystem', config.options);
|
|
27
|
+
case 'redis':
|
|
28
|
+
return createDriver('redis', config.options);
|
|
29
|
+
default:
|
|
30
|
+
throw new Error(`Unknown rate limit driver: ${config.driver}`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../src/rate-limit/factory.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAUH,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAA;AAC3D,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAA;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAA;AAKzD,MAAM,UAAU,YAAY,CAC1B,IAAyB,EACzB,OAAuG;IAEvG,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,QAAQ;YACX,OAAO,IAAI,qBAAqB,CAAC,OAAuC,CAAC,CAAA;QAC3E,KAAK,YAAY;YACf,OAAO,IAAI,yBAAyB,CAAC,OAA2C,CAAC,CAAA;QACnF,KAAK,OAAO;YACV,OAAO,IAAI,oBAAoB,CAAC,OAAsC,CAAC,CAAA;QACzE;YACE,MAAM,IAAI,KAAK,CAAC,mCAAmC,IAAI,EAAE,CAAC,CAAA;IAC9D,CAAC;AACH,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,MAA6B;IAClE,QAAQ,MAAM,CAAC,MAAM,EAAE,CAAC;QACtB,KAAK,QAAQ;YACX,OAAO,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,OAAO,CAAC,CAAA;QAC/C,KAAK,YAAY;YACf,OAAO,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC,OAAO,CAAC,CAAA;QACnD,KAAK,OAAO;YACV,OAAO,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAA;QAC9C;YACE,MAAM,IAAI,KAAK,CAAC,8BAA+B,MAA6B,CAAC,MAAM,EAAE,CAAC,CAAA;IAC1F,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export type { RateLimitDriver, RateLimitRecord, RateLimitDriverType, RateLimitDriverConfig, MemoryRateLimitDriverOptions, FilesystemRateLimitDriverOptions, RedisRateLimitDriverOptions, RedisLikeClient, } from './types.js';
|
|
2
|
+
export { createDriver, createDriverFromConfig, } from './factory.js';
|
|
3
|
+
export { MemoryRateLimitDriver } from './drivers/memory.js';
|
|
4
|
+
export { FilesystemRateLimitDriver } from './drivers/filesystem.js';
|
|
5
|
+
export { RedisRateLimitDriver } from './drivers/redis.js';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/rate-limit/index.ts"],"names":[],"mappings":"AAAA,YAAY,EACV,eAAe,EACf,eAAe,EACf,mBAAmB,EACnB,qBAAqB,EACrB,4BAA4B,EAC5B,gCAAgC,EAChC,2BAA2B,EAC3B,eAAe,GAChB,MAAM,YAAY,CAAA;AAEnB,OAAO,EACL,YAAY,EACZ,sBAAsB,GACvB,MAAM,cAAc,CAAA;AAErB,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAA;AAC3D,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAA;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAA"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { createDriver, createDriverFromConfig, } from './factory.js';
|
|
2
|
+
export { MemoryRateLimitDriver } from './drivers/memory.js';
|
|
3
|
+
export { FilesystemRateLimitDriver } from './drivers/filesystem.js';
|
|
4
|
+
export { RedisRateLimitDriver } from './drivers/redis.js';
|
|
5
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/rate-limit/index.ts"],"names":[],"mappings":"AAWA,OAAO,EACL,YAAY,EACZ,sBAAsB,GACvB,MAAM,cAAc,CAAA;AAErB,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAA;AAC3D,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAA;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAA"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rate Limit Driver Types
|
|
3
|
+
*
|
|
4
|
+
* Driver abstraction for pluggable rate limiting backends.
|
|
5
|
+
*/
|
|
6
|
+
export interface RateLimitRecord {
|
|
7
|
+
count: number;
|
|
8
|
+
resetAt: number;
|
|
9
|
+
}
|
|
10
|
+
export interface RateLimitDriver {
|
|
11
|
+
readonly name: string;
|
|
12
|
+
increment(key: string, windowMs: number): Promise<RateLimitRecord>;
|
|
13
|
+
decrement?(key: string): Promise<void>;
|
|
14
|
+
reset?(key: string): Promise<void>;
|
|
15
|
+
shutdown?(): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
export interface MemoryRateLimitDriverOptions {
|
|
18
|
+
/** Maximum number of keys to keep (default: 10000) */
|
|
19
|
+
maxKeys?: number;
|
|
20
|
+
/** Cleanup interval in ms (default: 60000) */
|
|
21
|
+
cleanupInterval?: number;
|
|
22
|
+
}
|
|
23
|
+
export interface FilesystemRateLimitDriverOptions {
|
|
24
|
+
/** Directory for storing rate limit state (default: '.rate-limit') */
|
|
25
|
+
directory?: string;
|
|
26
|
+
/** Cleanup interval in ms (default: 300000) */
|
|
27
|
+
cleanupInterval?: number;
|
|
28
|
+
}
|
|
29
|
+
export interface RedisRateLimitDriverOptions {
|
|
30
|
+
client: RedisLikeClient;
|
|
31
|
+
prefix?: string;
|
|
32
|
+
}
|
|
33
|
+
export interface RedisLikeClient {
|
|
34
|
+
incr(key: string): Promise<number>;
|
|
35
|
+
decr?(key: string): Promise<number>;
|
|
36
|
+
pexpire?(key: string, ttlMs: number): Promise<number>;
|
|
37
|
+
pttl?(key: string): Promise<number>;
|
|
38
|
+
del?(key: string): Promise<number>;
|
|
39
|
+
}
|
|
40
|
+
export type RateLimitDriverType = 'memory' | 'filesystem' | 'redis';
|
|
41
|
+
export type RateLimitDriverConfig = {
|
|
42
|
+
driver: 'memory';
|
|
43
|
+
options?: MemoryRateLimitDriverOptions;
|
|
44
|
+
} | {
|
|
45
|
+
driver: 'filesystem';
|
|
46
|
+
options?: FilesystemRateLimitDriverOptions;
|
|
47
|
+
} | {
|
|
48
|
+
driver: 'redis';
|
|
49
|
+
options: RedisRateLimitDriverOptions;
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/rate-limit/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAAA;IAClE,SAAS,CAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACtC,KAAK,CAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAClC,QAAQ,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;CAC3B;AAED,MAAM,WAAW,4BAA4B;IAC3C,sDAAsD;IACtD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,8CAA8C;IAC9C,eAAe,CAAC,EAAE,MAAM,CAAA;CACzB;AAED,MAAM,WAAW,gCAAgC;IAC/C,sEAAsE;IACtE,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,+CAA+C;IAC/C,eAAe,CAAC,EAAE,MAAM,CAAA;CACzB;AAED,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE,eAAe,CAAA;IACvB,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IAClC,IAAI,CAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IACnC,OAAO,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IACrD,IAAI,CAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IACnC,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;CACnC;AAED,MAAM,MAAM,mBAAmB,GAAG,QAAQ,GAAG,YAAY,GAAG,OAAO,CAAA;AAEnE,MAAM,MAAM,qBAAqB,GAC7B;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,OAAO,CAAC,EAAE,4BAA4B,CAAA;CAAE,GAC5D;IAAE,MAAM,EAAE,YAAY,CAAC;IAAC,OAAO,CAAC,EAAE,gCAAgC,CAAA;CAAE,GACpE;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,2BAA2B,CAAA;CAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/rate-limit/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server Builder Implementation
|
|
3
|
+
*
|
|
4
|
+
* Unified server builder with fluent API for multi-protocol support.
|
|
5
|
+
*/
|
|
6
|
+
import type { ServerOptions, RaffelServer } from './types.js';
|
|
7
|
+
/**
|
|
8
|
+
* Create a unified Raffel server
|
|
9
|
+
*/
|
|
10
|
+
export declare function createServer(options: ServerOptions): RaffelServer;
|
|
11
|
+
//# sourceMappingURL=builder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.d.ts","sourceRoot":"","sources":["../../src/server/builder.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAeH,OAAO,KAAK,EACV,aAAa,EAMb,YAAY,EAUb,MAAM,YAAY,CAAA;AAwDnB;;GAEG;AACH,wBAAgB,YAAY,CAAC,OAAO,EAAE,aAAa,GAAG,YAAY,CAg5DjE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.int.test.d.ts","sourceRoot":"","sources":["../../src/server/builder.int.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
|
|
@@ -0,0 +1,414 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Server Builder Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests for the unified server API.
|
|
5
|
+
*/
|
|
6
|
+
import { describe, it, expect, afterEach, beforeEach } from 'vitest';
|
|
7
|
+
import { createServer as createHttpServer } from 'node:http';
|
|
8
|
+
import { mkdtemp, writeFile, rm, mkdir } from 'node:fs/promises';
|
|
9
|
+
import path from 'node:path';
|
|
10
|
+
import os from 'node:os';
|
|
11
|
+
import { z } from 'zod';
|
|
12
|
+
import { createServer } from './builder.js';
|
|
13
|
+
import { createRouterModule } from './router-module.js';
|
|
14
|
+
import { createContext } from '../types/index.js';
|
|
15
|
+
import { registerValidator, resetValidation, createZodAdapter } from '../validation/index.js';
|
|
16
|
+
import { loadDiscovery } from './fs-routes/loader.js';
|
|
17
|
+
// Helper to create test envelope with context
|
|
18
|
+
function createTestEnvelope(procedure, payload = {}, type = 'request') {
|
|
19
|
+
return {
|
|
20
|
+
id: `test-${Date.now()}`,
|
|
21
|
+
procedure,
|
|
22
|
+
type,
|
|
23
|
+
payload,
|
|
24
|
+
metadata: {},
|
|
25
|
+
context: createContext('test-id'),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
async function getFreePort() {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
const server = createHttpServer();
|
|
31
|
+
server.on('error', reject);
|
|
32
|
+
server.listen(0, '127.0.0.1', () => {
|
|
33
|
+
const address = server.address();
|
|
34
|
+
if (!address || typeof address === 'string') {
|
|
35
|
+
server.close(() => reject(new Error('Failed to acquire free port')));
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const { port } = address;
|
|
39
|
+
server.close((err) => {
|
|
40
|
+
if (err) {
|
|
41
|
+
reject(err);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
resolve(port);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
async function createTempDir() {
|
|
51
|
+
return mkdtemp(path.join(os.tmpdir(), 'raffel-channels-'));
|
|
52
|
+
}
|
|
53
|
+
async function writeFixture(root, relativePath, content) {
|
|
54
|
+
const filePath = path.join(root, relativePath);
|
|
55
|
+
await mkdir(path.dirname(filePath), { recursive: true });
|
|
56
|
+
await writeFile(filePath, content, 'utf-8');
|
|
57
|
+
}
|
|
58
|
+
const TEST_PORT = 24000;
|
|
59
|
+
describe('createServer', () => {
|
|
60
|
+
let server = null;
|
|
61
|
+
beforeEach(() => {
|
|
62
|
+
// Register Zod adapter for validation tests
|
|
63
|
+
resetValidation();
|
|
64
|
+
registerValidator(createZodAdapter(z));
|
|
65
|
+
});
|
|
66
|
+
afterEach(async () => {
|
|
67
|
+
if (server?.isRunning) {
|
|
68
|
+
await server.stop();
|
|
69
|
+
}
|
|
70
|
+
server = null;
|
|
71
|
+
});
|
|
72
|
+
describe('basic lifecycle', () => {
|
|
73
|
+
it('should create a server with default options', () => {
|
|
74
|
+
server = createServer({ port: TEST_PORT });
|
|
75
|
+
expect(server).toBeDefined();
|
|
76
|
+
expect(server.isRunning).toBe(false);
|
|
77
|
+
});
|
|
78
|
+
it('should start and stop the server', async () => {
|
|
79
|
+
server = createServer({ port: TEST_PORT });
|
|
80
|
+
expect(server.isRunning).toBe(false);
|
|
81
|
+
await server.start();
|
|
82
|
+
expect(server.isRunning).toBe(true);
|
|
83
|
+
expect(server.addresses).toBeDefined();
|
|
84
|
+
expect(server.addresses?.http.port).toBe(TEST_PORT);
|
|
85
|
+
await server.stop();
|
|
86
|
+
expect(server.isRunning).toBe(false);
|
|
87
|
+
});
|
|
88
|
+
it('should restart the server', async () => {
|
|
89
|
+
server = createServer({ port: TEST_PORT });
|
|
90
|
+
await server.start();
|
|
91
|
+
expect(server.isRunning).toBe(true);
|
|
92
|
+
await server.restart();
|
|
93
|
+
expect(server.isRunning).toBe(true);
|
|
94
|
+
});
|
|
95
|
+
it('should throw error when starting already running server', async () => {
|
|
96
|
+
server = createServer({ port: TEST_PORT });
|
|
97
|
+
await server.start();
|
|
98
|
+
await expect(server.start()).rejects.toThrow('Server is already running');
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
describe('fluent procedure registration', () => {
|
|
102
|
+
it('should register a procedure with fluent API', async () => {
|
|
103
|
+
server = createServer({ port: TEST_PORT });
|
|
104
|
+
server
|
|
105
|
+
.procedure('users.create')
|
|
106
|
+
.input(z.object({ name: z.string() }))
|
|
107
|
+
.output(z.object({ id: z.string() }))
|
|
108
|
+
.description('Create a new user')
|
|
109
|
+
.handler(async (input) => {
|
|
110
|
+
return { id: `user-${input.name}` };
|
|
111
|
+
});
|
|
112
|
+
expect(server.registry.getProcedure('users.create')).toBeDefined();
|
|
113
|
+
});
|
|
114
|
+
it('should register a procedure with interceptor', async () => {
|
|
115
|
+
server = createServer({ port: TEST_PORT });
|
|
116
|
+
const calls = [];
|
|
117
|
+
const interceptor = async (_envelope, _ctx, next) => {
|
|
118
|
+
calls.push('before');
|
|
119
|
+
const result = await next();
|
|
120
|
+
calls.push('after');
|
|
121
|
+
return result;
|
|
122
|
+
};
|
|
123
|
+
server
|
|
124
|
+
.procedure('test')
|
|
125
|
+
.use(interceptor)
|
|
126
|
+
.handler(async () => {
|
|
127
|
+
calls.push('handler');
|
|
128
|
+
return 'done';
|
|
129
|
+
});
|
|
130
|
+
// Call the procedure directly via router
|
|
131
|
+
const result = (await server.router.handle(createTestEnvelope('test')));
|
|
132
|
+
expect(result.type).toBe('response');
|
|
133
|
+
expect(result.payload).toBe('done');
|
|
134
|
+
expect(calls).toEqual(['before', 'handler', 'after']);
|
|
135
|
+
});
|
|
136
|
+
it('should validate input with schema', async () => {
|
|
137
|
+
server = createServer({ port: TEST_PORT });
|
|
138
|
+
server
|
|
139
|
+
.procedure('validate')
|
|
140
|
+
.input(z.object({ age: z.number().min(0) }))
|
|
141
|
+
.handler(async (input) => {
|
|
142
|
+
return { age: input.age };
|
|
143
|
+
});
|
|
144
|
+
// Valid input
|
|
145
|
+
const validResult = (await server.router.handle(createTestEnvelope('validate', { age: 25 })));
|
|
146
|
+
expect(validResult.type).toBe('response');
|
|
147
|
+
expect(validResult.payload).toEqual({ age: 25 });
|
|
148
|
+
// Invalid input
|
|
149
|
+
const invalidResult = (await server.router.handle(createTestEnvelope('validate', { age: -5 })));
|
|
150
|
+
expect(invalidResult.type).toBe('error');
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
describe('handler groups', () => {
|
|
154
|
+
it('should create grouped procedures', async () => {
|
|
155
|
+
server = createServer({ port: TEST_PORT });
|
|
156
|
+
const users = server.group('users');
|
|
157
|
+
users.procedure('create').handler(async () => ({ id: '1' }));
|
|
158
|
+
users.procedure('get').handler(async () => ({ name: 'John' }));
|
|
159
|
+
users.procedure('list').handler(async () => []);
|
|
160
|
+
expect(server.registry.getProcedure('users.create')).toBeDefined();
|
|
161
|
+
expect(server.registry.getProcedure('users.get')).toBeDefined();
|
|
162
|
+
expect(server.registry.getProcedure('users.list')).toBeDefined();
|
|
163
|
+
});
|
|
164
|
+
it('should inherit middleware from group', async () => {
|
|
165
|
+
server = createServer({ port: TEST_PORT });
|
|
166
|
+
const calls = [];
|
|
167
|
+
const groupMiddleware = async (_envelope, _ctx, next) => {
|
|
168
|
+
calls.push('group-middleware');
|
|
169
|
+
return next();
|
|
170
|
+
};
|
|
171
|
+
const users = server.group('users').use(groupMiddleware);
|
|
172
|
+
users.procedure('test').handler(async () => {
|
|
173
|
+
calls.push('handler');
|
|
174
|
+
return 'done';
|
|
175
|
+
});
|
|
176
|
+
await server.router.handle(createTestEnvelope('users.test'));
|
|
177
|
+
expect(calls).toEqual(['group-middleware', 'handler']);
|
|
178
|
+
});
|
|
179
|
+
it('should support nested groups', async () => {
|
|
180
|
+
server = createServer({ port: TEST_PORT });
|
|
181
|
+
const users = server.group('users');
|
|
182
|
+
const admin = users.group('admin');
|
|
183
|
+
admin.procedure('ban').handler(async () => ({ banned: true }));
|
|
184
|
+
admin.procedure('unban').handler(async () => ({ banned: false }));
|
|
185
|
+
expect(server.registry.getProcedure('users.admin.ban')).toBeDefined();
|
|
186
|
+
expect(server.registry.getProcedure('users.admin.unban')).toBeDefined();
|
|
187
|
+
});
|
|
188
|
+
it('should inherit middleware through nested groups', async () => {
|
|
189
|
+
server = createServer({ port: TEST_PORT });
|
|
190
|
+
const calls = [];
|
|
191
|
+
const users = server.group('users').use(async (_env, _ctx, next) => {
|
|
192
|
+
calls.push('users-mw');
|
|
193
|
+
return next();
|
|
194
|
+
});
|
|
195
|
+
const admin = users.group('admin').use(async (_env, _ctx, next) => {
|
|
196
|
+
calls.push('admin-mw');
|
|
197
|
+
return next();
|
|
198
|
+
});
|
|
199
|
+
admin.procedure('action').handler(async () => {
|
|
200
|
+
calls.push('handler');
|
|
201
|
+
return 'done';
|
|
202
|
+
});
|
|
203
|
+
await server.router.handle(createTestEnvelope('users.admin.action'));
|
|
204
|
+
expect(calls).toEqual(['users-mw', 'admin-mw', 'handler']);
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
describe('router modules', () => {
|
|
208
|
+
it('should mount a module with prefix', async () => {
|
|
209
|
+
server = createServer({ port: TEST_PORT });
|
|
210
|
+
const users = createRouterModule('users');
|
|
211
|
+
users.procedure('create').handler(async () => ({ id: '1' }));
|
|
212
|
+
server.mount('admin', users);
|
|
213
|
+
expect(server.registry.getProcedure('admin.users.create')).toBeDefined();
|
|
214
|
+
});
|
|
215
|
+
it('should compose prefixes across nested module groups', async () => {
|
|
216
|
+
server = createServer({ port: TEST_PORT });
|
|
217
|
+
const users = createRouterModule('users');
|
|
218
|
+
const admin = users.group('admin');
|
|
219
|
+
admin.procedure('ban').handler(async () => ({ banned: true }));
|
|
220
|
+
server.mount('api', users);
|
|
221
|
+
expect(server.registry.getProcedure('api.users.admin.ban')).toBeDefined();
|
|
222
|
+
});
|
|
223
|
+
it('should apply interceptors in deterministic order', async () => {
|
|
224
|
+
server = createServer({ port: TEST_PORT });
|
|
225
|
+
const calls = [];
|
|
226
|
+
const record = (label) => async (_env, _ctx, next) => {
|
|
227
|
+
calls.push(label);
|
|
228
|
+
return next();
|
|
229
|
+
};
|
|
230
|
+
server.use(record('global'));
|
|
231
|
+
const module = createRouterModule('users').use(record('module'));
|
|
232
|
+
module
|
|
233
|
+
.procedure('action')
|
|
234
|
+
.use(record('handler'))
|
|
235
|
+
.handler(async () => {
|
|
236
|
+
calls.push('handler-fn');
|
|
237
|
+
return 'ok';
|
|
238
|
+
});
|
|
239
|
+
server.mount('admin', module, { interceptors: [record('mount')] });
|
|
240
|
+
await server.router.handle(createTestEnvelope('admin.users.action'));
|
|
241
|
+
expect(calls).toEqual(['global', 'mount', 'module', 'handler', 'handler-fn']);
|
|
242
|
+
});
|
|
243
|
+
});
|
|
244
|
+
describe('global middleware', () => {
|
|
245
|
+
it('should apply global middleware to all procedures', async () => {
|
|
246
|
+
server = createServer({ port: TEST_PORT });
|
|
247
|
+
const calls = [];
|
|
248
|
+
server.use(async (_env, _ctx, next) => {
|
|
249
|
+
calls.push('global');
|
|
250
|
+
return next();
|
|
251
|
+
});
|
|
252
|
+
server.procedure('test1').handler(async () => {
|
|
253
|
+
calls.push('handler1');
|
|
254
|
+
return 'done1';
|
|
255
|
+
});
|
|
256
|
+
server.procedure('test2').handler(async () => {
|
|
257
|
+
calls.push('handler2');
|
|
258
|
+
return 'done2';
|
|
259
|
+
});
|
|
260
|
+
await server.router.handle(createTestEnvelope('test1'));
|
|
261
|
+
calls.length = 0;
|
|
262
|
+
await server.router.handle(createTestEnvelope('test2'));
|
|
263
|
+
expect(calls).toEqual(['global', 'handler2']);
|
|
264
|
+
});
|
|
265
|
+
});
|
|
266
|
+
describe('direct registration (backwards compatible)', () => {
|
|
267
|
+
it('should support direct procedure registration', async () => {
|
|
268
|
+
server = createServer({ port: TEST_PORT });
|
|
269
|
+
server.procedure('legacy', async () => 'legacy-result');
|
|
270
|
+
const result = (await server.router.handle(createTestEnvelope('legacy')));
|
|
271
|
+
expect(result.type).toBe('response');
|
|
272
|
+
expect(result.payload).toBe('legacy-result');
|
|
273
|
+
});
|
|
274
|
+
});
|
|
275
|
+
describe('protocol configuration', () => {
|
|
276
|
+
it('should enable WebSocket', () => {
|
|
277
|
+
server = createServer({ port: TEST_PORT });
|
|
278
|
+
server.enableWebSocket('/ws');
|
|
279
|
+
// Can't test actual WebSocket without starting, but we can verify it's configured
|
|
280
|
+
expect(server).toBeDefined();
|
|
281
|
+
});
|
|
282
|
+
it('should enable JSON-RPC', () => {
|
|
283
|
+
server = createServer({ port: TEST_PORT });
|
|
284
|
+
server.enableJsonRpc('/rpc');
|
|
285
|
+
expect(server).toBeDefined();
|
|
286
|
+
});
|
|
287
|
+
it('should configure TCP', () => {
|
|
288
|
+
server = createServer({ port: TEST_PORT });
|
|
289
|
+
server.tcp({ port: TEST_PORT + 10 });
|
|
290
|
+
expect(server).toBeDefined();
|
|
291
|
+
});
|
|
292
|
+
it('should chain protocol configurations', () => {
|
|
293
|
+
server = createServer({ port: TEST_PORT })
|
|
294
|
+
.enableWebSocket()
|
|
295
|
+
.enableJsonRpc()
|
|
296
|
+
.tcp({ port: TEST_PORT + 10 });
|
|
297
|
+
expect(server).toBeDefined();
|
|
298
|
+
});
|
|
299
|
+
});
|
|
300
|
+
describe('shared protocol ports', () => {
|
|
301
|
+
it('should serve JSON-RPC and GraphQL over the HTTP port with basePath', async () => {
|
|
302
|
+
const port = await getFreePort();
|
|
303
|
+
server = createServer({
|
|
304
|
+
port,
|
|
305
|
+
basePath: '/api',
|
|
306
|
+
jsonrpc: { path: '/rpc' },
|
|
307
|
+
graphql: { path: '/graphql' },
|
|
308
|
+
});
|
|
309
|
+
server
|
|
310
|
+
.procedure('getHello')
|
|
311
|
+
.output(z.string())
|
|
312
|
+
.handler(async () => 'world');
|
|
313
|
+
await server.start();
|
|
314
|
+
expect(server.addresses?.jsonrpc?.port).toBe(port);
|
|
315
|
+
expect(server.addresses?.jsonrpc?.shared).toBe(true);
|
|
316
|
+
expect(server.addresses?.jsonrpc?.path).toBe('/api/rpc');
|
|
317
|
+
expect(server.addresses?.graphql?.port).toBe(port);
|
|
318
|
+
expect(server.addresses?.graphql?.shared).toBe(true);
|
|
319
|
+
expect(server.addresses?.graphql?.path).toBe('/api/graphql');
|
|
320
|
+
const rpcResponse = await fetch(`http://localhost:${port}/api/rpc`, {
|
|
321
|
+
method: 'POST',
|
|
322
|
+
headers: { 'content-type': 'application/json' },
|
|
323
|
+
body: JSON.stringify({
|
|
324
|
+
jsonrpc: '2.0',
|
|
325
|
+
id: 1,
|
|
326
|
+
method: 'getHello',
|
|
327
|
+
params: {},
|
|
328
|
+
}),
|
|
329
|
+
});
|
|
330
|
+
expect(rpcResponse.status).toBe(200);
|
|
331
|
+
const rpcBody = (await rpcResponse.json());
|
|
332
|
+
expect(rpcBody.result).toBe('world');
|
|
333
|
+
const gqlResponse = await fetch(`http://localhost:${port}/api/graphql`, {
|
|
334
|
+
method: 'POST',
|
|
335
|
+
headers: { 'content-type': 'application/json' },
|
|
336
|
+
body: JSON.stringify({ query: '{ getHello }' }),
|
|
337
|
+
});
|
|
338
|
+
expect(gqlResponse.status).toBe(200);
|
|
339
|
+
const gqlBody = (await gqlResponse.json());
|
|
340
|
+
expect(gqlBody.data).toEqual({ getHello: 'world' });
|
|
341
|
+
});
|
|
342
|
+
});
|
|
343
|
+
describe('channel auth discovery', () => {
|
|
344
|
+
let tempDir = null;
|
|
345
|
+
afterEach(async () => {
|
|
346
|
+
if (tempDir) {
|
|
347
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
348
|
+
tempDir = null;
|
|
349
|
+
}
|
|
350
|
+
});
|
|
351
|
+
it('should apply the closest _auth config for optional channels', async () => {
|
|
352
|
+
tempDir = await createTempDir();
|
|
353
|
+
await writeFixture(tempDir, 'src/channels/_auth.js', `export default { anonymous: { principal: 'root-guest' } }\n`);
|
|
354
|
+
await writeFixture(tempDir, 'src/channels/private/_auth.js', `export default { anonymous: { principal: 'private-guest' } }\n`);
|
|
355
|
+
await writeFixture(tempDir, 'src/channels/private/room.js', `export const auth = 'optional'\n`);
|
|
356
|
+
const discovery = await loadDiscovery({
|
|
357
|
+
baseDir: tempDir,
|
|
358
|
+
discovery: { channels: true },
|
|
359
|
+
extensions: ['.js'],
|
|
360
|
+
});
|
|
361
|
+
const port = await getFreePort();
|
|
362
|
+
let observedAuth;
|
|
363
|
+
server = createServer({
|
|
364
|
+
port,
|
|
365
|
+
websocket: {
|
|
366
|
+
channels: {
|
|
367
|
+
authorize: async (_socketId, _channel, ctx) => {
|
|
368
|
+
observedAuth = ctx.auth;
|
|
369
|
+
return true;
|
|
370
|
+
},
|
|
371
|
+
},
|
|
372
|
+
},
|
|
373
|
+
});
|
|
374
|
+
server.addDiscovery(discovery);
|
|
375
|
+
await server.start();
|
|
376
|
+
const ctx = createContext('socket-test');
|
|
377
|
+
const result = await server.channels.subscribe('socket-1', 'private/room', ctx);
|
|
378
|
+
expect(result.success).toBe(true);
|
|
379
|
+
expect(observedAuth?.principal).toBe('private-guest');
|
|
380
|
+
});
|
|
381
|
+
it('should enforce auth for required channels with _auth config', async () => {
|
|
382
|
+
tempDir = await createTempDir();
|
|
383
|
+
await writeFixture(tempDir, 'src/channels/_auth.js', `export default { anonymous: { principal: 'guest' } }\n`);
|
|
384
|
+
await writeFixture(tempDir, 'src/channels/secure.js', `export const auth = 'required'\n`);
|
|
385
|
+
const discovery = await loadDiscovery({
|
|
386
|
+
baseDir: tempDir,
|
|
387
|
+
discovery: { channels: true },
|
|
388
|
+
extensions: ['.js'],
|
|
389
|
+
});
|
|
390
|
+
const port = await getFreePort();
|
|
391
|
+
server = createServer({
|
|
392
|
+
port,
|
|
393
|
+
websocket: { channels: {} },
|
|
394
|
+
});
|
|
395
|
+
server.addDiscovery(discovery);
|
|
396
|
+
await server.start();
|
|
397
|
+
const ctx = createContext('socket-test');
|
|
398
|
+
const result = await server.channels.subscribe('socket-1', 'secure', ctx);
|
|
399
|
+
expect(result.success).toBe(false);
|
|
400
|
+
expect(result.error?.code).toBe('PERMISSION_DENIED');
|
|
401
|
+
});
|
|
402
|
+
});
|
|
403
|
+
describe('accessors', () => {
|
|
404
|
+
it('should provide access to registry', () => {
|
|
405
|
+
server = createServer({ port: TEST_PORT });
|
|
406
|
+
expect(server.registry).toBeDefined();
|
|
407
|
+
});
|
|
408
|
+
it('should provide access to router', () => {
|
|
409
|
+
server = createServer({ port: TEST_PORT });
|
|
410
|
+
expect(server.router).toBeDefined();
|
|
411
|
+
});
|
|
412
|
+
});
|
|
413
|
+
});
|
|
414
|
+
//# sourceMappingURL=builder.int.test.js.map
|