@bgord/bun 1.10.22 → 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 +10 -10
- 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,27 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import type { AbVariant } from "./ab-variant.vo";
|
|
3
|
+
import type { AbVariants } from "./ab-variants.vo";
|
|
4
|
+
import type { Hash } from "./hash.vo";
|
|
5
|
+
import { HashBucket } from "./hash-bucket.vo";
|
|
6
|
+
|
|
7
|
+
// Stryker disable all
|
|
8
|
+
export const AbVariantSelectorError = { NoVariantSelected: "ab.variant.selector.no.variant.selected" };
|
|
9
|
+
// Stryker restore all
|
|
10
|
+
|
|
11
|
+
export class AbVariantSelector {
|
|
12
|
+
constructor(private readonly variants: AbVariants) {}
|
|
13
|
+
|
|
14
|
+
select(hash: Hash): AbVariant {
|
|
15
|
+
const bucket = HashBucket.fromHash(hash);
|
|
16
|
+
|
|
17
|
+
let cumulative = tools.IntegerNonNegative.parse(0);
|
|
18
|
+
|
|
19
|
+
for (const variant of this.variants.variants) {
|
|
20
|
+
cumulative = tools.IntegerNonNegative.parse(cumulative + variant.config.weight);
|
|
21
|
+
|
|
22
|
+
if (bucket.isLessThan(cumulative)) return variant;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
throw new Error(AbVariantSelectorError.NoVariantSelected);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import * as z from "zod/v4";
|
|
2
|
+
|
|
3
|
+
export const AbVariantWeightErrors = { MinMax: "ab.variant.weight.min.max" };
|
|
4
|
+
|
|
5
|
+
// Stryker disable all
|
|
6
|
+
export const AbVariantWeight = z
|
|
7
|
+
// Stryker restore all
|
|
8
|
+
.int(AbVariantWeightErrors.MinMax)
|
|
9
|
+
.gte(1, AbVariantWeightErrors.MinMax)
|
|
10
|
+
.lte(99, AbVariantWeightErrors.MinMax)
|
|
11
|
+
.brand("AbVariantWeight");
|
|
12
|
+
|
|
13
|
+
export type AbVariantWeightType = z.infer<typeof AbVariantWeight>;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import type { AbVariant } from "./ab-variant.vo";
|
|
3
|
+
|
|
4
|
+
export const AbVariantsError = {
|
|
5
|
+
Min: "ab.variants.min",
|
|
6
|
+
Max: "ab.variants.max",
|
|
7
|
+
UniqueNames: "ab.variants.unique.names",
|
|
8
|
+
Sum: "ab.variants.sum",
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export class AbVariants {
|
|
12
|
+
constructor(readonly variants: ReadonlyArray<AbVariant>) {
|
|
13
|
+
if (variants.length <= 1) throw new Error(AbVariantsError.Min);
|
|
14
|
+
if (variants.length > 5) throw new Error(AbVariantsError.Max);
|
|
15
|
+
|
|
16
|
+
const names = new Set(variants.map((variant) => variant.config.name));
|
|
17
|
+
|
|
18
|
+
if (names.size !== variants.length) throw new Error(AbVariantsError.UniqueNames);
|
|
19
|
+
|
|
20
|
+
const sum = tools.Sum.of(variants.map((variant) => variant.config.weight));
|
|
21
|
+
|
|
22
|
+
if (sum !== 100) throw new Error(AbVariantsError.Sum);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { AbAssignmentStrategy } from "./ab-assignment.strategy";
|
|
2
|
+
import type { AbVariant } from "./ab-variant.vo";
|
|
3
|
+
import type { AbVariants } from "./ab-variants.vo";
|
|
4
|
+
import type { RequestContext } from "./request-context.port";
|
|
5
|
+
|
|
6
|
+
export class AbMiddleware {
|
|
7
|
+
constructor(
|
|
8
|
+
private readonly variants: AbVariants,
|
|
9
|
+
private readonly strategy: AbAssignmentStrategy,
|
|
10
|
+
) {}
|
|
11
|
+
|
|
12
|
+
async evaluate(context: RequestContext): Promise<AbVariant | undefined> {
|
|
13
|
+
return this.strategy.assign(context, this.variants);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import { ApiVersionMiddleware } from "./api-version.middleware";
|
|
3
|
+
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
4
|
+
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
5
|
+
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
6
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
7
|
+
|
|
8
|
+
type Dependencies = {
|
|
9
|
+
CacheResolver: CacheResolverStrategy;
|
|
10
|
+
HashContent: HashContentStrategy;
|
|
11
|
+
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export class ApiVersionHonoMiddleware implements MiddlewareHonoPort {
|
|
15
|
+
private readonly middleware: ApiVersionMiddleware;
|
|
16
|
+
|
|
17
|
+
constructor(deps: Dependencies) {
|
|
18
|
+
this.middleware = new ApiVersionMiddleware(deps);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
handle(): MiddlewareHandler {
|
|
22
|
+
return async (c, next) => {
|
|
23
|
+
const version = await this.middleware.evaluate();
|
|
24
|
+
|
|
25
|
+
c.res.headers.set(ApiVersionMiddleware.HEADER_NAME, version.toString());
|
|
26
|
+
|
|
27
|
+
return next();
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
2
|
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
3
3
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
4
|
-
import { CacheSubjectApplicationResolver } from "./cache-subject-application-resolver.vo";
|
|
5
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
6
4
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
5
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
6
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
7
7
|
|
|
8
8
|
type Dependencies = {
|
|
9
9
|
CacheResolver: CacheResolverStrategy;
|
|
@@ -11,21 +11,22 @@ type Dependencies = {
|
|
|
11
11
|
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
12
12
|
};
|
|
13
13
|
|
|
14
|
-
export class
|
|
14
|
+
export class ApiVersionMiddleware {
|
|
15
15
|
static readonly HEADER_NAME = "api-version";
|
|
16
16
|
|
|
17
|
-
|
|
18
|
-
createMiddleware(async (c, next) => {
|
|
19
|
-
const resolver = new CacheSubjectApplicationResolver(
|
|
20
|
-
[new CacheSubjectSegmentFixedStrategy("api-version")],
|
|
21
|
-
deps,
|
|
22
|
-
);
|
|
23
|
-
const subject = await resolver.resolve();
|
|
17
|
+
constructor(private readonly deps: Dependencies) {}
|
|
24
18
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
)
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
19
|
+
async evaluate(): Promise<tools.PackageVersion> {
|
|
20
|
+
const resolver = new SubjectApplicationResolver(
|
|
21
|
+
[new SubjectSegmentFixedStrategy("api-version")],
|
|
22
|
+
this.deps,
|
|
23
|
+
);
|
|
24
|
+
const subject = await resolver.resolve();
|
|
25
|
+
|
|
26
|
+
const build = await this.deps.CacheResolver.resolve(subject.hex, async () =>
|
|
27
|
+
this.deps.BuildInfoRepository.extract(),
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
return build.version;
|
|
31
|
+
}
|
|
31
32
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { HasRequestHeaders } from "./request-context.port";
|
|
2
2
|
|
|
3
|
+
export type AuthSessionType<User, Session> = { user: User; session: Session } | { user: null; session: null };
|
|
4
|
+
|
|
3
5
|
export interface AuthSessionReaderPort<User, Session> {
|
|
4
|
-
getSession(
|
|
5
|
-
context: HasRequestHeaders,
|
|
6
|
-
): Promise<{ user: User; session: Session } | { user: null; session: null }>;
|
|
6
|
+
getSession(context: HasRequestHeaders): Promise<AuthSessionType<User, Session>>;
|
|
7
7
|
}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import type { BasicAuthPasswordType } from "./basic-auth-password.vo";
|
|
2
2
|
import type { BasicAuthUsernameType } from "./basic-auth-username.vo";
|
|
3
3
|
|
|
4
|
-
type
|
|
4
|
+
type Config = { username: BasicAuthUsernameType; password: BasicAuthPasswordType };
|
|
5
5
|
|
|
6
6
|
export class BasicAuth {
|
|
7
|
-
static toHeaderValue(config:
|
|
7
|
+
static toHeaderValue(config: Config): { authorization: string } {
|
|
8
8
|
return { authorization: `Basic ${btoa(`${config.username}:${config.password}`)}` };
|
|
9
9
|
}
|
|
10
10
|
|
|
11
|
-
static toHeader(config:
|
|
11
|
+
static toHeader(config: Config): Headers {
|
|
12
12
|
return new Headers(BasicAuth.toHeaderValue(config));
|
|
13
13
|
}
|
|
14
14
|
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import type { ContentfulStatusCode } from "hono/utils/http-status";
|
|
3
|
+
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
4
|
+
import type { CacheResponseConfig } from "./cache-response.middleware";
|
|
5
|
+
import { CacheResponseMiddleware } from "./cache-response.middleware";
|
|
6
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
7
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
8
|
+
|
|
9
|
+
type Dependencies = { CacheResolver: CacheResolverStrategy };
|
|
10
|
+
|
|
11
|
+
export class CacheResponseHonoMiddleware implements MiddlewareHonoPort {
|
|
12
|
+
private readonly middleware: CacheResponseMiddleware;
|
|
13
|
+
|
|
14
|
+
constructor(config: CacheResponseConfig, deps: Dependencies) {
|
|
15
|
+
this.middleware = new CacheResponseMiddleware(config, deps);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
handle() {
|
|
19
|
+
return createMiddleware(async (c, next) => {
|
|
20
|
+
const context = new RequestContextHonoAdapter(c);
|
|
21
|
+
|
|
22
|
+
const result = await this.middleware.evaluate(context, async () => {
|
|
23
|
+
await next();
|
|
24
|
+
|
|
25
|
+
const response = c.res.clone();
|
|
26
|
+
|
|
27
|
+
return {
|
|
28
|
+
body: await response.text(),
|
|
29
|
+
headers: response.headers.toJSON(),
|
|
30
|
+
status: response.status as ContentfulStatusCode,
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
if (!result) return next();
|
|
35
|
+
|
|
36
|
+
c.header(CacheResponseMiddleware.CACHE_HIT_HEADER, result.source);
|
|
37
|
+
|
|
38
|
+
return c.newResponse(
|
|
39
|
+
result.response.body,
|
|
40
|
+
result.response.status as ContentfulStatusCode,
|
|
41
|
+
result.response.headers,
|
|
42
|
+
);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
clear() {
|
|
47
|
+
return createMiddleware(async (_c, next) => {
|
|
48
|
+
await this.middleware.clear();
|
|
49
|
+
|
|
50
|
+
return next();
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
@@ -1,53 +1,47 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import type {
|
|
3
|
-
import type {
|
|
4
|
-
import type { CacheSubjectRequestResolver } from "./cache-subject-request-resolver.vo";
|
|
5
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
1
|
+
import type { CacheResolverStrategy, CacheSourceEnum } from "./cache-resolver.strategy";
|
|
2
|
+
import type { RequestContext } from "./request-context.port";
|
|
3
|
+
import type { SubjectRequestResolver } from "./subject-request-resolver.vo";
|
|
6
4
|
|
|
7
5
|
type Dependencies = { CacheResolver: CacheResolverStrategy };
|
|
8
6
|
|
|
9
|
-
type
|
|
7
|
+
export type CacheResponseConfig = { enabled: boolean; resolver: SubjectRequestResolver };
|
|
10
8
|
|
|
11
|
-
type CachedResponse = {
|
|
12
|
-
body:
|
|
9
|
+
export type CachedResponse<T = string> = {
|
|
10
|
+
body: T;
|
|
13
11
|
headers: Record<string, string>;
|
|
14
|
-
status:
|
|
12
|
+
status: number;
|
|
15
13
|
};
|
|
16
14
|
|
|
17
|
-
export
|
|
15
|
+
export type CacheResponseResult<T = string> = {
|
|
16
|
+
response: CachedResponse<T>;
|
|
17
|
+
source: CacheSourceEnum;
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
export class CacheResponseMiddleware {
|
|
18
21
|
static readonly CACHE_HIT_HEADER = "Cache-Hit";
|
|
19
22
|
|
|
20
23
|
constructor(
|
|
21
|
-
private readonly config:
|
|
24
|
+
private readonly config: CacheResponseConfig,
|
|
22
25
|
private readonly deps: Dependencies,
|
|
23
26
|
) {}
|
|
24
27
|
|
|
25
|
-
|
|
26
|
-
|
|
28
|
+
async evaluate<T = string>(
|
|
29
|
+
context: RequestContext,
|
|
30
|
+
generateResponse: () => Promise<CachedResponse<T>>,
|
|
31
|
+
): Promise<CacheResponseResult<T> | null> {
|
|
32
|
+
if (!this.config.enabled) return null;
|
|
27
33
|
|
|
28
|
-
const context = new RequestContextAdapterHono(c);
|
|
29
34
|
const subject = await this.config.resolver.resolve(context);
|
|
30
35
|
|
|
31
|
-
const result = await this.deps.CacheResolver.resolveWithContext<CachedResponse
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
36
|
+
const result = await this.deps.CacheResolver.resolveWithContext<CachedResponse<T>>(
|
|
37
|
+
subject.hex,
|
|
38
|
+
generateResponse,
|
|
39
|
+
);
|
|
35
40
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
headers: response.headers.toJSON(),
|
|
39
|
-
status: response.status as ContentfulStatusCode,
|
|
40
|
-
};
|
|
41
|
-
});
|
|
41
|
+
return { response: result.value, source: result.source };
|
|
42
|
+
}
|
|
42
43
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
return c.newResponse(result.value.body, result.value.status, result.value.headers);
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
clear = createMiddleware(async (_, next) => {
|
|
44
|
+
async clear(): Promise<void> {
|
|
49
45
|
await this.deps.CacheResolver.flush();
|
|
50
|
-
|
|
51
|
-
return next();
|
|
52
|
-
});
|
|
46
|
+
}
|
|
53
47
|
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import { CorrelationIdMiddleware } from "./correlation-id.middleware";
|
|
3
|
+
import { CorrelationStorage } from "./correlation-storage.service";
|
|
4
|
+
import type { IdProviderPort } from "./id-provider.port";
|
|
5
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
6
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
7
|
+
import type { UUIDType } from "./uuid.vo";
|
|
8
|
+
|
|
9
|
+
type Dependencies = { IdProvider: IdProviderPort };
|
|
10
|
+
|
|
11
|
+
export type CorrelationVariables = { correlationId: UUIDType };
|
|
12
|
+
|
|
13
|
+
export class CorrelationHonoMiddleware implements MiddlewareHonoPort {
|
|
14
|
+
private readonly correlationId: CorrelationIdMiddleware;
|
|
15
|
+
|
|
16
|
+
constructor(deps: Dependencies) {
|
|
17
|
+
this.correlationId = new CorrelationIdMiddleware(deps);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
handle() {
|
|
21
|
+
return createMiddleware(async (c, next) => {
|
|
22
|
+
const context = new RequestContextHonoAdapter(c);
|
|
23
|
+
|
|
24
|
+
const result = this.correlationId.evaluate(context);
|
|
25
|
+
|
|
26
|
+
c.set("correlationId", result);
|
|
27
|
+
c.header(CorrelationIdMiddleware.HEADER_NAME, result);
|
|
28
|
+
|
|
29
|
+
return CorrelationStorage.run(result, next);
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { IdProviderPort } from "./id-provider.port";
|
|
2
|
+
import type { HasRequestHeader } from "./request-context.port";
|
|
3
|
+
import { UUID, type UUIDType } from "./uuid.vo";
|
|
4
|
+
|
|
5
|
+
type Dependencies = { IdProvider: IdProviderPort };
|
|
6
|
+
|
|
7
|
+
export class CorrelationIdMiddleware {
|
|
8
|
+
static readonly HEADER_NAME = "correlation-id";
|
|
9
|
+
|
|
10
|
+
constructor(private readonly deps: Dependencies) {}
|
|
11
|
+
|
|
12
|
+
evaluate(context: HasRequestHeader): UUIDType {
|
|
13
|
+
const incoming = context.request.header(CorrelationIdMiddleware.HEADER_NAME);
|
|
14
|
+
|
|
15
|
+
const existing = UUID.safeParse(incoming);
|
|
16
|
+
|
|
17
|
+
if (existing.success) return existing.data;
|
|
18
|
+
return this.deps.IdProvider.generate();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { AsyncLocalStorage } from "node:async_hooks";
|
|
2
|
-
import { createMiddleware } from "hono/factory";
|
|
3
2
|
import type { CorrelationIdType } from "./correlation-id.vo";
|
|
4
3
|
|
|
5
4
|
type CorrelationContext = { correlationId: CorrelationIdType };
|
|
@@ -25,6 +24,4 @@ export class CorrelationStorage {
|
|
|
25
24
|
if (!store) throw new Error(CorrelationStorageError.Missing);
|
|
26
25
|
return store.correlationId;
|
|
27
26
|
}
|
|
28
|
-
|
|
29
|
-
static handle = () => createMiddleware(async (c, next) => CorrelationStorage.run(c.get("requestId"), next));
|
|
30
27
|
}
|
|
@@ -1,22 +1,24 @@
|
|
|
1
1
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
2
|
-
import { CacheSubjectApplicationResolver } from "./cache-subject-application-resolver.vo";
|
|
3
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
4
2
|
import type { CryptoKeyProviderPort } from "./crypto-key-provider.port";
|
|
5
3
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
4
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
5
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
6
6
|
|
|
7
7
|
type Dependencies = { CacheResolver: CacheResolverStrategy; HashContent: HashContentStrategy };
|
|
8
8
|
|
|
9
|
+
type Config = { id: string; inner: CryptoKeyProviderPort };
|
|
10
|
+
|
|
9
11
|
export class CryptoKeyProviderWithCacheAdapter implements CryptoKeyProviderPort {
|
|
10
12
|
constructor(
|
|
11
|
-
private readonly config:
|
|
13
|
+
private readonly config: Config,
|
|
12
14
|
private readonly deps: Dependencies,
|
|
13
15
|
) {}
|
|
14
16
|
|
|
15
17
|
async get(): Promise<CryptoKey> {
|
|
16
|
-
const resolver = new
|
|
18
|
+
const resolver = new SubjectApplicationResolver(
|
|
17
19
|
[
|
|
18
|
-
new
|
|
19
|
-
new
|
|
20
|
+
new SubjectSegmentFixedStrategy("crypto_key_provider"),
|
|
21
|
+
new SubjectSegmentFixedStrategy(this.config.id),
|
|
20
22
|
],
|
|
21
23
|
this.deps,
|
|
22
24
|
);
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import type * as z from "zod/v4";
|
|
2
2
|
import type { NodeEnvironmentEnum } from "../src/node-env.vo";
|
|
3
3
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
4
|
-
import { CacheSubjectApplicationResolver } from "./cache-subject-application-resolver.vo";
|
|
5
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
6
4
|
import type { EnvironmentLoaderPort, EnvironmentResultType } from "./environment-loader.port";
|
|
7
5
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
6
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
7
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
8
8
|
|
|
9
9
|
type Dependencies = { CacheResolver: CacheResolverStrategy; HashContent: HashContentStrategy };
|
|
10
10
|
|
|
@@ -18,10 +18,7 @@ export class EnvironmentLoaderProcessSafeAdapter<Schema extends z.ZodObject<any>
|
|
|
18
18
|
) {}
|
|
19
19
|
|
|
20
20
|
async load(): Promise<Readonly<EnvironmentResultType<Schema>>> {
|
|
21
|
-
const resolver = new
|
|
22
|
-
[new CacheSubjectSegmentFixedStrategy("env")],
|
|
23
|
-
this.deps,
|
|
24
|
-
);
|
|
21
|
+
const resolver = new SubjectApplicationResolver([new SubjectSegmentFixedStrategy("env")], this.deps);
|
|
25
22
|
const subject = await resolver.resolve();
|
|
26
23
|
|
|
27
24
|
const result = await this.deps.CacheResolver.resolve(subject.hex, async () =>
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { MiddlewareHandler } from "hono";
|
|
3
|
+
import { ETagExtractorMiddleware } from "./etag-extractor.middleware";
|
|
4
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
5
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
6
|
+
|
|
7
|
+
/** @public */
|
|
8
|
+
export type ETagVariables = { ETag: tools.ETag | null };
|
|
9
|
+
|
|
10
|
+
export class ETagExtractorHonoMiddleware implements MiddlewareHonoPort {
|
|
11
|
+
private readonly middleware: ETagExtractorMiddleware;
|
|
12
|
+
|
|
13
|
+
constructor() {
|
|
14
|
+
this.middleware = new ETagExtractorMiddleware();
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
handle(): MiddlewareHandler {
|
|
18
|
+
return async (c, next) => {
|
|
19
|
+
const context = new RequestContextHonoAdapter(c);
|
|
20
|
+
const etag = this.middleware.evaluate(context);
|
|
21
|
+
|
|
22
|
+
c.set("ETag", etag);
|
|
23
|
+
|
|
24
|
+
await next();
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -1,20 +1,14 @@
|
|
|
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 ETagExtractor {
|
|
8
|
-
static attach = createMiddleware<{ Variables: EtagVariables }>(async (c, next) => {
|
|
4
|
+
export class ETagExtractorMiddleware {
|
|
5
|
+
evaluate(context: RequestContext): tools.ETag | null {
|
|
9
6
|
try {
|
|
10
|
-
const context = new RequestContextAdapterHono(c);
|
|
11
7
|
const header = context.request.header(tools.ETag.IF_MATCH_HEADER_NAME);
|
|
12
8
|
|
|
13
|
-
|
|
9
|
+
return tools.ETag.fromHeader(header);
|
|
14
10
|
} catch {
|
|
15
|
-
|
|
11
|
+
return null;
|
|
16
12
|
}
|
|
17
|
-
|
|
18
|
-
await next();
|
|
19
|
-
});
|
|
13
|
+
}
|
|
20
14
|
}
|
package/src/event-store.ts
CHANGED
|
@@ -14,10 +14,10 @@ type InserterEventsHandler = (
|
|
|
14
14
|
events: ReadonlyArray<z.infer<GenericParsedEventSchema>>,
|
|
15
15
|
) => Promise<ReadonlyArray<z.infer<GenericParsedEventSchema>>>;
|
|
16
16
|
|
|
17
|
-
type
|
|
17
|
+
type Config = { finder: FindEventsHandler; inserter: InserterEventsHandler };
|
|
18
18
|
|
|
19
19
|
export class EventStore<AllEvents extends GenericEventSchema> {
|
|
20
|
-
constructor(private readonly config:
|
|
20
|
+
constructor(private readonly config: Config) {}
|
|
21
21
|
|
|
22
22
|
static EMPTY_STREAM_REVISION = -1;
|
|
23
23
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as tools from "@bgord/tools";
|
|
2
2
|
import type { FileInspectionPort } from "./file-inspection.port";
|
|
3
3
|
|
|
4
|
-
type
|
|
4
|
+
type Config = {
|
|
5
5
|
exists: boolean;
|
|
6
6
|
isDirectory?: boolean;
|
|
7
7
|
permissions?: { read?: boolean; write?: boolean; execute?: boolean };
|
|
@@ -10,7 +10,7 @@ type FileInspectionNoopAdapterConfigType = {
|
|
|
10
10
|
};
|
|
11
11
|
|
|
12
12
|
export class FileInspectionNoopAdapter implements FileInspectionPort {
|
|
13
|
-
constructor(private readonly config:
|
|
13
|
+
constructor(private readonly config: Config) {}
|
|
14
14
|
|
|
15
15
|
async exists(_path: tools.FilePathRelative | tools.FilePathAbsolute | string): Promise<boolean> {
|
|
16
16
|
return this.config.exists;
|
|
@@ -1,26 +1,27 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
2
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
3
|
-
import { CacheSubjectApplicationResolver } from "./cache-subject-application-resolver.vo";
|
|
4
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
5
3
|
import type { FileReaderJsonOutputType, FileReaderJsonPort } from "./file-reader-json.port";
|
|
6
4
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
5
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
6
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
7
7
|
|
|
8
8
|
type Dependencies = { CacheResolver: CacheResolverStrategy; HashContent: HashContentStrategy };
|
|
9
|
+
type Config = { id: string; inner: FileReaderJsonPort };
|
|
9
10
|
|
|
10
11
|
export class FileReaderJsonWithCacheAdapter implements FileReaderJsonPort {
|
|
11
12
|
constructor(
|
|
12
|
-
private readonly config:
|
|
13
|
+
private readonly config: Config,
|
|
13
14
|
private readonly deps: Dependencies,
|
|
14
15
|
) {}
|
|
15
16
|
|
|
16
17
|
async read(
|
|
17
18
|
path: tools.FilePathRelative | tools.FilePathAbsolute | string,
|
|
18
19
|
): Promise<FileReaderJsonOutputType> {
|
|
19
|
-
const resolver = new
|
|
20
|
+
const resolver = new SubjectApplicationResolver(
|
|
20
21
|
[
|
|
21
|
-
new
|
|
22
|
-
new
|
|
23
|
-
new
|
|
22
|
+
new SubjectSegmentFixedStrategy("file_reader_json"),
|
|
23
|
+
new SubjectSegmentFixedStrategy(this.config.id),
|
|
24
|
+
new SubjectSegmentFixedStrategy(typeof path === "string" ? path : path.get()),
|
|
24
25
|
],
|
|
25
26
|
this.deps,
|
|
26
27
|
);
|
|
@@ -1,24 +1,25 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
2
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
3
|
-
import { CacheSubjectApplicationResolver } from "./cache-subject-application-resolver.vo";
|
|
4
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
5
3
|
import type { FileReaderRawPort } from "./file-reader-raw.port";
|
|
6
4
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
5
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
6
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
7
7
|
|
|
8
8
|
type Dependencies = { CacheResolver: CacheResolverStrategy; HashContent: HashContentStrategy };
|
|
9
|
+
type Config = { id: string; inner: FileReaderRawPort };
|
|
9
10
|
|
|
10
11
|
export class FileReaderRawWithCacheAdapter implements FileReaderRawPort {
|
|
11
12
|
constructor(
|
|
12
|
-
private readonly config:
|
|
13
|
+
private readonly config: Config,
|
|
13
14
|
private readonly deps: Dependencies,
|
|
14
15
|
) {}
|
|
15
16
|
|
|
16
17
|
async read(path: tools.FilePathRelative | tools.FilePathAbsolute | string): Promise<ArrayBuffer> {
|
|
17
|
-
const resolver = new
|
|
18
|
+
const resolver = new SubjectApplicationResolver(
|
|
18
19
|
[
|
|
19
|
-
new
|
|
20
|
-
new
|
|
21
|
-
new
|
|
20
|
+
new SubjectSegmentFixedStrategy("file_reader_raw"),
|
|
21
|
+
new SubjectSegmentFixedStrategy(this.config.id),
|
|
22
|
+
new SubjectSegmentFixedStrategy(typeof path === "string" ? path : path.get()),
|
|
22
23
|
],
|
|
23
24
|
this.deps,
|
|
24
25
|
);
|
|
@@ -1,24 +1,25 @@
|
|
|
1
1
|
import type * as tools from "@bgord/tools";
|
|
2
2
|
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
3
|
-
import { CacheSubjectApplicationResolver } from "./cache-subject-application-resolver.vo";
|
|
4
|
-
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
5
3
|
import type { FileReaderTextPort } from "./file-reader-text.port";
|
|
6
4
|
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
5
|
+
import { SubjectApplicationResolver } from "./subject-application-resolver.vo";
|
|
6
|
+
import { SubjectSegmentFixedStrategy } from "./subject-segment-fixed.strategy";
|
|
7
7
|
|
|
8
8
|
type Dependencies = { CacheResolver: CacheResolverStrategy; HashContent: HashContentStrategy };
|
|
9
|
+
type Config = { id: string; inner: FileReaderTextPort };
|
|
9
10
|
|
|
10
11
|
export class FileReaderTextWithCacheAdapter implements FileReaderTextPort {
|
|
11
12
|
constructor(
|
|
12
|
-
private readonly config:
|
|
13
|
+
private readonly config: Config,
|
|
13
14
|
private readonly deps: Dependencies,
|
|
14
15
|
) {}
|
|
15
16
|
|
|
16
17
|
async read(path: tools.FilePathRelative | tools.FilePathAbsolute | string): Promise<string> {
|
|
17
|
-
const resolver = new
|
|
18
|
+
const resolver = new SubjectApplicationResolver(
|
|
18
19
|
[
|
|
19
|
-
new
|
|
20
|
-
new
|
|
21
|
-
new
|
|
20
|
+
new SubjectSegmentFixedStrategy("file_reader_text"),
|
|
21
|
+
new SubjectSegmentFixedStrategy(this.config.id),
|
|
22
|
+
new SubjectSegmentFixedStrategy(typeof path === "string" ? path : path.get()),
|
|
22
23
|
],
|
|
23
24
|
this.deps,
|
|
24
25
|
);
|