use std::io; use scale::{Encode, Decode, IoReader}; use borsh::{BorshSerialize, BorshDeserialize}; use serai_primitives::{Balance, Data}; use serai_coins_primitives::OutInstructionWithBalance; use crate::Address; /// A payment to fulfill. #[derive(Clone, BorshSerialize, BorshDeserialize)] pub struct Payment { address: A, balance: Balance, data: Option>, } impl TryFrom for Payment { type Error = (); fn try_from(out_instruction_with_balance: OutInstructionWithBalance) -> Result { Ok(Payment { address: out_instruction_with_balance.instruction.address.try_into().map_err(|_| ())?, balance: out_instruction_with_balance.balance, data: out_instruction_with_balance.instruction.data.map(Data::consume), }) } } impl Payment { /// Create a new Payment. pub fn new(address: A, balance: Balance, data: Option>) -> Self { Payment { address, balance, data } } /// The address to pay. pub fn address(&self) -> &A { &self.address } /// The balance to transfer. pub fn balance(&self) -> Balance { self.balance } /// The data to associate with this payment. pub fn data(&self) -> &Option> { &self.data } /// Read a Payment. pub fn read(reader: &mut impl io::Read) -> io::Result { let address = A::read(reader)?; let reader = &mut IoReader(reader); let balance = Balance::decode(reader).map_err(io::Error::other)?; let data = Option::>::decode(reader).map_err(io::Error::other)?; Ok(Self { address, balance, data }) } /// Write the Payment. pub fn write(&self, writer: &mut impl io::Write) -> io::Result<()> { self.address.write(writer).unwrap(); self.balance.encode_to(writer); self.data.encode_to(writer); Ok(()) } }