@bgord/bun 1.6.7 → 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/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 +8 -8
- package/dist/client.vo.d.ts.map +1 -1
- package/dist/client.vo.js +13 -8
- 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 -49
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +124 -49
- 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 -2
- package/dist/logger-winston-production.adapter.d.ts.map +1 -1
- 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 -2
- 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 -7
- package/readme.md +129 -73
- package/src/api-version.middleware.ts +2 -2
- package/src/binary.vo.ts +2 -2
- 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 +20 -18
- 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 -49
- 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 +2 -5
- 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 -4
- 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-user-agent-blocker.adapter.d.ts +0 -7
- package/dist/shield-user-agent-blocker.adapter.d.ts.map +0 -1
- package/dist/shield-user-agent-blocker.adapter.js +0 -15
- package/dist/shield-user-agent-blocker.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-user-agent-blocker.adapter.ts +0 -18
- 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
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ALL_BOTS } from "./bots.vo";
|
|
2
|
+
import { ClientFromHono } from "./client-from-hono.adapter";
|
|
3
|
+
import { ClientUserAgent } from "./client-user-agent.vo";
|
|
4
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
5
|
+
export class SecurityRuleUserAgentStrategy {
|
|
6
|
+
blacklist;
|
|
7
|
+
constructor(blacklist = ALL_BOTS) {
|
|
8
|
+
this.blacklist = blacklist;
|
|
9
|
+
}
|
|
10
|
+
async isViolated(c) {
|
|
11
|
+
const client = ClientFromHono.translate(c);
|
|
12
|
+
return this.blacklist.some((bot) => client.matchesUa(ClientUserAgent.parse(bot)));
|
|
13
|
+
}
|
|
14
|
+
get name() {
|
|
15
|
+
return SecurityRuleName.parse("user_agent");
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=security-rule-user-agent.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-user-agent.strategy.js","sourceRoot":"","sources":["../src/security-rule-user-agent.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,OAAO,6BAA6B;IACX;IAA7B,YAA6B,YAAsB,QAAQ;QAA9B,cAAS,GAAT,SAAS,CAAqB;IAAG,CAAC;IAE/D,KAAK,CAAC,UAAU,CAAC,CAAU;QACzB,MAAM,MAAM,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAE3C,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACpF,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAC9C,CAAC;CACF"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { CacheRepositoryPort } from "./cache-repository.port";
|
|
3
|
+
import type { HashContentStrategy } from "./hash-content.strategy";
|
|
4
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
5
|
+
type Dependencies = {
|
|
6
|
+
CacheRepository: CacheRepositoryPort;
|
|
7
|
+
HashContent: HashContentStrategy;
|
|
8
|
+
};
|
|
9
|
+
export declare class SecurityRuleViolationThresholdStrategy implements SecurityRuleStrategy {
|
|
10
|
+
private readonly rule;
|
|
11
|
+
private readonly config;
|
|
12
|
+
private readonly deps;
|
|
13
|
+
constructor(rule: SecurityRuleStrategy, config: {
|
|
14
|
+
threshold: number;
|
|
15
|
+
}, deps: Dependencies);
|
|
16
|
+
isViolated(c: Context): Promise<boolean>;
|
|
17
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=security-rule-violation-threshold.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-violation-threshold.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-violation-threshold.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAInE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,KAAK,YAAY,GAAG;IAAE,eAAe,EAAE,mBAAmB,CAAC;IAAC,WAAW,EAAE,mBAAmB,CAAA;CAAE,CAAC;AAE/F,qBAAa,sCAAuC,YAAW,oBAAoB;IAE/E,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAFJ,IAAI,EAAE,oBAAoB,EAC1B,MAAM,EAAE;QAAE,SAAS,EAAE,MAAM,CAAA;KAAE,EAC7B,IAAI,EAAE,YAAY;IAI/B,UAAU,CAAC,CAAC,EAAE,OAAO;IAuB3B,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { CacheSubjectResolver } from "./cache-subject-resolver.vo";
|
|
2
|
+
import { CacheSubjectSegmentFixedStrategy } from "./cache-subject-segment-fixed.strategy";
|
|
3
|
+
import { CacheSubjectSegmentIpStrategy } from "./cache-subject-segment-ip.strategy";
|
|
4
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
5
|
+
export class SecurityRuleViolationThresholdStrategy {
|
|
6
|
+
rule;
|
|
7
|
+
config;
|
|
8
|
+
deps;
|
|
9
|
+
constructor(rule, config, deps) {
|
|
10
|
+
this.rule = rule;
|
|
11
|
+
this.config = config;
|
|
12
|
+
this.deps = deps;
|
|
13
|
+
}
|
|
14
|
+
// Best-effort increment, occasional lost increments are acceptable for concurrent requests.
|
|
15
|
+
async isViolated(c) {
|
|
16
|
+
const resolver = new CacheSubjectResolver([new CacheSubjectSegmentFixedStrategy(this.name), new CacheSubjectSegmentIpStrategy()], this.deps);
|
|
17
|
+
const subject = await resolver.resolve(c);
|
|
18
|
+
const violated = await this.rule.isViolated(c);
|
|
19
|
+
if (!violated)
|
|
20
|
+
return false;
|
|
21
|
+
try {
|
|
22
|
+
const count = (await this.deps.CacheRepository.get(subject.hex)) ?? 0;
|
|
23
|
+
await this.deps.CacheRepository.set(subject.hex, count + 1);
|
|
24
|
+
if (count + 1 >= this.config.threshold)
|
|
25
|
+
return true;
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
get name() {
|
|
33
|
+
return SecurityRuleName.parse(`violation_threshold_${this.config.threshold}_${this.rule.name}`);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=security-rule-violation-threshold.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-violation-threshold.strategy.js","sourceRoot":"","sources":["../src/security-rule-violation-threshold.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,gCAAgC,EAAE,MAAM,wCAAwC,CAAC;AAC1F,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;AAGpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAI3D,MAAM,OAAO,sCAAsC;IAE9B;IACA;IACA;IAHnB,YACmB,IAA0B,EAC1B,MAA6B,EAC7B,IAAkB;QAFlB,SAAI,GAAJ,IAAI,CAAsB;QAC1B,WAAM,GAAN,MAAM,CAAuB;QAC7B,SAAI,GAAJ,IAAI,CAAc;IAClC,CAAC;IAEJ,4FAA4F;IAC5F,KAAK,CAAC,UAAU,CAAC,CAAU;QACzB,MAAM,QAAQ,GAAG,IAAI,oBAAoB,CACvC,CAAC,IAAI,gCAAgC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,IAAI,6BAA6B,EAAE,CAAC,EACtF,IAAI,CAAC,IAAI,CACV,CAAC;QACF,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAE1C,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAE/C,IAAI,CAAC,QAAQ;YAAE,OAAO,KAAK,CAAC;QAE5B,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAS,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;YAE9E,MAAM,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAS,OAAO,CAAC,GAAG,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC;YAEpE,IAAI,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS;gBAAE,OAAO,IAAI,CAAC;YACpD,OAAO,KAAK,CAAC;QACf,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,uBAAuB,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAClG,CAAC;CACF"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { SecurityRuleNameType } from "./security-rule-name.vo";
|
|
3
|
+
export interface SecurityRuleStrategy {
|
|
4
|
+
isViolated(c: Context): Promise<boolean>;
|
|
5
|
+
get name(): SecurityRuleNameType;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=security-rule.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAEpE,MAAM,WAAW,oBAAoB;IACnC,UAAU,CAAC,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEzC,IAAI,IAAI,IAAI,oBAAoB,CAAC;CAClC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule.strategy.js","sourceRoot":"","sources":["../src/security-rule.strategy.ts"],"names":[],"mappings":""}
|
package/dist/setup.service.d.ts
CHANGED
|
@@ -1,23 +1,25 @@
|
|
|
1
1
|
import { cors } from "hono/cors";
|
|
2
2
|
import { secureHeaders } from "hono/secure-headers";
|
|
3
3
|
import type { ClockPort } from "./clock.port";
|
|
4
|
+
import type { FileReaderJsonPort } from "./file-reader-json.port";
|
|
4
5
|
import { type HttpLoggerOptions } from "./http-logger.middleware";
|
|
5
6
|
import type { I18nConfigType } from "./i18n.service";
|
|
6
7
|
import type { IdProviderPort } from "./id-provider.port";
|
|
7
|
-
import type { JsonFileReaderPort } from "./json-file-reader.port";
|
|
8
8
|
import type { LoggerPort } from "./logger.port";
|
|
9
|
+
import { type MaintenanceModeConfigType } from "./maintenance-mode.middleware";
|
|
9
10
|
export declare const BODY_LIMIT_MAX_SIZE: number & import("zod").$brand<"SizeBytes">;
|
|
10
11
|
type SetupOverridesType = {
|
|
11
12
|
cors?: Parameters<typeof cors>[0];
|
|
12
13
|
secureHeaders?: Parameters<typeof secureHeaders>[0];
|
|
13
14
|
httpLogger?: HttpLoggerOptions;
|
|
15
|
+
maintenanceMode?: MaintenanceModeConfigType;
|
|
14
16
|
};
|
|
15
17
|
type Dependencies = {
|
|
16
18
|
Logger: LoggerPort;
|
|
17
19
|
IdProvider: IdProviderPort;
|
|
18
20
|
I18n: I18nConfigType;
|
|
19
21
|
Clock: ClockPort;
|
|
20
|
-
JsonFileReader:
|
|
22
|
+
JsonFileReader: FileReaderJsonPort;
|
|
21
23
|
};
|
|
22
24
|
export declare class Setup {
|
|
23
25
|
static essentials(deps: Dependencies, overrides?: SetupOverridesType): (import("hono").MiddlewareHandler<any, string, {}, Response> | import("hono").MiddlewareHandler<{
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.service.d.ts","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAI9C,OAAO,EAAc,KAAK,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC9E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"setup.service.d.ts","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAI9C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAClE,OAAO,EAAc,KAAK,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC9E,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAmB,KAAK,yBAAyB,EAAE,MAAM,+BAA+B,CAAC;AAIhG,eAAO,MAAM,mBAAmB,4CAAmC,CAAC;AAEpE,KAAK,kBAAkB,GAAG;IACxB,IAAI,CAAC,EAAE,UAAU,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IAClC,aAAa,CAAC,EAAE,UAAU,CAAC,OAAO,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;IACpD,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,eAAe,CAAC,EAAE,yBAAyB,CAAC;CAC7C,CAAC;AAEF,KAAK,YAAY,GAAG;IAClB,MAAM,EAAE,UAAU,CAAC;IACnB,UAAU,EAAE,cAAc,CAAC;IAC3B,IAAI,EAAE,cAAc,CAAC;IACrB,KAAK,EAAE,SAAS,CAAC;IACjB,cAAc,EAAE,kBAAkB,CAAC;CACpC,CAAC;AAEF,qBAAa,KAAK;IAChB,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,YAAY,EAAE,SAAS,CAAC,EAAE,kBAAkB;;;CA6BrE"}
|
package/dist/setup.service.js
CHANGED
|
@@ -10,7 +10,7 @@ import { Context } from "./context.middleware";
|
|
|
10
10
|
import { CorrelationStorage } from "./correlation-storage.service";
|
|
11
11
|
import { ETagExtractor } from "./etag-extractor.middleware";
|
|
12
12
|
import { HttpLogger } from "./http-logger.middleware";
|
|
13
|
-
import {
|
|
13
|
+
import { MaintenanceMode } from "./maintenance-mode.middleware";
|
|
14
14
|
import { TimeZoneOffset } from "./time-zone-offset.middleware";
|
|
15
15
|
import { WeakETagExtractor } from "./weak-etag-extractor.middleware";
|
|
16
16
|
export const BODY_LIMIT_MAX_SIZE = tools.Size.fromKb(128).toBytes();
|
|
@@ -19,9 +19,9 @@ export class Setup {
|
|
|
19
19
|
const corsOptions = overrides?.cors ?? { origin: "*" };
|
|
20
20
|
const secureHeadersOptions = { crossOriginResourcePolicy: "cross-origin", ...overrides?.secureHeaders };
|
|
21
21
|
return [
|
|
22
|
+
MaintenanceMode.build(overrides?.maintenanceMode),
|
|
22
23
|
secureHeaders(secureHeadersOptions),
|
|
23
24
|
bodyLimit({ maxSize: BODY_LIMIT_MAX_SIZE }),
|
|
24
|
-
new ShieldUserAgentBlockerAdapter().verify,
|
|
25
25
|
ApiVersion.build({ Clock: deps.Clock, JsonFileReader: deps.JsonFileReader }),
|
|
26
26
|
cors(corsOptions),
|
|
27
27
|
languageDetector({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.service.js","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAEtD,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;
|
|
1
|
+
{"version":3,"file":"setup.service.js","sourceRoot":"","sources":["../src/setup.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAEtD,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAE5D,OAAO,EAAE,UAAU,EAA0B,MAAM,0BAA0B,CAAC;AAI9E,OAAO,EAAE,eAAe,EAAkC,MAAM,+BAA+B,CAAC;AAChG,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AAErE,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;AAiBpE,MAAM,OAAO,KAAK;IAChB,MAAM,CAAC,UAAU,CAAC,IAAkB,EAAE,SAA8B;QAClE,MAAM,WAAW,GAAG,SAAS,EAAE,IAAI,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;QACvD,MAAM,oBAAoB,GAAG,EAAE,yBAAyB,EAAE,cAAc,EAAE,GAAG,SAAS,EAAE,aAAa,EAAE,CAAC;QAExG,OAAO;YACL,eAAe,CAAC,KAAK,CAAC,SAAS,EAAE,eAAe,CAAC;YACjD,aAAa,CAAC,oBAAoB,CAAC;YACnC,SAAS,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,CAAC;YAC3C,UAAU,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC;YAC5E,IAAI,CAAC,WAAW,CAAC;YACjB,gBAAgB,CAAC;gBACf,kBAAkB,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC;gBAC7D,gBAAgB,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe;gBAC3C,MAAM,EAAE,KAAK;aACd,CAAC;YACF,SAAS,CAAC;gBACR,WAAW,EAAE,EAAE;gBACf,UAAU,EAAE,kBAAkB;gBAC9B,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;aAC5C,CAAC;YACF,cAAc,CAAC,MAAM;YACrB,OAAO,CAAC,MAAM;YACd,iBAAiB,CAAC,MAAM;YACxB,aAAa,CAAC,MAAM;YACpB,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,EAAE,UAAU,CAAC;YAC7C,MAAM,EAAE;YACR,kBAAkB,CAAC,MAAM,EAAE;SAC5B,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
4
|
+
type ApiKeyShieldConfigType = {
|
|
5
|
+
API_KEY: tools.ApiKeyType;
|
|
6
|
+
};
|
|
7
|
+
export declare const AccessDeniedApiKeyError: HTTPException;
|
|
8
|
+
export declare class ShieldApiKeyStrategy implements ShieldStrategy {
|
|
9
|
+
private readonly config;
|
|
10
|
+
static readonly HEADER_NAME = "bgord-api-key";
|
|
11
|
+
constructor(config: ApiKeyShieldConfigType);
|
|
12
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=shield-api-key.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-api-key.strategy.d.ts","sourceRoot":"","sources":["../src/shield-api-key.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAE3C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,KAAK,sBAAsB,GAAG;IAAE,OAAO,EAAE,KAAK,CAAC,UAAU,CAAA;CAAE,CAAC;AAE5D,eAAO,MAAM,uBAAuB,eAA+D,CAAC;AAEpG,qBAAa,oBAAqB,YAAW,cAAc;IAG7C,OAAO,CAAC,QAAQ,CAAC,MAAM;IAFnC,MAAM,CAAC,QAAQ,CAAC,WAAW,mBAAmB;gBAEjB,MAAM,EAAE,sBAAsB;IAE3D,MAAM,8DAIH;CACJ"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { createMiddleware } from "hono/factory";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
export const AccessDeniedApiKeyError = new HTTPException(403, { message: "access_denied_api_key" });
|
|
4
|
+
export class ShieldApiKeyStrategy {
|
|
5
|
+
config;
|
|
6
|
+
static HEADER_NAME = "bgord-api-key";
|
|
7
|
+
constructor(config) {
|
|
8
|
+
this.config = config;
|
|
9
|
+
}
|
|
10
|
+
verify = createMiddleware(async (c, next) => {
|
|
11
|
+
if (c.req.header(ShieldApiKeyStrategy.HEADER_NAME) === this.config.API_KEY)
|
|
12
|
+
return next();
|
|
13
|
+
throw AccessDeniedApiKeyError;
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=shield-api-key.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-api-key.strategy.js","sourceRoot":"","sources":["../src/shield-api-key.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKpD,MAAM,CAAC,MAAM,uBAAuB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,EAAE,CAAC,CAAC;AAEpG,MAAM,OAAO,oBAAoB;IAGF;IAF7B,MAAM,CAAU,WAAW,GAAG,eAAe,CAAC;IAE9C,YAA6B,MAA8B;QAA9B,WAAM,GAAN,MAAM,CAAwB;IAAG,CAAC;IAE/D,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAC1C,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,oBAAoB,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,OAAO,IAAI,EAAE,CAAC;QAE1F,MAAM,uBAAuB,CAAC;IAChC,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { betterAuth } from "better-auth";
|
|
2
|
+
import type hono from "hono";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
export declare const ShieldAuthStrategyError: HTTPException;
|
|
5
|
+
export declare class ShieldAuthStrategy {
|
|
6
|
+
private readonly Auth;
|
|
7
|
+
constructor(Auth: ReturnType<typeof betterAuth>);
|
|
8
|
+
attach: hono.MiddlewareHandler<any, any, {}, Response>;
|
|
9
|
+
verify: hono.MiddlewareHandler<any, any, {}, Response>;
|
|
10
|
+
reverse: hono.MiddlewareHandler<any, any, {}, Response>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=shield-auth.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-auth.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAE7B,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,eAAO,MAAM,uBAAuB,eAAmE,CAAC;AAExG,qBAAa,kBAAkB;IACjB,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC;IAEhE,MAAM,iDAcH;IAEH,MAAM,iDAKH;IAEH,OAAO,iDAKJ;CACJ"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
// TODO: tests
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
export const ShieldAuthStrategyError = new HTTPException(403, { message: "access_denied_auth_shield" });
|
|
5
|
+
export class ShieldAuthStrategy {
|
|
6
|
+
Auth;
|
|
7
|
+
constructor(Auth) {
|
|
8
|
+
this.Auth = Auth;
|
|
9
|
+
}
|
|
10
|
+
attach = createMiddleware(async (c, next) => {
|
|
11
|
+
const session = await this.Auth.api.getSession({ headers: c.req.raw.headers });
|
|
12
|
+
if (!session) {
|
|
13
|
+
c.set("user", null);
|
|
14
|
+
c.set("session", null);
|
|
15
|
+
return next();
|
|
16
|
+
}
|
|
17
|
+
c.set("user", session.user);
|
|
18
|
+
c.set("session", session.session);
|
|
19
|
+
return next();
|
|
20
|
+
});
|
|
21
|
+
verify = createMiddleware(async (c, next) => {
|
|
22
|
+
const user = c.get("user");
|
|
23
|
+
if (!user)
|
|
24
|
+
throw ShieldAuthStrategyError;
|
|
25
|
+
return next();
|
|
26
|
+
});
|
|
27
|
+
reverse = createMiddleware(async (c, next) => {
|
|
28
|
+
const user = c.get("user");
|
|
29
|
+
if (user)
|
|
30
|
+
throw ShieldAuthStrategyError;
|
|
31
|
+
return next();
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=shield-auth.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-auth.strategy.js","sourceRoot":"","sources":["../src/shield-auth.strategy.ts"],"names":[],"mappings":"AAAA,cAAc;AAId,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,MAAM,CAAC,MAAM,uBAAuB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,2BAA2B,EAAE,CAAC,CAAC;AAExG,MAAM,OAAO,kBAAkB;IACA;IAA7B,YAA6B,IAAmC;QAAnC,SAAI,GAAJ,IAAI,CAA+B;IAAG,CAAC;IAEpE,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACnE,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QAE/E,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACpB,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YAEvB,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QAED,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;QAElC,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACnE,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,IAAI;YAAE,MAAM,uBAAuB,CAAC;QACzC,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;IAEH,OAAO,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAe,EAAE,IAAe,EAAE,EAAE;QACpE,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,IAAI;YAAE,MAAM,uBAAuB,CAAC;QACxC,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;CACJ"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { BasicAuthPasswordType } from "./basic-auth-password.vo";
|
|
2
|
+
import type { BasicAuthUsernameType } from "./basic-auth-username.vo";
|
|
3
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
4
|
+
type ShieldBasicAuthConfigType = {
|
|
5
|
+
username: BasicAuthUsernameType;
|
|
6
|
+
password: BasicAuthPasswordType;
|
|
7
|
+
};
|
|
8
|
+
export declare class ShieldBasicAuthStrategy implements ShieldStrategy {
|
|
9
|
+
private readonly basicAuth;
|
|
10
|
+
constructor(config: ShieldBasicAuthConfigType);
|
|
11
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
12
|
+
}
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=shield-basic-auth.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-basic-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,KAAK,yBAAyB,GAAG;IAAE,QAAQ,EAAE,qBAAqB,CAAC;IAAC,QAAQ,EAAE,qBAAqB,CAAA;CAAE,CAAC;AAEtG,qBAAa,uBAAwB,YAAW,cAAc;IAC5D,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC;gBAEf,MAAM,EAAE,yBAAyB;IAI7C,MAAM,8DAAgE;CACvE"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { basicAuth } from "hono/basic-auth";
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
export class ShieldBasicAuthStrategy {
|
|
4
|
+
basicAuth;
|
|
5
|
+
constructor(config) {
|
|
6
|
+
this.basicAuth = basicAuth(config);
|
|
7
|
+
}
|
|
8
|
+
verify = createMiddleware(async (c, next) => this.basicAuth(c, next));
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=shield-basic-auth.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-basic-auth.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAOhD,MAAM,OAAO,uBAAuB;IACjB,SAAS,CAAC;IAE3B,YAAY,MAAiC;QAC3C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;CACvE"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { HTTPException } from "hono/http-exception";
|
|
2
|
+
import type { HCaptchaSecretKeyType } from "./hcaptcha-secret-key.vo";
|
|
3
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
4
|
+
export declare const AccessDeniedHcaptchaLocalError: HTTPException;
|
|
5
|
+
export declare class ShieldCaptchaHcaptchaLocalStrategy implements ShieldStrategy {
|
|
6
|
+
private readonly secretKey;
|
|
7
|
+
constructor(secretKey: HCaptchaSecretKeyType);
|
|
8
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=shield-captcha-hcaptcha-local.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-captcha-hcaptcha-local.strategy.d.ts","sourceRoot":"","sources":["../src/shield-captcha-hcaptcha-local.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,eAAO,MAAM,8BAA8B,eAEzC,CAAC;AAEH,qBAAa,kCAAmC,YAAW,cAAc;IAC3D,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,EAAE,qBAAqB;IAE7D,MAAM,8DASH;CACJ"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import hcaptcha from "hcaptcha";
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
export const AccessDeniedHcaptchaLocalError = new HTTPException(403, {
|
|
5
|
+
message: "access_denied_hcaptcha_local",
|
|
6
|
+
});
|
|
7
|
+
export class ShieldCaptchaHcaptchaLocalStrategy {
|
|
8
|
+
secretKey;
|
|
9
|
+
constructor(secretKey) {
|
|
10
|
+
this.secretKey = secretKey;
|
|
11
|
+
}
|
|
12
|
+
verify = createMiddleware(async (_c, next) => {
|
|
13
|
+
try {
|
|
14
|
+
const result = await hcaptcha.verify(this.secretKey, "10000000-aaaa-bbbb-cccc-000000000001");
|
|
15
|
+
if (!result?.success)
|
|
16
|
+
throw AccessDeniedHcaptchaLocalError;
|
|
17
|
+
return next();
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
throw AccessDeniedHcaptchaLocalError;
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=shield-captcha-hcaptcha-local.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-captcha-hcaptcha-local.strategy.js","sourceRoot":"","sources":["../src/shield-captcha-hcaptcha-local.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAIpD,MAAM,CAAC,MAAM,8BAA8B,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE;IACnE,OAAO,EAAE,8BAA8B;CACxC,CAAC,CAAC;AAEH,MAAM,OAAO,kCAAkC;IAChB;IAA7B,YAA6B,SAAgC;QAAhC,cAAS,GAAT,SAAS,CAAuB;IAAG,CAAC;IAEjE,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE;QAC3C,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,sCAAsC,CAAC,CAAC;YAE7F,IAAI,CAAC,MAAM,EAAE,OAAO;gBAAE,MAAM,8BAA8B,CAAC;YAC3D,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,8BAA8B,CAAC;QACvC,CAAC;IACH,CAAC,CAAC,CAAC;CACJ"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { HTTPException } from "hono/http-exception";
|
|
2
|
+
import type { HCaptchaSecretKeyType } from "./hcaptcha-secret-key.vo";
|
|
3
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
4
|
+
export declare const AccessDeniedHcaptchaError: HTTPException;
|
|
5
|
+
export declare class ShieldCaptchaHcaptchaStrategy implements ShieldStrategy {
|
|
6
|
+
private readonly secretKey;
|
|
7
|
+
constructor(secretKey: HCaptchaSecretKeyType);
|
|
8
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=shield-captcha-hcaptcha.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-captcha-hcaptcha.strategy.d.ts","sourceRoot":"","sources":["../src/shield-captcha-hcaptcha.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,eAAO,MAAM,yBAAyB,eAAgE,CAAC;AAEvG,qBAAa,6BAA8B,YAAW,cAAc;IACtD,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,EAAE,qBAAqB;IAE7D,MAAM,8DAWH;CACJ"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import hcaptcha from "hcaptcha";
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
export const AccessDeniedHcaptchaError = new HTTPException(403, { message: "access_denied_hcaptcha" });
|
|
5
|
+
export class ShieldCaptchaHcaptchaStrategy {
|
|
6
|
+
secretKey;
|
|
7
|
+
constructor(secretKey) {
|
|
8
|
+
this.secretKey = secretKey;
|
|
9
|
+
}
|
|
10
|
+
verify = createMiddleware(async (c, next) => {
|
|
11
|
+
try {
|
|
12
|
+
const form = await c.req.formData();
|
|
13
|
+
const hcaptchaTokenFormData = form.get("h-captcha-response")?.toString();
|
|
14
|
+
const result = await hcaptcha.verify(this.secretKey, hcaptchaTokenFormData);
|
|
15
|
+
if (!result?.success)
|
|
16
|
+
throw AccessDeniedHcaptchaError;
|
|
17
|
+
return next();
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
throw AccessDeniedHcaptchaError;
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=shield-captcha-hcaptcha.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-captcha-hcaptcha.strategy.js","sourceRoot":"","sources":["../src/shield-captcha-hcaptcha.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAIpD,MAAM,CAAC,MAAM,yBAAyB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,wBAAwB,EAAE,CAAC,CAAC;AAEvG,MAAM,OAAO,6BAA6B;IACX;IAA7B,YAA6B,SAAgC;QAAhC,cAAS,GAAT,SAAS,CAAuB;IAAG,CAAC;IAEjE,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAC1C,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,qBAAqB,GAAG,IAAI,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,QAAQ,EAAY,CAAC;YACnF,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,qBAAqB,CAAC,CAAC;YAE5E,IAAI,CAAC,MAAM,EAAE,OAAO;gBAAE,MAAM,yBAAyB,CAAC;YACtD,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,yBAAyB,CAAC;QAClC,CAAC;IACH,CAAC,CAAC,CAAC;CACJ"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { HTTPException } from "hono/http-exception";
|
|
2
|
+
import type { RecaptchaSecretKeyType } from "./recaptcha-secret-key.vo";
|
|
3
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
4
|
+
export type RecaptchaVerifierConfigType = {
|
|
5
|
+
secretKey: RecaptchaSecretKeyType;
|
|
6
|
+
};
|
|
7
|
+
export type RecaptchaResultType = {
|
|
8
|
+
success: boolean;
|
|
9
|
+
score: number;
|
|
10
|
+
};
|
|
11
|
+
export declare const AccessDeniedRecaptchaError: HTTPException;
|
|
12
|
+
export declare class ShieldCaptchaRecaptchaStrategy implements ShieldStrategy {
|
|
13
|
+
private readonly config;
|
|
14
|
+
private static readonly URL;
|
|
15
|
+
constructor(config: RecaptchaVerifierConfigType);
|
|
16
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=shield-captcha-recaptcha.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-captcha-recaptcha.strategy.d.ts","sourceRoot":"","sources":["../src/shield-captcha-recaptcha.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AACxE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,MAAM,MAAM,2BAA2B,GAAG;IAAE,SAAS,EAAE,sBAAsB,CAAA;CAAE,CAAC;AAChF,MAAM,MAAM,mBAAmB,GAAG;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC;AAEtE,eAAO,MAAM,0BAA0B,eAAiE,CAAC;AAEzG,qBAAa,8BAA+B,YAAW,cAAc;IAKvD,OAAO,CAAC,QAAQ,CAAC,MAAM;IAJnC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAEzB;gBAE2B,MAAM,EAAE,2BAA2B;IAEhE,MAAM,8DA6BH;CACJ"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
export const AccessDeniedRecaptchaError = new HTTPException(403, { message: "access_denied_recaptcha" });
|
|
5
|
+
export class ShieldCaptchaRecaptchaStrategy {
|
|
6
|
+
config;
|
|
7
|
+
static URL = tools.UrlWithoutSlash.parse("https://www.google.com/recaptcha/api/siteverify");
|
|
8
|
+
constructor(config) {
|
|
9
|
+
this.config = config;
|
|
10
|
+
}
|
|
11
|
+
verify = createMiddleware(async (c, next) => {
|
|
12
|
+
try {
|
|
13
|
+
const header = c.req.header("x-recaptcha-token");
|
|
14
|
+
const query = c.req.query("recaptchaToken");
|
|
15
|
+
const form = (await c.req.formData()).get("g-recaptcha-response")?.toString();
|
|
16
|
+
const token = header ?? query ?? form;
|
|
17
|
+
if (!token)
|
|
18
|
+
throw AccessDeniedRecaptchaError;
|
|
19
|
+
// cSpell:ignore remoteip
|
|
20
|
+
const remoteip = c.req.header("x-forwarded-for") ?? "";
|
|
21
|
+
const params = new URLSearchParams({ secret: this.config.secretKey, response: token, remoteip });
|
|
22
|
+
const response = await fetch(ShieldCaptchaRecaptchaStrategy.URL, {
|
|
23
|
+
method: "POST",
|
|
24
|
+
headers: { "Content-Type": "application/x-www-form-urlencoded" },
|
|
25
|
+
body: params,
|
|
26
|
+
});
|
|
27
|
+
const result = await response.json();
|
|
28
|
+
if (!result.success || result.score < 0.5)
|
|
29
|
+
throw AccessDeniedRecaptchaError;
|
|
30
|
+
await next();
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
throw AccessDeniedRecaptchaError;
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=shield-captcha-recaptcha.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-captcha-recaptcha.strategy.js","sourceRoot":"","sources":["../src/shield-captcha-recaptcha.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAOpD,MAAM,CAAC,MAAM,0BAA0B,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC,CAAC;AAEzG,MAAM,OAAO,8BAA8B;IAKZ;IAJrB,MAAM,CAAU,GAAG,GAAG,KAAK,CAAC,eAAe,CAAC,KAAK,CACvD,iDAAiD,CAClD,CAAC;IAEF,YAA6B,MAAmC;QAAnC,WAAM,GAAN,MAAM,CAA6B;IAAG,CAAC;IAEpE,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAC1C,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;YACjD,MAAM,KAAK,GAAG,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;YAC5C,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,sBAAsB,CAAC,EAAE,QAAQ,EAAE,CAAC;YAE9E,MAAM,KAAK,GAAG,MAAM,IAAI,KAAK,IAAI,IAAI,CAAC;YAEtC,IAAI,CAAC,KAAK;gBAAE,MAAM,0BAA0B,CAAC;YAE7C,yBAAyB;YACzB,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC;YAEvD,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;YAEjG,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,8BAA8B,CAAC,GAAG,EAAE;gBAC/D,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,EAAE,cAAc,EAAE,mCAAmC,EAAE;gBAChE,IAAI,EAAE,MAAM;aACb,CAAC,CAAC;YAEH,MAAM,MAAM,GAAwB,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;YAE1D,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,KAAK,GAAG,GAAG;gBAAE,MAAM,0BAA0B,CAAC;YAE5E,MAAM,IAAI,EAAE,CAAC;QACf,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,0BAA0B,CAAC;QACnC,CAAC;IACH,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-noop.strategy.d.ts","sourceRoot":"","sources":["../src/shield-noop.strategy.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,qBAAa,kBAAmB,YAAW,cAAc;IACvD,MAAM,8DAAgD;CACvD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-noop.strategy.js","sourceRoot":"","sources":["../src/shield-noop.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAGhD,MAAM,OAAO,kBAAkB;IAC7B,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;CACvD"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import { HTTPException } from "hono/http-exception";
|
|
3
|
+
import type { CacheResolverStrategy } from "./cache-resolver.strategy";
|
|
4
|
+
import type { CacheSubjectResolver } from "./cache-subject-resolver.vo";
|
|
5
|
+
import type { ClockPort } from "./clock.port";
|
|
6
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
7
|
+
type ShieldRateLimitOptionsType = {
|
|
8
|
+
enabled: boolean;
|
|
9
|
+
resolver: CacheSubjectResolver;
|
|
10
|
+
window: tools.Duration;
|
|
11
|
+
};
|
|
12
|
+
type Dependencies = {
|
|
13
|
+
Clock: ClockPort;
|
|
14
|
+
CacheResolver: CacheResolverStrategy;
|
|
15
|
+
};
|
|
16
|
+
export declare const TooManyRequestsError: HTTPException;
|
|
17
|
+
export declare class ShieldRateLimitStrategy implements ShieldStrategy {
|
|
18
|
+
private readonly options;
|
|
19
|
+
private readonly deps;
|
|
20
|
+
constructor(options: ShieldRateLimitOptionsType, deps: Dependencies);
|
|
21
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
24
|
+
//# sourceMappingURL=shield-rate-limit.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-rate-limit.strategy.d.ts","sourceRoot":"","sources":["../src/shield-rate-limit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAEtC,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AACvE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,KAAK,0BAA0B,GAAG;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,oBAAoB,CAAC;IAC/B,MAAM,EAAE,KAAK,CAAC,QAAQ,CAAC;CACxB,CAAC;AAEF,KAAK,YAAY,GAAG;IAAE,KAAK,EAAE,SAAS,CAAC;IAAC,aAAa,EAAE,qBAAqB,CAAA;CAAE,CAAC;AAE/E,eAAO,MAAM,oBAAoB,eAA+D,CAAC;AAEjG,qBAAa,uBAAwB,YAAW,cAAc;IAE1D,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,IAAI;gBADJ,OAAO,EAAE,0BAA0B,EACnC,IAAI,EAAE,YAAY;IAGrC,MAAM,8DAeH;CACJ"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import * as tools from "@bgord/tools";
|
|
2
|
+
import { createMiddleware } from "hono/factory";
|
|
3
|
+
import { HTTPException } from "hono/http-exception";
|
|
4
|
+
export const TooManyRequestsError = new HTTPException(429, { message: "app.too_many_requests" });
|
|
5
|
+
export class ShieldRateLimitStrategy {
|
|
6
|
+
options;
|
|
7
|
+
deps;
|
|
8
|
+
constructor(options, deps) {
|
|
9
|
+
this.options = options;
|
|
10
|
+
this.deps = deps;
|
|
11
|
+
}
|
|
12
|
+
verify = createMiddleware(async (c, next) => {
|
|
13
|
+
if (!this.options.enabled)
|
|
14
|
+
return next();
|
|
15
|
+
const subject = await this.options.resolver.resolve(c);
|
|
16
|
+
const limiter = await this.deps.CacheResolver.resolve(subject.hex, async () => new tools.RateLimiter(this.options.window));
|
|
17
|
+
const result = limiter.verify(this.deps.Clock.now());
|
|
18
|
+
if (!result.allowed)
|
|
19
|
+
throw TooManyRequestsError;
|
|
20
|
+
return next();
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=shield-rate-limit.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-rate-limit.strategy.js","sourceRoot":"","sources":["../src/shield-rate-limit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAcpD,MAAM,CAAC,MAAM,oBAAoB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,EAAE,CAAC,CAAC;AAEjG,MAAM,OAAO,uBAAuB;IAEf;IACA;IAFnB,YACmB,OAAmC,EACnC,IAAkB;QADlB,YAAO,GAAP,OAAO,CAA4B;QACnC,SAAI,GAAJ,IAAI,CAAc;IAClC,CAAC;IAEJ,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAC1C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO;YAAE,OAAO,IAAI,EAAE,CAAC;QAEzC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAEvD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CACnD,OAAO,CAAC,GAAG,EACX,KAAK,IAAI,EAAE,CAAC,IAAI,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CACvD,CAAC;QAEF,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QAErD,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,MAAM,oBAAoB,CAAC;QAEhD,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;CACJ"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { SecurityPolicy } from "./security-policy.vo";
|
|
2
|
+
import type { ShieldStrategy } from "./shield.strategy";
|
|
3
|
+
import type { SleeperPort } from "./sleeper.port";
|
|
4
|
+
type Dependencies = {
|
|
5
|
+
Sleeper: SleeperPort;
|
|
6
|
+
};
|
|
7
|
+
export declare const ShieldSecurityAdapterError: {
|
|
8
|
+
Unhandled: string;
|
|
9
|
+
MissingPolicies: string;
|
|
10
|
+
MaxPolicies: string;
|
|
11
|
+
};
|
|
12
|
+
export declare class ShieldSecurityStrategy implements ShieldStrategy {
|
|
13
|
+
private readonly policies;
|
|
14
|
+
private readonly deps;
|
|
15
|
+
constructor(policies: SecurityPolicy[], deps: Dependencies);
|
|
16
|
+
verify: import("hono").MiddlewareHandler<any, string, {}, (Response & import("hono").TypedResponse<string, 100 | 102 | 103 | 200 | 201 | 202 | 203 | 206 | 207 | 208 | 226 | 300 | 301 | 302 | 303 | 305 | 306 | 307 | 308 | 400 | 401 | 402 | 403 | 404 | 405 | 406 | 407 | 408 | 409 | 410 | 411 | 412 | 413 | 414 | 415 | 416 | 417 | 418 | 421 | 422 | 423 | 424 | 425 | 426 | 428 | 429 | 431 | 451 | 500 | 501 | 502 | 503 | 504 | 505 | 506 | 507 | 508 | 510 | 511 | -1, "text">) | (Response & import("hono").TypedResponse<{}, 100 | 102 | 103 | 200 | 201 | 202 | 203 | 206 | 207 | 208 | 226 | 300 | 301 | 302 | 303 | 305 | 306 | 307 | 308 | 400 | 401 | 402 | 403 | 404 | 405 | 406 | 407 | 408 | 409 | 410 | 411 | 412 | 413 | 414 | 415 | 416 | 417 | 418 | 421 | 422 | 423 | 424 | 425 | 426 | 428 | 429 | 431 | 451 | 500 | 501 | 502 | 503 | 504 | 505 | 506 | 507 | 508 | 510 | 511 | -1, "json">)>;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=shield-security.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shield-security.strategy.d.ts","sourceRoot":"","sources":["../src/shield-security.strategy.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAElD,KAAK,YAAY,GAAG;IAAE,OAAO,EAAE,WAAW,CAAA;CAAE,CAAC;AAE7C,eAAO,MAAM,0BAA0B;;;;CAItC,CAAC;AAEF,qBAAa,sBAAuB,YAAW,cAAc;IAEzD,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,IAAI;gBADJ,QAAQ,EAAE,cAAc,EAAE,EAC1B,IAAI,EAAE,YAAY;IAMrC,MAAM,m3BA4CH;CACJ"}
|