Module orca_whirlpool.internal.anchor.instructions.open_position_with_token_extensions

Expand source code
from __future__ import annotations
import typing
from solders.pubkey import Pubkey
from solders.system_program import ID as SYS_PROGRAM_ID
from spl.token.constants import ASSOCIATED_TOKEN_PROGRAM_ID
from solders.instruction import Instruction, AccountMeta
import borsh_construct as borsh
from ..program_id import PROGRAM_ID


class OpenPositionWithTokenExtensionsArgs(typing.TypedDict):
    tick_lower_index: int
    tick_upper_index: int
    with_token_metadata_extension: bool


layout = borsh.CStruct(
    "tick_lower_index" / borsh.I32,
    "tick_upper_index" / borsh.I32,
    "with_token_metadata_extension" / borsh.Bool,
)


class OpenPositionWithTokenExtensionsAccounts(typing.TypedDict):
    funder: Pubkey
    owner: Pubkey
    position: Pubkey
    position_mint: Pubkey
    position_token_account: Pubkey
    whirlpool: Pubkey
    token2022_program: Pubkey
    metadata_update_auth: Pubkey


def open_position_with_token_extensions(
    args: OpenPositionWithTokenExtensionsArgs,
    accounts: OpenPositionWithTokenExtensionsAccounts,
    program_id: Pubkey = PROGRAM_ID,
    remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None,
) -> Instruction:
    keys: list[AccountMeta] = [
        AccountMeta(pubkey=accounts["funder"], is_signer=True, is_writable=True),
        AccountMeta(pubkey=accounts["owner"], is_signer=False, is_writable=False),
        AccountMeta(pubkey=accounts["position"], is_signer=False, is_writable=True),
        AccountMeta(pubkey=accounts["position_mint"], is_signer=True, is_writable=True),
        AccountMeta(
            pubkey=accounts["position_token_account"], is_signer=False, is_writable=True
        ),
        AccountMeta(pubkey=accounts["whirlpool"], is_signer=False, is_writable=False),
        AccountMeta(
            pubkey=accounts["token2022_program"], is_signer=False, is_writable=False
        ),
        AccountMeta(pubkey=SYS_PROGRAM_ID, is_signer=False, is_writable=False),
        AccountMeta(
            pubkey=ASSOCIATED_TOKEN_PROGRAM_ID, is_signer=False, is_writable=False
        ),
        AccountMeta(
            pubkey=accounts["metadata_update_auth"], is_signer=False, is_writable=False
        ),
    ]
    if remaining_accounts is not None:
        keys += remaining_accounts
    identifier = b"\xd4/_\\rf\x83\xfa"
    encoded_args = layout.build(
        {
            "tick_lower_index": args["tick_lower_index"],
            "tick_upper_index": args["tick_upper_index"],
            "with_token_metadata_extension": args["with_token_metadata_extension"],
        }
    )
    data = identifier + encoded_args
    return Instruction(program_id, data, keys)

Functions

def open_position_with_token_extensions(args: OpenPositionWithTokenExtensionsArgs, accounts: OpenPositionWithTokenExtensionsAccounts, program_id: Pubkey = Pubkey( whirLbMiicVdio4qvUfM5KAg6Ct8VwpYzGff3uctyCc, ), remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None) ‑> solders.instruction.Instruction
Expand source code
def open_position_with_token_extensions(
    args: OpenPositionWithTokenExtensionsArgs,
    accounts: OpenPositionWithTokenExtensionsAccounts,
    program_id: Pubkey = PROGRAM_ID,
    remaining_accounts: typing.Optional[typing.List[AccountMeta]] = None,
) -> Instruction:
    keys: list[AccountMeta] = [
        AccountMeta(pubkey=accounts["funder"], is_signer=True, is_writable=True),
        AccountMeta(pubkey=accounts["owner"], is_signer=False, is_writable=False),
        AccountMeta(pubkey=accounts["position"], is_signer=False, is_writable=True),
        AccountMeta(pubkey=accounts["position_mint"], is_signer=True, is_writable=True),
        AccountMeta(
            pubkey=accounts["position_token_account"], is_signer=False, is_writable=True
        ),
        AccountMeta(pubkey=accounts["whirlpool"], is_signer=False, is_writable=False),
        AccountMeta(
            pubkey=accounts["token2022_program"], is_signer=False, is_writable=False
        ),
        AccountMeta(pubkey=SYS_PROGRAM_ID, is_signer=False, is_writable=False),
        AccountMeta(
            pubkey=ASSOCIATED_TOKEN_PROGRAM_ID, is_signer=False, is_writable=False
        ),
        AccountMeta(
            pubkey=accounts["metadata_update_auth"], is_signer=False, is_writable=False
        ),
    ]
    if remaining_accounts is not None:
        keys += remaining_accounts
    identifier = b"\xd4/_\\rf\x83\xfa"
    encoded_args = layout.build(
        {
            "tick_lower_index": args["tick_lower_index"],
            "tick_upper_index": args["tick_upper_index"],
            "with_token_metadata_extension": args["with_token_metadata_extension"],
        }
    )
    data = identifier + encoded_args
    return Instruction(program_id, data, keys)

Classes

class OpenPositionWithTokenExtensionsAccounts (*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 OpenPositionWithTokenExtensionsAccounts(typing.TypedDict):
    funder: Pubkey
    owner: Pubkey
    position: Pubkey
    position_mint: Pubkey
    position_token_account: Pubkey
    whirlpool: Pubkey
    token2022_program: Pubkey
    metadata_update_auth: Pubkey

Ancestors

  • builtins.dict

Class variables

var funder : solders.pubkey.Pubkey
var metadata_update_auth : solders.pubkey.Pubkey
var owner : solders.pubkey.Pubkey
var position : solders.pubkey.Pubkey
var position_mint : solders.pubkey.Pubkey
var position_token_account : solders.pubkey.Pubkey
var token2022_program : solders.pubkey.Pubkey
var whirlpool : solders.pubkey.Pubkey
class OpenPositionWithTokenExtensionsArgs (*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 OpenPositionWithTokenExtensionsArgs(typing.TypedDict):
    tick_lower_index: int
    tick_upper_index: int
    with_token_metadata_extension: bool

Ancestors

  • builtins.dict

Class variables

var tick_lower_index : int
var tick_upper_index : int
var with_token_metadata_extension : bool