Complex Data Retrieval
In this example we illustrate how to pass complex structures for on-chain usage with non-trivial schema. Suppose the on-chain handler requires five bids and asks from Binance for the symbol BTCUSDT
together with the value of lastUpdateId
for extra on-chain checks. Suppose the corresponding Solidity structures are
Binance returns prices and quantities as string-encoded fixed-point numbers. So assume also that multiplication by 108 is required prior to typecasting to uint256
to prevent precision loss.
In this case, the schema of the desired result is (uint256,(uint256,uint256)[5],(uint256,uint256)[5])
. The structures are ABI-encoded as tuples. The JSON resulting from the filter, therefore, must be a mixed-type array of length 3 (outer tuple type, three fields in OrderBook
structure) with first element being a number, second and third elements being arrays of length 5 ((uint256,uint256)[5]
). Every element of the second and the third entry is, in turn, two element array (pair of unsigned integers corresponding to the structure Order
).
The example of Binance API response is
We start building the filter step by step.
To cast a number from string to desired format,
tonumber*100000000 | floor
can be used.Now, the filter
.bids[0] | map(tonumber*100000000 | floor)
would yield the first bid converted to the right formatTo convert all the bids to the necessary format, apply this map as nested:
.bids | map(map(tonumber*100000000 | floor))
To reuse this filter for asks, process bids and asks as an array:
[.bids, .asks] | map(map(map(tonumber*100000000 | floor)))
. Now we have two arrays adhering to the encoding.Finally, prepend it with the value of
lastUpdateId
:[.lastUpdateId] + ([.bids, .asks] | map(map(map(tonumber*100000000|floor))))
The request to the oracle is therefore
The certified response will be returned in the following format:
Here the value
is ABI-encoded resulting structure. The on-chain handler can now use Solidity ABI to decode the data and seamlessly use the struct:
Last updated