@kamino-finance/klend-sdk 7.3.4 → 7.3.5-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-5DIL2ZCI.js +373 -0
- package/dist/chunk-5DIL2ZCI.js.map +1 -0
- package/dist/chunk-5RQOM3VO.js +1628 -0
- package/dist/chunk-5RQOM3VO.js.map +1 -0
- package/dist/chunk-GXZYS537.cjs +1630 -0
- package/dist/chunk-GXZYS537.cjs.map +1 -0
- package/dist/chunk-I7IRKIKG.cjs +35167 -0
- package/dist/chunk-I7IRKIKG.cjs.map +1 -0
- package/dist/chunk-K2DZLHPZ.cjs +4573 -0
- package/dist/chunk-K2DZLHPZ.cjs.map +1 -0
- package/dist/chunk-MR7WEZXN.cjs +398 -0
- package/dist/chunk-MR7WEZXN.cjs.map +1 -0
- package/dist/chunk-NNIHRGXK.js +34815 -0
- package/dist/chunk-NNIHRGXK.js.map +1 -0
- package/dist/chunk-O7I5CWRX.cjs +44 -0
- package/dist/chunk-O7I5CWRX.cjs.map +1 -0
- package/dist/chunk-OCDAUWFE.js +4456 -0
- package/dist/chunk-OCDAUWFE.js.map +1 -0
- package/dist/chunk-PR4QN5HX.js +39 -0
- package/dist/chunk-PR4QN5HX.js.map +1 -0
- package/dist/core.cjs +1504 -0
- package/dist/core.cjs.map +1 -0
- package/dist/core.d.cts +5629 -0
- package/dist/core.d.ts +5629 -0
- package/dist/core.js +7 -0
- package/dist/core.js.map +1 -0
- package/dist/errors.cjs +2523 -0
- package/dist/errors.cjs.map +1 -0
- package/dist/errors.d.cts +1888 -0
- package/dist/errors.d.ts +1888 -0
- package/dist/errors.js +2520 -0
- package/dist/errors.js.map +1 -0
- package/dist/fraction-BeFnhBaY.d.cts +5830 -0
- package/dist/fraction-BeFnhBaY.d.ts +5830 -0
- package/dist/index.cjs +1564 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +590 -0
- package/dist/index.d.ts +590 -2
- package/dist/index.js +6 -17
- package/dist/index.js.map +1 -1
- package/dist/jupiter-perps.cjs +14 -0
- package/dist/jupiter-perps.cjs.map +1 -0
- package/dist/jupiter-perps.d.cts +5 -0
- package/dist/jupiter-perps.d.ts +5 -0
- package/dist/jupiter-perps.js +5 -0
- package/dist/jupiter-perps.js.map +1 -0
- package/dist/oracle.cjs +130 -0
- package/dist/oracle.cjs.map +1 -0
- package/dist/oracle.d.cts +2478 -0
- package/dist/oracle.d.ts +2478 -0
- package/dist/oracle.js +5 -0
- package/dist/oracle.js.map +1 -0
- package/dist/standardStakePool-BXdhOcOo.d.cts +78 -0
- package/dist/standardStakePool-BXdhOcOo.d.ts +78 -0
- package/dist/unstaking-pool.cjs +56 -0
- package/dist/unstaking-pool.cjs.map +1 -0
- package/dist/unstaking-pool.d.cts +221 -0
- package/dist/unstaking-pool.d.ts +221 -0
- package/dist/unstaking-pool.js +7 -0
- package/dist/unstaking-pool.js.map +1 -0
- package/package.json +43 -6
- package/src/core.ts +97 -0
- package/src/errors.ts +11 -0
- package/src/jupiter-perps.ts +7 -0
- package/src/oracle.ts +18 -0
- package/src/unstaking-pool.ts +9 -0
- package/dist/@codegen/jupiter_perps/accounts/Custody.d.ts +0 -57
- package/dist/@codegen/jupiter_perps/accounts/Custody.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Custody.js +0 -176
- package/dist/@codegen/jupiter_perps/accounts/Custody.js.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Perpetuals.d.ts +0 -36
- package/dist/@codegen/jupiter_perps/accounts/Perpetuals.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Perpetuals.js +0 -132
- package/dist/@codegen/jupiter_perps/accounts/Perpetuals.js.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Pool.d.ts +0 -48
- package/dist/@codegen/jupiter_perps/accounts/Pool.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Pool.js +0 -156
- package/dist/@codegen/jupiter_perps/accounts/Pool.js.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Position.d.ts +0 -60
- package/dist/@codegen/jupiter_perps/accounts/Position.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/Position.js +0 -180
- package/dist/@codegen/jupiter_perps/accounts/Position.js.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/PositionRequest.d.ts +0 -84
- package/dist/@codegen/jupiter_perps/accounts/PositionRequest.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/PositionRequest.js +0 -228
- package/dist/@codegen/jupiter_perps/accounts/PositionRequest.js.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/TestOracle.d.ts +0 -29
- package/dist/@codegen/jupiter_perps/accounts/TestOracle.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/TestOracle.js +0 -118
- package/dist/@codegen/jupiter_perps/accounts/TestOracle.js.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/index.d.ts +0 -13
- package/dist/@codegen/jupiter_perps/accounts/index.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/accounts/index.js +0 -16
- package/dist/@codegen/jupiter_perps/accounts/index.js.map +0 -1
- package/dist/@codegen/jupiter_perps/errors/anchor.d.ts +0 -435
- package/dist/@codegen/jupiter_perps/errors/anchor.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/errors/anchor.js +0 -767
- package/dist/@codegen/jupiter_perps/errors/anchor.js.map +0 -1
- package/dist/@codegen/jupiter_perps/errors/custom.d.ts +0 -339
- package/dist/@codegen/jupiter_perps/errors/custom.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/errors/custom.js +0 -598
- package/dist/@codegen/jupiter_perps/errors/custom.js.map +0 -1
- package/dist/@codegen/jupiter_perps/errors/index.d.ts +0 -6
- package/dist/@codegen/jupiter_perps/errors/index.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/errors/index.js +0 -86
- package/dist/@codegen/jupiter_perps/errors/index.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/addCustody.d.ts +0 -21
- package/dist/@codegen/jupiter_perps/instructions/addCustody.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/addCustody.js +0 -67
- package/dist/@codegen/jupiter_perps/instructions/addCustody.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/addLiquidity.d.ts +0 -24
- package/dist/@codegen/jupiter_perps/instructions/addLiquidity.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/addLiquidity.js +0 -70
- package/dist/@codegen/jupiter_perps/instructions/addLiquidity.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/addPool.d.ts +0 -19
- package/dist/@codegen/jupiter_perps/instructions/addPool.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/addPool.js +0 -65
- package/dist/@codegen/jupiter_perps/instructions/addPool.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/closePositionRequest.d.ts +0 -21
- package/dist/@codegen/jupiter_perps/instructions/closePositionRequest.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/closePositionRequest.js +0 -77
- package/dist/@codegen/jupiter_perps/instructions/closePositionRequest.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/createDecreasePositionRequest.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/instructions/createDecreasePositionRequest.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/createDecreasePositionRequest.js +0 -78
- package/dist/@codegen/jupiter_perps/instructions/createDecreasePositionRequest.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/createIncreasePositionRequest.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/instructions/createIncreasePositionRequest.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/createIncreasePositionRequest.js +0 -78
- package/dist/@codegen/jupiter_perps/instructions/createIncreasePositionRequest.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/decreasePosition.d.ts +0 -29
- package/dist/@codegen/jupiter_perps/instructions/decreasePosition.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/decreasePosition.js +0 -79
- package/dist/@codegen/jupiter_perps/instructions/decreasePosition.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/decreasePositionPostSwap.d.ts +0 -16
- package/dist/@codegen/jupiter_perps/instructions/decreasePositionPostSwap.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/decreasePositionPostSwap.js +0 -62
- package/dist/@codegen/jupiter_perps/instructions/decreasePositionPostSwap.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getAddLiquidityAmountAndFee.d.ts +0 -16
- package/dist/@codegen/jupiter_perps/instructions/getAddLiquidityAmountAndFee.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getAddLiquidityAmountAndFee.js +0 -64
- package/dist/@codegen/jupiter_perps/instructions/getAddLiquidityAmountAndFee.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getDecreasePosition.d.ts +0 -18
- package/dist/@codegen/jupiter_perps/instructions/getDecreasePosition.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getDecreasePosition.js +0 -64
- package/dist/@codegen/jupiter_perps/instructions/getDecreasePosition.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getExactOutSwapAmountAndFees.d.ts +0 -17
- package/dist/@codegen/jupiter_perps/instructions/getExactOutSwapAmountAndFees.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getExactOutSwapAmountAndFees.js +0 -63
- package/dist/@codegen/jupiter_perps/instructions/getExactOutSwapAmountAndFees.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getIncreasePosition.d.ts +0 -18
- package/dist/@codegen/jupiter_perps/instructions/getIncreasePosition.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getIncreasePosition.js +0 -68
- package/dist/@codegen/jupiter_perps/instructions/getIncreasePosition.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getLiquidationState.d.ts +0 -17
- package/dist/@codegen/jupiter_perps/instructions/getLiquidationState.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getLiquidationState.js +0 -63
- package/dist/@codegen/jupiter_perps/instructions/getLiquidationState.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getOraclePrice.d.ts +0 -10
- package/dist/@codegen/jupiter_perps/instructions/getOraclePrice.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getOraclePrice.js +0 -19
- package/dist/@codegen/jupiter_perps/instructions/getOraclePrice.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getPnl.d.ts +0 -17
- package/dist/@codegen/jupiter_perps/instructions/getPnl.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getPnl.js +0 -63
- package/dist/@codegen/jupiter_perps/instructions/getPnl.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getRemoveLiquidityAmountAndFee.d.ts +0 -16
- package/dist/@codegen/jupiter_perps/instructions/getRemoveLiquidityAmountAndFee.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getRemoveLiquidityAmountAndFee.js +0 -62
- package/dist/@codegen/jupiter_perps/instructions/getRemoveLiquidityAmountAndFee.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getSwapAmountAndFees.d.ts +0 -17
- package/dist/@codegen/jupiter_perps/instructions/getSwapAmountAndFees.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/getSwapAmountAndFees.js +0 -63
- package/dist/@codegen/jupiter_perps/instructions/getSwapAmountAndFees.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/increasePosition.d.ts +0 -25
- package/dist/@codegen/jupiter_perps/instructions/increasePosition.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/increasePosition.js +0 -71
- package/dist/@codegen/jupiter_perps/instructions/increasePosition.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/increasePositionPreSwap.d.ts +0 -22
- package/dist/@codegen/jupiter_perps/instructions/increasePositionPreSwap.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/increasePositionPreSwap.js +0 -68
- package/dist/@codegen/jupiter_perps/instructions/increasePositionPreSwap.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/index.d.ts +0 -71
- package/dist/@codegen/jupiter_perps/instructions/index.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/index.js +0 -74
- package/dist/@codegen/jupiter_perps/instructions/index.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/init.d.ts +0 -19
- package/dist/@codegen/jupiter_perps/instructions/init.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/init.js +0 -69
- package/dist/@codegen/jupiter_perps/instructions/init.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/liquidatePosition.d.ts +0 -26
- package/dist/@codegen/jupiter_perps/instructions/liquidatePosition.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/liquidatePosition.js +0 -72
- package/dist/@codegen/jupiter_perps/instructions/liquidatePosition.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/removeLiquidity.d.ts +0 -24
- package/dist/@codegen/jupiter_perps/instructions/removeLiquidity.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/removeLiquidity.js +0 -70
- package/dist/@codegen/jupiter_perps/instructions/removeLiquidity.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setCustodyConfig.d.ts +0 -14
- package/dist/@codegen/jupiter_perps/instructions/setCustodyConfig.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setCustodyConfig.js +0 -60
- package/dist/@codegen/jupiter_perps/instructions/setCustodyConfig.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setCustodyGlobalLimit.d.ts +0 -13
- package/dist/@codegen/jupiter_perps/instructions/setCustodyGlobalLimit.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setCustodyGlobalLimit.js +0 -59
- package/dist/@codegen/jupiter_perps/instructions/setCustodyGlobalLimit.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setPerpetualsConfig.d.ts +0 -13
- package/dist/@codegen/jupiter_perps/instructions/setPerpetualsConfig.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setPerpetualsConfig.js +0 -59
- package/dist/@codegen/jupiter_perps/instructions/setPerpetualsConfig.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setPoolConfig.d.ts +0 -14
- package/dist/@codegen/jupiter_perps/instructions/setPoolConfig.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setPoolConfig.js +0 -60
- package/dist/@codegen/jupiter_perps/instructions/setPoolConfig.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setTestOraclePrice.d.ts +0 -17
- package/dist/@codegen/jupiter_perps/instructions/setTestOraclePrice.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setTestOraclePrice.js +0 -63
- package/dist/@codegen/jupiter_perps/instructions/setTestOraclePrice.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setTestTime.d.ts +0 -13
- package/dist/@codegen/jupiter_perps/instructions/setTestTime.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/setTestTime.js +0 -61
- package/dist/@codegen/jupiter_perps/instructions/setTestTime.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/swap.d.ts +0 -26
- package/dist/@codegen/jupiter_perps/instructions/swap.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/swap.js +0 -74
- package/dist/@codegen/jupiter_perps/instructions/swap.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/swapExactOut.d.ts +0 -26
- package/dist/@codegen/jupiter_perps/instructions/swapExactOut.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/swapExactOut.js +0 -72
- package/dist/@codegen/jupiter_perps/instructions/swapExactOut.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/testInit.d.ts +0 -17
- package/dist/@codegen/jupiter_perps/instructions/testInit.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/testInit.js +0 -67
- package/dist/@codegen/jupiter_perps/instructions/testInit.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/transferAdmin.d.ts +0 -14
- package/dist/@codegen/jupiter_perps/instructions/transferAdmin.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/transferAdmin.js +0 -60
- package/dist/@codegen/jupiter_perps/instructions/transferAdmin.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/updateDecreasePositionRequest.d.ts +0 -18
- package/dist/@codegen/jupiter_perps/instructions/updateDecreasePositionRequest.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/updateDecreasePositionRequest.js +0 -64
- package/dist/@codegen/jupiter_perps/instructions/updateDecreasePositionRequest.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/updateIncreasePositionRequest.d.ts +0 -18
- package/dist/@codegen/jupiter_perps/instructions/updateIncreasePositionRequest.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/updateIncreasePositionRequest.js +0 -64
- package/dist/@codegen/jupiter_perps/instructions/updateIncreasePositionRequest.js.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/withdrawFees.d.ts +0 -20
- package/dist/@codegen/jupiter_perps/instructions/withdrawFees.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/instructions/withdrawFees.js +0 -68
- package/dist/@codegen/jupiter_perps/instructions/withdrawFees.js.map +0 -1
- package/dist/@codegen/jupiter_perps/programId.d.ts +0 -4
- package/dist/@codegen/jupiter_perps/programId.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/programId.js +0 -9
- package/dist/@codegen/jupiter_perps/programId.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AddCustodyParams.d.ts +0 -101
- package/dist/@codegen/jupiter_perps/types/AddCustodyParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AddCustodyParams.js +0 -114
- package/dist/@codegen/jupiter_perps/types/AddCustodyParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AddLiquidityParams.d.ts +0 -33
- package/dist/@codegen/jupiter_perps/types/AddLiquidityParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AddLiquidityParams.js +0 -92
- package/dist/@codegen/jupiter_perps/types/AddLiquidityParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AddPoolParams.d.ts +0 -66
- package/dist/@codegen/jupiter_perps/types/AddPoolParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AddPoolParams.js +0 -100
- package/dist/@codegen/jupiter_perps/types/AddPoolParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AmountAndFee.d.ts +0 -33
- package/dist/@codegen/jupiter_perps/types/AmountAndFee.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/AmountAndFee.js +0 -88
- package/dist/@codegen/jupiter_perps/types/AmountAndFee.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Assets.d.ts +0 -48
- package/dist/@codegen/jupiter_perps/types/Assets.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Assets.js +0 -113
- package/dist/@codegen/jupiter_perps/types/Assets.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/ClosePositionRequestParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/ClosePositionRequestParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/ClosePositionRequestParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/ClosePositionRequestParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/CreateDecreasePositionRequestParams.d.ts +0 -71
- package/dist/@codegen/jupiter_perps/types/CreateDecreasePositionRequestParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/CreateDecreasePositionRequestParams.js +0 -135
- package/dist/@codegen/jupiter_perps/types/CreateDecreasePositionRequestParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/CreateIncreasePositionRequestParams.d.ts +0 -83
- package/dist/@codegen/jupiter_perps/types/CreateIncreasePositionRequestParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/CreateIncreasePositionRequestParams.js +0 -135
- package/dist/@codegen/jupiter_perps/types/CreateIncreasePositionRequestParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/DecreasePositionInfo.d.ts +0 -58
- package/dist/@codegen/jupiter_perps/types/DecreasePositionInfo.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/DecreasePositionInfo.js +0 -127
- package/dist/@codegen/jupiter_perps/types/DecreasePositionInfo.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/DecreasePositionParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/DecreasePositionParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/DecreasePositionParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/DecreasePositionParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/DecreasePositionPostSwapParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/DecreasePositionPostSwapParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/DecreasePositionPostSwapParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/DecreasePositionPostSwapParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Fees.d.ts +0 -63
- package/dist/@codegen/jupiter_perps/types/Fees.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Fees.js +0 -134
- package/dist/@codegen/jupiter_perps/types/Fees.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/FundingRateState.d.ts +0 -33
- package/dist/@codegen/jupiter_perps/types/FundingRateState.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/FundingRateState.js +0 -92
- package/dist/@codegen/jupiter_perps/types/FundingRateState.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetAddLiquidityAmountAndFeeParams.d.ts +0 -23
- package/dist/@codegen/jupiter_perps/types/GetAddLiquidityAmountAndFeeParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetAddLiquidityAmountAndFeeParams.js +0 -76
- package/dist/@codegen/jupiter_perps/types/GetAddLiquidityAmountAndFeeParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetDecreasePositionParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/GetDecreasePositionParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetDecreasePositionParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/GetDecreasePositionParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetExactOutSwapAmountAndFeesParams.d.ts +0 -23
- package/dist/@codegen/jupiter_perps/types/GetExactOutSwapAmountAndFeesParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetExactOutSwapAmountAndFeesParams.js +0 -76
- package/dist/@codegen/jupiter_perps/types/GetExactOutSwapAmountAndFeesParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetIncreasePositionParams.d.ts +0 -45
- package/dist/@codegen/jupiter_perps/types/GetIncreasePositionParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetIncreasePositionParams.js +0 -93
- package/dist/@codegen/jupiter_perps/types/GetIncreasePositionParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetLiquidationStateParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/GetLiquidationStateParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetLiquidationStateParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/GetLiquidationStateParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetPnlAndFeeParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/GetPnlAndFeeParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetPnlAndFeeParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/GetPnlAndFeeParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetRemoveLiquidityAmountAndFeeParams.d.ts +0 -23
- package/dist/@codegen/jupiter_perps/types/GetRemoveLiquidityAmountAndFeeParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetRemoveLiquidityAmountAndFeeParams.js +0 -76
- package/dist/@codegen/jupiter_perps/types/GetRemoveLiquidityAmountAndFeeParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetSwapAmountAndFeesParams.d.ts +0 -23
- package/dist/@codegen/jupiter_perps/types/GetSwapAmountAndFeesParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/GetSwapAmountAndFeesParams.js +0 -76
- package/dist/@codegen/jupiter_perps/types/GetSwapAmountAndFeesParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/IncreasePositionInfo.d.ts +0 -38
- package/dist/@codegen/jupiter_perps/types/IncreasePositionInfo.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/IncreasePositionInfo.js +0 -99
- package/dist/@codegen/jupiter_perps/types/IncreasePositionInfo.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/IncreasePositionParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/IncreasePositionParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/IncreasePositionParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/IncreasePositionParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/IncreasePositionPreSwapParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/IncreasePositionPreSwapParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/IncreasePositionPreSwapParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/IncreasePositionPreSwapParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/InitParams.d.ts +0 -52
- package/dist/@codegen/jupiter_perps/types/InitParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/InitParams.js +0 -116
- package/dist/@codegen/jupiter_perps/types/InitParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Limit.d.ts +0 -33
- package/dist/@codegen/jupiter_perps/types/Limit.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Limit.js +0 -92
- package/dist/@codegen/jupiter_perps/types/Limit.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/LiquidatePositionParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/LiquidatePositionParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/LiquidatePositionParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/LiquidatePositionParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OracleParams.d.ts +0 -51
- package/dist/@codegen/jupiter_perps/types/OracleParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OracleParams.js +0 -102
- package/dist/@codegen/jupiter_perps/types/OracleParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OraclePrice.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/OraclePrice.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OraclePrice.js +0 -82
- package/dist/@codegen/jupiter_perps/types/OraclePrice.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OraclePriceInfo.d.ts +0 -48
- package/dist/@codegen/jupiter_perps/types/OraclePriceInfo.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OraclePriceInfo.js +0 -113
- package/dist/@codegen/jupiter_perps/types/OraclePriceInfo.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OracleType.d.ts +0 -45
- package/dist/@codegen/jupiter_perps/types/OracleType.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/OracleType.js +0 -132
- package/dist/@codegen/jupiter_perps/types/OracleType.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Permissions.d.ts +0 -52
- package/dist/@codegen/jupiter_perps/types/Permissions.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Permissions.js +0 -116
- package/dist/@codegen/jupiter_perps/types/Permissions.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PnlAndFee.d.ts +0 -48
- package/dist/@codegen/jupiter_perps/types/PnlAndFee.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PnlAndFee.js +0 -113
- package/dist/@codegen/jupiter_perps/types/PnlAndFee.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PoolApr.d.ts +0 -33
- package/dist/@codegen/jupiter_perps/types/PoolApr.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PoolApr.js +0 -92
- package/dist/@codegen/jupiter_perps/types/PoolApr.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PriceCalcMode.d.ts +0 -45
- package/dist/@codegen/jupiter_perps/types/PriceCalcMode.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PriceCalcMode.js +0 -132
- package/dist/@codegen/jupiter_perps/types/PriceCalcMode.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PricingParams.d.ts +0 -48
- package/dist/@codegen/jupiter_perps/types/PricingParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/PricingParams.js +0 -113
- package/dist/@codegen/jupiter_perps/types/PricingParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/RemoveLiquidityParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/RemoveLiquidityParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/RemoveLiquidityParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/RemoveLiquidityParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/RequestChange.d.ts +0 -45
- package/dist/@codegen/jupiter_perps/types/RequestChange.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/RequestChange.js +0 -132
- package/dist/@codegen/jupiter_perps/types/RequestChange.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/RequestType.d.ts +0 -32
- package/dist/@codegen/jupiter_perps/types/RequestType.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/RequestType.js +0 -108
- package/dist/@codegen/jupiter_perps/types/RequestType.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetCustodyConfigParams.d.ts +0 -96
- package/dist/@codegen/jupiter_perps/types/SetCustodyConfigParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetCustodyConfigParams.js +0 -107
- package/dist/@codegen/jupiter_perps/types/SetCustodyConfigParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetCustodyGlobalLimitParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/SetCustodyGlobalLimitParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetCustodyGlobalLimitParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/SetCustodyGlobalLimitParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetPerpetualsConfigParams.d.ts +0 -38
- package/dist/@codegen/jupiter_perps/types/SetPerpetualsConfigParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetPerpetualsConfigParams.js +0 -73
- package/dist/@codegen/jupiter_perps/types/SetPerpetualsConfigParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetPoolConfigParams.d.ts +0 -61
- package/dist/@codegen/jupiter_perps/types/SetPoolConfigParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetPoolConfigParams.js +0 -93
- package/dist/@codegen/jupiter_perps/types/SetPoolConfigParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetTestOraclePriceParams.d.ts +0 -38
- package/dist/@codegen/jupiter_perps/types/SetTestOraclePriceParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetTestOraclePriceParams.js +0 -99
- package/dist/@codegen/jupiter_perps/types/SetTestOraclePriceParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetTestTimeParams.d.ts +0 -23
- package/dist/@codegen/jupiter_perps/types/SetTestTimeParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SetTestTimeParams.js +0 -76
- package/dist/@codegen/jupiter_perps/types/SetTestTimeParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Side.d.ts +0 -45
- package/dist/@codegen/jupiter_perps/types/Side.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/Side.js +0 -132
- package/dist/@codegen/jupiter_perps/types/Side.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SwapAmountAndFees.d.ts +0 -38
- package/dist/@codegen/jupiter_perps/types/SwapAmountAndFees.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SwapAmountAndFees.js +0 -99
- package/dist/@codegen/jupiter_perps/types/SwapAmountAndFees.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SwapExactOutParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/SwapExactOutParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SwapExactOutParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/SwapExactOutParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SwapParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/SwapParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/SwapParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/SwapParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/TestInitParams.d.ts +0 -52
- package/dist/@codegen/jupiter_perps/types/TestInitParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/TestInitParams.js +0 -116
- package/dist/@codegen/jupiter_perps/types/TestInitParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/TransferAdminParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/TransferAdminParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/TransferAdminParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/TransferAdminParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/UpdateDecreasePositionRequestParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/UpdateDecreasePositionRequestParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/UpdateDecreasePositionRequestParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/UpdateDecreasePositionRequestParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/UpdateIncreasePositionRequestParams.d.ts +0 -28
- package/dist/@codegen/jupiter_perps/types/UpdateIncreasePositionRequestParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/UpdateIncreasePositionRequestParams.js +0 -82
- package/dist/@codegen/jupiter_perps/types/UpdateIncreasePositionRequestParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/WithdrawFeesParams.d.ts +0 -15
- package/dist/@codegen/jupiter_perps/types/WithdrawFeesParams.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/WithdrawFeesParams.js +0 -61
- package/dist/@codegen/jupiter_perps/types/WithdrawFeesParams.js.map +0 -1
- package/dist/@codegen/jupiter_perps/types/index.d.ts +0 -119
- package/dist/@codegen/jupiter_perps/types/index.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/types/index.js +0 -146
- package/dist/@codegen/jupiter_perps/types/index.js.map +0 -1
- package/dist/@codegen/jupiter_perps/utils/borshAddress.d.ts +0 -4
- package/dist/@codegen/jupiter_perps/utils/borshAddress.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/utils/borshAddress.js +0 -30
- package/dist/@codegen/jupiter_perps/utils/borshAddress.js.map +0 -1
- package/dist/@codegen/jupiter_perps/utils/index.d.ts +0 -2
- package/dist/@codegen/jupiter_perps/utils/index.d.ts.map +0 -1
- package/dist/@codegen/jupiter_perps/utils/index.js +0 -18
- package/dist/@codegen/jupiter_perps/utils/index.js.map +0 -1
- package/dist/@codegen/klend/accounts/GlobalConfig.d.ts +0 -40
- package/dist/@codegen/klend/accounts/GlobalConfig.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/GlobalConfig.js +0 -118
- package/dist/@codegen/klend/accounts/GlobalConfig.js.map +0 -1
- package/dist/@codegen/klend/accounts/LendingMarket.d.ts +0 -285
- package/dist/@codegen/klend/accounts/LendingMarket.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/LendingMarket.js +0 -358
- package/dist/@codegen/klend/accounts/LendingMarket.js.map +0 -1
- package/dist/@codegen/klend/accounts/Obligation.d.ts +0 -199
- package/dist/@codegen/klend/accounts/Obligation.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/Obligation.js +0 -295
- package/dist/@codegen/klend/accounts/Obligation.js.map +0 -1
- package/dist/@codegen/klend/accounts/ReferrerState.d.ts +0 -22
- package/dist/@codegen/klend/accounts/ReferrerState.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/ReferrerState.js +0 -102
- package/dist/@codegen/klend/accounts/ReferrerState.js.map +0 -1
- package/dist/@codegen/klend/accounts/ReferrerTokenState.d.ts +0 -51
- package/dist/@codegen/klend/accounts/ReferrerTokenState.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/ReferrerTokenState.js +0 -137
- package/dist/@codegen/klend/accounts/ReferrerTokenState.js.map +0 -1
- package/dist/@codegen/klend/accounts/Reserve.d.ts +0 -90
- package/dist/@codegen/klend/accounts/Reserve.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/Reserve.js +0 -192
- package/dist/@codegen/klend/accounts/Reserve.js.map +0 -1
- package/dist/@codegen/klend/accounts/ShortUrl.d.ts +0 -22
- package/dist/@codegen/klend/accounts/ShortUrl.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/ShortUrl.js +0 -102
- package/dist/@codegen/klend/accounts/ShortUrl.js.map +0 -1
- package/dist/@codegen/klend/accounts/UserMetadata.d.ts +0 -48
- package/dist/@codegen/klend/accounts/UserMetadata.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/UserMetadata.js +0 -136
- package/dist/@codegen/klend/accounts/UserMetadata.js.map +0 -1
- package/dist/@codegen/klend/accounts/UserState.d.ts +0 -143
- package/dist/@codegen/klend/accounts/UserState.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/UserState.js +0 -222
- package/dist/@codegen/klend/accounts/UserState.js.map +0 -1
- package/dist/@codegen/klend/accounts/index.d.ts +0 -19
- package/dist/@codegen/klend/accounts/index.d.ts.map +0 -1
- package/dist/@codegen/klend/accounts/index.js +0 -22
- package/dist/@codegen/klend/accounts/index.js.map +0 -1
- package/dist/@codegen/klend/errors/anchor.d.ts +0 -435
- package/dist/@codegen/klend/errors/anchor.d.ts.map +0 -1
- package/dist/@codegen/klend/errors/anchor.js +0 -767
- package/dist/@codegen/klend/errors/anchor.js.map +0 -1
- package/dist/@codegen/klend/errors/custom.d.ts +0 -1067
- package/dist/@codegen/klend/errors/custom.d.ts.map +0 -1
- package/dist/@codegen/klend/errors/custom.js +0 -1874
- package/dist/@codegen/klend/errors/custom.js.map +0 -1
- package/dist/@codegen/klend/errors/index.d.ts +0 -6
- package/dist/@codegen/klend/errors/index.d.ts.map +0 -1
- package/dist/@codegen/klend/errors/index.js +0 -86
- package/dist/@codegen/klend/errors/index.js.map +0 -1
- package/dist/@codegen/klend/instructions/borrowObligationLiquidity.d.ts +0 -23
- package/dist/@codegen/klend/instructions/borrowObligationLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/borrowObligationLiquidity.js +0 -72
- package/dist/@codegen/klend/instructions/borrowObligationLiquidity.js.map +0 -1
- package/dist/@codegen/klend/instructions/borrowObligationLiquidityV2.d.ts +0 -30
- package/dist/@codegen/klend/instructions/borrowObligationLiquidityV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/borrowObligationLiquidityV2.js +0 -89
- package/dist/@codegen/klend/instructions/borrowObligationLiquidityV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/deleteReferrerStateAndShortUrl.d.ts +0 -11
- package/dist/@codegen/klend/instructions/deleteReferrerStateAndShortUrl.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/deleteReferrerStateAndShortUrl.js +0 -20
- package/dist/@codegen/klend/instructions/deleteReferrerStateAndShortUrl.js.map +0 -1
- package/dist/@codegen/klend/instructions/depositAndWithdraw.d.ts +0 -53
- package/dist/@codegen/klend/instructions/depositAndWithdraw.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/depositAndWithdraw.js +0 -135
- package/dist/@codegen/klend/instructions/depositAndWithdraw.js.map +0 -1
- package/dist/@codegen/klend/instructions/depositObligationCollateral.d.ts +0 -19
- package/dist/@codegen/klend/instructions/depositObligationCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/depositObligationCollateral.js +0 -64
- package/dist/@codegen/klend/instructions/depositObligationCollateral.js.map +0 -1
- package/dist/@codegen/klend/instructions/depositObligationCollateralV2.d.ts +0 -27
- package/dist/@codegen/klend/instructions/depositObligationCollateralV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/depositObligationCollateralV2.js +0 -81
- package/dist/@codegen/klend/instructions/depositObligationCollateralV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/depositReserveLiquidity.d.ts +0 -23
- package/dist/@codegen/klend/instructions/depositReserveLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/depositReserveLiquidity.js +0 -68
- package/dist/@codegen/klend/instructions/depositReserveLiquidity.js.map +0 -1
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateral.d.ts +0 -25
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateral.js +0 -77
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateral.js.map +0 -1
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateralV2.d.ts +0 -32
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateralV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateralV2.js +0 -96
- package/dist/@codegen/klend/instructions/depositReserveLiquidityAndObligationCollateralV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/flashBorrowReserveLiquidity.d.ts +0 -23
- package/dist/@codegen/klend/instructions/flashBorrowReserveLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/flashBorrowReserveLiquidity.js +0 -78
- package/dist/@codegen/klend/instructions/flashBorrowReserveLiquidity.js.map +0 -1
- package/dist/@codegen/klend/instructions/flashRepayReserveLiquidity.d.ts +0 -24
- package/dist/@codegen/klend/instructions/flashRepayReserveLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/flashRepayReserveLiquidity.js +0 -80
- package/dist/@codegen/klend/instructions/flashRepayReserveLiquidity.js.map +0 -1
- package/dist/@codegen/klend/instructions/idlMissingTypes.d.ts +0 -21
- package/dist/@codegen/klend/instructions/idlMissingTypes.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/idlMissingTypes.js +0 -73
- package/dist/@codegen/klend/instructions/idlMissingTypes.js.map +0 -1
- package/dist/@codegen/klend/instructions/index.d.ts +0 -99
- package/dist/@codegen/klend/instructions/index.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/index.js +0 -102
- package/dist/@codegen/klend/instructions/index.js.map +0 -1
- package/dist/@codegen/klend/instructions/initFarmsForReserve.d.ts +0 -20
- package/dist/@codegen/klend/instructions/initFarmsForReserve.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initFarmsForReserve.js +0 -68
- package/dist/@codegen/klend/instructions/initFarmsForReserve.js.map +0 -1
- package/dist/@codegen/klend/instructions/initGlobalConfig.d.ts +0 -11
- package/dist/@codegen/klend/instructions/initGlobalConfig.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initGlobalConfig.js +0 -20
- package/dist/@codegen/klend/instructions/initGlobalConfig.js.map +0 -1
- package/dist/@codegen/klend/instructions/initLendingMarket.d.ts +0 -15
- package/dist/@codegen/klend/instructions/initLendingMarket.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initLendingMarket.js +0 -65
- package/dist/@codegen/klend/instructions/initLendingMarket.js.map +0 -1
- package/dist/@codegen/klend/instructions/initObligation.d.ts +0 -20
- package/dist/@codegen/klend/instructions/initObligation.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initObligation.js +0 -70
- package/dist/@codegen/klend/instructions/initObligation.js.map +0 -1
- package/dist/@codegen/klend/instructions/initObligationFarmsForReserve.d.ts +0 -21
- package/dist/@codegen/klend/instructions/initObligationFarmsForReserve.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initObligationFarmsForReserve.js +0 -67
- package/dist/@codegen/klend/instructions/initObligationFarmsForReserve.js.map +0 -1
- package/dist/@codegen/klend/instructions/initReferrerStateAndShortUrl.d.ts +0 -16
- package/dist/@codegen/klend/instructions/initReferrerStateAndShortUrl.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initReferrerStateAndShortUrl.js +0 -62
- package/dist/@codegen/klend/instructions/initReferrerStateAndShortUrl.js.map +0 -1
- package/dist/@codegen/klend/instructions/initReferrerTokenState.d.ts +0 -13
- package/dist/@codegen/klend/instructions/initReferrerTokenState.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initReferrerTokenState.js +0 -22
- package/dist/@codegen/klend/instructions/initReferrerTokenState.js.map +0 -1
- package/dist/@codegen/klend/instructions/initReserve.d.ts +0 -20
- package/dist/@codegen/klend/instructions/initReserve.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initReserve.js +0 -29
- package/dist/@codegen/klend/instructions/initReserve.js.map +0 -1
- package/dist/@codegen/klend/instructions/initUserMetadata.d.ts +0 -16
- package/dist/@codegen/klend/instructions/initUserMetadata.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/initUserMetadata.js +0 -67
- package/dist/@codegen/klend/instructions/initUserMetadata.js.map +0 -1
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateral.d.ts +0 -33
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateral.js +0 -84
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateral.js.map +0 -1
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateralV2.d.ts +0 -44
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateralV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateralV2.js +0 -138
- package/dist/@codegen/klend/instructions/liquidateObligationAndRedeemReserveCollateralV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/markObligationForDeleveraging.d.ts +0 -13
- package/dist/@codegen/klend/instructions/markObligationForDeleveraging.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/markObligationForDeleveraging.js +0 -63
- package/dist/@codegen/klend/instructions/markObligationForDeleveraging.js.map +0 -1
- package/dist/@codegen/klend/instructions/redeemFees.d.ts +0 -13
- package/dist/@codegen/klend/instructions/redeemFees.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/redeemFees.js +0 -22
- package/dist/@codegen/klend/instructions/redeemFees.js.map +0 -1
- package/dist/@codegen/klend/instructions/redeemReserveCollateral.d.ts +0 -23
- package/dist/@codegen/klend/instructions/redeemReserveCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/redeemReserveCollateral.js +0 -70
- package/dist/@codegen/klend/instructions/redeemReserveCollateral.js.map +0 -1
- package/dist/@codegen/klend/instructions/refreshObligation.d.ts +0 -8
- package/dist/@codegen/klend/instructions/refreshObligation.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/refreshObligation.js +0 -17
- package/dist/@codegen/klend/instructions/refreshObligation.js.map +0 -1
- package/dist/@codegen/klend/instructions/refreshObligationFarmsForReserve.d.ts +0 -22
- package/dist/@codegen/klend/instructions/refreshObligationFarmsForReserve.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/refreshObligationFarmsForReserve.js +0 -66
- package/dist/@codegen/klend/instructions/refreshObligationFarmsForReserve.js.map +0 -1
- package/dist/@codegen/klend/instructions/refreshReserve.d.ts +0 -12
- package/dist/@codegen/klend/instructions/refreshReserve.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/refreshReserve.js +0 -31
- package/dist/@codegen/klend/instructions/refreshReserve.js.map +0 -1
- package/dist/@codegen/klend/instructions/refreshReservesBatch.d.ts +0 -8
- package/dist/@codegen/klend/instructions/refreshReservesBatch.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/refreshReservesBatch.js +0 -56
- package/dist/@codegen/klend/instructions/refreshReservesBatch.js.map +0 -1
- package/dist/@codegen/klend/instructions/repayAndWithdrawAndRedeem.d.ts +0 -48
- package/dist/@codegen/klend/instructions/repayAndWithdrawAndRedeem.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/repayAndWithdrawAndRedeem.js +0 -119
- package/dist/@codegen/klend/instructions/repayAndWithdrawAndRedeem.js.map +0 -1
- package/dist/@codegen/klend/instructions/repayObligationLiquidity.d.ts +0 -20
- package/dist/@codegen/klend/instructions/repayObligationLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/repayObligationLiquidity.js +0 -65
- package/dist/@codegen/klend/instructions/repayObligationLiquidity.js.map +0 -1
- package/dist/@codegen/klend/instructions/repayObligationLiquidityV2.d.ts +0 -28
- package/dist/@codegen/klend/instructions/repayObligationLiquidityV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/repayObligationLiquidityV2.js +0 -82
- package/dist/@codegen/klend/instructions/repayObligationLiquidityV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/requestElevationGroup.d.ts +0 -13
- package/dist/@codegen/klend/instructions/requestElevationGroup.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/requestElevationGroup.js +0 -59
- package/dist/@codegen/klend/instructions/requestElevationGroup.js.map +0 -1
- package/dist/@codegen/klend/instructions/seedDepositOnInitReserve.d.ts +0 -13
- package/dist/@codegen/klend/instructions/seedDepositOnInitReserve.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/seedDepositOnInitReserve.js +0 -24
- package/dist/@codegen/klend/instructions/seedDepositOnInitReserve.js.map +0 -1
- package/dist/@codegen/klend/instructions/setObligationOrder.d.ts +0 -15
- package/dist/@codegen/klend/instructions/setObligationOrder.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/setObligationOrder.js +0 -62
- package/dist/@codegen/klend/instructions/setObligationOrder.js.map +0 -1
- package/dist/@codegen/klend/instructions/socializeLoss.d.ts +0 -16
- package/dist/@codegen/klend/instructions/socializeLoss.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/socializeLoss.js +0 -65
- package/dist/@codegen/klend/instructions/socializeLoss.js.map +0 -1
- package/dist/@codegen/klend/instructions/socializeLossV2.d.ts +0 -24
- package/dist/@codegen/klend/instructions/socializeLossV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/socializeLossV2.js +0 -81
- package/dist/@codegen/klend/instructions/socializeLossV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/updateGlobalConfig.d.ts +0 -14
- package/dist/@codegen/klend/instructions/updateGlobalConfig.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/updateGlobalConfig.js +0 -65
- package/dist/@codegen/klend/instructions/updateGlobalConfig.js.map +0 -1
- package/dist/@codegen/klend/instructions/updateGlobalConfigAdmin.d.ts +0 -8
- package/dist/@codegen/klend/instructions/updateGlobalConfigAdmin.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/updateGlobalConfigAdmin.js +0 -21
- package/dist/@codegen/klend/instructions/updateGlobalConfigAdmin.js.map +0 -1
- package/dist/@codegen/klend/instructions/updateLendingMarket.d.ts +0 -14
- package/dist/@codegen/klend/instructions/updateLendingMarket.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/updateLendingMarket.js +0 -64
- package/dist/@codegen/klend/instructions/updateLendingMarket.js.map +0 -1
- package/dist/@codegen/klend/instructions/updateLendingMarketOwner.d.ts +0 -8
- package/dist/@codegen/klend/instructions/updateLendingMarketOwner.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/updateLendingMarketOwner.js +0 -21
- package/dist/@codegen/klend/instructions/updateLendingMarketOwner.js.map +0 -1
- package/dist/@codegen/klend/instructions/updateReserveConfig.d.ts +0 -17
- package/dist/@codegen/klend/instructions/updateReserveConfig.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/updateReserveConfig.js +0 -65
- package/dist/@codegen/klend/instructions/updateReserveConfig.js.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateral.d.ts +0 -20
- package/dist/@codegen/klend/instructions/withdrawObligationCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateral.js +0 -65
- package/dist/@codegen/klend/instructions/withdrawObligationCollateral.js.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateral.d.ts +0 -25
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateral.js +0 -77
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateral.js.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateralV2.d.ts +0 -32
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateralV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateralV2.js +0 -92
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralAndRedeemReserveCollateralV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralV2.d.ts +0 -27
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralV2.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralV2.js +0 -83
- package/dist/@codegen/klend/instructions/withdrawObligationCollateralV2.js.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawProtocolFee.d.ts +0 -19
- package/dist/@codegen/klend/instructions/withdrawProtocolFee.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawProtocolFee.js +0 -64
- package/dist/@codegen/klend/instructions/withdrawProtocolFee.js.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawReferrerFees.d.ts +0 -15
- package/dist/@codegen/klend/instructions/withdrawReferrerFees.d.ts.map +0 -1
- package/dist/@codegen/klend/instructions/withdrawReferrerFees.js +0 -26
- package/dist/@codegen/klend/instructions/withdrawReferrerFees.js.map +0 -1
- package/dist/@codegen/klend/programId.d.ts +0 -4
- package/dist/@codegen/klend/programId.d.ts.map +0 -1
- package/dist/@codegen/klend/programId.js +0 -9
- package/dist/@codegen/klend/programId.js.map +0 -1
- package/dist/@codegen/klend/types/AssetTier.d.ts +0 -45
- package/dist/@codegen/klend/types/AssetTier.d.ts.map +0 -1
- package/dist/@codegen/klend/types/AssetTier.js +0 -132
- package/dist/@codegen/klend/types/AssetTier.js.map +0 -1
- package/dist/@codegen/klend/types/BigFractionBytes.d.ts +0 -28
- package/dist/@codegen/klend/types/BigFractionBytes.d.ts.map +0 -1
- package/dist/@codegen/klend/types/BigFractionBytes.js +0 -85
- package/dist/@codegen/klend/types/BigFractionBytes.js.map +0 -1
- package/dist/@codegen/klend/types/BorrowRateCurve.d.ts +0 -28
- package/dist/@codegen/klend/types/BorrowRateCurve.d.ts.map +0 -1
- package/dist/@codegen/klend/types/BorrowRateCurve.js +0 -73
- package/dist/@codegen/klend/types/BorrowRateCurve.js.map +0 -1
- package/dist/@codegen/klend/types/CurvePoint.d.ts +0 -27
- package/dist/@codegen/klend/types/CurvePoint.d.ts.map +0 -1
- package/dist/@codegen/klend/types/CurvePoint.js +0 -78
- package/dist/@codegen/klend/types/CurvePoint.js.map +0 -1
- package/dist/@codegen/klend/types/ElevationGroup.d.ts +0 -67
- package/dist/@codegen/klend/types/ElevationGroup.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ElevationGroup.js +0 -137
- package/dist/@codegen/klend/types/ElevationGroup.js.map +0 -1
- package/dist/@codegen/klend/types/FeeCalculation.d.ts +0 -32
- package/dist/@codegen/klend/types/FeeCalculation.d.ts.map +0 -1
- package/dist/@codegen/klend/types/FeeCalculation.js +0 -108
- package/dist/@codegen/klend/types/FeeCalculation.js.map +0 -1
- package/dist/@codegen/klend/types/InitObligationArgs.d.ts +0 -27
- package/dist/@codegen/klend/types/InitObligationArgs.d.ts.map +0 -1
- package/dist/@codegen/klend/types/InitObligationArgs.js +0 -78
- package/dist/@codegen/klend/types/InitObligationArgs.js.map +0 -1
- package/dist/@codegen/klend/types/LastUpdate.d.ts +0 -48
- package/dist/@codegen/klend/types/LastUpdate.d.ts.map +0 -1
- package/dist/@codegen/klend/types/LastUpdate.js +0 -103
- package/dist/@codegen/klend/types/LastUpdate.js.map +0 -1
- package/dist/@codegen/klend/types/ObligationCollateral.d.ts +0 -72
- package/dist/@codegen/klend/types/ObligationCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ObligationCollateral.js +0 -119
- package/dist/@codegen/klend/types/ObligationCollateral.js.map +0 -1
- package/dist/@codegen/klend/types/ObligationLiquidity.d.ts +0 -84
- package/dist/@codegen/klend/types/ObligationLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ObligationLiquidity.js +0 -141
- package/dist/@codegen/klend/types/ObligationLiquidity.js.map +0 -1
- package/dist/@codegen/klend/types/ObligationOrder.d.ts +0 -284
- package/dist/@codegen/klend/types/ObligationOrder.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ObligationOrder.js +0 -205
- package/dist/@codegen/klend/types/ObligationOrder.js.map +0 -1
- package/dist/@codegen/klend/types/PriceHeuristic.d.ts +0 -42
- package/dist/@codegen/klend/types/PriceHeuristic.d.ts.map +0 -1
- package/dist/@codegen/klend/types/PriceHeuristic.js +0 -91
- package/dist/@codegen/klend/types/PriceHeuristic.js.map +0 -1
- package/dist/@codegen/klend/types/PythConfiguration.d.ts +0 -26
- package/dist/@codegen/klend/types/PythConfiguration.d.ts.map +0 -1
- package/dist/@codegen/klend/types/PythConfiguration.js +0 -75
- package/dist/@codegen/klend/types/PythConfiguration.js.map +0 -1
- package/dist/@codegen/klend/types/ReserveCollateral.d.ts +0 -54
- package/dist/@codegen/klend/types/ReserveCollateral.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ReserveCollateral.js +0 -112
- package/dist/@codegen/klend/types/ReserveCollateral.js.map +0 -1
- package/dist/@codegen/klend/types/ReserveConfig.d.ts +0 -472
- package/dist/@codegen/klend/types/ReserveConfig.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ReserveConfig.js +0 -377
- package/dist/@codegen/klend/types/ReserveConfig.js.map +0 -1
- package/dist/@codegen/klend/types/ReserveFarmKind.d.ts +0 -32
- package/dist/@codegen/klend/types/ReserveFarmKind.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ReserveFarmKind.js +0 -108
- package/dist/@codegen/klend/types/ReserveFarmKind.js.map +0 -1
- package/dist/@codegen/klend/types/ReserveFees.d.ts +0 -79
- package/dist/@codegen/klend/types/ReserveFees.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ReserveFees.js +0 -112
- package/dist/@codegen/klend/types/ReserveFees.js.map +0 -1
- package/dist/@codegen/klend/types/ReserveLiquidity.d.ts +0 -182
- package/dist/@codegen/klend/types/ReserveLiquidity.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ReserveLiquidity.js +0 -225
- package/dist/@codegen/klend/types/ReserveLiquidity.js.map +0 -1
- package/dist/@codegen/klend/types/ReserveStatus.d.ts +0 -45
- package/dist/@codegen/klend/types/ReserveStatus.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ReserveStatus.js +0 -132
- package/dist/@codegen/klend/types/ReserveStatus.js.map +0 -1
- package/dist/@codegen/klend/types/ScopeConfiguration.d.ts +0 -42
- package/dist/@codegen/klend/types/ScopeConfiguration.d.ts.map +0 -1
- package/dist/@codegen/klend/types/ScopeConfiguration.js +0 -93
- package/dist/@codegen/klend/types/ScopeConfiguration.js.map +0 -1
- package/dist/@codegen/klend/types/SwitchboardConfiguration.d.ts +0 -31
- package/dist/@codegen/klend/types/SwitchboardConfiguration.d.ts.map +0 -1
- package/dist/@codegen/klend/types/SwitchboardConfiguration.js +0 -81
- package/dist/@codegen/klend/types/SwitchboardConfiguration.js.map +0 -1
- package/dist/@codegen/klend/types/TokenInfo.d.ts +0 -118
- package/dist/@codegen/klend/types/TokenInfo.d.ts.map +0 -1
- package/dist/@codegen/klend/types/TokenInfo.js +0 -161
- package/dist/@codegen/klend/types/TokenInfo.js.map +0 -1
- package/dist/@codegen/klend/types/UpdateConfigMode.d.ts +0 -695
- package/dist/@codegen/klend/types/UpdateConfigMode.d.ts.map +0 -1
- package/dist/@codegen/klend/types/UpdateConfigMode.js +0 -1333
- package/dist/@codegen/klend/types/UpdateConfigMode.js.map +0 -1
- package/dist/@codegen/klend/types/UpdateGlobalConfigMode.d.ts +0 -32
- package/dist/@codegen/klend/types/UpdateGlobalConfigMode.d.ts.map +0 -1
- package/dist/@codegen/klend/types/UpdateGlobalConfigMode.js +0 -108
- package/dist/@codegen/klend/types/UpdateGlobalConfigMode.js.map +0 -1
- package/dist/@codegen/klend/types/UpdateLendingMarketConfigValue.d.ts +0 -198
- package/dist/@codegen/klend/types/UpdateLendingMarketConfigValue.d.ts.map +0 -1
- package/dist/@codegen/klend/types/UpdateLendingMarketConfigValue.js +0 -355
- package/dist/@codegen/klend/types/UpdateLendingMarketConfigValue.js.map +0 -1
- package/dist/@codegen/klend/types/UpdateLendingMarketMode.d.ts +0 -357
- package/dist/@codegen/klend/types/UpdateLendingMarketMode.d.ts.map +0 -1
- package/dist/@codegen/klend/types/UpdateLendingMarketMode.js +0 -708
- package/dist/@codegen/klend/types/UpdateLendingMarketMode.js.map +0 -1
- package/dist/@codegen/klend/types/WithdrawalCaps.d.ts +0 -39
- package/dist/@codegen/klend/types/WithdrawalCaps.d.ts.map +0 -1
- package/dist/@codegen/klend/types/WithdrawalCaps.js +0 -100
- package/dist/@codegen/klend/types/WithdrawalCaps.js.map +0 -1
- package/dist/@codegen/klend/types/index.d.ts +0 -72
- package/dist/@codegen/klend/types/index.d.ts.map +0 -1
- package/dist/@codegen/klend/types/index.js +0 -91
- package/dist/@codegen/klend/types/index.js.map +0 -1
- package/dist/@codegen/klend/utils/borshAddress.d.ts +0 -4
- package/dist/@codegen/klend/utils/borshAddress.d.ts.map +0 -1
- package/dist/@codegen/klend/utils/borshAddress.js +0 -30
- package/dist/@codegen/klend/utils/borshAddress.js.map +0 -1
- package/dist/@codegen/klend/utils/index.d.ts +0 -2
- package/dist/@codegen/klend/utils/index.d.ts.map +0 -1
- package/dist/@codegen/klend/utils/index.js +0 -18
- package/dist/@codegen/klend/utils/index.js.map +0 -1
- package/dist/@codegen/klend/zero_padding/ObligationZP.d.ts +0 -73
- package/dist/@codegen/klend/zero_padding/ObligationZP.d.ts.map +0 -1
- package/dist/@codegen/klend/zero_padding/ObligationZP.js +0 -225
- package/dist/@codegen/klend/zero_padding/ObligationZP.js.map +0 -1
- package/dist/@codegen/klend/zero_padding/index.d.ts +0 -2
- package/dist/@codegen/klend/zero_padding/index.d.ts.map +0 -1
- package/dist/@codegen/klend/zero_padding/index.js +0 -6
- package/dist/@codegen/klend/zero_padding/index.js.map +0 -1
- package/dist/@codegen/kvault/accounts/GlobalConfig.d.ts +0 -32
- package/dist/@codegen/kvault/accounts/GlobalConfig.d.ts.map +0 -1
- package/dist/@codegen/kvault/accounts/GlobalConfig.js +0 -125
- package/dist/@codegen/kvault/accounts/GlobalConfig.js.map +0 -1
- package/dist/@codegen/kvault/accounts/Reserve.d.ts +0 -90
- package/dist/@codegen/kvault/accounts/Reserve.d.ts.map +0 -1
- package/dist/@codegen/kvault/accounts/Reserve.js +0 -192
- package/dist/@codegen/kvault/accounts/Reserve.js.map +0 -1
- package/dist/@codegen/kvault/accounts/ReserveWhitelistEntry.d.ts +0 -52
- package/dist/@codegen/kvault/accounts/ReserveWhitelistEntry.d.ts.map +0 -1
- package/dist/@codegen/kvault/accounts/ReserveWhitelistEntry.js +0 -127
- package/dist/@codegen/kvault/accounts/ReserveWhitelistEntry.js.map +0 -1
- package/dist/@codegen/kvault/accounts/VaultState.d.ts +0 -144
- package/dist/@codegen/kvault/accounts/VaultState.d.ts.map +0 -1
- package/dist/@codegen/kvault/accounts/VaultState.js +0 -350
- package/dist/@codegen/kvault/accounts/VaultState.js.map +0 -1
- package/dist/@codegen/kvault/accounts/index.d.ts +0 -9
- package/dist/@codegen/kvault/accounts/index.d.ts.map +0 -1
- package/dist/@codegen/kvault/accounts/index.js +0 -12
- package/dist/@codegen/kvault/accounts/index.js.map +0 -1
- package/dist/@codegen/kvault/errors/anchor.d.ts +0 -435
- package/dist/@codegen/kvault/errors/anchor.d.ts.map +0 -1
- package/dist/@codegen/kvault/errors/anchor.js +0 -767
- package/dist/@codegen/kvault/errors/anchor.js.map +0 -1
- package/dist/@codegen/kvault/errors/custom.d.ts +0 -451
- package/dist/@codegen/kvault/errors/custom.d.ts.map +0 -1
- package/dist/@codegen/kvault/errors/custom.js +0 -795
- package/dist/@codegen/kvault/errors/custom.js.map +0 -1
- package/dist/@codegen/kvault/errors/index.d.ts +0 -6
- package/dist/@codegen/kvault/errors/index.d.ts.map +0 -1
- package/dist/@codegen/kvault/errors/index.js +0 -86
- package/dist/@codegen/kvault/errors/index.js.map +0 -1
- package/dist/@codegen/kvault/instructions/addUpdateWhitelistedReserve.d.ts +0 -16
- package/dist/@codegen/kvault/instructions/addUpdateWhitelistedReserve.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/addUpdateWhitelistedReserve.js +0 -66
- package/dist/@codegen/kvault/instructions/addUpdateWhitelistedReserve.js.map +0 -1
- package/dist/@codegen/kvault/instructions/buy.d.ts +0 -24
- package/dist/@codegen/kvault/instructions/buy.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/buy.js +0 -67
- package/dist/@codegen/kvault/instructions/buy.js.map +0 -1
- package/dist/@codegen/kvault/instructions/deposit.d.ts +0 -24
- package/dist/@codegen/kvault/instructions/deposit.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/deposit.js +0 -67
- package/dist/@codegen/kvault/instructions/deposit.js.map +0 -1
- package/dist/@codegen/kvault/instructions/giveUpPendingFees.d.ts +0 -14
- package/dist/@codegen/kvault/instructions/giveUpPendingFees.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/giveUpPendingFees.js +0 -65
- package/dist/@codegen/kvault/instructions/giveUpPendingFees.js.map +0 -1
- package/dist/@codegen/kvault/instructions/index.d.ts +0 -39
- package/dist/@codegen/kvault/instructions/index.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/index.js +0 -42
- package/dist/@codegen/kvault/instructions/index.js.map +0 -1
- package/dist/@codegen/kvault/instructions/initGlobalConfig.d.ts +0 -11
- package/dist/@codegen/kvault/instructions/initGlobalConfig.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/initGlobalConfig.js +0 -20
- package/dist/@codegen/kvault/instructions/initGlobalConfig.js.map +0 -1
- package/dist/@codegen/kvault/instructions/initVault.d.ts +0 -17
- package/dist/@codegen/kvault/instructions/initVault.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/initVault.js +0 -30
- package/dist/@codegen/kvault/instructions/initVault.js.map +0 -1
- package/dist/@codegen/kvault/instructions/initializeSharesMetadata.d.ts +0 -20
- package/dist/@codegen/kvault/instructions/initializeSharesMetadata.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/initializeSharesMetadata.js +0 -72
- package/dist/@codegen/kvault/instructions/initializeSharesMetadata.js.map +0 -1
- package/dist/@codegen/kvault/instructions/invest.d.ts +0 -24
- package/dist/@codegen/kvault/instructions/invest.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/invest.js +0 -36
- package/dist/@codegen/kvault/instructions/invest.js.map +0 -1
- package/dist/@codegen/kvault/instructions/removeAllocation.d.ts +0 -9
- package/dist/@codegen/kvault/instructions/removeAllocation.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/removeAllocation.js +0 -22
- package/dist/@codegen/kvault/instructions/removeAllocation.js.map +0 -1
- package/dist/@codegen/kvault/instructions/sell.d.ts +0 -40
- package/dist/@codegen/kvault/instructions/sell.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/sell.js +0 -98
- package/dist/@codegen/kvault/instructions/sell.js.map +0 -1
- package/dist/@codegen/kvault/instructions/updateAdmin.d.ts +0 -8
- package/dist/@codegen/kvault/instructions/updateAdmin.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/updateAdmin.js +0 -21
- package/dist/@codegen/kvault/instructions/updateAdmin.js.map +0 -1
- package/dist/@codegen/kvault/instructions/updateGlobalConfig.d.ts +0 -13
- package/dist/@codegen/kvault/instructions/updateGlobalConfig.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/updateGlobalConfig.js +0 -63
- package/dist/@codegen/kvault/instructions/updateGlobalConfig.js.map +0 -1
- package/dist/@codegen/kvault/instructions/updateGlobalConfigAdmin.d.ts +0 -8
- package/dist/@codegen/kvault/instructions/updateGlobalConfigAdmin.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/updateGlobalConfigAdmin.js +0 -21
- package/dist/@codegen/kvault/instructions/updateGlobalConfigAdmin.js.map +0 -1
- package/dist/@codegen/kvault/instructions/updateReserveAllocation.d.ts +0 -22
- package/dist/@codegen/kvault/instructions/updateReserveAllocation.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/updateReserveAllocation.js +0 -72
- package/dist/@codegen/kvault/instructions/updateReserveAllocation.js.map +0 -1
- package/dist/@codegen/kvault/instructions/updateSharesMetadata.d.ts +0 -17
- package/dist/@codegen/kvault/instructions/updateSharesMetadata.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/updateSharesMetadata.js +0 -71
- package/dist/@codegen/kvault/instructions/updateSharesMetadata.js.map +0 -1
- package/dist/@codegen/kvault/instructions/updateVaultConfig.d.ts +0 -16
- package/dist/@codegen/kvault/instructions/updateVaultConfig.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/updateVaultConfig.js +0 -63
- package/dist/@codegen/kvault/instructions/updateVaultConfig.js.map +0 -1
- package/dist/@codegen/kvault/instructions/withdraw.d.ts +0 -40
- package/dist/@codegen/kvault/instructions/withdraw.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/withdraw.js +0 -98
- package/dist/@codegen/kvault/instructions/withdraw.js.map +0 -1
- package/dist/@codegen/kvault/instructions/withdrawFromAvailable.d.ts +0 -25
- package/dist/@codegen/kvault/instructions/withdrawFromAvailable.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/withdrawFromAvailable.js +0 -70
- package/dist/@codegen/kvault/instructions/withdrawFromAvailable.js.map +0 -1
- package/dist/@codegen/kvault/instructions/withdrawPendingFees.d.ts +0 -23
- package/dist/@codegen/kvault/instructions/withdrawPendingFees.d.ts.map +0 -1
- package/dist/@codegen/kvault/instructions/withdrawPendingFees.js +0 -37
- package/dist/@codegen/kvault/instructions/withdrawPendingFees.js.map +0 -1
- package/dist/@codegen/kvault/programId.d.ts +0 -4
- package/dist/@codegen/kvault/programId.d.ts.map +0 -1
- package/dist/@codegen/kvault/programId.js +0 -9
- package/dist/@codegen/kvault/programId.js.map +0 -1
- package/dist/@codegen/kvault/types/BigFractionBytes.d.ts +0 -28
- package/dist/@codegen/kvault/types/BigFractionBytes.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/BigFractionBytes.js +0 -85
- package/dist/@codegen/kvault/types/BigFractionBytes.js.map +0 -1
- package/dist/@codegen/kvault/types/BorrowRateCurve.d.ts +0 -28
- package/dist/@codegen/kvault/types/BorrowRateCurve.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/BorrowRateCurve.js +0 -73
- package/dist/@codegen/kvault/types/BorrowRateCurve.js.map +0 -1
- package/dist/@codegen/kvault/types/CurvePoint.d.ts +0 -27
- package/dist/@codegen/kvault/types/CurvePoint.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/CurvePoint.js +0 -78
- package/dist/@codegen/kvault/types/CurvePoint.js.map +0 -1
- package/dist/@codegen/kvault/types/LastUpdate.d.ts +0 -48
- package/dist/@codegen/kvault/types/LastUpdate.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/LastUpdate.js +0 -103
- package/dist/@codegen/kvault/types/LastUpdate.js.map +0 -1
- package/dist/@codegen/kvault/types/PriceHeuristic.d.ts +0 -42
- package/dist/@codegen/kvault/types/PriceHeuristic.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/PriceHeuristic.js +0 -91
- package/dist/@codegen/kvault/types/PriceHeuristic.js.map +0 -1
- package/dist/@codegen/kvault/types/PythConfiguration.d.ts +0 -26
- package/dist/@codegen/kvault/types/PythConfiguration.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/PythConfiguration.js +0 -75
- package/dist/@codegen/kvault/types/PythConfiguration.js.map +0 -1
- package/dist/@codegen/kvault/types/ReserveCollateral.d.ts +0 -54
- package/dist/@codegen/kvault/types/ReserveCollateral.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/ReserveCollateral.js +0 -112
- package/dist/@codegen/kvault/types/ReserveCollateral.js.map +0 -1
- package/dist/@codegen/kvault/types/ReserveConfig.d.ts +0 -472
- package/dist/@codegen/kvault/types/ReserveConfig.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/ReserveConfig.js +0 -377
- package/dist/@codegen/kvault/types/ReserveConfig.js.map +0 -1
- package/dist/@codegen/kvault/types/ReserveFees.d.ts +0 -79
- package/dist/@codegen/kvault/types/ReserveFees.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/ReserveFees.js +0 -112
- package/dist/@codegen/kvault/types/ReserveFees.js.map +0 -1
- package/dist/@codegen/kvault/types/ReserveLiquidity.d.ts +0 -182
- package/dist/@codegen/kvault/types/ReserveLiquidity.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/ReserveLiquidity.js +0 -225
- package/dist/@codegen/kvault/types/ReserveLiquidity.js.map +0 -1
- package/dist/@codegen/kvault/types/ScopeConfiguration.d.ts +0 -42
- package/dist/@codegen/kvault/types/ScopeConfiguration.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/ScopeConfiguration.js +0 -93
- package/dist/@codegen/kvault/types/ScopeConfiguration.js.map +0 -1
- package/dist/@codegen/kvault/types/SwitchboardConfiguration.d.ts +0 -31
- package/dist/@codegen/kvault/types/SwitchboardConfiguration.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/SwitchboardConfiguration.js +0 -81
- package/dist/@codegen/kvault/types/SwitchboardConfiguration.js.map +0 -1
- package/dist/@codegen/kvault/types/TokenInfo.d.ts +0 -118
- package/dist/@codegen/kvault/types/TokenInfo.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/TokenInfo.js +0 -161
- package/dist/@codegen/kvault/types/TokenInfo.js.map +0 -1
- package/dist/@codegen/kvault/types/UpdateGlobalConfigMode.d.ts +0 -68
- package/dist/@codegen/kvault/types/UpdateGlobalConfigMode.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/UpdateGlobalConfigMode.js +0 -162
- package/dist/@codegen/kvault/types/UpdateGlobalConfigMode.js.map +0 -1
- package/dist/@codegen/kvault/types/UpdateReserveWhitelistMode.d.ts +0 -46
- package/dist/@codegen/kvault/types/UpdateReserveWhitelistMode.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/UpdateReserveWhitelistMode.js +0 -124
- package/dist/@codegen/kvault/types/UpdateReserveWhitelistMode.js.map +0 -1
- package/dist/@codegen/kvault/types/VaultAllocation.d.ts +0 -72
- package/dist/@codegen/kvault/types/VaultAllocation.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/VaultAllocation.js +0 -144
- package/dist/@codegen/kvault/types/VaultAllocation.js.map +0 -1
- package/dist/@codegen/kvault/types/VaultConfigField.d.ts +0 -253
- package/dist/@codegen/kvault/types/VaultConfigField.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/VaultConfigField.js +0 -516
- package/dist/@codegen/kvault/types/VaultConfigField.js.map +0 -1
- package/dist/@codegen/kvault/types/WithdrawalCaps.d.ts +0 -39
- package/dist/@codegen/kvault/types/WithdrawalCaps.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/WithdrawalCaps.js +0 -100
- package/dist/@codegen/kvault/types/WithdrawalCaps.js.map +0 -1
- package/dist/@codegen/kvault/types/index.d.ts +0 -43
- package/dist/@codegen/kvault/types/index.d.ts.map +0 -1
- package/dist/@codegen/kvault/types/index.js +0 -73
- package/dist/@codegen/kvault/types/index.js.map +0 -1
- package/dist/@codegen/kvault/utils/borshAddress.d.ts +0 -4
- package/dist/@codegen/kvault/utils/borshAddress.d.ts.map +0 -1
- package/dist/@codegen/kvault/utils/borshAddress.js +0 -30
- package/dist/@codegen/kvault/utils/borshAddress.js.map +0 -1
- package/dist/@codegen/kvault/utils/index.d.ts +0 -2
- package/dist/@codegen/kvault/utils/index.d.ts.map +0 -1
- package/dist/@codegen/kvault/utils/index.js +0 -18
- package/dist/@codegen/kvault/utils/index.js.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/Config.d.ts +0 -36
- package/dist/@codegen/pyth_rec/accounts/Config.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/Config.js +0 -134
- package/dist/@codegen/pyth_rec/accounts/Config.js.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/index.d.ts +0 -7
- package/dist/@codegen/pyth_rec/accounts/index.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/index.js +0 -10
- package/dist/@codegen/pyth_rec/accounts/index.js.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/priceUpdateV2.d.ts +0 -30
- package/dist/@codegen/pyth_rec/accounts/priceUpdateV2.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/priceUpdateV2.js +0 -120
- package/dist/@codegen/pyth_rec/accounts/priceUpdateV2.js.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/twapUpdate.d.ts +0 -23
- package/dist/@codegen/pyth_rec/accounts/twapUpdate.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/accounts/twapUpdate.js +0 -103
- package/dist/@codegen/pyth_rec/accounts/twapUpdate.js.map +0 -1
- package/dist/@codegen/pyth_rec/errors/anchor.d.ts +0 -435
- package/dist/@codegen/pyth_rec/errors/anchor.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/errors/anchor.js +0 -767
- package/dist/@codegen/pyth_rec/errors/anchor.js.map +0 -1
- package/dist/@codegen/pyth_rec/errors/custom.d.ts +0 -179
- package/dist/@codegen/pyth_rec/errors/custom.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/errors/custom.js +0 -318
- package/dist/@codegen/pyth_rec/errors/custom.js.map +0 -1
- package/dist/@codegen/pyth_rec/errors/index.d.ts +0 -6
- package/dist/@codegen/pyth_rec/errors/index.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/errors/index.js +0 -86
- package/dist/@codegen/pyth_rec/errors/index.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/acceptGovernanceAuthorityTransfer.d.ts +0 -8
- package/dist/@codegen/pyth_rec/instructions/acceptGovernanceAuthorityTransfer.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/acceptGovernanceAuthorityTransfer.js +0 -17
- package/dist/@codegen/pyth_rec/instructions/acceptGovernanceAuthorityTransfer.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/index.d.ts +0 -17
- package/dist/@codegen/pyth_rec/instructions/index.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/index.js +0 -20
- package/dist/@codegen/pyth_rec/instructions/index.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/reclaimRent.d.ts +0 -8
- package/dist/@codegen/pyth_rec/instructions/reclaimRent.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/reclaimRent.js +0 -17
- package/dist/@codegen/pyth_rec/instructions/reclaimRent.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/reclaimTwapRent.d.ts +0 -8
- package/dist/@codegen/pyth_rec/instructions/reclaimTwapRent.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/reclaimTwapRent.js +0 -17
- package/dist/@codegen/pyth_rec/instructions/reclaimTwapRent.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/requestGovernanceAuthorityTransfer.d.ts +0 -12
- package/dist/@codegen/pyth_rec/instructions/requestGovernanceAuthorityTransfer.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/requestGovernanceAuthorityTransfer.js +0 -59
- package/dist/@codegen/pyth_rec/instructions/requestGovernanceAuthorityTransfer.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setDataSources.d.ts +0 -13
- package/dist/@codegen/pyth_rec/instructions/setDataSources.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setDataSources.js +0 -59
- package/dist/@codegen/pyth_rec/instructions/setDataSources.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setFee.d.ts +0 -13
- package/dist/@codegen/pyth_rec/instructions/setFee.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setFee.js +0 -58
- package/dist/@codegen/pyth_rec/instructions/setFee.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setMinimumSignatures.d.ts +0 -12
- package/dist/@codegen/pyth_rec/instructions/setMinimumSignatures.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setMinimumSignatures.js +0 -58
- package/dist/@codegen/pyth_rec/instructions/setMinimumSignatures.js.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setWormholeAddress.d.ts +0 -12
- package/dist/@codegen/pyth_rec/instructions/setWormholeAddress.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/instructions/setWormholeAddress.js +0 -61
- package/dist/@codegen/pyth_rec/instructions/setWormholeAddress.js.map +0 -1
- package/dist/@codegen/pyth_rec/programId.d.ts +0 -4
- package/dist/@codegen/pyth_rec/programId.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/programId.js +0 -9
- package/dist/@codegen/pyth_rec/programId.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/DataSource.d.ts +0 -28
- package/dist/@codegen/pyth_rec/types/DataSource.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/DataSource.js +0 -80
- package/dist/@codegen/pyth_rec/types/DataSource.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/MerklePriceUpdate.d.ts +0 -27
- package/dist/@codegen/pyth_rec/types/MerklePriceUpdate.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/MerklePriceUpdate.js +0 -78
- package/dist/@codegen/pyth_rec/types/MerklePriceUpdate.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/PostTwapUpdateParams.d.ts +0 -44
- package/dist/@codegen/pyth_rec/types/PostTwapUpdateParams.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/PostTwapUpdateParams.js +0 -93
- package/dist/@codegen/pyth_rec/types/PostTwapUpdateParams.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/PostUpdateAtomicParams.d.ts +0 -38
- package/dist/@codegen/pyth_rec/types/PostUpdateAtomicParams.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/PostUpdateAtomicParams.js +0 -91
- package/dist/@codegen/pyth_rec/types/PostUpdateAtomicParams.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/PostUpdateParams.d.ts +0 -33
- package/dist/@codegen/pyth_rec/types/PostUpdateParams.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/PostUpdateParams.js +0 -84
- package/dist/@codegen/pyth_rec/types/PostUpdateParams.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/PriceFeedMessage.d.ts +0 -58
- package/dist/@codegen/pyth_rec/types/PriceFeedMessage.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/PriceFeedMessage.js +0 -127
- package/dist/@codegen/pyth_rec/types/PriceFeedMessage.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/TwapPrice.d.ts +0 -69
- package/dist/@codegen/pyth_rec/types/TwapPrice.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/TwapPrice.js +0 -128
- package/dist/@codegen/pyth_rec/types/TwapPrice.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/VerificationLevel.d.ts +0 -45
- package/dist/@codegen/pyth_rec/types/VerificationLevel.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/VerificationLevel.js +0 -124
- package/dist/@codegen/pyth_rec/types/VerificationLevel.js.map +0 -1
- package/dist/@codegen/pyth_rec/types/index.d.ts +0 -24
- package/dist/@codegen/pyth_rec/types/index.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/types/index.js +0 -53
- package/dist/@codegen/pyth_rec/types/index.js.map +0 -1
- package/dist/@codegen/pyth_rec/utils/borshAddress.d.ts +0 -4
- package/dist/@codegen/pyth_rec/utils/borshAddress.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/utils/borshAddress.js +0 -30
- package/dist/@codegen/pyth_rec/utils/borshAddress.js.map +0 -1
- package/dist/@codegen/pyth_rec/utils/index.d.ts +0 -2
- package/dist/@codegen/pyth_rec/utils/index.d.ts.map +0 -1
- package/dist/@codegen/pyth_rec/utils/index.js +0 -18
- package/dist/@codegen/pyth_rec/utils/index.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/AggregatorAccountData.d.ts +0 -123
- package/dist/@codegen/switchboard_v2/accounts/AggregatorAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/AggregatorAccountData.js +0 -312
- package/dist/@codegen/switchboard_v2/accounts/AggregatorAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/BufferRelayerAccountData.d.ts +0 -50
- package/dist/@codegen/switchboard_v2/accounts/BufferRelayerAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/BufferRelayerAccountData.js +0 -159
- package/dist/@codegen/switchboard_v2/accounts/BufferRelayerAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/CrankAccountData.d.ts +0 -40
- package/dist/@codegen/switchboard_v2/accounts/CrankAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/CrankAccountData.js +0 -138
- package/dist/@codegen/switchboard_v2/accounts/CrankAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/JobAccountData.d.ts +0 -47
- package/dist/@codegen/switchboard_v2/accounts/JobAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/JobAccountData.js +0 -155
- package/dist/@codegen/switchboard_v2/accounts/JobAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/LeaseAccountData.d.ts +0 -47
- package/dist/@codegen/switchboard_v2/accounts/LeaseAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/LeaseAccountData.js +0 -155
- package/dist/@codegen/switchboard_v2/accounts/LeaseAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/OracleAccountData.d.ts +0 -45
- package/dist/@codegen/switchboard_v2/accounts/OracleAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/OracleAccountData.js +0 -150
- package/dist/@codegen/switchboard_v2/accounts/OracleAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/OracleQueueAccountData.d.ts +0 -87
- package/dist/@codegen/switchboard_v2/accounts/OracleQueueAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/OracleQueueAccountData.js +0 -238
- package/dist/@codegen/switchboard_v2/accounts/OracleQueueAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/PermissionAccountData.d.ts +0 -35
- package/dist/@codegen/switchboard_v2/accounts/PermissionAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/PermissionAccountData.js +0 -131
- package/dist/@codegen/switchboard_v2/accounts/PermissionAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/RealmSpawnRecordAccountData.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/accounts/RealmSpawnRecordAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/RealmSpawnRecordAccountData.js +0 -93
- package/dist/@codegen/switchboard_v2/accounts/RealmSpawnRecordAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/SbState.d.ts +0 -31
- package/dist/@codegen/switchboard_v2/accounts/SbState.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/SbState.js +0 -120
- package/dist/@codegen/switchboard_v2/accounts/SbState.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/SlidingResultAccountData.d.ts +0 -26
- package/dist/@codegen/switchboard_v2/accounts/SlidingResultAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/SlidingResultAccountData.js +0 -108
- package/dist/@codegen/switchboard_v2/accounts/SlidingResultAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/TaskSpecRecord.d.ts +0 -20
- package/dist/@codegen/switchboard_v2/accounts/TaskSpecRecord.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/TaskSpecRecord.js +0 -96
- package/dist/@codegen/switchboard_v2/accounts/TaskSpecRecord.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/VrfAccountData.d.ts +0 -54
- package/dist/@codegen/switchboard_v2/accounts/VrfAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/VrfAccountData.js +0 -168
- package/dist/@codegen/switchboard_v2/accounts/VrfAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/VrfLiteAccountData.d.ts +0 -69
- package/dist/@codegen/switchboard_v2/accounts/VrfLiteAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/VrfLiteAccountData.js +0 -198
- package/dist/@codegen/switchboard_v2/accounts/VrfLiteAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/VrfPoolAccountData.d.ts +0 -43
- package/dist/@codegen/switchboard_v2/accounts/VrfPoolAccountData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/VrfPoolAccountData.js +0 -142
- package/dist/@codegen/switchboard_v2/accounts/VrfPoolAccountData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/index.d.ts +0 -31
- package/dist/@codegen/switchboard_v2/accounts/index.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/accounts/index.js +0 -34
- package/dist/@codegen/switchboard_v2/accounts/index.js.map +0 -1
- package/dist/@codegen/switchboard_v2/errors/anchor.d.ts +0 -435
- package/dist/@codegen/switchboard_v2/errors/anchor.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/errors/anchor.js +0 -767
- package/dist/@codegen/switchboard_v2/errors/anchor.js.map +0 -1
- package/dist/@codegen/switchboard_v2/errors/custom.d.ts +0 -801
- package/dist/@codegen/switchboard_v2/errors/custom.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/errors/custom.js +0 -1409
- package/dist/@codegen/switchboard_v2/errors/custom.js.map +0 -1
- package/dist/@codegen/switchboard_v2/errors/index.d.ts +0 -6
- package/dist/@codegen/switchboard_v2/errors/index.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/errors/index.js +0 -86
- package/dist/@codegen/switchboard_v2/errors/index.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorAddJob.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/aggregatorAddJob.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorAddJob.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/aggregatorAddJob.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorInit.d.ts +0 -14
- package/dist/@codegen/switchboard_v2/instructions/aggregatorInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorInit.js +0 -60
- package/dist/@codegen/switchboard_v2/instructions/aggregatorInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorLock.d.ts +0 -12
- package/dist/@codegen/switchboard_v2/instructions/aggregatorLock.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorLock.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/aggregatorLock.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorOpenRound.d.ts +0 -21
- package/dist/@codegen/switchboard_v2/instructions/aggregatorOpenRound.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorOpenRound.js +0 -67
- package/dist/@codegen/switchboard_v2/instructions/aggregatorOpenRound.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorRemoveJob.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/aggregatorRemoveJob.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorRemoveJob.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/aggregatorRemoveJob.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResult.d.ts +0 -23
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResult.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResult.js +0 -73
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResult.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResultV2.d.ts +0 -23
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResultV2.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResultV2.js +0 -73
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSaveResultV2.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetAuthority.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetAuthority.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetAuthority.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetAuthority.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetConfig.d.ts +0 -12
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetConfig.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetConfig.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetConfig.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetHistoryBuffer.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetHistoryBuffer.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetHistoryBuffer.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetHistoryBuffer.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetQueue.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetQueue.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetQueue.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetQueue.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetResolutionMode.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetResolutionMode.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetResolutionMode.js +0 -65
- package/dist/@codegen/switchboard_v2/instructions/aggregatorSetResolutionMode.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerInit.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerInit.js +0 -68
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerOpenRound.d.ts +0 -16
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerOpenRound.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerOpenRound.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerOpenRound.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerSaveResult.d.ts +0 -21
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerSaveResult.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerSaveResult.js +0 -71
- package/dist/@codegen/switchboard_v2/instructions/bufferRelayerSaveResult.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankInit.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/instructions/crankInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankInit.js +0 -59
- package/dist/@codegen/switchboard_v2/instructions/crankInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankPop.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/crankPop.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankPop.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/crankPop.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankPopV2.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/crankPopV2.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankPopV2.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/crankPopV2.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankPush.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/crankPush.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/crankPush.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/crankPush.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/index.d.ts +0 -97
- package/dist/@codegen/switchboard_v2/instructions/index.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/index.js +0 -100
- package/dist/@codegen/switchboard_v2/instructions/index.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/jobInit.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/instructions/jobInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/jobInit.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/jobInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/jobSetData.d.ts +0 -12
- package/dist/@codegen/switchboard_v2/instructions/jobSetData.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/jobSetData.js +0 -60
- package/dist/@codegen/switchboard_v2/instructions/jobSetData.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseExtend.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/leaseExtend.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseExtend.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/leaseExtend.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseInit.d.ts +0 -21
- package/dist/@codegen/switchboard_v2/instructions/leaseInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseInit.js +0 -65
- package/dist/@codegen/switchboard_v2/instructions/leaseInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseSetAuthority.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/leaseSetAuthority.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseSetAuthority.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/leaseSetAuthority.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseWithdraw.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/leaseWithdraw.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/leaseWithdraw.js +0 -67
- package/dist/@codegen/switchboard_v2/instructions/leaseWithdraw.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleHeartbeat.d.ts +0 -17
- package/dist/@codegen/switchboard_v2/instructions/oracleHeartbeat.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleHeartbeat.js +0 -67
- package/dist/@codegen/switchboard_v2/instructions/oracleHeartbeat.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleInit.d.ts +0 -17
- package/dist/@codegen/switchboard_v2/instructions/oracleInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleInit.js +0 -61
- package/dist/@codegen/switchboard_v2/instructions/oracleInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueInit.d.ts +0 -16
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueInit.js +0 -66
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueSetConfig.d.ts +0 -12
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueSetConfig.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueSetConfig.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/oracleQueueSetConfig.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleWithdraw.d.ts +0 -20
- package/dist/@codegen/switchboard_v2/instructions/oracleWithdraw.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/oracleWithdraw.js +0 -70
- package/dist/@codegen/switchboard_v2/instructions/oracleWithdraw.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/permissionInit.d.ts +0 -16
- package/dist/@codegen/switchboard_v2/instructions/permissionInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/permissionInit.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/permissionInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/permissionSet.d.ts +0 -12
- package/dist/@codegen/switchboard_v2/instructions/permissionSet.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/permissionSet.js +0 -60
- package/dist/@codegen/switchboard_v2/instructions/permissionSet.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/programConfig.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/programConfig.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/programConfig.js +0 -61
- package/dist/@codegen/switchboard_v2/instructions/programConfig.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/programInit.d.ts +0 -18
- package/dist/@codegen/switchboard_v2/instructions/programInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/programInit.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/programInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vaultTransfer.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/instructions/vaultTransfer.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vaultTransfer.js +0 -63
- package/dist/@codegen/switchboard_v2/instructions/vaultTransfer.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfCloseAction.d.ts +0 -20
- package/dist/@codegen/switchboard_v2/instructions/vrfCloseAction.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfCloseAction.js +0 -68
- package/dist/@codegen/switchboard_v2/instructions/vrfCloseAction.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfInit.d.ts +0 -16
- package/dist/@codegen/switchboard_v2/instructions/vrfInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfInit.js +0 -60
- package/dist/@codegen/switchboard_v2/instructions/vrfInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteCloseAction.d.ts +0 -20
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteCloseAction.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteCloseAction.js +0 -68
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteCloseAction.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteInit.d.ts +0 -23
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteInit.js +0 -67
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteProveAndVerify.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteProveAndVerify.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteProveAndVerify.js +0 -69
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteProveAndVerify.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteRequestRandomness.d.ts +0 -20
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteRequestRandomness.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteRequestRandomness.js +0 -70
- package/dist/@codegen/switchboard_v2/instructions/vrfLiteRequestRandomness.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolAdd.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolAdd.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolAdd.js +0 -59
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolAdd.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolInit.d.ts +0 -21
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolInit.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolInit.js +0 -65
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolInit.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRemove.d.ts +0 -13
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRemove.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRemove.js +0 -61
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRemove.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRequest.d.ts +0 -20
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRequest.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRequest.js +0 -70
- package/dist/@codegen/switchboard_v2/instructions/vrfPoolRequest.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfProveAndVerify.d.ts +0 -19
- package/dist/@codegen/switchboard_v2/instructions/vrfProveAndVerify.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfProveAndVerify.js +0 -69
- package/dist/@codegen/switchboard_v2/instructions/vrfProveAndVerify.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfRequestRandomness.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/instructions/vrfRequestRandomness.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfRequestRandomness.js +0 -76
- package/dist/@codegen/switchboard_v2/instructions/vrfRequestRandomness.js.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfSetCallback.d.ts +0 -12
- package/dist/@codegen/switchboard_v2/instructions/vrfSetCallback.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/instructions/vrfSetCallback.js +0 -62
- package/dist/@codegen/switchboard_v2/instructions/vrfSetCallback.js.map +0 -1
- package/dist/@codegen/switchboard_v2/programId.d.ts +0 -4
- package/dist/@codegen/switchboard_v2/programId.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/programId.js +0 -9
- package/dist/@codegen/switchboard_v2/programId.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AccountMetaBorsh.d.ts +0 -33
- package/dist/@codegen/switchboard_v2/types/AccountMetaBorsh.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AccountMetaBorsh.js +0 -90
- package/dist/@codegen/switchboard_v2/types/AccountMetaBorsh.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AccountMetaZC.d.ts +0 -33
- package/dist/@codegen/switchboard_v2/types/AccountMetaZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AccountMetaZC.js +0 -90
- package/dist/@codegen/switchboard_v2/types/AccountMetaZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorAddJobParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorAddJobParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorAddJobParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorAddJobParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorHistoryRow.d.ts +0 -34
- package/dist/@codegen/switchboard_v2/types/AggregatorHistoryRow.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorHistoryRow.js +0 -83
- package/dist/@codegen/switchboard_v2/types/AggregatorHistoryRow.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorInitParams.d.ts +0 -84
- package/dist/@codegen/switchboard_v2/types/AggregatorInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorInitParams.js +0 -158
- package/dist/@codegen/switchboard_v2/types/AggregatorInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorLockParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/AggregatorLockParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorLockParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/AggregatorLockParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorOpenRoundParams.d.ts +0 -37
- package/dist/@codegen/switchboard_v2/types/AggregatorOpenRoundParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorOpenRoundParams.js +0 -95
- package/dist/@codegen/switchboard_v2/types/AggregatorOpenRoundParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorRemoveJobParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorRemoveJobParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorRemoveJobParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorRemoveJobParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorResolutionMode.d.ts +0 -32
- package/dist/@codegen/switchboard_v2/types/AggregatorResolutionMode.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorResolutionMode.js +0 -108
- package/dist/@codegen/switchboard_v2/types/AggregatorResolutionMode.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorRound.d.ts +0 -119
- package/dist/@codegen/switchboard_v2/types/AggregatorRound.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorRound.js +0 -172
- package/dist/@codegen/switchboard_v2/types/AggregatorRound.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParams.d.ts +0 -86
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParams.js +0 -138
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParamsV2.d.ts +0 -97
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParamsV2.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParamsV2.js +0 -145
- package/dist/@codegen/switchboard_v2/types/AggregatorSaveResultParamsV2.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetAuthorityParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/AggregatorSetAuthorityParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetAuthorityParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/AggregatorSetAuthorityParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetBatchSizeParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorSetBatchSizeParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetBatchSizeParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorSetBatchSizeParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetConfigParams.d.ts +0 -84
- package/dist/@codegen/switchboard_v2/types/AggregatorSetConfigParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetConfigParams.js +0 -161
- package/dist/@codegen/switchboard_v2/types/AggregatorSetConfigParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetForceReportPeriodParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorSetForceReportPeriodParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetForceReportPeriodParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorSetForceReportPeriodParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetHistoryBufferParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/AggregatorSetHistoryBufferParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetHistoryBufferParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/AggregatorSetHistoryBufferParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinJobsParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinJobsParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinJobsParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinJobsParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinOraclesParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinOraclesParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinOraclesParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorSetMinOraclesParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetQueueParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/AggregatorSetQueueParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetQueueParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/AggregatorSetQueueParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetResolutionModeParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorSetResolutionModeParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetResolutionModeParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorSetResolutionModeParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetUpdateIntervalParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/AggregatorSetUpdateIntervalParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetUpdateIntervalParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/AggregatorSetUpdateIntervalParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetVarianceThresholdParams.d.ts +0 -29
- package/dist/@codegen/switchboard_v2/types/AggregatorSetVarianceThresholdParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/AggregatorSetVarianceThresholdParams.js +0 -75
- package/dist/@codegen/switchboard_v2/types/AggregatorSetVarianceThresholdParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BorshDecimal.d.ts +0 -28
- package/dist/@codegen/switchboard_v2/types/BorshDecimal.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BorshDecimal.js +0 -82
- package/dist/@codegen/switchboard_v2/types/BorshDecimal.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerInitParams.d.ts +0 -32
- package/dist/@codegen/switchboard_v2/types/BufferRelayerInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerInitParams.js +0 -88
- package/dist/@codegen/switchboard_v2/types/BufferRelayerInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerOpenRoundParams.d.ts +0 -27
- package/dist/@codegen/switchboard_v2/types/BufferRelayerOpenRoundParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerOpenRoundParams.js +0 -78
- package/dist/@codegen/switchboard_v2/types/BufferRelayerOpenRoundParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerRound.d.ts +0 -44
- package/dist/@codegen/switchboard_v2/types/BufferRelayerRound.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerRound.js +0 -108
- package/dist/@codegen/switchboard_v2/types/BufferRelayerRound.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerSaveResultParams.d.ts +0 -37
- package/dist/@codegen/switchboard_v2/types/BufferRelayerSaveResultParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/BufferRelayerSaveResultParams.js +0 -95
- package/dist/@codegen/switchboard_v2/types/BufferRelayerSaveResultParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Callback.d.ts +0 -41
- package/dist/@codegen/switchboard_v2/types/Callback.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Callback.js +0 -91
- package/dist/@codegen/switchboard_v2/types/Callback.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CallbackZC.d.ts +0 -51
- package/dist/@codegen/switchboard_v2/types/CallbackZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CallbackZC.js +0 -105
- package/dist/@codegen/switchboard_v2/types/CallbackZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CompletedPointZC.d.ts +0 -54
- package/dist/@codegen/switchboard_v2/types/CompletedPointZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CompletedPointZC.js +0 -96
- package/dist/@codegen/switchboard_v2/types/CompletedPointZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankInitParams.d.ts +0 -32
- package/dist/@codegen/switchboard_v2/types/CrankInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankInitParams.js +0 -84
- package/dist/@codegen/switchboard_v2/types/CrankInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankPopParams.d.ts +0 -42
- package/dist/@codegen/switchboard_v2/types/CrankPopParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankPopParams.js +0 -102
- package/dist/@codegen/switchboard_v2/types/CrankPopParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankPopParamsV2.d.ts +0 -47
- package/dist/@codegen/switchboard_v2/types/CrankPopParamsV2.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankPopParamsV2.js +0 -109
- package/dist/@codegen/switchboard_v2/types/CrankPopParamsV2.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankPushParams.d.ts +0 -32
- package/dist/@codegen/switchboard_v2/types/CrankPushParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankPushParams.js +0 -88
- package/dist/@codegen/switchboard_v2/types/CrankPushParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankRow.d.ts +0 -29
- package/dist/@codegen/switchboard_v2/types/CrankRow.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/CrankRow.js +0 -84
- package/dist/@codegen/switchboard_v2/types/CrankRow.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/EcvrfIntermediate.d.ts +0 -63
- package/dist/@codegen/switchboard_v2/types/EcvrfIntermediate.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/EcvrfIntermediate.js +0 -103
- package/dist/@codegen/switchboard_v2/types/EcvrfIntermediate.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/EcvrfProofZC.d.ts +0 -67
- package/dist/@codegen/switchboard_v2/types/EcvrfProofZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/EcvrfProofZC.js +0 -89
- package/dist/@codegen/switchboard_v2/types/EcvrfProofZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/EdwardsPointZC.d.ts +0 -54
- package/dist/@codegen/switchboard_v2/types/EdwardsPointZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/EdwardsPointZC.js +0 -96
- package/dist/@codegen/switchboard_v2/types/EdwardsPointZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Error.d.ts +0 -58
- package/dist/@codegen/switchboard_v2/types/Error.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Error.js +0 -156
- package/dist/@codegen/switchboard_v2/types/Error.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/FieldElementZC.d.ts +0 -23
- package/dist/@codegen/switchboard_v2/types/FieldElementZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/FieldElementZC.js +0 -76
- package/dist/@codegen/switchboard_v2/types/FieldElementZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Hash.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/Hash.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Hash.js +0 -72
- package/dist/@codegen/switchboard_v2/types/Hash.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/JobInitParams.d.ts +0 -43
- package/dist/@codegen/switchboard_v2/types/JobInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/JobInitParams.js +0 -106
- package/dist/@codegen/switchboard_v2/types/JobInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/JobSetDataParams.d.ts +0 -27
- package/dist/@codegen/switchboard_v2/types/JobSetDataParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/JobSetDataParams.js +0 -78
- package/dist/@codegen/switchboard_v2/types/JobSetDataParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseExtendParams.d.ts +0 -38
- package/dist/@codegen/switchboard_v2/types/LeaseExtendParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseExtendParams.js +0 -99
- package/dist/@codegen/switchboard_v2/types/LeaseExtendParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseInitParams.d.ts +0 -44
- package/dist/@codegen/switchboard_v2/types/LeaseInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseInitParams.js +0 -108
- package/dist/@codegen/switchboard_v2/types/LeaseInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseSetAuthorityParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/LeaseSetAuthorityParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseSetAuthorityParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/LeaseSetAuthorityParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseWithdrawParams.d.ts +0 -33
- package/dist/@codegen/switchboard_v2/types/LeaseWithdrawParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/LeaseWithdrawParams.js +0 -88
- package/dist/@codegen/switchboard_v2/types/LeaseWithdrawParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleHeartbeatParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/OracleHeartbeatParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleHeartbeatParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/OracleHeartbeatParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleInitParams.d.ts +0 -37
- package/dist/@codegen/switchboard_v2/types/OracleInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleInitParams.js +0 -95
- package/dist/@codegen/switchboard_v2/types/OracleInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleMetrics.d.ts +0 -63
- package/dist/@codegen/switchboard_v2/types/OracleMetrics.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleMetrics.js +0 -134
- package/dist/@codegen/switchboard_v2/types/OracleMetrics.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleQueueInitParams.d.ts +0 -94
- package/dist/@codegen/switchboard_v2/types/OracleQueueInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleQueueInitParams.js +0 -172
- package/dist/@codegen/switchboard_v2/types/OracleQueueInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetConfigParams.d.ts +0 -84
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetConfigParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetConfigParams.js +0 -175
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetConfigParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetRewardsParams.d.ts +0 -23
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetRewardsParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetRewardsParams.js +0 -76
- package/dist/@codegen/switchboard_v2/types/OracleQueueSetRewardsParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleResponseType.d.ts +0 -58
- package/dist/@codegen/switchboard_v2/types/OracleResponseType.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleResponseType.js +0 -156
- package/dist/@codegen/switchboard_v2/types/OracleResponseType.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleWithdrawParams.d.ts +0 -33
- package/dist/@codegen/switchboard_v2/types/OracleWithdrawParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/OracleWithdrawParams.js +0 -88
- package/dist/@codegen/switchboard_v2/types/OracleWithdrawParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/PermissionInitParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/PermissionInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/PermissionInitParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/PermissionInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/PermissionSetParams.d.ts +0 -39
- package/dist/@codegen/switchboard_v2/types/PermissionSetParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/PermissionSetParams.js +0 -79
- package/dist/@codegen/switchboard_v2/types/PermissionSetParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/ProgramConfigParams.d.ts +0 -33
- package/dist/@codegen/switchboard_v2/types/ProgramConfigParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/ProgramConfigParams.js +0 -86
- package/dist/@codegen/switchboard_v2/types/ProgramConfigParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/ProgramInitParams.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/ProgramInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/ProgramInitParams.js +0 -72
- package/dist/@codegen/switchboard_v2/types/ProgramInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/ProjectivePointZC.d.ts +0 -45
- package/dist/@codegen/switchboard_v2/types/ProjectivePointZC.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/ProjectivePointZC.js +0 -89
- package/dist/@codegen/switchboard_v2/types/ProjectivePointZC.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Scalar.d.ts +0 -22
- package/dist/@codegen/switchboard_v2/types/Scalar.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/Scalar.js +0 -72
- package/dist/@codegen/switchboard_v2/types/Scalar.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/SlidingWindowElement.d.ts +0 -45
- package/dist/@codegen/switchboard_v2/types/SlidingWindowElement.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/SlidingWindowElement.js +0 -102
- package/dist/@codegen/switchboard_v2/types/SlidingWindowElement.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/SwitchboardDecimal.d.ts +0 -28
- package/dist/@codegen/switchboard_v2/types/SwitchboardDecimal.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/SwitchboardDecimal.js +0 -82
- package/dist/@codegen/switchboard_v2/types/SwitchboardDecimal.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/SwitchboardPermission.d.ts +0 -45
- package/dist/@codegen/switchboard_v2/types/SwitchboardPermission.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/SwitchboardPermission.js +0 -132
- package/dist/@codegen/switchboard_v2/types/SwitchboardPermission.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VaultTransferParams.d.ts +0 -28
- package/dist/@codegen/switchboard_v2/types/VaultTransferParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VaultTransferParams.js +0 -82
- package/dist/@codegen/switchboard_v2/types/VaultTransferParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfBuilder.d.ts +0 -661
- package/dist/@codegen/switchboard_v2/types/VrfBuilder.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfBuilder.js +0 -338
- package/dist/@codegen/switchboard_v2/types/VrfBuilder.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfCloseParams.d.ts +0 -27
- package/dist/@codegen/switchboard_v2/types/VrfCloseParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfCloseParams.js +0 -78
- package/dist/@codegen/switchboard_v2/types/VrfCloseParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfInitParams.d.ts +0 -44
- package/dist/@codegen/switchboard_v2/types/VrfInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfInitParams.js +0 -79
- package/dist/@codegen/switchboard_v2/types/VrfInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteCloseParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/VrfLiteCloseParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteCloseParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/VrfLiteCloseParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteInitParams.d.ts +0 -50
- package/dist/@codegen/switchboard_v2/types/VrfLiteInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteInitParams.js +0 -95
- package/dist/@codegen/switchboard_v2/types/VrfLiteInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteProveAndVerifyParams.d.ts +0 -38
- package/dist/@codegen/switchboard_v2/types/VrfLiteProveAndVerifyParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteProveAndVerifyParams.js +0 -99
- package/dist/@codegen/switchboard_v2/types/VrfLiteProveAndVerifyParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteRequestRandomnessParams.d.ts +0 -39
- package/dist/@codegen/switchboard_v2/types/VrfLiteRequestRandomnessParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfLiteRequestRandomnessParams.js +0 -75
- package/dist/@codegen/switchboard_v2/types/VrfLiteRequestRandomnessParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolAddParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/VrfPoolAddParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolAddParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/VrfPoolAddParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolInitParams.d.ts +0 -32
- package/dist/@codegen/switchboard_v2/types/VrfPoolInitParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolInitParams.js +0 -84
- package/dist/@codegen/switchboard_v2/types/VrfPoolInitParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolRemoveParams.d.ts +0 -15
- package/dist/@codegen/switchboard_v2/types/VrfPoolRemoveParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolRemoveParams.js +0 -61
- package/dist/@codegen/switchboard_v2/types/VrfPoolRemoveParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolRequestParams.d.ts +0 -39
- package/dist/@codegen/switchboard_v2/types/VrfPoolRequestParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolRequestParams.js +0 -75
- package/dist/@codegen/switchboard_v2/types/VrfPoolRequestParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolRow.d.ts +0 -29
- package/dist/@codegen/switchboard_v2/types/VrfPoolRow.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfPoolRow.js +0 -84
- package/dist/@codegen/switchboard_v2/types/VrfPoolRow.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfProveAndVerifyParams.d.ts +0 -48
- package/dist/@codegen/switchboard_v2/types/VrfProveAndVerifyParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfProveAndVerifyParams.js +0 -113
- package/dist/@codegen/switchboard_v2/types/VrfProveAndVerifyParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfProveParams.d.ts +0 -27
- package/dist/@codegen/switchboard_v2/types/VrfProveParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfProveParams.js +0 -78
- package/dist/@codegen/switchboard_v2/types/VrfProveParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfRequestRandomnessParams.d.ts +0 -27
- package/dist/@codegen/switchboard_v2/types/VrfRequestRandomnessParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfRequestRandomnessParams.js +0 -78
- package/dist/@codegen/switchboard_v2/types/VrfRequestRandomnessParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfRound.d.ts +0 -53
- package/dist/@codegen/switchboard_v2/types/VrfRound.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfRound.js +0 -120
- package/dist/@codegen/switchboard_v2/types/VrfRound.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfSetCallbackParams.d.ts +0 -39
- package/dist/@codegen/switchboard_v2/types/VrfSetCallbackParams.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfSetCallbackParams.js +0 -73
- package/dist/@codegen/switchboard_v2/types/VrfSetCallbackParams.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfStatus.d.ts +0 -84
- package/dist/@codegen/switchboard_v2/types/VrfStatus.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/VrfStatus.js +0 -204
- package/dist/@codegen/switchboard_v2/types/VrfStatus.js.map +0 -1
- package/dist/@codegen/switchboard_v2/types/index.d.ts +0 -179
- package/dist/@codegen/switchboard_v2/types/index.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/types/index.js +0 -207
- package/dist/@codegen/switchboard_v2/types/index.js.map +0 -1
- package/dist/@codegen/switchboard_v2/utils/borshAddress.d.ts +0 -4
- package/dist/@codegen/switchboard_v2/utils/borshAddress.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/utils/borshAddress.js +0 -30
- package/dist/@codegen/switchboard_v2/utils/borshAddress.js.map +0 -1
- package/dist/@codegen/switchboard_v2/utils/index.d.ts +0 -2
- package/dist/@codegen/switchboard_v2/utils/index.d.ts.map +0 -1
- package/dist/@codegen/switchboard_v2/utils/index.js +0 -18
- package/dist/@codegen/switchboard_v2/utils/index.js.map +0 -1
- package/dist/@codegen/unstaking_pool/accounts/PoolState.d.ts +0 -53
- package/dist/@codegen/unstaking_pool/accounts/PoolState.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/accounts/PoolState.js +0 -167
- package/dist/@codegen/unstaking_pool/accounts/PoolState.js.map +0 -1
- package/dist/@codegen/unstaking_pool/accounts/UnstakeTicket.d.ts +0 -41
- package/dist/@codegen/unstaking_pool/accounts/UnstakeTicket.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/accounts/UnstakeTicket.js +0 -143
- package/dist/@codegen/unstaking_pool/accounts/UnstakeTicket.js.map +0 -1
- package/dist/@codegen/unstaking_pool/accounts/index.d.ts +0 -5
- package/dist/@codegen/unstaking_pool/accounts/index.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/accounts/index.js +0 -8
- package/dist/@codegen/unstaking_pool/accounts/index.js.map +0 -1
- package/dist/@codegen/unstaking_pool/errors/anchor.d.ts +0 -435
- package/dist/@codegen/unstaking_pool/errors/anchor.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/errors/anchor.js +0 -767
- package/dist/@codegen/unstaking_pool/errors/anchor.js.map +0 -1
- package/dist/@codegen/unstaking_pool/errors/custom.d.ts +0 -259
- package/dist/@codegen/unstaking_pool/errors/custom.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/errors/custom.js +0 -458
- package/dist/@codegen/unstaking_pool/errors/custom.js.map +0 -1
- package/dist/@codegen/unstaking_pool/errors/index.d.ts +0 -6
- package/dist/@codegen/unstaking_pool/errors/index.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/errors/index.js +0 -86
- package/dist/@codegen/unstaking_pool/errors/index.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/burn.d.ts +0 -21
- package/dist/@codegen/unstaking_pool/instructions/burn.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/burn.js +0 -67
- package/dist/@codegen/unstaking_pool/instructions/burn.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/changeTicketAuthority.d.ts +0 -8
- package/dist/@codegen/unstaking_pool/instructions/changeTicketAuthority.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/changeTicketAuthority.js +0 -16
- package/dist/@codegen/unstaking_pool/instructions/changeTicketAuthority.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/collect.d.ts +0 -16
- package/dist/@codegen/unstaking_pool/instructions/collect.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/collect.js +0 -24
- package/dist/@codegen/unstaking_pool/instructions/collect.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/index.d.ts +0 -17
- package/dist/@codegen/unstaking_pool/instructions/index.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/index.js +0 -20
- package/dist/@codegen/unstaking_pool/instructions/index.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/initializePool.d.ts +0 -14
- package/dist/@codegen/unstaking_pool/instructions/initializePool.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/initializePool.js +0 -22
- package/dist/@codegen/unstaking_pool/instructions/initializePool.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/mint.d.ts +0 -24
- package/dist/@codegen/unstaking_pool/instructions/mint.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/mint.js +0 -74
- package/dist/@codegen/unstaking_pool/instructions/mint.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/splitTicket.d.ts +0 -15
- package/dist/@codegen/unstaking_pool/instructions/splitTicket.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/splitTicket.js +0 -62
- package/dist/@codegen/unstaking_pool/instructions/splitTicket.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/updateAdmin.d.ts +0 -7
- package/dist/@codegen/unstaking_pool/instructions/updateAdmin.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/updateAdmin.js +0 -19
- package/dist/@codegen/unstaking_pool/instructions/updateAdmin.js.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/updatePoolConfig.d.ts +0 -13
- package/dist/@codegen/unstaking_pool/instructions/updatePoolConfig.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/instructions/updatePoolConfig.js +0 -60
- package/dist/@codegen/unstaking_pool/instructions/updatePoolConfig.js.map +0 -1
- package/dist/@codegen/unstaking_pool/programId.d.ts +0 -4
- package/dist/@codegen/unstaking_pool/programId.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/programId.js +0 -9
- package/dist/@codegen/unstaking_pool/programId.js.map +0 -1
- package/dist/@codegen/unstaking_pool/types/PoolConfigField.d.ts +0 -45
- package/dist/@codegen/unstaking_pool/types/PoolConfigField.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/types/PoolConfigField.js +0 -132
- package/dist/@codegen/unstaking_pool/types/PoolConfigField.js.map +0 -1
- package/dist/@codegen/unstaking_pool/types/index.d.ts +0 -5
- package/dist/@codegen/unstaking_pool/types/index.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/types/index.js +0 -39
- package/dist/@codegen/unstaking_pool/types/index.js.map +0 -1
- package/dist/@codegen/unstaking_pool/utils/borshAddress.d.ts +0 -4
- package/dist/@codegen/unstaking_pool/utils/borshAddress.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/utils/borshAddress.js +0 -30
- package/dist/@codegen/unstaking_pool/utils/borshAddress.js.map +0 -1
- package/dist/@codegen/unstaking_pool/utils/index.d.ts +0 -2
- package/dist/@codegen/unstaking_pool/utils/index.d.ts.map +0 -1
- package/dist/@codegen/unstaking_pool/utils/index.js +0 -18
- package/dist/@codegen/unstaking_pool/utils/index.js.map +0 -1
- package/dist/classes/action.d.ts +0 -211
- package/dist/classes/action.d.ts.map +0 -1
- package/dist/classes/action.js +0 -2230
- package/dist/classes/action.js.map +0 -1
- package/dist/classes/configItems.d.ts +0 -166
- package/dist/classes/configItems.d.ts.map +0 -1
- package/dist/classes/configItems.js +0 -202
- package/dist/classes/configItems.js.map +0 -1
- package/dist/classes/curve.d.ts +0 -16
- package/dist/classes/curve.d.ts.map +0 -1
- package/dist/classes/curve.js +0 -32
- package/dist/classes/curve.js.map +0 -1
- package/dist/classes/farm_utils.d.ts +0 -40
- package/dist/classes/farm_utils.d.ts.map +0 -1
- package/dist/classes/farm_utils.js +0 -168
- package/dist/classes/farm_utils.js.map +0 -1
- package/dist/classes/fraction.d.ts +0 -27
- package/dist/classes/fraction.d.ts.map +0 -1
- package/dist/classes/fraction.js +0 -91
- package/dist/classes/fraction.js.map +0 -1
- package/dist/classes/index.d.ts +0 -19
- package/dist/classes/index.d.ts.map +0 -1
- package/dist/classes/index.js +0 -35
- package/dist/classes/index.js.map +0 -1
- package/dist/classes/jupiterPerps.d.ts +0 -3
- package/dist/classes/jupiterPerps.d.ts.map +0 -1
- package/dist/classes/jupiterPerps.js +0 -13
- package/dist/classes/jupiterPerps.js.map +0 -1
- package/dist/classes/manager.d.ts +0 -686
- package/dist/classes/manager.d.ts.map +0 -1
- package/dist/classes/manager.js +0 -1206
- package/dist/classes/manager.js.map +0 -1
- package/dist/classes/market.d.ts +0 -250
- package/dist/classes/market.d.ts.map +0 -1
- package/dist/classes/market.js +0 -1240
- package/dist/classes/market.js.map +0 -1
- package/dist/classes/obligation.d.ts +0 -321
- package/dist/classes/obligation.d.ts.map +0 -1
- package/dist/classes/obligation.js +0 -1171
- package/dist/classes/obligation.js.map +0 -1
- package/dist/classes/obligationOrder.d.ts +0 -230
- package/dist/classes/obligationOrder.d.ts.map +0 -1
- package/dist/classes/obligationOrder.js +0 -407
- package/dist/classes/obligationOrder.js.map +0 -1
- package/dist/classes/reserve.d.ts +0 -257
- package/dist/classes/reserve.d.ts.map +0 -1
- package/dist/classes/reserve.js +0 -1020
- package/dist/classes/reserve.js.map +0 -1
- package/dist/classes/shared.d.ts +0 -74
- package/dist/classes/shared.d.ts.map +0 -1
- package/dist/classes/shared.js +0 -15
- package/dist/classes/shared.js.map +0 -1
- package/dist/classes/stakePool.d.ts +0 -8
- package/dist/classes/stakePool.d.ts.map +0 -1
- package/dist/classes/stakePool.js +0 -18
- package/dist/classes/stakePool.js.map +0 -1
- package/dist/classes/standardStakePool.d.ts +0 -76
- package/dist/classes/standardStakePool.d.ts.map +0 -1
- package/dist/classes/standardStakePool.js +0 -400
- package/dist/classes/standardStakePool.js.map +0 -1
- package/dist/classes/unstakingPool.d.ts +0 -115
- package/dist/classes/unstakingPool.d.ts.map +0 -1
- package/dist/classes/unstakingPool.js +0 -372
- package/dist/classes/unstakingPool.js.map +0 -1
- package/dist/classes/unstakingPoolTypes.d.ts +0 -10
- package/dist/classes/unstakingPoolTypes.d.ts.map +0 -1
- package/dist/classes/unstakingPoolTypes.js +0 -3
- package/dist/classes/unstakingPoolTypes.js.map +0 -1
- package/dist/classes/utils.d.ts +0 -75
- package/dist/classes/utils.d.ts.map +0 -1
- package/dist/classes/utils.js +0 -256
- package/dist/classes/utils.js.map +0 -1
- package/dist/classes/vault.d.ts +0 -805
- package/dist/classes/vault.d.ts.map +0 -1
- package/dist/classes/vault.js +0 -3075
- package/dist/classes/vault.js.map +0 -1
- package/dist/classes/vault_types.d.ts +0 -75
- package/dist/classes/vault_types.d.ts.map +0 -1
- package/dist/classes/vault_types.js +0 -3
- package/dist/classes/vault_types.js.map +0 -1
- package/dist/client/commands/borrow.d.ts +0 -4
- package/dist/client/commands/borrow.d.ts.map +0 -1
- package/dist/client/commands/borrow.js +0 -21
- package/dist/client/commands/borrow.js.map +0 -1
- package/dist/client/commands/deposit.d.ts +0 -4
- package/dist/client/commands/deposit.d.ts.map +0 -1
- package/dist/client/commands/deposit.js +0 -21
- package/dist/client/commands/deposit.js.map +0 -1
- package/dist/client/commands/initFarmsForReserve.d.ts +0 -4
- package/dist/client/commands/initFarmsForReserve.d.ts.map +0 -1
- package/dist/client/commands/initFarmsForReserve.js +0 -48
- package/dist/client/commands/initFarmsForReserve.js.map +0 -1
- package/dist/client/commands/printAllReserveAccounts.d.ts +0 -3
- package/dist/client/commands/printAllReserveAccounts.d.ts.map +0 -1
- package/dist/client/commands/printAllReserveAccounts.js +0 -20
- package/dist/client/commands/printAllReserveAccounts.js.map +0 -1
- package/dist/client/commands/printReserve.d.ts +0 -3
- package/dist/client/commands/printReserve.d.ts.map +0 -1
- package/dist/client/commands/printReserve.js +0 -16
- package/dist/client/commands/printReserve.js.map +0 -1
- package/dist/client/commands/repay.d.ts +0 -4
- package/dist/client/commands/repay.d.ts.map +0 -1
- package/dist/client/commands/repay.js +0 -21
- package/dist/client/commands/repay.js.map +0 -1
- package/dist/client/commands/withdraw.d.ts +0 -4
- package/dist/client/commands/withdraw.d.ts.map +0 -1
- package/dist/client/commands/withdraw.js +0 -21
- package/dist/client/commands/withdraw.js.map +0 -1
- package/dist/client/services/market.d.ts +0 -6
- package/dist/client/services/market.d.ts.map +0 -1
- package/dist/client/services/market.js +0 -28
- package/dist/client/services/market.js.map +0 -1
- package/dist/client/services/userMetadata.d.ts +0 -4
- package/dist/client/services/userMetadata.d.ts.map +0 -1
- package/dist/client/services/userMetadata.js +0 -23
- package/dist/client/services/userMetadata.js.map +0 -1
- package/dist/client/tx/CliConnectionPool.d.ts +0 -17
- package/dist/client/tx/CliConnectionPool.d.ts.map +0 -1
- package/dist/client/tx/CliConnectionPool.js +0 -39
- package/dist/client/tx/CliConnectionPool.js.map +0 -1
- package/dist/client/tx/CliEnv.d.ts +0 -27
- package/dist/client/tx/CliEnv.d.ts.map +0 -1
- package/dist/client/tx/CliEnv.js +0 -114
- package/dist/client/tx/CliEnv.js.map +0 -1
- package/dist/client/tx/keypair.d.ts +0 -4
- package/dist/client/tx/keypair.d.ts.map +0 -1
- package/dist/client/tx/keypair.js +0 -20
- package/dist/client/tx/keypair.js.map +0 -1
- package/dist/client/tx/multisig.d.ts +0 -4
- package/dist/client/tx/multisig.d.ts.map +0 -1
- package/dist/client/tx/multisig.js +0 -22
- package/dist/client/tx/multisig.js.map +0 -1
- package/dist/client/tx/priorityFee.d.ts +0 -7
- package/dist/client/tx/priorityFee.d.ts.map +0 -1
- package/dist/client/tx/priorityFee.js +0 -25
- package/dist/client/tx/priorityFee.js.map +0 -1
- package/dist/client/tx/processor.d.ts +0 -6
- package/dist/client/tx/processor.d.ts.map +0 -1
- package/dist/client/tx/processor.js +0 -25
- package/dist/client/tx/processor.js.map +0 -1
- package/dist/client/tx/rpc.d.ts +0 -30
- package/dist/client/tx/rpc.d.ts.map +0 -1
- package/dist/client/tx/rpc.js +0 -89
- package/dist/client/tx/rpc.js.map +0 -1
- package/dist/client/tx/simulate.d.ts +0 -7
- package/dist/client/tx/simulate.d.ts.map +0 -1
- package/dist/client/tx/simulate.js +0 -36
- package/dist/client/tx/simulate.js.map +0 -1
- package/dist/client/tx/tx.d.ts +0 -16
- package/dist/client/tx/tx.d.ts.map +0 -1
- package/dist/client/tx/tx.js +0 -115
- package/dist/client/tx/tx.js.map +0 -1
- package/dist/client/utils/modifiers.d.ts +0 -7
- package/dist/client/utils/modifiers.d.ts.map +0 -1
- package/dist/client/utils/modifiers.js +0 -3
- package/dist/client/utils/modifiers.js.map +0 -1
- package/dist/idl/klend.json +0 -6284
- package/dist/index.d.ts.map +0 -1
- package/dist/lending_operations/index.d.ts +0 -4
- package/dist/lending_operations/index.d.ts.map +0 -1
- package/dist/lending_operations/index.js +0 -20
- package/dist/lending_operations/index.js.map +0 -1
- package/dist/lending_operations/repay_with_collateral_calcs.d.ts +0 -38
- package/dist/lending_operations/repay_with_collateral_calcs.d.ts.map +0 -1
- package/dist/lending_operations/repay_with_collateral_calcs.js +0 -134
- package/dist/lending_operations/repay_with_collateral_calcs.js.map +0 -1
- package/dist/lending_operations/repay_with_collateral_operations.d.ts +0 -60
- package/dist/lending_operations/repay_with_collateral_operations.d.ts.map +0 -1
- package/dist/lending_operations/repay_with_collateral_operations.js +0 -209
- package/dist/lending_operations/repay_with_collateral_operations.js.map +0 -1
- package/dist/lending_operations/swap_collateral_operations.d.ts +0 -108
- package/dist/lending_operations/swap_collateral_operations.d.ts.map +0 -1
- package/dist/lending_operations/swap_collateral_operations.js +0 -321
- package/dist/lending_operations/swap_collateral_operations.js.map +0 -1
- package/dist/leverage/calcs.d.ts +0 -134
- package/dist/leverage/calcs.d.ts.map +0 -1
- package/dist/leverage/calcs.js +0 -342
- package/dist/leverage/calcs.js.map +0 -1
- package/dist/leverage/index.d.ts +0 -6
- package/dist/leverage/index.d.ts.map +0 -1
- package/dist/leverage/index.js +0 -22
- package/dist/leverage/index.js.map +0 -1
- package/dist/leverage/instructions.d.ts +0 -42
- package/dist/leverage/instructions.d.ts.map +0 -1
- package/dist/leverage/instructions.js +0 -80
- package/dist/leverage/instructions.js.map +0 -1
- package/dist/leverage/operations.d.ts +0 -30
- package/dist/leverage/operations.d.ts.map +0 -1
- package/dist/leverage/operations.js +0 -740
- package/dist/leverage/operations.js.map +0 -1
- package/dist/leverage/types.d.ts +0 -154
- package/dist/leverage/types.d.ts.map +0 -1
- package/dist/leverage/types.js +0 -3
- package/dist/leverage/types.js.map +0 -1
- package/dist/leverage/utils.d.ts +0 -6
- package/dist/leverage/utils.d.ts.map +0 -1
- package/dist/leverage/utils.js +0 -21
- package/dist/leverage/utils.js.map +0 -1
- package/dist/lib.d.ts +0 -17
- package/dist/lib.d.ts.map +0 -1
- package/dist/lib.js +0 -38
- package/dist/lib.js.map +0 -1
- package/dist/manager/client_kamino_manager.d.ts +0 -2
- package/dist/manager/client_kamino_manager.d.ts.map +0 -1
- package/dist/manager/client_kamino_manager.js +0 -1673
- package/dist/manager/client_kamino_manager.js.map +0 -1
- package/dist/manager/tx/ManagerConnectionPool.d.ts +0 -17
- package/dist/manager/tx/ManagerConnectionPool.d.ts.map +0 -1
- package/dist/manager/tx/ManagerConnectionPool.js +0 -39
- package/dist/manager/tx/ManagerConnectionPool.js.map +0 -1
- package/dist/manager/tx/ManagerEnv.d.ts +0 -37
- package/dist/manager/tx/ManagerEnv.d.ts.map +0 -1
- package/dist/manager/tx/ManagerEnv.js +0 -151
- package/dist/manager/tx/ManagerEnv.js.map +0 -1
- package/dist/manager/tx/keypair.d.ts +0 -4
- package/dist/manager/tx/keypair.d.ts.map +0 -1
- package/dist/manager/tx/keypair.js +0 -20
- package/dist/manager/tx/keypair.js.map +0 -1
- package/dist/manager/tx/multisig.d.ts +0 -4
- package/dist/manager/tx/multisig.d.ts.map +0 -1
- package/dist/manager/tx/multisig.js +0 -22
- package/dist/manager/tx/multisig.js.map +0 -1
- package/dist/manager/tx/priorityFee.d.ts +0 -7
- package/dist/manager/tx/priorityFee.d.ts.map +0 -1
- package/dist/manager/tx/priorityFee.js +0 -25
- package/dist/manager/tx/priorityFee.js.map +0 -1
- package/dist/manager/tx/processor.d.ts +0 -6
- package/dist/manager/tx/processor.d.ts.map +0 -1
- package/dist/manager/tx/processor.js +0 -22
- package/dist/manager/tx/processor.js.map +0 -1
- package/dist/manager/tx/rpc.d.ts +0 -30
- package/dist/manager/tx/rpc.d.ts.map +0 -1
- package/dist/manager/tx/rpc.js +0 -89
- package/dist/manager/tx/rpc.js.map +0 -1
- package/dist/manager/tx/simulate.d.ts +0 -7
- package/dist/manager/tx/simulate.d.ts.map +0 -1
- package/dist/manager/tx/simulate.js +0 -36
- package/dist/manager/tx/simulate.js.map +0 -1
- package/dist/manager/tx/tx.d.ts +0 -16
- package/dist/manager/tx/tx.d.ts.map +0 -1
- package/dist/manager/tx/tx.js +0 -114
- package/dist/manager/tx/tx.js.map +0 -1
- package/dist/manager/utils/consts.d.ts +0 -3
- package/dist/manager/utils/consts.d.ts.map +0 -1
- package/dist/manager/utils/consts.js +0 -6
- package/dist/manager/utils/consts.js.map +0 -1
- package/dist/manager/utils/modifiers.d.ts +0 -7
- package/dist/manager/utils/modifiers.d.ts.map +0 -1
- package/dist/manager/utils/modifiers.js +0 -3
- package/dist/manager/utils/modifiers.js.map +0 -1
- package/dist/obligation_orders/common.d.ts +0 -62
- package/dist/obligation_orders/common.d.ts.map +0 -1
- package/dist/obligation_orders/common.js +0 -20
- package/dist/obligation_orders/common.js.map +0 -1
- package/dist/obligation_orders/index.d.ts +0 -4
- package/dist/obligation_orders/index.d.ts.map +0 -1
- package/dist/obligation_orders/index.js +0 -20
- package/dist/obligation_orders/index.js.map +0 -1
- package/dist/obligation_orders/internal.d.ts +0 -6
- package/dist/obligation_orders/internal.d.ts.map +0 -1
- package/dist/obligation_orders/internal.js +0 -72
- package/dist/obligation_orders/internal.js.map +0 -1
- package/dist/obligation_orders/ltv_based.d.ts +0 -51
- package/dist/obligation_orders/ltv_based.d.ts.map +0 -1
- package/dist/obligation_orders/ltv_based.js +0 -107
- package/dist/obligation_orders/ltv_based.js.map +0 -1
- package/dist/obligation_orders/price_based.d.ts +0 -81
- package/dist/obligation_orders/price_based.d.ts.map +0 -1
- package/dist/obligation_orders/price_based.js +0 -166
- package/dist/obligation_orders/price_based.js.map +0 -1
- package/dist/referrals/index.d.ts +0 -3
- package/dist/referrals/index.d.ts.map +0 -1
- package/dist/referrals/index.js +0 -19
- package/dist/referrals/index.js.map +0 -1
- package/dist/referrals/instructions.d.ts +0 -18
- package/dist/referrals/instructions.d.ts.map +0 -1
- package/dist/referrals/instructions.js +0 -73
- package/dist/referrals/instructions.js.map +0 -1
- package/dist/referrals/operations.d.ts +0 -65
- package/dist/referrals/operations.d.ts.map +0 -1
- package/dist/referrals/operations.js +0 -186
- package/dist/referrals/operations.js.map +0 -1
- package/dist/utils/ObligationType.d.ts +0 -56
- package/dist/utils/ObligationType.d.ts.map +0 -1
- package/dist/utils/ObligationType.js +0 -183
- package/dist/utils/ObligationType.js.map +0 -1
- package/dist/utils/accountListing.d.ts +0 -6
- package/dist/utils/accountListing.d.ts.map +0 -1
- package/dist/utils/accountListing.js +0 -88
- package/dist/utils/accountListing.js.map +0 -1
- package/dist/utils/api.d.ts +0 -24
- package/dist/utils/api.d.ts.map +0 -1
- package/dist/utils/api.js +0 -65
- package/dist/utils/api.js.map +0 -1
- package/dist/utils/ata.d.ts +0 -54
- package/dist/utils/ata.d.ts.map +0 -1
- package/dist/utils/ata.js +0 -214
- package/dist/utils/ata.js.map +0 -1
- package/dist/utils/bigint.d.ts +0 -2
- package/dist/utils/bigint.d.ts.map +0 -1
- package/dist/utils/bigint.js +0 -7
- package/dist/utils/bigint.js.map +0 -1
- package/dist/utils/compat.d.ts +0 -6
- package/dist/utils/compat.d.ts.map +0 -1
- package/dist/utils/compat.js +0 -19
- package/dist/utils/compat.js.map +0 -1
- package/dist/utils/constants.d.ts +0 -58
- package/dist/utils/constants.d.ts.map +0 -1
- package/dist/utils/constants.js +0 -84
- package/dist/utils/constants.js.map +0 -1
- package/dist/utils/consts.d.ts +0 -4
- package/dist/utils/consts.d.ts.map +0 -1
- package/dist/utils/consts.js +0 -7
- package/dist/utils/consts.js.map +0 -1
- package/dist/utils/farmUtils.d.ts +0 -10
- package/dist/utils/farmUtils.d.ts.map +0 -1
- package/dist/utils/farmUtils.js +0 -38
- package/dist/utils/farmUtils.js.map +0 -1
- package/dist/utils/fuzz.d.ts +0 -3
- package/dist/utils/fuzz.d.ts.map +0 -1
- package/dist/utils/fuzz.js +0 -11
- package/dist/utils/fuzz.js.map +0 -1
- package/dist/utils/idl.d.ts +0 -3
- package/dist/utils/idl.d.ts.map +0 -1
- package/dist/utils/idl.js +0 -9
- package/dist/utils/idl.js.map +0 -1
- package/dist/utils/index.d.ts +0 -20
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js +0 -36
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/instruction.d.ts +0 -10
- package/dist/utils/instruction.d.ts.map +0 -1
- package/dist/utils/instruction.js +0 -64
- package/dist/utils/instruction.js.map +0 -1
- package/dist/utils/kamino.d.ts +0 -4
- package/dist/utils/kamino.d.ts.map +0 -1
- package/dist/utils/kamino.js +0 -16
- package/dist/utils/kamino.js.map +0 -1
- package/dist/utils/lookupTable.d.ts +0 -43
- package/dist/utils/lookupTable.d.ts.map +0 -1
- package/dist/utils/lookupTable.js +0 -139
- package/dist/utils/lookupTable.js.map +0 -1
- package/dist/utils/managerTypes.d.ts +0 -142
- package/dist/utils/managerTypes.d.ts.map +0 -1
- package/dist/utils/managerTypes.js +0 -298
- package/dist/utils/managerTypes.js.map +0 -1
- package/dist/utils/map.d.ts +0 -2
- package/dist/utils/map.d.ts.map +0 -1
- package/dist/utils/map.js +0 -13
- package/dist/utils/map.js.map +0 -1
- package/dist/utils/metadata.d.ts +0 -14
- package/dist/utils/metadata.d.ts.map +0 -1
- package/dist/utils/metadata.js +0 -79
- package/dist/utils/metadata.js.map +0 -1
- package/dist/utils/multisig.d.ts +0 -45
- package/dist/utils/multisig.d.ts.map +0 -1
- package/dist/utils/multisig.js +0 -30
- package/dist/utils/multisig.js.map +0 -1
- package/dist/utils/obligations.d.ts +0 -4
- package/dist/utils/obligations.d.ts.map +0 -1
- package/dist/utils/obligations.js +0 -54
- package/dist/utils/obligations.js.map +0 -1
- package/dist/utils/option.d.ts +0 -3
- package/dist/utils/option.d.ts.map +0 -1
- package/dist/utils/option.js +0 -12
- package/dist/utils/option.js.map +0 -1
- package/dist/utils/oracle.d.ts +0 -56
- package/dist/utils/oracle.d.ts.map +0 -1
- package/dist/utils/oracle.js +0 -280
- package/dist/utils/oracle.js.map +0 -1
- package/dist/utils/parse.d.ts +0 -10
- package/dist/utils/parse.d.ts.map +0 -1
- package/dist/utils/parse.js +0 -24
- package/dist/utils/parse.js.map +0 -1
- package/dist/utils/pubkey.d.ts +0 -12
- package/dist/utils/pubkey.d.ts.map +0 -1
- package/dist/utils/pubkey.js +0 -18
- package/dist/utils/pubkey.js.map +0 -1
- package/dist/utils/readCdnData.d.ts +0 -25
- package/dist/utils/readCdnData.d.ts.map +0 -1
- package/dist/utils/readCdnData.js +0 -29
- package/dist/utils/readCdnData.js.map +0 -1
- package/dist/utils/rpc.d.ts +0 -15
- package/dist/utils/rpc.d.ts.map +0 -1
- package/dist/utils/rpc.js +0 -51
- package/dist/utils/rpc.js.map +0 -1
- package/dist/utils/seeds.d.ts +0 -161
- package/dist/utils/seeds.d.ts.map +0 -1
- package/dist/utils/seeds.js +0 -260
- package/dist/utils/seeds.js.map +0 -1
- package/dist/utils/signer.d.ts +0 -4
- package/dist/utils/signer.d.ts.map +0 -1
- package/dist/utils/signer.js +0 -20
- package/dist/utils/signer.js.map +0 -1
- package/dist/utils/slots.d.ts +0 -19
- package/dist/utils/slots.d.ts.map +0 -1
- package/dist/utils/slots.js +0 -31
- package/dist/utils/slots.js.map +0 -1
- package/dist/utils/switchboard.d.ts +0 -4
- package/dist/utils/switchboard.d.ts.map +0 -1
- package/dist/utils/switchboard.js +0 -26
- package/dist/utils/switchboard.js.map +0 -1
- package/dist/utils/userMetadata.d.ts +0 -16
- package/dist/utils/userMetadata.d.ts.map +0 -1
- package/dist/utils/userMetadata.js +0 -250
- package/dist/utils/userMetadata.js.map +0 -1
- package/dist/utils/validations.d.ts +0 -5
- package/dist/utils/validations.d.ts.map +0 -1
- package/dist/utils/validations.js +0 -36
- package/dist/utils/validations.js.map +0 -1
- package/dist/utils/vault.d.ts +0 -3
- package/dist/utils/vault.d.ts.map +0 -1
- package/dist/utils/vault.js +0 -56
- package/dist/utils/vault.js.map +0 -1
- package/dist/utils/vaultAllocation.d.ts +0 -22
- package/dist/utils/vaultAllocation.d.ts.map +0 -1
- package/dist/utils/vaultAllocation.js +0 -74
- package/dist/utils/vaultAllocation.js.map +0 -1
package/dist/classes/vault.js
DELETED
|
@@ -1,3075 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.VaultHoldings = exports.ReserveAllocationConfig = exports.KaminoVaultConfig = exports.KaminoVault = exports.KaminoVaultClient = exports.INITIAL_DEPOSIT_LAMPORTS = exports.METADATA_PROGRAM_ID = exports.METADATA_SEED = exports.kaminoVaultStagingId = exports.kaminoVaultId = void 0;
|
|
7
|
-
exports.getCTokenVaultPda = getCTokenVaultPda;
|
|
8
|
-
exports.getEventAuthorityPda = getEventAuthorityPda;
|
|
9
|
-
exports.getKvaultGlobalConfigPda = getKvaultGlobalConfigPda;
|
|
10
|
-
exports.getReserveWhitelistEntryPda = getReserveWhitelistEntryPda;
|
|
11
|
-
const bn_js_1 = __importDefault(require("bn.js"));
|
|
12
|
-
const kit_1 = require("@solana/kit");
|
|
13
|
-
const lib_1 = require("../lib");
|
|
14
|
-
const instructions_1 = require("../@codegen/kvault/instructions");
|
|
15
|
-
const types_1 = require("../@codegen/kvault/types");
|
|
16
|
-
const accounts_1 = require("../@codegen/kvault/accounts");
|
|
17
|
-
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
18
|
-
const utils_1 = require("./utils");
|
|
19
|
-
const programId_1 = require("../@codegen/klend/programId");
|
|
20
|
-
const fraction_1 = require("./fraction");
|
|
21
|
-
const utils_2 = require("../utils");
|
|
22
|
-
const rpc_1 = require("../utils/rpc");
|
|
23
|
-
const kliquidity_sdk_1 = require("@kamino-finance/kliquidity-sdk");
|
|
24
|
-
const CreationParameters_1 = require("@kamino-finance/kliquidity-sdk/dist/utils/CreationParameters");
|
|
25
|
-
const dist_1 = require("@kamino-finance/farms-sdk/dist");
|
|
26
|
-
const lookupTable_1 = require("../utils/lookupTable");
|
|
27
|
-
const farm_utils_1 = require("./farm_utils");
|
|
28
|
-
const system_1 = require("@solana-program/system");
|
|
29
|
-
const metadata_1 = require("../utils/metadata");
|
|
30
|
-
const vault_1 = require("../utils/vault");
|
|
31
|
-
const token_2022_1 = require("@solana-program/token-2022");
|
|
32
|
-
const token_1 = require("@solana-program/token");
|
|
33
|
-
const sysvars_1 = require("@solana/sysvars");
|
|
34
|
-
const signer_1 = require("../utils/signer");
|
|
35
|
-
const farms_sdk_1 = require("@kamino-finance/farms-sdk");
|
|
36
|
-
const apy_1 = require("@kamino-finance/farms-sdk/dist/utils/apy");
|
|
37
|
-
const vaultAllocation_1 = require("../utils/vaultAllocation");
|
|
38
|
-
const farmUtils_1 = require("../utils/farmUtils");
|
|
39
|
-
const readCdnData_1 = require("../utils/readCdnData");
|
|
40
|
-
exports.kaminoVaultId = (0, kit_1.address)('KvauGMspG5k6rtzrqqn7WNn3oZdyKqLKwK2XWQ8FLjd');
|
|
41
|
-
exports.kaminoVaultStagingId = (0, kit_1.address)('stKvQfwRsQiKnLtMNVLHKS3exFJmZFsgfzBPWHECUYK');
|
|
42
|
-
const TOKEN_VAULT_SEED = 'token_vault';
|
|
43
|
-
const CTOKEN_VAULT_SEED = 'ctoken_vault';
|
|
44
|
-
const BASE_VAULT_AUTHORITY_SEED = 'authority';
|
|
45
|
-
const SHARES_SEED = 'shares';
|
|
46
|
-
const EVENT_AUTHORITY_SEED = '__event_authority';
|
|
47
|
-
exports.METADATA_SEED = 'metadata';
|
|
48
|
-
const GLOBAL_CONFIG_STATE_SEED = 'global_config';
|
|
49
|
-
const WHITELISTED_RESERVES_SEED = 'whitelisted_reserves';
|
|
50
|
-
exports.METADATA_PROGRAM_ID = (0, kit_1.address)('metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s');
|
|
51
|
-
exports.INITIAL_DEPOSIT_LAMPORTS = 1000;
|
|
52
|
-
const addressEncoder = (0, kit_1.getAddressEncoder)();
|
|
53
|
-
const base58Decoder = (0, kit_1.getBase58Decoder)();
|
|
54
|
-
/**
|
|
55
|
-
* KaminoVaultClient is a class that provides a high-level interface to interact with the Kamino Vault program.
|
|
56
|
-
*/
|
|
57
|
-
class KaminoVaultClient {
|
|
58
|
-
_rpc;
|
|
59
|
-
_kaminoVaultProgramId;
|
|
60
|
-
_kaminoLendProgramId;
|
|
61
|
-
recentSlotDurationMs;
|
|
62
|
-
constructor(rpc, recentSlotDurationMs, kaminoVaultprogramId, kaminoLendProgramId) {
|
|
63
|
-
this._rpc = rpc;
|
|
64
|
-
this.recentSlotDurationMs = recentSlotDurationMs;
|
|
65
|
-
this._kaminoVaultProgramId = kaminoVaultprogramId ? kaminoVaultprogramId : exports.kaminoVaultId;
|
|
66
|
-
this._kaminoLendProgramId = kaminoLendProgramId ? kaminoLendProgramId : programId_1.PROGRAM_ID;
|
|
67
|
-
}
|
|
68
|
-
getConnection() {
|
|
69
|
-
return this._rpc;
|
|
70
|
-
}
|
|
71
|
-
getProgramID() {
|
|
72
|
-
return this._kaminoVaultProgramId;
|
|
73
|
-
}
|
|
74
|
-
getRpc() {
|
|
75
|
-
return this._rpc;
|
|
76
|
-
}
|
|
77
|
-
hasFarm() {
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Prints a vault in a human readable form
|
|
82
|
-
* @param vaultPubkey - the address of the vault
|
|
83
|
-
* @param [vaultState] - optional parameter to pass the vault state directly; this will save a network call
|
|
84
|
-
* @returns - void; prints the vault to the console
|
|
85
|
-
*/
|
|
86
|
-
async printVault(vaultPubkey, vaultState) {
|
|
87
|
-
const vault = vaultState ? vaultState : await accounts_1.VaultState.fetch(this.getConnection(), vaultPubkey);
|
|
88
|
-
if (!vault) {
|
|
89
|
-
console.log(`Vault ${vaultPubkey.toString()} not found`);
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
const kaminoVault = KaminoVault.loadWithClientAndState(this, vaultPubkey, vault);
|
|
93
|
-
const vaultName = this.decodeVaultName(vault.name);
|
|
94
|
-
const slot = await this.getConnection().getSlot({ commitment: 'confirmed' }).send();
|
|
95
|
-
const tokensPerShare = await this.getTokensPerShareSingleVault(kaminoVault, slot);
|
|
96
|
-
const holdings = await this.getVaultHoldings(vault, slot);
|
|
97
|
-
const sharesIssued = new decimal_js_1.default(vault.sharesIssued.toString()).div(new decimal_js_1.default(vault.sharesMintDecimals.toString()));
|
|
98
|
-
console.log('Name: ', vaultName);
|
|
99
|
-
console.log('Shares issued: ', sharesIssued);
|
|
100
|
-
holdings.print();
|
|
101
|
-
console.log('Tokens per share: ', tokensPerShare);
|
|
102
|
-
}
|
|
103
|
-
/**
|
|
104
|
-
* This method initializes the kvault global config (one off, needs to be signed by program owner)
|
|
105
|
-
* @param admin - the admin of the kvault program
|
|
106
|
-
* @returns - an instruction to initialize the kvault global config
|
|
107
|
-
*/
|
|
108
|
-
async initKvaultGlobalConfigIx(admin) {
|
|
109
|
-
const globalConfigAddress = await getKvaultGlobalConfigPda(this.getProgramID());
|
|
110
|
-
const programData = await (0, utils_2.programDataPda)(this.getProgramID());
|
|
111
|
-
const ix = (0, instructions_1.initKVaultGlobalConfig)({
|
|
112
|
-
payer: admin,
|
|
113
|
-
globalConfig: globalConfigAddress,
|
|
114
|
-
programData: programData,
|
|
115
|
-
systemProgram: system_1.SYSTEM_PROGRAM_ADDRESS,
|
|
116
|
-
rent: sysvars_1.SYSVAR_RENT_ADDRESS,
|
|
117
|
-
}, undefined, this.getProgramID());
|
|
118
|
-
return ix;
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* This method will create a vault with a given config. The config can be changed later on, but it is recommended to set it up correctly from the start
|
|
122
|
-
* @param vaultConfig - the config object used to create a vault
|
|
123
|
-
* @returns vault: the keypair of the vault, used to sign the initialization transaction; initVaultIxs: a struct with ixs to initialize the vault and its lookup table + populateLUTIxs, a list to populate the lookup table which has to be executed in a separate transaction
|
|
124
|
-
*/
|
|
125
|
-
async createVaultIxs(vaultConfig) {
|
|
126
|
-
const vaultState = await (0, kit_1.generateKeyPairSigner)();
|
|
127
|
-
const size = BigInt(accounts_1.VaultState.layout.span + 8);
|
|
128
|
-
const createVaultIx = (0, system_1.getCreateAccountInstruction)({
|
|
129
|
-
payer: vaultConfig.admin,
|
|
130
|
-
space: size,
|
|
131
|
-
lamports: await this.getConnection().getMinimumBalanceForRentExemption(size).send(),
|
|
132
|
-
programAddress: this._kaminoVaultProgramId,
|
|
133
|
-
newAccount: vaultState,
|
|
134
|
-
});
|
|
135
|
-
const [slot, [tokenVault], [baseVaultAuthority], [sharesMint]] = await Promise.all([
|
|
136
|
-
this.getConnection().getSlot({ commitment: 'finalized' }).send(),
|
|
137
|
-
(0, kit_1.getProgramDerivedAddress)({
|
|
138
|
-
seeds: [Buffer.from(TOKEN_VAULT_SEED), addressEncoder.encode(vaultState.address)],
|
|
139
|
-
programAddress: this._kaminoVaultProgramId,
|
|
140
|
-
}),
|
|
141
|
-
(0, kit_1.getProgramDerivedAddress)({
|
|
142
|
-
seeds: [Buffer.from(BASE_VAULT_AUTHORITY_SEED), addressEncoder.encode(vaultState.address)],
|
|
143
|
-
programAddress: this._kaminoVaultProgramId,
|
|
144
|
-
}),
|
|
145
|
-
(0, kit_1.getProgramDerivedAddress)({
|
|
146
|
-
seeds: [Buffer.from(SHARES_SEED), addressEncoder.encode(vaultState.address)],
|
|
147
|
-
programAddress: this._kaminoVaultProgramId,
|
|
148
|
-
}),
|
|
149
|
-
]);
|
|
150
|
-
let adminTokenAccount;
|
|
151
|
-
const prerequisiteIxs = [];
|
|
152
|
-
const cleanupIxs = [];
|
|
153
|
-
if (vaultConfig.tokenMint === lib_1.WRAPPED_SOL_MINT) {
|
|
154
|
-
const { wsolAta, createAtaIxs, closeAtaIxs } = await (0, utils_2.createWsolAtaIfMissing)(this.getConnection(), new decimal_js_1.default(utils_2.VAULT_INITIAL_DEPOSIT), vaultConfig.admin);
|
|
155
|
-
adminTokenAccount = wsolAta;
|
|
156
|
-
prerequisiteIxs.push(...createAtaIxs);
|
|
157
|
-
cleanupIxs.push(...closeAtaIxs);
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
adminTokenAccount = (await (0, token_2022_1.findAssociatedTokenPda)({
|
|
161
|
-
mint: vaultConfig.tokenMint,
|
|
162
|
-
tokenProgram: vaultConfig.tokenMintProgramId,
|
|
163
|
-
owner: vaultConfig.admin.address,
|
|
164
|
-
}))[0];
|
|
165
|
-
}
|
|
166
|
-
const initVaultAccounts = {
|
|
167
|
-
adminAuthority: vaultConfig.admin,
|
|
168
|
-
vaultState: vaultState.address,
|
|
169
|
-
baseTokenMint: vaultConfig.tokenMint,
|
|
170
|
-
tokenVault,
|
|
171
|
-
baseVaultAuthority,
|
|
172
|
-
sharesMint,
|
|
173
|
-
systemProgram: system_1.SYSTEM_PROGRAM_ADDRESS,
|
|
174
|
-
rent: sysvars_1.SYSVAR_RENT_ADDRESS,
|
|
175
|
-
tokenProgram: vaultConfig.tokenMintProgramId,
|
|
176
|
-
sharesTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
177
|
-
adminTokenAccount,
|
|
178
|
-
};
|
|
179
|
-
const initVaultIx = (0, instructions_1.initVault)(initVaultAccounts, undefined, this._kaminoVaultProgramId);
|
|
180
|
-
const createVaultFarm = await this.createVaultFarm(vaultConfig.admin, vaultState.address, sharesMint);
|
|
181
|
-
// create and set up the vault lookup table
|
|
182
|
-
const [createLUTIx, lut] = await (0, lookupTable_1.initLookupTableIx)(vaultConfig.admin, slot);
|
|
183
|
-
const accountsToBeInserted = [
|
|
184
|
-
vaultConfig.admin.address,
|
|
185
|
-
vaultState.address,
|
|
186
|
-
vaultConfig.tokenMint,
|
|
187
|
-
vaultConfig.tokenMintProgramId,
|
|
188
|
-
baseVaultAuthority,
|
|
189
|
-
sharesMint,
|
|
190
|
-
system_1.SYSTEM_PROGRAM_ADDRESS,
|
|
191
|
-
sysvars_1.SYSVAR_RENT_ADDRESS,
|
|
192
|
-
token_1.TOKEN_PROGRAM_ADDRESS,
|
|
193
|
-
this._kaminoLendProgramId,
|
|
194
|
-
sysvars_1.SYSVAR_INSTRUCTIONS_ADDRESS,
|
|
195
|
-
createVaultFarm.farm.address,
|
|
196
|
-
farm_utils_1.FARMS_GLOBAL_CONFIG_MAINNET,
|
|
197
|
-
];
|
|
198
|
-
const insertIntoLUTIxs = await (0, lookupTable_1.insertIntoLookupTableIxs)(this.getConnection(), vaultConfig.admin, lut, accountsToBeInserted, []);
|
|
199
|
-
const setLUTIx = await this.updateUninitialisedVaultConfigIx(vaultConfig.admin, vaultState.address, new types_1.VaultConfigField.LookupTable(), lut.toString());
|
|
200
|
-
const ixs = [createVaultIx, initVaultIx, setLUTIx];
|
|
201
|
-
if (vaultConfig.getPerformanceFeeBps() > 0) {
|
|
202
|
-
const setPerformanceFeeIx = await this.updateUninitialisedVaultConfigIx(vaultConfig.admin, vaultState.address, new types_1.VaultConfigField.PerformanceFeeBps(), vaultConfig.getPerformanceFeeBps().toString());
|
|
203
|
-
ixs.push(setPerformanceFeeIx);
|
|
204
|
-
}
|
|
205
|
-
if (vaultConfig.getManagementFeeBps() > 0) {
|
|
206
|
-
const setManagementFeeIx = await this.updateUninitialisedVaultConfigIx(vaultConfig.admin, vaultState.address, new types_1.VaultConfigField.ManagementFeeBps(), vaultConfig.getManagementFeeBps().toString());
|
|
207
|
-
ixs.push(setManagementFeeIx);
|
|
208
|
-
}
|
|
209
|
-
if (vaultConfig.name && vaultConfig.name.length > 0) {
|
|
210
|
-
const setNameIx = await this.updateUninitialisedVaultConfigIx(vaultConfig.admin, vaultState.address, new types_1.VaultConfigField.Name(), vaultConfig.name);
|
|
211
|
-
ixs.push(setNameIx);
|
|
212
|
-
}
|
|
213
|
-
const setFarmIx = await this.updateUninitialisedVaultConfigIx(vaultConfig.admin, vaultState.address, new types_1.VaultConfigField.Farm(), createVaultFarm.farm.address);
|
|
214
|
-
const metadataIx = await this.getSetSharesMetadataIx(this.getConnection(), vaultConfig.admin, vaultState.address, sharesMint, baseVaultAuthority, vaultConfig.vaultTokenSymbol, vaultConfig.vaultTokenName);
|
|
215
|
-
return {
|
|
216
|
-
vault: vaultState,
|
|
217
|
-
lut,
|
|
218
|
-
initVaultIxs: {
|
|
219
|
-
createAtaIfNeededIxs: prerequisiteIxs,
|
|
220
|
-
initVaultIxs: ixs,
|
|
221
|
-
createLUTIx,
|
|
222
|
-
populateLUTIxs: insertIntoLUTIxs,
|
|
223
|
-
cleanupIxs,
|
|
224
|
-
initSharesMetadataIx: metadataIx,
|
|
225
|
-
createVaultFarm,
|
|
226
|
-
setFarmToVaultIx: setFarmIx,
|
|
227
|
-
},
|
|
228
|
-
};
|
|
229
|
-
}
|
|
230
|
-
/**
|
|
231
|
-
* This method creates a farm for a vault
|
|
232
|
-
* @param signer - the signer of the transaction
|
|
233
|
-
* @param vaultSharesMint - the mint of the vault shares
|
|
234
|
-
* @param vaultAddress - the address of the vault (it doesn't need to be already initialized)
|
|
235
|
-
* @returns a struct with the farm, the setup farm ixs and the update farm ixs
|
|
236
|
-
*/
|
|
237
|
-
async createVaultFarm(signer, vaultAddress, vaultSharesMint) {
|
|
238
|
-
const farmsSDK = new farms_sdk_1.Farms(this._rpc);
|
|
239
|
-
const farm = await (0, kit_1.generateKeyPairSigner)();
|
|
240
|
-
const ixs = await farmsSDK.createFarmIxs(signer, farm, farm_utils_1.FARMS_GLOBAL_CONFIG_MAINNET, vaultSharesMint);
|
|
241
|
-
const updatePendingFarmAdminIx = await farmsSDK.updateFarmConfigIx(signer, farm.address, lib_1.DEFAULT_PUBLIC_KEY, new dist_1.FarmConfigOption.UpdatePendingFarmAdmin(), farm_utils_1.FARMS_ADMIN_MAINNET, undefined, undefined, true);
|
|
242
|
-
const updateFarmVaultIdIx = await farmsSDK.updateFarmConfigIx(signer, farm.address, lib_1.DEFAULT_PUBLIC_KEY, new dist_1.FarmConfigOption.UpdateVaultId(), vaultAddress, undefined, undefined, true);
|
|
243
|
-
return {
|
|
244
|
-
farm,
|
|
245
|
-
setupFarmIxs: ixs,
|
|
246
|
-
updateFarmIxs: [updatePendingFarmAdminIx, updateFarmVaultIdIx],
|
|
247
|
-
};
|
|
248
|
-
}
|
|
249
|
-
/**
|
|
250
|
-
* This method creates an instruction to set the shares metadata for a vault
|
|
251
|
-
* @param rpc
|
|
252
|
-
* @param vaultAdmin
|
|
253
|
-
* @param vault - the vault to set the shares metadata for
|
|
254
|
-
* @param sharesMint
|
|
255
|
-
* @param baseVaultAuthority
|
|
256
|
-
* @param tokenName - the name of the token in the vault (symbol; e.g. "USDC" which becomes "kVUSDC")
|
|
257
|
-
* @param extraName - the extra string appended to the prefix("Kamino Vault USDC <extraName>")
|
|
258
|
-
* @returns - an instruction to set the shares metadata for the vault
|
|
259
|
-
*/
|
|
260
|
-
async getSetSharesMetadataIx(rpc, vaultAdmin, vault, sharesMint, baseVaultAuthority, tokenName, extraName) {
|
|
261
|
-
const [sharesMintMetadata] = await (0, utils_2.getKVaultSharesMetadataPda)(sharesMint);
|
|
262
|
-
const { name, symbol, uri } = (0, metadata_1.resolveMetadata)(sharesMint, extraName, tokenName);
|
|
263
|
-
const ix = !(await (0, kit_1.fetchEncodedAccount)(rpc, sharesMintMetadata, { commitment: 'processed' })).exists
|
|
264
|
-
? await (0, metadata_1.getInitializeKVaultSharesMetadataIx)(vaultAdmin, vault, sharesMint, baseVaultAuthority, name, symbol, uri)
|
|
265
|
-
: await (0, metadata_1.getUpdateSharesMetadataIx)(vaultAdmin, vault, sharesMint, baseVaultAuthority, name, symbol, uri);
|
|
266
|
-
return ix;
|
|
267
|
-
}
|
|
268
|
-
/**
|
|
269
|
-
* This method updates the vault reserve allocation config for an exiting vault reserve, or adds a new reserve to the vault if it does not exist.
|
|
270
|
-
* @param vault - vault to be updated
|
|
271
|
-
* @param reserveAllocationConfig - new reserve allocation config
|
|
272
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
273
|
-
* @returns - a struct with an instruction to update the reserve allocation and an optional list of instructions to update the lookup table for the allocation changes
|
|
274
|
-
*/
|
|
275
|
-
async updateReserveAllocationIxs(vault, reserveAllocationConfig, vaultAdminAuthority) {
|
|
276
|
-
const vaultState = await vault.getState();
|
|
277
|
-
const reserveState = reserveAllocationConfig.getReserveState();
|
|
278
|
-
const cTokenVault = await getCTokenVaultPda(vault.address, reserveAllocationConfig.getReserveAddress(), this._kaminoVaultProgramId);
|
|
279
|
-
const reserveWhitelistEntryOption = await getReserveWhitelistEntryIfExists(reserveAllocationConfig.getReserveAddress(), this.getConnection(), this._kaminoVaultProgramId);
|
|
280
|
-
const vaultAdmin = parseVaultAdmin(vaultState, vaultAdminAuthority);
|
|
281
|
-
const updateReserveAllocationAccounts = {
|
|
282
|
-
signer: vaultAdmin,
|
|
283
|
-
vaultState: vault.address,
|
|
284
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
285
|
-
reserveCollateralMint: reserveState.collateral.mintPubkey,
|
|
286
|
-
reserve: reserveAllocationConfig.getReserveAddress(),
|
|
287
|
-
ctokenVault: cTokenVault,
|
|
288
|
-
reserveWhitelistEntry: reserveWhitelistEntryOption,
|
|
289
|
-
systemProgram: system_1.SYSTEM_PROGRAM_ADDRESS,
|
|
290
|
-
rent: sysvars_1.SYSVAR_RENT_ADDRESS,
|
|
291
|
-
reserveCollateralTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
292
|
-
};
|
|
293
|
-
const updateReserveAllocationArgs = {
|
|
294
|
-
weight: new bn_js_1.default(reserveAllocationConfig.targetAllocationWeight),
|
|
295
|
-
cap: new bn_js_1.default(reserveAllocationConfig.getAllocationCapLamports().floor().toString()),
|
|
296
|
-
};
|
|
297
|
-
const updateReserveAllocationIx = (0, instructions_1.updateReserveAllocation)(updateReserveAllocationArgs, updateReserveAllocationAccounts, undefined, this._kaminoVaultProgramId);
|
|
298
|
-
const accountsToAddToLut = [
|
|
299
|
-
reserveAllocationConfig.getReserveAddress(),
|
|
300
|
-
cTokenVault,
|
|
301
|
-
...this.getReserveAccountsToInsertInLut(reserveState),
|
|
302
|
-
];
|
|
303
|
-
const [lendingMarketAuth] = await (0, utils_2.lendingMarketAuthPda)(reserveState.lendingMarket, this._kaminoLendProgramId);
|
|
304
|
-
accountsToAddToLut.push(lendingMarketAuth);
|
|
305
|
-
const insertIntoLutIxs = await (0, lookupTable_1.insertIntoLookupTableIxs)(this.getConnection(), vaultAdmin, vaultState.vaultLookupTable, accountsToAddToLut);
|
|
306
|
-
const updateReserveAllocationIxs = {
|
|
307
|
-
updateReserveAllocationIx,
|
|
308
|
-
updateLUTIxs: insertIntoLutIxs,
|
|
309
|
-
};
|
|
310
|
-
return updateReserveAllocationIxs;
|
|
311
|
-
}
|
|
312
|
-
/**
|
|
313
|
-
* This method updates the unallocated weight and cap of a vault (both are optional, if not provided the current values will be used)
|
|
314
|
-
* @param vault - the vault to update the unallocated weight and cap for
|
|
315
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
316
|
-
* @param [unallocatedWeight] - the new unallocated weight to set. If not provided, the current unallocated weight will be used
|
|
317
|
-
* @param [unallocatedCap] - the new unallocated cap to set. If not provided, the current unallocated cap will be used
|
|
318
|
-
* @returns - a list of instructions to update the unallocated weight and cap
|
|
319
|
-
*/
|
|
320
|
-
async updateVaultUnallocatedWeightAndCapIxs(vault, vaultAdminAuthority, unallocatedWeight, unallocatedCap) {
|
|
321
|
-
const vaultState = await vault.getState();
|
|
322
|
-
const unallocatedWeightToUse = unallocatedWeight ? unallocatedWeight : vaultState.unallocatedWeight;
|
|
323
|
-
const unallocatedCapToUse = unallocatedCap ? unallocatedCap : vaultState.unallocatedTokensCap;
|
|
324
|
-
const ixs = [];
|
|
325
|
-
if (!unallocatedWeightToUse.eq(vaultState.unallocatedWeight)) {
|
|
326
|
-
const updateVaultUnallocatedWeightIx = await this.updateVaultConfigIxs(vault, new types_1.VaultConfigField.UnallocatedWeight(), unallocatedWeightToUse.toString(), vaultAdminAuthority);
|
|
327
|
-
ixs.push(updateVaultUnallocatedWeightIx.updateVaultConfigIx);
|
|
328
|
-
}
|
|
329
|
-
if (!unallocatedCapToUse.eq(vaultState.unallocatedTokensCap)) {
|
|
330
|
-
const updateVaultUnallocatedCapIx = await this.updateVaultConfigIxs(vault, new types_1.VaultConfigField.UnallocatedTokensCap(), unallocatedCapToUse.toString(), vaultAdminAuthority);
|
|
331
|
-
ixs.push(updateVaultUnallocatedCapIx.updateVaultConfigIx);
|
|
332
|
-
}
|
|
333
|
-
return ixs;
|
|
334
|
-
}
|
|
335
|
-
/**
|
|
336
|
-
* This method withdraws all the funds from a reserve and blocks it from being invested by setting its weight and ctoken allocation to 0
|
|
337
|
-
* @param vault - the vault to withdraw the funds from
|
|
338
|
-
* @param reserve - the reserve to withdraw the funds from
|
|
339
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
340
|
-
* @returns - a struct with an instruction to update the reserve allocation and an optional list of instructions to update the lookup table for the allocation changes
|
|
341
|
-
*/
|
|
342
|
-
async withdrawEverythingAndBlockInvestReserve(vault, reserve, vaultAdminAuthority) {
|
|
343
|
-
const vaultState = await vault.getState();
|
|
344
|
-
const reserveIsPartOfAllocation = vaultState.vaultAllocationStrategy.some((allocation) => allocation.reserve === reserve);
|
|
345
|
-
const withdrawAndBlockReserveIxs = {
|
|
346
|
-
updateReserveAllocationIxs: [],
|
|
347
|
-
investIxs: [],
|
|
348
|
-
};
|
|
349
|
-
if (!reserveIsPartOfAllocation) {
|
|
350
|
-
return withdrawAndBlockReserveIxs;
|
|
351
|
-
}
|
|
352
|
-
const reserveState = await lib_1.Reserve.fetch(this.getConnection(), reserve);
|
|
353
|
-
if (reserveState === null) {
|
|
354
|
-
return withdrawAndBlockReserveIxs;
|
|
355
|
-
}
|
|
356
|
-
const reserveWithAddress = {
|
|
357
|
-
address: reserve,
|
|
358
|
-
state: reserveState,
|
|
359
|
-
};
|
|
360
|
-
const reserveAllocationConfig = new ReserveAllocationConfig(reserveWithAddress, 0, new decimal_js_1.default(0));
|
|
361
|
-
const admin = vaultAdminAuthority ? vaultAdminAuthority : (0, signer_1.noopSigner)(vaultState.vaultAdminAuthority);
|
|
362
|
-
// update allocation to have 0 weight and 0 cap
|
|
363
|
-
const updateAllocIxs = await this.updateReserveAllocationIxs(vault, reserveAllocationConfig, admin);
|
|
364
|
-
const investIx = await this.investSingleReserveIxs(admin, vault, reserveWithAddress);
|
|
365
|
-
withdrawAndBlockReserveIxs.updateReserveAllocationIxs = [updateAllocIxs.updateReserveAllocationIx];
|
|
366
|
-
withdrawAndBlockReserveIxs.investIxs = investIx;
|
|
367
|
-
return withdrawAndBlockReserveIxs;
|
|
368
|
-
}
|
|
369
|
-
/**
|
|
370
|
-
* This method withdraws all the funds from all the reserves and blocks them from being invested by setting their weight and ctoken allocation to 0
|
|
371
|
-
* @param vault - the vault to withdraw the invested funds from
|
|
372
|
-
* @param [vaultReservesMap] - optional parameter to pass a map of the vault reserves. If not provided, the reserves will be loaded from the vault
|
|
373
|
-
* @param [payer] - optional parameter to pass a different payer for the transaction. If not provided, the admin of the vault will be used; this is the payer for the invest ixs and it should have an ATA and some lamports (2x no_of_reserves) of the token vault
|
|
374
|
-
* @returns - a struct with an instruction to update the reserve allocations (set weight and ctoken allocation to 0) and an a list of instructions to disinvest the funds in the reserves
|
|
375
|
-
*/
|
|
376
|
-
async withdrawEverythingFromAllReservesAndBlockInvest(vault, vaultReservesMap, payer) {
|
|
377
|
-
const vaultState = await vault.getState();
|
|
378
|
-
const reserves = this.getVaultReserves(vaultState);
|
|
379
|
-
const withdrawAndBlockReserveIxs = {
|
|
380
|
-
updateReserveAllocationIxs: [],
|
|
381
|
-
investIxs: [],
|
|
382
|
-
};
|
|
383
|
-
if (!vaultReservesMap) {
|
|
384
|
-
vaultReservesMap = await this.loadVaultReserves(vaultState);
|
|
385
|
-
}
|
|
386
|
-
for (const reserve of reserves) {
|
|
387
|
-
const reserveWithAddress = {
|
|
388
|
-
address: reserve,
|
|
389
|
-
state: vaultReservesMap.get(reserve).state,
|
|
390
|
-
};
|
|
391
|
-
const reserveAllocationConfig = new ReserveAllocationConfig(reserveWithAddress, 0, new decimal_js_1.default(0));
|
|
392
|
-
// update allocation to have 0 weight and 0 cap
|
|
393
|
-
const updateAllocIxs = await this.updateReserveAllocationIxs(vault, reserveAllocationConfig, payer);
|
|
394
|
-
withdrawAndBlockReserveIxs.updateReserveAllocationIxs.push(updateAllocIxs.updateReserveAllocationIx);
|
|
395
|
-
}
|
|
396
|
-
const investPayer = payer ? payer : (0, signer_1.noopSigner)(vaultState.vaultAdminAuthority);
|
|
397
|
-
const investIxs = await this.investAllReservesIxs(investPayer, vault, true);
|
|
398
|
-
withdrawAndBlockReserveIxs.investIxs = investIxs;
|
|
399
|
-
return withdrawAndBlockReserveIxs;
|
|
400
|
-
}
|
|
401
|
-
/**
|
|
402
|
-
* This method disinvests all the funds from all the reserves and set their weight to 0; for vaults that are managed by external bot/crank, the bot can change the weight and invest in the reserves again
|
|
403
|
-
* @param vault - the vault to disinvest the invested funds from
|
|
404
|
-
* @param [vaultReservesMap] - optional parameter to pass a map of the vault reserves. If not provided, the reserves will be loaded from the vault
|
|
405
|
-
* @param [payer] - optional parameter to pass a different payer for the transaction. If not provided, the admin of the vault will be used; this is the payer for the invest ixs and it should have an ATA and some lamports (2x no_of_reserves) of the token vault
|
|
406
|
-
* @returns - a struct with an instruction to update the reserve allocations to 0 weight and a list of instructions to disinvest the funds in the reserves
|
|
407
|
-
*/
|
|
408
|
-
async disinvestAllReservesIxs(vault, vaultReservesMap, payer) {
|
|
409
|
-
const vaultState = await vault.getState();
|
|
410
|
-
const reserves = this.getVaultReserves(vaultState);
|
|
411
|
-
const disinvestAllReservesIxs = {
|
|
412
|
-
updateReserveAllocationIxs: [],
|
|
413
|
-
investIxs: [],
|
|
414
|
-
};
|
|
415
|
-
if (!vaultReservesMap) {
|
|
416
|
-
vaultReservesMap = await this.loadVaultReserves(vaultState);
|
|
417
|
-
}
|
|
418
|
-
for (const reserve of reserves) {
|
|
419
|
-
const reserveWithAddress = {
|
|
420
|
-
address: reserve,
|
|
421
|
-
state: vaultReservesMap.get(reserve).state,
|
|
422
|
-
};
|
|
423
|
-
const existingReserveAllocation = vaultState.vaultAllocationStrategy.find((allocation) => allocation.reserve === reserve);
|
|
424
|
-
if (!existingReserveAllocation) {
|
|
425
|
-
continue;
|
|
426
|
-
}
|
|
427
|
-
const reserveAllocationConfig = new ReserveAllocationConfig(reserveWithAddress, 0, new decimal_js_1.default(existingReserveAllocation.tokenAllocationCap.toString()));
|
|
428
|
-
// update allocation to have 0 weight and 0 cap
|
|
429
|
-
const updateAllocIxs = await this.updateReserveAllocationIxs(vault, reserveAllocationConfig, payer);
|
|
430
|
-
disinvestAllReservesIxs.updateReserveAllocationIxs.push(updateAllocIxs.updateReserveAllocationIx);
|
|
431
|
-
}
|
|
432
|
-
const investPayer = payer ? payer : (0, signer_1.noopSigner)(vaultState.vaultAdminAuthority);
|
|
433
|
-
const investIxs = await this.investAllReservesIxs(investPayer, vault, true);
|
|
434
|
-
disinvestAllReservesIxs.investIxs = investIxs;
|
|
435
|
-
return disinvestAllReservesIxs;
|
|
436
|
-
}
|
|
437
|
-
/**
|
|
438
|
-
* This method removes a reserve from the vault allocation strategy if already part of the allocation strategy
|
|
439
|
-
* @param vault - vault to remove the reserve from
|
|
440
|
-
* @param reserve - reserve to remove from the vault allocation strategy
|
|
441
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
442
|
-
* @returns - an instruction to remove the reserve from the vault allocation strategy or undefined if the reserve is not part of the allocation strategy
|
|
443
|
-
*/
|
|
444
|
-
async removeReserveFromAllocationIx(vault, reserve, vaultAdminAuthority) {
|
|
445
|
-
const vaultState = await vault.getState();
|
|
446
|
-
const vaultAdmin = parseVaultAdmin(vaultState, vaultAdminAuthority);
|
|
447
|
-
const reserveIsPartOfAllocation = vaultState.vaultAllocationStrategy.some((allocation) => allocation.reserve === reserve);
|
|
448
|
-
if (!reserveIsPartOfAllocation) {
|
|
449
|
-
return undefined;
|
|
450
|
-
}
|
|
451
|
-
const accounts = {
|
|
452
|
-
vaultAdminAuthority: vaultAdmin,
|
|
453
|
-
vaultState: vault.address,
|
|
454
|
-
reserve,
|
|
455
|
-
};
|
|
456
|
-
return (0, instructions_1.removeAllocation)(accounts);
|
|
457
|
-
}
|
|
458
|
-
/**
|
|
459
|
-
* Update a field of the vault. If the field is a pubkey it will return an extra instruction to add that account into the lookup table
|
|
460
|
-
* @param vault the vault to update
|
|
461
|
-
* @param mode the field to update (based on VaultConfigFieldKind enum)
|
|
462
|
-
* @param value the value to update the field with
|
|
463
|
-
* @param [adminAuthority] the signer of the transaction. Optional. If not provided the admin of the vault will be used. It should be used when changing the admin of the vault if we want to build or batch multiple ixs in the same tx.
|
|
464
|
-
* The global admin should be passed in when wanting to change the AllowAllocationsInWhitelistedReservesOnly or AllowInvestInWhitelistedReservesOnly fields to false
|
|
465
|
-
* @param [lutIxsSigner] the signer of the transaction to be used for the lookup table instructions. Optional. If not provided the admin of the vault will be used. It should be used when changing the admin of the vault if we want to build or batch multiple ixs in the same tx
|
|
466
|
-
* @param [skipLutUpdate] if true, the lookup table instructions will not be included in the returned instructions
|
|
467
|
-
* @returns a struct that contains the instruction to update the field and an optional list of instructions to update the lookup table
|
|
468
|
-
*/
|
|
469
|
-
async updateVaultConfigIxs(vault, mode, value, adminAuthority, lutIxsSigner, skipLutUpdate = false) {
|
|
470
|
-
const vaultState = await vault.getState();
|
|
471
|
-
const admin = parseVaultAdmin(vaultState, adminAuthority);
|
|
472
|
-
const globalConfig = await getKvaultGlobalConfigPda(this._kaminoVaultProgramId);
|
|
473
|
-
const updateVaultConfigAccs = {
|
|
474
|
-
signer: admin,
|
|
475
|
-
globalConfig: globalConfig,
|
|
476
|
-
vaultState: vault.address,
|
|
477
|
-
klendProgram: this._kaminoLendProgramId,
|
|
478
|
-
};
|
|
479
|
-
const updateVaultConfigArgs = {
|
|
480
|
-
entry: mode,
|
|
481
|
-
data: this.getValueForModeAsBuffer(mode, value),
|
|
482
|
-
};
|
|
483
|
-
const vaultReserves = this.getVaultReserves(vaultState);
|
|
484
|
-
const vaultReservesState = await this.loadVaultReserves(vaultState);
|
|
485
|
-
let updateVaultConfigIx = (0, instructions_1.updateVaultConfig)(updateVaultConfigArgs, updateVaultConfigAccs, undefined, this._kaminoVaultProgramId);
|
|
486
|
-
updateVaultConfigIx = this.appendRemainingAccountsForVaultReserves(updateVaultConfigIx, vaultReserves, vaultReservesState);
|
|
487
|
-
const updateLUTIxs = [];
|
|
488
|
-
if (!skipLutUpdate) {
|
|
489
|
-
const lutIxsSignerAccount = lutIxsSigner ? lutIxsSigner : admin;
|
|
490
|
-
if (mode.kind === new types_1.VaultConfigField.PendingVaultAdmin().kind) {
|
|
491
|
-
const newPubkey = (0, kit_1.address)(value);
|
|
492
|
-
const insertIntoLutIxs = await (0, lookupTable_1.insertIntoLookupTableIxs)(this.getConnection(), lutIxsSignerAccount, vaultState.vaultLookupTable, [newPubkey]);
|
|
493
|
-
updateLUTIxs.push(...insertIntoLutIxs);
|
|
494
|
-
}
|
|
495
|
-
else if (mode.kind === new types_1.VaultConfigField.Farm().kind) {
|
|
496
|
-
const keysToAddToLUT = [(0, kit_1.address)(value)];
|
|
497
|
-
// if the farm already exist we want to read its state to add it to the LUT
|
|
498
|
-
try {
|
|
499
|
-
const farmState = await dist_1.FarmState.fetch(this.getConnection(), keysToAddToLUT[0]);
|
|
500
|
-
keysToAddToLUT.push(farmState.farmVault, farmState.farmVaultsAuthority, farmState.token.mint, farmState.scopePrices, farmState.globalConfig);
|
|
501
|
-
const insertIntoLutIxs = await (0, lookupTable_1.insertIntoLookupTableIxs)(this.getConnection(), lutIxsSignerAccount, vaultState.vaultLookupTable, keysToAddToLUT);
|
|
502
|
-
updateLUTIxs.push(...insertIntoLutIxs);
|
|
503
|
-
}
|
|
504
|
-
catch (error) {
|
|
505
|
-
console.log(`Error fetching farm ${keysToAddToLUT[0].toString()} state`, error);
|
|
506
|
-
}
|
|
507
|
-
}
|
|
508
|
-
}
|
|
509
|
-
const updateVaultConfigIxs = {
|
|
510
|
-
updateVaultConfigIx,
|
|
511
|
-
updateLUTIxs,
|
|
512
|
-
};
|
|
513
|
-
return updateVaultConfigIxs;
|
|
514
|
-
}
|
|
515
|
-
/**
|
|
516
|
-
* Add or update a reserve whitelist entry. This controls whether the reserve is whitelisted for adding/updating
|
|
517
|
-
* allocations or for invest, depending on the mode parameter.
|
|
518
|
-
*
|
|
519
|
-
* @param reserve - Address of the reserve to whitelist
|
|
520
|
-
* @param mode - The whitelist mode: either 'Invest' or 'AddAllocation' with a value (1 = allow, 0 = deny)
|
|
521
|
-
* @param globalAdmin - The global admin that signs the transaction
|
|
522
|
-
* @returns - An instruction to add/update the whitelisted reserve
|
|
523
|
-
*/
|
|
524
|
-
async addUpdateWhitelistedReserveIx(reserve, mode, globalAdmin) {
|
|
525
|
-
const globalConfig = await getKvaultGlobalConfigPda(this._kaminoVaultProgramId);
|
|
526
|
-
const reserveWhitelistEntry = await getReserveWhitelistEntryPda(reserve, this._kaminoVaultProgramId);
|
|
527
|
-
const accounts = {
|
|
528
|
-
globalAdmin,
|
|
529
|
-
globalConfig,
|
|
530
|
-
reserve,
|
|
531
|
-
reserveWhitelistEntry,
|
|
532
|
-
systemProgram: system_1.SYSTEM_PROGRAM_ADDRESS,
|
|
533
|
-
};
|
|
534
|
-
const args = {
|
|
535
|
-
update: mode,
|
|
536
|
-
};
|
|
537
|
-
return (0, instructions_1.addUpdateWhitelistedReserve)(args, accounts, undefined, this._kaminoVaultProgramId);
|
|
538
|
-
}
|
|
539
|
-
/** Sets the farm where the shares can be staked. This is store in vault state and a vault can only have one farm, so the new farm will ovveride the old farm
|
|
540
|
-
* @param vault - vault to set the farm for
|
|
541
|
-
* @param farm - the farm where the vault shares can be staked
|
|
542
|
-
* @param [errorOnOverride] - if true, the function will throw an error if the vault already has a farm. If false, it will override the farm
|
|
543
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
544
|
-
* @param [lutIxsSigner] - the signer of the transaction to be used for the lookup table instructions. Optional. If not provided the admin of the vault will be used. It should be used when changing the admin of the vault if we want to build or batch multiple ixs in the same tx
|
|
545
|
-
* @param [skipLutUpdate] - if true, the lookup table instructions will not be included in the returned instructions
|
|
546
|
-
* @returns - a struct that contains the instruction to update the farm and an optional list of instructions to update the lookup table
|
|
547
|
-
*/
|
|
548
|
-
async setVaultFarmIxs(vault, farm, errorOnOverride = true, vaultAdminAuthority, lutIxsSigner, skipLutUpdate = false) {
|
|
549
|
-
const vaultHasFarm = await vault.hasFarm();
|
|
550
|
-
if (vaultHasFarm && errorOnOverride) {
|
|
551
|
-
throw new Error('Vault already has a farm, if you want to override it set errorOnOverride to false');
|
|
552
|
-
}
|
|
553
|
-
return this.updateVaultConfigIxs(vault, new types_1.VaultConfigField.Farm(), farm, vaultAdminAuthority, lutIxsSigner, skipLutUpdate);
|
|
554
|
-
}
|
|
555
|
-
/**
|
|
556
|
-
* This method updates the vault config during vault initialization, within the same transaction
|
|
557
|
-
* where the vault is created. Use this when the vault state is not yet committed to the chain
|
|
558
|
-
* and cannot be fetched via RPC. For updates to existing vaults, use updateVaultConfigIxs instead.
|
|
559
|
-
*
|
|
560
|
-
* @param admin - the admin that signs the transaction
|
|
561
|
-
* @param vault - address of vault to be updated
|
|
562
|
-
* @param mode - the field to be updated
|
|
563
|
-
* @param value - the new value for the field to be updated (number or pubkey)
|
|
564
|
-
* @returns - an instruction to update the vault config
|
|
565
|
-
*/
|
|
566
|
-
async updateUninitialisedVaultConfigIx(admin, vault, mode, value) {
|
|
567
|
-
const globalConfig = await getKvaultGlobalConfigPda(this._kaminoVaultProgramId);
|
|
568
|
-
const updateVaultConfigAccs = {
|
|
569
|
-
signer: admin,
|
|
570
|
-
globalConfig: globalConfig,
|
|
571
|
-
vaultState: vault,
|
|
572
|
-
klendProgram: this._kaminoLendProgramId,
|
|
573
|
-
};
|
|
574
|
-
const updateVaultConfigArgs = {
|
|
575
|
-
entry: mode,
|
|
576
|
-
data: this.getValueForModeAsBuffer(mode, value),
|
|
577
|
-
};
|
|
578
|
-
const updateVaultConfigIx = (0, instructions_1.updateVaultConfig)(updateVaultConfigArgs, updateVaultConfigAccs, undefined, this._kaminoVaultProgramId);
|
|
579
|
-
return updateVaultConfigIx;
|
|
580
|
-
}
|
|
581
|
-
/**
|
|
582
|
-
* This function creates the instruction for the `pendingAdmin` of the vault to accept to become the owner of the vault (step 2/2 of the ownership transfer)
|
|
583
|
-
* @param vault - vault to change the ownership for
|
|
584
|
-
* @param [pendingAdmin] - pending vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
585
|
-
* @returns - an instruction to accept the ownership of the vault and a list of instructions to update the lookup table
|
|
586
|
-
*/
|
|
587
|
-
async acceptVaultOwnershipIxs(vault, pendingAdmin) {
|
|
588
|
-
const vaultState = await vault.getState();
|
|
589
|
-
const signer = parseVaultPendingAdmin(vaultState, pendingAdmin);
|
|
590
|
-
const acceptOwneshipAccounts = {
|
|
591
|
-
pendingAdmin: signer,
|
|
592
|
-
vaultState: vault.address,
|
|
593
|
-
};
|
|
594
|
-
const acceptVaultOwnershipIx = (0, instructions_1.updateAdmin)(acceptOwneshipAccounts, undefined, this._kaminoVaultProgramId);
|
|
595
|
-
// read the current LUT and create a new one for the new admin and backfill it
|
|
596
|
-
const accountsInExistentLUT = (await (0, lookupTable_1.getAccountsInLut)(this.getConnection(), vaultState.vaultLookupTable)).filter((account) => account !== vaultState.vaultAdminAuthority);
|
|
597
|
-
const lutIxs = [];
|
|
598
|
-
const [initNewLutIx, newLut] = await (0, lookupTable_1.initLookupTableIx)(signer, await this.getConnection().getSlot({ commitment: 'finalized' }).send());
|
|
599
|
-
const insertIntoLUTIxs = await (0, lookupTable_1.insertIntoLookupTableIxs)(this.getConnection(), signer, newLut, accountsInExistentLUT, []);
|
|
600
|
-
lutIxs.push(...insertIntoLUTIxs);
|
|
601
|
-
const updateVaultConfigIxs = await this.updateVaultConfigIxs(vault, new types_1.VaultConfigField.LookupTable(), newLut.toString(), signer);
|
|
602
|
-
lutIxs.push(updateVaultConfigIxs.updateVaultConfigIx);
|
|
603
|
-
lutIxs.push(...updateVaultConfigIxs.updateLUTIxs);
|
|
604
|
-
const acceptVaultOwnershipIxs = {
|
|
605
|
-
acceptVaultOwnershipIx,
|
|
606
|
-
initNewLUTIx: initNewLutIx,
|
|
607
|
-
updateLUTIxs: lutIxs,
|
|
608
|
-
};
|
|
609
|
-
return acceptVaultOwnershipIxs;
|
|
610
|
-
}
|
|
611
|
-
/**
|
|
612
|
-
* This function creates the instruction for the admin to give up a part of the pending fees (which will be accounted as part of the vault)
|
|
613
|
-
* @param vault - vault to give up pending fees for
|
|
614
|
-
* @param maxAmountToGiveUp - the maximum amount of fees to give up, in tokens
|
|
615
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
616
|
-
* @returns - an instruction to give up the specified pending fees
|
|
617
|
-
*/
|
|
618
|
-
async giveUpPendingFeesIx(vault, maxAmountToGiveUp, vaultAdminAuthority) {
|
|
619
|
-
const vaultState = await vault.getState();
|
|
620
|
-
const vaultAdmin = parseVaultAdmin(vaultState, vaultAdminAuthority);
|
|
621
|
-
const giveUpPendingFeesAccounts = {
|
|
622
|
-
vaultAdminAuthority: vaultAdmin,
|
|
623
|
-
vaultState: vault.address,
|
|
624
|
-
klendProgram: this._kaminoLendProgramId,
|
|
625
|
-
};
|
|
626
|
-
const maxAmountToGiveUpLamports = (0, utils_1.numberToLamportsDecimal)(maxAmountToGiveUp, vaultState.tokenMintDecimals.toNumber());
|
|
627
|
-
const giveUpPendingFeesArgs = {
|
|
628
|
-
maxAmountToGiveUp: new bn_js_1.default(maxAmountToGiveUpLamports.toString()),
|
|
629
|
-
};
|
|
630
|
-
return (0, instructions_1.giveUpPendingFees)(giveUpPendingFeesArgs, giveUpPendingFeesAccounts, undefined, this._kaminoVaultProgramId);
|
|
631
|
-
}
|
|
632
|
-
/**
|
|
633
|
-
* This method withdraws all the pending fees from the vault to the owner's token ATA
|
|
634
|
-
* @param authority - vault admin
|
|
635
|
-
* @param vault - vault for which the admin withdraws the pending fees
|
|
636
|
-
* @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault
|
|
637
|
-
* @param [vaultReservesMap] - a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
638
|
-
* @param [vaultAdminAuthority] - vault admin - a noop vaultAdminAuthority is provided when absent for multisigs
|
|
639
|
-
* @returns - list of instructions to withdraw all pending fees, including the ATA creation instructions if needed
|
|
640
|
-
*/
|
|
641
|
-
async withdrawPendingFeesIxs(vault, slot, vaultReservesMap, vaultAdminAuthority) {
|
|
642
|
-
const vaultState = await vault.getState();
|
|
643
|
-
const vaultAdmin = parseVaultAdmin(vaultState, vaultAdminAuthority);
|
|
644
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
645
|
-
const [{ ata: adminTokenAta, createAtaIx }] = await (0, utils_2.createAtasIdempotent)(vaultAdmin, [
|
|
646
|
-
{
|
|
647
|
-
mint: vaultState.tokenMint,
|
|
648
|
-
tokenProgram: vaultState.tokenProgram,
|
|
649
|
-
},
|
|
650
|
-
]);
|
|
651
|
-
const tokensToWithdraw = new fraction_1.Fraction(vaultState.pendingFeesSf).toDecimal();
|
|
652
|
-
let tokenLeftToWithdraw = tokensToWithdraw;
|
|
653
|
-
tokenLeftToWithdraw = tokenLeftToWithdraw.sub(new decimal_js_1.default(vaultState.tokenAvailable.toString()));
|
|
654
|
-
const reservesToWithdraw = [];
|
|
655
|
-
if (tokenLeftToWithdraw.lte(0)) {
|
|
656
|
-
// Availabe enough to withdraw all - using first reserve as it does not matter
|
|
657
|
-
reservesToWithdraw.push(vaultState.vaultAllocationStrategy[0].reserve);
|
|
658
|
-
}
|
|
659
|
-
else {
|
|
660
|
-
// Get decreasing order sorted available liquidity to withdraw from each reserve allocated to
|
|
661
|
-
const reserveAllocationAvailableLiquidityToWithdraw = await this.getReserveAllocationAvailableLiquidityToWithdraw(vault, slot, vaultReservesState);
|
|
662
|
-
// sort
|
|
663
|
-
const reserveAllocationAvailableLiquidityToWithdrawSorted = new Map([...reserveAllocationAvailableLiquidityToWithdraw.entries()].sort((a, b) => b[1].sub(a[1]).toNumber()));
|
|
664
|
-
reserveAllocationAvailableLiquidityToWithdrawSorted.forEach((availableLiquidityToWithdraw, key) => {
|
|
665
|
-
if (tokenLeftToWithdraw.gt(0)) {
|
|
666
|
-
reservesToWithdraw.push(key);
|
|
667
|
-
tokenLeftToWithdraw = tokenLeftToWithdraw.sub(availableLiquidityToWithdraw);
|
|
668
|
-
}
|
|
669
|
-
});
|
|
670
|
-
}
|
|
671
|
-
const reserveStates = await lib_1.Reserve.fetchMultiple(this.getConnection(), reservesToWithdraw, this._kaminoLendProgramId);
|
|
672
|
-
const withdrawIxs = await Promise.all(reservesToWithdraw.map(async (reserve, index) => {
|
|
673
|
-
if (reserveStates[index] === null) {
|
|
674
|
-
throw new Error(`Reserve ${reserve} not found`);
|
|
675
|
-
}
|
|
676
|
-
const reserveState = reserveStates[index];
|
|
677
|
-
const marketAddress = reserveState.lendingMarket;
|
|
678
|
-
return this.withdrawPendingFeesIx(vaultAdmin, vault, vaultState, marketAddress, { address: reserve, state: reserveState }, adminTokenAta);
|
|
679
|
-
}));
|
|
680
|
-
return [createAtaIx, ...withdrawIxs];
|
|
681
|
-
}
|
|
682
|
-
// async closeVaultIx(vault: KaminoVault): Promise<Instruction> {
|
|
683
|
-
// const vaultState: VaultState = await vault.getState(this.getConnection());
|
|
684
|
-
// const closeVaultAccounts: CloseVaultAccounts = {
|
|
685
|
-
// adminAuthority: vaultState.adminAuthority,
|
|
686
|
-
// vaultState: vault.address,
|
|
687
|
-
// };
|
|
688
|
-
// return closeVault(closeVaultAccounts, this._kaminoVaultProgramId);
|
|
689
|
-
// }
|
|
690
|
-
/**
|
|
691
|
-
* This function creates instructions to deposit into a vault. It will also create ATA creation instructions for the vault shares that the user receives in return
|
|
692
|
-
* @param user - user to deposit
|
|
693
|
-
* @param vault - vault to deposit into (if the state is not provided, it will be fetched)
|
|
694
|
-
* @param tokenAmount - token amount to be deposited, in decimals (will be converted in lamports)
|
|
695
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
696
|
-
* @param [farmState] - the state of the vault farm, if the vault has a farm. Optional. If not provided, it will be fetched
|
|
697
|
-
* @returns - an instance of DepositIxs which contains the instructions to deposit in vault and the instructions to stake the shares in the farm if the vault has a farm
|
|
698
|
-
*/
|
|
699
|
-
async depositIxs(user, vault, tokenAmount, vaultReservesMap, farmState) {
|
|
700
|
-
return this.buildShareEntryIxs('deposit', user, vault, tokenAmount, vaultReservesMap, farmState);
|
|
701
|
-
}
|
|
702
|
-
async buySharesIxs(user, vault, tokenAmount, vaultReservesMap, farmState) {
|
|
703
|
-
return this.buildShareEntryIxs('buy', user, vault, tokenAmount, vaultReservesMap, farmState);
|
|
704
|
-
}
|
|
705
|
-
async buildShareEntryIxs(mode, user, vault, tokenAmount, vaultReservesMap, farmState) {
|
|
706
|
-
const vaultState = await vault.getState();
|
|
707
|
-
const tokenProgramID = vaultState.tokenProgram;
|
|
708
|
-
const userTokenAta = await (0, lib_1.getAssociatedTokenAddress)(vaultState.tokenMint, user.address, tokenProgramID);
|
|
709
|
-
const createAtasIxs = [];
|
|
710
|
-
const closeAtasIxs = [];
|
|
711
|
-
if (vaultState.tokenMint === lib_1.WRAPPED_SOL_MINT) {
|
|
712
|
-
const [{ ata: wsolAta, createAtaIx: createWsolAtaIxn }] = await (0, utils_2.createAtasIdempotent)(user, [
|
|
713
|
-
{
|
|
714
|
-
mint: lib_1.WRAPPED_SOL_MINT,
|
|
715
|
-
tokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
716
|
-
},
|
|
717
|
-
]);
|
|
718
|
-
createAtasIxs.push(createWsolAtaIxn);
|
|
719
|
-
const transferWsolIxs = (0, lib_1.getTransferWsolIxs)(user, wsolAta, (0, kit_1.lamports)(BigInt((0, utils_1.numberToLamportsDecimal)(tokenAmount, vaultState.tokenMintDecimals.toNumber()).ceil().toString())));
|
|
720
|
-
createAtasIxs.push(...transferWsolIxs);
|
|
721
|
-
}
|
|
722
|
-
const [{ ata: userSharesAta, createAtaIx: createSharesAtaIxs }] = await (0, utils_2.createAtasIdempotent)(user, [
|
|
723
|
-
{
|
|
724
|
-
mint: vaultState.sharesMint,
|
|
725
|
-
tokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
726
|
-
},
|
|
727
|
-
]);
|
|
728
|
-
createAtasIxs.push(createSharesAtaIxs);
|
|
729
|
-
const eventAuthority = await getEventAuthorityPda(this._kaminoVaultProgramId);
|
|
730
|
-
const tokenAmountLamports = (0, utils_1.numberToLamportsDecimal)(tokenAmount, vaultState.tokenMintDecimals.toNumber()).floor();
|
|
731
|
-
let entryIx;
|
|
732
|
-
if (mode === 'deposit') {
|
|
733
|
-
const depositAccounts = {
|
|
734
|
-
user,
|
|
735
|
-
vaultState: vault.address,
|
|
736
|
-
tokenVault: vaultState.tokenVault,
|
|
737
|
-
tokenMint: vaultState.tokenMint,
|
|
738
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
739
|
-
sharesMint: vaultState.sharesMint,
|
|
740
|
-
userTokenAta,
|
|
741
|
-
userSharesAta,
|
|
742
|
-
tokenProgram: tokenProgramID,
|
|
743
|
-
klendProgram: this._kaminoLendProgramId,
|
|
744
|
-
sharesTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
745
|
-
eventAuthority,
|
|
746
|
-
program: this._kaminoVaultProgramId,
|
|
747
|
-
};
|
|
748
|
-
const depositArgs = {
|
|
749
|
-
maxAmount: new bn_js_1.default(tokenAmountLamports.toString()),
|
|
750
|
-
};
|
|
751
|
-
entryIx = (0, instructions_1.deposit)(depositArgs, depositAccounts, undefined, this._kaminoVaultProgramId);
|
|
752
|
-
}
|
|
753
|
-
else {
|
|
754
|
-
const buyAccounts = {
|
|
755
|
-
user,
|
|
756
|
-
vaultState: vault.address,
|
|
757
|
-
tokenVault: vaultState.tokenVault,
|
|
758
|
-
tokenMint: vaultState.tokenMint,
|
|
759
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
760
|
-
sharesMint: vaultState.sharesMint,
|
|
761
|
-
userTokenAta,
|
|
762
|
-
userSharesAta,
|
|
763
|
-
tokenProgram: tokenProgramID,
|
|
764
|
-
klendProgram: this._kaminoLendProgramId,
|
|
765
|
-
sharesTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
766
|
-
eventAuthority,
|
|
767
|
-
program: this._kaminoVaultProgramId,
|
|
768
|
-
};
|
|
769
|
-
const buyArgs = {
|
|
770
|
-
maxAmount: new bn_js_1.default(tokenAmountLamports.toString()),
|
|
771
|
-
};
|
|
772
|
-
entryIx = (0, instructions_1.buy)(buyArgs, buyAccounts, undefined, this._kaminoVaultProgramId);
|
|
773
|
-
}
|
|
774
|
-
const vaultReserves = this.getVaultReserves(vaultState);
|
|
775
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
776
|
-
entryIx = this.appendRemainingAccountsForVaultReserves(entryIx, vaultReserves, vaultReservesState);
|
|
777
|
-
const result = {
|
|
778
|
-
depositIxs: [...createAtasIxs, entryIx, ...closeAtasIxs],
|
|
779
|
-
stakeInFarmIfNeededIxs: [],
|
|
780
|
-
};
|
|
781
|
-
if (!(await vault.hasFarm())) {
|
|
782
|
-
return result;
|
|
783
|
-
}
|
|
784
|
-
const stakeSharesIxs = await this.stakeSharesIxs(user, vault, undefined, farmState);
|
|
785
|
-
result.stakeInFarmIfNeededIxs = stakeSharesIxs;
|
|
786
|
-
return result;
|
|
787
|
-
}
|
|
788
|
-
/**
|
|
789
|
-
* This function creates instructions to stake the shares in the vault farm if the vault has a farm
|
|
790
|
-
* @param user - user to stake
|
|
791
|
-
* @param vault - vault to deposit into its farm (if the state is not provided, it will be fetched)
|
|
792
|
-
* @param [sharesAmount] - token amount to be deposited, in decimals (will be converted in lamports). Optional. If not provided, the user's share balance will be used
|
|
793
|
-
* @param [farmState] - the state of the vault farm, if the vault has a farm. Optional. If not provided, it will be fetched
|
|
794
|
-
* @returns - a list of instructions for the user to stake shares into the vault's farm, including the creation of prerequisite accounts if needed
|
|
795
|
-
*/
|
|
796
|
-
async stakeSharesIxs(user, vault, sharesAmount, farmState) {
|
|
797
|
-
const vaultState = await vault.getState();
|
|
798
|
-
let sharesToStakeLamports = new decimal_js_1.default(utils_2.U64_MAX);
|
|
799
|
-
if (sharesAmount) {
|
|
800
|
-
sharesToStakeLamports = (0, utils_1.numberToLamportsDecimal)(sharesAmount, vaultState.sharesMintDecimals.toNumber());
|
|
801
|
-
}
|
|
802
|
-
// if tokens to be staked are 0 or vault has no farm there is no stake needed
|
|
803
|
-
if (sharesToStakeLamports.lte(0) || !(await vault.hasFarm())) {
|
|
804
|
-
return [];
|
|
805
|
-
}
|
|
806
|
-
// returns the ix to create the farm state account if needed and the ix to stake the shares
|
|
807
|
-
return (0, farm_utils_1.getFarmStakeIxs)(this.getConnection(), user, sharesToStakeLamports, vaultState.vaultFarm, farmState);
|
|
808
|
-
}
|
|
809
|
-
/**
|
|
810
|
-
* This function will return a struct with the instructions to unstake from the farm if necessary and the instructions for the missing ATA creation instructions, as well as one or multiple withdraw instructions, based on how many reserves it's needed to withdraw from. This might have to be split in multiple transactions
|
|
811
|
-
* @param user - user to withdraw
|
|
812
|
-
* @param vault - vault to withdraw from
|
|
813
|
-
* @param shareAmount - share amount to withdraw (in tokens, not lamports), in order to withdraw everything, any value > user share amount
|
|
814
|
-
* @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault
|
|
815
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
816
|
-
* @param [farmState] - the state of the vault farm, if the vault has a farm. Optional. If not provided, it will be fetched
|
|
817
|
-
* @returns an array of instructions to create missing ATAs if needed and the withdraw instructions
|
|
818
|
-
*/
|
|
819
|
-
async withdrawIxs(user, vault, shareAmountToWithdraw, slot, vaultReservesMap, farmState) {
|
|
820
|
-
return this.buildShareExitIxs('withdraw', user, vault, shareAmountToWithdraw, slot, vaultReservesMap, farmState);
|
|
821
|
-
}
|
|
822
|
-
/**
|
|
823
|
-
* This function will return the missing ATA creation instructions, as well as one or multiple withdraw instructions, based on how many reserves it's needed to withdraw from. This might have to be split in multiple transactions
|
|
824
|
-
* @param user - user to sell shares for vault tokens
|
|
825
|
-
* @param vault - vault to sell shares from
|
|
826
|
-
* @param shareAmount - share amount to sell (in tokens, not lamports), in order to withdraw everything, any value > user share amount
|
|
827
|
-
* @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault
|
|
828
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
829
|
-
* @param [farmState] - the state of the vault farm, if the vault has a farm. Optional. If not provided, it will be fetched
|
|
830
|
-
* @returns an array of instructions to create missing ATAs if needed and the withdraw instructions
|
|
831
|
-
*/
|
|
832
|
-
async sellSharesIxs(user, vault, shareAmountToWithdraw, slot, vaultReservesMap, farmState) {
|
|
833
|
-
return this.buildShareExitIxs('sell', user, vault, shareAmountToWithdraw, slot, vaultReservesMap, farmState);
|
|
834
|
-
}
|
|
835
|
-
async buildShareExitIxs(mode, user, vault, shareAmountToWithdraw, slot, vaultReservesMap, farmState) {
|
|
836
|
-
const vaultState = await vault.getState();
|
|
837
|
-
const hasFarm = await vault.hasFarm();
|
|
838
|
-
const withdrawIxs = {
|
|
839
|
-
unstakeFromFarmIfNeededIxs: [],
|
|
840
|
-
withdrawIxs: [],
|
|
841
|
-
postWithdrawIxs: [],
|
|
842
|
-
};
|
|
843
|
-
// compute the total shares the user has (in ATA + in farm) and check if they want to withdraw everything or just a part
|
|
844
|
-
let userSharesAtaBalance = new decimal_js_1.default(0);
|
|
845
|
-
const userSharesAta = await (0, lib_1.getAssociatedTokenAddress)(vaultState.sharesMint, user.address);
|
|
846
|
-
const userSharesAtaState = await (0, token_2022_1.fetchMaybeToken)(this.getConnection(), userSharesAta);
|
|
847
|
-
if (userSharesAtaState.exists) {
|
|
848
|
-
const userSharesAtaBalanceInLamports = (0, lib_1.getTokenBalanceFromAccountInfoLamports)(userSharesAtaState);
|
|
849
|
-
userSharesAtaBalance = userSharesAtaBalanceInLamports.div(new decimal_js_1.default(10).pow(vaultState.sharesMintDecimals.toString()));
|
|
850
|
-
}
|
|
851
|
-
let userSharesInFarm = new decimal_js_1.default(0);
|
|
852
|
-
if (hasFarm) {
|
|
853
|
-
userSharesInFarm = await (0, farm_utils_1.getUserSharesInTokensStakedInFarm)(this.getConnection(), user.address, vaultState.vaultFarm, vaultState.sharesMintDecimals.toNumber());
|
|
854
|
-
}
|
|
855
|
-
let sharesToWithdraw = shareAmountToWithdraw;
|
|
856
|
-
const totalUserShares = userSharesAtaBalance.add(userSharesInFarm);
|
|
857
|
-
let withdrawAllShares = false;
|
|
858
|
-
if (sharesToWithdraw.gt(totalUserShares)) {
|
|
859
|
-
sharesToWithdraw = new decimal_js_1.default(utils_2.U64_MAX.toString()).div(new decimal_js_1.default(10).pow(vaultState.sharesMintDecimals.toString()));
|
|
860
|
-
withdrawAllShares = true;
|
|
861
|
-
}
|
|
862
|
-
// if not enough shares in ATA unstake from farm
|
|
863
|
-
const sharesInAtaAreEnoughForWithdraw = sharesToWithdraw.lte(userSharesAtaBalance);
|
|
864
|
-
if (hasFarm && !sharesInAtaAreEnoughForWithdraw && userSharesInFarm.gt(0)) {
|
|
865
|
-
// if we need to unstake we need to make sure share ata is created
|
|
866
|
-
const [{ createAtaIx }] = await (0, utils_2.createAtasIdempotent)(user, [
|
|
867
|
-
{
|
|
868
|
-
mint: vaultState.sharesMint,
|
|
869
|
-
tokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
870
|
-
},
|
|
871
|
-
]);
|
|
872
|
-
withdrawIxs.unstakeFromFarmIfNeededIxs.push(createAtaIx);
|
|
873
|
-
let shareLamportsToWithdraw = new decimal_js_1.default(utils_2.U64_MAX.toString());
|
|
874
|
-
if (!withdrawAllShares) {
|
|
875
|
-
const sharesToWithdrawFromFarm = sharesToWithdraw.sub(userSharesAtaBalance);
|
|
876
|
-
shareLamportsToWithdraw = (0, kliquidity_sdk_1.collToLamportsDecimal)(sharesToWithdrawFromFarm, vaultState.sharesMintDecimals.toNumber());
|
|
877
|
-
}
|
|
878
|
-
const unstakeAndWithdrawFromFarmIxs = await (0, farm_utils_1.getFarmUnstakeAndWithdrawIxs)(this.getConnection(), user, shareLamportsToWithdraw, vaultState.vaultFarm, farmState);
|
|
879
|
-
withdrawIxs.unstakeFromFarmIfNeededIxs.push(unstakeAndWithdrawFromFarmIxs.unstakeIx);
|
|
880
|
-
withdrawIxs.unstakeFromFarmIfNeededIxs.push(unstakeAndWithdrawFromFarmIxs.withdrawIx);
|
|
881
|
-
}
|
|
882
|
-
const hasAllocatedReserves = vaultState.vaultAllocationStrategy.some((allocation) => allocation.reserve !== lib_1.DEFAULT_PUBLIC_KEY);
|
|
883
|
-
if (hasAllocatedReserves) {
|
|
884
|
-
const reserveExitBuilder = mode === 'withdraw'
|
|
885
|
-
? (params) => this.withdrawIx(params.user, params.vault, params.vaultState, params.marketAddress, params.reserve, params.userSharesAta, params.userTokenAta, params.shareAmountLamports, params.vaultReservesState)
|
|
886
|
-
: (params) => this.sellIx(params.user, params.vault, params.vaultState, params.marketAddress, params.reserve, params.userSharesAta, params.userTokenAta, params.shareAmountLamports, params.vaultReservesState);
|
|
887
|
-
const withdrawFromVaultIxs = await this.buildReserveExitIxs({
|
|
888
|
-
user,
|
|
889
|
-
vault,
|
|
890
|
-
vaultState,
|
|
891
|
-
shareAmount: sharesToWithdraw,
|
|
892
|
-
allUserShares: totalUserShares,
|
|
893
|
-
slot,
|
|
894
|
-
vaultReservesMap,
|
|
895
|
-
builder: reserveExitBuilder,
|
|
896
|
-
});
|
|
897
|
-
withdrawIxs.withdrawIxs = withdrawFromVaultIxs;
|
|
898
|
-
}
|
|
899
|
-
else {
|
|
900
|
-
const withdrawFromVaultIxs = await this.withdrawFromAvailableIxs(user, vault, sharesToWithdraw);
|
|
901
|
-
withdrawIxs.withdrawIxs = withdrawFromVaultIxs;
|
|
902
|
-
}
|
|
903
|
-
// if the vault is for SOL return the ix to unwrap the SOL
|
|
904
|
-
if (vaultState.tokenMint === lib_1.WRAPPED_SOL_MINT) {
|
|
905
|
-
const userWsolAta = await (0, lib_1.getAssociatedTokenAddress)(lib_1.WRAPPED_SOL_MINT, user.address);
|
|
906
|
-
const unwrapIx = (0, token_2022_1.getCloseAccountInstruction)({
|
|
907
|
-
account: userWsolAta,
|
|
908
|
-
owner: user,
|
|
909
|
-
destination: user.address,
|
|
910
|
-
}, { programAddress: token_1.TOKEN_PROGRAM_ADDRESS });
|
|
911
|
-
withdrawIxs.postWithdrawIxs.push(unwrapIx);
|
|
912
|
-
}
|
|
913
|
-
// if we burn all of user's shares close its shares ATA
|
|
914
|
-
const burnAllUserShares = sharesToWithdraw.gt(totalUserShares);
|
|
915
|
-
if (burnAllUserShares) {
|
|
916
|
-
const closeAtaIx = (0, token_2022_1.getCloseAccountInstruction)({
|
|
917
|
-
account: userSharesAta,
|
|
918
|
-
owner: user,
|
|
919
|
-
destination: user.address,
|
|
920
|
-
}, { programAddress: token_1.TOKEN_PROGRAM_ADDRESS });
|
|
921
|
-
withdrawIxs.postWithdrawIxs.push(closeAtaIx);
|
|
922
|
-
}
|
|
923
|
-
return withdrawIxs;
|
|
924
|
-
}
|
|
925
|
-
async withdrawFromAvailableIxs(user, vault, shareAmount) {
|
|
926
|
-
const vaultState = await vault.getState();
|
|
927
|
-
const userSharesAta = await (0, lib_1.getAssociatedTokenAddress)(vaultState.sharesMint, user.address);
|
|
928
|
-
const [{ ata: userTokenAta, createAtaIx }] = await (0, utils_2.createAtasIdempotent)(user, [
|
|
929
|
-
{
|
|
930
|
-
mint: vaultState.tokenMint,
|
|
931
|
-
tokenProgram: vaultState.tokenProgram,
|
|
932
|
-
},
|
|
933
|
-
]);
|
|
934
|
-
const shareLamportsToWithdraw = (0, kliquidity_sdk_1.collToLamportsDecimal)(shareAmount, vaultState.sharesMintDecimals.toNumber());
|
|
935
|
-
const withdrawFromAvailableIxn = await this.withdrawFromAvailableIx(user, vault, vaultState, userSharesAta, userTokenAta, shareLamportsToWithdraw);
|
|
936
|
-
return [createAtaIx, withdrawFromAvailableIxn];
|
|
937
|
-
}
|
|
938
|
-
async buildReserveExitIxs({ user, vault, vaultState, shareAmount, allUserShares, slot, vaultReservesMap, builder, }) {
|
|
939
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
940
|
-
const userSharesAta = await (0, lib_1.getAssociatedTokenAddress)(vaultState.sharesMint, user.address);
|
|
941
|
-
const [{ ata: userTokenAta, createAtaIx }] = await (0, utils_2.createAtasIdempotent)(user, [
|
|
942
|
-
{
|
|
943
|
-
mint: vaultState.tokenMint,
|
|
944
|
-
tokenProgram: vaultState.tokenProgram,
|
|
945
|
-
},
|
|
946
|
-
]);
|
|
947
|
-
const withdrawAllShares = shareAmount.gte(allUserShares);
|
|
948
|
-
const actualSharesToWithdraw = shareAmount.lte(allUserShares) ? shareAmount : allUserShares;
|
|
949
|
-
const shareLamportsToWithdraw = (0, kliquidity_sdk_1.collToLamportsDecimal)(actualSharesToWithdraw, vaultState.sharesMintDecimals.toNumber());
|
|
950
|
-
const tokensPerShare = await this.getTokensPerShareSingleVault(vault, slot);
|
|
951
|
-
const sharesPerToken = new decimal_js_1.default(1).div(tokensPerShare);
|
|
952
|
-
const tokensToWithdraw = shareLamportsToWithdraw.mul(tokensPerShare);
|
|
953
|
-
let tokenLeftToWithdraw = tokensToWithdraw;
|
|
954
|
-
const availableTokens = new decimal_js_1.default(vaultState.tokenAvailable.toString());
|
|
955
|
-
tokenLeftToWithdraw = tokenLeftToWithdraw.sub(availableTokens);
|
|
956
|
-
const reserveWithSharesAmountToWithdraw = [];
|
|
957
|
-
let isFirstWithdraw = true;
|
|
958
|
-
if (tokenLeftToWithdraw.lte(0)) {
|
|
959
|
-
const firstReserve = vaultState.vaultAllocationStrategy.find((reserve) => reserve.reserve !== lib_1.DEFAULT_PUBLIC_KEY);
|
|
960
|
-
if (!firstReserve) {
|
|
961
|
-
throw new Error('No reserve available to satisfy withdraw request');
|
|
962
|
-
}
|
|
963
|
-
if (withdrawAllShares) {
|
|
964
|
-
reserveWithSharesAmountToWithdraw.push({
|
|
965
|
-
reserve: firstReserve.reserve,
|
|
966
|
-
shares: new decimal_js_1.default(utils_2.U64_MAX.toString()),
|
|
967
|
-
});
|
|
968
|
-
}
|
|
969
|
-
else {
|
|
970
|
-
reserveWithSharesAmountToWithdraw.push({
|
|
971
|
-
reserve: firstReserve.reserve,
|
|
972
|
-
shares: shareLamportsToWithdraw,
|
|
973
|
-
});
|
|
974
|
-
}
|
|
975
|
-
}
|
|
976
|
-
else {
|
|
977
|
-
const reserveAllocationAvailableLiquidityToWithdraw = await this.getReserveAllocationAvailableLiquidityToWithdraw(vault, slot, vaultReservesState);
|
|
978
|
-
const reserveAllocationAvailableLiquidityToWithdrawSorted = [
|
|
979
|
-
...reserveAllocationAvailableLiquidityToWithdraw.entries(),
|
|
980
|
-
].sort((a, b) => b[1].sub(a[1]).toNumber());
|
|
981
|
-
reserveAllocationAvailableLiquidityToWithdrawSorted.forEach(([key, availableLiquidityToWithdraw]) => {
|
|
982
|
-
if (tokenLeftToWithdraw.gt(0)) {
|
|
983
|
-
let tokensToWithdrawFromReserve = decimal_js_1.default.min(tokenLeftToWithdraw, availableLiquidityToWithdraw);
|
|
984
|
-
if (isFirstWithdraw) {
|
|
985
|
-
tokensToWithdrawFromReserve = tokensToWithdrawFromReserve.add(availableTokens);
|
|
986
|
-
isFirstWithdraw = false;
|
|
987
|
-
}
|
|
988
|
-
if (withdrawAllShares) {
|
|
989
|
-
reserveWithSharesAmountToWithdraw.push({ reserve: key, shares: new decimal_js_1.default(utils_2.U64_MAX.toString()) });
|
|
990
|
-
}
|
|
991
|
-
else {
|
|
992
|
-
const sharesToWithdrawFromReserve = tokensToWithdrawFromReserve.mul(sharesPerToken).floor();
|
|
993
|
-
reserveWithSharesAmountToWithdraw.push({ reserve: key, shares: sharesToWithdrawFromReserve });
|
|
994
|
-
}
|
|
995
|
-
tokenLeftToWithdraw = tokenLeftToWithdraw.sub(tokensToWithdrawFromReserve);
|
|
996
|
-
}
|
|
997
|
-
});
|
|
998
|
-
}
|
|
999
|
-
const withdrawIxs = [];
|
|
1000
|
-
withdrawIxs.push(createAtaIx);
|
|
1001
|
-
for (const reserveWithTokens of reserveWithSharesAmountToWithdraw) {
|
|
1002
|
-
const reserveState = vaultReservesState.get(reserveWithTokens.reserve);
|
|
1003
|
-
if (reserveState === undefined) {
|
|
1004
|
-
throw new Error(`Reserve ${reserveWithTokens.reserve} not found in vault reserves map`);
|
|
1005
|
-
}
|
|
1006
|
-
const marketAddress = reserveState.state.lendingMarket;
|
|
1007
|
-
const exitIx = await builder({
|
|
1008
|
-
user,
|
|
1009
|
-
vault,
|
|
1010
|
-
vaultState,
|
|
1011
|
-
marketAddress,
|
|
1012
|
-
reserve: { address: reserveWithTokens.reserve, state: reserveState.state },
|
|
1013
|
-
userSharesAta,
|
|
1014
|
-
userTokenAta,
|
|
1015
|
-
shareAmountLamports: reserveWithTokens.shares,
|
|
1016
|
-
vaultReservesState,
|
|
1017
|
-
});
|
|
1018
|
-
withdrawIxs.push(exitIx);
|
|
1019
|
-
}
|
|
1020
|
-
return withdrawIxs;
|
|
1021
|
-
}
|
|
1022
|
-
/**
|
|
1023
|
-
* This will trigger invest by balancing, based on weights, the reserve allocations of the vault. It can either withdraw or deposit into reserves to balance them. This is a function that should be cranked
|
|
1024
|
-
* @param payer wallet that pays the tx
|
|
1025
|
-
* @param vault - vault to invest from
|
|
1026
|
-
* @param skipComputationChecks - if true, the function will skip the computation checks and will invest all the reserves; it is useful for txs where we update reserve allocations and invest atomically
|
|
1027
|
-
* @returns - an array of invest instructions for each invest action required for the vault reserves
|
|
1028
|
-
*/
|
|
1029
|
-
async investAllReservesIxs(payer, vault, skipComputationChecks = false) {
|
|
1030
|
-
const vaultState = await vault.reloadState();
|
|
1031
|
-
const minInvestAmount = vaultState.minInvestAmount;
|
|
1032
|
-
const allReserves = this.getVaultReserves(vaultState);
|
|
1033
|
-
if (allReserves.length === 0) {
|
|
1034
|
-
throw new Error('No reserves found for the vault, please select at least one reserve for the vault');
|
|
1035
|
-
}
|
|
1036
|
-
const [allReservesStateMap, computedReservesAllocation] = await Promise.all([
|
|
1037
|
-
this.loadVaultReserves(vaultState),
|
|
1038
|
-
this.getVaultComputedReservesAllocation(vaultState),
|
|
1039
|
-
]);
|
|
1040
|
-
const tokenProgram = await (0, rpc_1.getAccountOwner)(this.getConnection(), vaultState.tokenMint);
|
|
1041
|
-
const [{ createAtaIx }] = await (0, utils_2.createAtasIdempotent)(payer, [{ mint: vaultState.tokenMint, tokenProgram }]);
|
|
1042
|
-
// compute total vault holdings and expected distribution based on weights
|
|
1043
|
-
const curentVaultAllocations = this.getVaultAllocations(vaultState);
|
|
1044
|
-
const reservesToDisinvestFrom = [];
|
|
1045
|
-
const reservesToInvestInto = [];
|
|
1046
|
-
for (let index = 0; index < allReserves.length; index++) {
|
|
1047
|
-
const reservePubkey = allReserves[index];
|
|
1048
|
-
const reserveState = allReservesStateMap.get(reservePubkey);
|
|
1049
|
-
const computedAllocation = computedReservesAllocation.targetReservesAllocation.get(reservePubkey);
|
|
1050
|
-
const currentCTokenAllocation = curentVaultAllocations.get(reservePubkey).ctokenAllocation;
|
|
1051
|
-
const currentAllocationCap = curentVaultAllocations.get(reservePubkey).tokenAllocationCap;
|
|
1052
|
-
const reserveCollExchangeRate = reserveState.getCollateralExchangeRate();
|
|
1053
|
-
const reserveAllocationLiquidityAmount = (0, lib_1.lamportsToDecimal)(currentCTokenAllocation.div(reserveCollExchangeRate), vaultState.tokenMintDecimals.toNumber());
|
|
1054
|
-
const diffInReserveTokens = computedAllocation.sub(reserveAllocationLiquidityAmount);
|
|
1055
|
-
const diffInReserveLamports = (0, kliquidity_sdk_1.collToLamportsDecimal)(diffInReserveTokens, vaultState.tokenMintDecimals.toNumber());
|
|
1056
|
-
// it is possible that the tokens to invest are > minInvestAmountLamports but the ctokens it represent are 0, which will make an invest move 0 tokens
|
|
1057
|
-
const diffInCtokenLamports = reserveCollExchangeRate.mul(diffInReserveLamports.abs());
|
|
1058
|
-
const actualDiffInLamports = diffInCtokenLamports.floor().div(reserveCollExchangeRate).floor();
|
|
1059
|
-
// if the diff for the reserve is smaller than the min invest amount, we do not need to invest or disinvest
|
|
1060
|
-
const minInvestAmountLamports = new decimal_js_1.default(minInvestAmount.toString());
|
|
1061
|
-
if (actualDiffInLamports.gt(minInvestAmountLamports) || skipComputationChecks) {
|
|
1062
|
-
if (computedAllocation.lt(reserveAllocationLiquidityAmount)) {
|
|
1063
|
-
reservesToDisinvestFrom.push(reservePubkey);
|
|
1064
|
-
}
|
|
1065
|
-
else {
|
|
1066
|
-
const actualTarget = currentAllocationCap.gt(computedAllocation) ? computedAllocation : currentAllocationCap;
|
|
1067
|
-
const lamportsToAddToReserve = actualTarget.sub(reserveAllocationLiquidityAmount);
|
|
1068
|
-
if (lamportsToAddToReserve.gt(minInvestAmountLamports)) {
|
|
1069
|
-
reservesToInvestInto.push(reservePubkey);
|
|
1070
|
-
}
|
|
1071
|
-
}
|
|
1072
|
-
}
|
|
1073
|
-
}
|
|
1074
|
-
const investIxsPromises = [];
|
|
1075
|
-
// invest first the reserves from which we disinvest, then the other ones
|
|
1076
|
-
for (const reserve of reservesToDisinvestFrom) {
|
|
1077
|
-
const reserveState = allReservesStateMap.get(reserve);
|
|
1078
|
-
if (reserveState === null) {
|
|
1079
|
-
throw new Error(`Reserve ${reserve} not found`);
|
|
1080
|
-
}
|
|
1081
|
-
const investIxsPromise = this.investSingleReserveIxs(payer, vault, {
|
|
1082
|
-
address: reserve,
|
|
1083
|
-
state: reserveState.state,
|
|
1084
|
-
}, allReservesStateMap, false);
|
|
1085
|
-
investIxsPromises.push(investIxsPromise);
|
|
1086
|
-
}
|
|
1087
|
-
for (const reserve of reservesToInvestInto) {
|
|
1088
|
-
const reserveState = allReservesStateMap.get(reserve);
|
|
1089
|
-
if (reserveState === null) {
|
|
1090
|
-
throw new Error(`Reserve ${reserve} not found`);
|
|
1091
|
-
}
|
|
1092
|
-
const investIxsPromise = this.investSingleReserveIxs(payer, vault, {
|
|
1093
|
-
address: reserve,
|
|
1094
|
-
state: reserveState.state,
|
|
1095
|
-
}, allReservesStateMap, false);
|
|
1096
|
-
investIxsPromises.push(investIxsPromise);
|
|
1097
|
-
}
|
|
1098
|
-
let investIxs = [];
|
|
1099
|
-
investIxs.push(createAtaIx);
|
|
1100
|
-
investIxs = await Promise.all(investIxsPromises).then((ixs) => ixs.flat());
|
|
1101
|
-
return investIxs;
|
|
1102
|
-
}
|
|
1103
|
-
// todo: make sure we also check the ata of the investor for the vault token exists
|
|
1104
|
-
/**
|
|
1105
|
-
* This will trigger invest by balancing, based on weights, the reserve allocation of the vault. It can either withdraw or deposit into the given reserve to balance it
|
|
1106
|
-
* @param payer wallet pubkey - the instruction is permissionless and does not require the vault admin, due to rounding between cTokens and the underlying, the payer may have to contribute 1 or more lamports of the underlying from their token account
|
|
1107
|
-
* @param vault - vault to invest from
|
|
1108
|
-
* @param reserve - reserve to invest into or disinvest from
|
|
1109
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1110
|
-
* @param [createAtaIfNeeded]
|
|
1111
|
-
* @returns - an array of invest instructions for each invest action required for the vault reserves
|
|
1112
|
-
*/
|
|
1113
|
-
async investSingleReserveIxs(payer, vault, reserve, vaultReservesMap, createAtaIfNeeded = true) {
|
|
1114
|
-
const vaultState = await vault.getState();
|
|
1115
|
-
const cTokenVault = await getCTokenVaultPda(vault.address, reserve.address, this._kaminoVaultProgramId);
|
|
1116
|
-
const [lendingMarketAuth] = await (0, utils_2.lendingMarketAuthPda)(reserve.state.lendingMarket, this._kaminoLendProgramId);
|
|
1117
|
-
const ixs = [];
|
|
1118
|
-
const tokenProgram = await (0, rpc_1.getAccountOwner)(this.getConnection(), vaultState.tokenMint);
|
|
1119
|
-
const [{ ata: payerTokenAta, createAtaIx }] = await (0, utils_2.createAtasIdempotent)(payer, [
|
|
1120
|
-
{ mint: vaultState.tokenMint, tokenProgram },
|
|
1121
|
-
]);
|
|
1122
|
-
if (createAtaIfNeeded) {
|
|
1123
|
-
ixs.push(createAtaIx);
|
|
1124
|
-
}
|
|
1125
|
-
const reserveWhitelistEntryOption = await getReserveWhitelistEntryIfExists(reserve.address, this.getConnection(), this._kaminoVaultProgramId);
|
|
1126
|
-
const investAccounts = {
|
|
1127
|
-
payer,
|
|
1128
|
-
vaultState: vault.address,
|
|
1129
|
-
tokenVault: vaultState.tokenVault,
|
|
1130
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
1131
|
-
ctokenVault: cTokenVault,
|
|
1132
|
-
reserve: reserve.address,
|
|
1133
|
-
/** CPI accounts */
|
|
1134
|
-
lendingMarket: reserve.state.lendingMarket,
|
|
1135
|
-
lendingMarketAuthority: lendingMarketAuth,
|
|
1136
|
-
reserveLiquiditySupply: reserve.state.liquidity.supplyVault,
|
|
1137
|
-
reserveCollateralMint: reserve.state.collateral.mintPubkey,
|
|
1138
|
-
reserveWhitelistEntry: reserveWhitelistEntryOption,
|
|
1139
|
-
klendProgram: this._kaminoLendProgramId,
|
|
1140
|
-
instructionSysvarAccount: sysvars_1.SYSVAR_INSTRUCTIONS_ADDRESS,
|
|
1141
|
-
tokenProgram: tokenProgram,
|
|
1142
|
-
payerTokenAccount: payerTokenAta,
|
|
1143
|
-
tokenMint: vaultState.tokenMint,
|
|
1144
|
-
reserveCollateralTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1145
|
-
};
|
|
1146
|
-
let investIx = (0, instructions_1.invest)(investAccounts, undefined, this._kaminoVaultProgramId);
|
|
1147
|
-
const vaultReserves = this.getVaultReserves(vaultState);
|
|
1148
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
1149
|
-
investIx = this.appendRemainingAccountsForVaultReserves(investIx, vaultReserves, vaultReservesState);
|
|
1150
|
-
return [createAtaIx, investIx];
|
|
1151
|
-
}
|
|
1152
|
-
/** Convert a string to a u8 representation to be stored on chain */
|
|
1153
|
-
encodeVaultName(token) {
|
|
1154
|
-
const maxArray = new Uint8Array(40);
|
|
1155
|
-
const s = new TextEncoder().encode(token);
|
|
1156
|
-
maxArray.set(s);
|
|
1157
|
-
return maxArray;
|
|
1158
|
-
}
|
|
1159
|
-
/**Convert an u8 array to a string */
|
|
1160
|
-
decodeVaultName(token) {
|
|
1161
|
-
return (0, utils_1.decodeVaultName)(token);
|
|
1162
|
-
}
|
|
1163
|
-
/** Helper to serialize value as Buffer for updateVaultConfig instruction */
|
|
1164
|
-
getValueForModeAsBuffer(mode, value) {
|
|
1165
|
-
const isWhitelistOnlyFlag = mode.kind === new types_1.VaultConfigField.AllowInvestInWhitelistedReservesOnly().kind ||
|
|
1166
|
-
mode.kind === new types_1.VaultConfigField.AllowAllocationsInWhitelistedReservesOnly().kind;
|
|
1167
|
-
if (isWhitelistOnlyFlag) {
|
|
1168
|
-
const flag = (0, utils_2.parseBooleanFlag)(value);
|
|
1169
|
-
return Buffer.from([flag]);
|
|
1170
|
-
}
|
|
1171
|
-
else if (isNaN(+value)) {
|
|
1172
|
-
if (mode.kind === new types_1.VaultConfigField.Name().kind) {
|
|
1173
|
-
const data = Array.from(this.encodeVaultName(value));
|
|
1174
|
-
return Buffer.from(data);
|
|
1175
|
-
}
|
|
1176
|
-
else {
|
|
1177
|
-
const data = (0, kit_1.address)(value);
|
|
1178
|
-
return Buffer.from(addressEncoder.encode(data));
|
|
1179
|
-
}
|
|
1180
|
-
}
|
|
1181
|
-
else {
|
|
1182
|
-
const buffer = Buffer.alloc(8);
|
|
1183
|
-
buffer.writeBigUInt64LE(BigInt(value.toString()));
|
|
1184
|
-
return buffer;
|
|
1185
|
-
}
|
|
1186
|
-
}
|
|
1187
|
-
async sellIx(user, vault, vaultState, marketAddress, reserve, userSharesAta, userTokenAta, shareAmountLamports, vaultReservesState) {
|
|
1188
|
-
const [lendingMarketAuth] = await (0, utils_2.lendingMarketAuthPda)(marketAddress, this._kaminoLendProgramId);
|
|
1189
|
-
const globalConfig = await getKvaultGlobalConfigPda(this._kaminoVaultProgramId);
|
|
1190
|
-
const eventAuthority = await getEventAuthorityPda(this._kaminoVaultProgramId);
|
|
1191
|
-
const sellAccounts = {
|
|
1192
|
-
withdrawFromAvailable: {
|
|
1193
|
-
user,
|
|
1194
|
-
vaultState: vault.address,
|
|
1195
|
-
globalConfig: globalConfig,
|
|
1196
|
-
tokenVault: vaultState.tokenVault,
|
|
1197
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
1198
|
-
userTokenAta: userTokenAta,
|
|
1199
|
-
tokenMint: vaultState.tokenMint,
|
|
1200
|
-
userSharesAta: userSharesAta,
|
|
1201
|
-
sharesMint: vaultState.sharesMint,
|
|
1202
|
-
tokenProgram: vaultState.tokenProgram,
|
|
1203
|
-
sharesTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1204
|
-
klendProgram: this._kaminoLendProgramId,
|
|
1205
|
-
eventAuthority: eventAuthority,
|
|
1206
|
-
program: this._kaminoVaultProgramId,
|
|
1207
|
-
},
|
|
1208
|
-
withdrawFromReserveAccounts: {
|
|
1209
|
-
vaultState: vault.address,
|
|
1210
|
-
reserve: reserve.address,
|
|
1211
|
-
ctokenVault: await getCTokenVaultPda(vault.address, reserve.address, this._kaminoVaultProgramId),
|
|
1212
|
-
lendingMarket: marketAddress,
|
|
1213
|
-
lendingMarketAuthority: lendingMarketAuth,
|
|
1214
|
-
reserveLiquiditySupply: reserve.state.liquidity.supplyVault,
|
|
1215
|
-
reserveCollateralMint: reserve.state.collateral.mintPubkey,
|
|
1216
|
-
reserveCollateralTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1217
|
-
instructionSysvarAccount: sysvars_1.SYSVAR_INSTRUCTIONS_ADDRESS,
|
|
1218
|
-
},
|
|
1219
|
-
eventAuthority: eventAuthority,
|
|
1220
|
-
program: this._kaminoVaultProgramId,
|
|
1221
|
-
};
|
|
1222
|
-
const sellArgs = {
|
|
1223
|
-
sharesAmount: new bn_js_1.default(shareAmountLamports.floor().toString()),
|
|
1224
|
-
};
|
|
1225
|
-
let sellIxn = (0, instructions_1.sell)(sellArgs, sellAccounts, undefined, this._kaminoVaultProgramId);
|
|
1226
|
-
const vaultReserves = this.getVaultReserves(vaultState);
|
|
1227
|
-
sellIxn = this.appendRemainingAccountsForVaultReserves(sellIxn, vaultReserves, vaultReservesState);
|
|
1228
|
-
return sellIxn;
|
|
1229
|
-
}
|
|
1230
|
-
async withdrawIx(user, vault, vaultState, marketAddress, reserve, userSharesAta, userTokenAta, shareAmountLamports, vaultReservesState) {
|
|
1231
|
-
const [lendingMarketAuth] = await (0, utils_2.lendingMarketAuthPda)(marketAddress, this._kaminoLendProgramId);
|
|
1232
|
-
const globalConfig = await getKvaultGlobalConfigPda(this._kaminoVaultProgramId);
|
|
1233
|
-
const eventAuthority = await getEventAuthorityPda(this._kaminoVaultProgramId);
|
|
1234
|
-
const withdrawAccounts = {
|
|
1235
|
-
withdrawFromAvailable: {
|
|
1236
|
-
user,
|
|
1237
|
-
vaultState: vault.address,
|
|
1238
|
-
globalConfig: globalConfig,
|
|
1239
|
-
tokenVault: vaultState.tokenVault,
|
|
1240
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
1241
|
-
userTokenAta: userTokenAta,
|
|
1242
|
-
tokenMint: vaultState.tokenMint,
|
|
1243
|
-
userSharesAta: userSharesAta,
|
|
1244
|
-
sharesMint: vaultState.sharesMint,
|
|
1245
|
-
tokenProgram: vaultState.tokenProgram,
|
|
1246
|
-
sharesTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1247
|
-
klendProgram: this._kaminoLendProgramId,
|
|
1248
|
-
eventAuthority: eventAuthority,
|
|
1249
|
-
program: this._kaminoVaultProgramId,
|
|
1250
|
-
},
|
|
1251
|
-
withdrawFromReserveAccounts: {
|
|
1252
|
-
vaultState: vault.address,
|
|
1253
|
-
reserve: reserve.address,
|
|
1254
|
-
ctokenVault: await getCTokenVaultPda(vault.address, reserve.address, this._kaminoVaultProgramId),
|
|
1255
|
-
lendingMarket: marketAddress,
|
|
1256
|
-
lendingMarketAuthority: lendingMarketAuth,
|
|
1257
|
-
reserveLiquiditySupply: reserve.state.liquidity.supplyVault,
|
|
1258
|
-
reserveCollateralMint: reserve.state.collateral.mintPubkey,
|
|
1259
|
-
reserveCollateralTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1260
|
-
instructionSysvarAccount: sysvars_1.SYSVAR_INSTRUCTIONS_ADDRESS,
|
|
1261
|
-
},
|
|
1262
|
-
eventAuthority: eventAuthority,
|
|
1263
|
-
program: this._kaminoVaultProgramId,
|
|
1264
|
-
};
|
|
1265
|
-
const withdrawArgs = {
|
|
1266
|
-
sharesAmount: new bn_js_1.default(shareAmountLamports.floor().toString()),
|
|
1267
|
-
};
|
|
1268
|
-
let withdrawIxn = (0, instructions_1.withdraw)(withdrawArgs, withdrawAccounts, undefined, this._kaminoVaultProgramId);
|
|
1269
|
-
const vaultReserves = this.getVaultReserves(vaultState);
|
|
1270
|
-
withdrawIxn = this.appendRemainingAccountsForVaultReserves(withdrawIxn, vaultReserves, vaultReservesState);
|
|
1271
|
-
return withdrawIxn;
|
|
1272
|
-
}
|
|
1273
|
-
async withdrawFromAvailableIx(user, vault, vaultState, userSharesAta, userTokenAta, shareAmountLamports) {
|
|
1274
|
-
const globalConfig = await getKvaultGlobalConfigPda(this._kaminoVaultProgramId);
|
|
1275
|
-
const eventAuthority = await getEventAuthorityPda(this._kaminoVaultProgramId);
|
|
1276
|
-
const withdrawFromAvailableAccounts = {
|
|
1277
|
-
user,
|
|
1278
|
-
vaultState: vault.address,
|
|
1279
|
-
globalConfig: globalConfig,
|
|
1280
|
-
tokenVault: vaultState.tokenVault,
|
|
1281
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
1282
|
-
userTokenAta,
|
|
1283
|
-
tokenMint: vaultState.tokenMint,
|
|
1284
|
-
userSharesAta,
|
|
1285
|
-
sharesMint: vaultState.sharesMint,
|
|
1286
|
-
tokenProgram: vaultState.tokenProgram,
|
|
1287
|
-
sharesTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1288
|
-
klendProgram: this._kaminoLendProgramId,
|
|
1289
|
-
eventAuthority,
|
|
1290
|
-
program: this._kaminoVaultProgramId,
|
|
1291
|
-
};
|
|
1292
|
-
const withdrawFromAvailableArgs = {
|
|
1293
|
-
sharesAmount: new bn_js_1.default(shareAmountLamports.floor().toString()),
|
|
1294
|
-
};
|
|
1295
|
-
return (0, instructions_1.withdrawFromAvailable)(withdrawFromAvailableArgs, withdrawFromAvailableAccounts, undefined, this._kaminoVaultProgramId);
|
|
1296
|
-
}
|
|
1297
|
-
async withdrawPendingFeesIx(authority, vault, vaultState, marketAddress, reserve, adminTokenAta) {
|
|
1298
|
-
const [lendingMarketAuth] = await (0, utils_2.lendingMarketAuthPda)(marketAddress, this._kaminoLendProgramId);
|
|
1299
|
-
const withdrawPendingFeesAccounts = {
|
|
1300
|
-
vaultAdminAuthority: authority,
|
|
1301
|
-
vaultState: vault.address,
|
|
1302
|
-
reserve: reserve.address,
|
|
1303
|
-
tokenVault: vaultState.tokenVault,
|
|
1304
|
-
ctokenVault: await getCTokenVaultPda(vault.address, reserve.address, this._kaminoVaultProgramId),
|
|
1305
|
-
baseVaultAuthority: vaultState.baseVaultAuthority,
|
|
1306
|
-
tokenAta: adminTokenAta,
|
|
1307
|
-
tokenMint: vaultState.tokenMint,
|
|
1308
|
-
tokenProgram: vaultState.tokenProgram,
|
|
1309
|
-
/** CPI accounts */
|
|
1310
|
-
lendingMarket: marketAddress,
|
|
1311
|
-
lendingMarketAuthority: lendingMarketAuth,
|
|
1312
|
-
reserveLiquiditySupply: reserve.state.liquidity.supplyVault,
|
|
1313
|
-
reserveCollateralMint: reserve.state.collateral.mintPubkey,
|
|
1314
|
-
klendProgram: this._kaminoLendProgramId,
|
|
1315
|
-
instructionSysvarAccount: sysvars_1.SYSVAR_INSTRUCTIONS_ADDRESS,
|
|
1316
|
-
reserveCollateralTokenProgram: token_1.TOKEN_PROGRAM_ADDRESS,
|
|
1317
|
-
};
|
|
1318
|
-
let withdrawPendingFeesIxn = (0, instructions_1.withdrawPendingFees)(withdrawPendingFeesAccounts, undefined, this._kaminoVaultProgramId);
|
|
1319
|
-
const vaultReserves = this.getVaultReserves(vaultState);
|
|
1320
|
-
const vaultReservesState = await this.loadVaultReserves(vaultState);
|
|
1321
|
-
withdrawPendingFeesIxn = this.appendRemainingAccountsForVaultReserves(withdrawPendingFeesIxn, vaultReserves, vaultReservesState);
|
|
1322
|
-
return withdrawPendingFeesIxn;
|
|
1323
|
-
}
|
|
1324
|
-
/**
|
|
1325
|
-
* Sync a vault for lookup table; create and set the LUT for the vault if needed and fill it with all the needed accounts
|
|
1326
|
-
* @param authority - vault admin
|
|
1327
|
-
* @param vault the vault to sync and set the LUT for if needed
|
|
1328
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1329
|
-
* @returns a struct that contains a list of ix to create the LUT and assign it to the vault if needed + a list of ixs to insert all the accounts in the LUT
|
|
1330
|
-
*/
|
|
1331
|
-
async syncVaultLookupTableIxs(authority, vault, vaultReservesMap) {
|
|
1332
|
-
const vaultState = await vault.getState();
|
|
1333
|
-
const allAccountsToBeInserted = [
|
|
1334
|
-
vault.address,
|
|
1335
|
-
vaultState.vaultAdminAuthority,
|
|
1336
|
-
vaultState.baseVaultAuthority,
|
|
1337
|
-
vaultState.tokenMint,
|
|
1338
|
-
vaultState.tokenVault,
|
|
1339
|
-
vaultState.sharesMint,
|
|
1340
|
-
vaultState.tokenProgram,
|
|
1341
|
-
this._kaminoLendProgramId,
|
|
1342
|
-
];
|
|
1343
|
-
vaultState.vaultAllocationStrategy.forEach((allocation) => {
|
|
1344
|
-
allAccountsToBeInserted.push(allocation.reserve);
|
|
1345
|
-
allAccountsToBeInserted.push(allocation.ctokenVault);
|
|
1346
|
-
});
|
|
1347
|
-
if (vaultReservesMap) {
|
|
1348
|
-
vaultReservesMap.forEach((reserve) => {
|
|
1349
|
-
allAccountsToBeInserted.push(reserve.state.lendingMarket);
|
|
1350
|
-
allAccountsToBeInserted.push(reserve.state.farmCollateral);
|
|
1351
|
-
allAccountsToBeInserted.push(reserve.state.farmDebt);
|
|
1352
|
-
allAccountsToBeInserted.push(reserve.state.liquidity.supplyVault);
|
|
1353
|
-
allAccountsToBeInserted.push(reserve.state.liquidity.feeVault);
|
|
1354
|
-
allAccountsToBeInserted.push(reserve.state.collateral.mintPubkey);
|
|
1355
|
-
allAccountsToBeInserted.push(reserve.state.collateral.supplyVault);
|
|
1356
|
-
});
|
|
1357
|
-
}
|
|
1358
|
-
else {
|
|
1359
|
-
const vaultReservesState = await this.loadVaultReserves(vaultState);
|
|
1360
|
-
vaultReservesState.forEach((reserve) => {
|
|
1361
|
-
allAccountsToBeInserted.push(reserve.state.lendingMarket);
|
|
1362
|
-
allAccountsToBeInserted.push(reserve.state.farmCollateral);
|
|
1363
|
-
allAccountsToBeInserted.push(reserve.state.farmDebt);
|
|
1364
|
-
allAccountsToBeInserted.push(reserve.state.liquidity.supplyVault);
|
|
1365
|
-
allAccountsToBeInserted.push(reserve.state.liquidity.feeVault);
|
|
1366
|
-
allAccountsToBeInserted.push(reserve.state.collateral.mintPubkey);
|
|
1367
|
-
allAccountsToBeInserted.push(reserve.state.collateral.supplyVault);
|
|
1368
|
-
});
|
|
1369
|
-
}
|
|
1370
|
-
if (vaultState.vaultFarm !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1371
|
-
allAccountsToBeInserted.push(vaultState.vaultFarm);
|
|
1372
|
-
}
|
|
1373
|
-
const setupLUTIfNeededIxs = [];
|
|
1374
|
-
let lut = vaultState.vaultLookupTable;
|
|
1375
|
-
if (lut === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1376
|
-
const recentSlot = await this.getConnection().getSlot({ commitment: 'confirmed' }).send();
|
|
1377
|
-
const [ix, address] = await (0, lookupTable_1.initLookupTableIx)(authority, recentSlot);
|
|
1378
|
-
setupLUTIfNeededIxs.push(ix);
|
|
1379
|
-
lut = address;
|
|
1380
|
-
// set the new LUT for the vault
|
|
1381
|
-
const updateVaultConfigIxs = await this.updateVaultConfigIxs(vault, new types_1.VaultConfigField.LookupTable(), lut.toString());
|
|
1382
|
-
setupLUTIfNeededIxs.push(updateVaultConfigIxs.updateVaultConfigIx);
|
|
1383
|
-
}
|
|
1384
|
-
const ixs = [];
|
|
1385
|
-
let overriddenExistentAccounts = undefined;
|
|
1386
|
-
if (vaultState.vaultLookupTable === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1387
|
-
overriddenExistentAccounts = [];
|
|
1388
|
-
}
|
|
1389
|
-
ixs.push(...(await (0, lookupTable_1.insertIntoLookupTableIxs)(this.getConnection(), authority, lut, allAccountsToBeInserted, overriddenExistentAccounts)));
|
|
1390
|
-
return {
|
|
1391
|
-
setupLUTIfNeededIxs,
|
|
1392
|
-
syncLUTIxs: ixs,
|
|
1393
|
-
};
|
|
1394
|
-
}
|
|
1395
|
-
getReserveAccountsToInsertInLut(reserveState) {
|
|
1396
|
-
return [
|
|
1397
|
-
reserveState.lendingMarket,
|
|
1398
|
-
reserveState.farmCollateral,
|
|
1399
|
-
reserveState.farmDebt,
|
|
1400
|
-
reserveState.liquidity.mintPubkey,
|
|
1401
|
-
reserveState.liquidity.supplyVault,
|
|
1402
|
-
reserveState.liquidity.feeVault,
|
|
1403
|
-
reserveState.collateral.mintPubkey,
|
|
1404
|
-
reserveState.collateral.supplyVault,
|
|
1405
|
-
];
|
|
1406
|
-
}
|
|
1407
|
-
/** Read the total holdings of a vault and the reserve weights and returns a map from each reserve to how many tokens should be deposited.
|
|
1408
|
-
* @param vaultState - the vault state to calculate the allocation for
|
|
1409
|
-
* @param [slot] - the slot for which to calculate the allocation. Optional. If not provided the function will fetch the current slot
|
|
1410
|
-
* @param [vaultReserves] - a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1411
|
-
* @param [currentSlot] - the latest confirmed slot. Optional. If provided the function will be faster as it will not have to fetch the latest slot
|
|
1412
|
-
* @returns - a map from each reserve to how many tokens should be invested into
|
|
1413
|
-
*/
|
|
1414
|
-
async getVaultComputedReservesAllocation(vaultState, slot, vaultReserves, currentSlot) {
|
|
1415
|
-
// 1. Read the states
|
|
1416
|
-
const holdings = await this.getVaultHoldings(vaultState, slot, vaultReserves, currentSlot);
|
|
1417
|
-
// if there are no vault reserves or all have weight 0 everything has to be in Available
|
|
1418
|
-
const allReservesPubkeys = this.getVaultReserves(vaultState);
|
|
1419
|
-
const reservesAllocations = this.getVaultAllocations(vaultState);
|
|
1420
|
-
const allReservesHaveWeight0 = allReservesPubkeys.every((reserve) => {
|
|
1421
|
-
const allocation = reservesAllocations.get(reserve);
|
|
1422
|
-
return allocation?.targetWeight.isZero();
|
|
1423
|
-
});
|
|
1424
|
-
if (allReservesPubkeys.length === 0 || allReservesHaveWeight0) {
|
|
1425
|
-
const computedHoldings = new Map();
|
|
1426
|
-
allReservesPubkeys.forEach((reserve) => {
|
|
1427
|
-
computedHoldings.set(reserve, new decimal_js_1.default(0));
|
|
1428
|
-
});
|
|
1429
|
-
return {
|
|
1430
|
-
targetUnallocatedAmount: holdings.totalAUMIncludingFees.sub(holdings.pendingFees),
|
|
1431
|
-
targetReservesAllocation: computedHoldings,
|
|
1432
|
-
};
|
|
1433
|
-
}
|
|
1434
|
-
const initialVaultAllocations = this.getVaultAllocations(vaultState);
|
|
1435
|
-
// 2. Compute the allocation
|
|
1436
|
-
return this.computeReservesAllocation(holdings.totalAUMIncludingFees.sub(holdings.pendingFees), new decimal_js_1.default(vaultState.unallocatedWeight.toString()), new decimal_js_1.default(vaultState.unallocatedTokensCap.toString()), initialVaultAllocations, vaultState.tokenMintDecimals.toNumber());
|
|
1437
|
-
}
|
|
1438
|
-
computeReservesAllocation(vaultAUM, vaultUnallocatedWeight, vaultUnallocatedCap, initialVaultAllocations, vaultTokenDecimals) {
|
|
1439
|
-
return (0, vaultAllocation_1.computeReservesAllocation)(vaultAUM, vaultUnallocatedWeight, vaultUnallocatedCap, initialVaultAllocations, vaultTokenDecimals);
|
|
1440
|
-
}
|
|
1441
|
-
/**
|
|
1442
|
-
* This method returns the user shares balance for a given vault
|
|
1443
|
-
* @param user - user to calculate the shares balance for
|
|
1444
|
-
* @param vault - vault to calculate shares balance for
|
|
1445
|
-
* @returns - user share balance in tokens (not lamports)
|
|
1446
|
-
*/
|
|
1447
|
-
async getUserSharesBalanceSingleVault(user, vault) {
|
|
1448
|
-
const vaultState = await vault.getState();
|
|
1449
|
-
const userShares = {
|
|
1450
|
-
unstakedShares: new decimal_js_1.default(0),
|
|
1451
|
-
stakedShares: new decimal_js_1.default(0),
|
|
1452
|
-
totalShares: new decimal_js_1.default(0),
|
|
1453
|
-
};
|
|
1454
|
-
const userSharesTokenAccounts = await (0, utils_2.getAllStandardTokenProgramTokenAccounts)(this.getConnection(), user);
|
|
1455
|
-
const userSharesTokenAccount = userSharesTokenAccounts.filter((tokenAccount) => {
|
|
1456
|
-
const accountData = tokenAccount.account.data;
|
|
1457
|
-
const mint = (0, utils_2.getTokenAccountMint)(accountData);
|
|
1458
|
-
return mint === vaultState.sharesMint;
|
|
1459
|
-
});
|
|
1460
|
-
userShares.unstakedShares = userSharesTokenAccount.reduce((acc, tokenAccount) => {
|
|
1461
|
-
const accountData = tokenAccount.account.data;
|
|
1462
|
-
const amount = (0, utils_2.getTokenAccountAmount)(accountData);
|
|
1463
|
-
if (amount !== null) {
|
|
1464
|
-
return acc.add(new decimal_js_1.default(amount));
|
|
1465
|
-
}
|
|
1466
|
-
return acc;
|
|
1467
|
-
}, new decimal_js_1.default(0));
|
|
1468
|
-
if (await vault.hasFarm()) {
|
|
1469
|
-
const userSharesInFarm = await (0, farm_utils_1.getUserSharesInTokensStakedInFarm)(this.getConnection(), user, vaultState.vaultFarm, vaultState.sharesMintDecimals.toNumber());
|
|
1470
|
-
userShares.stakedShares = userSharesInFarm;
|
|
1471
|
-
}
|
|
1472
|
-
userShares.totalShares = userShares.unstakedShares.add(userShares.stakedShares);
|
|
1473
|
-
return userShares;
|
|
1474
|
-
}
|
|
1475
|
-
/**
|
|
1476
|
-
* This method returns the user shares balance for all existing vaults
|
|
1477
|
-
* @param user - user to calculate the shares balance for
|
|
1478
|
-
* @param [vaultsOverride] - the kamino vaults if already fetched, in order to reduce rpc calls.Optional
|
|
1479
|
-
* @returns - hash map with keys as vault address and value as user share balance in decimal (not lamports)
|
|
1480
|
-
*/
|
|
1481
|
-
async getUserSharesBalanceAllVaults(user, vaultsOverride) {
|
|
1482
|
-
const vaults = vaultsOverride ? vaultsOverride : await this.getAllVaults();
|
|
1483
|
-
// read all user shares stake in vault farms
|
|
1484
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
1485
|
-
const allUserFarmStates = await farmClient.getAllUserStatesForUser(user);
|
|
1486
|
-
const allUserFarmStatesMap = new Map();
|
|
1487
|
-
allUserFarmStates.forEach((userFarmState) => {
|
|
1488
|
-
allUserFarmStatesMap.set(userFarmState.userState.farmState, userFarmState.userState);
|
|
1489
|
-
});
|
|
1490
|
-
// stores vault address for each userSharesAta
|
|
1491
|
-
const vaultUserShareBalance = new Map();
|
|
1492
|
-
const allUserTokenAccounts = await (0, utils_2.getAllStandardTokenProgramTokenAccounts)(this.getConnection(), user);
|
|
1493
|
-
const userSharesTokenAccountsPerVault = new Map();
|
|
1494
|
-
vaults.forEach(async (vault) => {
|
|
1495
|
-
const state = vault.state;
|
|
1496
|
-
if (!state) {
|
|
1497
|
-
throw new Error(`Vault ${vault.address} not fetched`);
|
|
1498
|
-
}
|
|
1499
|
-
const userSharesTokenAccounts = allUserTokenAccounts.filter((tokenAccount) => {
|
|
1500
|
-
const accountData = tokenAccount.account.data;
|
|
1501
|
-
const mint = (0, utils_2.getTokenAccountMint)(accountData);
|
|
1502
|
-
return mint === state.sharesMint;
|
|
1503
|
-
});
|
|
1504
|
-
userSharesTokenAccountsPerVault.set(vault.address, userSharesTokenAccounts);
|
|
1505
|
-
if (await vault.hasFarm()) {
|
|
1506
|
-
const userFarmState = allUserFarmStatesMap.get(state.vaultFarm);
|
|
1507
|
-
if (userFarmState) {
|
|
1508
|
-
const stakedShares = (0, farm_utils_1.getSharesInFarmUserPosition)(userFarmState, state.sharesMintDecimals.toNumber());
|
|
1509
|
-
const userSharesBalance = vaultUserShareBalance.get(vault.address);
|
|
1510
|
-
if (userSharesBalance) {
|
|
1511
|
-
userSharesBalance.stakedShares = stakedShares;
|
|
1512
|
-
userSharesBalance.totalShares = userSharesBalance.unstakedShares.add(userSharesBalance.stakedShares);
|
|
1513
|
-
vaultUserShareBalance.set(vault.address, userSharesBalance);
|
|
1514
|
-
}
|
|
1515
|
-
else {
|
|
1516
|
-
vaultUserShareBalance.set(vault.address, {
|
|
1517
|
-
unstakedShares: new decimal_js_1.default(0),
|
|
1518
|
-
stakedShares,
|
|
1519
|
-
totalShares: stakedShares,
|
|
1520
|
-
});
|
|
1521
|
-
}
|
|
1522
|
-
}
|
|
1523
|
-
}
|
|
1524
|
-
});
|
|
1525
|
-
userSharesTokenAccountsPerVault.forEach((userSharesTokenAccounts, vaultAddress) => {
|
|
1526
|
-
userSharesTokenAccounts.forEach((userSharesTokenAccount) => {
|
|
1527
|
-
let userSharesForVault = vaultUserShareBalance.get(vaultAddress);
|
|
1528
|
-
if (!userSharesForVault) {
|
|
1529
|
-
userSharesForVault = {
|
|
1530
|
-
unstakedShares: new decimal_js_1.default(0),
|
|
1531
|
-
stakedShares: new decimal_js_1.default(0),
|
|
1532
|
-
totalShares: new decimal_js_1.default(0),
|
|
1533
|
-
};
|
|
1534
|
-
}
|
|
1535
|
-
if (!userSharesTokenAccount) {
|
|
1536
|
-
vaultUserShareBalance.set(vaultAddress, userSharesForVault);
|
|
1537
|
-
}
|
|
1538
|
-
else {
|
|
1539
|
-
const accountData = userSharesTokenAccount.account.data;
|
|
1540
|
-
const amount = (0, utils_2.getTokenAccountAmount)(accountData);
|
|
1541
|
-
if (amount !== null) {
|
|
1542
|
-
userSharesForVault.unstakedShares = new decimal_js_1.default(amount);
|
|
1543
|
-
userSharesForVault.totalShares = userSharesForVault.unstakedShares.add(userSharesForVault.stakedShares);
|
|
1544
|
-
vaultUserShareBalance.set(vaultAddress, userSharesForVault);
|
|
1545
|
-
}
|
|
1546
|
-
}
|
|
1547
|
-
});
|
|
1548
|
-
});
|
|
1549
|
-
return vaultUserShareBalance;
|
|
1550
|
-
}
|
|
1551
|
-
/**
|
|
1552
|
-
* This method returns the management and performance fee percentages
|
|
1553
|
-
* @param vaultState - vault to retrieve the fees percentages from
|
|
1554
|
-
* @returns - VaultFeesPct containing management and performance fee percentages
|
|
1555
|
-
*/
|
|
1556
|
-
getVaultFeesPct(vaultState) {
|
|
1557
|
-
return {
|
|
1558
|
-
managementFeePct: (0, utils_1.bpsToPct)(new decimal_js_1.default(vaultState.managementFeeBps.toString())),
|
|
1559
|
-
performanceFeePct: (0, utils_1.bpsToPct)(new decimal_js_1.default(vaultState.performanceFeeBps.toString())),
|
|
1560
|
-
};
|
|
1561
|
-
}
|
|
1562
|
-
/**
|
|
1563
|
-
* This method calculates the token per share value. This will always change based on interest earned from the vault, but calculating it requires a bunch of rpc requests. Caching this for a short duration would be optimal
|
|
1564
|
-
* @param vaultState - vault state to calculate tokensPerShare for
|
|
1565
|
-
* @param [slot] - the slot at which we retrieve the tokens per share. Optional. If not provided, the function will fetch the current slot
|
|
1566
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1567
|
-
* @param [currentSlot] - the latest confirmed slot. Optional. If provided the function will be faster as it will not have to fetch the latest slot
|
|
1568
|
-
* @returns - token per share value
|
|
1569
|
-
*/
|
|
1570
|
-
async getTokensPerShareSingleVault(vaultOrState, slot, vaultReservesMap, currentSlot) {
|
|
1571
|
-
// Determine if we have a KaminoVault or VaultState
|
|
1572
|
-
const vaultState = 'getState' in vaultOrState ? await vaultOrState.getState() : vaultOrState;
|
|
1573
|
-
if (vaultState.sharesIssued.isZero()) {
|
|
1574
|
-
return new decimal_js_1.default(0);
|
|
1575
|
-
}
|
|
1576
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
1577
|
-
const sharesDecimal = (0, lib_1.lamportsToDecimal)(vaultState.sharesIssued.toString(), vaultState.sharesMintDecimals.toString());
|
|
1578
|
-
const holdings = await this.getVaultHoldings(vaultState, slot, vaultReservesState, currentSlot);
|
|
1579
|
-
const netAUM = holdings.totalAUMIncludingFees.sub(holdings.pendingFees);
|
|
1580
|
-
return netAUM.div(sharesDecimal);
|
|
1581
|
-
}
|
|
1582
|
-
/**
|
|
1583
|
-
* This method calculates the token per share value. This will always change based on interest earned from the vault, but calculating it requires a bunch of rpc requests. Caching this for a short duration would be optimal
|
|
1584
|
-
* @param [vaultsOverride] - a list of vaults to get the tokens per share for; if provided with state it will not fetch the state again. Optional
|
|
1585
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1586
|
-
* @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault
|
|
1587
|
-
* @returns - token per share value
|
|
1588
|
-
*/
|
|
1589
|
-
async getTokensPerShareAllVaults(slot, vaultsOverride, vaultReservesMap) {
|
|
1590
|
-
const vaults = vaultsOverride ? vaultsOverride : await this.getAllVaults();
|
|
1591
|
-
const vaultTokensPerShare = new Map();
|
|
1592
|
-
for (const vault of vaults) {
|
|
1593
|
-
const tokensPerShare = await this.getTokensPerShareSingleVault(vault, slot, vaultReservesMap);
|
|
1594
|
-
vaultTokensPerShare.set(vault.address, tokensPerShare);
|
|
1595
|
-
}
|
|
1596
|
-
return vaultTokensPerShare;
|
|
1597
|
-
}
|
|
1598
|
-
/**
|
|
1599
|
-
* Get all vaults
|
|
1600
|
-
* @returns an array of all vaults
|
|
1601
|
-
*/
|
|
1602
|
-
async getAllVaults() {
|
|
1603
|
-
const filters = [
|
|
1604
|
-
{
|
|
1605
|
-
dataSize: BigInt(accounts_1.VaultState.layout.span + 8),
|
|
1606
|
-
},
|
|
1607
|
-
{
|
|
1608
|
-
memcmp: {
|
|
1609
|
-
offset: 0n,
|
|
1610
|
-
bytes: base58Decoder.decode(accounts_1.VaultState.discriminator),
|
|
1611
|
-
encoding: 'base58',
|
|
1612
|
-
},
|
|
1613
|
-
},
|
|
1614
|
-
];
|
|
1615
|
-
return await this.getAllVaultsWithFilter(filters);
|
|
1616
|
-
}
|
|
1617
|
-
/**
|
|
1618
|
-
* Get all vaults for a given token
|
|
1619
|
-
* @param token - the token to get all vaults for
|
|
1620
|
-
* @returns an array of all vaults for the given token
|
|
1621
|
-
*/
|
|
1622
|
-
async getAllVaultsForToken(token) {
|
|
1623
|
-
const filters = [
|
|
1624
|
-
{
|
|
1625
|
-
dataSize: BigInt(accounts_1.VaultState.layout.span + 8),
|
|
1626
|
-
},
|
|
1627
|
-
{
|
|
1628
|
-
memcmp: {
|
|
1629
|
-
offset: 0n,
|
|
1630
|
-
bytes: base58Decoder.decode(accounts_1.VaultState.discriminator),
|
|
1631
|
-
encoding: 'base58',
|
|
1632
|
-
},
|
|
1633
|
-
},
|
|
1634
|
-
{
|
|
1635
|
-
memcmp: {
|
|
1636
|
-
offset: 80n, // tokenMint offset: 8 + 32 + 32 + 8 (discriminator + vaultAdminAuthority + baseVaultAuthority + baseVaultAuthorityBump)
|
|
1637
|
-
bytes: token.toString(),
|
|
1638
|
-
encoding: 'base58',
|
|
1639
|
-
},
|
|
1640
|
-
},
|
|
1641
|
-
];
|
|
1642
|
-
return await this.getAllVaultsWithFilter(filters);
|
|
1643
|
-
}
|
|
1644
|
-
async getAllVaultsWithFilter(filters) {
|
|
1645
|
-
const kaminoVaults = await (0, rpc_1.getProgramAccounts)(this.getConnection(), this._kaminoVaultProgramId, accounts_1.VaultState.layout.span + 8, filters);
|
|
1646
|
-
return kaminoVaults.map((kaminoVault) => {
|
|
1647
|
-
const kaminoVaultAccount = (0, vault_1.decodeVaultState)(kaminoVault.data);
|
|
1648
|
-
if (!kaminoVaultAccount) {
|
|
1649
|
-
throw Error(`kaminoVault with pubkey ${kaminoVault.address} could not be decoded`);
|
|
1650
|
-
}
|
|
1651
|
-
return KaminoVault.loadWithClientAndState(this, kaminoVault.address, kaminoVaultAccount);
|
|
1652
|
-
});
|
|
1653
|
-
}
|
|
1654
|
-
/**
|
|
1655
|
-
* Get a list of kaminoVaults
|
|
1656
|
-
* @param vaults - a list of vaults to get the states for; if not provided, all vaults will be fetched
|
|
1657
|
-
* @returns a list of vaults
|
|
1658
|
-
*/
|
|
1659
|
-
async getVaults(vaults) {
|
|
1660
|
-
if (!vaults) {
|
|
1661
|
-
vaults = (await this.getAllVaults()).map((x) => x.address);
|
|
1662
|
-
}
|
|
1663
|
-
const vaultStates = await (0, kliquidity_sdk_1.batchFetch)(vaults, (chunk) => this.getVaultsStates(chunk));
|
|
1664
|
-
return vaults.map((vault, index) => {
|
|
1665
|
-
const state = vaultStates[index];
|
|
1666
|
-
return state ? KaminoVault.loadWithClientAndState(this, vault, state) : null;
|
|
1667
|
-
});
|
|
1668
|
-
}
|
|
1669
|
-
async getVaultsStates(vaults) {
|
|
1670
|
-
return await accounts_1.VaultState.fetchMultiple(this.getConnection(), vaults, this._kaminoVaultProgramId);
|
|
1671
|
-
}
|
|
1672
|
-
/**
|
|
1673
|
-
* This will return the amount of token invested from the vault into the given reserve
|
|
1674
|
-
* @param vaultState - the kamino vault to get invested amount in reserve for
|
|
1675
|
-
* @param slot - current slot
|
|
1676
|
-
* @param reserve - the reserve state to get vault invested amount in
|
|
1677
|
-
* @returns vault amount supplied in reserve in decimal
|
|
1678
|
-
*/
|
|
1679
|
-
getSuppliedInReserve(vaultState, slot, reserve) {
|
|
1680
|
-
let referralFeeBps = 0;
|
|
1681
|
-
const denominator = reserve.state.config.protocolTakeRatePct / 100;
|
|
1682
|
-
if (denominator > 0) {
|
|
1683
|
-
referralFeeBps = new fraction_1.Fraction(reserve.state.liquidity.absoluteReferralRateSf)
|
|
1684
|
-
.toDecimal()
|
|
1685
|
-
.div(denominator)
|
|
1686
|
-
.floor()
|
|
1687
|
-
.toNumber();
|
|
1688
|
-
}
|
|
1689
|
-
const reserveCollExchangeRate = reserve.getEstimatedCollateralExchangeRate(slot, referralFeeBps);
|
|
1690
|
-
const reserveAllocation = vaultState.vaultAllocationStrategy.find((allocation) => allocation.reserve === reserve.address);
|
|
1691
|
-
if (!reserveAllocation) {
|
|
1692
|
-
throw new Error(`Reserve ${reserve.address} not found in vault allocation strategy`);
|
|
1693
|
-
}
|
|
1694
|
-
const reserveAllocationLiquidityAmountLamports = new decimal_js_1.default(reserveAllocation.ctokenAllocation.toString()).div(reserveCollExchangeRate);
|
|
1695
|
-
const reserveAllocationLiquidityAmount = (0, lib_1.lamportsToDecimal)(reserveAllocationLiquidityAmountLamports, vaultState.tokenMintDecimals.toNumber());
|
|
1696
|
-
return reserveAllocationLiquidityAmount;
|
|
1697
|
-
}
|
|
1698
|
-
/**
|
|
1699
|
-
* This will return the a map between reserve pubkey and the pct of the vault invested amount in each reserve
|
|
1700
|
-
* @param vaultState - the kamino vault to get reserves distribution for
|
|
1701
|
-
* @returns a map between reserve pubkey and the allocation pct for the reserve
|
|
1702
|
-
*/
|
|
1703
|
-
getAllocationsDistribuionPct(vaultState) {
|
|
1704
|
-
const allocationsDistributionPct = new Map();
|
|
1705
|
-
let totalAllocation = new decimal_js_1.default(0);
|
|
1706
|
-
const filteredAllocations = vaultState.vaultAllocationStrategy.filter((allocation) => allocation.reserve !== lib_1.DEFAULT_PUBLIC_KEY);
|
|
1707
|
-
filteredAllocations.forEach((allocation) => {
|
|
1708
|
-
totalAllocation = totalAllocation.add(new decimal_js_1.default(allocation.targetAllocationWeight.toString()));
|
|
1709
|
-
});
|
|
1710
|
-
filteredAllocations.forEach((allocation) => {
|
|
1711
|
-
allocationsDistributionPct.set(allocation.reserve, new decimal_js_1.default(allocation.targetAllocationWeight.toString()).mul(new decimal_js_1.default(100)).div(totalAllocation));
|
|
1712
|
-
});
|
|
1713
|
-
return allocationsDistributionPct;
|
|
1714
|
-
}
|
|
1715
|
-
/**
|
|
1716
|
-
* This will return the a map between reserve pubkey and the allocation overview for the reserve
|
|
1717
|
-
* @param vaultState - the kamino vault to get reserves allocation overview for
|
|
1718
|
-
* @returns a map between reserve pubkey and the allocation overview for the reserve
|
|
1719
|
-
*/
|
|
1720
|
-
getVaultAllocations(vaultState) {
|
|
1721
|
-
const vaultAllocations = new Map();
|
|
1722
|
-
vaultState.vaultAllocationStrategy.map((allocation) => {
|
|
1723
|
-
if (allocation.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1724
|
-
return;
|
|
1725
|
-
}
|
|
1726
|
-
const allocationOverview = {
|
|
1727
|
-
targetWeight: new decimal_js_1.default(allocation.targetAllocationWeight.toString()),
|
|
1728
|
-
tokenAllocationCap: new decimal_js_1.default(allocation.tokenAllocationCap.toString()),
|
|
1729
|
-
ctokenAllocation: new decimal_js_1.default(allocation.ctokenAllocation.toString()),
|
|
1730
|
-
};
|
|
1731
|
-
vaultAllocations.set(allocation.reserve, allocationOverview);
|
|
1732
|
-
});
|
|
1733
|
-
return vaultAllocations;
|
|
1734
|
-
}
|
|
1735
|
-
/**
|
|
1736
|
-
* This will return an unsorted hash map of all reserves that the given vault has allocations for, toghether with the amount that can be withdrawn from each of the reserves
|
|
1737
|
-
* @param vault - the kamino vault to get available liquidity to withdraw for
|
|
1738
|
-
* @param slot - current slot
|
|
1739
|
-
*@param [vaultReservesMap] - a hashmap from each reserve pubkey to the reserve state
|
|
1740
|
-
* @returns an HashMap of reserves (key) with the amount available to withdraw for each (value)
|
|
1741
|
-
*/
|
|
1742
|
-
async getReserveAllocationAvailableLiquidityToWithdraw(vault, slot, vaultReservesMap) {
|
|
1743
|
-
const vaultState = await vault.getState();
|
|
1744
|
-
const reserveAllocationAvailableLiquidityToWithdraw = new Map();
|
|
1745
|
-
vaultState.vaultAllocationStrategy.forEach((allocationStrategy) => {
|
|
1746
|
-
if (allocationStrategy.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1747
|
-
return;
|
|
1748
|
-
}
|
|
1749
|
-
const reserve = vaultReservesMap.get(allocationStrategy.reserve);
|
|
1750
|
-
if (reserve === undefined) {
|
|
1751
|
-
throw new Error(`Reserve ${allocationStrategy.reserve} not found`);
|
|
1752
|
-
}
|
|
1753
|
-
let referralFeeBps = 0;
|
|
1754
|
-
const denominator = reserve.state.config.protocolTakeRatePct / 100;
|
|
1755
|
-
if (denominator > 0) {
|
|
1756
|
-
referralFeeBps = new fraction_1.Fraction(reserve.state.liquidity.absoluteReferralRateSf)
|
|
1757
|
-
.toDecimal()
|
|
1758
|
-
.div(denominator)
|
|
1759
|
-
.floor()
|
|
1760
|
-
.toNumber();
|
|
1761
|
-
}
|
|
1762
|
-
const reserveCollExchangeRate = reserve.getEstimatedCollateralExchangeRate(slot, referralFeeBps);
|
|
1763
|
-
const reserveAllocationLiquidityAmount = new decimal_js_1.default(allocationStrategy.ctokenAllocation.toString()).div(reserveCollExchangeRate);
|
|
1764
|
-
const reserveAvailableLiquidityAmount = reserve.getLiquidityAvailableAmount();
|
|
1765
|
-
reserveAllocationAvailableLiquidityToWithdraw.set(allocationStrategy.reserve, decimal_js_1.default.min(reserveAllocationLiquidityAmount, reserveAvailableLiquidityAmount));
|
|
1766
|
-
});
|
|
1767
|
-
return reserveAllocationAvailableLiquidityToWithdraw;
|
|
1768
|
-
}
|
|
1769
|
-
/**
|
|
1770
|
-
* This will get the list of all reserve pubkeys that the vault has allocations for ex
|
|
1771
|
-
* @param vault - the vault state to load reserves for
|
|
1772
|
-
* @returns a hashmap from each reserve pubkey to the reserve state
|
|
1773
|
-
*/
|
|
1774
|
-
getVaultReserves(vault) {
|
|
1775
|
-
return vault.vaultAllocationStrategy
|
|
1776
|
-
.filter((vaultAllocation) => vaultAllocation.reserve !== lib_1.DEFAULT_PUBLIC_KEY)
|
|
1777
|
-
.map((vaultAllocation) => vaultAllocation.reserve);
|
|
1778
|
-
}
|
|
1779
|
-
/**
|
|
1780
|
-
* This will load the onchain state for all the reserves that the vault has allocations for
|
|
1781
|
-
* @param vaultState - the vault state to load reserves for
|
|
1782
|
-
* @returns a hashmap from each reserve pubkey to the reserve state
|
|
1783
|
-
*/
|
|
1784
|
-
async loadVaultReserves(vaultState) {
|
|
1785
|
-
return this.loadVaultsReserves([vaultState]);
|
|
1786
|
-
}
|
|
1787
|
-
async loadReserializedReserves(vaultReservesAddresses) {
|
|
1788
|
-
const reserveAccounts = await this.getConnection()
|
|
1789
|
-
.getMultipleAccounts(vaultReservesAddresses, { commitment: 'processed' })
|
|
1790
|
-
.send();
|
|
1791
|
-
return reserveAccounts.value.map((reserve, i) => {
|
|
1792
|
-
if (reserve === null) {
|
|
1793
|
-
// maybe reuse old here
|
|
1794
|
-
throw new Error(`Reserve account ${vaultReservesAddresses[i]} was not found`);
|
|
1795
|
-
}
|
|
1796
|
-
const reserveAccount = lib_1.Reserve.decode(Buffer.from(reserve.data[0], 'base64'));
|
|
1797
|
-
if (!reserveAccount) {
|
|
1798
|
-
throw Error(`Could not parse reserve ${vaultReservesAddresses[i]}`);
|
|
1799
|
-
}
|
|
1800
|
-
return {
|
|
1801
|
-
address: vaultReservesAddresses[i],
|
|
1802
|
-
state: reserveAccount,
|
|
1803
|
-
};
|
|
1804
|
-
});
|
|
1805
|
-
}
|
|
1806
|
-
/**
|
|
1807
|
-
* This will load the onchain state for all the reserves that the vaults have allocations for, deduplicating the reserves
|
|
1808
|
-
* @param vaults - the vault states to load reserves for
|
|
1809
|
-
* @param oracleAccounts (optional) all reserve oracle accounts, if not supplied will make an additional rpc call to fetch these accounts
|
|
1810
|
-
* @returns a hashmap from each reserve pubkey to the reserve state
|
|
1811
|
-
*/
|
|
1812
|
-
async loadVaultsReserves(vaults, oracleAccounts) {
|
|
1813
|
-
const vaultReservesAddressesSet = new Set(vaults.flatMap((vault) => this.getVaultReserves(vault)));
|
|
1814
|
-
const vaultReservesAddresses = [...vaultReservesAddressesSet];
|
|
1815
|
-
const deserializedReserves = await (0, kliquidity_sdk_1.batchFetch)(vaultReservesAddresses, (chunk) => this.loadReserializedReserves(chunk));
|
|
1816
|
-
const [reservesAndOracles, cdnResourcesData] = await Promise.all([
|
|
1817
|
-
(0, lib_1.getTokenOracleData)(this.getConnection(), deserializedReserves, oracleAccounts),
|
|
1818
|
-
(0, readCdnData_1.fetchKaminoCdnData)(),
|
|
1819
|
-
]);
|
|
1820
|
-
const kaminoReserves = new Map();
|
|
1821
|
-
reservesAndOracles.forEach(([reserve, oracle], index) => {
|
|
1822
|
-
if (!oracle) {
|
|
1823
|
-
throw Error(`Could not find oracle for ${(0, utils_1.parseTokenSymbol)(reserve.config.tokenInfo.name)} (${vaultReservesAddresses[index]}) reserve in market ${reserve.lendingMarket}`);
|
|
1824
|
-
}
|
|
1825
|
-
const kaminoReserve = lib_1.KaminoReserve.initialize(vaultReservesAddresses[index], reserve, oracle, this.getConnection(), this.recentSlotDurationMs, cdnResourcesData);
|
|
1826
|
-
kaminoReserves.set(kaminoReserve.address, kaminoReserve);
|
|
1827
|
-
});
|
|
1828
|
-
return kaminoReserves;
|
|
1829
|
-
}
|
|
1830
|
-
/**
|
|
1831
|
-
* This will retrieve all the tokens that can be used as collateral by the users who borrow the token in the vault alongside details about the min and max loan to value ratio
|
|
1832
|
-
* @param vaultState - the vault state to load reserves for
|
|
1833
|
-
* @param [slot] - the slot for which to retrieve the vault collaterals for. Optional. If not provided the function will fetch the current slot
|
|
1834
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1835
|
-
* @param [kaminoMarkets] - a list of all the kamino markets. Optional. If provided the function will be significantly faster as it will not have to fetch the markets
|
|
1836
|
-
* @param oracleAccounts (optional) all reserve oracle accounts, if not supplied will make an additional rpc call to fetch these accounts
|
|
1837
|
-
* @returns a hashmap from each reserve pubkey to the market overview of the collaterals that can be used and the min and max loan to value ratio in that market
|
|
1838
|
-
*/
|
|
1839
|
-
async getVaultCollaterals(vaultState, slot, vaultReservesMap, kaminoMarkets, oracleAccounts) {
|
|
1840
|
-
const vaultReservesStateMap = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
1841
|
-
const vaultReservesState = [];
|
|
1842
|
-
const missingReserves = new Set([]);
|
|
1843
|
-
// filter the reserves that are not part of the vault allocation strategy
|
|
1844
|
-
vaultState.vaultAllocationStrategy.forEach(async (allocation) => {
|
|
1845
|
-
if (allocation.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1846
|
-
return;
|
|
1847
|
-
}
|
|
1848
|
-
const reserve = vaultReservesStateMap.get(allocation.reserve);
|
|
1849
|
-
if (!reserve) {
|
|
1850
|
-
missingReserves.add(allocation.reserve);
|
|
1851
|
-
return;
|
|
1852
|
-
}
|
|
1853
|
-
vaultReservesState.push(reserve);
|
|
1854
|
-
});
|
|
1855
|
-
// read missing reserves
|
|
1856
|
-
const missingReserveAddresses = [...missingReserves];
|
|
1857
|
-
const missingReservesStates = (await lib_1.Reserve.fetchMultiple(this.getConnection(), missingReserveAddresses))
|
|
1858
|
-
.map((reserve, index) => {
|
|
1859
|
-
if (!reserve) {
|
|
1860
|
-
return null;
|
|
1861
|
-
}
|
|
1862
|
-
return {
|
|
1863
|
-
address: missingReserveAddresses[index],
|
|
1864
|
-
state: reserve,
|
|
1865
|
-
};
|
|
1866
|
-
})
|
|
1867
|
-
.filter((state) => state !== null);
|
|
1868
|
-
const missingReservesAndOracles = await (0, lib_1.getTokenOracleData)(this.getConnection(), missingReservesStates, oracleAccounts);
|
|
1869
|
-
missingReservesAndOracles.forEach(([reserve, oracle], index) => {
|
|
1870
|
-
const fetchedReserve = new lib_1.KaminoReserve(reserve, missingReserveAddresses[index], // Set maintains order
|
|
1871
|
-
oracle, this.getConnection(), this.recentSlotDurationMs);
|
|
1872
|
-
vaultReservesState.push(fetchedReserve);
|
|
1873
|
-
});
|
|
1874
|
-
const vaultCollateralsPerReserve = new Map();
|
|
1875
|
-
for (const reserve of vaultReservesState) {
|
|
1876
|
-
// try to read the market from the provided list, if it doesn't exist fetch it
|
|
1877
|
-
let lendingMarket = undefined;
|
|
1878
|
-
if (kaminoMarkets) {
|
|
1879
|
-
lendingMarket = kaminoMarkets?.find((market) => reserve.state.lendingMarket === market.address);
|
|
1880
|
-
}
|
|
1881
|
-
if (!lendingMarket) {
|
|
1882
|
-
const fetchedLendingMarket = await lib_1.KaminoMarket.load(this.getConnection(), reserve.state.lendingMarket, lib_1.DEFAULT_RECENT_SLOT_DURATION_MS);
|
|
1883
|
-
if (!fetchedLendingMarket) {
|
|
1884
|
-
throw Error(`Could not fetch lending market ${reserve.state.lendingMarket}`);
|
|
1885
|
-
}
|
|
1886
|
-
lendingMarket = fetchedLendingMarket;
|
|
1887
|
-
}
|
|
1888
|
-
const marketReserves = lendingMarket.getReserves();
|
|
1889
|
-
const marketOverview = {
|
|
1890
|
-
address: reserve.state.lendingMarket,
|
|
1891
|
-
reservesAsCollateral: [],
|
|
1892
|
-
minLTVPct: new decimal_js_1.default(0),
|
|
1893
|
-
maxLTVPct: new decimal_js_1.default(100),
|
|
1894
|
-
};
|
|
1895
|
-
marketReserves
|
|
1896
|
-
.filter((marketReserve) => {
|
|
1897
|
-
return (marketReserve.state.config.liquidationThresholdPct > 0 &&
|
|
1898
|
-
marketReserve.address !== reserve.address &&
|
|
1899
|
-
marketReserve.state.config.status === 0);
|
|
1900
|
-
})
|
|
1901
|
-
.map((filteredReserve) => {
|
|
1902
|
-
const reserveAsCollateral = {
|
|
1903
|
-
mint: filteredReserve.getLiquidityMint(),
|
|
1904
|
-
address: filteredReserve.address,
|
|
1905
|
-
liquidationLTVPct: new decimal_js_1.default(filteredReserve.state.config.liquidationThresholdPct),
|
|
1906
|
-
};
|
|
1907
|
-
marketOverview.reservesAsCollateral.push(reserveAsCollateral);
|
|
1908
|
-
if (reserveAsCollateral.liquidationLTVPct.lt(marketOverview.minLTVPct) || marketOverview.minLTVPct.eq(0)) {
|
|
1909
|
-
marketOverview.minLTVPct = reserveAsCollateral.liquidationLTVPct;
|
|
1910
|
-
}
|
|
1911
|
-
if (reserveAsCollateral.liquidationLTVPct.gt(marketOverview.maxLTVPct) || marketOverview.maxLTVPct.eq(0)) {
|
|
1912
|
-
marketOverview.maxLTVPct = reserveAsCollateral.liquidationLTVPct;
|
|
1913
|
-
}
|
|
1914
|
-
});
|
|
1915
|
-
vaultCollateralsPerReserve.set(reserve.address, marketOverview);
|
|
1916
|
-
}
|
|
1917
|
-
return vaultCollateralsPerReserve;
|
|
1918
|
-
}
|
|
1919
|
-
/**
|
|
1920
|
-
* This will return an VaultHoldings object which contains the amount available (uninvested) in vault, total amount invested in reseves and a breakdown of the amount invested in each reserve
|
|
1921
|
-
* @param vault - the kamino vault to get available liquidity to withdraw for
|
|
1922
|
-
* @param [slot] - the slot for which to calculate the holdings. Optional. If not provided the function will fetch the current slot
|
|
1923
|
-
* @param [vaultReserves] - a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1924
|
-
* @param [currentSlot] - the latest confirmed slot. Optional. If provided the function will be faster as it will not have to fetch the latest slot
|
|
1925
|
-
* @returns an VaultHoldings object representing the amount available (uninvested) in vault, total amount invested in reseves and a breakdown of the amount invested in each reserve
|
|
1926
|
-
*/
|
|
1927
|
-
async getVaultHoldings(vault, slot, vaultReserves, currentSlot) {
|
|
1928
|
-
const vaultHoldings = new VaultHoldings({
|
|
1929
|
-
available: new decimal_js_1.default(vault.tokenAvailable.toString()),
|
|
1930
|
-
invested: new decimal_js_1.default(0),
|
|
1931
|
-
investedInReserves: new Map(),
|
|
1932
|
-
totalAUMIncludingFees: new decimal_js_1.default(0),
|
|
1933
|
-
pendingFees: new decimal_js_1.default(0),
|
|
1934
|
-
});
|
|
1935
|
-
const currentSlotToUse = currentSlot ?? (await this.getConnection().getSlot({ commitment: 'confirmed' }).send());
|
|
1936
|
-
const vaultReservesState = vaultReserves ? vaultReserves : await this.loadVaultReserves(vault);
|
|
1937
|
-
const decimals = new decimal_js_1.default(vault.tokenMintDecimals.toString());
|
|
1938
|
-
vault.vaultAllocationStrategy.forEach((allocationStrategy) => {
|
|
1939
|
-
if (allocationStrategy.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
1940
|
-
return;
|
|
1941
|
-
}
|
|
1942
|
-
const reserve = vaultReservesState.get(allocationStrategy.reserve);
|
|
1943
|
-
if (reserve === undefined) {
|
|
1944
|
-
throw new Error(`Reserve ${allocationStrategy.reserve} not found`);
|
|
1945
|
-
}
|
|
1946
|
-
let reserveCollExchangeRate;
|
|
1947
|
-
if (slot) {
|
|
1948
|
-
reserveCollExchangeRate = reserve.getEstimatedCollateralExchangeRate(slot, 0);
|
|
1949
|
-
}
|
|
1950
|
-
else {
|
|
1951
|
-
reserveCollExchangeRate = reserve.getCollateralExchangeRate();
|
|
1952
|
-
}
|
|
1953
|
-
const reserveAllocationLiquidityAmount = new decimal_js_1.default(allocationStrategy.ctokenAllocation.toString()).div(reserveCollExchangeRate);
|
|
1954
|
-
vaultHoldings.invested = vaultHoldings.invested.add(reserveAllocationLiquidityAmount);
|
|
1955
|
-
vaultHoldings.investedInReserves.set(allocationStrategy.reserve, (0, lib_1.lamportsToDecimal)(reserveAllocationLiquidityAmount, decimals));
|
|
1956
|
-
});
|
|
1957
|
-
const currentPendingFees = new fraction_1.Fraction(vault.pendingFeesSf).toDecimal();
|
|
1958
|
-
let totalPendingFees = currentPendingFees;
|
|
1959
|
-
// if there is a slot passed and it is in the future we need to estimate the fees from current time until that moment
|
|
1960
|
-
if (slot && slot > currentSlotToUse) {
|
|
1961
|
-
const currentTimestampSec = new Date().getTime() / 1000;
|
|
1962
|
-
const timeAtPassedSlot = currentTimestampSec + Number.parseInt((slot - currentSlotToUse).toString()) * this.recentSlotDurationMs;
|
|
1963
|
-
const timeUntilPassedSlot = timeAtPassedSlot - currentTimestampSec;
|
|
1964
|
-
const managementFeeFactor = new decimal_js_1.default(timeUntilPassedSlot)
|
|
1965
|
-
.mul(new decimal_js_1.default(vault.managementFeeBps.toString()))
|
|
1966
|
-
.div(new decimal_js_1.default(utils_2.SECONDS_PER_YEAR))
|
|
1967
|
-
.div(CreationParameters_1.FullBPSDecimal);
|
|
1968
|
-
const prevAUM = (0, lib_1.lamportsToDecimal)(new fraction_1.Fraction(vault.prevAumSf).toDecimal(), vault.tokenMintDecimals.toNumber());
|
|
1969
|
-
const simulatedMgmtFee = prevAUM.mul(managementFeeFactor);
|
|
1970
|
-
totalPendingFees = totalPendingFees.add(simulatedMgmtFee);
|
|
1971
|
-
const simulatedEarnedInterest = vaultHoldings.invested
|
|
1972
|
-
.add(vaultHoldings.available)
|
|
1973
|
-
.sub(prevAUM)
|
|
1974
|
-
.sub(simulatedMgmtFee);
|
|
1975
|
-
const simulatedPerformanceFee = simulatedEarnedInterest
|
|
1976
|
-
.mul(new decimal_js_1.default(vault.performanceFeeBps.toString()))
|
|
1977
|
-
.div(CreationParameters_1.FullBPSDecimal);
|
|
1978
|
-
totalPendingFees = totalPendingFees.add(simulatedPerformanceFee);
|
|
1979
|
-
}
|
|
1980
|
-
const totalAvailableDecimal = (0, lib_1.lamportsToDecimal)(vaultHoldings.available, decimals);
|
|
1981
|
-
const totalInvestedDecimal = (0, lib_1.lamportsToDecimal)(vaultHoldings.invested, decimals);
|
|
1982
|
-
const pendingFees = (0, lib_1.lamportsToDecimal)(totalPendingFees, decimals);
|
|
1983
|
-
return new VaultHoldings({
|
|
1984
|
-
available: totalAvailableDecimal,
|
|
1985
|
-
invested: totalInvestedDecimal,
|
|
1986
|
-
investedInReserves: vaultHoldings.investedInReserves,
|
|
1987
|
-
totalAUMIncludingFees: totalAvailableDecimal.add(totalInvestedDecimal),
|
|
1988
|
-
pendingFees: pendingFees,
|
|
1989
|
-
});
|
|
1990
|
-
}
|
|
1991
|
-
/**
|
|
1992
|
-
* This will return an VaultOverview object that encapsulates all the information about the vault, including the holdings, reserves details, theoretical APY, utilization ratio and total borrowed amount
|
|
1993
|
-
* @param vault - the kamino vault to get available liquidity to withdraw for
|
|
1994
|
-
* @param price - the price of the token in the vault (e.g. USDC)
|
|
1995
|
-
* @param [slot] - the slot for which to retrieve the vault overview for. Optional. If not provided the function will fetch the current slot
|
|
1996
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
1997
|
-
* @param [currentSlot] - the latest confirmed slot. Optional. If provided the function will be faster as it will not have to fetch the latest slot
|
|
1998
|
-
* @returns an VaultOverview object with details about the tokens available and invested in the vault, denominated in tokens and USD
|
|
1999
|
-
*/
|
|
2000
|
-
async getVaultHoldingsWithPrice(vault, price, slot, vaultReservesMap, currentSlot) {
|
|
2001
|
-
const holdings = await this.getVaultHoldings(vault, slot, vaultReservesMap, currentSlot);
|
|
2002
|
-
const investedInReservesUSD = new Map();
|
|
2003
|
-
holdings.investedInReserves.forEach((amount, reserve) => {
|
|
2004
|
-
investedInReservesUSD.set(reserve, amount.mul(price));
|
|
2005
|
-
});
|
|
2006
|
-
return {
|
|
2007
|
-
holdings: holdings,
|
|
2008
|
-
availableUSD: holdings.available.mul(price),
|
|
2009
|
-
investedUSD: holdings.invested.mul(price),
|
|
2010
|
-
investedInReservesUSD: investedInReservesUSD,
|
|
2011
|
-
totalUSDIncludingFees: holdings.totalAUMIncludingFees.mul(price),
|
|
2012
|
-
pendingFeesUSD: holdings.pendingFees.mul(price),
|
|
2013
|
-
};
|
|
2014
|
-
}
|
|
2015
|
-
/**
|
|
2016
|
-
* This will return an VaultOverview object that encapsulates all the information about the vault, including the holdings, reserves details, theoretical APY, utilization ratio and total borrowed amount
|
|
2017
|
-
* @param vault - the kamino vault to get available liquidity to withdraw for
|
|
2018
|
-
* @param vaultTokenPrice - the price of the token in the vault (e.g. USDC)
|
|
2019
|
-
* @param [slot] - the slot for which to retrieve the vault overview for. Optional. If not provided the function will fetch the current slot
|
|
2020
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2021
|
-
* @param [kaminoMarkets] - a list of all kamino markets. Optional. If provided the function will be significantly faster as it will not have to fetch the markets
|
|
2022
|
-
* @param [currentSlot] - the latest confirmed slot. Optional. If provided the function will be faster as it will not have to fetch the latest slot
|
|
2023
|
-
* @param [tokensPrices] - a hashmap from a token pubkey to the price of the token in USD. Optional. If some tokens are not in the map, the function will fetch the price
|
|
2024
|
-
* @returns an VaultOverview object with details about the tokens available and invested in the vault, denominated in tokens and USD, along sie APYs
|
|
2025
|
-
*/
|
|
2026
|
-
async getVaultOverview(vault, vaultTokenPrice, slot, vaultReservesMap, kaminoMarkets, currentSlot, tokensPrices) {
|
|
2027
|
-
const vaultState = await vault.getState();
|
|
2028
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
2029
|
-
const vaultHoldingsWithUSDValuePromise = this.getVaultHoldingsWithPrice(vaultState, vaultTokenPrice, slot, vaultReservesState, currentSlot);
|
|
2030
|
-
const slotForOverview = slot ? slot : await this.getConnection().getSlot().send();
|
|
2031
|
-
const farmsClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2032
|
-
const vaultTheoreticalAPYPromise = this.getVaultTheoreticalAPY(vaultState, slotForOverview, vaultReservesState);
|
|
2033
|
-
const vaultActualAPYPromise = this.getVaultActualAPY(vaultState, slotForOverview, vaultReservesState);
|
|
2034
|
-
const totalInvestedAndBorrowedPromise = this.getTotalBorrowedAndInvested(vaultState, slotForOverview, vaultReservesState);
|
|
2035
|
-
const vaultCollateralsPromise = this.getVaultCollaterals(vaultState, slotForOverview, vaultReservesState, kaminoMarkets);
|
|
2036
|
-
const reservesOverviewPromise = this.getVaultReservesDetails(vaultState, slotForOverview, vaultReservesState);
|
|
2037
|
-
const vaultFarmIncentivesPromise = this.getVaultRewardsAPY(vault, vaultTokenPrice, farmsClient, slotForOverview, tokensPrices);
|
|
2038
|
-
const vaultReservesFarmIncentivesPromise = this.getVaultReservesFarmsIncentives(vault, vaultTokenPrice, farmsClient, slotForOverview, vaultReservesState, tokensPrices);
|
|
2039
|
-
const vaultDelegatedFarmIncentivesPromise = this.getVaultDelegatedFarmRewardsAPY(vault, vaultTokenPrice, farmsClient, slotForOverview, tokensPrices);
|
|
2040
|
-
// all the async part of the functions above just read the vaultReservesState which is read beforehand, so excepting vaultCollateralsPromise they should do no additional network calls
|
|
2041
|
-
const [vaultHoldingsWithUSDValue, vaultTheoreticalAPYs, vaultActualAPYs, totalInvestedAndBorrowed, vaultCollaterals, reservesOverview, vaultFarmIncentives, vaultReservesFarmIncentives, vaultDelegatedFarmIncentives,] = await Promise.all([
|
|
2042
|
-
vaultHoldingsWithUSDValuePromise,
|
|
2043
|
-
vaultTheoreticalAPYPromise,
|
|
2044
|
-
vaultActualAPYPromise,
|
|
2045
|
-
totalInvestedAndBorrowedPromise,
|
|
2046
|
-
vaultCollateralsPromise,
|
|
2047
|
-
reservesOverviewPromise,
|
|
2048
|
-
vaultFarmIncentivesPromise,
|
|
2049
|
-
vaultReservesFarmIncentivesPromise,
|
|
2050
|
-
vaultDelegatedFarmIncentivesPromise,
|
|
2051
|
-
]);
|
|
2052
|
-
return {
|
|
2053
|
-
holdingsUSD: vaultHoldingsWithUSDValue,
|
|
2054
|
-
reservesOverview: reservesOverview,
|
|
2055
|
-
vaultCollaterals: vaultCollaterals,
|
|
2056
|
-
actualSupplyAPY: vaultActualAPYs,
|
|
2057
|
-
theoreticalSupplyAPY: vaultTheoreticalAPYs,
|
|
2058
|
-
vaultFarmIncentives: vaultFarmIncentives,
|
|
2059
|
-
reservesFarmsIncentives: vaultReservesFarmIncentives,
|
|
2060
|
-
delegatedFarmIncentives: vaultDelegatedFarmIncentives,
|
|
2061
|
-
totalBorrowed: totalInvestedAndBorrowed.totalBorrowed,
|
|
2062
|
-
totalBorrowedUSD: totalInvestedAndBorrowed.totalBorrowed.mul(vaultTokenPrice),
|
|
2063
|
-
utilizationRatio: totalInvestedAndBorrowed.utilizationRatio,
|
|
2064
|
-
totalSupplied: totalInvestedAndBorrowed.totalInvested,
|
|
2065
|
-
totalSuppliedUSD: totalInvestedAndBorrowed.totalInvested.mul(vaultTokenPrice),
|
|
2066
|
-
};
|
|
2067
|
-
}
|
|
2068
|
-
/**
|
|
2069
|
-
* This will return an aggregation of the current state of the vault with all the invested amounts and the utilization ratio of the vault
|
|
2070
|
-
* @param vault - the kamino vault to get available liquidity to withdraw for
|
|
2071
|
-
* @param slot - current slot
|
|
2072
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2073
|
-
* @returns an VaultReserveTotalBorrowedAndInvested object with the total invested amount, total borrowed amount and the utilization ratio of the vault
|
|
2074
|
-
*/
|
|
2075
|
-
async getTotalBorrowedAndInvested(vault, slot, vaultReservesMap) {
|
|
2076
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vault);
|
|
2077
|
-
const totalAvailable = (0, lib_1.lamportsToDecimal)(new decimal_js_1.default(vault.tokenAvailable.toString()), new decimal_js_1.default(vault.tokenMintDecimals.toString()));
|
|
2078
|
-
let totalInvested = new decimal_js_1.default(0);
|
|
2079
|
-
let totalBorrowed = new decimal_js_1.default(0);
|
|
2080
|
-
vault.vaultAllocationStrategy.forEach((allocationStrategy) => {
|
|
2081
|
-
if (allocationStrategy.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2082
|
-
return;
|
|
2083
|
-
}
|
|
2084
|
-
const reserve = vaultReservesState.get(allocationStrategy.reserve);
|
|
2085
|
-
if (reserve === undefined) {
|
|
2086
|
-
throw new Error(`Reserve ${allocationStrategy.reserve} not found`);
|
|
2087
|
-
}
|
|
2088
|
-
const reserveCollExchangeRate = reserve.getEstimatedCollateralExchangeRate(slot, 0);
|
|
2089
|
-
const reserveAllocationLiquidityAmountLamports = new decimal_js_1.default(allocationStrategy.ctokenAllocation.toString()).div(reserveCollExchangeRate);
|
|
2090
|
-
const reserveAllocationLiquidityAmount = (0, lib_1.lamportsToDecimal)(reserveAllocationLiquidityAmountLamports, vault.tokenMintDecimals.toString());
|
|
2091
|
-
const utilizationRatio = reserve.getEstimatedUtilizationRatio(slot, 0);
|
|
2092
|
-
totalInvested = totalInvested.add(reserveAllocationLiquidityAmount);
|
|
2093
|
-
totalBorrowed = totalBorrowed.add(reserveAllocationLiquidityAmount.mul(utilizationRatio));
|
|
2094
|
-
});
|
|
2095
|
-
let utilizationRatio = new decimal_js_1.default(0);
|
|
2096
|
-
if (!totalInvested.isZero()) {
|
|
2097
|
-
utilizationRatio = totalBorrowed.div(totalInvested.add(totalAvailable));
|
|
2098
|
-
}
|
|
2099
|
-
return {
|
|
2100
|
-
totalInvested: totalInvested,
|
|
2101
|
-
totalBorrowed: totalBorrowed,
|
|
2102
|
-
utilizationRatio: utilizationRatio,
|
|
2103
|
-
};
|
|
2104
|
-
}
|
|
2105
|
-
/**
|
|
2106
|
-
* This will return a map of the cumulative rewards issued for all the delegated farms
|
|
2107
|
-
* @param [vaults] - the vaults to get the cumulative rewards for; if not provided, the function will get the cumulative rewards for all the vaults
|
|
2108
|
-
* @returns a map of the cumulative rewards issued for all the delegated farms, per token, in lamports
|
|
2109
|
-
*/
|
|
2110
|
-
async getCumulativeDelegatedFarmsRewardsIssuedForAllVaults(vaults) {
|
|
2111
|
-
const vaultsWithDelegatedFarms = await this.getVaultsWithDelegatedFarm();
|
|
2112
|
-
const delegatedFarmsAddresses = [];
|
|
2113
|
-
if (vaults) {
|
|
2114
|
-
vaults.forEach((vault) => {
|
|
2115
|
-
const delegatedFarm = vaultsWithDelegatedFarms.get(vault);
|
|
2116
|
-
if (delegatedFarm) {
|
|
2117
|
-
delegatedFarmsAddresses.push(delegatedFarm);
|
|
2118
|
-
}
|
|
2119
|
-
});
|
|
2120
|
-
}
|
|
2121
|
-
else {
|
|
2122
|
-
delegatedFarmsAddresses.push(...Array.from(vaultsWithDelegatedFarms.values()));
|
|
2123
|
-
}
|
|
2124
|
-
const farmsSDK = new farms_sdk_1.Farms(this.getConnection());
|
|
2125
|
-
const delegatedFarmsStates = await farmsSDK.fetchMultipleFarmStatesWithCheckedSize(delegatedFarmsAddresses);
|
|
2126
|
-
const cumulativeRewardsPerToken = new Map();
|
|
2127
|
-
for (const delegatedFarmState of delegatedFarmsStates) {
|
|
2128
|
-
if (!delegatedFarmState) {
|
|
2129
|
-
continue;
|
|
2130
|
-
}
|
|
2131
|
-
delegatedFarmState.rewardInfos.forEach((rewardInfo) => {
|
|
2132
|
-
if (rewardInfo.token.mint === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2133
|
-
return;
|
|
2134
|
-
}
|
|
2135
|
-
const rewardTokenMint = rewardInfo.token.mint;
|
|
2136
|
-
if (cumulativeRewardsPerToken.has(rewardTokenMint)) {
|
|
2137
|
-
cumulativeRewardsPerToken.set(rewardTokenMint, cumulativeRewardsPerToken
|
|
2138
|
-
.get(rewardTokenMint)
|
|
2139
|
-
.add(new decimal_js_1.default(rewardInfo.rewardsIssuedCumulative.toString())));
|
|
2140
|
-
}
|
|
2141
|
-
else {
|
|
2142
|
-
cumulativeRewardsPerToken.set(rewardTokenMint, new decimal_js_1.default(rewardInfo.rewardsIssuedCumulative.toString()));
|
|
2143
|
-
}
|
|
2144
|
-
});
|
|
2145
|
-
}
|
|
2146
|
-
return cumulativeRewardsPerToken;
|
|
2147
|
-
}
|
|
2148
|
-
/**
|
|
2149
|
-
* This will return an overview of each reserve that is part of the vault allocation
|
|
2150
|
-
* @param vault - the kamino vault to get available liquidity to withdraw for
|
|
2151
|
-
* @param slot - current slot
|
|
2152
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2153
|
-
* @returns a hashmap from vault reserve pubkey to ReserveOverview object
|
|
2154
|
-
*/
|
|
2155
|
-
async getVaultReservesDetails(vault, slot, vaultReserves) {
|
|
2156
|
-
const vaultReservesState = vaultReserves ? vaultReserves : await this.loadVaultReserves(vault);
|
|
2157
|
-
const reservesDetails = new Map();
|
|
2158
|
-
vault.vaultAllocationStrategy.forEach((allocationStrategy) => {
|
|
2159
|
-
if (allocationStrategy.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2160
|
-
return;
|
|
2161
|
-
}
|
|
2162
|
-
const reserve = vaultReservesState.get(allocationStrategy.reserve);
|
|
2163
|
-
if (reserve === undefined) {
|
|
2164
|
-
throw new Error(`Reserve ${allocationStrategy.reserve} not found`);
|
|
2165
|
-
}
|
|
2166
|
-
const suppliedInReserve = this.getSuppliedInReserve(vault, slot, reserve);
|
|
2167
|
-
const utilizationRatio = new decimal_js_1.default(reserve.getEstimatedUtilizationRatio(slot, 0));
|
|
2168
|
-
const reserveOverview = {
|
|
2169
|
-
supplyAPY: new decimal_js_1.default(reserve.totalSupplyAPY(slot)),
|
|
2170
|
-
utilizationRatio: utilizationRatio,
|
|
2171
|
-
liquidationThresholdPct: new decimal_js_1.default(reserve.state.config.liquidationThresholdPct),
|
|
2172
|
-
totalBorrowedAmount: reserve.getBorrowedAmount(),
|
|
2173
|
-
amountBorrowedFromSupplied: suppliedInReserve.mul(utilizationRatio),
|
|
2174
|
-
market: reserve.state.lendingMarket,
|
|
2175
|
-
suppliedAmount: suppliedInReserve,
|
|
2176
|
-
};
|
|
2177
|
-
reservesDetails.set(allocationStrategy.reserve, reserveOverview);
|
|
2178
|
-
});
|
|
2179
|
-
return reservesDetails;
|
|
2180
|
-
}
|
|
2181
|
-
/**
|
|
2182
|
-
* This will return the APY of the vault under the assumption that all the available tokens in the vault are all the time invested in the reserves as requested by the weights; for percentage it needs multiplication by 100
|
|
2183
|
-
* @param vault - the kamino vault to get APY for
|
|
2184
|
-
* @param slot - current slot
|
|
2185
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2186
|
-
* @returns a struct containing estimated gross APY and net APY (gross - vault fees) for the vault
|
|
2187
|
-
*/
|
|
2188
|
-
async getVaultTheoreticalAPY(vault, slot, vaultReservesMap) {
|
|
2189
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vault);
|
|
2190
|
-
let totalWeights = new decimal_js_1.default(0);
|
|
2191
|
-
let totalAPY = new decimal_js_1.default(0);
|
|
2192
|
-
vault.vaultAllocationStrategy.forEach((allocationStrategy) => {
|
|
2193
|
-
if (allocationStrategy.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2194
|
-
return;
|
|
2195
|
-
}
|
|
2196
|
-
const reserve = vaultReservesState.get(allocationStrategy.reserve);
|
|
2197
|
-
if (reserve === undefined) {
|
|
2198
|
-
throw new Error(`Reserve ${allocationStrategy.reserve} not found`);
|
|
2199
|
-
}
|
|
2200
|
-
const reserveAPY = new decimal_js_1.default(reserve.totalSupplyAPY(slot));
|
|
2201
|
-
const weight = new decimal_js_1.default(allocationStrategy.targetAllocationWeight.toString());
|
|
2202
|
-
const weightedAPY = reserveAPY.mul(weight);
|
|
2203
|
-
totalAPY = totalAPY.add(weightedAPY);
|
|
2204
|
-
totalWeights = totalWeights.add(weight);
|
|
2205
|
-
});
|
|
2206
|
-
if (totalWeights.isZero()) {
|
|
2207
|
-
return {
|
|
2208
|
-
grossAPY: new decimal_js_1.default(0),
|
|
2209
|
-
netAPY: new decimal_js_1.default(0),
|
|
2210
|
-
};
|
|
2211
|
-
}
|
|
2212
|
-
const grossAPY = totalAPY.div(totalWeights);
|
|
2213
|
-
const netAPY = grossAPY
|
|
2214
|
-
.mul(new decimal_js_1.default(1).sub(new decimal_js_1.default(vault.performanceFeeBps.toString()).div(CreationParameters_1.FullBPSDecimal)))
|
|
2215
|
-
.mul(new decimal_js_1.default(1).sub(new decimal_js_1.default(vault.managementFeeBps.toString()).div(CreationParameters_1.FullBPSDecimal)));
|
|
2216
|
-
return {
|
|
2217
|
-
grossAPY,
|
|
2218
|
-
netAPY,
|
|
2219
|
-
};
|
|
2220
|
-
}
|
|
2221
|
-
/**
|
|
2222
|
-
* This will return the APY of the vault based on the current invested amounts; for percentage it needs multiplication by 100
|
|
2223
|
-
* @param vault - the kamino vault to get APY for
|
|
2224
|
-
* @param slot - current slot
|
|
2225
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2226
|
-
* @returns a struct containing estimated gross APY and net APY (gross - vault fees) for the vault
|
|
2227
|
-
*/
|
|
2228
|
-
async getVaultActualAPY(vault, slot, vaultReservesMap) {
|
|
2229
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vault);
|
|
2230
|
-
let totalAUM = new decimal_js_1.default(vault.tokenAvailable.toString());
|
|
2231
|
-
let totalAPY = new decimal_js_1.default(0);
|
|
2232
|
-
vault.vaultAllocationStrategy.forEach((allocationStrategy) => {
|
|
2233
|
-
if (allocationStrategy.reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2234
|
-
return;
|
|
2235
|
-
}
|
|
2236
|
-
const reserve = vaultReservesState.get(allocationStrategy.reserve);
|
|
2237
|
-
if (reserve === undefined) {
|
|
2238
|
-
throw new Error(`Reserve ${allocationStrategy.reserve} not found`);
|
|
2239
|
-
}
|
|
2240
|
-
const reserveAPY = new decimal_js_1.default(reserve.totalSupplyAPY(slot));
|
|
2241
|
-
const exchangeRate = reserve.getEstimatedCollateralExchangeRate(slot, 0);
|
|
2242
|
-
const investedInReserve = exchangeRate.mul(new decimal_js_1.default(allocationStrategy.ctokenAllocation.toString()));
|
|
2243
|
-
const weightedAPY = reserveAPY.mul(investedInReserve);
|
|
2244
|
-
totalAPY = totalAPY.add(weightedAPY);
|
|
2245
|
-
totalAUM = totalAUM.add(investedInReserve);
|
|
2246
|
-
});
|
|
2247
|
-
if (totalAUM.isZero()) {
|
|
2248
|
-
return {
|
|
2249
|
-
grossAPY: new decimal_js_1.default(0),
|
|
2250
|
-
netAPY: new decimal_js_1.default(0),
|
|
2251
|
-
};
|
|
2252
|
-
}
|
|
2253
|
-
const grossAPY = totalAPY.div(totalAUM);
|
|
2254
|
-
const netAPY = grossAPY
|
|
2255
|
-
.mul(new decimal_js_1.default(1).sub(new decimal_js_1.default(vault.performanceFeeBps.toString()).div(CreationParameters_1.FullBPSDecimal)))
|
|
2256
|
-
.mul(new decimal_js_1.default(1).sub(new decimal_js_1.default(vault.managementFeeBps.toString()).div(CreationParameters_1.FullBPSDecimal)));
|
|
2257
|
-
return {
|
|
2258
|
-
grossAPY,
|
|
2259
|
-
netAPY,
|
|
2260
|
-
};
|
|
2261
|
-
}
|
|
2262
|
-
/**
|
|
2263
|
-
* Retrive the total amount of interest earned by the vault since its inception, up to the last interaction with the vault on chain, including what was charged as fees
|
|
2264
|
-
* @param vaultState the kamino vault state to get total net yield for
|
|
2265
|
-
* @returns a struct containing a Decimal representing the net number of tokens earned by the vault since its inception and the timestamp of the last fee charge
|
|
2266
|
-
*/
|
|
2267
|
-
async getVaultCumulativeInterest(vaultState) {
|
|
2268
|
-
const netYieldLamports = new fraction_1.Fraction(vaultState.cumulativeEarnedInterestSf).toDecimal();
|
|
2269
|
-
const cumulativeInterest = (0, lib_1.lamportsToDecimal)(netYieldLamports, vaultState.tokenMintDecimals.toString());
|
|
2270
|
-
return {
|
|
2271
|
-
cumulativeInterest: cumulativeInterest,
|
|
2272
|
-
timestamp: vaultState.lastFeeChargeTimestamp.toNumber(),
|
|
2273
|
-
};
|
|
2274
|
-
}
|
|
2275
|
-
/**
|
|
2276
|
-
* Simulate the current holdings of the vault and the earned interest
|
|
2277
|
-
* @param vaultState the kamino vault state to get simulated holdings and earnings for
|
|
2278
|
-
* @param [vaultReservesMap] - hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2279
|
-
* @param [currentSlot] - the current slot. Optional. If not provided it will fetch the current slot
|
|
2280
|
-
* @param [previousNetAUM] - the previous AUM of the vault to compute the earned interest relative to this value. Optional. If not provided the function will estimate the total AUM at the slot of the last state update on chain
|
|
2281
|
-
* @param [currentSlot] - the latest confirmed slot. Optional. If provided the function will be faster as it will not have to fetch the latest slot
|
|
2282
|
-
* @returns a struct of simulated vault holdings and earned interest
|
|
2283
|
-
*/
|
|
2284
|
-
async calculateSimulatedHoldingsWithInterest(vaultState, vaultReservesMap, slot, previousNetAUM, currentSlot) {
|
|
2285
|
-
let prevAUM;
|
|
2286
|
-
let pendingFees = kliquidity_sdk_1.ZERO;
|
|
2287
|
-
if (previousNetAUM) {
|
|
2288
|
-
prevAUM = previousNetAUM;
|
|
2289
|
-
}
|
|
2290
|
-
else {
|
|
2291
|
-
const tokenDecimals = vaultState.tokenMintDecimals.toNumber();
|
|
2292
|
-
prevAUM = (0, lib_1.lamportsToDecimal)(new fraction_1.Fraction(vaultState.prevAumSf).toDecimal(), tokenDecimals);
|
|
2293
|
-
pendingFees = (0, lib_1.lamportsToDecimal)(new fraction_1.Fraction(vaultState.pendingFeesSf).toDecimal(), tokenDecimals);
|
|
2294
|
-
}
|
|
2295
|
-
const latestSlot = slot ? slot : await this.getConnection().getSlot({ commitment: 'confirmed' }).send();
|
|
2296
|
-
const currentHoldings = await this.getVaultHoldings(vaultState, latestSlot, vaultReservesMap, currentSlot);
|
|
2297
|
-
const earnedInterest = currentHoldings.totalAUMIncludingFees.sub(prevAUM).sub(pendingFees);
|
|
2298
|
-
return {
|
|
2299
|
-
holdings: currentHoldings,
|
|
2300
|
-
earnedInterest: earnedInterest,
|
|
2301
|
-
};
|
|
2302
|
-
}
|
|
2303
|
-
/**
|
|
2304
|
-
* Simulate the current holdings and compute the fees that would be charged
|
|
2305
|
-
* @param vaultState the kamino vault state to get simulated fees for
|
|
2306
|
-
* @param [simulatedCurrentHoldingsWithInterest] the simulated holdings and interest earned by the vault. Optional
|
|
2307
|
-
* @param [currentTimestamp] the current date. Optional. If not provided it will fetch the current unix timestamp
|
|
2308
|
-
* @returns a VaultFees struct of simulated management and interest fees
|
|
2309
|
-
*/
|
|
2310
|
-
async calculateSimulatedFees(vaultState, simulatedCurrentHoldingsWithInterest, currentTimestamp) {
|
|
2311
|
-
const timestampNowInSeconds = currentTimestamp ? currentTimestamp.valueOf() / 1000 : Date.now() / 1000;
|
|
2312
|
-
const timestampLastUpdate = vaultState.lastFeeChargeTimestamp.toNumber();
|
|
2313
|
-
const timeElapsed = timestampNowInSeconds - timestampLastUpdate;
|
|
2314
|
-
const simulatedCurrentHoldings = simulatedCurrentHoldingsWithInterest
|
|
2315
|
-
? simulatedCurrentHoldingsWithInterest
|
|
2316
|
-
: await this.calculateSimulatedHoldingsWithInterest(vaultState);
|
|
2317
|
-
const performanceFee = simulatedCurrentHoldings.earnedInterest.mul(new decimal_js_1.default(vaultState.performanceFeeBps.toString()).div(CreationParameters_1.FullBPSDecimal));
|
|
2318
|
-
const managementFeeFactor = new decimal_js_1.default(timeElapsed)
|
|
2319
|
-
.mul(new decimal_js_1.default(vaultState.managementFeeBps.toString()))
|
|
2320
|
-
.div(new decimal_js_1.default(utils_2.SECONDS_PER_YEAR))
|
|
2321
|
-
.div(CreationParameters_1.FullBPSDecimal);
|
|
2322
|
-
const prevAUM = (0, lib_1.lamportsToDecimal)(new fraction_1.Fraction(vaultState.prevAumSf).toDecimal(), vaultState.tokenMintDecimals.toNumber());
|
|
2323
|
-
const mgmtFee = prevAUM.mul(managementFeeFactor);
|
|
2324
|
-
return {
|
|
2325
|
-
managementFee: mgmtFee,
|
|
2326
|
-
performanceFee: performanceFee,
|
|
2327
|
-
};
|
|
2328
|
-
}
|
|
2329
|
-
/**
|
|
2330
|
-
* This will compute the PDA that is used as delegatee in Farms program to compute the user state PDA for vault depositor investing in vault with reserve having a supply farm
|
|
2331
|
-
*/
|
|
2332
|
-
computeUserFarmStateDelegateePDAForUserInVault(farmsProgramId, vault, reserve, user) {
|
|
2333
|
-
return (0, kit_1.getProgramDerivedAddress)({
|
|
2334
|
-
seeds: [addressEncoder.encode(reserve), addressEncoder.encode(vault), addressEncoder.encode(user)],
|
|
2335
|
-
programAddress: farmsProgramId,
|
|
2336
|
-
});
|
|
2337
|
-
}
|
|
2338
|
-
/**
|
|
2339
|
-
* Compute the delegatee PDA for the user farm state for a vault delegate farm
|
|
2340
|
-
* @param farmProgramID - the program ID of the farm program
|
|
2341
|
-
* @param vault - the address of the vault
|
|
2342
|
-
* @param farm - the address of the delegated farm
|
|
2343
|
-
* @param user - the address of the user
|
|
2344
|
-
* @returns the PDA of the delegatee user farm state for the delegated farm
|
|
2345
|
-
*/
|
|
2346
|
-
async computeUserFarmStateDelegateePDAForUserInDelegatedVaultFarm(farmProgramID, vault, farm, user) {
|
|
2347
|
-
return (0, kit_1.getProgramDerivedAddress)({
|
|
2348
|
-
seeds: [addressEncoder.encode(vault), addressEncoder.encode(farm), addressEncoder.encode(user)],
|
|
2349
|
-
programAddress: farmProgramID,
|
|
2350
|
-
});
|
|
2351
|
-
}
|
|
2352
|
-
/**
|
|
2353
|
-
* Compute the user state PDA for a user in a delegated vault farm
|
|
2354
|
-
* @param farmProgramID - the program ID of the farm program
|
|
2355
|
-
* @param vault - the address of the vault
|
|
2356
|
-
* @param farm - the address of the delegated farm
|
|
2357
|
-
* @param user - the address of the user
|
|
2358
|
-
* @returns the PDA of the user state for the delegated farm
|
|
2359
|
-
*/
|
|
2360
|
-
async computeUserStatePDAForUserInDelegatedVaultFarm(farmProgramID, vault, farm, user) {
|
|
2361
|
-
const delegateePDA = await this.computeDelegateeForUserInDelegatedFarm(farmProgramID, vault, farm, user);
|
|
2362
|
-
return (0, dist_1.getUserStatePDA)(farmProgramID, farm, delegateePDA);
|
|
2363
|
-
}
|
|
2364
|
-
async computeDelegateeForUserInDelegatedFarm(farmProgramID, vault, farm, user) {
|
|
2365
|
-
const delegateePDA = await this.computeUserFarmStateDelegateePDAForUserInDelegatedVaultFarm(farmProgramID, vault, farm, user);
|
|
2366
|
-
return delegateePDA[0];
|
|
2367
|
-
}
|
|
2368
|
-
/**
|
|
2369
|
-
* Read the APY of the farm built on top of the vault (farm in vaultState.vaultFarm)
|
|
2370
|
-
* @param vault - the vault to read the farm APY for
|
|
2371
|
-
* @param vaultTokenPrice - the price of the vault token in USD (e.g. 1.0 for USDC)
|
|
2372
|
-
* @param [farmsClient] - the farms client to use. Optional. If not provided, the function will create a new one
|
|
2373
|
-
* @param [slot] - the slot to read the farm APY for. Optional. If not provided, the function will read the current slot
|
|
2374
|
-
* @returns the APY of the farm built on top of the vault
|
|
2375
|
-
*/
|
|
2376
|
-
async getVaultRewardsAPY(vaultOrState, vaultTokenPrice, farmsClient, slot, tokensPrices) {
|
|
2377
|
-
// Determine if we have a KaminoVault or VaultState
|
|
2378
|
-
const vaultState = 'getState' in vaultOrState ? await vaultOrState.getState() : vaultOrState;
|
|
2379
|
-
if (vaultState.vaultFarm === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2380
|
-
return {
|
|
2381
|
-
incentivesStats: [],
|
|
2382
|
-
totalIncentivesApy: 0,
|
|
2383
|
-
};
|
|
2384
|
-
}
|
|
2385
|
-
const tokensPerShare = await this.getTokensPerShareSingleVault(vaultState, slot);
|
|
2386
|
-
const sharePrice = tokensPerShare.mul(vaultTokenPrice);
|
|
2387
|
-
const stakedTokenMintDecimals = vaultState.sharesMintDecimals.toNumber();
|
|
2388
|
-
const kFarmsClient = farmsClient ? farmsClient : new farms_sdk_1.Farms(this.getConnection());
|
|
2389
|
-
return (0, apy_1.getFarmIncentives)(kFarmsClient, vaultState.vaultFarm, sharePrice, stakedTokenMintDecimals, tokensPrices);
|
|
2390
|
-
}
|
|
2391
|
-
/**
|
|
2392
|
-
* Read the APY of the delegated farm providing incentives for vault depositors
|
|
2393
|
-
* @param vault - the vault to read the farm APY for
|
|
2394
|
-
* @param vaultTokenPrice - the price of the vault token in USD (e.g. 1.0 for USDC)
|
|
2395
|
-
* @param [farmsClient] - the farms client to use. Optional. If not provided, the function will create a new one
|
|
2396
|
-
* @param [slot] - the slot to read the farm APY for. Optional. If not provided, the function will read the current slot
|
|
2397
|
-
* @param [tokensPrices] - the prices of the tokens in USD. Optional. If not provided, the function will fetch the prices
|
|
2398
|
-
* @returns the APY of the delegated farm providing incentives for vault depositors
|
|
2399
|
-
*/
|
|
2400
|
-
async getVaultDelegatedFarmRewardsAPY(vault, vaultTokenPrice, farmsClient, slot, tokensPrices) {
|
|
2401
|
-
const delegatedFarm = await this.getDelegatedFarmForVault(vault.address);
|
|
2402
|
-
if (!delegatedFarm) {
|
|
2403
|
-
return {
|
|
2404
|
-
incentivesStats: [],
|
|
2405
|
-
totalIncentivesApy: 0,
|
|
2406
|
-
};
|
|
2407
|
-
}
|
|
2408
|
-
const vaultState = await vault.getState();
|
|
2409
|
-
const tokensPerShare = await this.getTokensPerShareSingleVault(vaultState, slot);
|
|
2410
|
-
const sharePrice = tokensPerShare.mul(vaultTokenPrice);
|
|
2411
|
-
const stakedTokenMintDecimals = vaultState.sharesMintDecimals.toNumber();
|
|
2412
|
-
const kFarmsClient = farmsClient ? farmsClient : new farms_sdk_1.Farms(this.getConnection());
|
|
2413
|
-
return (0, apy_1.getFarmIncentives)(kFarmsClient, delegatedFarm, sharePrice, stakedTokenMintDecimals, tokensPrices);
|
|
2414
|
-
}
|
|
2415
|
-
/**
|
|
2416
|
-
* Get all the token mints of the vault, vault farm rewards and the allocation rewards
|
|
2417
|
-
* @param vaults - the vaults to get the token mints for
|
|
2418
|
-
* @param [vaultReservesMap] - the vault reserves map to get the reserves for; if not provided, the function will fetch the reserves
|
|
2419
|
-
* @param farmsMap - the farms map to get the farms for
|
|
2420
|
-
* @returns a set of token mints
|
|
2421
|
-
*/
|
|
2422
|
-
async getAllVaultsTokenMintsIncludingRewards(vaults, vaultReservesMap, farmsMap) {
|
|
2423
|
-
const vaultsTokenMints = new Set();
|
|
2424
|
-
const kFarmsMap = farmsMap ? farmsMap : new Map();
|
|
2425
|
-
const farmsToFetch = new Set();
|
|
2426
|
-
const reservesToFetch = new Set();
|
|
2427
|
-
for (const vault of vaults) {
|
|
2428
|
-
const vaultState = await vault.getState();
|
|
2429
|
-
vaultsTokenMints.add(vaultState.tokenMint);
|
|
2430
|
-
const hasFarm = await vault.hasFarm();
|
|
2431
|
-
if (hasFarm) {
|
|
2432
|
-
const farmAddress = vaultState.vaultFarm;
|
|
2433
|
-
if (!kFarmsMap.has(farmAddress)) {
|
|
2434
|
-
farmsToFetch.add(farmAddress);
|
|
2435
|
-
}
|
|
2436
|
-
else {
|
|
2437
|
-
const farmState = kFarmsMap.get(farmAddress);
|
|
2438
|
-
farmState.rewardInfos.forEach((rewardInfo) => {
|
|
2439
|
-
if (rewardInfo.token.mint !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2440
|
-
vaultsTokenMints.add(rewardInfo.token.mint);
|
|
2441
|
-
}
|
|
2442
|
-
});
|
|
2443
|
-
}
|
|
2444
|
-
}
|
|
2445
|
-
const reserves = vaultState.vaultAllocationStrategy.map((allocationStrategy) => allocationStrategy.reserve);
|
|
2446
|
-
reserves.forEach((reserve) => {
|
|
2447
|
-
if (reserve === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2448
|
-
return;
|
|
2449
|
-
}
|
|
2450
|
-
if (vaultReservesMap && !vaultReservesMap.has(reserve)) {
|
|
2451
|
-
const reserveState = vaultReservesMap.get(reserve);
|
|
2452
|
-
const supplyFarm = reserveState.state.farmCollateral;
|
|
2453
|
-
if (supplyFarm !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2454
|
-
if (!kFarmsMap.has(supplyFarm)) {
|
|
2455
|
-
farmsToFetch.add(supplyFarm);
|
|
2456
|
-
}
|
|
2457
|
-
else {
|
|
2458
|
-
const farmState = kFarmsMap.get(supplyFarm);
|
|
2459
|
-
farmState.rewardInfos.forEach((rewardInfo) => {
|
|
2460
|
-
if (rewardInfo.token.mint !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2461
|
-
vaultsTokenMints.add(rewardInfo.token.mint);
|
|
2462
|
-
}
|
|
2463
|
-
});
|
|
2464
|
-
}
|
|
2465
|
-
}
|
|
2466
|
-
}
|
|
2467
|
-
else {
|
|
2468
|
-
reservesToFetch.add(reserve);
|
|
2469
|
-
}
|
|
2470
|
-
});
|
|
2471
|
-
}
|
|
2472
|
-
// fetch the reserves first so we can add their farms to farms to be fetched, if needed
|
|
2473
|
-
const missingReservesStates = await lib_1.Reserve.fetchMultiple(this.getConnection(), Array.from(reservesToFetch));
|
|
2474
|
-
missingReservesStates.forEach((reserveState) => {
|
|
2475
|
-
if (reserveState) {
|
|
2476
|
-
const supplyFarm = reserveState.farmCollateral;
|
|
2477
|
-
if (supplyFarm !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2478
|
-
if (!kFarmsMap.has(supplyFarm)) {
|
|
2479
|
-
farmsToFetch.add(supplyFarm);
|
|
2480
|
-
}
|
|
2481
|
-
else {
|
|
2482
|
-
const farmState = kFarmsMap.get(supplyFarm);
|
|
2483
|
-
farmState.rewardInfos.forEach((rewardInfo) => {
|
|
2484
|
-
if (rewardInfo.token.mint !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2485
|
-
vaultsTokenMints.add(rewardInfo.token.mint);
|
|
2486
|
-
}
|
|
2487
|
-
});
|
|
2488
|
-
}
|
|
2489
|
-
}
|
|
2490
|
-
}
|
|
2491
|
-
});
|
|
2492
|
-
// fetch the missing farms
|
|
2493
|
-
const missingFarmsStates = await dist_1.FarmState.fetchMultiple(this.getConnection(), Array.from(farmsToFetch));
|
|
2494
|
-
missingFarmsStates.forEach((farmState) => {
|
|
2495
|
-
if (farmState) {
|
|
2496
|
-
farmState.rewardInfos.forEach((rewardInfo) => {
|
|
2497
|
-
if (rewardInfo.token.mint !== lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2498
|
-
vaultsTokenMints.add(rewardInfo.token.mint);
|
|
2499
|
-
}
|
|
2500
|
-
});
|
|
2501
|
-
}
|
|
2502
|
-
});
|
|
2503
|
-
return vaultsTokenMints;
|
|
2504
|
-
}
|
|
2505
|
-
async getVaultReservesFarmsIncentives(vaultOrState, vaultTokenPrice, farmsClient, slot, vaultReservesMap, tokensPrices) {
|
|
2506
|
-
const vaultState = 'getState' in vaultOrState ? await vaultOrState.getState() : vaultOrState;
|
|
2507
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
2508
|
-
const currentSlot = slot ?? (await this.getConnection().getSlot({ commitment: 'confirmed' }).send());
|
|
2509
|
-
const holdings = await this.getVaultHoldings(vaultState, currentSlot, vaultReservesState);
|
|
2510
|
-
const vaultReservesAddresses = vaultState.vaultAllocationStrategy.map((allocationStrategy) => allocationStrategy.reserve);
|
|
2511
|
-
const vaultReservesFarmsIncentives = new Map();
|
|
2512
|
-
let totalIncentivesApy = new decimal_js_1.default(0);
|
|
2513
|
-
const kFarmsClient = farmsClient ? farmsClient : new farms_sdk_1.Farms(this.getConnection());
|
|
2514
|
-
for (const reserveAddress of vaultReservesAddresses) {
|
|
2515
|
-
if (reserveAddress === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2516
|
-
continue;
|
|
2517
|
-
}
|
|
2518
|
-
const reserveState = vaultReservesState.get(reserveAddress);
|
|
2519
|
-
if (reserveState === undefined) {
|
|
2520
|
-
console.log(`Reserve to read farm incentives for not found: ${reserveAddress}`);
|
|
2521
|
-
vaultReservesFarmsIncentives.set(reserveAddress, {
|
|
2522
|
-
incentivesStats: [],
|
|
2523
|
-
totalIncentivesApy: 0,
|
|
2524
|
-
});
|
|
2525
|
-
continue;
|
|
2526
|
-
}
|
|
2527
|
-
const reserveFarmIncentives = await (0, farmUtils_1.getReserveFarmRewardsAPY)(this._rpc, this.recentSlotDurationMs, reserveAddress, vaultTokenPrice, this._kaminoLendProgramId, kFarmsClient, currentSlot, reserveState.state, tokensPrices);
|
|
2528
|
-
vaultReservesFarmsIncentives.set(reserveAddress, reserveFarmIncentives.collateralFarmIncentives);
|
|
2529
|
-
const investedInReserve = holdings.investedInReserves.get(reserveAddress);
|
|
2530
|
-
const weightedReserveAPY = new decimal_js_1.default(reserveFarmIncentives.collateralFarmIncentives.totalIncentivesApy)
|
|
2531
|
-
.mul(investedInReserve ?? 0)
|
|
2532
|
-
.div(holdings.totalAUMIncludingFees);
|
|
2533
|
-
totalIncentivesApy = totalIncentivesApy.add(weightedReserveAPY);
|
|
2534
|
-
}
|
|
2535
|
-
return {
|
|
2536
|
-
reserveFarmsIncentives: vaultReservesFarmsIncentives,
|
|
2537
|
-
totalIncentivesAPY: totalIncentivesApy,
|
|
2538
|
-
};
|
|
2539
|
-
}
|
|
2540
|
-
/// reads the pending rewards for a user in the vault farm
|
|
2541
|
-
/// @param user - the user address
|
|
2542
|
-
/// @param vault - the vault
|
|
2543
|
-
/// @returns a map of the pending rewards token mint and amount in lamports
|
|
2544
|
-
async getUserPendingRewardsInVaultFarm(user, vault) {
|
|
2545
|
-
const vaultState = await vault.getState();
|
|
2546
|
-
const hasFarm = await vault.hasFarm();
|
|
2547
|
-
if (!hasFarm) {
|
|
2548
|
-
return new Map();
|
|
2549
|
-
}
|
|
2550
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2551
|
-
const userState = await (0, dist_1.getUserStatePDA)(farmClient.getProgramID(), vaultState.vaultFarm, user);
|
|
2552
|
-
return (0, farm_utils_1.getUserPendingRewardsInFarm)(this.getConnection(), userState, vaultState.vaultFarm);
|
|
2553
|
-
}
|
|
2554
|
-
/// reads the pending rewards for a user in a delegated vault farm
|
|
2555
|
-
/// @param user - the user address
|
|
2556
|
-
/// @param vaultAddress - the address of the vault
|
|
2557
|
-
/// @returns a map of the pending rewards token mint and amount in lamports
|
|
2558
|
-
async getUserPendingRewardsInVaultDelegatedFarm(user, vaultAddress) {
|
|
2559
|
-
const delegatedFarm = await this.getDelegatedFarmForVault(vaultAddress);
|
|
2560
|
-
if (!delegatedFarm) {
|
|
2561
|
-
return new Map();
|
|
2562
|
-
}
|
|
2563
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2564
|
-
const userState = await this.computeUserStatePDAForUserInDelegatedVaultFarm(farmClient.getProgramID(), vaultAddress, delegatedFarm, user);
|
|
2565
|
-
return (0, farm_utils_1.getUserPendingRewardsInFarm)(this.getConnection(), userState, delegatedFarm);
|
|
2566
|
-
}
|
|
2567
|
-
/// gets the delegated farm for a vault
|
|
2568
|
-
async getDelegatedFarmForVault(vault) {
|
|
2569
|
-
const response = await fetch(`${utils_2.CDN_ENDPOINT}/resources.json`);
|
|
2570
|
-
if (!response.ok) {
|
|
2571
|
-
console.log(`Failed to fetch CDN for user pending rewards in vault delegated farm: ${response.statusText}`);
|
|
2572
|
-
return undefined;
|
|
2573
|
-
}
|
|
2574
|
-
const data = (await response.json());
|
|
2575
|
-
const delegatedVaultFarms = data['mainnet-beta']?.delegatedVaultFarms;
|
|
2576
|
-
if (!delegatedVaultFarms) {
|
|
2577
|
-
return undefined;
|
|
2578
|
-
}
|
|
2579
|
-
const delegatedFarmWithVault = delegatedVaultFarms.find((vaultWithFarm) => vaultWithFarm.vault === vault);
|
|
2580
|
-
if (!delegatedFarmWithVault) {
|
|
2581
|
-
return undefined;
|
|
2582
|
-
}
|
|
2583
|
-
return (0, kit_1.address)(delegatedFarmWithVault.farm);
|
|
2584
|
-
}
|
|
2585
|
-
/**
|
|
2586
|
-
* gets all the delegated farms addresses
|
|
2587
|
-
* @returns a list of delegated farms addresses
|
|
2588
|
-
*/
|
|
2589
|
-
async getAllDelegatedFarms() {
|
|
2590
|
-
const vaultsWithDelegatedFarm = await this.getVaultsWithDelegatedFarm();
|
|
2591
|
-
return Array.from(vaultsWithDelegatedFarm.values());
|
|
2592
|
-
}
|
|
2593
|
-
/**
|
|
2594
|
-
* This will return a map of the vault address and the delegated farm address for that vault
|
|
2595
|
-
* @returns a map of the vault address and the delegated farm address for that vault
|
|
2596
|
-
*/
|
|
2597
|
-
async getVaultsWithDelegatedFarm() {
|
|
2598
|
-
const response = await fetch(`${utils_2.CDN_ENDPOINT}/resources.json`);
|
|
2599
|
-
if (!response.ok) {
|
|
2600
|
-
console.log(`Failed to fetch CDN for get vaults with delegated farm`);
|
|
2601
|
-
return new Map();
|
|
2602
|
-
}
|
|
2603
|
-
const data = (await response.json());
|
|
2604
|
-
const delegatedVaultFarms = data['mainnet-beta']?.delegatedVaultFarms;
|
|
2605
|
-
if (!delegatedVaultFarms) {
|
|
2606
|
-
return new Map();
|
|
2607
|
-
}
|
|
2608
|
-
return new Map(delegatedVaultFarms.map((delegatedFarm) => [(0, kit_1.address)(delegatedFarm.vault), (0, kit_1.address)(delegatedFarm.farm)]));
|
|
2609
|
-
}
|
|
2610
|
-
/// reads the pending rewards for a user in the reserves farms of a vault
|
|
2611
|
-
/// @param user - the user address
|
|
2612
|
-
/// @param vault - the vault
|
|
2613
|
-
/// @param [vaultReservesMap] - the vault reserves map to get the reserves for; if not provided, the function will fetch the reserves
|
|
2614
|
-
/// @returns a map of the pending rewards token mint and amount in lamports
|
|
2615
|
-
async getUserPendingRewardsInVaultReservesFarms(user, vault, vaultReservesMap) {
|
|
2616
|
-
const vaultState = await vault.getState();
|
|
2617
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
2618
|
-
const vaultReserves = vaultState.vaultAllocationStrategy
|
|
2619
|
-
.map((allocationStrategy) => allocationStrategy.reserve)
|
|
2620
|
-
.filter((reserve) => reserve !== lib_1.DEFAULT_PUBLIC_KEY);
|
|
2621
|
-
const pendingRewardsPerToken = new Map();
|
|
2622
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2623
|
-
for (const reserveAddress of vaultReserves) {
|
|
2624
|
-
const reserveState = vaultReservesState.get(reserveAddress);
|
|
2625
|
-
if (!reserveState) {
|
|
2626
|
-
console.log(`Reserve to read farm incentives for not found: ${reserveAddress}`);
|
|
2627
|
-
continue;
|
|
2628
|
-
}
|
|
2629
|
-
if (reserveState.state.farmCollateral === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2630
|
-
continue;
|
|
2631
|
-
}
|
|
2632
|
-
const delegatee = await this.computeUserFarmStateDelegateePDAForUserInVault(farmClient.getProgramID(), vault.address, reserveAddress, user);
|
|
2633
|
-
const userState = await (0, dist_1.getUserStatePDA)(farmClient.getProgramID(), reserveState.state.farmCollateral, delegatee[0]);
|
|
2634
|
-
const pendingRewards = await (0, farm_utils_1.getUserPendingRewardsInFarm)(this.getConnection(), userState, reserveState.state.farmCollateral);
|
|
2635
|
-
pendingRewards.forEach((reward, token) => {
|
|
2636
|
-
const existingReward = pendingRewardsPerToken.get(token);
|
|
2637
|
-
if (existingReward) {
|
|
2638
|
-
pendingRewardsPerToken.set(token, existingReward.add(reward));
|
|
2639
|
-
}
|
|
2640
|
-
else {
|
|
2641
|
-
pendingRewardsPerToken.set(token, reward);
|
|
2642
|
-
}
|
|
2643
|
-
});
|
|
2644
|
-
}
|
|
2645
|
-
return pendingRewardsPerToken;
|
|
2646
|
-
}
|
|
2647
|
-
/// reads the pending rewards for a user in the vault farm, the reserves farms of the vault and the delegated vault farm
|
|
2648
|
-
/// @param user - the user address
|
|
2649
|
-
/// @param vault - the vault
|
|
2650
|
-
/// @param [vaultReservesMap] - the vault reserves map to get the reserves for; if not provided, the function will fetch the reserves
|
|
2651
|
-
/// @returns a struct containing the pending rewards in the vault farm, the reserves farms of the vault and the delegated vault farm, and the total pending rewards in lamports
|
|
2652
|
-
async getAllPendingRewardsForUserInVault(user, vault, vaultReservesMap) {
|
|
2653
|
-
const pendingRewardsInVaultFarm = await this.getUserPendingRewardsInVaultFarm(user, vault);
|
|
2654
|
-
const pendingRewardsInVaultReservesFarms = await this.getUserPendingRewardsInVaultReservesFarms(user, vault, vaultReservesMap);
|
|
2655
|
-
const pendingRewardsInVaultDelegatedFarm = await this.getUserPendingRewardsInVaultDelegatedFarm(user, vault.address);
|
|
2656
|
-
const totalPendingRewards = new Map();
|
|
2657
|
-
pendingRewardsInVaultFarm.forEach((reward, token) => {
|
|
2658
|
-
const existingReward = totalPendingRewards.get(token);
|
|
2659
|
-
if (existingReward) {
|
|
2660
|
-
totalPendingRewards.set(token, existingReward.add(reward));
|
|
2661
|
-
}
|
|
2662
|
-
else {
|
|
2663
|
-
totalPendingRewards.set(token, reward);
|
|
2664
|
-
}
|
|
2665
|
-
});
|
|
2666
|
-
pendingRewardsInVaultReservesFarms.forEach((reward, token) => {
|
|
2667
|
-
const existingReward = totalPendingRewards.get(token);
|
|
2668
|
-
if (existingReward) {
|
|
2669
|
-
totalPendingRewards.set(token, existingReward.add(reward));
|
|
2670
|
-
}
|
|
2671
|
-
else {
|
|
2672
|
-
totalPendingRewards.set(token, reward);
|
|
2673
|
-
}
|
|
2674
|
-
});
|
|
2675
|
-
pendingRewardsInVaultDelegatedFarm.forEach((reward, token) => {
|
|
2676
|
-
const existingReward = totalPendingRewards.get(token);
|
|
2677
|
-
if (existingReward) {
|
|
2678
|
-
totalPendingRewards.set(token, existingReward.add(reward));
|
|
2679
|
-
}
|
|
2680
|
-
else {
|
|
2681
|
-
totalPendingRewards.set(token, reward);
|
|
2682
|
-
}
|
|
2683
|
-
});
|
|
2684
|
-
return {
|
|
2685
|
-
pendingRewardsInVaultFarm,
|
|
2686
|
-
pendingRewardsInVaultReservesFarms,
|
|
2687
|
-
pendingRewardsInVaultDelegatedFarm,
|
|
2688
|
-
totalPendingRewards,
|
|
2689
|
-
};
|
|
2690
|
-
}
|
|
2691
|
-
/**
|
|
2692
|
-
* This function will return the instructions to claim the rewards for the farm of a vault, the delegated farm of the vault and the reserves farms of the vault
|
|
2693
|
-
* @param user - the user to claim the rewards
|
|
2694
|
-
* @param vault - the vault
|
|
2695
|
-
* @param [vaultReservesMap] - the vault reserves map to get the reserves for; if not provided, the function will fetch the reserves
|
|
2696
|
-
* @returns the instructions to claim the rewards for the farm of the vault, the delegated farm of the vault and the reserves farms of the vault
|
|
2697
|
-
*/
|
|
2698
|
-
async getClaimAllRewardsForVaultIxs(user, vault, vaultReservesMap) {
|
|
2699
|
-
const [vaultFarmIxs, delegatedFarmIxs, reservesFarmsIxs] = await Promise.all([
|
|
2700
|
-
this.getClaimVaultFarmRewardsIxs(user, vault),
|
|
2701
|
-
this.getClaimVaultDelegatedFarmRewardsIxs(user, vault),
|
|
2702
|
-
this.getClaimVaultReservesFarmsRewardsIxs(user, vault, vaultReservesMap),
|
|
2703
|
-
]);
|
|
2704
|
-
return [...new Set([...vaultFarmIxs, ...delegatedFarmIxs, ...reservesFarmsIxs])];
|
|
2705
|
-
}
|
|
2706
|
-
/**
|
|
2707
|
-
* This function will return the instructions to claim the rewards for the farm of a vault
|
|
2708
|
-
* @param user - the user to claim the rewards
|
|
2709
|
-
* @param vault - the vault
|
|
2710
|
-
* @returns the instructions to claim the rewards for the farm of the vault
|
|
2711
|
-
*/
|
|
2712
|
-
async getClaimVaultFarmRewardsIxs(user, vault) {
|
|
2713
|
-
const vaultState = await vault.getState();
|
|
2714
|
-
const hasFarm = await vault.hasFarm();
|
|
2715
|
-
if (!hasFarm) {
|
|
2716
|
-
return [];
|
|
2717
|
-
}
|
|
2718
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2719
|
-
const pendingRewardsInVaultFarm = await this.getUserPendingRewardsInVaultFarm(user.address, vault);
|
|
2720
|
-
// if there are no pending rewards of their total is 0 no ix is needed
|
|
2721
|
-
const totalPendingRewards = Array.from(pendingRewardsInVaultFarm.values()).reduce((acc, reward) => acc.add(reward), new decimal_js_1.default(0));
|
|
2722
|
-
if (totalPendingRewards.eq(0)) {
|
|
2723
|
-
return [];
|
|
2724
|
-
}
|
|
2725
|
-
return farmClient.claimForUserForFarmAllRewardsIx(user, vaultState.vaultFarm, false);
|
|
2726
|
-
}
|
|
2727
|
-
/**
|
|
2728
|
-
* This function will return the instructions to claim the rewards for the delegated farm of a vault
|
|
2729
|
-
* @param user - the user to claim the rewards
|
|
2730
|
-
* @param vault - the vault
|
|
2731
|
-
* @returns the instructions to claim the rewards for the delegated farm of the vault
|
|
2732
|
-
*/
|
|
2733
|
-
async getClaimVaultDelegatedFarmRewardsIxs(user, vault) {
|
|
2734
|
-
const delegatedFarm = await this.getDelegatedFarmForVault(vault.address);
|
|
2735
|
-
if (!delegatedFarm) {
|
|
2736
|
-
return [];
|
|
2737
|
-
}
|
|
2738
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2739
|
-
const delegatee = await this.computeDelegateeForUserInDelegatedFarm(farmClient.getProgramID(), vault.address, delegatedFarm, user.address);
|
|
2740
|
-
const userState = await (0, dist_1.getUserStatePDA)(farmClient.getProgramID(), delegatedFarm, delegatee);
|
|
2741
|
-
// check if the user state exists
|
|
2742
|
-
const userStateExists = await (0, kit_1.fetchEncodedAccount)(this.getConnection(), userState);
|
|
2743
|
-
if (!userStateExists.exists) {
|
|
2744
|
-
return [];
|
|
2745
|
-
}
|
|
2746
|
-
return farmClient.claimForUserForFarmAllRewardsIx(user, delegatedFarm, true, [delegatee]);
|
|
2747
|
-
}
|
|
2748
|
-
/**
|
|
2749
|
-
* This function will return the instructions to claim the rewards for the reserves farms of a vault
|
|
2750
|
-
* @param user - the user to claim the rewards
|
|
2751
|
-
* @param vault - the vault
|
|
2752
|
-
* @param [vaultReservesMap] - the vault reserves map to get the reserves for; if not provided, the function will fetch the reserves
|
|
2753
|
-
* @returns the instructions to claim the rewards for the reserves farms of the vault
|
|
2754
|
-
*/
|
|
2755
|
-
async getClaimVaultReservesFarmsRewardsIxs(user, vault, vaultReservesMap) {
|
|
2756
|
-
const vaultState = await vault.getState();
|
|
2757
|
-
const vaultReservesState = vaultReservesMap ? vaultReservesMap : await this.loadVaultReserves(vaultState);
|
|
2758
|
-
const vaultReserves = vaultState.vaultAllocationStrategy
|
|
2759
|
-
.map((allocationStrategy) => allocationStrategy.reserve)
|
|
2760
|
-
.filter((reserve) => reserve !== lib_1.DEFAULT_PUBLIC_KEY);
|
|
2761
|
-
const ixs = [];
|
|
2762
|
-
const farmClient = new farms_sdk_1.Farms(this.getConnection());
|
|
2763
|
-
for (const reserveAddress of vaultReserves) {
|
|
2764
|
-
const reserveState = vaultReservesState.get(reserveAddress);
|
|
2765
|
-
if (!reserveState) {
|
|
2766
|
-
console.log(`Reserve to read farm incentives for not found: ${reserveAddress}`);
|
|
2767
|
-
continue;
|
|
2768
|
-
}
|
|
2769
|
-
if (reserveState.state.farmCollateral === lib_1.DEFAULT_PUBLIC_KEY) {
|
|
2770
|
-
continue;
|
|
2771
|
-
}
|
|
2772
|
-
const delegatee = await this.computeUserFarmStateDelegateePDAForUserInVault(farmClient.getProgramID(), vault.address, reserveAddress, user.address);
|
|
2773
|
-
const userState = await (0, dist_1.getUserStatePDA)(farmClient.getProgramID(), reserveState.state.farmCollateral, delegatee[0]);
|
|
2774
|
-
const pendingRewards = await (0, farm_utils_1.getUserPendingRewardsInFarm)(this.getConnection(), userState, reserveState.state.farmCollateral);
|
|
2775
|
-
const totalPendingRewards = Array.from(pendingRewards.values()).reduce((acc, reward) => acc.add(reward), new decimal_js_1.default(0));
|
|
2776
|
-
if (totalPendingRewards.eq(0)) {
|
|
2777
|
-
continue;
|
|
2778
|
-
}
|
|
2779
|
-
const ix = await farmClient.claimForUserForFarmAllRewardsIx(user, reserveState.state.farmCollateral, true, [
|
|
2780
|
-
delegatee[0],
|
|
2781
|
-
]);
|
|
2782
|
-
ixs.push(...ix);
|
|
2783
|
-
}
|
|
2784
|
-
return ixs;
|
|
2785
|
-
}
|
|
2786
|
-
appendRemainingAccountsForVaultReserves(ix, vaultReserves, vaultReservesState) {
|
|
2787
|
-
let vaultReservesAccountMetas = [];
|
|
2788
|
-
let vaultReservesLendingMarkets = [];
|
|
2789
|
-
vaultReserves.forEach((reserve) => {
|
|
2790
|
-
const reserveState = vaultReservesState.get(reserve);
|
|
2791
|
-
if (reserveState === undefined) {
|
|
2792
|
-
throw new Error(`Reserve ${reserve} not found`);
|
|
2793
|
-
}
|
|
2794
|
-
vaultReservesAccountMetas = vaultReservesAccountMetas.concat([{ address: reserve, role: kit_1.AccountRole.WRITABLE }]);
|
|
2795
|
-
vaultReservesLendingMarkets = vaultReservesLendingMarkets.concat([
|
|
2796
|
-
{ address: reserveState.state.lendingMarket, role: kit_1.AccountRole.READONLY },
|
|
2797
|
-
]);
|
|
2798
|
-
});
|
|
2799
|
-
return {
|
|
2800
|
-
...ix,
|
|
2801
|
-
accounts: ix.accounts?.concat([...vaultReservesAccountMetas, ...vaultReservesLendingMarkets]),
|
|
2802
|
-
};
|
|
2803
|
-
}
|
|
2804
|
-
} // KaminoVaultClient
|
|
2805
|
-
exports.KaminoVaultClient = KaminoVaultClient;
|
|
2806
|
-
class KaminoVault {
|
|
2807
|
-
address;
|
|
2808
|
-
state;
|
|
2809
|
-
programId;
|
|
2810
|
-
client;
|
|
2811
|
-
vaultReservesStateCache;
|
|
2812
|
-
constructor(rpc, vaultAddress, state, programId = exports.kaminoVaultId, recentSlotDurationMs = lib_1.DEFAULT_RECENT_SLOT_DURATION_MS) {
|
|
2813
|
-
this.address = vaultAddress;
|
|
2814
|
-
this.state = state;
|
|
2815
|
-
this.programId = programId;
|
|
2816
|
-
this.client = new KaminoVaultClient(rpc, recentSlotDurationMs);
|
|
2817
|
-
}
|
|
2818
|
-
static loadWithClientAndState(client, vaultAddress, state) {
|
|
2819
|
-
const vault = new KaminoVault(client.getConnection(), vaultAddress);
|
|
2820
|
-
vault.state = state;
|
|
2821
|
-
vault.programId = client.getProgramID();
|
|
2822
|
-
vault.client = client;
|
|
2823
|
-
return vault;
|
|
2824
|
-
}
|
|
2825
|
-
async getState() {
|
|
2826
|
-
if (!this.state) {
|
|
2827
|
-
const res = await accounts_1.VaultState.fetch(this.client.getConnection(), this.address, this.programId);
|
|
2828
|
-
if (!res) {
|
|
2829
|
-
throw new Error('Invalid vault');
|
|
2830
|
-
}
|
|
2831
|
-
this.state = res;
|
|
2832
|
-
return res;
|
|
2833
|
-
}
|
|
2834
|
-
else {
|
|
2835
|
-
return this.state;
|
|
2836
|
-
}
|
|
2837
|
-
}
|
|
2838
|
-
async reloadVaultReserves() {
|
|
2839
|
-
this.vaultReservesStateCache = await this.client.loadVaultReserves(this.state);
|
|
2840
|
-
}
|
|
2841
|
-
async reloadState() {
|
|
2842
|
-
this.state = await accounts_1.VaultState.fetch(this.client.getConnection(), this.address, this.programId);
|
|
2843
|
-
if (!this.state) {
|
|
2844
|
-
throw new Error('Could not fetch vault');
|
|
2845
|
-
}
|
|
2846
|
-
return this.state;
|
|
2847
|
-
}
|
|
2848
|
-
async hasFarm() {
|
|
2849
|
-
const state = await this.getState();
|
|
2850
|
-
return state.vaultFarm !== lib_1.DEFAULT_PUBLIC_KEY;
|
|
2851
|
-
}
|
|
2852
|
-
/**
|
|
2853
|
-
* This will return an VaultHoldings object which contains the amount available (uninvested) in vault, total amount invested in reseves and a breakdown of the amount invested in each reserve
|
|
2854
|
-
* @returns an VaultHoldings object representing the amount available (uninvested) in vault, total amount invested in reseves and a breakdown of the amount invested in each reserve
|
|
2855
|
-
*/
|
|
2856
|
-
async getVaultHoldings() {
|
|
2857
|
-
if (!this.state || !this.vaultReservesStateCache) {
|
|
2858
|
-
await this.reloadState();
|
|
2859
|
-
await this.reloadVaultReserves();
|
|
2860
|
-
}
|
|
2861
|
-
return await this.client.getVaultHoldings(this.state, undefined, this.vaultReservesStateCache, undefined);
|
|
2862
|
-
}
|
|
2863
|
-
/**
|
|
2864
|
-
* This will return the a map between reserve pubkey and the allocation overview for the reserve
|
|
2865
|
-
* @returns a map between reserve pubkey and the allocation overview for the reserve
|
|
2866
|
-
*/
|
|
2867
|
-
async getVaultAllocations() {
|
|
2868
|
-
if (!this.state) {
|
|
2869
|
-
await this.reloadState();
|
|
2870
|
-
}
|
|
2871
|
-
return this.client.getVaultAllocations(this.state);
|
|
2872
|
-
}
|
|
2873
|
-
/**
|
|
2874
|
-
* This will return the APY of the vault based on the current invested amounts and the theoretical APY if all the available tokens were invested
|
|
2875
|
-
* @returns a struct containing actualAPY and theoreticalAPY for the vault
|
|
2876
|
-
*/
|
|
2877
|
-
async getAPYs(slot) {
|
|
2878
|
-
if (!this.state || !this.vaultReservesStateCache) {
|
|
2879
|
-
await this.reloadState();
|
|
2880
|
-
await this.reloadVaultReserves();
|
|
2881
|
-
}
|
|
2882
|
-
const latestSlot = slot ?? (await this.client.getConnection().getSlot({ commitment: 'confirmed' }).send());
|
|
2883
|
-
const actualApy = await this.client.getVaultActualAPY(this.state, latestSlot, this.vaultReservesStateCache);
|
|
2884
|
-
const theoreticalApy = await this.client.getVaultTheoreticalAPY(this.state, latestSlot, this.vaultReservesStateCache);
|
|
2885
|
-
return {
|
|
2886
|
-
actualAPY: actualApy,
|
|
2887
|
-
theoreticalAPY: theoreticalApy,
|
|
2888
|
-
};
|
|
2889
|
-
}
|
|
2890
|
-
/**
|
|
2891
|
-
* This method returns the exchange rate of the vault (tokens per share)
|
|
2892
|
-
* @returns - Decimal representing the exchange rate (tokens per share)
|
|
2893
|
-
*/
|
|
2894
|
-
async getExchangeRate(slot) {
|
|
2895
|
-
if (!this.state || !this.vaultReservesStateCache) {
|
|
2896
|
-
await this.reloadState();
|
|
2897
|
-
await this.reloadVaultReserves();
|
|
2898
|
-
}
|
|
2899
|
-
const latestSlot = slot ?? (await this.client.getConnection().getSlot({ commitment: 'confirmed' }).send());
|
|
2900
|
-
const tokensPerShare = await this.client.getTokensPerShareSingleVault(this.state, latestSlot);
|
|
2901
|
-
return tokensPerShare;
|
|
2902
|
-
}
|
|
2903
|
-
/**
|
|
2904
|
-
* This method returns the user shares balance for a given vault
|
|
2905
|
-
* @param user - user to calculate the shares balance for
|
|
2906
|
-
* @param vault - vault to calculate shares balance for
|
|
2907
|
-
* @returns - a struct of user share balance (staked in vault farm if the vault has a farm and unstaked) in decimal (not lamports)
|
|
2908
|
-
*/
|
|
2909
|
-
async getUserShares(user) {
|
|
2910
|
-
return this.client.getUserSharesBalanceSingleVault(user, this);
|
|
2911
|
-
}
|
|
2912
|
-
/**
|
|
2913
|
-
* This function creates instructions to deposit into a vault. It will also create ATA creation instructions for the vault shares that the user receives in return
|
|
2914
|
-
* @param user - user to deposit
|
|
2915
|
-
* @param tokenAmount - token amount to be deposited, in decimals (will be converted in lamports)
|
|
2916
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. Optional. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2917
|
-
* @param [farmState] - the state of the vault farm, if the vault has a farm. Optional. If not provided, it will be fetched
|
|
2918
|
-
* @returns - an instance of DepositIxs which contains the instructions to deposit in vault and the instructions to stake the shares in the farm if the vault has a farm
|
|
2919
|
-
*/
|
|
2920
|
-
async depositIxs(user, tokenAmount, vaultReservesMap, farmState) {
|
|
2921
|
-
if (vaultReservesMap) {
|
|
2922
|
-
this.vaultReservesStateCache = vaultReservesMap;
|
|
2923
|
-
}
|
|
2924
|
-
return this.client.depositIxs(user, this, tokenAmount, this.vaultReservesStateCache, farmState);
|
|
2925
|
-
}
|
|
2926
|
-
/**
|
|
2927
|
-
* This function will return the missing ATA creation instructions, as well as one or multiple withdraw instructions, based on how many reserves it's needed to withdraw from. This might have to be split in multiple transactions
|
|
2928
|
-
* @param user - user to withdraw
|
|
2929
|
-
* @param shareAmount - share amount to withdraw (in tokens, not lamports), in order to withdraw everything, any value > user share amount
|
|
2930
|
-
* @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault
|
|
2931
|
-
* @param [vaultReservesMap] - optional parameter; a hashmap from each reserve pubkey to the reserve state. If provided the function will be significantly faster as it will not have to fetch the reserves
|
|
2932
|
-
* @param [farmState] - the state of the vault farm, if the vault has a farm. Optional. If not provided, it will be fetched
|
|
2933
|
-
* @returns an array of instructions to create missing ATAs if needed and the withdraw instructions
|
|
2934
|
-
*/
|
|
2935
|
-
async withdrawIxs(user, shareAmount, slot, vaultReservesMap, farmState) {
|
|
2936
|
-
if (vaultReservesMap) {
|
|
2937
|
-
this.vaultReservesStateCache = vaultReservesMap;
|
|
2938
|
-
}
|
|
2939
|
-
const currentSlot = slot ?? (await this.client.getConnection().getSlot({ commitment: 'confirmed' }).send());
|
|
2940
|
-
return this.client.withdrawIxs(user, this, shareAmount, currentSlot, this.vaultReservesStateCache, farmState);
|
|
2941
|
-
}
|
|
2942
|
-
}
|
|
2943
|
-
exports.KaminoVault = KaminoVault;
|
|
2944
|
-
/**
|
|
2945
|
-
* Used to initialize a Kamino Vault
|
|
2946
|
-
*/
|
|
2947
|
-
class KaminoVaultConfig {
|
|
2948
|
-
/** The admin of the vault */
|
|
2949
|
-
admin;
|
|
2950
|
-
/** The token mint for the vault */
|
|
2951
|
-
tokenMint;
|
|
2952
|
-
/** The token mint program id */
|
|
2953
|
-
tokenMintProgramId;
|
|
2954
|
-
/** The performance fee rate of the vault, as percents, expressed as a decimal */
|
|
2955
|
-
performanceFeeRatePercentage;
|
|
2956
|
-
/** The management fee rate of the vault, as percents, expressed as a decimal */
|
|
2957
|
-
managementFeeRatePercentage;
|
|
2958
|
-
/** The name to be stored on chain for the vault (max 40 characters). */
|
|
2959
|
-
name;
|
|
2960
|
-
/** The symbol of the vault token to be stored (max 5 characters). E.g. USDC for a vault using USDC as token. */
|
|
2961
|
-
vaultTokenSymbol;
|
|
2962
|
-
/** The name of the vault token to be stored (max 10 characters), after the prefix `Kamino Vault <vaultTokenSymbol>`. E.g. USDC Vault for a vault using USDC as token. */
|
|
2963
|
-
vaultTokenName;
|
|
2964
|
-
constructor(args) {
|
|
2965
|
-
this.admin = args.admin;
|
|
2966
|
-
this.tokenMint = args.tokenMint;
|
|
2967
|
-
this.performanceFeeRatePercentage = args.performanceFeeRatePercentage;
|
|
2968
|
-
this.managementFeeRatePercentage = args.managementFeeRatePercentage;
|
|
2969
|
-
this.tokenMintProgramId = args.tokenMintProgramId;
|
|
2970
|
-
this.name = args.name;
|
|
2971
|
-
this.vaultTokenSymbol = args.vaultTokenSymbol;
|
|
2972
|
-
this.vaultTokenName = args.vaultTokenName;
|
|
2973
|
-
}
|
|
2974
|
-
getPerformanceFeeBps() {
|
|
2975
|
-
return this.performanceFeeRatePercentage.mul(100).toNumber();
|
|
2976
|
-
}
|
|
2977
|
-
getManagementFeeBps() {
|
|
2978
|
-
return this.managementFeeRatePercentage.mul(100).toNumber();
|
|
2979
|
-
}
|
|
2980
|
-
}
|
|
2981
|
-
exports.KaminoVaultConfig = KaminoVaultConfig;
|
|
2982
|
-
class ReserveAllocationConfig {
|
|
2983
|
-
reserve;
|
|
2984
|
-
targetAllocationWeight;
|
|
2985
|
-
allocationCapDecimal;
|
|
2986
|
-
constructor(reserve, targetAllocationWeight, allocationCapDecimal) {
|
|
2987
|
-
this.reserve = reserve;
|
|
2988
|
-
this.targetAllocationWeight = targetAllocationWeight;
|
|
2989
|
-
this.allocationCapDecimal = allocationCapDecimal;
|
|
2990
|
-
}
|
|
2991
|
-
getAllocationCapLamports() {
|
|
2992
|
-
return (0, utils_1.numberToLamportsDecimal)(this.allocationCapDecimal, this.reserve.state.liquidity.mintDecimals.toNumber());
|
|
2993
|
-
}
|
|
2994
|
-
getReserveState() {
|
|
2995
|
-
return this.reserve.state;
|
|
2996
|
-
}
|
|
2997
|
-
getReserveAddress() {
|
|
2998
|
-
return this.reserve.address;
|
|
2999
|
-
}
|
|
3000
|
-
}
|
|
3001
|
-
exports.ReserveAllocationConfig = ReserveAllocationConfig;
|
|
3002
|
-
async function getCTokenVaultPda(vaultAddress, reserveAddress, kaminoVaultProgramId) {
|
|
3003
|
-
return (await (0, kit_1.getProgramDerivedAddress)({
|
|
3004
|
-
seeds: [
|
|
3005
|
-
Buffer.from(CTOKEN_VAULT_SEED),
|
|
3006
|
-
addressEncoder.encode(vaultAddress),
|
|
3007
|
-
addressEncoder.encode(reserveAddress),
|
|
3008
|
-
],
|
|
3009
|
-
programAddress: kaminoVaultProgramId,
|
|
3010
|
-
}))[0];
|
|
3011
|
-
}
|
|
3012
|
-
async function getEventAuthorityPda(kaminoVaultProgramId) {
|
|
3013
|
-
return (await (0, kit_1.getProgramDerivedAddress)({
|
|
3014
|
-
seeds: [Buffer.from(EVENT_AUTHORITY_SEED)],
|
|
3015
|
-
programAddress: kaminoVaultProgramId,
|
|
3016
|
-
}))[0];
|
|
3017
|
-
}
|
|
3018
|
-
async function getKvaultGlobalConfigPda(kaminoVaultProgramId) {
|
|
3019
|
-
return (await (0, kit_1.getProgramDerivedAddress)({
|
|
3020
|
-
seeds: [Buffer.from(GLOBAL_CONFIG_STATE_SEED)],
|
|
3021
|
-
programAddress: kaminoVaultProgramId,
|
|
3022
|
-
}))[0];
|
|
3023
|
-
}
|
|
3024
|
-
async function getReserveWhitelistEntryPda(reserveAddress, kaminoVaultProgramId) {
|
|
3025
|
-
return (await (0, kit_1.getProgramDerivedAddress)({
|
|
3026
|
-
seeds: [Buffer.from(WHITELISTED_RESERVES_SEED), addressEncoder.encode(reserveAddress)],
|
|
3027
|
-
programAddress: kaminoVaultProgramId,
|
|
3028
|
-
}))[0];
|
|
3029
|
-
}
|
|
3030
|
-
async function getReserveWhitelistEntryIfExists(reserveAddress, rpc, kaminoVaultProgramId) {
|
|
3031
|
-
const reserveWhitelistEntry = await getReserveWhitelistEntryPda(reserveAddress, kaminoVaultProgramId);
|
|
3032
|
-
const reserveWhitelistEntryAccount = await (0, kit_1.fetchEncodedAccount)(rpc, reserveWhitelistEntry, {
|
|
3033
|
-
commitment: 'processed',
|
|
3034
|
-
});
|
|
3035
|
-
return reserveWhitelistEntryAccount.exists ? (0, kit_1.some)(reserveWhitelistEntry) : (0, kit_1.none)();
|
|
3036
|
-
}
|
|
3037
|
-
function parseVaultAdmin(vault, signer) {
|
|
3038
|
-
return signer ?? (0, signer_1.noopSigner)(vault.vaultAdminAuthority);
|
|
3039
|
-
}
|
|
3040
|
-
function parseVaultPendingAdmin(vault, signer) {
|
|
3041
|
-
return signer ?? (0, signer_1.noopSigner)(vault.pendingAdmin);
|
|
3042
|
-
}
|
|
3043
|
-
class VaultHoldings {
|
|
3044
|
-
available;
|
|
3045
|
-
invested;
|
|
3046
|
-
investedInReserves;
|
|
3047
|
-
pendingFees;
|
|
3048
|
-
totalAUMIncludingFees;
|
|
3049
|
-
constructor(params) {
|
|
3050
|
-
this.available = params.available;
|
|
3051
|
-
this.invested = params.invested;
|
|
3052
|
-
this.investedInReserves = params.investedInReserves;
|
|
3053
|
-
this.pendingFees = params.pendingFees;
|
|
3054
|
-
this.totalAUMIncludingFees = params.totalAUMIncludingFees;
|
|
3055
|
-
}
|
|
3056
|
-
asJSON() {
|
|
3057
|
-
return {
|
|
3058
|
-
available: this.available.toString(),
|
|
3059
|
-
invested: this.invested.toString(),
|
|
3060
|
-
totalAUMIncludingFees: this.totalAUMIncludingFees.toString(),
|
|
3061
|
-
pendingFees: this.pendingFees.toString(),
|
|
3062
|
-
investedInReserves: (0, utils_1.pubkeyHashMapToJson)(this.investedInReserves),
|
|
3063
|
-
};
|
|
3064
|
-
}
|
|
3065
|
-
print() {
|
|
3066
|
-
console.log('Holdings:');
|
|
3067
|
-
console.log(' Available:', this.available.toString());
|
|
3068
|
-
console.log(' Invested:', this.invested.toString());
|
|
3069
|
-
console.log(' Total AUM including fees:', this.totalAUMIncludingFees.toString());
|
|
3070
|
-
console.log(' Pending fees:', this.pendingFees.toString());
|
|
3071
|
-
console.log(' Invested in reserves:', (0, utils_1.pubkeyHashMapToJson)(this.investedInReserves));
|
|
3072
|
-
}
|
|
3073
|
-
}
|
|
3074
|
-
exports.VaultHoldings = VaultHoldings;
|
|
3075
|
-
//# sourceMappingURL=vault.js.map
|