@toon-protocol/connector 1.7.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +421 -0
- package/dist/btp/btp-claim-types.d.ts +30 -0
- package/dist/btp/btp-claim-types.d.ts.map +1 -0
- package/dist/btp/btp-claim-types.js +103 -0
- package/dist/btp/btp-claim-types.js.map +1 -0
- package/dist/btp/btp-client-manager.d.ts +27 -0
- package/dist/btp/btp-client-manager.d.ts.map +1 -0
- package/dist/btp/btp-client-manager.js +138 -0
- package/dist/btp/btp-client-manager.js.map +1 -0
- package/dist/btp/btp-client.d.ts +55 -0
- package/dist/btp/btp-client.d.ts.map +1 -0
- package/dist/btp/btp-client.js +474 -0
- package/dist/btp/btp-client.js.map +1 -0
- package/dist/btp/btp-message-parser.d.ts +4 -0
- package/dist/btp/btp-message-parser.d.ts.map +1 -0
- package/dist/btp/btp-message-parser.js +211 -0
- package/dist/btp/btp-message-parser.js.map +1 -0
- package/dist/btp/btp-server.d.ts +30 -0
- package/dist/btp/btp-server.d.ts.map +1 -0
- package/dist/btp/btp-server.js +458 -0
- package/dist/btp/btp-server.js.map +1 -0
- package/dist/btp/btp-types.d.ts +43 -0
- package/dist/btp/btp-types.d.ts.map +1 -0
- package/dist/btp/btp-types.js +44 -0
- package/dist/btp/btp-types.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +175 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/onboarding-wizard.d.ts +7 -0
- package/dist/cli/onboarding-wizard.d.ts.map +1 -0
- package/dist/cli/onboarding-wizard.js +257 -0
- package/dist/cli/onboarding-wizard.js.map +1 -0
- package/dist/cli/types.d.ts +38 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +3 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/config/aptos-env-validator.d.ts +8 -0
- package/dist/config/aptos-env-validator.d.ts.map +1 -0
- package/dist/config/aptos-env-validator.js +25 -0
- package/dist/config/aptos-env-validator.js.map +1 -0
- package/dist/config/config-loader.d.ts +20 -0
- package/dist/config/config-loader.d.ts.map +1 -0
- package/dist/config/config-loader.js +269 -0
- package/dist/config/config-loader.js.map +1 -0
- package/dist/config/environment-validator.d.ts +4 -0
- package/dist/config/environment-validator.d.ts.map +1 -0
- package/dist/config/environment-validator.js +239 -0
- package/dist/config/environment-validator.js.map +1 -0
- package/dist/config/index.d.ts +2 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +7 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/key-manager-config.d.ts +7 -0
- package/dist/config/key-manager-config.d.ts.map +1 -0
- package/dist/config/key-manager-config.js +209 -0
- package/dist/config/key-manager-config.js.map +1 -0
- package/dist/config/topology-validator.d.ts +14 -0
- package/dist/config/topology-validator.d.ts.map +1 -0
- package/dist/config/topology-validator.js +142 -0
- package/dist/config/topology-validator.js.map +1 -0
- package/dist/config/types.d.ts +210 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +10 -0
- package/dist/config/types.js.map +1 -0
- package/dist/core/connector-node.d.ts +79 -0
- package/dist/core/connector-node.d.ts.map +1 -0
- package/dist/core/connector-node.js +1036 -0
- package/dist/core/connector-node.js.map +1 -0
- package/dist/core/local-delivery-client.d.ts +16 -0
- package/dist/core/local-delivery-client.d.ts.map +1 -0
- package/dist/core/local-delivery-client.js +176 -0
- package/dist/core/local-delivery-client.js.map +1 -0
- package/dist/core/packet-handler.d.ts +45 -0
- package/dist/core/packet-handler.d.ts.map +1 -0
- package/dist/core/packet-handler.js +606 -0
- package/dist/core/packet-handler.js.map +1 -0
- package/dist/core/payment-handler.d.ts +27 -0
- package/dist/core/payment-handler.d.ts.map +1 -0
- package/dist/core/payment-handler.js +115 -0
- package/dist/core/payment-handler.js.map +1 -0
- package/dist/discovery/index.d.ts +3 -0
- package/dist/discovery/index.d.ts.map +1 -0
- package/dist/discovery/index.js +6 -0
- package/dist/discovery/index.js.map +1 -0
- package/dist/discovery/peer-discovery-service.d.ts +29 -0
- package/dist/discovery/peer-discovery-service.d.ts.map +1 -0
- package/dist/discovery/peer-discovery-service.js +230 -0
- package/dist/discovery/peer-discovery-service.js.map +1 -0
- package/dist/discovery/types.d.ts +38 -0
- package/dist/discovery/types.d.ts.map +1 -0
- package/dist/discovery/types.js +3 -0
- package/dist/discovery/types.js.map +1 -0
- package/dist/encoding/oer-parser.d.ts +39 -0
- package/dist/encoding/oer-parser.d.ts.map +1 -0
- package/dist/encoding/oer-parser.js +154 -0
- package/dist/encoding/oer-parser.js.map +1 -0
- package/dist/explorer-ui/assets/EventDetailPanel-CnSaMk3V.js +6 -0
- package/dist/explorer-ui/assets/FilterBar-BEmAzBku.js +26 -0
- package/dist/explorer-ui/assets/chevron-right-BUT9VhYe.js +11 -0
- package/dist/explorer-ui/assets/index-BZ2INVgy.js +360 -0
- package/dist/explorer-ui/assets/index-Cemh6svI.css +1 -0
- package/dist/explorer-ui/index.html +14 -0
- package/dist/explorer-ui/vite.svg +1 -0
- package/dist/facilitator/index.d.ts +2 -0
- package/dist/facilitator/index.d.ts.map +1 -0
- package/dist/facilitator/index.js +7 -0
- package/dist/facilitator/index.js.map +1 -0
- package/dist/facilitator/spsp-client.d.ts +18 -0
- package/dist/facilitator/spsp-client.d.ts.map +1 -0
- package/dist/facilitator/spsp-client.js +95 -0
- package/dist/facilitator/spsp-client.js.map +1 -0
- package/dist/http/admin-api.d.ts +123 -0
- package/dist/http/admin-api.d.ts.map +1 -0
- package/dist/http/admin-api.js +1057 -0
- package/dist/http/admin-api.js.map +1 -0
- package/dist/http/admin-server.d.ts +41 -0
- package/dist/http/admin-server.d.ts.map +1 -0
- package/dist/http/admin-server.js +156 -0
- package/dist/http/admin-server.js.map +1 -0
- package/dist/http/health-server.d.ts +22 -0
- package/dist/http/health-server.d.ts.map +1 -0
- package/dist/http/health-server.js +192 -0
- package/dist/http/health-server.js.map +1 -0
- package/dist/http/ilp-send-handler.d.ts +19 -0
- package/dist/http/ilp-send-handler.d.ts.map +1 -0
- package/dist/http/ilp-send-handler.js +162 -0
- package/dist/http/ilp-send-handler.js.map +1 -0
- package/dist/http/types.d.ts +39 -0
- package/dist/http/types.d.ts.map +1 -0
- package/dist/http/types.js +3 -0
- package/dist/http/types.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/lib.d.ts +22 -0
- package/dist/lib.d.ts.map +1 -0
- package/dist/lib.js +41 -0
- package/dist/lib.js.map +1 -0
- package/dist/main.d.ts +4 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +79 -0
- package/dist/main.js.map +1 -0
- package/dist/routing/packet-processor.d.ts +36 -0
- package/dist/routing/packet-processor.d.ts.map +1 -0
- package/dist/routing/packet-processor.js +112 -0
- package/dist/routing/packet-processor.js.map +1 -0
- package/dist/routing/packet-worker.d.ts +10 -0
- package/dist/routing/packet-worker.d.ts.map +1 -0
- package/dist/routing/packet-worker.js +34 -0
- package/dist/routing/packet-worker.js.map +1 -0
- package/dist/routing/routing-table.d.ts +15 -0
- package/dist/routing/routing-table.d.ts.map +1 -0
- package/dist/routing/routing-table.js +63 -0
- package/dist/routing/routing-table.js.map +1 -0
- package/dist/routing/worker-pool.d.ts +43 -0
- package/dist/routing/worker-pool.d.ts.map +1 -0
- package/dist/routing/worker-pool.js +228 -0
- package/dist/routing/worker-pool.js.map +1 -0
- package/dist/security/alert-notifier.d.ts +34 -0
- package/dist/security/alert-notifier.d.ts.map +1 -0
- package/dist/security/alert-notifier.js +136 -0
- package/dist/security/alert-notifier.js.map +1 -0
- package/dist/security/audit-logger.d.ts +34 -0
- package/dist/security/audit-logger.d.ts.map +1 -0
- package/dist/security/audit-logger.js +132 -0
- package/dist/security/audit-logger.js.map +1 -0
- package/dist/security/backends/aws-kms-backend.d.ts +18 -0
- package/dist/security/backends/aws-kms-backend.d.ts.map +1 -0
- package/dist/security/backends/aws-kms-backend.js +130 -0
- package/dist/security/backends/aws-kms-backend.js.map +1 -0
- package/dist/security/backends/azure-kv-backend.d.ts +17 -0
- package/dist/security/backends/azure-kv-backend.d.ts.map +1 -0
- package/dist/security/backends/azure-kv-backend.js +121 -0
- package/dist/security/backends/azure-kv-backend.js.map +1 -0
- package/dist/security/backends/environment-backend.d.ts +15 -0
- package/dist/security/backends/environment-backend.d.ts.map +1 -0
- package/dist/security/backends/environment-backend.js +56 -0
- package/dist/security/backends/environment-backend.js.map +1 -0
- package/dist/security/backends/gcp-kms-backend.d.ts +17 -0
- package/dist/security/backends/gcp-kms-backend.d.ts.map +1 -0
- package/dist/security/backends/gcp-kms-backend.js +110 -0
- package/dist/security/backends/gcp-kms-backend.js.map +1 -0
- package/dist/security/backends/hsm-backend.d.ts +18 -0
- package/dist/security/backends/hsm-backend.d.ts.map +1 -0
- package/dist/security/backends/hsm-backend.js +187 -0
- package/dist/security/backends/hsm-backend.js.map +1 -0
- package/dist/security/fraud-detector.d.ts +79 -0
- package/dist/security/fraud-detector.d.ts.map +1 -0
- package/dist/security/fraud-detector.js +147 -0
- package/dist/security/fraud-detector.js.map +1 -0
- package/dist/security/key-manager-signer.d.ts +15 -0
- package/dist/security/key-manager-signer.d.ts.map +1 -0
- package/dist/security/key-manager-signer.js +91 -0
- package/dist/security/key-manager-signer.js.map +1 -0
- package/dist/security/key-manager.d.ts +69 -0
- package/dist/security/key-manager.d.ts.map +1 -0
- package/dist/security/key-manager.js +79 -0
- package/dist/security/key-manager.js.map +1 -0
- package/dist/security/key-rotation-manager.d.ts +27 -0
- package/dist/security/key-rotation-manager.d.ts.map +1 -0
- package/dist/security/key-rotation-manager.js +142 -0
- package/dist/security/key-rotation-manager.js.map +1 -0
- package/dist/security/rate-limit-config.d.ts +7 -0
- package/dist/security/rate-limit-config.d.ts.map +1 -0
- package/dist/security/rate-limit-config.js +57 -0
- package/dist/security/rate-limit-config.js.map +1 -0
- package/dist/security/rate-limiter.d.ts +46 -0
- package/dist/security/rate-limiter.d.ts.map +1 -0
- package/dist/security/rate-limiter.js +170 -0
- package/dist/security/rate-limiter.js.map +1 -0
- package/dist/security/reputation-tracker.d.ts +30 -0
- package/dist/security/reputation-tracker.d.ts.map +1 -0
- package/dist/security/reputation-tracker.js +111 -0
- package/dist/security/reputation-tracker.js.map +1 -0
- package/dist/security/rules/balance-manipulation-rule.d.ts +23 -0
- package/dist/security/rules/balance-manipulation-rule.d.ts.map +1 -0
- package/dist/security/rules/balance-manipulation-rule.js +70 -0
- package/dist/security/rules/balance-manipulation-rule.js.map +1 -0
- package/dist/security/rules/double-spend-detection-rule.d.ts +23 -0
- package/dist/security/rules/double-spend-detection-rule.d.ts.map +1 -0
- package/dist/security/rules/double-spend-detection-rule.js +61 -0
- package/dist/security/rules/double-spend-detection-rule.js.map +1 -0
- package/dist/security/rules/rapid-channel-closure-rule.d.ts +16 -0
- package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +1 -0
- package/dist/security/rules/rapid-channel-closure-rule.js +57 -0
- package/dist/security/rules/rapid-channel-closure-rule.js.map +1 -0
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts +18 -0
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +1 -0
- package/dist/security/rules/sudden-traffic-spike-rule.js +92 -0
- package/dist/security/rules/sudden-traffic-spike-rule.js.map +1 -0
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts +12 -0
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +1 -0
- package/dist/security/rules/unusual-settlement-amount-rule.js +33 -0
- package/dist/security/rules/unusual-settlement-amount-rule.js.map +1 -0
- package/dist/security/token-bucket.d.ts +16 -0
- package/dist/security/token-bucket.d.ts.map +1 -0
- package/dist/security/token-bucket.js +49 -0
- package/dist/security/token-bucket.js.map +1 -0
- package/dist/security/violation-counter.d.ts +11 -0
- package/dist/security/violation-counter.d.ts.map +1 -0
- package/dist/security/violation-counter.js +61 -0
- package/dist/security/violation-counter.js.map +1 -0
- package/dist/settlement/account-id-generator.d.ts +4 -0
- package/dist/settlement/account-id-generator.d.ts.map +1 -0
- package/dist/settlement/account-id-generator.js +38 -0
- package/dist/settlement/account-id-generator.js.map +1 -0
- package/dist/settlement/account-manager.d.ts +47 -0
- package/dist/settlement/account-manager.d.ts.map +1 -0
- package/dist/settlement/account-manager.js +447 -0
- package/dist/settlement/account-manager.js.map +1 -0
- package/dist/settlement/account-metadata.d.ts +11 -0
- package/dist/settlement/account-metadata.d.ts.map +1 -0
- package/dist/settlement/account-metadata.js +40 -0
- package/dist/settlement/account-metadata.js.map +1 -0
- package/dist/settlement/aptos-channel-sdk.d.ts +66 -0
- package/dist/settlement/aptos-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/aptos-channel-sdk.js +274 -0
- package/dist/settlement/aptos-channel-sdk.js.map +1 -0
- package/dist/settlement/aptos-claim-signer.d.ts +57 -0
- package/dist/settlement/aptos-claim-signer.d.ts.map +1 -0
- package/dist/settlement/aptos-claim-signer.js +200 -0
- package/dist/settlement/aptos-claim-signer.js.map +1 -0
- package/dist/settlement/aptos-client.d.ts +99 -0
- package/dist/settlement/aptos-client.d.ts.map +1 -0
- package/dist/settlement/aptos-client.js +474 -0
- package/dist/settlement/aptos-client.js.map +1 -0
- package/dist/settlement/channel-manager.d.ts +66 -0
- package/dist/settlement/channel-manager.d.ts.map +1 -0
- package/dist/settlement/channel-manager.js +214 -0
- package/dist/settlement/channel-manager.js.map +1 -0
- package/dist/settlement/claim-receiver-db-schema.d.ts +4 -0
- package/dist/settlement/claim-receiver-db-schema.d.ts.map +1 -0
- package/dist/settlement/claim-receiver-db-schema.js +25 -0
- package/dist/settlement/claim-receiver-db-schema.js.map +1 -0
- package/dist/settlement/claim-receiver.d.ts +31 -0
- package/dist/settlement/claim-receiver.d.ts.map +1 -0
- package/dist/settlement/claim-receiver.js +228 -0
- package/dist/settlement/claim-receiver.js.map +1 -0
- package/dist/settlement/claim-redemption-service.d.ts +39 -0
- package/dist/settlement/claim-redemption-service.d.ts.map +1 -0
- package/dist/settlement/claim-redemption-service.js +189 -0
- package/dist/settlement/claim-redemption-service.js.map +1 -0
- package/dist/settlement/claim-sender-db-schema.d.ts +3 -0
- package/dist/settlement/claim-sender-db-schema.d.ts.map +1 -0
- package/dist/settlement/claim-sender-db-schema.js +18 -0
- package/dist/settlement/claim-sender-db-schema.js.map +1 -0
- package/dist/settlement/claim-sender.d.ts +22 -0
- package/dist/settlement/claim-sender.d.ts.map +1 -0
- package/dist/settlement/claim-sender.js +108 -0
- package/dist/settlement/claim-sender.js.map +1 -0
- package/dist/settlement/eip712-helper.d.ts +13 -0
- package/dist/settlement/eip712-helper.d.ts.map +1 -0
- package/dist/settlement/eip712-helper.js +24 -0
- package/dist/settlement/eip712-helper.js.map +1 -0
- package/dist/settlement/in-memory-ledger-client.d.ts +40 -0
- package/dist/settlement/in-memory-ledger-client.d.ts.map +1 -0
- package/dist/settlement/in-memory-ledger-client.js +177 -0
- package/dist/settlement/in-memory-ledger-client.js.map +1 -0
- package/dist/settlement/ledger-client.d.ts +22 -0
- package/dist/settlement/ledger-client.d.ts.map +1 -0
- package/dist/settlement/ledger-client.js +3 -0
- package/dist/settlement/ledger-client.js.map +1 -0
- package/dist/settlement/metrics-collector.d.ts +29 -0
- package/dist/settlement/metrics-collector.d.ts.map +1 -0
- package/dist/settlement/metrics-collector.js +81 -0
- package/dist/settlement/metrics-collector.js.map +1 -0
- package/dist/settlement/payment-channel-sdk.d.ts +59 -0
- package/dist/settlement/payment-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/payment-channel-sdk.js +677 -0
- package/dist/settlement/payment-channel-sdk.js.map +1 -0
- package/dist/settlement/per-packet-claim-service.d.ts +33 -0
- package/dist/settlement/per-packet-claim-service.d.ts.map +1 -0
- package/dist/settlement/per-packet-claim-service.js +177 -0
- package/dist/settlement/per-packet-claim-service.js.map +1 -0
- package/dist/settlement/settlement-api.d.ts +37 -0
- package/dist/settlement/settlement-api.d.ts.map +1 -0
- package/dist/settlement/settlement-api.js +172 -0
- package/dist/settlement/settlement-api.js.map +1 -0
- package/dist/settlement/settlement-coordinator.d.ts +47 -0
- package/dist/settlement/settlement-coordinator.d.ts.map +1 -0
- package/dist/settlement/settlement-coordinator.js +166 -0
- package/dist/settlement/settlement-coordinator.js.map +1 -0
- package/dist/settlement/settlement-executor.d.ts +44 -0
- package/dist/settlement/settlement-executor.d.ts.map +1 -0
- package/dist/settlement/settlement-executor.js +247 -0
- package/dist/settlement/settlement-executor.js.map +1 -0
- package/dist/settlement/settlement-monitor.d.ts +29 -0
- package/dist/settlement/settlement-monitor.d.ts.map +1 -0
- package/dist/settlement/settlement-monitor.js +172 -0
- package/dist/settlement/settlement-monitor.js.map +1 -0
- package/dist/settlement/tigerbeetle-batch-writer.d.ts +58 -0
- package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +1 -0
- package/dist/settlement/tigerbeetle-batch-writer.js +162 -0
- package/dist/settlement/tigerbeetle-batch-writer.js.map +1 -0
- package/dist/settlement/tigerbeetle-client.d.ts +40 -0
- package/dist/settlement/tigerbeetle-client.d.ts.map +1 -0
- package/dist/settlement/tigerbeetle-client.js +279 -0
- package/dist/settlement/tigerbeetle-client.js.map +1 -0
- package/dist/settlement/tigerbeetle-errors.d.ts +23 -0
- package/dist/settlement/tigerbeetle-errors.d.ts.map +1 -0
- package/dist/settlement/tigerbeetle-errors.js +58 -0
- package/dist/settlement/tigerbeetle-errors.js.map +1 -0
- package/dist/settlement/types.d.ts +64 -0
- package/dist/settlement/types.d.ts.map +1 -0
- package/dist/settlement/types.js +42 -0
- package/dist/settlement/types.js.map +1 -0
- package/dist/settlement/unified-settlement-executor.d.ts +34 -0
- package/dist/settlement/unified-settlement-executor.d.ts.map +1 -0
- package/dist/settlement/unified-settlement-executor.js +145 -0
- package/dist/settlement/unified-settlement-executor.js.map +1 -0
- package/dist/settlement/xrp-channel-lifecycle.d.ts +41 -0
- package/dist/settlement/xrp-channel-lifecycle.d.ts.map +1 -0
- package/dist/settlement/xrp-channel-lifecycle.js +142 -0
- package/dist/settlement/xrp-channel-lifecycle.js.map +1 -0
- package/dist/settlement/xrp-channel-manager.d.ts +59 -0
- package/dist/settlement/xrp-channel-manager.d.ts.map +1 -0
- package/dist/settlement/xrp-channel-manager.js +160 -0
- package/dist/settlement/xrp-channel-manager.js.map +1 -0
- package/dist/settlement/xrp-channel-sdk.d.ts +30 -0
- package/dist/settlement/xrp-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/xrp-channel-sdk.js +164 -0
- package/dist/settlement/xrp-channel-sdk.js.map +1 -0
- package/dist/settlement/xrp-claim-signer.d.ts +22 -0
- package/dist/settlement/xrp-claim-signer.d.ts.map +1 -0
- package/dist/settlement/xrp-claim-signer.js +122 -0
- package/dist/settlement/xrp-claim-signer.js.map +1 -0
- package/dist/settlement/xrpl-client.d.ts +104 -0
- package/dist/settlement/xrpl-client.d.ts.map +1 -0
- package/dist/settlement/xrpl-client.js +304 -0
- package/dist/settlement/xrpl-client.js.map +1 -0
- package/dist/test/testnet-config.d.ts +58 -0
- package/dist/test/testnet-config.d.ts.map +1 -0
- package/dist/test/testnet-config.js +89 -0
- package/dist/test/testnet-config.js.map +1 -0
- package/dist/test-utils/index.d.ts +3 -0
- package/dist/test-utils/index.d.ts.map +1 -0
- package/dist/test-utils/index.js +15 -0
- package/dist/test-utils/index.js.map +1 -0
- package/dist/test-utils/isolated-test-env.d.ts +31 -0
- package/dist/test-utils/isolated-test-env.d.ts.map +1 -0
- package/dist/test-utils/isolated-test-env.js +127 -0
- package/dist/test-utils/isolated-test-env.js.map +1 -0
- package/dist/test-utils/mock-factories-patch.d.ts +2 -0
- package/dist/test-utils/mock-factories-patch.d.ts.map +1 -0
- package/dist/test-utils/mock-factories-patch.js +3 -0
- package/dist/test-utils/mock-factories-patch.js.map +1 -0
- package/dist/test-utils/mock-factories.d.ts +22 -0
- package/dist/test-utils/mock-factories.d.ts.map +1 -0
- package/dist/test-utils/mock-factories.js +56 -0
- package/dist/test-utils/mock-factories.js.map +1 -0
- package/dist/utils/connection-pool.d.ts +42 -0
- package/dist/utils/connection-pool.d.ts.map +1 -0
- package/dist/utils/connection-pool.js +209 -0
- package/dist/utils/connection-pool.js.map +1 -0
- package/dist/utils/evm-rpc-connection-pool.d.ts +8 -0
- package/dist/utils/evm-rpc-connection-pool.d.ts.map +1 -0
- package/dist/utils/evm-rpc-connection-pool.js +40 -0
- package/dist/utils/evm-rpc-connection-pool.js.map +1 -0
- package/dist/utils/logger.d.ts +6 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +58 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/optional-require.d.ts +2 -0
- package/dist/utils/optional-require.d.ts.map +1 -0
- package/dist/utils/optional-require.js +54 -0
- package/dist/utils/optional-require.js.map +1 -0
- package/dist/utils/xrp-wss-connection-pool.d.ts +8 -0
- package/dist/utils/xrp-wss-connection-pool.d.ts.map +1 -0
- package/dist/utils/xrp-wss-connection-pool.js +42 -0
- package/dist/utils/xrp-wss-connection-pool.js.map +1 -0
- package/dist/wallet/audit-logger.d.ts +22 -0
- package/dist/wallet/audit-logger.d.ts.map +1 -0
- package/dist/wallet/audit-logger.js +120 -0
- package/dist/wallet/audit-logger.js.map +1 -0
- package/dist/wallet/fraud-detector-interface.d.ts +14 -0
- package/dist/wallet/fraud-detector-interface.d.ts.map +1 -0
- package/dist/wallet/fraud-detector-interface.js +3 -0
- package/dist/wallet/fraud-detector-interface.js.map +1 -0
- package/dist/wallet/key-manager.d.ts +6 -0
- package/dist/wallet/key-manager.d.ts.map +1 -0
- package/dist/wallet/key-manager.js +3 -0
- package/dist/wallet/key-manager.js.map +1 -0
- package/dist/wallet/placeholder-fraud-detector.d.ts +10 -0
- package/dist/wallet/placeholder-fraud-detector.d.ts.map +1 -0
- package/dist/wallet/placeholder-fraud-detector.js +10 -0
- package/dist/wallet/placeholder-fraud-detector.js.map +1 -0
- package/dist/wallet/rate-limiter.d.ts +26 -0
- package/dist/wallet/rate-limiter.d.ts.map +1 -0
- package/dist/wallet/rate-limiter.js +114 -0
- package/dist/wallet/rate-limiter.js.map +1 -0
- package/dist/wallet/suspicious-activity-detector.d.ts +25 -0
- package/dist/wallet/suspicious-activity-detector.d.ts.map +1 -0
- package/dist/wallet/suspicious-activity-detector.js +97 -0
- package/dist/wallet/suspicious-activity-detector.js.map +1 -0
- package/dist/wallet/treasury-wallet.d.ts +20 -0
- package/dist/wallet/treasury-wallet.d.ts.map +1 -0
- package/dist/wallet/treasury-wallet.js +151 -0
- package/dist/wallet/treasury-wallet.js.map +1 -0
- package/dist/wallet/wallet-authentication.d.ts +31 -0
- package/dist/wallet/wallet-authentication.d.ts.map +1 -0
- package/dist/wallet/wallet-authentication.js +102 -0
- package/dist/wallet/wallet-authentication.js.map +1 -0
- package/dist/wallet/wallet-db-schema.d.ts +11 -0
- package/dist/wallet/wallet-db-schema.d.ts.map +1 -0
- package/dist/wallet/wallet-db-schema.js +79 -0
- package/dist/wallet/wallet-db-schema.js.map +1 -0
- package/dist/wallet/wallet-security.d.ts +58 -0
- package/dist/wallet/wallet-security.d.ts.map +1 -0
- package/dist/wallet/wallet-security.js +148 -0
- package/dist/wallet/wallet-security.js.map +1 -0
- package/dist/wallet/wallet-seed-manager.d.ts +65 -0
- package/dist/wallet/wallet-seed-manager.d.ts.map +1 -0
- package/dist/wallet/wallet-seed-manager.js +418 -0
- package/dist/wallet/wallet-seed-manager.js.map +1 -0
- package/package.json +134 -0
|
@@ -0,0 +1,91 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-manager-signer.js","sourceRoot":"","sources":["../../src/security/key-manager-signer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,69 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,79 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-manager.js","sourceRoot":"","sources":["../../src/security/key-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,142 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-rotation-manager.js","sourceRoot":"","sources":["../../src/security/key-rotation-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,57 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
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
|
|
@@ -0,0 +1 @@
|
|
|
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"}
|