@toon-protocol/connector 2.6.1 → 3.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +2 -2
- package/dist/btp/btp-claim-types.d.ts +0 -52
- package/dist/btp/btp-claim-types.d.ts.map +0 -1
- package/dist/btp/btp-claim-types.js +0 -209
- package/dist/btp/btp-claim-types.js.map +0 -1
- package/dist/btp/btp-client-manager.d.ts +0 -30
- package/dist/btp/btp-client-manager.d.ts.map +0 -1
- package/dist/btp/btp-client-manager.js +0 -153
- package/dist/btp/btp-client-manager.js.map +0 -1
- package/dist/btp/btp-client.d.ts +0 -58
- package/dist/btp/btp-client.d.ts.map +0 -1
- package/dist/btp/btp-client.js +0 -485
- package/dist/btp/btp-client.js.map +0 -1
- package/dist/btp/btp-message-parser.d.ts +0 -4
- package/dist/btp/btp-message-parser.d.ts.map +0 -1
- package/dist/btp/btp-message-parser.js +0 -211
- package/dist/btp/btp-message-parser.js.map +0 -1
- package/dist/btp/btp-server.d.ts +0 -33
- package/dist/btp/btp-server.d.ts.map +0 -1
- package/dist/btp/btp-server.js +0 -485
- package/dist/btp/btp-server.js.map +0 -1
- package/dist/btp/btp-types.d.ts +0 -43
- package/dist/btp/btp-types.d.ts.map +0 -1
- package/dist/btp/btp-types.js +0 -44
- package/dist/btp/btp-types.js.map +0 -1
- package/dist/btp/inbound-claim-validator.d.ts +0 -20
- package/dist/btp/inbound-claim-validator.d.ts.map +0 -1
- package/dist/btp/inbound-claim-validator.js +0 -150
- package/dist/btp/inbound-claim-validator.js.map +0 -1
- package/dist/cli/index.d.ts +0 -3
- package/dist/cli/index.d.ts.map +0 -1
- package/dist/cli/index.js +0 -175
- package/dist/cli/index.js.map +0 -1
- package/dist/cli/onboarding-wizard.d.ts +0 -7
- package/dist/cli/onboarding-wizard.d.ts.map +0 -1
- package/dist/cli/onboarding-wizard.js +0 -257
- package/dist/cli/onboarding-wizard.js.map +0 -1
- package/dist/cli/types.d.ts +0 -38
- package/dist/cli/types.d.ts.map +0 -1
- package/dist/cli/types.js +0 -3
- package/dist/cli/types.js.map +0 -1
- package/dist/config/config-loader.d.ts +0 -24
- package/dist/config/config-loader.d.ts.map +0 -1
- package/dist/config/config-loader.js +0 -436
- package/dist/config/config-loader.js.map +0 -1
- package/dist/config/environment-validator.d.ts +0 -4
- package/dist/config/environment-validator.d.ts.map +0 -1
- package/dist/config/environment-validator.js +0 -239
- package/dist/config/environment-validator.js.map +0 -1
- package/dist/config/index.d.ts +0 -3
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/index.js +0 -7
- package/dist/config/index.js.map +0 -1
- package/dist/config/key-manager-config.d.ts +0 -7
- package/dist/config/key-manager-config.d.ts.map +0 -1
- package/dist/config/key-manager-config.js +0 -209
- package/dist/config/key-manager-config.js.map +0 -1
- package/dist/config/topology-validator.d.ts +0 -14
- package/dist/config/topology-validator.d.ts.map +0 -1
- package/dist/config/topology-validator.js +0 -142
- package/dist/config/topology-validator.js.map +0 -1
- package/dist/config/types.d.ts +0 -223
- package/dist/config/types.d.ts.map +0 -1
- package/dist/config/types.js +0 -52
- package/dist/config/types.js.map +0 -1
- package/dist/core/connector-node.d.ts +0 -91
- package/dist/core/connector-node.d.ts.map +0 -1
- package/dist/core/connector-node.js +0 -1322
- package/dist/core/connector-node.js.map +0 -1
- package/dist/core/local-delivery-client.d.ts +0 -16
- package/dist/core/local-delivery-client.d.ts.map +0 -1
- package/dist/core/local-delivery-client.js +0 -160
- package/dist/core/local-delivery-client.js.map +0 -1
- package/dist/core/packet-handler.d.ts +0 -57
- package/dist/core/packet-handler.d.ts.map +0 -1
- package/dist/core/packet-handler.js +0 -655
- package/dist/core/packet-handler.js.map +0 -1
- package/dist/core/payment-handler.d.ts +0 -25
- package/dist/core/payment-handler.d.ts.map +0 -1
- package/dist/core/payment-handler.js +0 -104
- package/dist/core/payment-handler.js.map +0 -1
- package/dist/discovery/index.d.ts +0 -3
- package/dist/discovery/index.d.ts.map +0 -1
- package/dist/discovery/index.js +0 -6
- package/dist/discovery/index.js.map +0 -1
- package/dist/discovery/peer-discovery-service.d.ts +0 -29
- package/dist/discovery/peer-discovery-service.d.ts.map +0 -1
- package/dist/discovery/peer-discovery-service.js +0 -230
- package/dist/discovery/peer-discovery-service.js.map +0 -1
- package/dist/discovery/types.d.ts +0 -38
- package/dist/discovery/types.d.ts.map +0 -1
- package/dist/discovery/types.js +0 -3
- package/dist/discovery/types.js.map +0 -1
- package/dist/encoding/oer-parser.d.ts +0 -39
- package/dist/encoding/oer-parser.d.ts.map +0 -1
- package/dist/encoding/oer-parser.js +0 -154
- package/dist/encoding/oer-parser.js.map +0 -1
- package/dist/facilitator/index.d.ts +0 -2
- package/dist/facilitator/index.d.ts.map +0 -1
- package/dist/facilitator/index.js +0 -7
- package/dist/facilitator/index.js.map +0 -1
- package/dist/facilitator/spsp-client.d.ts +0 -18
- package/dist/facilitator/spsp-client.d.ts.map +0 -1
- package/dist/facilitator/spsp-client.js +0 -95
- package/dist/facilitator/spsp-client.js.map +0 -1
- package/dist/http/admin-api-inventory.d.ts +0 -29
- package/dist/http/admin-api-inventory.d.ts.map +0 -1
- package/dist/http/admin-api-inventory.js +0 -480
- package/dist/http/admin-api-inventory.js.map +0 -1
- package/dist/http/admin-api.d.ts +0 -182
- package/dist/http/admin-api.d.ts.map +0 -1
- package/dist/http/admin-api.js +0 -1324
- package/dist/http/admin-api.js.map +0 -1
- package/dist/http/admin-server.d.ts +0 -49
- package/dist/http/admin-server.d.ts.map +0 -1
- package/dist/http/admin-server.js +0 -160
- package/dist/http/admin-server.js.map +0 -1
- package/dist/http/health-server.d.ts +0 -22
- package/dist/http/health-server.d.ts.map +0 -1
- package/dist/http/health-server.js +0 -192
- package/dist/http/health-server.js.map +0 -1
- package/dist/http/ilp-send-handler.d.ts +0 -15
- package/dist/http/ilp-send-handler.d.ts.map +0 -1
- package/dist/http/ilp-send-handler.js +0 -149
- package/dist/http/ilp-send-handler.js.map +0 -1
- package/dist/http/types.d.ts +0 -43
- package/dist/http/types.d.ts.map +0 -1
- package/dist/http/types.js +0 -3
- package/dist/http/types.js.map +0 -1
- package/dist/index.d.ts +0 -2
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -5
- package/dist/index.js.map +0 -1
- package/dist/lib.d.ts +0 -22
- package/dist/lib.d.ts.map +0 -1
- package/dist/lib.js +0 -39
- package/dist/lib.js.map +0 -1
- package/dist/main.d.ts +0 -4
- package/dist/main.d.ts.map +0 -1
- package/dist/main.js +0 -79
- package/dist/main.js.map +0 -1
- package/dist/observability/metrics-registry.d.ts +0 -39
- package/dist/observability/metrics-registry.d.ts.map +0 -1
- package/dist/observability/metrics-registry.js +0 -151
- package/dist/observability/metrics-registry.js.map +0 -1
- package/dist/routing/packet-processor.d.ts +0 -36
- package/dist/routing/packet-processor.d.ts.map +0 -1
- package/dist/routing/packet-processor.js +0 -112
- package/dist/routing/packet-processor.js.map +0 -1
- package/dist/routing/packet-worker.d.ts +0 -10
- package/dist/routing/packet-worker.d.ts.map +0 -1
- package/dist/routing/packet-worker.js +0 -34
- package/dist/routing/packet-worker.js.map +0 -1
- package/dist/routing/routing-table.d.ts +0 -15
- package/dist/routing/routing-table.d.ts.map +0 -1
- package/dist/routing/routing-table.js +0 -63
- package/dist/routing/routing-table.js.map +0 -1
- package/dist/routing/worker-pool.d.ts +0 -43
- package/dist/routing/worker-pool.d.ts.map +0 -1
- package/dist/routing/worker-pool.js +0 -228
- package/dist/routing/worker-pool.js.map +0 -1
- package/dist/security/alert-notifier.d.ts +0 -34
- package/dist/security/alert-notifier.d.ts.map +0 -1
- package/dist/security/alert-notifier.js +0 -136
- package/dist/security/alert-notifier.js.map +0 -1
- package/dist/security/audit-logger.d.ts +0 -34
- package/dist/security/audit-logger.d.ts.map +0 -1
- package/dist/security/audit-logger.js +0 -132
- package/dist/security/audit-logger.js.map +0 -1
- package/dist/security/backends/environment-backend.d.ts +0 -15
- package/dist/security/backends/environment-backend.d.ts.map +0 -1
- package/dist/security/backends/environment-backend.js +0 -56
- package/dist/security/backends/environment-backend.js.map +0 -1
- package/dist/security/fraud-detector.d.ts +0 -79
- package/dist/security/fraud-detector.d.ts.map +0 -1
- package/dist/security/fraud-detector.js +0 -147
- package/dist/security/fraud-detector.js.map +0 -1
- package/dist/security/key-manager-signer.d.ts +0 -15
- package/dist/security/key-manager-signer.d.ts.map +0 -1
- package/dist/security/key-manager-signer.js +0 -91
- package/dist/security/key-manager-signer.js.map +0 -1
- package/dist/security/key-manager.d.ts +0 -69
- package/dist/security/key-manager.d.ts.map +0 -1
- package/dist/security/key-manager.js +0 -79
- package/dist/security/key-manager.js.map +0 -1
- package/dist/security/key-rotation-manager.d.ts +0 -27
- package/dist/security/key-rotation-manager.d.ts.map +0 -1
- package/dist/security/key-rotation-manager.js +0 -142
- package/dist/security/key-rotation-manager.js.map +0 -1
- package/dist/security/rate-limit-config.d.ts +0 -7
- package/dist/security/rate-limit-config.d.ts.map +0 -1
- package/dist/security/rate-limit-config.js +0 -57
- package/dist/security/rate-limit-config.js.map +0 -1
- package/dist/security/rate-limiter.d.ts +0 -46
- package/dist/security/rate-limiter.d.ts.map +0 -1
- package/dist/security/rate-limiter.js +0 -170
- package/dist/security/rate-limiter.js.map +0 -1
- package/dist/security/reputation-tracker.d.ts +0 -30
- package/dist/security/reputation-tracker.d.ts.map +0 -1
- package/dist/security/reputation-tracker.js +0 -111
- package/dist/security/reputation-tracker.js.map +0 -1
- package/dist/security/rules/balance-manipulation-rule.d.ts +0 -23
- package/dist/security/rules/balance-manipulation-rule.d.ts.map +0 -1
- package/dist/security/rules/balance-manipulation-rule.js +0 -70
- package/dist/security/rules/balance-manipulation-rule.js.map +0 -1
- package/dist/security/rules/double-spend-detection-rule.d.ts +0 -23
- package/dist/security/rules/double-spend-detection-rule.d.ts.map +0 -1
- package/dist/security/rules/double-spend-detection-rule.js +0 -61
- package/dist/security/rules/double-spend-detection-rule.js.map +0 -1
- package/dist/security/rules/rapid-channel-closure-rule.d.ts +0 -16
- package/dist/security/rules/rapid-channel-closure-rule.d.ts.map +0 -1
- package/dist/security/rules/rapid-channel-closure-rule.js +0 -57
- package/dist/security/rules/rapid-channel-closure-rule.js.map +0 -1
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts +0 -18
- package/dist/security/rules/sudden-traffic-spike-rule.d.ts.map +0 -1
- package/dist/security/rules/sudden-traffic-spike-rule.js +0 -92
- package/dist/security/rules/sudden-traffic-spike-rule.js.map +0 -1
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts +0 -12
- package/dist/security/rules/unusual-settlement-amount-rule.d.ts.map +0 -1
- package/dist/security/rules/unusual-settlement-amount-rule.js +0 -33
- package/dist/security/rules/unusual-settlement-amount-rule.js.map +0 -1
- package/dist/security/token-bucket.d.ts +0 -16
- package/dist/security/token-bucket.d.ts.map +0 -1
- package/dist/security/token-bucket.js +0 -49
- package/dist/security/token-bucket.js.map +0 -1
- package/dist/security/violation-counter.d.ts +0 -11
- package/dist/security/violation-counter.d.ts.map +0 -1
- package/dist/security/violation-counter.js +0 -61
- package/dist/security/violation-counter.js.map +0 -1
- package/dist/settlement/account-id-generator.d.ts +0 -4
- package/dist/settlement/account-id-generator.d.ts.map +0 -1
- package/dist/settlement/account-id-generator.js +0 -38
- package/dist/settlement/account-id-generator.js.map +0 -1
- package/dist/settlement/account-manager.d.ts +0 -51
- package/dist/settlement/account-manager.d.ts.map +0 -1
- package/dist/settlement/account-manager.js +0 -459
- package/dist/settlement/account-manager.js.map +0 -1
- package/dist/settlement/account-metadata.d.ts +0 -11
- package/dist/settlement/account-metadata.d.ts.map +0 -1
- package/dist/settlement/account-metadata.js +0 -40
- package/dist/settlement/account-metadata.js.map +0 -1
- package/dist/settlement/channel-manager.d.ts +0 -67
- package/dist/settlement/channel-manager.d.ts.map +0 -1
- package/dist/settlement/channel-manager.js +0 -226
- package/dist/settlement/channel-manager.js.map +0 -1
- package/dist/settlement/claim-receiver-db-schema.d.ts +0 -4
- package/dist/settlement/claim-receiver-db-schema.d.ts.map +0 -1
- package/dist/settlement/claim-receiver-db-schema.js +0 -25
- package/dist/settlement/claim-receiver-db-schema.js.map +0 -1
- package/dist/settlement/claim-receiver.d.ts +0 -67
- package/dist/settlement/claim-receiver.d.ts.map +0 -1
- package/dist/settlement/claim-receiver.js +0 -707
- package/dist/settlement/claim-receiver.js.map +0 -1
- package/dist/settlement/claim-redemption-service.d.ts +0 -39
- package/dist/settlement/claim-redemption-service.d.ts.map +0 -1
- package/dist/settlement/claim-redemption-service.js +0 -189
- package/dist/settlement/claim-redemption-service.js.map +0 -1
- package/dist/settlement/claim-sender-db-schema.d.ts +0 -3
- package/dist/settlement/claim-sender-db-schema.d.ts.map +0 -1
- package/dist/settlement/claim-sender-db-schema.js +0 -18
- package/dist/settlement/claim-sender-db-schema.js.map +0 -1
- package/dist/settlement/claim-sender.d.ts +0 -24
- package/dist/settlement/claim-sender.d.ts.map +0 -1
- package/dist/settlement/claim-sender.js +0 -146
- package/dist/settlement/claim-sender.js.map +0 -1
- package/dist/settlement/eip712-helper.d.ts +0 -13
- package/dist/settlement/eip712-helper.d.ts.map +0 -1
- package/dist/settlement/eip712-helper.js +0 -24
- package/dist/settlement/eip712-helper.js.map +0 -1
- package/dist/settlement/in-memory-ledger-client.d.ts +0 -40
- package/dist/settlement/in-memory-ledger-client.d.ts.map +0 -1
- package/dist/settlement/in-memory-ledger-client.js +0 -177
- package/dist/settlement/in-memory-ledger-client.js.map +0 -1
- package/dist/settlement/ledger-client.d.ts +0 -22
- package/dist/settlement/ledger-client.d.ts.map +0 -1
- package/dist/settlement/ledger-client.js +0 -3
- package/dist/settlement/ledger-client.js.map +0 -1
- package/dist/settlement/metrics-collector.d.ts +0 -29
- package/dist/settlement/metrics-collector.d.ts.map +0 -1
- package/dist/settlement/metrics-collector.js +0 -81
- package/dist/settlement/metrics-collector.js.map +0 -1
- package/dist/settlement/mina-payment-channel-sdk.d.ts +0 -73
- package/dist/settlement/mina-payment-channel-sdk.d.ts.map +0 -1
- package/dist/settlement/mina-payment-channel-sdk.js +0 -538
- package/dist/settlement/mina-payment-channel-sdk.js.map +0 -1
- package/dist/settlement/payment-channel-sdk.d.ts +0 -59
- package/dist/settlement/payment-channel-sdk.d.ts.map +0 -1
- package/dist/settlement/payment-channel-sdk.js +0 -677
- package/dist/settlement/payment-channel-sdk.js.map +0 -1
- package/dist/settlement/per-packet-claim-service.d.ts +0 -39
- package/dist/settlement/per-packet-claim-service.d.ts.map +0 -1
- package/dist/settlement/per-packet-claim-service.js +0 -342
- package/dist/settlement/per-packet-claim-service.js.map +0 -1
- package/dist/settlement/privacy/index.d.ts +0 -3
- package/dist/settlement/privacy/index.d.ts.map +0 -1
- package/dist/settlement/privacy/index.js +0 -11
- package/dist/settlement/privacy/index.js.map +0 -1
- package/dist/settlement/privacy/nip59-claim-wrapper.d.ts +0 -60
- package/dist/settlement/privacy/nip59-claim-wrapper.d.ts.map +0 -1
- package/dist/settlement/privacy/nip59-claim-wrapper.js +0 -361
- package/dist/settlement/privacy/nip59-claim-wrapper.js.map +0 -1
- package/dist/settlement/provider/chain-provider-registry.d.ts +0 -20
- package/dist/settlement/provider/chain-provider-registry.d.ts.map +0 -1
- package/dist/settlement/provider/chain-provider-registry.js +0 -53
- package/dist/settlement/provider/chain-provider-registry.js.map +0 -1
- package/dist/settlement/provider/evm-payment-channel-provider.d.ts +0 -31
- package/dist/settlement/provider/evm-payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/evm-payment-channel-provider.js +0 -207
- package/dist/settlement/provider/evm-payment-channel-provider.js.map +0 -1
- package/dist/settlement/provider/index.d.ts +0 -6
- package/dist/settlement/provider/index.d.ts.map +0 -1
- package/dist/settlement/provider/index.js +0 -16
- package/dist/settlement/provider/index.js.map +0 -1
- package/dist/settlement/provider/mina-payment-channel-provider.d.ts +0 -43
- package/dist/settlement/provider/mina-payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/mina-payment-channel-provider.js +0 -330
- package/dist/settlement/provider/mina-payment-channel-provider.js.map +0 -1
- package/dist/settlement/provider/payment-channel-provider.d.ts +0 -88
- package/dist/settlement/provider/payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/payment-channel-provider.js +0 -3
- package/dist/settlement/provider/payment-channel-provider.js.map +0 -1
- package/dist/settlement/provider/solana-payment-channel-provider.d.ts +0 -38
- package/dist/settlement/provider/solana-payment-channel-provider.d.ts.map +0 -1
- package/dist/settlement/provider/solana-payment-channel-provider.js +0 -262
- package/dist/settlement/provider/solana-payment-channel-provider.js.map +0 -1
- package/dist/settlement/sent-claims-queries.d.ts +0 -23
- package/dist/settlement/sent-claims-queries.d.ts.map +0 -1
- package/dist/settlement/sent-claims-queries.js +0 -134
- package/dist/settlement/sent-claims-queries.js.map +0 -1
- package/dist/settlement/settlement-api.d.ts +0 -37
- package/dist/settlement/settlement-api.d.ts.map +0 -1
- package/dist/settlement/settlement-api.js +0 -172
- package/dist/settlement/settlement-api.js.map +0 -1
- package/dist/settlement/settlement-coordinator.d.ts +0 -47
- package/dist/settlement/settlement-coordinator.d.ts.map +0 -1
- package/dist/settlement/settlement-coordinator.js +0 -166
- package/dist/settlement/settlement-coordinator.js.map +0 -1
- package/dist/settlement/settlement-executor.d.ts +0 -51
- package/dist/settlement/settlement-executor.d.ts.map +0 -1
- package/dist/settlement/settlement-executor.js +0 -265
- package/dist/settlement/settlement-executor.js.map +0 -1
- package/dist/settlement/settlement-monitor.d.ts +0 -30
- package/dist/settlement/settlement-monitor.d.ts.map +0 -1
- package/dist/settlement/settlement-monitor.js +0 -141
- package/dist/settlement/settlement-monitor.js.map +0 -1
- package/dist/settlement/solana-payment-channel-sdk.d.ts +0 -79
- package/dist/settlement/solana-payment-channel-sdk.d.ts.map +0 -1
- package/dist/settlement/solana-payment-channel-sdk.js +0 -636
- package/dist/settlement/solana-payment-channel-sdk.js.map +0 -1
- package/dist/settlement/tigerbeetle-batch-writer.d.ts +0 -58
- package/dist/settlement/tigerbeetle-batch-writer.d.ts.map +0 -1
- package/dist/settlement/tigerbeetle-batch-writer.js +0 -162
- package/dist/settlement/tigerbeetle-batch-writer.js.map +0 -1
- package/dist/settlement/tigerbeetle-client.d.ts +0 -40
- package/dist/settlement/tigerbeetle-client.d.ts.map +0 -1
- package/dist/settlement/tigerbeetle-client.js +0 -279
- package/dist/settlement/tigerbeetle-client.js.map +0 -1
- package/dist/settlement/tigerbeetle-errors.d.ts +0 -23
- package/dist/settlement/tigerbeetle-errors.d.ts.map +0 -1
- package/dist/settlement/tigerbeetle-errors.js +0 -58
- package/dist/settlement/tigerbeetle-errors.js.map +0 -1
- package/dist/settlement/types.d.ts +0 -64
- package/dist/settlement/types.d.ts.map +0 -1
- package/dist/settlement/types.js +0 -42
- package/dist/settlement/types.js.map +0 -1
- package/dist/settlement/unified-settlement-executor.d.ts +0 -34
- package/dist/settlement/unified-settlement-executor.d.ts.map +0 -1
- package/dist/settlement/unified-settlement-executor.js +0 -145
- package/dist/settlement/unified-settlement-executor.js.map +0 -1
- package/dist/test-utils/index.d.ts +0 -3
- package/dist/test-utils/index.d.ts.map +0 -1
- package/dist/test-utils/index.js +0 -15
- package/dist/test-utils/index.js.map +0 -1
- package/dist/test-utils/isolated-test-env.d.ts +0 -31
- package/dist/test-utils/isolated-test-env.d.ts.map +0 -1
- package/dist/test-utils/isolated-test-env.js +0 -127
- package/dist/test-utils/isolated-test-env.js.map +0 -1
- package/dist/test-utils/mock-factories-patch.d.ts +0 -2
- package/dist/test-utils/mock-factories-patch.d.ts.map +0 -1
- package/dist/test-utils/mock-factories-patch.js +0 -3
- package/dist/test-utils/mock-factories-patch.js.map +0 -1
- package/dist/test-utils/mock-factories.d.ts +0 -22
- package/dist/test-utils/mock-factories.d.ts.map +0 -1
- package/dist/test-utils/mock-factories.js +0 -56
- package/dist/test-utils/mock-factories.js.map +0 -1
- package/dist/transport/direct-transport-provider.d.ts +0 -12
- package/dist/transport/direct-transport-provider.d.ts.map +0 -1
- package/dist/transport/direct-transport-provider.js +0 -27
- package/dist/transport/direct-transport-provider.js.map +0 -1
- package/dist/transport/index.d.ts +0 -7
- package/dist/transport/index.d.ts.map +0 -1
- package/dist/transport/index.js +0 -16
- package/dist/transport/index.js.map +0 -1
- package/dist/transport/managed-anon-client.d.ts +0 -47
- package/dist/transport/managed-anon-client.d.ts.map +0 -1
- package/dist/transport/managed-anon-client.js +0 -265
- package/dist/transport/managed-anon-client.js.map +0 -1
- package/dist/transport/probe-tcp-port.d.ts +0 -3
- package/dist/transport/probe-tcp-port.d.ts.map +0 -1
- package/dist/transport/probe-tcp-port.js +0 -59
- package/dist/transport/probe-tcp-port.js.map +0 -1
- package/dist/transport/socks-transport-provider.d.ts +0 -29
- package/dist/transport/socks-transport-provider.d.ts.map +0 -1
- package/dist/transport/socks-transport-provider.js +0 -136
- package/dist/transport/socks-transport-provider.js.map +0 -1
- package/dist/transport/socks-url.d.ts +0 -6
- package/dist/transport/socks-url.d.ts.map +0 -1
- package/dist/transport/socks-url.js +0 -29
- package/dist/transport/socks-url.js.map +0 -1
- package/dist/transport/transport-provider.d.ts +0 -9
- package/dist/transport/transport-provider.d.ts.map +0 -1
- package/dist/transport/transport-provider.js +0 -3
- package/dist/transport/transport-provider.js.map +0 -1
- package/dist/utils/connection-pool.d.ts +0 -42
- package/dist/utils/connection-pool.d.ts.map +0 -1
- package/dist/utils/connection-pool.js +0 -209
- package/dist/utils/connection-pool.js.map +0 -1
- package/dist/utils/evm-rpc-connection-pool.d.ts +0 -8
- package/dist/utils/evm-rpc-connection-pool.d.ts.map +0 -1
- package/dist/utils/evm-rpc-connection-pool.js +0 -40
- package/dist/utils/evm-rpc-connection-pool.js.map +0 -1
- package/dist/utils/logger.d.ts +0 -6
- package/dist/utils/logger.d.ts.map +0 -1
- package/dist/utils/logger.js +0 -58
- package/dist/utils/logger.js.map +0 -1
- package/dist/utils/optional-require.d.ts +0 -2
- package/dist/utils/optional-require.d.ts.map +0 -1
- package/dist/utils/optional-require.js +0 -54
- package/dist/utils/optional-require.js.map +0 -1
- package/dist/utils/redact.d.ts +0 -3
- package/dist/utils/redact.d.ts.map +0 -1
- package/dist/utils/redact.js +0 -21
- package/dist/utils/redact.js.map +0 -1
- package/dist/wallet/audit-logger.d.ts +0 -22
- package/dist/wallet/audit-logger.d.ts.map +0 -1
- package/dist/wallet/audit-logger.js +0 -120
- package/dist/wallet/audit-logger.js.map +0 -1
- package/dist/wallet/fraud-detector-interface.d.ts +0 -14
- package/dist/wallet/fraud-detector-interface.d.ts.map +0 -1
- package/dist/wallet/fraud-detector-interface.js +0 -3
- package/dist/wallet/fraud-detector-interface.js.map +0 -1
- package/dist/wallet/key-manager.d.ts +0 -6
- package/dist/wallet/key-manager.d.ts.map +0 -1
- package/dist/wallet/key-manager.js +0 -3
- package/dist/wallet/key-manager.js.map +0 -1
- package/dist/wallet/placeholder-fraud-detector.d.ts +0 -10
- package/dist/wallet/placeholder-fraud-detector.d.ts.map +0 -1
- package/dist/wallet/placeholder-fraud-detector.js +0 -10
- package/dist/wallet/placeholder-fraud-detector.js.map +0 -1
- package/dist/wallet/rate-limiter.d.ts +0 -26
- package/dist/wallet/rate-limiter.d.ts.map +0 -1
- package/dist/wallet/rate-limiter.js +0 -114
- package/dist/wallet/rate-limiter.js.map +0 -1
- package/dist/wallet/suspicious-activity-detector.d.ts +0 -25
- package/dist/wallet/suspicious-activity-detector.d.ts.map +0 -1
- package/dist/wallet/suspicious-activity-detector.js +0 -97
- package/dist/wallet/suspicious-activity-detector.js.map +0 -1
- package/dist/wallet/treasury-wallet.d.ts +0 -20
- package/dist/wallet/treasury-wallet.d.ts.map +0 -1
- package/dist/wallet/treasury-wallet.js +0 -151
- package/dist/wallet/treasury-wallet.js.map +0 -1
- package/dist/wallet/wallet-authentication.d.ts +0 -31
- package/dist/wallet/wallet-authentication.d.ts.map +0 -1
- package/dist/wallet/wallet-authentication.js +0 -102
- package/dist/wallet/wallet-authentication.js.map +0 -1
- package/dist/wallet/wallet-db-schema.d.ts +0 -11
- package/dist/wallet/wallet-db-schema.d.ts.map +0 -1
- package/dist/wallet/wallet-db-schema.js +0 -79
- package/dist/wallet/wallet-db-schema.js.map +0 -1
- package/dist/wallet/wallet-security.d.ts +0 -58
- package/dist/wallet/wallet-security.d.ts.map +0 -1
- package/dist/wallet/wallet-security.js +0 -148
- package/dist/wallet/wallet-security.js.map +0 -1
- package/dist/wallet/wallet-seed-manager.d.ts +0 -65
- package/dist/wallet/wallet-seed-manager.d.ts.map +0 -1
- package/dist/wallet/wallet-seed-manager.js +0 -418
- package/dist/wallet/wallet-seed-manager.js.map +0 -1
|
@@ -1,36 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,112 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"packet-processor.js","sourceRoot":"","sources":["../../src/routing/packet-processor.ts"],"names":[],"mappings":";;;;AACA,+CAA6D;AAE7D,mDAA6B;AAC7B,+CAAyB;AAuBzB,MAAa,eAAe;IACT,MAAM,CAAS;IACf,MAAM,CAAkC;IACjD,UAAU,CAAc;IACxB,cAAc,CAAS;IAE/B,YAAY,MAA6B,EAAE,MAAc;QACvD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAC9D,IAAI,CAAC,MAAM,GAAG;YACZ,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,EAAE,CAAC,IAAI,EAAE,CAAC,MAAM;YACvD,SAAS,EAAE,MAAM,CAAC,SAAS,IAAI,GAAG;YAClC,wBAAwB,EAAE,MAAM,CAAC,wBAAwB,IAAI,IAAI;SAClE,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QAExB,IAAI,CAAC,MAAM,CAAC,IAAI,CACd;YACE,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa;YACxC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS;YAChC,wBAAwB,EAAE,IAAI,CAAC,MAAM,CAAC,wBAAwB;SAC/D,EACD,6BAA6B,CAC9B,CAAC;IACJ,CAAC;IAKD,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,wBAAwB,EAAE,CAAC;YAC1C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sDAAsD,CAAC,CAAC;YACzE,OAAO;QACT,CAAC;QAGD,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,kBAAkB,CAAC,CAAC;QAElE,MAAM,UAAU,GAAqB;YACnC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa;YACrC,YAAY,EAAE,gBAAgB;YAC9B,YAAY,EAAE,KAAK;SACpB,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG,IAAI,wBAAU,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC1D,MAAM,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC;QAEnC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yCAAyC,CAAC,CAAC;IAC9D,CAAC;IAKD,KAAK,CAAC,YAAY,CAAC,OAAiB;QAClC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAG,SAAS,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;QAEjD,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,wBAAwB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YAE9D,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YACxD,MAAM,gBAAgB,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YAEhD,OAAO;gBACL,gBAAgB;gBAChB,OAAO;gBACP,gBAAgB;aACjB,CAAC;QACJ,CAAC;QAGD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAA4C;gBACtF,OAAO;aACR,CAAC,CAAC;YAEH,MAAM,gBAAgB,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;YAEhD,IAAI,CAAC,MAAM,CAAC,KAAK,CACf;gBACE,OAAO;gBACP,WAAW,EAAE,OAAO,CAAC,MAAM;gBAC3B,gBAAgB;aACjB,EACD,iBAAiB,CAClB,CAAC;YAEF,OAAO;gBACL,gBAAgB,EAAE,MAAM,CAAC,gBAAgB;gBACzC,OAAO;gBACP,gBAAgB;aACjB,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,MAAM,CAAC,KAAK,CACf;gBACE,OAAO;gBACP,KAAK,EAAG,KAAe,CAAC,OAAO;aAChC,EACD,wBAAwB,CACzB,CAAC;YACF,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAKO,gBAAgB,CAAC,OAAiB;QAGxC,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YAC5B,MAAM,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC/C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClB,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;IAKD,KAAK,CAAC,aAAa,CAAC,MAAc;QAChC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;QAC7D,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAKD,KAAK,CAAC,QAAQ;QACZ,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;IAKD,QAAQ;QAMN,OAAO;YACL,eAAe,EAAE,IAAI,CAAC,UAAU,EAAE,QAAQ,EAAE;YAC5C,yBAAyB,EAAE,IAAI,CAAC,MAAM,CAAC,wBAAwB;YAC/D,uBAAuB,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa;YAClD,mBAAmB,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS;SAC3C,CAAC;IACJ,CAAC;IAKD,MAAM;QACJ,OAAO,IAAI,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,KAAK,CAAC;IAC5C,CAAC;CACF;AAhKD,0CAgKC"}
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,34 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,15 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,63 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"routing-table.js","sourceRoot":"","sources":["../../src/routing/routing-table.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,43 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|
|
@@ -1,228 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"worker-pool.js","sourceRoot":"","sources":["../../src/routing/worker-pool.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,34 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"}
|