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
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 common::command::{CliCommand, CliCommandInfo, CliConfig, CliError, ProcessResult};
use common::contract::instructions::update_config_protocol_fee_rate::new_update_config_protocol_fee_rate;
use common::math::fee::ui_fee_to_lamport;
use common::utils::send::send_tx;

pub fn parse_update_config_protocol_fee_rate<'a>(matches: &'a ArgMatches, default_signer: Box<DefaultSigner>, mut wallet_manager: Box<Option<Arc<RemoteWalletManager>>>) -> Result<CliCommandInfo, CliError> {
    let clmm_config = matches.value_of("clmm_config");
    let new_protocol_fee_rate = matches.value_of("new_protocol_fee_rate");
    Ok(CliCommandInfo {
        command: Box::new(CliCommand::PairConfigProtocolFeeRateUpdate {
            clmm_config: Pubkey::from_str(clmm_config.unwrap()).unwrap(),
            new_protocol_fee_rate: ui_fee_to_lamport(new_protocol_fee_rate.unwrap().parse::<f64>().unwrap()) as u16,
        }),
        signers: vec![check_and_update_err!(default_signer.signer_from_path(matches, wallet_manager.as_mut()), CliError::RpcRequestError("owner key is invalid".to_string()))?],
    })
}

pub fn process_update_config_protocol_fee_rate(
    rpc_client: &RpcClient,
    config: &CliConfig,
    clmm_config: &Pubkey,
    new_protocol_fee_rate: &u16,
) -> ProcessResult {
    let ixs = [new_update_config_protocol_fee_rate(clmm_config, new_protocol_fee_rate, config.pubkey().unwrap())];

    let res = send_tx(rpc_client, config, &ixs)?;

    Ok("signers : ".to_owned() + res.to_string().as_str())
}