pub struct ProposalV1 {
Show 24 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 max_vote_weight: Option<u64>, pub vote_threshold: Option<VoteThreshold>, 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

§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.

§vote_threshold: Option<VoteThreshold>

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.

§name: String

Proposal name

§description_link: String

Link to proposal’s description

Trait Implementations§

source§

impl BorshDeserialize for ProposalV1

source§

fn deserialize_reader<R: Read>(reader: &mut R) -> Result<Self, Error>

source§

fn deserialize(buf: &mut &[u8]) -> Result<Self, Error>

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

fn try_from_slice(v: &[u8]) -> Result<Self, Error>

Deserialize this instance from a slice of bytes.
source§

fn try_from_reader<R>(reader: &mut R) -> Result<Self, Error>
where R: Read,

source§

impl BorshSchema for ProposalV1

source§

fn declaration() -> Declaration

Get the name of the type without brackets.
source§

fn add_definitions_recursively( definitions: &mut HashMap<Declaration, Definition> )

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.
source§

fn add_definition( declaration: String, definition: Definition, definitions: &mut HashMap<String, Definition> )

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

fn schema_container() -> BorshSchemaContainer

source§

impl BorshSerialize for ProposalV1

source§

fn serialize<W: Write>(&self, writer: &mut W) -> Result<(), Error>

source§

fn try_to_vec(&self) -> Result<Vec<u8>, Error>

Serialize this instance into a vector of bytes.
source§

impl Clone for ProposalV1

source§

fn clone(&self) -> ProposalV1

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ProposalV1

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl IsInitialized for ProposalV1

source§

fn is_initialized(&self) -> bool

Is initialized
source§

impl PartialEq for ProposalV1

source§

fn eq(&self, other: &ProposalV1) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Eq for ProposalV1

source§

impl StructuralEq for ProposalV1

source§

impl StructuralPartialEq for ProposalV1

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> AbiExample for T

§

default fn example() -> T

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

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

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V