8365f4d80e
* updated ethabi to version 4.0 * ethabi 4.0.1
357 lines
31 KiB
Rust
357 lines
31 KiB
Rust
// Autogenerated from JSON contract definition using Rust contract convertor.
|
|
|
|
use std::string::String;
|
|
use std::result::Result;
|
|
use std::fmt;
|
|
use ethabi;
|
|
use util;
|
|
use bigint;
|
|
|
|
pub struct Operations {
|
|
contract: ethabi::Contract,
|
|
address: util::Address,
|
|
do_call: Box<Fn(util::Address, Vec<u8>) -> Result<Vec<u8>, String> + Send + Sync + 'static>,
|
|
}
|
|
impl Operations {
|
|
pub fn new<F>(address: util::Address, do_call: F) -> Self where F: Fn(util::Address, Vec<u8>) -> Result<Vec<u8>, String> + Send + Sync + 'static {
|
|
Operations {
|
|
contract: ethabi::Contract::load(b"[{\"constant\":false,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_newOwner\",\"type\":\"address\"}],\"name\":\"resetClientOwner\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_release\",\"type\":\"bytes32\"}],\"name\":\"isLatest\",\"outputs\":[{\"name\":\"\",\"type\":\"bool\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_txid\",\"type\":\"bytes32\"}],\"name\":\"rejectTransaction\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_newOwner\",\"type\":\"address\"}],\"name\":\"setOwner\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_number\",\"type\":\"uint32\"},{\"name\":\"_name\",\"type\":\"bytes32\"},{\"name\":\"_hard\",\"type\":\"bool\"},{\"name\":\"_spec\",\"type\":\"bytes32\"}],\"name\":\"proposeFork\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"}],\"name\":\"removeClient\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_release\",\"type\":\"bytes32\"}],\"name\":\"release\",\"outputs\":[{\"name\":\"o_forkBlock\",\"type\":\"uint32\"},{\"name\":\"o_track\",\"type\":\"uint8\"},{\"name\":\"o_semver\",\"type\":\"uint24\"},{\"name\":\"o_critical\",\"type\":\"bool\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_checksum\",\"type\":\"bytes32\"}],\"name\":\"build\",\"outputs\":[{\"name\":\"o_release\",\"type\":\"bytes32\"},{\"name\":\"o_platform\",\"type\":\"bytes32\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[],\"name\":\"rejectFork\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"bytes32\"}],\"name\":\"client\",\"outputs\":[{\"name\":\"owner\",\"type\":\"address\"},{\"name\":\"required\",\"type\":\"bool\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_newOwner\",\"type\":\"address\"}],\"name\":\"setClientOwner\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"uint32\"}],\"name\":\"fork\",\"outputs\":[{\"name\":\"name\",\"type\":\"bytes32\"},{\"name\":\"spec\",\"type\":\"bytes32\"},{\"name\":\"hard\",\"type\":\"bool\"},{\"name\":\"ratified\",\"type\":\"bool\"},{\"name\":\"requiredCount\",\"type\":\"uint256\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_release\",\"type\":\"bytes32\"},{\"name\":\"_platform\",\"type\":\"bytes32\"},{\"name\":\"_checksum\",\"type\":\"bytes32\"}],\"name\":\"addChecksum\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_txid\",\"type\":\"bytes32\"}],\"name\":\"confirmTransaction\",\"outputs\":[{\"name\":\"txSuccess\",\"type\":\"uint256\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"bytes32\"}],\"name\":\"proxy\",\"outputs\":[{\"name\":\"requiredCount\",\"type\":\"uint256\"},{\"name\":\"to\",\"type\":\"address\"},{\"name\":\"data\",\"type\":\"bytes\"},{\"name\":\"value\",\"type\":\"uint256\"},{\"name\":\"gas\",\"type\":\"uint256\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_owner\",\"type\":\"address\"}],\"name\":\"addClient\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"}],\"name\":\"clientOwner\",\"outputs\":[{\"name\":\"\",\"type\":\"bytes32\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_txid\",\"type\":\"bytes32\"},{\"name\":\"_to\",\"type\":\"address\"},{\"name\":\"_data\",\"type\":\"bytes\"},{\"name\":\"_value\",\"type\":\"uint256\"},{\"name\":\"_gas\",\"type\":\"uint256\"}],\"name\":\"proposeTransaction\",\"outputs\":[{\"name\":\"txSuccess\",\"type\":\"uint256\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"grandOwner\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_release\",\"type\":\"bytes32\"},{\"name\":\"_forkBlock\",\"type\":\"uint32\"},{\"name\":\"_track\",\"type\":\"uint8\"},{\"name\":\"_semver\",\"type\":\"uint24\"},{\"name\":\"_critical\",\"type\":\"bool\"}],\"name\":\"addRelease\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[],\"name\":\"acceptFork\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"clientsRequired\",\"outputs\":[{\"name\":\"\",\"type\":\"uint32\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_release\",\"type\":\"bytes32\"}],\"name\":\"track\",\"outputs\":[{\"name\":\"\",\"type\":\"uint8\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_r\",\"type\":\"bool\"}],\"name\":\"setClientRequired\",\"outputs\":[],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"latestFork\",\"outputs\":[{\"name\":\"\",\"type\":\"uint32\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_track\",\"type\":\"uint8\"}],\"name\":\"latestInTrack\",\"outputs\":[{\"name\":\"\",\"type\":\"bytes32\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_client\",\"type\":\"bytes32\"},{\"name\":\"_release\",\"type\":\"bytes32\"},{\"name\":\"_platform\",\"type\":\"bytes32\"}],\"name\":\"checksum\",\"outputs\":[{\"name\":\"\",\"type\":\"bytes32\"}],\"payable\":false,\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"proposedFork\",\"outputs\":[{\"name\":\"\",\"type\":\"uint32\"}],\"payable\":false,\"type\":\"function\"}]" as &[u8]).expect("JSON is autogenerated; qed"),
|
|
address: address,
|
|
do_call: Box::new(do_call),
|
|
}
|
|
}
|
|
fn as_string<T: fmt::Debug>(e: T) -> String { format!("{:?}", e) }
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_newOwner","type":"address"}],"name":"resetClientOwner","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn reset_client_owner(&self, _client: &str, _new_owner: &util::Address) -> Result<(), String> {
|
|
let call = self.contract.function("resetClientOwner".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::Address(_new_owner.clone().0)]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_release","type":"bytes32"}],"name":"isLatest","outputs":[{"name":"","type":"bool"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn is_latest(&self, _client: &str, _release: &bigint::hash::H256) -> Result<bool, String> {
|
|
let call = self.contract.function("isLatest".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::FixedBytes(_release.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_bool().ok_or("Invalid type returned")?; r }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_txid","type":"bytes32"}],"name":"rejectTransaction","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn reject_transaction(&self, _txid: &bigint::hash::H256) -> Result<(), String> {
|
|
let call = self.contract.function("rejectTransaction".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_txid.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_newOwner","type":"address"}],"name":"setOwner","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn set_owner(&self, _new_owner: &util::Address) -> Result<(), String> {
|
|
let call = self.contract.function("setOwner".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::Address(_new_owner.clone().0)]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_number","type":"uint32"},{"name":"_name","type":"bytes32"},{"name":"_hard","type":"bool"},{"name":"_spec","type":"bytes32"}],"name":"proposeFork","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn propose_fork(&self, _number: u32, _name: &bigint::hash::H256, _hard: bool, _spec: &bigint::hash::H256) -> Result<(), String> {
|
|
let call = self.contract.function("proposeFork".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::Uint({ let mut r = [0u8; 32]; bigint::prelude::U256::from(_number as u64).to_big_endian(&mut r); r }), ethabi::Token::FixedBytes(_name.as_ref().to_owned()), ethabi::Token::Bool(_hard), ethabi::Token::FixedBytes(_spec.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_client","type":"bytes32"}],"name":"removeClient","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn remove_client(&self, _client: &str) -> Result<(), String> {
|
|
let call = self.contract.function("removeClient".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_release","type":"bytes32"}],"name":"release","outputs":[{"name":"o_forkBlock","type":"uint32"},{"name":"o_track","type":"uint8"},{"name":"o_semver","type":"uint24"},{"name":"o_critical","type":"bool"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn release(&self, _client: &str, _release: &bigint::hash::H256) -> Result<(u32, u8, u32, bool), String> {
|
|
let call = self.contract.function("release".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::FixedBytes(_release.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u32 }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u8 }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u32 }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_bool().ok_or("Invalid type returned")?; r }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_checksum","type":"bytes32"}],"name":"build","outputs":[{"name":"o_release","type":"bytes32"},{"name":"o_platform","type":"bytes32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn build(&self, _client: &str, _checksum: &bigint::hash::H256) -> Result<(bigint::hash::H256, bigint::hash::H256), String> {
|
|
let call = self.contract.function("build".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::FixedBytes(_checksum.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[],"name":"rejectFork","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn reject_fork(&self) -> Result<(), String> {
|
|
let call = self.contract.function("rejectFork".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"","type":"bytes32"}],"name":"client","outputs":[{"name":"owner","type":"address"},{"name":"required","type":"bool"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn client(&self, _1: &bigint::hash::H256) -> Result<(util::Address, bool), String> {
|
|
let call = self.contract.function("client".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_1.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_address().ok_or("Invalid type returned")?; util::Address::from(r) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_bool().ok_or("Invalid type returned")?; r }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_newOwner","type":"address"}],"name":"setClientOwner","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn set_client_owner(&self, _new_owner: &util::Address) -> Result<(), String> {
|
|
let call = self.contract.function("setClientOwner".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::Address(_new_owner.clone().0)]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"","type":"uint32"}],"name":"fork","outputs":[{"name":"name","type":"bytes32"},{"name":"spec","type":"bytes32"},{"name":"hard","type":"bool"},{"name":"ratified","type":"bool"},{"name":"requiredCount","type":"uint256"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn fork(&self, _1: u32) -> Result<(bigint::hash::H256, bigint::hash::H256, bool, bool, bigint::prelude::U256), String> {
|
|
let call = self.contract.function("fork".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::Uint({ let mut r = [0u8; 32]; bigint::prelude::U256::from(_1 as u64).to_big_endian(&mut r); r })]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_bool().ok_or("Invalid type returned")?; r }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_bool().ok_or("Invalid type returned")?; r }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_release","type":"bytes32"},{"name":"_platform","type":"bytes32"},{"name":"_checksum","type":"bytes32"}],"name":"addChecksum","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn add_checksum(&self, _release: &bigint::hash::H256, _platform: &str, _checksum: &bigint::hash::H256) -> Result<(), String> {
|
|
let call = self.contract.function("addChecksum".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_release.as_ref().to_owned()), ethabi::Token::FixedBytes(_platform.as_bytes().to_owned()), ethabi::Token::FixedBytes(_checksum.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_txid","type":"bytes32"}],"name":"confirmTransaction","outputs":[{"name":"txSuccess","type":"uint256"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn confirm_transaction(&self, _txid: &bigint::hash::H256) -> Result<bigint::prelude::U256, String> {
|
|
let call = self.contract.function("confirmTransaction".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_txid.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"","type":"bytes32"}],"name":"proxy","outputs":[{"name":"requiredCount","type":"uint256"},{"name":"to","type":"address"},{"name":"data","type":"bytes"},{"name":"value","type":"uint256"},{"name":"gas","type":"uint256"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn proxy(&self, _1: &bigint::hash::H256) -> Result<(bigint::prelude::U256, util::Address, Vec<u8>, bigint::prelude::U256, bigint::prelude::U256), String> {
|
|
let call = self.contract.function("proxy".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_1.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_address().ok_or("Invalid type returned")?; util::Address::from(r) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_bytes().ok_or("Invalid type returned")?; r }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()) }, { let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_owner","type":"address"}],"name":"addClient","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn add_client(&self, _client: &str, _owner: &util::Address) -> Result<(), String> {
|
|
let call = self.contract.function("addClient".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::Address(_owner.clone().0)]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"","type":"address"}],"name":"clientOwner","outputs":[{"name":"","type":"bytes32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn client_owner(&self, _1: &util::Address) -> Result<bigint::hash::H256, String> {
|
|
let call = self.contract.function("clientOwner".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::Address(_1.clone().0)]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_txid","type":"bytes32"},{"name":"_to","type":"address"},{"name":"_data","type":"bytes"},{"name":"_value","type":"uint256"},{"name":"_gas","type":"uint256"}],"name":"proposeTransaction","outputs":[{"name":"txSuccess","type":"uint256"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn propose_transaction(&self, _txid: &bigint::hash::H256, _to: &util::Address, _data: &[u8], _value: bigint::prelude::U256, _gas: bigint::prelude::U256) -> Result<bigint::prelude::U256, String> {
|
|
let call = self.contract.function("proposeTransaction".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_txid.as_ref().to_owned()), ethabi::Token::Address(_to.clone().0), ethabi::Token::Bytes(_data.to_owned()), ethabi::Token::Uint({ let mut r = [0u8; 32]; _value.to_big_endian(&mut r); r }), ethabi::Token::Uint({ let mut r = [0u8; 32]; _gas.to_big_endian(&mut r); r })]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[],"name":"grandOwner","outputs":[{"name":"","type":"address"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn grand_owner(&self) -> Result<util::Address, String> {
|
|
let call = self.contract.function("grandOwner".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_address().ok_or("Invalid type returned")?; util::Address::from(r) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_release","type":"bytes32"},{"name":"_forkBlock","type":"uint32"},{"name":"_track","type":"uint8"},{"name":"_semver","type":"uint24"},{"name":"_critical","type":"bool"}],"name":"addRelease","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn add_release(&self, _release: &bigint::hash::H256, _fork_block: u32, _track: u8, _semver: u32, _critical: bool) -> Result<(), String> {
|
|
let call = self.contract.function("addRelease".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_release.as_ref().to_owned()), ethabi::Token::Uint({ let mut r = [0u8; 32]; bigint::prelude::U256::from(_fork_block as u64).to_big_endian(&mut r); r }), ethabi::Token::Uint({ let mut r = [0u8; 32]; bigint::prelude::U256::from(_track as u64).to_big_endian(&mut r); r }), ethabi::Token::Uint({ let mut r = [0u8; 32]; bigint::prelude::U256::from(_semver as u64).to_big_endian(&mut r); r }), ethabi::Token::Bool(_critical)]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[],"name":"acceptFork","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn accept_fork(&self) -> Result<(), String> {
|
|
let call = self.contract.function("acceptFork".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[],"name":"clientsRequired","outputs":[{"name":"","type":"uint32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn clients_required(&self) -> Result<u32, String> {
|
|
let call = self.contract.function("clientsRequired".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u32 }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_release","type":"bytes32"}],"name":"track","outputs":[{"name":"","type":"uint8"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn track(&self, _client: &str, _release: &bigint::hash::H256) -> Result<u8, String> {
|
|
let call = self.contract.function("track".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::FixedBytes(_release.as_ref().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u8 }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":false,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_r","type":"bool"}],"name":"setClientRequired","outputs":[],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn set_client_required(&self, _client: &str, _r: bool) -> Result<(), String> {
|
|
let call = self.contract.function("setClientRequired".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::Bool(_r)]
|
|
).map_err(Self::as_string)?;
|
|
call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[],"name":"latestFork","outputs":[{"name":"","type":"uint32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn latest_fork(&self) -> Result<u32, String> {
|
|
let call = self.contract.function("latestFork".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&[]).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u32 }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_track","type":"uint8"}],"name":"latestInTrack","outputs":[{"name":"","type":"bytes32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn latest_in_track(&self, _client: &str, _track: u8) -> Result<bigint::hash::H256, String> {
|
|
let call = self.contract.function("latestInTrack".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
&vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::Uint({ let mut r = [0u8; 32]; bigint::prelude::U256::from(_track as u64).to_big_endian(&mut r); r })]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[{"name":"_client","type":"bytes32"},{"name":"_release","type":"bytes32"},{"name":"_platform","type":"bytes32"}],"name":"checksum","outputs":[{"name":"","type":"bytes32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn checksum(&self, _client: &str, _release: &bigint::hash::H256, _platform: &str) -> Result<bigint::hash::H256, String> {
|
|
let call = self.contract.function("checksum".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&
|
|
vec![ethabi::Token::FixedBytes(_client.as_bytes().to_owned()), ethabi::Token::FixedBytes(_release.as_ref().to_owned()), ethabi::Token::FixedBytes(_platform.as_bytes().to_owned())]
|
|
).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_fixed_bytes().ok_or("Invalid type returned")?; bigint::hash::H256::from_slice(r.as_ref()) }))
|
|
}
|
|
|
|
/// Auto-generated from: `{"constant":true,"inputs":[],"name":"proposedFork","outputs":[{"name":"","type":"uint32"}],"payable":false,"type":"function"}`
|
|
#[allow(dead_code)]
|
|
pub fn proposed_fork(&self) -> Result<u32, String> {
|
|
let call = self.contract.function("proposedFork".into()).map_err(Self::as_string)?;
|
|
let data = call.encode_input(&[]).map_err(Self::as_string)?;
|
|
let output = call.decode_output(&(self.do_call)(self.address.clone(), data)?).map_err(Self::as_string)?;
|
|
let mut result = output.into_iter().rev().collect::<Vec<_>>();
|
|
Ok(({ let r = result.pop().ok_or("Invalid return arity")?; let r = r.to_uint().ok_or("Invalid type returned")?; bigint::prelude::U256::from(r.as_ref()).as_u64() as u32 }))
|
|
}
|
|
}
|