@toon-protocol/connector 1.7.1
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/LICENSE +21 -0
- package/README.md +421 -0
- package/dist/btp/btp-claim-types.d.ts +30 -0
- package/dist/btp/btp-claim-types.d.ts.map +1 -0
- package/dist/btp/btp-claim-types.js +103 -0
- package/dist/btp/btp-claim-types.js.map +1 -0
- package/dist/btp/btp-client-manager.d.ts +27 -0
- package/dist/btp/btp-client-manager.d.ts.map +1 -0
- package/dist/btp/btp-client-manager.js +138 -0
- package/dist/btp/btp-client-manager.js.map +1 -0
- package/dist/btp/btp-client.d.ts +55 -0
- package/dist/btp/btp-client.d.ts.map +1 -0
- package/dist/btp/btp-client.js +474 -0
- package/dist/btp/btp-client.js.map +1 -0
- package/dist/btp/btp-message-parser.d.ts +4 -0
- package/dist/btp/btp-message-parser.d.ts.map +1 -0
- package/dist/btp/btp-message-parser.js +211 -0
- package/dist/btp/btp-message-parser.js.map +1 -0
- package/dist/btp/btp-server.d.ts +30 -0
- package/dist/btp/btp-server.d.ts.map +1 -0
- package/dist/btp/btp-server.js +458 -0
- package/dist/btp/btp-server.js.map +1 -0
- package/dist/btp/btp-types.d.ts +43 -0
- package/dist/btp/btp-types.d.ts.map +1 -0
- package/dist/btp/btp-types.js +44 -0
- package/dist/btp/btp-types.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +175 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/onboarding-wizard.d.ts +7 -0
- package/dist/cli/onboarding-wizard.d.ts.map +1 -0
- package/dist/cli/onboarding-wizard.js +257 -0
- package/dist/cli/onboarding-wizard.js.map +1 -0
- package/dist/cli/types.d.ts +38 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +3 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/config/aptos-env-validator.d.ts +8 -0
- package/dist/config/aptos-env-validator.d.ts.map +1 -0
- package/dist/config/aptos-env-validator.js +25 -0
- package/dist/config/aptos-env-validator.js.map +1 -0
- package/dist/config/config-loader.d.ts +20 -0
- package/dist/config/config-loader.d.ts.map +1 -0
- package/dist/config/config-loader.js +269 -0
- package/dist/config/config-loader.js.map +1 -0
- package/dist/config/environment-validator.d.ts +4 -0
- package/dist/config/environment-validator.d.ts.map +1 -0
- package/dist/config/environment-validator.js +239 -0
- package/dist/config/environment-validator.js.map +1 -0
- package/dist/config/index.d.ts +2 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +7 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/key-manager-config.d.ts +7 -0
- package/dist/config/key-manager-config.d.ts.map +1 -0
- package/dist/config/key-manager-config.js +209 -0
- package/dist/config/key-manager-config.js.map +1 -0
- package/dist/config/topology-validator.d.ts +14 -0
- package/dist/config/topology-validator.d.ts.map +1 -0
- package/dist/config/topology-validator.js +142 -0
- package/dist/config/topology-validator.js.map +1 -0
- package/dist/config/types.d.ts +210 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +10 -0
- package/dist/config/types.js.map +1 -0
- package/dist/core/connector-node.d.ts +79 -0
- package/dist/core/connector-node.d.ts.map +1 -0
- package/dist/core/connector-node.js +1036 -0
- package/dist/core/connector-node.js.map +1 -0
- package/dist/core/local-delivery-client.d.ts +16 -0
- package/dist/core/local-delivery-client.d.ts.map +1 -0
- package/dist/core/local-delivery-client.js +176 -0
- package/dist/core/local-delivery-client.js.map +1 -0
- package/dist/core/packet-handler.d.ts +45 -0
- package/dist/core/packet-handler.d.ts.map +1 -0
- package/dist/core/packet-handler.js +606 -0
- package/dist/core/packet-handler.js.map +1 -0
- package/dist/core/payment-handler.d.ts +27 -0
- package/dist/core/payment-handler.d.ts.map +1 -0
- package/dist/core/payment-handler.js +115 -0
- package/dist/core/payment-handler.js.map +1 -0
- package/dist/discovery/index.d.ts +3 -0
- package/dist/discovery/index.d.ts.map +1 -0
- package/dist/discovery/index.js +6 -0
- package/dist/discovery/index.js.map +1 -0
- package/dist/discovery/peer-discovery-service.d.ts +29 -0
- package/dist/discovery/peer-discovery-service.d.ts.map +1 -0
- package/dist/discovery/peer-discovery-service.js +230 -0
- package/dist/discovery/peer-discovery-service.js.map +1 -0
- package/dist/discovery/types.d.ts +38 -0
- package/dist/discovery/types.d.ts.map +1 -0
- package/dist/discovery/types.js +3 -0
- package/dist/discovery/types.js.map +1 -0
- package/dist/encoding/oer-parser.d.ts +39 -0
- package/dist/encoding/oer-parser.d.ts.map +1 -0
- package/dist/encoding/oer-parser.js +154 -0
- package/dist/encoding/oer-parser.js.map +1 -0
- package/dist/explorer-ui/assets/EventDetailPanel-CnSaMk3V.js +6 -0
- package/dist/explorer-ui/assets/FilterBar-BEmAzBku.js +26 -0
- package/dist/explorer-ui/assets/chevron-right-BUT9VhYe.js +11 -0
- package/dist/explorer-ui/assets/index-BZ2INVgy.js +360 -0
- package/dist/explorer-ui/assets/index-Cemh6svI.css +1 -0
- package/dist/explorer-ui/index.html +14 -0
- package/dist/explorer-ui/vite.svg +1 -0
- package/dist/facilitator/index.d.ts +2 -0
- package/dist/facilitator/index.d.ts.map +1 -0
- package/dist/facilitator/index.js +7 -0
- package/dist/facilitator/index.js.map +1 -0
- package/dist/facilitator/spsp-client.d.ts +18 -0
- package/dist/facilitator/spsp-client.d.ts.map +1 -0
- package/dist/facilitator/spsp-client.js +95 -0
- package/dist/facilitator/spsp-client.js.map +1 -0
- package/dist/http/admin-api.d.ts +123 -0
- package/dist/http/admin-api.d.ts.map +1 -0
- package/dist/http/admin-api.js +1057 -0
- package/dist/http/admin-api.js.map +1 -0
- package/dist/http/admin-server.d.ts +41 -0
- package/dist/http/admin-server.d.ts.map +1 -0
- package/dist/http/admin-server.js +156 -0
- package/dist/http/admin-server.js.map +1 -0
- package/dist/http/health-server.d.ts +22 -0
- package/dist/http/health-server.d.ts.map +1 -0
- package/dist/http/health-server.js +192 -0
- package/dist/http/health-server.js.map +1 -0
- package/dist/http/ilp-send-handler.d.ts +19 -0
- package/dist/http/ilp-send-handler.d.ts.map +1 -0
- package/dist/http/ilp-send-handler.js +162 -0
- package/dist/http/ilp-send-handler.js.map +1 -0
- package/dist/http/types.d.ts +39 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +3 -0
- package/dist/http/types.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/lib.d.ts +22 -0
- package/dist/lib.d.ts.map +1 -0
- package/dist/lib.js +41 -0
- package/dist/lib.js.map +1 -0
- package/dist/main.d.ts +4 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +79 -0
- package/dist/main.js.map +1 -0
- package/dist/routing/packet-processor.d.ts +36 -0
- package/dist/routing/packet-processor.d.ts.map +1 -0
- package/dist/routing/packet-processor.js +112 -0
- package/dist/routing/packet-processor.js.map +1 -0
- package/dist/routing/packet-worker.d.ts +10 -0
- package/dist/routing/packet-worker.d.ts.map +1 -0
- package/dist/routing/packet-worker.js +34 -0
- package/dist/routing/packet-worker.js.map +1 -0
- package/dist/routing/routing-table.d.ts +15 -0
- package/dist/routing/routing-table.d.ts.map +1 -0
- package/dist/routing/routing-table.js +63 -0
- package/dist/routing/routing-table.js.map +1 -0
- package/dist/routing/worker-pool.d.ts +43 -0
- package/dist/routing/worker-pool.d.ts.map +1 -0
- package/dist/routing/worker-pool.js +228 -0
- package/dist/routing/worker-pool.js.map +1 -0
- package/dist/security/alert-notifier.d.ts +34 -0
- package/dist/security/alert-notifier.d.ts.map +1 -0
- package/dist/security/alert-notifier.js +136 -0
- package/dist/security/alert-notifier.js.map +1 -0
- package/dist/security/audit-logger.d.ts +34 -0
- package/dist/security/audit-logger.d.ts.map +1 -0
- package/dist/security/audit-logger.js +132 -0
- package/dist/security/audit-logger.js.map +1 -0
- package/dist/security/backends/aws-kms-backend.d.ts +18 -0
- package/dist/security/backends/aws-kms-backend.d.ts.map +1 -0
- package/dist/security/backends/aws-kms-backend.js +130 -0
- package/dist/security/backends/aws-kms-backend.js.map +1 -0
- package/dist/security/backends/azure-kv-backend.d.ts +17 -0
- package/dist/security/backends/azure-kv-backend.d.ts.map +1 -0
- package/dist/security/backends/azure-kv-backend.js +121 -0
- package/dist/security/backends/azure-kv-backend.js.map +1 -0
- package/dist/security/backends/environment-backend.d.ts +15 -0
- package/dist/security/backends/environment-backend.d.ts.map +1 -0
- package/dist/security/backends/environment-backend.js +56 -0
- package/dist/security/backends/environment-backend.js.map +1 -0
- package/dist/security/backends/gcp-kms-backend.d.ts +17 -0
- package/dist/security/backends/gcp-kms-backend.d.ts.map +1 -0
- package/dist/security/backends/gcp-kms-backend.js +110 -0
- package/dist/security/backends/gcp-kms-backend.js.map +1 -0
- package/dist/security/backends/hsm-backend.d.ts +18 -0
- package/dist/security/backends/hsm-backend.d.ts.map +1 -0
- package/dist/security/backends/hsm-backend.js +187 -0
- package/dist/security/backends/hsm-backend.js.map +1 -0
- package/dist/security/fraud-detector.d.ts +79 -0
- package/dist/security/fraud-detector.d.ts.map +1 -0
- package/dist/security/fraud-detector.js +147 -0
- package/dist/security/fraud-detector.js.map +1 -0
- package/dist/security/key-manager-signer.d.ts +15 -0
- package/dist/security/key-manager-signer.d.ts.map +1 -0
- package/dist/security/key-manager-signer.js +91 -0
- package/dist/security/key-manager-signer.js.map +1 -0
- package/dist/security/key-manager.d.ts +69 -0
- package/dist/security/key-manager.d.ts.map +1 -0
- package/dist/security/key-manager.js +79 -0
- package/dist/security/key-manager.js.map +1 -0
- package/dist/security/key-rotation-manager.d.ts +27 -0
- package/dist/security/key-rotation-manager.d.ts.map +1 -0
- package/dist/security/key-rotation-manager.js +142 -0
- package/dist/security/key-rotation-manager.js.map +1 -0
- package/dist/security/rate-limit-config.d.ts +7 -0
- package/dist/security/rate-limit-config.d.ts.map +1 -0
- package/dist/security/rate-limit-config.js +57 -0
- package/dist/security/rate-limit-config.js.map +1 -0
- package/dist/security/rate-limiter.d.ts +46 -0
- package/dist/security/rate-limiter.d.ts.map +1 -0
- package/dist/security/rate-limiter.js +170 -0
- package/dist/security/rate-limiter.js.map +1 -0
- package/dist/security/reputation-tracker.d.ts +30 -0
- package/dist/security/reputation-tracker.d.ts.map +1 -0
- package/dist/security/reputation-tracker.js +111 -0
- package/dist/security/reputation-tracker.js.map +1 -0
- package/dist/security/rules/balance-manipulation-rule.d.ts +23 -0
- package/dist/security/rules/balance-manipulation-rule.d.ts.map +1 -0
- package/dist/security/rules/balance-manipulation-rule.js +70 -0
- package/dist/security/rules/balance-manipulation-rule.js.map +1 -0
- package/dist/security/rules/double-spend-detection-rule.d.ts +23 -0
- package/dist/security/rules/double-spend-detection-rule.d.ts.map +1 -0
- package/dist/security/rules/double-spend-detection-rule.js +61 -0
- package/dist/security/rules/double-spend-detection-rule.js.map +1 -0
- package/dist/security/rules/rapid-channel-closure-rule.d.ts +16 -0
- package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +1 -0
- package/dist/security/rules/rapid-channel-closure-rule.js +57 -0
- package/dist/security/rules/rapid-channel-closure-rule.js.map +1 -0
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts +18 -0
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +1 -0
- package/dist/security/rules/sudden-traffic-spike-rule.js +92 -0
- package/dist/security/rules/sudden-traffic-spike-rule.js.map +1 -0
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts +12 -0
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +1 -0
- package/dist/security/rules/unusual-settlement-amount-rule.js +33 -0
- package/dist/security/rules/unusual-settlement-amount-rule.js.map +1 -0
- package/dist/security/token-bucket.d.ts +16 -0
- package/dist/security/token-bucket.d.ts.map +1 -0
- package/dist/security/token-bucket.js +49 -0
- package/dist/security/token-bucket.js.map +1 -0
- package/dist/security/violation-counter.d.ts +11 -0
- package/dist/security/violation-counter.d.ts.map +1 -0
- package/dist/security/violation-counter.js +61 -0
- package/dist/security/violation-counter.js.map +1 -0
- package/dist/settlement/account-id-generator.d.ts +4 -0
- package/dist/settlement/account-id-generator.d.ts.map +1 -0
- package/dist/settlement/account-id-generator.js +38 -0
- package/dist/settlement/account-id-generator.js.map +1 -0
- package/dist/settlement/account-manager.d.ts +47 -0
- package/dist/settlement/account-manager.d.ts.map +1 -0
- package/dist/settlement/account-manager.js +447 -0
- package/dist/settlement/account-manager.js.map +1 -0
- package/dist/settlement/account-metadata.d.ts +11 -0
- package/dist/settlement/account-metadata.d.ts.map +1 -0
- package/dist/settlement/account-metadata.js +40 -0
- package/dist/settlement/account-metadata.js.map +1 -0
- package/dist/settlement/aptos-channel-sdk.d.ts +66 -0
- package/dist/settlement/aptos-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/aptos-channel-sdk.js +274 -0
- package/dist/settlement/aptos-channel-sdk.js.map +1 -0
- package/dist/settlement/aptos-claim-signer.d.ts +57 -0
- package/dist/settlement/aptos-claim-signer.d.ts.map +1 -0
- package/dist/settlement/aptos-claim-signer.js +200 -0
- package/dist/settlement/aptos-claim-signer.js.map +1 -0
- package/dist/settlement/aptos-client.d.ts +99 -0
- package/dist/settlement/aptos-client.d.ts.map +1 -0
- package/dist/settlement/aptos-client.js +474 -0
- package/dist/settlement/aptos-client.js.map +1 -0
- package/dist/settlement/channel-manager.d.ts +66 -0
- package/dist/settlement/channel-manager.d.ts.map +1 -0
- package/dist/settlement/channel-manager.js +214 -0
- package/dist/settlement/channel-manager.js.map +1 -0
- package/dist/settlement/claim-receiver-db-schema.d.ts +4 -0
- package/dist/settlement/claim-receiver-db-schema.d.ts.map +1 -0
- package/dist/settlement/claim-receiver-db-schema.js +25 -0
- package/dist/settlement/claim-receiver-db-schema.js.map +1 -0
- package/dist/settlement/claim-receiver.d.ts +31 -0
- package/dist/settlement/claim-receiver.d.ts.map +1 -0
- package/dist/settlement/claim-receiver.js +228 -0
- package/dist/settlement/claim-receiver.js.map +1 -0
- package/dist/settlement/claim-redemption-service.d.ts +39 -0
- package/dist/settlement/claim-redemption-service.d.ts.map +1 -0
- package/dist/settlement/claim-redemption-service.js +189 -0
- package/dist/settlement/claim-redemption-service.js.map +1 -0
- package/dist/settlement/claim-sender-db-schema.d.ts +3 -0
- package/dist/settlement/claim-sender-db-schema.d.ts.map +1 -0
- package/dist/settlement/claim-sender-db-schema.js +18 -0
- package/dist/settlement/claim-sender-db-schema.js.map +1 -0
- package/dist/settlement/claim-sender.d.ts +22 -0
- package/dist/settlement/claim-sender.d.ts.map +1 -0
- package/dist/settlement/claim-sender.js +108 -0
- package/dist/settlement/claim-sender.js.map +1 -0
- package/dist/settlement/eip712-helper.d.ts +13 -0
- package/dist/settlement/eip712-helper.d.ts.map +1 -0
- package/dist/settlement/eip712-helper.js +24 -0
- package/dist/settlement/eip712-helper.js.map +1 -0
- package/dist/settlement/in-memory-ledger-client.d.ts +40 -0
- package/dist/settlement/in-memory-ledger-client.d.ts.map +1 -0
- package/dist/settlement/in-memory-ledger-client.js +177 -0
- package/dist/settlement/in-memory-ledger-client.js.map +1 -0
- package/dist/settlement/ledger-client.d.ts +22 -0
- package/dist/settlement/ledger-client.d.ts.map +1 -0
- package/dist/settlement/ledger-client.js +3 -0
- package/dist/settlement/ledger-client.js.map +1 -0
- package/dist/settlement/metrics-collector.d.ts +29 -0
- package/dist/settlement/metrics-collector.d.ts.map +1 -0
- package/dist/settlement/metrics-collector.js +81 -0
- package/dist/settlement/metrics-collector.js.map +1 -0
- package/dist/settlement/payment-channel-sdk.d.ts +59 -0
- package/dist/settlement/payment-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/payment-channel-sdk.js +677 -0
- package/dist/settlement/payment-channel-sdk.js.map +1 -0
- package/dist/settlement/per-packet-claim-service.d.ts +33 -0
- package/dist/settlement/per-packet-claim-service.d.ts.map +1 -0
- package/dist/settlement/per-packet-claim-service.js +177 -0
- package/dist/settlement/per-packet-claim-service.js.map +1 -0
- package/dist/settlement/settlement-api.d.ts +37 -0
- package/dist/settlement/settlement-api.d.ts.map +1 -0
- package/dist/settlement/settlement-api.js +172 -0
- package/dist/settlement/settlement-api.js.map +1 -0
- package/dist/settlement/settlement-coordinator.d.ts +47 -0
- package/dist/settlement/settlement-coordinator.d.ts.map +1 -0
- package/dist/settlement/settlement-coordinator.js +166 -0
- package/dist/settlement/settlement-coordinator.js.map +1 -0
- package/dist/settlement/settlement-executor.d.ts +44 -0
- package/dist/settlement/settlement-executor.d.ts.map +1 -0
- package/dist/settlement/settlement-executor.js +247 -0
- package/dist/settlement/settlement-executor.js.map +1 -0
- package/dist/settlement/settlement-monitor.d.ts +29 -0
- package/dist/settlement/settlement-monitor.d.ts.map +1 -0
- package/dist/settlement/settlement-monitor.js +172 -0
- package/dist/settlement/settlement-monitor.js.map +1 -0
- package/dist/settlement/tigerbeetle-batch-writer.d.ts +58 -0
- package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +1 -0
- package/dist/settlement/tigerbeetle-batch-writer.js +162 -0
- package/dist/settlement/tigerbeetle-batch-writer.js.map +1 -0
- package/dist/settlement/tigerbeetle-client.d.ts +40 -0
- package/dist/settlement/tigerbeetle-client.d.ts.map +1 -0
- package/dist/settlement/tigerbeetle-client.js +279 -0
- package/dist/settlement/tigerbeetle-client.js.map +1 -0
- package/dist/settlement/tigerbeetle-errors.d.ts +23 -0
- package/dist/settlement/tigerbeetle-errors.d.ts.map +1 -0
- package/dist/settlement/tigerbeetle-errors.js +58 -0
- package/dist/settlement/tigerbeetle-errors.js.map +1 -0
- package/dist/settlement/types.d.ts +64 -0
- package/dist/settlement/types.d.ts.map +1 -0
- package/dist/settlement/types.js +42 -0
- package/dist/settlement/types.js.map +1 -0
- package/dist/settlement/unified-settlement-executor.d.ts +34 -0
- package/dist/settlement/unified-settlement-executor.d.ts.map +1 -0
- package/dist/settlement/unified-settlement-executor.js +145 -0
- package/dist/settlement/unified-settlement-executor.js.map +1 -0
- package/dist/settlement/xrp-channel-lifecycle.d.ts +41 -0
- package/dist/settlement/xrp-channel-lifecycle.d.ts.map +1 -0
- package/dist/settlement/xrp-channel-lifecycle.js +142 -0
- package/dist/settlement/xrp-channel-lifecycle.js.map +1 -0
- package/dist/settlement/xrp-channel-manager.d.ts +59 -0
- package/dist/settlement/xrp-channel-manager.d.ts.map +1 -0
- package/dist/settlement/xrp-channel-manager.js +160 -0
- package/dist/settlement/xrp-channel-manager.js.map +1 -0
- package/dist/settlement/xrp-channel-sdk.d.ts +30 -0
- package/dist/settlement/xrp-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/xrp-channel-sdk.js +164 -0
- package/dist/settlement/xrp-channel-sdk.js.map +1 -0
- package/dist/settlement/xrp-claim-signer.d.ts +22 -0
- package/dist/settlement/xrp-claim-signer.d.ts.map +1 -0
- package/dist/settlement/xrp-claim-signer.js +122 -0
- package/dist/settlement/xrp-claim-signer.js.map +1 -0
- package/dist/settlement/xrpl-client.d.ts +104 -0
- package/dist/settlement/xrpl-client.d.ts.map +1 -0
- package/dist/settlement/xrpl-client.js +304 -0
- package/dist/settlement/xrpl-client.js.map +1 -0
- package/dist/test/testnet-config.d.ts +58 -0
- package/dist/test/testnet-config.d.ts.map +1 -0
- package/dist/test/testnet-config.js +89 -0
- package/dist/test/testnet-config.js.map +1 -0
- package/dist/test-utils/index.d.ts +3 -0
- package/dist/test-utils/index.d.ts.map +1 -0
- package/dist/test-utils/index.js +15 -0
- package/dist/test-utils/index.js.map +1 -0
- package/dist/test-utils/isolated-test-env.d.ts +31 -0
- package/dist/test-utils/isolated-test-env.d.ts.map +1 -0
- package/dist/test-utils/isolated-test-env.js +127 -0
- package/dist/test-utils/isolated-test-env.js.map +1 -0
- package/dist/test-utils/mock-factories-patch.d.ts +2 -0
- package/dist/test-utils/mock-factories-patch.d.ts.map +1 -0
- package/dist/test-utils/mock-factories-patch.js +3 -0
- package/dist/test-utils/mock-factories-patch.js.map +1 -0
- package/dist/test-utils/mock-factories.d.ts +22 -0
- package/dist/test-utils/mock-factories.d.ts.map +1 -0
- package/dist/test-utils/mock-factories.js +56 -0
- package/dist/test-utils/mock-factories.js.map +1 -0
- package/dist/utils/connection-pool.d.ts +42 -0
- package/dist/utils/connection-pool.d.ts.map +1 -0
- package/dist/utils/connection-pool.js +209 -0
- package/dist/utils/connection-pool.js.map +1 -0
- package/dist/utils/evm-rpc-connection-pool.d.ts +8 -0
- package/dist/utils/evm-rpc-connection-pool.d.ts.map +1 -0
- package/dist/utils/evm-rpc-connection-pool.js +40 -0
- package/dist/utils/evm-rpc-connection-pool.js.map +1 -0
- package/dist/utils/logger.d.ts +6 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +58 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/optional-require.d.ts +2 -0
- package/dist/utils/optional-require.d.ts.map +1 -0
- package/dist/utils/optional-require.js +54 -0
- package/dist/utils/optional-require.js.map +1 -0
- package/dist/utils/xrp-wss-connection-pool.d.ts +8 -0
- package/dist/utils/xrp-wss-connection-pool.d.ts.map +1 -0
- package/dist/utils/xrp-wss-connection-pool.js +42 -0
- package/dist/utils/xrp-wss-connection-pool.js.map +1 -0
- package/dist/wallet/audit-logger.d.ts +22 -0
- package/dist/wallet/audit-logger.d.ts.map +1 -0
- package/dist/wallet/audit-logger.js +120 -0
- package/dist/wallet/audit-logger.js.map +1 -0
- package/dist/wallet/fraud-detector-interface.d.ts +14 -0
- package/dist/wallet/fraud-detector-interface.d.ts.map +1 -0
- package/dist/wallet/fraud-detector-interface.js +3 -0
- package/dist/wallet/fraud-detector-interface.js.map +1 -0
- package/dist/wallet/key-manager.d.ts +6 -0
- package/dist/wallet/key-manager.d.ts.map +1 -0
- package/dist/wallet/key-manager.js +3 -0
- package/dist/wallet/key-manager.js.map +1 -0
- package/dist/wallet/placeholder-fraud-detector.d.ts +10 -0
- package/dist/wallet/placeholder-fraud-detector.d.ts.map +1 -0
- package/dist/wallet/placeholder-fraud-detector.js +10 -0
- package/dist/wallet/placeholder-fraud-detector.js.map +1 -0
- package/dist/wallet/rate-limiter.d.ts +26 -0
- package/dist/wallet/rate-limiter.d.ts.map +1 -0
- package/dist/wallet/rate-limiter.js +114 -0
- package/dist/wallet/rate-limiter.js.map +1 -0
- package/dist/wallet/suspicious-activity-detector.d.ts +25 -0
- package/dist/wallet/suspicious-activity-detector.d.ts.map +1 -0
- package/dist/wallet/suspicious-activity-detector.js +97 -0
- package/dist/wallet/suspicious-activity-detector.js.map +1 -0
- package/dist/wallet/treasury-wallet.d.ts +20 -0
- package/dist/wallet/treasury-wallet.d.ts.map +1 -0
- package/dist/wallet/treasury-wallet.js +151 -0
- package/dist/wallet/treasury-wallet.js.map +1 -0
- package/dist/wallet/wallet-authentication.d.ts +31 -0
- package/dist/wallet/wallet-authentication.d.ts.map +1 -0
- package/dist/wallet/wallet-authentication.js +102 -0
- package/dist/wallet/wallet-authentication.js.map +1 -0
- package/dist/wallet/wallet-db-schema.d.ts +11 -0
- package/dist/wallet/wallet-db-schema.d.ts.map +1 -0
- package/dist/wallet/wallet-db-schema.js +79 -0
- package/dist/wallet/wallet-db-schema.js.map +1 -0
- package/dist/wallet/wallet-security.d.ts +58 -0
- package/dist/wallet/wallet-security.d.ts.map +1 -0
- package/dist/wallet/wallet-security.js +148 -0
- package/dist/wallet/wallet-security.js.map +1 -0
- package/dist/wallet/wallet-seed-manager.d.ts +65 -0
- package/dist/wallet/wallet-seed-manager.d.ts.map +1 -0
- package/dist/wallet/wallet-seed-manager.js +418 -0
- package/dist/wallet/wallet-seed-manager.js.map +1 -0
- package/package.json +134 -0
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RateLimiter = void 0;
|
|
4
|
+
const token_bucket_1 = require("./token-bucket");
|
|
5
|
+
const violation_counter_1 = require("./violation-counter");
|
|
6
|
+
class RateLimiter {
|
|
7
|
+
config;
|
|
8
|
+
logger;
|
|
9
|
+
tokenBuckets = new Map();
|
|
10
|
+
blockedPeers = new Map();
|
|
11
|
+
violationCounter;
|
|
12
|
+
metrics;
|
|
13
|
+
adaptiveLimits = new Map();
|
|
14
|
+
constructor(config, logger, metrics) {
|
|
15
|
+
this.config = config;
|
|
16
|
+
this.logger = logger;
|
|
17
|
+
this.validateConfig(config);
|
|
18
|
+
this.violationCounter = new violation_counter_1.ViolationCounter(config.violationWindowSeconds);
|
|
19
|
+
this.metrics = metrics;
|
|
20
|
+
}
|
|
21
|
+
async checkLimit(peerId, requestType) {
|
|
22
|
+
if (this.blockedPeers.has(peerId)) {
|
|
23
|
+
this.logger.debug({ peerId, requestType }, 'Request blocked by circuit breaker');
|
|
24
|
+
this.metrics?.recordBlocked(peerId, requestType);
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
const bucket = this.getOrCreateBucket(peerId);
|
|
28
|
+
if (bucket.tryConsume()) {
|
|
29
|
+
this.metrics?.recordAllowed(peerId, requestType);
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
this.logger.warn({ peerId, requestType }, 'Request rate limited');
|
|
33
|
+
this.metrics?.recordThrottled(peerId, requestType);
|
|
34
|
+
this.handleViolation(peerId, requestType);
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
getOrCreateBucket(peerId) {
|
|
38
|
+
let bucket = this.tokenBuckets.get(peerId);
|
|
39
|
+
if (!bucket) {
|
|
40
|
+
const { capacity, refillRate } = this.getBucketConfig(peerId);
|
|
41
|
+
bucket = new token_bucket_1.TokenBucket(capacity, refillRate);
|
|
42
|
+
this.tokenBuckets.set(peerId, bucket);
|
|
43
|
+
}
|
|
44
|
+
return bucket;
|
|
45
|
+
}
|
|
46
|
+
getBucketConfig(peerId) {
|
|
47
|
+
const peerConfig = this.config.peerLimits?.get(peerId);
|
|
48
|
+
if (peerConfig) {
|
|
49
|
+
return {
|
|
50
|
+
capacity: peerConfig.burstSize,
|
|
51
|
+
refillRate: peerConfig.maxRequestsPerSecond,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
let refillRate = this.config.maxRequestsPerSecond;
|
|
55
|
+
if (this.config.adaptiveRateLimiting) {
|
|
56
|
+
const multiplier = this.adaptiveLimits.get(peerId) ?? 1.0;
|
|
57
|
+
refillRate = refillRate * multiplier;
|
|
58
|
+
}
|
|
59
|
+
return {
|
|
60
|
+
capacity: this.config.burstSize,
|
|
61
|
+
refillRate,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
handleViolation(peerId, requestType) {
|
|
65
|
+
const violations = this.violationCounter.increment(peerId);
|
|
66
|
+
if (this.config.adaptiveRateLimiting && !this.config.trustedPeers?.has(peerId)) {
|
|
67
|
+
this.decreaseAdaptiveLimit(peerId);
|
|
68
|
+
}
|
|
69
|
+
if (violations >= this.config.violationThreshold) {
|
|
70
|
+
if (this.config.trustedPeers?.has(peerId)) {
|
|
71
|
+
this.logger.info({ peerId, violations, requestType }, 'Trusted peer exceeded violations but not blocked');
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
this.blockPeer(peerId, this.config.blockDuration);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
blockPeer(peerId, durationSeconds) {
|
|
78
|
+
if (this.blockedPeers.has(peerId)) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
const violations = this.violationCounter.getCount(peerId);
|
|
82
|
+
this.logger.warn({
|
|
83
|
+
peerId,
|
|
84
|
+
violations,
|
|
85
|
+
blockDuration: durationSeconds,
|
|
86
|
+
}, 'Peer blocked due to sustained rate limit violations');
|
|
87
|
+
const unblockTimeout = setTimeout(() => {
|
|
88
|
+
this.unblockPeer(peerId);
|
|
89
|
+
}, durationSeconds * 1000);
|
|
90
|
+
this.blockedPeers.set(peerId, {
|
|
91
|
+
peerId,
|
|
92
|
+
blockedAt: Date.now(),
|
|
93
|
+
unblockTimeout,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
unblockPeer(peerId) {
|
|
97
|
+
const blocked = this.blockedPeers.get(peerId);
|
|
98
|
+
if (!blocked) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
this.logger.info({ peerId }, 'Peer unblocked');
|
|
102
|
+
this.blockedPeers.delete(peerId);
|
|
103
|
+
this.violationCounter.reset(peerId);
|
|
104
|
+
this.adaptiveLimits.delete(peerId);
|
|
105
|
+
}
|
|
106
|
+
increaseAdaptiveLimit(peerId) {
|
|
107
|
+
if (!this.config.adaptiveRateLimiting) {
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
const current = this.adaptiveLimits.get(peerId) ?? 1.0;
|
|
111
|
+
const newLimit = Math.min(5.0, current * 1.1);
|
|
112
|
+
this.adaptiveLimits.set(peerId, newLimit);
|
|
113
|
+
this.logger.debug({ peerId, newMultiplier: newLimit }, 'Increased adaptive rate limit');
|
|
114
|
+
}
|
|
115
|
+
decreaseAdaptiveLimit(peerId) {
|
|
116
|
+
const current = this.adaptiveLimits.get(peerId) ?? 1.0;
|
|
117
|
+
const newLimit = Math.max(0.1, current * 0.9);
|
|
118
|
+
this.adaptiveLimits.set(peerId, newLimit);
|
|
119
|
+
this.logger.debug({ peerId, newMultiplier: newLimit }, 'Decreased adaptive rate limit');
|
|
120
|
+
}
|
|
121
|
+
getBlockedPeers() {
|
|
122
|
+
return Array.from(this.blockedPeers.keys());
|
|
123
|
+
}
|
|
124
|
+
getRequestsPerSecond(peerId) {
|
|
125
|
+
const bucket = this.tokenBuckets.get(peerId);
|
|
126
|
+
if (!bucket) {
|
|
127
|
+
return 0;
|
|
128
|
+
}
|
|
129
|
+
const available = bucket.getAvailableTokens();
|
|
130
|
+
const { capacity, refillRate } = this.getBucketConfig(peerId);
|
|
131
|
+
return Math.max(0, refillRate - (capacity - available));
|
|
132
|
+
}
|
|
133
|
+
unblock(peerId) {
|
|
134
|
+
const blocked = this.blockedPeers.get(peerId);
|
|
135
|
+
if (blocked) {
|
|
136
|
+
clearTimeout(blocked.unblockTimeout);
|
|
137
|
+
this.unblockPeer(peerId);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
validateConfig(config) {
|
|
141
|
+
if (config.maxRequestsPerSecond <= 0) {
|
|
142
|
+
throw new Error('maxRequestsPerSecond must be positive');
|
|
143
|
+
}
|
|
144
|
+
if (config.maxRequestsPerMinute <= 0) {
|
|
145
|
+
throw new Error('maxRequestsPerMinute must be positive');
|
|
146
|
+
}
|
|
147
|
+
if (config.burstSize <= 0) {
|
|
148
|
+
throw new Error('burstSize must be positive');
|
|
149
|
+
}
|
|
150
|
+
if (config.blockDuration <= 0) {
|
|
151
|
+
throw new Error('blockDuration must be positive');
|
|
152
|
+
}
|
|
153
|
+
if (config.violationThreshold <= 0) {
|
|
154
|
+
throw new Error('violationThreshold must be positive');
|
|
155
|
+
}
|
|
156
|
+
if (config.violationWindowSeconds <= 0) {
|
|
157
|
+
throw new Error('violationWindowSeconds must be positive');
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
destroy() {
|
|
161
|
+
for (const blocked of this.blockedPeers.values()) {
|
|
162
|
+
clearTimeout(blocked.unblockTimeout);
|
|
163
|
+
}
|
|
164
|
+
this.blockedPeers.clear();
|
|
165
|
+
this.tokenBuckets.clear();
|
|
166
|
+
this.adaptiveLimits.clear();
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
exports.RateLimiter = RateLimiter;
|
|
170
|
+
//# sourceMappingURL=rate-limiter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limiter.js","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Logger } from 'pino';
|
|
2
|
+
import { PeerReputationScore } from './fraud-detector';
|
|
3
|
+
export interface ReputationTrackerConfig {
|
|
4
|
+
autoPauseThreshold: number;
|
|
5
|
+
decayRate: number;
|
|
6
|
+
maxScore: number;
|
|
7
|
+
}
|
|
8
|
+
export interface FraudDetectionEvent {
|
|
9
|
+
ruleName: string;
|
|
10
|
+
severity: 'low' | 'medium' | 'high' | 'critical';
|
|
11
|
+
peerId: string;
|
|
12
|
+
timestamp: number;
|
|
13
|
+
details?: {
|
|
14
|
+
[key: string]: unknown;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export declare class ReputationTracker {
|
|
18
|
+
private readonly logger;
|
|
19
|
+
private readonly config;
|
|
20
|
+
private readonly reputationScores;
|
|
21
|
+
constructor(logger: Logger, config: ReputationTrackerConfig);
|
|
22
|
+
updateReputationScore(event: FraudDetectionEvent): Promise<void>;
|
|
23
|
+
applyScoreDecay(peerId: string, currentTime: number): void;
|
|
24
|
+
applyScoreDecayAll(currentTime: number): void;
|
|
25
|
+
getReputationScore(peerId: string): PeerReputationScore | undefined;
|
|
26
|
+
getAllReputationScores(): Map<string, PeerReputationScore>;
|
|
27
|
+
shouldAutoPause(peerId: string): boolean;
|
|
28
|
+
clearAll(): void;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=reputation-tracker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reputation-tracker.d.ts","sourceRoot":"","sources":["../../src/security/reputation-tracker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAevD,MAAM,WAAW,uBAAuB;IAKtC,kBAAkB,EAAE,MAAM,CAAC;IAK3B,SAAS,EAAE,MAAM,CAAC;IAKlB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAKD,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;IACjD,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE;QACR,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;KACxB,CAAC;CACH;AAUD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA0B;IACjD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAmC;gBAExD,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,uBAAuB;IAe9C,qBAAqB,CAAC,KAAK,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC;IAuDtE,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI;IAmC1D,kBAAkB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAS7C,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB,GAAG,SAAS;IAOnE,sBAAsB,IAAI,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC;IAO1D,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAYxC,QAAQ,IAAI,IAAI;CAGxB"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ReputationTracker = void 0;
|
|
4
|
+
const SEVERITY_PENALTIES = {
|
|
5
|
+
low: 1,
|
|
6
|
+
medium: 5,
|
|
7
|
+
high: 10,
|
|
8
|
+
critical: 25,
|
|
9
|
+
};
|
|
10
|
+
class ReputationTracker {
|
|
11
|
+
logger;
|
|
12
|
+
config;
|
|
13
|
+
reputationScores;
|
|
14
|
+
constructor(logger, config) {
|
|
15
|
+
this.logger = logger.child({ component: 'ReputationTracker' });
|
|
16
|
+
this.config = config;
|
|
17
|
+
this.reputationScores = new Map();
|
|
18
|
+
this.logger.info('ReputationTracker initialized', {
|
|
19
|
+
autoPauseThreshold: config.autoPauseThreshold,
|
|
20
|
+
decayRate: config.decayRate,
|
|
21
|
+
maxScore: config.maxScore,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
async updateReputationScore(event) {
|
|
25
|
+
try {
|
|
26
|
+
const { peerId, ruleName, severity, timestamp } = event;
|
|
27
|
+
let score = this.reputationScores.get(peerId);
|
|
28
|
+
if (!score) {
|
|
29
|
+
score = {
|
|
30
|
+
peerId,
|
|
31
|
+
score: this.config.maxScore,
|
|
32
|
+
lastUpdated: timestamp,
|
|
33
|
+
violations: [],
|
|
34
|
+
};
|
|
35
|
+
this.reputationScores.set(peerId, score);
|
|
36
|
+
}
|
|
37
|
+
const penalty = SEVERITY_PENALTIES[severity];
|
|
38
|
+
const newScore = Math.max(0, score.score - penalty);
|
|
39
|
+
score.violations.push({
|
|
40
|
+
timestamp,
|
|
41
|
+
ruleViolated: ruleName,
|
|
42
|
+
severity,
|
|
43
|
+
penaltyApplied: penalty,
|
|
44
|
+
});
|
|
45
|
+
score.score = newScore;
|
|
46
|
+
score.lastUpdated = timestamp;
|
|
47
|
+
this.logger.info('Reputation score updated', {
|
|
48
|
+
peerId,
|
|
49
|
+
previousScore: score.score + penalty,
|
|
50
|
+
newScore,
|
|
51
|
+
penalty,
|
|
52
|
+
severity,
|
|
53
|
+
ruleName,
|
|
54
|
+
violationCount: score.violations.length,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
this.logger.error('Failed to update reputation score', {
|
|
59
|
+
peerId: event.peerId,
|
|
60
|
+
error: error instanceof Error ? error.message : String(error),
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
applyScoreDecay(peerId, currentTime) {
|
|
65
|
+
const score = this.reputationScores.get(peerId);
|
|
66
|
+
if (!score) {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const msPerDay = 24 * 60 * 60 * 1000;
|
|
70
|
+
const daysElapsed = Math.floor((currentTime - score.lastUpdated) / msPerDay);
|
|
71
|
+
if (daysElapsed === 0) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
const decayAmount = daysElapsed * this.config.decayRate;
|
|
75
|
+
const newScore = Math.min(this.config.maxScore, score.score + decayAmount);
|
|
76
|
+
if (newScore !== score.score) {
|
|
77
|
+
this.logger.debug('Score decay applied', {
|
|
78
|
+
peerId,
|
|
79
|
+
previousScore: score.score,
|
|
80
|
+
newScore,
|
|
81
|
+
daysElapsed,
|
|
82
|
+
decayAmount,
|
|
83
|
+
});
|
|
84
|
+
score.score = newScore;
|
|
85
|
+
score.lastUpdated = currentTime;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
applyScoreDecayAll(currentTime) {
|
|
89
|
+
for (const [peerId] of Array.from(this.reputationScores)) {
|
|
90
|
+
this.applyScoreDecay(peerId, currentTime);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
getReputationScore(peerId) {
|
|
94
|
+
return this.reputationScores.get(peerId);
|
|
95
|
+
}
|
|
96
|
+
getAllReputationScores() {
|
|
97
|
+
return new Map(this.reputationScores);
|
|
98
|
+
}
|
|
99
|
+
shouldAutoPause(peerId) {
|
|
100
|
+
const score = this.reputationScores.get(peerId);
|
|
101
|
+
if (!score) {
|
|
102
|
+
return false;
|
|
103
|
+
}
|
|
104
|
+
return score.score < this.config.autoPauseThreshold;
|
|
105
|
+
}
|
|
106
|
+
clearAll() {
|
|
107
|
+
this.reputationScores.clear();
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
exports.ReputationTracker = ReputationTracker;
|
|
111
|
+
//# sourceMappingURL=reputation-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reputation-tracker.js","sourceRoot":"","sources":["../../src/security/reputation-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
|
|
2
|
+
export interface BalanceEvent extends SettlementEvent {
|
|
3
|
+
previousBalance?: number;
|
|
4
|
+
newBalance?: number;
|
|
5
|
+
}
|
|
6
|
+
interface BalanceHistory {
|
|
7
|
+
peerId: string;
|
|
8
|
+
balances: {
|
|
9
|
+
balance: number;
|
|
10
|
+
timestamp: number;
|
|
11
|
+
}[];
|
|
12
|
+
}
|
|
13
|
+
export declare class BalanceManipulationRule implements FraudRule {
|
|
14
|
+
readonly name = "BalanceManipulationRule";
|
|
15
|
+
readonly severity: "critical";
|
|
16
|
+
private readonly balanceHistory;
|
|
17
|
+
constructor();
|
|
18
|
+
check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
|
|
19
|
+
clearHistory(): void;
|
|
20
|
+
getBalanceHistory(peerId: string): BalanceHistory | undefined;
|
|
21
|
+
}
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=balance-manipulation-rule.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"balance-manipulation-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/balance-manipulation-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,MAAM,WAAW,YAAa,SAAQ,eAAe;IACnD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAKD,UAAU,cAAc;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE;QACR,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,MAAM,CAAC;KACnB,EAAE,CAAC;CACL;AASD,qBAAa,uBAAwB,YAAW,SAAS;IACvD,SAAgB,IAAI,6BAA6B;IACjD,SAAgB,QAAQ,EAAG,UAAU,CAAU;IAE/C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;;IAShD,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IAqEzF,YAAY,IAAI,IAAI;IAOpB,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,GAAG,SAAS;CAGrE"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BalanceManipulationRule = void 0;
|
|
4
|
+
class BalanceManipulationRule {
|
|
5
|
+
name = 'BalanceManipulationRule';
|
|
6
|
+
severity = 'critical';
|
|
7
|
+
balanceHistory;
|
|
8
|
+
constructor() {
|
|
9
|
+
this.balanceHistory = new Map();
|
|
10
|
+
}
|
|
11
|
+
async check(event) {
|
|
12
|
+
if (event.type !== 'settlement') {
|
|
13
|
+
return { detected: false };
|
|
14
|
+
}
|
|
15
|
+
const balanceEvent = event;
|
|
16
|
+
if (balanceEvent.newBalance === undefined) {
|
|
17
|
+
return { detected: false };
|
|
18
|
+
}
|
|
19
|
+
if (balanceEvent.newBalance < 0) {
|
|
20
|
+
return {
|
|
21
|
+
detected: true,
|
|
22
|
+
peerId: balanceEvent.peerId,
|
|
23
|
+
details: {
|
|
24
|
+
description: `Negative balance attempt detected: ${balanceEvent.newBalance}`,
|
|
25
|
+
newBalance: balanceEvent.newBalance,
|
|
26
|
+
previousBalance: balanceEvent.previousBalance,
|
|
27
|
+
timestamp: balanceEvent.timestamp,
|
|
28
|
+
},
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
if (balanceEvent.previousBalance !== undefined) {
|
|
32
|
+
let history = this.balanceHistory.get(balanceEvent.peerId);
|
|
33
|
+
if (!history) {
|
|
34
|
+
history = {
|
|
35
|
+
peerId: balanceEvent.peerId,
|
|
36
|
+
balances: [],
|
|
37
|
+
};
|
|
38
|
+
this.balanceHistory.set(balanceEvent.peerId, history);
|
|
39
|
+
}
|
|
40
|
+
const balanceDecrease = balanceEvent.previousBalance - balanceEvent.newBalance;
|
|
41
|
+
if (balanceDecrease > 0 && balanceDecrease !== balanceEvent.amount) {
|
|
42
|
+
return {
|
|
43
|
+
detected: true,
|
|
44
|
+
peerId: balanceEvent.peerId,
|
|
45
|
+
details: {
|
|
46
|
+
description: `Unexpected balance decrease detected: ${balanceDecrease} units (expected: ${balanceEvent.amount})`,
|
|
47
|
+
previousBalance: balanceEvent.previousBalance,
|
|
48
|
+
newBalance: balanceEvent.newBalance,
|
|
49
|
+
expectedDecrease: balanceEvent.amount,
|
|
50
|
+
actualDecrease: balanceDecrease,
|
|
51
|
+
timestamp: balanceEvent.timestamp,
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
history.balances.push({
|
|
56
|
+
balance: balanceEvent.newBalance,
|
|
57
|
+
timestamp: balanceEvent.timestamp,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
return { detected: false };
|
|
61
|
+
}
|
|
62
|
+
clearHistory() {
|
|
63
|
+
this.balanceHistory.clear();
|
|
64
|
+
}
|
|
65
|
+
getBalanceHistory(peerId) {
|
|
66
|
+
return this.balanceHistory.get(peerId);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
exports.BalanceManipulationRule = BalanceManipulationRule;
|
|
70
|
+
//# sourceMappingURL=balance-manipulation-rule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"balance-manipulation-rule.js","sourceRoot":"","sources":["../../../src/security/rules/balance-manipulation-rule.ts"],"names":[],"mappings":";;;AAkCA,MAAa,uBAAuB;IAClB,IAAI,GAAG,yBAAyB,CAAC;IACjC,QAAQ,GAAG,UAAmB,CAAC;IAE9B,cAAc,CAA8B;IAE7D;QACE,IAAI,CAAC,cAAc,GAAG,IAAI,GAAG,EAAE,CAAC;IAClC,CAAC;IAKM,KAAK,CAAC,KAAK,CAAC,KAAmD;QAEpE,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;YAChC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,YAAY,GAAG,KAAqB,CAAC;QAG3C,IAAI,YAAY,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YAC1C,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAGD,IAAI,YAAY,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC;YAChC,OAAO;gBACL,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE;oBACP,WAAW,EAAE,sCAAsC,YAAY,CAAC,UAAU,EAAE;oBAC5E,UAAU,EAAE,YAAY,CAAC,UAAU;oBACnC,eAAe,EAAE,YAAY,CAAC,eAAe;oBAC7C,SAAS,EAAE,YAAY,CAAC,SAAS;iBAClC;aACF,CAAC;QACJ,CAAC;QAGD,IAAI,YAAY,CAAC,eAAe,KAAK,SAAS,EAAE,CAAC;YAE/C,IAAI,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;YAC3D,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,GAAG;oBACR,MAAM,EAAE,YAAY,CAAC,MAAM;oBAC3B,QAAQ,EAAE,EAAE;iBACb,CAAC;gBACF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;YACxD,CAAC;YAGD,MAAM,eAAe,GAAG,YAAY,CAAC,eAAe,GAAG,YAAY,CAAC,UAAU,CAAC;YAC/E,IAAI,eAAe,GAAG,CAAC,IAAI,eAAe,KAAK,YAAY,CAAC,MAAM,EAAE,CAAC;gBACnE,OAAO;oBACL,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,YAAY,CAAC,MAAM;oBAC3B,OAAO,EAAE;wBACP,WAAW,EAAE,yCAAyC,eAAe,qBAAqB,YAAY,CAAC,MAAM,GAAG;wBAChH,eAAe,EAAE,YAAY,CAAC,eAAe;wBAC7C,UAAU,EAAE,YAAY,CAAC,UAAU;wBACnC,gBAAgB,EAAE,YAAY,CAAC,MAAM;wBACrC,cAAc,EAAE,eAAe;wBAC/B,SAAS,EAAE,YAAY,CAAC,SAAS;qBAClC;iBACF,CAAC;YACJ,CAAC;YAGD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACpB,OAAO,EAAE,YAAY,CAAC,UAAU;gBAChC,SAAS,EAAE,YAAY,CAAC,SAAS;aAClC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAKM,YAAY;QACjB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;IAKM,iBAAiB,CAAC,MAAc;QACrC,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;CACF;AA5FD,0DA4FC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
|
|
2
|
+
interface ClaimHistory {
|
|
3
|
+
peerId: string;
|
|
4
|
+
channelId: string;
|
|
5
|
+
claims: {
|
|
6
|
+
amount: number;
|
|
7
|
+
timestamp: number;
|
|
8
|
+
}[];
|
|
9
|
+
}
|
|
10
|
+
export interface ClaimEvent extends SettlementEvent {
|
|
11
|
+
claimAmount?: number;
|
|
12
|
+
}
|
|
13
|
+
export declare class DoubleSpendDetectionRule implements FraudRule {
|
|
14
|
+
readonly name = "DoubleSpendDetectionRule";
|
|
15
|
+
readonly severity: "critical";
|
|
16
|
+
private readonly claimHistory;
|
|
17
|
+
constructor();
|
|
18
|
+
check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
|
|
19
|
+
clearHistory(): void;
|
|
20
|
+
getClaimHistory(peerId: string, channelId: string): ClaimHistory | undefined;
|
|
21
|
+
}
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=double-spend-detection-rule.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"double-spend-detection-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/double-spend-detection-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,UAAU,YAAY;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE;QACN,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,EAAE,MAAM,CAAC;KACnB,EAAE,CAAC;CACL;AAKD,MAAM,WAAW,UAAW,SAAQ,eAAe;IACjD,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AASD,qBAAa,wBAAyB,YAAW,SAAS;IACxD,SAAgB,IAAI,8BAA8B;IAClD,SAAgB,QAAQ,EAAG,UAAU,CAAU;IAE/C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA4B;;IAS5C,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IA0DzF,YAAY,IAAI,IAAI;IAOpB,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;CAGpF"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DoubleSpendDetectionRule = void 0;
|
|
4
|
+
class DoubleSpendDetectionRule {
|
|
5
|
+
name = 'DoubleSpendDetectionRule';
|
|
6
|
+
severity = 'critical';
|
|
7
|
+
claimHistory;
|
|
8
|
+
constructor() {
|
|
9
|
+
this.claimHistory = new Map();
|
|
10
|
+
}
|
|
11
|
+
async check(event) {
|
|
12
|
+
if (event.type !== 'settlement') {
|
|
13
|
+
return { detected: false };
|
|
14
|
+
}
|
|
15
|
+
const settlementEvent = event;
|
|
16
|
+
if (!settlementEvent.channelId || settlementEvent.claimAmount === undefined) {
|
|
17
|
+
return { detected: false };
|
|
18
|
+
}
|
|
19
|
+
const historyKey = `${settlementEvent.peerId}:${settlementEvent.channelId}`;
|
|
20
|
+
let history = this.claimHistory.get(historyKey);
|
|
21
|
+
if (!history) {
|
|
22
|
+
history = {
|
|
23
|
+
peerId: settlementEvent.peerId,
|
|
24
|
+
channelId: settlementEvent.channelId,
|
|
25
|
+
claims: [],
|
|
26
|
+
};
|
|
27
|
+
this.claimHistory.set(historyKey, history);
|
|
28
|
+
}
|
|
29
|
+
const previousClaims = history.claims;
|
|
30
|
+
if (previousClaims.length > 0) {
|
|
31
|
+
const lastClaim = previousClaims[previousClaims.length - 1];
|
|
32
|
+
if (lastClaim && settlementEvent.claimAmount < lastClaim.amount) {
|
|
33
|
+
return {
|
|
34
|
+
detected: true,
|
|
35
|
+
peerId: settlementEvent.peerId,
|
|
36
|
+
details: {
|
|
37
|
+
description: `Double-spend attempt detected: Claim amount ${settlementEvent.claimAmount} is lower than previous claim ${lastClaim.amount}`,
|
|
38
|
+
currentClaimAmount: settlementEvent.claimAmount,
|
|
39
|
+
previousClaimAmount: lastClaim.amount,
|
|
40
|
+
channelId: settlementEvent.channelId,
|
|
41
|
+
timestamp: settlementEvent.timestamp,
|
|
42
|
+
previousClaimTimestamp: lastClaim.timestamp,
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
history.claims.push({
|
|
48
|
+
amount: settlementEvent.claimAmount,
|
|
49
|
+
timestamp: settlementEvent.timestamp,
|
|
50
|
+
});
|
|
51
|
+
return { detected: false };
|
|
52
|
+
}
|
|
53
|
+
clearHistory() {
|
|
54
|
+
this.claimHistory.clear();
|
|
55
|
+
}
|
|
56
|
+
getClaimHistory(peerId, channelId) {
|
|
57
|
+
return this.claimHistory.get(`${peerId}:${channelId}`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
exports.DoubleSpendDetectionRule = DoubleSpendDetectionRule;
|
|
61
|
+
//# sourceMappingURL=double-spend-detection-rule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"double-spend-detection-rule.js","sourceRoot":"","sources":["../../../src/security/rules/double-spend-detection-rule.ts"],"names":[],"mappings":";;;AAkCA,MAAa,wBAAwB;IACnB,IAAI,GAAG,0BAA0B,CAAC;IAClC,QAAQ,GAAG,UAAmB,CAAC;IAE9B,YAAY,CAA4B;IAEzD;QACE,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,EAAE,CAAC;IAChC,CAAC;IAKM,KAAK,CAAC,KAAK,CAAC,KAAmD;QAEpE,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;YAChC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,eAAe,GAAG,KAAmB,CAAC;QAG5C,IAAI,CAAC,eAAe,CAAC,SAAS,IAAI,eAAe,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;YAC5E,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,UAAU,GAAG,GAAG,eAAe,CAAC,MAAM,IAAI,eAAe,CAAC,SAAS,EAAE,CAAC;QAG5E,IAAI,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,GAAG;gBACR,MAAM,EAAE,eAAe,CAAC,MAAM;gBAC9B,SAAS,EAAE,eAAe,CAAC,SAAS;gBACpC,MAAM,EAAE,EAAE;aACX,CAAC;YACF,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAC7C,CAAC;QAGD,MAAM,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC;QACtC,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,MAAM,SAAS,GAAG,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAC5D,IAAI,SAAS,IAAI,eAAe,CAAC,WAAW,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC;gBAChE,OAAO;oBACL,QAAQ,EAAE,IAAI;oBACd,MAAM,EAAE,eAAe,CAAC,MAAM;oBAC9B,OAAO,EAAE;wBACP,WAAW,EAAE,+CAA+C,eAAe,CAAC,WAAW,iCAAiC,SAAS,CAAC,MAAM,EAAE;wBAC1I,kBAAkB,EAAE,eAAe,CAAC,WAAW;wBAC/C,mBAAmB,EAAE,SAAS,CAAC,MAAM;wBACrC,SAAS,EAAE,eAAe,CAAC,SAAS;wBACpC,SAAS,EAAE,eAAe,CAAC,SAAS;wBACpC,sBAAsB,EAAE,SAAS,CAAC,SAAS;qBAC5C;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;QAGD,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;YAClB,MAAM,EAAE,eAAe,CAAC,WAAW;YACnC,SAAS,EAAE,eAAe,CAAC,SAAS;SACrC,CAAC,CAAC;QAEH,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAKM,YAAY;QACjB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAKM,eAAe,CAAC,MAAc,EAAE,SAAiB;QACtD,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,MAAM,IAAI,SAAS,EAAE,CAAC,CAAC;IACzD,CAAC;CACF;AAjFD,4DAiFC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
|
|
2
|
+
export interface RapidChannelClosureConfig {
|
|
3
|
+
maxClosures: number;
|
|
4
|
+
timeWindow: number;
|
|
5
|
+
}
|
|
6
|
+
export declare class RapidChannelClosureRule implements FraudRule {
|
|
7
|
+
readonly name = "RapidChannelClosureRule";
|
|
8
|
+
readonly severity: "high";
|
|
9
|
+
private readonly config;
|
|
10
|
+
private readonly closureHistory;
|
|
11
|
+
constructor(config: RapidChannelClosureConfig);
|
|
12
|
+
check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
|
|
13
|
+
private cleanupOldClosures;
|
|
14
|
+
clearHistory(): void;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=rapid-channel-closure-rule.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rapid-channel-closure-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/rapid-channel-closure-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,MAAM,WAAW,yBAAyB;IAIxC,WAAW,EAAE,MAAM,CAAC;IAKpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAmBD,qBAAa,uBAAwB,YAAW,SAAS;IACvD,SAAgB,IAAI,6BAA6B;IACjD,SAAgB,QAAQ,EAAG,MAAM,CAAU;IAE3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4B;IACnD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;gBAEjD,MAAM,EAAE,yBAAyB;IAQhC,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IAkDhG,OAAO,CAAC,kBAAkB;IAQnB,YAAY,IAAI,IAAI;CAG5B"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RapidChannelClosureRule = void 0;
|
|
4
|
+
class RapidChannelClosureRule {
|
|
5
|
+
name = 'RapidChannelClosureRule';
|
|
6
|
+
severity = 'high';
|
|
7
|
+
config;
|
|
8
|
+
closureHistory;
|
|
9
|
+
constructor(config) {
|
|
10
|
+
this.config = config;
|
|
11
|
+
this.closureHistory = new Map();
|
|
12
|
+
}
|
|
13
|
+
async check(event) {
|
|
14
|
+
if (event.type !== 'channel' || event.action !== 'close') {
|
|
15
|
+
return { detected: false };
|
|
16
|
+
}
|
|
17
|
+
const channelEvent = event;
|
|
18
|
+
const now = channelEvent.timestamp;
|
|
19
|
+
let history = this.closureHistory.get(channelEvent.peerId);
|
|
20
|
+
if (!history) {
|
|
21
|
+
history = {
|
|
22
|
+
peerId: channelEvent.peerId,
|
|
23
|
+
closures: [],
|
|
24
|
+
};
|
|
25
|
+
this.closureHistory.set(channelEvent.peerId, history);
|
|
26
|
+
}
|
|
27
|
+
history.closures.push({
|
|
28
|
+
channelId: channelEvent.channelId,
|
|
29
|
+
timestamp: now,
|
|
30
|
+
});
|
|
31
|
+
this.cleanupOldClosures(history, now);
|
|
32
|
+
if (history.closures.length > this.config.maxClosures) {
|
|
33
|
+
const closureCount = history.closures.length;
|
|
34
|
+
return {
|
|
35
|
+
detected: true,
|
|
36
|
+
peerId: channelEvent.peerId,
|
|
37
|
+
details: {
|
|
38
|
+
description: `Rapid channel closures detected: ${closureCount} closures in ${this.config.timeWindow / 1000}s (threshold: ${this.config.maxClosures})`,
|
|
39
|
+
closureCount,
|
|
40
|
+
maxClosures: this.config.maxClosures,
|
|
41
|
+
timeWindow: this.config.timeWindow,
|
|
42
|
+
channelIds: history.closures.map((c) => c.channelId),
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
return { detected: false };
|
|
47
|
+
}
|
|
48
|
+
cleanupOldClosures(history, now) {
|
|
49
|
+
const cutoffTime = now - this.config.timeWindow;
|
|
50
|
+
history.closures = history.closures.filter((closure) => closure.timestamp >= cutoffTime);
|
|
51
|
+
}
|
|
52
|
+
clearHistory() {
|
|
53
|
+
this.closureHistory.clear();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
exports.RapidChannelClosureRule = RapidChannelClosureRule;
|
|
57
|
+
//# sourceMappingURL=rapid-channel-closure-rule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rapid-channel-closure-rule.js","sourceRoot":"","sources":["../../../src/security/rules/rapid-channel-closure-rule.ts"],"names":[],"mappings":";;;AAwCA,MAAa,uBAAuB;IAClB,IAAI,GAAG,yBAAyB,CAAC;IACjC,QAAQ,GAAG,MAAe,CAAC;IAE1B,MAAM,CAA4B;IAClC,cAAc,CAA8B;IAE7D,YAAY,MAAiC;QAC3C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,cAAc,GAAG,IAAI,GAAG,EAAE,CAAC;IAClC,CAAC;IAKM,KAAK,CAAC,KAAK,CAAC,KAAmD;QAEpE,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;YACzD,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,MAAM,YAAY,GAAG,KAAqB,CAAC;QAC3C,MAAM,GAAG,GAAG,YAAY,CAAC,SAAS,CAAC;QAGnC,IAAI,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC3D,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,GAAG;gBACR,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,QAAQ,EAAE,EAAE;aACb,CAAC;YACF,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QACxD,CAAC;QAGD,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;YACpB,SAAS,EAAE,YAAY,CAAC,SAAS;YACjC,SAAS,EAAE,GAAG;SACf,CAAC,CAAC;QAGH,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QAGtC,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;YACtD,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC7C,OAAO;gBACL,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,YAAY,CAAC,MAAM;gBAC3B,OAAO,EAAE;oBACP,WAAW,EAAE,oCAAoC,YAAY,gBAAgB,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,iBAAiB,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG;oBACrJ,YAAY;oBACZ,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW;oBACpC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;oBAClC,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;iBACrD;aACF,CAAC;QACJ,CAAC;QAED,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAC7B,CAAC;IAKO,kBAAkB,CAAC,OAAuB,EAAE,GAAW;QAC7D,MAAM,UAAU,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;QAChD,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,IAAI,UAAU,CAAC,CAAC;IAC3F,CAAC;IAKM,YAAY;QACjB,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;CACF;AA5ED,0DA4EC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { FraudRule, FraudDetection, SettlementEvent, PacketEvent, ChannelEvent } from '../fraud-detector';
|
|
2
|
+
export interface SuddenTrafficSpikeConfig {
|
|
3
|
+
spikeThreshold: number;
|
|
4
|
+
timeWindow: number;
|
|
5
|
+
}
|
|
6
|
+
export declare class SuddenTrafficSpikeRule implements FraudRule {
|
|
7
|
+
readonly name = "SuddenTrafficSpikeRule";
|
|
8
|
+
readonly severity: "medium";
|
|
9
|
+
private readonly config;
|
|
10
|
+
private readonly trafficHistory;
|
|
11
|
+
constructor(config: SuddenTrafficSpikeConfig);
|
|
12
|
+
check(event: SettlementEvent | PacketEvent | ChannelEvent): Promise<FraudDetection>;
|
|
13
|
+
private cleanupOldEntries;
|
|
14
|
+
private calculateCurrentRate;
|
|
15
|
+
private calculateHistoricalAverage;
|
|
16
|
+
clearHistory(): void;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=sudden-traffic-spike-rule.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sudden-traffic-spike-rule.d.ts","sourceRoot":"","sources":["../../../src/security/rules/sudden-traffic-spike-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,cAAc,EACd,eAAe,EACf,WAAW,EACX,YAAY,EACb,MAAM,mBAAmB,CAAC;AAK3B,MAAM,WAAW,wBAAwB;IAIvC,cAAc,EAAE,MAAM,CAAC;IAKvB,UAAU,EAAE,MAAM,CAAC;CACpB;AAkBD,qBAAa,sBAAuB,YAAW,SAAS;IACtD,SAAgB,IAAI,4BAA4B;IAChD,SAAgB,QAAQ,EAAG,QAAQ,CAAU;IAE7C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2B;IAClD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;gBAEjD,MAAM,EAAE,wBAAwB;IAQ/B,KAAK,CAAC,KAAK,EAAE,eAAe,GAAG,WAAW,GAAG,YAAY,GAAG,OAAO,CAAC,cAAc,CAAC;IA4DhG,OAAO,CAAC,iBAAiB;IAuBzB,OAAO,CAAC,oBAAoB;IAkB5B,OAAO,CAAC,0BAA0B;IAe3B,YAAY,IAAI,IAAI;CAG5B"}
|