5 releases
0.0.5 | Nov 14, 2024 |
---|---|
0.0.4 | Nov 12, 2024 |
0.0.3 | Nov 7, 2024 |
0.0.2 | Oct 29, 2024 |
0.0.1 | Oct 29, 2024 |
#44 in #price
40 downloads per month
11KB
92 lines
Stork Solana SDK
This is a Rust SDK to build Solana programs that consume Stork price feeds. This crate is maintained by Stork Labs.
It is available on crates.io.
Pull Model
The Stork Solana SDK allows users to consume Stork price updates on a pull basis. This puts the responsibility of submitting the price updates on-chain to the user whenever they want to interact with an app that consumes Stork price feeds. Stork Labs maintains a Chain Pusher in order to do this.
Stork Price Feed Accounts
On Solana, Stork price feeds exist as on-chain accounts. These accounts are instances of the TemporalNumericValueFeed
account, and are created and owned by the Stork Oracle contract. These account have an ID which associates them with a specific asset, and a latest_value
field which stores the latest price update.
Example
The following snippet is an example of how to use this sdk to consume Stork price feed on chain. A full example is available here.
// This instruction reads the latest price from a Stork feed
pub fn read_price(ctx: Context<ReadPrice>, feed_id: [u8; 32]) -> Result<()> {
let feed = &ctx.accounts.feed;
let latest_value = feed.get_latest_canonical_temporal_numeric_value_unchecked(&feed_id)?;
// Get the latest timestamp and value from the feed
let timestamp = latest_value.timestamp_ns;
let value = latest_value.quantized_value;
// You can do something with the price here...
Ok(())
}
}
#[derive(Accounts)]
#[instruction(feed_id: [u8; 32])]
pub struct ReadPrice<'info> {
// This account holds the price feed data
#[account(
seeds = [STORK_FEED_SEED.as_ref(), feed_id.as_ref()],
bump,
seeds::program = stork_sdk::ID
)]
pub feed: Account<'info, TemporalNumericValueFeed>,
}
Dependencies
~18–26MB
~456K SLoC