Marinade.finance is a liquid staking protocol built on Solana. People stake their Solana tokens with Marinade using automatic staking strategies and receive "staked SOL" tokens they can use in the world of DeFi or to swap any time back to original SOL tokens to unstake.
This SDK wraps the staking protocol and allows you to start marinading from your applications.
Contents:
$ npm install @marinade.finance/marinade-ts-sdk
- Use the default configuration (with Solana devnet):
import { Marinade } from '@marinade.finance/marinade-ts-sdk'
const marinade = new Marinade()
or using plain HTML (do not forget to replace <VERSION>
):
<script src='https://github.com/marinade-finance/marinade-ts-sdk/releases/download/<VERSION>/marinade-ts-sdk.min.js'></script>
<script>
const { Marinade } = MarinadeSdk
const marinade = new Marinade()
</script>
- Extend your configuration with other options:
import { Marinade, MarinadeConfig, Wallet, Provider } from '@marinade.finance/marinade-ts-sdk'
const config = new MarinadeConfig({
connection: currentConnection,
pubkey: wallet.pubKey
})
const marinade = new Marinade(config)
- When you use the
referral code
, staking/unstaking functions are run against the Marinade Referral Program.
import { Marinade, MarinadeConfig } from '@marinade.finance/marinade-ts-sdk'
const MY_REFERRAL_ACCOUNT = "...." // <-- your referral account
const config = new MarinadeConfig({
connection: currentConnection,
pubkey: wallet.pubKey,
referralCode: new web3.PublicKey(MY_REFERRAL_ACCOUNT),
})
const marinade = new Marinade(config)
Stake SOL and get your mSOL:
...
const {
associatedMSolTokenAccountAddress,
transaction,
} = await marinade.deposit(amountLamports)
// sign and send the `transaction`
const signature = await provider.send(transaction)
Swap your mSOL to get back SOL immediately using the liquidity pool:
...
const {
associatedMSolTokenAccountAddress,
transaction,
} = await marinade.liquidUnstake(amountLamports)
// sign and send the `transaction`
const signature = await provider.send(transaction)
Add liquidity to the liquidity pool and receive LP tokens:
...
const {
associatedLPTokenAccountAddress,
transaction,
} = await marinade.addLiquidity(amountLamports)
// sign and send the `transaction`
const signature = await provider.send(transaction)
Burn LP tokens and get SOL and mSOL back from the liquidity pool:
...
const {
associatedLPTokenAccountAddress,
associatedMSolTokenAccountAddress,
transaction,
} = await marinade.removeLiquidity(amountLamports)
// sign and send the `transaction`
const signature = await provider.send(transaction)
For more examples have a look at Marinade TS CLI