@toon-protocol/connector 2.6.1 → 3.3.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/package.json +2 -2
- package/dist/btp/btp-claim-types.d.ts +0 -52
- package/dist/btp/btp-claim-types.d.ts.map +0 -1
- package/dist/btp/btp-claim-types.js +0 -209
- package/dist/btp/btp-claim-types.js.map +0 -1
- package/dist/btp/btp-client-manager.d.ts +0 -30
- package/dist/btp/btp-client-manager.d.ts.map +0 -1
- package/dist/btp/btp-client-manager.js +0 -153
- package/dist/btp/btp-client-manager.js.map +0 -1
- package/dist/btp/btp-client.d.ts +0 -58
- package/dist/btp/btp-client.d.ts.map +0 -1
- package/dist/btp/btp-client.js +0 -485
- package/dist/btp/btp-client.js.map +0 -1
- package/dist/btp/btp-message-parser.d.ts +0 -4
- package/dist/btp/btp-message-parser.d.ts.map +0 -1
- package/dist/btp/btp-message-parser.js +0 -211
- package/dist/btp/btp-message-parser.js.map +0 -1
- package/dist/btp/btp-server.d.ts +0 -33
- package/dist/btp/btp-server.d.ts.map +0 -1
- package/dist/btp/btp-server.js +0 -485
- package/dist/btp/btp-server.js.map +0 -1
- package/dist/btp/btp-types.d.ts +0 -43
- package/dist/btp/btp-types.d.ts.map +0 -1
- package/dist/btp/btp-types.js +0 -44
- package/dist/btp/btp-types.js.map +0 -1
- package/dist/btp/inbound-claim-validator.d.ts +0 -20
- package/dist/btp/inbound-claim-validator.d.ts.map +0 -1
- package/dist/btp/inbound-claim-validator.js +0 -150
- package/dist/btp/inbound-claim-validator.js.map +0 -1
- package/dist/cli/index.d.ts +0 -3
- package/dist/cli/index.d.ts.map +0 -1
- package/dist/cli/index.js +0 -175
- package/dist/cli/index.js.map +0 -1
- package/dist/cli/onboarding-wizard.d.ts +0 -7
- package/dist/cli/onboarding-wizard.d.ts.map +0 -1
- package/dist/cli/onboarding-wizard.js +0 -257
- package/dist/cli/onboarding-wizard.js.map +0 -1
- package/dist/cli/types.d.ts +0 -38
- package/dist/cli/types.d.ts.map +0 -1
- package/dist/cli/types.js +0 -3
- package/dist/cli/types.js.map +0 -1
- package/dist/config/config-loader.d.ts +0 -24
- package/dist/config/config-loader.d.ts.map +0 -1
- package/dist/config/config-loader.js +0 -436
- package/dist/config/config-loader.js.map +0 -1
- package/dist/config/environment-validator.d.ts +0 -4
- package/dist/config/environment-validator.d.ts.map +0 -1
- package/dist/config/environment-validator.js +0 -239
- package/dist/config/environment-validator.js.map +0 -1
- package/dist/config/index.d.ts +0 -3
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/index.js +0 -7
- package/dist/config/index.js.map +0 -1
- package/dist/config/key-manager-config.d.ts +0 -7
- package/dist/config/key-manager-config.d.ts.map +0 -1
- package/dist/config/key-manager-config.js +0 -209
- package/dist/config/key-manager-config.js.map +0 -1
- package/dist/config/topology-validator.d.ts +0 -14
- package/dist/config/topology-validator.d.ts.map +0 -1
- package/dist/config/topology-validator.js +0 -142
- package/dist/config/topology-validator.js.map +0 -1
- package/dist/config/types.d.ts +0 -223
- package/dist/config/types.d.ts.map +0 -1
- package/dist/config/types.js +0 -52
- package/dist/config/types.js.map +0 -1
- package/dist/core/connector-node.d.ts +0 -91
- package/dist/core/connector-node.d.ts.map +0 -1
- package/dist/core/connector-node.js +0 -1322
- package/dist/core/connector-node.js.map +0 -1
- package/dist/core/local-delivery-client.d.ts +0 -16
- package/dist/core/local-delivery-client.d.ts.map +0 -1
- package/dist/core/local-delivery-client.js +0 -160
- package/dist/core/local-delivery-client.js.map +0 -1
- package/dist/core/packet-handler.d.ts +0 -57
- package/dist/core/packet-handler.d.ts.map +0 -1
- package/dist/core/packet-handler.js +0 -655
- package/dist/core/packet-handler.js.map +0 -1
- package/dist/core/payment-handler.d.ts +0 -25
- package/dist/core/payment-handler.d.ts.map +0 -1
- package/dist/core/payment-handler.js +0 -104
- package/dist/core/payment-handler.js.map +0 -1
- package/dist/discovery/index.d.ts +0 -3
- package/dist/discovery/index.d.ts.map +0 -1
- package/dist/discovery/index.js +0 -6
- package/dist/discovery/index.js.map +0 -1
- package/dist/discovery/peer-discovery-service.d.ts +0 -29
- package/dist/discovery/peer-discovery-service.d.ts.map +0 -1
- package/dist/discovery/peer-discovery-service.js +0 -230
- package/dist/discovery/peer-discovery-service.js.map +0 -1
- package/dist/discovery/types.d.ts +0 -38
- package/dist/discovery/types.d.ts.map +0 -1
- package/dist/discovery/types.js +0 -3
- package/dist/discovery/types.js.map +0 -1
- package/dist/encoding/oer-parser.d.ts +0 -39
- package/dist/encoding/oer-parser.d.ts.map +0 -1
- package/dist/encoding/oer-parser.js +0 -154
- package/dist/encoding/oer-parser.js.map +0 -1
- package/dist/facilitator/index.d.ts +0 -2
- package/dist/facilitator/index.d.ts.map +0 -1
- package/dist/facilitator/index.js +0 -7
- package/dist/facilitator/index.js.map +0 -1
- package/dist/facilitator/spsp-client.d.ts +0 -18
- package/dist/facilitator/spsp-client.d.ts.map +0 -1
- package/dist/facilitator/spsp-client.js +0 -95
- package/dist/facilitator/spsp-client.js.map +0 -1
- package/dist/http/admin-api-inventory.d.ts +0 -29
- package/dist/http/admin-api-inventory.d.ts.map +0 -1
- package/dist/http/admin-api-inventory.js +0 -480
- package/dist/http/admin-api-inventory.js.map +0 -1
- package/dist/http/admin-api.d.ts +0 -182
- package/dist/http/admin-api.d.ts.map +0 -1
- package/dist/http/admin-api.js +0 -1324
- package/dist/http/admin-api.js.map +0 -1
- package/dist/http/admin-server.d.ts +0 -49
- package/dist/http/admin-server.d.ts.map +0 -1
- package/dist/http/admin-server.js +0 -160
- package/dist/http/admin-server.js.map +0 -1
- package/dist/http/health-server.d.ts +0 -22
- package/dist/http/health-server.d.ts.map +0 -1
- package/dist/http/health-server.js +0 -192
- package/dist/http/health-server.js.map +0 -1
- package/dist/http/ilp-send-handler.d.ts +0 -15
- package/dist/http/ilp-send-handler.d.ts.map +0 -1
- package/dist/http/ilp-send-handler.js +0 -149
- package/dist/http/ilp-send-handler.js.map +0 -1
- package/dist/http/types.d.ts +0 -43
- package/dist/http/types.d.ts.map +0 -1
- package/dist/http/types.js +0 -3
- package/dist/http/types.js.map +0 -1
- package/dist/index.d.ts +0 -2
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -5
- package/dist/index.js.map +0 -1
- package/dist/lib.d.ts +0 -22
- package/dist/lib.d.ts.map +0 -1
- package/dist/lib.js +0 -39
- package/dist/lib.js.map +0 -1
- package/dist/main.d.ts +0 -4
- package/dist/main.d.ts.map +0 -1
- package/dist/main.js +0 -79
- package/dist/main.js.map +0 -1
- package/dist/observability/metrics-registry.d.ts +0 -39
- package/dist/observability/metrics-registry.d.ts.map +0 -1
- package/dist/observability/metrics-registry.js +0 -151
- package/dist/observability/metrics-registry.js.map +0 -1
- package/dist/routing/packet-processor.d.ts +0 -36
- package/dist/routing/packet-processor.d.ts.map +0 -1
- package/dist/routing/packet-processor.js +0 -112
- package/dist/routing/packet-processor.js.map +0 -1
- package/dist/routing/packet-worker.d.ts +0 -10
- package/dist/routing/packet-worker.d.ts.map +0 -1
- package/dist/routing/packet-worker.js +0 -34
- package/dist/routing/packet-worker.js.map +0 -1
- package/dist/routing/routing-table.d.ts +0 -15
- package/dist/routing/routing-table.d.ts.map +0 -1
- package/dist/routing/routing-table.js +0 -63
- package/dist/routing/routing-table.js.map +0 -1
- package/dist/routing/worker-pool.d.ts +0 -43
- package/dist/routing/worker-pool.d.ts.map +0 -1
- package/dist/routing/worker-pool.js +0 -228
- package/dist/routing/worker-pool.js.map +0 -1
- package/dist/security/alert-notifier.d.ts +0 -34
- package/dist/security/alert-notifier.d.ts.map +0 -1
- package/dist/security/alert-notifier.js +0 -136
- package/dist/security/alert-notifier.js.map +0 -1
- package/dist/security/audit-logger.d.ts +0 -34
- package/dist/security/audit-logger.d.ts.map +0 -1
- package/dist/security/audit-logger.js +0 -132
- package/dist/security/audit-logger.js.map +0 -1
- package/dist/security/backends/environment-backend.d.ts +0 -15
- package/dist/security/backends/environment-backend.d.ts.map +0 -1
- package/dist/security/backends/environment-backend.js +0 -56
- package/dist/security/backends/environment-backend.js.map +0 -1
- package/dist/security/fraud-detector.d.ts +0 -79
- package/dist/security/fraud-detector.d.ts.map +0 -1
- package/dist/security/fraud-detector.js +0 -147
- package/dist/security/fraud-detector.js.map +0 -1
- package/dist/security/key-manager-signer.d.ts +0 -15
- package/dist/security/key-manager-signer.d.ts.map +0 -1
- package/dist/security/key-manager-signer.js +0 -91
- package/dist/security/key-manager-signer.js.map +0 -1
- package/dist/security/key-manager.d.ts +0 -69
- package/dist/security/key-manager.d.ts.map +0 -1
- package/dist/security/key-manager.js +0 -79
- package/dist/security/key-manager.js.map +0 -1
- package/dist/security/key-rotation-manager.d.ts +0 -27
- package/dist/security/key-rotation-manager.d.ts.map +0 -1
- package/dist/security/key-rotation-manager.js +0 -142
- package/dist/security/key-rotation-manager.js.map +0 -1
- package/dist/security/rate-limit-config.d.ts +0 -7
- package/dist/security/rate-limit-config.d.ts.map +0 -1
- package/dist/security/rate-limit-config.js +0 -57
- package/dist/security/rate-limit-config.js.map +0 -1
- package/dist/security/rate-limiter.d.ts +0 -46
- package/dist/security/rate-limiter.d.ts.map +0 -1
- package/dist/security/rate-limiter.js +0 -170
- package/dist/security/rate-limiter.js.map +0 -1
- package/dist/security/reputation-tracker.d.ts +0 -30
- package/dist/security/reputation-tracker.d.ts.map +0 -1
- package/dist/security/reputation-tracker.js +0 -111
- package/dist/security/reputation-tracker.js.map +0 -1
- package/dist/security/rules/balance-manipulation-rule.d.ts +0 -23
- package/dist/security/rules/balance-manipulation-rule.d.ts.map +0 -1
- package/dist/security/rules/balance-manipulation-rule.js +0 -70
- package/dist/security/rules/balance-manipulation-rule.js.map +0 -1
- package/dist/security/rules/double-spend-detection-rule.d.ts +0 -23
- package/dist/security/rules/double-spend-detection-rule.d.ts.map +0 -1
- package/dist/security/rules/double-spend-detection-rule.js +0 -61
- package/dist/security/rules/double-spend-detection-rule.js.map +0 -1
- package/dist/security/rules/rapid-channel-closure-rule.d.ts +0 -16
- package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +0 -1
- package/dist/security/rules/rapid-channel-closure-rule.js +0 -57
- package/dist/security/rules/rapid-channel-closure-rule.js.map +0 -1
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts +0 -18
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +0 -1
- package/dist/security/rules/sudden-traffic-spike-rule.js +0 -92
- package/dist/security/rules/sudden-traffic-spike-rule.js.map +0 -1
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts +0 -12
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +0 -1
- package/dist/security/rules/unusual-settlement-amount-rule.js +0 -33
- package/dist/security/rules/unusual-settlement-amount-rule.js.map +0 -1
- package/dist/security/token-bucket.d.ts +0 -16
- package/dist/security/token-bucket.d.ts.map +0 -1
- package/dist/security/token-bucket.js +0 -49
- package/dist/security/token-bucket.js.map +0 -1
- package/dist/security/violation-counter.d.ts +0 -11
- package/dist/security/violation-counter.d.ts.map +0 -1
- package/dist/security/violation-counter.js +0 -61
- package/dist/security/violation-counter.js.map +0 -1
- package/dist/settlement/account-id-generator.d.ts +0 -4
- package/dist/settlement/account-id-generator.d.ts.map +0 -1
- package/dist/settlement/account-id-generator.js +0 -38
- package/dist/settlement/account-id-generator.js.map +0 -1
- package/dist/settlement/account-manager.d.ts +0 -51
- package/dist/settlement/account-manager.d.ts.map +0 -1
- package/dist/settlement/account-manager.js +0 -459
- package/dist/settlement/account-manager.js.map +0 -1
- package/dist/settlement/account-metadata.d.ts +0 -11
- package/dist/settlement/account-metadata.d.ts.map +0 -1
- package/dist/settlement/account-metadata.js +0 -40
- package/dist/settlement/account-metadata.js.map +0 -1
- package/dist/settlement/channel-manager.d.ts +0 -67
- package/dist/settlement/channel-manager.d.ts.map +0 -1
- package/dist/settlement/channel-manager.js +0 -226
- package/dist/settlement/channel-manager.js.map +0 -1
- package/dist/settlement/claim-receiver-db-schema.d.ts +0 -4
- package/dist/settlement/claim-receiver-db-schema.d.ts.map +0 -1
- package/dist/settlement/claim-receiver-db-schema.js +0 -25
- package/dist/settlement/claim-receiver-db-schema.js.map +0 -1
- package/dist/settlement/claim-receiver.d.ts +0 -67
- package/dist/settlement/claim-receiver.d.ts.map +0 -1
- package/dist/settlement/claim-receiver.js +0 -707
- package/dist/settlement/claim-receiver.js.map +0 -1
- package/dist/settlement/claim-redemption-service.d.ts +0 -39
- package/dist/settlement/claim-redemption-service.d.ts.map +0 -1
- package/dist/settlement/claim-redemption-service.js +0 -189
- package/dist/settlement/claim-redemption-service.js.map +0 -1
- package/dist/settlement/claim-sender-db-schema.d.ts +0 -3
- package/dist/settlement/claim-sender-db-schema.d.ts.map +0 -1
- package/dist/settlement/claim-sender-db-schema.js +0 -18
- package/dist/settlement/claim-sender-db-schema.js.map +0 -1
- package/dist/settlement/claim-sender.d.ts +0 -24
- package/dist/settlement/claim-sender.d.ts.map +0 -1
- package/dist/settlement/claim-sender.js +0 -146
- package/dist/settlement/claim-sender.js.map +0 -1
- package/dist/settlement/eip712-helper.d.ts +0 -13
- package/dist/settlement/eip712-helper.d.ts.map +0 -1
- package/dist/settlement/eip712-helper.js +0 -24
- package/dist/settlement/eip712-helper.js.map +0 -1
- package/dist/settlement/in-memory-ledger-client.d.ts +0 -40
- package/dist/settlement/in-memory-ledger-client.d.ts.map +0 -1
- package/dist/settlement/in-memory-ledger-client.js +0 -177
- package/dist/settlement/in-memory-ledger-client.js.map +0 -1
- package/dist/settlement/ledger-client.d.ts +0 -22
- package/dist/settlement/ledger-client.d.ts.map +0 -1
- package/dist/settlement/ledger-client.js +0 -3
- package/dist/settlement/ledger-client.js.map +0 -1
- package/dist/settlement/metrics-collector.d.ts +0 -29
- package/dist/settlement/metrics-collector.d.ts.map +0 -1
- package/dist/settlement/metrics-collector.js +0 -81
- package/dist/settlement/metrics-collector.js.map +0 -1
- package/dist/settlement/mina-payment-channel-sdk.d.ts +0 -73
- package/dist/settlement/mina-payment-channel-sdk.d.ts.map +0 -1
- package/dist/settlement/mina-payment-channel-sdk.js +0 -538
- package/dist/settlement/mina-payment-channel-sdk.js.map +0 -1
- package/dist/settlement/payment-channel-sdk.d.ts +0 -59
- package/dist/settlement/payment-channel-sdk.d.ts.map +0 -1
- package/dist/settlement/payment-channel-sdk.js +0 -677
- package/dist/settlement/payment-channel-sdk.js.map +0 -1
- package/dist/settlement/per-packet-claim-service.d.ts +0 -39
- package/dist/settlement/per-packet-claim-service.d.ts.map +0 -1
- package/dist/settlement/per-packet-claim-service.js +0 -342
- package/dist/settlement/per-packet-claim-service.js.map +0 -1
- package/dist/settlement/privacy/index.d.ts +0 -3
- package/dist/settlement/privacy/index.d.ts.map +0 -1
- package/dist/settlement/privacy/index.js +0 -11
- package/dist/settlement/privacy/index.js.map +0 -1
- package/dist/settlement/privacy/nip59-claim-wrapper.d.ts +0 -60
- package/dist/settlement/privacy/nip59-claim-wrapper.d.ts.map +0 -1
- package/dist/settlement/privacy/nip59-claim-wrapper.js +0 -361
- package/dist/settlement/privacy/nip59-claim-wrapper.js.map +0 -1
- package/dist/settlement/provider/chain-provider-registry.d.ts +0 -20
- package/dist/settlement/provider/chain-provider-registry.d.ts.map +0 -1
- package/dist/settlement/provider/chain-provider-registry.js +0 -53
- package/dist/settlement/provider/chain-provider-registry.js.map +0 -1
- package/dist/settlement/provider/evm-payment-channel-provider.d.ts +0 -31
- package/dist/settlement/provider/evm-payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/evm-payment-channel-provider.js +0 -207
- package/dist/settlement/provider/evm-payment-channel-provider.js.map +0 -1
- package/dist/settlement/provider/index.d.ts +0 -6
- package/dist/settlement/provider/index.d.ts.map +0 -1
- package/dist/settlement/provider/index.js +0 -16
- package/dist/settlement/provider/index.js.map +0 -1
- package/dist/settlement/provider/mina-payment-channel-provider.d.ts +0 -43
- package/dist/settlement/provider/mina-payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/mina-payment-channel-provider.js +0 -330
- package/dist/settlement/provider/mina-payment-channel-provider.js.map +0 -1
- package/dist/settlement/provider/payment-channel-provider.d.ts +0 -88
- package/dist/settlement/provider/payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/payment-channel-provider.js +0 -3
- package/dist/settlement/provider/payment-channel-provider.js.map +0 -1
- package/dist/settlement/provider/solana-payment-channel-provider.d.ts +0 -38
- package/dist/settlement/provider/solana-payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/solana-payment-channel-provider.js +0 -262
- package/dist/settlement/provider/solana-payment-channel-provider.js.map +0 -1
- package/dist/settlement/sent-claims-queries.d.ts +0 -23
- package/dist/settlement/sent-claims-queries.d.ts.map +0 -1
- package/dist/settlement/sent-claims-queries.js +0 -134
- package/dist/settlement/sent-claims-queries.js.map +0 -1
- package/dist/settlement/settlement-api.d.ts +0 -37
- package/dist/settlement/settlement-api.d.ts.map +0 -1
- package/dist/settlement/settlement-api.js +0 -172
- package/dist/settlement/settlement-api.js.map +0 -1
- package/dist/settlement/settlement-coordinator.d.ts +0 -47
- package/dist/settlement/settlement-coordinator.d.ts.map +0 -1
- package/dist/settlement/settlement-coordinator.js +0 -166
- package/dist/settlement/settlement-coordinator.js.map +0 -1
- package/dist/settlement/settlement-executor.d.ts +0 -51
- package/dist/settlement/settlement-executor.d.ts.map +0 -1
- package/dist/settlement/settlement-executor.js +0 -265
- package/dist/settlement/settlement-executor.js.map +0 -1
- package/dist/settlement/settlement-monitor.d.ts +0 -30
- package/dist/settlement/settlement-monitor.d.ts.map +0 -1
- package/dist/settlement/settlement-monitor.js +0 -141
- package/dist/settlement/settlement-monitor.js.map +0 -1
- package/dist/settlement/solana-payment-channel-sdk.d.ts +0 -79
- package/dist/settlement/solana-payment-channel-sdk.d.ts.map +0 -1
- package/dist/settlement/solana-payment-channel-sdk.js +0 -636
- package/dist/settlement/solana-payment-channel-sdk.js.map +0 -1
- package/dist/settlement/tigerbeetle-batch-writer.d.ts +0 -58
- package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +0 -1
- package/dist/settlement/tigerbeetle-batch-writer.js +0 -162
- package/dist/settlement/tigerbeetle-batch-writer.js.map +0 -1
- package/dist/settlement/tigerbeetle-client.d.ts +0 -40
- package/dist/settlement/tigerbeetle-client.d.ts.map +0 -1
- package/dist/settlement/tigerbeetle-client.js +0 -279
- package/dist/settlement/tigerbeetle-client.js.map +0 -1
- package/dist/settlement/tigerbeetle-errors.d.ts +0 -23
- package/dist/settlement/tigerbeetle-errors.d.ts.map +0 -1
- package/dist/settlement/tigerbeetle-errors.js +0 -58
- package/dist/settlement/tigerbeetle-errors.js.map +0 -1
- package/dist/settlement/types.d.ts +0 -64
- package/dist/settlement/types.d.ts.map +0 -1
- package/dist/settlement/types.js +0 -42
- package/dist/settlement/types.js.map +0 -1
- package/dist/settlement/unified-settlement-executor.d.ts +0 -34
- package/dist/settlement/unified-settlement-executor.d.ts.map +0 -1
- package/dist/settlement/unified-settlement-executor.js +0 -145
- package/dist/settlement/unified-settlement-executor.js.map +0 -1
- package/dist/test-utils/index.d.ts +0 -3
- package/dist/test-utils/index.d.ts.map +0 -1
- package/dist/test-utils/index.js +0 -15
- package/dist/test-utils/index.js.map +0 -1
- package/dist/test-utils/isolated-test-env.d.ts +0 -31
- package/dist/test-utils/isolated-test-env.d.ts.map +0 -1
- package/dist/test-utils/isolated-test-env.js +0 -127
- package/dist/test-utils/isolated-test-env.js.map +0 -1
- package/dist/test-utils/mock-factories-patch.d.ts +0 -2
- package/dist/test-utils/mock-factories-patch.d.ts.map +0 -1
- package/dist/test-utils/mock-factories-patch.js +0 -3
- package/dist/test-utils/mock-factories-patch.js.map +0 -1
- package/dist/test-utils/mock-factories.d.ts +0 -22
- package/dist/test-utils/mock-factories.d.ts.map +0 -1
- package/dist/test-utils/mock-factories.js +0 -56
- package/dist/test-utils/mock-factories.js.map +0 -1
- package/dist/transport/direct-transport-provider.d.ts +0 -12
- package/dist/transport/direct-transport-provider.d.ts.map +0 -1
- package/dist/transport/direct-transport-provider.js +0 -27
- package/dist/transport/direct-transport-provider.js.map +0 -1
- package/dist/transport/index.d.ts +0 -7
- package/dist/transport/index.d.ts.map +0 -1
- package/dist/transport/index.js +0 -16
- package/dist/transport/index.js.map +0 -1
- package/dist/transport/managed-anon-client.d.ts +0 -47
- package/dist/transport/managed-anon-client.d.ts.map +0 -1
- package/dist/transport/managed-anon-client.js +0 -265
- package/dist/transport/managed-anon-client.js.map +0 -1
- package/dist/transport/probe-tcp-port.d.ts +0 -3
- package/dist/transport/probe-tcp-port.d.ts.map +0 -1
- package/dist/transport/probe-tcp-port.js +0 -59
- package/dist/transport/probe-tcp-port.js.map +0 -1
- package/dist/transport/socks-transport-provider.d.ts +0 -29
- package/dist/transport/socks-transport-provider.d.ts.map +0 -1
- package/dist/transport/socks-transport-provider.js +0 -136
- package/dist/transport/socks-transport-provider.js.map +0 -1
- package/dist/transport/socks-url.d.ts +0 -6
- package/dist/transport/socks-url.d.ts.map +0 -1
- package/dist/transport/socks-url.js +0 -29
- package/dist/transport/socks-url.js.map +0 -1
- package/dist/transport/transport-provider.d.ts +0 -9
- package/dist/transport/transport-provider.d.ts.map +0 -1
- package/dist/transport/transport-provider.js +0 -3
- package/dist/transport/transport-provider.js.map +0 -1
- package/dist/utils/connection-pool.d.ts +0 -42
- package/dist/utils/connection-pool.d.ts.map +0 -1
- package/dist/utils/connection-pool.js +0 -209
- package/dist/utils/connection-pool.js.map +0 -1
- package/dist/utils/evm-rpc-connection-pool.d.ts +0 -8
- package/dist/utils/evm-rpc-connection-pool.d.ts.map +0 -1
- package/dist/utils/evm-rpc-connection-pool.js +0 -40
- package/dist/utils/evm-rpc-connection-pool.js.map +0 -1
- package/dist/utils/logger.d.ts +0 -6
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js +0 -58
- package/dist/utils/logger.js.map +0 -1
- package/dist/utils/optional-require.d.ts +0 -2
- package/dist/utils/optional-require.d.ts.map +0 -1
- package/dist/utils/optional-require.js +0 -54
- package/dist/utils/optional-require.js.map +0 -1
- package/dist/utils/redact.d.ts +0 -3
- package/dist/utils/redact.d.ts.map +0 -1
- package/dist/utils/redact.js +0 -21
- package/dist/utils/redact.js.map +0 -1
- package/dist/wallet/audit-logger.d.ts +0 -22
- package/dist/wallet/audit-logger.d.ts.map +0 -1
- package/dist/wallet/audit-logger.js +0 -120
- package/dist/wallet/audit-logger.js.map +0 -1
- package/dist/wallet/fraud-detector-interface.d.ts +0 -14
- package/dist/wallet/fraud-detector-interface.d.ts.map +0 -1
- package/dist/wallet/fraud-detector-interface.js +0 -3
- package/dist/wallet/fraud-detector-interface.js.map +0 -1
- package/dist/wallet/key-manager.d.ts +0 -6
- package/dist/wallet/key-manager.d.ts.map +0 -1
- package/dist/wallet/key-manager.js +0 -3
- package/dist/wallet/key-manager.js.map +0 -1
- package/dist/wallet/placeholder-fraud-detector.d.ts +0 -10
- package/dist/wallet/placeholder-fraud-detector.d.ts.map +0 -1
- package/dist/wallet/placeholder-fraud-detector.js +0 -10
- package/dist/wallet/placeholder-fraud-detector.js.map +0 -1
- package/dist/wallet/rate-limiter.d.ts +0 -26
- package/dist/wallet/rate-limiter.d.ts.map +0 -1
- package/dist/wallet/rate-limiter.js +0 -114
- package/dist/wallet/rate-limiter.js.map +0 -1
- package/dist/wallet/suspicious-activity-detector.d.ts +0 -25
- package/dist/wallet/suspicious-activity-detector.d.ts.map +0 -1
- package/dist/wallet/suspicious-activity-detector.js +0 -97
- package/dist/wallet/suspicious-activity-detector.js.map +0 -1
- package/dist/wallet/treasury-wallet.d.ts +0 -20
- package/dist/wallet/treasury-wallet.d.ts.map +0 -1
- package/dist/wallet/treasury-wallet.js +0 -151
- package/dist/wallet/treasury-wallet.js.map +0 -1
- package/dist/wallet/wallet-authentication.d.ts +0 -31
- package/dist/wallet/wallet-authentication.d.ts.map +0 -1
- package/dist/wallet/wallet-authentication.js +0 -102
- package/dist/wallet/wallet-authentication.js.map +0 -1
- package/dist/wallet/wallet-db-schema.d.ts +0 -11
- package/dist/wallet/wallet-db-schema.d.ts.map +0 -1
- package/dist/wallet/wallet-db-schema.js +0 -79
- package/dist/wallet/wallet-db-schema.js.map +0 -1
- package/dist/wallet/wallet-security.d.ts +0 -58
- package/dist/wallet/wallet-security.d.ts.map +0 -1
- package/dist/wallet/wallet-security.js +0 -148
- package/dist/wallet/wallet-security.js.map +0 -1
- package/dist/wallet/wallet-seed-manager.d.ts +0 -65
- package/dist/wallet/wallet-seed-manager.d.ts.map +0 -1
- package/dist/wallet/wallet-seed-manager.js +0 -418
- package/dist/wallet/wallet-seed-manager.js.map +0 -1
|
@@ -1,170 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rate-limiter.js","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,30 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,111 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"reputation-tracker.js","sourceRoot":"","sources":["../../src/security/reputation-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,23 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,70 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,23 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,61 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,16 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,57 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|