pub struct RealmV2 {
    pub account_type: GovernanceAccountType,
    pub community_mint: Pubkey,
    pub config: RealmConfig,
    pub reserved: [u8; 6],
    pub legacy1: u16,
    pub authority: Option<Pubkey>,
    pub name: String,
    pub reserved_v2: [u8; 128],
}
Expand description

Governance Realm Account Account PDA seeds“ [‘governance’, name]

Fields§

§account_type: GovernanceAccountType

Governance account type

§community_mint: Pubkey

Community mint

§config: RealmConfig

Configuration of the Realm

§reserved: [u8; 6]

Reserved space for future versions

§legacy1: u16

Legacy field not used since program V3 any longer Note: If the field is going to be reused in future version it must be taken under consideration that for some Realms it might be already set to none zero because it was used as voting_proposal_count before

§authority: Option<Pubkey>

Realm authority. The authority must sign transactions which update the realm config The authority should be transferred to Realm Governance to make the Realm self governed through proposals

§name: String

Governance Realm name

§reserved_v2: [u8; 128]

Reserved space for versions v2 and onwards Note: V1 accounts must be resized before using this space

Implementations§

source§

impl RealmV2

source

pub fn assert_is_valid_governing_token_mint( &self, governing_token_mint: &Pubkey ) -> Result<(), ProgramError>

Asserts the given mint is either Community or Council mint of the Realm

source

pub fn get_proposal_governing_token_mint_for_vote( &self, vote_governing_token_mint: &Pubkey, vote_kind: &VoteKind ) -> Result<Pubkey, ProgramError>

Returns the governing token mint which is used to vote on a proposal given the provided Vote kind and vote_governing_token_mint

Veto vote is cast on a proposal configured for the opposite voting population defined using governing_token_mint Council can veto Community vote and Community can veto Council assuming the veto for the voting population is enabled

For all votes other than Veto (Electorate votes) the vote_governing_token_mint is the same as Proposal governing_token_mint

source

pub fn assert_is_valid_governing_token_mint_and_holding( &self, program_id: &Pubkey, realm: &Pubkey, governing_token_mint: &Pubkey, governing_token_holding: &Pubkey ) -> Result<(), ProgramError>

Asserts the given governing token mint and holding accounts are valid for the realm

source

pub fn assert_create_authority_can_create_governance( &self, program_id: &Pubkey, realm: &Pubkey, token_owner_record_info: &AccountInfo<'_>, create_authority_info: &AccountInfo<'_>, account_info_iter: &mut Iter<'_, AccountInfo<'_>> ) -> Result<(), ProgramError>

Assert the given create authority can create governance

source

pub fn serialize<W: Write>(self, writer: W) -> Result<(), ProgramError>

Serializes account into the target buffer

Trait Implementations§

source§

impl AccountMaxSize for RealmV2

source§

fn get_max_size(&self) -> Option<usize>

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

impl BorshDeserialize for RealmV2

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 RealmV2

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 RealmV2

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 RealmV2

source§

fn clone(&self) -> RealmV2

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 RealmV2

source§

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

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

impl IsInitialized for RealmV2

source§

fn is_initialized(&self) -> bool

Is initialized
source§

impl PartialEq for RealmV2

source§

fn eq(&self, other: &RealmV2) -> 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 RealmV2

source§

impl StructuralEq for RealmV2

source§

impl StructuralPartialEq for RealmV2

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