Pyth

Pyth est un Oracle utilisé pour obtenir des données financières et des données sur le marché des crypto-monnaies dans le monde réel. L'Oracle de Pyth peut être utilisé par les programmes on-chain afin d'utiliser des données dans divers cas d'utilisation.

Comment utiliser Pyth dans le Client

Pyth fournit une bibliothèque JavaScript/TypeScript appelée @pythnetwork/client. Cette bibliothèque peut être utilisée pour lire les données on-chain de Pyth pour des applications off-chain, comme l'affichage du prix du jeton Pyth sur un site web. Plus d'informations à ce sujet iciopen in new window

Press </> button to view full source
import * as web3 from "@solana/web3.js";
import * as pyth from "@pythnetwork/client";

(async () => {
  const connection = new web3.Connection(
    web3.clusterApiUrl("devnet"),
    "confirmed"
  );
  const pythConnection = new pyth.PythConnection(
    connection,
    pyth.getPythProgramKeyForCluster("devnet")
  );

  pythConnection.onPriceChange((product, price) => {
    if (price.price && price.confidence) {
      console.log(
        `${product.symbol}: $${price.price} \xB1$${price.confidence}`
      );
    } else {
      console.log(
        `${product.symbol}: price currently unavailable. status is ${price.status}`
      );
    }
  });
  pythConnection.start();
})();

Comment utiliser Pyth dans Anchor

Pyth fournit un Crate Rust qui peut être utilisé par des programmes on-chain ou des applications off-chain pour utiliser les données de Pyth.

Press </> button to view full source
use anchor_lang::prelude::*;
use pyth_client::{self, load_price, Price};

declare_id!("6B7XgKFmo73geJY8ZboSpLhkTumvwXeCXBpeP7nCT35w");

#[program]
pub mod pyth_test {
    use super::*;

    pub fn get_sol_price(ctx: Context<SolPrice>) -> Result<()> {
        let pyth_price_info = &ctx.accounts.pyth_account;
        let pyth_price_data = &pyth_price_info.try_borrow_data()?;
        let price_account: Price = *load_price(pyth_price_data).unwrap();

        msg!("price_account .. {:?}", pyth_price_info.key);
        msg!("price_type ... {:?}", price_account.ptype);
        msg!("price ........ {}", price_account.agg.price);

        Ok(())
    }
}

#[derive(Accounts)]
pub struct SolPrice<'info> {
    #[account(mut)]
    pub user_account: Signer<'info>,
    pub pyth_account: UncheckedAccount<'info>,
    pub system_program: UncheckedAccount<'info>,
    pub rent: Sysvar<'info, Rent>,
}

Autres Ressources

Last Updated:
Contributors: cryptoloutre