pub struct CreateAndInitPool<'info> {
    pub pool_creator: Signer<'info>,
    pub token_0: Box<Account<'info, Mint>>,
    pub token_1: Box<Account<'info, Mint>>,
    pub fee_state: AccountLoader<'info, FeeState>,
    pub pool_state: AccountLoader<'info, PoolState>,
    pub initial_observation_state: AccountLoader<'info, ObservationState>,
    pub vault_0: Box<Account<'info, TokenAccount>>,
    pub vault_1: Box<Account<'info, TokenAccount>>,
    pub system_program: Program<'info, System>,
    pub rent: Sysvar<'info, Rent>,
    pub token_program: Program<'info, Token>,
    pub associated_token_program: Program<'info, AssociatedToken>,
}

Fields

pool_creator: Signer<'info>

Address paying to create the pool. Can be anyone

token_0: Box<Account<'info, Mint>>

Desired token pair for the pool token_0 mint address should be smaller than token_1 address

token_1: Box<Account<'info, Mint>>fee_state: AccountLoader<'info, FeeState>

Stores the desired fee for the pool

pool_state: AccountLoader<'info, PoolState>

Initialize an account to store the pool state

initial_observation_state: AccountLoader<'info, ObservationState>

Initialize an account to store oracle observations

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

The address that holds pool tokens for token_0

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

The address that holds pool tokens for token_1

system_program: Program<'info, System>

To create a new program account

rent: Sysvar<'info, Rent>

Sysvar for program account and ATA creation

token_program: Program<'info, Token>

To create new token accounts for the pool

associated_token_program: Program<'info, AssociatedToken>

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.