@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,162 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IlpSendHandler = void 0;
|
|
4
|
+
exports.computeConditionFromData = computeConditionFromData;
|
|
5
|
+
exports.validateIlpSendRequest = validateIlpSendRequest;
|
|
6
|
+
const tslib_1 = require("tslib");
|
|
7
|
+
const crypto = tslib_1.__importStar(require("crypto"));
|
|
8
|
+
const shared_1 = require("@toon-protocol/shared");
|
|
9
|
+
const DEFAULT_TIMEOUT_MS = 30000;
|
|
10
|
+
const MAX_DATA_SIZE = 65536;
|
|
11
|
+
function computeConditionFromData(data) {
|
|
12
|
+
const fulfillment = crypto.createHash('sha256').update(data).digest();
|
|
13
|
+
const condition = crypto.createHash('sha256').update(fulfillment).digest();
|
|
14
|
+
return { condition, fulfillment };
|
|
15
|
+
}
|
|
16
|
+
function validateIlpSendRequest(body) {
|
|
17
|
+
if (!body.destination || typeof body.destination !== 'string') {
|
|
18
|
+
return 'Missing required field: destination';
|
|
19
|
+
}
|
|
20
|
+
if (!(0, shared_1.isValidILPAddress)(body.destination)) {
|
|
21
|
+
return `Invalid ILP address: ${body.destination}`;
|
|
22
|
+
}
|
|
23
|
+
if (body.amount === undefined || body.amount === null || typeof body.amount !== 'string') {
|
|
24
|
+
return 'Missing required field: amount';
|
|
25
|
+
}
|
|
26
|
+
if (!/^\d+$/.test(body.amount)) {
|
|
27
|
+
return 'Amount must be a non-negative integer string';
|
|
28
|
+
}
|
|
29
|
+
if (body.data === undefined || body.data === null || typeof body.data !== 'string') {
|
|
30
|
+
return 'Missing required field: data';
|
|
31
|
+
}
|
|
32
|
+
let decodedData;
|
|
33
|
+
try {
|
|
34
|
+
decodedData = Buffer.from(body.data, 'base64');
|
|
35
|
+
if (decodedData.toString('base64') !== body.data) {
|
|
36
|
+
return 'Data must be valid base64';
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
return 'Data must be valid base64';
|
|
41
|
+
}
|
|
42
|
+
if (decodedData.length > MAX_DATA_SIZE) {
|
|
43
|
+
return `Data exceeds maximum size of ${MAX_DATA_SIZE} bytes`;
|
|
44
|
+
}
|
|
45
|
+
if (body.timeoutMs !== undefined) {
|
|
46
|
+
if (typeof body.timeoutMs !== 'number' ||
|
|
47
|
+
!Number.isInteger(body.timeoutMs) ||
|
|
48
|
+
body.timeoutMs <= 0) {
|
|
49
|
+
return 'timeoutMs must be a positive integer';
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
class IlpSendHandler {
|
|
55
|
+
_sendPacket;
|
|
56
|
+
_isReady;
|
|
57
|
+
_logger;
|
|
58
|
+
constructor(sendPacket, isReady, logger) {
|
|
59
|
+
this._sendPacket = sendPacket;
|
|
60
|
+
this._isReady = isReady;
|
|
61
|
+
this._logger = logger.child({ component: 'IlpSendHandler' });
|
|
62
|
+
}
|
|
63
|
+
async handle(req, res) {
|
|
64
|
+
this._logger.info({ path: req.path }, 'Received ILP send request');
|
|
65
|
+
try {
|
|
66
|
+
if (!this._sendPacket) {
|
|
67
|
+
this._logger.warn('Outbound sender not configured');
|
|
68
|
+
res.status(503).json({
|
|
69
|
+
error: 'Service unavailable',
|
|
70
|
+
message: 'Outbound sender not configured',
|
|
71
|
+
});
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
if (!this._isReady || !this._isReady()) {
|
|
75
|
+
this._logger.warn('Connector not ready');
|
|
76
|
+
res.status(503).json({
|
|
77
|
+
error: 'Service unavailable',
|
|
78
|
+
message: 'Connector not ready',
|
|
79
|
+
});
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
const body = req.body;
|
|
83
|
+
const validationError = validateIlpSendRequest(body);
|
|
84
|
+
if (validationError) {
|
|
85
|
+
this._logger.debug({ error: validationError }, 'Request validation failed');
|
|
86
|
+
res.status(400).json({
|
|
87
|
+
error: 'Bad request',
|
|
88
|
+
message: validationError,
|
|
89
|
+
});
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
const request = body;
|
|
93
|
+
const timeoutMs = request.timeoutMs ?? DEFAULT_TIMEOUT_MS;
|
|
94
|
+
const rawDataBytes = Buffer.from(request.data, 'base64');
|
|
95
|
+
const { condition } = computeConditionFromData(rawDataBytes);
|
|
96
|
+
const params = {
|
|
97
|
+
destination: request.destination,
|
|
98
|
+
amount: BigInt(request.amount),
|
|
99
|
+
executionCondition: condition,
|
|
100
|
+
expiresAt: new Date(Date.now() + timeoutMs),
|
|
101
|
+
data: rawDataBytes,
|
|
102
|
+
};
|
|
103
|
+
let timeoutHandle;
|
|
104
|
+
const response = await Promise.race([
|
|
105
|
+
this._sendPacket(params),
|
|
106
|
+
new Promise((_resolve, reject) => {
|
|
107
|
+
timeoutHandle = setTimeout(() => reject(new TimeoutError(timeoutMs)), timeoutMs);
|
|
108
|
+
}),
|
|
109
|
+
]).finally(() => {
|
|
110
|
+
if (timeoutHandle) {
|
|
111
|
+
clearTimeout(timeoutHandle);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
if (response.type === shared_1.PacketType.FULFILL) {
|
|
115
|
+
const fulfillResponse = {
|
|
116
|
+
accepted: true,
|
|
117
|
+
fulfilled: true,
|
|
118
|
+
fulfillment: response.fulfillment.toString('base64'),
|
|
119
|
+
data: response.data.length > 0 ? response.data.toString('base64') : undefined,
|
|
120
|
+
};
|
|
121
|
+
this._logger.info({ destination: request.destination, amount: request.amount }, 'ILP packet fulfilled');
|
|
122
|
+
res.status(200).json(fulfillResponse);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
const rejectResponse = {
|
|
126
|
+
accepted: false,
|
|
127
|
+
fulfilled: false,
|
|
128
|
+
code: response.code,
|
|
129
|
+
message: response.message,
|
|
130
|
+
data: response.data.length > 0 ? response.data.toString('base64') : undefined,
|
|
131
|
+
};
|
|
132
|
+
this._logger.info({ destination: request.destination, code: response.code, message: response.message }, 'ILP packet rejected');
|
|
133
|
+
res.status(200).json(rejectResponse);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
catch (error) {
|
|
137
|
+
if (error instanceof TimeoutError) {
|
|
138
|
+
this._logger.warn({ timeoutMs: error.timeoutMs }, 'ILP send request timed out');
|
|
139
|
+
res.status(408).json({
|
|
140
|
+
error: 'Request timeout',
|
|
141
|
+
message: `No response received within ${error.timeoutMs}ms`,
|
|
142
|
+
});
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
this._logger.error({ error }, 'Error handling ILP send request');
|
|
146
|
+
res.status(500).json({
|
|
147
|
+
error: 'Internal server error',
|
|
148
|
+
message: error instanceof Error ? error.message : 'Unknown error',
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
exports.IlpSendHandler = IlpSendHandler;
|
|
154
|
+
class TimeoutError extends Error {
|
|
155
|
+
timeoutMs;
|
|
156
|
+
constructor(timeoutMs) {
|
|
157
|
+
super(`Timeout after ${timeoutMs}ms`);
|
|
158
|
+
this.name = 'TimeoutError';
|
|
159
|
+
this.timeoutMs = timeoutMs;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
//# sourceMappingURL=ilp-send-handler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ilp-send-handler.js","sourceRoot":"","sources":["../../src/http/ilp-send-handler.ts"],"names":[],"mappings":";;;AAsCA,4DAIC;AAQD,wDAkDC;;AArFD,uDAAiC;AAGjC,kDAAsE;AAKtE,MAAM,kBAAkB,GAAG,KAAK,CAAC;AAGjC,MAAM,aAAa,GAAG,KAAK,CAAC;AAY5B,SAAgB,wBAAwB,CAAC,IAAY;IACnD,MAAM,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;IACtE,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,MAAM,EAAE,CAAC;IAC3E,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,CAAC;AACpC,CAAC;AAQD,SAAgB,sBAAsB,CAAC,IAA6B;IAElE,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,OAAO,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE,CAAC;QAC9D,OAAO,qCAAqC,CAAC;IAC/C,CAAC;IACD,IAAI,CAAC,IAAA,0BAAiB,EAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;QACzC,OAAO,wBAAwB,IAAI,CAAC,WAAW,EAAE,CAAC;IACpD,CAAC;IAGD,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;QACzF,OAAO,gCAAgC,CAAC;IAC1C,CAAC;IACD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;QAC/B,OAAO,8CAA8C,CAAC;IACxD,CAAC;IAGD,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QACnF,OAAO,8BAA8B,CAAC;IACxC,CAAC;IAGD,IAAI,WAAmB,CAAC;IACxB,IAAI,CAAC;QACH,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAC/C,IAAI,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC;YACjD,OAAO,2BAA2B,CAAC;QACrC,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,2BAA2B,CAAC;IACrC,CAAC;IAGD,IAAI,WAAW,CAAC,MAAM,GAAG,aAAa,EAAE,CAAC;QACvC,OAAO,gCAAgC,aAAa,QAAQ,CAAC;IAC/D,CAAC;IAGD,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;QACjC,IACE,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ;YAClC,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC;YACjC,IAAI,CAAC,SAAS,IAAI,CAAC,EACnB,CAAC;YACD,OAAO,sCAAsC,CAAC;QAChD,CAAC;IACH,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC;AAaD,MAAa,cAAc;IACR,WAAW,CAAwB;IACnC,QAAQ,CAAmB;IAC3B,OAAO,CAAS;IAEjC,YAAY,UAAiC,EAAE,OAAyB,EAAE,MAAc;QACtF,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAC;IAC/D,CAAC;IAKD,KAAK,CAAC,MAAM,CAAC,GAAY,EAAE,GAAa;QACtC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,EAAE,2BAA2B,CAAC,CAAC;QAEnE,IAAI,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACtB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;gBACpD,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;oBACnB,KAAK,EAAE,qBAAqB;oBAC5B,OAAO,EAAE,gCAAgC;iBAC1C,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;YAGD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;gBACvC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;gBACzC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;oBACnB,KAAK,EAAE,qBAAqB;oBAC5B,OAAO,EAAE,qBAAqB;iBAC/B,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;YAGD,MAAM,IAAI,GAAG,GAAG,CAAC,IAA+B,CAAC;YACjD,MAAM,eAAe,GAAG,sBAAsB,CAAC,IAAI,CAAC,CAAC;YACrD,IAAI,eAAe,EAAE,CAAC;gBACpB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,eAAe,EAAE,EAAE,2BAA2B,CAAC,CAAC;gBAC5E,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;oBACnB,KAAK,EAAE,aAAa;oBACpB,OAAO,EAAE,eAAe;iBACzB,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;YAED,MAAM,OAAO,GAAG,IAAiC,CAAC;YAClD,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,kBAAkB,CAAC;YAC1D,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YAGzD,MAAM,EAAE,SAAS,EAAE,GAAG,wBAAwB,CAAC,YAAY,CAAC,CAAC;YAG7D,MAAM,MAAM,GAAqB;gBAC/B,WAAW,EAAE,OAAO,CAAC,WAAW;gBAChC,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;gBAC9B,kBAAkB,EAAE,SAAS;gBAC7B,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;gBAC3C,IAAI,EAAE,YAAY;aACnB,CAAC;YAGF,IAAI,aAAyC,CAAC;YAC9C,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC;gBAClC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;gBACxB,IAAI,OAAO,CAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE;oBACtC,aAAa,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,YAAY,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;gBACnF,CAAC,CAAC;aACH,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE;gBACd,IAAI,aAAa,EAAE,CAAC;oBAClB,YAAY,CAAC,aAAa,CAAC,CAAC;gBAC9B,CAAC;YACH,CAAC,CAAC,CAAC;YAGH,IAAI,QAAQ,CAAC,IAAI,KAAK,mBAAU,CAAC,OAAO,EAAE,CAAC;gBACzC,MAAM,eAAe,GAAoB;oBACvC,QAAQ,EAAE,IAAI;oBACd,SAAS,EAAE,IAAI;oBACf,WAAW,EAAE,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC;oBACpD,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS;iBAC9E,CAAC;gBACF,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,EAAE,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,EAC5D,sBAAsB,CACvB,CAAC;gBACF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACxC,CAAC;iBAAM,CAAC;gBACN,MAAM,cAAc,GAAoB;oBACtC,QAAQ,EAAE,KAAK;oBACf,SAAS,EAAE,KAAK;oBAChB,IAAI,EAAE,QAAQ,CAAC,IAAI;oBACnB,OAAO,EAAE,QAAQ,CAAC,OAAO;oBACzB,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS;iBAC9E,CAAC;gBACF,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,EAAE,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,QAAQ,CAAC,OAAO,EAAE,EACpF,qBAAqB,CACtB,CAAC;gBACF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,YAAY,EAAE,CAAC;gBAClC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,EAAE,4BAA4B,CAAC,CAAC;gBAChF,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;oBACnB,KAAK,EAAE,iBAAiB;oBACxB,OAAO,EAAE,+BAA+B,KAAK,CAAC,SAAS,IAAI;iBAC5D,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;YAED,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,EAAE,iCAAiC,CAAC,CAAC;YACjE,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC;gBACnB,KAAK,EAAE,uBAAuB;gBAC9B,OAAO,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe;aAClE,CAAC,CAAC;QACL,CAAC;IACH,CAAC;CACF;AA3HD,wCA2HC;AAKD,MAAM,YAAa,SAAQ,KAAK;IACrB,SAAS,CAAS;IAE3B,YAAY,SAAiB;QAC3B,KAAK,CAAC,iBAAiB,SAAS,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,IAAI,GAAG,cAAc,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;CACF"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export interface HealthStatus {
|
|
2
|
+
status: 'healthy' | 'unhealthy' | 'starting';
|
|
3
|
+
uptime: number;
|
|
4
|
+
peersConnected: number;
|
|
5
|
+
totalPeers: number;
|
|
6
|
+
timestamp: string;
|
|
7
|
+
nodeId?: string;
|
|
8
|
+
version?: string;
|
|
9
|
+
explorer?: {
|
|
10
|
+
enabled: boolean;
|
|
11
|
+
port: number;
|
|
12
|
+
eventCount: number;
|
|
13
|
+
wsConnections: number;
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
export interface HealthStatusProvider {
|
|
17
|
+
getHealthStatus(): HealthStatus;
|
|
18
|
+
}
|
|
19
|
+
export interface DependencyHealthStatus {
|
|
20
|
+
status: 'up' | 'down';
|
|
21
|
+
latencyMs?: number;
|
|
22
|
+
}
|
|
23
|
+
export interface SLAMetricsSnapshot {
|
|
24
|
+
packetSuccessRate: number;
|
|
25
|
+
settlementSuccessRate: number;
|
|
26
|
+
p99LatencyMs: number;
|
|
27
|
+
}
|
|
28
|
+
export interface HealthStatusExtended extends Omit<HealthStatus, 'status'> {
|
|
29
|
+
status: 'healthy' | 'degraded' | 'unhealthy' | 'starting';
|
|
30
|
+
dependencies: {
|
|
31
|
+
tigerbeetle: DependencyHealthStatus;
|
|
32
|
+
evm?: DependencyHealthStatus;
|
|
33
|
+
};
|
|
34
|
+
sla: SLAMetricsSnapshot;
|
|
35
|
+
}
|
|
36
|
+
export interface HealthStatusExtendedProvider extends HealthStatusProvider {
|
|
37
|
+
getHealthStatusExtended(): HealthStatusExtended;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/http/types.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAO3B,MAAM,EAAE,SAAS,GAAG,WAAW,GAAG,UAAU,CAAC;IAM7C,MAAM,EAAE,MAAM,CAAC;IAMf,cAAc,EAAE,MAAM,CAAC;IAMvB,UAAU,EAAE,MAAM,CAAC;IAMnB,SAAS,EAAE,MAAM,CAAC;IAMlB,MAAM,CAAC,EAAE,MAAM,CAAC;IAMhB,OAAO,CAAC,EAAE,MAAM,CAAC;IAMjB,QAAQ,CAAC,EAAE;QAET,OAAO,EAAE,OAAO,CAAC;QAEjB,IAAI,EAAE,MAAM,CAAC;QAEb,UAAU,EAAE,MAAM,CAAC;QAEnB,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC;CACH;AAkBD,MAAM,WAAW,oBAAoB;IAKnC,eAAe,IAAI,YAAY,CAAC;CACjC;AAMD,MAAM,WAAW,sBAAsB;IAErC,MAAM,EAAE,IAAI,GAAG,MAAM,CAAC;IAEtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAMD,MAAM,WAAW,kBAAkB;IAEjC,iBAAiB,EAAE,MAAM,CAAC;IAE1B,qBAAqB,EAAE,MAAM,CAAC;IAE9B,YAAY,EAAE,MAAM,CAAC;CACtB;AAOD,MAAM,WAAW,oBAAqB,SAAQ,IAAI,CAAC,YAAY,EAAE,QAAQ,CAAC;IAQxE,MAAM,EAAE,SAAS,GAAG,UAAU,GAAG,WAAW,GAAG,UAAU,CAAC;IAM1D,YAAY,EAAE;QACZ,WAAW,EAAE,sBAAsB,CAAC;QACpC,GAAG,CAAC,EAAE,sBAAsB,CAAC;KAC9B,CAAC;IAMF,GAAG,EAAE,kBAAkB,CAAC;CACzB;AAMD,MAAM,WAAW,4BAA6B,SAAQ,oBAAoB;IAKxE,uBAAuB,IAAI,oBAAoB,CAAC;CACjD"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/http/types.ts"],"names":[],"mappings":""}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAMA,cAAc,OAAO,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAMA,gDAAsB"}
|
package/dist/lib.d.ts
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { ConnectorNode } from './core/connector-node';
|
|
2
|
+
import { ConfigLoader, ConfigurationError, ConnectorNotStartedError } from './config/config-loader';
|
|
3
|
+
import { createLogger } from './utils/logger';
|
|
4
|
+
import { RoutingTable } from './routing/routing-table';
|
|
5
|
+
import { PacketHandler } from './core/packet-handler';
|
|
6
|
+
import { BTPServer } from './btp/btp-server';
|
|
7
|
+
import { BTPClient } from './btp/btp-client';
|
|
8
|
+
import { BTPClientManager } from './btp/btp-client-manager';
|
|
9
|
+
import { AdminServer } from './http/admin-server';
|
|
10
|
+
import { AccountManager } from './settlement/account-manager';
|
|
11
|
+
import { SettlementMonitor } from './settlement/settlement-monitor';
|
|
12
|
+
import { UnifiedSettlementExecutor } from './settlement/unified-settlement-executor';
|
|
13
|
+
import { createPaymentHandlerAdapter, REJECT_CODE_MAP, computeFulfillmentFromData, generatePaymentId, mapRejectCode, validateResponseData } from './core/payment-handler';
|
|
14
|
+
import { IlpSendHandler, computeConditionFromData, validateIlpSendRequest } from './http/ilp-send-handler';
|
|
15
|
+
export { ConnectorNode, ConfigLoader, ConfigurationError, ConnectorNotStartedError, RoutingTable, PacketHandler, BTPServer, BTPClient, BTPClientManager, AdminServer, AccountManager, SettlementMonitor, UnifiedSettlementExecutor, createLogger, createPaymentHandlerAdapter, REJECT_CODE_MAP, computeFulfillmentFromData, generatePaymentId, mapRejectCode, validateResponseData, IlpSendHandler, computeConditionFromData, validateIlpSendRequest, };
|
|
16
|
+
export type { ConnectorConfig, PeerConfig, RouteConfig, SettlementConfig, LocalDeliveryConfig, LocalDeliveryHandler, LocalDeliveryRequest, LocalDeliveryResponse, SendPacketParams, SettlementInfraConfig, PeerRegistrationRequest, PeerInfo, PeerAccountBalance, RouteInfo, RemovePeerResult, IlpSendRequest, IlpSendResponse, } from './config/types';
|
|
17
|
+
export type { AdminSettlementConfig } from './settlement/types';
|
|
18
|
+
export type { ChannelOpenOptions, ChannelMetadata } from './settlement/channel-manager';
|
|
19
|
+
export type { PaymentRequest, PaymentResponse, PaymentHandler } from './core/payment-handler';
|
|
20
|
+
export type { PacketSenderFn, IsReadyFn } from './http/ilp-send-handler';
|
|
21
|
+
export type { ILPPreparePacket, ILPFulfillPacket, ILPRejectPacket } from '@toon-protocol/shared';
|
|
22
|
+
//# sourceMappingURL=lib.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lib.d.ts","sourceRoot":"","sources":["../src/lib.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AACpG,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAI5D,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;AACpE,OAAO,EAAE,yBAAyB,EAAE,MAAM,0CAA0C,CAAC;AACrF,OAAO,EACL,2BAA2B,EAC3B,eAAe,EACf,0BAA0B,EAC1B,iBAAiB,EACjB,aAAa,EACb,oBAAoB,EACrB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EACL,cAAc,EACd,wBAAwB,EACxB,sBAAsB,EACvB,MAAM,yBAAyB,CAAC;AAGjC,OAAO,EACL,aAAa,EACb,YAAY,EACZ,kBAAkB,EAClB,wBAAwB,EACxB,YAAY,EACZ,aAAa,EACb,SAAS,EACT,SAAS,EACT,gBAAgB,EAGhB,WAAW,EACX,cAAc,EACd,iBAAiB,EACjB,yBAAyB,EACzB,YAAY,EAEZ,2BAA2B,EAC3B,eAAe,EACf,0BAA0B,EAC1B,iBAAiB,EACjB,aAAa,EACb,oBAAoB,EAEpB,cAAc,EACd,wBAAwB,EACxB,sBAAsB,GACvB,CAAC;AAGF,YAAY,EACV,eAAe,EACf,UAAU,EACV,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACpB,qBAAqB,EACrB,gBAAgB,EAChB,qBAAqB,EACrB,uBAAuB,EACvB,QAAQ,EACR,kBAAkB,EAClB,SAAS,EACT,gBAAgB,EAChB,cAAc,EACd,eAAe,GAChB,MAAM,gBAAgB,CAAC;AAGxB,YAAY,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;AAGhE,YAAY,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAGxF,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAG9F,YAAY,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAGzE,YAAY,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC"}
|
package/dist/lib.js
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateIlpSendRequest = exports.computeConditionFromData = exports.IlpSendHandler = exports.validateResponseData = exports.mapRejectCode = exports.generatePaymentId = exports.computeFulfillmentFromData = exports.REJECT_CODE_MAP = exports.createPaymentHandlerAdapter = exports.createLogger = exports.UnifiedSettlementExecutor = exports.SettlementMonitor = exports.AccountManager = exports.AdminServer = exports.BTPClientManager = exports.BTPClient = exports.BTPServer = exports.PacketHandler = exports.RoutingTable = exports.ConnectorNotStartedError = exports.ConfigurationError = exports.ConfigLoader = exports.ConnectorNode = void 0;
|
|
4
|
+
const connector_node_1 = require("./core/connector-node");
|
|
5
|
+
Object.defineProperty(exports, "ConnectorNode", { enumerable: true, get: function () { return connector_node_1.ConnectorNode; } });
|
|
6
|
+
const config_loader_1 = require("./config/config-loader");
|
|
7
|
+
Object.defineProperty(exports, "ConfigLoader", { enumerable: true, get: function () { return config_loader_1.ConfigLoader; } });
|
|
8
|
+
Object.defineProperty(exports, "ConfigurationError", { enumerable: true, get: function () { return config_loader_1.ConfigurationError; } });
|
|
9
|
+
Object.defineProperty(exports, "ConnectorNotStartedError", { enumerable: true, get: function () { return config_loader_1.ConnectorNotStartedError; } });
|
|
10
|
+
const logger_1 = require("./utils/logger");
|
|
11
|
+
Object.defineProperty(exports, "createLogger", { enumerable: true, get: function () { return logger_1.createLogger; } });
|
|
12
|
+
const routing_table_1 = require("./routing/routing-table");
|
|
13
|
+
Object.defineProperty(exports, "RoutingTable", { enumerable: true, get: function () { return routing_table_1.RoutingTable; } });
|
|
14
|
+
const packet_handler_1 = require("./core/packet-handler");
|
|
15
|
+
Object.defineProperty(exports, "PacketHandler", { enumerable: true, get: function () { return packet_handler_1.PacketHandler; } });
|
|
16
|
+
const btp_server_1 = require("./btp/btp-server");
|
|
17
|
+
Object.defineProperty(exports, "BTPServer", { enumerable: true, get: function () { return btp_server_1.BTPServer; } });
|
|
18
|
+
const btp_client_1 = require("./btp/btp-client");
|
|
19
|
+
Object.defineProperty(exports, "BTPClient", { enumerable: true, get: function () { return btp_client_1.BTPClient; } });
|
|
20
|
+
const btp_client_manager_1 = require("./btp/btp-client-manager");
|
|
21
|
+
Object.defineProperty(exports, "BTPClientManager", { enumerable: true, get: function () { return btp_client_manager_1.BTPClientManager; } });
|
|
22
|
+
const admin_server_1 = require("./http/admin-server");
|
|
23
|
+
Object.defineProperty(exports, "AdminServer", { enumerable: true, get: function () { return admin_server_1.AdminServer; } });
|
|
24
|
+
const account_manager_1 = require("./settlement/account-manager");
|
|
25
|
+
Object.defineProperty(exports, "AccountManager", { enumerable: true, get: function () { return account_manager_1.AccountManager; } });
|
|
26
|
+
const settlement_monitor_1 = require("./settlement/settlement-monitor");
|
|
27
|
+
Object.defineProperty(exports, "SettlementMonitor", { enumerable: true, get: function () { return settlement_monitor_1.SettlementMonitor; } });
|
|
28
|
+
const unified_settlement_executor_1 = require("./settlement/unified-settlement-executor");
|
|
29
|
+
Object.defineProperty(exports, "UnifiedSettlementExecutor", { enumerable: true, get: function () { return unified_settlement_executor_1.UnifiedSettlementExecutor; } });
|
|
30
|
+
const payment_handler_1 = require("./core/payment-handler");
|
|
31
|
+
Object.defineProperty(exports, "createPaymentHandlerAdapter", { enumerable: true, get: function () { return payment_handler_1.createPaymentHandlerAdapter; } });
|
|
32
|
+
Object.defineProperty(exports, "REJECT_CODE_MAP", { enumerable: true, get: function () { return payment_handler_1.REJECT_CODE_MAP; } });
|
|
33
|
+
Object.defineProperty(exports, "computeFulfillmentFromData", { enumerable: true, get: function () { return payment_handler_1.computeFulfillmentFromData; } });
|
|
34
|
+
Object.defineProperty(exports, "generatePaymentId", { enumerable: true, get: function () { return payment_handler_1.generatePaymentId; } });
|
|
35
|
+
Object.defineProperty(exports, "mapRejectCode", { enumerable: true, get: function () { return payment_handler_1.mapRejectCode; } });
|
|
36
|
+
Object.defineProperty(exports, "validateResponseData", { enumerable: true, get: function () { return payment_handler_1.validateResponseData; } });
|
|
37
|
+
const ilp_send_handler_1 = require("./http/ilp-send-handler");
|
|
38
|
+
Object.defineProperty(exports, "IlpSendHandler", { enumerable: true, get: function () { return ilp_send_handler_1.IlpSendHandler; } });
|
|
39
|
+
Object.defineProperty(exports, "computeConditionFromData", { enumerable: true, get: function () { return ilp_send_handler_1.computeConditionFromData; } });
|
|
40
|
+
Object.defineProperty(exports, "validateIlpSendRequest", { enumerable: true, get: function () { return ilp_send_handler_1.validateIlpSendRequest; } });
|
|
41
|
+
//# sourceMappingURL=lib.js.map
|
package/dist/lib.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../src/lib.ts"],"names":[],"mappings":";;;AAMA,0DAAsD;AA+BpD,8FA/BO,8BAAa,OA+BP;AA9Bf,0DAAoG;AA+BlG,6FA/BO,4BAAY,OA+BP;AACZ,mGAhCqB,kCAAkB,OAgCrB;AAClB,yGAjCyC,wCAAwB,OAiCzC;AAhC1B,2CAA8C;AA4C5C,6FA5CO,qBAAY,OA4CP;AA3Cd,2DAAuD;AAgCrD,6FAhCO,4BAAY,OAgCP;AA/Bd,0DAAsD;AAgCpD,8FAhCO,8BAAa,OAgCP;AA/Bf,iDAA6C;AAgC3C,0FAhCO,sBAAS,OAgCP;AA/BX,iDAA6C;AAgC3C,0FAhCO,sBAAS,OAgCP;AA/BX,iEAA4D;AAgC1D,iGAhCO,qCAAgB,OAgCP;AA5BlB,sDAAkD;AA+BhD,4FA/BO,0BAAW,OA+BP;AA9Bb,kEAA8D;AA+B5D,+FA/BO,gCAAc,OA+BP;AA9BhB,wEAAoE;AA+BlE,kGA/BO,sCAAiB,OA+BP;AA9BnB,0FAAqF;AA+BnF,0GA/BO,uDAAyB,OA+BP;AA9B3B,4DAOgC;AA0B9B,4GAhCA,6CAA2B,OAgCA;AAC3B,gGAhCA,iCAAe,OAgCA;AACf,2GAhCA,4CAA0B,OAgCA;AAC1B,kGAhCA,mCAAiB,OAgCA;AACjB,8FAhCA,+BAAa,OAgCA;AACb,qGAhCA,sCAAoB,OAgCA;AA9BtB,8DAIiC;AA4B/B,+FA/BA,iCAAc,OA+BA;AACd,yGA/BA,2CAAwB,OA+BA;AACxB,uGA/BA,yCAAsB,OA+BA"}
|
package/dist/main.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":";AAWA,OAAO,EAAE,IAAI,EAAE,CAAC;AAMhB,iBAAe,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CASnC"}
|
package/dist/main.js
ADDED
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
"use strict";
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.main = main;
|
|
5
|
+
const lib_1 = require("./lib");
|
|
6
|
+
async function main() {
|
|
7
|
+
const configFile = process.env.CONFIG_FILE || './config.yaml';
|
|
8
|
+
const logLevel = process.env.LOG_LEVEL || 'info';
|
|
9
|
+
const logger = (0, lib_1.createLogger)('connector-startup', logLevel);
|
|
10
|
+
await startConnectorMode(configFile, logger);
|
|
11
|
+
}
|
|
12
|
+
async function startConnectorMode(configFile, logger) {
|
|
13
|
+
let connectorNode;
|
|
14
|
+
try {
|
|
15
|
+
connectorNode = new lib_1.ConnectorNode(configFile, logger);
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
if (error instanceof lib_1.ConfigurationError) {
|
|
19
|
+
logger.error({
|
|
20
|
+
event: 'configuration_error',
|
|
21
|
+
filePath: configFile,
|
|
22
|
+
error: error.message,
|
|
23
|
+
}, 'Configuration error');
|
|
24
|
+
console.error(`Configuration error: ${error.message}`);
|
|
25
|
+
process.exit(1);
|
|
26
|
+
}
|
|
27
|
+
throw error;
|
|
28
|
+
}
|
|
29
|
+
async function shutdown(signal) {
|
|
30
|
+
logger.info({ event: 'connector_shutdown_initiated', signal }, 'Shutdown signal received');
|
|
31
|
+
try {
|
|
32
|
+
await connectorNode.stop();
|
|
33
|
+
logger.info({ event: 'connector_shutdown' }, 'Connector stopped');
|
|
34
|
+
process.exit(0);
|
|
35
|
+
}
|
|
36
|
+
catch (error) {
|
|
37
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
38
|
+
logger.error({ event: 'connector_shutdown_failed', error: errorMessage }, 'Shutdown failed');
|
|
39
|
+
process.exit(1);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
process.on('SIGTERM', () => void shutdown('SIGTERM'));
|
|
43
|
+
process.on('SIGINT', () => void shutdown('SIGINT'));
|
|
44
|
+
process.on('uncaughtException', (error) => {
|
|
45
|
+
logger.error({
|
|
46
|
+
event: 'uncaught_exception',
|
|
47
|
+
error: error.message,
|
|
48
|
+
stack: error.stack,
|
|
49
|
+
}, 'Uncaught exception');
|
|
50
|
+
void shutdown('uncaughtException');
|
|
51
|
+
});
|
|
52
|
+
process.on('unhandledRejection', (reason) => {
|
|
53
|
+
const errorMessage = reason instanceof Error ? reason.message : String(reason);
|
|
54
|
+
logger.error({
|
|
55
|
+
event: 'unhandled_rejection',
|
|
56
|
+
reason: errorMessage,
|
|
57
|
+
}, 'Unhandled promise rejection');
|
|
58
|
+
void shutdown('unhandledRejection');
|
|
59
|
+
});
|
|
60
|
+
try {
|
|
61
|
+
await connectorNode.start();
|
|
62
|
+
logger.info({
|
|
63
|
+
event: 'connector_started',
|
|
64
|
+
}, 'Connector started successfully');
|
|
65
|
+
}
|
|
66
|
+
catch (error) {
|
|
67
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
68
|
+
logger.error({
|
|
69
|
+
event: 'connector_start_failed',
|
|
70
|
+
error: errorMessage,
|
|
71
|
+
}, 'Failed to start connector');
|
|
72
|
+
process.exit(1);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
const isMainModule = require.main === module || process.argv[1]?.includes('connector');
|
|
76
|
+
if (isMainModule) {
|
|
77
|
+
void main();
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Logger } from 'pino';
|
|
2
|
+
import { WorkerPool } from './worker-pool';
|
|
3
|
+
export interface PacketProcessorConfig {
|
|
4
|
+
workerThreads?: number;
|
|
5
|
+
batchSize?: number;
|
|
6
|
+
enableParallelProcessing?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface PacketBatch {
|
|
9
|
+
packets: Buffer[];
|
|
10
|
+
batchId: string;
|
|
11
|
+
}
|
|
12
|
+
export interface ProcessedPacketBatch {
|
|
13
|
+
processedPackets: Buffer[];
|
|
14
|
+
batchId: string;
|
|
15
|
+
processingTimeMs: number;
|
|
16
|
+
}
|
|
17
|
+
export declare class PacketProcessor {
|
|
18
|
+
private readonly logger;
|
|
19
|
+
private readonly config;
|
|
20
|
+
private workerPool?;
|
|
21
|
+
private batchIdCounter;
|
|
22
|
+
constructor(config: PacketProcessorConfig, logger: Logger);
|
|
23
|
+
initialize(): Promise<void>;
|
|
24
|
+
processBatch(packets: Buffer[]): Promise<ProcessedPacketBatch>;
|
|
25
|
+
private processBatchSync;
|
|
26
|
+
processPacket(packet: Buffer): Promise<Buffer>;
|
|
27
|
+
shutdown(): Promise<void>;
|
|
28
|
+
getStats(): {
|
|
29
|
+
workerPoolStats?: ReturnType<WorkerPool['getStats']>;
|
|
30
|
+
parallelProcessingEnabled: boolean;
|
|
31
|
+
configuredWorkerThreads: number;
|
|
32
|
+
configuredBatchSize: number;
|
|
33
|
+
};
|
|
34
|
+
isBusy(): boolean;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=packet-processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"packet-processor.d.ts","sourceRoot":"","sources":["../../src/routing/packet-processor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,UAAU,EAAoB,MAAM,eAAe,CAAC;AAK7D,MAAM,WAAW,qBAAqB;IACpC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,wBAAwB,CAAC,EAAE,OAAO,CAAC;CACpC;AAED,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,oBAAoB;IACnC,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAMD,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkC;IACzD,OAAO,CAAC,UAAU,CAAC,CAAa;IAChC,OAAO,CAAC,cAAc,CAAS;gBAEnB,MAAM,EAAE,qBAAqB,EAAE,MAAM,EAAE,MAAM;IAsBnD,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAwB3B,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAqDpE,OAAO,CAAC,gBAAgB;IAalB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAY9C,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAU/B,QAAQ,IAAI;QACV,eAAe,CAAC,EAAE,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;QACrD,yBAAyB,EAAE,OAAO,CAAC;QACnC,uBAAuB,EAAE,MAAM,CAAC;QAChC,mBAAmB,EAAE,MAAM,CAAC;KAC7B;IAYD,MAAM,IAAI,OAAO;CAGlB"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PacketProcessor = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const worker_pool_1 = require("./worker-pool");
|
|
6
|
+
const path = tslib_1.__importStar(require("path"));
|
|
7
|
+
const os = tslib_1.__importStar(require("os"));
|
|
8
|
+
class PacketProcessor {
|
|
9
|
+
logger;
|
|
10
|
+
config;
|
|
11
|
+
workerPool;
|
|
12
|
+
batchIdCounter;
|
|
13
|
+
constructor(config, logger) {
|
|
14
|
+
this.logger = logger.child({ component: 'packet-processor' });
|
|
15
|
+
this.config = {
|
|
16
|
+
workerThreads: config.workerThreads || os.cpus().length,
|
|
17
|
+
batchSize: config.batchSize || 100,
|
|
18
|
+
enableParallelProcessing: config.enableParallelProcessing ?? true,
|
|
19
|
+
};
|
|
20
|
+
this.batchIdCounter = 0;
|
|
21
|
+
this.logger.info({
|
|
22
|
+
workerThreads: this.config.workerThreads,
|
|
23
|
+
batchSize: this.config.batchSize,
|
|
24
|
+
enableParallelProcessing: this.config.enableParallelProcessing,
|
|
25
|
+
}, 'PacketProcessor initialized');
|
|
26
|
+
}
|
|
27
|
+
async initialize() {
|
|
28
|
+
if (!this.config.enableParallelProcessing) {
|
|
29
|
+
this.logger.info('Parallel processing disabled, using synchronous mode');
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const workerScriptPath = path.join(__dirname, 'packet-worker.js');
|
|
33
|
+
const poolConfig = {
|
|
34
|
+
numWorkers: this.config.workerThreads,
|
|
35
|
+
workerScript: workerScriptPath,
|
|
36
|
+
maxQueueSize: 10000,
|
|
37
|
+
};
|
|
38
|
+
this.workerPool = new worker_pool_1.WorkerPool(poolConfig, this.logger);
|
|
39
|
+
await this.workerPool.initialize();
|
|
40
|
+
this.logger.info('PacketProcessor worker pool initialized');
|
|
41
|
+
}
|
|
42
|
+
async processBatch(packets) {
|
|
43
|
+
const startTime = Date.now();
|
|
44
|
+
const batchId = `batch-${this.batchIdCounter++}`;
|
|
45
|
+
if (!this.config.enableParallelProcessing || !this.workerPool) {
|
|
46
|
+
const processedPackets = this.processBatchSync(packets);
|
|
47
|
+
const processingTimeMs = Date.now() - startTime;
|
|
48
|
+
return {
|
|
49
|
+
processedPackets,
|
|
50
|
+
batchId,
|
|
51
|
+
processingTimeMs,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
try {
|
|
55
|
+
const result = await this.workerPool.execute({
|
|
56
|
+
packets,
|
|
57
|
+
});
|
|
58
|
+
const processingTimeMs = Date.now() - startTime;
|
|
59
|
+
this.logger.trace({
|
|
60
|
+
batchId,
|
|
61
|
+
packetCount: packets.length,
|
|
62
|
+
processingTimeMs,
|
|
63
|
+
}, 'Batch processed');
|
|
64
|
+
return {
|
|
65
|
+
processedPackets: result.processedPackets,
|
|
66
|
+
batchId,
|
|
67
|
+
processingTimeMs,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
this.logger.error({
|
|
72
|
+
batchId,
|
|
73
|
+
error: error.message,
|
|
74
|
+
}, 'Error processing batch');
|
|
75
|
+
throw error;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
processBatchSync(packets) {
|
|
79
|
+
return packets.map((packet) => {
|
|
80
|
+
const copy = Buffer.allocUnsafe(packet.length);
|
|
81
|
+
packet.copy(copy);
|
|
82
|
+
return copy;
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
async processPacket(packet) {
|
|
86
|
+
const result = await this.processBatch([packet]);
|
|
87
|
+
const processed = result.processedPackets[0];
|
|
88
|
+
if (!processed) {
|
|
89
|
+
throw new Error('No processed packet returned from batch');
|
|
90
|
+
}
|
|
91
|
+
return processed;
|
|
92
|
+
}
|
|
93
|
+
async shutdown() {
|
|
94
|
+
if (this.workerPool) {
|
|
95
|
+
await this.workerPool.shutdown();
|
|
96
|
+
this.logger.info('PacketProcessor worker pool shutdown complete');
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
getStats() {
|
|
100
|
+
return {
|
|
101
|
+
workerPoolStats: this.workerPool?.getStats(),
|
|
102
|
+
parallelProcessingEnabled: this.config.enableParallelProcessing,
|
|
103
|
+
configuredWorkerThreads: this.config.workerThreads,
|
|
104
|
+
configuredBatchSize: this.config.batchSize,
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
isBusy() {
|
|
108
|
+
return this.workerPool?.isBusy() ?? false;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
exports.PacketProcessor = PacketProcessor;
|
|
112
|
+
//# sourceMappingURL=packet-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"packet-processor.js","sourceRoot":"","sources":["../../src/routing/packet-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"packet-worker.d.ts","sourceRoot":"","sources":["../../src/routing/packet-worker.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const worker_threads_1 = require("worker_threads");
|
|
4
|
+
if (!worker_threads_1.parentPort) {
|
|
5
|
+
throw new Error('This script must be run as a worker thread');
|
|
6
|
+
}
|
|
7
|
+
const workerId = worker_threads_1.workerData?.workerId ?? 0;
|
|
8
|
+
worker_threads_1.parentPort.on('message', (task) => {
|
|
9
|
+
try {
|
|
10
|
+
const processedPackets = processPackets(task.packets);
|
|
11
|
+
const result = {
|
|
12
|
+
taskId: task.taskId,
|
|
13
|
+
processedPackets,
|
|
14
|
+
};
|
|
15
|
+
worker_threads_1.parentPort.postMessage(result);
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
const result = {
|
|
19
|
+
taskId: task.taskId,
|
|
20
|
+
processedPackets: [],
|
|
21
|
+
error: error.message,
|
|
22
|
+
};
|
|
23
|
+
worker_threads_1.parentPort.postMessage(result);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
function processPackets(packets) {
|
|
27
|
+
return packets.map((packet) => {
|
|
28
|
+
const copy = Buffer.allocUnsafe(packet.length);
|
|
29
|
+
packet.copy(copy);
|
|
30
|
+
return copy;
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
worker_threads_1.parentPort.postMessage({ ready: true, workerId });
|
|
34
|
+
//# sourceMappingURL=packet-worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"packet-worker.js","sourceRoot":"","sources":["../../src/routing/packet-worker.ts"],"names":[],"mappings":";;AAAA,mDAAwD;AAkBxD,IAAI,CAAC,2BAAU,EAAE,CAAC;IAChB,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;AAChE,CAAC;AAED,MAAM,QAAQ,GAAG,2BAAU,EAAE,QAAQ,IAAI,CAAC,CAAC;AAG3C,2BAAU,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAsB,EAAE,EAAE;IAClD,IAAI,CAAC;QAEH,MAAM,gBAAgB,GAAG,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAGtD,MAAM,MAAM,GAAuB;YACjC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,gBAAgB;SACjB,CAAC;QAEF,2BAAW,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAEf,MAAM,MAAM,GAAuB;YACjC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,gBAAgB,EAAE,EAAE;YACpB,KAAK,EAAG,KAAe,CAAC,OAAO;SAChC,CAAC;QAEF,2BAAW,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;AACH,CAAC,CAAC,CAAC;AAMH,SAAS,cAAc,CAAC,OAAiB;IASvC,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QAE5B,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC/C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClB,OAAO,IAAI,CAAC;IACd,CAAC,CAAC,CAAC;AACL,CAAC;AAGD,2BAAU,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC"}
|