pub struct CollectContext<'info> {
    pub owner: Signer<'info>,
    pub pool_state: UncheckedAccount<'info>,
    pub tick_lower_state: UncheckedAccount<'info>,
    pub tick_upper_state: UncheckedAccount<'info>,
    pub position_state: UncheckedAccount<'info>,
    pub vault_0: Box<Account<'info, TokenAccount>>,
    pub vault_1: Box<Account<'info, TokenAccount>>,
    pub recipient_wallet_0: UncheckedAccount<'info>,
    pub recipient_wallet_1: UncheckedAccount<'info>,
    pub token_program: Program<'info, Token>,
}

Fields

owner: Signer<'info>

The position owner

pool_state: UncheckedAccount<'info>

The program account for the liquidity pool from which fees are collected CHECK: Safety check performed inside function body

tick_lower_state: UncheckedAccount<'info>

The lower tick of the position for which to collect fees CHECK: Safety check performed inside function body

tick_upper_state: UncheckedAccount<'info>

The upper tick of the position for which to collect fees CHECK: Safety check performed inside function body

position_state: UncheckedAccount<'info>

The position program account to collect fees from CHECK: Safety check performed inside function body

vault_0: Box<Account<'info, TokenAccount>>

The account holding pool tokens for token_0

vault_1: Box<Account<'info, TokenAccount>>

The account holding pool tokens for token_1

recipient_wallet_0: UncheckedAccount<'info>

The destination token account for the collected amount_0 CHECK: Account validation is performed by the token program

recipient_wallet_1: UncheckedAccount<'info>

The destination token account for the collected amount_1 CHECK: Account validation is performed by the token program

token_program: Program<'info, Token>

SPL program to transfer out tokens

Trait Implementations

Returns the validated accounts struct. What constitutes “valid” is program dependent. However, users of these types should never have to worry about account substitution attacks. For example, if a program expects a Mint account from the SPL token program in a particular field, then it should be impossible for this method to return Ok if any other account type is given–from the SPL token program or elsewhere. Read more

program_id is the currently executing program.

is_signer is given as an optional override for the signer meta field. This covers the edge case when a program-derived-address needs to relay a transaction from a client to another program but sign the transaction before the relay. The client cannot mark the field as a signer, and so we have to override the is_signer meta field given by the client. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The alignment of pointer.

The type for initializers.

Initializes a with the given initializer. Read more

Dereferences the given pointer. Read more

Mutably dereferences the given pointer. Read more

Drops the object pointed to by the given pointer. Read more

Should always be Self

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.