Module orca_whirlpool.internal.anchor.instructions.decrease_liquidity
Expand source code
from __future__ import annotations
import typing
from solders.pubkey import Pubkey
from spl.token.constants import TOKEN_PROGRAM_ID
from solders.instruction import Instruction, AccountMeta
import borsh_construct as borsh
from ..program_id import PROGRAM_ID
class DecreaseLiquidityArgs(typing.TypedDict):
liquidity_amount: int
token_min_a: int
token_min_b: int
layout = borsh.CStruct(
"liquidity_amount" / borsh.U128,
"token_min_a" / borsh.U64,
"token_min_b" / borsh.U64,
)
class DecreaseLiquidityAccounts(typing.TypedDict):
whirlpool: Pubkey
position_authority: Pubkey
position: Pubkey
position_token_account: Pubkey
token_owner_account_a: Pubkey
token_owner_account_b: Pubkey
token_vault_a: Pubkey
token_vault_b: Pubkey
tick_array_lower: Pubkey
tick_array_upper: Pubkey
def decrease_liquidity(
args: DecreaseLiquidityArgs,
accounts: DecreaseLiquidityAccounts,
program_id: Pubkey = PROGRAM_ID,
remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None,
) -> Instruction:
keys: list[AccountMeta] = [
AccountMeta(pubkey=accounts["whirlpool"], is_signer=False, is_writable=True),
AccountMeta(pubkey=TOKEN_PROGRAM_ID, is_signer=False, is_writable=False),
AccountMeta(
pubkey=accounts["position_authority"], is_signer=True, is_writable=False
),
AccountMeta(pubkey=accounts["position"], is_signer=False, is_writable=True),
AccountMeta(
pubkey=accounts["position_token_account"],
is_signer=False,
is_writable=False,
),
AccountMeta(
pubkey=accounts["token_owner_account_a"], is_signer=False, is_writable=True
),
AccountMeta(
pubkey=accounts["token_owner_account_b"], is_signer=False, is_writable=True
),
AccountMeta(
pubkey=accounts["token_vault_a"], is_signer=False, is_writable=True
),
AccountMeta(
pubkey=accounts["token_vault_b"], is_signer=False, is_writable=True
),
AccountMeta(
pubkey=accounts["tick_array_lower"], is_signer=False, is_writable=True
),
AccountMeta(
pubkey=accounts["tick_array_upper"], is_signer=False, is_writable=True
),
]
if remaining_accounts is not None:
keys += remaining_accounts
identifier = b"\xa0&\xd0oh[,\x01"
encoded_args = layout.build(
{
"liquidity_amount": args["liquidity_amount"],
"token_min_a": args["token_min_a"],
"token_min_b": args["token_min_b"],
}
)
data = identifier + encoded_args
return Instruction(program_id, data, keys)
Functions
def decrease_liquidity(args: DecreaseLiquidityArgs, accounts: DecreaseLiquidityAccounts, program_id: Pubkey = Pubkey( whirLbMiicVdio4qvUfM5KAg6Ct8VwpYzGff3uctyCc, ), remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None) ‑> solders.instruction.Instruction
-
Expand source code
def decrease_liquidity( args: DecreaseLiquidityArgs, accounts: DecreaseLiquidityAccounts, program_id: Pubkey = PROGRAM_ID, remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None, ) -> Instruction: keys: list[AccountMeta] = [ AccountMeta(pubkey=accounts["whirlpool"], is_signer=False, is_writable=True), AccountMeta(pubkey=TOKEN_PROGRAM_ID, is_signer=False, is_writable=False), AccountMeta( pubkey=accounts["position_authority"], is_signer=True, is_writable=False ), AccountMeta(pubkey=accounts["position"], is_signer=False, is_writable=True), AccountMeta( pubkey=accounts["position_token_account"], is_signer=False, is_writable=False, ), AccountMeta( pubkey=accounts["token_owner_account_a"], is_signer=False, is_writable=True ), AccountMeta( pubkey=accounts["token_owner_account_b"], is_signer=False, is_writable=True ), AccountMeta( pubkey=accounts["token_vault_a"], is_signer=False, is_writable=True ), AccountMeta( pubkey=accounts["token_vault_b"], is_signer=False, is_writable=True ), AccountMeta( pubkey=accounts["tick_array_lower"], is_signer=False, is_writable=True ), AccountMeta( pubkey=accounts["tick_array_upper"], is_signer=False, is_writable=True ), ] if remaining_accounts is not None: keys += remaining_accounts identifier = b"\xa0&\xd0oh[,\x01" encoded_args = layout.build( { "liquidity_amount": args["liquidity_amount"], "token_min_a": args["token_min_a"], "token_min_b": args["token_min_b"], } ) data = identifier + encoded_args return Instruction(program_id, data, keys)
Classes
class DecreaseLiquidityAccounts (*args, **kwargs)
-
dict() -> new empty dictionary dict(mapping) -> new dictionary initialized from a mapping object's (key, value) pairs dict(iterable) -> new dictionary initialized as if via: d = {} for k, v in iterable: d[k] = v dict(**kwargs) -> new dictionary initialized with the name=value pairs in the keyword argument list. For example: dict(one=1, two=2)
Expand source code
class DecreaseLiquidityAccounts(typing.TypedDict): whirlpool: Pubkey position_authority: Pubkey position: Pubkey position_token_account: Pubkey token_owner_account_a: Pubkey token_owner_account_b: Pubkey token_vault_a: Pubkey token_vault_b: Pubkey tick_array_lower: Pubkey tick_array_upper: Pubkey
Ancestors
- builtins.dict
Class variables
var position : solders.pubkey.Pubkey
var position_token_account : solders.pubkey.Pubkey
var tick_array_lower : solders.pubkey.Pubkey
var tick_array_upper : solders.pubkey.Pubkey
var token_owner_account_a : solders.pubkey.Pubkey
var token_owner_account_b : solders.pubkey.Pubkey
var token_vault_a : solders.pubkey.Pubkey
var token_vault_b : solders.pubkey.Pubkey
var whirlpool : solders.pubkey.Pubkey
class DecreaseLiquidityArgs (*args, **kwargs)
-
dict() -> new empty dictionary dict(mapping) -> new dictionary initialized from a mapping object's (key, value) pairs dict(iterable) -> new dictionary initialized as if via: d = {} for k, v in iterable: d[k] = v dict(**kwargs) -> new dictionary initialized with the name=value pairs in the keyword argument list. For example: dict(one=1, two=2)
Expand source code
class DecreaseLiquidityArgs(typing.TypedDict): liquidity_amount: int token_min_a: int token_min_b: int
Ancestors
- builtins.dict
Class variables
var liquidity_amount : int
var token_min_a : int
var token_min_b : int