@toon-protocol/connector 2.6.1 → 3.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +1 -1
- 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,15 +0,0 @@
|
|
|
1
|
-
import type { KeyManager } from './key-manager';
|
|
2
|
-
import type { Provider, TransactionRequest, Signer, TypedDataDomain, TypedDataField, TransactionResponse } from 'ethers';
|
|
3
|
-
export interface IKeyManagerSigner extends Signer {
|
|
4
|
-
getAddress(): Promise<string>;
|
|
5
|
-
signTransaction(transaction: TransactionRequest): Promise<string>;
|
|
6
|
-
sendTransaction(transaction: TransactionRequest): Promise<TransactionResponse>;
|
|
7
|
-
signMessage(message: string | Uint8Array): Promise<string>;
|
|
8
|
-
signTypedData(domain: TypedDataDomain, types: Record<string, TypedDataField[]>, value: Record<string, any>): Promise<string>;
|
|
9
|
-
connect(provider: Provider): IKeyManagerSigner;
|
|
10
|
-
}
|
|
11
|
-
export declare function createKeyManagerSigner(keyManager: KeyManager, evmKeyId: string, provider?: Provider): Promise<IKeyManagerSigner>;
|
|
12
|
-
export declare const KeyManagerSigner: {
|
|
13
|
-
new (keyManager: KeyManager, evmKeyId: string, provider?: Provider): IKeyManagerSigner;
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=key-manager-signer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-manager-signer.d.ts","sourceRoot":"","sources":["../../src/security/key-manager-signer.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,KAAK,EACV,QAAQ,EACR,kBAAkB,EAClB,MAAM,EACN,eAAe,EACf,cAAc,EACd,mBAAmB,EACpB,MAAM,QAAQ,CAAC;AAOhB,MAAM,WAAW,iBAAkB,SAAQ,MAAM;IAC/C,UAAU,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;IAC9B,eAAe,CAAC,WAAW,EAAE,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAClE,eAAe,CAAC,WAAW,EAAE,kBAAkB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAC/E,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC3D,aAAa,CACX,MAAM,EAAE,eAAe,EACvB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,EAAE,CAAC,EAEvC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACzB,OAAO,CAAC,MAAM,CAAC,CAAC;IACnB,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,iBAAiB,CAAC;CAChD;AAWD,wBAAsB,sBAAsB,CAC1C,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,MAAM,EAChB,QAAQ,CAAC,EAAE,QAAQ,GAClB,OAAO,CAAC,iBAAiB,CAAC,CAuL5B;AAOD,eAAO,MAAM,gBAAgB,EAAsB;IACjD,KAAK,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,QAAQ,GAAG,iBAAiB,CAAC;CACxF,CAAC"}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.KeyManagerSigner = void 0;
|
|
4
|
-
exports.createKeyManagerSigner = createKeyManagerSigner;
|
|
5
|
-
const optional_require_1 = require("../utils/optional-require");
|
|
6
|
-
async function createKeyManagerSigner(keyManager, evmKeyId, provider) {
|
|
7
|
-
const { ethers } = await (0, optional_require_1.requireOptional)('ethers', 'EVM settlement');
|
|
8
|
-
class KeyManagerSignerImpl extends ethers.AbstractSigner {
|
|
9
|
-
keyManager;
|
|
10
|
-
evmKeyId;
|
|
11
|
-
_cachedAddress = null;
|
|
12
|
-
constructor(km, keyId, p) {
|
|
13
|
-
super(p);
|
|
14
|
-
this.keyManager = km;
|
|
15
|
-
this.evmKeyId = keyId;
|
|
16
|
-
}
|
|
17
|
-
async getAddress() {
|
|
18
|
-
if (this._cachedAddress) {
|
|
19
|
-
return this._cachedAddress;
|
|
20
|
-
}
|
|
21
|
-
const publicKeyBuffer = await this.keyManager.getPublicKey(this.evmKeyId);
|
|
22
|
-
const publicKeyHex = '0x' + publicKeyBuffer.toString('hex');
|
|
23
|
-
const pubKeyWithoutPrefix = publicKeyHex.startsWith('0x04')
|
|
24
|
-
? '0x' + publicKeyHex.slice(4)
|
|
25
|
-
: publicKeyHex;
|
|
26
|
-
const addressHash = ethers.keccak256(pubKeyWithoutPrefix);
|
|
27
|
-
this._cachedAddress = ethers.getAddress('0x' + addressHash.slice(-40));
|
|
28
|
-
return this._cachedAddress;
|
|
29
|
-
}
|
|
30
|
-
async signTransaction(transaction) {
|
|
31
|
-
const resolved = await ethers.resolveProperties(transaction);
|
|
32
|
-
const tx = ethers.Transaction.from(resolved);
|
|
33
|
-
const digest = tx.unsignedHash;
|
|
34
|
-
const signatureBuffer = await this.keyManager.sign(Buffer.from(digest.slice(2), 'hex'), this.evmKeyId);
|
|
35
|
-
const signature = ethers.Signature.from('0x' + signatureBuffer.toString('hex'));
|
|
36
|
-
tx.signature = signature;
|
|
37
|
-
return tx.serialized;
|
|
38
|
-
}
|
|
39
|
-
async sendTransaction(transaction) {
|
|
40
|
-
const provider = this.provider;
|
|
41
|
-
if (!provider) {
|
|
42
|
-
throw new Error('Provider required to send transaction');
|
|
43
|
-
}
|
|
44
|
-
const from = await this.getAddress();
|
|
45
|
-
const network = await provider.getNetwork();
|
|
46
|
-
const chainId = Number(network.chainId);
|
|
47
|
-
const feeData = await provider.getFeeData();
|
|
48
|
-
if (!feeData.maxFeePerGas || !feeData.maxPriorityFeePerGas) {
|
|
49
|
-
throw new Error('Unable to retrieve EIP-1559 fee data from provider');
|
|
50
|
-
}
|
|
51
|
-
const populatedTx = await ethers.resolveProperties({
|
|
52
|
-
to: transaction.to,
|
|
53
|
-
nonce: transaction.nonce !== undefined
|
|
54
|
-
? transaction.nonce
|
|
55
|
-
: await provider.getTransactionCount(from, 'pending'),
|
|
56
|
-
gasLimit: transaction.gasLimit !== undefined
|
|
57
|
-
? transaction.gasLimit
|
|
58
|
-
: await provider.estimateGas({
|
|
59
|
-
...transaction,
|
|
60
|
-
from: from,
|
|
61
|
-
}),
|
|
62
|
-
data: transaction.data ?? '0x',
|
|
63
|
-
value: transaction.value ?? 0,
|
|
64
|
-
chainId: transaction.chainId ?? chainId,
|
|
65
|
-
type: 2,
|
|
66
|
-
maxFeePerGas: transaction.maxFeePerGas ?? feeData.maxFeePerGas,
|
|
67
|
-
maxPriorityFeePerGas: transaction.maxPriorityFeePerGas ?? feeData.maxPriorityFeePerGas,
|
|
68
|
-
});
|
|
69
|
-
const signedTx = await this.signTransaction(populatedTx);
|
|
70
|
-
const txResponse = await provider.broadcastTransaction(signedTx);
|
|
71
|
-
return txResponse;
|
|
72
|
-
}
|
|
73
|
-
async signMessage(message) {
|
|
74
|
-
const messageBytes = typeof message === 'string' ? ethers.toUtf8Bytes(message) : message;
|
|
75
|
-
const messageHash = ethers.hashMessage(messageBytes);
|
|
76
|
-
const signatureBuffer = await this.keyManager.sign(Buffer.from(messageHash.slice(2), 'hex'), this.evmKeyId);
|
|
77
|
-
return '0x' + signatureBuffer.toString('hex');
|
|
78
|
-
}
|
|
79
|
-
async signTypedData(domain, types, value) {
|
|
80
|
-
const hash = ethers.TypedDataEncoder.hash(domain, types, value);
|
|
81
|
-
const signatureBuffer = await this.keyManager.sign(Buffer.from(hash.slice(2), 'hex'), this.evmKeyId);
|
|
82
|
-
return '0x' + signatureBuffer.toString('hex');
|
|
83
|
-
}
|
|
84
|
-
connect(provider) {
|
|
85
|
-
return new KeyManagerSignerImpl(this.keyManager, this.evmKeyId, provider);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
return new KeyManagerSignerImpl(keyManager, evmKeyId, provider);
|
|
89
|
-
}
|
|
90
|
-
exports.KeyManagerSigner = null;
|
|
91
|
-
//# sourceMappingURL=key-manager-signer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-manager-signer.js","sourceRoot":"","sources":["../../src/security/key-manager-signer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
import { Logger } from 'pino';
|
|
2
|
-
export interface KeyManagerBackend {
|
|
3
|
-
sign(message: Buffer, keyId: string): Promise<Buffer>;
|
|
4
|
-
getPublicKey(keyId: string): Promise<Buffer>;
|
|
5
|
-
rotateKey(keyId: string): Promise<string>;
|
|
6
|
-
}
|
|
7
|
-
export interface AWSConfig {
|
|
8
|
-
region: string;
|
|
9
|
-
evmKeyId: string;
|
|
10
|
-
credentials?: {
|
|
11
|
-
accessKeyId: string;
|
|
12
|
-
secretAccessKey: string;
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
export interface GCPConfig {
|
|
16
|
-
projectId: string;
|
|
17
|
-
locationId: string;
|
|
18
|
-
keyRingId: string;
|
|
19
|
-
evmKeyId: string;
|
|
20
|
-
}
|
|
21
|
-
export interface AzureConfig {
|
|
22
|
-
vaultUrl: string;
|
|
23
|
-
evmKeyName: string;
|
|
24
|
-
credentials?: {
|
|
25
|
-
tenantId: string;
|
|
26
|
-
clientId: string;
|
|
27
|
-
clientSecret: string;
|
|
28
|
-
};
|
|
29
|
-
}
|
|
30
|
-
export interface HSMConfig {
|
|
31
|
-
pkcs11LibraryPath: string;
|
|
32
|
-
slotId: number;
|
|
33
|
-
pin: string;
|
|
34
|
-
evmKeyLabel: string;
|
|
35
|
-
}
|
|
36
|
-
export interface KeyRotationConfig {
|
|
37
|
-
enabled: boolean;
|
|
38
|
-
intervalDays: number;
|
|
39
|
-
overlapDays: number;
|
|
40
|
-
notifyBeforeDays: number;
|
|
41
|
-
}
|
|
42
|
-
export interface KeyManagerConfig {
|
|
43
|
-
backend: 'env' | 'aws-kms' | 'gcp-kms' | 'azure-kv' | 'hsm';
|
|
44
|
-
nodeId: string;
|
|
45
|
-
evmPrivateKey?: string;
|
|
46
|
-
aws?: AWSConfig;
|
|
47
|
-
gcp?: GCPConfig;
|
|
48
|
-
azure?: AzureConfig;
|
|
49
|
-
hsm?: HSMConfig;
|
|
50
|
-
rotation?: KeyRotationConfig;
|
|
51
|
-
}
|
|
52
|
-
export interface AuditLogEntry {
|
|
53
|
-
event: 'SIGN_REQUEST' | 'SIGN_SUCCESS' | 'SIGN_FAILURE' | 'KEY_ROTATION_START' | 'KEY_ROTATION_COMPLETE' | 'KEY_ACCESS_DENIED';
|
|
54
|
-
keyId: string;
|
|
55
|
-
timestamp: number;
|
|
56
|
-
nodeId: string;
|
|
57
|
-
backend: string;
|
|
58
|
-
details?: Record<string, unknown>;
|
|
59
|
-
}
|
|
60
|
-
export declare class KeyManager {
|
|
61
|
-
private backend;
|
|
62
|
-
private logger;
|
|
63
|
-
private auditLogger;
|
|
64
|
-
constructor(config: KeyManagerConfig, logger: Logger);
|
|
65
|
-
sign(message: Buffer, keyId: string): Promise<Buffer>;
|
|
66
|
-
getPublicKey(keyId: string): Promise<Buffer>;
|
|
67
|
-
rotateKey(keyId: string): Promise<string>;
|
|
68
|
-
}
|
|
69
|
-
//# sourceMappingURL=key-manager.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-manager.d.ts","sourceRoot":"","sources":["../../src/security/key-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAO9B,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACtD,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7C,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CAC3C;AAKD,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE;QACZ,WAAW,EAAE,MAAM,CAAC;QACpB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAKD,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAKD,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE;QACZ,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC;CACH;AAKD,MAAM,WAAW,SAAS;IACxB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,WAAW,EAAE,MAAM,CAAC;CACrB;AAKD,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAKD,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,KAAK,GAAG,SAAS,GAAG,SAAS,GAAG,UAAU,GAAG,KAAK,CAAC;IAC5D,MAAM,EAAE,MAAM,CAAC;IAGf,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,GAAG,CAAC,EAAE,SAAS,CAAC;IAChB,QAAQ,CAAC,EAAE,iBAAiB,CAAC;CAC9B;AAKD,MAAM,WAAW,aAAa;IAC5B,KAAK,EACD,cAAc,GACd,cAAc,GACd,cAAc,GACd,oBAAoB,GACpB,uBAAuB,GACvB,mBAAmB,CAAC;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACnC;AAMD,qBAAa,UAAU;IACrB,OAAO,CAAC,OAAO,CAAoB;IACnC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,WAAW,CAAc;gBAErB,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM;IAyC9C,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IA6BrD,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAkB5C,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAkBhD"}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.KeyManager = void 0;
|
|
4
|
-
const audit_logger_1 = require("./audit-logger");
|
|
5
|
-
class KeyManager {
|
|
6
|
-
backend;
|
|
7
|
-
logger;
|
|
8
|
-
auditLogger;
|
|
9
|
-
constructor(config, logger) {
|
|
10
|
-
this.logger = logger.child({ component: 'KeyManager' });
|
|
11
|
-
this.auditLogger = new audit_logger_1.AuditLogger(logger, {
|
|
12
|
-
nodeId: config.nodeId,
|
|
13
|
-
backend: config.backend,
|
|
14
|
-
});
|
|
15
|
-
switch (config.backend) {
|
|
16
|
-
case 'env': {
|
|
17
|
-
const { EnvironmentVariableBackend } = require('./backends/environment-backend');
|
|
18
|
-
this.backend = new EnvironmentVariableBackend(this.logger, {
|
|
19
|
-
evmPrivateKey: config.evmPrivateKey,
|
|
20
|
-
});
|
|
21
|
-
break;
|
|
22
|
-
}
|
|
23
|
-
case 'aws-kms':
|
|
24
|
-
case 'gcp-kms':
|
|
25
|
-
case 'azure-kv':
|
|
26
|
-
case 'hsm': {
|
|
27
|
-
throw new Error(`Backend type '${config.backend}' is not supported. Only 'env' backend is available.`);
|
|
28
|
-
}
|
|
29
|
-
default:
|
|
30
|
-
throw new Error(`Unknown backend type: ${config.backend}`);
|
|
31
|
-
}
|
|
32
|
-
this.logger.info({ backend: config.backend }, 'KeyManager initialized');
|
|
33
|
-
}
|
|
34
|
-
async sign(message, keyId) {
|
|
35
|
-
const messageHash = message.toString('hex');
|
|
36
|
-
this.auditLogger.logSignRequest(keyId, messageHash);
|
|
37
|
-
this.logger.debug({ keyId, messageLength: message.length }, 'Signing message');
|
|
38
|
-
try {
|
|
39
|
-
const signature = await this.backend.sign(message, keyId);
|
|
40
|
-
const signatureHash = signature.toString('hex');
|
|
41
|
-
this.auditLogger.logSignSuccess(keyId, signatureHash);
|
|
42
|
-
this.logger.info({ keyId, signatureLength: signature.length }, 'Message signed successfully');
|
|
43
|
-
return signature;
|
|
44
|
-
}
|
|
45
|
-
catch (error) {
|
|
46
|
-
this.auditLogger.logSignFailure(keyId, error);
|
|
47
|
-
this.logger.error({ keyId, error }, 'Message signing failed');
|
|
48
|
-
throw error;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
async getPublicKey(keyId) {
|
|
52
|
-
this.logger.debug({ keyId }, 'Retrieving public key');
|
|
53
|
-
try {
|
|
54
|
-
const publicKey = await this.backend.getPublicKey(keyId);
|
|
55
|
-
this.logger.info({ keyId, publicKeyLength: publicKey.length }, 'Public key retrieved');
|
|
56
|
-
return publicKey;
|
|
57
|
-
}
|
|
58
|
-
catch (error) {
|
|
59
|
-
this.logger.error({ keyId, error }, 'Public key retrieval failed');
|
|
60
|
-
throw error;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
async rotateKey(keyId) {
|
|
64
|
-
this.auditLogger.logKeyRotation(keyId, '', 'START');
|
|
65
|
-
this.logger.info({ keyId }, 'Starting key rotation');
|
|
66
|
-
try {
|
|
67
|
-
const newKeyId = await this.backend.rotateKey(keyId);
|
|
68
|
-
this.auditLogger.logKeyRotation(keyId, newKeyId, 'COMPLETE');
|
|
69
|
-
this.logger.info({ oldKeyId: keyId, newKeyId }, 'Key rotation completed');
|
|
70
|
-
return newKeyId;
|
|
71
|
-
}
|
|
72
|
-
catch (error) {
|
|
73
|
-
this.logger.error({ keyId, error }, 'Key rotation failed');
|
|
74
|
-
throw error;
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
exports.KeyManager = KeyManager;
|
|
79
|
-
//# sourceMappingURL=key-manager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-manager.js","sourceRoot":"","sources":["../../src/security/key-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { KeyManager, KeyRotationConfig } from './key-manager';
|
|
2
|
-
import { Logger } from 'pino';
|
|
3
|
-
export interface KeyRotationMetadata {
|
|
4
|
-
oldKeyId: string;
|
|
5
|
-
newKeyId: string;
|
|
6
|
-
rotationDate: number;
|
|
7
|
-
overlapEndsAt: number;
|
|
8
|
-
}
|
|
9
|
-
export declare class KeyRotationManager {
|
|
10
|
-
private readonly keyManager;
|
|
11
|
-
private readonly config;
|
|
12
|
-
private readonly logger;
|
|
13
|
-
private rotationTimer?;
|
|
14
|
-
private notificationTimer?;
|
|
15
|
-
private rotationMetadata;
|
|
16
|
-
constructor(keyManager: KeyManager, config: KeyRotationConfig, logger: Logger);
|
|
17
|
-
start(): void;
|
|
18
|
-
stop(): void;
|
|
19
|
-
private checkNotificationNeeded;
|
|
20
|
-
rotateKey(keyId: string): Promise<string>;
|
|
21
|
-
private scheduleOverlapCleanup;
|
|
22
|
-
private disableOldKey;
|
|
23
|
-
isKeyValid(keyId: string): boolean;
|
|
24
|
-
getRotationMetadata(keyId: string): KeyRotationMetadata | undefined;
|
|
25
|
-
getAllRotationMetadata(): Map<string, KeyRotationMetadata>;
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=key-rotation-manager.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-rotation-manager.d.ts","sourceRoot":"","sources":["../../src/security/key-rotation-manager.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAM9B,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;CACvB;AAWD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IACxC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAC3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,aAAa,CAAC,CAAiB;IACvC,OAAO,CAAC,iBAAiB,CAAC,CAAiB;IAC3C,OAAO,CAAC,gBAAgB,CAA+C;gBAS3D,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM;IA2B7E,KAAK,IAAI,IAAI;IAyCb,IAAI,IAAI,IAAI;IAkBZ,OAAO,CAAC,uBAAuB;IA0BzB,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAiD/C,OAAO,CAAC,sBAAsB;IA8B9B,OAAO,CAAC,aAAa;IA6BrB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IA0BlC,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,mBAAmB,GAAG,SAAS;IAsBnE,sBAAsB,IAAI,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC;CAG3D"}
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.KeyRotationManager = void 0;
|
|
4
|
-
class KeyRotationManager {
|
|
5
|
-
keyManager;
|
|
6
|
-
config;
|
|
7
|
-
logger;
|
|
8
|
-
rotationTimer;
|
|
9
|
-
notificationTimer;
|
|
10
|
-
rotationMetadata = new Map();
|
|
11
|
-
constructor(keyManager, config, logger) {
|
|
12
|
-
this.keyManager = keyManager;
|
|
13
|
-
this.config = config;
|
|
14
|
-
this.logger = logger.child({ component: 'KeyRotationManager' });
|
|
15
|
-
if (config.intervalDays <= 0) {
|
|
16
|
-
throw new Error('Rotation interval must be positive');
|
|
17
|
-
}
|
|
18
|
-
if (config.overlapDays < 0) {
|
|
19
|
-
throw new Error('Overlap days must be non-negative');
|
|
20
|
-
}
|
|
21
|
-
if (config.notifyBeforeDays < 0) {
|
|
22
|
-
throw new Error('Notification days must be non-negative');
|
|
23
|
-
}
|
|
24
|
-
if (config.overlapDays >= config.intervalDays) {
|
|
25
|
-
throw new Error('Overlap period must be less than rotation interval');
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
start() {
|
|
29
|
-
if (!this.config.enabled) {
|
|
30
|
-
this.logger.info('Key rotation is disabled in configuration');
|
|
31
|
-
return;
|
|
32
|
-
}
|
|
33
|
-
this.stop();
|
|
34
|
-
const rotationIntervalMs = this.config.intervalDays * 24 * 60 * 60 * 1000;
|
|
35
|
-
this.rotationTimer = setInterval(() => {
|
|
36
|
-
this.logger.info('Rotation timer triggered - checking for keys to rotate');
|
|
37
|
-
}, rotationIntervalMs);
|
|
38
|
-
const dailyCheckMs = 24 * 60 * 60 * 1000;
|
|
39
|
-
this.notificationTimer = setInterval(() => {
|
|
40
|
-
this.checkNotificationNeeded();
|
|
41
|
-
}, dailyCheckMs);
|
|
42
|
-
this.logger.info({
|
|
43
|
-
rotationIntervalDays: this.config.intervalDays,
|
|
44
|
-
overlapDays: this.config.overlapDays,
|
|
45
|
-
notifyBeforeDays: this.config.notifyBeforeDays,
|
|
46
|
-
}, 'Key rotation scheduler started');
|
|
47
|
-
}
|
|
48
|
-
stop() {
|
|
49
|
-
if (this.rotationTimer) {
|
|
50
|
-
clearInterval(this.rotationTimer);
|
|
51
|
-
this.rotationTimer = undefined;
|
|
52
|
-
}
|
|
53
|
-
if (this.notificationTimer) {
|
|
54
|
-
clearInterval(this.notificationTimer);
|
|
55
|
-
this.notificationTimer = undefined;
|
|
56
|
-
}
|
|
57
|
-
this.logger.info('Key rotation scheduler stopped');
|
|
58
|
-
}
|
|
59
|
-
checkNotificationNeeded() {
|
|
60
|
-
this.logger.debug('Checking if rotation notifications needed');
|
|
61
|
-
}
|
|
62
|
-
async rotateKey(keyId) {
|
|
63
|
-
this.logger.info({ keyId }, 'Starting key rotation');
|
|
64
|
-
try {
|
|
65
|
-
const newKeyId = await this.keyManager.rotateKey(keyId);
|
|
66
|
-
const rotationDate = Date.now();
|
|
67
|
-
const overlapEndsAt = rotationDate + this.config.overlapDays * 24 * 60 * 60 * 1000;
|
|
68
|
-
const metadata = {
|
|
69
|
-
oldKeyId: keyId,
|
|
70
|
-
newKeyId,
|
|
71
|
-
rotationDate,
|
|
72
|
-
overlapEndsAt,
|
|
73
|
-
};
|
|
74
|
-
this.rotationMetadata.set(newKeyId, metadata);
|
|
75
|
-
this.logger.info({
|
|
76
|
-
oldKeyId: keyId,
|
|
77
|
-
newKeyId,
|
|
78
|
-
rotationDate: new Date(rotationDate).toISOString(),
|
|
79
|
-
overlapEndsAt: new Date(overlapEndsAt).toISOString(),
|
|
80
|
-
overlapDays: this.config.overlapDays,
|
|
81
|
-
}, 'Key rotation completed - overlap period started');
|
|
82
|
-
this.scheduleOverlapCleanup(keyId, newKeyId, overlapEndsAt);
|
|
83
|
-
return newKeyId;
|
|
84
|
-
}
|
|
85
|
-
catch (error) {
|
|
86
|
-
this.logger.error({ keyId, error }, 'Key rotation failed');
|
|
87
|
-
throw error;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
scheduleOverlapCleanup(oldKeyId, newKeyId, overlapEndsAt) {
|
|
91
|
-
const delayMs = overlapEndsAt - Date.now();
|
|
92
|
-
if (delayMs <= 0) {
|
|
93
|
-
this.disableOldKey(oldKeyId, newKeyId);
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
setTimeout(() => {
|
|
97
|
-
this.disableOldKey(oldKeyId, newKeyId);
|
|
98
|
-
}, delayMs);
|
|
99
|
-
this.logger.debug({
|
|
100
|
-
oldKeyId,
|
|
101
|
-
newKeyId,
|
|
102
|
-
overlapEndsAt: new Date(overlapEndsAt).toISOString(),
|
|
103
|
-
delayMs,
|
|
104
|
-
}, 'Scheduled old key cleanup after overlap period');
|
|
105
|
-
}
|
|
106
|
-
disableOldKey(oldKeyId, newKeyId) {
|
|
107
|
-
this.logger.info({
|
|
108
|
-
oldKeyId,
|
|
109
|
-
newKeyId,
|
|
110
|
-
}, 'Overlap period expired - disabling old key');
|
|
111
|
-
this.rotationMetadata.delete(newKeyId);
|
|
112
|
-
}
|
|
113
|
-
isKeyValid(keyId) {
|
|
114
|
-
const metadata = this.rotationMetadata.get(keyId);
|
|
115
|
-
if (metadata) {
|
|
116
|
-
return true;
|
|
117
|
-
}
|
|
118
|
-
for (const [, meta] of this.rotationMetadata.entries()) {
|
|
119
|
-
if (meta.oldKeyId === keyId) {
|
|
120
|
-
return Date.now() < meta.overlapEndsAt;
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
return true;
|
|
124
|
-
}
|
|
125
|
-
getRotationMetadata(keyId) {
|
|
126
|
-
const metadata = this.rotationMetadata.get(keyId);
|
|
127
|
-
if (metadata) {
|
|
128
|
-
return metadata;
|
|
129
|
-
}
|
|
130
|
-
for (const [, meta] of this.rotationMetadata.entries()) {
|
|
131
|
-
if (meta.oldKeyId === keyId) {
|
|
132
|
-
return meta;
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
return undefined;
|
|
136
|
-
}
|
|
137
|
-
getAllRotationMetadata() {
|
|
138
|
-
return new Map(this.rotationMetadata);
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
exports.KeyRotationManager = KeyRotationManager;
|
|
142
|
-
//# sourceMappingURL=key-rotation-manager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"key-rotation-manager.js","sourceRoot":"","sources":["../../src/security/key-rotation-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import type { RateLimitConfig, PeerRateLimitConfig } from './rate-limiter';
|
|
2
|
-
export declare const DEFAULT_RATE_LIMIT_CONFIG: RateLimitConfig;
|
|
3
|
-
export declare function createRateLimitConfig(overrides?: Partial<RateLimitConfig>): RateLimitConfig;
|
|
4
|
-
export declare function addTrustedPeer(config: RateLimitConfig, peerId: string): RateLimitConfig;
|
|
5
|
-
export declare function setPeerLimit(config: RateLimitConfig, peerId: string, peerConfig: PeerRateLimitConfig): RateLimitConfig;
|
|
6
|
-
export declare function isRateLimitingEnabled(): boolean;
|
|
7
|
-
//# sourceMappingURL=rate-limit-config.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rate-limit-config.d.ts","sourceRoot":"","sources":["../../src/security/rate-limit-config.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAK3E,eAAO,MAAM,yBAAyB,EAAE,eAQvC,CAAC;AAKF,wBAAgB,qBAAqB,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,eAAe,CAAC,GAAG,eAAe,CAK3F;AAKD,wBAAgB,cAAc,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,GAAG,eAAe,CAOvF;AAKD,wBAAgB,YAAY,CAC1B,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,mBAAmB,GAC9B,eAAe,CAOjB;AA8BD,wBAAgB,qBAAqB,IAAI,OAAO,CAE/C"}
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DEFAULT_RATE_LIMIT_CONFIG = void 0;
|
|
4
|
-
exports.createRateLimitConfig = createRateLimitConfig;
|
|
5
|
-
exports.addTrustedPeer = addTrustedPeer;
|
|
6
|
-
exports.setPeerLimit = setPeerLimit;
|
|
7
|
-
exports.isRateLimitingEnabled = isRateLimitingEnabled;
|
|
8
|
-
exports.DEFAULT_RATE_LIMIT_CONFIG = {
|
|
9
|
-
maxRequestsPerSecond: parseIntEnv('RATE_LIMIT_MAX_PER_SECOND', 1000),
|
|
10
|
-
maxRequestsPerMinute: parseIntEnv('RATE_LIMIT_MAX_PER_MINUTE', 60000),
|
|
11
|
-
burstSize: parseIntEnv('RATE_LIMIT_BURST_SIZE', 2000),
|
|
12
|
-
blockDuration: parseIntEnv('RATE_LIMIT_BLOCK_DURATION', 300),
|
|
13
|
-
violationThreshold: parseIntEnv('RATE_LIMIT_VIOLATION_THRESHOLD', 100),
|
|
14
|
-
violationWindowSeconds: parseIntEnv('RATE_LIMIT_VIOLATION_WINDOW', 60),
|
|
15
|
-
adaptiveRateLimiting: parseBoolEnv('RATE_LIMIT_ADAPTIVE_ENABLED', true),
|
|
16
|
-
};
|
|
17
|
-
function createRateLimitConfig(overrides) {
|
|
18
|
-
return {
|
|
19
|
-
...exports.DEFAULT_RATE_LIMIT_CONFIG,
|
|
20
|
-
...overrides,
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
function addTrustedPeer(config, peerId) {
|
|
24
|
-
const trustedPeers = config.trustedPeers ?? new Set();
|
|
25
|
-
trustedPeers.add(peerId);
|
|
26
|
-
return {
|
|
27
|
-
...config,
|
|
28
|
-
trustedPeers,
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
function setPeerLimit(config, peerId, peerConfig) {
|
|
32
|
-
const peerLimits = config.peerLimits ?? new Map();
|
|
33
|
-
peerLimits.set(peerId, peerConfig);
|
|
34
|
-
return {
|
|
35
|
-
...config,
|
|
36
|
-
peerLimits,
|
|
37
|
-
};
|
|
38
|
-
}
|
|
39
|
-
function parseIntEnv(key, defaultValue) {
|
|
40
|
-
const value = process.env[key];
|
|
41
|
-
if (!value) {
|
|
42
|
-
return defaultValue;
|
|
43
|
-
}
|
|
44
|
-
const parsed = parseInt(value, 10);
|
|
45
|
-
return isNaN(parsed) ? defaultValue : parsed;
|
|
46
|
-
}
|
|
47
|
-
function parseBoolEnv(key, defaultValue) {
|
|
48
|
-
const value = process.env[key]?.toLowerCase();
|
|
49
|
-
if (!value) {
|
|
50
|
-
return defaultValue;
|
|
51
|
-
}
|
|
52
|
-
return value === 'true' || value === '1' || value === 'yes';
|
|
53
|
-
}
|
|
54
|
-
function isRateLimitingEnabled() {
|
|
55
|
-
return parseBoolEnv('RATE_LIMIT_ENABLED', true);
|
|
56
|
-
}
|
|
57
|
-
//# sourceMappingURL=rate-limit-config.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rate-limit-config.js","sourceRoot":"","sources":["../../src/security/rate-limit-config.ts"],"names":[],"mappings":";;;AAwBA,sDAKC;AAKD,wCAOC;AAKD,oCAWC;AA8BD,sDAEC;AA9EY,QAAA,yBAAyB,GAAoB;IACxD,oBAAoB,EAAE,WAAW,CAAC,2BAA2B,EAAE,IAAI,CAAC;IACpE,oBAAoB,EAAE,WAAW,CAAC,2BAA2B,EAAE,KAAK,CAAC;IACrE,SAAS,EAAE,WAAW,CAAC,uBAAuB,EAAE,IAAI,CAAC;IACrD,aAAa,EAAE,WAAW,CAAC,2BAA2B,EAAE,GAAG,CAAC;IAC5D,kBAAkB,EAAE,WAAW,CAAC,gCAAgC,EAAE,GAAG,CAAC;IACtE,sBAAsB,EAAE,WAAW,CAAC,6BAA6B,EAAE,EAAE,CAAC;IACtE,oBAAoB,EAAE,YAAY,CAAC,6BAA6B,EAAE,IAAI,CAAC;CACxE,CAAC;AAKF,SAAgB,qBAAqB,CAAC,SAAoC;IACxE,OAAO;QACL,GAAG,iCAAyB;QAC5B,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAKD,SAAgB,cAAc,CAAC,MAAuB,EAAE,MAAc;IACpE,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,IAAI,GAAG,EAAE,CAAC;IACtD,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACzB,OAAO;QACL,GAAG,MAAM;QACT,YAAY;KACb,CAAC;AACJ,CAAC;AAKD,SAAgB,YAAY,CAC1B,MAAuB,EACvB,MAAc,EACd,UAA+B;IAE/B,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,IAAI,IAAI,GAAG,EAAE,CAAC;IAClD,UAAU,CAAC,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IACnC,OAAO;QACL,GAAG,MAAM;QACT,UAAU;KACX,CAAC;AACJ,CAAC;AAOD,SAAS,WAAW,CAAC,GAAW,EAAE,YAAoB;IACpD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC/B,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACnC,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC;AAC/C,CAAC;AAKD,SAAS,YAAY,CAAC,GAAW,EAAE,YAAqB;IACtD,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,CAAC;IAC9C,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,OAAO,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,KAAK,CAAC;AAC9D,CAAC;AAKD,SAAgB,qBAAqB;IACnC,OAAO,YAAY,CAAC,oBAAoB,EAAE,IAAI,CAAC,CAAC;AAClD,CAAC"}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import type { Logger } from '../utils/logger';
|
|
2
|
-
export type RequestType = 'BTP_CONNECTION' | 'BTP_MESSAGE' | 'ILP_PACKET' | 'SETTLEMENT' | 'HTTP_API';
|
|
3
|
-
export interface RateLimitConfig {
|
|
4
|
-
maxRequestsPerSecond: number;
|
|
5
|
-
maxRequestsPerMinute: number;
|
|
6
|
-
burstSize: number;
|
|
7
|
-
blockDuration: number;
|
|
8
|
-
violationThreshold: number;
|
|
9
|
-
violationWindowSeconds: number;
|
|
10
|
-
peerLimits?: Map<string, PeerRateLimitConfig>;
|
|
11
|
-
trustedPeers?: Set<string>;
|
|
12
|
-
adaptiveRateLimiting?: boolean;
|
|
13
|
-
}
|
|
14
|
-
export interface PeerRateLimitConfig {
|
|
15
|
-
maxRequestsPerSecond: number;
|
|
16
|
-
burstSize: number;
|
|
17
|
-
}
|
|
18
|
-
export interface RateLimitMetrics {
|
|
19
|
-
recordAllowed(peerId: string, requestType: RequestType): void;
|
|
20
|
-
recordThrottled(peerId: string, requestType: RequestType): void;
|
|
21
|
-
recordBlocked(peerId: string, requestType: RequestType): void;
|
|
22
|
-
}
|
|
23
|
-
export declare class RateLimiter {
|
|
24
|
-
private config;
|
|
25
|
-
private logger;
|
|
26
|
-
private tokenBuckets;
|
|
27
|
-
private blockedPeers;
|
|
28
|
-
private violationCounter;
|
|
29
|
-
private metrics?;
|
|
30
|
-
private adaptiveLimits;
|
|
31
|
-
constructor(config: RateLimitConfig, logger: Logger, metrics?: RateLimitMetrics);
|
|
32
|
-
checkLimit(peerId: string, requestType: RequestType): Promise<boolean>;
|
|
33
|
-
private getOrCreateBucket;
|
|
34
|
-
private getBucketConfig;
|
|
35
|
-
private handleViolation;
|
|
36
|
-
private blockPeer;
|
|
37
|
-
private unblockPeer;
|
|
38
|
-
increaseAdaptiveLimit(peerId: string): void;
|
|
39
|
-
private decreaseAdaptiveLimit;
|
|
40
|
-
getBlockedPeers(): string[];
|
|
41
|
-
getRequestsPerSecond(peerId: string): number;
|
|
42
|
-
unblock(peerId: string): void;
|
|
43
|
-
private validateConfig;
|
|
44
|
-
destroy(): void;
|
|
45
|
-
}
|
|
46
|
-
//# sourceMappingURL=rate-limiter.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAO9C,MAAM,MAAM,WAAW,GACnB,gBAAgB,GAChB,aAAa,GACb,YAAY,GACZ,YAAY,GACZ,UAAU,CAAC;AAKf,MAAM,WAAW,eAAe;IAE9B,oBAAoB,EAAE,MAAM,CAAC;IAE7B,oBAAoB,EAAE,MAAM,CAAC;IAE7B,SAAS,EAAE,MAAM,CAAC;IAElB,aAAa,EAAE,MAAM,CAAC;IAEtB,kBAAkB,EAAE,MAAM,CAAC;IAE3B,sBAAsB,EAAE,MAAM,CAAC;IAE/B,UAAU,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;IAE9C,YAAY,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IAE3B,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAKD,MAAM,WAAW,mBAAmB;IAClC,oBAAoB,EAAE,MAAM,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;CACnB;AAKD,MAAM,WAAW,gBAAgB;IAC/B,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAC9D,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAChE,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;CAC/D;AAcD,qBAAa,WAAW;IAQpB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,MAAM;IARhB,OAAO,CAAC,YAAY,CAAkC;IACtD,OAAO,CAAC,YAAY,CAAkC;IACtD,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,OAAO,CAAC,CAAmB;IACnC,OAAO,CAAC,cAAc,CAA6B;gBAGzC,MAAM,EAAE,eAAe,EACvB,MAAM,EAAE,MAAM,EACtB,OAAO,CAAC,EAAE,gBAAgB;IAatB,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IA2B5E,OAAO,CAAC,iBAAiB;IAazB,OAAO,CAAC,eAAe;IA0BvB,OAAO,CAAC,eAAe;IA0BvB,OAAO,CAAC,SAAS;IAgCjB,OAAO,CAAC,WAAW;IAiBnB,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAe3C,OAAO,CAAC,qBAAqB;IAW7B,eAAe,IAAI,MAAM,EAAE;IAO3B,oBAAoB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAe5C,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAW7B,OAAO,CAAC,cAAc;IAwBtB,OAAO,IAAI,IAAI;CAQhB"}
|