pub struct TokenOwnerRecordV2 {
    pub account_type: GovernanceAccountType,
    pub realm: Pubkey,
    pub governing_token_mint: Pubkey,
    pub governing_token_owner: Pubkey,
    pub governing_token_deposit_amount: u64,
    pub unrelinquished_votes_count: u64,
    pub outstanding_proposal_count: u8,
    pub version: u8,
    pub reserved: [u8; 6],
    pub governance_delegate: Option<Pubkey>,
    pub reserved_v2: [u8; 128],
}
Expand description

Governance Token Owner Record Account PDA seeds: [‘governance’, realm, token_mint, token_owner ]

Fields§

§account_type: GovernanceAccountType

Governance account type

§realm: Pubkey

The Realm the TokenOwnerRecord belongs to

§governing_token_mint: Pubkey

Governing Token Mint the TokenOwnerRecord holds deposit for

§governing_token_owner: Pubkey

The owner (either single or multisig) of the deposited governing SPL Tokens This is who can authorize a withdrawal of the tokens

§governing_token_deposit_amount: u64

The amount of governing tokens deposited into the Realm This amount is the voter weight used when voting on proposals

§unrelinquished_votes_count: u64

The number of votes cast by TokenOwner but not relinquished yet Every time a vote is cast this number is increased and it’s always decreased when relinquishing a vote regardless of the vote state

§outstanding_proposal_count: u8

The number of outstanding proposals the TokenOwner currently owns The count is increased when TokenOwner creates a proposal and decreased once it’s either voted on (Succeeded or Defeated) or Cancelled By default it’s restricted to 1 outstanding Proposal per token owner

§version: u8

Version of the account layout Note: In future versions (>program V3) we should introduce GovernanceAccountType::TokenOwnerRecord(version:u8) as a way to version this account (and all other accounts too) It can’t be done in program V3 because it would require to fetch another GovernanceAccountType by the UI and the RPC is already overloaded with all the existing types The new account type and versioning scheme can be introduced once we migrate UI to use indexer to fetch all the accounts Once the new versioning scheme is introduced this field can be migrated and removed

The other issues which need to be addressed before we can cleanup the account versioning code:

  1. Remove the specific governance accounts (ProgramGovernance, TokenGovernance, MintGovernance) The only reason they exist is the UI which can’t handle the generic use case for those assets
  2. For account layout breaking changes all plugins would have to be upgraded
  3. For account layout changes the Holaplex indexer would have to be upgraded
  4. We should migrate the UI to use the indexer for fetching data and stop using getProgramAccounts
  5. The UI would have to be upgraded to support account migration to the latest version
  6. The client sdk is already messy because of the different program/account versions and it should be cleaned up before we add even more versions.
§reserved: [u8; 6]

Reserved space for future versions

§governance_delegate: Option<Pubkey>

A single account that is allowed to operate governance with the deposited governing tokens It can be delegated to by the governing_token_owner or current governance_delegate

§reserved_v2: [u8; 128]

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

Implementations§

source§

impl TokenOwnerRecordV2

source

pub fn assert_token_owner_or_delegate_is_signer( &self, governance_authority_info: &AccountInfo<'_> ) -> Result<(), ProgramError>

Checks whether the provided Governance Authority signed transaction

source

pub fn assert_can_create_proposal( &self, realm_data: &RealmV2, config: &GovernanceConfig, voter_weight: u64 ) -> Result<(), ProgramError>

Asserts TokenOwner has enough tokens to be allowed to create proposal and doesn’t have any outstanding proposals

source

pub fn assert_can_create_governance( &self, realm_data: &RealmV2, voter_weight: u64 ) -> Result<(), ProgramError>

Asserts TokenOwner has enough tokens to be allowed to create governance

source

pub fn assert_can_withdraw_governing_tokens(&self) -> Result<(), ProgramError>

Asserts TokenOwner can withdraw tokens from Realm

source

pub fn decrease_outstanding_proposal_count(&mut self)

Decreases outstanding_proposal_count

source

pub fn resolve_voter_weight( &self, account_info_iter: &mut Iter<'_, AccountInfo<'_>>, realm_data: &RealmV2, realm_config_data: &RealmConfigAccount, weight_action: VoterWeightAction, weight_action_target: &Pubkey ) -> Result<u64, ProgramError>

Resolves voter’s weight using either the amount deposited into the realm or weight provided by voter weight addin (if configured)

source

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

Serializes account into the target buffer

Trait Implementations§

source§

impl AccountMaxSize for TokenOwnerRecordV2

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 TokenOwnerRecordV2

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 TokenOwnerRecordV2

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 TokenOwnerRecordV2

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 TokenOwnerRecordV2

source§

fn clone(&self) -> TokenOwnerRecordV2

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 TokenOwnerRecordV2

source§

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

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

impl IsInitialized for TokenOwnerRecordV2

source§

fn is_initialized(&self) -> bool

Is initialized
source§

impl PartialEq for TokenOwnerRecordV2

source§

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

source§

impl StructuralEq for TokenOwnerRecordV2

source§

impl StructuralPartialEq for TokenOwnerRecordV2

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