pub struct ProposalV2 {
Show 27 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 vote_type: VoteType, pub options: Vec<ProposalOption>, pub deny_vote_weight: Option<u64>, pub veto_vote_weight: Option<u64>, pub abstain_vote_weight: Option<u64>, pub start_voting_at: Option<UnixTimestamp>, 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 max_vote_weight: Option<u64>, pub max_voting_time: Option<u32>, pub vote_threshold_percentage: Option<VoteThresholdPercentage>, pub reserved: [u8; 64], 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

vote_type: VoteType

Vote type

options: Vec<ProposalOption>

Proposal options

deny_vote_weight: Option<u64>

The total weight of the Proposal rejection votes If the proposal has no deny option then the weight is None Only proposals with the deny option can have executable instructions attached to them Without the deny option a proposal is only non executable survey

veto_vote_weight: Option<u64>

The total weight of Veto votes Note: Veto is not supported in the current version

abstain_vote_weight: Option<u64>

The total weight of votes Note: Abstain is not supported in the current version

start_voting_at: Option<UnixTimestamp>

Optional start time if the Proposal should not enter voting state immediately after being signed off Note: start_at is not supported in the current version

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

max_vote_weight: Option<u64>

The max vote weight for the Governing Token mint at the time Proposal was decided It’s used to show correct vote results for historical proposals in cases when the mint supply or max weight source changed after vote was completed.

max_voting_time: Option<u32>

Max voting time for the proposal if different from parent Governance (only higher value possible) Note: This field is not used in the current version

vote_threshold_percentage: Option<VoteThresholdPercentage>

The vote threshold percentage at the time Proposal was decided It’s used to show correct vote results for historical proposals in cases when the threshold was changed for governance config after vote was completed. TODO: Use this field to override for the threshold from parent Governance (only higher value possible)

reserved: [u8; 64]

Reserved space for future versions

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 whether the voting time has ended for the proposal

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

Resolves max voter weight

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 It also asserts whether the Proposal is executable (has the reject option)

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

Checks if the instruction can be flagged with error for the Proposal in the given state

Asserts the given vote is valid for the proposal

Serializes account into the target buffer

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.

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.

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)

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.