@bgord/bun 1.10.23 → 1.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ab-assignment-composite.strategy.d.ts +10 -0
- package/dist/ab-assignment-composite.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-composite.strategy.js +15 -0
- package/dist/ab-assignment-composite.strategy.js.map +1 -0
- package/dist/ab-assignment-fixed.strategy.d.ts +10 -0
- package/dist/ab-assignment-fixed.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-fixed.strategy.js +10 -0
- package/dist/ab-assignment-fixed.strategy.js.map +1 -0
- package/dist/ab-assignment-hash.strategy.d.ts +12 -0
- package/dist/ab-assignment-hash.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-hash.strategy.js +14 -0
- package/dist/ab-assignment-hash.strategy.js.map +1 -0
- package/dist/ab-assignment-query.strategy.d.ts +10 -0
- package/dist/ab-assignment-query.strategy.d.ts.map +1 -0
- package/dist/ab-assignment-query.strategy.js +11 -0
- package/dist/ab-assignment-query.strategy.js.map +1 -0
- package/dist/ab-assignment.strategy.d.ts +7 -0
- package/dist/ab-assignment.strategy.d.ts.map +1 -0
- package/dist/ab-assignment.strategy.js +2 -0
- package/dist/ab-assignment.strategy.js.map +1 -0
- package/dist/ab-hono-noop.middleware.d.ts +10 -0
- package/dist/ab-hono-noop.middleware.d.ts.map +1 -0
- package/dist/ab-hono-noop.middleware.js +18 -0
- package/dist/ab-hono-noop.middleware.js.map +1 -0
- package/dist/ab-hono.middleware.d.ts +14 -0
- package/dist/ab-hono.middleware.d.ts.map +1 -0
- package/dist/ab-hono.middleware.js +17 -0
- package/dist/ab-hono.middleware.js.map +1 -0
- package/dist/ab-variant-selector.service.d.ts +12 -0
- package/dist/ab-variant-selector.service.d.ts.map +1 -0
- package/dist/ab-variant-selector.service.js +22 -0
- package/dist/ab-variant-selector.service.js.map +1 -0
- package/dist/ab-variant-weight.vo.d.ts +7 -0
- package/dist/ab-variant-weight.vo.d.ts.map +1 -0
- package/dist/ab-variant-weight.vo.js +10 -0
- package/dist/ab-variant-weight.vo.js.map +1 -0
- package/dist/ab-variant.vo.d.ts +11 -0
- package/dist/ab-variant.vo.d.ts.map +1 -0
- package/dist/ab-variant.vo.js +7 -0
- package/dist/ab-variant.vo.js.map +1 -0
- package/dist/ab-variants.vo.d.ts +12 -0
- package/dist/ab-variants.vo.d.ts.map +1 -0
- package/dist/ab-variants.vo.js +24 -0
- package/dist/ab-variants.vo.js.map +1 -0
- package/dist/ab.middleware.d.ts +11 -0
- package/dist/ab.middleware.d.ts.map +1 -0
- package/dist/ab.middleware.js +12 -0
- package/dist/ab.middleware.js.map +1 -0
- package/dist/api-version-hono.middleware.d.ts +17 -0
- package/dist/api-version-hono.middleware.d.ts.map +1 -0
- package/dist/api-version-hono.middleware.js +15 -0
- package/dist/api-version-hono.middleware.js.map +1 -0
- package/dist/api-version.middleware.d.ts +5 -2
- package/dist/api-version.middleware.d.ts.map +1 -1
- package/dist/api-version.middleware.js +12 -10
- package/dist/api-version.middleware.js.map +1 -1
- package/dist/auth-session-reader.port.d.ts +8 -7
- package/dist/auth-session-reader.port.d.ts.map +1 -1
- package/dist/basic-auth.service.d.ts +3 -3
- package/dist/basic-auth.service.d.ts.map +1 -1
- package/dist/basic-auth.service.js.map +1 -1
- package/dist/cache-response-hono.middleware.d.ts +14 -0
- package/dist/cache-response-hono.middleware.d.ts.map +1 -0
- package/dist/cache-response-hono.middleware.js +34 -0
- package/dist/cache-response-hono.middleware.js.map +1 -0
- package/dist/cache-response.middleware.d.ts +18 -8
- package/dist/cache-response.middleware.d.ts.map +1 -1
- package/dist/cache-response.middleware.js +8 -21
- package/dist/cache-response.middleware.js.map +1 -1
- package/dist/command-bus-collecting.adapter.d.ts +10 -0
- package/dist/command-bus-collecting.adapter.d.ts.map +1 -0
- package/dist/command-bus-collecting.adapter.js +8 -0
- package/dist/command-bus-collecting.adapter.js.map +1 -0
- package/dist/command-bus-emittery-v1.adapter.d.ts +11 -0
- package/dist/command-bus-emittery-v1.adapter.d.ts.map +1 -0
- package/dist/command-bus-emittery-v1.adapter.js +14 -0
- package/dist/command-bus-emittery-v1.adapter.js.map +1 -0
- package/dist/command-bus-noop.adapter.d.ts +9 -0
- package/dist/command-bus-noop.adapter.d.ts.map +1 -0
- package/dist/command-bus-noop.adapter.js +5 -0
- package/dist/command-bus-noop.adapter.js.map +1 -0
- package/dist/command-bus-with-logger.adapter.d.ts +18 -0
- package/dist/command-bus-with-logger.adapter.d.ts.map +1 -0
- package/dist/command-bus-with-logger.adapter.js +21 -0
- package/dist/command-bus-with-logger.adapter.js.map +1 -0
- package/dist/command-bus.port.d.ts +8 -0
- package/dist/command-bus.port.d.ts.map +1 -0
- package/dist/command-bus.port.js +2 -0
- package/dist/command-bus.port.js.map +1 -0
- package/dist/correlation-hono.middleware.d.ts +16 -0
- package/dist/correlation-hono.middleware.d.ts.map +1 -0
- package/dist/correlation-hono.middleware.js +20 -0
- package/dist/correlation-hono.middleware.js.map +1 -0
- package/dist/correlation-id.middleware.d.ts +14 -0
- package/dist/correlation-id.middleware.d.ts.map +1 -0
- package/dist/correlation-id.middleware.js +16 -0
- package/dist/correlation-id.middleware.js.map +1 -0
- package/dist/correlation-storage.service.d.ts +0 -1
- package/dist/correlation-storage.service.d.ts.map +1 -1
- package/dist/correlation-storage.service.js +0 -2
- package/dist/correlation-storage.service.js.map +1 -1
- package/dist/crypto-key-provider-with-cache.adapter.d.ts +5 -4
- package/dist/crypto-key-provider-with-cache.adapter.d.ts.map +1 -1
- package/dist/crypto-key-provider-with-cache.adapter.js +5 -5
- package/dist/crypto-key-provider-with-cache.adapter.js.map +1 -1
- package/dist/dispatching-event-store.d.ts +2 -3
- package/dist/dispatching-event-store.d.ts.map +1 -1
- package/dist/dispatching-event-store.js.map +1 -1
- package/dist/environment-loader-process-safe.adapter.d.ts.map +1 -1
- package/dist/environment-loader-process-safe.adapter.js +3 -3
- package/dist/environment-loader-process-safe.adapter.js.map +1 -1
- package/dist/etag-extractor-hono.middleware.d.ts +13 -0
- package/dist/etag-extractor-hono.middleware.d.ts.map +1 -0
- package/dist/etag-extractor-hono.middleware.js +17 -0
- package/dist/etag-extractor-hono.middleware.js.map +1 -0
- package/dist/etag-extractor.middleware.d.ts +3 -8
- package/dist/etag-extractor.middleware.d.ts.map +1 -1
- package/dist/etag-extractor.middleware.js +5 -9
- package/dist/etag-extractor.middleware.js.map +1 -1
- package/dist/event-bus-collecting.adapter.d.ts +10 -0
- package/dist/event-bus-collecting.adapter.d.ts.map +1 -0
- package/dist/event-bus-collecting.adapter.js +8 -0
- package/dist/event-bus-collecting.adapter.js.map +1 -0
- package/dist/event-bus-emittery-v1.adapter.d.ts +11 -0
- package/dist/event-bus-emittery-v1.adapter.d.ts.map +1 -0
- package/dist/event-bus-emittery-v1.adapter.js +14 -0
- package/dist/event-bus-emittery-v1.adapter.js.map +1 -0
- package/dist/event-bus-noop.adapter.d.ts +9 -0
- package/dist/event-bus-noop.adapter.d.ts.map +1 -0
- package/dist/event-bus-noop.adapter.js +5 -0
- package/dist/event-bus-noop.adapter.js.map +1 -0
- package/dist/event-bus-with-logger.adapter.d.ts +18 -0
- package/dist/event-bus-with-logger.adapter.d.ts.map +1 -0
- package/dist/event-bus-with-logger.adapter.js +21 -0
- package/dist/event-bus-with-logger.adapter.js.map +1 -0
- package/dist/event-bus.port.d.ts +8 -0
- package/dist/event-bus.port.d.ts.map +1 -0
- package/dist/event-bus.port.js +2 -0
- package/dist/event-bus.port.js.map +1 -0
- package/dist/event-store.d.ts +2 -2
- package/dist/event-store.d.ts.map +1 -1
- package/dist/event-store.js.map +1 -1
- package/dist/file-inspection-noop.adapter.d.ts +2 -2
- package/dist/file-inspection-noop.adapter.d.ts.map +1 -1
- package/dist/file-inspection-noop.adapter.js.map +1 -1
- package/dist/file-reader-json-with-cache.adapter.d.ts +5 -4
- package/dist/file-reader-json-with-cache.adapter.d.ts.map +1 -1
- package/dist/file-reader-json-with-cache.adapter.js +6 -6
- package/dist/file-reader-json-with-cache.adapter.js.map +1 -1
- package/dist/file-reader-raw-with-cache.adapter.d.ts +5 -4
- package/dist/file-reader-raw-with-cache.adapter.d.ts.map +1 -1
- package/dist/file-reader-raw-with-cache.adapter.js +6 -6
- package/dist/file-reader-raw-with-cache.adapter.js.map +1 -1
- package/dist/file-reader-text-with-cache.adapter.d.ts +5 -4
- package/dist/file-reader-text-with-cache.adapter.d.ts.map +1 -1
- package/dist/file-reader-text-with-cache.adapter.js +6 -6
- package/dist/file-reader-text-with-cache.adapter.js.map +1 -1
- package/dist/file-uploader-hono.middleware.d.ts +13 -0
- package/dist/file-uploader-hono.middleware.d.ts.map +1 -0
- package/dist/file-uploader-hono.middleware.js +37 -0
- package/dist/file-uploader-hono.middleware.js.map +1 -0
- package/dist/file-uploader.middleware.d.ts +19 -8
- package/dist/file-uploader.middleware.d.ts.map +1 -1
- package/dist/file-uploader.middleware.js +24 -26
- package/dist/file-uploader.middleware.js.map +1 -1
- package/dist/handler-hono.port.d.ts +5 -0
- package/dist/handler-hono.port.d.ts.map +1 -0
- package/dist/handler-hono.port.js +2 -0
- package/dist/handler-hono.port.js.map +1 -0
- package/dist/hash-bucket.vo.d.ts +9 -0
- package/dist/hash-bucket.vo.d.ts.map +1 -0
- package/dist/hash-bucket.vo.js +17 -0
- package/dist/hash-bucket.vo.js.map +1 -0
- package/dist/healthcheck-hono.handler.d.ts +87 -0
- package/dist/healthcheck-hono.handler.d.ts.map +1 -0
- package/dist/healthcheck-hono.handler.js +17 -0
- package/dist/healthcheck-hono.handler.js.map +1 -0
- package/dist/healthcheck.handler.d.ts +83 -0
- package/dist/healthcheck.handler.d.ts.map +1 -0
- package/dist/{healthcheck.service.js → healthcheck.handler.js} +21 -19
- package/dist/healthcheck.handler.js.map +1 -0
- package/dist/http-logger-hono.middleware.d.ts +17 -0
- package/dist/http-logger-hono.middleware.d.ts.map +1 -0
- package/dist/http-logger-hono.middleware.js +37 -0
- package/dist/http-logger-hono.middleware.js.map +1 -0
- package/dist/http-logger.middleware.d.ts +19 -4
- package/dist/http-logger.middleware.d.ts.map +1 -1
- package/dist/http-logger.middleware.js +31 -41
- package/dist/http-logger.middleware.js.map +1 -1
- package/dist/i18n.service.d.ts +1 -1
- package/dist/i18n.service.d.ts.map +1 -1
- package/dist/image-info-noop.adapter.d.ts +1 -1
- package/dist/image-info-noop.adapter.d.ts.map +1 -1
- package/dist/image-info-noop.adapter.js +1 -1
- package/dist/image-info-noop.adapter.js.map +1 -1
- package/dist/image-info-sharp.adapter.d.ts +1 -1
- package/dist/image-info-sharp.adapter.d.ts.map +1 -1
- package/dist/image-info-sharp.adapter.js +3 -3
- package/dist/image-info-sharp.adapter.js.map +1 -1
- package/dist/image-info.port.d.ts +1 -1
- package/dist/image-info.port.d.ts.map +1 -1
- package/dist/in-flight-requests-hono.middleware.d.ts +7 -0
- package/dist/in-flight-requests-hono.middleware.d.ts.map +1 -0
- package/dist/in-flight-requests-hono.middleware.js +16 -0
- package/dist/in-flight-requests-hono.middleware.js.map +1 -0
- package/dist/in-flight-requests-tracker.service.d.ts.map +1 -1
- package/dist/in-flight-requests-tracker.service.js +0 -1
- package/dist/in-flight-requests-tracker.service.js.map +1 -1
- package/dist/in-flight-requests.middleware.d.ts +3 -2
- package/dist/in-flight-requests.middleware.d.ts.map +1 -1
- package/dist/in-flight-requests.middleware.js +6 -10
- package/dist/in-flight-requests.middleware.js.map +1 -1
- package/dist/index.d.ts +80 -28
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +80 -28
- package/dist/index.js.map +1 -1
- package/dist/invariant-error-handler.service.d.ts +1 -2
- package/dist/invariant-error-handler.service.d.ts.map +1 -1
- package/dist/invariant-error-handler.service.js.map +1 -1
- package/dist/invariant.service.d.ts +2 -2
- package/dist/invariant.service.d.ts.map +1 -1
- package/dist/mailer-resend.adapter.d.ts +2 -2
- package/dist/mailer-resend.adapter.d.ts.map +1 -1
- package/dist/mailer-resend.adapter.js.map +1 -1
- package/dist/mailer-smtp.adapter.d.ts +2 -2
- package/dist/mailer-smtp.adapter.d.ts.map +1 -1
- package/dist/mailer-smtp.adapter.js.map +1 -1
- package/dist/middleware-hono-noop.adapter.d.ts +6 -0
- package/dist/middleware-hono-noop.adapter.d.ts.map +1 -0
- package/dist/middleware-hono-noop.adapter.js +6 -0
- package/dist/middleware-hono-noop.adapter.js.map +1 -0
- package/dist/middleware-hono.port.d.ts +5 -0
- package/dist/middleware-hono.port.d.ts.map +1 -0
- package/dist/middleware-hono.port.js +2 -0
- package/dist/middleware-hono.port.js.map +1 -0
- package/dist/modules/preferences/invariants/user-language-has-changed.d.ts +6 -6
- package/dist/modules/preferences/invariants/user-language-has-changed.d.ts.map +1 -1
- package/dist/modules/preferences/invariants/user-language-has-changed.js.map +1 -1
- package/dist/ping-hono.handler.d.ts +6 -0
- package/dist/ping-hono.handler.d.ts.map +1 -0
- package/dist/ping-hono.handler.js +13 -0
- package/dist/ping-hono.handler.js.map +1 -0
- package/dist/ping.handler.d.ts +4 -0
- package/dist/ping.handler.d.ts.map +1 -0
- package/dist/ping.handler.js +6 -0
- package/dist/ping.handler.js.map +1 -0
- package/dist/prerequisite-verifier-binary.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-binary.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-binary.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-bun.adapter.d.ts +6 -4
- package/dist/prerequisite-verifier-bun.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-bun.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-clock-drift.adapter.d.ts +4 -3
- package/dist/prerequisite-verifier-clock-drift.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-clock-drift.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-directory.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-directory.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-directory.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-dns.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-dns.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-dns.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-external-api.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-external-api.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-external-api.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-file.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-file.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-file.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-jobs.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-jobs.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-jobs.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-memory.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-memory.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-memory.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-node.adapter.d.ts +6 -4
- package/dist/prerequisite-verifier-node.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-node.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-os.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-os.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-os.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-port.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-port.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-port.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-ram.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-ram.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-ram.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-running-user.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-running-user.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-running-user.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-space.adapter.d.ts +4 -3
- package/dist/prerequisite-verifier-space.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-space.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-sqlite.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-sqlite.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-sqlite.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts +5 -3
- package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-timezone-utc.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-translations.adapter.d.ts +1 -1
- package/dist/prerequisite-verifier-translations.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-translations.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-cache.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-with-cache.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-cache.adapter.js +6 -6
- package/dist/prerequisite-verifier-with-cache.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts +2 -2
- package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-fail-safe.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-logger.adapter.d.ts +4 -3
- package/dist/prerequisite-verifier-with-logger.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-logger.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-retry.adapter.d.ts +6 -5
- package/dist/prerequisite-verifier-with-retry.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-retry.adapter.js.map +1 -1
- package/dist/prerequisite-verifier-with-timeout.adapter.d.ts +5 -4
- package/dist/prerequisite-verifier-with-timeout.adapter.d.ts.map +1 -1
- package/dist/prerequisite-verifier-with-timeout.adapter.js.map +1 -1
- package/dist/prerequisite-verifier.decorator.d.ts +4 -4
- package/dist/prerequisite-verifier.decorator.d.ts.map +1 -1
- package/dist/prerequisite-verifier.decorator.js.map +1 -1
- package/dist/prerequisite.vo.d.ts +2 -2
- package/dist/prerequisite.vo.d.ts.map +1 -1
- package/dist/prerequisite.vo.js.map +1 -1
- package/dist/remote-file-storage-disk.adapter.d.ts +4 -4
- package/dist/remote-file-storage-disk.adapter.d.ts.map +1 -1
- package/dist/remote-file-storage-disk.adapter.js.map +1 -1
- package/dist/request-context-hono.adapter.d.ts +1 -1
- package/dist/request-context-hono.adapter.d.ts.map +1 -1
- package/dist/request-context-hono.adapter.js +10 -1
- package/dist/request-context-hono.adapter.js.map +1 -1
- package/dist/request-context.port.d.ts +18 -0
- package/dist/request-context.port.d.ts.map +1 -1
- package/dist/retry.service.d.ts +5 -5
- package/dist/retry.service.d.ts.map +1 -1
- package/dist/retry.service.js.map +1 -1
- package/dist/security-countermeasure-ban.strategy.d.ts +8 -7
- package/dist/security-countermeasure-ban.strategy.d.ts.map +1 -1
- package/dist/security-countermeasure-ban.strategy.js.map +1 -1
- package/dist/security-countermeasure-mirage.strategy.d.ts +6 -5
- package/dist/security-countermeasure-mirage.strategy.d.ts.map +1 -1
- package/dist/security-countermeasure-mirage.strategy.js.map +1 -1
- package/dist/security-countermeasure-tarpit.strategy.d.ts +5 -4
- package/dist/security-countermeasure-tarpit.strategy.d.ts.map +1 -1
- package/dist/security-countermeasure-tarpit.strategy.js.map +1 -1
- package/dist/security-rule-violation-threshold.strategy.d.ts +4 -3
- package/dist/security-rule-violation-threshold.strategy.d.ts.map +1 -1
- package/dist/security-rule-violation-threshold.strategy.js +4 -4
- package/dist/security-rule-violation-threshold.strategy.js.map +1 -1
- package/dist/setup-hono.service.d.ts +31 -0
- package/dist/setup-hono.service.d.ts.map +1 -0
- package/dist/{setup.service.js → setup-hono.service.js} +25 -33
- package/dist/setup-hono.service.js.map +1 -0
- package/dist/shield-api-key-hono.strategy.d.ts +11 -0
- package/dist/shield-api-key-hono.strategy.d.ts.map +1 -0
- package/dist/shield-api-key-hono.strategy.js +19 -0
- package/dist/shield-api-key-hono.strategy.js.map +1 -0
- package/dist/shield-api-key.strategy.d.ts +9 -9
- package/dist/shield-api-key.strategy.d.ts.map +1 -1
- package/dist/shield-api-key.strategy.js +5 -11
- package/dist/shield-api-key.strategy.js.map +1 -1
- package/dist/shield-auth-hono.strategy.d.ts +16 -0
- package/dist/shield-auth-hono.strategy.d.ts.map +1 -0
- package/dist/shield-auth-hono.strategy.js +31 -0
- package/dist/shield-auth-hono.strategy.js.map +1 -0
- package/dist/shield-auth.strategy.d.ts +8 -7
- package/dist/shield-auth.strategy.d.ts.map +1 -1
- package/dist/shield-auth.strategy.js +10 -23
- package/dist/shield-auth.strategy.js.map +1 -1
- package/dist/shield-basic-auth-hono.strategy.d.ts +11 -0
- package/dist/shield-basic-auth-hono.strategy.d.ts.map +1 -0
- package/dist/shield-basic-auth-hono.strategy.js +21 -0
- package/dist/shield-basic-auth-hono.strategy.js.map +1 -0
- package/dist/shield-basic-auth.strategy.d.ts +9 -7
- package/dist/shield-basic-auth.strategy.d.ts.map +1 -1
- package/dist/shield-basic-auth.strategy.js +18 -5
- package/dist/shield-basic-auth.strategy.js.map +1 -1
- package/dist/shield-body-limit-hono.strategy.d.ts +10 -0
- package/dist/shield-body-limit-hono.strategy.d.ts.map +1 -0
- package/dist/shield-body-limit-hono.strategy.js +21 -0
- package/dist/shield-body-limit-hono.strategy.js.map +1 -0
- package/dist/shield-body-limit.strategy.d.ts +14 -0
- package/dist/shield-body-limit.strategy.d.ts.map +1 -0
- package/dist/shield-body-limit.strategy.js +19 -0
- package/dist/shield-body-limit.strategy.js.map +1 -0
- package/dist/shield-csrf-hono.strategy.d.ts +11 -0
- package/dist/shield-csrf-hono.strategy.d.ts.map +1 -0
- package/dist/shield-csrf-hono.strategy.js +19 -0
- package/dist/shield-csrf-hono.strategy.js.map +1 -0
- package/dist/shield-csrf.strategy.d.ts +8 -7
- package/dist/shield-csrf.strategy.d.ts.map +1 -1
- package/dist/shield-csrf.strategy.js +7 -11
- package/dist/shield-csrf.strategy.js.map +1 -1
- package/dist/shield-hcaptcha-hono-local.strategy.d.ts +14 -0
- package/dist/shield-hcaptcha-hono-local.strategy.d.ts.map +1 -0
- package/dist/shield-hcaptcha-hono-local.strategy.js +20 -0
- package/dist/shield-hcaptcha-hono-local.strategy.js.map +1 -0
- package/dist/shield-hcaptcha-hono.strategy.d.ts +11 -0
- package/dist/shield-hcaptcha-hono.strategy.d.ts.map +1 -0
- package/dist/shield-hcaptcha-hono.strategy.js +19 -0
- package/dist/shield-hcaptcha-hono.strategy.js.map +1 -0
- package/dist/shield-hcaptcha.strategy.d.ts +5 -5
- package/dist/shield-hcaptcha.strategy.d.ts.map +1 -1
- package/dist/shield-hcaptcha.strategy.js +6 -12
- package/dist/shield-hcaptcha.strategy.js.map +1 -1
- package/dist/shield-maintenance-hono.strategy.d.ts +9 -0
- package/dist/shield-maintenance-hono.strategy.d.ts.map +1 -0
- package/dist/shield-maintenance-hono.strategy.js +18 -0
- package/dist/shield-maintenance-hono.strategy.js.map +1 -0
- package/dist/shield-maintenance.strategy.d.ts +15 -0
- package/dist/shield-maintenance.strategy.d.ts.map +1 -0
- package/dist/shield-maintenance.strategy.js +13 -0
- package/dist/shield-maintenance.strategy.js.map +1 -0
- package/dist/shield-rate-limit-hono.strategy.d.ts +18 -0
- package/dist/shield-rate-limit-hono.strategy.d.ts.map +1 -0
- package/dist/shield-rate-limit-hono.strategy.js +21 -0
- package/dist/shield-rate-limit-hono.strategy.js.map +1 -0
- package/dist/shield-rate-limit.strategy.d.ts +11 -10
- package/dist/shield-rate-limit.strategy.d.ts.map +1 -1
- package/dist/shield-rate-limit.strategy.js +9 -16
- package/dist/shield-rate-limit.strategy.js.map +1 -1
- package/dist/shield-recaptcha-hono.strategy.d.ts +11 -0
- package/dist/shield-recaptcha-hono.strategy.d.ts.map +1 -0
- package/dist/shield-recaptcha-hono.strategy.js +22 -0
- package/dist/shield-recaptcha-hono.strategy.js.map +1 -0
- package/dist/shield-recaptcha.strategy.d.ts +9 -8
- package/dist/shield-recaptcha.strategy.d.ts.map +1 -1
- package/dist/shield-recaptcha.strategy.js +8 -13
- package/dist/shield-recaptcha.strategy.js.map +1 -1
- package/dist/shield-security-hono.strategy.d.ts +18 -0
- package/dist/shield-security-hono.strategy.d.ts.map +1 -0
- package/dist/shield-security-hono.strategy.js +43 -0
- package/dist/shield-security-hono.strategy.js.map +1 -0
- package/dist/shield-security.strategy.d.ts +6 -12
- package/dist/shield-security.strategy.d.ts.map +1 -1
- package/dist/shield-security.strategy.js +12 -43
- package/dist/shield-security.strategy.js.map +1 -1
- package/dist/shield-timeout-hono.strategy.d.ts +11 -0
- package/dist/shield-timeout-hono.strategy.d.ts.map +1 -0
- package/dist/shield-timeout-hono.strategy.js +15 -0
- package/dist/shield-timeout-hono.strategy.js.map +1 -0
- package/dist/shield-timeout.strategy.d.ts +7 -9
- package/dist/shield-timeout.strategy.d.ts.map +1 -1
- package/dist/shield-timeout.strategy.js +3 -7
- package/dist/shield-timeout.strategy.js.map +1 -1
- package/dist/simulated-error-hono.middleware.d.ts +8 -0
- package/dist/simulated-error-hono.middleware.d.ts.map +1 -0
- package/dist/simulated-error-hono.middleware.js +13 -0
- package/dist/simulated-error-hono.middleware.js.map +1 -0
- package/dist/simulated-error.middleware.d.ts +2 -2
- package/dist/simulated-error.middleware.d.ts.map +1 -1
- package/dist/simulated-error.middleware.js +3 -4
- package/dist/simulated-error.middleware.js.map +1 -1
- package/dist/slower-hono.middleware.d.ts +14 -0
- package/dist/slower-hono.middleware.d.ts.map +1 -0
- package/dist/slower-hono.middleware.js +14 -0
- package/dist/slower-hono.middleware.js.map +1 -0
- package/dist/slower.middleware.d.ts +5 -2
- package/dist/slower.middleware.d.ts.map +1 -1
- package/dist/slower.middleware.js +10 -6
- package/dist/slower.middleware.js.map +1 -1
- package/dist/{ssr.d.ts → ssr-bun.service.d.ts} +2 -2
- package/dist/ssr-bun.service.d.ts.map +1 -0
- package/dist/ssr-bun.service.js +14 -0
- package/dist/ssr-bun.service.js.map +1 -0
- package/dist/ssr.service.d.ts +26 -0
- package/dist/ssr.service.d.ts.map +1 -0
- package/dist/ssr.service.js +49 -0
- package/dist/ssr.service.js.map +1 -0
- package/dist/{static-files.service.d.ts → static-files-hono.service.d.ts} +2 -2
- package/dist/static-files-hono.service.d.ts.map +1 -0
- package/dist/{static-files.service.js → static-files-hono.service.js} +2 -2
- package/dist/static-files-hono.service.js.map +1 -0
- package/dist/subject-application-resolver.vo.d.ts +23 -0
- package/dist/subject-application-resolver.vo.d.ts.map +1 -0
- package/dist/{cache-subject-application-resolver.vo.js → subject-application-resolver.vo.js} +7 -7
- package/dist/subject-application-resolver.vo.js.map +1 -0
- package/dist/{cache-subject-request-resolver.vo.d.ts → subject-request-resolver.vo.d.ts} +6 -6
- package/dist/subject-request-resolver.vo.d.ts.map +1 -0
- package/dist/{cache-subject-request-resolver.vo.js → subject-request-resolver.vo.js} +7 -7
- package/dist/subject-request-resolver.vo.js.map +1 -0
- package/dist/subject-segment-application.strategy.d.ts +6 -0
- package/dist/subject-segment-application.strategy.d.ts.map +1 -0
- package/dist/subject-segment-application.strategy.js +2 -0
- package/dist/subject-segment-application.strategy.js.map +1 -0
- package/dist/subject-segment-build.strategy.d.ts +9 -0
- package/dist/subject-segment-build.strategy.d.ts.map +1 -0
- package/dist/subject-segment-build.strategy.js +13 -0
- package/dist/subject-segment-build.strategy.js.map +1 -0
- package/dist/subject-segment-cookie.strategy.d.ts +9 -0
- package/dist/subject-segment-cookie.strategy.d.ts.map +1 -0
- package/dist/subject-segment-cookie.strategy.js +11 -0
- package/dist/subject-segment-cookie.strategy.js.map +1 -0
- package/dist/subject-segment-env.strategy.d.ts +9 -0
- package/dist/subject-segment-env.strategy.d.ts.map +1 -0
- package/dist/{cache-subject-segment-env.strategy.js → subject-segment-env.strategy.js} +2 -2
- package/dist/subject-segment-env.strategy.js.map +1 -0
- package/dist/subject-segment-fixed.strategy.d.ts +8 -0
- package/dist/subject-segment-fixed.strategy.d.ts.map +1 -0
- package/dist/{cache-subject-segment-fixed.strategy.js → subject-segment-fixed.strategy.js} +2 -2
- package/dist/subject-segment-fixed.strategy.js.map +1 -0
- package/dist/subject-segment-header.strategy.d.ts +9 -0
- package/dist/subject-segment-header.strategy.d.ts.map +1 -0
- package/dist/subject-segment-header.strategy.js +11 -0
- package/dist/subject-segment-header.strategy.js.map +1 -0
- package/dist/subject-segment-ip.strategy.d.ts +6 -0
- package/dist/subject-segment-ip.strategy.d.ts.map +1 -0
- package/dist/subject-segment-ip.strategy.js +7 -0
- package/dist/subject-segment-ip.strategy.js.map +1 -0
- package/dist/subject-segment-path.strategy.d.ts +6 -0
- package/dist/subject-segment-path.strategy.d.ts.map +1 -0
- package/dist/subject-segment-path.strategy.js +6 -0
- package/dist/subject-segment-path.strategy.js.map +1 -0
- package/dist/subject-segment-query.strategy.d.ts +7 -0
- package/dist/subject-segment-query.strategy.d.ts.map +1 -0
- package/dist/subject-segment-query.strategy.js +12 -0
- package/dist/subject-segment-query.strategy.js.map +1 -0
- package/dist/subject-segment-request.strategy.d.ts +9 -0
- package/dist/subject-segment-request.strategy.d.ts.map +1 -0
- package/dist/subject-segment-request.strategy.js +2 -0
- package/dist/subject-segment-request.strategy.js.map +1 -0
- package/dist/subject-segment-user.strategy.d.ts +6 -0
- package/dist/subject-segment-user.strategy.d.ts.map +1 -0
- package/dist/subject-segment-user.strategy.js +7 -0
- package/dist/subject-segment-user.strategy.js.map +1 -0
- package/dist/time-zone-offset-hono.middleware.d.ts +12 -0
- package/dist/time-zone-offset-hono.middleware.d.ts.map +1 -0
- package/dist/time-zone-offset-hono.middleware.js +17 -0
- package/dist/time-zone-offset-hono.middleware.js.map +1 -0
- package/dist/time-zone-offset.middleware.d.ts +3 -6
- package/dist/time-zone-offset.middleware.d.ts.map +1 -1
- package/dist/time-zone-offset.middleware.js +5 -13
- package/dist/time-zone-offset.middleware.js.map +1 -1
- package/dist/timing-hono.middleware.d.ts +12 -0
- package/dist/timing-hono.middleware.d.ts.map +1 -0
- package/dist/timing-hono.middleware.js +15 -0
- package/dist/timing-hono.middleware.js.map +1 -0
- package/dist/timing.middleware.d.ts +12 -0
- package/dist/timing.middleware.d.ts.map +1 -0
- package/dist/timing.middleware.js +14 -0
- package/dist/timing.middleware.js.map +1 -0
- package/dist/trailing-slash-hono.middleware.d.ts +7 -0
- package/dist/trailing-slash-hono.middleware.d.ts.map +1 -0
- package/dist/trailing-slash-hono.middleware.js +21 -0
- package/dist/trailing-slash-hono.middleware.js.map +1 -0
- package/dist/trailing-slash.middleware.d.ts +11 -0
- package/dist/trailing-slash.middleware.d.ts.map +1 -0
- package/dist/trailing-slash.middleware.js +10 -0
- package/dist/trailing-slash.middleware.js.map +1 -0
- package/dist/translations-hono.handler.d.ts +23 -0
- package/dist/translations-hono.handler.d.ts.map +1 -0
- package/dist/translations-hono.handler.js +17 -0
- package/dist/translations-hono.handler.js.map +1 -0
- package/dist/translations.handler.d.ts +22 -0
- package/dist/translations.handler.d.ts.map +1 -0
- package/dist/translations.handler.js +18 -0
- package/dist/translations.handler.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/weak-etag-extractor-hono.middleware.d.ts +12 -0
- package/dist/weak-etag-extractor-hono.middleware.d.ts.map +1 -0
- package/dist/weak-etag-extractor-hono.middleware.js +17 -0
- package/dist/weak-etag-extractor-hono.middleware.js.map +1 -0
- package/dist/weak-etag-extractor.middleware.d.ts +4 -5
- package/dist/weak-etag-extractor.middleware.d.ts.map +1 -1
- package/dist/weak-etag-extractor.middleware.js +5 -9
- package/dist/weak-etag-extractor.middleware.js.map +1 -1
- package/dist/woodchopper-dispatcher-async.strategy.d.ts.map +1 -1
- package/dist/woodchopper-dispatcher-async.strategy.js +2 -0
- package/dist/woodchopper-dispatcher-async.strategy.js.map +1 -1
- package/dist/woodchopper-sampling-correlation-id.strategy.d.ts +2 -2
- package/dist/woodchopper-sampling-correlation-id.strategy.d.ts.map +1 -1
- package/dist/woodchopper-sampling-correlation-id.strategy.js.map +1 -1
- package/dist/woodchopper-sampling-every-nth.strategy.d.ts +3 -2
- package/dist/woodchopper-sampling-every-nth.strategy.d.ts.map +1 -1
- package/dist/woodchopper-sampling-every-nth.strategy.js.map +1 -1
- package/dist/woodchopper.d.ts +2 -2
- package/dist/woodchopper.d.ts.map +1 -1
- package/dist/woodchopper.js.map +1 -1
- package/package.json +10 -9
- package/readme.md +79 -28
- package/src/ab-assignment-composite.strategy.ts +17 -0
- package/src/ab-assignment-fixed.strategy.ts +12 -0
- package/src/ab-assignment-hash.strategy.ts +23 -0
- package/src/ab-assignment-query.strategy.ts +14 -0
- package/src/ab-assignment.strategy.ts +7 -0
- package/src/ab-hono-noop.middleware.ts +26 -0
- package/src/ab-hono.middleware.ts +28 -0
- package/src/ab-variant-selector.service.ts +27 -0
- package/src/ab-variant-weight.vo.ts +13 -0
- package/src/ab-variant.vo.ts +7 -0
- package/src/ab-variants.vo.ts +24 -0
- package/src/ab.middleware.ts +15 -0
- package/src/api-version-hono.middleware.ts +30 -0
- package/src/api-version.middleware.ts +18 -17
- package/src/auth-session-reader.port.ts +3 -3
- package/src/basic-auth.service.ts +3 -3
- package/src/cache-response-hono.middleware.ts +53 -0
- package/src/cache-response.middleware.ts +27 -33
- package/src/command-bus-collecting.adapter.ts +15 -0
- package/src/command-bus-emittery-v1.adapter.ts +22 -0
- package/src/command-bus-noop.adapter.ts +11 -0
- package/src/command-bus-with-logger.adapter.ts +31 -0
- package/src/command-bus.port.ts +10 -0
- package/src/correlation-hono.middleware.ts +32 -0
- package/src/correlation-id.middleware.ts +20 -0
- package/src/correlation-storage.service.ts +0 -3
- package/src/crypto-key-provider-with-cache.adapter.ts +8 -6
- package/src/dispatching-event-store.ts +2 -2
- package/src/environment-loader-process-safe.adapter.ts +3 -6
- package/src/etag-extractor-hono.middleware.ts +27 -0
- package/src/etag-extractor.middleware.ts +6 -12
- package/src/event-bus-collecting.adapter.ts +15 -0
- package/src/event-bus-emittery-v1.adapter.ts +22 -0
- package/src/event-bus-noop.adapter.ts +11 -0
- package/src/event-bus-with-logger.adapter.ts +31 -0
- package/src/event-bus.port.ts +10 -0
- package/src/event-store.ts +2 -2
- package/src/file-inspection-noop.adapter.ts +2 -2
- package/src/file-reader-json-with-cache.adapter.ts +8 -7
- package/src/file-reader-raw-with-cache.adapter.ts +8 -7
- package/src/file-reader-text-with-cache.adapter.ts +8 -7
- package/src/file-uploader-hono.middleware.ts +47 -0
- package/src/file-uploader.middleware.ts +21 -25
- package/src/handler-hono.port.ts +5 -0
- package/src/hash-bucket.vo.ts +19 -0
- package/src/healthcheck-hono.handler.ts +31 -0
- package/src/healthcheck.handler.ts +150 -0
- package/src/http-logger-hono.middleware.ts +50 -0
- package/src/http-logger.middleware.ts +56 -63
- package/src/i18n.service.ts +1 -1
- package/src/image-info-noop.adapter.ts +1 -1
- package/src/image-info-sharp.adapter.ts +3 -3
- package/src/image-info.port.ts +1 -1
- package/src/in-flight-requests-hono.middleware.ts +19 -0
- package/src/in-flight-requests-tracker.service.ts +0 -2
- package/src/in-flight-requests.middleware.ts +7 -11
- package/src/index.ts +80 -28
- package/src/invariant-error-handler.service.ts +2 -3
- package/src/invariant.service.ts +2 -2
- package/src/mailer-resend.adapter.ts +2 -2
- package/src/mailer-smtp.adapter.ts +2 -2
- package/src/middleware-hono-noop.adapter.ts +8 -0
- package/src/middleware-hono.port.ts +5 -0
- package/src/modules/preferences/invariants/user-language-has-changed.ts +4 -7
- package/src/ping-hono.handler.ts +17 -0
- package/src/ping.handler.ts +5 -0
- package/src/prerequisite-verifier-binary.adapter.ts +3 -1
- package/src/prerequisite-verifier-bun.adapter.ts +3 -1
- package/src/prerequisite-verifier-clock-drift.adapter.ts +2 -1
- package/src/prerequisite-verifier-directory.adapter.ts +6 -4
- package/src/prerequisite-verifier-dns.adapter.ts +3 -1
- package/src/prerequisite-verifier-external-api.adapter.ts +3 -1
- package/src/prerequisite-verifier-file.adapter.ts +6 -4
- package/src/prerequisite-verifier-jobs.adapter.ts +3 -1
- package/src/prerequisite-verifier-memory.adapter.ts +3 -1
- package/src/prerequisite-verifier-node.adapter.ts +3 -1
- package/src/prerequisite-verifier-os.adapter.ts +3 -1
- package/src/prerequisite-verifier-port.adapter.ts +3 -1
- package/src/prerequisite-verifier-ram.adapter.ts +3 -1
- package/src/prerequisite-verifier-running-user.adapter.ts +3 -1
- package/src/prerequisite-verifier-space.adapter.ts +2 -1
- package/src/prerequisite-verifier-sqlite.adapter.ts +3 -1
- package/src/prerequisite-verifier-ssl-certificate-expiry.adapter.ts +3 -1
- package/src/prerequisite-verifier-timezone-utc.adapter.ts +3 -1
- package/src/prerequisite-verifier-translations.adapter.ts +1 -2
- package/src/prerequisite-verifier-with-cache.adapter.ts +8 -7
- package/src/prerequisite-verifier-with-fail-safe.adapter.ts +4 -4
- package/src/prerequisite-verifier-with-logger.adapter.ts +3 -1
- package/src/prerequisite-verifier-with-retry.adapter.ts +3 -2
- package/src/prerequisite-verifier-with-timeout.adapter.ts +2 -1
- package/src/prerequisite-verifier.decorator.ts +4 -4
- package/src/prerequisite.vo.ts +2 -5
- package/src/remote-file-storage-disk.adapter.ts +3 -3
- package/src/request-context-hono.adapter.ts +12 -1
- package/src/request-context.port.ts +15 -0
- package/src/retry.service.ts +4 -4
- package/src/security-countermeasure-ban.strategy.ts +6 -4
- package/src/security-countermeasure-mirage.strategy.ts +2 -1
- package/src/security-countermeasure-tarpit.strategy.ts +2 -1
- package/src/security-rule-violation-threshold.strategy.ts +7 -6
- package/src/{setup.service.ts → setup-hono.service.ts} +36 -43
- package/src/shield-api-key-hono.strategy.ts +28 -0
- package/src/shield-api-key.strategy.ts +9 -15
- package/src/shield-auth-hono.strategy.ts +41 -0
- package/src/shield-auth.strategy.ts +12 -26
- package/src/shield-basic-auth-hono.strategy.ts +30 -0
- package/src/shield-basic-auth.strategy.ts +21 -10
- package/src/shield-body-limit-hono.strategy.ts +30 -0
- package/src/shield-body-limit.strategy.ts +23 -0
- package/src/shield-csrf-hono.strategy.ts +24 -0
- package/src/shield-csrf.strategy.ts +11 -16
- package/src/shield-hcaptcha-hono-local.strategy.ts +26 -0
- package/src/shield-hcaptcha-hono.strategy.ts +25 -0
- package/src/shield-hcaptcha.strategy.ts +7 -13
- package/src/shield-maintenance-hono.strategy.ts +23 -0
- package/src/shield-maintenance.strategy.ts +17 -0
- package/src/shield-rate-limit-hono.strategy.ts +34 -0
- package/src/shield-rate-limit.strategy.ts +11 -19
- package/src/shield-recaptcha-hono.strategy.ts +31 -0
- package/src/shield-recaptcha.strategy.ts +14 -20
- package/src/shield-security-hono.strategy.ts +62 -0
- package/src/shield-security.strategy.ts +19 -62
- package/src/shield-timeout-hono.strategy.ts +25 -0
- package/src/shield-timeout.strategy.ts +4 -14
- package/src/simulated-error-hono.middleware.ts +17 -0
- package/src/simulated-error.middleware.ts +4 -7
- package/src/slower-hono.middleware.ts +23 -0
- package/src/slower.middleware.ts +8 -7
- package/src/ssr-bun.service.ts +25 -0
- package/src/ssr.service.ts +66 -0
- package/src/{static-files.service.ts → static-files-hono.service.ts} +1 -1
- package/src/subject-application-resolver.vo.ts +34 -0
- package/src/subject-request-resolver.vo.ts +34 -0
- package/src/subject-segment-application.strategy.ts +7 -0
- package/src/subject-segment-build.strategy.ts +15 -0
- package/src/subject-segment-cookie.strategy.ts +14 -0
- package/src/subject-segment-env.strategy.ts +11 -0
- package/src/subject-segment-fixed.strategy.ts +12 -0
- package/src/subject-segment-header.strategy.ts +14 -0
- package/src/subject-segment-ip.strategy.ts +12 -0
- package/src/subject-segment-path.strategy.ts +8 -0
- package/src/subject-segment-query.strategy.ts +19 -0
- package/src/{cache-subject-segment-request.strategy.ts → subject-segment-request.strategy.ts} +4 -4
- package/src/subject-segment-user.strategy.ts +12 -0
- package/src/time-zone-offset-hono.middleware.ts +26 -0
- package/src/time-zone-offset.middleware.ts +6 -18
- package/src/timing-hono.middleware.ts +22 -0
- package/src/timing.middleware.ts +18 -0
- package/src/trailing-slash-hono.middleware.ts +27 -0
- package/src/trailing-slash.middleware.ts +11 -0
- package/src/translations-hono.handler.ts +26 -0
- package/src/translations.handler.ts +31 -0
- package/src/weak-etag-extractor-hono.middleware.ts +26 -0
- package/src/weak-etag-extractor.middleware.ts +6 -11
- package/src/woodchopper-dispatcher-async.strategy.ts +2 -0
- package/src/woodchopper-sampling-correlation-id.strategy.ts +2 -2
- package/src/woodchopper-sampling-every-nth.strategy.ts +2 -2
- package/src/woodchopper.ts +2 -2
- package/dist/cache-subject-application-resolver.vo.d.ts +0 -23
- package/dist/cache-subject-application-resolver.vo.d.ts.map +0 -1
- package/dist/cache-subject-application-resolver.vo.js.map +0 -1
- package/dist/cache-subject-request-resolver.vo.d.ts.map +0 -1
- package/dist/cache-subject-request-resolver.vo.js.map +0 -1
- package/dist/cache-subject-segment-application.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-application.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-application.strategy.js +0 -2
- package/dist/cache-subject-segment-application.strategy.js.map +0 -1
- package/dist/cache-subject-segment-build.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-build.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-build.strategy.js +0 -13
- package/dist/cache-subject-segment-build.strategy.js.map +0 -1
- package/dist/cache-subject-segment-cookie.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-cookie.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-cookie.strategy.js +0 -11
- package/dist/cache-subject-segment-cookie.strategy.js.map +0 -1
- package/dist/cache-subject-segment-env.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-env.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-env.strategy.js.map +0 -1
- package/dist/cache-subject-segment-fixed.strategy.d.ts +0 -8
- package/dist/cache-subject-segment-fixed.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-fixed.strategy.js.map +0 -1
- package/dist/cache-subject-segment-header.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-header.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-header.strategy.js +0 -11
- package/dist/cache-subject-segment-header.strategy.js.map +0 -1
- package/dist/cache-subject-segment-ip.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-ip.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-ip.strategy.js +0 -7
- package/dist/cache-subject-segment-ip.strategy.js.map +0 -1
- package/dist/cache-subject-segment-path.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-path.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-path.strategy.js +0 -6
- package/dist/cache-subject-segment-path.strategy.js.map +0 -1
- package/dist/cache-subject-segment-query.strategy.d.ts +0 -7
- package/dist/cache-subject-segment-query.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-query.strategy.js +0 -12
- package/dist/cache-subject-segment-query.strategy.js.map +0 -1
- package/dist/cache-subject-segment-request.strategy.d.ts +0 -9
- package/dist/cache-subject-segment-request.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-request.strategy.js +0 -2
- package/dist/cache-subject-segment-request.strategy.js.map +0 -1
- package/dist/cache-subject-segment-user.strategy.d.ts +0 -6
- package/dist/cache-subject-segment-user.strategy.d.ts.map +0 -1
- package/dist/cache-subject-segment-user.strategy.js +0 -7
- package/dist/cache-subject-segment-user.strategy.js.map +0 -1
- package/dist/command-logger.service.d.ts +0 -13
- package/dist/command-logger.service.d.ts.map +0 -1
- package/dist/command-logger.service.js +0 -16
- package/dist/command-logger.service.js.map +0 -1
- package/dist/context.middleware.d.ts +0 -14
- package/dist/context.middleware.d.ts.map +0 -1
- package/dist/context.middleware.js +0 -11
- package/dist/context.middleware.js.map +0 -1
- package/dist/event-bus-like.types.d.ts +0 -12
- package/dist/event-bus-like.types.d.ts.map +0 -1
- package/dist/event-bus-like.types.js +0 -2
- package/dist/event-bus-like.types.js.map +0 -1
- package/dist/event-logger.service.d.ts +0 -13
- package/dist/event-logger.service.d.ts.map +0 -1
- package/dist/event-logger.service.js +0 -16
- package/dist/event-logger.service.js.map +0 -1
- package/dist/event-publisher.types.d.ts +0 -4
- package/dist/event-publisher.types.d.ts.map +0 -1
- package/dist/event-publisher.types.js +0 -2
- package/dist/event-publisher.types.js.map +0 -1
- package/dist/healthcheck.service.d.ts +0 -96
- package/dist/healthcheck.service.d.ts.map +0 -1
- package/dist/healthcheck.service.js.map +0 -1
- package/dist/maintenance-mode.middleware.d.ts +0 -11
- package/dist/maintenance-mode.middleware.d.ts.map +0 -1
- package/dist/maintenance-mode.middleware.js +0 -12
- package/dist/maintenance-mode.middleware.js.map +0 -1
- package/dist/ping.service.d.ts +0 -4
- package/dist/ping.service.d.ts.map +0 -1
- package/dist/ping.service.js +0 -6
- package/dist/ping.service.js.map +0 -1
- package/dist/setup.service.d.ts +0 -35
- package/dist/setup.service.d.ts.map +0 -1
- package/dist/setup.service.js.map +0 -1
- package/dist/shield-hcaptcha-local.strategy.d.ts +0 -11
- package/dist/shield-hcaptcha-local.strategy.d.ts.map +0 -1
- package/dist/shield-hcaptcha-local.strategy.js +0 -23
- package/dist/shield-hcaptcha-local.strategy.js.map +0 -1
- package/dist/shield-noop.strategy.d.ts +0 -5
- package/dist/shield-noop.strategy.d.ts.map +0 -1
- package/dist/shield-noop.strategy.js +0 -5
- package/dist/shield-noop.strategy.js.map +0 -1
- package/dist/shield.strategy.d.ts +0 -5
- package/dist/shield.strategy.d.ts.map +0 -1
- package/dist/shield.strategy.js +0 -2
- package/dist/shield.strategy.js.map +0 -1
- package/dist/ssr.d.ts.map +0 -1
- package/dist/ssr.js +0 -43
- package/dist/ssr.js.map +0 -1
- package/dist/static-files.service.d.ts.map +0 -1
- package/dist/static-files.service.js.map +0 -1
- package/dist/translations.service.d.ts +0 -21
- package/dist/translations.service.d.ts.map +0 -1
- package/dist/translations.service.js +0 -11
- package/dist/translations.service.js.map +0 -1
- package/src/cache-subject-application-resolver.vo.ts +0 -34
- package/src/cache-subject-request-resolver.vo.ts +0 -39
- package/src/cache-subject-segment-application.strategy.ts +0 -7
- package/src/cache-subject-segment-build.strategy.ts +0 -15
- package/src/cache-subject-segment-cookie.strategy.ts +0 -14
- package/src/cache-subject-segment-env.strategy.ts +0 -11
- package/src/cache-subject-segment-fixed.strategy.ts +0 -15
- package/src/cache-subject-segment-header.strategy.ts +0 -14
- package/src/cache-subject-segment-ip.strategy.ts +0 -12
- package/src/cache-subject-segment-path.strategy.ts +0 -11
- package/src/cache-subject-segment-query.strategy.ts +0 -19
- package/src/cache-subject-segment-user.strategy.ts +0 -12
- package/src/command-logger.service.ts +0 -23
- package/src/context.middleware.ts +0 -24
- package/src/event-bus-like.types.ts +0 -10
- package/src/event-logger.service.ts +0 -23
- package/src/event-publisher.types.ts +0 -3
- package/src/healthcheck.service.ts +0 -154
- package/src/maintenance-mode.middleware.ts +0 -15
- package/src/ping.service.ts +0 -7
- package/src/shield-hcaptcha-local.strategy.ts +0 -24
- package/src/shield-noop.strategy.ts +0 -6
- package/src/shield.strategy.ts +0 -5
- package/src/ssr.ts +0 -57
- package/src/translations.service.ts +0 -20
|
@@ -1,30 +1,28 @@
|
|
|
1
1
|
import * as tools from "@bgord/tools";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}),
|
|
27
|
-
];
|
|
2
|
+
export const FileUploaderError = {
|
|
3
|
+
MissingFile: "file.uploader.missing.file",
|
|
4
|
+
EmptyFile: "file.uploader.empty.file",
|
|
5
|
+
InvalidMime: "file.uploader.invalid.mime",
|
|
6
|
+
SizeLimit: "file.uploader.size.limit",
|
|
7
|
+
};
|
|
8
|
+
export class FileUploaderMiddleware {
|
|
9
|
+
config;
|
|
10
|
+
constructor(config) {
|
|
11
|
+
this.config = config;
|
|
12
|
+
}
|
|
13
|
+
validate(file) {
|
|
14
|
+
if (!file)
|
|
15
|
+
return { valid: false, error: FileUploaderError.MissingFile };
|
|
16
|
+
if (file.size === 0)
|
|
17
|
+
return { valid: false, error: FileUploaderError.EmptyFile };
|
|
18
|
+
const size = tools.Size.fromBytes(file.size);
|
|
19
|
+
if (size.isGreaterThan(this.config.maxSize))
|
|
20
|
+
return { valid: false, error: FileUploaderError.SizeLimit };
|
|
21
|
+
const mime = tools.Mime.fromString(file.type);
|
|
22
|
+
if (!this.config.MimeRegistry.hasMime(mime)) {
|
|
23
|
+
return { valid: false, error: FileUploaderError.InvalidMime };
|
|
24
|
+
}
|
|
25
|
+
return { valid: true };
|
|
28
26
|
}
|
|
29
27
|
}
|
|
30
28
|
//# sourceMappingURL=file-uploader.middleware.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"file-uploader.middleware.js","sourceRoot":"","sources":["../src/file-uploader.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"file-uploader.middleware.js","sourceRoot":"","sources":["../src/file-uploader.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAItC,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,WAAW,EAAE,4BAA4B;IACzC,SAAS,EAAE,0BAA0B;IACrC,WAAW,EAAE,4BAA4B;IACzC,SAAS,EAAE,0BAA0B;CAC7B,CAAC;AAMX,MAAM,OAAO,sBAAsB;IACJ;IAA7B,YAA6B,MAA0B;QAA1B,WAAM,GAAN,MAAM,CAAoB;IAAG,CAAC;IAE3D,QAAQ,CAAC,IAAiB;QACxB,IAAI,CAAC,IAAI;YAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,CAAC;QACzE,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC;YAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,iBAAiB,CAAC,SAAS,EAAE,CAAC;QAEjF,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE7C,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,iBAAiB,CAAC,SAAS,EAAE,CAAC;QAEzG,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE9C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAC5C,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,iBAAiB,CAAC,WAAW,EAAE,CAAC;QAChE,CAAC;QACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IACzB,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler-hono.port.d.ts","sourceRoot":"","sources":["../src/handler-hono.port.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAEpC,MAAM,WAAW,eAAe;IAC9B,MAAM,IAAI,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC;CACpC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handler-hono.port.js","sourceRoot":"","sources":["../src/handler-hono.port.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import type { Hash } from "./hash.vo";
|
|
3
|
+
export declare class HashBucket {
|
|
4
|
+
readonly value: tools.IntegerNonNegativeType;
|
|
5
|
+
private constructor();
|
|
6
|
+
static fromHash(hash: Hash): HashBucket;
|
|
7
|
+
isLessThan(threshold: tools.IntegerNonNegativeType): boolean;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=hash-bucket.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hash-bucket.vo.d.ts","sourceRoot":"","sources":["../src/hash-bucket.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEtC,qBAAa,UAAU;IACD,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,sBAAsB;IAAhE,OAAO;IAEP,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,UAAU;IASvC,UAAU,CAAC,SAAS,EAAE,KAAK,CAAC,sBAAsB,GAAG,OAAO;CAG7D"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
export class HashBucket {
|
|
3
|
+
value;
|
|
4
|
+
constructor(value) {
|
|
5
|
+
this.value = value;
|
|
6
|
+
}
|
|
7
|
+
static fromHash(hash) {
|
|
8
|
+
const hex = hash.get().substring(0, 8);
|
|
9
|
+
const integer = Number.parseInt(hex, 16);
|
|
10
|
+
const bucket = integer % 100;
|
|
11
|
+
return new HashBucket(tools.IntegerNonNegative.parse(bucket));
|
|
12
|
+
}
|
|
13
|
+
isLessThan(threshold) {
|
|
14
|
+
return this.value < threshold;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=hash-bucket.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hash-bucket.vo.js","sourceRoot":"","sources":["../src/hash-bucket.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAGtC,MAAM,OAAO,UAAU;IACQ;IAA7B,YAA6B,KAAmC;QAAnC,UAAK,GAAL,KAAK,CAA8B;IAAG,CAAC;IAEpE,MAAM,CAAC,QAAQ,CAAC,IAAU;QACxB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACvC,MAAM,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAEzC,MAAM,MAAM,GAAG,OAAO,GAAG,GAAG,CAAC;QAE7B,OAAO,IAAI,UAAU,CAAC,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;IAChE,CAAC;IAED,UAAU,CAAC,SAAuC;QAChD,OAAO,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IAChC,CAAC;CACF"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import type { BuildInfoRepositoryStrategy } from "./build-info-repository.strategy";
|
|
2
|
+
import type { ClockPort } from "./clock.port";
|
|
3
|
+
import type { HandlerHonoPort } from "./handler-hono.port";
|
|
4
|
+
import { type HealthcheckConfig } from "./healthcheck.handler";
|
|
5
|
+
import type { LoggerStatsProviderPort } from "./logger-stats-provider.port";
|
|
6
|
+
type Dependencies = {
|
|
7
|
+
Clock: ClockPort;
|
|
8
|
+
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
9
|
+
LoggerStatsProvider?: LoggerStatsProviderPort;
|
|
10
|
+
};
|
|
11
|
+
export declare class HealthcheckHonoHandler implements HandlerHonoPort {
|
|
12
|
+
private readonly handler;
|
|
13
|
+
constructor(config: HealthcheckConfig, deps: Dependencies);
|
|
14
|
+
handle(): [import("hono/types").H<import("hono").Env, string, {}, Promise<Response & import("hono").TypedResponse<{
|
|
15
|
+
ok: boolean;
|
|
16
|
+
deployment: {
|
|
17
|
+
version: string;
|
|
18
|
+
timestamp: import("@bgord/tools").TimestampValueType;
|
|
19
|
+
date: string;
|
|
20
|
+
sha: import("./commit-sha-value.vo").CommitShaValueType;
|
|
21
|
+
size: string;
|
|
22
|
+
environment: import("./node-env.vo").NodeEnvironmentEnum;
|
|
23
|
+
};
|
|
24
|
+
server: {
|
|
25
|
+
pid: typeof process.pid;
|
|
26
|
+
hostname: ReturnType<typeof import("node:os").hostname>;
|
|
27
|
+
cpus: import("@bgord/tools").IntegerNonNegativeType;
|
|
28
|
+
startup: import("@bgord/tools").TimestampValueType;
|
|
29
|
+
uptime: {
|
|
30
|
+
formatted: ReturnType<typeof import("@bgord/tools").DateFormatters["relative"]>;
|
|
31
|
+
durationMs: import("@bgord/tools").DurationMsType;
|
|
32
|
+
};
|
|
33
|
+
memory: {
|
|
34
|
+
total: {
|
|
35
|
+
bytes: import("@bgord/tools").Size["bytes"];
|
|
36
|
+
formatted: ReturnType<import("@bgord/tools").Size["format"]>;
|
|
37
|
+
};
|
|
38
|
+
heap: {
|
|
39
|
+
used: {
|
|
40
|
+
bytes: import("@bgord/tools").Size["bytes"];
|
|
41
|
+
formatted: ReturnType<import("@bgord/tools").Size["format"]>;
|
|
42
|
+
};
|
|
43
|
+
total: {
|
|
44
|
+
bytes: import("@bgord/tools").Size["bytes"];
|
|
45
|
+
formatted: ReturnType<import("@bgord/tools").Size["format"]>;
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
};
|
|
49
|
+
eventLoop: {
|
|
50
|
+
lag: {
|
|
51
|
+
p50: import("@bgord/tools").DurationMsType;
|
|
52
|
+
p95: import("@bgord/tools").DurationMsType;
|
|
53
|
+
p99: import("@bgord/tools").DurationMsType;
|
|
54
|
+
};
|
|
55
|
+
utilization: import("./event-loop-utilization.service").EventLoopUtilizationSnapshot;
|
|
56
|
+
};
|
|
57
|
+
inFlight: import("@bgord/tools").IntegerType;
|
|
58
|
+
};
|
|
59
|
+
details: readonly {
|
|
60
|
+
label: import("./prerequisite.vo").PrerequisiteLabelType;
|
|
61
|
+
outcome: {
|
|
62
|
+
outcome: import("./prerequisite-verifier.port").PrerequisiteVerificationOutcome.success;
|
|
63
|
+
} | {
|
|
64
|
+
outcome: import("./prerequisite-verifier.port").PrerequisiteVerificationOutcome.failure;
|
|
65
|
+
error?: {
|
|
66
|
+
message: string;
|
|
67
|
+
name?: string | undefined;
|
|
68
|
+
stack?: string | undefined;
|
|
69
|
+
cause?: /*elided*/ any | undefined;
|
|
70
|
+
} | undefined;
|
|
71
|
+
} | {
|
|
72
|
+
outcome: import("./prerequisite-verifier.port").PrerequisiteVerificationOutcome.undetermined;
|
|
73
|
+
};
|
|
74
|
+
durationMs: import("@bgord/tools").DurationMsType;
|
|
75
|
+
}[];
|
|
76
|
+
logger?: {
|
|
77
|
+
written: number;
|
|
78
|
+
dropped: number;
|
|
79
|
+
deliveryFailures: number;
|
|
80
|
+
state: import("./logger-stats-provider.port").LoggerState;
|
|
81
|
+
} | undefined;
|
|
82
|
+
durationMs: import("@bgord/tools").Duration["ms"];
|
|
83
|
+
timestamp: import("@bgord/tools").TimestampValueType;
|
|
84
|
+
}, 200 | 424, "json">>>];
|
|
85
|
+
}
|
|
86
|
+
export {};
|
|
87
|
+
//# sourceMappingURL=healthcheck-hono.handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"healthcheck-hono.handler.d.ts","sourceRoot":"","sources":["../src/healthcheck-hono.handler.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AACpF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,KAAK,iBAAiB,EAAsB,MAAM,uBAAuB,CAAC;AACnF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AAE5E,KAAK,YAAY,GAAG;IAClB,KAAK,EAAE,SAAS,CAAC;IACjB,mBAAmB,EAAE,2BAA2B,CAAC;IACjD,mBAAmB,CAAC,EAAE,uBAAuB,CAAC;CAC/C,CAAC;AAIF,qBAAa,sBAAuB,YAAW,eAAe;IAC5D,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAqB;gBAEjC,MAAM,EAAE,iBAAiB,EAAE,IAAI,EAAE,YAAY;IAIzD,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAQP"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { createFactory } from "hono/factory";
|
|
2
|
+
import { HealthcheckHandler } from "./healthcheck.handler";
|
|
3
|
+
const factory = createFactory();
|
|
4
|
+
export class HealthcheckHonoHandler {
|
|
5
|
+
handler;
|
|
6
|
+
constructor(config, deps) {
|
|
7
|
+
this.handler = new HealthcheckHandler(config, deps);
|
|
8
|
+
}
|
|
9
|
+
handle() {
|
|
10
|
+
return factory.createHandlers(async (c) => {
|
|
11
|
+
const healthcheck = await this.handler.check();
|
|
12
|
+
const code = healthcheck.ok ? 200 : 424;
|
|
13
|
+
return c.json(healthcheck, code);
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=healthcheck-hono.handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"healthcheck-hono.handler.js","sourceRoot":"","sources":["../src/healthcheck-hono.handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAI7C,OAAO,EAA0B,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AASnF,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;AAEhC,MAAM,OAAO,sBAAsB;IAChB,OAAO,CAAqB;IAE7C,YAAY,MAAyB,EAAE,IAAkB;QACvD,IAAI,CAAC,OAAO,GAAG,IAAI,kBAAkB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,MAAM;QACJ,OAAO,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACxC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAC/C,MAAM,IAAI,GAAG,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAExC,OAAO,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -0,0 +1,83 @@
|
|
|
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 { type EventLoopUtilizationSnapshot } from "./event-loop-utilization.service";
|
|
7
|
+
import type { LoggerStatsProviderPort, LoggerStatsSnapshot } from "./logger-stats-provider.port";
|
|
8
|
+
import type { NodeEnvironmentEnum } from "./node-env.vo";
|
|
9
|
+
import { Prerequisite, type PrerequisiteLabelType } from "./prerequisite.vo";
|
|
10
|
+
import { type PrerequisiteVerificationResult } from "./prerequisite-verifier.port";
|
|
11
|
+
import type { RedactorStrategy } from "./redactor.strategy";
|
|
12
|
+
import { type UptimeResultType } from "./uptime.service";
|
|
13
|
+
type Dependencies = {
|
|
14
|
+
Clock: ClockPort;
|
|
15
|
+
BuildInfoRepository: BuildInfoRepositoryStrategy;
|
|
16
|
+
LoggerStatsProvider?: LoggerStatsProviderPort;
|
|
17
|
+
};
|
|
18
|
+
export type HealthcheckConfig = {
|
|
19
|
+
Env: NodeEnvironmentEnum;
|
|
20
|
+
prerequisites: ReadonlyArray<Prerequisite>;
|
|
21
|
+
redactor?: RedactorStrategy;
|
|
22
|
+
};
|
|
23
|
+
export type HealthcheckResult = {
|
|
24
|
+
ok: boolean;
|
|
25
|
+
deployment: {
|
|
26
|
+
version: string;
|
|
27
|
+
timestamp: tools.TimestampValueType;
|
|
28
|
+
date: string;
|
|
29
|
+
sha: CommitShaValueType;
|
|
30
|
+
size: string;
|
|
31
|
+
environment: NodeEnvironmentEnum;
|
|
32
|
+
};
|
|
33
|
+
server: {
|
|
34
|
+
pid: typeof process.pid;
|
|
35
|
+
hostname: ReturnType<typeof os.hostname>;
|
|
36
|
+
cpus: tools.IntegerNonNegativeType;
|
|
37
|
+
startup: tools.TimestampValueType;
|
|
38
|
+
uptime: Omit<UptimeResultType, "duration"> & {
|
|
39
|
+
durationMs: tools.DurationMsType;
|
|
40
|
+
};
|
|
41
|
+
memory: {
|
|
42
|
+
total: {
|
|
43
|
+
bytes: tools.Size["bytes"];
|
|
44
|
+
formatted: ReturnType<tools.Size["format"]>;
|
|
45
|
+
};
|
|
46
|
+
heap: {
|
|
47
|
+
used: {
|
|
48
|
+
bytes: tools.Size["bytes"];
|
|
49
|
+
formatted: ReturnType<tools.Size["format"]>;
|
|
50
|
+
};
|
|
51
|
+
total: {
|
|
52
|
+
bytes: tools.Size["bytes"];
|
|
53
|
+
formatted: ReturnType<tools.Size["format"]>;
|
|
54
|
+
};
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
eventLoop: {
|
|
58
|
+
lag: {
|
|
59
|
+
p50: tools.DurationMsType;
|
|
60
|
+
p95: tools.DurationMsType;
|
|
61
|
+
p99: tools.DurationMsType;
|
|
62
|
+
};
|
|
63
|
+
utilization: EventLoopUtilizationSnapshot;
|
|
64
|
+
};
|
|
65
|
+
inFlight: tools.IntegerType;
|
|
66
|
+
};
|
|
67
|
+
details: ReadonlyArray<{
|
|
68
|
+
label: PrerequisiteLabelType;
|
|
69
|
+
outcome: PrerequisiteVerificationResult;
|
|
70
|
+
durationMs: tools.DurationMsType;
|
|
71
|
+
}>;
|
|
72
|
+
logger?: LoggerStatsSnapshot;
|
|
73
|
+
durationMs: tools.Duration["ms"];
|
|
74
|
+
timestamp: tools.TimestampValueType;
|
|
75
|
+
};
|
|
76
|
+
export declare class HealthcheckHandler {
|
|
77
|
+
private readonly config;
|
|
78
|
+
private readonly deps;
|
|
79
|
+
constructor(config: HealthcheckConfig, deps: Dependencies);
|
|
80
|
+
check(): Promise<HealthcheckResult>;
|
|
81
|
+
}
|
|
82
|
+
export {};
|
|
83
|
+
//# sourceMappingURL=healthcheck.handler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"healthcheck.handler.d.ts","sourceRoot":"","sources":["../src/healthcheck.handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import os from "node:os";
|
|
2
2
|
import * as tools from "@bgord/tools";
|
|
3
|
-
import { createFactory } from "hono/factory";
|
|
4
3
|
import { EventLoopLag } from "./event-loop-lag.service";
|
|
5
4
|
import { EventLoopUtilization } from "./event-loop-utilization.service";
|
|
6
5
|
import { InFlightRequestsTracker } from "./in-flight-requests-tracker.service";
|
|
@@ -10,30 +9,34 @@ import { PrerequisiteVerificationOutcome, } from "./prerequisite-verifier.port";
|
|
|
10
9
|
import { PrerequisiteVerifierSelfAdapter } from "./prerequisite-verifier-self.adapter";
|
|
11
10
|
import { Stopwatch } from "./stopwatch.service";
|
|
12
11
|
import { Uptime } from "./uptime.service";
|
|
13
|
-
const handler = createFactory();
|
|
14
12
|
const self = new Prerequisite("self", new PrerequisiteVerifierSelfAdapter());
|
|
15
|
-
export class
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
13
|
+
export class HealthcheckHandler {
|
|
14
|
+
config;
|
|
15
|
+
deps;
|
|
16
|
+
constructor(config, deps) {
|
|
17
|
+
this.config = config;
|
|
18
|
+
this.deps = deps;
|
|
19
|
+
}
|
|
20
|
+
async check() {
|
|
21
|
+
const stopwatch = new Stopwatch(this.deps);
|
|
22
|
+
const prerequisites = [self, ...this.config.prerequisites]
|
|
19
23
|
.filter((prerequisite) => prerequisite.enabled)
|
|
20
24
|
.filter((prerequisite) => prerequisite.kind !== "port");
|
|
21
25
|
const details = await Promise.all(prerequisites.map(async (prerequisite) => {
|
|
22
|
-
const stopwatch = new Stopwatch(deps);
|
|
26
|
+
const stopwatch = new Stopwatch(this.deps);
|
|
23
27
|
const outcome = await prerequisite.build().verify();
|
|
24
28
|
return {
|
|
25
29
|
label: prerequisite.label,
|
|
26
|
-
outcome: config.redactor ? config.redactor.redact(outcome) : outcome,
|
|
30
|
+
outcome: this.config.redactor ? this.config.redactor.redact(outcome) : outcome,
|
|
27
31
|
durationMs: stopwatch.stop().ms,
|
|
28
32
|
};
|
|
29
33
|
}));
|
|
30
34
|
const ok = details.every((result) => result.outcome.outcome !== PrerequisiteVerificationOutcome.failure);
|
|
31
|
-
const
|
|
32
|
-
const
|
|
33
|
-
const uptime = Uptime.get(deps.Clock);
|
|
35
|
+
const build = await this.deps.BuildInfoRepository.extract();
|
|
36
|
+
const uptime = Uptime.get(this.deps.Clock);
|
|
34
37
|
const histogram = EventLoopLag.snapshot();
|
|
35
38
|
const memory = MemoryConsumption.snapshot();
|
|
36
|
-
|
|
39
|
+
return {
|
|
37
40
|
ok,
|
|
38
41
|
details,
|
|
39
42
|
deployment: {
|
|
@@ -42,13 +45,13 @@ export class Healthcheck {
|
|
|
42
45
|
date: new Date(build.timestamp.ms).toISOString(),
|
|
43
46
|
sha: build.sha.toString(),
|
|
44
47
|
size: build.size.format(tools.Size.unit.MB),
|
|
45
|
-
environment: config.Env,
|
|
48
|
+
environment: this.config.Env,
|
|
46
49
|
},
|
|
47
50
|
server: {
|
|
48
51
|
pid: process.pid,
|
|
49
52
|
hostname: os.hostname(),
|
|
50
53
|
cpus: tools.IntegerNonNegative.parse(os.cpus().length),
|
|
51
|
-
startup: deps.Clock.now().subtract(uptime.duration).ms,
|
|
54
|
+
startup: this.deps.Clock.now().subtract(uptime.duration).ms,
|
|
52
55
|
uptime: { durationMs: uptime.duration.ms, formatted: uptime.formatted },
|
|
53
56
|
memory: {
|
|
54
57
|
total: { bytes: memory.total.toBytes(), formatted: memory.total.format(tools.Size.unit.MB) },
|
|
@@ -69,11 +72,10 @@ export class Healthcheck {
|
|
|
69
72
|
},
|
|
70
73
|
inFlight: InFlightRequestsTracker.get(),
|
|
71
74
|
},
|
|
72
|
-
logger: deps.LoggerStatsProvider?.getStats(),
|
|
75
|
+
logger: this.deps.LoggerStatsProvider?.getStats(),
|
|
73
76
|
durationMs: stopwatch.stop().ms,
|
|
74
|
-
timestamp: deps.Clock.now().ms,
|
|
77
|
+
timestamp: this.deps.Clock.now().ms,
|
|
75
78
|
};
|
|
76
|
-
|
|
77
|
-
});
|
|
79
|
+
}
|
|
78
80
|
}
|
|
79
|
-
//# sourceMappingURL=healthcheck.
|
|
81
|
+
//# sourceMappingURL=healthcheck.handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"healthcheck.handler.js","sourceRoot":"","sources":["../src/healthcheck.handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { MiddlewareHandler } from "hono";
|
|
2
|
+
import type { ClockPort } from "./clock.port";
|
|
3
|
+
import { type HttpLoggerConfig } from "./http-logger.middleware";
|
|
4
|
+
import type { LoggerPort } from "./logger.port";
|
|
5
|
+
import type { MiddlewareHonoPort } from "./middleware-hono.port";
|
|
6
|
+
type Dependencies = {
|
|
7
|
+
Logger: LoggerPort;
|
|
8
|
+
Clock: ClockPort;
|
|
9
|
+
};
|
|
10
|
+
export declare class HttpLoggerHonoMiddleware implements MiddlewareHonoPort {
|
|
11
|
+
private readonly middleware;
|
|
12
|
+
constructor(deps: Dependencies, config?: HttpLoggerConfig);
|
|
13
|
+
handle(): MiddlewareHandler;
|
|
14
|
+
private static parseJSON;
|
|
15
|
+
}
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=http-logger-hono.middleware.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-logger-hono.middleware.d.ts","sourceRoot":"","sources":["../src/http-logger-hono.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAG9C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,KAAK,gBAAgB,EAAwB,MAAM,0BAA0B,CAAC;AACvF,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAGjE,KAAK,YAAY,GAAG;IAAE,MAAM,EAAE,UAAU,CAAC;IAAC,KAAK,EAAE,SAAS,CAAA;CAAE,CAAC;AAE7D,qBAAa,wBAAyB,YAAW,kBAAkB;IACjE,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAuB;gBAEtC,IAAI,EAAE,YAAY,EAAE,MAAM,CAAC,EAAE,gBAAgB;IAIzD,MAAM,IAAI,iBAAiB;mBA0BN,SAAS;CAK/B"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { CacheSourceEnum } from "./cache-resolver.strategy";
|
|
2
|
+
import { CacheResponseMiddleware } from "./cache-response.middleware";
|
|
3
|
+
import { HttpLoggerMiddleware } from "./http-logger.middleware";
|
|
4
|
+
import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
|
|
5
|
+
export class HttpLoggerHonoMiddleware {
|
|
6
|
+
middleware;
|
|
7
|
+
constructor(deps, config) {
|
|
8
|
+
this.middleware = new HttpLoggerMiddleware(deps, config);
|
|
9
|
+
}
|
|
10
|
+
handle() {
|
|
11
|
+
return async (c, next) => {
|
|
12
|
+
const context = new RequestContextHonoAdapter(c);
|
|
13
|
+
if (this.middleware.shouldSkip(context))
|
|
14
|
+
return await next();
|
|
15
|
+
const request = c.req.raw.clone();
|
|
16
|
+
const correlationId = c.get("correlationId");
|
|
17
|
+
const body = await HttpLoggerHonoMiddleware.parseJSON(request);
|
|
18
|
+
const { stopwatch } = this.middleware.before(context, correlationId, body);
|
|
19
|
+
await next();
|
|
20
|
+
const response = c.res.clone();
|
|
21
|
+
const responseBody = await HttpLoggerHonoMiddleware.parseJSON(response);
|
|
22
|
+
this.middleware.after(context, correlationId, {
|
|
23
|
+
stopwatch,
|
|
24
|
+
status: response.status,
|
|
25
|
+
cacheHit: response.headers.get(CacheResponseMiddleware.CACHE_HIT_HEADER) === CacheSourceEnum.hit,
|
|
26
|
+
responseBody,
|
|
27
|
+
});
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
static async parseJSON(resource) {
|
|
31
|
+
try {
|
|
32
|
+
return await resource.json();
|
|
33
|
+
}
|
|
34
|
+
catch { }
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=http-logger-hono.middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-logger-hono.middleware.js","sourceRoot":"","sources":["../src/http-logger-hono.middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAEtE,OAAO,EAAyB,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGvF,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAI3E,MAAM,OAAO,wBAAwB;IAClB,UAAU,CAAuB;IAElD,YAAY,IAAkB,EAAE,MAAyB;QACvD,IAAI,CAAC,UAAU,GAAG,IAAI,oBAAoB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC3D,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,OAAO,CAAC;gBAAE,OAAO,MAAM,IAAI,EAAE,CAAC;YAE7D,MAAM,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;YAClC,MAAM,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YAC7C,MAAM,IAAI,GAAG,MAAM,wBAAwB,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YAE/D,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;YAE3E,MAAM,IAAI,EAAE,CAAC;YAEb,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;YAC/B,MAAM,YAAY,GAAG,MAAM,wBAAwB,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAExE,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,OAAO,EAAE,aAAa,EAAE;gBAC5C,SAAS;gBACT,MAAM,EAAE,QAAQ,CAAC,MAAM;gBACvB,QAAQ,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,uBAAuB,CAAC,gBAAgB,CAAC,KAAK,eAAe,CAAC,GAAG;gBAChG,YAAY;aACb,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,QAA4B;QACzD,IAAI,CAAC;YACH,OAAO,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC/B,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACZ,CAAC;CACF"}
|
|
@@ -1,16 +1,31 @@
|
|
|
1
1
|
import type { ClockPort } from "./clock.port";
|
|
2
2
|
import { type LoggerPort } from "./logger.port";
|
|
3
|
+
import type { HasRequestPath, RequestContext } from "./request-context.port";
|
|
4
|
+
import { Stopwatch } from "./stopwatch.service";
|
|
3
5
|
export declare const UNINFORMATIVE_HEADERS: string[];
|
|
4
6
|
type Dependencies = {
|
|
5
7
|
Logger: LoggerPort;
|
|
6
8
|
Clock: ClockPort;
|
|
7
9
|
};
|
|
8
|
-
export type
|
|
10
|
+
export type HttpLoggerConfig = {
|
|
9
11
|
skip?: ReadonlyArray<string>;
|
|
10
12
|
};
|
|
11
|
-
export
|
|
12
|
-
|
|
13
|
-
|
|
13
|
+
export type HttpLoggerBeforeResult = {
|
|
14
|
+
stopwatch: Stopwatch;
|
|
15
|
+
};
|
|
16
|
+
export type HttpLoggerAfterInput = {
|
|
17
|
+
stopwatch: Stopwatch;
|
|
18
|
+
status: number;
|
|
19
|
+
cacheHit: boolean;
|
|
20
|
+
responseBody: any;
|
|
21
|
+
};
|
|
22
|
+
export declare class HttpLoggerMiddleware {
|
|
23
|
+
private readonly deps;
|
|
24
|
+
private readonly config?;
|
|
25
|
+
constructor(deps: Dependencies, config?: HttpLoggerConfig | undefined);
|
|
26
|
+
shouldSkip(context: HasRequestPath): boolean;
|
|
27
|
+
before(context: RequestContext, correlationId: string, body?: any): HttpLoggerBeforeResult;
|
|
28
|
+
after(context: RequestContext, correlationId: string, input: HttpLoggerAfterInput): void;
|
|
14
29
|
}
|
|
15
30
|
export {};
|
|
16
31
|
//# sourceMappingURL=http-logger.middleware.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"http-logger.middleware.d.ts","sourceRoot":"","sources":["../src/http-logger.middleware.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"http-logger.middleware.d.ts","sourceRoot":"","sources":["../src/http-logger.middleware.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,KAAK,UAAU,EAAgB,MAAM,eAAe,CAAC;AAC9D,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC7E,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,eAAO,MAAM,qBAAqB,UAoBjC,CAAC;AAEF,KAAK,YAAY,GAAG;IAAE,MAAM,EAAE,UAAU,CAAC;IAAC,KAAK,EAAE,SAAS,CAAA;CAAE,CAAC;AAE7D,MAAM,MAAM,gBAAgB,GAAG;IAAE,IAAI,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,CAAA;CAAE,CAAC;AAEhE,MAAM,MAAM,sBAAsB,GAAG;IAAE,SAAS,EAAE,SAAS,CAAA;CAAE,CAAC;AAC9D,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;IAClB,YAAY,EAAE,GAAG,CAAC;CACnB,CAAC;AAEF,qBAAa,oBAAoB;IAE7B,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;gBADP,IAAI,EAAE,YAAY,EAClB,MAAM,CAAC,EAAE,gBAAgB,YAAA;IAG5C,UAAU,CAAC,OAAO,EAAE,cAAc,GAAG,OAAO;IAI5C,MAAM,CAAC,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,EAAE,IAAI,GAAE,GAAQ,GAAG,sBAAsB;IA4B9F,KAAK,CAAC,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,EAAE,KAAK,EAAE,oBAAoB,GAAG,IAAI;CAmBzF"}
|
|
@@ -1,8 +1,4 @@
|
|
|
1
|
-
import { createMiddleware } from "hono/factory";
|
|
2
|
-
import { CacheSourceEnum } from "./cache-resolver.strategy";
|
|
3
|
-
import { CacheResponse } from "./cache-response.middleware";
|
|
4
1
|
import { LogLevelEnum } from "./logger.port";
|
|
5
|
-
import { RequestContextAdapterHono } from "./request-context-hono.adapter";
|
|
6
2
|
import { Stopwatch } from "./stopwatch.service";
|
|
7
3
|
export const UNINFORMATIVE_HEADERS = [
|
|
8
4
|
"accept",
|
|
@@ -25,59 +21,53 @@ export const UNINFORMATIVE_HEADERS = [
|
|
|
25
21
|
"if-none-match",
|
|
26
22
|
"priority",
|
|
27
23
|
];
|
|
28
|
-
export class
|
|
29
|
-
|
|
30
|
-
|
|
24
|
+
export class HttpLoggerMiddleware {
|
|
25
|
+
deps;
|
|
26
|
+
config;
|
|
27
|
+
constructor(deps, config) {
|
|
28
|
+
this.deps = deps;
|
|
29
|
+
this.config = config;
|
|
30
|
+
}
|
|
31
|
+
shouldSkip(context) {
|
|
32
|
+
return this.config?.skip?.some((prefix) => context.request.path.startsWith(prefix)) ?? false;
|
|
33
|
+
}
|
|
34
|
+
before(context, correlationId, body = {}) {
|
|
31
35
|
const client = { ip: context.identity.ip(), ua: context.identity.ua() };
|
|
32
|
-
const
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
}
|
|
37
|
-
// Stryker restore all
|
|
38
|
-
const correlationId = c.get("requestId");
|
|
39
|
-
const httpRequestBeforeMetadata = {
|
|
40
|
-
params: c.req.param(),
|
|
41
|
-
headers: Object.fromEntries(Object.entries(request.headers.toJSON()).filter(([header]) => !UNINFORMATIVE_HEADERS.includes(header))),
|
|
42
|
-
body: (await HttpLogger.parseJSON(request)) ?? {},
|
|
36
|
+
const metadata = {
|
|
37
|
+
params: context.request.params(),
|
|
38
|
+
headers: Object.fromEntries(Object.entries(context.request.headersObject()).filter(([header]) => !UNINFORMATIVE_HEADERS.includes(header))),
|
|
39
|
+
body,
|
|
43
40
|
query: context.request.query(),
|
|
44
41
|
};
|
|
45
|
-
deps.Logger.http({
|
|
42
|
+
this.deps.Logger.http({
|
|
46
43
|
component: "http",
|
|
47
44
|
operation: "http_request_before",
|
|
48
45
|
correlationId,
|
|
49
46
|
message: "request",
|
|
50
|
-
method: request.method,
|
|
51
|
-
url: request.url,
|
|
47
|
+
method: context.request.method,
|
|
48
|
+
url: context.request.url(),
|
|
52
49
|
client,
|
|
53
|
-
metadata
|
|
50
|
+
metadata,
|
|
54
51
|
});
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
const
|
|
59
|
-
const
|
|
60
|
-
|
|
52
|
+
return { stopwatch: new Stopwatch(this.deps) };
|
|
53
|
+
}
|
|
54
|
+
after(context, correlationId, input) {
|
|
55
|
+
const client = { ip: context.identity.ip(), ua: context.identity.ua() };
|
|
56
|
+
const duration = input.stopwatch.stop();
|
|
57
|
+
const level = input.status >= 400 ? LogLevelEnum.error : LogLevelEnum.http;
|
|
58
|
+
this.deps.Logger[level]({
|
|
61
59
|
component: "http",
|
|
62
60
|
operation: "http_request_after",
|
|
63
61
|
correlationId,
|
|
64
62
|
message: "response",
|
|
65
|
-
method: request.method,
|
|
66
|
-
url: request.url,
|
|
67
|
-
status:
|
|
63
|
+
method: context.request.method,
|
|
64
|
+
url: context.request.url(),
|
|
65
|
+
status: input.status,
|
|
68
66
|
durationMs: duration.ms,
|
|
69
67
|
client,
|
|
70
|
-
cacheHit:
|
|
71
|
-
metadata: { response:
|
|
68
|
+
cacheHit: input.cacheHit,
|
|
69
|
+
metadata: { response: input.responseBody },
|
|
72
70
|
});
|
|
73
|
-
});
|
|
74
|
-
static async parseJSON(resource) {
|
|
75
|
-
let result;
|
|
76
|
-
try {
|
|
77
|
-
result = await resource.json();
|
|
78
|
-
}
|
|
79
|
-
catch { }
|
|
80
|
-
return result;
|
|
81
71
|
}
|
|
82
72
|
}
|
|
83
73
|
//# sourceMappingURL=http-logger.middleware.js.map
|