use std::str::FromStr;
use std::sync::Arc;
use clap::ArgMatches;
use solana_clap_utils::keypair::DefaultSigner;
use solana_client::rpc_client::RpcClient;
use solana_program::pubkey::Pubkey;
use solana_remote_wallet::remote_wallet::RemoteWalletManager;
use crate::check_and_update_err;
use crate::command::{CliCommand, CliCommandInfo, CliConfig, CliError, ProcessResult};
use crate::contract::state::farming::mint_wrapper::MintWrapper;
use crate::utils::send::send_tx;
pub fn parse_farming_mint_wrapper_transfer_authority<'a>(matches: &'a ArgMatches, default_signer: &DefaultSigner, wallet_manager: &mut Option<Arc<RemoteWalletManager>>) -> Result<CliCommandInfo<'a>, CliError> {
let wrapper = matches.value_of("wrapper");
Ok(CliCommandInfo {
command: CliCommand::FarmingMintWrapperTransferAuthority {
wrapper: Pubkey::from_str(wrapper.unwrap()).unwrap(),
},
signers: vec![check_and_update_err!(default_signer.signer_from_path(matches, wallet_manager), CliError::RpcRequestError("owner key is invalid".to_string()))?],
})
}
pub fn process_farming_mint_wrapper_transfer_authority(
rpc_client: &RpcClient,
config: &CliConfig,
wrapper: Pubkey,
) -> ProcessResult {
let wrapper_info = MintWrapper::get_info(rpc_client, &wrapper);
let ixs = [
spl_token::instruction::set_authority(
&spl_token::id(),
&wrapper_info.token_mint,
Some(&wrapper),
spl_token::instruction::AuthorityType::MintTokens,
&config.pubkey().unwrap(),
&[&config.pubkey().unwrap()]
).unwrap()
];
let res = send_tx(rpc_client, config, &ixs)?;
Ok("signers : ".to_owned() + res.to_string().as_str())
}