Skip to main content

ValidatorInfo

Struct ValidatorInfo 

Source
pub struct ValidatorInfo {
Show 15 fields pub node_identity: Pubkey, pub authorized_withdrawer: Pubkey, pub stake: u64, pub address: Vec<u8>, pub hostname: String, pub authority_key: Vec<u8>, pub protocol_key: Pubkey, pub network_key: Pubkey, pub registration_time: i64, pub last_update: i64, pub unbonding_periods: BTreeMap<u64, u64>, pub lockup_period: u64, pub commission_rate: u16, pub new_commission_rate: Option<u16>, pub earliest_shutdown: Option<u64>,
}
Expand description

Data structure for the validator information account. This data structure is meant to hold all information about a validator, such that we can leverage it in Epoch negotiation and create a proper Authority object on Epoch change.

Fields§

§node_identity: Pubkey§authorized_withdrawer: Pubkey§stake: u64§address: Vec<u8>§hostname: String§authority_key: Vec<u8>§protocol_key: Pubkey§network_key: Pubkey§registration_time: i64§last_update: i64§unbonding_periods: BTreeMap<u64, u64>

Historical unbonding periods: effective_from_timestamp → unbonding_period_ms.

The duration in milliseconds that deactivating StakeInfo accounts wait before becoming inactive. Set by the runtime (via SetUnbondingPeriod) to punish misbehaving validators.

The first entry (key = registration_time) contains the default unbonding period. Subsequent entries are added by SetUnbondingPeriod to extend or reduce the period. Entries are in ascending order by timestamp (guaranteed by BTreeMap).

Note: A deactivated stake cannot be withdrawn until the unbonding period that was effective at deactivation time has elapsed — see end_of_unbonding().

§lockup_period: u64

The minimum duration in milliseconds that StakeInfo accounts must commit to delegate for. Can be set by the validator to earn increased rewards (bonus). Note: An activated stake cannot be deactivated until current_timestamp >= activation_requested + lockup_period. This is fixed at registration and cannot be changed.

§commission_rate: u16

The validator’s commission from the inflation rewards in basis points, e.g. 835 corresponds to 8.35%

§new_commission_rate: Option<u16>

New commission_rate to be applied from the next epoch

§earliest_shutdown: Option<u64>

Optional timestamp (ms) after which the validator does not intend to participate in committees. Must be >= current_timestamp + lockup_period when set. Passing None resets the field (validator decides to continue).

Implementations§

Source§

impl ValidatorInfo

Source

pub const MAX_UNBONDING_PERIOD_ENTRIES: usize = 100

Maximum number of historical unbonding period entries allowed in the unbonding_periods map. 100 entries × 16 bytes (8-byte key + 8-byte value) = 1600 bytes of map data. Enforced by the SetUnbondingPeriod handler to prevent unbounded account growth.

Source

pub const fn account_size( address_len: usize, hostname_len: usize, authority_key_len: usize, ) -> usize

Calculate the account data size needed to store a ValidatorInfo with the given variable-length field sizes.

Uses the in-memory struct size as a safe upper bound, plus the actual lengths of the variable-length fields (address, hostname, authority_key).

Source

pub fn end_of_unbonding(&self, deactivation_requested: u64) -> u64

Calculate when unbonding ends for a stake that requested deactivation at the given timestamp.

This handles three cases correctly:

  1. Active stake: Deactivated after punishment → uses punished period
  2. Unbonding stake: Was unbonding when punishment hit → gets extended
  3. Fully unbonded: Completed unbonding before punishment → exempt
§Algorithm (Dual-Tracking)

Uses two variables to achieve fairness (reductions apply to still-unbonding accounts) while preventing flash attacks (brief 0-period can’t free accounts):

  • max_end: monotonically increasing, tracks the longest unbonding window ever applicable. Used ONLY for the exemption check (“was this account genuinely done before this entry?”). Prevents flash reductions from creating false exemption gaps.

  • effective_end: tracks the latest applicable period. This is the ACTUAL result. Can decrease when governance reduces a punishment.

§Complexity

O(log n + k) where n = total entries, k = entries after deactivation (typically 0-2)

§Arguments
  • deactivation_requested - When DeactivateStake was called (in milliseconds)
§Returns

The timestamp when unbonding completes

Trait Implementations§

Source§

impl Clone for ValidatorInfo

Source§

fn clone(&self) -> ValidatorInfo

Returns a duplicate 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 ValidatorInfo

Source§

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

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

impl<'de> Deserialize<'de> for ValidatorInfo

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<ValidatorInfo, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for ValidatorInfo

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for ValidatorInfo

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for ValidatorInfo

Source§

impl StructuralPartialEq for ValidatorInfo

Auto Trait Implementations§

Blanket Implementations§

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

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

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

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

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

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

Source§

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.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

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

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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>,

Source§

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>,

Source§

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

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

Source§

fn vzip(self) -> V

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,