@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
|
@@ -1,19 +1,9 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
|
-
import { createMiddleware } from "hono/factory";
|
|
3
|
-
import { HTTPException } from "hono/http-exception";
|
|
4
|
-
import { timeout } from "hono/timeout";
|
|
5
|
-
import type { ShieldStrategy } from "./shield.strategy";
|
|
6
2
|
|
|
7
|
-
export
|
|
3
|
+
export type ShieldTimeoutConfig = { duration: tools.Duration };
|
|
8
4
|
|
|
9
|
-
|
|
5
|
+
export const ShieldTimeoutStrategyError = { Rejected: "shield.timeout.rejected" };
|
|
10
6
|
|
|
11
|
-
export class ShieldTimeoutStrategy
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
constructor(config: ShieldTimeoutConfigType) {
|
|
15
|
-
this.timeout = timeout(config.duration.ms, ShieldTimeoutError);
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
verify = createMiddleware(async (context, next) => this.timeout(context, next));
|
|
7
|
+
export class ShieldTimeoutStrategy {
|
|
8
|
+
constructor(readonly config: ShieldTimeoutConfig) {}
|
|
19
9
|
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
3
|
+
import { SimulatedErrorMiddleware } from "./simulated-error.middleware";
|
|
4
|
+
|
|
5
|
+
export class SimulatedErrorHonoMiddleware implements MiddlewareHonoPort {
|
|
6
|
+
private readonly middleware: SimulatedErrorMiddleware;
|
|
7
|
+
|
|
8
|
+
constructor() {
|
|
9
|
+
this.middleware = new SimulatedErrorMiddleware();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
handle(): MiddlewareHandler {
|
|
13
|
+
return async (_c, _next) => {
|
|
14
|
+
this.middleware.evaluate();
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -1,8 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
createMiddleware(async (_, _next) => {
|
|
6
|
-
throw new Error("Simulated error");
|
|
7
|
-
});
|
|
1
|
+
export class SimulatedErrorMiddleware {
|
|
2
|
+
evaluate(): never {
|
|
3
|
+
throw new Error("Simulated error");
|
|
4
|
+
}
|
|
8
5
|
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { MiddlewareHandler } from "hono";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import type { SleeperPort } from "./sleeper.port";
|
|
5
|
+
import { SlowerMiddleware } from "./slower.middleware";
|
|
6
|
+
|
|
7
|
+
type Dependencies = { Sleeper: SleeperPort };
|
|
8
|
+
|
|
9
|
+
export class SlowerHonoMiddleware implements MiddlewareHonoPort {
|
|
10
|
+
private readonly middleware: SlowerMiddleware;
|
|
11
|
+
|
|
12
|
+
constructor(offset: tools.Duration, deps: Dependencies) {
|
|
13
|
+
this.middleware = new SlowerMiddleware(offset, deps);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
handle(): MiddlewareHandler {
|
|
17
|
+
return async (_c, next) => {
|
|
18
|
+
await this.middleware.evaluate();
|
|
19
|
+
|
|
20
|
+
return next();
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
}
|
package/src/slower.middleware.ts
CHANGED
|
@@ -1,14 +1,15 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
|
-
import { createMiddleware } from "hono/factory";
|
|
3
2
|
import type { SleeperPort } from "./sleeper.port";
|
|
4
3
|
|
|
5
4
|
type Dependencies = { Sleeper: SleeperPort };
|
|
6
5
|
|
|
7
|
-
export class
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
6
|
+
export class SlowerMiddleware {
|
|
7
|
+
constructor(
|
|
8
|
+
private readonly offset: tools.Duration,
|
|
9
|
+
private readonly deps: Dependencies,
|
|
10
|
+
) {}
|
|
11
11
|
|
|
12
|
-
|
|
13
|
-
|
|
12
|
+
async evaluate(): Promise<void> {
|
|
13
|
+
await this.deps.Sleeper.wait(this.offset);
|
|
14
|
+
}
|
|
14
15
|
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { NonceProviderPort } from "./nonce-provider.port";
|
|
2
|
+
import type { NonceValueType } from "./nonce-value.vo";
|
|
3
|
+
import { SSRService } from "./ssr.service";
|
|
4
|
+
|
|
5
|
+
type Dependencies = { NonceProvider: NonceProviderPort };
|
|
6
|
+
|
|
7
|
+
export class SSRBun {
|
|
8
|
+
static essentials(
|
|
9
|
+
handler: (request: Request, nonce: NonceValueType) => Promise<Response>,
|
|
10
|
+
deps: Dependencies,
|
|
11
|
+
) {
|
|
12
|
+
const service = new SSRService(deps);
|
|
13
|
+
|
|
14
|
+
return async (request: Request): Promise<Response> => {
|
|
15
|
+
const nonce = service.nonce;
|
|
16
|
+
|
|
17
|
+
const response = await handler(request, nonce);
|
|
18
|
+
|
|
19
|
+
const headers = service.secure(nonce);
|
|
20
|
+
Object.entries(headers).forEach(([name, value]) => response.headers.set(name, value));
|
|
21
|
+
|
|
22
|
+
return response;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import type { NonceProviderPort } from "./nonce-provider.port";
|
|
2
|
+
import type { NonceValueType } from "./nonce-value.vo";
|
|
3
|
+
|
|
4
|
+
type Dependencies = { NonceProvider: NonceProviderPort };
|
|
5
|
+
|
|
6
|
+
export type SSRSecurityHeaders = {
|
|
7
|
+
"Content-Security-Policy": string;
|
|
8
|
+
"Permissions-Policy": string;
|
|
9
|
+
"Cross-Origin-Opener-Policy": string;
|
|
10
|
+
"Cross-Origin-Resource-Policy": string;
|
|
11
|
+
"Referrer-Policy": string;
|
|
12
|
+
"Strict-Transport-Security": string;
|
|
13
|
+
"X-Content-Type-Options": string;
|
|
14
|
+
"X-DNS-Prefetch-Control": string;
|
|
15
|
+
"X-Download-Options": string;
|
|
16
|
+
"X-Permitted-Cross-Domain-Policies": string;
|
|
17
|
+
"X-XSS-Protection": string;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export class SSRService {
|
|
21
|
+
constructor(private readonly deps: Dependencies) {}
|
|
22
|
+
|
|
23
|
+
get nonce(): NonceValueType {
|
|
24
|
+
return this.deps.NonceProvider.generate();
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
secure(nonce: NonceValueType): SSRSecurityHeaders {
|
|
28
|
+
return {
|
|
29
|
+
"Content-Security-Policy": [
|
|
30
|
+
"default-src 'none'",
|
|
31
|
+
"base-uri 'none'",
|
|
32
|
+
"object-src 'none'",
|
|
33
|
+
"frame-ancestors 'none'",
|
|
34
|
+
`script-src 'self' 'nonce-${nonce}'`,
|
|
35
|
+
`script-src-elem 'self' 'nonce-${nonce}'`,
|
|
36
|
+
`style-src 'self' 'nonce-${nonce}'`,
|
|
37
|
+
"style-src-attr 'unsafe-inline'",
|
|
38
|
+
"img-src 'self'",
|
|
39
|
+
"font-src 'self'",
|
|
40
|
+
"connect-src 'self'",
|
|
41
|
+
"form-action 'self'",
|
|
42
|
+
].join("; "),
|
|
43
|
+
"Permissions-Policy": [
|
|
44
|
+
"accelerometer=()",
|
|
45
|
+
"autoplay=()",
|
|
46
|
+
"camera=()",
|
|
47
|
+
"fullscreen=(self)",
|
|
48
|
+
"geolocation=()",
|
|
49
|
+
"gyroscope=()",
|
|
50
|
+
"magnetometer=()",
|
|
51
|
+
"microphone=()",
|
|
52
|
+
"payment=()",
|
|
53
|
+
"usb=()",
|
|
54
|
+
].join(", "),
|
|
55
|
+
"Cross-Origin-Opener-Policy": "same-origin",
|
|
56
|
+
"Cross-Origin-Resource-Policy": "same-origin",
|
|
57
|
+
"Referrer-Policy": "no-referrer",
|
|
58
|
+
"Strict-Transport-Security": "max-age=15552000; includeSubDomains",
|
|
59
|
+
"X-Content-Type-Options": "nosniff",
|
|
60
|
+
"X-DNS-Prefetch-Control": "off",
|
|
61
|
+
"X-Download-Options": "noopen",
|
|
62
|
+
"X-Permitted-Cross-Domain-Policies": "none",
|
|
63
|
+
"X-XSS-Protection": "0",
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -58,7 +58,7 @@ const staticDocumentHeaders = secureHeaders({
|
|
|
58
58
|
|
|
59
59
|
type StaticFilesOptions = { root?: string };
|
|
60
60
|
|
|
61
|
-
export class
|
|
61
|
+
export class StaticFilesHono {
|
|
62
62
|
static handle(path: string, strategy: StaticFilesStrategy, options?: StaticFilesOptions) {
|
|
63
63
|
// Stryker disable all
|
|
64
64
|
const root = options?.root ?? "./";
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { Hash } from "./hash.vo";
|
|
2
|
+
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
3
|
+
import type { SubjectSegmentApplicationStrategy } from "./subject-segment-application.strategy";
|
|
4
|
+
import type { SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
5
|
+
|
|
6
|
+
type Dependencies = { HashContent: HashContentStrategy };
|
|
7
|
+
|
|
8
|
+
export const SubjectApplicationResolverError = {
|
|
9
|
+
NoSegments: "subject.application.no.segments",
|
|
10
|
+
TooManySegments: "subject.application.too.many.segments",
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export class SubjectApplicationResolver {
|
|
14
|
+
private readonly SEPARATOR = "|";
|
|
15
|
+
|
|
16
|
+
constructor(
|
|
17
|
+
private readonly segments: ReadonlyArray<SubjectSegmentApplicationStrategy>,
|
|
18
|
+
private readonly deps: Dependencies,
|
|
19
|
+
) {
|
|
20
|
+
if (this.segments.length === 0) throw new Error(SubjectApplicationResolverError.NoSegments);
|
|
21
|
+
if (this.segments.length > 10) throw new Error(SubjectApplicationResolverError.TooManySegments);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
async resolve(): Promise<{ hex: Hash; raw: ReadonlyArray<SubjectSegmentType> }> {
|
|
25
|
+
const segments = this.segments.map((segment) =>
|
|
26
|
+
segment.create().replaceAll(this.SEPARATOR, encodeURIComponent(this.SEPARATOR)),
|
|
27
|
+
);
|
|
28
|
+
const subject = segments.join(this.SEPARATOR);
|
|
29
|
+
|
|
30
|
+
const hex = await this.deps.HashContent.hash(subject);
|
|
31
|
+
|
|
32
|
+
return { hex, raw: segments };
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { Hash } from "./hash.vo";
|
|
2
|
+
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
3
|
+
import type { RequestContext } from "./request-context.port";
|
|
4
|
+
import type { SubjectSegmentRequestStrategy, SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
5
|
+
|
|
6
|
+
type Dependencies = { HashContent: HashContentStrategy };
|
|
7
|
+
|
|
8
|
+
export const SubjectRequestResolverError = {
|
|
9
|
+
NoSegments: "subject.request.no.segments",
|
|
10
|
+
TooManySegments: "subject.request.too.many.segments",
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export class SubjectRequestResolver {
|
|
14
|
+
private readonly SEPARATOR = "|";
|
|
15
|
+
|
|
16
|
+
constructor(
|
|
17
|
+
private readonly segments: ReadonlyArray<SubjectSegmentRequestStrategy>,
|
|
18
|
+
private readonly deps: Dependencies,
|
|
19
|
+
) {
|
|
20
|
+
if (this.segments.length === 0) throw new Error(SubjectRequestResolverError.NoSegments);
|
|
21
|
+
if (this.segments.length > 10) throw new Error(SubjectRequestResolverError.TooManySegments);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
async resolve(context: RequestContext): Promise<{ hex: Hash; raw: ReadonlyArray<SubjectSegmentType> }> {
|
|
25
|
+
const segments = this.segments.map((segment) =>
|
|
26
|
+
segment.create(context).replaceAll(this.SEPARATOR, encodeURIComponent(this.SEPARATOR)),
|
|
27
|
+
);
|
|
28
|
+
const subject = segments.join(this.SEPARATOR);
|
|
29
|
+
|
|
30
|
+
const hex = await this.deps.HashContent.hash(subject);
|
|
31
|
+
|
|
32
|
+
return { hex, raw: segments };
|
|
33
|
+
}
|
|
34
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import {
|
|
3
|
+
SubjectSegmentApplicationEmpty,
|
|
4
|
+
type SubjectSegmentApplicationStrategy,
|
|
5
|
+
} from "./subject-segment-application.strategy";
|
|
6
|
+
import type { SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
7
|
+
|
|
8
|
+
export class SubjectSegmentBuildStrategy implements SubjectSegmentApplicationStrategy {
|
|
9
|
+
constructor(private readonly build?: tools.PackageVersion) {}
|
|
10
|
+
|
|
11
|
+
create(): SubjectSegmentType {
|
|
12
|
+
if (!this.build) return SubjectSegmentApplicationEmpty;
|
|
13
|
+
return this.build.toString();
|
|
14
|
+
}
|
|
15
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { HasRequestCookie } from "./request-context.port";
|
|
2
|
+
import type { SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
3
|
+
import {
|
|
4
|
+
SubjectSegmentRequestEmpty,
|
|
5
|
+
type SubjectSegmentRequestStrategy,
|
|
6
|
+
} from "./subject-segment-request.strategy";
|
|
7
|
+
|
|
8
|
+
export class SubjectSegmentCookieStrategy implements SubjectSegmentRequestStrategy {
|
|
9
|
+
constructor(private readonly name: string) {}
|
|
10
|
+
|
|
11
|
+
create(context: HasRequestCookie): SubjectSegmentType {
|
|
12
|
+
return context.request.cookie(this.name) ?? SubjectSegmentRequestEmpty;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { NodeEnvironmentEnum } from "./node-env.vo";
|
|
2
|
+
import type { SubjectSegmentApplicationStrategy } from "./subject-segment-application.strategy";
|
|
3
|
+
import type { SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
4
|
+
|
|
5
|
+
export class SubjectSegmentEnvStrategy implements SubjectSegmentApplicationStrategy {
|
|
6
|
+
constructor(private readonly type: NodeEnvironmentEnum) {}
|
|
7
|
+
|
|
8
|
+
create(): SubjectSegmentType {
|
|
9
|
+
return this.type;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { SubjectSegmentApplicationStrategy } from "./subject-segment-application.strategy";
|
|
2
|
+
import type { SubjectSegmentRequestStrategy, SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
3
|
+
|
|
4
|
+
export class SubjectSegmentFixedStrategy
|
|
5
|
+
implements SubjectSegmentRequestStrategy, SubjectSegmentApplicationStrategy
|
|
6
|
+
{
|
|
7
|
+
constructor(private readonly value: string) {}
|
|
8
|
+
|
|
9
|
+
create(): SubjectSegmentType {
|
|
10
|
+
return this.value;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { HasRequestHeader } from "./request-context.port";
|
|
2
|
+
import type { SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
3
|
+
import {
|
|
4
|
+
SubjectSegmentRequestEmpty,
|
|
5
|
+
type SubjectSegmentRequestStrategy,
|
|
6
|
+
} from "./subject-segment-request.strategy";
|
|
7
|
+
|
|
8
|
+
export class SubjectSegmentHeaderStrategy implements SubjectSegmentRequestStrategy {
|
|
9
|
+
constructor(private readonly name: string) {}
|
|
10
|
+
|
|
11
|
+
create(context: HasRequestHeader): SubjectSegmentType {
|
|
12
|
+
return context.request.header(this.name) ?? SubjectSegmentRequestEmpty;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { HasIdentityIp } from "./request-context.port";
|
|
2
|
+
import {
|
|
3
|
+
SubjectSegmentRequestEmpty,
|
|
4
|
+
type SubjectSegmentRequestStrategy,
|
|
5
|
+
type SubjectSegmentType,
|
|
6
|
+
} from "./subject-segment-request.strategy";
|
|
7
|
+
|
|
8
|
+
export class SubjectSegmentIpStrategy implements SubjectSegmentRequestStrategy {
|
|
9
|
+
create(context: HasIdentityIp): SubjectSegmentType {
|
|
10
|
+
return context.identity.ip() ?? SubjectSegmentRequestEmpty;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { HasRequestPath } from "./request-context.port";
|
|
2
|
+
import type { SubjectSegmentRequestStrategy, SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
3
|
+
|
|
4
|
+
export class SubjectSegmentPathStrategy implements SubjectSegmentRequestStrategy {
|
|
5
|
+
create(context: HasRequestPath): SubjectSegmentType {
|
|
6
|
+
return context.request.path;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { HasRequestQuery } from "./request-context.port";
|
|
2
|
+
import type { SubjectSegmentType } from "./subject-segment-request.strategy";
|
|
3
|
+
import {
|
|
4
|
+
SubjectSegmentRequestEmpty,
|
|
5
|
+
type SubjectSegmentRequestStrategy,
|
|
6
|
+
} from "./subject-segment-request.strategy";
|
|
7
|
+
|
|
8
|
+
export class SubjectSegmentQueryStrategy implements SubjectSegmentRequestStrategy {
|
|
9
|
+
create(context: HasRequestQuery): SubjectSegmentType {
|
|
10
|
+
const query = context.request.query();
|
|
11
|
+
|
|
12
|
+
const keys = Object.keys(query).toSorted();
|
|
13
|
+
|
|
14
|
+
const result = keys.map((key) => `${key}=${query[key]}`).join("&");
|
|
15
|
+
|
|
16
|
+
if (!result) return SubjectSegmentRequestEmpty;
|
|
17
|
+
return result;
|
|
18
|
+
}
|
|
19
|
+
}
|
package/src/{cache-subject-segment-request.strategy.ts → subject-segment-request.strategy.ts}
RENAMED
|
@@ -7,9 +7,9 @@ import type {
|
|
|
7
7
|
HasRequestQuery,
|
|
8
8
|
} from "./request-context.port";
|
|
9
9
|
|
|
10
|
-
export
|
|
10
|
+
export type SubjectSegmentType = string;
|
|
11
11
|
|
|
12
|
-
export
|
|
12
|
+
export const SubjectSegmentRequestEmpty: SubjectSegmentType = "__absent__";
|
|
13
13
|
|
|
14
14
|
type RequestContextCapabilities = HasRequestCookie &
|
|
15
15
|
HasRequestHeader &
|
|
@@ -18,6 +18,6 @@ type RequestContextCapabilities = HasRequestCookie &
|
|
|
18
18
|
HasIdentityIp &
|
|
19
19
|
HasIdentityUserId;
|
|
20
20
|
|
|
21
|
-
export interface
|
|
22
|
-
create(context: RequestContextCapabilities):
|
|
21
|
+
export interface SubjectSegmentRequestStrategy {
|
|
22
|
+
create(context: RequestContextCapabilities): SubjectSegmentType;
|
|
23
23
|
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { HasIdentityUserId } from "./request-context.port";
|
|
2
|
+
import {
|
|
3
|
+
SubjectSegmentRequestEmpty,
|
|
4
|
+
type SubjectSegmentRequestStrategy,
|
|
5
|
+
type SubjectSegmentType,
|
|
6
|
+
} from "./subject-segment-request.strategy";
|
|
7
|
+
|
|
8
|
+
export class SubjectSegmentUserStrategy implements SubjectSegmentRequestStrategy {
|
|
9
|
+
create(context: HasIdentityUserId): SubjectSegmentType {
|
|
10
|
+
return context.identity.userId() ?? SubjectSegmentRequestEmpty;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { MiddlewareHandler } from "hono";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
5
|
+
import { TimeZoneOffsetMiddleware } from "./time-zone-offset.middleware";
|
|
6
|
+
|
|
7
|
+
export type TimeZoneOffsetVariables = { timeZoneOffset: tools.Duration };
|
|
8
|
+
|
|
9
|
+
export class TimeZoneOffsetHonoMiddleware implements MiddlewareHonoPort {
|
|
10
|
+
private readonly middleware: TimeZoneOffsetMiddleware;
|
|
11
|
+
|
|
12
|
+
constructor() {
|
|
13
|
+
this.middleware = new TimeZoneOffsetMiddleware();
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
handle(): MiddlewareHandler {
|
|
17
|
+
return async (c, next) => {
|
|
18
|
+
const context = new RequestContextHonoAdapter(c);
|
|
19
|
+
const offset = this.middleware.evaluate(context);
|
|
20
|
+
|
|
21
|
+
c.set("timeZoneOffset", offset);
|
|
22
|
+
|
|
23
|
+
await next();
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -1,27 +1,15 @@
|
|
|
1
1
|
import * as tools from "@bgord/tools";
|
|
2
|
-
import {
|
|
3
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
2
|
+
import type { RequestContext } from "./request-context.port";
|
|
4
3
|
|
|
5
|
-
export
|
|
6
|
-
|
|
7
|
-
export class TimeZoneOffset {
|
|
4
|
+
export class TimeZoneOffsetMiddleware {
|
|
8
5
|
static readonly TIME_ZONE_OFFSET_HEADER_NAME = "time-zone-offset";
|
|
9
|
-
|
|
10
6
|
static readonly DEFAULT = tools.Duration.Minutes(0);
|
|
11
7
|
|
|
12
|
-
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
const header = context.request.header(TimeZoneOffset.TIME_ZONE_OFFSET_HEADER_NAME);
|
|
8
|
+
evaluate(context: RequestContext): tools.Duration {
|
|
9
|
+
const header = context.request.header(TimeZoneOffsetMiddleware.TIME_ZONE_OFFSET_HEADER_NAME);
|
|
16
10
|
const offset = tools.TimeZoneOffsetValue.safeParse(header);
|
|
17
11
|
|
|
18
|
-
if (offset.success)
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
await next();
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
static adjustDate(timestamp: tools.Timestamp, offset: tools.Duration): Date {
|
|
25
|
-
return new Date(timestamp.subtract(offset).ms);
|
|
12
|
+
if (offset.success) return tools.Duration.Minutes(offset.data);
|
|
13
|
+
return TimeZoneOffsetMiddleware.DEFAULT;
|
|
26
14
|
}
|
|
27
15
|
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import type { ClockPort } from "./clock.port";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
import { TimingMiddleware } from "./timing.middleware";
|
|
5
|
+
|
|
6
|
+
type Dependencies = { Clock: ClockPort };
|
|
7
|
+
|
|
8
|
+
export class TimingHonoMiddleware implements MiddlewareHonoPort {
|
|
9
|
+
private readonly middleware: TimingMiddleware;
|
|
10
|
+
|
|
11
|
+
constructor(deps: Dependencies) {
|
|
12
|
+
this.middleware = new TimingMiddleware(deps);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
handle() {
|
|
16
|
+
return createMiddleware(async (c, next) => {
|
|
17
|
+
const result = await this.middleware.measure(() => next());
|
|
18
|
+
|
|
19
|
+
c.header(TimingMiddleware.HEADER_NAME, result);
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ClockPort } from "./clock.port";
|
|
2
|
+
import { Stopwatch } from "./stopwatch.service";
|
|
3
|
+
|
|
4
|
+
type Dependencies = { Clock: ClockPort };
|
|
5
|
+
|
|
6
|
+
export class TimingMiddleware {
|
|
7
|
+
static readonly HEADER_NAME = "Server-Timing";
|
|
8
|
+
|
|
9
|
+
constructor(private readonly deps: Dependencies) {}
|
|
10
|
+
|
|
11
|
+
async measure(action: () => void | Promise<void>): Promise<string> {
|
|
12
|
+
const stopwatch = new Stopwatch(this.deps);
|
|
13
|
+
|
|
14
|
+
await action();
|
|
15
|
+
|
|
16
|
+
return `total;dur=${stopwatch.stop().ms}`;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
3
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
4
|
+
import { TrailingSlashMiddleware } from "./trailing-slash.middleware";
|
|
5
|
+
|
|
6
|
+
export class TrailingSlashHonoMiddleware implements MiddlewareHonoPort {
|
|
7
|
+
private readonly middleware: TrailingSlashMiddleware;
|
|
8
|
+
|
|
9
|
+
constructor() {
|
|
10
|
+
this.middleware = new TrailingSlashMiddleware();
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
handle() {
|
|
14
|
+
return createMiddleware(async (c, next) => {
|
|
15
|
+
const context = new RequestContextHonoAdapter(c);
|
|
16
|
+
|
|
17
|
+
const result = this.middleware.evaluate(context);
|
|
18
|
+
|
|
19
|
+
if (!result.redirect) return next();
|
|
20
|
+
|
|
21
|
+
const url = new URL(context.request.url());
|
|
22
|
+
url.pathname = result.pathname;
|
|
23
|
+
|
|
24
|
+
return c.redirect(url.toString(), 301);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { HasRequestPath } from "./request-context.port";
|
|
2
|
+
|
|
3
|
+
export type TrailingSlashResult = { redirect: false } | { redirect: true; pathname: string };
|
|
4
|
+
|
|
5
|
+
export class TrailingSlashMiddleware {
|
|
6
|
+
evaluate(context: HasRequestPath): TrailingSlashResult {
|
|
7
|
+
if (!context.request.path.endsWith("/")) return { redirect: false };
|
|
8
|
+
if (context.request.path === "/") return { redirect: false };
|
|
9
|
+
return { redirect: true, pathname: context.request.path.slice(0, -1) };
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { createFactory } from "hono/factory";
|
|
2
|
+
import type { FileReaderJsonPort } from "./file-reader-json.port";
|
|
3
|
+
import type { HandlerHonoPort } from "./handler-hono.port";
|
|
4
|
+
import type { LoggerPort } from "./logger.port";
|
|
5
|
+
import { type TranslationsConfig, TranslationsHandler } from "./translations.handler";
|
|
6
|
+
|
|
7
|
+
type Dependencies = { FileReaderJson: FileReaderJsonPort; Logger: LoggerPort };
|
|
8
|
+
|
|
9
|
+
const factory = createFactory();
|
|
10
|
+
|
|
11
|
+
export class TranslationsHonoHandler implements HandlerHonoPort {
|
|
12
|
+
private readonly handler: TranslationsHandler;
|
|
13
|
+
|
|
14
|
+
constructor(config: TranslationsConfig, deps: Dependencies) {
|
|
15
|
+
this.handler = new TranslationsHandler(config, deps);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
handle() {
|
|
19
|
+
return factory.createHandlers(async (c) => {
|
|
20
|
+
const language = c.get("language");
|
|
21
|
+
const result = await this.handler.execute(language);
|
|
22
|
+
|
|
23
|
+
return c.json(result);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { FileReaderJsonPort } from "./file-reader-json.port";
|
|
3
|
+
import { I18n, type TranslationsSupportedLanguagesType, type TranslationsType } from "./i18n.service";
|
|
4
|
+
import type { LoggerPort } from "./logger.port";
|
|
5
|
+
|
|
6
|
+
export type TranslationsConfig = TranslationsSupportedLanguagesType;
|
|
7
|
+
|
|
8
|
+
type Dependencies = { FileReaderJson: FileReaderJsonPort; Logger: LoggerPort };
|
|
9
|
+
|
|
10
|
+
export type TranslationsResult = {
|
|
11
|
+
translations: TranslationsType;
|
|
12
|
+
language: tools.LanguageType;
|
|
13
|
+
supportedLanguages: TranslationsSupportedLanguagesType;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
export class TranslationsHandler {
|
|
17
|
+
constructor(
|
|
18
|
+
private readonly config: TranslationsConfig,
|
|
19
|
+
private readonly deps: Dependencies,
|
|
20
|
+
) {}
|
|
21
|
+
|
|
22
|
+
async execute(language: string): Promise<TranslationsResult> {
|
|
23
|
+
const translations = await new I18n(this.deps).getTranslations(language);
|
|
24
|
+
|
|
25
|
+
return {
|
|
26
|
+
translations,
|
|
27
|
+
language,
|
|
28
|
+
supportedLanguages: this.config,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
}
|