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
use borsh::{ BorshDeserialize };
use solana_program::{
account_info::{ AccountInfo },
program_error::ProgramError,
pubkey::Pubkey,
borsh::try_from_slice_unchecked,
};
use std::str::FromStr;
#[derive(BorshDeserialize)]
pub struct Report {
pub magic: u64,
pub bump: u8,
pub active: bool,
pub process: Pubkey,
pub info: ReportInfo,
}
#[derive(BorshDeserialize)]
pub struct ReportInfo {
pub source_chain: u32,
pub price: u64,
pub risk: u64,
pub time: u64,
pub decimal: u64,
pub program_addr: Pubkey,
pub token_addr: Pubkey,
pub local_addr: Pubkey,
pub name: String,
pub price_type: String,
}
fn check_owner(owner: &Pubkey) -> bool {
let oracle_program_id = Pubkey::from_str("BorcZEiGQJAL62M9QotWAvZYGkymuVnf42mj5HYnLZQj").unwrap();
owner.eq(&oracle_program_id)
}
pub fn get_report_info(account_info: &AccountInfo) -> Result<ReportInfo, ProgramError> {
if !check_owner(account_info.owner) {
return Err(ProgramError::IllegalOwner);
}
let report: Report = try_from_slice_unchecked(&account_info.data.borrow())?;
if !report.active {
return Err(ProgramError::InvalidAccountData);
}
Ok(report.info)
}