Detalhes do pacote

@marinade.finance/marinade-ts-sdk

marinade-finance2.3kISC5.0.15

Marinade SDK for Typescript

solana, marinade.finance, blockchain, staking

readme (leia-me)

Marinade

marinade-ts-sdk

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.

Build

Contents:

Installation

$ npm install @marinade.finance/marinade-ts-sdk

Examples

Initialize the library

1) 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>

2) Extend your configuration with other options:

import { Marinade, MarinadeConfig, Wallet, Provider } from '@marinade.finance/marinade-ts-sdk'

const config = new MarinadeConfig({
  connection: currentConnection,
  publicKey: wallet.pubKey
})
const marinade = new Marinade(config)

3) 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,
  publicKey: wallet.pubKey,
  referralCode: new web3.PublicKey(MY_REFERRAL_ACCOUNT),
})
const marinade = new Marinade(config)

Staking

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)

Marinade Native Staking

You can now stake assets in Marinade Native through the SDK, either with or without a referral code.

Stake without referral code

If you choose to stake without a referral code, the methods exposed in marinade-native-stake.ts serve as wrappers for those already detailed in the Native Stake SDK. Please note that staking without a referral code will yield only Transaction Instructions.

Stake with referral code

To acquire a referral code, you'll need to visit the Marinade dApp to retrieve it. Once you have the code, you can input it into the methods described below. Please note that the method returns a Versioned Transaction.

Stake SOL to Marinade Native

...
const versionedTransaction = await getRefNativeStakeSOLTx(userPublicKey, amountLamports, refCode)
// sign and send the `transaction`
const signature = await wallet.sendTransaction(unsignedTx, connection)

Deposit Stake Account to Marinade Native

...
const versionedTransaction = await getRefNativeStakeAccountTx(userPublicKey, stakeAccountAddress, refCode)
// sign and send the `transaction`
const signature = await wallet.sendTransaction(versionedTransaction, connection)

Prepare for Unstake from Marinade Native

To initiate the process of unstaking, you'll need to merge your stake accounts back into a single account and pay the associated fee (in SOL). To do this, execute the following command:

...
const transaction = new Transaction()
const prepareUnstakeIx = await getPrepareNativeUnstakeSOLIx(userPublicKey, amountLamports)
transaction.add(...prepareUnstakeIx.payFees)
// sign and send the `transaction`
const signature = await wallet.sendTransaction(transaction, connection)
await authIx.onPaid()

Liquidity pool

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

Learn more

Marinade Lookup Table

Marinade lookup table address: DCcQeBaCiYsEsjjmEsSYPCr9o4n174LKqXNDvQT5wVd8

solana address-lookup-table --keypair ...
solana address-lookup-table extend --keypair ... DCcQeBaCiYsEsjjmEsSYPCr9o4n174LKqXNDvQT5wVd8 --addresses \
11111111111111111111111111111111,\
TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA,\
SysvarC1ock11111111111111111111111111111111,\
SysvarRent111111111111111111111111111111111,\
Stake11111111111111111111111111111111111111,\
MarBmsSgKXdrN1egZf5sqe1TMai9K1rChYNDJgjq7aD,\
8szGkuLTAux9XMgZ2vtY39jVSowEcpBfFfD8hXSEqdGC,\
mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So,\
UefNb6z6yvArqe4cJHTXCqStRsKmWhGxnZzuHbikP5Q,\
7GgPYjS5Dza89wV6FpZ23kUJRG5vbQ1GM25ezspYFSoE,\
EyaSjUtSgo9aRD1f8LWXwdvkpDTmXAW54yoSHZRF14WL,\
Du3Ysj1wKbxPKkuPPnvzQLQh8oMSVifs3jGZjJWXFmHN,\
3JLPCS1qM2zRw3Dp6V4hZnYHd4toMNPkNesXdX9tg6KM,\
Anv3XE7e5saNdm16MU6bniYS59Mpv7DzQXHAhxJUmAKW,\
DwFYJNnhLmw19FBTrVaLWZ8SZJpxdPoSYVSJaio9tjbY,\
J1toso1uCk3RLmjorhTtrVwY9HJ7X8V9yYac6Y7kGCPn,\
Jito4APyf642JPZPx3hGc6WWJ8zPKtRbRs4P815Awbb,\
Bcr3rbZq1g7FsPz8tawDzT6fCzN1pvADthcv3CtTpd3b,\
MariuAU5bpAbmyX21J2igSHTRF3Ah4GyERRfDBwrPYo,\
D8cy77BBepLMngZx6ZukaTff5hCt1HrWyKk3Hnd9oitf,\
9Ed78GzZrHN61XH9CkcMHFrkSMD88sPWVJCvjres46cT,\
GWvyD94pBVHqV7swFG6ASwD8BHeyeumonQ1yv6qEt3ce,\
CnUPHtfUVw3D2s4FB8H6QBuLwoes8YxauVgDtFybm7rz,\
dsNNp4g7NUv4u7GA8GqfMPCCPPxYdHk8vypbp2fbkiC,\
A8kEy5wWgdW4FG593fQJ5QPVbqx1wkfXw9c4L9bPo2CN,\
9nnLbotNTcUhvbrsA6Mdkx45Sm82G35zo28AqUvjExn8,\
So11111111111111111111111111111111111111112,\
AGcY7eBWGuLJVWc8HdamDZHBPQCn8K4ydB8pafEkcQz3,\
GkSKNXhfvhqpCrF2BqjMKoaczRXQSc8pVJai7qkmhx9V,\
JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4,\
FhLPkpFmszHtSyyayj7KsXNZeBTqfQbUPmvgWAyJHBXh,\
HxTk98CmBcxmtkrBWqRszYxrnDpqAsbitQBc2QjVBG3j,\
Dy1zNe9eqoTtVBjUbkunuJ8fFbHsMBdMxFemerFWAsKy,\
HtncvpUBGhSrs48KtC58ntJcTDw53sn78Lpq71zVwiez,\
GN3KFotCLCme8na7CTdCR9Wy6CTxHmjmHvXaLnNRKabZ,\
4VKKMz4XCyHkRYy86tGRF9ninmwVCHdxdk3dRjY3WGxc

changelog (log de mudanças)

v5.0.15

Feat:

- Expose withdraw stake account fee value from program

v5.0.14

Feat:

- Expose withdraw stake account method from program

v5.0.13

Fix:

- Bring BN division fix from @glitchful-dev/sol-apy-sdk

v5.0.12

Chore:

- Bump @solana/web3.js version

v5.0.11

Chore:

- Bump Marinade Native Stake SDK to latest update

v5.0.10

Fix:

- Remove directed vote instruction from stake transaction to prevent accidental vote reset

v5.0.9

Fix:

- Naming consistency

v5.0.8

Fix:

- Update directed stake sdk and method call
- Add warning about low liquidity on unstake via our pool

v5.0.7

Feat:

- Add method to support delayed unstake with PublicKey instead of Keypair

v5.0.6

Feat:

- IDL update coming with upgrade of liquid-staking-program contract

v5.0.5

Feat:

- Add support to stake into Marinade Native with or without Referral Code
- Add support to unstake from Marinade Native

v5.0.4

Fix:

- Make it possible to stake locked stake accounts that have the lock period in the past

v5.0.3

Feat:

- Add beta support to (partially) deposit activating stake accounts via `depositActivatingStakeAccount`
- Make `createDirectedStakeVoteIx` public so it can be used in various transactions (like when swapping LSTs via Jup)
- Add setup to run integration tests on local validator within the pipeline
- Add beta support to partially deposit stake accounts via `partiallyDepositStakeAccount`
- Add beta support to partially liquidate stake accounts via `partiallyLiquidateStakeAccount`

v5.0.2

Fix:

- Update missing refactor change for `addLiquidity` that would cause this method to be unusable

v5.0.1

Feat:

- Created Marinade Address lookup table at `DCcQeBaCiYsEsjjmEsSYPCr9o4n174LKqXNDvQT5wVd8`
- Add beta support to deposit Stake Pool Tokens to mSOL via `depositStakePoolToken`
- Add beta support to liquidate Stake Pool Tokens via `liquidateStakePoolToken`
- Add delayed unstake support in SDK via `orderUnstake`
- Add claim tickets support in SDK via `claim`
- Add support to retrieve user Directed stake vote via `getUsersVoteRecord`

Chore:

- More house work on improving the codebase
- Migrate to `pnpm`

v5.0.0

Feat:

- Add support for Directed stake on all stake methods (both from SOL and stake accounts)
- Add support to deposit deactivating stake accounts via `depositStakeAccountByAccount`
- Add same contract checks in the SDK for stake accounts on `depositStakeAccountByAccount`

Chore:

- House work on using dependencies and IDLs

v4.0.6

Fix:

- Adjust `liquidateStakeAccount` to use the right amounts

Chore:

- Small house work on descriptions/methods

v4.0.5

Fix:

- Claim extra lamports when staking/liquidating stake accounts (most common case: these stake accounts have extra lamports from MEV rewards)

Chore:

- Update `spl-token` library and refactor code accordingly

v4.0.3

Feat:

- Add support to retrieve all referral partners

v4.0.2

Fix incorrect mSOL amount calculation in function liquidateStakeAccount, when using a referral code

v4.0.1

Fix incorrect mSOL amount calculation in function liquidateStakeAccount, when using a referral code

v4.0.0

Uses Referral-Program V2