27 releases

0.4.0 Jun 20, 2023
0.2.0 Jun 20, 2023
0.1.23 Mar 16, 2023
0.1.17 Dec 19, 2022
0.1.8 Mar 3, 2022

#8 in #switchboard

Download history 282/week @ 2024-07-29 261/week @ 2024-08-05 369/week @ 2024-08-12 303/week @ 2024-08-19 455/week @ 2024-08-26 339/week @ 2024-09-02 299/week @ 2024-09-09 328/week @ 2024-09-16 206/week @ 2024-09-23 269/week @ 2024-09-30 76/week @ 2024-10-07 371/week @ 2024-10-14 645/week @ 2024-10-21 1319/week @ 2024-10-28 1489/week @ 2024-11-04 1042/week @ 2024-11-11

4,500 downloads per month
Used in psyoracleutils

MIT license

115KB
2.5K SLoC

6/12/2023 - Deprecated in favor of the switchboard-solana crate.

Switchboard Logo

switchboard-v2

A Rust library to interact with Switchboard accounts on Solana.

Crates.io

Install

Run the following Cargo command in your project directory:

cargo add switchboard-v2

Or add the following line to your Cargo.toml:

[dependencies]
switchboard-v2 = "0.3.0"

Usage

Directory

Read Latest Result

Read an aggregator result on-chain

use anchor_lang::solana_program::clock;
use std::convert::TryInto;
use switchboard_v2::{AggregatorAccountData, SwitchboardDecimal, SWITCHBOARD_PROGRAM_ID};

// check feed owner
let owner = *aggregator.owner;
if owner != SWITCHBOARD_PROGRAM_ID {
  return Err(error!(ErrorCode::InvalidSwitchboardAccount));
}

// deserialize account info
let feed = ctx.accounts.aggregator.load()?;
// OR
let feed = AggregatorAccountData::new(feed_account_info)?;

// get result
let decimal: f64 = feed.get_result()?.try_into()?;

// check if feed has been updated in the last 5 minutes
feed.check_staleness(clock::Clock::get().unwrap().unix_timestamp, 300)?;

// check if feed exceeds a confidence interval of +/i $0.80
feed.check_confidence_interval(SwitchboardDecimal::from_f64(0.80))?;

Read History Buffer

Note: The Aggregator must have a history buffer initialized before using

use switchboard_v2::AggregatorHistoryBuffer;
use std::convert::TryInto;

let history_buffer = AggregatorHistoryBuffer::new(history_account_info)?;
let current_timestamp = Clock::get()?.unix_timestamp;
let one_hour_ago: f64 = history_buffer.lower_bound(current_timestamp - 3600).unwrap().try_into()?;

Read VRF

use switchboard_v2::VrfAccountData;

// deserialize the account info
let vrf = ctx.accounts.vrf.load()?;
// OR
let vrf = VrfAccountData::new(vrf_account_info)?;

// read the result
let result_buffer = vrf.get_result()?;
let value: &[u128] = bytemuck::cast_slice(&result_buffer[..]);
let result = value[0] % 256000 as u128;

Request Randomness CPI

pub use switchboard_v2::{VrfAccountData, VrfRequestRandomness};

let switchboard_program = ctx.accounts.switchboard_program.to_account_info();

let vrf_request_randomness = VrfRequestRandomness {
  authority: ctx.accounts.state.to_account_info(),
  vrf: ctx.accounts.vrf.to_account_info(),
  oracle_queue: ctx.accounts.oracle_queue.to_account_info(),
  queue_authority: ctx.accounts.queue_authority.to_account_info(),
  data_buffer: ctx.accounts.data_buffer.to_account_info(),
  permission: ctx.accounts.permission.to_account_info(),
  escrow: ctx.accounts.escrow.clone(),
  payer_wallet: ctx.accounts.payer_wallet.clone(),
  payer_authority: ctx.accounts.payer_authority.to_account_info(),
  recent_blockhashes: ctx.accounts.recent_blockhashes.to_account_info(),
  program_state: ctx.accounts.program_state.to_account_info(),
  token_program: ctx.accounts.token_program.to_account_info(),
};

let vrf_key = ctx.accounts.vrf.key.clone();
let authority_key = ctx.accounts.authority.key.clone();

let state_seeds: &[&[&[u8]]] = &[&[
  &STATE_SEED,
  vrf_key.as_ref(),
  authority_key.as_ref(),
  &[bump],
]];
msg!("requesting randomness");
vrf_request_randomness.invoke_signed(
  switchboard_program,
  params.switchboard_state_bump,
  params.permission_bump,
  state_seeds,
)?;

Read Buffer Relayer

use anchor_lang::solana_program::clock;
use std::convert::TryInto;
use switchboard_v2::{BufferRelayerAccountData, SWITCHBOARD_PROGRAM_ID};

// check feed owner
let owner = *aggregator.owner;
if owner != SWITCHBOARD_PROGRAM_ID {
  return Err(error!(ErrorCode::InvalidSwitchboardAccount));
}

// deserialize account info
let buffer = BufferRelayerAccountData::new(feed_account_info)?;

// get result
let buffer_result = buffer.get_result();

// check if feed has been updated in the last 5 minutes
buffer.check_staleness(clock::Clock::get().unwrap().unix_timestamp, 300)?;

// convert buffer to a string
let result_string = String::from_utf8(buffer.result)
  .map_err(|_| error!(ErrorCode::StringConversionFailed))?;
msg!("Buffer string {:?}!", result_string);

Dependencies

~18–28MB
~441K SLoC