@aztec/foundation 0.7.2 → 0.7.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.tsbuildinfo +1 -0
- package/dest/abi/abi.d.ts +232 -0
- package/dest/abi/abi.d.ts.map +1 -0
- package/dest/abi/abi.js +37 -0
- package/dest/abi/abi_coder.d.ts +8 -0
- package/dest/abi/abi_coder.d.ts.map +1 -0
- package/dest/abi/abi_coder.js +24 -0
- package/dest/abi/decoder.d.ts +57 -0
- package/dest/abi/decoder.d.ts.map +1 -0
- package/dest/abi/decoder.js +149 -0
- package/dest/abi/decoder.test.d.ts +2 -0
- package/dest/abi/decoder.test.d.ts.map +1 -0
- package/dest/abi/decoder.test.js +70 -0
- package/dest/abi/encoder.d.ts +10 -0
- package/dest/abi/encoder.d.ts.map +1 -0
- package/dest/abi/encoder.js +89 -0
- package/dest/abi/encoder.test.d.ts +2 -0
- package/dest/abi/encoder.test.d.ts.map +1 -0
- package/dest/abi/encoder.test.js +74 -0
- package/dest/abi/function_selector.d.ts +73 -0
- package/dest/abi/function_selector.d.ts.map +1 -0
- package/dest/abi/function_selector.js +104 -0
- package/dest/abi/index.d.ts +6 -0
- package/dest/abi/index.d.ts.map +1 -0
- package/dest/abi/index.js +6 -0
- package/dest/async-map/async_map.test.d.ts +2 -0
- package/dest/async-map/async_map.test.d.ts.map +1 -0
- package/dest/async-map/async_map.test.js +9 -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 +19 -0
- package/dest/aztec-address/index.d.ts +114 -0
- package/dest/aztec-address/index.d.ts.map +1 -0
- package/dest/aztec-address/index.js +148 -0
- package/dest/bigint-buffer/bigint-buffer.test.d.ts +2 -0
- package/dest/bigint-buffer/bigint-buffer.test.d.ts.map +1 -0
- package/dest/bigint-buffer/bigint-buffer.test.js +18 -0
- package/dest/bigint-buffer/index.d.ts +35 -0
- package/dest/bigint-buffer/index.d.ts.map +1 -0
- package/dest/bigint-buffer/index.js +68 -0
- package/dest/collection/array.d.ts +30 -0
- package/dest/collection/array.d.ts.map +1 -0
- package/dest/collection/array.js +47 -0
- package/dest/collection/index.d.ts +2 -0
- package/dest/collection/index.d.ts.map +1 -0
- package/dest/collection/index.js +2 -0
- package/dest/committable/committable.d.ts +28 -0
- package/dest/committable/committable.d.ts.map +1 -0
- package/dest/committable/committable.js +41 -0
- package/dest/committable/committable.test.d.ts +2 -0
- package/dest/committable/committable.test.d.ts.map +1 -0
- package/dest/committable/committable.test.js +26 -0
- package/dest/committable/index.d.ts +2 -0
- package/dest/committable/index.d.ts.map +1 -0
- package/dest/committable/index.js +2 -0
- package/dest/crypto/index.d.ts +4 -0
- package/dest/crypto/index.d.ts.map +1 -0
- package/dest/crypto/index.js +4 -0
- package/dest/crypto/keccak/index.d.ts +20 -0
- package/dest/crypto/keccak/index.d.ts.map +1 -0
- package/dest/crypto/keccak/index.js +31 -0
- package/dest/crypto/random/index.d.ts +3 -0
- package/dest/crypto/random/index.d.ts.map +1 -0
- package/dest/crypto/random/index.js +36 -0
- package/dest/crypto/random/index.test.d.ts +2 -0
- package/dest/crypto/random/index.test.d.ts.map +1 -0
- package/dest/crypto/random/index.test.js +13 -0
- package/dest/crypto/sha256/index.d.ts +11 -0
- package/dest/crypto/sha256/index.d.ts.map +1 -0
- package/dest/crypto/sha256/index.js +14 -0
- package/dest/crypto/sha256/index.test.d.ts +2 -0
- package/dest/crypto/sha256/index.test.d.ts.map +1 -0
- package/dest/crypto/sha256/index.test.js +11 -0
- package/dest/errors/index.d.ts +8 -0
- package/dest/errors/index.d.ts.map +1 -0
- package/dest/errors/index.js +8 -0
- package/dest/eth-address/eth_address.test.d.ts +2 -0
- package/dest/eth-address/eth_address.test.d.ts.map +1 -0
- package/dest/eth-address/eth_address.test.js +95 -0
- package/dest/eth-address/index.d.ts +144 -0
- package/dest/eth-address/index.d.ts.map +1 -0
- package/dest/eth-address/index.js +228 -0
- package/dest/fields/coordinate.d.ts +67 -0
- package/dest/fields/coordinate.d.ts.map +1 -0
- package/dest/fields/coordinate.js +95 -0
- package/dest/fields/coordinate.test.d.ts +2 -0
- package/dest/fields/coordinate.test.d.ts.map +1 -0
- package/dest/fields/coordinate.test.js +22 -0
- package/dest/fields/fields.d.ts +177 -0
- package/dest/fields/fields.d.ts.map +1 -0
- package/dest/fields/fields.js +219 -0
- package/dest/fields/grumpkin_scalar.d.ts +96 -0
- package/dest/fields/grumpkin_scalar.d.ts.map +1 -0
- package/dest/fields/grumpkin_scalar.js +125 -0
- package/dest/fields/grumpkin_scalar.test.d.ts +2 -0
- package/dest/fields/grumpkin_scalar.test.d.ts.map +1 -0
- package/dest/fields/grumpkin_scalar.test.js +45 -0
- package/dest/fields/index.d.ts +5 -0
- package/dest/fields/index.d.ts.map +1 -0
- package/dest/fields/index.js +5 -0
- package/dest/fields/point.d.ts +105 -0
- package/dest/fields/point.d.ts.map +1 -0
- package/dest/fields/point.js +125 -0
- package/dest/fifo/bounded_serial_queue.d.ts +56 -0
- package/dest/fifo/bounded_serial_queue.d.ts.map +1 -0
- package/dest/fifo/bounded_serial_queue.js +94 -0
- package/dest/fifo/index.d.ts +5 -0
- package/dest/fifo/index.d.ts.map +1 -0
- package/dest/fifo/index.js +5 -0
- package/dest/fifo/memory_fifo.d.ts +55 -0
- package/dest/fifo/memory_fifo.d.ts.map +1 -0
- package/dest/fifo/memory_fifo.js +109 -0
- package/dest/fifo/semaphore.d.ts +23 -0
- package/dest/fifo/semaphore.d.ts.map +1 -0
- package/dest/fifo/semaphore.js +30 -0
- package/dest/fifo/serial_queue.d.ts +48 -0
- package/dest/fifo/serial_queue.d.ts.map +1 -0
- package/dest/fifo/serial_queue.js +74 -0
- package/dest/json-rpc/class_converter.d.ts +144 -0
- package/dest/json-rpc/class_converter.d.ts.map +1 -0
- package/dest/json-rpc/class_converter.js +100 -0
- package/dest/json-rpc/client/index.d.ts +2 -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/json_rpc_client.d.ts +29 -0
- package/dest/json-rpc/client/json_rpc_client.d.ts.map +1 -0
- package/dest/json-rpc/client/json_rpc_client.js +104 -0
- package/dest/json-rpc/client/json_rpc_client.test.d.ts +2 -0
- package/dest/json-rpc/client/json_rpc_client.test.d.ts.map +1 -0
- package/dest/json-rpc/client/json_rpc_client.test.js +20 -0
- package/dest/json-rpc/convert.d.ts +28 -0
- package/dest/json-rpc/convert.d.ts.map +1 -0
- package/dest/json-rpc/convert.js +139 -0
- package/dest/json-rpc/convert.test.d.ts +2 -0
- package/dest/json-rpc/convert.test.d.ts.map +1 -0
- package/dest/json-rpc/convert.test.js +68 -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 +17 -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 +17 -0
- package/dest/json-rpc/fixtures/test_state.d.ts +47 -0
- package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -0
- package/dest/json-rpc/fixtures/test_state.js +62 -0
- package/dest/json-rpc/index.d.ts +3 -0
- package/dest/json-rpc/index.d.ts.map +1 -0
- package/dest/json-rpc/index.js +3 -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 +18 -0
- package/dest/json-rpc/server/index.d.ts +3 -0
- package/dest/json-rpc/server/index.d.ts.map +1 -0
- package/dest/json-rpc/server/index.js +3 -0
- package/dest/json-rpc/server/json_proxy.d.ts +18 -0
- package/dest/json-rpc/server/json_proxy.d.ts.map +1 -0
- package/dest/json-rpc/server/json_proxy.js +36 -0
- package/dest/json-rpc/server/json_rpc_server.d.ts +34 -0
- package/dest/json-rpc/server/json_rpc_server.d.ts.map +1 -0
- package/dest/json-rpc/server/json_rpc_server.js +133 -0
- package/dest/json-rpc/server/json_rpc_server.test.d.ts +2 -0
- package/dest/json-rpc/server/json_rpc_server.test.d.ts.map +1 -0
- package/dest/json-rpc/server/json_rpc_server.test.js +22 -0
- package/dest/log/console.d.ts +11 -0
- package/dest/log/console.d.ts.map +1 -0
- package/dest/log/console.js +38 -0
- package/dest/log/debug.d.ts +43 -0
- package/dest/log/debug.d.ts.map +1 -0
- package/dest/log/debug.js +75 -0
- package/dest/log/index.d.ts +9 -0
- package/dest/log/index.d.ts.map +1 -0
- package/dest/log/index.js +5 -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 +42 -0
- package/dest/log/log_history.test.d.ts +2 -0
- package/dest/log/log_history.test.d.ts.map +1 -0
- package/dest/log/log_history.test.js +78 -0
- package/dest/log/logger.d.ts +34 -0
- package/dest/log/logger.d.ts.map +1 -0
- package/dest/log/logger.js +78 -0
- package/dest/mutex/index.d.ts +53 -0
- package/dest/mutex/index.d.ts.map +1 -0
- package/dest/mutex/index.js +74 -0
- package/dest/mutex/mutex.test.d.ts +9 -0
- package/dest/mutex/mutex.test.d.ts.map +1 -0
- package/dest/mutex/mutex.test.js +58 -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 +2 -0
- package/dest/retry/index.d.ts +44 -0
- package/dest/retry/index.d.ts.map +1 -0
- package/dest/retry/index.js +89 -0
- package/dest/running-promise/index.d.ts +35 -0
- package/dest/running-promise/index.d.ts.map +1 -0
- package/dest/running-promise/index.js +59 -0
- package/dest/serialize/buffer_reader.d.ts +188 -0
- package/dest/serialize/buffer_reader.d.ts.map +1 -0
- package/dest/serialize/buffer_reader.js +229 -0
- package/dest/serialize/buffer_reader.test.d.ts +2 -0
- package/dest/serialize/buffer_reader.test.d.ts.map +1 -0
- package/dest/serialize/buffer_reader.test.js +156 -0
- package/dest/serialize/deserializer.d.ts +134 -0
- package/dest/serialize/deserializer.d.ts.map +1 -0
- package/dest/serialize/deserializer.js +145 -0
- package/dest/serialize/free_funcs.d.ts +203 -0
- package/dest/serialize/free_funcs.d.ts.map +1 -0
- package/dest/serialize/free_funcs.js +250 -0
- package/dest/serialize/index.d.ts +6 -0
- package/dest/serialize/index.d.ts.map +1 -0
- package/dest/serialize/index.js +6 -0
- package/dest/serialize/serialize.test.d.ts +2 -0
- package/dest/serialize/serialize.test.d.ts.map +1 -0
- package/dest/serialize/serialize.test.js +68 -0
- package/dest/serialize/serializer.d.ts +89 -0
- package/dest/serialize/serializer.d.ts.map +1 -0
- package/dest/serialize/serializer.js +111 -0
- package/dest/serialize/types.d.ts +33 -0
- package/dest/serialize/types.d.ts.map +1 -0
- package/dest/serialize/types.js +22 -0
- package/dest/sleep/index.d.ts +52 -0
- package/dest/sleep/index.d.ts.map +1 -0
- package/dest/sleep/index.js +70 -0
- package/dest/timer/index.d.ts +3 -0
- package/dest/timer/index.d.ts.map +1 -0
- package/dest/timer/index.js +3 -0
- package/dest/timer/timeout.d.ts +41 -0
- package/dest/timer/timeout.d.ts.map +1 -0
- package/dest/timer/timeout.js +62 -0
- package/dest/timer/timer.d.ts +33 -0
- package/dest/timer/timer.d.ts.map +1 -0
- package/dest/timer/timer.js +38 -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 +5 -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 +46 -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 +21 -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 +37 -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 +39 -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 +18 -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 +56 -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 +12 -0
- package/dest/transport/index.d.ts +12 -0
- package/dest/transport/index.d.ts.map +1 -0
- package/dest/transport/index.js +12 -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 +2 -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 +2 -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 +2 -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 +3 -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 +28 -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 +48 -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 +30 -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 +44 -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 +94 -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 +101 -0
- package/dest/types/index.d.ts +7 -0
- package/dest/types/index.d.ts.map +1 -0
- package/dest/types/index.js +2 -0
- package/dest/url/index.d.ts +9 -0
- package/dest/url/index.d.ts.map +1 -0
- package/dest/url/index.js +66 -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 +166 -0
- package/dest/wasm/index.d.ts +2 -0
- package/dest/wasm/index.d.ts.map +1 -0
- package/dest/wasm/index.js +2 -0
- package/dest/wasm/wasm_module.d.ts +135 -0
- package/dest/wasm/wasm_module.d.ts.map +1 -0
- package/dest/wasm/wasm_module.js +205 -0
- package/dest/wasm/wasm_module.test.d.ts +2 -0
- package/dest/wasm/wasm_module.test.d.ts.map +1 -0
- package/dest/wasm/wasm_module.test.js +24 -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 +3 -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 +22 -0
- package/dest/worker/browser/web_data_store.d.ts +23 -0
- package/dest/worker/browser/web_data_store.d.ts.map +1 -0
- package/dest/worker/browser/web_data_store.js +32 -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 +23 -0
- package/dest/worker/data_store.d.ts +20 -0
- package/dest/worker/data_store.d.ts.map +1 -0
- package/dest/worker/data_store.js +2 -0
- package/dest/worker/index.d.ts +3 -0
- package/dest/worker/index.d.ts.map +1 -0
- package/dest/worker/index.js +2 -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 +3 -0
- package/dest/worker/node/node_data_store.d.ts +12 -0
- package/dest/worker/node/node_data_store.d.ts.map +1 -0
- package/dest/worker/node/node_data_store.js +21 -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 +20 -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 +26 -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 +2 -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 +62 -0
- package/package.json +1 -1
- package/Dockerfile +0 -15
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
import { Fq, Fr } from '../fields/fields.js';
|
|
3
|
+
import { Tuple } from './types.js';
|
|
4
|
+
/**
|
|
5
|
+
* The BufferReader class provides a utility for reading various data types from a buffer.
|
|
6
|
+
* It supports reading numbers, booleans, byte arrays, Fr and Fq field elements,
|
|
7
|
+
* vectors, arrays, objects, strings, and maps. It maintains an internal index to
|
|
8
|
+
* keep track of the current reading position in the buffer.
|
|
9
|
+
*
|
|
10
|
+
* Usage:
|
|
11
|
+
* Create a new instance of BufferReader with a buffer and an optional offset.
|
|
12
|
+
* Use the provided methods to read desired data types from the buffer.
|
|
13
|
+
* The reading methods automatically advance the internal index.
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* const reader = new BufferReader(someBuffer);
|
|
17
|
+
* const num = reader.readNumber();
|
|
18
|
+
* const bool = reader.readBoolean();
|
|
19
|
+
* const byteArray = reader.readBytes(4);
|
|
20
|
+
*/
|
|
21
|
+
export declare class BufferReader {
|
|
22
|
+
private buffer;
|
|
23
|
+
private index;
|
|
24
|
+
constructor(buffer: Buffer, offset?: number);
|
|
25
|
+
/**
|
|
26
|
+
* Creates a BufferReader instance from either a Buffer or an existing BufferReader.
|
|
27
|
+
* If the input is a Buffer, it creates a new BufferReader with the given buffer.
|
|
28
|
+
* If the input is already a BufferReader, it returns the input unchanged.
|
|
29
|
+
*
|
|
30
|
+
* @param bufferOrReader - A Buffer or BufferReader to initialize the BufferReader.
|
|
31
|
+
* @returns An instance of BufferReader.
|
|
32
|
+
*/
|
|
33
|
+
static asReader(bufferOrReader: Buffer | BufferReader): BufferReader;
|
|
34
|
+
/**
|
|
35
|
+
* Reads a 32-bit unsigned integer from the buffer at the current index position.
|
|
36
|
+
* Updates the index position by 4 bytes after reading the number.
|
|
37
|
+
*
|
|
38
|
+
* @returns The read 32-bit unsigned integer value.
|
|
39
|
+
*/
|
|
40
|
+
readNumber(): number;
|
|
41
|
+
/**
|
|
42
|
+
* Reads a 16-bit unsigned integer from the buffer at the current index position.
|
|
43
|
+
* Updates the index position by 2 bytes after reading the number.
|
|
44
|
+
*
|
|
45
|
+
* @returns The read 16 bit value.
|
|
46
|
+
*/
|
|
47
|
+
readUInt16(): number;
|
|
48
|
+
/**
|
|
49
|
+
* Reads and returns the next boolean value from the buffer.
|
|
50
|
+
* Advances the internal index by 1, treating the byte at the current index as a boolean value.
|
|
51
|
+
* Returns true if the byte is non-zero, false otherwise.
|
|
52
|
+
*
|
|
53
|
+
* @returns A boolean value representing the byte at the current index.
|
|
54
|
+
*/
|
|
55
|
+
readBoolean(): boolean;
|
|
56
|
+
/**
|
|
57
|
+
* Reads a specified number of bytes from the buffer and returns a new Buffer containing those bytes.
|
|
58
|
+
* Advances the reader's index by the number of bytes read. Throws an error if there are not enough
|
|
59
|
+
* bytes left in the buffer to satisfy the requested number of bytes.
|
|
60
|
+
*
|
|
61
|
+
* @param n - The number of bytes to read from the buffer.
|
|
62
|
+
* @returns A new Buffer containing the read bytes.
|
|
63
|
+
*/
|
|
64
|
+
readBytes(n: number): Buffer;
|
|
65
|
+
/**
|
|
66
|
+
* Reads a Fr (finite field) element from the buffer using the 'fromBuffer' method of the Fr class.
|
|
67
|
+
* The Fr class should provide a 'fromBuffer' method that takes a BufferReader instance as input.
|
|
68
|
+
*
|
|
69
|
+
* @returns An instance of the Fr class representing the finite field element.
|
|
70
|
+
*/
|
|
71
|
+
readFr(): Fr;
|
|
72
|
+
/**
|
|
73
|
+
* Reads the next Fq element from the buffer using the Fq.fromBuffer method.
|
|
74
|
+
* The Fq element represents a finite field in elliptic curve cryptography and is used for calculations.
|
|
75
|
+
* Advances the internal buffer index by the number of bytes read.
|
|
76
|
+
*
|
|
77
|
+
* @returns An Fq instance representing the finite field element.
|
|
78
|
+
*/
|
|
79
|
+
readFq(): Fq;
|
|
80
|
+
/**
|
|
81
|
+
* Reads a vector of numbers from the buffer and returns it as an array of numbers.
|
|
82
|
+
* The method utilizes the 'readVector' method, passing a deserializer that reads numbers.
|
|
83
|
+
*
|
|
84
|
+
* @returns An array of numbers representing the vector read from the buffer.
|
|
85
|
+
*/
|
|
86
|
+
readNumberVector(): number[];
|
|
87
|
+
/**
|
|
88
|
+
* Reads a vector of fixed size from the buffer and deserializes its elements using the provided itemDeserializer object.
|
|
89
|
+
* The 'itemDeserializer' object should have a 'fromBuffer' method that takes a BufferReader instance and returns the deserialized element.
|
|
90
|
+
* The method first reads the size of the vector (a number) from the buffer, then iterates through its elements,
|
|
91
|
+
* deserializing each one using the 'fromBuffer' method of 'itemDeserializer'.
|
|
92
|
+
*
|
|
93
|
+
* @param itemDeserializer - Object with 'fromBuffer' method to deserialize vector elements.
|
|
94
|
+
* @returns An array of deserialized elements of type T.
|
|
95
|
+
*/
|
|
96
|
+
readVector<T>(itemDeserializer: {
|
|
97
|
+
/**
|
|
98
|
+
* A method to deserialize data from a buffer.
|
|
99
|
+
*/
|
|
100
|
+
fromBuffer: (reader: BufferReader) => T;
|
|
101
|
+
}): T[];
|
|
102
|
+
/**
|
|
103
|
+
* Read an array of a fixed size with elements of type T from the buffer.
|
|
104
|
+
* The 'itemDeserializer' object should have a 'fromBuffer' method that takes a BufferReader instance as input,
|
|
105
|
+
* and returns an instance of the desired deserialized data type T.
|
|
106
|
+
* This method will call the 'fromBuffer' method for each element in the array and return the resulting array.
|
|
107
|
+
*
|
|
108
|
+
* @param size - The fixed number of elements in the array.
|
|
109
|
+
* @param itemDeserializer - An object with a 'fromBuffer' method to deserialize individual elements of type T.
|
|
110
|
+
* @returns An array of instances of type T.
|
|
111
|
+
*/
|
|
112
|
+
readArray<T, N extends number>(size: N, itemDeserializer: {
|
|
113
|
+
/**
|
|
114
|
+
* A function for deserializing data from a BufferReader instance.
|
|
115
|
+
*/
|
|
116
|
+
fromBuffer: (reader: BufferReader) => T;
|
|
117
|
+
}): Tuple<T, N>;
|
|
118
|
+
/**
|
|
119
|
+
* Read a variable sized Buffer array where elements are represented by length + data.
|
|
120
|
+
* The method consecutively looks for a number which is the size of the proceeding buffer,
|
|
121
|
+
* then reads the bytes until it reaches the end of the reader's internal buffer.
|
|
122
|
+
* NOTE: if `size` is not provided, this will run to the end of the reader's buffer.
|
|
123
|
+
* @param size - Size of the buffer array in bytes (full remaining buffer length if left empty).
|
|
124
|
+
* @returns An array of variable sized buffers.
|
|
125
|
+
*/
|
|
126
|
+
readBufferArray(size?: number): Buffer[];
|
|
127
|
+
/**
|
|
128
|
+
* Reads a serialized object from a buffer and returns the deserialized object using the given deserializer.
|
|
129
|
+
*
|
|
130
|
+
* @typeparam T - The type of the deserialized object.
|
|
131
|
+
* @param deserializer - An object with a 'fromBuffer' method that takes a BufferReader instance and returns an instance of the deserialized object.
|
|
132
|
+
* @returns The deserialized object of type T.
|
|
133
|
+
*/
|
|
134
|
+
readObject<T>(deserializer: {
|
|
135
|
+
/**
|
|
136
|
+
* A method that takes a BufferReader instance and returns an instance of the deserialized data type.
|
|
137
|
+
*/
|
|
138
|
+
fromBuffer: (reader: BufferReader) => T;
|
|
139
|
+
}): T;
|
|
140
|
+
/**
|
|
141
|
+
* Returns a Buffer containing the next n bytes from the current buffer without modifying the reader's index position.
|
|
142
|
+
* If n is not provided or exceeds the remaining length of the buffer, it returns all bytes from the current position till the end of the buffer.
|
|
143
|
+
*
|
|
144
|
+
* @param n - The number of bytes to peek from the current buffer. (Optional).
|
|
145
|
+
* @returns A Buffer with the next n bytes or the remaining bytes if n is not provided or exceeds the buffer length.
|
|
146
|
+
*/
|
|
147
|
+
peekBytes(n?: number): Buffer;
|
|
148
|
+
/**
|
|
149
|
+
* Reads a string from the buffer and returns it.
|
|
150
|
+
* The method first reads the size of the string, then reads the corresponding
|
|
151
|
+
* number of bytes from the buffer and converts them to a string.
|
|
152
|
+
*
|
|
153
|
+
* @returns The read string from the buffer.
|
|
154
|
+
*/
|
|
155
|
+
readString(): string;
|
|
156
|
+
/**
|
|
157
|
+
* Reads a buffer from the current position of the reader and advances the index.
|
|
158
|
+
* The method first reads the size (number) of bytes to be read, and then returns
|
|
159
|
+
* a Buffer with that size containing the bytes. Useful for reading variable-length
|
|
160
|
+
* binary data encoded as (size, data) format.
|
|
161
|
+
*
|
|
162
|
+
* @returns A Buffer containing the read bytes.
|
|
163
|
+
*/
|
|
164
|
+
readBuffer(): Buffer;
|
|
165
|
+
/**
|
|
166
|
+
* Reads and constructs a map object from the current buffer using the provided deserializer.
|
|
167
|
+
* The method reads the number of entries in the map, followed by iterating through each key-value pair.
|
|
168
|
+
* The key is read as a string, while the value is obtained using the passed deserializer's `fromBuffer` method.
|
|
169
|
+
* The resulting map object is returned, containing all the key-value pairs read from the buffer.
|
|
170
|
+
*
|
|
171
|
+
* @param deserializer - An object with a `fromBuffer` method to deserialize the values in the map.
|
|
172
|
+
* @returns A map object with string keys and deserialized values based on the provided deserializer.
|
|
173
|
+
*/
|
|
174
|
+
readMap<T>(deserializer: {
|
|
175
|
+
/**
|
|
176
|
+
* Deserializes an element of type T from a BufferReader instance.
|
|
177
|
+
*/
|
|
178
|
+
fromBuffer: (reader: BufferReader) => T;
|
|
179
|
+
}): {
|
|
180
|
+
[key: string]: T;
|
|
181
|
+
};
|
|
182
|
+
/**
|
|
183
|
+
* Get the length of the reader's buffer.
|
|
184
|
+
* @returns The length of the underlying reader's buffer.
|
|
185
|
+
*/
|
|
186
|
+
getLength(): number;
|
|
187
|
+
}
|
|
188
|
+
//# sourceMappingURL=buffer_reader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffer_reader.d.ts","sourceRoot":"","sources":["../../src/serialize/buffer_reader.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC;;;;;;;;;;;;;;;;GAgBG;AACH,qBAAa,YAAY;IAEX,OAAO,CAAC,MAAM;IAD1B,OAAO,CAAC,KAAK,CAAS;gBACF,MAAM,EAAE,MAAM,EAAE,MAAM,SAAI;IAI9C;;;;;;;OAOG;WACW,QAAQ,CAAC,cAAc,EAAE,MAAM,GAAG,YAAY;IAI5D;;;;;OAKG;IACI,UAAU,IAAI,MAAM;IAK3B;;;;;OAKG;IACI,UAAU,IAAI,MAAM;IAK3B;;;;;;OAMG;IACI,WAAW,IAAI,OAAO;IAK7B;;;;;;;OAOG;IACI,SAAS,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAKnC;;;;;OAKG;IACI,MAAM,IAAI,EAAE;IAInB;;;;;;OAMG;IACI,MAAM,IAAI,EAAE;IAInB;;;;;OAKG;IACI,gBAAgB,IAAI,MAAM,EAAE;IAMnC;;;;;;;;OAQG;IACI,UAAU,CAAC,CAAC,EAAE,gBAAgB,EAAE;QACrC;;WAEG;QACH,UAAU,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,CAAC,CAAC;KACzC,GAAG,CAAC,EAAE;IASP;;;;;;;;;OASG;IACI,SAAS,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,EAClC,IAAI,EAAE,CAAC,EACP,gBAAgB,EAAE;QAChB;;WAEG;QACH,UAAU,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,CAAC,CAAC;KACzC,GACA,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;IAKd;;;;;;;OAOG;IACI,eAAe,CAAC,IAAI,SAAK,GAAG,MAAM,EAAE;IAgB3C;;;;;;OAMG;IACI,UAAU,CAAC,CAAC,EAAE,YAAY,EAAE;QACjC;;WAEG;QACH,UAAU,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,CAAC,CAAC;KACzC,GAAG,CAAC;IAIL;;;;;;OAMG;IACI,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM;IAIpC;;;;;;OAMG;IACI,UAAU,IAAI,MAAM;IAI3B;;;;;;;OAOG;IACI,UAAU,IAAI,MAAM;IAK3B;;;;;;;;OAQG;IACI,OAAO,CAAC,CAAC,EAAE,YAAY,EAAE;QAC9B;;WAEG;QACH,UAAU,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,CAAC,CAAC;KACzC,GAAG;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,CAAC,CAAA;KAAE;IAWxB;;;OAGG;IACI,SAAS,IAAI,MAAM;CAG3B"}
|
|
@@ -0,0 +1,229 @@
|
|
|
1
|
+
import { Fq, Fr } from '../fields/fields.js';
|
|
2
|
+
/**
|
|
3
|
+
* The BufferReader class provides a utility for reading various data types from a buffer.
|
|
4
|
+
* It supports reading numbers, booleans, byte arrays, Fr and Fq field elements,
|
|
5
|
+
* vectors, arrays, objects, strings, and maps. It maintains an internal index to
|
|
6
|
+
* keep track of the current reading position in the buffer.
|
|
7
|
+
*
|
|
8
|
+
* Usage:
|
|
9
|
+
* Create a new instance of BufferReader with a buffer and an optional offset.
|
|
10
|
+
* Use the provided methods to read desired data types from the buffer.
|
|
11
|
+
* The reading methods automatically advance the internal index.
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* const reader = new BufferReader(someBuffer);
|
|
15
|
+
* const num = reader.readNumber();
|
|
16
|
+
* const bool = reader.readBoolean();
|
|
17
|
+
* const byteArray = reader.readBytes(4);
|
|
18
|
+
*/
|
|
19
|
+
export class BufferReader {
|
|
20
|
+
constructor(buffer, offset = 0) {
|
|
21
|
+
this.buffer = buffer;
|
|
22
|
+
this.index = offset;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Creates a BufferReader instance from either a Buffer or an existing BufferReader.
|
|
26
|
+
* If the input is a Buffer, it creates a new BufferReader with the given buffer.
|
|
27
|
+
* If the input is already a BufferReader, it returns the input unchanged.
|
|
28
|
+
*
|
|
29
|
+
* @param bufferOrReader - A Buffer or BufferReader to initialize the BufferReader.
|
|
30
|
+
* @returns An instance of BufferReader.
|
|
31
|
+
*/
|
|
32
|
+
static asReader(bufferOrReader) {
|
|
33
|
+
return Buffer.isBuffer(bufferOrReader) ? new BufferReader(bufferOrReader) : bufferOrReader;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Reads a 32-bit unsigned integer from the buffer at the current index position.
|
|
37
|
+
* Updates the index position by 4 bytes after reading the number.
|
|
38
|
+
*
|
|
39
|
+
* @returns The read 32-bit unsigned integer value.
|
|
40
|
+
*/
|
|
41
|
+
readNumber() {
|
|
42
|
+
this.index += 4;
|
|
43
|
+
return this.buffer.readUint32BE(this.index - 4);
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Reads a 16-bit unsigned integer from the buffer at the current index position.
|
|
47
|
+
* Updates the index position by 2 bytes after reading the number.
|
|
48
|
+
*
|
|
49
|
+
* @returns The read 16 bit value.
|
|
50
|
+
*/
|
|
51
|
+
readUInt16() {
|
|
52
|
+
this.index += 2;
|
|
53
|
+
return this.buffer.readUInt16BE(this.index - 2);
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Reads and returns the next boolean value from the buffer.
|
|
57
|
+
* Advances the internal index by 1, treating the byte at the current index as a boolean value.
|
|
58
|
+
* Returns true if the byte is non-zero, false otherwise.
|
|
59
|
+
*
|
|
60
|
+
* @returns A boolean value representing the byte at the current index.
|
|
61
|
+
*/
|
|
62
|
+
readBoolean() {
|
|
63
|
+
this.index += 1;
|
|
64
|
+
return Boolean(this.buffer.at(this.index - 1));
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Reads a specified number of bytes from the buffer and returns a new Buffer containing those bytes.
|
|
68
|
+
* Advances the reader's index by the number of bytes read. Throws an error if there are not enough
|
|
69
|
+
* bytes left in the buffer to satisfy the requested number of bytes.
|
|
70
|
+
*
|
|
71
|
+
* @param n - The number of bytes to read from the buffer.
|
|
72
|
+
* @returns A new Buffer containing the read bytes.
|
|
73
|
+
*/
|
|
74
|
+
readBytes(n) {
|
|
75
|
+
this.index += n;
|
|
76
|
+
return Buffer.from(this.buffer.subarray(this.index - n, this.index));
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Reads a Fr (finite field) element from the buffer using the 'fromBuffer' method of the Fr class.
|
|
80
|
+
* The Fr class should provide a 'fromBuffer' method that takes a BufferReader instance as input.
|
|
81
|
+
*
|
|
82
|
+
* @returns An instance of the Fr class representing the finite field element.
|
|
83
|
+
*/
|
|
84
|
+
readFr() {
|
|
85
|
+
return Fr.fromBuffer(this);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Reads the next Fq element from the buffer using the Fq.fromBuffer method.
|
|
89
|
+
* The Fq element represents a finite field in elliptic curve cryptography and is used for calculations.
|
|
90
|
+
* Advances the internal buffer index by the number of bytes read.
|
|
91
|
+
*
|
|
92
|
+
* @returns An Fq instance representing the finite field element.
|
|
93
|
+
*/
|
|
94
|
+
readFq() {
|
|
95
|
+
return Fq.fromBuffer(this);
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Reads a vector of numbers from the buffer and returns it as an array of numbers.
|
|
99
|
+
* The method utilizes the 'readVector' method, passing a deserializer that reads numbers.
|
|
100
|
+
*
|
|
101
|
+
* @returns An array of numbers representing the vector read from the buffer.
|
|
102
|
+
*/
|
|
103
|
+
readNumberVector() {
|
|
104
|
+
return this.readVector({
|
|
105
|
+
fromBuffer: (reader) => reader.readNumber(),
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Reads a vector of fixed size from the buffer and deserializes its elements using the provided itemDeserializer object.
|
|
110
|
+
* The 'itemDeserializer' object should have a 'fromBuffer' method that takes a BufferReader instance and returns the deserialized element.
|
|
111
|
+
* The method first reads the size of the vector (a number) from the buffer, then iterates through its elements,
|
|
112
|
+
* deserializing each one using the 'fromBuffer' method of 'itemDeserializer'.
|
|
113
|
+
*
|
|
114
|
+
* @param itemDeserializer - Object with 'fromBuffer' method to deserialize vector elements.
|
|
115
|
+
* @returns An array of deserialized elements of type T.
|
|
116
|
+
*/
|
|
117
|
+
readVector(itemDeserializer) {
|
|
118
|
+
const size = this.readNumber();
|
|
119
|
+
const result = new Array(size);
|
|
120
|
+
for (let i = 0; i < size; i++) {
|
|
121
|
+
result[i] = itemDeserializer.fromBuffer(this);
|
|
122
|
+
}
|
|
123
|
+
return result;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Read an array of a fixed size with elements of type T from the buffer.
|
|
127
|
+
* The 'itemDeserializer' object should have a 'fromBuffer' method that takes a BufferReader instance as input,
|
|
128
|
+
* and returns an instance of the desired deserialized data type T.
|
|
129
|
+
* This method will call the 'fromBuffer' method for each element in the array and return the resulting array.
|
|
130
|
+
*
|
|
131
|
+
* @param size - The fixed number of elements in the array.
|
|
132
|
+
* @param itemDeserializer - An object with a 'fromBuffer' method to deserialize individual elements of type T.
|
|
133
|
+
* @returns An array of instances of type T.
|
|
134
|
+
*/
|
|
135
|
+
readArray(size, itemDeserializer) {
|
|
136
|
+
const result = Array.from({ length: size }, () => itemDeserializer.fromBuffer(this));
|
|
137
|
+
return result;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Read a variable sized Buffer array where elements are represented by length + data.
|
|
141
|
+
* The method consecutively looks for a number which is the size of the proceeding buffer,
|
|
142
|
+
* then reads the bytes until it reaches the end of the reader's internal buffer.
|
|
143
|
+
* NOTE: if `size` is not provided, this will run to the end of the reader's buffer.
|
|
144
|
+
* @param size - Size of the buffer array in bytes (full remaining buffer length if left empty).
|
|
145
|
+
* @returns An array of variable sized buffers.
|
|
146
|
+
*/
|
|
147
|
+
readBufferArray(size = -1) {
|
|
148
|
+
const result = [];
|
|
149
|
+
const end = size >= 0 ? this.index + size : this.buffer.length;
|
|
150
|
+
while (this.index < end) {
|
|
151
|
+
const item = this.readBuffer();
|
|
152
|
+
result.push(item);
|
|
153
|
+
}
|
|
154
|
+
// Ensure that all bytes have been read.
|
|
155
|
+
if (this.index !== end) {
|
|
156
|
+
throw new Error(`Reader buffer was not fully consumed. Consumed up to ${this.index} bytes. End of data: ${end} bytes.`);
|
|
157
|
+
}
|
|
158
|
+
return result;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Reads a serialized object from a buffer and returns the deserialized object using the given deserializer.
|
|
162
|
+
*
|
|
163
|
+
* @typeparam T - The type of the deserialized object.
|
|
164
|
+
* @param deserializer - An object with a 'fromBuffer' method that takes a BufferReader instance and returns an instance of the deserialized object.
|
|
165
|
+
* @returns The deserialized object of type T.
|
|
166
|
+
*/
|
|
167
|
+
readObject(deserializer) {
|
|
168
|
+
return deserializer.fromBuffer(this);
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Returns a Buffer containing the next n bytes from the current buffer without modifying the reader's index position.
|
|
172
|
+
* If n is not provided or exceeds the remaining length of the buffer, it returns all bytes from the current position till the end of the buffer.
|
|
173
|
+
*
|
|
174
|
+
* @param n - The number of bytes to peek from the current buffer. (Optional).
|
|
175
|
+
* @returns A Buffer with the next n bytes or the remaining bytes if n is not provided or exceeds the buffer length.
|
|
176
|
+
*/
|
|
177
|
+
peekBytes(n) {
|
|
178
|
+
return this.buffer.subarray(this.index, n ? this.index + n : undefined);
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Reads a string from the buffer and returns it.
|
|
182
|
+
* The method first reads the size of the string, then reads the corresponding
|
|
183
|
+
* number of bytes from the buffer and converts them to a string.
|
|
184
|
+
*
|
|
185
|
+
* @returns The read string from the buffer.
|
|
186
|
+
*/
|
|
187
|
+
readString() {
|
|
188
|
+
return this.readBuffer().toString();
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Reads a buffer from the current position of the reader and advances the index.
|
|
192
|
+
* The method first reads the size (number) of bytes to be read, and then returns
|
|
193
|
+
* a Buffer with that size containing the bytes. Useful for reading variable-length
|
|
194
|
+
* binary data encoded as (size, data) format.
|
|
195
|
+
*
|
|
196
|
+
* @returns A Buffer containing the read bytes.
|
|
197
|
+
*/
|
|
198
|
+
readBuffer() {
|
|
199
|
+
const size = this.readNumber();
|
|
200
|
+
return this.readBytes(size);
|
|
201
|
+
}
|
|
202
|
+
/**
|
|
203
|
+
* Reads and constructs a map object from the current buffer using the provided deserializer.
|
|
204
|
+
* The method reads the number of entries in the map, followed by iterating through each key-value pair.
|
|
205
|
+
* The key is read as a string, while the value is obtained using the passed deserializer's `fromBuffer` method.
|
|
206
|
+
* The resulting map object is returned, containing all the key-value pairs read from the buffer.
|
|
207
|
+
*
|
|
208
|
+
* @param deserializer - An object with a `fromBuffer` method to deserialize the values in the map.
|
|
209
|
+
* @returns A map object with string keys and deserialized values based on the provided deserializer.
|
|
210
|
+
*/
|
|
211
|
+
readMap(deserializer) {
|
|
212
|
+
const numEntries = this.readNumber();
|
|
213
|
+
const map = {};
|
|
214
|
+
for (let i = 0; i < numEntries; i++) {
|
|
215
|
+
const key = this.readString();
|
|
216
|
+
const value = this.readObject(deserializer);
|
|
217
|
+
map[key] = value;
|
|
218
|
+
}
|
|
219
|
+
return map;
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Get the length of the reader's buffer.
|
|
223
|
+
* @returns The length of the underlying reader's buffer.
|
|
224
|
+
*/
|
|
225
|
+
getLength() {
|
|
226
|
+
return this.buffer.length;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVmZmVyX3JlYWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJpYWxpemUvYnVmZmVyX3JlYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRzdDOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBTSxPQUFPLFlBQVk7SUFFdkIsWUFBb0IsTUFBYyxFQUFFLE1BQU0sR0FBRyxDQUFDO1FBQTFCLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUM7SUFDdEIsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSSxNQUFNLENBQUMsUUFBUSxDQUFDLGNBQXFDO1FBQzFELE9BQU8sTUFBTSxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxZQUFZLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQztJQUM3RixDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxVQUFVO1FBQ2YsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUM7UUFDaEIsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ2xELENBQUM7SUFFRDs7Ozs7T0FLRztJQUNJLFVBQVU7UUFDZixJQUFJLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQztRQUNoQixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNJLFdBQVc7UUFDaEIsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUM7UUFDaEIsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFF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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buffer_reader.test.d.ts","sourceRoot":"","sources":["../../src/serialize/buffer_reader.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import { jest } from '@jest/globals';
|
|
2
|
+
import { randomBytes } from '../crypto/index.js';
|
|
3
|
+
import { Fq, Fr } from '../fields/fields.js';
|
|
4
|
+
import { BufferReader } from './buffer_reader.js';
|
|
5
|
+
import { serializeBufferArrayToVector } from './free_funcs.js';
|
|
6
|
+
const ARRAY = Array.from(Array(32)).map((_, idx) => (idx % 2 === 0 ? 0 : 1));
|
|
7
|
+
const BUFFER = Buffer.from(ARRAY);
|
|
8
|
+
const NUMBER = 65537;
|
|
9
|
+
const sizes = [16, 48, 32];
|
|
10
|
+
describe('buffer reader', () => {
|
|
11
|
+
let bufferReader;
|
|
12
|
+
beforeEach(() => {
|
|
13
|
+
bufferReader = new BufferReader(BUFFER);
|
|
14
|
+
});
|
|
15
|
+
describe('readNumber', () => {
|
|
16
|
+
it('should return number', () => {
|
|
17
|
+
expect(bufferReader.readNumber()).toBe(NUMBER);
|
|
18
|
+
});
|
|
19
|
+
});
|
|
20
|
+
describe('readBoolean', () => {
|
|
21
|
+
it('should read true when 1 and false when 0', () => {
|
|
22
|
+
ARRAY.forEach(element => {
|
|
23
|
+
if (element !== 0) {
|
|
24
|
+
expect(bufferReader.readBoolean()).toBe(true);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
expect(bufferReader.readBoolean()).toBe(false);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
describe('readBytes', () => {
|
|
33
|
+
it('should read buffer by slices', () => {
|
|
34
|
+
expect(bufferReader.readBytes(2)).toEqual(Buffer.from(ARRAY.slice(0, 2)));
|
|
35
|
+
expect(bufferReader.readBytes(3)).toEqual(Buffer.from(ARRAY.slice(2, 5)));
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
describe('readFr', () => {
|
|
39
|
+
it('should get Fr from buffer', () => {
|
|
40
|
+
expect(bufferReader.readFr()).toEqual(Fr.fromBuffer(BUFFER));
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
describe('readFq', () => {
|
|
44
|
+
it('should get Fq from buffer', () => {
|
|
45
|
+
expect(bufferReader.readFq()).toEqual(Fq.fromBuffer(BUFFER));
|
|
46
|
+
});
|
|
47
|
+
});
|
|
48
|
+
describe('readNumberVector', () => {
|
|
49
|
+
let vectorBufferReader;
|
|
50
|
+
beforeEach(() => {
|
|
51
|
+
const uintArr = [7, 13, 16];
|
|
52
|
+
const uintBufArr = uintArr.map(num => {
|
|
53
|
+
const uintBuf = Buffer.alloc(4);
|
|
54
|
+
uintBuf.writeUInt32BE(num, 0);
|
|
55
|
+
return uintBuf;
|
|
56
|
+
});
|
|
57
|
+
const uintArrVec = serializeBufferArrayToVector(uintBufArr);
|
|
58
|
+
vectorBufferReader = new BufferReader(uintArrVec);
|
|
59
|
+
});
|
|
60
|
+
it('should read number vector', () => {
|
|
61
|
+
expect(vectorBufferReader.readNumberVector()).toEqual([7, 13, 16]);
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
describe('readVector', () => {
|
|
65
|
+
it('should read vector and generate result array', () => {
|
|
66
|
+
const fn = jest.fn();
|
|
67
|
+
let i = -1;
|
|
68
|
+
const result = bufferReader.readVector({
|
|
69
|
+
fromBuffer: () => {
|
|
70
|
+
fn();
|
|
71
|
+
i++;
|
|
72
|
+
return i;
|
|
73
|
+
},
|
|
74
|
+
});
|
|
75
|
+
expect(result.length).toBe(NUMBER);
|
|
76
|
+
expect(result).toEqual(Array.from(Array(NUMBER).keys()));
|
|
77
|
+
expect(fn).toHaveBeenCalledTimes(NUMBER);
|
|
78
|
+
});
|
|
79
|
+
});
|
|
80
|
+
describe('readArray', () => {
|
|
81
|
+
it('should read array from buffer', () => {
|
|
82
|
+
const fn = jest.fn();
|
|
83
|
+
let i = -1;
|
|
84
|
+
expect(bufferReader.readArray(10, {
|
|
85
|
+
fromBuffer: () => {
|
|
86
|
+
fn();
|
|
87
|
+
i++;
|
|
88
|
+
return i;
|
|
89
|
+
},
|
|
90
|
+
})).toEqual([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
describe('readBufferArray', () => {
|
|
94
|
+
it('should read variable length array from buffer', () => {
|
|
95
|
+
// Testing `readBufferArray` with a buffer that ONLY contains the data that will be read.
|
|
96
|
+
// No `size` variable is passed in this case.
|
|
97
|
+
const bufferArray = [];
|
|
98
|
+
let buf = Buffer.alloc(0);
|
|
99
|
+
for (const size of sizes) {
|
|
100
|
+
const sizeBuf = Buffer.alloc(4);
|
|
101
|
+
sizeBuf.writeUInt32BE(size);
|
|
102
|
+
const bytes = randomBytes(size);
|
|
103
|
+
const ranBuf = Buffer.concat([sizeBuf, bytes]);
|
|
104
|
+
bufferArray.push(bytes);
|
|
105
|
+
buf = Buffer.concat([buf, ranBuf]);
|
|
106
|
+
}
|
|
107
|
+
const reader = BufferReader.asReader(buf);
|
|
108
|
+
const res = reader.readBufferArray();
|
|
109
|
+
expect(res).toEqual(bufferArray);
|
|
110
|
+
});
|
|
111
|
+
it('should read variable length array from buffer with other contents', () => {
|
|
112
|
+
// testing `readBufferArray` with a buffer that includes some other data before and after the data that will be read.
|
|
113
|
+
// The `size` variable needs to be passed in this case.
|
|
114
|
+
const bufferArray = [];
|
|
115
|
+
const prefixBytes = randomBytes(32);
|
|
116
|
+
const postfixBytes = randomBytes(16);
|
|
117
|
+
let bufLen = 0;
|
|
118
|
+
let buf = Buffer.alloc(32, prefixBytes);
|
|
119
|
+
for (const size of sizes) {
|
|
120
|
+
const sizeBuf = Buffer.alloc(4);
|
|
121
|
+
sizeBuf.writeUInt32BE(size);
|
|
122
|
+
const bytes = randomBytes(size);
|
|
123
|
+
const ranBuf = Buffer.concat([sizeBuf, bytes]);
|
|
124
|
+
buf = Buffer.concat([buf, ranBuf]);
|
|
125
|
+
bufferArray.push(bytes);
|
|
126
|
+
bufLen += ranBuf.length;
|
|
127
|
+
}
|
|
128
|
+
buf = Buffer.concat([buf, postfixBytes]);
|
|
129
|
+
const reader = BufferReader.asReader(buf);
|
|
130
|
+
const preRes = reader.readBytes(prefixBytes.length);
|
|
131
|
+
expect(preRes).toEqual(prefixBytes);
|
|
132
|
+
expect(reader.readBufferArray(bufLen)).toEqual(bufferArray);
|
|
133
|
+
expect(reader.readBytes(postfixBytes.length)).toEqual(postfixBytes);
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
describe('readObject', () => {
|
|
137
|
+
it('should read object from buffer', () => {
|
|
138
|
+
const fn = jest.fn();
|
|
139
|
+
const object = bufferReader.readObject({
|
|
140
|
+
fromBuffer: (reader) => {
|
|
141
|
+
fn();
|
|
142
|
+
return { value: 'test-string', buffer: reader };
|
|
143
|
+
},
|
|
144
|
+
});
|
|
145
|
+
expect(object.value).toEqual('test-string');
|
|
146
|
+
expect(object.buffer).toEqual(bufferReader);
|
|
147
|
+
expect(fn).toHaveBeenCalledTimes(1);
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
describe('peekBytes', () => {
|
|
151
|
+
it('should return bytes from buffer', () => {
|
|
152
|
+
expect(bufferReader.peekBytes(10)).toEqual(Buffer.from(ARRAY.slice(0, 10)));
|
|
153
|
+
});
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVmZmVyX3JlYWRlci50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcmlhbGl6ZS9idWZmZXJfcmVhZGVyLnRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVyQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDakQsT0FBTyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbEQsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0QsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDN0UsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUNsQyxNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUM7QUFDckIsTUFBTSxLQUFLLEdBQUcsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBRTNCLFFBQVEsQ0FBQyxlQUFlLEVBQUUsR0FBRyxFQUFFO0lBQzdCLElBQUksWUFBMEIsQ0FBQztJQUUvQixVQUFVLENBQUMsR0FBRyxFQUFFO1FBQ2QsWUFBWSxHQUFHLElBQUksWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzFDLENBQUMsQ0FBQyxDQUFDO0lBRUgsUUFBUSxDQUFDLFlBQVksRUFBRSxHQUFHLEVBQUU7UUFD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
|