From f83240a8684bc20cbf9c592fa2453c7a2103076b Mon Sep 17 00:00:00 2001 From: Jon Cinque Date: Wed, 17 Nov 2021 23:41:55 +0100 Subject: [PATCH] token-swap: Prevent single deposits for curves that don't allow it (#2590) --- token-swap/program/src/processor.rs | 73 ++++++++++++++++++++++++++++- 1 file changed, 72 insertions(+), 1 deletion(-) diff --git a/token-swap/program/src/processor.rs b/token-swap/program/src/processor.rs index 722da6f0e10..fdd32a50b2b 100644 --- a/token-swap/program/src/processor.rs +++ b/token-swap/program/src/processor.rs @@ -744,6 +744,10 @@ impl Processor { let token_program_info = next_account_info(account_info_iter)?; let token_swap = SwapVersion::unpack(&swap_info.data.borrow())?; + let calculator = &token_swap.swap_curve().calculator; + if !calculator.allows_deposits() { + return Err(SwapError::UnsupportedCurveOperation.into()); + } let source_account = Self::unpack_token_account(source_info, token_swap.token_program_id())?; let swap_token_a = @@ -793,7 +797,7 @@ impl Processor { ) .ok_or(SwapError::ZeroTradingTokens)? } else { - token_swap.swap_curve().calculator.new_pool_supply() + calculator.new_pool_supply() }; let pool_token_amount = to_u64(pool_token_amount)?; @@ -6855,4 +6859,71 @@ mod tests { ) .unwrap(); } + + #[test] + fn test_deposits_allowed_single_token() { + let trade_fee_numerator = 1; + let trade_fee_denominator = 10; + let owner_trade_fee_numerator = 1; + let owner_trade_fee_denominator = 30; + let owner_withdraw_fee_numerator = 0; + let owner_withdraw_fee_denominator = 30; + let host_fee_numerator = 10; + let host_fee_denominator = 100; + + let token_a_amount = 1_000_000; + let token_b_amount = 0; + let fees = Fees { + trade_fee_numerator, + trade_fee_denominator, + owner_trade_fee_numerator, + owner_trade_fee_denominator, + owner_withdraw_fee_numerator, + owner_withdraw_fee_denominator, + host_fee_numerator, + host_fee_denominator, + }; + + let token_b_offset = 2_000_000; + let swap_curve = SwapCurve { + curve_type: CurveType::Offset, + calculator: Box::new(OffsetCurve { token_b_offset }), + }; + let creator_key = Pubkey::new_unique(); + let depositor_key = Pubkey::new_unique(); + + let mut accounts = SwapAccountInfo::new( + &creator_key, + fees, + swap_curve, + token_a_amount, + token_b_amount, + ); + + accounts.initialize_swap().unwrap(); + + let initial_a = 1_000_000; + let initial_b = 2_000_000; + let ( + _depositor_token_a_key, + _depositor_token_a_account, + depositor_token_b_key, + mut depositor_token_b_account, + depositor_pool_key, + mut depositor_pool_account, + ) = accounts.setup_token_accounts(&creator_key, &depositor_key, initial_a, initial_b, 0); + + assert_eq!( + Err(SwapError::UnsupportedCurveOperation.into()), + accounts.deposit_single_token_type_exact_amount_in( + &depositor_key, + &depositor_token_b_key, + &mut depositor_token_b_account, + &depositor_pool_key, + &mut depositor_pool_account, + initial_b, + 0, + ) + ); + } }