1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
use std::str::FromStr;
use std::sync::Arc;
use borsh::BorshDeserialize;
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 common::command::{CliCommand, CliCommandInfo, CliConfig, CliError, ProcessResult};
use common::contract::instructions::update_protocol_fee_rate::new_update_protocol_fee_rate;
use common::contract::state::Clmmpool;
use common::utils::send::send_tx;
pub fn parse_update_protocol_fee_rate<'a>(matches: &'a ArgMatches, default_signer: &DefaultSigner, wallet_manager: &mut Option<Arc<RemoteWalletManager>>) -> Result<CliCommandInfo<'a>, CliError> {
let clmmpool = matches.value_of("clmmpool");
Ok(CliCommandInfo {
command: CliCommand::PairProtocolFeeRateUpdate {
clmmpool: Pubkey::from_str(clmmpool.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_update_protocol_fee_rate(
rpc_client: &RpcClient,
config: &CliConfig,
clmmpool: &Pubkey,
) -> ProcessResult {
let data = rpc_client.get_account_data(clmmpool).unwrap();
let swap_account: Clmmpool = Clmmpool::try_from_slice(&data[8..]).unwrap();
let ixs = [new_update_protocol_fee_rate(&swap_account.clmm_config, clmmpool, config.pubkey().unwrap())];
let res = send_tx(rpc_client, config, &ixs)?;
Ok("signers : ".to_owned() + res.to_string().as_str())
}