pub struct Initialize<'info> {
pub payer: Signer<'info>,
pub authority: Option<Signer<'info>>,
pub receiver: Option<Signer<'info>>,
pub holding: Option<Signer<'info>>,
pub store: AccountLoader<'info, Store>,
pub system_program: Program<'info, System>,
}Expand description
The accounts definition for initialize.
Fields§
§payer: Signer<'info>The payer for the rent-exempt fee of the Store Account.
The authority of the the Store account.
If it is not specified, the payer will be set as the authority of this Store Account.
receiver: Option<Signer<'info>>The receiver address of the the Store account.
Defaults to the authority address.
holding: Option<Signer<'info>>The holding address.
Defaults to the authority address.
store: AccountLoader<'info, Store>The account to be used for creating the Store Account.
Its address is a PDA derived from a constant SEED
and a hashed key as the seeds.
system_program: Program<'info, System>The [System] program.
Trait Implementations§
Source§impl<'info> Accounts<'info, InitializeBumps> for Initialize<'info>where
'info: 'info,
impl<'info> Accounts<'info, InitializeBumps> for Initialize<'info>where
'info: 'info,
Source§fn try_accounts(
__program_id: &Pubkey,
__accounts: &mut &'info [AccountInfo<'info>],
__ix_data: &[u8],
__bumps: &mut InitializeBumps,
__reallocs: &mut BTreeSet<Pubkey>,
) -> Result<Self>
fn try_accounts( __program_id: &Pubkey, __accounts: &mut &'info [AccountInfo<'info>], __ix_data: &[u8], __bumps: &mut InitializeBumps, __reallocs: &mut BTreeSet<Pubkey>, ) -> Result<Self>
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 moreSource§impl<'info> AccountsExit<'info> for Initialize<'info>where
'info: 'info,
impl<'info> AccountsExit<'info> for Initialize<'info>where
'info: 'info,
Source§impl<'info> Bumps for Initialize<'info>where
'info: 'info,
impl<'info> Bumps for Initialize<'info>where
'info: 'info,
Source§type Bumps = InitializeBumps
type Bumps = InitializeBumps
Struct to hold account bump seeds.
Source§impl<'info> ToAccountInfos<'info> for Initialize<'info>where
'info: 'info,
impl<'info> ToAccountInfos<'info> for Initialize<'info>where
'info: 'info,
fn to_account_infos(&self) -> Vec<AccountInfo<'info>>
Source§impl<'info> ToAccountMetas for Initialize<'info>
impl<'info> ToAccountMetas for Initialize<'info>
Source§fn to_account_metas(&self, is_signer: Option<bool>) -> Vec<AccountMeta>
fn to_account_metas(&self, is_signer: Option<bool>) -> Vec<AccountMeta>
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.Auto Trait Implementations§
impl<'info> Freeze for Initialize<'info>
impl<'info> !RefUnwindSafe for Initialize<'info>
impl<'info> !Send for Initialize<'info>
impl<'info> !Sync for Initialize<'info>
impl<'info> Unpin for Initialize<'info>
impl<'info> !UnwindSafe for Initialize<'info>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more