Struct spl_governance::state::proposal::Proposal[][src]

#[repr(C)]
pub struct Proposal {
Show fields pub account_type: GovernanceAccountType, pub governance: Pubkey, pub governing_token_mint: Pubkey, pub state: ProposalState, pub token_owner_record: Pubkey, pub signatories_count: u8, pub signatories_signed_off_count: u8, pub yes_votes_count: u64, pub no_votes_count: u64, pub instructions_executed_count: u16, pub instructions_count: u16, pub instructions_next_index: u16, pub draft_at: UnixTimestamp, pub signing_off_at: Option<UnixTimestamp>, pub voting_at: Option<UnixTimestamp>, pub voting_at_slot: Option<Slot>, pub voting_completed_at: Option<UnixTimestamp>, pub executing_at: Option<UnixTimestamp>, pub closed_at: Option<UnixTimestamp>, pub execution_flags: InstructionExecutionFlags, pub name: String, pub description_link: String,
}
Expand description

Governance Proposal

Fields

account_type: GovernanceAccountType

Governance account type

governance: Pubkey

Governance account the Proposal belongs to

governing_token_mint: Pubkey

Indicates which Governing Token is used to vote on the Proposal Whether the general Community token owners or the Council tokens owners vote on this Proposal

state: ProposalState

Current proposal state

token_owner_record: Pubkey

The TokenOwnerRecord representing the user who created and owns this Proposal

signatories_count: u8

The number of signatories assigned to the Proposal

signatories_signed_off_count: u8

The number of signatories who already signed

yes_votes_count: u64

The number of Yes votes

no_votes_count: u64

The number of No votes

instructions_executed_count: u16

The number of the instructions already executed

instructions_count: u16

The number of instructions included in the proposal

instructions_next_index: u16

The index of the the next instruction to be added

draft_at: UnixTimestamp

When the Proposal was created and entered Draft state

signing_off_at: Option<UnixTimestamp>

When Signatories started signing off the Proposal

voting_at: Option<UnixTimestamp>

When the Proposal began voting as UnixTimestamp

voting_at_slot: Option<Slot>

When the Proposal began voting as Slot Note: The slot is not currently used but the exact slot is going to be required to support snapshot based vote weights

voting_completed_at: Option<UnixTimestamp>

When the Proposal ended voting and entered either Succeeded or Defeated

executing_at: Option<UnixTimestamp>

When the Proposal entered Executing state

closed_at: Option<UnixTimestamp>

When the Proposal entered final state Completed or Cancelled and was closed

execution_flags: InstructionExecutionFlags

Instruction execution flag for ordered and transactional instructions Note: This field is not used in the current version

name: String

Proposal name

description_link: String

Link to proposal’s description

Implementations

Checks if Signatories can be edited (added or removed) for the Proposal in the given state

Checks if Proposal can be singed off

Checks if Proposal can be voted on

Checks if Proposal can be finalized

Finalizes vote by moving it to final state Succeeded or Defeated if max_voting_time has passed If Proposal is still within max_voting_time period then error is returned

Checks if vote can be tipped and automatically transitioned to Succeeded or Defeated state If the conditions are met the state is updated accordingly

Checks if vote can be tipped and automatically transitioned to Succeeded or Defeated state If yes then Some(ProposalState) is returned and None otherwise

Checks if Proposal can be canceled in the given state

Checks if Instructions can be edited (inserted or removed) for the Proposal in the given state

Checks if Instructions can be executed for the Proposal in the given state

Trait Implementations

Returns max account size or None if max size is not known and actual instance size should be used

Deserializes this instance from a given slice of bytes. Updates the buffer to point at the remaining bytes. Read more

Deserialize this instance from a slice of bytes.

Whether Self is u8. NOTE: Vec<u8> is the most common use-case for serialization and deserialization, it’s worth handling it as a special case to improve performance. It’s a workaround for specific Vec<u8> implementation versus generic Vec<T> implementation. See https://github.com/rust-lang/rfcs/pull/1210 for details. Read more

Get the name of the type without brackets.

Recursively, using DFS, add type definitions required for this type. For primitive types this is an empty map. Type definition explains how to serialize/deserialize a type. Read more

Helper method to add a single type definition to the map.

Serialize this instance into a vector of bytes.

Whether Self is u8. NOTE: Vec<u8> is the most common use-case for serialization and deserialization, it’s worth handling it as a special case to improve performance. It’s a workaround for specific Vec<u8> implementation versus generic Vec<T> implementation. See https://github.com/rust-lang/rfcs/pull/1210 for details. Read more

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Is initialized

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

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

Performs the conversion.

Performs the conversion.

Should always be Self

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

Uses borrowed data to replace owned data, usually by cloning. Read more

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.