use ethereum_types::{U256, H256, Address};
use bytes::Bytes;
use hash::{keccak, KECCAK_EMPTY};
use ethjson;
use action_type::ActionType;
use std::sync::Arc;
#[derive(Clone, Debug)]
pub enum ActionValue {
Transfer(U256),
Apparent(U256)
}
#[derive(Clone, Debug)]
pub enum ParamsType {
Embedded,
Separate,
}
impl ActionValue {
pub fn value(&self) -> U256 {
match *self {
ActionValue::Transfer(x) | ActionValue::Apparent(x) => x
}
}
pub fn transfer<T: Into<U256>>(transfer_value: T) -> ActionValue {
ActionValue::Transfer(transfer_value.into())
}
pub fn apparent<T: Into<U256>>(apparent_value: T) -> ActionValue {
ActionValue::Apparent(apparent_value.into())
}
}
#[derive(Clone, Debug)]
pub struct ActionParams {
pub code_address: Address,
pub code_hash: Option<H256>,
pub address: Address,
pub sender: Address,
pub origin: Address,
pub gas: U256,
pub gas_price: U256,
pub value: ActionValue,
pub code: Option<Arc<Bytes>>,
pub code_version: U256,
pub data: Option<Bytes>,
pub action_type: ActionType,
pub params_type: ParamsType,
}
impl Default for ActionParams {
fn default() -> ActionParams {
ActionParams {
code_address: Address::zero(),
code_hash: Some(KECCAK_EMPTY),
address: Address::zero(),
sender: Address::zero(),
origin: Address::zero(),
gas: U256::zero(),
gas_price: U256::zero(),
value: ActionValue::Transfer(U256::zero()),
code: None,
code_version: U256::zero(),
data: None,
action_type: ActionType::Create,
params_type: ParamsType::Separate,
}
}
}
impl From<ethjson::vm::Transaction> for ActionParams {
fn from(t: ethjson::vm::Transaction) -> Self {
let address: Address = t.address.into();
ActionParams {
code_address: Address::zero(),
code_hash: Some(keccak(&*t.code)),
address: address,
sender: t.sender.into(),
origin: t.origin.into(),
code: Some(Arc::new(t.code.into())),
code_version: t.code_version.into(),
data: Some(t.data.into()),
gas: t.gas.into(),
gas_price: t.gas_price.into(),
value: ActionValue::Transfer(t.value.into()),
action_type: ActionType::Call,
params_type: ParamsType::Separate,
}
}
}