solana_sysvar_id/lib.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
//! Access to special accounts with dynamically-updated data.
//!
//! Sysvars are special accounts that contain dynamically-updated data about the
//! network cluster, the blockchain history, and the executing transaction. Each
//! sysvar is defined in its own crate. The [`clock`], [`epoch_schedule`],
//! [`instructions`], and [`rent`] sysvars are most useful to on-chain programs.
//!
//! [`clock`]: https://docs.rs/solana-clock/latest
//! [`epoch_schedule`]: https://docs.rs/solana-epoch-schedule/latest
//! [`instructions`]: https://docs.rs/solana-program/latest/solana_program/sysvar/instructions
//! [`rent`]: https://docs.rs/solana-rent/latest
//!
//! All sysvar accounts are owned by the account identified by [`solana_sysvar::ID`].
//!
//! [`solana_sysvar::ID`]: crate::ID
//!
//! For more details see the Solana [documentation on sysvars][sysvardoc].
//!
//! [sysvardoc]: https://docs.solanalabs.com/runtime/sysvars
/// Re-export types required for macros
pub use {
solana_pubkey::{declare_deprecated_id, declare_id, Pubkey},
solana_sdk_ids::sysvar::{check_id, id, ID},
};
/// A type that holds sysvar data and has an associated sysvar `Pubkey`.
pub trait SysvarId {
/// The `Pubkey` of the sysvar.
fn id() -> Pubkey;
/// Returns `true` if the given pubkey is the program ID.
fn check_id(pubkey: &Pubkey) -> bool;
}
/// Implements [`SysvarId`] for a module that already uses
/// `declare_id``
#[macro_export]
macro_rules! impl_sysvar_id(
($type:ty) => {
impl $crate::SysvarId for $type {
fn id() -> $crate::Pubkey {
id()
}
fn check_id(pubkey: &$crate::Pubkey) -> bool {
check_id(pubkey)
}
}
}
);
/// Implements [`SysvarId`] for a module that already uses
/// `declare_deprecated_id``
#[macro_export]
macro_rules! impl_deprecated_sysvar_id(
($type:ty) => {
impl $crate::SysvarId for $type {
fn id() -> $crate::Pubkey {
#[allow(deprecated)]
id()
}
fn check_id(pubkey: &$crate::Pubkey) -> bool {
#[allow(deprecated)]
check_id(pubkey)
}
}
}
);
/// Declares an ID that implements [`SysvarId`].
#[macro_export]
macro_rules! declare_sysvar_id(
($name:expr, $type:ty) => (
$crate::declare_id!($name);
impl_sysvar_id!($type);
)
);
/// Same as [`declare_sysvar_id`] except that it reports that this ID has been deprecated.
#[macro_export]
macro_rules! declare_deprecated_sysvar_id(
($name:expr, $type:ty) => (
$crate::declare_deprecated_id!($name);
impl_deprecated_sysvar_id!($type);
)
);