use clap::{command, Parser};
use crate::{commands::tx, tx::builder, xdr};
#[allow(clippy::struct_excessive_bools, clippy::doc_markdown)]
#[derive(Parser, Debug, Clone)]
#[group(skip)]
pub struct Cmd {
#[command(flatten)]
pub tx: tx::Args,
#[arg(long)]
pub trustor: xdr::AccountId,
#[arg(long)]
pub asset: builder::Asset,
#[arg(long, conflicts_with = "clear_authorize")]
pub set_authorize: bool,
#[arg(long, conflicts_with = "clear_authorize_to_maintain_liabilities")]
pub set_authorize_to_maintain_liabilities: bool,
#[arg(long, conflicts_with = "clear_trustline_clawback_enabled")]
pub set_trustline_clawback_enabled: bool,
#[arg(long)]
pub clear_authorize: bool,
#[arg(long)]
pub clear_authorize_to_maintain_liabilities: bool,
#[arg(long)]
pub clear_trustline_clawback_enabled: bool,
}
impl From<&Cmd> for xdr::OperationBody {
fn from(cmd: &Cmd) -> Self {
let mut set_flags = 0;
let mut set_flag = |flag: xdr::TrustLineFlags| set_flags |= flag as u32;
if cmd.set_authorize {
set_flag(xdr::TrustLineFlags::AuthorizedFlag);
};
if cmd.set_authorize_to_maintain_liabilities {
set_flag(xdr::TrustLineFlags::AuthorizedToMaintainLiabilitiesFlag);
};
if cmd.set_trustline_clawback_enabled {
set_flag(xdr::TrustLineFlags::TrustlineClawbackEnabledFlag);
};
let mut clear_flags = 0;
let mut clear_flag = |flag: xdr::TrustLineFlags| clear_flags |= flag as u32;
if cmd.clear_authorize {
clear_flag(xdr::TrustLineFlags::AuthorizedFlag);
};
if cmd.clear_authorize_to_maintain_liabilities {
clear_flag(xdr::TrustLineFlags::AuthorizedToMaintainLiabilitiesFlag);
};
if cmd.clear_trustline_clawback_enabled {
clear_flag(xdr::TrustLineFlags::TrustlineClawbackEnabledFlag);
};
xdr::OperationBody::SetTrustLineFlags(xdr::SetTrustLineFlagsOp {
trustor: cmd.trustor.clone(),
asset: cmd.asset.clone().into(),
clear_flags,
set_flags,
})
}
}