@bgord/bun 1.10.23 → 1.12.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/dist/ab-assignment-composite.strategy.d.ts +10 -0
- package/dist/ab-assignment-composite.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-composite.strategy.js +15 -0
- package/dist/ab-assignment-composite.strategy.js.map +1 -0
- package/dist/ab-assignment-fixed.strategy.d.ts +10 -0
- package/dist/ab-assignment-fixed.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-fixed.strategy.js +10 -0
- package/dist/ab-assignment-fixed.strategy.js.map +1 -0
- package/dist/ab-assignment-hash.strategy.d.ts +12 -0
- package/dist/ab-assignment-hash.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-hash.strategy.js +14 -0
- package/dist/ab-assignment-hash.strategy.js.map +1 -0
- package/dist/ab-assignment-query.strategy.d.ts +10 -0
- package/dist/ab-assignment-query.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-query.strategy.js +11 -0
- package/dist/ab-assignment-query.strategy.js.map +1 -0
- package/dist/ab-assignment.strategy.d.ts +7 -0
- package/dist/ab-assignment.strategy.d.ts.map +1 -0
- package/dist/ab-assignment.strategy.js +2 -0
- package/dist/ab-assignment.strategy.js.map +1 -0
- package/dist/ab-hono-noop.middleware.d.ts +10 -0
- package/dist/ab-hono-noop.middleware.d.ts.map +1 -0
- package/dist/ab-hono-noop.middleware.js +18 -0
- package/dist/ab-hono-noop.middleware.js.map +1 -0
- package/dist/ab-hono.middleware.d.ts +14 -0
- package/dist/ab-hono.middleware.d.ts.map +1 -0
- package/dist/ab-hono.middleware.js +17 -0
- package/dist/ab-hono.middleware.js.map +1 -0
- package/dist/ab-variant-selector.service.d.ts +12 -0
- package/dist/ab-variant-selector.service.d.ts.map +1 -0
- package/dist/ab-variant-selector.service.js +22 -0
- package/dist/ab-variant-selector.service.js.map +1 -0
- package/dist/ab-variant-weight.vo.d.ts +7 -0
- package/dist/ab-variant-weight.vo.d.ts.map +1 -0
- package/dist/ab-variant-weight.vo.js +10 -0
- package/dist/ab-variant-weight.vo.js.map +1 -0
- package/dist/ab-variant.vo.d.ts +11 -0
- package/dist/ab-variant.vo.d.ts.map +1 -0
- package/dist/ab-variant.vo.js +7 -0
- package/dist/ab-variant.vo.js.map +1 -0
- package/dist/ab-variants.vo.d.ts +12 -0
- package/dist/ab-variants.vo.d.ts.map +1 -0
- package/dist/ab-variants.vo.js +24 -0
- package/dist/ab-variants.vo.js.map +1 -0
- package/dist/ab.middleware.d.ts +11 -0
- package/dist/ab.middleware.d.ts.map +1 -0
- package/dist/ab.middleware.js +12 -0
- package/dist/ab.middleware.js.map +1 -0
- package/dist/api-version-hono.middleware.d.ts +17 -0
- package/dist/api-version-hono.middleware.d.ts.map +1 -0
- package/dist/api-version-hono.middleware.js +15 -0
- package/dist/api-version-hono.middleware.js.map +1 -0
- package/dist/api-version.middleware.d.ts +5 -2
- package/dist/api-version.middleware.d.ts.map +1 -1
- package/dist/api-version.middleware.js +12 -10
- package/dist/api-version.middleware.js.map +1 -1
- package/dist/auth-session-reader.port.d.ts +8 -7
- package/dist/auth-session-reader.port.d.ts.map +1 -1
- package/dist/basic-auth.service.d.ts +3 -3
- package/dist/basic-auth.service.d.ts.map +1 -1
- package/dist/basic-auth.service.js.map +1 -1
- package/dist/cache-response-hono.middleware.d.ts +14 -0
- package/dist/cache-response-hono.middleware.d.ts.map +1 -0
- package/dist/cache-response-hono.middleware.js +34 -0
- package/dist/cache-response-hono.middleware.js.map +1 -0
- package/dist/cache-response.middleware.d.ts +18 -8
- package/dist/cache-response.middleware.d.ts.map +1 -1
- package/dist/cache-response.middleware.js +8 -21
- package/dist/cache-response.middleware.js.map +1 -1
- package/dist/command-bus-collecting.adapter.d.ts +10 -0
- package/dist/command-bus-collecting.adapter.d.ts.map +1 -0
- package/dist/command-bus-collecting.adapter.js +8 -0
- package/dist/command-bus-collecting.adapter.js.map +1 -0
- package/dist/command-bus-emittery-v1.adapter.d.ts +11 -0
- package/dist/command-bus-emittery-v1.adapter.d.ts.map +1 -0
- package/dist/command-bus-emittery-v1.adapter.js +14 -0
- package/dist/command-bus-emittery-v1.adapter.js.map +1 -0
- package/dist/command-bus-noop.adapter.d.ts +9 -0
- package/dist/command-bus-noop.adapter.d.ts.map +1 -0
- package/dist/command-bus-noop.adapter.js +5 -0
- package/dist/command-bus-noop.adapter.js.map +1 -0
- package/dist/command-bus-with-logger.adapter.d.ts +18 -0
- package/dist/command-bus-with-logger.adapter.d.ts.map +1 -0
- package/dist/command-bus-with-logger.adapter.js +21 -0
- package/dist/command-bus-with-logger.adapter.js.map +1 -0
- package/dist/command-bus.port.d.ts +8 -0
- package/dist/command-bus.port.d.ts.map +1 -0
- package/dist/command-bus.port.js +2 -0
- package/dist/command-bus.port.js.map +1 -0
- package/dist/correlation-hono.middleware.d.ts +16 -0
- package/dist/correlation-hono.middleware.d.ts.map +1 -0
- package/dist/correlation-hono.middleware.js +20 -0
- package/dist/correlation-hono.middleware.js.map +1 -0
- package/dist/correlation-id.middleware.d.ts +14 -0
- package/dist/correlation-id.middleware.d.ts.map +1 -0
- package/dist/correlation-id.middleware.js +16 -0
- package/dist/correlation-id.middleware.js.map +1 -0
- package/dist/correlation-storage.service.d.ts +0 -1
- package/dist/correlation-storage.service.d.ts.map +1 -1
- package/dist/correlation-storage.service.js +0 -2
- package/dist/correlation-storage.service.js.map +1 -1
- package/dist/crypto-key-provider-with-cache.adapter.d.ts +5 -4
- package/dist/crypto-key-provider-with-cache.adapter.d.ts.map +1 -1
- package/dist/crypto-key-provider-with-cache.adapter.js +5 -5
- package/dist/crypto-key-provider-with-cache.adapter.js.map +1 -1
- package/dist/dispatching-event-store.d.ts +2 -3
- package/dist/dispatching-event-store.d.ts.map +1 -1
- package/dist/dispatching-event-store.js.map +1 -1
- package/dist/environment-loader-process-safe.adapter.d.ts.map +1 -1
- package/dist/environment-loader-process-safe.adapter.js +3 -3
- package/dist/environment-loader-process-safe.adapter.js.map +1 -1
- package/dist/etag-extractor-hono.middleware.d.ts +13 -0
- package/dist/etag-extractor-hono.middleware.d.ts.map +1 -0
- package/dist/etag-extractor-hono.middleware.js +17 -0
- package/dist/etag-extractor-hono.middleware.js.map +1 -0
- package/dist/etag-extractor.middleware.d.ts +3 -8
- package/dist/etag-extractor.middleware.d.ts.map +1 -1
- package/dist/etag-extractor.middleware.js +5 -9
- package/dist/etag-extractor.middleware.js.map +1 -1
- package/dist/event-bus-collecting.adapter.d.ts +10 -0
- package/dist/event-bus-collecting.adapter.d.ts.map +1 -0
- package/dist/event-bus-collecting.adapter.js +8 -0
- package/dist/event-bus-collecting.adapter.js.map +1 -0
- package/dist/event-bus-emittery-v1.adapter.d.ts +11 -0
- package/dist/event-bus-emittery-v1.adapter.d.ts.map +1 -0
- package/dist/event-bus-emittery-v1.adapter.js +14 -0
- package/dist/event-bus-emittery-v1.adapter.js.map +1 -0
- package/dist/event-bus-noop.adapter.d.ts +9 -0
- package/dist/event-bus-noop.adapter.d.ts.map +1 -0
- package/dist/event-bus-noop.adapter.js +5 -0
- package/dist/event-bus-noop.adapter.js.map +1 -0
- package/dist/event-bus-with-logger.adapter.d.ts +18 -0
- package/dist/event-bus-with-logger.adapter.d.ts.map +1 -0
- package/dist/event-bus-with-logger.adapter.js +21 -0
- package/dist/event-bus-with-logger.adapter.js.map +1 -0
- package/dist/event-bus.port.d.ts +8 -0
- package/dist/event-bus.port.d.ts.map +1 -0
- package/dist/event-bus.port.js +2 -0
- package/dist/event-bus.port.js.map +1 -0
- package/dist/event-store.d.ts +2 -2
- package/dist/event-store.d.ts.map +1 -1
- package/dist/event-store.js.map +1 -1
- package/dist/file-inspection-noop.adapter.d.ts +2 -2
- package/dist/file-inspection-noop.adapter.d.ts.map +1 -1
- package/dist/file-inspection-noop.adapter.js.map +1 -1
- package/dist/file-reader-json-with-cache.adapter.d.ts +5 -4
- package/dist/file-reader-json-with-cache.adapter.d.ts.map +1 -1
- package/dist/file-reader-json-with-cache.adapter.js +6 -6
- package/dist/file-reader-json-with-cache.adapter.js.map +1 -1
- package/dist/file-reader-raw-with-cache.adapter.d.ts +5 -4
- package/dist/file-reader-raw-with-cache.adapter.d.ts.map +1 -1
- package/dist/file-reader-raw-with-cache.adapter.js +6 -6
- package/dist/file-reader-raw-with-cache.adapter.js.map +1 -1
- package/dist/file-reader-text-with-cache.adapter.d.ts +5 -4
- package/dist/file-reader-text-with-cache.adapter.d.ts.map +1 -1
- package/dist/file-reader-text-with-cache.adapter.js +6 -6
- package/dist/file-reader-text-with-cache.adapter.js.map +1 -1
- package/dist/file-uploader-hono.middleware.d.ts +13 -0
- package/dist/file-uploader-hono.middleware.d.ts.map +1 -0
- package/dist/file-uploader-hono.middleware.js +37 -0
- package/dist/file-uploader-hono.middleware.js.map +1 -0
- package/dist/file-uploader.middleware.d.ts +19 -8
- package/dist/file-uploader.middleware.d.ts.map +1 -1
- package/dist/file-uploader.middleware.js +24 -26
- package/dist/file-uploader.middleware.js.map +1 -1
- package/dist/handler-hono.port.d.ts +5 -0
- package/dist/handler-hono.port.d.ts.map +1 -0
- package/dist/handler-hono.port.js +2 -0
- package/dist/handler-hono.port.js.map +1 -0
- package/dist/hash-bucket.vo.d.ts +9 -0
- package/dist/hash-bucket.vo.d.ts.map +1 -0
- package/dist/hash-bucket.vo.js +17 -0
- package/dist/hash-bucket.vo.js.map +1 -0
- package/dist/healthcheck-hono.handler.d.ts +87 -0
- package/dist/healthcheck-hono.handler.d.ts.map +1 -0
- package/dist/healthcheck-hono.handler.js +17 -0
- package/dist/healthcheck-hono.handler.js.map +1 -0
- package/dist/healthcheck.handler.d.ts +83 -0
- package/dist/healthcheck.handler.d.ts.map +1 -0
- package/dist/{healthcheck.service.js → healthcheck.handler.js} +21 -19
- package/dist/healthcheck.handler.js.map +1 -0
- package/dist/http-logger-hono.middleware.d.ts +17 -0
- package/dist/http-logger-hono.middleware.d.ts.map +1 -0
- package/dist/http-logger-hono.middleware.js +37 -0
- package/dist/http-logger-hono.middleware.js.map +1 -0
- package/dist/http-logger.middleware.d.ts +19 -4
- package/dist/http-logger.middleware.d.ts.map +1 -1
- package/dist/http-logger.middleware.js +31 -41
- package/dist/http-logger.middleware.js.map +1 -1
- package/dist/i18n.service.d.ts +1 -1
- package/dist/i18n.service.d.ts.map +1 -1
- package/dist/image-info-noop.adapter.d.ts +1 -1
- package/dist/image-info-noop.adapter.d.ts.map +1 -1
- package/dist/image-info-noop.adapter.js +1 -1
- package/dist/image-info-noop.adapter.js.map +1 -1
- package/dist/image-info-sharp.adapter.d.ts +1 -1
- package/dist/image-info-sharp.adapter.d.ts.map +1 -1
- package/dist/image-info-sharp.adapter.js +3 -3
- package/dist/image-info-sharp.adapter.js.map +1 -1
- package/dist/image-info.port.d.ts +1 -1
- package/dist/image-info.port.d.ts.map +1 -1
- package/dist/in-flight-requests-hono.middleware.d.ts +7 -0
- package/dist/in-flight-requests-hono.middleware.d.ts.map +1 -0
- package/dist/in-flight-requests-hono.middleware.js +16 -0
- package/dist/in-flight-requests-hono.middleware.js.map +1 -0
- package/dist/in-flight-requests-tracker.service.d.ts.map +1 -1
- package/dist/in-flight-requests-tracker.service.js +0 -1
- package/dist/in-flight-requests-tracker.service.js.map +1 -1
- package/dist/in-flight-requests.middleware.d.ts +3 -2
- package/dist/in-flight-requests.middleware.d.ts.map +1 -1
- package/dist/in-flight-requests.middleware.js +6 -10
- package/dist/in-flight-requests.middleware.js.map +1 -1
- package/dist/index.d.ts +80 -28
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +80 -28
- package/dist/index.js.map +1 -1
- package/dist/invariant-error-handler.service.d.ts +1 -2
- package/dist/invariant-error-handler.service.d.ts.map +1 -1
- package/dist/invariant-error-handler.service.js.map +1 -1
- package/dist/invariant.service.d.ts +2 -2
- package/dist/invariant.service.d.ts.map +1 -1
- package/dist/mailer-resend.adapter.d.ts +2 -2
- package/dist/mailer-resend.adapter.d.ts.map +1 -1
- package/dist/mailer-resend.adapter.js.map +1 -1
- package/dist/mailer-smtp.adapter.d.ts +2 -2
- package/dist/mailer-smtp.adapter.d.ts.map +1 -1
- package/dist/mailer-smtp.adapter.js.map +1 -1
- package/dist/middleware-hono-noop.adapter.d.ts +6 -0
- package/dist/middleware-hono-noop.adapter.d.ts.map +1 -0
- package/dist/middleware-hono-noop.adapter.js +6 -0
- package/dist/middleware-hono-noop.adapter.js.map +1 -0
- package/dist/middleware-hono.port.d.ts +5 -0
- package/dist/middleware-hono.port.d.ts.map +1 -0
- package/dist/middleware-hono.port.js +2 -0
- package/dist/middleware-hono.port.js.map +1 -0
- package/dist/modules/preferences/invariants/user-language-has-changed.d.ts +6 -6
- package/dist/modules/preferences/invariants/user-language-has-changed.d.ts.map +1 -1
- package/dist/modules/preferences/invariants/user-language-has-changed.js.map +1 -1
- package/dist/ping-hono.handler.d.ts +6 -0
- package/dist/ping-hono.handler.d.ts.map +1 -0
- package/dist/ping-hono.handler.js +13 -0
- package/dist/ping-hono.handler.js.map +1 -0
- package/dist/ping.handler.d.ts +4 -0
- package/dist/ping.handler.d.ts.map +1 -0
- package/dist/ping.handler.js +6 -0
- package/dist/ping.handler.js.map +1 -0
- package/dist/prerequisite-verifier-binary.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-binary.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-binary.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-bun.adapter.d.ts +6 -4
- package/dist/prerequisite-verifier-bun.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-bun.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-clock-drift.adapter.d.ts +4 -3
- package/dist/prerequisite-verifier-clock-drift.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-clock-drift.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-directory.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-directory.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-directory.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-dns.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-dns.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-dns.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-external-api.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-external-api.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-external-api.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-file.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-file.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-file.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-jobs.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-jobs.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-jobs.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-memory.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-memory.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-memory.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-node.adapter.d.ts +6 -4
- package/dist/prerequisite-verifier-node.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-node.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-os.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-os.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-os.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-port.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-port.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-port.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-ram.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-ram.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-ram.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-running-user.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-running-user.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-running-user.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-space.adapter.d.ts +4 -3
- package/dist/prerequisite-verifier-space.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-space.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-sqlite.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-sqlite.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-sqlite.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-timezone-utc.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-translations.adapter.d.ts +1 -1
- package/dist/prerequisite-verifier-translations.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-translations.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-cache.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-with-cache.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-cache.adapter.js +6 -6
- package/dist/prerequisite-verifier-with-cache.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts +2 -2
- package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-fail-safe.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-logger.adapter.d.ts +4 -3
- package/dist/prerequisite-verifier-with-logger.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-logger.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-retry.adapter.d.ts +6 -5
- package/dist/prerequisite-verifier-with-retry.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-retry.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-timeout.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-with-timeout.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-timeout.adapter.js.map +1 -1
- package/dist/prerequisite-verifier.decorator.d.ts +4 -4
- package/dist/prerequisite-verifier.decorator.d.ts.map +1 -1
- package/dist/prerequisite-verifier.decorator.js.map +1 -1
- package/dist/prerequisite.vo.d.ts +2 -2
- package/dist/prerequisite.vo.d.ts.map +1 -1
- package/dist/prerequisite.vo.js.map +1 -1
- package/dist/remote-file-storage-disk.adapter.d.ts +4 -4
- package/dist/remote-file-storage-disk.adapter.d.ts.map +1 -1
- package/dist/remote-file-storage-disk.adapter.js.map +1 -1
- package/dist/request-context-hono.adapter.d.ts +1 -1
- package/dist/request-context-hono.adapter.d.ts.map +1 -1
- package/dist/request-context-hono.adapter.js +10 -1
- package/dist/request-context-hono.adapter.js.map +1 -1
- package/dist/request-context.port.d.ts +18 -0
- package/dist/request-context.port.d.ts.map +1 -1
- package/dist/retry.service.d.ts +5 -5
- package/dist/retry.service.d.ts.map +1 -1
- package/dist/retry.service.js.map +1 -1
- package/dist/security-countermeasure-ban.strategy.d.ts +8 -7
- package/dist/security-countermeasure-ban.strategy.d.ts.map +1 -1
- package/dist/security-countermeasure-ban.strategy.js.map +1 -1
- package/dist/security-countermeasure-mirage.strategy.d.ts +6 -5
- package/dist/security-countermeasure-mirage.strategy.d.ts.map +1 -1
- package/dist/security-countermeasure-mirage.strategy.js.map +1 -1
- package/dist/security-countermeasure-tarpit.strategy.d.ts +5 -4
- package/dist/security-countermeasure-tarpit.strategy.d.ts.map +1 -1
- package/dist/security-countermeasure-tarpit.strategy.js.map +1 -1
- package/dist/security-rule-violation-threshold.strategy.d.ts +4 -3
- package/dist/security-rule-violation-threshold.strategy.d.ts.map +1 -1
- package/dist/security-rule-violation-threshold.strategy.js +4 -4
- package/dist/security-rule-violation-threshold.strategy.js.map +1 -1
- package/dist/setup-hono.service.d.ts +31 -0
- package/dist/setup-hono.service.d.ts.map +1 -0
- package/dist/{setup.service.js → setup-hono.service.js} +25 -33
- package/dist/setup-hono.service.js.map +1 -0
- package/dist/shield-api-key-hono.strategy.d.ts +11 -0
- package/dist/shield-api-key-hono.strategy.d.ts.map +1 -0
- package/dist/shield-api-key-hono.strategy.js +19 -0
- package/dist/shield-api-key-hono.strategy.js.map +1 -0
- package/dist/shield-api-key.strategy.d.ts +9 -9
- package/dist/shield-api-key.strategy.d.ts.map +1 -1
- package/dist/shield-api-key.strategy.js +5 -11
- package/dist/shield-api-key.strategy.js.map +1 -1
- package/dist/shield-auth-hono.strategy.d.ts +16 -0
- package/dist/shield-auth-hono.strategy.d.ts.map +1 -0
- package/dist/shield-auth-hono.strategy.js +31 -0
- package/dist/shield-auth-hono.strategy.js.map +1 -0
- package/dist/shield-auth.strategy.d.ts +8 -7
- package/dist/shield-auth.strategy.d.ts.map +1 -1
- package/dist/shield-auth.strategy.js +10 -23
- package/dist/shield-auth.strategy.js.map +1 -1
- package/dist/shield-basic-auth-hono.strategy.d.ts +11 -0
- package/dist/shield-basic-auth-hono.strategy.d.ts.map +1 -0
- package/dist/shield-basic-auth-hono.strategy.js +21 -0
- package/dist/shield-basic-auth-hono.strategy.js.map +1 -0
- package/dist/shield-basic-auth.strategy.d.ts +9 -7
- package/dist/shield-basic-auth.strategy.d.ts.map +1 -1
- package/dist/shield-basic-auth.strategy.js +18 -5
- package/dist/shield-basic-auth.strategy.js.map +1 -1
- package/dist/shield-body-limit-hono.strategy.d.ts +10 -0
- package/dist/shield-body-limit-hono.strategy.d.ts.map +1 -0
- package/dist/shield-body-limit-hono.strategy.js +21 -0
- package/dist/shield-body-limit-hono.strategy.js.map +1 -0
- package/dist/shield-body-limit.strategy.d.ts +14 -0
- package/dist/shield-body-limit.strategy.d.ts.map +1 -0
- package/dist/shield-body-limit.strategy.js +19 -0
- package/dist/shield-body-limit.strategy.js.map +1 -0
- package/dist/shield-csrf-hono.strategy.d.ts +11 -0
- package/dist/shield-csrf-hono.strategy.d.ts.map +1 -0
- package/dist/shield-csrf-hono.strategy.js +19 -0
- package/dist/shield-csrf-hono.strategy.js.map +1 -0
- package/dist/shield-csrf.strategy.d.ts +8 -7
- package/dist/shield-csrf.strategy.d.ts.map +1 -1
- package/dist/shield-csrf.strategy.js +7 -11
- package/dist/shield-csrf.strategy.js.map +1 -1
- package/dist/shield-hcaptcha-hono-local.strategy.d.ts +14 -0
- package/dist/shield-hcaptcha-hono-local.strategy.d.ts.map +1 -0
- package/dist/shield-hcaptcha-hono-local.strategy.js +20 -0
- package/dist/shield-hcaptcha-hono-local.strategy.js.map +1 -0
- package/dist/shield-hcaptcha-hono.strategy.d.ts +11 -0
- package/dist/shield-hcaptcha-hono.strategy.d.ts.map +1 -0
- package/dist/shield-hcaptcha-hono.strategy.js +19 -0
- package/dist/shield-hcaptcha-hono.strategy.js.map +1 -0
- package/dist/shield-hcaptcha.strategy.d.ts +5 -5
- package/dist/shield-hcaptcha.strategy.d.ts.map +1 -1
- package/dist/shield-hcaptcha.strategy.js +6 -12
- package/dist/shield-hcaptcha.strategy.js.map +1 -1
- package/dist/shield-maintenance-hono.strategy.d.ts +9 -0
- package/dist/shield-maintenance-hono.strategy.d.ts.map +1 -0
- package/dist/shield-maintenance-hono.strategy.js +18 -0
- package/dist/shield-maintenance-hono.strategy.js.map +1 -0
- package/dist/shield-maintenance.strategy.d.ts +15 -0
- package/dist/shield-maintenance.strategy.d.ts.map +1 -0
- package/dist/shield-maintenance.strategy.js +13 -0
- package/dist/shield-maintenance.strategy.js.map +1 -0
- package/dist/shield-rate-limit-hono.strategy.d.ts +18 -0
- package/dist/shield-rate-limit-hono.strategy.d.ts.map +1 -0
- package/dist/shield-rate-limit-hono.strategy.js +21 -0
- package/dist/shield-rate-limit-hono.strategy.js.map +1 -0
- package/dist/shield-rate-limit.strategy.d.ts +11 -10
- package/dist/shield-rate-limit.strategy.d.ts.map +1 -1
- package/dist/shield-rate-limit.strategy.js +9 -16
- package/dist/shield-rate-limit.strategy.js.map +1 -1
- package/dist/shield-recaptcha-hono.strategy.d.ts +11 -0
- package/dist/shield-recaptcha-hono.strategy.d.ts.map +1 -0
- package/dist/shield-recaptcha-hono.strategy.js +22 -0
- package/dist/shield-recaptcha-hono.strategy.js.map +1 -0
- package/dist/shield-recaptcha.strategy.d.ts +9 -8
- package/dist/shield-recaptcha.strategy.d.ts.map +1 -1
- package/dist/shield-recaptcha.strategy.js +8 -13
- package/dist/shield-recaptcha.strategy.js.map +1 -1
- package/dist/shield-security-hono.strategy.d.ts +18 -0
- package/dist/shield-security-hono.strategy.d.ts.map +1 -0
- package/dist/shield-security-hono.strategy.js +43 -0
- package/dist/shield-security-hono.strategy.js.map +1 -0
- package/dist/shield-security.strategy.d.ts +6 -12
- package/dist/shield-security.strategy.d.ts.map +1 -1
- package/dist/shield-security.strategy.js +12 -43
- package/dist/shield-security.strategy.js.map +1 -1
- package/dist/shield-timeout-hono.strategy.d.ts +11 -0
- package/dist/shield-timeout-hono.strategy.d.ts.map +1 -0
- package/dist/shield-timeout-hono.strategy.js +15 -0
- package/dist/shield-timeout-hono.strategy.js.map +1 -0
- package/dist/shield-timeout.strategy.d.ts +7 -9
- package/dist/shield-timeout.strategy.d.ts.map +1 -1
- package/dist/shield-timeout.strategy.js +3 -7
- package/dist/shield-timeout.strategy.js.map +1 -1
- package/dist/simulated-error-hono.middleware.d.ts +8 -0
- package/dist/simulated-error-hono.middleware.d.ts.map +1 -0
- package/dist/simulated-error-hono.middleware.js +13 -0
- package/dist/simulated-error-hono.middleware.js.map +1 -0
- package/dist/simulated-error.middleware.d.ts +2 -2
- package/dist/simulated-error.middleware.d.ts.map +1 -1
- package/dist/simulated-error.middleware.js +3 -4
- package/dist/simulated-error.middleware.js.map +1 -1
- package/dist/slower-hono.middleware.d.ts +14 -0
- package/dist/slower-hono.middleware.d.ts.map +1 -0
- package/dist/slower-hono.middleware.js +14 -0
- package/dist/slower-hono.middleware.js.map +1 -0
- package/dist/slower.middleware.d.ts +5 -2
- package/dist/slower.middleware.d.ts.map +1 -1
- package/dist/slower.middleware.js +10 -6
- package/dist/slower.middleware.js.map +1 -1
- package/dist/{ssr.d.ts → ssr-bun.service.d.ts} +2 -2
- package/dist/ssr-bun.service.d.ts.map +1 -0
- package/dist/ssr-bun.service.js +14 -0
- package/dist/ssr-bun.service.js.map +1 -0
- package/dist/ssr.service.d.ts +26 -0
- package/dist/ssr.service.d.ts.map +1 -0
- package/dist/ssr.service.js +49 -0
- package/dist/ssr.service.js.map +1 -0
- package/dist/{static-files.service.d.ts → static-files-hono.service.d.ts} +2 -2
- package/dist/static-files-hono.service.d.ts.map +1 -0
- package/dist/{static-files.service.js → static-files-hono.service.js} +2 -2
- package/dist/static-files-hono.service.js.map +1 -0
- package/dist/subject-application-resolver.vo.d.ts +23 -0
- package/dist/subject-application-resolver.vo.d.ts.map +1 -0
- package/dist/{cache-subject-application-resolver.vo.js → subject-application-resolver.vo.js} +7 -7
- package/dist/subject-application-resolver.vo.js.map +1 -0
- package/dist/{cache-subject-request-resolver.vo.d.ts → subject-request-resolver.vo.d.ts} +6 -6
- package/dist/subject-request-resolver.vo.d.ts.map +1 -0
- package/dist/{cache-subject-request-resolver.vo.js → subject-request-resolver.vo.js} +7 -7
- package/dist/subject-request-resolver.vo.js.map +1 -0
- package/dist/subject-segment-application.strategy.d.ts +6 -0
- package/dist/subject-segment-application.strategy.d.ts.map +1 -0
- package/dist/subject-segment-application.strategy.js +2 -0
- package/dist/subject-segment-application.strategy.js.map +1 -0
- package/dist/subject-segment-build.strategy.d.ts +9 -0
- package/dist/subject-segment-build.strategy.d.ts.map +1 -0
- package/dist/subject-segment-build.strategy.js +13 -0
- package/dist/subject-segment-build.strategy.js.map +1 -0
- package/dist/subject-segment-cookie.strategy.d.ts +9 -0
- package/dist/subject-segment-cookie.strategy.d.ts.map +1 -0
- package/dist/subject-segment-cookie.strategy.js +11 -0
- package/dist/subject-segment-cookie.strategy.js.map +1 -0
- package/dist/subject-segment-env.strategy.d.ts +9 -0
- package/dist/subject-segment-env.strategy.d.ts.map +1 -0
- package/dist/{cache-subject-segment-env.strategy.js → subject-segment-env.strategy.js} +2 -2
- package/dist/subject-segment-env.strategy.js.map +1 -0
- package/dist/subject-segment-fixed.strategy.d.ts +8 -0
- package/dist/subject-segment-fixed.strategy.d.ts.map +1 -0
- package/dist/{cache-subject-segment-fixed.strategy.js → subject-segment-fixed.strategy.js} +2 -2
- package/dist/subject-segment-fixed.strategy.js.map +1 -0
- package/dist/subject-segment-header.strategy.d.ts +9 -0
- package/dist/subject-segment-header.strategy.d.ts.map +1 -0
- package/dist/subject-segment-header.strategy.js +11 -0
- package/dist/subject-segment-header.strategy.js.map +1 -0
- package/dist/subject-segment-ip.strategy.d.ts +6 -0
- package/dist/subject-segment-ip.strategy.d.ts.map +1 -0
- package/dist/subject-segment-ip.strategy.js +7 -0
- package/dist/subject-segment-ip.strategy.js.map +1 -0
- package/dist/subject-segment-path.strategy.d.ts +6 -0
- package/dist/subject-segment-path.strategy.d.ts.map +1 -0
- package/dist/subject-segment-path.strategy.js +6 -0
- package/dist/subject-segment-path.strategy.js.map +1 -0
- package/dist/subject-segment-query.strategy.d.ts +7 -0
- package/dist/subject-segment-query.strategy.d.ts.map +1 -0
- package/dist/subject-segment-query.strategy.js +12 -0
- package/dist/subject-segment-query.strategy.js.map +1 -0
- package/dist/subject-segment-request.strategy.d.ts +9 -0
- package/dist/subject-segment-request.strategy.d.ts.map +1 -0
- package/dist/subject-segment-request.strategy.js +2 -0
- package/dist/subject-segment-request.strategy.js.map +1 -0
- package/dist/subject-segment-user.strategy.d.ts +6 -0
- package/dist/subject-segment-user.strategy.d.ts.map +1 -0
- package/dist/subject-segment-user.strategy.js +7 -0
- package/dist/subject-segment-user.strategy.js.map +1 -0
- package/dist/time-zone-offset-hono.middleware.d.ts +12 -0
- package/dist/time-zone-offset-hono.middleware.d.ts.map +1 -0
- package/dist/time-zone-offset-hono.middleware.js +17 -0
- package/dist/time-zone-offset-hono.middleware.js.map +1 -0
- package/dist/time-zone-offset.middleware.d.ts +3 -6
- package/dist/time-zone-offset.middleware.d.ts.map +1 -1
- package/dist/time-zone-offset.middleware.js +5 -13
- package/dist/time-zone-offset.middleware.js.map +1 -1
- package/dist/timing-hono.middleware.d.ts +12 -0
- package/dist/timing-hono.middleware.d.ts.map +1 -0
- package/dist/timing-hono.middleware.js +15 -0
- package/dist/timing-hono.middleware.js.map +1 -0
- package/dist/timing.middleware.d.ts +12 -0
- package/dist/timing.middleware.d.ts.map +1 -0
- package/dist/timing.middleware.js +14 -0
- package/dist/timing.middleware.js.map +1 -0
- package/dist/trailing-slash-hono.middleware.d.ts +7 -0
- package/dist/trailing-slash-hono.middleware.d.ts.map +1 -0
- package/dist/trailing-slash-hono.middleware.js +21 -0
- package/dist/trailing-slash-hono.middleware.js.map +1 -0
- package/dist/trailing-slash.middleware.d.ts +11 -0
- package/dist/trailing-slash.middleware.d.ts.map +1 -0
- package/dist/trailing-slash.middleware.js +10 -0
- package/dist/trailing-slash.middleware.js.map +1 -0
- package/dist/translations-hono.handler.d.ts +23 -0
- package/dist/translations-hono.handler.d.ts.map +1 -0
- package/dist/translations-hono.handler.js +17 -0
- package/dist/translations-hono.handler.js.map +1 -0
- package/dist/translations.handler.d.ts +22 -0
- package/dist/translations.handler.d.ts.map +1 -0
- package/dist/translations.handler.js +18 -0
- package/dist/translations.handler.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/weak-etag-extractor-hono.middleware.d.ts +12 -0
- package/dist/weak-etag-extractor-hono.middleware.d.ts.map +1 -0
- package/dist/weak-etag-extractor-hono.middleware.js +17 -0
- package/dist/weak-etag-extractor-hono.middleware.js.map +1 -0
- package/dist/weak-etag-extractor.middleware.d.ts +4 -5
- package/dist/weak-etag-extractor.middleware.d.ts.map +1 -1
- package/dist/weak-etag-extractor.middleware.js +5 -9
- package/dist/weak-etag-extractor.middleware.js.map +1 -1
- package/dist/woodchopper-dispatcher-async.strategy.d.ts.map +1 -1
- package/dist/woodchopper-dispatcher-async.strategy.js +2 -0
- package/dist/woodchopper-dispatcher-async.strategy.js.map +1 -1
- package/dist/woodchopper-sampling-correlation-id.strategy.d.ts +2 -2
- package/dist/woodchopper-sampling-correlation-id.strategy.d.ts.map +1 -1
- package/dist/woodchopper-sampling-correlation-id.strategy.js.map +1 -1
- package/dist/woodchopper-sampling-every-nth.strategy.d.ts +3 -2
- package/dist/woodchopper-sampling-every-nth.strategy.d.ts.map +1 -1
- package/dist/woodchopper-sampling-every-nth.strategy.js.map +1 -1
- package/dist/woodchopper.d.ts +2 -2
- package/dist/woodchopper.d.ts.map +1 -1
- package/dist/woodchopper.js.map +1 -1
- package/package.json +10 -9
- package/readme.md +79 -28
- package/src/ab-assignment-composite.strategy.ts +17 -0
- package/src/ab-assignment-fixed.strategy.ts +12 -0
- package/src/ab-assignment-hash.strategy.ts +23 -0
- package/src/ab-assignment-query.strategy.ts +14 -0
- package/src/ab-assignment.strategy.ts +7 -0
- package/src/ab-hono-noop.middleware.ts +26 -0
- package/src/ab-hono.middleware.ts +28 -0
- package/src/ab-variant-selector.service.ts +27 -0
- package/src/ab-variant-weight.vo.ts +13 -0
- package/src/ab-variant.vo.ts +7 -0
- package/src/ab-variants.vo.ts +24 -0
- package/src/ab.middleware.ts +15 -0
- package/src/api-version-hono.middleware.ts +30 -0
- package/src/api-version.middleware.ts +18 -17
- package/src/auth-session-reader.port.ts +3 -3
- package/src/basic-auth.service.ts +3 -3
- package/src/cache-response-hono.middleware.ts +53 -0
- package/src/cache-response.middleware.ts +27 -33
- package/src/command-bus-collecting.adapter.ts +15 -0
- package/src/command-bus-emittery-v1.adapter.ts +22 -0
- package/src/command-bus-noop.adapter.ts +11 -0
- package/src/command-bus-with-logger.adapter.ts +31 -0
- package/src/command-bus.port.ts +10 -0
- package/src/correlation-hono.middleware.ts +32 -0
- package/src/correlation-id.middleware.ts +20 -0
- package/src/correlation-storage.service.ts +0 -3
- package/src/crypto-key-provider-with-cache.adapter.ts +8 -6
- package/src/dispatching-event-store.ts +2 -2
- package/src/environment-loader-process-safe.adapter.ts +3 -6
- package/src/etag-extractor-hono.middleware.ts +27 -0
- package/src/etag-extractor.middleware.ts +6 -12
- package/src/event-bus-collecting.adapter.ts +15 -0
- package/src/event-bus-emittery-v1.adapter.ts +22 -0
- package/src/event-bus-noop.adapter.ts +11 -0
- package/src/event-bus-with-logger.adapter.ts +31 -0
- package/src/event-bus.port.ts +10 -0
- package/src/event-store.ts +2 -2
- package/src/file-inspection-noop.adapter.ts +2 -2
- package/src/file-reader-json-with-cache.adapter.ts +8 -7
- package/src/file-reader-raw-with-cache.adapter.ts +8 -7
- package/src/file-reader-text-with-cache.adapter.ts +8 -7
- package/src/file-uploader-hono.middleware.ts +47 -0
- package/src/file-uploader.middleware.ts +21 -25
- package/src/handler-hono.port.ts +5 -0
- package/src/hash-bucket.vo.ts +19 -0
- package/src/healthcheck-hono.handler.ts +31 -0
- package/src/healthcheck.handler.ts +150 -0
- package/src/http-logger-hono.middleware.ts +50 -0
- package/src/http-logger.middleware.ts +56 -63
- package/src/i18n.service.ts +1 -1
- package/src/image-info-noop.adapter.ts +1 -1
- package/src/image-info-sharp.adapter.ts +3 -3
- package/src/image-info.port.ts +1 -1
- package/src/in-flight-requests-hono.middleware.ts +19 -0
- package/src/in-flight-requests-tracker.service.ts +0 -2
- package/src/in-flight-requests.middleware.ts +7 -11
- package/src/index.ts +80 -28
- package/src/invariant-error-handler.service.ts +2 -3
- package/src/invariant.service.ts +2 -2
- package/src/mailer-resend.adapter.ts +2 -2
- package/src/mailer-smtp.adapter.ts +2 -2
- package/src/middleware-hono-noop.adapter.ts +8 -0
- package/src/middleware-hono.port.ts +5 -0
- package/src/modules/preferences/invariants/user-language-has-changed.ts +4 -7
- package/src/ping-hono.handler.ts +17 -0
- package/src/ping.handler.ts +5 -0
- package/src/prerequisite-verifier-binary.adapter.ts +3 -1
- package/src/prerequisite-verifier-bun.adapter.ts +3 -1
- package/src/prerequisite-verifier-clock-drift.adapter.ts +2 -1
- package/src/prerequisite-verifier-directory.adapter.ts +6 -4
- package/src/prerequisite-verifier-dns.adapter.ts +3 -1
- package/src/prerequisite-verifier-external-api.adapter.ts +3 -1
- package/src/prerequisite-verifier-file.adapter.ts +6 -4
- package/src/prerequisite-verifier-jobs.adapter.ts +3 -1
- package/src/prerequisite-verifier-memory.adapter.ts +3 -1
- package/src/prerequisite-verifier-node.adapter.ts +3 -1
- package/src/prerequisite-verifier-os.adapter.ts +3 -1
- package/src/prerequisite-verifier-port.adapter.ts +3 -1
- package/src/prerequisite-verifier-ram.adapter.ts +3 -1
- package/src/prerequisite-verifier-running-user.adapter.ts +3 -1
- package/src/prerequisite-verifier-space.adapter.ts +2 -1
- package/src/prerequisite-verifier-sqlite.adapter.ts +3 -1
- package/src/prerequisite-verifier-ssl-certificate-expiry.adapter.ts +3 -1
- package/src/prerequisite-verifier-timezone-utc.adapter.ts +3 -1
- package/src/prerequisite-verifier-translations.adapter.ts +1 -2
- package/src/prerequisite-verifier-with-cache.adapter.ts +8 -7
- package/src/prerequisite-verifier-with-fail-safe.adapter.ts +4 -4
- package/src/prerequisite-verifier-with-logger.adapter.ts +3 -1
- package/src/prerequisite-verifier-with-retry.adapter.ts +3 -2
- package/src/prerequisite-verifier-with-timeout.adapter.ts +2 -1
- package/src/prerequisite-verifier.decorator.ts +4 -4
- package/src/prerequisite.vo.ts +2 -5
- package/src/remote-file-storage-disk.adapter.ts +3 -3
- package/src/request-context-hono.adapter.ts +12 -1
- package/src/request-context.port.ts +15 -0
- package/src/retry.service.ts +4 -4
- package/src/security-countermeasure-ban.strategy.ts +6 -4
- package/src/security-countermeasure-mirage.strategy.ts +2 -1
- package/src/security-countermeasure-tarpit.strategy.ts +2 -1
- package/src/security-rule-violation-threshold.strategy.ts +7 -6
- package/src/{setup.service.ts → setup-hono.service.ts} +36 -43
- package/src/shield-api-key-hono.strategy.ts +28 -0
- package/src/shield-api-key.strategy.ts +9 -15
- package/src/shield-auth-hono.strategy.ts +41 -0
- package/src/shield-auth.strategy.ts +12 -26
- package/src/shield-basic-auth-hono.strategy.ts +30 -0
- package/src/shield-basic-auth.strategy.ts +21 -10
- package/src/shield-body-limit-hono.strategy.ts +30 -0
- package/src/shield-body-limit.strategy.ts +23 -0
- package/src/shield-csrf-hono.strategy.ts +24 -0
- package/src/shield-csrf.strategy.ts +11 -16
- package/src/shield-hcaptcha-hono-local.strategy.ts +26 -0
- package/src/shield-hcaptcha-hono.strategy.ts +25 -0
- package/src/shield-hcaptcha.strategy.ts +7 -13
- package/src/shield-maintenance-hono.strategy.ts +23 -0
- package/src/shield-maintenance.strategy.ts +17 -0
- package/src/shield-rate-limit-hono.strategy.ts +34 -0
- package/src/shield-rate-limit.strategy.ts +11 -19
- package/src/shield-recaptcha-hono.strategy.ts +31 -0
- package/src/shield-recaptcha.strategy.ts +14 -20
- package/src/shield-security-hono.strategy.ts +62 -0
- package/src/shield-security.strategy.ts +19 -62
- package/src/shield-timeout-hono.strategy.ts +25 -0
- package/src/shield-timeout.strategy.ts +4 -14
- package/src/simulated-error-hono.middleware.ts +17 -0
- package/src/simulated-error.middleware.ts +4 -7
- package/src/slower-hono.middleware.ts +23 -0
- package/src/slower.middleware.ts +8 -7
- package/src/ssr-bun.service.ts +25 -0
- package/src/ssr.service.ts +66 -0
- package/src/{static-files.service.ts → static-files-hono.service.ts} +1 -1
- package/src/subject-application-resolver.vo.ts +34 -0
- package/src/subject-request-resolver.vo.ts +34 -0
- package/src/subject-segment-application.strategy.ts +7 -0
- package/src/subject-segment-build.strategy.ts +15 -0
- package/src/subject-segment-cookie.strategy.ts +14 -0
- package/src/subject-segment-env.strategy.ts +11 -0
- package/src/subject-segment-fixed.strategy.ts +12 -0
- package/src/subject-segment-header.strategy.ts +14 -0
- package/src/subject-segment-ip.strategy.ts +12 -0
- package/src/subject-segment-path.strategy.ts +8 -0
- package/src/subject-segment-query.strategy.ts +19 -0
- package/src/{cache-subject-segment-request.strategy.ts → subject-segment-request.strategy.ts} +4 -4
- package/src/subject-segment-user.strategy.ts +12 -0
- package/src/time-zone-offset-hono.middleware.ts +26 -0
- package/src/time-zone-offset.middleware.ts +6 -18
- package/src/timing-hono.middleware.ts +22 -0
- package/src/timing.middleware.ts +18 -0
- package/src/trailing-slash-hono.middleware.ts +27 -0
- package/src/trailing-slash.middleware.ts +11 -0
- package/src/translations-hono.handler.ts +26 -0
- package/src/translations.handler.ts +31 -0
- package/src/weak-etag-extractor-hono.middleware.ts +26 -0
- package/src/weak-etag-extractor.middleware.ts +6 -11
- package/src/woodchopper-dispatcher-async.strategy.ts +2 -0
- package/src/woodchopper-sampling-correlation-id.strategy.ts +2 -2
- package/src/woodchopper-sampling-every-nth.strategy.ts +2 -2
- package/src/woodchopper.ts +2 -2
- package/dist/cache-subject-application-resolver.vo.d.ts +0 -23
- package/dist/cache-subject-application-resolver.vo.d.ts.map +0 -1
- package/dist/cache-subject-application-resolver.vo.js.map +0 -1
- package/dist/cache-subject-request-resolver.vo.d.ts.map +0 -1
- package/dist/cache-subject-request-resolver.vo.js.map +0 -1
- package/dist/cache-subject-segment-application.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-application.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-application.strategy.js +0 -2
- package/dist/cache-subject-segment-application.strategy.js.map +0 -1
- package/dist/cache-subject-segment-build.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-build.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-build.strategy.js +0 -13
- package/dist/cache-subject-segment-build.strategy.js.map +0 -1
- package/dist/cache-subject-segment-cookie.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-cookie.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-cookie.strategy.js +0 -11
- package/dist/cache-subject-segment-cookie.strategy.js.map +0 -1
- package/dist/cache-subject-segment-env.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-env.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-env.strategy.js.map +0 -1
- package/dist/cache-subject-segment-fixed.strategy.d.ts +0 -8
- package/dist/cache-subject-segment-fixed.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-fixed.strategy.js.map +0 -1
- package/dist/cache-subject-segment-header.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-header.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-header.strategy.js +0 -11
- package/dist/cache-subject-segment-header.strategy.js.map +0 -1
- package/dist/cache-subject-segment-ip.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-ip.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-ip.strategy.js +0 -7
- package/dist/cache-subject-segment-ip.strategy.js.map +0 -1
- package/dist/cache-subject-segment-path.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-path.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-path.strategy.js +0 -6
- package/dist/cache-subject-segment-path.strategy.js.map +0 -1
- package/dist/cache-subject-segment-query.strategy.d.ts +0 -7
- package/dist/cache-subject-segment-query.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-query.strategy.js +0 -12
- package/dist/cache-subject-segment-query.strategy.js.map +0 -1
- package/dist/cache-subject-segment-request.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-request.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-request.strategy.js +0 -2
- package/dist/cache-subject-segment-request.strategy.js.map +0 -1
- package/dist/cache-subject-segment-user.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-user.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-user.strategy.js +0 -7
- package/dist/cache-subject-segment-user.strategy.js.map +0 -1
- package/dist/command-logger.service.d.ts +0 -13
- package/dist/command-logger.service.d.ts.map +0 -1
- package/dist/command-logger.service.js +0 -16
- package/dist/command-logger.service.js.map +0 -1
- package/dist/context.middleware.d.ts +0 -14
- package/dist/context.middleware.d.ts.map +0 -1
- package/dist/context.middleware.js +0 -11
- package/dist/context.middleware.js.map +0 -1
- package/dist/event-bus-like.types.d.ts +0 -12
- package/dist/event-bus-like.types.d.ts.map +0 -1
- package/dist/event-bus-like.types.js +0 -2
- package/dist/event-bus-like.types.js.map +0 -1
- package/dist/event-logger.service.d.ts +0 -13
- package/dist/event-logger.service.d.ts.map +0 -1
- package/dist/event-logger.service.js +0 -16
- package/dist/event-logger.service.js.map +0 -1
- package/dist/event-publisher.types.d.ts +0 -4
- package/dist/event-publisher.types.d.ts.map +0 -1
- package/dist/event-publisher.types.js +0 -2
- package/dist/event-publisher.types.js.map +0 -1
- package/dist/healthcheck.service.d.ts +0 -96
- package/dist/healthcheck.service.d.ts.map +0 -1
- package/dist/healthcheck.service.js.map +0 -1
- package/dist/maintenance-mode.middleware.d.ts +0 -11
- package/dist/maintenance-mode.middleware.d.ts.map +0 -1
- package/dist/maintenance-mode.middleware.js +0 -12
- package/dist/maintenance-mode.middleware.js.map +0 -1
- package/dist/ping.service.d.ts +0 -4
- package/dist/ping.service.d.ts.map +0 -1
- package/dist/ping.service.js +0 -6
- package/dist/ping.service.js.map +0 -1
- package/dist/setup.service.d.ts +0 -35
- package/dist/setup.service.d.ts.map +0 -1
- package/dist/setup.service.js.map +0 -1
- package/dist/shield-hcaptcha-local.strategy.d.ts +0 -11
- package/dist/shield-hcaptcha-local.strategy.d.ts.map +0 -1
- package/dist/shield-hcaptcha-local.strategy.js +0 -23
- package/dist/shield-hcaptcha-local.strategy.js.map +0 -1
- package/dist/shield-noop.strategy.d.ts +0 -5
- package/dist/shield-noop.strategy.d.ts.map +0 -1
- package/dist/shield-noop.strategy.js +0 -5
- package/dist/shield-noop.strategy.js.map +0 -1
- package/dist/shield.strategy.d.ts +0 -5
- package/dist/shield.strategy.d.ts.map +0 -1
- package/dist/shield.strategy.js +0 -2
- package/dist/shield.strategy.js.map +0 -1
- package/dist/ssr.d.ts.map +0 -1
- package/dist/ssr.js +0 -43
- package/dist/ssr.js.map +0 -1
- package/dist/static-files.service.d.ts.map +0 -1
- package/dist/static-files.service.js.map +0 -1
- package/dist/translations.service.d.ts +0 -21
- package/dist/translations.service.d.ts.map +0 -1
- package/dist/translations.service.js +0 -11
- package/dist/translations.service.js.map +0 -1
- package/src/cache-subject-application-resolver.vo.ts +0 -34
- package/src/cache-subject-request-resolver.vo.ts +0 -39
- package/src/cache-subject-segment-application.strategy.ts +0 -7
- package/src/cache-subject-segment-build.strategy.ts +0 -15
- package/src/cache-subject-segment-cookie.strategy.ts +0 -14
- package/src/cache-subject-segment-env.strategy.ts +0 -11
- package/src/cache-subject-segment-fixed.strategy.ts +0 -15
- package/src/cache-subject-segment-header.strategy.ts +0 -14
- package/src/cache-subject-segment-ip.strategy.ts +0 -12
- package/src/cache-subject-segment-path.strategy.ts +0 -11
- package/src/cache-subject-segment-query.strategy.ts +0 -19
- package/src/cache-subject-segment-user.strategy.ts +0 -12
- package/src/command-logger.service.ts +0 -23
- package/src/context.middleware.ts +0 -24
- package/src/event-bus-like.types.ts +0 -10
- package/src/event-logger.service.ts +0 -23
- package/src/event-publisher.types.ts +0 -3
- package/src/healthcheck.service.ts +0 -154
- package/src/maintenance-mode.middleware.ts +0 -15
- package/src/ping.service.ts +0 -7
- package/src/shield-hcaptcha-local.strategy.ts +0 -24
- package/src/shield-noop.strategy.ts +0 -6
- package/src/shield.strategy.ts +0 -5
- package/src/ssr.ts +0 -57
- package/src/translations.service.ts +0 -20
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"security-rule-violation-threshold.strategy.js","sourceRoot":"","sources":["../src/security-rule-violation-threshold.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"security-rule-violation-threshold.strategy.js","sourceRoot":"","sources":["../src/security-rule-violation-threshold.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAKtC,OAAO,EAAE,gBAAgB,EAA6B,MAAM,yBAAyB,CAAC;AACtF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AACvE,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAKzE,MAAM,OAAO,sCAAsC;IAE9B;IACA;IACA;IAHnB,YACmB,IAA0B,EAC1B,MAAc,EACd,IAAkB;QAFlB,SAAI,GAAJ,IAAI,CAAsB;QAC1B,WAAM,GAAN,MAAM,CAAQ;QACd,SAAI,GAAJ,IAAI,CAAc;IAClC,CAAC;IAEJ,4FAA4F;IAC5F,KAAK,CAAC,UAAU,CAAC,OAAuB;QACtC,MAAM,QAAQ,GAAG,IAAI,sBAAsB,CACzC,CAAC,IAAI,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,wBAAwB,EAAE,CAAC,EAC5E,IAAI,CAAC,IAAI,CACV,CAAC;QACF,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAEhD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAErD,IAAI,CAAC,QAAQ;YAAE,OAAO,KAAK,CAAC;QAE5B,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAA+B,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YAEpG,MAAM,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CACjC,OAAO,CAAC,GAAG,EACX,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAC1C,CAAC;YAEF,IAAI,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS;gBAAE,OAAO,IAAI,CAAC;YACpD,OAAO,KAAK,CAAC;QACf,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,uBAAuB,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAClG,CAAC;CACF"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { cors } from "hono/cors";
|
|
2
|
+
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
3
|
+
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
4
|
+
import type { ClockPort } from "./clock.port";
|
|
5
|
+
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
6
|
+
import type { HttpLoggerConfig } from "./http-logger.middleware";
|
|
7
|
+
import type { I18nConfig } from "./i18n.service";
|
|
8
|
+
import type { IdProviderPort } from "./id-provider.port";
|
|
9
|
+
import type { LoggerPort } from "./logger.port";
|
|
10
|
+
import type { ShieldCsrfConfig } from "./shield-csrf.strategy";
|
|
11
|
+
import type { ShieldMaintenanceConfig } from "./shield-maintenance.strategy";
|
|
12
|
+
type Dependencies = {
|
|
13
|
+
Logger: LoggerPort;
|
|
14
|
+
IdProvider: IdProviderPort;
|
|
15
|
+
I18n: I18nConfig;
|
|
16
|
+
Clock: ClockPort;
|
|
17
|
+
CacheResolver: CacheResolverStrategy;
|
|
18
|
+
HashContent: HashContentStrategy;
|
|
19
|
+
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
20
|
+
};
|
|
21
|
+
type Config = {
|
|
22
|
+
csrf: ShieldCsrfConfig;
|
|
23
|
+
cors?: Parameters<typeof cors>[0];
|
|
24
|
+
httpLogger?: HttpLoggerConfig;
|
|
25
|
+
maintenanceMode?: ShieldMaintenanceConfig;
|
|
26
|
+
};
|
|
27
|
+
export declare class SetupHono {
|
|
28
|
+
static essentials(config: Config, deps: Dependencies): import("hono").MiddlewareHandler[];
|
|
29
|
+
}
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=setup-hono.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup-hono.service.d.ts","sourceRoot":"","sources":["../src/setup-hono.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAIjC,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AACpF,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AACvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAG9C,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,+BAA+B,CAAC;AAO7E,KAAK,YAAY,GAAG;IAClB,MAAM,EAAE,UAAU,CAAC;IACnB,UAAU,EAAE,cAAc,CAAC;IAC3B,IAAI,EAAE,UAAU,CAAC;IACjB,KAAK,EAAE,SAAS,CAAC;IACjB,aAAa,EAAE,qBAAqB,CAAC;IACrC,WAAW,EAAE,mBAAmB,CAAC;IACjC,mBAAmB,EAAE,2BAA2B,CAAC;CAClD,CAAC;AAEF,KAAK,MAAM,GAAG;IACZ,IAAI,EAAE,gBAAgB,CAAC;IACvB,IAAI,CAAC,EAAE,UAAU,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAClC,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,eAAe,CAAC,EAAE,uBAAuB,CAAC;CAC3C,CAAC;AAEF,qBAAa,SAAS;IAIpB,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY;CAkDrD"}
|
|
@@ -1,33 +1,28 @@
|
|
|
1
1
|
import * as tools from "@bgord/tools";
|
|
2
|
-
import { bodyLimit } from "hono/body-limit";
|
|
3
2
|
import { cors } from "hono/cors";
|
|
4
3
|
import { languageDetector } from "hono/language";
|
|
5
|
-
import { requestId } from "hono/request-id";
|
|
6
4
|
import { secureHeaders } from "hono/secure-headers";
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
14
|
-
import {
|
|
15
|
-
import {
|
|
16
|
-
import {
|
|
17
|
-
|
|
18
|
-
|
|
5
|
+
import { ApiVersionHonoMiddleware } from "./api-version-hono.middleware";
|
|
6
|
+
import { CorrelationHonoMiddleware } from "./correlation-hono.middleware";
|
|
7
|
+
import { ETagExtractorHonoMiddleware } from "./etag-extractor-hono.middleware";
|
|
8
|
+
import { HttpLoggerHonoMiddleware } from "./http-logger-hono.middleware";
|
|
9
|
+
import { ShieldCsrfHonoStrategy } from "./shield-csrf-hono.strategy";
|
|
10
|
+
import { ShieldMaintenanceHonoStrategy } from "./shield-maintenance-hono.strategy";
|
|
11
|
+
import { TimeZoneOffsetHonoMiddleware } from "./time-zone-offset-hono.middleware";
|
|
12
|
+
import { TimingHonoMiddleware } from "./timing-hono.middleware";
|
|
13
|
+
import { TrailingSlashHonoMiddleware } from "./trailing-slash-hono.middleware";
|
|
14
|
+
import { WeakETagExtractorHonoMiddleware } from "./weak-etag-extractor-hono.middleware";
|
|
15
|
+
export class SetupHono {
|
|
16
|
+
// Configure body size limit at the framework level
|
|
17
|
+
// - Bun: maxRequestBodySize in Bun.serve()
|
|
18
|
+
// - Express: limit in express.json()
|
|
19
19
|
static essentials(config, deps) {
|
|
20
|
-
const BODY_LIMIT_MAX_SIZE = config.BODY_LIMIT_MAX_SIZE ?? tools.Size.fromKb(128);
|
|
21
20
|
return [
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
generator: () => deps.IdProvider.generate(),
|
|
28
|
-
}),
|
|
29
|
-
ApiVersion.build(deps),
|
|
30
|
-
new ShieldCsrfStrategy(config.csrf).verify,
|
|
21
|
+
new ShieldMaintenanceHonoStrategy(config.maintenanceMode).handle(),
|
|
22
|
+
new TrailingSlashHonoMiddleware().handle(),
|
|
23
|
+
new CorrelationHonoMiddleware(deps).handle(),
|
|
24
|
+
new ApiVersionHonoMiddleware(deps).handle(),
|
|
25
|
+
new ShieldCsrfHonoStrategy(config.csrf).handle(),
|
|
31
26
|
secureHeaders({
|
|
32
27
|
referrerPolicy: "no-referrer",
|
|
33
28
|
xContentTypeOptions: "nosniff",
|
|
@@ -40,7 +35,6 @@ export class Setup {
|
|
|
40
35
|
originAgentCluster: false,
|
|
41
36
|
xFrameOptions: false,
|
|
42
37
|
}),
|
|
43
|
-
bodyLimit({ maxSize: BODY_LIMIT_MAX_SIZE.toBytes() }),
|
|
44
38
|
cors({
|
|
45
39
|
// Stryker disable all
|
|
46
40
|
origin: (origin, c) => {
|
|
@@ -65,14 +59,12 @@ export class Setup {
|
|
|
65
59
|
caches: false,
|
|
66
60
|
// Stryker restore all
|
|
67
61
|
}),
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
timing(),
|
|
74
|
-
CorrelationStorage.handle(),
|
|
62
|
+
new TimeZoneOffsetHonoMiddleware().handle(),
|
|
63
|
+
new WeakETagExtractorHonoMiddleware().handle(),
|
|
64
|
+
new ETagExtractorHonoMiddleware().handle(),
|
|
65
|
+
new HttpLoggerHonoMiddleware(deps, config.httpLogger).handle(),
|
|
66
|
+
new TimingHonoMiddleware(deps).handle(),
|
|
75
67
|
];
|
|
76
68
|
}
|
|
77
69
|
}
|
|
78
|
-
//# sourceMappingURL=setup.service.js.map
|
|
70
|
+
//# sourceMappingURL=setup-hono.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup-hono.service.js","sourceRoot":"","sources":["../src/setup-hono.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAIzE,OAAO,EAAE,yBAAyB,EAAE,MAAM,+BAA+B,CAAC;AAC1E,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAG/E,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAKzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAErE,OAAO,EAAE,6BAA6B,EAAE,MAAM,oCAAoC,CAAC;AACnF,OAAO,EAAE,4BAA4B,EAAE,MAAM,oCAAoC,CAAC;AAClF,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAC/E,OAAO,EAAE,+BAA+B,EAAE,MAAM,uCAAuC,CAAC;AAmBxF,MAAM,OAAO,SAAS;IACpB,mDAAmD;IACnD,2CAA2C;IAC3C,qCAAqC;IACrC,MAAM,CAAC,UAAU,CAAC,MAAc,EAAE,IAAkB;QAClD,OAAO;YACL,IAAI,6BAA6B,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,MAAM,EAAE;YAClE,IAAI,2BAA2B,EAAE,CAAC,MAAM,EAAE;YAC1C,IAAI,yBAAyB,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE;YAC5C,IAAI,wBAAwB,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE;YAC3C,IAAI,sBAAsB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE;YAChD,aAAa,CAAC;gBACZ,cAAc,EAAE,aAAa;gBAC7B,mBAAmB,EAAE,SAAS;gBAC9B,mBAAmB,EAAE,KAAK;gBAC1B,gBAAgB,EAAE,IAAI;gBACtB,6BAA6B,EAAE,KAAK;gBACpC,yBAAyB,EAAE,KAAK;gBAChC,uBAAuB,EAAE,KAAK;gBAC9B,yBAAyB,EAAE,KAAK;gBAChC,kBAAkB,EAAE,KAAK;gBACzB,aAAa,EAAE,KAAK;aACrB,CAAC;YACF,IAAI,CAAC;gBACH,sBAAsB;gBACtB,MAAM,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACpB,iDAAiD;oBACjD,IAAI,CAAC,MAAM;wBAAE,OAAO,SAAS,CAAC;oBAE9B,oBAAoB;oBACpB,IAAI,MAAM,KAAK,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM;wBAAE,OAAO,MAAM,CAAC;oBAExD,oBAAoB;oBACpB,OAAO,IAAI,CAAC;gBACd,CAAC;gBACD,sBAAsB;gBACtB,WAAW,EAAE,KAAK;gBAClB,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,OAAO;gBAC1C,GAAG,MAAM,CAAC,IAAI;aACf,CAAC;YACF,gBAAgB,CAAC;gBACf,kBAAkB,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC;gBAC7D,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe;gBAC3C,sBAAsB;gBACtB,MAAM,EAAE,KAAK;gBACb,sBAAsB;aACvB,CAAC;YACF,IAAI,4BAA4B,EAAE,CAAC,MAAM,EAAE;YAC3C,IAAI,+BAA+B,EAAE,CAAC,MAAM,EAAE;YAC9C,IAAI,2BAA2B,EAAE,CAAC,MAAM,EAAE;YAC1C,IAAI,wBAAwB,CAAC,IAAI,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE;YAC9D,IAAI,oBAAoB,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE;SACxC,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { type ApiKeyShieldConfig } from "./shield-api-key.strategy";
|
|
5
|
+
export declare const ShieldApiKeyError: HTTPException;
|
|
6
|
+
export declare class ShieldApiKeyHonoStrategy implements MiddlewareHonoPort {
|
|
7
|
+
private readonly strategy;
|
|
8
|
+
constructor(config: ApiKeyShieldConfig);
|
|
9
|
+
handle(): MiddlewareHandler;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=shield-api-key-hono.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-api-key-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-api-key-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EACL,KAAK,kBAAkB,EAGxB,MAAM,2BAA2B,CAAC;AAEnC,eAAO,MAAM,iBAAiB,eAA0E,CAAC;AAEzG,qBAAa,wBAAyB,YAAW,kBAAkB;IACjE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAuB;gBAEpC,MAAM,EAAE,kBAAkB;IAItC,MAAM,IAAI,iBAAiB;CAQ5B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { HTTPException } from "hono/http-exception";
|
|
2
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
3
|
+
import { ShieldApiKeyStrategy, ShieldApiKeyStrategyError, } from "./shield-api-key.strategy";
|
|
4
|
+
export const ShieldApiKeyError = new HTTPException(403, { message: ShieldApiKeyStrategyError.Rejected });
|
|
5
|
+
export class ShieldApiKeyHonoStrategy {
|
|
6
|
+
strategy;
|
|
7
|
+
constructor(config) {
|
|
8
|
+
this.strategy = new ShieldApiKeyStrategy(config);
|
|
9
|
+
}
|
|
10
|
+
handle() {
|
|
11
|
+
return async (c, next) => {
|
|
12
|
+
const context = new RequestContextHonoAdapter(c);
|
|
13
|
+
if (this.strategy.evaluate(context))
|
|
14
|
+
return next();
|
|
15
|
+
throw ShieldApiKeyError;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=shield-api-key-hono.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-api-key-hono.strategy.js","sourceRoot":"","sources":["../src/shield-api-key-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAEL,oBAAoB,EACpB,yBAAyB,GAC1B,MAAM,2BAA2B,CAAC;AAEnC,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,yBAAyB,CAAC,QAAQ,EAAE,CAAC,CAAC;AAEzG,MAAM,OAAO,wBAAwB;IAClB,QAAQ,CAAuB;IAEhD,YAAY,MAA0B;QACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAoB,CAAC,MAAM,CAAC,CAAC;IACnD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACnD,MAAM,iBAAiB,CAAC;QAC1B,CAAC,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
type ApiKeyShieldConfigType = {
|
|
2
|
+
import type { HasRequestHeader } from "./request-context.port";
|
|
3
|
+
export type ApiKeyShieldConfig = {
|
|
5
4
|
API_KEY: tools.ApiKeyType;
|
|
6
5
|
};
|
|
7
|
-
export declare const
|
|
8
|
-
|
|
6
|
+
export declare const ShieldApiKeyStrategyError: {
|
|
7
|
+
Rejected: string;
|
|
8
|
+
};
|
|
9
|
+
export declare class ShieldApiKeyStrategy {
|
|
9
10
|
private readonly config;
|
|
10
|
-
static readonly HEADER_NAME = "
|
|
11
|
-
constructor(config:
|
|
12
|
-
|
|
11
|
+
static readonly HEADER_NAME = "api-key";
|
|
12
|
+
constructor(config: ApiKeyShieldConfig);
|
|
13
|
+
evaluate(context: HasRequestHeader): boolean;
|
|
13
14
|
}
|
|
14
|
-
export {};
|
|
15
15
|
//# sourceMappingURL=shield-api-key.strategy.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shield-api-key.strategy.d.ts","sourceRoot":"","sources":["../src/shield-api-key.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"shield-api-key.strategy.d.ts","sourceRoot":"","sources":["../src/shield-api-key.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,MAAM,MAAM,kBAAkB,GAAG;IAAE,OAAO,EAAE,KAAK,CAAC,UAAU,CAAA;CAAE,CAAC;AAE/D,eAAO,MAAM,yBAAyB;;CAA0C,CAAC;AAEjF,qBAAa,oBAAoB;IAGnB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAFnC,MAAM,CAAC,QAAQ,CAAC,WAAW,aAAa;gBAEX,MAAM,EAAE,kBAAkB;IAEvD,QAAQ,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;CAG7C"}
|
|
@@ -1,18 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
import { HTTPException } from "hono/http-exception";
|
|
3
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
4
|
-
export const ShieldApiKeyError = new HTTPException(403, { message: "shield.api.key" });
|
|
1
|
+
export const ShieldApiKeyStrategyError = { Rejected: "shield.api.key.rejected" };
|
|
5
2
|
export class ShieldApiKeyStrategy {
|
|
6
3
|
config;
|
|
7
|
-
static HEADER_NAME = "
|
|
4
|
+
static HEADER_NAME = "api-key";
|
|
8
5
|
constructor(config) {
|
|
9
6
|
this.config = config;
|
|
10
7
|
}
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
return next();
|
|
15
|
-
throw ShieldApiKeyError;
|
|
16
|
-
});
|
|
8
|
+
evaluate(context) {
|
|
9
|
+
return context.request.header(ShieldApiKeyStrategy.HEADER_NAME) === this.config.API_KEY;
|
|
10
|
+
}
|
|
17
11
|
}
|
|
18
12
|
//# sourceMappingURL=shield-api-key.strategy.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shield-api-key.strategy.js","sourceRoot":"","sources":["../src/shield-api-key.strategy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"shield-api-key.strategy.js","sourceRoot":"","sources":["../src/shield-api-key.strategy.ts"],"names":[],"mappings":"AAKA,MAAM,CAAC,MAAM,yBAAyB,GAAG,EAAE,QAAQ,EAAE,yBAAyB,EAAE,CAAC;AAEjF,MAAM,OAAO,oBAAoB;IAGF;IAF7B,MAAM,CAAU,WAAW,GAAG,SAAS,CAAC;IAExC,YAA6B,MAA0B;QAA1B,WAAM,GAAN,MAAM,CAAoB;IAAG,CAAC;IAE3D,QAAQ,CAAC,OAAyB;QAChC,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,oBAAoB,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;IAC1F,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type hono from "hono";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { AuthSessionReaderPort } from "./auth-session-reader.port";
|
|
4
|
+
type Dependencies<User, Session> = {
|
|
5
|
+
AuthSessionReader: AuthSessionReaderPort<User, Session>;
|
|
6
|
+
};
|
|
7
|
+
export declare const ShieldAuthError: HTTPException;
|
|
8
|
+
export declare class ShieldAuthHonoStrategy<User, Session> {
|
|
9
|
+
private readonly strategy;
|
|
10
|
+
constructor(deps: Dependencies<User, Session>);
|
|
11
|
+
attach: hono.MiddlewareHandler<any, any, {}, Response>;
|
|
12
|
+
verify: hono.MiddlewareHandler<any, any, {}, Response>;
|
|
13
|
+
reverse: hono.MiddlewareHandler<any, any, {}, Response>;
|
|
14
|
+
}
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=shield-auth-hono.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-auth-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-auth-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAE7B,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAIxE,KAAK,YAAY,CAAC,IAAI,EAAE,OAAO,IAAI;IAAE,iBAAiB,EAAE,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;CAAE,CAAC;AAE/F,eAAO,MAAM,eAAe,eAAwE,CAAC;AAErG,qBAAa,sBAAsB,CAAC,IAAI,EAAE,OAAO;IAC/C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAoC;gBAEjD,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC;IAI7C,MAAM,iDAOH;IAEH,MAAM,iDAKH;IAEH,OAAO,iDAKJ;CACJ"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
4
|
+
import { ShieldAuthStrategy, ShieldAuthStrategyError } from "./shield-auth.strategy";
|
|
5
|
+
export const ShieldAuthError = new HTTPException(403, { message: ShieldAuthStrategyError.Rejected });
|
|
6
|
+
export class ShieldAuthHonoStrategy {
|
|
7
|
+
strategy;
|
|
8
|
+
constructor(deps) {
|
|
9
|
+
this.strategy = new ShieldAuthStrategy(deps);
|
|
10
|
+
}
|
|
11
|
+
attach = createMiddleware(async (c, next) => {
|
|
12
|
+
const context = new RequestContextHonoAdapter(c);
|
|
13
|
+
const auth = await this.strategy.attach(context);
|
|
14
|
+
c.set("user", auth.user);
|
|
15
|
+
c.set("session", auth.session);
|
|
16
|
+
return next();
|
|
17
|
+
});
|
|
18
|
+
verify = createMiddleware(async (c, next) => {
|
|
19
|
+
const user = c.get("user");
|
|
20
|
+
if (this.strategy.verify(user))
|
|
21
|
+
return next();
|
|
22
|
+
throw ShieldAuthError;
|
|
23
|
+
});
|
|
24
|
+
reverse = createMiddleware(async (c, next) => {
|
|
25
|
+
const user = c.get("user");
|
|
26
|
+
if (this.strategy.reverse(user))
|
|
27
|
+
return next();
|
|
28
|
+
throw ShieldAuthError;
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=shield-auth-hono.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-auth-hono.strategy.js","sourceRoot":"","sources":["../src/shield-auth-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AAIrF,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,CAAC,QAAQ,EAAE,CAAC,CAAC;AAErG,MAAM,OAAO,sBAAsB;IAChB,QAAQ,CAAoC;IAE7D,YAAY,IAAiC;QAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACnE,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAEjD,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/B,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACnE,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,EAAE,CAAC;QAC9C,MAAM,eAAe,CAAC;IACxB,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACpE,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,EAAE,CAAC;QAC/C,MAAM,eAAe,CAAC;IACxB,CAAC,CAAC,CAAC;CACJ"}
|
|
@@ -1,16 +1,17 @@
|
|
|
1
|
-
import type
|
|
2
|
-
import {
|
|
3
|
-
import type { AuthSessionReaderPort } from "./auth-session-reader.port";
|
|
1
|
+
import type { AuthSessionReaderPort, AuthSessionType } from "./auth-session-reader.port";
|
|
2
|
+
import type { HasRequestHeaders } from "./request-context.port";
|
|
4
3
|
type Dependencies<User, Session> = {
|
|
5
4
|
AuthSessionReader: AuthSessionReaderPort<User, Session>;
|
|
6
5
|
};
|
|
7
|
-
export declare const
|
|
6
|
+
export declare const ShieldAuthStrategyError: {
|
|
7
|
+
Rejected: string;
|
|
8
|
+
};
|
|
8
9
|
export declare class ShieldAuthStrategy<User, Session> {
|
|
9
10
|
private readonly deps;
|
|
10
11
|
constructor(deps: Dependencies<User, Session>);
|
|
11
|
-
attach:
|
|
12
|
-
verify:
|
|
13
|
-
reverse:
|
|
12
|
+
attach(context: HasRequestHeaders): Promise<AuthSessionType<User, Session>>;
|
|
13
|
+
verify(user: User | null): boolean;
|
|
14
|
+
reverse(user: User | null): boolean;
|
|
14
15
|
}
|
|
15
16
|
export {};
|
|
16
17
|
//# sourceMappingURL=shield-auth.strategy.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shield-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-auth.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"shield-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-auth.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AACzF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAEhE,KAAK,YAAY,CAAC,IAAI,EAAE,OAAO,IAAI;IAAE,iBAAiB,EAAE,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;CAAE,CAAC;AAE/F,eAAO,MAAM,uBAAuB;;CAAuC,CAAC;AAE5E,qBAAa,kBAAkB,CAAC,IAAI,EAAE,OAAO;IAC/B,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC;IAExD,MAAM,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,eAAe,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAIjF,MAAM,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,OAAO;IAIlC,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,OAAO;CAGpC"}
|
|
@@ -1,30 +1,17 @@
|
|
|
1
|
-
|
|
2
|
-
import { HTTPException } from "hono/http-exception";
|
|
3
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
4
|
-
export const ShieldAuthError = new HTTPException(403, { message: "shield.auth" });
|
|
1
|
+
export const ShieldAuthStrategyError = { Rejected: "shield.auth.rejected" };
|
|
5
2
|
export class ShieldAuthStrategy {
|
|
6
3
|
deps;
|
|
7
4
|
constructor(deps) {
|
|
8
5
|
this.deps = deps;
|
|
9
6
|
}
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
if (!user)
|
|
20
|
-
throw ShieldAuthError;
|
|
21
|
-
return next();
|
|
22
|
-
});
|
|
23
|
-
reverse = createMiddleware(async (c, next) => {
|
|
24
|
-
const user = c.get("user");
|
|
25
|
-
if (user)
|
|
26
|
-
throw ShieldAuthError;
|
|
27
|
-
return next();
|
|
28
|
-
});
|
|
7
|
+
async attach(context) {
|
|
8
|
+
return await this.deps.AuthSessionReader.getSession(context);
|
|
9
|
+
}
|
|
10
|
+
verify(user) {
|
|
11
|
+
return user !== null;
|
|
12
|
+
}
|
|
13
|
+
reverse(user) {
|
|
14
|
+
return user === null;
|
|
15
|
+
}
|
|
29
16
|
}
|
|
30
17
|
//# sourceMappingURL=shield-auth.strategy.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shield-auth.strategy.js","sourceRoot":"","sources":["../src/shield-auth.strategy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"shield-auth.strategy.js","sourceRoot":"","sources":["../src/shield-auth.strategy.ts"],"names":[],"mappings":"AAKA,MAAM,CAAC,MAAM,uBAAuB,GAAG,EAAE,QAAQ,EAAE,sBAAsB,EAAE,CAAC;AAE5E,MAAM,OAAO,kBAAkB;IACA;IAA7B,YAA6B,IAAiC;QAAjC,SAAI,GAAJ,IAAI,CAA6B;IAAG,CAAC;IAElE,KAAK,CAAC,MAAM,CAAC,OAA0B;QACrC,OAAO,MAAM,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAC/D,CAAC;IAED,MAAM,CAAC,IAAiB;QACtB,OAAO,IAAI,KAAK,IAAI,CAAC;IACvB,CAAC;IAED,OAAO,CAAC,IAAiB;QACvB,OAAO,IAAI,KAAK,IAAI,CAAC;IACvB,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { type ShieldBasicAuthConfig } from "./shield-basic-auth.strategy";
|
|
5
|
+
export declare const ShieldBasicAuthError: HTTPException;
|
|
6
|
+
export declare class ShieldBasicAuthHonoStrategy implements MiddlewareHonoPort {
|
|
7
|
+
private readonly strategy;
|
|
8
|
+
constructor(config: ShieldBasicAuthConfig);
|
|
9
|
+
handle(): MiddlewareHandler;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=shield-basic-auth-hono.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-basic-auth-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,8BAA8B,CAAC;AAEtC,eAAO,MAAM,oBAAoB,eAE/B,CAAC;AAEH,qBAAa,2BAA4B,YAAW,kBAAkB;IACpE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;gBAEvC,MAAM,EAAE,qBAAqB;IAIzC,MAAM,IAAI,iBAAiB;CAQ5B"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { HTTPException } from "hono/http-exception";
|
|
2
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
3
|
+
import { ShieldBasicAuthStrategy, ShieldBasicAuthStrategyError, } from "./shield-basic-auth.strategy";
|
|
4
|
+
export const ShieldBasicAuthError = new HTTPException(401, {
|
|
5
|
+
message: ShieldBasicAuthStrategyError.Rejected,
|
|
6
|
+
});
|
|
7
|
+
export class ShieldBasicAuthHonoStrategy {
|
|
8
|
+
strategy;
|
|
9
|
+
constructor(config) {
|
|
10
|
+
this.strategy = new ShieldBasicAuthStrategy(config);
|
|
11
|
+
}
|
|
12
|
+
handle() {
|
|
13
|
+
return async (c, next) => {
|
|
14
|
+
const context = new RequestContextHonoAdapter(c);
|
|
15
|
+
if (this.strategy.evaluate(context))
|
|
16
|
+
return next();
|
|
17
|
+
throw ShieldBasicAuthError;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=shield-basic-auth-hono.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-basic-auth-hono.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAEL,uBAAuB,EACvB,4BAA4B,GAC7B,MAAM,8BAA8B,CAAC;AAEtC,MAAM,CAAC,MAAM,oBAAoB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE;IACzD,OAAO,EAAE,4BAA4B,CAAC,QAAQ;CAC/C,CAAC,CAAC;AAEH,MAAM,OAAO,2BAA2B;IACrB,QAAQ,CAA0B;IAEnD,YAAY,MAA6B;QACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAAC;IACtD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACnD,MAAM,oBAAoB,CAAC;QAC7B,CAAC,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import type { BasicAuthPasswordType } from "./basic-auth-password.vo";
|
|
2
2
|
import type { BasicAuthUsernameType } from "./basic-auth-username.vo";
|
|
3
|
-
import type {
|
|
4
|
-
type
|
|
3
|
+
import type { HasRequestHeader } from "./request-context.port";
|
|
4
|
+
export type ShieldBasicAuthConfig = {
|
|
5
5
|
username: BasicAuthUsernameType;
|
|
6
6
|
password: BasicAuthPasswordType;
|
|
7
7
|
};
|
|
8
|
-
export declare
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
export declare const ShieldBasicAuthStrategyError: {
|
|
9
|
+
Rejected: string;
|
|
10
|
+
};
|
|
11
|
+
export declare class ShieldBasicAuthStrategy {
|
|
12
|
+
private readonly config;
|
|
13
|
+
constructor(config: ShieldBasicAuthConfig);
|
|
14
|
+
evaluate(context: HasRequestHeader): boolean;
|
|
12
15
|
}
|
|
13
|
-
export {};
|
|
14
16
|
//# sourceMappingURL=shield-basic-auth.strategy.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shield-basic-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"shield-basic-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,MAAM,MAAM,qBAAqB,GAAG;IAAE,QAAQ,EAAE,qBAAqB,CAAC;IAAC,QAAQ,EAAE,qBAAqB,CAAA;CAAE,CAAC;AAEzG,eAAO,MAAM,4BAA4B;;CAA6C,CAAC;AAEvF,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,qBAAqB;IAE1D,QAAQ,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;CAgB7C"}
|
|
@@ -1,10 +1,23 @@
|
|
|
1
|
-
|
|
2
|
-
import { createMiddleware } from "hono/factory";
|
|
1
|
+
export const ShieldBasicAuthStrategyError = { Rejected: "shield.basic.auth.rejected" };
|
|
3
2
|
export class ShieldBasicAuthStrategy {
|
|
4
|
-
|
|
3
|
+
config;
|
|
5
4
|
constructor(config) {
|
|
6
|
-
this.
|
|
5
|
+
this.config = config;
|
|
6
|
+
}
|
|
7
|
+
evaluate(context) {
|
|
8
|
+
const header = context.request.header("authorization");
|
|
9
|
+
try {
|
|
10
|
+
const credentials = atob(String(header).replace("Basic ", ""));
|
|
11
|
+
const [username, password] = credentials.split(":");
|
|
12
|
+
if (username !== this.config.username)
|
|
13
|
+
return false;
|
|
14
|
+
if (password !== this.config.password)
|
|
15
|
+
return false;
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
return false;
|
|
20
|
+
}
|
|
7
21
|
}
|
|
8
|
-
verify = createMiddleware(async (context, next) => this.basicAuth(context, next));
|
|
9
22
|
}
|
|
10
23
|
//# sourceMappingURL=shield-basic-auth.strategy.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shield-basic-auth.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"shield-basic-auth.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,4BAA4B,GAAG,EAAE,QAAQ,EAAE,4BAA4B,EAAE,CAAC;AAEvF,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,MAA6B;QAA7B,WAAM,GAAN,MAAM,CAAuB;IAAG,CAAC;IAE9D,QAAQ,CAAC,OAAyB;QAChC,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAEvD,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;YAE/D,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAEpD,IAAI,QAAQ,KAAK,IAAI,CAAC,MAAM,CAAC,QAAQ;gBAAE,OAAO,KAAK,CAAC;YACpD,IAAI,QAAQ,KAAK,IAAI,CAAC,MAAM,CAAC,QAAQ;gBAAE,OAAO,KAAK,CAAC;YAEpD,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { HTTPException } from "hono/http-exception";
|
|
2
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
3
|
+
import { type ShieldBodyLimitConfig } from "./shield-body-limit.strategy";
|
|
4
|
+
export declare const ShieldBodyLimitTooBigError: HTTPException;
|
|
5
|
+
export declare class ShieldBodyLimitHonoStrategy implements MiddlewareHonoPort {
|
|
6
|
+
private readonly strategy;
|
|
7
|
+
constructor(config: ShieldBodyLimitConfig);
|
|
8
|
+
handle(): import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=shield-body-limit-hono.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-body-limit-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-body-limit-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,8BAA8B,CAAC;AAEtC,eAAO,MAAM,0BAA0B,eAAmE,CAAC;AAE3G,qBAAa,2BAA4B,YAAW,kBAAkB;IACpE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;gBAEvC,MAAM,EAAE,qBAAqB;IAIzC,MAAM;CAUP"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
4
|
+
import { ShieldBodyLimitError, ShieldBodyLimitStrategy, } from "./shield-body-limit.strategy";
|
|
5
|
+
export const ShieldBodyLimitTooBigError = new HTTPException(413, { message: ShieldBodyLimitError.TooBig });
|
|
6
|
+
export class ShieldBodyLimitHonoStrategy {
|
|
7
|
+
strategy;
|
|
8
|
+
constructor(config) {
|
|
9
|
+
this.strategy = new ShieldBodyLimitStrategy(config);
|
|
10
|
+
}
|
|
11
|
+
handle() {
|
|
12
|
+
return createMiddleware(async (c, next) => {
|
|
13
|
+
const context = new RequestContextHonoAdapter(c);
|
|
14
|
+
const result = this.strategy.evaluate(context);
|
|
15
|
+
if (!result)
|
|
16
|
+
throw ShieldBodyLimitTooBigError;
|
|
17
|
+
return next();
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=shield-body-limit-hono.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-body-limit-hono.strategy.js","sourceRoot":"","sources":["../src/shield-body-limit-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAEL,oBAAoB,EACpB,uBAAuB,GACxB,MAAM,8BAA8B,CAAC;AAEtC,MAAM,CAAC,MAAM,0BAA0B,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,oBAAoB,CAAC,MAAM,EAAE,CAAC,CAAC;AAE3G,MAAM,OAAO,2BAA2B;IACrB,QAAQ,CAA0B;IAEnD,YAAY,MAA6B;QACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAAC;IACtD,CAAC;IAED,MAAM;QACJ,OAAO,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACxC,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YAE/C,IAAI,CAAC,MAAM;gBAAE,MAAM,0BAA0B,CAAC;YAC9C,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import type { HasRequestHeader } from "./request-context.port";
|
|
3
|
+
export type ShieldBodyLimitConfig = {
|
|
4
|
+
maxSize: tools.Size;
|
|
5
|
+
};
|
|
6
|
+
export declare const ShieldBodyLimitError: {
|
|
7
|
+
TooBig: string;
|
|
8
|
+
};
|
|
9
|
+
export declare class ShieldBodyLimitStrategy {
|
|
10
|
+
private readonly config;
|
|
11
|
+
constructor(config: ShieldBodyLimitConfig);
|
|
12
|
+
evaluate(context: HasRequestHeader): boolean;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=shield-body-limit.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-body-limit.strategy.d.ts","sourceRoot":"","sources":["../src/shield-body-limit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,MAAM,MAAM,qBAAqB,GAAG;IAAE,OAAO,EAAE,KAAK,CAAC,IAAI,CAAA;CAAE,CAAC;AAE5D,eAAO,MAAM,oBAAoB;;CAA2C,CAAC;AAE7E,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,qBAAqB;IAE1D,QAAQ,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;CAY7C"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
export const ShieldBodyLimitError = { TooBig: "shield.body.limit.rejected" };
|
|
3
|
+
export class ShieldBodyLimitStrategy {
|
|
4
|
+
config;
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.config = config;
|
|
7
|
+
}
|
|
8
|
+
evaluate(context) {
|
|
9
|
+
const header = context.request.header("content-length");
|
|
10
|
+
const contentLength = tools.SizeBytes.safeParse(Number(header));
|
|
11
|
+
if (!contentLength.success)
|
|
12
|
+
return true;
|
|
13
|
+
const size = tools.Size.fromBytes(contentLength.data);
|
|
14
|
+
if (size.isGreaterThan(this.config.maxSize))
|
|
15
|
+
return false;
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=shield-body-limit.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-body-limit.strategy.js","sourceRoot":"","sources":["../src/shield-body-limit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAKtC,MAAM,CAAC,MAAM,oBAAoB,GAAG,EAAE,MAAM,EAAE,4BAA4B,EAAE,CAAC;AAE7E,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,MAA6B;QAA7B,WAAM,GAAN,MAAM,CAAuB;IAAG,CAAC;IAE9D,QAAQ,CAAC,OAAyB;QAChC,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAExD,MAAM,aAAa,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;QAEhE,IAAI,CAAC,aAAa,CAAC,OAAO;YAAE,OAAO,IAAI,CAAC;QAExC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAEtD,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAAE,OAAO,KAAK,CAAC;QAC1D,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { type ShieldCsrfConfig } from "./shield-csrf.strategy";
|
|
5
|
+
export declare const ShieldCsrfError: HTTPException;
|
|
6
|
+
export declare class ShieldCsrfHonoStrategy implements MiddlewareHonoPort {
|
|
7
|
+
private readonly strategy;
|
|
8
|
+
constructor(config: ShieldCsrfConfig);
|
|
9
|
+
handle(): MiddlewareHandler;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=shield-csrf-hono.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-csrf-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-csrf-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EAAE,KAAK,gBAAgB,EAA+C,MAAM,wBAAwB,CAAC;AAE5G,eAAO,MAAM,eAAe,eAAwE,CAAC;AAErG,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;gBAElC,MAAM,EAAE,gBAAgB;IAIpC,MAAM,IAAI,iBAAiB;CAQ5B"}
|