@bgord/bun 1.6.6 → 1.7.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/api-version.middleware.d.ts +2 -2
- package/dist/binary.vo.js +2 -2
- package/dist/binary.vo.js.map +1 -1
- package/dist/bots.vo.d.ts +1 -1
- package/dist/bots.vo.d.ts.map +1 -1
- package/dist/bots.vo.js +132 -3
- package/dist/bots.vo.js.map +1 -1
- package/dist/build-info-repository.service.d.ts +2 -2
- package/dist/build-info-repository.service.js +1 -1
- package/dist/build-info-repository.service.js.map +1 -1
- package/dist/cache-repository-lru-cache.adapter.d.ts +11 -0
- package/dist/cache-repository-lru-cache.adapter.d.ts.map +1 -0
- package/dist/cache-repository-lru-cache.adapter.js +24 -0
- package/dist/cache-repository-lru-cache.adapter.js.map +1 -0
- package/dist/cache-repository-node-cache.adapter.d.ts +2 -7
- package/dist/cache-repository-node-cache.adapter.d.ts.map +1 -1
- package/dist/cache-repository-node-cache.adapter.js +1 -7
- package/dist/cache-repository-node-cache.adapter.js.map +1 -1
- package/dist/cache-repository-noop.adapter.d.ts +2 -7
- package/dist/cache-repository-noop.adapter.d.ts.map +1 -1
- package/dist/cache-repository-noop.adapter.js +1 -7
- package/dist/cache-repository-noop.adapter.js.map +1 -1
- package/dist/cache-repository.port.d.ts +6 -1
- package/dist/cache-repository.port.d.ts.map +1 -1
- package/dist/cache-resolver-simple.strategy.d.ts +18 -0
- package/dist/cache-resolver-simple.strategy.d.ts.map +1 -0
- package/dist/cache-resolver-simple.strategy.js +23 -0
- package/dist/cache-resolver-simple.strategy.js.map +1 -0
- package/dist/cache-resolver.strategy.d.ts +14 -0
- package/dist/cache-resolver.strategy.d.ts.map +1 -0
- package/dist/cache-resolver.strategy.js +6 -0
- package/dist/cache-resolver.strategy.js.map +1 -0
- package/dist/cache-response.middleware.d.ts +2 -2
- package/dist/cache-response.middleware.d.ts.map +1 -1
- package/dist/cache-subject-resolver.vo.d.ts +4 -4
- package/dist/cache-subject-resolver.vo.d.ts.map +1 -1
- package/dist/cache-subject-resolver.vo.js.map +1 -1
- package/dist/cache-subject-segment-cookie.strategy.d.ts +8 -0
- package/dist/cache-subject-segment-cookie.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-cookie.strategy.js +13 -0
- package/dist/cache-subject-segment-cookie.strategy.js.map +1 -0
- package/dist/cache-subject-segment-fixed.strategy.d.ts +7 -0
- package/dist/cache-subject-segment-fixed.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-fixed.strategy.js +10 -0
- package/dist/cache-subject-segment-fixed.strategy.js.map +1 -0
- package/dist/cache-subject-segment-header.strategy.d.ts +8 -0
- package/dist/cache-subject-segment-header.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-header.strategy.js +10 -0
- package/dist/cache-subject-segment-header.strategy.js.map +1 -0
- package/dist/cache-subject-segment-ip.strategy.d.ts +6 -0
- package/dist/cache-subject-segment-ip.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-ip.strategy.js +9 -0
- package/dist/cache-subject-segment-ip.strategy.js.map +1 -0
- package/dist/cache-subject-segment-path.strategy.d.ts +6 -0
- package/dist/cache-subject-segment-path.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-path.strategy.js +6 -0
- package/dist/cache-subject-segment-path.strategy.js.map +1 -0
- package/dist/cache-subject-segment-query.strategy.d.ts +6 -0
- package/dist/cache-subject-segment-query.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-query.strategy.js +10 -0
- package/dist/cache-subject-segment-query.strategy.js.map +1 -0
- package/dist/cache-subject-segment-user.strategy.d.ts +6 -0
- package/dist/cache-subject-segment-user.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment-user.strategy.js +6 -0
- package/dist/cache-subject-segment-user.strategy.js.map +1 -0
- package/dist/cache-subject-segment.strategy.d.ts +6 -0
- package/dist/cache-subject-segment.strategy.d.ts.map +1 -0
- package/dist/cache-subject-segment.strategy.js +2 -0
- package/dist/cache-subject-segment.strategy.js.map +1 -0
- package/dist/certificate-inspector-tls.adapter.d.ts.map +1 -1
- package/dist/certificate-inspector-tls.adapter.js +2 -3
- package/dist/certificate-inspector-tls.adapter.js.map +1 -1
- package/dist/client-from-hono.adapter.d.ts +6 -0
- package/dist/client-from-hono.adapter.d.ts.map +1 -0
- package/dist/client-from-hono.adapter.js +11 -0
- package/dist/client-from-hono.adapter.js.map +1 -0
- package/dist/client-ip.vo.d.ts +8 -0
- package/dist/client-ip.vo.d.ts.map +1 -0
- package/dist/client-ip.vo.js +7 -0
- package/dist/client-ip.vo.js.map +1 -0
- package/dist/client-user-agent.vo.d.ts +9 -0
- package/dist/client-user-agent.vo.d.ts.map +1 -0
- package/dist/client-user-agent.vo.js +12 -0
- package/dist/client-user-agent.vo.js.map +1 -0
- package/dist/client.vo.d.ts +11 -6
- package/dist/client.vo.d.ts.map +1 -1
- package/dist/client.vo.js +27 -7
- package/dist/client.vo.js.map +1 -1
- package/dist/clock-fixed.adapter.d.ts +0 -1
- package/dist/clock-fixed.adapter.d.ts.map +1 -1
- package/dist/clock-fixed.adapter.js +0 -3
- package/dist/clock-fixed.adapter.js.map +1 -1
- package/dist/clock-offset.adapter.d.ts +13 -0
- package/dist/clock-offset.adapter.d.ts.map +1 -0
- package/dist/clock-offset.adapter.js +12 -0
- package/dist/clock-offset.adapter.js.map +1 -0
- package/dist/clock-system.adapter.d.ts +0 -1
- package/dist/clock-system.adapter.d.ts.map +1 -1
- package/dist/clock-system.adapter.js +0 -3
- package/dist/clock-system.adapter.js.map +1 -1
- package/dist/clock.port.d.ts +0 -1
- package/dist/clock.port.d.ts.map +1 -1
- package/dist/command-envelope.js +1 -1
- package/dist/command-envelope.js.map +1 -1
- package/dist/crypto-aes-gcm.service.d.ts +10 -0
- package/dist/crypto-aes-gcm.service.d.ts.map +1 -0
- package/dist/crypto-aes-gcm.service.js +22 -0
- package/dist/crypto-aes-gcm.service.js.map +1 -0
- package/dist/crypto-key-provider-with-cache.adapter.d.ts +18 -0
- package/dist/crypto-key-provider-with-cache.adapter.d.ts.map +1 -0
- package/dist/crypto-key-provider-with-cache.adapter.js +19 -0
- package/dist/crypto-key-provider-with-cache.adapter.js.map +1 -0
- package/dist/decorators.service.d.ts.map +1 -1
- package/dist/decorators.service.js +1 -1
- package/dist/decorators.service.js.map +1 -1
- package/dist/encryption-aes-gcm.adapter.d.ts +18 -0
- package/dist/encryption-aes-gcm.adapter.d.ts.map +1 -0
- package/dist/encryption-aes-gcm.adapter.js +42 -0
- package/dist/encryption-aes-gcm.adapter.js.map +1 -0
- package/dist/environment-loader-noop.adapter.d.ts +13 -0
- package/dist/environment-loader-noop.adapter.d.ts.map +1 -0
- package/dist/environment-loader-noop.adapter.js +12 -0
- package/dist/environment-loader-noop.adapter.js.map +1 -0
- package/dist/environment-loader-process-safe.adapter.d.ts +4 -4
- package/dist/environment-loader-process-safe.adapter.d.ts.map +1 -1
- package/dist/environment-loader-process-safe.adapter.js +2 -2
- package/dist/environment-loader-process-safe.adapter.js.map +1 -1
- package/dist/event-envelope.js +1 -1
- package/dist/event-envelope.js.map +1 -1
- package/dist/event-handler-bare.strategy.d.ts +9 -0
- package/dist/event-handler-bare.strategy.d.ts.map +1 -0
- package/dist/event-handler-bare.strategy.js +6 -0
- package/dist/event-handler-bare.strategy.js.map +1 -0
- package/dist/event-handler-noop.strategy.d.ts +9 -0
- package/dist/event-handler-noop.strategy.d.ts.map +1 -0
- package/dist/event-handler-noop.strategy.js +6 -0
- package/dist/event-handler-noop.strategy.js.map +1 -0
- package/dist/event-handler-with-logger.strategy.d.ts +18 -0
- package/dist/event-handler-with-logger.strategy.d.ts.map +1 -0
- package/dist/event-handler-with-logger.strategy.js +26 -0
- package/dist/event-handler-with-logger.strategy.js.map +1 -0
- package/dist/event-handler.strategy.d.ts +8 -0
- package/dist/event-handler.strategy.d.ts.map +1 -0
- package/dist/event-handler.strategy.js +2 -0
- package/dist/event-handler.strategy.js.map +1 -0
- package/dist/event-store-like.types.d.ts +0 -2
- package/dist/event-store-like.types.d.ts.map +1 -1
- package/dist/event-store.d.ts +0 -2
- package/dist/event-store.d.ts.map +1 -1
- package/dist/event-store.js +0 -4
- package/dist/event-store.js.map +1 -1
- package/dist/file-reader-json-bun-forgiving.adapter.d.ts +6 -0
- package/dist/file-reader-json-bun-forgiving.adapter.d.ts.map +1 -0
- package/dist/file-reader-json-bun-forgiving.adapter.js +11 -0
- package/dist/file-reader-json-bun-forgiving.adapter.js.map +1 -0
- package/dist/file-reader-json-bun.adapter.d.ts +6 -0
- package/dist/file-reader-json-bun.adapter.d.ts.map +1 -0
- package/dist/file-reader-json-bun.adapter.js +6 -0
- package/dist/file-reader-json-bun.adapter.js.map +1 -0
- package/dist/file-reader-json-noop.adapter.d.ts +8 -0
- package/dist/file-reader-json-noop.adapter.d.ts.map +1 -0
- package/dist/file-reader-json-noop.adapter.js +10 -0
- package/dist/file-reader-json-noop.adapter.js.map +1 -0
- package/dist/file-reader-json-with-cache.adapter.d.ts +19 -0
- package/dist/file-reader-json-with-cache.adapter.d.ts.map +1 -0
- package/dist/file-reader-json-with-cache.adapter.js +20 -0
- package/dist/file-reader-json-with-cache.adapter.js.map +1 -0
- package/dist/file-reader-json.port.d.ts +6 -0
- package/dist/file-reader-json.port.d.ts.map +1 -0
- package/dist/file-reader-json.port.js +2 -0
- package/dist/file-reader-json.port.js.map +1 -0
- package/dist/hash-content-noop.strategy.d.ts +6 -0
- package/dist/hash-content-noop.strategy.d.ts.map +1 -0
- package/dist/hash-content-noop.strategy.js +7 -0
- package/dist/hash-content-noop.strategy.js.map +1 -0
- package/dist/hash-content-sha256-bun.strategy.d.ts +6 -0
- package/dist/hash-content-sha256-bun.strategy.d.ts.map +1 -0
- package/dist/hash-content-sha256-bun.strategy.js +9 -0
- package/dist/hash-content-sha256-bun.strategy.js.map +1 -0
- package/dist/hash-content.strategy.d.ts +5 -0
- package/dist/hash-content.strategy.d.ts.map +1 -0
- package/dist/hash-content.strategy.js +2 -0
- package/dist/hash-content.strategy.js.map +1 -0
- package/dist/hash-file-sha256-bun.adapter.d.ts +2 -2
- package/dist/hash-file-sha256-bun.adapter.d.ts.map +1 -1
- package/dist/healthcheck.service.d.ts +32 -21
- package/dist/healthcheck.service.d.ts.map +1 -1
- package/dist/healthcheck.service.js +38 -19
- package/dist/healthcheck.service.js.map +1 -1
- package/dist/http-logger.middleware.d.ts.map +1 -1
- package/dist/http-logger.middleware.js +5 -5
- package/dist/http-logger.middleware.js.map +1 -1
- package/dist/i18n.service.d.ts +2 -2
- package/dist/index.d.ts +123 -48
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +124 -48
- package/dist/index.js.map +1 -1
- package/dist/job-handler-bare.strategy.d.ts +12 -0
- package/dist/job-handler-bare.strategy.d.ts.map +1 -0
- package/dist/job-handler-bare.strategy.js +12 -0
- package/dist/job-handler-bare.strategy.js.map +1 -0
- package/dist/job-handler-noop.strategy.d.ts +6 -0
- package/dist/job-handler-noop.strategy.d.ts.map +1 -0
- package/dist/job-handler-noop.strategy.js +7 -0
- package/dist/job-handler-noop.strategy.js.map +1 -0
- package/dist/job-handler-with-logger.strategy.d.ts +17 -0
- package/dist/job-handler-with-logger.strategy.d.ts.map +1 -0
- package/dist/job-handler-with-logger.strategy.js +36 -0
- package/dist/job-handler-with-logger.strategy.js.map +1 -0
- package/dist/job-handler.strategy.d.ts +9 -0
- package/dist/job-handler.strategy.d.ts.map +1 -0
- package/dist/job-handler.strategy.js +2 -0
- package/dist/job-handler.strategy.js.map +1 -0
- package/dist/logger-winston-local.adapter.d.ts +2 -2
- package/dist/logger-winston-local.adapter.d.ts.map +1 -1
- package/dist/logger-winston-local.adapter.js +1 -1
- package/dist/logger-winston-local.adapter.js.map +1 -1
- package/dist/logger-winston-production.adapter.d.ts +2 -3
- package/dist/logger-winston-production.adapter.d.ts.map +1 -1
- package/dist/logger-winston-production.adapter.js +1 -7
- package/dist/logger-winston-production.adapter.js.map +1 -1
- package/dist/logger-winston.adapter.d.ts +2 -2
- package/dist/logger-winston.adapter.d.ts.map +1 -1
- package/dist/maintenance-mode.middleware.d.ts +11 -0
- package/dist/maintenance-mode.middleware.d.ts.map +1 -0
- package/dist/maintenance-mode.middleware.js +12 -0
- package/dist/maintenance-mode.middleware.js.map +1 -0
- package/dist/modules/system/events/SECURITY_VIOLATION_DETECTED_EVENT.d.ts +23 -0
- package/dist/modules/system/events/SECURITY_VIOLATION_DETECTED_EVENT.d.ts.map +1 -0
- package/dist/modules/system/events/SECURITY_VIOLATION_DETECTED_EVENT.js +20 -0
- package/dist/modules/system/events/SECURITY_VIOLATION_DETECTED_EVENT.js.map +1 -0
- package/dist/modules/system/events/index.d.ts +1 -0
- package/dist/modules/system/events/index.d.ts.map +1 -1
- package/dist/modules/system/events/index.js +1 -0
- package/dist/modules/system/events/index.js.map +1 -1
- package/dist/modules/system/services/passage-of-time-hourly.service.d.ts +1 -1
- package/dist/modules/system/services/passage-of-time-hourly.service.d.ts.map +1 -1
- package/dist/modules/system/services/passage-of-time-hourly.service.js +1 -2
- package/dist/modules/system/services/passage-of-time-hourly.service.js.map +1 -1
- package/dist/modules/system/services/passage-of-time-minute.service.d.ts +1 -1
- package/dist/modules/system/services/passage-of-time-minute.service.d.ts.map +1 -1
- package/dist/modules/system/services/passage-of-time-minute.service.js +1 -2
- package/dist/modules/system/services/passage-of-time-minute.service.js.map +1 -1
- package/dist/prerequisite-runner-startup.service.d.ts +19 -0
- package/dist/prerequisite-runner-startup.service.d.ts.map +1 -0
- package/dist/prerequisite-runner-startup.service.js +32 -0
- package/dist/prerequisite-runner-startup.service.js.map +1 -0
- package/dist/prerequisite-verifier-binary.adapter.d.ts +13 -0
- package/dist/prerequisite-verifier-binary.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-binary.adapter.js +22 -0
- package/dist/prerequisite-verifier-binary.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-bun.adapter.d.ts +14 -0
- package/dist/prerequisite-verifier-bun.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-bun.adapter.js +23 -0
- package/dist/prerequisite-verifier-bun.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-clock-drift.adapter.d.ts +21 -0
- package/dist/prerequisite-verifier-clock-drift.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-clock-drift.adapter.js +27 -0
- package/dist/prerequisite-verifier-clock-drift.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-dependency-vulnerabilities.adapter.d.ts +8 -0
- package/dist/prerequisite-verifier-dependency-vulnerabilities.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-dependency-vulnerabilities.adapter.js +26 -0
- package/dist/prerequisite-verifier-dependency-vulnerabilities.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-directory.adapter.d.ts +19 -0
- package/dist/prerequisite-verifier-directory.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-directory.adapter.js +48 -0
- package/dist/prerequisite-verifier-directory.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-dns.adapter.d.ts +12 -0
- package/dist/prerequisite-verifier-dns.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-dns.adapter.js +21 -0
- package/dist/prerequisite-verifier-dns.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-external-api.adapter.d.ts +12 -0
- package/dist/prerequisite-verifier-external-api.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-external-api.adapter.js +22 -0
- package/dist/prerequisite-verifier-external-api.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-file.adapter.d.ts +19 -0
- package/dist/prerequisite-verifier-file.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-file.adapter.js +49 -0
- package/dist/prerequisite-verifier-file.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-jobs.adapter.d.ts +13 -0
- package/dist/prerequisite-verifier-jobs.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-jobs.adapter.js +17 -0
- package/dist/prerequisite-verifier-jobs.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-log-file.adapter.d.ts +15 -0
- package/dist/prerequisite-verifier-log-file.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-log-file.adapter.js +27 -0
- package/dist/prerequisite-verifier-log-file.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-mailer.adapter.d.ts +15 -0
- package/dist/prerequisite-verifier-mailer.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-mailer.adapter.js +20 -0
- package/dist/prerequisite-verifier-mailer.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-memory.adapter.d.ts +13 -0
- package/dist/prerequisite-verifier-memory.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-memory.adapter.js +21 -0
- package/dist/prerequisite-verifier-memory.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-node.adapter.d.ts +14 -0
- package/dist/prerequisite-verifier-node.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-node.adapter.js +23 -0
- package/dist/prerequisite-verifier-node.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-os.adapter.d.ts +12 -0
- package/dist/prerequisite-verifier-os.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-os.adapter.js +21 -0
- package/dist/prerequisite-verifier-os.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-outside-connectivity.adapter.d.ts +10 -0
- package/dist/prerequisite-verifier-outside-connectivity.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-outside-connectivity.adapter.js +21 -0
- package/dist/prerequisite-verifier-outside-connectivity.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-port.adapter.d.ts +11 -0
- package/dist/prerequisite-verifier-port.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-port.adapter.js +19 -0
- package/dist/prerequisite-verifier-port.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-ram.adapter.d.ts +13 -0
- package/dist/prerequisite-verifier-ram.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-ram.adapter.js +20 -0
- package/dist/prerequisite-verifier-ram.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-running-user.adapter.d.ts +12 -0
- package/dist/prerequisite-verifier-running-user.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-running-user.adapter.js +18 -0
- package/dist/prerequisite-verifier-running-user.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-self.adapter.d.ts +8 -0
- package/dist/prerequisite-verifier-self.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-self.adapter.js +10 -0
- package/dist/prerequisite-verifier-self.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-space.adapter.d.ts +19 -0
- package/dist/prerequisite-verifier-space.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-space.adapter.js +28 -0
- package/dist/prerequisite-verifier-space.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-sqlite.adapter.d.ts +13 -0
- package/dist/prerequisite-verifier-sqlite.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-sqlite.adapter.js +23 -0
- package/dist/prerequisite-verifier-sqlite.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts +19 -0
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.js +22 -0
- package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts +15 -0
- package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-timezone-utc.adapter.js +19 -0
- package/dist/prerequisite-verifier-timezone-utc.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-translations.adapter.d.ts +23 -0
- package/dist/prerequisite-verifier-translations.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-translations.adapter.js +58 -0
- package/dist/prerequisite-verifier-translations.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-with-cache.adapter.d.ts +19 -0
- package/dist/prerequisite-verifier-with-cache.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-with-cache.adapter.js +23 -0
- package/dist/prerequisite-verifier-with-cache.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts +15 -0
- package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-with-fail-safe.adapter.js +20 -0
- package/dist/prerequisite-verifier-with-fail-safe.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-with-logger.adapter.d.ts +19 -0
- package/dist/prerequisite-verifier-with-logger.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-with-logger.adapter.js +43 -0
- package/dist/prerequisite-verifier-with-logger.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-with-retry.adapter.d.ts +18 -0
- package/dist/prerequisite-verifier-with-retry.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-with-retry.adapter.js +27 -0
- package/dist/prerequisite-verifier-with-retry.adapter.js.map +1 -0
- package/dist/prerequisite-verifier-with-timeout.adapter.d.ts +18 -0
- package/dist/prerequisite-verifier-with-timeout.adapter.d.ts.map +1 -0
- package/dist/prerequisite-verifier-with-timeout.adapter.js +21 -0
- package/dist/prerequisite-verifier-with-timeout.adapter.js.map +1 -0
- package/dist/prerequisite-verifier.decorator.d.ts +29 -0
- package/dist/prerequisite-verifier.decorator.d.ts.map +1 -0
- package/dist/prerequisite-verifier.decorator.js +12 -0
- package/dist/prerequisite-verifier.decorator.js.map +1 -0
- package/dist/prerequisite-verifier.port.d.ts +31 -0
- package/dist/prerequisite-verifier.port.d.ts.map +1 -0
- package/dist/prerequisite-verifier.port.js +18 -0
- package/dist/prerequisite-verifier.port.js.map +1 -0
- package/dist/prerequisite.vo.d.ts +18 -0
- package/dist/prerequisite.vo.d.ts.map +1 -0
- package/dist/prerequisite.vo.js +19 -0
- package/dist/prerequisite.vo.js.map +1 -0
- package/dist/redactor-compact-array.strategy.d.ts +5 -0
- package/dist/redactor-compact-array.strategy.d.ts.map +1 -0
- package/dist/redactor-compact-array.strategy.js +7 -0
- package/dist/redactor-compact-array.strategy.js.map +1 -0
- package/dist/redactor-compact-object.strategy.d.ts +12 -0
- package/dist/redactor-compact-object.strategy.d.ts.map +1 -0
- package/dist/redactor-compact-object.strategy.js +17 -0
- package/dist/redactor-compact-object.strategy.js.map +1 -0
- package/dist/redactor-composite.strategy.d.ts +7 -0
- package/dist/redactor-composite.strategy.d.ts.map +1 -0
- package/dist/redactor-composite.strategy.js +10 -0
- package/dist/redactor-composite.strategy.js.map +1 -0
- package/dist/redactor-mask.strategy.d.ts +8 -0
- package/dist/redactor-mask.strategy.d.ts.map +1 -0
- package/dist/redactor-mask.strategy.js +33 -0
- package/dist/redactor-mask.strategy.js.map +1 -0
- package/dist/redactor-noop.strategy.d.ts +5 -0
- package/dist/redactor-noop.strategy.d.ts.map +1 -0
- package/dist/redactor-noop.strategy.js +6 -0
- package/dist/redactor-noop.strategy.js.map +1 -0
- package/dist/redactor.strategy.d.ts +4 -0
- package/dist/redactor.strategy.d.ts.map +1 -0
- package/dist/redactor.strategy.js +2 -0
- package/dist/redactor.strategy.js.map +1 -0
- package/dist/retry-backoff-exponential.strategy.d.ts +8 -0
- package/dist/retry-backoff-exponential.strategy.d.ts.map +1 -0
- package/dist/retry-backoff-exponential.strategy.js +13 -0
- package/dist/retry-backoff-exponential.strategy.js.map +1 -0
- package/dist/retry-backoff-fibonacci.strategy.d.ts +9 -0
- package/dist/retry-backoff-fibonacci.strategy.d.ts.map +1 -0
- package/dist/retry-backoff-fibonacci.strategy.js +18 -0
- package/dist/retry-backoff-fibonacci.strategy.js.map +1 -0
- package/dist/retry-backoff-linear.strategy.d.ts +8 -0
- package/dist/retry-backoff-linear.strategy.d.ts.map +1 -0
- package/dist/retry-backoff-linear.strategy.js +11 -0
- package/dist/retry-backoff-linear.strategy.js.map +1 -0
- package/dist/retry-backoff-noop.strategy.d.ts +6 -0
- package/dist/retry-backoff-noop.strategy.d.ts.map +1 -0
- package/dist/retry-backoff-noop.strategy.js +7 -0
- package/dist/retry-backoff-noop.strategy.js.map +1 -0
- package/dist/retry-backoff.strategy.d.ts +5 -0
- package/dist/retry-backoff.strategy.d.ts.map +1 -0
- package/dist/retry-backoff.strategy.js +2 -0
- package/dist/retry-backoff.strategy.js.map +1 -0
- package/dist/retry.service.d.ts +20 -0
- package/dist/retry.service.d.ts.map +1 -0
- package/dist/retry.service.js +25 -0
- package/dist/retry.service.js.map +1 -0
- package/dist/sealer-aes-gcm.adapter.d.ts +17 -0
- package/dist/sealer-aes-gcm.adapter.d.ts.map +1 -0
- package/dist/sealer-aes-gcm.adapter.js +27 -0
- package/dist/sealer-aes-gcm.adapter.js.map +1 -0
- package/dist/sealer-noop.adapter.d.ts +6 -0
- package/dist/sealer-noop.adapter.d.ts.map +1 -0
- package/dist/sealer-noop.adapter.js +9 -0
- package/dist/sealer-noop.adapter.js.map +1 -0
- package/dist/sealer.port.d.ts +5 -0
- package/dist/sealer.port.d.ts.map +1 -0
- package/dist/sealer.port.js +2 -0
- package/dist/sealer.port.js.map +1 -0
- package/dist/security-context.vo.d.ts +10 -0
- package/dist/security-context.vo.d.ts.map +1 -0
- package/dist/security-context.vo.js +11 -0
- package/dist/security-context.vo.js.map +1 -0
- package/dist/security-countermeasure-ban.strategy.d.ts +29 -0
- package/dist/security-countermeasure-ban.strategy.d.ts.map +1 -0
- package/dist/security-countermeasure-ban.strategy.js +40 -0
- package/dist/security-countermeasure-ban.strategy.js.map +1 -0
- package/dist/security-countermeasure-mirage.strategy.d.ts +19 -0
- package/dist/security-countermeasure-mirage.strategy.d.ts.map +1 -0
- package/dist/security-countermeasure-mirage.strategy.js +24 -0
- package/dist/security-countermeasure-mirage.strategy.js.map +1 -0
- package/dist/security-countermeasure-name.vo.d.ts +10 -0
- package/dist/security-countermeasure-name.vo.d.ts.map +1 -0
- package/dist/security-countermeasure-name.vo.js +16 -0
- package/dist/security-countermeasure-name.vo.js.map +1 -0
- package/dist/security-countermeasure-noop.strategy.d.ts +6 -0
- package/dist/security-countermeasure-noop.strategy.d.ts.map +1 -0
- package/dist/security-countermeasure-noop.strategy.js +10 -0
- package/dist/security-countermeasure-noop.strategy.js.map +1 -0
- package/dist/security-countermeasure-report.strategy.d.ts +14 -0
- package/dist/security-countermeasure-report.strategy.d.ts.map +1 -0
- package/dist/security-countermeasure-report.strategy.js +22 -0
- package/dist/security-countermeasure-report.strategy.js.map +1 -0
- package/dist/security-countermeasure-tarpit.strategy.d.ts +19 -0
- package/dist/security-countermeasure-tarpit.strategy.d.ts.map +1 -0
- package/dist/security-countermeasure-tarpit.strategy.js +24 -0
- package/dist/security-countermeasure-tarpit.strategy.js.map +1 -0
- package/dist/security-countermeasure.strategy.d.ts +26 -0
- package/dist/security-countermeasure.strategy.d.ts.map +1 -0
- package/dist/security-countermeasure.strategy.js +2 -0
- package/dist/security-countermeasure.strategy.js.map +1 -0
- package/dist/security-policy.vo.d.ts +8 -0
- package/dist/security-policy.vo.d.ts.map +1 -0
- package/dist/security-policy.vo.js +9 -0
- package/dist/security-policy.vo.js.map +1 -0
- package/dist/security-rule-and.strategy.d.ts +13 -0
- package/dist/security-rule-and.strategy.d.ts.map +1 -0
- package/dist/security-rule-and.strategy.js +22 -0
- package/dist/security-rule-and.strategy.js.map +1 -0
- package/dist/security-rule-bait-routes.strategy.d.ts +9 -0
- package/dist/security-rule-bait-routes.strategy.d.ts.map +1 -0
- package/dist/security-rule-bait-routes.strategy.js +14 -0
- package/dist/security-rule-bait-routes.strategy.js.map +1 -0
- package/dist/security-rule-fail.strategy.d.ts +6 -0
- package/dist/security-rule-fail.strategy.d.ts.map +1 -0
- package/dist/security-rule-fail.strategy.js +10 -0
- package/dist/security-rule-fail.strategy.js.map +1 -0
- package/dist/security-rule-honey-pot-field.strategy.d.ts +9 -0
- package/dist/security-rule-honey-pot-field.strategy.d.ts.map +1 -0
- package/dist/security-rule-honey-pot-field.strategy.js +17 -0
- package/dist/security-rule-honey-pot-field.strategy.js.map +1 -0
- package/dist/security-rule-name.vo.d.ts +10 -0
- package/dist/security-rule-name.vo.d.ts.map +1 -0
- package/dist/security-rule-name.vo.js +16 -0
- package/dist/security-rule-name.vo.js.map +1 -0
- package/dist/security-rule-or.strategy.d.ts +13 -0
- package/dist/security-rule-or.strategy.d.ts.map +1 -0
- package/dist/security-rule-or.strategy.js +22 -0
- package/dist/security-rule-or.strategy.js.map +1 -0
- package/dist/security-rule-pass.strategy.d.ts +6 -0
- package/dist/security-rule-pass.strategy.d.ts.map +1 -0
- package/dist/security-rule-pass.strategy.js +10 -0
- package/dist/security-rule-pass.strategy.js.map +1 -0
- package/dist/security-rule-user-agent.strategy.d.ts +9 -0
- package/dist/security-rule-user-agent.strategy.d.ts.map +1 -0
- package/dist/security-rule-user-agent.strategy.js +18 -0
- package/dist/security-rule-user-agent.strategy.js.map +1 -0
- package/dist/security-rule-violation-threshold.strategy.d.ts +20 -0
- package/dist/security-rule-violation-threshold.strategy.d.ts.map +1 -0
- package/dist/security-rule-violation-threshold.strategy.js +36 -0
- package/dist/security-rule-violation-threshold.strategy.js.map +1 -0
- package/dist/security-rule.strategy.d.ts +7 -0
- package/dist/security-rule.strategy.d.ts.map +1 -0
- package/dist/security-rule.strategy.js +2 -0
- package/dist/security-rule.strategy.js.map +1 -0
- package/dist/setup.service.d.ts +4 -2
- package/dist/setup.service.d.ts.map +1 -1
- package/dist/setup.service.js +2 -3
- package/dist/setup.service.js.map +1 -1
- package/dist/shield-api-key.strategy.d.ts +15 -0
- package/dist/shield-api-key.strategy.d.ts.map +1 -0
- package/dist/shield-api-key.strategy.js +16 -0
- package/dist/shield-api-key.strategy.js.map +1 -0
- package/dist/shield-auth.strategy.d.ts +12 -0
- package/dist/shield-auth.strategy.d.ts.map +1 -0
- package/dist/shield-auth.strategy.js +34 -0
- package/dist/shield-auth.strategy.js.map +1 -0
- package/dist/shield-basic-auth.strategy.d.ts +14 -0
- package/dist/shield-basic-auth.strategy.d.ts.map +1 -0
- package/dist/shield-basic-auth.strategy.js +10 -0
- package/dist/shield-basic-auth.strategy.js.map +1 -0
- package/dist/shield-captcha-hcaptcha-local.strategy.d.ts +10 -0
- package/dist/shield-captcha-hcaptcha-local.strategy.d.ts.map +1 -0
- package/dist/shield-captcha-hcaptcha-local.strategy.js +24 -0
- package/dist/shield-captcha-hcaptcha-local.strategy.js.map +1 -0
- package/dist/shield-captcha-hcaptcha.strategy.d.ts +10 -0
- package/dist/shield-captcha-hcaptcha.strategy.d.ts.map +1 -0
- package/dist/shield-captcha-hcaptcha.strategy.js +24 -0
- package/dist/shield-captcha-hcaptcha.strategy.js.map +1 -0
- package/dist/shield-captcha-recaptcha.strategy.d.ts +18 -0
- package/dist/shield-captcha-recaptcha.strategy.d.ts.map +1 -0
- package/dist/shield-captcha-recaptcha.strategy.js +37 -0
- package/dist/shield-captcha-recaptcha.strategy.js.map +1 -0
- package/dist/shield-noop.strategy.d.ts +5 -0
- package/dist/shield-noop.strategy.d.ts.map +1 -0
- package/dist/shield-noop.strategy.js +5 -0
- package/dist/shield-noop.strategy.js.map +1 -0
- package/dist/shield-rate-limit.strategy.d.ts +24 -0
- package/dist/shield-rate-limit.strategy.d.ts.map +1 -0
- package/dist/shield-rate-limit.strategy.js +23 -0
- package/dist/shield-rate-limit.strategy.js.map +1 -0
- package/dist/shield-security.strategy.d.ts +19 -0
- package/dist/shield-security.strategy.d.ts.map +1 -0
- package/dist/shield-security.strategy.js +54 -0
- package/dist/shield-security.strategy.js.map +1 -0
- package/dist/shield-timeout.strategy.d.ts +14 -0
- package/dist/shield-timeout.strategy.d.ts.map +1 -0
- package/dist/shield-timeout.strategy.js +12 -0
- package/dist/shield-timeout.strategy.js.map +1 -0
- package/dist/shield.strategy.d.ts +5 -0
- package/dist/shield.strategy.d.ts.map +1 -0
- package/dist/shield.strategy.js +2 -0
- package/dist/shield.strategy.js.map +1 -0
- package/dist/sleeper-noop.adapter.d.ts +5 -0
- package/dist/sleeper-noop.adapter.d.ts.map +1 -0
- package/dist/sleeper-noop.adapter.js +4 -0
- package/dist/sleeper-noop.adapter.js.map +1 -0
- package/dist/sleeper-system.adapter.d.ts +6 -0
- package/dist/sleeper-system.adapter.d.ts.map +1 -0
- package/dist/sleeper-system.adapter.js +6 -0
- package/dist/sleeper-system.adapter.js.map +1 -0
- package/dist/sleeper.port.d.ts +5 -0
- package/dist/sleeper.port.d.ts.map +1 -0
- package/dist/sleeper.port.js +2 -0
- package/dist/sleeper.port.js.map +1 -0
- package/dist/slower.middleware.d.ts +6 -1
- package/dist/slower.middleware.d.ts.map +1 -1
- package/dist/slower.middleware.js +2 -2
- package/dist/slower.middleware.js.map +1 -1
- package/dist/stopwatch.service.d.ts +18 -0
- package/dist/stopwatch.service.d.ts.map +1 -0
- package/dist/stopwatch.service.js +22 -0
- package/dist/stopwatch.service.js.map +1 -0
- package/dist/time-zone-offset.middleware.d.ts +2 -1
- package/dist/time-zone-offset.middleware.d.ts.map +1 -1
- package/dist/time-zone-offset.middleware.js +11 -2
- package/dist/time-zone-offset.middleware.js.map +1 -1
- package/dist/timekeeper-google.adapter.d.ts.map +1 -1
- package/dist/timekeeper-google.adapter.js +1 -1
- package/dist/timekeeper-google.adapter.js.map +1 -1
- package/dist/timeout-cancellable-runner-bare.adapter.d.ts +6 -0
- package/dist/timeout-cancellable-runner-bare.adapter.d.ts.map +1 -0
- package/dist/timeout-cancellable-runner-bare.adapter.js +24 -0
- package/dist/timeout-cancellable-runner-bare.adapter.js.map +1 -0
- package/dist/timeout-cancellable-runner-noop.adapter.d.ts +5 -0
- package/dist/timeout-cancellable-runner-noop.adapter.d.ts.map +1 -0
- package/dist/timeout-cancellable-runner-noop.adapter.js +7 -0
- package/dist/timeout-cancellable-runner-noop.adapter.js.map +1 -0
- package/dist/timeout-cancellable-runner.port.d.ts +8 -0
- package/dist/timeout-cancellable-runner.port.d.ts.map +1 -0
- package/dist/timeout-cancellable-runner.port.js +2 -0
- package/dist/timeout-cancellable-runner.port.js.map +1 -0
- package/dist/timeout-runner-bare.adapter.d.ts +6 -0
- package/dist/timeout-runner-bare.adapter.d.ts.map +1 -0
- package/dist/timeout-runner-bare.adapter.js +17 -0
- package/dist/timeout-runner-bare.adapter.js.map +1 -0
- package/dist/timeout-runner-error.adapter.d.ts +6 -0
- package/dist/timeout-runner-error.adapter.d.ts.map +1 -0
- package/dist/timeout-runner-error.adapter.js +7 -0
- package/dist/timeout-runner-error.adapter.js.map +1 -0
- package/dist/timeout-runner-monitor.adapter.d.ts +13 -0
- package/dist/timeout-runner-monitor.adapter.d.ts.map +1 -0
- package/dist/timeout-runner-monitor.adapter.js +16 -0
- package/dist/timeout-runner-monitor.adapter.js.map +1 -0
- package/dist/timeout-runner-noop.adapter.d.ts +6 -0
- package/dist/timeout-runner-noop.adapter.d.ts.map +1 -0
- package/dist/timeout-runner-noop.adapter.js +6 -0
- package/dist/timeout-runner-noop.adapter.js.map +1 -0
- package/dist/timeout-runner.port.d.ts +8 -0
- package/dist/timeout-runner.port.d.ts.map +1 -0
- package/dist/timeout-runner.port.js +2 -0
- package/dist/timeout-runner.port.js.map +1 -0
- package/dist/translations.service.d.ts +2 -2
- package/dist/translations.service.d.ts.map +1 -1
- package/dist/translations.service.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/uptime.service.d.ts.map +1 -1
- package/dist/uptime.service.js +1 -1
- package/dist/uptime.service.js.map +1 -1
- package/dist/visitor-id-client.strategy.d.ts +14 -0
- package/dist/visitor-id-client.strategy.d.ts.map +1 -0
- package/dist/visitor-id-client.strategy.js +14 -0
- package/dist/visitor-id-client.strategy.js.map +1 -0
- package/dist/visitor-id.strategy.d.ts +5 -0
- package/dist/visitor-id.strategy.d.ts.map +1 -0
- package/dist/visitor-id.strategy.js +2 -0
- package/dist/visitor-id.strategy.js.map +1 -0
- package/package.json +12 -11
- package/readme.md +129 -72
- package/src/api-version.middleware.ts +2 -2
- package/src/binary.vo.ts +2 -2
- package/src/bots.vo.ts +132 -3
- package/src/build-info-repository.service.ts +3 -3
- package/src/cache-repository-lru-cache.adapter.ts +32 -0
- package/src/cache-repository-node-cache.adapter.ts +3 -9
- package/src/cache-repository-noop.adapter.ts +2 -7
- package/src/cache-repository.port.ts +2 -1
- package/src/cache-resolver-simple.strategy.ts +33 -0
- package/src/cache-resolver.strategy.ts +17 -0
- package/src/cache-response.middleware.ts +2 -2
- package/src/cache-subject-resolver.vo.ts +4 -4
- package/src/cache-subject-segment-cookie.strategy.ts +12 -0
- package/src/cache-subject-segment-fixed.strategy.ts +9 -0
- package/src/cache-subject-segment-header.strategy.ts +10 -0
- package/src/cache-subject-segment-ip.strategy.ts +10 -0
- package/src/cache-subject-segment-path.strategy.ts +8 -0
- package/src/cache-subject-segment-query.strategy.ts +13 -0
- package/src/cache-subject-segment-user.strategy.ts +8 -0
- package/src/cache-subject-segment.strategy.ts +7 -0
- package/src/certificate-inspector-tls.adapter.ts +4 -3
- package/src/client-from-hono.adapter.ts +16 -0
- package/src/client-ip.vo.ts +10 -0
- package/src/client-user-agent.vo.ts +15 -0
- package/src/client.vo.ts +35 -13
- package/src/clock-fixed.adapter.ts +0 -4
- package/src/clock-offset.adapter.ts +15 -0
- package/src/clock-system.adapter.ts +0 -4
- package/src/clock.port.ts +0 -2
- package/src/command-envelope.ts +1 -1
- package/src/crypto-aes-gcm.service.ts +37 -0
- package/src/crypto-key-provider-with-cache.adapter.ts +28 -0
- package/src/decorators.service.ts +1 -1
- package/src/encryption-aes-gcm.adapter.ts +57 -0
- package/src/environment-loader-noop.adapter.ts +16 -0
- package/src/environment-loader-process-safe.adapter.ts +5 -5
- package/src/event-envelope.ts +1 -1
- package/src/event-handler-bare.strategy.ts +9 -0
- package/src/event-handler-noop.strategy.ts +9 -0
- package/src/event-handler-with-logger.strategy.ts +31 -0
- package/src/event-handler.strategy.ts +8 -0
- package/src/event-store-like.types.ts +0 -4
- package/src/event-store.ts +0 -6
- package/src/file-reader-json-bun-forgiving.adapter.ts +14 -0
- package/src/file-reader-json-bun.adapter.ts +10 -0
- package/src/file-reader-json-noop.adapter.ts +12 -0
- package/src/file-reader-json-with-cache.adapter.ts +34 -0
- package/src/file-reader-json.port.ts +7 -0
- package/src/hash-content-noop.strategy.ts +8 -0
- package/src/hash-content-sha256-bun.strategy.ts +11 -0
- package/src/hash-content.strategy.ts +5 -0
- package/src/hash-file-sha256-bun.adapter.ts +2 -2
- package/src/healthcheck.service.ts +68 -29
- package/src/http-logger.middleware.ts +5 -5
- package/src/i18n.service.ts +2 -2
- package/src/index.ts +124 -48
- package/src/job-handler-bare.strategy.ts +15 -0
- package/src/job-handler-noop.strategy.ts +9 -0
- package/src/job-handler-with-logger.strategy.ts +44 -0
- package/src/job-handler.strategy.ts +10 -0
- package/src/logger-winston-local.adapter.ts +3 -3
- package/src/logger-winston-production.adapter.ts +3 -13
- package/src/logger-winston.adapter.ts +2 -2
- package/src/maintenance-mode.middleware.ts +15 -0
- package/src/modules/system/events/SECURITY_VIOLATION_DETECTED_EVENT.ts +23 -0
- package/src/modules/system/events/index.ts +1 -0
- package/src/modules/system/services/passage-of-time-hourly.service.ts +2 -4
- package/src/modules/system/services/passage-of-time-minute.service.ts +2 -4
- package/src/prerequisite-runner-startup.service.ts +44 -0
- package/src/prerequisite-verifier-binary.adapter.ts +21 -0
- package/src/prerequisite-verifier-bun.adapter.ts +21 -0
- package/src/prerequisite-verifier-clock-drift.adapter.ts +32 -0
- package/src/prerequisite-verifier-dependency-vulnerabilities.adapter.ts +38 -0
- package/src/prerequisite-verifier-directory.adapter.ts +56 -0
- package/src/prerequisite-verifier-dns.adapter.ts +20 -0
- package/src/prerequisite-verifier-external-api.adapter.ts +20 -0
- package/src/prerequisite-verifier-file.adapter.ts +57 -0
- package/src/prerequisite-verifier-jobs.adapter.ts +15 -0
- package/src/prerequisite-verifier-log-file.adapter.ts +29 -0
- package/src/prerequisite-verifier-mailer.adapter.ts +22 -0
- package/src/prerequisite-verifier-memory.adapter.ts +22 -0
- package/src/prerequisite-verifier-node.adapter.ts +21 -0
- package/src/prerequisite-verifier-os.adapter.ts +22 -0
- package/src/prerequisite-verifier-outside-connectivity.adapter.ts +23 -0
- package/src/prerequisite-verifier-port.adapter.ts +23 -0
- package/src/prerequisite-verifier-ram.adapter.ts +20 -0
- package/src/prerequisite-verifier-running-user.adapter.ts +17 -0
- package/src/prerequisite-verifier-self.adapter.ts +11 -0
- package/src/prerequisite-verifier-space.adapter.ts +32 -0
- package/src/prerequisite-verifier-sqlite.adapter.ts +25 -0
- package/src/prerequisite-verifier-ssl-certificate-expiry.adapter.ts +27 -0
- package/src/prerequisite-verifier-timezone-utc.adapter.ts +20 -0
- package/src/prerequisite-verifier-translations.adapter.ts +86 -0
- package/src/prerequisite-verifier-with-cache.adapter.ts +35 -0
- package/src/prerequisite-verifier-with-fail-safe.adapter.ts +37 -0
- package/src/prerequisite-verifier-with-logger.adapter.ts +51 -0
- package/src/prerequisite-verifier-with-retry.adapter.ts +35 -0
- package/src/prerequisite-verifier-with-timeout.adapter.ts +31 -0
- package/src/prerequisite-verifier.decorator.ts +49 -0
- package/src/prerequisite-verifier.port.ts +38 -0
- package/src/prerequisite.vo.ts +28 -0
- package/src/redactor-compact-array.strategy.ts +10 -0
- package/src/redactor-compact-object.strategy.ts +24 -0
- package/src/redactor-composite.strategy.ts +9 -0
- package/src/redactor-mask.strategy.ts +38 -0
- package/src/redactor-noop.strategy.ts +7 -0
- package/src/redactor.strategy.ts +3 -0
- package/src/retry-backoff-exponential.strategy.ts +11 -0
- package/src/retry-backoff-fibonacci.strategy.ts +16 -0
- package/src/retry-backoff-linear.strategy.ts +10 -0
- package/src/retry-backoff-noop.strategy.ts +8 -0
- package/src/retry-backoff.strategy.ts +5 -0
- package/src/retry.service.ts +36 -0
- package/src/sealer-aes-gcm.adapter.ts +38 -0
- package/src/sealer-noop.adapter.ts +11 -0
- package/src/sealer.port.ts +4 -0
- package/src/security-context.vo.ts +11 -0
- package/src/security-countermeasure-ban.strategy.ts +62 -0
- package/src/security-countermeasure-mirage.strategy.ts +30 -0
- package/src/security-countermeasure-name.vo.ts +20 -0
- package/src/security-countermeasure-noop.strategy.ts +12 -0
- package/src/security-countermeasure-report.strategy.ts +27 -0
- package/src/security-countermeasure-tarpit.strategy.ts +31 -0
- package/src/security-countermeasure.strategy.ts +15 -0
- package/src/security-policy.vo.ts +9 -0
- package/src/security-rule-and.strategy.ts +23 -0
- package/src/security-rule-bait-routes.strategy.ts +15 -0
- package/src/security-rule-fail.strategy.ts +12 -0
- package/src/security-rule-honey-pot-field.strategy.ts +20 -0
- package/src/security-rule-name.vo.ts +20 -0
- package/src/security-rule-or.strategy.ts +23 -0
- package/src/security-rule-pass.strategy.ts +12 -0
- package/src/security-rule-user-agent.strategy.ts +20 -0
- package/src/security-rule-violation-threshold.strategy.ts +46 -0
- package/src/security-rule.strategy.ts +8 -0
- package/src/setup.service.ts +5 -5
- package/src/shield-api-key.strategy.ts +20 -0
- package/src/shield-auth.strategy.ts +42 -0
- package/src/shield-basic-auth.strategy.ts +17 -0
- package/src/shield-captcha-hcaptcha-local.strategy.ts +24 -0
- package/src/shield-captcha-hcaptcha.strategy.ts +24 -0
- package/src/shield-captcha-recaptcha.strategy.ts +49 -0
- package/src/shield-noop.strategy.ts +6 -0
- package/src/shield-rate-limit.strategy.ts +41 -0
- package/src/shield-security.strategy.ts +71 -0
- package/src/shield-timeout.strategy.ts +19 -0
- package/src/shield.strategy.ts +5 -0
- package/src/sleeper-noop.adapter.ts +5 -0
- package/src/sleeper-system.adapter.ts +8 -0
- package/src/sleeper.port.ts +5 -0
- package/src/slower.middleware.ts +5 -2
- package/src/stopwatch.service.ts +30 -0
- package/src/time-zone-offset.middleware.ts +12 -3
- package/src/timekeeper-google.adapter.ts +3 -2
- package/src/timeout-cancellable-runner-bare.adapter.ts +35 -0
- package/src/timeout-cancellable-runner-noop.adapter.ts +9 -0
- package/src/timeout-cancellable-runner.port.ts +7 -0
- package/src/timeout-runner-bare.adapter.ts +23 -0
- package/src/timeout-runner-error.adapter.ts +8 -0
- package/src/timeout-runner-monitor.adapter.ts +24 -0
- package/src/timeout-runner-noop.adapter.ts +8 -0
- package/src/timeout-runner.port.ts +7 -0
- package/src/translations.service.ts +2 -2
- package/src/uptime.service.ts +1 -1
- package/src/visitor-id-client.strategy.ts +20 -0
- package/src/visitor-id.strategy.ts +5 -0
- package/dist/cache-resolver-simple.adapter.d.ts +0 -19
- package/dist/cache-resolver-simple.adapter.d.ts.map +0 -1
- package/dist/cache-resolver-simple.adapter.js +0 -26
- package/dist/cache-resolver-simple.adapter.js.map +0 -1
- package/dist/cache-resolver.port.d.ts +0 -16
- package/dist/cache-resolver.port.d.ts.map +0 -1
- package/dist/cache-resolver.port.js +0 -6
- package/dist/cache-resolver.port.js.map +0 -1
- package/dist/cache-subject-segment-cookie.d.ts +0 -8
- package/dist/cache-subject-segment-cookie.d.ts.map +0 -1
- package/dist/cache-subject-segment-cookie.js +0 -13
- package/dist/cache-subject-segment-cookie.js.map +0 -1
- package/dist/cache-subject-segment-fixed.d.ts +0 -7
- package/dist/cache-subject-segment-fixed.d.ts.map +0 -1
- package/dist/cache-subject-segment-fixed.js +0 -10
- package/dist/cache-subject-segment-fixed.js.map +0 -1
- package/dist/cache-subject-segment-header.d.ts +0 -8
- package/dist/cache-subject-segment-header.d.ts.map +0 -1
- package/dist/cache-subject-segment-header.js +0 -10
- package/dist/cache-subject-segment-header.js.map +0 -1
- package/dist/cache-subject-segment-path.d.ts +0 -6
- package/dist/cache-subject-segment-path.d.ts.map +0 -1
- package/dist/cache-subject-segment-path.js +0 -6
- package/dist/cache-subject-segment-path.js.map +0 -1
- package/dist/cache-subject-segment-query.d.ts +0 -6
- package/dist/cache-subject-segment-query.d.ts.map +0 -1
- package/dist/cache-subject-segment-query.js +0 -10
- package/dist/cache-subject-segment-query.js.map +0 -1
- package/dist/cache-subject-segment-user.d.ts +0 -6
- package/dist/cache-subject-segment-user.d.ts.map +0 -1
- package/dist/cache-subject-segment-user.js +0 -6
- package/dist/cache-subject-segment-user.js.map +0 -1
- package/dist/cache-subject-segment.port.d.ts +0 -6
- package/dist/cache-subject-segment.port.d.ts.map +0 -1
- package/dist/cache-subject-segment.port.js +0 -2
- package/dist/cache-subject-segment.port.js.map +0 -1
- package/dist/encryption-bun.adapter.d.ts +0 -21
- package/dist/encryption-bun.adapter.d.ts.map +0 -1
- package/dist/encryption-bun.adapter.js +0 -54
- package/dist/encryption-bun.adapter.js.map +0 -1
- package/dist/event-handler-bare.adapter.d.ts +0 -9
- package/dist/event-handler-bare.adapter.d.ts.map +0 -1
- package/dist/event-handler-bare.adapter.js +0 -6
- package/dist/event-handler-bare.adapter.js.map +0 -1
- package/dist/event-handler-noop.adapter.d.ts +0 -9
- package/dist/event-handler-noop.adapter.d.ts.map +0 -1
- package/dist/event-handler-noop.adapter.js +0 -6
- package/dist/event-handler-noop.adapter.js.map +0 -1
- package/dist/event-handler-with-logger.adapter.d.ts +0 -18
- package/dist/event-handler-with-logger.adapter.d.ts.map +0 -1
- package/dist/event-handler-with-logger.adapter.js +0 -26
- package/dist/event-handler-with-logger.adapter.js.map +0 -1
- package/dist/event-handler.port.d.ts +0 -8
- package/dist/event-handler.port.d.ts.map +0 -1
- package/dist/event-handler.port.js +0 -2
- package/dist/event-handler.port.js.map +0 -1
- package/dist/hash-content-noop.adapter.d.ts +0 -6
- package/dist/hash-content-noop.adapter.d.ts.map +0 -1
- package/dist/hash-content-noop.adapter.js +0 -7
- package/dist/hash-content-noop.adapter.js.map +0 -1
- package/dist/hash-content-sha256-bun.adapter.d.ts +0 -6
- package/dist/hash-content-sha256-bun.adapter.d.ts.map +0 -1
- package/dist/hash-content-sha256-bun.adapter.js +0 -9
- package/dist/hash-content-sha256-bun.adapter.js.map +0 -1
- package/dist/hash-content.port.d.ts +0 -5
- package/dist/hash-content.port.d.ts.map +0 -1
- package/dist/hash-content.port.js +0 -2
- package/dist/hash-content.port.js.map +0 -1
- package/dist/job-handler-bare.adapter.d.ts +0 -12
- package/dist/job-handler-bare.adapter.d.ts.map +0 -1
- package/dist/job-handler-bare.adapter.js +0 -12
- package/dist/job-handler-bare.adapter.js.map +0 -1
- package/dist/job-handler-noop.adapter.d.ts +0 -6
- package/dist/job-handler-noop.adapter.d.ts.map +0 -1
- package/dist/job-handler-noop.adapter.js +0 -7
- package/dist/job-handler-noop.adapter.js.map +0 -1
- package/dist/job-handler-with-logger.adapter.d.ts +0 -17
- package/dist/job-handler-with-logger.adapter.d.ts.map +0 -1
- package/dist/job-handler-with-logger.adapter.js +0 -36
- package/dist/job-handler-with-logger.adapter.js.map +0 -1
- package/dist/job-handler.port.d.ts +0 -9
- package/dist/job-handler.port.d.ts.map +0 -1
- package/dist/job-handler.port.js +0 -2
- package/dist/job-handler.port.js.map +0 -1
- package/dist/json-file-reader-bun-forgiving.adapter.d.ts +0 -6
- package/dist/json-file-reader-bun-forgiving.adapter.d.ts.map +0 -1
- package/dist/json-file-reader-bun-forgiving.adapter.js +0 -11
- package/dist/json-file-reader-bun-forgiving.adapter.js.map +0 -1
- package/dist/json-file-reader-bun.adapter.d.ts +0 -6
- package/dist/json-file-reader-bun.adapter.d.ts.map +0 -1
- package/dist/json-file-reader-bun.adapter.js +0 -6
- package/dist/json-file-reader-bun.adapter.js.map +0 -1
- package/dist/json-file-reader-noop.adapter.d.ts +0 -8
- package/dist/json-file-reader-noop.adapter.d.ts.map +0 -1
- package/dist/json-file-reader-noop.adapter.js +0 -10
- package/dist/json-file-reader-noop.adapter.js.map +0 -1
- package/dist/json-file-reader.port.d.ts +0 -5
- package/dist/json-file-reader.port.d.ts.map +0 -1
- package/dist/json-file-reader.port.js +0 -2
- package/dist/json-file-reader.port.js.map +0 -1
- package/dist/prerequisites/binary.d.ts +0 -14
- package/dist/prerequisites/binary.d.ts.map +0 -1
- package/dist/prerequisites/binary.js +0 -28
- package/dist/prerequisites/binary.js.map +0 -1
- package/dist/prerequisites/bun.d.ts +0 -16
- package/dist/prerequisites/bun.d.ts.map +0 -1
- package/dist/prerequisites/bun.js +0 -34
- package/dist/prerequisites/bun.js.map +0 -1
- package/dist/prerequisites/clock-drift.d.ts +0 -22
- package/dist/prerequisites/clock-drift.d.ts.map +0 -1
- package/dist/prerequisites/clock-drift.js +0 -38
- package/dist/prerequisites/clock-drift.js.map +0 -1
- package/dist/prerequisites/dependency-vulnerabilities.d.ts +0 -10
- package/dist/prerequisites/dependency-vulnerabilities.d.ts.map +0 -1
- package/dist/prerequisites/dependency-vulnerabilities.js +0 -34
- package/dist/prerequisites/dependency-vulnerabilities.js.map +0 -1
- package/dist/prerequisites/directory.d.ts +0 -21
- package/dist/prerequisites/directory.d.ts.map +0 -1
- package/dist/prerequisites/directory.js +0 -56
- package/dist/prerequisites/directory.js.map +0 -1
- package/dist/prerequisites/dns.d.ts +0 -16
- package/dist/prerequisites/dns.d.ts.map +0 -1
- package/dist/prerequisites/dns.js +0 -30
- package/dist/prerequisites/dns.js.map +0 -1
- package/dist/prerequisites/external-api.d.ts +0 -16
- package/dist/prerequisites/external-api.d.ts.map +0 -1
- package/dist/prerequisites/external-api.js +0 -31
- package/dist/prerequisites/external-api.js.map +0 -1
- package/dist/prerequisites/file.d.ts +0 -21
- package/dist/prerequisites/file.d.ts.map +0 -1
- package/dist/prerequisites/file.js +0 -56
- package/dist/prerequisites/file.js.map +0 -1
- package/dist/prerequisites/index.d.ts +0 -25
- package/dist/prerequisites/index.d.ts.map +0 -1
- package/dist/prerequisites/index.js +0 -25
- package/dist/prerequisites/index.js.map +0 -1
- package/dist/prerequisites/jobs.d.ts +0 -14
- package/dist/prerequisites/jobs.d.ts.map +0 -1
- package/dist/prerequisites/jobs.js +0 -23
- package/dist/prerequisites/jobs.js.map +0 -1
- package/dist/prerequisites/log-file.d.ts +0 -16
- package/dist/prerequisites/log-file.d.ts.map +0 -1
- package/dist/prerequisites/log-file.js +0 -34
- package/dist/prerequisites/log-file.js.map +0 -1
- package/dist/prerequisites/mailer.d.ts +0 -20
- package/dist/prerequisites/mailer.d.ts.map +0 -1
- package/dist/prerequisites/mailer.js +0 -29
- package/dist/prerequisites/mailer.js.map +0 -1
- package/dist/prerequisites/memory.d.ts +0 -14
- package/dist/prerequisites/memory.d.ts.map +0 -1
- package/dist/prerequisites/memory.js +0 -27
- package/dist/prerequisites/memory.js.map +0 -1
- package/dist/prerequisites/node.d.ts +0 -16
- package/dist/prerequisites/node.d.ts.map +0 -1
- package/dist/prerequisites/node.js +0 -32
- package/dist/prerequisites/node.js.map +0 -1
- package/dist/prerequisites/os.d.ts +0 -13
- package/dist/prerequisites/os.d.ts.map +0 -1
- package/dist/prerequisites/os.js +0 -27
- package/dist/prerequisites/os.js.map +0 -1
- package/dist/prerequisites/outside-connectivity.d.ts +0 -15
- package/dist/prerequisites/outside-connectivity.d.ts.map +0 -1
- package/dist/prerequisites/outside-connectivity.js +0 -30
- package/dist/prerequisites/outside-connectivity.js.map +0 -1
- package/dist/prerequisites/port.d.ts +0 -14
- package/dist/prerequisites/port.d.ts.map +0 -1
- package/dist/prerequisites/port.js +0 -25
- package/dist/prerequisites/port.js.map +0 -1
- package/dist/prerequisites/ram.d.ts +0 -14
- package/dist/prerequisites/ram.d.ts.map +0 -1
- package/dist/prerequisites/ram.js +0 -26
- package/dist/prerequisites/ram.js.map +0 -1
- package/dist/prerequisites/running-user.d.ts +0 -13
- package/dist/prerequisites/running-user.d.ts.map +0 -1
- package/dist/prerequisites/running-user.js +0 -24
- package/dist/prerequisites/running-user.js.map +0 -1
- package/dist/prerequisites/self.d.ts +0 -10
- package/dist/prerequisites/self.d.ts.map +0 -1
- package/dist/prerequisites/self.js +0 -18
- package/dist/prerequisites/self.js.map +0 -1
- package/dist/prerequisites/space.d.ts +0 -20
- package/dist/prerequisites/space.d.ts.map +0 -1
- package/dist/prerequisites/space.js +0 -36
- package/dist/prerequisites/space.js.map +0 -1
- package/dist/prerequisites/sqlite.d.ts +0 -14
- package/dist/prerequisites/sqlite.d.ts.map +0 -1
- package/dist/prerequisites/sqlite.js +0 -29
- package/dist/prerequisites/sqlite.js.map +0 -1
- package/dist/prerequisites/ssl-certificate-expiry.d.ts +0 -21
- package/dist/prerequisites/ssl-certificate-expiry.d.ts.map +0 -1
- package/dist/prerequisites/ssl-certificate-expiry.js +0 -32
- package/dist/prerequisites/ssl-certificate-expiry.js.map +0 -1
- package/dist/prerequisites/timezone-utc.d.ts +0 -16
- package/dist/prerequisites/timezone-utc.d.ts.map +0 -1
- package/dist/prerequisites/timezone-utc.js +0 -25
- package/dist/prerequisites/timezone-utc.js.map +0 -1
- package/dist/prerequisites/translations.d.ts +0 -25
- package/dist/prerequisites/translations.d.ts.map +0 -1
- package/dist/prerequisites/translations.js +0 -68
- package/dist/prerequisites/translations.js.map +0 -1
- package/dist/prerequisites.service.d.ts +0 -60
- package/dist/prerequisites.service.d.ts.map +0 -1
- package/dist/prerequisites.service.js +0 -51
- package/dist/prerequisites.service.js.map +0 -1
- package/dist/redactor-compact-array.adapter.d.ts +0 -5
- package/dist/redactor-compact-array.adapter.d.ts.map +0 -1
- package/dist/redactor-compact-array.adapter.js +0 -7
- package/dist/redactor-compact-array.adapter.js.map +0 -1
- package/dist/redactor-compact-object.adapter.d.ts +0 -12
- package/dist/redactor-compact-object.adapter.d.ts.map +0 -1
- package/dist/redactor-compact-object.adapter.js +0 -17
- package/dist/redactor-compact-object.adapter.js.map +0 -1
- package/dist/redactor-composite.adapter.d.ts +0 -7
- package/dist/redactor-composite.adapter.d.ts.map +0 -1
- package/dist/redactor-composite.adapter.js +0 -10
- package/dist/redactor-composite.adapter.js.map +0 -1
- package/dist/redactor-encrypt.adapter.d.ts +0 -8
- package/dist/redactor-encrypt.adapter.d.ts.map +0 -1
- package/dist/redactor-encrypt.adapter.js +0 -25
- package/dist/redactor-encrypt.adapter.js.map +0 -1
- package/dist/redactor-mask.adapter.d.ts +0 -8
- package/dist/redactor-mask.adapter.d.ts.map +0 -1
- package/dist/redactor-mask.adapter.js +0 -33
- package/dist/redactor-mask.adapter.js.map +0 -1
- package/dist/redactor-noop.adapter.d.ts +0 -5
- package/dist/redactor-noop.adapter.d.ts.map +0 -1
- package/dist/redactor-noop.adapter.js +0 -6
- package/dist/redactor-noop.adapter.js.map +0 -1
- package/dist/redactor.port.d.ts +0 -4
- package/dist/redactor.port.d.ts.map +0 -1
- package/dist/redactor.port.js +0 -2
- package/dist/redactor.port.js.map +0 -1
- package/dist/secret.vo.d.ts +0 -7
- package/dist/secret.vo.d.ts.map +0 -1
- package/dist/secret.vo.js +0 -2
- package/dist/secret.vo.js.map +0 -1
- package/dist/shield-api-key.adapter.d.ts +0 -15
- package/dist/shield-api-key.adapter.d.ts.map +0 -1
- package/dist/shield-api-key.adapter.js +0 -16
- package/dist/shield-api-key.adapter.js.map +0 -1
- package/dist/shield-auth.middleware.d.ts +0 -12
- package/dist/shield-auth.middleware.d.ts.map +0 -1
- package/dist/shield-auth.middleware.js +0 -34
- package/dist/shield-auth.middleware.js.map +0 -1
- package/dist/shield-basic-auth.adapter.d.ts +0 -14
- package/dist/shield-basic-auth.adapter.d.ts.map +0 -1
- package/dist/shield-basic-auth.adapter.js +0 -10
- package/dist/shield-basic-auth.adapter.js.map +0 -1
- package/dist/shield-captcha-hcaptcha-local.adapter.d.ts +0 -10
- package/dist/shield-captcha-hcaptcha-local.adapter.d.ts.map +0 -1
- package/dist/shield-captcha-hcaptcha-local.adapter.js +0 -24
- package/dist/shield-captcha-hcaptcha-local.adapter.js.map +0 -1
- package/dist/shield-captcha-hcaptcha.adapter.d.ts +0 -10
- package/dist/shield-captcha-hcaptcha.adapter.d.ts.map +0 -1
- package/dist/shield-captcha-hcaptcha.adapter.js +0 -24
- package/dist/shield-captcha-hcaptcha.adapter.js.map +0 -1
- package/dist/shield-captcha-recaptcha.adapter.d.ts +0 -18
- package/dist/shield-captcha-recaptcha.adapter.d.ts.map +0 -1
- package/dist/shield-captcha-recaptcha.adapter.js +0 -37
- package/dist/shield-captcha-recaptcha.adapter.js.map +0 -1
- package/dist/shield-noop.adapter.d.ts +0 -5
- package/dist/shield-noop.adapter.d.ts.map +0 -1
- package/dist/shield-noop.adapter.js +0 -5
- package/dist/shield-noop.adapter.js.map +0 -1
- package/dist/shield-rate-limit.adapter.d.ts +0 -22
- package/dist/shield-rate-limit.adapter.d.ts.map +0 -1
- package/dist/shield-rate-limit.adapter.js +0 -23
- package/dist/shield-rate-limit.adapter.js.map +0 -1
- package/dist/shield-timeout.adapter.d.ts +0 -14
- package/dist/shield-timeout.adapter.d.ts.map +0 -1
- package/dist/shield-timeout.adapter.js +0 -12
- package/dist/shield-timeout.adapter.js.map +0 -1
- package/dist/shield.port.d.ts +0 -5
- package/dist/shield.port.d.ts.map +0 -1
- package/dist/shield.port.js +0 -2
- package/dist/shield.port.js.map +0 -1
- package/dist/timeout.service.d.ts +0 -11
- package/dist/timeout.service.d.ts.map +0 -1
- package/dist/timeout.service.js +0 -46
- package/dist/timeout.service.js.map +0 -1
- package/dist/visitor-id-client.adapter.d.ts +0 -14
- package/dist/visitor-id-client.adapter.d.ts.map +0 -1
- package/dist/visitor-id-client.adapter.js +0 -14
- package/dist/visitor-id-client.adapter.js.map +0 -1
- package/dist/visitor-id.port.d.ts +0 -5
- package/dist/visitor-id.port.d.ts.map +0 -1
- package/dist/visitor-id.port.js +0 -2
- package/dist/visitor-id.port.js.map +0 -1
- package/src/cache-resolver-simple.adapter.ts +0 -37
- package/src/cache-resolver.port.ts +0 -20
- package/src/cache-subject-segment-cookie.ts +0 -12
- package/src/cache-subject-segment-fixed.ts +0 -9
- package/src/cache-subject-segment-header.ts +0 -10
- package/src/cache-subject-segment-path.ts +0 -8
- package/src/cache-subject-segment-query.ts +0 -13
- package/src/cache-subject-segment-user.ts +0 -8
- package/src/cache-subject-segment.port.ts +0 -7
- package/src/encryption-bun.adapter.ts +0 -84
- package/src/event-handler-bare.adapter.ts +0 -9
- package/src/event-handler-noop.adapter.ts +0 -9
- package/src/event-handler-with-logger.adapter.ts +0 -31
- package/src/event-handler.port.ts +0 -8
- package/src/hash-content-noop.adapter.ts +0 -8
- package/src/hash-content-sha256-bun.adapter.ts +0 -11
- package/src/hash-content.port.ts +0 -5
- package/src/job-handler-bare.adapter.ts +0 -15
- package/src/job-handler-noop.adapter.ts +0 -9
- package/src/job-handler-with-logger.adapter.ts +0 -44
- package/src/job-handler.port.ts +0 -10
- package/src/json-file-reader-bun-forgiving.adapter.ts +0 -12
- package/src/json-file-reader-bun.adapter.ts +0 -8
- package/src/json-file-reader-noop.adapter.ts +0 -10
- package/src/json-file-reader.port.ts +0 -5
- package/src/prerequisites/binary.ts +0 -33
- package/src/prerequisites/bun.ts +0 -38
- package/src/prerequisites/clock-drift.ts +0 -51
- package/src/prerequisites/dependency-vulnerabilities.ts +0 -49
- package/src/prerequisites/directory.ts +0 -70
- package/src/prerequisites/dns.ts +0 -36
- package/src/prerequisites/external-api.ts +0 -41
- package/src/prerequisites/file.ts +0 -69
- package/src/prerequisites/index.ts +0 -24
- package/src/prerequisites/jobs.ts +0 -27
- package/src/prerequisites/log-file.ts +0 -42
- package/src/prerequisites/mailer.ts +0 -38
- package/src/prerequisites/memory.ts +0 -34
- package/src/prerequisites/node.ts +0 -37
- package/src/prerequisites/os.ts +0 -33
- package/src/prerequisites/outside-connectivity.ts +0 -38
- package/src/prerequisites/port.ts +0 -34
- package/src/prerequisites/ram.ts +0 -32
- package/src/prerequisites/running-user.ts +0 -30
- package/src/prerequisites/self.ts +0 -21
- package/src/prerequisites/space.ts +0 -45
- package/src/prerequisites/sqlite.ts +0 -38
- package/src/prerequisites/ssl-certificate-expiry.ts +0 -43
- package/src/prerequisites/timezone-utc.ts +0 -32
- package/src/prerequisites/translations.ts +0 -103
- package/src/prerequisites.service.ts +0 -92
- package/src/redactor-compact-array.adapter.ts +0 -10
- package/src/redactor-compact-object.adapter.ts +0 -24
- package/src/redactor-composite.adapter.ts +0 -9
- package/src/redactor-encrypt.adapter.ts +0 -32
- package/src/redactor-mask.adapter.ts +0 -38
- package/src/redactor-noop.adapter.ts +0 -7
- package/src/redactor.port.ts +0 -3
- package/src/secret.vo.ts +0 -7
- package/src/shield-api-key.adapter.ts +0 -20
- package/src/shield-auth.middleware.ts +0 -42
- package/src/shield-basic-auth.adapter.ts +0 -17
- package/src/shield-captcha-hcaptcha-local.adapter.ts +0 -24
- package/src/shield-captcha-hcaptcha.adapter.ts +0 -24
- package/src/shield-captcha-recaptcha.adapter.ts +0 -49
- package/src/shield-noop.adapter.ts +0 -6
- package/src/shield-rate-limit.adapter.ts +0 -37
- package/src/shield-timeout.adapter.ts +0 -19
- package/src/shield.port.ts +0 -5
- package/src/timeout.service.ts +0 -71
- package/src/visitor-id-client.adapter.ts +0 -20
- package/src/visitor-id.port.ts +0 -5
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import * as tools from "@bgord/tools";
|
|
2
|
-
import type { ClockPort } from "../clock.port";
|
|
3
|
-
import { MemoryConsumption } from "../memory-consumption.service";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
export class PrerequisiteMemory implements prereqs.Prerequisite {
|
|
7
|
-
readonly kind = "memory";
|
|
8
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
9
|
-
readonly enabled?: boolean = true;
|
|
10
|
-
|
|
11
|
-
private readonly maximum: tools.Size;
|
|
12
|
-
|
|
13
|
-
constructor(config: prereqs.PrerequisiteConfigType & { maximum: tools.Size }) {
|
|
14
|
-
this.label = config.label;
|
|
15
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
16
|
-
|
|
17
|
-
this.maximum = config.maximum;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
21
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
22
|
-
|
|
23
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
24
|
-
|
|
25
|
-
const memoryConsumption = MemoryConsumption.get();
|
|
26
|
-
|
|
27
|
-
if (memoryConsumption.isGreaterThan(this.maximum)) {
|
|
28
|
-
return prereqs.Verification.failure(stopwatch.stop(), {
|
|
29
|
-
message: `Memory consumption: ${memoryConsumption.format(tools.Size.unit.MB)}`,
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
return prereqs.Verification.success(stopwatch.stop());
|
|
33
|
-
}
|
|
34
|
-
}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import * as tools from "@bgord/tools";
|
|
2
|
-
import type { ClockPort } from "../clock.port";
|
|
3
|
-
import * as prereqs from "../prerequisites.service";
|
|
4
|
-
|
|
5
|
-
export class PrerequisiteNode implements prereqs.Prerequisite {
|
|
6
|
-
readonly kind = "node";
|
|
7
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
8
|
-
readonly enabled?: boolean = true;
|
|
9
|
-
|
|
10
|
-
private readonly version: tools.PackageVersion;
|
|
11
|
-
private readonly current: string;
|
|
12
|
-
|
|
13
|
-
constructor(config: prereqs.PrerequisiteConfigType & { version: tools.PackageVersion; current: string }) {
|
|
14
|
-
this.label = config.label;
|
|
15
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
16
|
-
|
|
17
|
-
this.version = config.version;
|
|
18
|
-
this.current = config.current;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
22
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
23
|
-
|
|
24
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
25
|
-
|
|
26
|
-
try {
|
|
27
|
-
const current = tools.PackageVersion.fromVersionString(this.current);
|
|
28
|
-
|
|
29
|
-
if (current.isGreaterThanOrEqual(this.version)) return prereqs.Verification.success(stopwatch.stop());
|
|
30
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: `Version: ${this.current}` });
|
|
31
|
-
} catch {
|
|
32
|
-
return prereqs.Verification.failure(stopwatch.stop(), {
|
|
33
|
-
message: `Invalid version passed: ${this.current}`,
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
}
|
package/src/prerequisites/os.ts
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import os from "node:os";
|
|
2
|
-
import * as tools from "@bgord/tools";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
export class PrerequisiteOs implements prereqs.Prerequisite {
|
|
7
|
-
readonly kind = "os";
|
|
8
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
9
|
-
readonly enabled?: boolean = true;
|
|
10
|
-
|
|
11
|
-
private readonly accepted: string[];
|
|
12
|
-
|
|
13
|
-
constructor(config: prereqs.PrerequisiteConfigType & { accepted: string[] }) {
|
|
14
|
-
this.label = config.label;
|
|
15
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
16
|
-
this.accepted = config.accepted;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
20
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
21
|
-
|
|
22
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
23
|
-
|
|
24
|
-
const type = os.type();
|
|
25
|
-
|
|
26
|
-
if (this.accepted.map((type) => type.toLowerCase()).includes(type.toLowerCase())) {
|
|
27
|
-
return prereqs.Verification.success(stopwatch.stop());
|
|
28
|
-
}
|
|
29
|
-
return prereqs.Verification.failure(stopwatch.stop(), {
|
|
30
|
-
message: `Unacceptable os: ${this.accepted.join(", ")}`,
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import * as tools from "@bgord/tools";
|
|
2
|
-
import type { ClockPort } from "../clock.port";
|
|
3
|
-
import * as prereqs from "../prerequisites.service";
|
|
4
|
-
import { Timeout } from "../timeout.service";
|
|
5
|
-
|
|
6
|
-
export class PrerequisiteOutsideConnectivity implements prereqs.Prerequisite {
|
|
7
|
-
readonly kind = "outside-connectivity";
|
|
8
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
9
|
-
readonly enabled?: boolean = true;
|
|
10
|
-
|
|
11
|
-
private static readonly URL = tools.UrlWithoutSlash.parse("https://google.com");
|
|
12
|
-
readonly timeout: tools.Duration;
|
|
13
|
-
|
|
14
|
-
constructor(config: prereqs.PrerequisiteConfigType & { timeout?: tools.Duration }) {
|
|
15
|
-
this.label = config.label;
|
|
16
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
17
|
-
|
|
18
|
-
this.timeout = config.timeout ?? tools.Duration.Seconds(2);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
22
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
23
|
-
|
|
24
|
-
try {
|
|
25
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
26
|
-
|
|
27
|
-
const response = await Timeout.cancellable(
|
|
28
|
-
(signal: AbortSignal) => fetch(PrerequisiteOutsideConnectivity.URL, { method: "HEAD", signal }),
|
|
29
|
-
this.timeout,
|
|
30
|
-
);
|
|
31
|
-
|
|
32
|
-
if (response.ok) return prereqs.Verification.success(stopwatch.stop());
|
|
33
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: `HTTP ${response.status}` });
|
|
34
|
-
} catch (error) {
|
|
35
|
-
return prereqs.Verification.failure(stopwatch.stop(), error as Error);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import net from "node:net";
|
|
2
|
-
import * as tools from "@bgord/tools";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import type { PortType } from "../port.vo";
|
|
5
|
-
import * as prereqs from "../prerequisites.service";
|
|
6
|
-
|
|
7
|
-
export class PrerequisitePort implements prereqs.Prerequisite {
|
|
8
|
-
readonly kind = "port";
|
|
9
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
10
|
-
readonly enabled?: boolean = true;
|
|
11
|
-
|
|
12
|
-
private readonly port: PortType;
|
|
13
|
-
|
|
14
|
-
constructor(config: prereqs.PrerequisiteConfigType & { port: PortType }) {
|
|
15
|
-
this.label = config.label;
|
|
16
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
17
|
-
|
|
18
|
-
this.port = config.port;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
22
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
23
|
-
|
|
24
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
25
|
-
|
|
26
|
-
return new Promise((resolve) => {
|
|
27
|
-
const server = net.createServer();
|
|
28
|
-
server.listen(this.port, () =>
|
|
29
|
-
server.close(() => resolve(prereqs.Verification.success(stopwatch.stop()))),
|
|
30
|
-
);
|
|
31
|
-
server.on("error", () => resolve(prereqs.Verification.failure(stopwatch.stop())));
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
}
|
package/src/prerequisites/ram.ts
DELETED
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import os from "node:os";
|
|
2
|
-
import * as tools from "@bgord/tools";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
export class PrerequisiteRAM implements prereqs.Prerequisite {
|
|
7
|
-
readonly kind = "ram";
|
|
8
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
9
|
-
readonly enabled?: boolean = true;
|
|
10
|
-
|
|
11
|
-
private readonly minimum: tools.Size;
|
|
12
|
-
|
|
13
|
-
constructor(config: prereqs.PrerequisiteConfigType & { minimum: tools.Size }) {
|
|
14
|
-
this.label = config.label;
|
|
15
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
16
|
-
|
|
17
|
-
this.minimum = config.minimum;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
21
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
22
|
-
|
|
23
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
24
|
-
|
|
25
|
-
const freeRAM = tools.Size.fromBytes(os.freemem());
|
|
26
|
-
|
|
27
|
-
if (freeRAM.isGreaterThan(this.minimum)) return prereqs.Verification.success(stopwatch.stop());
|
|
28
|
-
return prereqs.Verification.failure(stopwatch.stop(), {
|
|
29
|
-
message: `Free RAM: ${freeRAM.format(tools.Size.unit.MB)}`,
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import os from "node:os";
|
|
2
|
-
import * as tools from "@bgord/tools";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
export class PrerequisiteRunningUser implements prereqs.Prerequisite {
|
|
7
|
-
readonly kind = "running-user";
|
|
8
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
9
|
-
readonly enabled?: boolean = true;
|
|
10
|
-
|
|
11
|
-
private readonly username: string;
|
|
12
|
-
|
|
13
|
-
constructor(config: prereqs.PrerequisiteConfigType & { username: string }) {
|
|
14
|
-
this.label = config.label;
|
|
15
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
16
|
-
|
|
17
|
-
this.username = config.username;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
21
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
22
|
-
|
|
23
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
24
|
-
|
|
25
|
-
const current = os.userInfo().username;
|
|
26
|
-
|
|
27
|
-
if (current === this.username) return prereqs.Verification.success(stopwatch.stop());
|
|
28
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: `Current user: ${current}` });
|
|
29
|
-
}
|
|
30
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import * as tools from "@bgord/tools";
|
|
2
|
-
import type { ClockPort } from "../clock.port";
|
|
3
|
-
import * as prereqs from "../prerequisites.service";
|
|
4
|
-
|
|
5
|
-
export class PrerequisiteSelf implements prereqs.Prerequisite {
|
|
6
|
-
readonly kind = "self";
|
|
7
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
8
|
-
readonly enabled?: boolean = true;
|
|
9
|
-
|
|
10
|
-
constructor(config: prereqs.PrerequisiteConfigType) {
|
|
11
|
-
this.label = config.label;
|
|
12
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
16
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
17
|
-
|
|
18
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
19
|
-
return prereqs.Verification.success(stopwatch.stop());
|
|
20
|
-
}
|
|
21
|
-
}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import path from "node:path";
|
|
2
|
-
import * as tools from "@bgord/tools";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import type { DiskSpaceCheckerPort } from "../disk-space-checker.port";
|
|
5
|
-
import { DiskSpaceCheckerBunAdapter } from "../disk-space-checker-bun.adapter";
|
|
6
|
-
import * as prereqs from "../prerequisites.service";
|
|
7
|
-
|
|
8
|
-
type Dependencies = { DiskSpaceChecker?: DiskSpaceCheckerPort };
|
|
9
|
-
|
|
10
|
-
export class PrerequisiteSpace implements prereqs.Prerequisite {
|
|
11
|
-
readonly kind = "space";
|
|
12
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
13
|
-
readonly enabled?: boolean = true;
|
|
14
|
-
|
|
15
|
-
private readonly minimum: tools.Size;
|
|
16
|
-
|
|
17
|
-
constructor(
|
|
18
|
-
config: prereqs.PrerequisiteConfigType & { minimum: tools.Size },
|
|
19
|
-
private readonly deps?: Dependencies,
|
|
20
|
-
) {
|
|
21
|
-
this.label = config.label;
|
|
22
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
23
|
-
|
|
24
|
-
this.minimum = config.minimum;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
28
|
-
const DiskSpaceChecker = this.deps?.DiskSpaceChecker ?? new DiskSpaceCheckerBunAdapter();
|
|
29
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
30
|
-
|
|
31
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
32
|
-
|
|
33
|
-
try {
|
|
34
|
-
const root = path.sep;
|
|
35
|
-
const freeDiskSpace = await DiskSpaceChecker.get(root);
|
|
36
|
-
|
|
37
|
-
if (freeDiskSpace.isGreaterThan(this.minimum)) return prereqs.Verification.success(stopwatch.stop());
|
|
38
|
-
return prereqs.Verification.failure(stopwatch.stop(), {
|
|
39
|
-
message: `Free disk space: ${freeDiskSpace.format(tools.Size.unit.MB)}`,
|
|
40
|
-
});
|
|
41
|
-
} catch (error) {
|
|
42
|
-
return prereqs.Verification.failure(stopwatch.stop(), error as Error);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
import type { Database } from "bun:sqlite";
|
|
2
|
-
import * as tools from "@bgord/tools";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
export class PrerequisiteSQLite implements prereqs.Prerequisite {
|
|
7
|
-
readonly kind = "sqlite";
|
|
8
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
9
|
-
readonly enabled?: boolean = true;
|
|
10
|
-
|
|
11
|
-
private readonly sqlite: Database;
|
|
12
|
-
|
|
13
|
-
constructor(config: prereqs.PrerequisiteConfigType & { sqlite: Database }) {
|
|
14
|
-
this.label = config.label;
|
|
15
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
16
|
-
|
|
17
|
-
this.sqlite = config.sqlite;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
21
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
22
|
-
|
|
23
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
24
|
-
|
|
25
|
-
try {
|
|
26
|
-
const integrity = this.sqlite.query("PRAGMA integrity_check;").get() as
|
|
27
|
-
| { integrity_check?: string }
|
|
28
|
-
| undefined;
|
|
29
|
-
|
|
30
|
-
if (!integrity || (integrity.integrity_check ?? "").toLowerCase() !== "ok") {
|
|
31
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: "Integrity check failed" });
|
|
32
|
-
}
|
|
33
|
-
return prereqs.Verification.success(stopwatch.stop());
|
|
34
|
-
} catch (error) {
|
|
35
|
-
return prereqs.Verification.failure(stopwatch.stop(), error as Error);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import * as tools from "@bgord/tools";
|
|
2
|
-
import type { CertificateInspectorPort } from "../certificate-inspector.port";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
type Dependencies = { CertificateInspector: CertificateInspectorPort };
|
|
7
|
-
|
|
8
|
-
export class PrerequisiteSSLCertificateExpiry implements prereqs.Prerequisite {
|
|
9
|
-
readonly kind = "ssl-certificate-expiry";
|
|
10
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
11
|
-
readonly enabled?: boolean = true;
|
|
12
|
-
|
|
13
|
-
private readonly hostname: string;
|
|
14
|
-
private readonly days: number;
|
|
15
|
-
|
|
16
|
-
constructor(
|
|
17
|
-
config: prereqs.PrerequisiteConfigType & { hostname: string; days: number },
|
|
18
|
-
private readonly deps: Dependencies,
|
|
19
|
-
) {
|
|
20
|
-
this.label = config.label;
|
|
21
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
22
|
-
|
|
23
|
-
this.hostname = config.hostname;
|
|
24
|
-
this.days = config.days;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
28
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
29
|
-
|
|
30
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
31
|
-
|
|
32
|
-
const result = await this.deps.CertificateInspector.inspect(this.hostname);
|
|
33
|
-
|
|
34
|
-
if (!result.success)
|
|
35
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: "Certificate unavailable" });
|
|
36
|
-
if (result.daysRemaining <= this.days) {
|
|
37
|
-
return prereqs.Verification.failure(stopwatch.stop(), {
|
|
38
|
-
message: `${result.daysRemaining} days remaining`,
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
return prereqs.Verification.success(stopwatch.stop());
|
|
42
|
-
}
|
|
43
|
-
}
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import * as tools from "@bgord/tools";
|
|
2
|
-
import { z } from "zod/v4";
|
|
3
|
-
import type { ClockPort } from "../clock.port";
|
|
4
|
-
import * as prereqs from "../prerequisites.service";
|
|
5
|
-
|
|
6
|
-
export const TimezoneUtc = z.literal("UTC");
|
|
7
|
-
|
|
8
|
-
export class PrerequisiteTimezoneUTC implements prereqs.Prerequisite {
|
|
9
|
-
readonly kind = "timezone-utc";
|
|
10
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
11
|
-
readonly enabled?: boolean = true;
|
|
12
|
-
|
|
13
|
-
private readonly timezone: tools.TimezoneType;
|
|
14
|
-
|
|
15
|
-
constructor(config: prereqs.PrerequisiteConfigType & { timezone: tools.TimezoneType }) {
|
|
16
|
-
this.label = config.label;
|
|
17
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
18
|
-
|
|
19
|
-
this.timezone = config.timezone;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
23
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
24
|
-
|
|
25
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
26
|
-
|
|
27
|
-
const result = TimezoneUtc.safeParse(this.timezone);
|
|
28
|
-
|
|
29
|
-
if (result.success) return prereqs.Verification.success(stopwatch.stop());
|
|
30
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: `Timezone: ${this.timezone}` });
|
|
31
|
-
}
|
|
32
|
-
}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
import { constants } from "node:fs";
|
|
2
|
-
import fsp from "node:fs/promises";
|
|
3
|
-
import * as tools from "@bgord/tools";
|
|
4
|
-
import type { ClockPort } from "../clock.port";
|
|
5
|
-
import type * as types from "../i18n.service";
|
|
6
|
-
import { I18n } from "../i18n.service";
|
|
7
|
-
import type { JsonFileReaderPort } from "../json-file-reader.port";
|
|
8
|
-
import { JsonFileReaderBunForgivingAdapter } from "../json-file-reader-bun-forgiving.adapter";
|
|
9
|
-
import type { LoggerPort } from "../logger.port";
|
|
10
|
-
import * as prereqs from "../prerequisites.service";
|
|
11
|
-
|
|
12
|
-
type PrerequisiteTranslationsProblemType = {
|
|
13
|
-
key: types.TranslationsKeyType;
|
|
14
|
-
existsIn: tools.LanguageType;
|
|
15
|
-
missingIn: tools.LanguageType;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
type Dependencies = { Logger: LoggerPort; JsonFileReader?: JsonFileReaderPort };
|
|
19
|
-
|
|
20
|
-
export class PrerequisiteTranslations implements prereqs.Prerequisite {
|
|
21
|
-
readonly kind = "translations";
|
|
22
|
-
readonly label: prereqs.PrerequisiteLabelType;
|
|
23
|
-
readonly enabled?: boolean = true;
|
|
24
|
-
|
|
25
|
-
private readonly translationsPath?: typeof I18n.DEFAULT_TRANSLATIONS_PATH;
|
|
26
|
-
private readonly supportedLanguages: types.I18nConfigType["supportedLanguages"];
|
|
27
|
-
|
|
28
|
-
constructor(
|
|
29
|
-
config: prereqs.PrerequisiteConfigType & {
|
|
30
|
-
translationsPath?: typeof I18n.DEFAULT_TRANSLATIONS_PATH;
|
|
31
|
-
supportedLanguages: types.I18nConfigType["supportedLanguages"];
|
|
32
|
-
},
|
|
33
|
-
private readonly deps: Dependencies,
|
|
34
|
-
) {
|
|
35
|
-
this.label = config.label;
|
|
36
|
-
this.enabled = config.enabled === undefined ? true : config.enabled;
|
|
37
|
-
|
|
38
|
-
this.translationsPath = config.translationsPath;
|
|
39
|
-
this.supportedLanguages = config.supportedLanguages;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
async verify(clock: ClockPort): Promise<prereqs.VerifyOutcome> {
|
|
43
|
-
const JsonFileReader = this.deps.JsonFileReader ?? new JsonFileReaderBunForgivingAdapter();
|
|
44
|
-
|
|
45
|
-
const stopwatch = new tools.Stopwatch(clock.now());
|
|
46
|
-
|
|
47
|
-
if (!this.enabled) return prereqs.Verification.undetermined(stopwatch.stop());
|
|
48
|
-
|
|
49
|
-
const translationsPath = this.translationsPath ?? I18n.DEFAULT_TRANSLATIONS_PATH;
|
|
50
|
-
|
|
51
|
-
const supportedLanguages = Object.keys(this.supportedLanguages);
|
|
52
|
-
const i18n = new I18n({ Logger: this.deps.Logger, JsonFileReader: JsonFileReader });
|
|
53
|
-
|
|
54
|
-
try {
|
|
55
|
-
await fsp.access(translationsPath, constants.R_OK);
|
|
56
|
-
|
|
57
|
-
for (const language of supportedLanguages) {
|
|
58
|
-
await fsp.access(i18n.getTranslationPathForLanguage(language).get(), constants.R_OK);
|
|
59
|
-
}
|
|
60
|
-
} catch (error) {
|
|
61
|
-
return prereqs.Verification.failure(stopwatch.stop(), error as Error);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
if (supportedLanguages.length === 1) return prereqs.Verification.success(stopwatch.stop());
|
|
65
|
-
|
|
66
|
-
const languageToTranslationKeys: Record<tools.LanguageType, types.TranslationsKeyType[]> = {};
|
|
67
|
-
|
|
68
|
-
const problems: PrerequisiteTranslationsProblemType[] = [];
|
|
69
|
-
|
|
70
|
-
for (const language of supportedLanguages) {
|
|
71
|
-
const translations = await i18n.getTranslations(language);
|
|
72
|
-
const translationKeys = Object.keys(translations);
|
|
73
|
-
|
|
74
|
-
languageToTranslationKeys[language] = translationKeys;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
for (const language in languageToTranslationKeys) {
|
|
78
|
-
const translationKeys = languageToTranslationKeys[language] ?? [];
|
|
79
|
-
|
|
80
|
-
for (const translationKey of translationKeys) {
|
|
81
|
-
for (const supportedLanguage of supportedLanguages) {
|
|
82
|
-
if (supportedLanguage === language) continue;
|
|
83
|
-
|
|
84
|
-
const translationKeyExists = languageToTranslationKeys[supportedLanguage]?.some(
|
|
85
|
-
(key) => translationKey === key,
|
|
86
|
-
);
|
|
87
|
-
|
|
88
|
-
if (!translationKeyExists) {
|
|
89
|
-
problems.push({ key: translationKey, existsIn: language, missingIn: supportedLanguage });
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
if (problems.length === 0) return prereqs.Verification.success(stopwatch.stop());
|
|
96
|
-
|
|
97
|
-
const summary = problems
|
|
98
|
-
.map((problem) => `Key: ${problem.key}, exists in ${problem.existsIn}, missing in ${problem.missingIn}`)
|
|
99
|
-
.join("\n");
|
|
100
|
-
|
|
101
|
-
return prereqs.Verification.failure(stopwatch.stop(), { message: summary });
|
|
102
|
-
}
|
|
103
|
-
}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
import type * as tools from "@bgord/tools";
|
|
2
|
-
import type { ClockPort } from "../src/clock.port";
|
|
3
|
-
import type { ErrorInfo, LoggerPort } from "../src/logger.port";
|
|
4
|
-
import { formatError } from "../src/logger-format-error.service";
|
|
5
|
-
|
|
6
|
-
export type PrerequisiteLabelType = string;
|
|
7
|
-
|
|
8
|
-
export enum PrerequisiteStatusEnum {
|
|
9
|
-
success = "success",
|
|
10
|
-
failure = "failure",
|
|
11
|
-
undetermined = "undetermined",
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export type VerifySuccess = { status: PrerequisiteStatusEnum.success; durationMs: tools.DurationMsType };
|
|
15
|
-
export type VerifyFailure = {
|
|
16
|
-
status: PrerequisiteStatusEnum.failure;
|
|
17
|
-
durationMs: tools.DurationMsType;
|
|
18
|
-
error?: ErrorInfo;
|
|
19
|
-
};
|
|
20
|
-
export type VerifyUndetermined = {
|
|
21
|
-
status: PrerequisiteStatusEnum.undetermined;
|
|
22
|
-
durationMs: tools.DurationMsType;
|
|
23
|
-
};
|
|
24
|
-
export type VerifyOutcome = VerifySuccess | VerifyFailure | VerifyUndetermined;
|
|
25
|
-
|
|
26
|
-
export interface Prerequisite {
|
|
27
|
-
readonly label: PrerequisiteLabelType;
|
|
28
|
-
readonly kind: string;
|
|
29
|
-
readonly enabled?: boolean;
|
|
30
|
-
verify(clock: ClockPort): Promise<VerifyOutcome>;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
export type PrerequisiteResult = {
|
|
34
|
-
label: PrerequisiteLabelType;
|
|
35
|
-
status: PrerequisiteStatusEnum;
|
|
36
|
-
kind: string;
|
|
37
|
-
error?: ErrorInfo;
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
export class Verification {
|
|
41
|
-
static success(duration: tools.Duration): VerifySuccess {
|
|
42
|
-
return { status: PrerequisiteStatusEnum.success, durationMs: duration.ms };
|
|
43
|
-
}
|
|
44
|
-
static failure(duration: tools.Duration, meta?: Error | ErrorInfo): VerifyFailure {
|
|
45
|
-
return {
|
|
46
|
-
status: PrerequisiteStatusEnum.failure,
|
|
47
|
-
durationMs: duration.ms,
|
|
48
|
-
error: meta instanceof Error ? formatError(meta) : meta,
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
static undetermined(duration: tools.Duration): VerifyUndetermined {
|
|
52
|
-
return { status: PrerequisiteStatusEnum.undetermined, durationMs: duration.ms };
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export type PrerequisiteConfigType = { label: string; enabled?: boolean };
|
|
57
|
-
|
|
58
|
-
export const PrerequisitesError = { Failure: "prerequisites.failure" } as const;
|
|
59
|
-
|
|
60
|
-
type Dependencies = { Logger: LoggerPort; Clock: ClockPort };
|
|
61
|
-
|
|
62
|
-
/** @public */
|
|
63
|
-
export class Prerequisites {
|
|
64
|
-
private readonly base = { component: "infra", operation: "startup" };
|
|
65
|
-
|
|
66
|
-
constructor(private readonly deps: Dependencies) {}
|
|
67
|
-
|
|
68
|
-
async check(prerequisites: Prerequisite[]) {
|
|
69
|
-
const results = await Promise.all(
|
|
70
|
-
prerequisites.map(async (prerequisite) => ({
|
|
71
|
-
prerequisite,
|
|
72
|
-
outcome: await prerequisite.verify(this.deps.Clock),
|
|
73
|
-
})),
|
|
74
|
-
);
|
|
75
|
-
|
|
76
|
-
const failed = results.filter((result) => result.outcome.status === PrerequisiteStatusEnum.failure);
|
|
77
|
-
|
|
78
|
-
if (failed.length === 0) return this.deps.Logger.info({ message: "Prerequisites ok", ...this.base });
|
|
79
|
-
|
|
80
|
-
for (const failure of failed) {
|
|
81
|
-
this.deps.Logger.error({
|
|
82
|
-
message: "Prerequisite failed",
|
|
83
|
-
metadata: { label: failure.prerequisite.label, kind: failure.prerequisite.kind },
|
|
84
|
-
// @ts-expect-error
|
|
85
|
-
error: failure.outcome.error ?? { message: "unknown error" },
|
|
86
|
-
...this.base,
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
throw new Error(PrerequisitesError.Failure);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import cloneDeepWith from "lodash/cloneDeepWith";
|
|
2
|
-
import type { RedactorPort } from "./redactor.port";
|
|
3
|
-
|
|
4
|
-
export class RedactorCompactArrayAdapter implements RedactorPort {
|
|
5
|
-
redact<T>(input: T): T {
|
|
6
|
-
return cloneDeepWith(input, (value) =>
|
|
7
|
-
Array.isArray(value) ? { type: "Array", length: value.length } : undefined,
|
|
8
|
-
);
|
|
9
|
-
}
|
|
10
|
-
}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import _ from "lodash";
|
|
2
|
-
import type { RedactorPort } from "./redactor.port";
|
|
3
|
-
|
|
4
|
-
type RedactorWideObjectOptions = { maxKeys?: number };
|
|
5
|
-
|
|
6
|
-
export class RedactorCompactObjectAdapter implements RedactorPort {
|
|
7
|
-
private static readonly DEFAULT_MAX_KEYS = 20;
|
|
8
|
-
|
|
9
|
-
private readonly maxKeys: number;
|
|
10
|
-
|
|
11
|
-
constructor(options: RedactorWideObjectOptions = {}) {
|
|
12
|
-
this.maxKeys = options.maxKeys ?? RedactorCompactObjectAdapter.DEFAULT_MAX_KEYS;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
redact<T>(input: T): T {
|
|
16
|
-
return _.cloneDeepWith(input, (value) => {
|
|
17
|
-
if (!_.isPlainObject(value)) return undefined;
|
|
18
|
-
|
|
19
|
-
const keys = Object.keys(value).length;
|
|
20
|
-
|
|
21
|
-
return keys <= this.maxKeys ? undefined : { type: "Object", keys };
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { RedactorPort } from "./redactor.port";
|
|
2
|
-
|
|
3
|
-
export class RedactorCompositeAdapter implements RedactorPort {
|
|
4
|
-
constructor(private readonly pipeline: readonly RedactorPort[]) {}
|
|
5
|
-
|
|
6
|
-
redact<T>(input: T): T {
|
|
7
|
-
return this.pipeline.reduce((result, redactor) => redactor.redact(result), input);
|
|
8
|
-
}
|
|
9
|
-
}
|