@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
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import {
|
|
4
|
+
type FileUploaderConfig,
|
|
5
|
+
FileUploaderError,
|
|
6
|
+
FileUploaderMiddleware,
|
|
7
|
+
} from "./file-uploader.middleware";
|
|
8
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
9
|
+
|
|
10
|
+
export const FileUploaderMissingFileError = new HTTPException(400, {
|
|
11
|
+
message: FileUploaderError.MissingFile,
|
|
12
|
+
});
|
|
13
|
+
export const FileUploaderEmptyFileError = new HTTPException(400, { message: FileUploaderError.EmptyFile });
|
|
14
|
+
export const FileUploaderSizeLimitError = new HTTPException(400, { message: FileUploaderError.SizeLimit });
|
|
15
|
+
export const FileUploaderInvalidMimeError = new HTTPException(400, {
|
|
16
|
+
message: FileUploaderError.InvalidMime,
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
export class FileUploaderHonoMiddleware implements MiddlewareHonoPort {
|
|
20
|
+
private readonly middleware: FileUploaderMiddleware;
|
|
21
|
+
|
|
22
|
+
constructor(config: FileUploaderConfig) {
|
|
23
|
+
this.middleware = new FileUploaderMiddleware(config);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
handle() {
|
|
27
|
+
return createMiddleware(async (context, next) => {
|
|
28
|
+
const body = await context.req.raw.clone().formData();
|
|
29
|
+
const file = body.get("file");
|
|
30
|
+
|
|
31
|
+
const result = this.middleware.validate(file instanceof File ? file : null);
|
|
32
|
+
|
|
33
|
+
if (result.valid) return next();
|
|
34
|
+
|
|
35
|
+
switch (result.error) {
|
|
36
|
+
case FileUploaderError.MissingFile:
|
|
37
|
+
throw FileUploaderMissingFileError;
|
|
38
|
+
case FileUploaderError.EmptyFile:
|
|
39
|
+
throw FileUploaderEmptyFileError;
|
|
40
|
+
case FileUploaderError.SizeLimit:
|
|
41
|
+
throw FileUploaderSizeLimitError;
|
|
42
|
+
case FileUploaderError.InvalidMime:
|
|
43
|
+
throw FileUploaderInvalidMimeError;
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -1,38 +1,34 @@
|
|
|
1
1
|
import * as tools from "@bgord/tools";
|
|
2
|
-
import { bodyLimit } from "hono/body-limit";
|
|
3
|
-
import { createMiddleware } from "hono/factory";
|
|
4
|
-
import { HTTPException } from "hono/http-exception";
|
|
5
2
|
|
|
6
|
-
type
|
|
3
|
+
export type FileUploaderConfig = { MimeRegistry: tools.MimeRegistry; maxSize: tools.Size };
|
|
7
4
|
|
|
8
|
-
export const
|
|
5
|
+
export const FileUploaderError = {
|
|
6
|
+
MissingFile: "file.uploader.missing.file",
|
|
7
|
+
EmptyFile: "file.uploader.empty.file",
|
|
8
|
+
InvalidMime: "file.uploader.invalid.mime",
|
|
9
|
+
SizeLimit: "file.uploader.size.limit",
|
|
10
|
+
} as const;
|
|
9
11
|
|
|
10
|
-
export
|
|
12
|
+
export type FileValidationError = (typeof FileUploaderError)[keyof typeof FileUploaderError];
|
|
11
13
|
|
|
12
|
-
export
|
|
13
|
-
static validate(config: FileUploaderConfigType) {
|
|
14
|
-
return [
|
|
15
|
-
bodyLimit({
|
|
16
|
-
maxSize: config.maxFilesSize.toBytes(),
|
|
17
|
-
onError: () => {
|
|
18
|
-
throw FileUploaderTooBigError;
|
|
19
|
-
},
|
|
20
|
-
}),
|
|
14
|
+
export type FileValidationResult = { valid: true } | { valid: false; error: FileValidationError };
|
|
21
15
|
|
|
22
|
-
|
|
23
|
-
|
|
16
|
+
export class FileUploaderMiddleware {
|
|
17
|
+
constructor(private readonly config: FileUploaderConfig) {}
|
|
24
18
|
|
|
25
|
-
|
|
19
|
+
validate(file: File | null): FileValidationResult {
|
|
20
|
+
if (!file) return { valid: false, error: FileUploaderError.MissingFile };
|
|
21
|
+
if (file.size === 0) return { valid: false, error: FileUploaderError.EmptyFile };
|
|
26
22
|
|
|
27
|
-
|
|
23
|
+
const size = tools.Size.fromBytes(file.size);
|
|
28
24
|
|
|
29
|
-
|
|
25
|
+
if (size.isGreaterThan(this.config.maxSize)) return { valid: false, error: FileUploaderError.SizeLimit };
|
|
30
26
|
|
|
31
|
-
|
|
27
|
+
const mime = tools.Mime.fromString(file.type);
|
|
32
28
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
29
|
+
if (!this.config.MimeRegistry.hasMime(mime)) {
|
|
30
|
+
return { valid: false, error: FileUploaderError.InvalidMime };
|
|
31
|
+
}
|
|
32
|
+
return { valid: true };
|
|
37
33
|
}
|
|
38
34
|
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import type { Hash } from "./hash.vo";
|
|
3
|
+
|
|
4
|
+
export class HashBucket {
|
|
5
|
+
private constructor(readonly value: tools.IntegerNonNegativeType) {}
|
|
6
|
+
|
|
7
|
+
static fromHash(hash: Hash): HashBucket {
|
|
8
|
+
const hex = hash.get().substring(0, 8);
|
|
9
|
+
const integer = Number.parseInt(hex, 16);
|
|
10
|
+
|
|
11
|
+
const bucket = integer % 100;
|
|
12
|
+
|
|
13
|
+
return new HashBucket(tools.IntegerNonNegative.parse(bucket));
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
isLessThan(threshold: tools.IntegerNonNegativeType): boolean {
|
|
17
|
+
return this.value < threshold;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { createFactory } from "hono/factory";
|
|
2
|
+
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
3
|
+
import type { ClockPort } from "./clock.port";
|
|
4
|
+
import type { HandlerHonoPort } from "./handler-hono.port";
|
|
5
|
+
import { type HealthcheckConfig, HealthcheckHandler } from "./healthcheck.handler";
|
|
6
|
+
import type { LoggerStatsProviderPort } from "./logger-stats-provider.port";
|
|
7
|
+
|
|
8
|
+
type Dependencies = {
|
|
9
|
+
Clock: ClockPort;
|
|
10
|
+
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
11
|
+
LoggerStatsProvider?: LoggerStatsProviderPort;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const factory = createFactory();
|
|
15
|
+
|
|
16
|
+
export class HealthcheckHonoHandler implements HandlerHonoPort {
|
|
17
|
+
private readonly handler: HealthcheckHandler;
|
|
18
|
+
|
|
19
|
+
constructor(config: HealthcheckConfig, deps: Dependencies) {
|
|
20
|
+
this.handler = new HealthcheckHandler(config, deps);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
handle() {
|
|
24
|
+
return factory.createHandlers(async (c) => {
|
|
25
|
+
const healthcheck = await this.handler.check();
|
|
26
|
+
const code = healthcheck.ok ? 200 : 424;
|
|
27
|
+
|
|
28
|
+
return c.json(healthcheck, code);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import os from "node:os";
|
|
2
|
+
import * as tools from "@bgord/tools";
|
|
3
|
+
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
4
|
+
import type { ClockPort } from "./clock.port";
|
|
5
|
+
import type { CommitShaValueType } from "./commit-sha-value.vo";
|
|
6
|
+
import { EventLoopLag } from "./event-loop-lag.service";
|
|
7
|
+
import { EventLoopUtilization, type EventLoopUtilizationSnapshot } from "./event-loop-utilization.service";
|
|
8
|
+
import { InFlightRequestsTracker } from "./in-flight-requests-tracker.service";
|
|
9
|
+
import type { LoggerStatsProviderPort, LoggerStatsSnapshot } from "./logger-stats-provider.port";
|
|
10
|
+
import { MemoryConsumption } from "./memory-consumption.service";
|
|
11
|
+
import type { NodeEnvironmentEnum } from "./node-env.vo";
|
|
12
|
+
import { Prerequisite, type PrerequisiteLabelType } from "./prerequisite.vo";
|
|
13
|
+
import {
|
|
14
|
+
PrerequisiteVerificationOutcome,
|
|
15
|
+
type PrerequisiteVerificationResult,
|
|
16
|
+
} from "./prerequisite-verifier.port";
|
|
17
|
+
import { PrerequisiteVerifierSelfAdapter } from "./prerequisite-verifier-self.adapter";
|
|
18
|
+
import type { RedactorStrategy } from "./redactor.strategy";
|
|
19
|
+
import { Stopwatch } from "./stopwatch.service";
|
|
20
|
+
import { Uptime, type UptimeResultType } from "./uptime.service";
|
|
21
|
+
|
|
22
|
+
type Dependencies = {
|
|
23
|
+
Clock: ClockPort;
|
|
24
|
+
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
25
|
+
LoggerStatsProvider?: LoggerStatsProviderPort;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export type HealthcheckConfig = {
|
|
29
|
+
Env: NodeEnvironmentEnum;
|
|
30
|
+
prerequisites: ReadonlyArray<Prerequisite>;
|
|
31
|
+
redactor?: RedactorStrategy;
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
const self = new Prerequisite("self", new PrerequisiteVerifierSelfAdapter());
|
|
35
|
+
|
|
36
|
+
export type HealthcheckResult = {
|
|
37
|
+
ok: boolean;
|
|
38
|
+
deployment: {
|
|
39
|
+
version: string;
|
|
40
|
+
timestamp: tools.TimestampValueType;
|
|
41
|
+
date: string;
|
|
42
|
+
sha: CommitShaValueType;
|
|
43
|
+
size: string;
|
|
44
|
+
environment: NodeEnvironmentEnum;
|
|
45
|
+
};
|
|
46
|
+
server: {
|
|
47
|
+
pid: typeof process.pid;
|
|
48
|
+
hostname: ReturnType<typeof os.hostname>;
|
|
49
|
+
cpus: tools.IntegerNonNegativeType;
|
|
50
|
+
startup: tools.TimestampValueType;
|
|
51
|
+
uptime: Omit<UptimeResultType, "duration"> & { durationMs: tools.DurationMsType };
|
|
52
|
+
memory: {
|
|
53
|
+
total: { bytes: tools.Size["bytes"]; formatted: ReturnType<tools.Size["format"]> };
|
|
54
|
+
heap: {
|
|
55
|
+
used: { bytes: tools.Size["bytes"]; formatted: ReturnType<tools.Size["format"]> };
|
|
56
|
+
total: { bytes: tools.Size["bytes"]; formatted: ReturnType<tools.Size["format"]> };
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
eventLoop: {
|
|
60
|
+
lag: { p50: tools.DurationMsType; p95: tools.DurationMsType; p99: tools.DurationMsType };
|
|
61
|
+
utilization: EventLoopUtilizationSnapshot;
|
|
62
|
+
};
|
|
63
|
+
inFlight: tools.IntegerType;
|
|
64
|
+
};
|
|
65
|
+
details: ReadonlyArray<{
|
|
66
|
+
label: PrerequisiteLabelType;
|
|
67
|
+
outcome: PrerequisiteVerificationResult;
|
|
68
|
+
durationMs: tools.DurationMsType;
|
|
69
|
+
}>;
|
|
70
|
+
logger?: LoggerStatsSnapshot;
|
|
71
|
+
durationMs: tools.Duration["ms"];
|
|
72
|
+
timestamp: tools.TimestampValueType;
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export class HealthcheckHandler {
|
|
76
|
+
constructor(
|
|
77
|
+
private readonly config: HealthcheckConfig,
|
|
78
|
+
private readonly deps: Dependencies,
|
|
79
|
+
) {}
|
|
80
|
+
|
|
81
|
+
async check(): Promise<HealthcheckResult> {
|
|
82
|
+
const stopwatch = new Stopwatch(this.deps);
|
|
83
|
+
|
|
84
|
+
const prerequisites = [self, ...this.config.prerequisites]
|
|
85
|
+
.filter((prerequisite) => prerequisite.enabled)
|
|
86
|
+
.filter((prerequisite) => prerequisite.kind !== "port");
|
|
87
|
+
|
|
88
|
+
const details = await Promise.all(
|
|
89
|
+
prerequisites.map(async (prerequisite) => {
|
|
90
|
+
const stopwatch = new Stopwatch(this.deps);
|
|
91
|
+
|
|
92
|
+
const outcome = await prerequisite.build().verify();
|
|
93
|
+
|
|
94
|
+
return {
|
|
95
|
+
label: prerequisite.label,
|
|
96
|
+
outcome: this.config.redactor ? this.config.redactor.redact(outcome) : outcome,
|
|
97
|
+
durationMs: stopwatch.stop().ms,
|
|
98
|
+
};
|
|
99
|
+
}),
|
|
100
|
+
);
|
|
101
|
+
|
|
102
|
+
const ok = details.every((result) => result.outcome.outcome !== PrerequisiteVerificationOutcome.failure);
|
|
103
|
+
|
|
104
|
+
const build = await this.deps.BuildInfoRepository.extract();
|
|
105
|
+
const uptime = Uptime.get(this.deps.Clock);
|
|
106
|
+
const histogram = EventLoopLag.snapshot();
|
|
107
|
+
const memory = MemoryConsumption.snapshot();
|
|
108
|
+
|
|
109
|
+
return {
|
|
110
|
+
ok,
|
|
111
|
+
details,
|
|
112
|
+
deployment: {
|
|
113
|
+
version: build.version.toString(),
|
|
114
|
+
timestamp: build.timestamp.ms,
|
|
115
|
+
date: new Date(build.timestamp.ms).toISOString(),
|
|
116
|
+
sha: build.sha.toString(),
|
|
117
|
+
size: build.size.format(tools.Size.unit.MB),
|
|
118
|
+
environment: this.config.Env,
|
|
119
|
+
},
|
|
120
|
+
server: {
|
|
121
|
+
pid: process.pid,
|
|
122
|
+
hostname: os.hostname(),
|
|
123
|
+
cpus: tools.IntegerNonNegative.parse(os.cpus().length),
|
|
124
|
+
startup: this.deps.Clock.now().subtract(uptime.duration).ms,
|
|
125
|
+
uptime: { durationMs: uptime.duration.ms, formatted: uptime.formatted },
|
|
126
|
+
memory: {
|
|
127
|
+
total: { bytes: memory.total.toBytes(), formatted: memory.total.format(tools.Size.unit.MB) },
|
|
128
|
+
heap: {
|
|
129
|
+
used: {
|
|
130
|
+
bytes: memory.heap.used.toBytes(),
|
|
131
|
+
formatted: memory.heap.used.format(tools.Size.unit.MB),
|
|
132
|
+
},
|
|
133
|
+
total: {
|
|
134
|
+
bytes: memory.heap.total.toBytes(),
|
|
135
|
+
formatted: memory.heap.total.format(tools.Size.unit.MB),
|
|
136
|
+
},
|
|
137
|
+
},
|
|
138
|
+
},
|
|
139
|
+
eventLoop: {
|
|
140
|
+
lag: { p50: histogram.p50.ms, p95: histogram.p95.ms, p99: histogram.p99.ms },
|
|
141
|
+
utilization: EventLoopUtilization.snapshot(),
|
|
142
|
+
},
|
|
143
|
+
inFlight: InFlightRequestsTracker.get(),
|
|
144
|
+
},
|
|
145
|
+
logger: this.deps.LoggerStatsProvider?.getStats(),
|
|
146
|
+
durationMs: stopwatch.stop().ms,
|
|
147
|
+
timestamp: this.deps.Clock.now().ms,
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { CacheSourceEnum } from "./cache-resolver.strategy";
|
|
3
|
+
import { CacheResponseMiddleware } from "./cache-response.middleware";
|
|
4
|
+
import type { ClockPort } from "./clock.port";
|
|
5
|
+
import { type HttpLoggerConfig, HttpLoggerMiddleware } from "./http-logger.middleware";
|
|
6
|
+
import type { LoggerPort } from "./logger.port";
|
|
7
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
8
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
9
|
+
|
|
10
|
+
type Dependencies = { Logger: LoggerPort; Clock: ClockPort };
|
|
11
|
+
|
|
12
|
+
export class HttpLoggerHonoMiddleware implements MiddlewareHonoPort {
|
|
13
|
+
private readonly middleware: HttpLoggerMiddleware;
|
|
14
|
+
|
|
15
|
+
constructor(deps: Dependencies, config?: HttpLoggerConfig) {
|
|
16
|
+
this.middleware = new HttpLoggerMiddleware(deps, config);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
handle(): MiddlewareHandler {
|
|
20
|
+
return async (c, next) => {
|
|
21
|
+
const context = new RequestContextHonoAdapter(c);
|
|
22
|
+
|
|
23
|
+
if (this.middleware.shouldSkip(context)) return await next();
|
|
24
|
+
|
|
25
|
+
const request = c.req.raw.clone();
|
|
26
|
+
const correlationId = c.get("correlationId");
|
|
27
|
+
const body = await HttpLoggerHonoMiddleware.parseJSON(request);
|
|
28
|
+
|
|
29
|
+
const { stopwatch } = this.middleware.before(context, correlationId, body);
|
|
30
|
+
|
|
31
|
+
await next();
|
|
32
|
+
|
|
33
|
+
const response = c.res.clone();
|
|
34
|
+
const responseBody = await HttpLoggerHonoMiddleware.parseJSON(response);
|
|
35
|
+
|
|
36
|
+
this.middleware.after(context, correlationId, {
|
|
37
|
+
stopwatch,
|
|
38
|
+
status: response.status,
|
|
39
|
+
cacheHit: response.headers.get(CacheResponseMiddleware.CACHE_HIT_HEADER) === CacheSourceEnum.hit,
|
|
40
|
+
responseBody,
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
private static async parseJSON(resource: Request | Response): Promise<any> {
|
|
46
|
+
try {
|
|
47
|
+
return await resource.json();
|
|
48
|
+
} catch {}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
@@ -1,9 +1,6 @@
|
|
|
1
|
-
import { createMiddleware } from "hono/factory";
|
|
2
|
-
import { CacheSourceEnum } from "./cache-resolver.strategy";
|
|
3
|
-
import { CacheResponse } from "./cache-response.middleware";
|
|
4
1
|
import type { ClockPort } from "./clock.port";
|
|
5
2
|
import { type LoggerPort, LogLevelEnum } from "./logger.port";
|
|
6
|
-
import {
|
|
3
|
+
import type { HasRequestPath, RequestContext } from "./request-context.port";
|
|
7
4
|
import { Stopwatch } from "./stopwatch.service";
|
|
8
5
|
|
|
9
6
|
export const UNINFORMATIVE_HEADERS = [
|
|
@@ -30,75 +27,71 @@ export const UNINFORMATIVE_HEADERS = [
|
|
|
30
27
|
|
|
31
28
|
type Dependencies = { Logger: LoggerPort; Clock: ClockPort };
|
|
32
29
|
|
|
33
|
-
export type
|
|
30
|
+
export type HttpLoggerConfig = { skip?: ReadonlyArray<string> };
|
|
34
31
|
|
|
35
|
-
export
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
32
|
+
export type HttpLoggerBeforeResult = { stopwatch: Stopwatch };
|
|
33
|
+
export type HttpLoggerAfterInput = {
|
|
34
|
+
stopwatch: Stopwatch;
|
|
35
|
+
status: number;
|
|
36
|
+
cacheHit: boolean;
|
|
37
|
+
responseBody: any;
|
|
38
|
+
};
|
|
40
39
|
|
|
41
|
-
|
|
40
|
+
export class HttpLoggerMiddleware {
|
|
41
|
+
constructor(
|
|
42
|
+
private readonly deps: Dependencies,
|
|
43
|
+
private readonly config?: HttpLoggerConfig,
|
|
44
|
+
) {}
|
|
42
45
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
// Stryker restore all
|
|
46
|
+
shouldSkip(context: HasRequestPath): boolean {
|
|
47
|
+
return this.config?.skip?.some((prefix) => context.request.path.startsWith(prefix)) ?? false;
|
|
48
|
+
}
|
|
48
49
|
|
|
49
|
-
|
|
50
|
+
before(context: RequestContext, correlationId: string, body: any = {}): HttpLoggerBeforeResult {
|
|
51
|
+
const client = { ip: context.identity.ip(), ua: context.identity.ua() };
|
|
50
52
|
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
),
|
|
53
|
+
const metadata = {
|
|
54
|
+
params: context.request.params(),
|
|
55
|
+
headers: Object.fromEntries(
|
|
56
|
+
Object.entries(context.request.headersObject()).filter(
|
|
57
|
+
([header]) => !UNINFORMATIVE_HEADERS.includes(header),
|
|
57
58
|
),
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
deps.Logger.http({
|
|
63
|
-
component: "http",
|
|
64
|
-
operation: "http_request_before",
|
|
65
|
-
correlationId,
|
|
66
|
-
message: "request",
|
|
67
|
-
method: request.method,
|
|
68
|
-
url: request.url,
|
|
69
|
-
client,
|
|
70
|
-
metadata: httpRequestBeforeMetadata,
|
|
71
|
-
});
|
|
59
|
+
),
|
|
60
|
+
body,
|
|
61
|
+
query: context.request.query(),
|
|
62
|
+
};
|
|
72
63
|
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
64
|
+
this.deps.Logger.http({
|
|
65
|
+
component: "http",
|
|
66
|
+
operation: "http_request_before",
|
|
67
|
+
correlationId,
|
|
68
|
+
message: "request",
|
|
69
|
+
method: context.request.method,
|
|
70
|
+
url: context.request.url(),
|
|
71
|
+
client,
|
|
72
|
+
metadata,
|
|
73
|
+
});
|
|
76
74
|
|
|
77
|
-
|
|
75
|
+
return { stopwatch: new Stopwatch(this.deps) };
|
|
76
|
+
}
|
|
78
77
|
|
|
79
|
-
|
|
78
|
+
after(context: RequestContext, correlationId: string, input: HttpLoggerAfterInput): void {
|
|
79
|
+
const client = { ip: context.identity.ip(), ua: context.identity.ua() };
|
|
80
|
+
const duration = input.stopwatch.stop();
|
|
81
|
+
const level = input.status >= 400 ? LogLevelEnum.error : LogLevelEnum.http;
|
|
80
82
|
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
});
|
|
83
|
+
this.deps.Logger[level]({
|
|
84
|
+
component: "http",
|
|
85
|
+
operation: "http_request_after",
|
|
86
|
+
correlationId,
|
|
87
|
+
message: "response",
|
|
88
|
+
method: context.request.method,
|
|
89
|
+
url: context.request.url(),
|
|
90
|
+
status: input.status,
|
|
91
|
+
durationMs: duration.ms,
|
|
92
|
+
client,
|
|
93
|
+
cacheHit: input.cacheHit,
|
|
94
|
+
metadata: { response: input.responseBody },
|
|
94
95
|
});
|
|
95
|
-
|
|
96
|
-
private static async parseJSON(resource: Request | Response) {
|
|
97
|
-
let result: any;
|
|
98
|
-
try {
|
|
99
|
-
result = await resource.json();
|
|
100
|
-
} catch {}
|
|
101
|
-
|
|
102
|
-
return result;
|
|
103
96
|
}
|
|
104
97
|
}
|
package/src/i18n.service.ts
CHANGED
|
@@ -11,7 +11,7 @@ export type TranslationVariableType = Record<TranslationPlaceholderType, Transla
|
|
|
11
11
|
|
|
12
12
|
export type TranslationsSupportedLanguagesType = Record<string, string>;
|
|
13
13
|
|
|
14
|
-
export type
|
|
14
|
+
export type I18nConfig = {
|
|
15
15
|
supportedLanguages: TranslationsSupportedLanguagesType;
|
|
16
16
|
translationsPath?: tools.DirectoryPathRelativeType;
|
|
17
17
|
defaultLanguage?: string;
|
|
@@ -4,7 +4,7 @@ import type { ImageInfoPort, ImageInfoType } from "./image-info.port";
|
|
|
4
4
|
export class ImageInfoNoopAdapter implements ImageInfoPort {
|
|
5
5
|
constructor(private readonly mime: tools.Mime) {}
|
|
6
6
|
|
|
7
|
-
async inspect(
|
|
7
|
+
async inspect(_input: tools.FilePathRelative | tools.FilePathAbsolute): Promise<ImageInfoType> {
|
|
8
8
|
return {
|
|
9
9
|
width: tools.ImageWidth.parse(400),
|
|
10
10
|
height: tools.ImageHeight.parse(400),
|
|
@@ -37,10 +37,10 @@ export class ImageInfoSharpAdapter implements ImageInfoPort {
|
|
|
37
37
|
}
|
|
38
38
|
// Stryker restore all
|
|
39
39
|
|
|
40
|
-
async inspect(
|
|
41
|
-
const size = await this.deps.FileInspection.size(
|
|
40
|
+
async inspect(input: tools.FilePathRelative | tools.FilePathAbsolute): Promise<ImageInfoType> {
|
|
41
|
+
const size = await this.deps.FileInspection.size(input);
|
|
42
42
|
|
|
43
|
-
const pipeline = this.sharp(
|
|
43
|
+
const pipeline = this.sharp(input.get());
|
|
44
44
|
using _sharp_ = { [Symbol.dispose]: () => pipeline.destroy() };
|
|
45
45
|
|
|
46
46
|
const metadata = await pipeline.metadata();
|
package/src/image-info.port.ts
CHANGED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { InFlightRequestsMiddleware } from "./in-flight-requests.middleware";
|
|
3
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
4
|
+
|
|
5
|
+
export class InFlightRequestsHonoMiddleware implements MiddlewareHonoPort {
|
|
6
|
+
private readonly middleware = new InFlightRequestsMiddleware();
|
|
7
|
+
|
|
8
|
+
handle(): MiddlewareHandler {
|
|
9
|
+
return async (_c, next) => {
|
|
10
|
+
await this.middleware.evaluate();
|
|
11
|
+
|
|
12
|
+
try {
|
|
13
|
+
await next();
|
|
14
|
+
} finally {
|
|
15
|
+
this.middleware.cleanup();
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
}
|
|
@@ -15,10 +15,8 @@ export class InFlightRequestsTracker {
|
|
|
15
15
|
return InFlightRequestsTracker.count;
|
|
16
16
|
}
|
|
17
17
|
|
|
18
|
-
// Stryker disable all
|
|
19
18
|
/** @internal */
|
|
20
19
|
static _resetForTest(): void {
|
|
21
20
|
InFlightRequestsTracker.count = tools.Integer.parse(0);
|
|
22
21
|
}
|
|
23
|
-
// Stryker restore all
|
|
24
22
|
}
|
|
@@ -1,15 +1,11 @@
|
|
|
1
|
-
import { createMiddleware } from "hono/factory";
|
|
2
1
|
import { InFlightRequestsTracker } from "./in-flight-requests-tracker.service";
|
|
3
2
|
|
|
4
|
-
export class
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
3
|
+
export class InFlightRequestsMiddleware {
|
|
4
|
+
async evaluate(): Promise<void> {
|
|
5
|
+
InFlightRequestsTracker.increment();
|
|
6
|
+
}
|
|
8
7
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
InFlightRequestsTracker.decrement();
|
|
13
|
-
}
|
|
14
|
-
});
|
|
8
|
+
cleanup(): void {
|
|
9
|
+
InFlightRequestsTracker.decrement();
|
|
10
|
+
}
|
|
15
11
|
}
|