@kamino-finance/klend-sdk
Version:
Typescript SDK for interacting with the Kamino Lending (klend) protocol
97 lines (93 loc) • 4.31 kB
text/typescript
/* eslint-disable @typescript-eslint/no-unused-vars */
import {
Address,
isSome,
AccountMeta,
AccountSignerMeta,
Instruction,
Option,
TransactionSigner,
} from "@solana/kit"
/* eslint-enable @typescript-eslint/no-unused-vars */
import BN from "bn.js" // eslint-disable-line @typescript-eslint/no-unused-vars
import * as borsh from "@coral-xyz/borsh" // eslint-disable-line @typescript-eslint/no-unused-vars
import { borshAddress } from "../utils" // eslint-disable-line @typescript-eslint/no-unused-vars
import * as types from "../types" // eslint-disable-line @typescript-eslint/no-unused-vars
import { PROGRAM_ID } from "../programId"
export const DISCRIMINATOR = Buffer.from([102, 4, 167, 76, 131, 170, 93, 19])
export interface FillBorrowOrderAccounts {
borrowAccounts: {
payer: TransactionSigner
/** The obligation with a [BorrowOrder]. */
obligation: Address
/** The [Self::obligation]'s market - needed for borrowing-related configuration. */
lendingMarket: Address
/** The [Self::lending_market]'s authority, needed to transfer the newly-borrowed funds out of the [Self::reserve_source_liquidity]. */
lendingMarketAuthority: Address
/** The reserve to borrow from. Its mint must match the asset requested by the [BorrowOrder::debt_liquidity_mint]. */
borrowReserve: Address
/** The mint of [Self::borrow_reserve] - needed to execute the transfer. */
borrowReserveLiquidityMint: Address
/** The vault of [Self::borrow_reserve], from which the funds are transferred. */
reserveSourceLiquidity: Address
/** The fee vault of [Self::borrow_reserve], to which the fees are transferred. */
borrowReserveLiquidityFeeReceiver: Address
/** The destination token account that should receive the newly borrowed funds. It must match [BorrowOrder::filled_debt_destination], owner and mint. **Warning:** An altered destination account will prevent an order from being filled. */
userDestinationLiquidity: Address
/** The referrer's account, for accumulating fees - needed if the [Obligation::has_referrer]. */
referrerTokenState: Option<Address>
/** The token program of [Self::borrow_reserve] - needed to execute the transfer. */
tokenProgram: Address
}
farmsAccounts: {
obligationFarmUserState: Option<Address>
reserveFarmState: Option<Address>
}
farmsProgram: Address
eventAuthority: Address
program: Address
}
export function fillBorrowOrder(
accounts: FillBorrowOrderAccounts,
remainingAccounts: Array<AccountMeta | AccountSignerMeta> = [],
programAddress: Address = PROGRAM_ID
) {
const keys: Array<AccountMeta | AccountSignerMeta> = [
{
address: accounts.borrowAccounts.payer.address,
role: 2,
signer: accounts.borrowAccounts.payer,
},
{ address: accounts.borrowAccounts.obligation, role: 1 },
{ address: accounts.borrowAccounts.lendingMarket, role: 0 },
{ address: accounts.borrowAccounts.lendingMarketAuthority, role: 0 },
{ address: accounts.borrowAccounts.borrowReserve, role: 1 },
{ address: accounts.borrowAccounts.borrowReserveLiquidityMint, role: 0 },
{ address: accounts.borrowAccounts.reserveSourceLiquidity, role: 1 },
{
address: accounts.borrowAccounts.borrowReserveLiquidityFeeReceiver,
role: 1,
},
{ address: accounts.borrowAccounts.userDestinationLiquidity, role: 1 },
isSome(accounts.borrowAccounts.referrerTokenState)
? { address: accounts.borrowAccounts.referrerTokenState.value, role: 1 }
: { address: programAddress, role: 0 },
{ address: accounts.borrowAccounts.tokenProgram, role: 0 },
isSome(accounts.farmsAccounts.obligationFarmUserState)
? {
address: accounts.farmsAccounts.obligationFarmUserState.value,
role: 1,
}
: { address: programAddress, role: 0 },
isSome(accounts.farmsAccounts.reserveFarmState)
? { address: accounts.farmsAccounts.reserveFarmState.value, role: 1 }
: { address: programAddress, role: 0 },
{ address: accounts.farmsProgram, role: 0 },
{ address: accounts.eventAuthority, role: 0 },
{ address: accounts.program, role: 0 },
...remainingAccounts,
]
const data = DISCRIMINATOR
const ix: Instruction = { accounts: keys, programAddress, data }
return ix
}