@bgord/bun 1.10.23 → 1.11.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/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/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-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 +70 -25
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +70 -25
- 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 +9 -9
- package/readme.md +69 -24
- 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/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/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-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 +70 -25
- 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/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/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/context.middleware.ts +0 -24
- 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
|
@@ -5,20 +5,20 @@ import {
|
|
|
5
5
|
type PrerequisiteVerifierPort,
|
|
6
6
|
} from "./prerequisite-verifier.port";
|
|
7
7
|
|
|
8
|
-
export type
|
|
8
|
+
export type PrerequisiteVerifierWithFailSafeAdapterConfig = (
|
|
9
9
|
result: PrerequisiteVerificationResult,
|
|
10
10
|
) => boolean;
|
|
11
11
|
|
|
12
|
-
const AnyErrorFailSafe:
|
|
12
|
+
const AnyErrorFailSafe: PrerequisiteVerifierWithFailSafeAdapterConfig = (result) =>
|
|
13
13
|
result.outcome === PrerequisiteVerificationOutcome.failure;
|
|
14
14
|
|
|
15
15
|
export class PrerequisiteVerifierWithFailSafeAdapter implements PrerequisiteVerifierPort {
|
|
16
|
-
private readonly when:
|
|
16
|
+
private readonly when: PrerequisiteVerifierWithFailSafeAdapterConfig;
|
|
17
17
|
|
|
18
18
|
constructor(
|
|
19
19
|
private readonly config: {
|
|
20
20
|
inner: PrerequisiteVerifierPort;
|
|
21
|
-
when?:
|
|
21
|
+
when?: PrerequisiteVerifierWithFailSafeAdapterConfig;
|
|
22
22
|
},
|
|
23
23
|
) {
|
|
24
24
|
this.when = config.when ?? AnyErrorFailSafe;
|
|
@@ -10,6 +10,8 @@ import { Stopwatch } from "./stopwatch.service";
|
|
|
10
10
|
|
|
11
11
|
type Dependencies = { Logger: LoggerPort; Clock: ClockPort };
|
|
12
12
|
|
|
13
|
+
type Config = { inner: PrerequisiteVerifierPort };
|
|
14
|
+
|
|
13
15
|
export class PrerequisiteVerifierWithLoggerAdapter implements PrerequisiteVerifierPort {
|
|
14
16
|
private readonly base = (duration: tools.Duration) => ({
|
|
15
17
|
component: "infra",
|
|
@@ -18,7 +20,7 @@ export class PrerequisiteVerifierWithLoggerAdapter implements PrerequisiteVerifi
|
|
|
18
20
|
});
|
|
19
21
|
|
|
20
22
|
constructor(
|
|
21
|
-
private readonly config:
|
|
23
|
+
private readonly config: Config,
|
|
22
24
|
private readonly deps: Dependencies,
|
|
23
25
|
) {}
|
|
24
26
|
|
|
@@ -4,14 +4,15 @@ import {
|
|
|
4
4
|
type PrerequisiteVerificationResult,
|
|
5
5
|
type PrerequisiteVerifierPort,
|
|
6
6
|
} from "./prerequisite-verifier.port";
|
|
7
|
-
import { Retry, type
|
|
7
|
+
import { Retry, type RetryConfig } from "./retry.service";
|
|
8
8
|
import type { SleeperPort } from "./sleeper.port";
|
|
9
9
|
|
|
10
10
|
type Dependencies = { Sleeper: SleeperPort };
|
|
11
|
+
type Config = { inner: PrerequisiteVerifierPort; retry: RetryConfig };
|
|
11
12
|
|
|
12
13
|
export class PrerequisiteVerifierWithRetryAdapter implements PrerequisiteVerifierPort {
|
|
13
14
|
constructor(
|
|
14
|
-
private readonly config:
|
|
15
|
+
private readonly config: Config,
|
|
15
16
|
private readonly deps: Dependencies,
|
|
16
17
|
) {}
|
|
17
18
|
|
|
@@ -7,10 +7,11 @@ import {
|
|
|
7
7
|
import type { TimeoutRunnerPort } from "./timeout-runner.port";
|
|
8
8
|
|
|
9
9
|
type Dependencies = { TimeoutRunner: TimeoutRunnerPort };
|
|
10
|
+
type Config = { inner: PrerequisiteVerifierPort; timeout: tools.Duration };
|
|
10
11
|
|
|
11
12
|
export class PrerequisiteVerifierWithTimeoutAdapter implements PrerequisiteVerifierPort {
|
|
12
13
|
constructor(
|
|
13
|
-
private readonly config:
|
|
14
|
+
private readonly config: Config,
|
|
14
15
|
private readonly deps: Dependencies,
|
|
15
16
|
) {}
|
|
16
17
|
|
|
@@ -7,12 +7,12 @@ import type { PrerequisiteVerifierPort } from "./prerequisite-verifier.port";
|
|
|
7
7
|
import { PrerequisiteVerifierWithCacheAdapter } from "./prerequisite-verifier-with-cache.adapter";
|
|
8
8
|
import {
|
|
9
9
|
PrerequisiteVerifierWithFailSafeAdapter,
|
|
10
|
-
type
|
|
10
|
+
type PrerequisiteVerifierWithFailSafeAdapterConfig,
|
|
11
11
|
} from "./prerequisite-verifier-with-fail-safe.adapter";
|
|
12
12
|
import { PrerequisiteVerifierWithLoggerAdapter } from "./prerequisite-verifier-with-logger.adapter";
|
|
13
13
|
import { PrerequisiteVerifierWithRetryAdapter } from "./prerequisite-verifier-with-retry.adapter";
|
|
14
14
|
import { PrerequisiteVerifierWithTimeoutAdapter } from "./prerequisite-verifier-with-timeout.adapter";
|
|
15
|
-
import type {
|
|
15
|
+
import type { RetryConfig } from "./retry.service";
|
|
16
16
|
import type { SleeperPort } from "./sleeper.port";
|
|
17
17
|
import type { TimeoutRunnerPort } from "./timeout-runner.port";
|
|
18
18
|
|
|
@@ -37,12 +37,12 @@ const withLogger =
|
|
|
37
37
|
new PrerequisiteVerifierWithLoggerAdapter({ inner }, deps);
|
|
38
38
|
|
|
39
39
|
const withRetry =
|
|
40
|
-
(retry:
|
|
40
|
+
(retry: RetryConfig, deps: { Sleeper: SleeperPort }): PrerequisiteVerifierDecorator =>
|
|
41
41
|
(inner) =>
|
|
42
42
|
new PrerequisiteVerifierWithRetryAdapter({ inner, retry }, deps);
|
|
43
43
|
|
|
44
44
|
const withFailSafe =
|
|
45
|
-
(when:
|
|
45
|
+
(when: PrerequisiteVerifierWithFailSafeAdapterConfig): PrerequisiteVerifierDecorator =>
|
|
46
46
|
(inner) =>
|
|
47
47
|
new PrerequisiteVerifierWithFailSafeAdapter({ inner, when });
|
|
48
48
|
|
package/src/prerequisite.vo.ts
CHANGED
|
@@ -3,10 +3,7 @@ import type { PrerequisiteVerifierPort } from "./prerequisite-verifier.port";
|
|
|
3
3
|
|
|
4
4
|
export type PrerequisiteLabelType = string;
|
|
5
5
|
|
|
6
|
-
type
|
|
7
|
-
decorators?: ReadonlyArray<PrerequisiteVerifierDecorator>;
|
|
8
|
-
enabled?: boolean;
|
|
9
|
-
};
|
|
6
|
+
type Config = { decorators?: ReadonlyArray<PrerequisiteVerifierDecorator>; enabled?: boolean };
|
|
10
7
|
|
|
11
8
|
export class Prerequisite {
|
|
12
9
|
private readonly decorators: ReadonlyArray<PrerequisiteVerifierDecorator>;
|
|
@@ -15,7 +12,7 @@ export class Prerequisite {
|
|
|
15
12
|
constructor(
|
|
16
13
|
readonly label: PrerequisiteLabelType,
|
|
17
14
|
private readonly verifier: PrerequisiteVerifierPort,
|
|
18
|
-
config?:
|
|
15
|
+
config?: Config,
|
|
19
16
|
) {
|
|
20
17
|
this.decorators = config?.decorators ?? [];
|
|
21
18
|
this.enabled = config?.enabled ?? true;
|
|
@@ -11,8 +11,6 @@ import type {
|
|
|
11
11
|
RemotePutFromPathResult,
|
|
12
12
|
} from "./remote-file-storage.port";
|
|
13
13
|
|
|
14
|
-
type RemoteFileStorageDiskConfig = { root: tools.DirectoryPathAbsoluteType };
|
|
15
|
-
|
|
16
14
|
type Dependencies = {
|
|
17
15
|
HashFile: HashFilePort;
|
|
18
16
|
FileCleaner: FileCleanerPort;
|
|
@@ -21,9 +19,11 @@ type Dependencies = {
|
|
|
21
19
|
DirectoryEnsurer: DirectoryEnsurerPort;
|
|
22
20
|
};
|
|
23
21
|
|
|
22
|
+
type Config = { root: tools.DirectoryPathAbsoluteType };
|
|
23
|
+
|
|
24
24
|
export class RemoteFileStorageDiskAdapter implements RemoteFileStoragePort {
|
|
25
25
|
constructor(
|
|
26
|
-
private readonly config:
|
|
26
|
+
private readonly config: Config,
|
|
27
27
|
private readonly deps: Dependencies,
|
|
28
28
|
) {}
|
|
29
29
|
|
|
@@ -3,7 +3,7 @@ import { getConnInfo } from "hono/bun";
|
|
|
3
3
|
import { getCookie } from "hono/cookie";
|
|
4
4
|
import type { RequestContext } from "./request-context.port";
|
|
5
5
|
|
|
6
|
-
export class
|
|
6
|
+
export class RequestContextHonoAdapter implements RequestContext {
|
|
7
7
|
readonly request: RequestContext["request"];
|
|
8
8
|
readonly identity: RequestContext["identity"];
|
|
9
9
|
|
|
@@ -11,9 +11,20 @@ export class RequestContextAdapterHono implements RequestContext {
|
|
|
11
11
|
this.request = {
|
|
12
12
|
path: context.req.path,
|
|
13
13
|
method: context.req.method,
|
|
14
|
+
url: () => context.req.url,
|
|
14
15
|
header: (name) => context.req.header(name),
|
|
15
16
|
headers: () => context.req.raw.headers,
|
|
17
|
+
headersObject: () => {
|
|
18
|
+
const headers: Record<string, string> = {};
|
|
19
|
+
|
|
20
|
+
context.req.raw.headers.forEach((value, key) => {
|
|
21
|
+
headers[key] = value;
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
return headers;
|
|
25
|
+
},
|
|
16
26
|
query: () => context.req.query(),
|
|
27
|
+
params: () => context.req.param(),
|
|
17
28
|
cookie: (name) => getCookie(context)[name],
|
|
18
29
|
json: async () => {
|
|
19
30
|
try {
|
|
@@ -4,11 +4,14 @@ export interface RequestContext {
|
|
|
4
4
|
readonly request: {
|
|
5
5
|
readonly path: string;
|
|
6
6
|
readonly method: string;
|
|
7
|
+
url(): string;
|
|
7
8
|
header(name: string): string | undefined;
|
|
8
9
|
query(): Record<string, string>;
|
|
10
|
+
params(): Record<string, string>;
|
|
9
11
|
cookie(name: string): string | undefined;
|
|
10
12
|
json(): Promise<Record<string, unknown>>;
|
|
11
13
|
headers: () => Headers;
|
|
14
|
+
headersObject: () => Record<string, string>;
|
|
12
15
|
};
|
|
13
16
|
|
|
14
17
|
readonly identity: {
|
|
@@ -18,6 +21,10 @@ export interface RequestContext {
|
|
|
18
21
|
};
|
|
19
22
|
}
|
|
20
23
|
|
|
24
|
+
export interface HasRequestUrl {
|
|
25
|
+
readonly request: { url(): string };
|
|
26
|
+
}
|
|
27
|
+
|
|
21
28
|
export interface HasRequestPath {
|
|
22
29
|
readonly request: { readonly path: string };
|
|
23
30
|
}
|
|
@@ -34,10 +41,18 @@ export interface HasRequestHeaders {
|
|
|
34
41
|
readonly request: { headers: () => Headers };
|
|
35
42
|
}
|
|
36
43
|
|
|
44
|
+
export interface HasRequestHeadersObject {
|
|
45
|
+
readonly request: { headers: () => Record<string, string> };
|
|
46
|
+
}
|
|
47
|
+
|
|
37
48
|
export interface HasRequestQuery {
|
|
38
49
|
readonly request: { query(): Record<string, string> };
|
|
39
50
|
}
|
|
40
51
|
|
|
52
|
+
export interface HasRequestParams {
|
|
53
|
+
readonly request: { params(): Record<string, string> };
|
|
54
|
+
}
|
|
55
|
+
|
|
41
56
|
export interface HasRequestCookie {
|
|
42
57
|
readonly request: { cookie(name: string): string | undefined };
|
|
43
58
|
}
|
package/src/retry.service.ts
CHANGED
|
@@ -2,20 +2,20 @@ import * as tools from "@bgord/tools";
|
|
|
2
2
|
import type { RetryBackoffStrategy } from "./retry-backoff.strategy";
|
|
3
3
|
import type { SleeperPort } from "./sleeper.port";
|
|
4
4
|
|
|
5
|
+
export const RetryError = { InvalidMax: "retry.invalid.max" };
|
|
6
|
+
|
|
5
7
|
type Dependencies = { Sleeper: SleeperPort };
|
|
6
8
|
|
|
7
|
-
export type
|
|
9
|
+
export type RetryConfig = {
|
|
8
10
|
max: tools.IntegerPositiveType;
|
|
9
11
|
backoff: RetryBackoffStrategy;
|
|
10
12
|
when?: (error: unknown) => boolean;
|
|
11
13
|
};
|
|
12
14
|
|
|
13
|
-
export const RetryError = { InvalidMax: "retry.invalid.max" };
|
|
14
|
-
|
|
15
15
|
export class Retry {
|
|
16
16
|
constructor(private readonly deps: Dependencies) {}
|
|
17
17
|
|
|
18
|
-
async run<T>(action: () => Promise<T>, config:
|
|
18
|
+
async run<T>(action: () => Promise<T>, config: RetryConfig): Promise<T> {
|
|
19
19
|
if (config.max < 1) throw new Error(RetryError.InvalidMax);
|
|
20
20
|
|
|
21
21
|
let lastError: unknown;
|
|
@@ -16,6 +16,10 @@ import {
|
|
|
16
16
|
type SecurityCountermeasureNameType,
|
|
17
17
|
} from "./security-countermeasure-name.vo";
|
|
18
18
|
|
|
19
|
+
export const SecurityCountermeasureBanStrategyError = {
|
|
20
|
+
Executed: "security.countermeasure.ban.strategy.executed",
|
|
21
|
+
};
|
|
22
|
+
|
|
19
23
|
type Dependencies = {
|
|
20
24
|
IdProvider: IdProviderPort;
|
|
21
25
|
Clock: ClockPort;
|
|
@@ -23,14 +27,12 @@ type Dependencies = {
|
|
|
23
27
|
EventStore: EventStoreLike<SecurityViolationDetectedEventType>;
|
|
24
28
|
};
|
|
25
29
|
|
|
26
|
-
|
|
27
|
-
Executed: "security.countermeasure.ban.strategy.executed",
|
|
28
|
-
};
|
|
30
|
+
type Config = { response: { status: number } };
|
|
29
31
|
|
|
30
32
|
export class SecurityCountermeasureBanStrategy implements SecurityCountermeasureStrategy {
|
|
31
33
|
constructor(
|
|
32
34
|
private readonly deps: Dependencies,
|
|
33
|
-
private readonly config:
|
|
35
|
+
private readonly config: Config = { response: { status: 403 } },
|
|
34
36
|
) {}
|
|
35
37
|
|
|
36
38
|
async execute(context: SecurityContext): Promise<SecurityAction> {
|
|
@@ -8,11 +8,12 @@ import {
|
|
|
8
8
|
} from "./security-countermeasure-name.vo";
|
|
9
9
|
|
|
10
10
|
type Dependencies = { Logger: LoggerPort };
|
|
11
|
+
type Config = { response: { status: number } };
|
|
11
12
|
|
|
12
13
|
export class SecurityCountermeasureMirageStrategy implements SecurityCountermeasureStrategy {
|
|
13
14
|
constructor(
|
|
14
15
|
private readonly deps: Dependencies,
|
|
15
|
-
private readonly config:
|
|
16
|
+
private readonly config: Config = { response: { status: 200 } },
|
|
16
17
|
) {}
|
|
17
18
|
|
|
18
19
|
async execute(context: SecurityContext): Promise<SecurityAction> {
|
|
@@ -9,11 +9,12 @@ import {
|
|
|
9
9
|
} from "./security-countermeasure-name.vo";
|
|
10
10
|
|
|
11
11
|
type Dependencies = { Logger: LoggerPort };
|
|
12
|
+
type Config = { duration: tools.Duration; after: SecurityAction };
|
|
12
13
|
|
|
13
14
|
export class SecurityCountermeasureTarpitStrategy implements SecurityCountermeasureStrategy {
|
|
14
15
|
constructor(
|
|
15
16
|
private readonly deps: Dependencies,
|
|
16
|
-
private readonly config:
|
|
17
|
+
private readonly config: Config,
|
|
17
18
|
) {}
|
|
18
19
|
|
|
19
20
|
async execute(context: SecurityContext): Promise<SecurityAction> {
|
|
@@ -1,26 +1,27 @@
|
|
|
1
1
|
import * as tools from "@bgord/tools";
|
|
2
2
|
import type { CacheRepositoryPort } from "./cache-repository.port";
|
|
3
|
-
import { CacheSubjectRequestResolver } from "./cache-subject-request-resolver.vo";
|
|
4
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
5
|
-
import { CacheSubjectSegmentIpStrategy } from "./cache-subject-segment-ip.strategy";
|
|
6
3
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
7
4
|
import type { RequestContext } from "./request-context.port";
|
|
8
5
|
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
9
6
|
import { SecurityRuleName, type SecurityRuleNameType } from "./security-rule-name.vo";
|
|
7
|
+
import { SubjectRequestResolver } from "./subject-request-resolver.vo";
|
|
8
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
9
|
+
import { SubjectSegmentIpStrategy } from "./subject-segment-ip.strategy";
|
|
10
10
|
|
|
11
11
|
type Dependencies = { CacheRepository: CacheRepositoryPort; HashContent: HashContentStrategy };
|
|
12
|
+
type Config = { threshold: tools.IntegerPositiveType };
|
|
12
13
|
|
|
13
14
|
export class SecurityRuleViolationThresholdStrategy implements SecurityRuleStrategy {
|
|
14
15
|
constructor(
|
|
15
16
|
private readonly rule: SecurityRuleStrategy,
|
|
16
|
-
private readonly config:
|
|
17
|
+
private readonly config: Config,
|
|
17
18
|
private readonly deps: Dependencies,
|
|
18
19
|
) {}
|
|
19
20
|
|
|
20
21
|
// Best-effort increment, occasional lost increments are acceptable for concurrent requests.
|
|
21
22
|
async isViolated(context: RequestContext): Promise<boolean> {
|
|
22
|
-
const resolver = new
|
|
23
|
-
[new
|
|
23
|
+
const resolver = new SubjectRequestResolver(
|
|
24
|
+
[new SubjectSegmentFixedStrategy(this.name), new SubjectSegmentIpStrategy()],
|
|
24
25
|
this.deps,
|
|
25
26
|
);
|
|
26
27
|
const subject = await resolver.resolve(context);
|
|
@@ -1,60 +1,56 @@
|
|
|
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 { trimTrailingSlash } from "hono/trailing-slash";
|
|
9
|
-
import { ApiVersion } from "./api-version.middleware";
|
|
5
|
+
import { ApiVersionHonoMiddleware } from "./api-version-hono.middleware";
|
|
10
6
|
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
11
7
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
12
8
|
import type { ClockPort } from "./clock.port";
|
|
13
|
-
import {
|
|
14
|
-
import {
|
|
15
|
-
import { ETagExtractor } from "./etag-extractor.middleware";
|
|
9
|
+
import { CorrelationHonoMiddleware } from "./correlation-hono.middleware";
|
|
10
|
+
import { ETagExtractorHonoMiddleware } from "./etag-extractor-hono.middleware";
|
|
16
11
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
17
|
-
import {
|
|
18
|
-
import
|
|
12
|
+
import type { HttpLoggerConfig } from "./http-logger.middleware";
|
|
13
|
+
import { HttpLoggerHonoMiddleware } from "./http-logger-hono.middleware";
|
|
14
|
+
import type { I18nConfig } from "./i18n.service";
|
|
19
15
|
import type { IdProviderPort } from "./id-provider.port";
|
|
20
16
|
import type { LoggerPort } from "./logger.port";
|
|
21
|
-
import {
|
|
22
|
-
import {
|
|
23
|
-
import {
|
|
24
|
-
import {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
httpLogger?: HttpLoggerOptions;
|
|
30
|
-
maintenanceMode?: MaintenanceModeConfigType;
|
|
31
|
-
BODY_LIMIT_MAX_SIZE?: tools.Size;
|
|
32
|
-
};
|
|
17
|
+
import type { ShieldCsrfConfig } from "./shield-csrf.strategy";
|
|
18
|
+
import { ShieldCsrfHonoStrategy } from "./shield-csrf-hono.strategy";
|
|
19
|
+
import type { ShieldMaintenanceConfig } from "./shield-maintenance.strategy";
|
|
20
|
+
import { ShieldMaintenanceHonoStrategy } from "./shield-maintenance-hono.strategy";
|
|
21
|
+
import { TimeZoneOffsetHonoMiddleware } from "./time-zone-offset-hono.middleware";
|
|
22
|
+
import { TimingHonoMiddleware } from "./timing-hono.middleware";
|
|
23
|
+
import { TrailingSlashHonoMiddleware } from "./trailing-slash-hono.middleware";
|
|
24
|
+
import { WeakETagExtractorHonoMiddleware } from "./weak-etag-extractor-hono.middleware";
|
|
33
25
|
|
|
34
26
|
type Dependencies = {
|
|
35
27
|
Logger: LoggerPort;
|
|
36
28
|
IdProvider: IdProviderPort;
|
|
37
|
-
I18n:
|
|
29
|
+
I18n: I18nConfig;
|
|
38
30
|
Clock: ClockPort;
|
|
39
31
|
CacheResolver: CacheResolverStrategy;
|
|
40
32
|
HashContent: HashContentStrategy;
|
|
41
33
|
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
42
34
|
};
|
|
43
35
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
36
|
+
type Config = {
|
|
37
|
+
csrf: ShieldCsrfConfig;
|
|
38
|
+
cors?: Parameters<typeof cors>[0];
|
|
39
|
+
httpLogger?: HttpLoggerConfig;
|
|
40
|
+
maintenanceMode?: ShieldMaintenanceConfig;
|
|
41
|
+
};
|
|
47
42
|
|
|
43
|
+
export class SetupHono {
|
|
44
|
+
// Configure body size limit at the framework level
|
|
45
|
+
// - Bun: maxRequestBodySize in Bun.serve()
|
|
46
|
+
// - Express: limit in express.json()
|
|
47
|
+
static essentials(config: Config, deps: Dependencies) {
|
|
48
48
|
return [
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
generator: () => deps.IdProvider.generate(),
|
|
55
|
-
}),
|
|
56
|
-
ApiVersion.build(deps),
|
|
57
|
-
new ShieldCsrfStrategy(config.csrf).verify,
|
|
49
|
+
new ShieldMaintenanceHonoStrategy(config.maintenanceMode).handle(),
|
|
50
|
+
new TrailingSlashHonoMiddleware().handle(),
|
|
51
|
+
new CorrelationHonoMiddleware(deps).handle(),
|
|
52
|
+
new ApiVersionHonoMiddleware(deps).handle(),
|
|
53
|
+
new ShieldCsrfHonoStrategy(config.csrf).handle(),
|
|
58
54
|
secureHeaders({
|
|
59
55
|
referrerPolicy: "no-referrer",
|
|
60
56
|
xContentTypeOptions: "nosniff",
|
|
@@ -67,7 +63,6 @@ export class Setup {
|
|
|
67
63
|
originAgentCluster: false,
|
|
68
64
|
xFrameOptions: false,
|
|
69
65
|
}),
|
|
70
|
-
bodyLimit({ maxSize: BODY_LIMIT_MAX_SIZE.toBytes() }),
|
|
71
66
|
cors({
|
|
72
67
|
// Stryker disable all
|
|
73
68
|
origin: (origin, c) => {
|
|
@@ -92,13 +87,11 @@ export class Setup {
|
|
|
92
87
|
caches: false,
|
|
93
88
|
// Stryker restore all
|
|
94
89
|
}),
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
timing(),
|
|
101
|
-
CorrelationStorage.handle(),
|
|
90
|
+
new TimeZoneOffsetHonoMiddleware().handle(),
|
|
91
|
+
new WeakETagExtractorHonoMiddleware().handle(),
|
|
92
|
+
new ETagExtractorHonoMiddleware().handle(),
|
|
93
|
+
new HttpLoggerHonoMiddleware(deps, config.httpLogger).handle(),
|
|
94
|
+
new TimingHonoMiddleware(deps).handle(),
|
|
102
95
|
];
|
|
103
96
|
}
|
|
104
97
|
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
5
|
+
import {
|
|
6
|
+
type ApiKeyShieldConfig,
|
|
7
|
+
ShieldApiKeyStrategy,
|
|
8
|
+
ShieldApiKeyStrategyError,
|
|
9
|
+
} from "./shield-api-key.strategy";
|
|
10
|
+
|
|
11
|
+
export const ShieldApiKeyError = new HTTPException(403, { message: ShieldApiKeyStrategyError.Rejected });
|
|
12
|
+
|
|
13
|
+
export class ShieldApiKeyHonoStrategy implements MiddlewareHonoPort {
|
|
14
|
+
private readonly strategy: ShieldApiKeyStrategy;
|
|
15
|
+
|
|
16
|
+
constructor(config: ApiKeyShieldConfig) {
|
|
17
|
+
this.strategy = new ShieldApiKeyStrategy(config);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
handle(): MiddlewareHandler {
|
|
21
|
+
return async (c, next) => {
|
|
22
|
+
const context = new RequestContextHonoAdapter(c);
|
|
23
|
+
|
|
24
|
+
if (this.strategy.evaluate(context)) return next();
|
|
25
|
+
throw ShieldApiKeyError;
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
}
|
|
@@ -1,22 +1,16 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
|
-
import {
|
|
3
|
-
import { HTTPException } from "hono/http-exception";
|
|
4
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
5
|
-
import type { ShieldStrategy } from "./shield.strategy";
|
|
2
|
+
import type { HasRequestHeader } from "./request-context.port";
|
|
6
3
|
|
|
7
|
-
type
|
|
4
|
+
export type ApiKeyShieldConfig = { API_KEY: tools.ApiKeyType };
|
|
8
5
|
|
|
9
|
-
export const
|
|
6
|
+
export const ShieldApiKeyStrategyError = { Rejected: "shield.api.key.rejected" };
|
|
10
7
|
|
|
11
|
-
export class ShieldApiKeyStrategy
|
|
12
|
-
static readonly HEADER_NAME = "
|
|
8
|
+
export class ShieldApiKeyStrategy {
|
|
9
|
+
static readonly HEADER_NAME = "api-key";
|
|
13
10
|
|
|
14
|
-
constructor(private readonly config:
|
|
11
|
+
constructor(private readonly config: ApiKeyShieldConfig) {}
|
|
15
12
|
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
if (context.request.header(ShieldApiKeyStrategy.HEADER_NAME) === this.config.API_KEY) return next();
|
|
20
|
-
throw ShieldApiKeyError;
|
|
21
|
-
});
|
|
13
|
+
evaluate(context: HasRequestHeader): boolean {
|
|
14
|
+
return context.request.header(ShieldApiKeyStrategy.HEADER_NAME) === this.config.API_KEY;
|
|
15
|
+
}
|
|
22
16
|
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type hono from "hono";
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
import type { AuthSessionReaderPort } from "./auth-session-reader.port";
|
|
5
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
6
|
+
import { ShieldAuthStrategy, ShieldAuthStrategyError } from "./shield-auth.strategy";
|
|
7
|
+
|
|
8
|
+
type Dependencies<User, Session> = { AuthSessionReader: AuthSessionReaderPort<User, Session> };
|
|
9
|
+
|
|
10
|
+
export const ShieldAuthError = new HTTPException(403, { message: ShieldAuthStrategyError.Rejected });
|
|
11
|
+
|
|
12
|
+
export class ShieldAuthHonoStrategy<User, Session> {
|
|
13
|
+
private readonly strategy: ShieldAuthStrategy<User, Session>;
|
|
14
|
+
|
|
15
|
+
constructor(deps: Dependencies<User, Session>) {
|
|
16
|
+
this.strategy = new ShieldAuthStrategy(deps);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
attach = createMiddleware(async (c: hono.Context, next: hono.Next) => {
|
|
20
|
+
const context = new RequestContextHonoAdapter(c);
|
|
21
|
+
const auth = await this.strategy.attach(context);
|
|
22
|
+
|
|
23
|
+
c.set("user", auth.user);
|
|
24
|
+
c.set("session", auth.session);
|
|
25
|
+
return next();
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
verify = createMiddleware(async (c: hono.Context, next: hono.Next) => {
|
|
29
|
+
const user = c.get("user");
|
|
30
|
+
|
|
31
|
+
if (this.strategy.verify(user)) return next();
|
|
32
|
+
throw ShieldAuthError;
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
reverse = createMiddleware(async (c: hono.Context, next: hono.Next) => {
|
|
36
|
+
const user = c.get("user");
|
|
37
|
+
|
|
38
|
+
if (this.strategy.reverse(user)) return next();
|
|
39
|
+
throw ShieldAuthError;
|
|
40
|
+
});
|
|
41
|
+
}
|
|
@@ -1,36 +1,22 @@
|
|
|
1
|
-
import type
|
|
2
|
-
import {
|
|
3
|
-
import { HTTPException } from "hono/http-exception";
|
|
4
|
-
import type { AuthSessionReaderPort } from "./auth-session-reader.port";
|
|
5
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
1
|
+
import type { AuthSessionReaderPort, AuthSessionType } from "./auth-session-reader.port";
|
|
2
|
+
import type { HasRequestHeaders } from "./request-context.port";
|
|
6
3
|
|
|
7
4
|
type Dependencies<User, Session> = { AuthSessionReader: AuthSessionReaderPort<User, Session> };
|
|
8
5
|
|
|
9
|
-
export const
|
|
6
|
+
export const ShieldAuthStrategyError = { Rejected: "shield.auth.rejected" };
|
|
10
7
|
|
|
11
8
|
export class ShieldAuthStrategy<User, Session> {
|
|
12
9
|
constructor(private readonly deps: Dependencies<User, Session>) {}
|
|
13
10
|
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
11
|
+
async attach(context: HasRequestHeaders): Promise<AuthSessionType<User, Session>> {
|
|
12
|
+
return await this.deps.AuthSessionReader.getSession(context);
|
|
13
|
+
}
|
|
17
14
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
});
|
|
15
|
+
verify(user: User | null): boolean {
|
|
16
|
+
return user !== null;
|
|
17
|
+
}
|
|
22
18
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
if (!user) throw ShieldAuthError;
|
|
27
|
-
return next();
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
reverse = createMiddleware(async (c: hono.Context, next: hono.Next) => {
|
|
31
|
-
const user = c.get("user");
|
|
32
|
-
|
|
33
|
-
if (user) throw ShieldAuthError;
|
|
34
|
-
return next();
|
|
35
|
-
});
|
|
19
|
+
reverse(user: User | null): boolean {
|
|
20
|
+
return user === null;
|
|
21
|
+
}
|
|
36
22
|
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
5
|
+
import {
|
|
6
|
+
type ShieldBasicAuthConfig,
|
|
7
|
+
ShieldBasicAuthStrategy,
|
|
8
|
+
ShieldBasicAuthStrategyError,
|
|
9
|
+
} from "./shield-basic-auth.strategy";
|
|
10
|
+
|
|
11
|
+
export const ShieldBasicAuthError = new HTTPException(401, {
|
|
12
|
+
message: ShieldBasicAuthStrategyError.Rejected,
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
export class ShieldBasicAuthHonoStrategy implements MiddlewareHonoPort {
|
|
16
|
+
private readonly strategy: ShieldBasicAuthStrategy;
|
|
17
|
+
|
|
18
|
+
constructor(config: ShieldBasicAuthConfig) {
|
|
19
|
+
this.strategy = new ShieldBasicAuthStrategy(config);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
handle(): MiddlewareHandler {
|
|
23
|
+
return async (c, next) => {
|
|
24
|
+
const context = new RequestContextHonoAdapter(c);
|
|
25
|
+
|
|
26
|
+
if (this.strategy.evaluate(context)) return next();
|
|
27
|
+
throw ShieldBasicAuthError;
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
}
|