@toon-protocol/connector 3.3.1 → 3.3.3
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/dist/btp/btp-claim-types.d.ts +52 -0
- package/dist/btp/btp-claim-types.d.ts.map +1 -0
- package/dist/btp/btp-claim-types.js +209 -0
- package/dist/btp/btp-claim-types.js.map +1 -0
- package/dist/btp/btp-client-manager.d.ts +30 -0
- package/dist/btp/btp-client-manager.d.ts.map +1 -0
- package/dist/btp/btp-client-manager.js +153 -0
- package/dist/btp/btp-client-manager.js.map +1 -0
- package/dist/btp/btp-client.d.ts +58 -0
- package/dist/btp/btp-client.d.ts.map +1 -0
- package/dist/btp/btp-client.js +485 -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 +33 -0
- package/dist/btp/btp-server.d.ts.map +1 -0
- package/dist/btp/btp-server.js +485 -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/btp/inbound-claim-validator.d.ts +20 -0
- package/dist/btp/inbound-claim-validator.d.ts.map +1 -0
- package/dist/btp/inbound-claim-validator.js +150 -0
- package/dist/btp/inbound-claim-validator.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/config-loader.d.ts +24 -0
- package/dist/config/config-loader.d.ts.map +1 -0
- package/dist/config/config-loader.js +436 -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 +3 -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 +226 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +52 -0
- package/dist/config/types.js.map +1 -0
- package/dist/core/connector-node.d.ts +91 -0
- package/dist/core/connector-node.d.ts.map +1 -0
- package/dist/core/connector-node.js +1322 -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 +160 -0
- package/dist/core/local-delivery-client.js.map +1 -0
- package/dist/core/packet-handler.d.ts +57 -0
- package/dist/core/packet-handler.d.ts.map +1 -0
- package/dist/core/packet-handler.js +655 -0
- package/dist/core/packet-handler.js.map +1 -0
- package/dist/core/payment-handler.d.ts +26 -0
- package/dist/core/payment-handler.d.ts.map +1 -0
- package/dist/core/payment-handler.js +106 -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/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-inventory.d.ts +29 -0
- package/dist/http/admin-api-inventory.d.ts.map +1 -0
- package/dist/http/admin-api-inventory.js +480 -0
- package/dist/http/admin-api-inventory.js.map +1 -0
- package/dist/http/admin-api.d.ts +182 -0
- package/dist/http/admin-api.d.ts.map +1 -0
- package/dist/http/admin-api.js +1324 -0
- package/dist/http/admin-api.js.map +1 -0
- package/dist/http/admin-server.d.ts +49 -0
- package/dist/http/admin-server.d.ts.map +1 -0
- package/dist/http/admin-server.js +160 -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 +15 -0
- package/dist/http/ilp-send-handler.d.ts.map +1 -0
- package/dist/http/ilp-send-handler.js +167 -0
- package/dist/http/ilp-send-handler.js.map +1 -0
- package/dist/http/types.d.ts +43 -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 +39 -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/observability/metrics-registry.d.ts +39 -0
- package/dist/observability/metrics-registry.d.ts.map +1 -0
- package/dist/observability/metrics-registry.js +151 -0
- package/dist/observability/metrics-registry.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/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/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 +51 -0
- package/dist/settlement/account-manager.d.ts.map +1 -0
- package/dist/settlement/account-manager.js +459 -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/channel-manager.d.ts +67 -0
- package/dist/settlement/channel-manager.d.ts.map +1 -0
- package/dist/settlement/channel-manager.js +226 -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 +67 -0
- package/dist/settlement/claim-receiver.d.ts.map +1 -0
- package/dist/settlement/claim-receiver.js +707 -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 +24 -0
- package/dist/settlement/claim-sender.d.ts.map +1 -0
- package/dist/settlement/claim-sender.js +146 -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/mina-payment-channel-sdk.d.ts +73 -0
- package/dist/settlement/mina-payment-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/mina-payment-channel-sdk.js +538 -0
- package/dist/settlement/mina-payment-channel-sdk.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 +39 -0
- package/dist/settlement/per-packet-claim-service.d.ts.map +1 -0
- package/dist/settlement/per-packet-claim-service.js +342 -0
- package/dist/settlement/per-packet-claim-service.js.map +1 -0
- package/dist/settlement/privacy/index.d.ts +3 -0
- package/dist/settlement/privacy/index.d.ts.map +1 -0
- package/dist/settlement/privacy/index.js +11 -0
- package/dist/settlement/privacy/index.js.map +1 -0
- package/dist/settlement/privacy/nip59-claim-wrapper.d.ts +60 -0
- package/dist/settlement/privacy/nip59-claim-wrapper.d.ts.map +1 -0
- package/dist/settlement/privacy/nip59-claim-wrapper.js +361 -0
- package/dist/settlement/privacy/nip59-claim-wrapper.js.map +1 -0
- package/dist/settlement/provider/chain-provider-registry.d.ts +20 -0
- package/dist/settlement/provider/chain-provider-registry.d.ts.map +1 -0
- package/dist/settlement/provider/chain-provider-registry.js +53 -0
- package/dist/settlement/provider/chain-provider-registry.js.map +1 -0
- package/dist/settlement/provider/evm-payment-channel-provider.d.ts +31 -0
- package/dist/settlement/provider/evm-payment-channel-provider.d.ts.map +1 -0
- package/dist/settlement/provider/evm-payment-channel-provider.js +207 -0
- package/dist/settlement/provider/evm-payment-channel-provider.js.map +1 -0
- package/dist/settlement/provider/index.d.ts +6 -0
- package/dist/settlement/provider/index.d.ts.map +1 -0
- package/dist/settlement/provider/index.js +16 -0
- package/dist/settlement/provider/index.js.map +1 -0
- package/dist/settlement/provider/mina-payment-channel-provider.d.ts +43 -0
- package/dist/settlement/provider/mina-payment-channel-provider.d.ts.map +1 -0
- package/dist/settlement/provider/mina-payment-channel-provider.js +330 -0
- package/dist/settlement/provider/mina-payment-channel-provider.js.map +1 -0
- package/dist/settlement/provider/payment-channel-provider.d.ts +88 -0
- package/dist/settlement/provider/payment-channel-provider.d.ts.map +1 -0
- package/dist/settlement/provider/payment-channel-provider.js +3 -0
- package/dist/settlement/provider/payment-channel-provider.js.map +1 -0
- package/dist/settlement/provider/solana-payment-channel-provider.d.ts +38 -0
- package/dist/settlement/provider/solana-payment-channel-provider.d.ts.map +1 -0
- package/dist/settlement/provider/solana-payment-channel-provider.js +262 -0
- package/dist/settlement/provider/solana-payment-channel-provider.js.map +1 -0
- package/dist/settlement/sent-claims-queries.d.ts +23 -0
- package/dist/settlement/sent-claims-queries.d.ts.map +1 -0
- package/dist/settlement/sent-claims-queries.js +134 -0
- package/dist/settlement/sent-claims-queries.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 +51 -0
- package/dist/settlement/settlement-executor.d.ts.map +1 -0
- package/dist/settlement/settlement-executor.js +265 -0
- package/dist/settlement/settlement-executor.js.map +1 -0
- package/dist/settlement/settlement-monitor.d.ts +30 -0
- package/dist/settlement/settlement-monitor.d.ts.map +1 -0
- package/dist/settlement/settlement-monitor.js +141 -0
- package/dist/settlement/settlement-monitor.js.map +1 -0
- package/dist/settlement/solana-payment-channel-sdk.d.ts +79 -0
- package/dist/settlement/solana-payment-channel-sdk.d.ts.map +1 -0
- package/dist/settlement/solana-payment-channel-sdk.js +636 -0
- package/dist/settlement/solana-payment-channel-sdk.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/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/transport/direct-transport-provider.d.ts +12 -0
- package/dist/transport/direct-transport-provider.d.ts.map +1 -0
- package/dist/transport/direct-transport-provider.js +27 -0
- package/dist/transport/direct-transport-provider.js.map +1 -0
- package/dist/transport/index.d.ts +7 -0
- package/dist/transport/index.d.ts.map +1 -0
- package/dist/transport/index.js +16 -0
- package/dist/transport/index.js.map +1 -0
- package/dist/transport/managed-anon-client.d.ts +47 -0
- package/dist/transport/managed-anon-client.d.ts.map +1 -0
- package/dist/transport/managed-anon-client.js +265 -0
- package/dist/transport/managed-anon-client.js.map +1 -0
- package/dist/transport/probe-tcp-port.d.ts +3 -0
- package/dist/transport/probe-tcp-port.d.ts.map +1 -0
- package/dist/transport/probe-tcp-port.js +59 -0
- package/dist/transport/probe-tcp-port.js.map +1 -0
- package/dist/transport/socks-transport-provider.d.ts +29 -0
- package/dist/transport/socks-transport-provider.d.ts.map +1 -0
- package/dist/transport/socks-transport-provider.js +136 -0
- package/dist/transport/socks-transport-provider.js.map +1 -0
- package/dist/transport/socks-url.d.ts +6 -0
- package/dist/transport/socks-url.d.ts.map +1 -0
- package/dist/transport/socks-url.js +29 -0
- package/dist/transport/socks-url.js.map +1 -0
- package/dist/transport/transport-provider.d.ts +9 -0
- package/dist/transport/transport-provider.d.ts.map +1 -0
- package/dist/transport/transport-provider.js +3 -0
- package/dist/transport/transport-provider.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/redact.d.ts +3 -0
- package/dist/utils/redact.d.ts.map +1 -0
- package/dist/utils/redact.js +21 -0
- package/dist/utils/redact.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/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 +1 -1
|
@@ -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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ILPAddress, RoutingTableEntry } from '@toon-protocol/shared';
|
|
2
|
+
export declare class RoutingTable {
|
|
3
|
+
private readonly routes;
|
|
4
|
+
private readonly logger?;
|
|
5
|
+
constructor(initialRoutes?: RoutingTableEntry[], logger?: {
|
|
6
|
+
info: (obj: object, msg?: string) => void;
|
|
7
|
+
error: (obj: object, msg?: string) => void;
|
|
8
|
+
});
|
|
9
|
+
addRoute(prefix: ILPAddress, nextHop: string, priority?: number): void;
|
|
10
|
+
removeRoute(prefix: string): void;
|
|
11
|
+
getNextHop(destination: ILPAddress): string | null;
|
|
12
|
+
getAllRoutes(): RoutingTableEntry[];
|
|
13
|
+
get size(): number;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=routing-table.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routing-table.d.ts","sourceRoot":"","sources":["../../src/routing/routing-table.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAqB,MAAM,uBAAuB,CAAC;AAqBzF,qBAAa,YAAY;IAMvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiC;IAQxD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAGtB;gBASA,aAAa,CAAC,EAAE,iBAAiB,EAAE,EACnC,MAAM,CAAC,EAAE;QACP,IAAI,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;QAC1C,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;KAC5C;IA0BH,QAAQ,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,GAAE,MAAU,GAAG,IAAI;IAoBzE,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IA+BjC,UAAU,CAAC,WAAW,EAAE,UAAU,GAAG,MAAM,GAAG,IAAI;IA+BlD,YAAY,IAAI,iBAAiB,EAAE;IAYnC,IAAI,IAAI,IAAI,MAAM,CAEjB;CACF"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RoutingTable = void 0;
|
|
4
|
+
const shared_1 = require("@toon-protocol/shared");
|
|
5
|
+
class RoutingTable {
|
|
6
|
+
routes;
|
|
7
|
+
logger;
|
|
8
|
+
constructor(initialRoutes, logger) {
|
|
9
|
+
this.routes = new Map();
|
|
10
|
+
this.logger = logger;
|
|
11
|
+
if (initialRoutes && initialRoutes.length > 0) {
|
|
12
|
+
for (const route of initialRoutes) {
|
|
13
|
+
this.addRoute(route.prefix, route.nextHop, route.priority);
|
|
14
|
+
}
|
|
15
|
+
this.logger?.info({ routeCount: initialRoutes.length }, `Initialized routing table with ${initialRoutes.length} routes`);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
addRoute(prefix, nextHop, priority = 0) {
|
|
19
|
+
if (!(0, shared_1.isValidILPAddress)(prefix)) {
|
|
20
|
+
const error = new Error(`Invalid ILP address prefix: ${prefix}`);
|
|
21
|
+
this.logger?.error({ prefix, nextHop, priority }, error.message);
|
|
22
|
+
throw error;
|
|
23
|
+
}
|
|
24
|
+
const entry = { prefix, nextHop, priority };
|
|
25
|
+
this.routes.set(prefix, entry);
|
|
26
|
+
this.logger?.info({ prefix, nextHop, priority }, `Added route: ${prefix} -> ${nextHop}`);
|
|
27
|
+
}
|
|
28
|
+
removeRoute(prefix) {
|
|
29
|
+
const existed = this.routes.has(prefix);
|
|
30
|
+
this.routes.delete(prefix);
|
|
31
|
+
if (existed) {
|
|
32
|
+
this.logger?.info({ prefix }, `Removed route: ${prefix}`);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
getNextHop(destination) {
|
|
36
|
+
let bestMatch = null;
|
|
37
|
+
let longestPrefixLength = -1;
|
|
38
|
+
for (const route of this.routes.values()) {
|
|
39
|
+
if (destination === route.prefix || destination.startsWith(route.prefix + '.')) {
|
|
40
|
+
const prefixLength = route.prefix.length;
|
|
41
|
+
if (prefixLength > longestPrefixLength ||
|
|
42
|
+
(prefixLength === longestPrefixLength &&
|
|
43
|
+
(route.priority ?? 0) > (bestMatch?.priority ?? 0))) {
|
|
44
|
+
bestMatch = route;
|
|
45
|
+
longestPrefixLength = prefixLength;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return bestMatch?.nextHop ?? null;
|
|
50
|
+
}
|
|
51
|
+
getAllRoutes() {
|
|
52
|
+
return Array.from(this.routes.values()).map((route) => ({
|
|
53
|
+
prefix: route.prefix,
|
|
54
|
+
nextHop: route.nextHop,
|
|
55
|
+
priority: route.priority,
|
|
56
|
+
}));
|
|
57
|
+
}
|
|
58
|
+
get size() {
|
|
59
|
+
return this.routes.size;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.RoutingTable = RoutingTable;
|
|
63
|
+
//# sourceMappingURL=routing-table.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routing-table.js","sourceRoot":"","sources":["../../src/routing/routing-table.ts"],"names":[],"mappings":";;;AAMA,kDAAyF;AAqBzF,MAAa,YAAY;IAMN,MAAM,CAAiC;IAQvC,MAAM,CAGrB;IAQF,YACE,aAAmC,EACnC,MAGC;QAED,IAAI,CAAC,MAAM,GAAG,IAAI,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QAErB,IAAI,aAAa,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9C,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;gBAClC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC7D,CAAC;YACD,IAAI,CAAC,MAAM,EAAE,IAAI,CACf,EAAE,UAAU,EAAE,aAAa,CAAC,MAAM,EAAE,EACpC,kCAAkC,aAAa,CAAC,MAAM,SAAS,CAChE,CAAC;QACJ,CAAC;IACH,CAAC;IAYD,QAAQ,CAAC,MAAkB,EAAE,OAAe,EAAE,WAAmB,CAAC;QAChE,IAAI,CAAC,IAAA,0BAAiB,EAAC,MAAM,CAAC,EAAE,CAAC;YAC/B,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,+BAA+B,MAAM,EAAE,CAAC,CAAC;YACjE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;YACjE,MAAM,KAAK,CAAC;QACd,CAAC;QAED,MAAM,KAAK,GAAsB,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC;QAC/D,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAE/B,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,gBAAgB,MAAM,OAAO,OAAO,EAAE,CAAC,CAAC;IAC3F,CAAC;IASD,WAAW,CAAC,MAAc;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACxC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,kBAAkB,MAAM,EAAE,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAwBD,UAAU,CAAC,WAAuB;QAChC,IAAI,SAAS,GAA6B,IAAI,CAAC;QAC/C,IAAI,mBAAmB,GAAG,CAAC,CAAC,CAAC;QAE7B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC;YAEzC,IAAI,WAAW,KAAK,KAAK,CAAC,MAAM,IAAI,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,EAAE,CAAC;gBAC/E,MAAM,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;gBAGzC,IACE,YAAY,GAAG,mBAAmB;oBAClC,CAAC,YAAY,KAAK,mBAAmB;wBACnC,CAAC,KAAK,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,IAAI,CAAC,CAAC,CAAC,EACrD,CAAC;oBACD,SAAS,GAAG,KAAK,CAAC;oBAClB,mBAAmB,GAAG,YAAY,CAAC;gBACrC,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,SAAS,EAAE,OAAO,IAAI,IAAI,CAAC;IACpC,CAAC;IASD,YAAY;QACV,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACtD,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;SACzB,CAAC,CAAC,CAAC;IACN,CAAC;IAMD,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;IAC1B,CAAC;CACF;AAzJD,oCAyJC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Logger } from 'pino';
|
|
2
|
+
import { EventEmitter } from 'events';
|
|
3
|
+
export interface WorkerPoolConfig {
|
|
4
|
+
numWorkers: number;
|
|
5
|
+
workerScript: string;
|
|
6
|
+
maxQueueSize?: number;
|
|
7
|
+
}
|
|
8
|
+
export interface WorkerTask<T = any, R = any> {
|
|
9
|
+
id: string;
|
|
10
|
+
data: T;
|
|
11
|
+
resolve: (result: R) => void;
|
|
12
|
+
reject: (error: Error) => void;
|
|
13
|
+
}
|
|
14
|
+
export declare class WorkerPool extends EventEmitter {
|
|
15
|
+
private readonly logger;
|
|
16
|
+
private readonly config;
|
|
17
|
+
private readonly workers;
|
|
18
|
+
private readonly taskQueue;
|
|
19
|
+
private readonly pendingTasks;
|
|
20
|
+
private nextWorkerIndex;
|
|
21
|
+
private isShuttingDown;
|
|
22
|
+
private taskIdCounter;
|
|
23
|
+
constructor(config: WorkerPoolConfig, logger: Logger);
|
|
24
|
+
initialize(): Promise<void>;
|
|
25
|
+
private spawnWorker;
|
|
26
|
+
private handleWorkerMessage;
|
|
27
|
+
private handleWorkerError;
|
|
28
|
+
private handleWorkerExit;
|
|
29
|
+
execute<T = any, R = any>(data: T): Promise<R>;
|
|
30
|
+
private processQueue;
|
|
31
|
+
private findAvailableWorker;
|
|
32
|
+
shutdown(): Promise<void>;
|
|
33
|
+
getStats(): {
|
|
34
|
+
totalWorkers: number;
|
|
35
|
+
busyWorkers: number;
|
|
36
|
+
queuedTasks: number;
|
|
37
|
+
pendingTasks: number;
|
|
38
|
+
totalTasksProcessed: number;
|
|
39
|
+
};
|
|
40
|
+
getQueueSize(): number;
|
|
41
|
+
isBusy(): boolean;
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=worker-pool.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-pool.d.ts","sourceRoot":"","sources":["../../src/routing/worker-pool.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAGtC,MAAM,WAAW,gBAAgB;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAGD,MAAM,WAAW,UAAU,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG;IAC1C,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,CAAC,CAAC;IACR,OAAO,EAAE,CAAC,MAAM,EAAE,CAAC,KAAK,IAAI,CAAC;IAC7B,MAAM,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;CAChC;AAaD,qBAAa,UAAW,SAAQ,YAAY;IAC1C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA6B;IACpD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;IACxC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAe;IACzC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA0B;IACvD,OAAO,CAAC,eAAe,CAAS;IAChC,OAAO,CAAC,cAAc,CAAU;IAChC,OAAO,CAAC,aAAa,CAAS;gBAElB,MAAM,EAAE,gBAAgB,EAAE,MAAM,EAAE,MAAM;IA4B9C,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;YAkBnB,WAAW;IA2CzB,OAAO,CAAC,mBAAmB;IA0C3B,OAAO,CAAC,iBAAiB;YAeX,gBAAgB;IAyBxB,OAAO,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,EAAE,IAAI,EAAE,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IA+BpD,OAAO,CAAC,YAAY;IAmCpB,OAAO,CAAC,mBAAmB;IAmBrB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IA0C/B,QAAQ,IAAI;QACV,YAAY,EAAE,MAAM,CAAC;QACrB,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;QACpB,YAAY,EAAE,MAAM,CAAC;QACrB,mBAAmB,EAAE,MAAM,CAAC;KAC7B;IAgBD,YAAY,IAAI,MAAM;IAOtB,MAAM,IAAI,OAAO;CAGlB"}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.WorkerPool = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const worker_threads_1 = require("worker_threads");
|
|
6
|
+
const events_1 = require("events");
|
|
7
|
+
const os = tslib_1.__importStar(require("os"));
|
|
8
|
+
class WorkerPool extends events_1.EventEmitter {
|
|
9
|
+
logger;
|
|
10
|
+
config;
|
|
11
|
+
workers;
|
|
12
|
+
taskQueue;
|
|
13
|
+
pendingTasks;
|
|
14
|
+
nextWorkerIndex;
|
|
15
|
+
isShuttingDown;
|
|
16
|
+
taskIdCounter;
|
|
17
|
+
constructor(config, logger) {
|
|
18
|
+
super();
|
|
19
|
+
this.logger = logger.child({ component: 'worker-pool' });
|
|
20
|
+
this.config = {
|
|
21
|
+
numWorkers: config.numWorkers || os.cpus().length,
|
|
22
|
+
workerScript: config.workerScript,
|
|
23
|
+
maxQueueSize: config.maxQueueSize || 10000,
|
|
24
|
+
};
|
|
25
|
+
this.workers = [];
|
|
26
|
+
this.taskQueue = [];
|
|
27
|
+
this.pendingTasks = new Map();
|
|
28
|
+
this.nextWorkerIndex = 0;
|
|
29
|
+
this.isShuttingDown = false;
|
|
30
|
+
this.taskIdCounter = 0;
|
|
31
|
+
this.logger.info({
|
|
32
|
+
numWorkers: this.config.numWorkers,
|
|
33
|
+
workerScript: this.config.workerScript,
|
|
34
|
+
maxQueueSize: this.config.maxQueueSize,
|
|
35
|
+
}, 'WorkerPool initialized');
|
|
36
|
+
}
|
|
37
|
+
async initialize() {
|
|
38
|
+
if (this.workers.length > 0) {
|
|
39
|
+
throw new Error('WorkerPool already initialized');
|
|
40
|
+
}
|
|
41
|
+
const initPromises = [];
|
|
42
|
+
for (let i = 0; i < this.config.numWorkers; i++) {
|
|
43
|
+
initPromises.push(this.spawnWorker(i));
|
|
44
|
+
}
|
|
45
|
+
await Promise.all(initPromises);
|
|
46
|
+
this.logger.info({ workerCount: this.workers.length }, 'WorkerPool initialization complete');
|
|
47
|
+
}
|
|
48
|
+
async spawnWorker(workerId) {
|
|
49
|
+
return new Promise((resolve, reject) => {
|
|
50
|
+
const worker = new worker_threads_1.Worker(this.config.workerScript, {
|
|
51
|
+
workerData: { workerId },
|
|
52
|
+
});
|
|
53
|
+
const workerState = {
|
|
54
|
+
worker,
|
|
55
|
+
busy: false,
|
|
56
|
+
taskCount: 0,
|
|
57
|
+
currentTask: null,
|
|
58
|
+
};
|
|
59
|
+
worker.on('message', (result) => {
|
|
60
|
+
if (result.ready) {
|
|
61
|
+
this.logger.debug({ workerId }, 'Worker ready');
|
|
62
|
+
resolve();
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
this.handleWorkerMessage(workerId, result);
|
|
66
|
+
});
|
|
67
|
+
worker.on('error', (error) => {
|
|
68
|
+
this.handleWorkerError(workerId, error);
|
|
69
|
+
reject(error);
|
|
70
|
+
});
|
|
71
|
+
worker.on('exit', (code) => {
|
|
72
|
+
this.handleWorkerExit(workerId, code);
|
|
73
|
+
});
|
|
74
|
+
this.workers[workerId] = workerState;
|
|
75
|
+
this.logger.debug({ workerId }, 'Worker spawned');
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
handleWorkerMessage(workerId, result) {
|
|
79
|
+
const workerState = this.workers[workerId];
|
|
80
|
+
if (!workerState) {
|
|
81
|
+
this.logger.warn({ workerId }, 'Received message from unknown worker');
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const taskId = result.taskId;
|
|
85
|
+
const task = this.pendingTasks.get(taskId);
|
|
86
|
+
if (!task) {
|
|
87
|
+
this.logger.warn({ taskId }, 'Received result for unknown task');
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
this.pendingTasks.delete(taskId);
|
|
91
|
+
workerState.busy = false;
|
|
92
|
+
workerState.taskCount++;
|
|
93
|
+
workerState.currentTask = null;
|
|
94
|
+
this.logger.trace({ workerId, taskId, taskCount: workerState.taskCount }, 'Worker completed task');
|
|
95
|
+
if (result.error) {
|
|
96
|
+
task.reject(new Error(result.error));
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
task.resolve(result);
|
|
100
|
+
}
|
|
101
|
+
this.processQueue();
|
|
102
|
+
}
|
|
103
|
+
handleWorkerError(workerId, error) {
|
|
104
|
+
this.logger.error({ workerId, error: error.message }, 'Worker encountered error');
|
|
105
|
+
const workerState = this.workers[workerId];
|
|
106
|
+
if (workerState?.currentTask) {
|
|
107
|
+
workerState.currentTask.reject(error);
|
|
108
|
+
workerState.currentTask = null;
|
|
109
|
+
}
|
|
110
|
+
this.emit('worker-error', { workerId, error });
|
|
111
|
+
}
|
|
112
|
+
async handleWorkerExit(workerId, code) {
|
|
113
|
+
this.logger.warn({ workerId, exitCode: code }, 'Worker exited');
|
|
114
|
+
if (this.isShuttingDown) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
if (code !== 0) {
|
|
118
|
+
this.logger.info({ workerId }, 'Restarting worker after unexpected exit');
|
|
119
|
+
try {
|
|
120
|
+
await this.spawnWorker(workerId);
|
|
121
|
+
}
|
|
122
|
+
catch (error) {
|
|
123
|
+
this.logger.error({ workerId, error: error.message }, 'Failed to restart worker');
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
async execute(data) {
|
|
128
|
+
if (this.isShuttingDown) {
|
|
129
|
+
throw new Error('WorkerPool is shutting down');
|
|
130
|
+
}
|
|
131
|
+
if (this.workers.length === 0) {
|
|
132
|
+
throw new Error('WorkerPool not initialized');
|
|
133
|
+
}
|
|
134
|
+
if (this.taskQueue.length >= this.config.maxQueueSize) {
|
|
135
|
+
throw new Error('Task queue is full');
|
|
136
|
+
}
|
|
137
|
+
return new Promise((resolve, reject) => {
|
|
138
|
+
const taskId = `task-${this.taskIdCounter++}`;
|
|
139
|
+
const task = {
|
|
140
|
+
id: taskId,
|
|
141
|
+
data,
|
|
142
|
+
resolve,
|
|
143
|
+
reject,
|
|
144
|
+
};
|
|
145
|
+
this.taskQueue.push(task);
|
|
146
|
+
this.pendingTasks.set(taskId, task);
|
|
147
|
+
this.processQueue();
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
processQueue() {
|
|
151
|
+
if (this.taskQueue.length === 0) {
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
const availableWorker = this.findAvailableWorker();
|
|
155
|
+
if (!availableWorker) {
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
const task = this.taskQueue.shift();
|
|
159
|
+
if (!task) {
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
availableWorker.state.busy = true;
|
|
163
|
+
availableWorker.state.currentTask = task;
|
|
164
|
+
availableWorker.state.worker.postMessage({
|
|
165
|
+
taskId: task.id,
|
|
166
|
+
...task.data,
|
|
167
|
+
});
|
|
168
|
+
this.logger.trace({ workerId: availableWorker.index, taskId: task.id }, 'Task dispatched to worker');
|
|
169
|
+
}
|
|
170
|
+
findAvailableWorker() {
|
|
171
|
+
const startIndex = this.nextWorkerIndex;
|
|
172
|
+
let currentIndex = startIndex;
|
|
173
|
+
do {
|
|
174
|
+
const workerState = this.workers[currentIndex];
|
|
175
|
+
if (workerState && !workerState.busy) {
|
|
176
|
+
this.nextWorkerIndex = (currentIndex + 1) % this.workers.length;
|
|
177
|
+
return { index: currentIndex, state: workerState };
|
|
178
|
+
}
|
|
179
|
+
currentIndex = (currentIndex + 1) % this.workers.length;
|
|
180
|
+
} while (currentIndex !== startIndex);
|
|
181
|
+
return null;
|
|
182
|
+
}
|
|
183
|
+
async shutdown() {
|
|
184
|
+
this.isShuttingDown = true;
|
|
185
|
+
this.logger.info('Shutting down worker pool');
|
|
186
|
+
for (const [taskId, task] of this.pendingTasks.entries()) {
|
|
187
|
+
task.reject(new Error('WorkerPool is shutting down'));
|
|
188
|
+
this.pendingTasks.delete(taskId);
|
|
189
|
+
}
|
|
190
|
+
for (const task of this.taskQueue) {
|
|
191
|
+
task.reject(new Error('WorkerPool is shutting down'));
|
|
192
|
+
}
|
|
193
|
+
this.taskQueue.length = 0;
|
|
194
|
+
const terminationPromises = this.workers.map(async (workerState, index) => {
|
|
195
|
+
if (workerState) {
|
|
196
|
+
try {
|
|
197
|
+
await workerState.worker.terminate();
|
|
198
|
+
this.logger.debug({ workerId: index }, 'Worker terminated');
|
|
199
|
+
}
|
|
200
|
+
catch (error) {
|
|
201
|
+
this.logger.error({ workerId: index, error: error.message }, 'Error terminating worker');
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
});
|
|
205
|
+
await Promise.all(terminationPromises);
|
|
206
|
+
this.workers.length = 0;
|
|
207
|
+
this.logger.info('Worker pool shutdown complete');
|
|
208
|
+
}
|
|
209
|
+
getStats() {
|
|
210
|
+
const busyWorkers = this.workers.filter((w) => w?.busy).length;
|
|
211
|
+
const totalTasksProcessed = this.workers.reduce((sum, w) => sum + (w?.taskCount || 0), 0);
|
|
212
|
+
return {
|
|
213
|
+
totalWorkers: this.workers.length,
|
|
214
|
+
busyWorkers,
|
|
215
|
+
queuedTasks: this.taskQueue.length,
|
|
216
|
+
pendingTasks: this.pendingTasks.size,
|
|
217
|
+
totalTasksProcessed,
|
|
218
|
+
};
|
|
219
|
+
}
|
|
220
|
+
getQueueSize() {
|
|
221
|
+
return this.taskQueue.length;
|
|
222
|
+
}
|
|
223
|
+
isBusy() {
|
|
224
|
+
return this.workers.every((w) => w?.busy);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
exports.WorkerPool = WorkerPool;
|
|
228
|
+
//# sourceMappingURL=worker-pool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-pool.js","sourceRoot":"","sources":["../../src/routing/worker-pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Logger } from 'pino';
|
|
2
|
+
import { FraudDetectionEvent } from './reputation-tracker';
|
|
3
|
+
export interface EmailAlertConfig {
|
|
4
|
+
enabled: boolean;
|
|
5
|
+
recipients: string[];
|
|
6
|
+
smtpHost?: string;
|
|
7
|
+
smtpPort?: number;
|
|
8
|
+
smtpUser?: string;
|
|
9
|
+
smtpPassword?: string;
|
|
10
|
+
}
|
|
11
|
+
export interface SlackAlertConfig {
|
|
12
|
+
enabled: boolean;
|
|
13
|
+
webhookUrl: string;
|
|
14
|
+
channel: string;
|
|
15
|
+
}
|
|
16
|
+
export interface AlertConfig {
|
|
17
|
+
email?: EmailAlertConfig;
|
|
18
|
+
slack?: SlackAlertConfig;
|
|
19
|
+
retryAttempts?: number;
|
|
20
|
+
retryDelayMs?: number;
|
|
21
|
+
}
|
|
22
|
+
export declare class AlertNotifier {
|
|
23
|
+
private readonly logger;
|
|
24
|
+
private readonly config;
|
|
25
|
+
constructor(logger: Logger, config: AlertConfig);
|
|
26
|
+
sendAlert(event: FraudDetectionEvent): Promise<void>;
|
|
27
|
+
sendEmailAlert(severity: string, message: string): Promise<void>;
|
|
28
|
+
private sendEmailAlertInternal;
|
|
29
|
+
sendSlackAlert(severity: string, message: string): Promise<void>;
|
|
30
|
+
private sendSlackAlertInternal;
|
|
31
|
+
private formatAlertMessage;
|
|
32
|
+
private sleep;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=alert-notifier.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert-notifier.d.ts","sourceRoot":"","sources":["../../src/security/alert-notifier.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC9B,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAK3D,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAKD,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CACjB;AAKD,MAAM,WAAW,WAAW;IAC1B,KAAK,CAAC,EAAE,gBAAgB,CAAC;IACzB,KAAK,CAAC,EAAE,gBAAgB,CAAC;IAIzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAUD,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;gBAEzB,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW;IAiBlC,SAAS,CAAC,KAAK,EAAE,mBAAmB,GAAG,OAAO,CAAC,IAAI,CAAC;IA2BpD,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAqC/D,sBAAsB;IAuBvB,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAqC/D,sBAAsB;IAuBpC,OAAO,CAAC,kBAAkB;IAmB1B,OAAO,CAAC,KAAK;CAGd"}
|