Module orca_whirlpool.internal.anchor.instructions.swap_v2
Expand source code
from __future__ import annotations
import typing
from solders.pubkey import Pubkey
from solders.instruction import Instruction, AccountMeta
import borsh_construct as borsh
from .. import types
from ..program_id import PROGRAM_ID
class SwapV2Args(typing.TypedDict):
amount: int
other_amount_threshold: int
sqrt_price_limit: int
amount_specified_is_input: bool
a_to_b: bool
remaining_accounts_info: typing.Optional[
types.remaining_accounts_info.RemainingAccountsInfo
]
layout = borsh.CStruct(
"amount" / borsh.U64,
"other_amount_threshold" / borsh.U64,
"sqrt_price_limit" / borsh.U128,
"amount_specified_is_input" / borsh.Bool,
"a_to_b" / borsh.Bool,
"remaining_accounts_info"
/ borsh.Option(types.remaining_accounts_info.RemainingAccountsInfo.layout),
)
class SwapV2Accounts(typing.TypedDict):
token_program_a: Pubkey
token_program_b: Pubkey
memo_program: Pubkey
token_authority: Pubkey
whirlpool: Pubkey
token_mint_a: Pubkey
token_mint_b: Pubkey
token_owner_account_a: Pubkey
token_vault_a: Pubkey
token_owner_account_b: Pubkey
token_vault_b: Pubkey
tick_array0: Pubkey
tick_array1: Pubkey
tick_array2: Pubkey
oracle: Pubkey
def swap_v2(
args: SwapV2Args,
accounts: SwapV2Accounts,
program_id: Pubkey = PROGRAM_ID,
remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None,
) -> Instruction:
keys: list[AccountMeta] = [
AccountMeta(
pubkey=accounts["token_program_a"], is_signer=False, is_writable=False
),
AccountMeta(
pubkey=accounts["token_program_b"], is_signer=False, is_writable=False
),
AccountMeta(
pubkey=accounts["memo_program"], is_signer=False, is_writable=False
),
AccountMeta(
pubkey=accounts["token_authority"], is_signer=True, is_writable=False
),
AccountMeta(pubkey=accounts["whirlpool"], is_signer=False, is_writable=True),
AccountMeta(
pubkey=accounts["token_mint_a"], is_signer=False, is_writable=False
),
AccountMeta(
pubkey=accounts["token_mint_b"], is_signer=False, is_writable=False
),
AccountMeta(
pubkey=accounts["token_owner_account_a"], is_signer=False, is_writable=True
),
AccountMeta(
pubkey=accounts["token_vault_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_b"], is_signer=False, is_writable=True
),
AccountMeta(pubkey=accounts["tick_array0"], is_signer=False, is_writable=True),
AccountMeta(pubkey=accounts["tick_array1"], is_signer=False, is_writable=True),
AccountMeta(pubkey=accounts["tick_array2"], is_signer=False, is_writable=True),
AccountMeta(pubkey=accounts["oracle"], is_signer=False, is_writable=True),
]
if remaining_accounts is not None:
keys += remaining_accounts
identifier = b"+\x04\xed\x0b\x1a\xc9\x1eb"
encoded_args = layout.build(
{
"amount": args["amount"],
"other_amount_threshold": args["other_amount_threshold"],
"sqrt_price_limit": args["sqrt_price_limit"],
"amount_specified_is_input": args["amount_specified_is_input"],
"a_to_b": args["a_to_b"],
"remaining_accounts_info": (
None
if args["remaining_accounts_info"] is None
else args["remaining_accounts_info"].to_encodable()
),
}
)
data = identifier + encoded_args
return Instruction(program_id, data, keys)
Functions
def swap_v2(args: SwapV2Args, accounts: SwapV2Accounts, program_id: Pubkey = Pubkey( whirLbMiicVdio4qvUfM5KAg6Ct8VwpYzGff3uctyCc, ), remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None) ‑> solders.instruction.Instruction
-
Expand source code
def swap_v2( args: SwapV2Args, accounts: SwapV2Accounts, program_id: Pubkey = PROGRAM_ID, remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None, ) -> Instruction: keys: list[AccountMeta] = [ AccountMeta( pubkey=accounts["token_program_a"], is_signer=False, is_writable=False ), AccountMeta( pubkey=accounts["token_program_b"], is_signer=False, is_writable=False ), AccountMeta( pubkey=accounts["memo_program"], is_signer=False, is_writable=False ), AccountMeta( pubkey=accounts["token_authority"], is_signer=True, is_writable=False ), AccountMeta(pubkey=accounts["whirlpool"], is_signer=False, is_writable=True), AccountMeta( pubkey=accounts["token_mint_a"], is_signer=False, is_writable=False ), AccountMeta( pubkey=accounts["token_mint_b"], is_signer=False, is_writable=False ), AccountMeta( pubkey=accounts["token_owner_account_a"], is_signer=False, is_writable=True ), AccountMeta( pubkey=accounts["token_vault_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_b"], is_signer=False, is_writable=True ), AccountMeta(pubkey=accounts["tick_array0"], is_signer=False, is_writable=True), AccountMeta(pubkey=accounts["tick_array1"], is_signer=False, is_writable=True), AccountMeta(pubkey=accounts["tick_array2"], is_signer=False, is_writable=True), AccountMeta(pubkey=accounts["oracle"], is_signer=False, is_writable=True), ] if remaining_accounts is not None: keys += remaining_accounts identifier = b"+\x04\xed\x0b\x1a\xc9\x1eb" encoded_args = layout.build( { "amount": args["amount"], "other_amount_threshold": args["other_amount_threshold"], "sqrt_price_limit": args["sqrt_price_limit"], "amount_specified_is_input": args["amount_specified_is_input"], "a_to_b": args["a_to_b"], "remaining_accounts_info": ( None if args["remaining_accounts_info"] is None else args["remaining_accounts_info"].to_encodable() ), } ) data = identifier + encoded_args return Instruction(program_id, data, keys)
Classes
class SwapV2Accounts (*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 SwapV2Accounts(typing.TypedDict): token_program_a: Pubkey token_program_b: Pubkey memo_program: Pubkey token_authority: Pubkey whirlpool: Pubkey token_mint_a: Pubkey token_mint_b: Pubkey token_owner_account_a: Pubkey token_vault_a: Pubkey token_owner_account_b: Pubkey token_vault_b: Pubkey tick_array0: Pubkey tick_array1: Pubkey tick_array2: Pubkey oracle: Pubkey
Ancestors
- builtins.dict
Class variables
var memo_program : solders.pubkey.Pubkey
var oracle : solders.pubkey.Pubkey
var tick_array0 : solders.pubkey.Pubkey
var tick_array1 : solders.pubkey.Pubkey
var tick_array2 : solders.pubkey.Pubkey
var token_mint_a : solders.pubkey.Pubkey
var token_mint_b : solders.pubkey.Pubkey
var token_owner_account_a : solders.pubkey.Pubkey
var token_owner_account_b : solders.pubkey.Pubkey
var token_program_a : solders.pubkey.Pubkey
var token_program_b : solders.pubkey.Pubkey
var token_vault_a : solders.pubkey.Pubkey
var token_vault_b : solders.pubkey.Pubkey
var whirlpool : solders.pubkey.Pubkey
class SwapV2Args (*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 SwapV2Args(typing.TypedDict): amount: int other_amount_threshold: int sqrt_price_limit: int amount_specified_is_input: bool a_to_b: bool remaining_accounts_info: typing.Optional[ types.remaining_accounts_info.RemainingAccountsInfo ]
Ancestors
- builtins.dict
Class variables
var a_to_b : bool
var amount : int
var amount_specified_is_input : bool
var other_amount_threshold : int
var remaining_accounts_info : Optional[RemainingAccountsInfo]
var sqrt_price_limit : int