@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,40 @@
|
|
|
1
|
+
import { CorrelationStorage } from "./correlation-storage.service";
|
|
2
|
+
import { createEventEnvelope } from "./event-envelope";
|
|
3
|
+
import { SECURITY_VIOLATION_DETECTED_EVENT, SecurityViolationDetectedEvent, } from "./modules/system/events/SECURITY_VIOLATION_DETECTED_EVENT";
|
|
4
|
+
import { SecurityCountermeasureName } from "./security-countermeasure-name.vo";
|
|
5
|
+
export const SecurityCountermeasureBanStrategyError = {
|
|
6
|
+
Executed: "security.countermeasure.ban.strategy.executed",
|
|
7
|
+
};
|
|
8
|
+
export class SecurityCountermeasureBanStrategy {
|
|
9
|
+
deps;
|
|
10
|
+
config;
|
|
11
|
+
constructor(deps, config = { response: { status: 403 } }) {
|
|
12
|
+
this.deps = deps;
|
|
13
|
+
this.config = config;
|
|
14
|
+
}
|
|
15
|
+
async execute(context) {
|
|
16
|
+
const action = {
|
|
17
|
+
kind: "deny",
|
|
18
|
+
reason: SecurityCountermeasureBanStrategyError.Executed,
|
|
19
|
+
...this.config,
|
|
20
|
+
};
|
|
21
|
+
this.deps.Logger.info({
|
|
22
|
+
message: "Security countermeasure ban",
|
|
23
|
+
component: "security",
|
|
24
|
+
operation: "security_countermeasure_ban",
|
|
25
|
+
correlationId: CorrelationStorage.get(),
|
|
26
|
+
metadata: context,
|
|
27
|
+
});
|
|
28
|
+
const event = SecurityViolationDetectedEvent.parse({
|
|
29
|
+
...createEventEnvelope("security", this.deps),
|
|
30
|
+
name: SECURITY_VIOLATION_DETECTED_EVENT,
|
|
31
|
+
payload: { ...context, countermeasure: this.name, action: action.kind },
|
|
32
|
+
});
|
|
33
|
+
await this.deps.EventStore.save([event]);
|
|
34
|
+
return action;
|
|
35
|
+
}
|
|
36
|
+
get name() {
|
|
37
|
+
return SecurityCountermeasureName.parse("ban");
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=security-countermeasure-ban.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-ban.strategy.js","sourceRoot":"","sources":["../src/security-countermeasure-ban.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAIvD,OAAO,EACL,iCAAiC,EACjC,8BAA8B,GAE/B,MAAM,2DAA2D,CAAC;AAGnE,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAS/E,MAAM,CAAC,MAAM,sCAAsC,GAAG;IACpD,QAAQ,EAAE,+CAA+C;CAC1D,CAAC;AAEF,MAAM,OAAO,iCAAiC;IAEzB;IACA;IAFnB,YACmB,IAAkB,EAClB,SAA2C,EAAE,QAAQ,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE;QADxE,SAAI,GAAJ,IAAI,CAAc;QAClB,WAAM,GAAN,MAAM,CAAkE;IACxF,CAAC;IAEJ,KAAK,CAAC,OAAO,CAAC,OAAwB;QACpC,MAAM,MAAM,GAAG;YACb,IAAI,EAAE,MAAM;YACZ,MAAM,EAAE,sCAAsC,CAAC,QAAQ;YACvD,GAAG,IAAI,CAAC,MAAM;SACN,CAAC;QAEX,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YACpB,OAAO,EAAE,6BAA6B;YACtC,SAAS,EAAE,UAAU;YACrB,SAAS,EAAE,6BAA6B;YACxC,aAAa,EAAE,kBAAkB,CAAC,GAAG,EAAE;YACvC,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,8BAA8B,CAAC,KAAK,CAAC;YACjD,GAAG,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC;YAC7C,IAAI,EAAE,iCAAiC;YACvC,OAAO,EAAE,EAAE,GAAG,OAAO,EAAE,cAAc,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE;SAC3B,CAAC,CAAC;QAEhD,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAEzC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,0BAA0B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { LoggerPort } from "./logger.port";
|
|
2
|
+
import type { SecurityContext } from "./security-context.vo";
|
|
3
|
+
import type { SecurityAction, SecurityCountermeasureStrategy } from "./security-countermeasure.strategy";
|
|
4
|
+
type Dependencies = {
|
|
5
|
+
Logger: LoggerPort;
|
|
6
|
+
};
|
|
7
|
+
export declare class SecurityCountermeasureMirageStrategy implements SecurityCountermeasureStrategy {
|
|
8
|
+
private readonly deps;
|
|
9
|
+
private readonly config;
|
|
10
|
+
constructor(deps: Dependencies, config?: {
|
|
11
|
+
response: {
|
|
12
|
+
status: number;
|
|
13
|
+
};
|
|
14
|
+
});
|
|
15
|
+
execute(context: SecurityContext): Promise<SecurityAction>;
|
|
16
|
+
get name(): string & import("zod").$brand<"SecurityCountermeasureName">;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=security-countermeasure-mirage.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-mirage.strategy.d.ts","sourceRoot":"","sources":["../src/security-countermeasure-mirage.strategy.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AAGzG,KAAK,YAAY,GAAG;IAAE,MAAM,EAAE,UAAU,CAAA;CAAE,CAAC;AAE3C,qBAAa,oCAAqC,YAAW,8BAA8B;IAEvF,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBADN,IAAI,EAAE,YAAY,EAClB,MAAM,GAAE;QAAE,QAAQ,EAAE;YAAE,MAAM,EAAE,MAAM,CAAA;SAAE,CAAA;KAAkC;IAGrF,OAAO,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,cAAc,CAAC;IAYhE,IAAI,IAAI,gEAEP;CACF"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { CorrelationStorage } from "./correlation-storage.service";
|
|
2
|
+
import { SecurityCountermeasureName } from "./security-countermeasure-name.vo";
|
|
3
|
+
export class SecurityCountermeasureMirageStrategy {
|
|
4
|
+
deps;
|
|
5
|
+
config;
|
|
6
|
+
constructor(deps, config = { response: { status: 200 } }) {
|
|
7
|
+
this.deps = deps;
|
|
8
|
+
this.config = config;
|
|
9
|
+
}
|
|
10
|
+
async execute(context) {
|
|
11
|
+
this.deps.Logger.info({
|
|
12
|
+
message: "Security countermeasure mirage",
|
|
13
|
+
component: "security",
|
|
14
|
+
operation: "security_countermeasure_mirage",
|
|
15
|
+
correlationId: CorrelationStorage.get(),
|
|
16
|
+
metadata: context,
|
|
17
|
+
});
|
|
18
|
+
return { kind: "mirage", ...this.config };
|
|
19
|
+
}
|
|
20
|
+
get name() {
|
|
21
|
+
return SecurityCountermeasureName.parse("mirage");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=security-countermeasure-mirage.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-mirage.strategy.js","sourceRoot":"","sources":["../src/security-countermeasure-mirage.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAInE,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAI/E,MAAM,OAAO,oCAAoC;IAE5B;IACA;IAFnB,YACmB,IAAkB,EAClB,SAA2C,EAAE,QAAQ,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE;QADxE,SAAI,GAAJ,IAAI,CAAc;QAClB,WAAM,GAAN,MAAM,CAAkE;IACxF,CAAC;IAEJ,KAAK,CAAC,OAAO,CAAC,OAAwB;QACpC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YACpB,OAAO,EAAE,gCAAgC;YACzC,SAAS,EAAE,UAAU;YACrB,SAAS,EAAE,gCAAgC;YAC3C,aAAa,EAAE,kBAAkB,CAAC,GAAG,EAAE;YACvC,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC;QAEH,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;IAC5C,CAAC;IAED,IAAI,IAAI;QACN,OAAO,0BAA0B,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { z } from "zod/v4";
|
|
2
|
+
export declare const SecurityCountermeasureNameError: {
|
|
3
|
+
Type: string;
|
|
4
|
+
Empty: string;
|
|
5
|
+
TooLong: string;
|
|
6
|
+
BadChars: string;
|
|
7
|
+
};
|
|
8
|
+
export declare const SecurityCountermeasureName: z.core.$ZodBranded<z.ZodString, "SecurityCountermeasureName">;
|
|
9
|
+
export type SecurityCountermeasureNameType = z.infer<typeof SecurityCountermeasureName>;
|
|
10
|
+
//# sourceMappingURL=security-countermeasure-name.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-name.vo.d.ts","sourceRoot":"","sources":["../src/security-countermeasure-name.vo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B,eAAO,MAAM,+BAA+B;;;;;CAK3C,CAAC;AAKF,eAAO,MAAM,0BAA0B,+DAKD,CAAC;AAEvC,MAAM,MAAM,8BAA8B,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,0BAA0B,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { z } from "zod/v4";
|
|
2
|
+
export const SecurityCountermeasureNameError = {
|
|
3
|
+
Type: "security.countermeasure.name.type",
|
|
4
|
+
Empty: "security.countermeasure.name.empty",
|
|
5
|
+
TooLong: "security.countermeasure.name.too.long",
|
|
6
|
+
BadChars: "security.countermeasure.name.bad.chars",
|
|
7
|
+
};
|
|
8
|
+
// One to sixty four letters, digits, or underscores
|
|
9
|
+
const CHARS_WHITELIST = /^[a-zA-Z0-9_]{1,64}$/;
|
|
10
|
+
export const SecurityCountermeasureName = z
|
|
11
|
+
.string(SecurityCountermeasureNameError.Type)
|
|
12
|
+
.min(1, SecurityCountermeasureNameError.Empty)
|
|
13
|
+
.max(64, SecurityCountermeasureNameError.TooLong)
|
|
14
|
+
.regex(CHARS_WHITELIST, SecurityCountermeasureNameError.BadChars)
|
|
15
|
+
.brand("SecurityCountermeasureName");
|
|
16
|
+
//# sourceMappingURL=security-countermeasure-name.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-name.vo.js","sourceRoot":"","sources":["../src/security-countermeasure-name.vo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B,MAAM,CAAC,MAAM,+BAA+B,GAAG;IAC7C,IAAI,EAAE,mCAAmC;IACzC,KAAK,EAAE,oCAAoC;IAC3C,OAAO,EAAE,uCAAuC;IAChD,QAAQ,EAAE,wCAAwC;CACnD,CAAC;AAEF,oDAAoD;AACpD,MAAM,eAAe,GAAG,sBAAsB,CAAC;AAE/C,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC;KACxC,MAAM,CAAC,+BAA+B,CAAC,IAAI,CAAC;KAC5C,GAAG,CAAC,CAAC,EAAE,+BAA+B,CAAC,KAAK,CAAC;KAC7C,GAAG,CAAC,EAAE,EAAE,+BAA+B,CAAC,OAAO,CAAC;KAChD,KAAK,CAAC,eAAe,EAAE,+BAA+B,CAAC,QAAQ,CAAC;KAChE,KAAK,CAAC,4BAA4B,CAAC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { SecurityAction, SecurityCountermeasureStrategy } from "./security-countermeasure.strategy";
|
|
2
|
+
export declare class SecurityCountermeasureNoopStrategy implements SecurityCountermeasureStrategy {
|
|
3
|
+
execute(): Promise<SecurityAction>;
|
|
4
|
+
get name(): string & import("zod").$brand<"SecurityCountermeasureName">;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=security-countermeasure-noop.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-noop.strategy.d.ts","sourceRoot":"","sources":["../src/security-countermeasure-noop.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AAGzG,qBAAa,kCAAmC,YAAW,8BAA8B;IACjF,OAAO,IAAI,OAAO,CAAC,cAAc,CAAC;IAIxC,IAAI,IAAI,gEAEP;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { SecurityCountermeasureName } from "./security-countermeasure-name.vo";
|
|
2
|
+
export class SecurityCountermeasureNoopStrategy {
|
|
3
|
+
async execute() {
|
|
4
|
+
return { kind: "allow" };
|
|
5
|
+
}
|
|
6
|
+
get name() {
|
|
7
|
+
return SecurityCountermeasureName.parse("noop");
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=security-countermeasure-noop.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-noop.strategy.js","sourceRoot":"","sources":["../src/security-countermeasure-noop.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAE/E,MAAM,OAAO,kCAAkC;IAC7C,KAAK,CAAC,OAAO;QACX,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,IAAI;QACN,OAAO,0BAA0B,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAClD,CAAC;CACF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { LoggerPort } from "./logger.port";
|
|
2
|
+
import type { SecurityContext } from "./security-context.vo";
|
|
3
|
+
import type { SecurityAction, SecurityCountermeasureStrategy } from "./security-countermeasure.strategy";
|
|
4
|
+
type Dependencies = {
|
|
5
|
+
Logger: LoggerPort;
|
|
6
|
+
};
|
|
7
|
+
export declare class SecurityCountermeasureReportStrategy implements SecurityCountermeasureStrategy {
|
|
8
|
+
private readonly deps;
|
|
9
|
+
constructor(deps: Dependencies);
|
|
10
|
+
execute(context: SecurityContext): Promise<SecurityAction>;
|
|
11
|
+
get name(): string & import("zod").$brand<"SecurityCountermeasureName">;
|
|
12
|
+
}
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=security-countermeasure-report.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-report.strategy.d.ts","sourceRoot":"","sources":["../src/security-countermeasure-report.strategy.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AAGzG,KAAK,YAAY,GAAG;IAAE,MAAM,EAAE,UAAU,CAAA;CAAE,CAAC;AAE3C,qBAAa,oCAAqC,YAAW,8BAA8B;IAC7E,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,YAAY;IAEzC,OAAO,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,cAAc,CAAC;IAYhE,IAAI,IAAI,gEAEP;CACF"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { CorrelationStorage } from "./correlation-storage.service";
|
|
2
|
+
import { SecurityCountermeasureName } from "./security-countermeasure-name.vo";
|
|
3
|
+
export class SecurityCountermeasureReportStrategy {
|
|
4
|
+
deps;
|
|
5
|
+
constructor(deps) {
|
|
6
|
+
this.deps = deps;
|
|
7
|
+
}
|
|
8
|
+
async execute(context) {
|
|
9
|
+
this.deps.Logger.info({
|
|
10
|
+
message: "Security countermeasure report",
|
|
11
|
+
component: "security",
|
|
12
|
+
operation: "security_countermeasure_report",
|
|
13
|
+
correlationId: CorrelationStorage.get(),
|
|
14
|
+
metadata: context,
|
|
15
|
+
});
|
|
16
|
+
return { kind: "allow" };
|
|
17
|
+
}
|
|
18
|
+
get name() {
|
|
19
|
+
return SecurityCountermeasureName.parse("report");
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=security-countermeasure-report.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-report.strategy.js","sourceRoot":"","sources":["../src/security-countermeasure-report.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAInE,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAI/E,MAAM,OAAO,oCAAoC;IAClB;IAA7B,YAA6B,IAAkB;QAAlB,SAAI,GAAJ,IAAI,CAAc;IAAG,CAAC;IAEnD,KAAK,CAAC,OAAO,CAAC,OAAwB;QACpC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YACpB,OAAO,EAAE,gCAAgC;YACzC,SAAS,EAAE,UAAU;YACrB,SAAS,EAAE,gCAAgC;YAC3C,aAAa,EAAE,kBAAkB,CAAC,GAAG,EAAE;YACvC,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC;QAEH,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED,IAAI,IAAI;QACN,OAAO,0BAA0B,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;CACF"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { LoggerPort } from "./logger.port";
|
|
3
|
+
import type { SecurityContext } from "./security-context.vo";
|
|
4
|
+
import type { SecurityAction, SecurityCountermeasureStrategy } from "./security-countermeasure.strategy";
|
|
5
|
+
type Dependencies = {
|
|
6
|
+
Logger: LoggerPort;
|
|
7
|
+
};
|
|
8
|
+
export declare class SecurityCountermeasureTarpitStrategy implements SecurityCountermeasureStrategy {
|
|
9
|
+
private readonly deps;
|
|
10
|
+
private readonly config;
|
|
11
|
+
constructor(deps: Dependencies, config: {
|
|
12
|
+
duration: tools.Duration;
|
|
13
|
+
after: SecurityAction;
|
|
14
|
+
});
|
|
15
|
+
execute(context: SecurityContext): Promise<SecurityAction>;
|
|
16
|
+
get name(): string & import("zod").$brand<"SecurityCountermeasureName">;
|
|
17
|
+
}
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=security-countermeasure-tarpit.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-tarpit.strategy.d.ts","sourceRoot":"","sources":["../src/security-countermeasure-tarpit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAE3C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EAAE,cAAc,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AAGzG,KAAK,YAAY,GAAG;IAAE,MAAM,EAAE,UAAU,CAAA;CAAE,CAAC;AAE3C,qBAAa,oCAAqC,YAAW,8BAA8B;IAEvF,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBADN,IAAI,EAAE,YAAY,EAClB,MAAM,EAAE;QAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC;QAAC,KAAK,EAAE,cAAc,CAAA;KAAE;IAGxE,OAAO,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,cAAc,CAAC;IAYhE,IAAI,IAAI,gEAEP;CACF"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { CorrelationStorage } from "./correlation-storage.service";
|
|
2
|
+
import { SecurityCountermeasureName } from "./security-countermeasure-name.vo";
|
|
3
|
+
export class SecurityCountermeasureTarpitStrategy {
|
|
4
|
+
deps;
|
|
5
|
+
config;
|
|
6
|
+
constructor(deps, config) {
|
|
7
|
+
this.deps = deps;
|
|
8
|
+
this.config = config;
|
|
9
|
+
}
|
|
10
|
+
async execute(context) {
|
|
11
|
+
this.deps.Logger.info({
|
|
12
|
+
message: "Security countermeasure tarpit",
|
|
13
|
+
component: "security",
|
|
14
|
+
operation: "security_countermeasure_tarpit",
|
|
15
|
+
correlationId: CorrelationStorage.get(),
|
|
16
|
+
metadata: context,
|
|
17
|
+
});
|
|
18
|
+
return { kind: "delay", ...this.config };
|
|
19
|
+
}
|
|
20
|
+
get name() {
|
|
21
|
+
return SecurityCountermeasureName.parse("tarpit");
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=security-countermeasure-tarpit.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure-tarpit.strategy.js","sourceRoot":"","sources":["../src/security-countermeasure-tarpit.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAInE,OAAO,EAAE,0BAA0B,EAAE,MAAM,mCAAmC,CAAC;AAI/E,MAAM,OAAO,oCAAoC;IAE5B;IACA;IAFnB,YACmB,IAAkB,EAClB,MAA2D;QAD3D,SAAI,GAAJ,IAAI,CAAc;QAClB,WAAM,GAAN,MAAM,CAAqD;IAC3E,CAAC;IAEJ,KAAK,CAAC,OAAO,CAAC,OAAwB;QACpC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;YACpB,OAAO,EAAE,gCAAgC;YACzC,SAAS,EAAE,UAAU;YACrB,SAAS,EAAE,gCAAgC;YAC3C,aAAa,EAAE,kBAAkB,CAAC,GAAG,EAAE;YACvC,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC;QAEH,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;IAC3C,CAAC;IAED,IAAI,IAAI;QACN,OAAO,0BAA0B,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;CACF"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type * as tools from "@bgord/tools";
|
|
2
|
+
import type { SecurityContext } from "./security-context.vo";
|
|
3
|
+
import type { SecurityCountermeasureNameType } from "./security-countermeasure-name.vo";
|
|
4
|
+
export type SecurityAction = {
|
|
5
|
+
kind: "allow";
|
|
6
|
+
} | {
|
|
7
|
+
kind: "deny";
|
|
8
|
+
reason: string;
|
|
9
|
+
response: {
|
|
10
|
+
status: number;
|
|
11
|
+
};
|
|
12
|
+
} | {
|
|
13
|
+
kind: "delay";
|
|
14
|
+
duration: tools.Duration;
|
|
15
|
+
after: SecurityAction;
|
|
16
|
+
} | {
|
|
17
|
+
kind: "mirage";
|
|
18
|
+
response: {
|
|
19
|
+
status: number;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
export interface SecurityCountermeasureStrategy {
|
|
23
|
+
execute(context: SecurityContext): Promise<SecurityAction>;
|
|
24
|
+
get name(): SecurityCountermeasureNameType;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=security-countermeasure.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure.strategy.d.ts","sourceRoot":"","sources":["../src/security-countermeasure.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,cAAc,CAAC;AAC3C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,mCAAmC,CAAC;AAExF,MAAM,MAAM,cAAc,GACtB;IAAE,IAAI,EAAE,OAAO,CAAA;CAAE,GACjB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,GAC9D;IAAE,IAAI,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC;IAAC,KAAK,EAAE,cAAc,CAAA;CAAE,GAClE;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,QAAQ,EAAE;QAAE,MAAM,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,CAAC;AAErD,MAAM,WAAW,8BAA8B;IAC7C,OAAO,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;IAE3D,IAAI,IAAI,IAAI,8BAA8B,CAAC;CAC5C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-countermeasure.strategy.js","sourceRoot":"","sources":["../src/security-countermeasure.strategy.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SecurityCountermeasureStrategy } from "./security-countermeasure.strategy";
|
|
2
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
3
|
+
export declare class SecurityPolicy {
|
|
4
|
+
readonly rule: SecurityRuleStrategy;
|
|
5
|
+
readonly countermeasure: SecurityCountermeasureStrategy;
|
|
6
|
+
constructor(rule: SecurityRuleStrategy, countermeasure: SecurityCountermeasureStrategy);
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=security-policy.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-policy.vo.d.ts","sourceRoot":"","sources":["../src/security-policy.vo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAC;AACzF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAErE,qBAAa,cAAc;IAEvB,QAAQ,CAAC,IAAI,EAAE,oBAAoB;IACnC,QAAQ,CAAC,cAAc,EAAE,8BAA8B;gBAD9C,IAAI,EAAE,oBAAoB,EAC1B,cAAc,EAAE,8BAA8B;CAE1D"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-policy.vo.js","sourceRoot":"","sources":["../src/security-policy.vo.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,cAAc;IAEd;IACA;IAFX,YACW,IAA0B,EAC1B,cAA8C;QAD9C,SAAI,GAAJ,IAAI,CAAsB;QAC1B,mBAAc,GAAd,cAAc,CAAgC;IACtD,CAAC;CACL"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
3
|
+
export declare const SecurityRuleAndStrategyError: {
|
|
4
|
+
MissingRules: string;
|
|
5
|
+
MaxRules: string;
|
|
6
|
+
};
|
|
7
|
+
export declare class SecurityRuleAndStrategy implements SecurityRuleStrategy {
|
|
8
|
+
private readonly rules;
|
|
9
|
+
constructor(rules: SecurityRuleStrategy[]);
|
|
10
|
+
isViolated(c: Context): Promise<boolean>;
|
|
11
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=security-rule-and.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-and.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-and.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,eAAO,MAAM,4BAA4B;;;CAGxC,CAAC;AAEF,qBAAa,uBAAwB,YAAW,oBAAoB;IACtD,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,oBAAoB,EAAE;IAKpD,UAAU,CAAC,CAAC,EAAE,OAAO;IAI3B,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
2
|
+
export const SecurityRuleAndStrategyError = {
|
|
3
|
+
MissingRules: "security.rule.and.adapter.error.missing.rules",
|
|
4
|
+
MaxRules: "security.rule.and.adapter.error.max.rules",
|
|
5
|
+
};
|
|
6
|
+
export class SecurityRuleAndStrategy {
|
|
7
|
+
rules;
|
|
8
|
+
constructor(rules) {
|
|
9
|
+
this.rules = rules;
|
|
10
|
+
if (rules.length === 0)
|
|
11
|
+
throw new Error(SecurityRuleAndStrategyError.MissingRules);
|
|
12
|
+
if (rules.length > 5)
|
|
13
|
+
throw new Error(SecurityRuleAndStrategyError.MaxRules);
|
|
14
|
+
}
|
|
15
|
+
async isViolated(c) {
|
|
16
|
+
return this.rules.every((rule) => rule.isViolated(c));
|
|
17
|
+
}
|
|
18
|
+
get name() {
|
|
19
|
+
return SecurityRuleName.parse(`and_${this.rules.map((rule) => rule.name).join("_")}`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=security-rule-and.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-and.strategy.js","sourceRoot":"","sources":["../src/security-rule-and.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,CAAC,MAAM,4BAA4B,GAAG;IAC1C,YAAY,EAAE,+CAA+C;IAC7D,QAAQ,EAAE,2CAA2C;CACtD,CAAC;AAEF,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,KAA6B;QAA7B,UAAK,GAAL,KAAK,CAAwB;QACxD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,YAAY,CAAC,CAAC;QACnF,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,QAAQ,CAAC,CAAC;IAC/E,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,CAAU;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACxF,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
3
|
+
export declare class SecurityRuleBaitRoutesStrategy implements SecurityRuleStrategy {
|
|
4
|
+
private readonly routes;
|
|
5
|
+
constructor(routes: string[]);
|
|
6
|
+
isViolated(c: Context): Promise<boolean>;
|
|
7
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=security-rule-bait-routes.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-bait-routes.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-bait-routes.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,qBAAa,8BAA+B,YAAW,oBAAoB;IAC7D,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM,EAAE;IAEvC,UAAU,CAAC,CAAC,EAAE,OAAO;IAI3B,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
2
|
+
export class SecurityRuleBaitRoutesStrategy {
|
|
3
|
+
routes;
|
|
4
|
+
constructor(routes) {
|
|
5
|
+
this.routes = routes;
|
|
6
|
+
}
|
|
7
|
+
async isViolated(c) {
|
|
8
|
+
return this.routes.includes(c.req.path);
|
|
9
|
+
}
|
|
10
|
+
get name() {
|
|
11
|
+
return SecurityRuleName.parse("bait_routes");
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=security-rule-bait-routes.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-bait-routes.strategy.js","sourceRoot":"","sources":["../src/security-rule-bait-routes.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,OAAO,8BAA8B;IACZ;IAA7B,YAA6B,MAAgB;QAAhB,WAAM,GAAN,MAAM,CAAU;IAAG,CAAC;IAEjD,KAAK,CAAC,UAAU,CAAC,CAAU;QACzB,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAC/C,CAAC;CACF"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
2
|
+
export declare class SecurityRuleFailStrategy implements SecurityRuleStrategy {
|
|
3
|
+
isViolated(): Promise<boolean>;
|
|
4
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=security-rule-fail.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-fail.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-fail.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,qBAAa,wBAAyB,YAAW,oBAAoB;IAC7D,UAAU;IAIhB,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
2
|
+
export class SecurityRuleFailStrategy {
|
|
3
|
+
async isViolated() {
|
|
4
|
+
return true;
|
|
5
|
+
}
|
|
6
|
+
get name() {
|
|
7
|
+
return SecurityRuleName.parse("fail");
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=security-rule-fail.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-fail.strategy.js","sourceRoot":"","sources":["../src/security-rule-fail.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,OAAO,wBAAwB;IACnC,KAAK,CAAC,UAAU;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
3
|
+
export declare class SecurityRuleHoneyPotFieldStrategy implements SecurityRuleStrategy {
|
|
4
|
+
private readonly field;
|
|
5
|
+
constructor(field: string);
|
|
6
|
+
isViolated(c: Context): Promise<boolean>;
|
|
7
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=security-rule-honey-pot-field.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-honey-pot-field.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-honey-pot-field.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,qBAAa,iCAAkC,YAAW,oBAAoB;IAChE,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,MAAM;IAEpC,UAAU,CAAC,CAAC,EAAE,OAAO;IAS3B,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
2
|
+
export class SecurityRuleHoneyPotFieldStrategy {
|
|
3
|
+
field;
|
|
4
|
+
constructor(field) {
|
|
5
|
+
this.field = field;
|
|
6
|
+
}
|
|
7
|
+
async isViolated(c) {
|
|
8
|
+
const request = c.req.raw.clone();
|
|
9
|
+
const body = await request.json().catch(() => ({}));
|
|
10
|
+
const value = body[this.field];
|
|
11
|
+
return value !== undefined && value !== null && value !== "";
|
|
12
|
+
}
|
|
13
|
+
get name() {
|
|
14
|
+
return SecurityRuleName.parse("honey_pot_field");
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=security-rule-honey-pot-field.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-honey-pot-field.strategy.js","sourceRoot":"","sources":["../src/security-rule-honey-pot-field.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,OAAO,iCAAiC;IACf;IAA7B,YAA6B,KAAa;QAAb,UAAK,GAAL,KAAK,CAAQ;IAAG,CAAC;IAE9C,KAAK,CAAC,UAAU,CAAC,CAAU;QACzB,MAAM,OAAO,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC;QAElC,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACpD,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/B,OAAO,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;IAC/D,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;IACnD,CAAC;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { z } from "zod/v4";
|
|
2
|
+
export declare const SecurityRuleNameError: {
|
|
3
|
+
Type: string;
|
|
4
|
+
Empty: string;
|
|
5
|
+
TooLong: string;
|
|
6
|
+
BadChars: string;
|
|
7
|
+
};
|
|
8
|
+
export declare const SecurityRuleName: z.core.$ZodBranded<z.ZodString, "SecurityRuleName">;
|
|
9
|
+
export type SecurityRuleNameType = z.infer<typeof SecurityRuleName>;
|
|
10
|
+
//# sourceMappingURL=security-rule-name.vo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-name.vo.d.ts","sourceRoot":"","sources":["../src/security-rule-name.vo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B,eAAO,MAAM,qBAAqB;;;;;CAKjC,CAAC;AAKF,eAAO,MAAM,gBAAgB,qDAKD,CAAC;AAE7B,MAAM,MAAM,oBAAoB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { z } from "zod/v4";
|
|
2
|
+
export const SecurityRuleNameError = {
|
|
3
|
+
Type: "security.rule.name.type",
|
|
4
|
+
Empty: "security.rule.name.empty",
|
|
5
|
+
TooLong: "security.rule.name.too.long",
|
|
6
|
+
BadChars: "security.rule.name.bad.chars",
|
|
7
|
+
};
|
|
8
|
+
// One to sixty four letters, digits, or underscores
|
|
9
|
+
const CHARS_WHITELIST = /^[a-zA-Z0-9_]{1,512}$/;
|
|
10
|
+
export const SecurityRuleName = z
|
|
11
|
+
.string(SecurityRuleNameError.Type)
|
|
12
|
+
.min(1, SecurityRuleNameError.Empty)
|
|
13
|
+
.max(512, SecurityRuleNameError.TooLong)
|
|
14
|
+
.regex(CHARS_WHITELIST, SecurityRuleNameError.BadChars)
|
|
15
|
+
.brand("SecurityRuleName");
|
|
16
|
+
//# sourceMappingURL=security-rule-name.vo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-name.vo.js","sourceRoot":"","sources":["../src/security-rule-name.vo.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,QAAQ,CAAC;AAE3B,MAAM,CAAC,MAAM,qBAAqB,GAAG;IACnC,IAAI,EAAE,yBAAyB;IAC/B,KAAK,EAAE,0BAA0B;IACjC,OAAO,EAAE,6BAA6B;IACtC,QAAQ,EAAE,8BAA8B;CACzC,CAAC;AAEF,oDAAoD;AACpD,MAAM,eAAe,GAAG,uBAAuB,CAAC;AAEhD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC;KAC9B,MAAM,CAAC,qBAAqB,CAAC,IAAI,CAAC;KAClC,GAAG,CAAC,CAAC,EAAE,qBAAqB,CAAC,KAAK,CAAC;KACnC,GAAG,CAAC,GAAG,EAAE,qBAAqB,CAAC,OAAO,CAAC;KACvC,KAAK,CAAC,eAAe,EAAE,qBAAqB,CAAC,QAAQ,CAAC;KACtD,KAAK,CAAC,kBAAkB,CAAC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
3
|
+
export declare const SecurityRuleOrStrategyError: {
|
|
4
|
+
MissingRules: string;
|
|
5
|
+
MaxRules: string;
|
|
6
|
+
};
|
|
7
|
+
export declare class SecurityRuleOrStrategy implements SecurityRuleStrategy {
|
|
8
|
+
private readonly rules;
|
|
9
|
+
constructor(rules: SecurityRuleStrategy[]);
|
|
10
|
+
isViolated(c: Context): Promise<boolean>;
|
|
11
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=security-rule-or.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-or.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-or.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,eAAO,MAAM,2BAA2B;;;CAGvC,CAAC;AAEF,qBAAa,sBAAuB,YAAW,oBAAoB;IACrD,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,oBAAoB,EAAE;IAKpD,UAAU,CAAC,CAAC,EAAE,OAAO;IAI3B,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
2
|
+
export const SecurityRuleOrStrategyError = {
|
|
3
|
+
MissingRules: "security.rule.or.adapter.error.missing.rules",
|
|
4
|
+
MaxRules: "security.rule.or.adapter.error.max.rules",
|
|
5
|
+
};
|
|
6
|
+
export class SecurityRuleOrStrategy {
|
|
7
|
+
rules;
|
|
8
|
+
constructor(rules) {
|
|
9
|
+
this.rules = rules;
|
|
10
|
+
if (rules.length === 0)
|
|
11
|
+
throw new Error(SecurityRuleOrStrategyError.MissingRules);
|
|
12
|
+
if (rules.length > 5)
|
|
13
|
+
throw new Error(SecurityRuleOrStrategyError.MaxRules);
|
|
14
|
+
}
|
|
15
|
+
async isViolated(c) {
|
|
16
|
+
return this.rules.some((rule) => rule.isViolated(c));
|
|
17
|
+
}
|
|
18
|
+
get name() {
|
|
19
|
+
return SecurityRuleName.parse(`or_${this.rules.map((rule) => rule.name).join("_")}`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=security-rule-or.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-or.strategy.js","sourceRoot":"","sources":["../src/security-rule-or.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,CAAC,MAAM,2BAA2B,GAAG;IACzC,YAAY,EAAE,8CAA8C;IAC5D,QAAQ,EAAE,0CAA0C;CACrD,CAAC;AAEF,MAAM,OAAO,sBAAsB;IACJ;IAA7B,YAA6B,KAA6B;QAA7B,UAAK,GAAL,KAAK,CAAwB;QACxD,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,YAAY,CAAC,CAAC;QAClF,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,QAAQ,CAAC,CAAC;IAC9E,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,CAAU;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACvF,CAAC;CACF"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
2
|
+
export declare class SecurityRulePassStrategy implements SecurityRuleStrategy {
|
|
3
|
+
isViolated(): Promise<boolean>;
|
|
4
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=security-rule-pass.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-pass.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-pass.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,qBAAa,wBAAyB,YAAW,oBAAoB;IAC7D,UAAU;IAIhB,IAAI,IAAI,sDAEP;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { SecurityRuleName } from "./security-rule-name.vo";
|
|
2
|
+
export class SecurityRulePassStrategy {
|
|
3
|
+
async isViolated() {
|
|
4
|
+
return false;
|
|
5
|
+
}
|
|
6
|
+
get name() {
|
|
7
|
+
return SecurityRuleName.parse("pass");
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=security-rule-pass.strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-pass.strategy.js","sourceRoot":"","sources":["../src/security-rule-pass.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,MAAM,OAAO,wBAAwB;IACnC,KAAK,CAAC,UAAU;QACd,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,IAAI;QACN,OAAO,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Context } from "hono";
|
|
2
|
+
import type { SecurityRuleStrategy } from "./security-rule.strategy";
|
|
3
|
+
export declare class SecurityRuleUserAgentStrategy implements SecurityRuleStrategy {
|
|
4
|
+
private readonly blacklist;
|
|
5
|
+
constructor(blacklist?: string[]);
|
|
6
|
+
isViolated(c: Context): Promise<boolean>;
|
|
7
|
+
get name(): string & import("zod").$brand<"SecurityRuleName">;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=security-rule-user-agent.strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security-rule-user-agent.strategy.d.ts","sourceRoot":"","sources":["../src/security-rule-user-agent.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAIpC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGrE,qBAAa,6BAA8B,YAAW,oBAAoB;IAC5D,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,GAAE,MAAM,EAAa;IAErD,UAAU,CAAC,CAAC,EAAE,OAAO;IAM3B,IAAI,IAAI,sDAEP;CACF"}
|