Airnode ABI

This library allows to encode and decode different types of data during interaction between API3 Airnode and Ethereum smart contracts

See details of protocol are at Airnode Specification

Parameters from contract event logs are consumed as Vec<U256>, which avoids reading random raw bytes and provides guarantee of a proper data alignment on input.

Second parameter of decoding is strict flag, which defines whether decoding could be done into extended types (String32,Bool,Date) that are actually represented as Bytes32 on a protocol level.

decoding example

``` use airnodeabi::ABI; use ethereumtypes::U256; use hex_literal::hex;

fn main() { let data: Vec = vec![ hex!("3162000000000000000000000000000000000000000000000000000000000000").into(), hex!("54657374427974657333324e616d650000000000000000000000000000000000").into(), hex!("536f6d6520627974657333322076616c75650000000000000000000000000000").into(), ]; let res: ABI = ABI::decode(&data, true).unwrap(); println!("{:#?}", res); } ```

encoding example

``` use airnodeabi::{ABI, Param}; use ethereumtypes::U256;

fn main() { let param = Param::String { name: "hello".toowned(), value: "world".toowned(), }; let res: Vec = ABI::new(vec![param]).encode().unwrap(); println!("{:#?}", res); } ``` Please see more examples for each type of the parameter in unit tests.

License

MIT