123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 |
- #![allow(unused_imports)]
- #![allow(unused_variables)]
- #![allow(unused_mut)]
- pub mod dot;
- use anchor_lang::prelude::*;
- use anchor_spl::{
- associated_token::{self, AssociatedToken},
- token::{self, Mint, Token, TokenAccount},
- };
- use dot::program::*;
- use std::{cell::RefCell, rc::Rc};
- declare_id!("2RjL4mpTANyGxz7fLWEbQtmdEDti7c4CqsLR96mgvcaV");
- pub mod seahorse_util {
- use super::*;
- #[cfg(feature = "pyth-sdk-solana")]
- pub use pyth_sdk_solana::{load_price_feed_from_account_info, PriceFeed};
- use std::{collections::HashMap, fmt::Debug, ops::Deref};
- pub struct Mutable<T>(Rc<RefCell<T>>);
- impl<T> Mutable<T> {
- pub fn new(obj: T) -> Self {
- Self(Rc::new(RefCell::new(obj)))
- }
- }
- impl<T> Clone for Mutable<T> {
- fn clone(&self) -> Self {
- Self(self.0.clone())
- }
- }
- impl<T> Deref for Mutable<T> {
- type Target = Rc<RefCell<T>>;
- fn deref(&self) -> &Self::Target {
- &self.0
- }
- }
- impl<T: Debug> Debug for Mutable<T> {
- fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
- write!(f, "{:?}", self.0)
- }
- }
- impl<T: Default> Default for Mutable<T> {
- fn default() -> Self {
- Self::new(T::default())
- }
- }
- impl<T: Clone> Mutable<Vec<T>> {
- pub fn wrapped_index(&self, mut index: i128) -> usize {
- if index >= 0 {
- return index.try_into().unwrap();
- }
- index += self.borrow().len() as i128;
- return index.try_into().unwrap();
- }
- }
- impl<T: Clone, const N: usize> Mutable<[T; N]> {
- pub fn wrapped_index(&self, mut index: i128) -> usize {
- if index >= 0 {
- return index.try_into().unwrap();
- }
- index += self.borrow().len() as i128;
- return index.try_into().unwrap();
- }
- }
- #[derive(Clone)]
- pub struct Empty<T: Clone> {
- pub account: T,
- pub bump: Option<u8>,
- }
- #[derive(Clone, Debug)]
- pub struct ProgramsMap<'info>(pub HashMap<&'static str, AccountInfo<'info>>);
- impl<'info> ProgramsMap<'info> {
- pub fn get(&self, name: &'static str) -> AccountInfo<'info> {
- self.0.get(name).unwrap().clone()
- }
- }
- #[derive(Clone, Debug)]
- pub struct WithPrograms<'info, 'entrypoint, A> {
- pub account: &'entrypoint A,
- pub programs: &'entrypoint ProgramsMap<'info>,
- }
- impl<'info, 'entrypoint, A> Deref for WithPrograms<'info, 'entrypoint, A> {
- type Target = A;
- fn deref(&self) -> &Self::Target {
- &self.account
- }
- }
- pub type SeahorseAccount<'info, 'entrypoint, A> =
- WithPrograms<'info, 'entrypoint, Box<Account<'info, A>>>;
- pub type SeahorseSigner<'info, 'entrypoint> = WithPrograms<'info, 'entrypoint, Signer<'info>>;
- #[derive(Clone, Debug)]
- pub struct CpiAccount<'info> {
- #[doc = "CHECK: CpiAccounts temporarily store AccountInfos."]
- pub account_info: AccountInfo<'info>,
- pub is_writable: bool,
- pub is_signer: bool,
- pub seeds: Option<Vec<Vec<u8>>>,
- }
- #[macro_export]
- macro_rules! seahorse_const {
- ($ name : ident , $ value : expr) => {
- macro_rules! $name {
- () => {
- $value
- };
- }
- pub(crate) use $name;
- };
- }
- #[macro_export]
- macro_rules! assign {
- ($ lval : expr , $ rval : expr) => {{
- let temp = $rval;
- $lval = temp;
- }};
- }
- #[macro_export]
- macro_rules! index_assign {
- ($ lval : expr , $ idx : expr , $ rval : expr) => {
- let temp_rval = $rval;
- let temp_idx = $idx;
- $lval[temp_idx] = temp_rval;
- };
- }
- pub(crate) use assign;
- pub(crate) use index_assign;
- pub(crate) use seahorse_const;
- }
- #[program]
- mod seahorse {
- use super::*;
- use seahorse_util::*;
- use std::collections::HashMap;
- #[derive(Accounts)]
- pub struct InitMockAccount<'info> {
- #[account(mut)]
- pub signer: Signer<'info>,
- # [account (init , space = std :: mem :: size_of :: < dot :: program :: MockAccount > () + 8 , payer = signer , seeds = ["mock_account" . as_bytes () . as_ref ()] , bump)]
- pub mock_account: Box<Account<'info, dot::program::MockAccount>>,
- pub rent: Sysvar<'info, Rent>,
- pub system_program: Program<'info, System>,
- }
- pub fn init_mock_account(ctx: Context<InitMockAccount>) -> Result<()> {
- let mut programs = HashMap::new();
- programs.insert(
- "system_program",
- ctx.accounts.system_program.to_account_info(),
- );
- let programs_map = ProgramsMap(programs);
- let signer = SeahorseSigner {
- account: &ctx.accounts.signer,
- programs: &programs_map,
- };
- let mock_account = Empty {
- account: dot::program::MockAccount::load(&mut ctx.accounts.mock_account, &programs_map),
- bump: ctx.bumps.get("mock_account").map(|bump| *bump),
- };
- init_mock_account_handler(signer.clone(), mock_account.clone());
- dot::program::MockAccount::store(mock_account.account);
- return Ok(());
- }
- #[derive(Accounts)]
- # [instruction (amount : u64)]
- pub struct TransferSolWithCpi<'info> {
- #[account(mut)]
- pub sender: Signer<'info>,
- #[account(mut)]
- pub recipient: Box<Account<'info, dot::program::MockAccount>>,
- pub system_program: Program<'info, System>,
- }
- pub fn transfer_sol_with_cpi(ctx: Context<TransferSolWithCpi>, amount: u64) -> Result<()> {
- let mut programs = HashMap::new();
- programs.insert(
- "system_program",
- ctx.accounts.system_program.to_account_info(),
- );
- let programs_map = ProgramsMap(programs);
- let sender = SeahorseSigner {
- account: &ctx.accounts.sender,
- programs: &programs_map,
- };
- let recipient = dot::program::MockAccount::load(&mut ctx.accounts.recipient, &programs_map);
- transfer_sol_with_cpi_handler(sender.clone(), recipient.clone(), amount);
- dot::program::MockAccount::store(recipient);
- return Ok(());
- }
- }
|