@aztec/foundation 0.0.0-test.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/dest/array/array.d.ts +71 -0
- package/dest/array/array.d.ts.map +1 -0
- package/dest/array/array.js +100 -0
- package/dest/array/index.d.ts +2 -0
- package/dest/array/index.d.ts.map +1 -0
- package/dest/array/index.js +1 -0
- package/dest/async-map/index.d.ts +13 -0
- package/dest/async-map/index.d.ts.map +1 -0
- package/dest/async-map/index.js +17 -0
- package/dest/async-pool/index.d.ts +3 -0
- package/dest/async-pool/index.d.ts.map +1 -0
- package/dest/async-pool/index.js +47 -0
- package/dest/bigint-buffer/index.d.ts +42 -0
- package/dest/bigint-buffer/index.d.ts.map +1 -0
- package/dest/bigint-buffer/index.js +76 -0
- package/dest/buffer/buffer32.d.ts +91 -0
- package/dest/buffer/buffer32.d.ts.map +1 -0
- package/dest/buffer/buffer32.js +115 -0
- package/dest/buffer/index.d.ts +2 -0
- package/dest/buffer/index.d.ts.map +1 -0
- package/dest/buffer/index.js +1 -0
- package/dest/collection/array.d.ts +101 -0
- package/dest/collection/array.d.ts.map +1 -0
- package/dest/collection/array.js +164 -0
- package/dest/collection/index.d.ts +3 -0
- package/dest/collection/index.d.ts.map +1 -0
- package/dest/collection/index.js +2 -0
- package/dest/collection/object.d.ts +14 -0
- package/dest/collection/object.d.ts.map +1 -0
- package/dest/collection/object.js +32 -0
- package/dest/committable/committable.d.ts +28 -0
- package/dest/committable/committable.d.ts.map +1 -0
- package/dest/committable/committable.js +36 -0
- package/dest/committable/index.d.ts +2 -0
- package/dest/committable/index.d.ts.map +1 -0
- package/dest/committable/index.js +1 -0
- package/dest/config/env_var.d.ts +2 -0
- package/dest/config/env_var.d.ts.map +1 -0
- package/dest/config/env_var.js +1 -0
- package/dest/config/index.d.ts +66 -0
- package/dest/config/index.d.ts.map +1 -0
- package/dest/config/index.js +125 -0
- package/dest/crypto/aes128/index.d.ts +34 -0
- package/dest/crypto/aes128/index.d.ts.map +1 -0
- package/dest/crypto/aes128/index.js +49 -0
- package/dest/crypto/ecdsa/index.d.ts +39 -0
- package/dest/crypto/ecdsa/index.d.ts.map +1 -0
- package/dest/crypto/ecdsa/index.js +88 -0
- package/dest/crypto/ecdsa/signature.d.ts +71 -0
- package/dest/crypto/ecdsa/signature.d.ts.map +1 -0
- package/dest/crypto/ecdsa/signature.js +92 -0
- package/dest/crypto/grumpkin/index.d.ts +47 -0
- package/dest/crypto/grumpkin/index.d.ts.map +1 -0
- package/dest/crypto/grumpkin/index.js +154 -0
- package/dest/crypto/index.d.ts +15 -0
- package/dest/crypto/index.d.ts.map +1 -0
- package/dest/crypto/index.js +14 -0
- package/dest/crypto/keccak/index.d.ts +28 -0
- package/dest/crypto/keccak/index.d.ts.map +1 -0
- package/dest/crypto/keccak/index.js +248 -0
- package/dest/crypto/keys/index.d.ts +5 -0
- package/dest/crypto/keys/index.d.ts.map +1 -0
- package/dest/crypto/keys/index.js +7 -0
- package/dest/crypto/pedersen/index.d.ts +2 -0
- package/dest/crypto/pedersen/index.d.ts.map +1 -0
- package/dest/crypto/pedersen/index.js +1 -0
- package/dest/crypto/pedersen/pedersen.elliptic.d.ts +13 -0
- package/dest/crypto/pedersen/pedersen.elliptic.d.ts.map +1 -0
- package/dest/crypto/pedersen/pedersen.elliptic.js +582 -0
- package/dest/crypto/pedersen/pedersen.noble.d.ts +11 -0
- package/dest/crypto/pedersen/pedersen.noble.d.ts.map +1 -0
- package/dest/crypto/pedersen/pedersen.noble.js +558 -0
- package/dest/crypto/pedersen/pedersen.wasm.d.ts +21 -0
- package/dest/crypto/pedersen/pedersen.wasm.d.ts.map +1 -0
- package/dest/crypto/pedersen/pedersen.wasm.js +41 -0
- package/dest/crypto/poseidon/index.d.ts +26 -0
- package/dest/crypto/poseidon/index.d.ts.map +1 -0
- package/dest/crypto/poseidon/index.js +58 -0
- package/dest/crypto/random/index.d.ts +25 -0
- package/dest/crypto/random/index.d.ts.map +1 -0
- package/dest/crypto/random/index.js +70 -0
- package/dest/crypto/random/randomness_singleton.d.ts +25 -0
- package/dest/crypto/random/randomness_singleton.d.ts.map +1 -0
- package/dest/crypto/random/randomness_singleton.js +55 -0
- package/dest/crypto/schnorr/index.d.ts +30 -0
- package/dest/crypto/schnorr/index.d.ts.map +1 -0
- package/dest/crypto/schnorr/index.js +68 -0
- package/dest/crypto/schnorr/signature.d.ts +70 -0
- package/dest/crypto/schnorr/signature.d.ts.map +1 -0
- package/dest/crypto/schnorr/signature.js +93 -0
- package/dest/crypto/secp256k1/index.d.ts +32 -0
- package/dest/crypto/secp256k1/index.d.ts.map +1 -0
- package/dest/crypto/secp256k1/index.js +116 -0
- package/dest/crypto/secp256k1-signer/index.d.ts +3 -0
- package/dest/crypto/secp256k1-signer/index.d.ts.map +1 -0
- package/dest/crypto/secp256k1-signer/index.js +2 -0
- package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts +24 -0
- package/dest/crypto/secp256k1-signer/secp256k1_signer.d.ts.map +1 -0
- package/dest/crypto/secp256k1-signer/secp256k1_signer.js +30 -0
- package/dest/crypto/secp256k1-signer/utils.d.ts +40 -0
- package/dest/crypto/secp256k1-signer/utils.d.ts.map +1 -0
- package/dest/crypto/secp256k1-signer/utils.js +84 -0
- package/dest/crypto/serialize.d.ts +53 -0
- package/dest/crypto/serialize.d.ts.map +1 -0
- package/dest/crypto/serialize.js +68 -0
- package/dest/crypto/sha256/index.d.ts +20 -0
- package/dest/crypto/sha256/index.d.ts.map +1 -0
- package/dest/crypto/sha256/index.js +166 -0
- package/dest/crypto/sha512/index.d.ts +11 -0
- package/dest/crypto/sha512/index.d.ts.map +1 -0
- package/dest/crypto/sha512/index.js +12 -0
- package/dest/crypto/signature/index.d.ts +19 -0
- package/dest/crypto/signature/index.d.ts.map +1 -0
- package/dest/crypto/signature/index.js +3 -0
- package/dest/crypto/sync/index.d.ts +3 -0
- package/dest/crypto/sync/index.d.ts.map +1 -0
- package/dest/crypto/sync/index.js +4 -0
- package/dest/crypto/sync/pedersen/index.d.ts +21 -0
- package/dest/crypto/sync/pedersen/index.d.ts.map +1 -0
- package/dest/crypto/sync/pedersen/index.js +38 -0
- package/dest/crypto/sync/poseidon/index.d.ts +26 -0
- package/dest/crypto/sync/poseidon/index.d.ts.map +1 -0
- package/dest/crypto/sync/poseidon/index.js +53 -0
- package/dest/decorators/index.d.ts +2 -0
- package/dest/decorators/index.d.ts.map +1 -0
- package/dest/decorators/index.js +1 -0
- package/dest/decorators/memoize.d.ts +2 -0
- package/dest/decorators/memoize.d.ts.map +1 -0
- package/dest/decorators/memoize.js +11 -0
- package/dest/error/index.d.ts +21 -0
- package/dest/error/index.d.ts.map +1 -0
- package/dest/error/index.js +17 -0
- package/dest/eth-address/index.d.ts +134 -0
- package/dest/eth-address/index.d.ts.map +1 -0
- package/dest/eth-address/index.js +198 -0
- package/dest/eth-signature/eth_signature.d.ts +62 -0
- package/dest/eth-signature/eth_signature.d.ts.map +1 -0
- package/dest/eth-signature/eth_signature.js +91 -0
- package/dest/eth-signature/index.d.ts +2 -0
- package/dest/eth-signature/index.d.ts.map +1 -0
- package/dest/eth-signature/index.js +1 -0
- package/dest/fields/coordinate.d.ts +68 -0
- package/dest/fields/coordinate.d.ts.map +1 -0
- package/dest/fields/coordinate.js +96 -0
- package/dest/fields/fields.d.ts +176 -0
- package/dest/fields/fields.d.ts.map +1 -0
- package/dest/fields/fields.js +383 -0
- package/dest/fields/index.d.ts +4 -0
- package/dest/fields/index.d.ts.map +1 -0
- package/dest/fields/index.js +3 -0
- package/dest/fields/point.d.ts +175 -0
- package/dest/fields/point.d.ts.map +1 -0
- package/dest/fields/point.js +260 -0
- package/dest/fs/index.d.ts +2 -0
- package/dest/fs/index.d.ts.map +1 -0
- package/dest/fs/index.js +1 -0
- package/dest/fs/run_in_dir.d.ts +2 -0
- package/dest/fs/run_in_dir.d.ts.map +1 -0
- package/dest/fs/run_in_dir.js +31 -0
- package/dest/index.d.ts +31 -0
- package/dest/index.d.ts.map +1 -0
- package/dest/index.js +31 -0
- package/dest/iterable/all.d.ts +9 -0
- package/dest/iterable/all.d.ts.map +1 -0
- package/dest/iterable/all.js +18 -0
- package/dest/iterable/filter.d.ts +10 -0
- package/dest/iterable/filter.d.ts.map +1 -0
- package/dest/iterable/filter.js +48 -0
- package/dest/iterable/index.d.ts +8 -0
- package/dest/iterable/index.d.ts.map +1 -0
- package/dest/iterable/index.js +7 -0
- package/dest/iterable/isAsyncIt.d.ts +7 -0
- package/dest/iterable/isAsyncIt.d.ts.map +1 -0
- package/dest/iterable/isAsyncIt.js +7 -0
- package/dest/iterable/map.d.ts +12 -0
- package/dest/iterable/map.d.ts.map +1 -0
- package/dest/iterable/map.js +36 -0
- package/dest/iterable/peek.d.ts +19 -0
- package/dest/iterable/peek.d.ts.map +1 -0
- package/dest/iterable/peek.js +33 -0
- package/dest/iterable/sort.d.ts +14 -0
- package/dest/iterable/sort.d.ts.map +1 -0
- package/dest/iterable/sort.js +15 -0
- package/dest/iterable/take.d.ts +10 -0
- package/dest/iterable/take.d.ts.map +1 -0
- package/dest/iterable/take.js +32 -0
- package/dest/iterable/toArray.d.ts +2 -0
- package/dest/iterable/toArray.d.ts.map +1 -0
- package/dest/iterable/toArray.js +7 -0
- package/dest/jest/setup.js +7 -0
- package/dest/json-rpc/client/fetch.d.ts +32 -0
- package/dest/json-rpc/client/fetch.d.ts.map +1 -0
- package/dest/json-rpc/client/fetch.js +77 -0
- package/dest/json-rpc/client/index.d.ts +3 -0
- package/dest/json-rpc/client/index.d.ts.map +1 -0
- package/dest/json-rpc/client/index.js +2 -0
- package/dest/json-rpc/client/safe_json_rpc_client.d.ts +26 -0
- package/dest/json-rpc/client/safe_json_rpc_client.d.ts.map +1 -0
- package/dest/json-rpc/client/safe_json_rpc_client.js +57 -0
- package/dest/json-rpc/client/undici.d.ts +5 -0
- package/dest/json-rpc/client/undici.d.ts.map +1 -0
- package/dest/json-rpc/client/undici.js +63 -0
- package/dest/json-rpc/convert.d.ts +27 -0
- package/dest/json-rpc/convert.d.ts.map +1 -0
- package/dest/json-rpc/convert.js +48 -0
- package/dest/json-rpc/fixtures/class_a.d.ts +11 -0
- package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -0
- package/dest/json-rpc/fixtures/class_a.js +20 -0
- package/dest/json-rpc/fixtures/class_b.d.ts +11 -0
- package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -0
- package/dest/json-rpc/fixtures/class_b.js +20 -0
- package/dest/json-rpc/fixtures/test_state.d.ts +89 -0
- package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -0
- package/dest/json-rpc/fixtures/test_state.js +131 -0
- package/dest/json-rpc/index.d.ts +2 -0
- package/dest/json-rpc/index.d.ts.map +1 -0
- package/dest/json-rpc/index.js +1 -0
- package/dest/json-rpc/js_utils.d.ts +13 -0
- package/dest/json-rpc/js_utils.d.ts.map +1 -0
- package/dest/json-rpc/js_utils.js +16 -0
- package/dest/json-rpc/server/index.d.ts +2 -0
- package/dest/json-rpc/server/index.d.ts.map +1 -0
- package/dest/json-rpc/server/index.js +1 -0
- package/dest/json-rpc/server/safe_json_rpc_server.d.ts +140 -0
- package/dest/json-rpc/server/safe_json_rpc_server.d.ts.map +1 -0
- package/dest/json-rpc/server/safe_json_rpc_server.js +346 -0
- package/dest/json-rpc/server/telemetry.d.ts +2 -0
- package/dest/json-rpc/server/telemetry.d.ts.map +1 -0
- package/dest/json-rpc/server/telemetry.js +0 -0
- package/dest/json-rpc/test/index.d.ts +2 -0
- package/dest/json-rpc/test/index.d.ts.map +1 -0
- package/dest/json-rpc/test/index.js +1 -0
- package/dest/json-rpc/test/integration.d.ts +15 -0
- package/dest/json-rpc/test/integration.d.ts.map +1 -0
- package/dest/json-rpc/test/integration.js +21 -0
- package/dest/log/console.d.ts +11 -0
- package/dest/log/console.d.ts.map +1 -0
- package/dest/log/console.js +36 -0
- package/dest/log/debug.d.ts +56 -0
- package/dest/log/debug.d.ts.map +1 -0
- package/dest/log/debug.js +75 -0
- package/dest/log/gcloud-logger-config.d.ts +14 -0
- package/dest/log/gcloud-logger-config.d.ts.map +1 -0
- package/dest/log/gcloud-logger-config.js +66 -0
- package/dest/log/index.d.ts +7 -0
- package/dest/log/index.d.ts.map +1 -0
- package/dest/log/index.js +6 -0
- package/dest/log/libp2p_logger.d.ts +7 -0
- package/dest/log/libp2p_logger.d.ts.map +1 -0
- package/dest/log/libp2p_logger.js +55 -0
- package/dest/log/log-filters.d.ts +7 -0
- package/dest/log/log-filters.d.ts.map +1 -0
- package/dest/log/log-filters.js +59 -0
- package/dest/log/log-levels.d.ts +3 -0
- package/dest/log/log-levels.d.ts.map +1 -0
- package/dest/log/log-levels.js +10 -0
- package/dest/log/log_fn.d.ts +7 -0
- package/dest/log/log_fn.d.ts.map +1 -0
- package/dest/log/log_fn.js +1 -0
- package/dest/log/log_history.d.ts +31 -0
- package/dest/log/log_history.d.ts.map +1 -0
- package/dest/log/log_history.js +38 -0
- package/dest/log/pino-logger.d.ts +57 -0
- package/dest/log/pino-logger.d.ts.map +1 -0
- package/dest/log/pino-logger.js +207 -0
- package/dest/message/index.d.ts +32 -0
- package/dest/message/index.d.ts.map +1 -0
- package/dest/message/index.js +27 -0
- package/dest/mutex/index.d.ts +53 -0
- package/dest/mutex/index.d.ts.map +1 -0
- package/dest/mutex/index.js +78 -0
- package/dest/mutex/mutex_database.d.ts +10 -0
- package/dest/mutex/mutex_database.d.ts.map +1 -0
- package/dest/mutex/mutex_database.js +4 -0
- package/dest/noir/index.d.ts +2 -0
- package/dest/noir/index.d.ts.map +1 -0
- package/dest/noir/index.js +1 -0
- package/dest/noir/noir_package_config.d.ts +129 -0
- package/dest/noir/noir_package_config.d.ts.map +1 -0
- package/dest/noir/noir_package_config.js +36 -0
- package/dest/promise/index.d.ts +3 -0
- package/dest/promise/index.d.ts.map +1 -0
- package/dest/promise/index.js +2 -0
- package/dest/promise/running-promise.d.ts +47 -0
- package/dest/promise/running-promise.d.ts.map +1 -0
- package/dest/promise/running-promise.js +110 -0
- package/dest/promise/utils.d.ts +12 -0
- package/dest/promise/utils.d.ts.map +1 -0
- package/dest/promise/utils.js +20 -0
- package/dest/queue/base_memory_queue.d.ts +65 -0
- package/dest/queue/base_memory_queue.d.ts.map +1 -0
- package/dest/queue/base_memory_queue.js +116 -0
- package/dest/queue/batch_queue.d.ts +47 -0
- package/dest/queue/batch_queue.d.ts.map +1 -0
- package/dest/queue/batch_queue.js +105 -0
- package/dest/queue/bounded_serial_queue.d.ts +56 -0
- package/dest/queue/bounded_serial_queue.d.ts.map +1 -0
- package/dest/queue/bounded_serial_queue.js +84 -0
- package/dest/queue/fifo_memory_queue.d.ts +21 -0
- package/dest/queue/fifo_memory_queue.d.ts.map +1 -0
- package/dest/queue/fifo_memory_queue.js +29 -0
- package/dest/queue/index.d.ts +7 -0
- package/dest/queue/index.d.ts.map +1 -0
- package/dest/queue/index.js +6 -0
- package/dest/queue/priority_memory_queue.d.ts +13 -0
- package/dest/queue/priority_memory_queue.d.ts.map +1 -0
- package/dest/queue/priority_memory_queue.js +16 -0
- package/dest/queue/priority_queue.d.ts +14 -0
- package/dest/queue/priority_queue.d.ts.map +1 -0
- package/dest/queue/priority_queue.js +29 -0
- package/dest/queue/semaphore.d.ts +23 -0
- package/dest/queue/semaphore.d.ts.map +1 -0
- package/dest/queue/semaphore.js +26 -0
- package/dest/queue/serial_queue.d.ts +49 -0
- package/dest/queue/serial_queue.d.ts.map +1 -0
- package/dest/queue/serial_queue.js +72 -0
- package/dest/retry/index.d.ts +44 -0
- package/dest/retry/index.d.ts.map +1 -0
- package/dest/retry/index.js +93 -0
- package/dest/running-promise/index.d.ts +2 -0
- package/dest/running-promise/index.d.ts.map +1 -0
- package/dest/running-promise/index.js +1 -0
- package/dest/schemas/api.d.ts +21 -0
- package/dest/schemas/api.d.ts.map +1 -0
- package/dest/schemas/api.js +3 -0
- package/dest/schemas/index.d.ts +6 -0
- package/dest/schemas/index.d.ts.map +1 -0
- package/dest/schemas/index.js +5 -0
- package/dest/schemas/parse.d.ts +9 -0
- package/dest/schemas/parse.d.ts.map +1 -0
- package/dest/schemas/parse.js +22 -0
- package/dest/schemas/schemas.d.ts +45 -0
- package/dest/schemas/schemas.d.ts.map +1 -0
- package/dest/schemas/schemas.js +38 -0
- package/dest/schemas/types.d.ts +3 -0
- package/dest/schemas/types.d.ts.map +1 -0
- package/dest/schemas/types.js +1 -0
- package/dest/schemas/utils.d.ts +53 -0
- package/dest/schemas/utils.d.ts.map +1 -0
- package/dest/schemas/utils.js +60 -0
- package/dest/serialize/buffer_reader.d.ts +239 -0
- package/dest/serialize/buffer_reader.d.ts.map +1 -0
- package/dest/serialize/buffer_reader.js +290 -0
- package/dest/serialize/field_reader.d.ts +112 -0
- package/dest/serialize/field_reader.d.ts.map +1 -0
- package/dest/serialize/field_reader.js +147 -0
- package/dest/serialize/free_funcs.d.ts +105 -0
- package/dest/serialize/free_funcs.d.ts.map +1 -0
- package/dest/serialize/free_funcs.js +189 -0
- package/dest/serialize/index.d.ts +7 -0
- package/dest/serialize/index.d.ts.map +1 -0
- package/dest/serialize/index.js +6 -0
- package/dest/serialize/serialize.d.ts +182 -0
- package/dest/serialize/serialize.d.ts.map +1 -0
- package/dest/serialize/serialize.js +248 -0
- package/dest/serialize/type_registry.d.ts +23 -0
- package/dest/serialize/type_registry.d.ts.map +1 -0
- package/dest/serialize/type_registry.js +61 -0
- package/dest/serialize/types.d.ts +33 -0
- package/dest/serialize/types.d.ts.map +1 -0
- package/dest/serialize/types.js +21 -0
- package/dest/sleep/index.d.ts +51 -0
- package/dest/sleep/index.d.ts.map +1 -0
- package/dest/sleep/index.js +67 -0
- package/dest/string/index.d.ts +11 -0
- package/dest/string/index.d.ts.map +1 -0
- package/dest/string/index.js +24 -0
- package/dest/testing/files/index.d.ts +20 -0
- package/dest/testing/files/index.d.ts.map +1 -0
- package/dest/testing/files/index.js +58 -0
- package/dest/testing/index.d.ts +4 -0
- package/dest/testing/index.d.ts.map +1 -0
- package/dest/testing/index.js +3 -0
- package/dest/testing/port_allocator.d.ts +10 -0
- package/dest/testing/port_allocator.d.ts.map +1 -0
- package/dest/testing/port_allocator.js +29 -0
- package/dest/testing/snapshot_serializer.d.ts +5 -0
- package/dest/testing/snapshot_serializer.d.ts.map +1 -0
- package/dest/testing/snapshot_serializer.js +32 -0
- package/dest/testing/test_data.d.ts +7 -0
- package/dest/testing/test_data.d.ts.map +1 -0
- package/dest/testing/test_data.js +29 -0
- package/dest/timer/date.d.ts +13 -0
- package/dest/timer/date.d.ts.map +1 -0
- package/dest/timer/date.js +24 -0
- package/dest/timer/elapsed.d.ts +13 -0
- package/dest/timer/elapsed.d.ts.map +1 -0
- package/dest/timer/elapsed.js +25 -0
- package/dest/timer/index.d.ts +5 -0
- package/dest/timer/index.d.ts.map +1 -0
- package/dest/timer/index.js +4 -0
- package/dest/timer/timeout.d.ts +41 -0
- package/dest/timer/timeout.d.ts.map +1 -0
- package/dest/timer/timeout.js +66 -0
- package/dest/timer/timer.d.ts +37 -0
- package/dest/timer/timer.d.ts.map +1 -0
- package/dest/timer/timer.js +40 -0
- package/dest/transport/browser/index.d.ts +5 -0
- package/dest/transport/browser/index.d.ts.map +1 -0
- package/dest/transport/browser/index.js +4 -0
- package/dest/transport/browser/message_port_socket.d.ts +37 -0
- package/dest/transport/browser/message_port_socket.d.ts.map +1 -0
- package/dest/transport/browser/message_port_socket.js +42 -0
- package/dest/transport/browser/shared_worker_connector.d.ts +19 -0
- package/dest/transport/browser/shared_worker_connector.d.ts.map +1 -0
- package/dest/transport/browser/shared_worker_connector.js +19 -0
- package/dest/transport/browser/shared_worker_listener.d.ts +38 -0
- package/dest/transport/browser/shared_worker_listener.d.ts.map +1 -0
- package/dest/transport/browser/shared_worker_listener.js +33 -0
- package/dest/transport/browser/worker_connector.d.ts +26 -0
- package/dest/transport/browser/worker_connector.d.ts.map +1 -0
- package/dest/transport/browser/worker_connector.js +30 -0
- package/dest/transport/browser/worker_listener.d.ts +39 -0
- package/dest/transport/browser/worker_listener.d.ts.map +1 -0
- package/dest/transport/browser/worker_listener.js +35 -0
- package/dest/transport/dispatch/create_dispatch_fn.d.ts +25 -0
- package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -0
- package/dest/transport/dispatch/create_dispatch_fn.js +17 -0
- package/dest/transport/dispatch/create_dispatch_proxy.d.ts +102 -0
- package/dest/transport/dispatch/create_dispatch_proxy.d.ts.map +1 -0
- package/dest/transport/dispatch/create_dispatch_proxy.js +59 -0
- package/dest/transport/dispatch/messages.d.ts +52 -0
- package/dest/transport/dispatch/messages.d.ts.map +1 -0
- package/dest/transport/dispatch/messages.js +13 -0
- package/dest/transport/index.d.ts +12 -0
- package/dest/transport/index.d.ts.map +1 -0
- package/dest/transport/index.js +11 -0
- package/dest/transport/interface/connector.d.ts +8 -0
- package/dest/transport/interface/connector.d.ts.map +1 -0
- package/dest/transport/interface/connector.js +3 -0
- package/dest/transport/interface/listener.d.ts +13 -0
- package/dest/transport/interface/listener.d.ts.map +1 -0
- package/dest/transport/interface/listener.js +4 -0
- package/dest/transport/interface/socket.d.ts +13 -0
- package/dest/transport/interface/socket.d.ts.map +1 -0
- package/dest/transport/interface/socket.js +7 -0
- package/dest/transport/interface/transferable.d.ts +68 -0
- package/dest/transport/interface/transferable.d.ts.map +1 -0
- package/dest/transport/interface/transferable.js +63 -0
- package/dest/transport/node/index.d.ts +3 -0
- package/dest/transport/node/index.d.ts.map +1 -0
- package/dest/transport/node/index.js +2 -0
- package/dest/transport/node/node_connector.d.ts +28 -0
- package/dest/transport/node/node_connector.d.ts.map +1 -0
- package/dest/transport/node/node_connector.js +26 -0
- package/dest/transport/node/node_connector_socket.d.ts +42 -0
- package/dest/transport/node/node_connector_socket.d.ts.map +1 -0
- package/dest/transport/node/node_connector_socket.js +44 -0
- package/dest/transport/node/node_listener.d.ts +26 -0
- package/dest/transport/node/node_listener.d.ts.map +1 -0
- package/dest/transport/node/node_listener.js +26 -0
- package/dest/transport/node/node_listener_socket.d.ts +37 -0
- package/dest/transport/node/node_listener_socket.d.ts.map +1 -0
- package/dest/transport/node/node_listener_socket.js +40 -0
- package/dest/transport/transport_client.d.ts +61 -0
- package/dest/transport/transport_client.d.ts.map +1 -0
- package/dest/transport/transport_client.js +96 -0
- package/dest/transport/transport_server.d.ts +56 -0
- package/dest/transport/transport_server.d.ts.map +1 -0
- package/dest/transport/transport_server.js +114 -0
- package/dest/trees/hasher.d.ts +39 -0
- package/dest/trees/hasher.d.ts.map +1 -0
- package/dest/trees/hasher.js +5 -0
- package/dest/trees/index.d.ts +11 -0
- package/dest/trees/index.d.ts.map +1 -0
- package/dest/trees/index.js +10 -0
- package/dest/trees/indexed_merkle_tree.d.ts +13 -0
- package/dest/trees/indexed_merkle_tree.d.ts.map +1 -0
- package/dest/trees/indexed_merkle_tree.js +27 -0
- package/dest/trees/indexed_merkle_tree_calculator.d.ts +23 -0
- package/dest/trees/indexed_merkle_tree_calculator.d.ts.map +1 -0
- package/dest/trees/indexed_merkle_tree_calculator.js +83 -0
- package/dest/trees/indexed_tree_leaf.d.ts +57 -0
- package/dest/trees/indexed_tree_leaf.d.ts.map +1 -0
- package/dest/trees/indexed_tree_leaf.js +5 -0
- package/dest/trees/membership_witness.d.ts +62 -0
- package/dest/trees/membership_witness.d.ts.map +1 -0
- package/dest/trees/membership_witness.js +70 -0
- package/dest/trees/merkle_tree.d.ts +18 -0
- package/dest/trees/merkle_tree.d.ts.map +1 -0
- package/dest/trees/merkle_tree.js +58 -0
- package/dest/trees/merkle_tree_calculator.d.ts +16 -0
- package/dest/trees/merkle_tree_calculator.d.ts.map +1 -0
- package/dest/trees/merkle_tree_calculator.js +61 -0
- package/dest/trees/sibling_path.d.ts +132 -0
- package/dest/trees/sibling_path.d.ts.map +1 -0
- package/dest/trees/sibling_path.js +144 -0
- package/dest/trees/unbalanced_merkle_tree.d.ts +17 -0
- package/dest/trees/unbalanced_merkle_tree.d.ts.map +1 -0
- package/dest/trees/unbalanced_merkle_tree.js +100 -0
- package/dest/trees/unbalanced_tree_store.d.ts +19 -0
- package/dest/trees/unbalanced_tree_store.d.ts.map +1 -0
- package/dest/trees/unbalanced_tree_store.js +94 -0
- package/dest/types/index.d.ts +19 -0
- package/dest/types/index.d.ts.map +1 -0
- package/dest/types/index.js +3 -0
- package/dest/url/index.d.ts +9 -0
- package/dest/url/index.d.ts.map +1 -0
- package/dest/url/index.js +62 -0
- package/dest/validation/index.d.ts +9 -0
- package/dest/validation/index.d.ts.map +1 -0
- package/dest/validation/index.js +15 -0
- package/dest/wasm/empty_wasi_sdk.d.ts +130 -0
- package/dest/wasm/empty_wasi_sdk.d.ts.map +1 -0
- package/dest/wasm/empty_wasi_sdk.js +148 -0
- package/dest/wasm/index.d.ts +2 -0
- package/dest/wasm/index.d.ts.map +1 -0
- package/dest/wasm/index.js +1 -0
- package/dest/wasm/wasm_module.d.ts +136 -0
- package/dest/wasm/wasm_module.d.ts.map +1 -0
- package/dest/wasm/wasm_module.js +196 -0
- package/dest/worker/browser/index.d.ts +3 -0
- package/dest/worker/browser/index.d.ts.map +1 -0
- package/dest/worker/browser/index.js +2 -0
- package/dest/worker/browser/start_web_module.d.ts +7 -0
- package/dest/worker/browser/start_web_module.d.ts.map +1 -0
- package/dest/worker/browser/start_web_module.js +27 -0
- package/dest/worker/browser/web_data_store.d.ts +24 -0
- package/dest/worker/browser/web_data_store.d.ts.map +1 -0
- package/dest/worker/browser/web_data_store.js +29 -0
- package/dest/worker/browser/web_worker.d.ts +10 -0
- package/dest/worker/browser/web_worker.d.ts.map +1 -0
- package/dest/worker/browser/web_worker.js +25 -0
- package/dest/worker/data_store.d.ts +21 -0
- package/dest/worker/data_store.d.ts.map +1 -0
- package/dest/worker/data_store.js +3 -0
- package/dest/worker/index.d.ts +3 -0
- package/dest/worker/index.d.ts.map +1 -0
- package/dest/worker/index.js +1 -0
- package/dest/worker/node/index.d.ts +3 -0
- package/dest/worker/node/index.d.ts.map +1 -0
- package/dest/worker/node/index.js +2 -0
- package/dest/worker/node/node_data_store.d.ts +13 -0
- package/dest/worker/node/node_data_store.d.ts.map +1 -0
- package/dest/worker/node/node_data_store.js +20 -0
- package/dest/worker/node/node_worker.d.ts +6 -0
- package/dest/worker/node/node_worker.d.ts.map +1 -0
- package/dest/worker/node/node_worker.js +22 -0
- package/dest/worker/node/start_node_module.d.ts +7 -0
- package/dest/worker/node/start_node_module.d.ts.map +1 -0
- package/dest/worker/node/start_node_module.js +31 -0
- package/dest/worker/wasm_worker.d.ts +9 -0
- package/dest/worker/wasm_worker.d.ts.map +1 -0
- package/dest/worker/wasm_worker.js +3 -0
- package/dest/worker/worker_pool.d.ts +40 -0
- package/dest/worker/worker_pool.d.ts.map +1 -0
- package/dest/worker/worker_pool.js +51 -0
- package/package.json +176 -0
- package/src/array/array.ts +150 -0
- package/src/array/index.ts +1 -0
- package/src/async-map/index.ts +18 -0
- package/src/async-pool/index.ts +50 -0
- package/src/bigint-buffer/index.ts +87 -0
- package/src/buffer/buffer32.ts +144 -0
- package/src/buffer/index.ts +1 -0
- package/src/collection/array.ts +203 -0
- package/src/collection/index.ts +2 -0
- package/src/collection/object.ts +52 -0
- package/src/committable/committable.ts +46 -0
- package/src/committable/index.ts +1 -0
- package/src/config/env_var.ts +207 -0
- package/src/config/index.ts +167 -0
- package/src/crypto/aes128/index.ts +59 -0
- package/src/crypto/ecdsa/index.ts +70 -0
- package/src/crypto/ecdsa/signature.ts +100 -0
- package/src/crypto/grumpkin/index.ts +97 -0
- package/src/crypto/index.ts +14 -0
- package/src/crypto/keccak/index.ts +283 -0
- package/src/crypto/keys/index.ts +10 -0
- package/src/crypto/pedersen/index.ts +1 -0
- package/src/crypto/pedersen/pedersen.elliptic.ts +584 -0
- package/src/crypto/pedersen/pedersen.noble.ts +573 -0
- package/src/crypto/pedersen/pedersen.wasm.ts +48 -0
- package/src/crypto/poseidon/index.ts +77 -0
- package/src/crypto/random/index.ts +85 -0
- package/src/crypto/random/randomness_singleton.ts +62 -0
- package/src/crypto/schnorr/index.ts +55 -0
- package/src/crypto/schnorr/signature.ts +116 -0
- package/src/crypto/secp256k1/index.ts +57 -0
- package/src/crypto/secp256k1-signer/index.ts +2 -0
- package/src/crypto/secp256k1-signer/secp256k1_signer.ts +38 -0
- package/src/crypto/secp256k1-signer/utils.ts +99 -0
- package/src/crypto/serialize.ts +85 -0
- package/src/crypto/sha256/index.ts +147 -0
- package/src/crypto/sha512/index.ts +16 -0
- package/src/crypto/signature/index.ts +17 -0
- package/src/crypto/sync/index.ts +6 -0
- package/src/crypto/sync/pedersen/index.ts +45 -0
- package/src/crypto/sync/poseidon/index.ts +76 -0
- package/src/decorators/index.ts +1 -0
- package/src/decorators/memoize.ts +11 -0
- package/src/error/index.ts +22 -0
- package/src/eth-address/index.ts +241 -0
- package/src/eth-signature/eth_signature.ts +128 -0
- package/src/eth-signature/index.ts +1 -0
- package/src/fields/coordinate.ts +104 -0
- package/src/fields/fields.ts +505 -0
- package/src/fields/index.ts +3 -0
- package/src/fields/point.ts +300 -0
- package/src/fs/index.ts +1 -0
- package/src/fs/run_in_dir.ts +33 -0
- package/src/index.ts +31 -0
- package/src/iterable/all.ts +32 -0
- package/src/iterable/filter.ts +77 -0
- package/src/iterable/index.ts +7 -0
- package/src/iterable/isAsyncIt.ts +8 -0
- package/src/iterable/map.ts +66 -0
- package/src/iterable/peek.ts +58 -0
- package/src/iterable/sort.ts +39 -0
- package/src/iterable/take.ts +54 -0
- package/src/iterable/toArray.ts +9 -0
- package/src/jest/setup.mjs +9 -0
- package/src/json-rpc/README.md +55 -0
- package/src/json-rpc/client/fetch.ts +103 -0
- package/src/json-rpc/client/index.ts +2 -0
- package/src/json-rpc/client/safe_json_rpc_client.ts +67 -0
- package/src/json-rpc/client/undici.ts +75 -0
- package/src/json-rpc/convert.ts +61 -0
- package/src/json-rpc/fixtures/class_a.ts +15 -0
- package/src/json-rpc/fixtures/class_b.ts +15 -0
- package/src/json-rpc/fixtures/test_state.ts +143 -0
- package/src/json-rpc/index.ts +1 -0
- package/src/json-rpc/js_utils.ts +21 -0
- package/src/json-rpc/server/index.ts +1 -0
- package/src/json-rpc/server/safe_json_rpc_server.ts +376 -0
- package/src/json-rpc/server/telemetry.ts +0 -0
- package/src/json-rpc/test/index.ts +1 -0
- package/src/json-rpc/test/integration.ts +35 -0
- package/src/log/console.ts +39 -0
- package/src/log/debug.ts +104 -0
- package/src/log/gcloud-logger-config.ts +71 -0
- package/src/log/index.ts +6 -0
- package/src/log/libp2p_logger.ts +67 -0
- package/src/log/log-filters.ts +63 -0
- package/src/log/log-levels.ts +3 -0
- package/src/log/log_fn.ts +5 -0
- package/src/log/log_history.ts +44 -0
- package/src/log/pino-logger.ts +243 -0
- package/src/message/index.ts +43 -0
- package/src/mutex/index.ts +84 -0
- package/src/mutex/mutex_database.ts +12 -0
- package/src/noir/index.ts +1 -0
- package/src/noir/noir_package_config.ts +54 -0
- package/src/promise/index.ts +2 -0
- package/src/promise/running-promise.ts +125 -0
- package/src/promise/utils.ts +29 -0
- package/src/queue/base_memory_queue.ts +138 -0
- package/src/queue/batch_queue.ts +120 -0
- package/src/queue/bounded_serial_queue.ts +100 -0
- package/src/queue/fifo_memory_queue.ts +39 -0
- package/src/queue/index.ts +6 -0
- package/src/queue/priority_memory_queue.ts +20 -0
- package/src/queue/priority_queue.ts +34 -0
- package/src/queue/semaphore.ts +33 -0
- package/src/queue/serial_queue.ts +86 -0
- package/src/retry/index.ts +100 -0
- package/src/running-promise/index.ts +1 -0
- package/src/schemas/api.ts +47 -0
- package/src/schemas/index.ts +5 -0
- package/src/schemas/parse.ts +29 -0
- package/src/schemas/schemas.ts +64 -0
- package/src/schemas/types.ts +3 -0
- package/src/schemas/utils.ts +112 -0
- package/src/serialize/buffer_reader.ts +383 -0
- package/src/serialize/field_reader.ts +184 -0
- package/src/serialize/free_funcs.ts +204 -0
- package/src/serialize/index.ts +6 -0
- package/src/serialize/serialize.ts +336 -0
- package/src/serialize/type_registry.ts +75 -0
- package/src/serialize/types.ts +40 -0
- package/src/sleep/index.ts +75 -0
- package/src/string/index.ts +31 -0
- package/src/testing/files/index.ts +69 -0
- package/src/testing/index.ts +3 -0
- package/src/testing/port_allocator.ts +31 -0
- package/src/testing/snapshot_serializer.ts +33 -0
- package/src/testing/test_data.ts +36 -0
- package/src/timer/date.ts +24 -0
- package/src/timer/elapsed.ts +23 -0
- package/src/timer/index.ts +4 -0
- package/src/timer/timeout.ts +70 -0
- package/src/timer/timer.ts +48 -0
- package/src/transport/browser/index.ts +4 -0
- package/src/transport/browser/message_port_socket.ts +48 -0
- package/src/transport/browser/shared_worker_connector.ts +21 -0
- package/src/transport/browser/shared_worker_listener.ts +53 -0
- package/src/transport/browser/worker_connector.ts +30 -0
- package/src/transport/browser/worker_listener.ts +54 -0
- package/src/transport/dispatch/create_dispatch_fn.ts +35 -0
- package/src/transport/dispatch/create_dispatch_proxy.ts +141 -0
- package/src/transport/dispatch/messages.ts +58 -0
- package/src/transport/index.ts +11 -0
- package/src/transport/interface/connector.ts +9 -0
- package/src/transport/interface/listener.ts +16 -0
- package/src/transport/interface/socket.ts +15 -0
- package/src/transport/interface/transferable.ts +125 -0
- package/src/transport/node/index.ts +2 -0
- package/src/transport/node/node_connector.ts +30 -0
- package/src/transport/node/node_connector_socket.ts +52 -0
- package/src/transport/node/node_listener.ts +34 -0
- package/src/transport/node/node_listener_socket.ts +48 -0
- package/src/transport/transport_client.ts +131 -0
- package/src/transport/transport_server.ts +108 -0
- package/src/trees/hasher.ts +39 -0
- package/src/trees/index.ts +10 -0
- package/src/trees/indexed_merkle_tree.ts +36 -0
- package/src/trees/indexed_merkle_tree_calculator.ts +94 -0
- package/src/trees/indexed_tree_leaf.ts +56 -0
- package/src/trees/membership_witness.ts +99 -0
- package/src/trees/merkle_tree.ts +72 -0
- package/src/trees/merkle_tree_calculator.ts +67 -0
- package/src/trees/sibling_path.ts +183 -0
- package/src/trees/unbalanced_merkle_tree.ts +103 -0
- package/src/trees/unbalanced_tree_store.ts +102 -0
- package/src/types/index.ts +25 -0
- package/src/url/index.ts +73 -0
- package/src/validation/index.ts +18 -0
- package/src/wasm/README.md +6 -0
- package/src/wasm/empty_wasi_sdk.ts +166 -0
- package/src/wasm/fixtures/gcd.wasm +0 -0
- package/src/wasm/fixtures/gcd.wat +27 -0
- package/src/wasm/index.ts +1 -0
- package/src/wasm/wasm_module.ts +260 -0
- package/src/worker/browser/index.ts +2 -0
- package/src/worker/browser/start_web_module.ts +24 -0
- package/src/worker/browser/web_data_store.ts +38 -0
- package/src/worker/browser/web_worker.ts +25 -0
- package/src/worker/data_store.ts +19 -0
- package/src/worker/index.ts +2 -0
- package/src/worker/node/index.ts +2 -0
- package/src/worker/node/node_data_store.ts +27 -0
- package/src/worker/node/node_worker.ts +23 -0
- package/src/worker/node/start_node_module.ts +30 -0
- package/src/worker/wasm_worker.ts +7 -0
- package/src/worker/worker_pool.ts +73 -0
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
const noirGitDependencySchema = z.object({
|
|
3
|
+
git: z.string(),
|
|
4
|
+
tag: z.string(),
|
|
5
|
+
directory: z.string().optional()
|
|
6
|
+
});
|
|
7
|
+
const noirLocalDependencySchema = z.object({
|
|
8
|
+
path: z.string()
|
|
9
|
+
});
|
|
10
|
+
const noirPackageConfigSchema = z.object({
|
|
11
|
+
package: z.object({
|
|
12
|
+
name: z.string().default(''),
|
|
13
|
+
type: z.enum([
|
|
14
|
+
'lib',
|
|
15
|
+
'contract',
|
|
16
|
+
'bin'
|
|
17
|
+
]).default('bin'),
|
|
18
|
+
entry: z.string().optional(),
|
|
19
|
+
description: z.string().optional(),
|
|
20
|
+
authors: z.array(z.string()).optional(),
|
|
21
|
+
// eslint-disable-next-line camelcase
|
|
22
|
+
compiler_version: z.string().optional(),
|
|
23
|
+
backend: z.string().optional(),
|
|
24
|
+
license: z.string().optional()
|
|
25
|
+
}),
|
|
26
|
+
dependencies: z.record(z.union([
|
|
27
|
+
noirGitDependencySchema,
|
|
28
|
+
noirLocalDependencySchema
|
|
29
|
+
])).default({})
|
|
30
|
+
});
|
|
31
|
+
/**
|
|
32
|
+
* Checks that an object is a package configuration.
|
|
33
|
+
* @param config - Config to check
|
|
34
|
+
*/ export function parseNoirPackageConfig(config) {
|
|
35
|
+
return noirPackageConfigSchema.parse(config);
|
|
36
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/promise/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { type Logger } from '../log/pino-logger.js';
|
|
2
|
+
declare const EXIT: unique symbol;
|
|
3
|
+
export type ErrorHandler = (err: unknown) => typeof EXIT | void | Promise<typeof EXIT | void>;
|
|
4
|
+
export declare function makeLoggingErrorHandler(logger: Logger, ...ignoredErrors: (new (...args: any[]) => Error)[]): ErrorHandler;
|
|
5
|
+
/**
|
|
6
|
+
* RunningPromise is a utility class that helps manage the execution of an asynchronous function
|
|
7
|
+
* at a specified polling interval. It allows starting, stopping, and checking the status of the
|
|
8
|
+
* internally managed promise. The class also supports interrupting the polling process when stopped.
|
|
9
|
+
*/
|
|
10
|
+
export declare class RunningPromise {
|
|
11
|
+
private fn;
|
|
12
|
+
private logger;
|
|
13
|
+
private pollingIntervalMS;
|
|
14
|
+
private handleError;
|
|
15
|
+
private running;
|
|
16
|
+
private runningPromise;
|
|
17
|
+
private interruptibleSleep;
|
|
18
|
+
private requested;
|
|
19
|
+
static readonly EXIT: typeof EXIT;
|
|
20
|
+
constructor(fn: () => void | Promise<void>, logger?: Logger, pollingIntervalMS?: number, handleError?: ErrorHandler);
|
|
21
|
+
/**
|
|
22
|
+
* Starts the running promise.
|
|
23
|
+
*/
|
|
24
|
+
start(): void;
|
|
25
|
+
/**
|
|
26
|
+
* Stops the running promise, resolves any pending interruptible sleep,
|
|
27
|
+
* and waits for the currently executing function to complete.
|
|
28
|
+
*/
|
|
29
|
+
stop(): Promise<void>;
|
|
30
|
+
/**
|
|
31
|
+
* Checks if the running promise is currently active.
|
|
32
|
+
* @returns True if the promise is running.
|
|
33
|
+
*/
|
|
34
|
+
isRunning(): boolean;
|
|
35
|
+
/**
|
|
36
|
+
* Triggers an immediate run of the function, bypassing the polling interval.
|
|
37
|
+
* If the function is currently running, it will be allowed to continue and then called again immediately.
|
|
38
|
+
*/
|
|
39
|
+
trigger(): Promise<void>;
|
|
40
|
+
/**
|
|
41
|
+
* Updates the polling interval. The new interval will take effect after the next poll.
|
|
42
|
+
* @param pollingIntervalMS The polling interval in milliseconds.
|
|
43
|
+
*/
|
|
44
|
+
setPollingIntervalMS(pollingIntervalMS: number): void;
|
|
45
|
+
}
|
|
46
|
+
export {};
|
|
47
|
+
//# sourceMappingURL=running-promise.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"running-promise.d.ts","sourceRoot":"","sources":["../../src/promise/running-promise.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAgB,MAAM,uBAAuB,CAAC;AAIlE,QAAA,MAAM,IAAI,eAAoC,CAAC;AAE/C,MAAM,MAAM,YAAY,GAAG,CAAC,GAAG,EAAE,OAAO,KAAK,OAAO,IAAI,GAAG,IAAI,GAAG,OAAO,CAAC,OAAO,IAAI,GAAG,IAAI,CAAC,CAAC;AAE9F,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,MAAM,EACd,GAAG,aAAa,EAAE,CAAC,KAAK,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,KAAK,CAAC,EAAE,GAClD,YAAY,CAMd;AAED;;;;GAIG;AACH,qBAAa,cAAc;IASvB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,WAAW;IAXrB,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,cAAc,CAAqB;IAC3C,OAAO,CAAC,kBAAkB,CAA4B;IACtD,OAAO,CAAC,SAAS,CAAqD;IAEtE,gBAAuB,IAAI,EAAE,OAAO,IAAI,CAAQ;gBAGtC,EAAE,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,EAC9B,MAAM,SAAkC,EACxC,iBAAiB,SAAQ,EACzB,WAAW,GAAE,YAA8C;IAGrE;;OAEG;IACI,KAAK;IAmCZ;;;OAGG;IACG,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAU3B;;;OAGG;IACI,SAAS;IAIhB;;;OAGG;IACU,OAAO;IAcpB;;;OAGG;IACH,oBAAoB,CAAC,iBAAiB,EAAE,MAAM;CAG/C"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { createLogger } from '../log/pino-logger.js';
|
|
2
|
+
import { InterruptibleSleep } from '../sleep/index.js';
|
|
3
|
+
import { promiseWithResolvers } from './utils.js';
|
|
4
|
+
const EXIT = Symbol.for('RunningPromise.EXIT');
|
|
5
|
+
export function makeLoggingErrorHandler(logger, ...ignoredErrors) {
|
|
6
|
+
return (err)=>{
|
|
7
|
+
if (err instanceof Error && !ignoredErrors.some((ErrorType)=>err instanceof ErrorType)) {
|
|
8
|
+
logger.error('Error in running promise', err);
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* RunningPromise is a utility class that helps manage the execution of an asynchronous function
|
|
14
|
+
* at a specified polling interval. It allows starting, stopping, and checking the status of the
|
|
15
|
+
* internally managed promise. The class also supports interrupting the polling process when stopped.
|
|
16
|
+
*/ export class RunningPromise {
|
|
17
|
+
fn;
|
|
18
|
+
logger;
|
|
19
|
+
pollingIntervalMS;
|
|
20
|
+
handleError;
|
|
21
|
+
running;
|
|
22
|
+
runningPromise;
|
|
23
|
+
interruptibleSleep;
|
|
24
|
+
requested;
|
|
25
|
+
static EXIT = EXIT;
|
|
26
|
+
constructor(fn, logger = createLogger('running-promise'), pollingIntervalMS = 10000, handleError = makeLoggingErrorHandler(logger)){
|
|
27
|
+
this.fn = fn;
|
|
28
|
+
this.logger = logger;
|
|
29
|
+
this.pollingIntervalMS = pollingIntervalMS;
|
|
30
|
+
this.handleError = handleError;
|
|
31
|
+
this.running = false;
|
|
32
|
+
this.runningPromise = Promise.resolve();
|
|
33
|
+
this.interruptibleSleep = new InterruptibleSleep();
|
|
34
|
+
this.requested = undefined;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Starts the running promise.
|
|
38
|
+
*/ start() {
|
|
39
|
+
if (this.running) {
|
|
40
|
+
this.logger.warn(`Attempted to start running promise that was already started`);
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
this.running = true;
|
|
44
|
+
const poll = async ()=>{
|
|
45
|
+
while(this.running){
|
|
46
|
+
const hasRequested = this.requested !== undefined;
|
|
47
|
+
try {
|
|
48
|
+
await this.fn();
|
|
49
|
+
} catch (err) {
|
|
50
|
+
const code = await this.handleError(err);
|
|
51
|
+
if (code === RunningPromise.EXIT) {
|
|
52
|
+
this.logger.warn('Error handler has requested to exit', {
|
|
53
|
+
err
|
|
54
|
+
});
|
|
55
|
+
this.running = false;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
// If an immediate run had been requested *before* the function started running, resolve the request.
|
|
59
|
+
if (hasRequested) {
|
|
60
|
+
this.requested.resolve();
|
|
61
|
+
this.requested = undefined;
|
|
62
|
+
}
|
|
63
|
+
// If no immediate run was requested, sleep for the polling interval.
|
|
64
|
+
if (this.requested === undefined && this.running) {
|
|
65
|
+
await this.interruptibleSleep.sleep(this.pollingIntervalMS);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
this.runningPromise = poll();
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Stops the running promise, resolves any pending interruptible sleep,
|
|
73
|
+
* and waits for the currently executing function to complete.
|
|
74
|
+
*/ async stop() {
|
|
75
|
+
if (!this.running) {
|
|
76
|
+
this.logger.warn(`Running promise was not started`);
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
this.running = false;
|
|
80
|
+
this.interruptibleSleep.interrupt();
|
|
81
|
+
await this.runningPromise;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Checks if the running promise is currently active.
|
|
85
|
+
* @returns True if the promise is running.
|
|
86
|
+
*/ isRunning() {
|
|
87
|
+
return this.running;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Triggers an immediate run of the function, bypassing the polling interval.
|
|
91
|
+
* If the function is currently running, it will be allowed to continue and then called again immediately.
|
|
92
|
+
*/ async trigger() {
|
|
93
|
+
if (!this.running) {
|
|
94
|
+
return this.fn();
|
|
95
|
+
}
|
|
96
|
+
let requested = this.requested;
|
|
97
|
+
if (!requested) {
|
|
98
|
+
requested = promiseWithResolvers();
|
|
99
|
+
this.requested = requested;
|
|
100
|
+
this.interruptibleSleep.interrupt();
|
|
101
|
+
}
|
|
102
|
+
await requested.promise;
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Updates the polling interval. The new interval will take effect after the next poll.
|
|
106
|
+
* @param pollingIntervalMS The polling interval in milliseconds.
|
|
107
|
+
*/ setPollingIntervalMS(pollingIntervalMS) {
|
|
108
|
+
this.pollingIntervalMS = pollingIntervalMS;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type PromiseWithResolvers<T> = {
|
|
2
|
+
promise: Promise<T>;
|
|
3
|
+
resolve: (value: T) => void;
|
|
4
|
+
reject: (reason?: any) => void;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* A polyfill for the Promise.withResolvers proposed API.
|
|
8
|
+
* @see https://github.com/tc39/proposal-promise-with-resolvers
|
|
9
|
+
* @returns A promise with resolvers.
|
|
10
|
+
*/
|
|
11
|
+
export declare function promiseWithResolvers<T>(): PromiseWithResolvers<T>;
|
|
12
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/promise/utils.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,oBAAoB,CAAC,CAAC,IAAI;IACpC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACpB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC;IAC5B,MAAM,EAAE,CAAC,MAAM,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;CAChC,CAAC;AAEF;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,KAAK,oBAAoB,CAAC,CAAC,CAAC,CAiBjE"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A polyfill for the Promise.withResolvers proposed API.
|
|
3
|
+
* @see https://github.com/tc39/proposal-promise-with-resolvers
|
|
4
|
+
* @returns A promise with resolvers.
|
|
5
|
+
*/ export function promiseWithResolvers() {
|
|
6
|
+
// use ! operator to avoid TS error
|
|
7
|
+
let resolve;
|
|
8
|
+
let reject;
|
|
9
|
+
// the ES spec guarantees that the promise executor is called synchronously
|
|
10
|
+
// so the resolve and reject functions will be defined
|
|
11
|
+
const promise = new Promise((res, rej)=>{
|
|
12
|
+
resolve = res;
|
|
13
|
+
reject = rej;
|
|
14
|
+
});
|
|
15
|
+
return {
|
|
16
|
+
promise,
|
|
17
|
+
resolve,
|
|
18
|
+
reject
|
|
19
|
+
};
|
|
20
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export declare abstract class BaseMemoryQueue<T> {
|
|
2
|
+
private log;
|
|
3
|
+
private waiting;
|
|
4
|
+
private flushing;
|
|
5
|
+
constructor(log?: import("../log/pino-logger.js").Logger);
|
|
6
|
+
protected abstract get items(): {
|
|
7
|
+
length: number;
|
|
8
|
+
get(): T | undefined;
|
|
9
|
+
put(item: T): void;
|
|
10
|
+
clear: () => void;
|
|
11
|
+
};
|
|
12
|
+
/**
|
|
13
|
+
* Returns the current number of items in the queue.
|
|
14
|
+
* The length represents the size of the queue at the time of invocation and may change as new items are added or consumed.
|
|
15
|
+
*
|
|
16
|
+
* @returns The number of items in the queue.
|
|
17
|
+
*/
|
|
18
|
+
length(): number;
|
|
19
|
+
/**
|
|
20
|
+
* Returns next item within the queue, or undefined if the queue is empty. Does not block.
|
|
21
|
+
* @returns The next item in the queue.
|
|
22
|
+
*/
|
|
23
|
+
getImmediate(): T | undefined;
|
|
24
|
+
/**
|
|
25
|
+
* Returns next item within the queue, or blocks until an item has been put into the queue.
|
|
26
|
+
*
|
|
27
|
+
* If given a timeout, the promise will reject if no item is received after `timeoutSec` seconds.
|
|
28
|
+
* If the timeout is undefined (default), this call will block until an item is available or the queue is closed.
|
|
29
|
+
* If the timeout is 0 and there are no items available then the queue will immediately reject with a TimeoutError.
|
|
30
|
+
*
|
|
31
|
+
* If the queue is flushing, `null` is returned.
|
|
32
|
+
* @param timeoutSec - The timeout in seconds.
|
|
33
|
+
* @returns A result promise.
|
|
34
|
+
*/
|
|
35
|
+
get(timeoutSec?: number): Promise<T | null>;
|
|
36
|
+
/**
|
|
37
|
+
* Put an item onto back of the queue.
|
|
38
|
+
* @param item - The item to enqueue.
|
|
39
|
+
* @returns A boolean indicating whether the item was successfully added to the queue.
|
|
40
|
+
*/
|
|
41
|
+
put(item: T): boolean;
|
|
42
|
+
/**
|
|
43
|
+
* Once ended, no further items are added to queue. Consumers will consume remaining items within the queue.
|
|
44
|
+
* The queue is not reusable after calling `end()`.
|
|
45
|
+
* Any consumers waiting for an item receive null.
|
|
46
|
+
*/
|
|
47
|
+
end(): void;
|
|
48
|
+
/**
|
|
49
|
+
* Once cancelled, all items are discarded from the queue, and no further items are added to the queue.
|
|
50
|
+
* The queue is not reusable after calling `cancel()`.
|
|
51
|
+
* Any consumers waiting for an item receive null.
|
|
52
|
+
*/
|
|
53
|
+
cancel(): void;
|
|
54
|
+
/**
|
|
55
|
+
* Process items from the queue using a provided handler function.
|
|
56
|
+
* The function iterates over items in the queue, invoking the handler for each item until the queue is empty and flushing.
|
|
57
|
+
* If the handler throws an error, it will be caught and logged as 'Queue handler exception:', but the iteration will continue.
|
|
58
|
+
* The process function returns a promise that resolves when there are no more items in the queue and the queue is flushing.
|
|
59
|
+
*
|
|
60
|
+
* @param handler - A function that takes an item of type T and returns a Promise<void> after processing the item.
|
|
61
|
+
* @returns A Promise<void> that resolves when the queue is finished processing.
|
|
62
|
+
*/
|
|
63
|
+
process(handler: (item: T) => Promise<void>): Promise<void>;
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=base_memory_queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base_memory_queue.d.ts","sourceRoot":"","sources":["../../src/queue/base_memory_queue.ts"],"names":[],"mappings":"AAGA,8BAAsB,eAAe,CAAC,CAAC;IAIzB,OAAO,CAAC,GAAG;IAHvB,OAAO,CAAC,OAAO,CAAoC;IACnD,OAAO,CAAC,QAAQ,CAAS;gBAEL,GAAG,yCAAyC;IAEhE,SAAS,CAAC,QAAQ,KAAK,KAAK,IAAI;QAC9B,MAAM,EAAE,MAAM,CAAC;QACf,GAAG,IAAI,CAAC,GAAG,SAAS,CAAC;QACrB,GAAG,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,CAAC;QACnB,KAAK,EAAE,MAAM,IAAI,CAAC;KACnB,CAAC;IAEF;;;;;OAKG;IACI,MAAM;IAIb;;;OAGG;IACI,YAAY,IAAI,CAAC,GAAG,SAAS;IAIpC;;;;;;;;;;OAUG;IACI,GAAG,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IA+BlD;;;;OAIG;IACI,GAAG,CAAC,IAAI,EAAE,CAAC,GAAG,OAAO;IAa5B;;;;OAIG;IACI,GAAG;IAKV;;;;OAIG;IACI,MAAM;IAMb;;;;;;;;OAQG;IACU,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC;CAazD"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { TimeoutError } from '../error/index.js';
|
|
2
|
+
import { createLogger } from '../log/index.js';
|
|
3
|
+
export class BaseMemoryQueue {
|
|
4
|
+
log;
|
|
5
|
+
waiting;
|
|
6
|
+
flushing;
|
|
7
|
+
constructor(log = createLogger('foundation:memory_fifo')){
|
|
8
|
+
this.log = log;
|
|
9
|
+
this.waiting = [];
|
|
10
|
+
this.flushing = false;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Returns the current number of items in the queue.
|
|
14
|
+
* The length represents the size of the queue at the time of invocation and may change as new items are added or consumed.
|
|
15
|
+
*
|
|
16
|
+
* @returns The number of items in the queue.
|
|
17
|
+
*/ length() {
|
|
18
|
+
return this.items.length;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Returns next item within the queue, or undefined if the queue is empty. Does not block.
|
|
22
|
+
* @returns The next item in the queue.
|
|
23
|
+
*/ getImmediate() {
|
|
24
|
+
return this.items.get();
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Returns next item within the queue, or blocks until an item has been put into the queue.
|
|
28
|
+
*
|
|
29
|
+
* If given a timeout, the promise will reject if no item is received after `timeoutSec` seconds.
|
|
30
|
+
* If the timeout is undefined (default), this call will block until an item is available or the queue is closed.
|
|
31
|
+
* If the timeout is 0 and there are no items available then the queue will immediately reject with a TimeoutError.
|
|
32
|
+
*
|
|
33
|
+
* If the queue is flushing, `null` is returned.
|
|
34
|
+
* @param timeoutSec - The timeout in seconds.
|
|
35
|
+
* @returns A result promise.
|
|
36
|
+
*/ get(timeoutSec) {
|
|
37
|
+
if (this.items.length) {
|
|
38
|
+
return Promise.resolve(this.items.get());
|
|
39
|
+
}
|
|
40
|
+
if (this.items.length === 0 && this.flushing) {
|
|
41
|
+
return Promise.resolve(null);
|
|
42
|
+
}
|
|
43
|
+
// if the caller doesn't want to wait for an item to be available
|
|
44
|
+
// immediately reject with a Timeout error
|
|
45
|
+
if (timeoutSec === 0) {
|
|
46
|
+
return Promise.reject(new TimeoutError('Timeout getting item from queue.'));
|
|
47
|
+
}
|
|
48
|
+
return new Promise((resolve, reject)=>{
|
|
49
|
+
this.waiting.push(resolve);
|
|
50
|
+
if (timeoutSec) {
|
|
51
|
+
setTimeout(()=>{
|
|
52
|
+
const index = this.waiting.findIndex((r)=>r === resolve);
|
|
53
|
+
if (index > -1) {
|
|
54
|
+
this.waiting.splice(index, 1);
|
|
55
|
+
const err = new TimeoutError('Timeout getting item from queue.');
|
|
56
|
+
reject(err);
|
|
57
|
+
}
|
|
58
|
+
}, timeoutSec * 1000);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Put an item onto back of the queue.
|
|
64
|
+
* @param item - The item to enqueue.
|
|
65
|
+
* @returns A boolean indicating whether the item was successfully added to the queue.
|
|
66
|
+
*/ put(item) {
|
|
67
|
+
if (this.flushing) {
|
|
68
|
+
this.log.warn('Discarding item because queue is flushing');
|
|
69
|
+
return false;
|
|
70
|
+
} else if (this.waiting.length) {
|
|
71
|
+
this.waiting.shift()(item);
|
|
72
|
+
return true;
|
|
73
|
+
} else {
|
|
74
|
+
this.items.put(item);
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Once ended, no further items are added to queue. Consumers will consume remaining items within the queue.
|
|
80
|
+
* The queue is not reusable after calling `end()`.
|
|
81
|
+
* Any consumers waiting for an item receive null.
|
|
82
|
+
*/ end() {
|
|
83
|
+
this.flushing = true;
|
|
84
|
+
this.waiting.forEach((resolve)=>resolve(null));
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Once cancelled, all items are discarded from the queue, and no further items are added to the queue.
|
|
88
|
+
* The queue is not reusable after calling `cancel()`.
|
|
89
|
+
* Any consumers waiting for an item receive null.
|
|
90
|
+
*/ cancel() {
|
|
91
|
+
this.flushing = true;
|
|
92
|
+
this.items.clear();
|
|
93
|
+
this.waiting.forEach((resolve)=>resolve(null));
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Process items from the queue using a provided handler function.
|
|
97
|
+
* The function iterates over items in the queue, invoking the handler for each item until the queue is empty and flushing.
|
|
98
|
+
* If the handler throws an error, it will be caught and logged as 'Queue handler exception:', but the iteration will continue.
|
|
99
|
+
* The process function returns a promise that resolves when there are no more items in the queue and the queue is flushing.
|
|
100
|
+
*
|
|
101
|
+
* @param handler - A function that takes an item of type T and returns a Promise<void> after processing the item.
|
|
102
|
+
* @returns A Promise<void> that resolves when the queue is finished processing.
|
|
103
|
+
*/ async process(handler) {
|
|
104
|
+
try {
|
|
105
|
+
while(true){
|
|
106
|
+
const item = await this.get();
|
|
107
|
+
if (item === null) {
|
|
108
|
+
break;
|
|
109
|
+
}
|
|
110
|
+
await handler(item);
|
|
111
|
+
}
|
|
112
|
+
} catch (err) {
|
|
113
|
+
this.log.error('Queue handler exception', err);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A queue that groups items into batches based on a group key.
|
|
3
|
+
*
|
|
4
|
+
* The batching algorithm is greedy, meaning that as long as consecutive items have the same group key then they will
|
|
5
|
+
* be batvched together. As soon as an item with a different group key is encountered, the old batch is flushed to the
|
|
6
|
+
* queue and a new batch is started.
|
|
7
|
+
*
|
|
8
|
+
* A batch can also be flushed to the queue if:
|
|
9
|
+
* - it reaches the selected batch size limit
|
|
10
|
+
* - or the batch duration limit is hit (in milliseconds)
|
|
11
|
+
*
|
|
12
|
+
* This ensures that batches don't grow too big and that they are flushed at a minimum rate of 1 batch every interval.
|
|
13
|
+
*
|
|
14
|
+
* The consumer side of this queue will process batches as quickly as possible.
|
|
15
|
+
*/
|
|
16
|
+
export declare class BatchQueue<T, K extends string | number> {
|
|
17
|
+
private processBatch;
|
|
18
|
+
private maxBatchSize;
|
|
19
|
+
private maxBatchDuration;
|
|
20
|
+
private log;
|
|
21
|
+
private container;
|
|
22
|
+
private currentBatch?;
|
|
23
|
+
private runningPromise?;
|
|
24
|
+
constructor(processBatch: (items: Array<T>, key: K) => void | Promise<void>, maxBatchSize: number, maxBatchDuration: number, log?: import("../log/pino-logger.js").Logger);
|
|
25
|
+
/**
|
|
26
|
+
* Put an item in the queue. It will be routed based on the given key
|
|
27
|
+
* @param item - The item to add
|
|
28
|
+
* @param key - The group key for this item
|
|
29
|
+
* @returns A promise that resolves or rejects when the batch this item is part of is processed
|
|
30
|
+
*/
|
|
31
|
+
put(item: T, key: K): Promise<void>;
|
|
32
|
+
/**
|
|
33
|
+
* Immediately flushes the current batch, starting a new one
|
|
34
|
+
*/
|
|
35
|
+
flushCurrentBatch: () => void;
|
|
36
|
+
/**
|
|
37
|
+
* Starts the queue.
|
|
38
|
+
*/
|
|
39
|
+
start(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Stops the queue. Any items in the queue will continue to be processed but new items won't be accepted anymore
|
|
42
|
+
* @returns A promise that resolves when the queue is drained completely
|
|
43
|
+
*/
|
|
44
|
+
stop(): Promise<void>;
|
|
45
|
+
private execProcessor;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=batch_queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"batch_queue.d.ts","sourceRoot":"","sources":["../../src/queue/batch_queue.ts"],"names":[],"mappings":"AAWA;;;;;;;;;;;;;;GAcG;AACH,qBAAa,UAAU,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,GAAG,MAAM;IAMhD,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,GAAG;IARb,OAAO,CAAC,SAAS,CAAsC;IACvD,OAAO,CAAC,YAAY,CAAC,CAAc;IACnC,OAAO,CAAC,cAAc,CAAC,CAAgB;gBAG7B,YAAY,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,EAC/D,YAAY,EAAE,MAAM,EACpB,gBAAgB,EAAE,MAAM,EACxB,GAAG,yCAAyC;IAGtD;;;;;OAKG;IACI,GAAG,CAAC,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IA4B1C;;OAEG;IACI,iBAAiB,QAAO,IAAI,CAOjC;IAEF;;OAEG;IACI,KAAK;IAQZ;;;OAGG;IACI,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAY5B,OAAO,CAAC,aAAa,CAOnB;CACH"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { createLogger } from '../log/pino-logger.js';
|
|
2
|
+
import { promiseWithResolvers } from '../promise/utils.js';
|
|
3
|
+
import { FifoMemoryQueue } from './fifo_memory_queue.js';
|
|
4
|
+
/**
|
|
5
|
+
* A queue that groups items into batches based on a group key.
|
|
6
|
+
*
|
|
7
|
+
* The batching algorithm is greedy, meaning that as long as consecutive items have the same group key then they will
|
|
8
|
+
* be batvched together. As soon as an item with a different group key is encountered, the old batch is flushed to the
|
|
9
|
+
* queue and a new batch is started.
|
|
10
|
+
*
|
|
11
|
+
* A batch can also be flushed to the queue if:
|
|
12
|
+
* - it reaches the selected batch size limit
|
|
13
|
+
* - or the batch duration limit is hit (in milliseconds)
|
|
14
|
+
*
|
|
15
|
+
* This ensures that batches don't grow too big and that they are flushed at a minimum rate of 1 batch every interval.
|
|
16
|
+
*
|
|
17
|
+
* The consumer side of this queue will process batches as quickly as possible.
|
|
18
|
+
*/ export class BatchQueue {
|
|
19
|
+
processBatch;
|
|
20
|
+
maxBatchSize;
|
|
21
|
+
maxBatchDuration;
|
|
22
|
+
log;
|
|
23
|
+
container;
|
|
24
|
+
currentBatch;
|
|
25
|
+
runningPromise;
|
|
26
|
+
constructor(processBatch, maxBatchSize, maxBatchDuration, log = createLogger('foundation:batch_queue')){
|
|
27
|
+
this.processBatch = processBatch;
|
|
28
|
+
this.maxBatchSize = maxBatchSize;
|
|
29
|
+
this.maxBatchDuration = maxBatchDuration;
|
|
30
|
+
this.log = log;
|
|
31
|
+
this.container = new FifoMemoryQueue();
|
|
32
|
+
this.flushCurrentBatch = ()=>{
|
|
33
|
+
if (this.currentBatch) {
|
|
34
|
+
this.log.trace('Flushing batch', {
|
|
35
|
+
size: this.currentBatch.items.length,
|
|
36
|
+
key: this.currentBatch.key
|
|
37
|
+
});
|
|
38
|
+
clearTimeout(this.currentBatch.enqueueTimeout);
|
|
39
|
+
this.container.put(this.currentBatch);
|
|
40
|
+
this.currentBatch = undefined;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
this.execProcessor = async (batch)=>{
|
|
44
|
+
try {
|
|
45
|
+
await this.processBatch(batch.items, batch.key);
|
|
46
|
+
batch.deferred.resolve();
|
|
47
|
+
} catch (err) {
|
|
48
|
+
batch.deferred.reject(err);
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Put an item in the queue. It will be routed based on the given key
|
|
54
|
+
* @param item - The item to add
|
|
55
|
+
* @param key - The group key for this item
|
|
56
|
+
* @returns A promise that resolves or rejects when the batch this item is part of is processed
|
|
57
|
+
*/ put(item, key) {
|
|
58
|
+
if (!this.runningPromise) {
|
|
59
|
+
return Promise.reject(new Error('BatchQueue is not started'));
|
|
60
|
+
}
|
|
61
|
+
let currentBatch = this.currentBatch;
|
|
62
|
+
if (!currentBatch || currentBatch.key !== key || currentBatch.items.length >= this.maxBatchSize) {
|
|
63
|
+
this.flushCurrentBatch();
|
|
64
|
+
this.log.trace('Creating new batch', {
|
|
65
|
+
key
|
|
66
|
+
});
|
|
67
|
+
currentBatch = {
|
|
68
|
+
items: [],
|
|
69
|
+
key,
|
|
70
|
+
deferred: promiseWithResolvers(),
|
|
71
|
+
enqueueTimeout: setTimeout(this.flushCurrentBatch, this.maxBatchDuration)
|
|
72
|
+
};
|
|
73
|
+
this.currentBatch = currentBatch;
|
|
74
|
+
}
|
|
75
|
+
currentBatch.items.push(item);
|
|
76
|
+
if (currentBatch.items.length >= this.maxBatchSize) {
|
|
77
|
+
this.flushCurrentBatch();
|
|
78
|
+
}
|
|
79
|
+
return currentBatch.deferred.promise;
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Immediately flushes the current batch, starting a new one
|
|
83
|
+
*/ flushCurrentBatch;
|
|
84
|
+
/**
|
|
85
|
+
* Starts the queue.
|
|
86
|
+
*/ start() {
|
|
87
|
+
if (this.runningPromise) {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
this.runningPromise = this.container.process(this.execProcessor);
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Stops the queue. Any items in the queue will continue to be processed but new items won't be accepted anymore
|
|
94
|
+
* @returns A promise that resolves when the queue is drained completely
|
|
95
|
+
*/ stop() {
|
|
96
|
+
const runningPromise = this.runningPromise;
|
|
97
|
+
this.runningPromise = undefined;
|
|
98
|
+
if (!runningPromise) {
|
|
99
|
+
return Promise.resolve();
|
|
100
|
+
}
|
|
101
|
+
this.container.end();
|
|
102
|
+
return runningPromise;
|
|
103
|
+
}
|
|
104
|
+
execProcessor;
|
|
105
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Leverages the unbounded SerialQueue and Semaphore to create a SerialQueue that will block when putting an item
|
|
3
|
+
* if the queue size = maxQueueSize.
|
|
4
|
+
*/
|
|
5
|
+
export declare class BoundedSerialQueue {
|
|
6
|
+
private log;
|
|
7
|
+
private readonly queue;
|
|
8
|
+
private semaphore;
|
|
9
|
+
constructor(maxQueueSize: number, log?: import("../log/pino-logger.js").Logger);
|
|
10
|
+
/**
|
|
11
|
+
* Initializes the underlying SerialQueue instance, allowing items to be processed from the queue.
|
|
12
|
+
* The start method should be called before using the BoundedSerialQueue to ensure proper functionality.
|
|
13
|
+
*/
|
|
14
|
+
start(): void;
|
|
15
|
+
/**
|
|
16
|
+
* Returns the current number of items in the queue.
|
|
17
|
+
* This is useful for monitoring the size of BoundedSerialQueue and understanding its utilization.
|
|
18
|
+
*
|
|
19
|
+
* @returns The length of the queue as an integer value.
|
|
20
|
+
*/
|
|
21
|
+
length(): number;
|
|
22
|
+
/**
|
|
23
|
+
* Cancels the current operation in the SerialQueue, if any, and clears the queue.
|
|
24
|
+
* Any pending tasks in the queue will not be executed, and the queue will be emptied.
|
|
25
|
+
* This method is useful for cleaning up resources and stopping ongoing processes when they are no longer needed.
|
|
26
|
+
* @returns A promise, resolved once cancelled.
|
|
27
|
+
*/
|
|
28
|
+
cancel(): Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* Ends the queue processing gracefully, preventing new items from being added.
|
|
31
|
+
* The currently executing item, if any, will complete and remaining queued items
|
|
32
|
+
* will be processed in order. Once all items have been processed, the queue becomes
|
|
33
|
+
* permanently unusable.
|
|
34
|
+
*
|
|
35
|
+
* @returns A promise that resolves when all items in the queue have been processed.
|
|
36
|
+
*/
|
|
37
|
+
end(): Promise<void>;
|
|
38
|
+
/**
|
|
39
|
+
* The caller will block until fn is successfully enqueued.
|
|
40
|
+
* The fn itself is execute asynchronously and its result discarded.
|
|
41
|
+
* TODO(AD) do we need this if we have exec()?
|
|
42
|
+
* @param fn - The function to call once unblocked.
|
|
43
|
+
*/
|
|
44
|
+
put(fn: () => Promise<void>): Promise<void>;
|
|
45
|
+
/**
|
|
46
|
+
* The caller will block until fn is successfully executed, and it's result returned.
|
|
47
|
+
* @param fn - The function.
|
|
48
|
+
* @returns A promise that resolves with the result once executed.
|
|
49
|
+
*/
|
|
50
|
+
exec<T>(fn: () => Promise<T>): Promise<T>;
|
|
51
|
+
/**
|
|
52
|
+
* Awaiting this ensures the queue is empty before resuming.
|
|
53
|
+
*/
|
|
54
|
+
syncPoint(): Promise<void>;
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=bounded_serial_queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bounded_serial_queue.d.ts","sourceRoot":"","sources":["../../src/queue/bounded_serial_queue.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,qBAAa,kBAAkB;IAIK,OAAO,CAAC,GAAG;IAH7C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAqB;IAC3C,OAAO,CAAC,SAAS,CAAY;gBAEjB,YAAY,EAAE,MAAM,EAAU,GAAG,yCAAkD;IAI/F;;;OAGG;IACI,KAAK;IAIZ;;;;;OAKG;IACI,MAAM;IAIb;;;;;OAKG;IACI,MAAM;IAIb;;;;;;;OAOG;IACI,GAAG;IAIV;;;;;OAKG;IACU,GAAG,CAAC,EAAE,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAexD;;;;OAIG;IACU,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAWtD;;OAEG;IACU,SAAS;CAGvB"}
|