use borsh::{BorshDeserialize, BorshSerialize};
use solana_program::instruction::{AccountMeta, Instruction};
use solana_program::pubkey::Pubkey;
use crate::program::PROGRAM_ID;
use crate::utils::sighash;
#[derive(BorshSerialize, BorshDeserialize, PartialEq, Debug, Clone)]
pub struct DecreaseLiquidityArgs {
pub delta_liquidity: u128,
pub token_a_min: u64,
pub token_b_min: u64,
}
pub fn new_decrease_liquidity(
clmmpool: &Pubkey,
position: &Pubkey,
position_ata: &Pubkey,
token_a_ata: &Pubkey,
token_b_ata: &Pubkey,
token_a_value: &Pubkey,
token_b_value: &Pubkey,
tick_array_lower: &Pubkey,
tick_array_upper: &Pubkey,
tick_array_map: &Pubkey,
delta_liquidity: &u128,
token_a_min: &u64,
token_b_min: &u64,
payer: Pubkey,
) -> Instruction {
let data = &DecreaseLiquidityArgs {
delta_liquidity: *delta_liquidity,
token_a_min: *token_a_min,
token_b_min: *token_b_min,
};
let mut dsa = data.try_to_vec().unwrap();
let mut distor = sighash::sighash("global", "decrease_liquidity").to_vec();
distor.append(&mut dsa);
Instruction {
program_id: PROGRAM_ID,
accounts: vec![
AccountMeta::new(payer, true),
AccountMeta::new(*clmmpool, false),
AccountMeta::new(*position, false),
AccountMeta::new_readonly(*position_ata, false),
AccountMeta::new(*token_a_ata, false),
AccountMeta::new(*token_b_ata, false),
AccountMeta::new(*token_a_value, false),
AccountMeta::new(*token_b_value, false),
AccountMeta::new(*tick_array_lower, false),
AccountMeta::new(*tick_array_upper, false),
AccountMeta::new(*tick_array_map, false),
AccountMeta::new_readonly(spl_token::id(), false),
],
data: distor,
}
}