Architecture
Architecture Overview

Account Structure
Magic-Fi's oPMM is Optimus Proactive Market Making (oPMM) contract on the Solana blockchain. This repository contains the Rust smart contract as well as the Typescript SDK (@magicfi/Magic_Fi_Solana) to interact with a deployed program.
MagicConfig
A MagicConfig is a config struct to record:
- authority: Owner of the program 
- paused: Whether the program is paused 
- Magicpool's admin authority 
- Magicoracle's admin_authority 
- Collect fee authority 
- Guardian set authority 
- Pause program authority 
MagicPool
A MagicPool is a concentrated liquidity pool for a token.
Each MagicPool account hosts the necessary information to deal with the accounting of the pool. It also hosts the PDAs to the vaults. Only the Marble oPMM program has the authority to withdraw from the vault.
A MagicPool account is hashed by the MagicConfig, token mint address and quote token mint address.
MagicOracle
A MagicOracle is an on-chain price feed in order to simulate the order book from centralized exchanges without sacrificing capital efficiency.
MagicFi in Solana uses Pyth oracle to check whether Marble oracle's price is valid.
Detail explanation can check on MagicFi Developer Portal
Fee rate
Fee rate setting stored in MagicPool's fee_rate param, can be updated by set_pool_fee_rate function by admin.
Magic-Fi's oPMM Rust Environment Setup
Magic-Fi's oPMM is Synthetic Proactive Market Making (oPMM) contract on the Solana blockchain. This repository contains the Rust smart contract as well as the Typescript SDK (@magicfi/Magic_Fi_Solana) to interact with a deployed program.
Requirements
- Anchor 0.29.0 
- Solana 1.17.31 
- Rust 1.72.0 
Setup
Set up a valid Solana keypair at the path specified in the wallet in Anchor.toml to do local testing with anchor test flows.
$NODE_PATH must be set to the node_modules directory of your global installs. For example, using Node 18.20.4 installed through nvm, the $NODE_PATH is the following:
Copy
$ echo $NODE_PATH
/Users/<home_dir>/.nvm/versions/node/v18.20.4/lib/node_modulesUsage
Tests
- Run "cargo test --lib" to run Rust unit tests 
Last updated
