@kamino-finance/kliquidity-sdk 6.0.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/README.md +462 -0
- package/dist/Kamino.d.ts +962 -0
- package/dist/Kamino.js +5116 -0
- package/dist/Kamino.js.map +1 -0
- package/dist/constants/DefaultStrategyConfig.d.ts +6 -0
- package/dist/constants/DefaultStrategyConfig.js +13 -0
- package/dist/constants/DefaultStrategyConfig.js.map +1 -0
- package/dist/constants/deposit_method.d.ts +2 -0
- package/dist/constants/deposit_method.js +6 -0
- package/dist/constants/deposit_method.js.map +1 -0
- package/dist/constants/frontend.d.ts +1 -0
- package/dist/constants/frontend.js +5 -0
- package/dist/constants/frontend.js.map +1 -0
- package/dist/constants/index.d.ts +3 -0
- package/dist/constants/index.js +20 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/constants/metadata.d.ts +3 -0
- package/dist/constants/metadata.js +7 -0
- package/dist/constants/metadata.js.map +1 -0
- package/dist/constants/numericalValues.d.ts +1 -0
- package/dist/constants/numericalValues.js +5 -0
- package/dist/constants/numericalValues.js.map +1 -0
- package/dist/constants/pubkeys.d.ts +10 -0
- package/dist/constants/pubkeys.js +14 -0
- package/dist/constants/pubkeys.js.map +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +23 -0
- package/dist/index.js.map +1 -0
- package/dist/kamino-client/accounts/CollateralInfos.d.ts +19 -0
- package/dist/kamino-client/accounts/CollateralInfos.js +96 -0
- package/dist/kamino-client/accounts/CollateralInfos.js.map +1 -0
- package/dist/kamino-client/accounts/GlobalConfig.d.ts +88 -0
- package/dist/kamino-client/accounts/GlobalConfig.js +218 -0
- package/dist/kamino-client/accounts/GlobalConfig.js.map +1 -0
- package/dist/kamino-client/accounts/PersonalPositionState.d.ts +83 -0
- package/dist/kamino-client/accounts/PersonalPositionState.js +156 -0
- package/dist/kamino-client/accounts/PersonalPositionState.js.map +1 -0
- package/dist/kamino-client/accounts/PoolState.d.ts +212 -0
- package/dist/kamino-client/accounts/PoolState.js +281 -0
- package/dist/kamino-client/accounts/PoolState.js.map +1 -0
- package/dist/kamino-client/accounts/Position.d.ts +47 -0
- package/dist/kamino-client/accounts/Position.js +146 -0
- package/dist/kamino-client/accounts/Position.js.map +1 -0
- package/dist/kamino-client/accounts/ProtocolPositionState.d.ts +79 -0
- package/dist/kamino-client/accounts/ProtocolPositionState.js +150 -0
- package/dist/kamino-client/accounts/ProtocolPositionState.js.map +1 -0
- package/dist/kamino-client/accounts/ScopeChainAccount.d.ts +18 -0
- package/dist/kamino-client/accounts/ScopeChainAccount.js +95 -0
- package/dist/kamino-client/accounts/ScopeChainAccount.js.map +1 -0
- package/dist/kamino-client/accounts/TermsSignature.d.ts +18 -0
- package/dist/kamino-client/accounts/TermsSignature.js +95 -0
- package/dist/kamino-client/accounts/TermsSignature.js.map +1 -0
- package/dist/kamino-client/accounts/Whirlpool.d.ts +75 -0
- package/dist/kamino-client/accounts/Whirlpool.js +192 -0
- package/dist/kamino-client/accounts/Whirlpool.js.map +1 -0
- package/dist/kamino-client/accounts/WhirlpoolStrategy.d.ts +317 -0
- package/dist/kamino-client/accounts/WhirlpoolStrategy.js +596 -0
- package/dist/kamino-client/accounts/WhirlpoolStrategy.js.map +1 -0
- package/dist/kamino-client/accounts/index.d.ts +20 -0
- package/dist/kamino-client/accounts/index.js +24 -0
- package/dist/kamino-client/accounts/index.js.map +1 -0
- package/dist/kamino-client/errors/anchor.d.ts +434 -0
- package/dist/kamino-client/errors/anchor.js +713 -0
- package/dist/kamino-client/errors/anchor.js.map +1 -0
- package/dist/kamino-client/errors/custom.d.ts +1258 -0
- package/dist/kamino-client/errors/custom.js +2054 -0
- package/dist/kamino-client/errors/custom.js.map +1 -0
- package/dist/kamino-client/errors/index.d.ts +5 -0
- package/dist/kamino-client/errors/index.js +70 -0
- package/dist/kamino-client/errors/index.js.map +1 -0
- package/dist/kamino-client/idl.json +7186 -0
- package/dist/kamino-client/instructions/addKaminoRewards.d.ts +17 -0
- package/dist/kamino-client/instructions/addKaminoRewards.js +55 -0
- package/dist/kamino-client/instructions/addKaminoRewards.js.map +1 -0
- package/dist/kamino-client/instructions/changePool.d.ts +12 -0
- package/dist/kamino-client/instructions/changePool.js +34 -0
- package/dist/kamino-client/instructions/changePool.js.map +1 -0
- package/dist/kamino-client/instructions/checkExpectedVaultsBalances.d.ts +13 -0
- package/dist/kamino-client/instructions/checkExpectedVaultsBalances.js +51 -0
- package/dist/kamino-client/instructions/checkExpectedVaultsBalances.js.map +1 -0
- package/dist/kamino-client/instructions/closeProgramAccount.d.ts +9 -0
- package/dist/kamino-client/instructions/closeProgramAccount.js +19 -0
- package/dist/kamino-client/instructions/closeProgramAccount.js.map +1 -0
- package/dist/kamino-client/instructions/closeStrategy.d.ts +49 -0
- package/dist/kamino-client/instructions/closeStrategy.js +79 -0
- package/dist/kamino-client/instructions/closeStrategy.js.map +1 -0
- package/dist/kamino-client/instructions/collectFeesAndRewards.d.ts +43 -0
- package/dist/kamino-client/instructions/collectFeesAndRewards.js +71 -0
- package/dist/kamino-client/instructions/collectFeesAndRewards.js.map +1 -0
- package/dist/kamino-client/instructions/deposit.d.ts +33 -0
- package/dist/kamino-client/instructions/deposit.js +79 -0
- package/dist/kamino-client/instructions/deposit.js.map +1 -0
- package/dist/kamino-client/instructions/depositAndInvest.d.ts +42 -0
- package/dist/kamino-client/instructions/depositAndInvest.js +95 -0
- package/dist/kamino-client/instructions/depositAndInvest.js.map +1 -0
- package/dist/kamino-client/instructions/emergencySwap.d.ts +35 -0
- package/dist/kamino-client/instructions/emergencySwap.js +70 -0
- package/dist/kamino-client/instructions/emergencySwap.js.map +1 -0
- package/dist/kamino-client/instructions/executiveWithdraw.d.ts +33 -0
- package/dist/kamino-client/instructions/executiveWithdraw.js +77 -0
- package/dist/kamino-client/instructions/executiveWithdraw.js.map +1 -0
- package/dist/kamino-client/instructions/flashSwapUnevenVaultsEnd.d.ts +40 -0
- package/dist/kamino-client/instructions/flashSwapUnevenVaultsEnd.js +83 -0
- package/dist/kamino-client/instructions/flashSwapUnevenVaultsEnd.js.map +1 -0
- package/dist/kamino-client/instructions/flashSwapUnevenVaultsStart.d.ts +41 -0
- package/dist/kamino-client/instructions/flashSwapUnevenVaultsStart.js +80 -0
- package/dist/kamino-client/instructions/flashSwapUnevenVaultsStart.js.map +1 -0
- package/dist/kamino-client/instructions/index.d.ts +72 -0
- package/dist/kamino-client/instructions/index.js +76 -0
- package/dist/kamino-client/instructions/index.js.map +1 -0
- package/dist/kamino-client/instructions/initializeCollateralInfo.d.ts +8 -0
- package/dist/kamino-client/instructions/initializeCollateralInfo.js +18 -0
- package/dist/kamino-client/instructions/initializeCollateralInfo.js.map +1 -0
- package/dist/kamino-client/instructions/initializeGlobalConfig.d.ts +7 -0
- package/dist/kamino-client/instructions/initializeGlobalConfig.js +17 -0
- package/dist/kamino-client/instructions/initializeGlobalConfig.js.map +1 -0
- package/dist/kamino-client/instructions/initializeKaminoReward.d.ts +20 -0
- package/dist/kamino-client/instructions/initializeKaminoReward.js +58 -0
- package/dist/kamino-client/instructions/initializeKaminoReward.js.map +1 -0
- package/dist/kamino-client/instructions/initializeSharesMetadata.d.ts +19 -0
- package/dist/kamino-client/instructions/initializeSharesMetadata.js +63 -0
- package/dist/kamino-client/instructions/initializeSharesMetadata.js.map +1 -0
- package/dist/kamino-client/instructions/initializeStrategy.d.ts +29 -0
- package/dist/kamino-client/instructions/initializeStrategy.js +67 -0
- package/dist/kamino-client/instructions/initializeStrategy.js.map +1 -0
- package/dist/kamino-client/instructions/insertCollateralInfo.d.ts +14 -0
- package/dist/kamino-client/instructions/insertCollateralInfo.js +52 -0
- package/dist/kamino-client/instructions/insertCollateralInfo.js.map +1 -0
- package/dist/kamino-client/instructions/invest.d.ts +30 -0
- package/dist/kamino-client/instructions/invest.js +52 -0
- package/dist/kamino-client/instructions/invest.js.map +1 -0
- package/dist/kamino-client/instructions/openLiquidityPosition.d.ts +46 -0
- package/dist/kamino-client/instructions/openLiquidityPosition.js +117 -0
- package/dist/kamino-client/instructions/openLiquidityPosition.js.map +1 -0
- package/dist/kamino-client/instructions/orcaSwap.d.ts +30 -0
- package/dist/kamino-client/instructions/orcaSwap.js +71 -0
- package/dist/kamino-client/instructions/orcaSwap.js.map +1 -0
- package/dist/kamino-client/instructions/permisionlessWithdrawFromTreasury.d.ts +11 -0
- package/dist/kamino-client/instructions/permisionlessWithdrawFromTreasury.js +25 -0
- package/dist/kamino-client/instructions/permisionlessWithdrawFromTreasury.js.map +1 -0
- package/dist/kamino-client/instructions/signTerms.d.ts +12 -0
- package/dist/kamino-client/instructions/signTerms.js +48 -0
- package/dist/kamino-client/instructions/signTerms.js.map +1 -0
- package/dist/kamino-client/instructions/singleTokenDepositAndInvestWithMin.d.ts +42 -0
- package/dist/kamino-client/instructions/singleTokenDepositAndInvestWithMin.js +95 -0
- package/dist/kamino-client/instructions/singleTokenDepositAndInvestWithMin.js.map +1 -0
- package/dist/kamino-client/instructions/singleTokenDepositWithMin.d.ts +33 -0
- package/dist/kamino-client/instructions/singleTokenDepositWithMin.js +79 -0
- package/dist/kamino-client/instructions/singleTokenDepositWithMin.js.map +1 -0
- package/dist/kamino-client/instructions/swapRewards.d.ts +37 -0
- package/dist/kamino-client/instructions/swapRewards.js +98 -0
- package/dist/kamino-client/instructions/swapRewards.js.map +1 -0
- package/dist/kamino-client/instructions/swapUnevenVaults.d.ts +42 -0
- package/dist/kamino-client/instructions/swapUnevenVaults.js +82 -0
- package/dist/kamino-client/instructions/swapUnevenVaults.js.map +1 -0
- package/dist/kamino-client/instructions/updateCollateralInfo.d.ts +14 -0
- package/dist/kamino-client/instructions/updateCollateralInfo.js +53 -0
- package/dist/kamino-client/instructions/updateCollateralInfo.js.map +1 -0
- package/dist/kamino-client/instructions/updateGlobalConfig.d.ts +13 -0
- package/dist/kamino-client/instructions/updateGlobalConfig.js +53 -0
- package/dist/kamino-client/instructions/updateGlobalConfig.js.map +1 -0
- package/dist/kamino-client/instructions/updateRewardMapping.d.ts +20 -0
- package/dist/kamino-client/instructions/updateRewardMapping.js +59 -0
- package/dist/kamino-client/instructions/updateRewardMapping.js.map +1 -0
- package/dist/kamino-client/instructions/updateSharesMetadata.d.ts +17 -0
- package/dist/kamino-client/instructions/updateSharesMetadata.js +61 -0
- package/dist/kamino-client/instructions/updateSharesMetadata.js.map +1 -0
- package/dist/kamino-client/instructions/updateStrategyConfig.d.ts +14 -0
- package/dist/kamino-client/instructions/updateStrategyConfig.js +53 -0
- package/dist/kamino-client/instructions/updateStrategyConfig.js.map +1 -0
- package/dist/kamino-client/instructions/updateTreasuryFeeVault.d.ts +17 -0
- package/dist/kamino-client/instructions/updateTreasuryFeeVault.js +57 -0
- package/dist/kamino-client/instructions/updateTreasuryFeeVault.js.map +1 -0
- package/dist/kamino-client/instructions/withdraw.d.ts +38 -0
- package/dist/kamino-client/instructions/withdraw.js +89 -0
- package/dist/kamino-client/instructions/withdraw.js.map +1 -0
- package/dist/kamino-client/instructions/withdrawFromTopup.d.ts +12 -0
- package/dist/kamino-client/instructions/withdrawFromTopup.js +47 -0
- package/dist/kamino-client/instructions/withdrawFromTopup.js.map +1 -0
- package/dist/kamino-client/instructions/withdrawFromTreasury.d.ts +18 -0
- package/dist/kamino-client/instructions/withdrawFromTreasury.js +57 -0
- package/dist/kamino-client/instructions/withdrawFromTreasury.js.map +1 -0
- package/dist/kamino-client/programId.d.ts +4 -0
- package/dist/kamino-client/programId.js +13 -0
- package/dist/kamino-client/programId.js.map +1 -0
- package/dist/kamino-client/types/BalanceStatus.d.ts +31 -0
- package/dist/kamino-client/types/BalanceStatus.js +102 -0
- package/dist/kamino-client/types/BalanceStatus.js.map +1 -0
- package/dist/kamino-client/types/BinAddLiquidityStrategy.d.ts +76 -0
- package/dist/kamino-client/types/BinAddLiquidityStrategy.js +162 -0
- package/dist/kamino-client/types/BinAddLiquidityStrategy.js.map +1 -0
- package/dist/kamino-client/types/CollateralInfo.d.ts +93 -0
- package/dist/kamino-client/types/CollateralInfo.js +152 -0
- package/dist/kamino-client/types/CollateralInfo.js.map +1 -0
- package/dist/kamino-client/types/CollateralInfoParams.d.ts +83 -0
- package/dist/kamino-client/types/CollateralInfoParams.js +140 -0
- package/dist/kamino-client/types/CollateralInfoParams.js.map +1 -0
- package/dist/kamino-client/types/CollateralTestToken.d.ts +369 -0
- package/dist/kamino-client/types/CollateralTestToken.js +778 -0
- package/dist/kamino-client/types/CollateralTestToken.js.map +1 -0
- package/dist/kamino-client/types/CreationStatus.d.ts +70 -0
- package/dist/kamino-client/types/CreationStatus.js +180 -0
- package/dist/kamino-client/types/CreationStatus.js.map +1 -0
- package/dist/kamino-client/types/DEX.d.ts +44 -0
- package/dist/kamino-client/types/DEX.js +128 -0
- package/dist/kamino-client/types/DEX.js.map +1 -0
- package/dist/kamino-client/types/DexSpecificPrice.d.ts +46 -0
- package/dist/kamino-client/types/DexSpecificPrice.js +116 -0
- package/dist/kamino-client/types/DexSpecificPrice.js.map +1 -0
- package/dist/kamino-client/types/DriftDirection.d.ts +31 -0
- package/dist/kamino-client/types/DriftDirection.js +102 -0
- package/dist/kamino-client/types/DriftDirection.js.map +1 -0
- package/dist/kamino-client/types/ExecutiveWithdrawAction.d.ts +44 -0
- package/dist/kamino-client/types/ExecutiveWithdrawAction.js +128 -0
- package/dist/kamino-client/types/ExecutiveWithdrawAction.js.map +1 -0
- package/dist/kamino-client/types/ExpanderStep.d.ts +38 -0
- package/dist/kamino-client/types/ExpanderStep.js +107 -0
- package/dist/kamino-client/types/ExpanderStep.js.map +1 -0
- package/dist/kamino-client/types/GlobalConfigOption.d.ts +304 -0
- package/dist/kamino-client/types/GlobalConfigOption.js +648 -0
- package/dist/kamino-client/types/GlobalConfigOption.js.map +1 -0
- package/dist/kamino-client/types/KaminoRewardInfo.d.ts +63 -0
- package/dist/kamino-client/types/KaminoRewardInfo.js +116 -0
- package/dist/kamino-client/types/KaminoRewardInfo.js.map +1 -0
- package/dist/kamino-client/types/LiquidityCalculationMode.d.ts +31 -0
- package/dist/kamino-client/types/LiquidityCalculationMode.js +102 -0
- package/dist/kamino-client/types/LiquidityCalculationMode.js.map +1 -0
- package/dist/kamino-client/types/MintingMethod.d.ts +31 -0
- package/dist/kamino-client/types/MintingMethod.js +102 -0
- package/dist/kamino-client/types/MintingMethod.js.map +1 -0
- package/dist/kamino-client/types/PeriodicRebalanceState.d.ts +22 -0
- package/dist/kamino-client/types/PeriodicRebalanceState.js +65 -0
- package/dist/kamino-client/types/PeriodicRebalanceState.js.map +1 -0
- package/dist/kamino-client/types/PositionRewardInfo.d.ts +27 -0
- package/dist/kamino-client/types/PositionRewardInfo.js +70 -0
- package/dist/kamino-client/types/PositionRewardInfo.js.map +1 -0
- package/dist/kamino-client/types/Price.d.ts +27 -0
- package/dist/kamino-client/types/Price.js +70 -0
- package/dist/kamino-client/types/Price.js.map +1 -0
- package/dist/kamino-client/types/RebalanceAction.d.ts +83 -0
- package/dist/kamino-client/types/RebalanceAction.js +150 -0
- package/dist/kamino-client/types/RebalanceAction.js.map +1 -0
- package/dist/kamino-client/types/RebalanceAutodriftParams.d.ts +75 -0
- package/dist/kamino-client/types/RebalanceAutodriftParams.js +100 -0
- package/dist/kamino-client/types/RebalanceAutodriftParams.js.map +1 -0
- package/dist/kamino-client/types/RebalanceAutodriftState.d.ts +88 -0
- package/dist/kamino-client/types/RebalanceAutodriftState.js +76 -0
- package/dist/kamino-client/types/RebalanceAutodriftState.js.map +1 -0
- package/dist/kamino-client/types/RebalanceAutodriftStep.d.ts +31 -0
- package/dist/kamino-client/types/RebalanceAutodriftStep.js +102 -0
- package/dist/kamino-client/types/RebalanceAutodriftStep.js.map +1 -0
- package/dist/kamino-client/types/RebalanceAutodriftWindow.d.ts +54 -0
- package/dist/kamino-client/types/RebalanceAutodriftWindow.js +98 -0
- package/dist/kamino-client/types/RebalanceAutodriftWindow.js.map +1 -0
- package/dist/kamino-client/types/RebalanceDriftParams.d.ts +50 -0
- package/dist/kamino-client/types/RebalanceDriftParams.js +92 -0
- package/dist/kamino-client/types/RebalanceDriftParams.js.map +1 -0
- package/dist/kamino-client/types/RebalanceDriftState.d.ts +40 -0
- package/dist/kamino-client/types/RebalanceDriftState.js +80 -0
- package/dist/kamino-client/types/RebalanceDriftState.js.map +1 -0
- package/dist/kamino-client/types/RebalanceDriftStep.d.ts +31 -0
- package/dist/kamino-client/types/RebalanceDriftStep.js +102 -0
- package/dist/kamino-client/types/RebalanceDriftStep.js.map +1 -0
- package/dist/kamino-client/types/RebalanceEffects.d.ts +39 -0
- package/dist/kamino-client/types/RebalanceEffects.js +108 -0
- package/dist/kamino-client/types/RebalanceEffects.js.map +1 -0
- package/dist/kamino-client/types/RebalanceExpanderState.d.ts +27 -0
- package/dist/kamino-client/types/RebalanceExpanderState.js +70 -0
- package/dist/kamino-client/types/RebalanceExpanderState.js.map +1 -0
- package/dist/kamino-client/types/RebalanceManualState.d.ts +14 -0
- package/dist/kamino-client/types/RebalanceManualState.js +51 -0
- package/dist/kamino-client/types/RebalanceManualState.js.map +1 -0
- package/dist/kamino-client/types/RebalancePricePercentageState.d.ts +27 -0
- package/dist/kamino-client/types/RebalancePricePercentageState.js +73 -0
- package/dist/kamino-client/types/RebalancePricePercentageState.js.map +1 -0
- package/dist/kamino-client/types/RebalancePricePercentageWithResetState.d.ts +27 -0
- package/dist/kamino-client/types/RebalancePricePercentageWithResetState.js +75 -0
- package/dist/kamino-client/types/RebalancePricePercentageWithResetState.js.map +1 -0
- package/dist/kamino-client/types/RebalanceRaw.d.ts +31 -0
- package/dist/kamino-client/types/RebalanceRaw.js +75 -0
- package/dist/kamino-client/types/RebalanceRaw.js.map +1 -0
- package/dist/kamino-client/types/RebalanceTakeProfitState.d.ts +33 -0
- package/dist/kamino-client/types/RebalanceTakeProfitState.js +62 -0
- package/dist/kamino-client/types/RebalanceTakeProfitState.js.map +1 -0
- package/dist/kamino-client/types/RebalanceTakeProfitStep.d.ts +44 -0
- package/dist/kamino-client/types/RebalanceTakeProfitStep.js +128 -0
- package/dist/kamino-client/types/RebalanceTakeProfitStep.js.map +1 -0
- package/dist/kamino-client/types/RebalanceTakeProfitToken.d.ts +31 -0
- package/dist/kamino-client/types/RebalanceTakeProfitToken.js +99 -0
- package/dist/kamino-client/types/RebalanceTakeProfitToken.js.map +1 -0
- package/dist/kamino-client/types/RebalanceType.d.ts +109 -0
- package/dist/kamino-client/types/RebalanceType.js +258 -0
- package/dist/kamino-client/types/RebalanceType.js.map +1 -0
- package/dist/kamino-client/types/ReferencePriceType.d.ts +31 -0
- package/dist/kamino-client/types/ReferencePriceType.js +102 -0
- package/dist/kamino-client/types/ReferencePriceType.js.map +1 -0
- package/dist/kamino-client/types/RemoveLiquidityMode.d.ts +59 -0
- package/dist/kamino-client/types/RemoveLiquidityMode.js +142 -0
- package/dist/kamino-client/types/RemoveLiquidityMode.js.map +1 -0
- package/dist/kamino-client/types/RewardInfo.d.ts +115 -0
- package/dist/kamino-client/types/RewardInfo.js +128 -0
- package/dist/kamino-client/types/RewardInfo.js.map +1 -0
- package/dist/kamino-client/types/ScopeConversionChain.d.ts +0 -0
- package/dist/kamino-client/types/ScopeConversionChain.js +2 -0
- package/dist/kamino-client/types/ScopeConversionChain.js.map +1 -0
- package/dist/kamino-client/types/ScopePriceIdTest.d.ts +915 -0
- package/dist/kamino-client/types/ScopePriceIdTest.js +1871 -0
- package/dist/kamino-client/types/ScopePriceIdTest.js.map +1 -0
- package/dist/kamino-client/types/SimulationPrice.d.ts +59 -0
- package/dist/kamino-client/types/SimulationPrice.js +142 -0
- package/dist/kamino-client/types/SimulationPrice.js.map +1 -0
- package/dist/kamino-client/types/StakingRateSource.d.ts +31 -0
- package/dist/kamino-client/types/StakingRateSource.js +102 -0
- package/dist/kamino-client/types/StakingRateSource.js.map +1 -0
- package/dist/kamino-client/types/StrategyConfigOption.d.ts +668 -0
- package/dist/kamino-client/types/StrategyConfigOption.js +1377 -0
- package/dist/kamino-client/types/StrategyConfigOption.js.map +1 -0
- package/dist/kamino-client/types/StrategyStatus.d.ts +70 -0
- package/dist/kamino-client/types/StrategyStatus.js +180 -0
- package/dist/kamino-client/types/StrategyStatus.js.map +1 -0
- package/dist/kamino-client/types/StrategyType.d.ts +44 -0
- package/dist/kamino-client/types/StrategyType.js +128 -0
- package/dist/kamino-client/types/StrategyType.js.map +1 -0
- package/dist/kamino-client/types/SwapLimit.d.ts +66 -0
- package/dist/kamino-client/types/SwapLimit.js +138 -0
- package/dist/kamino-client/types/SwapLimit.js.map +1 -0
- package/dist/kamino-client/types/UpdateCollateralInfoMode.d.ts +174 -0
- package/dist/kamino-client/types/UpdateCollateralInfoMode.js +388 -0
- package/dist/kamino-client/types/UpdateCollateralInfoMode.js.map +1 -0
- package/dist/kamino-client/types/WhirlpoolRewardInfo.d.ts +67 -0
- package/dist/kamino-client/types/WhirlpoolRewardInfo.js +92 -0
- package/dist/kamino-client/types/WhirlpoolRewardInfo.js.map +1 -0
- package/dist/kamino-client/types/WithdrawalCapAccumulatorAction.d.ts +31 -0
- package/dist/kamino-client/types/WithdrawalCapAccumulatorAction.js +102 -0
- package/dist/kamino-client/types/WithdrawalCapAccumulatorAction.js.map +1 -0
- package/dist/kamino-client/types/WithdrawalCaps.d.ts +37 -0
- package/dist/kamino-client/types/WithdrawalCaps.js +85 -0
- package/dist/kamino-client/types/WithdrawalCaps.js.map +1 -0
- package/dist/kamino-client/types/index.d.ts +160 -0
- package/dist/kamino-client/types/index.js +127 -0
- package/dist/kamino-client/types/index.js.map +1 -0
- package/dist/meteora_client/accounts/BinArray.d.ts +41 -0
- package/dist/meteora_client/accounts/BinArray.js +127 -0
- package/dist/meteora_client/accounts/BinArray.js.map +1 -0
- package/dist/meteora_client/accounts/BinArrayBitmapExtension.d.ts +31 -0
- package/dist/meteora_client/accounts/BinArrayBitmapExtension.js +110 -0
- package/dist/meteora_client/accounts/BinArrayBitmapExtension.js.map +1 -0
- package/dist/meteora_client/accounts/LbPair.d.ts +179 -0
- package/dist/meteora_client/accounts/LbPair.js +246 -0
- package/dist/meteora_client/accounts/LbPair.js.map +1 -0
- package/dist/meteora_client/accounts/Oracle.d.ts +34 -0
- package/dist/meteora_client/accounts/Oracle.js +109 -0
- package/dist/meteora_client/accounts/Oracle.js.map +1 -0
- package/dist/meteora_client/accounts/Position.d.ts +89 -0
- package/dist/meteora_client/accounts/Position.js +156 -0
- package/dist/meteora_client/accounts/Position.js.map +1 -0
- package/dist/meteora_client/accounts/PositionV2.d.ts +113 -0
- package/dist/meteora_client/accounts/PositionV2.js +177 -0
- package/dist/meteora_client/accounts/PositionV2.js.map +1 -0
- package/dist/meteora_client/accounts/PresetParameter.d.ts +75 -0
- package/dist/meteora_client/accounts/PresetParameter.js +140 -0
- package/dist/meteora_client/accounts/PresetParameter.js.map +1 -0
- package/dist/meteora_client/accounts/index.d.ts +14 -0
- package/dist/meteora_client/accounts/index.js +18 -0
- package/dist/meteora_client/accounts/index.js.map +1 -0
- package/dist/meteora_client/errors/anchor.d.ts +434 -0
- package/dist/meteora_client/errors/anchor.js +713 -0
- package/dist/meteora_client/errors/anchor.js.map +1 -0
- package/dist/meteora_client/errors/custom.d.ts +474 -0
- package/dist/meteora_client/errors/custom.js +778 -0
- package/dist/meteora_client/errors/custom.js.map +1 -0
- package/dist/meteora_client/errors/index.d.ts +5 -0
- package/dist/meteora_client/errors/index.js +70 -0
- package/dist/meteora_client/errors/index.js.map +1 -0
- package/dist/meteora_client/instructions/addLiquidity.d.ts +25 -0
- package/dist/meteora_client/instructions/addLiquidity.js +67 -0
- package/dist/meteora_client/instructions/addLiquidity.js.map +1 -0
- package/dist/meteora_client/instructions/addLiquidityByStrategy.d.ts +25 -0
- package/dist/meteora_client/instructions/addLiquidityByStrategy.js +67 -0
- package/dist/meteora_client/instructions/addLiquidityByStrategy.js.map +1 -0
- package/dist/meteora_client/instructions/addLiquidityByStrategyOneSide.d.ts +21 -0
- package/dist/meteora_client/instructions/addLiquidityByStrategyOneSide.js +63 -0
- package/dist/meteora_client/instructions/addLiquidityByStrategyOneSide.js.map +1 -0
- package/dist/meteora_client/instructions/addLiquidityByWeight.d.ts +25 -0
- package/dist/meteora_client/instructions/addLiquidityByWeight.js +67 -0
- package/dist/meteora_client/instructions/addLiquidityByWeight.js.map +1 -0
- package/dist/meteora_client/instructions/addLiquidityOneSide.d.ts +21 -0
- package/dist/meteora_client/instructions/addLiquidityOneSide.js +63 -0
- package/dist/meteora_client/instructions/addLiquidityOneSide.js.map +1 -0
- package/dist/meteora_client/instructions/addLiquidityOneSidePrecise.d.ts +21 -0
- package/dist/meteora_client/instructions/addLiquidityOneSidePrecise.js +63 -0
- package/dist/meteora_client/instructions/addLiquidityOneSidePrecise.js.map +1 -0
- package/dist/meteora_client/instructions/claimFee.d.ts +18 -0
- package/dist/meteora_client/instructions/claimFee.js +28 -0
- package/dist/meteora_client/instructions/claimFee.js.map +1 -0
- package/dist/meteora_client/instructions/claimReward.d.ts +20 -0
- package/dist/meteora_client/instructions/claimReward.js +55 -0
- package/dist/meteora_client/instructions/claimReward.js.map +1 -0
- package/dist/meteora_client/instructions/closePosition.d.ts +12 -0
- package/dist/meteora_client/instructions/closePosition.js +22 -0
- package/dist/meteora_client/instructions/closePosition.js.map +1 -0
- package/dist/meteora_client/instructions/closePresetParameter.d.ts +7 -0
- package/dist/meteora_client/instructions/closePresetParameter.js +17 -0
- package/dist/meteora_client/instructions/closePresetParameter.js.map +1 -0
- package/dist/meteora_client/instructions/fundReward.d.ts +20 -0
- package/dist/meteora_client/instructions/fundReward.js +59 -0
- package/dist/meteora_client/instructions/fundReward.js.map +1 -0
- package/dist/meteora_client/instructions/goToABin.d.ts +14 -0
- package/dist/meteora_client/instructions/goToABin.js +54 -0
- package/dist/meteora_client/instructions/goToABin.js.map +1 -0
- package/dist/meteora_client/instructions/increaseOracleLength.d.ts +14 -0
- package/dist/meteora_client/instructions/increaseOracleLength.js +49 -0
- package/dist/meteora_client/instructions/increaseOracleLength.js.map +1 -0
- package/dist/meteora_client/instructions/index.d.ts +84 -0
- package/dist/meteora_client/instructions/index.js +88 -0
- package/dist/meteora_client/instructions/index.js.map +1 -0
- package/dist/meteora_client/instructions/initializeBinArray.d.ts +13 -0
- package/dist/meteora_client/instructions/initializeBinArray.js +48 -0
- package/dist/meteora_client/instructions/initializeBinArray.js.map +1 -0
- package/dist/meteora_client/instructions/initializeBinArrayBitmapExtension.d.ts +10 -0
- package/dist/meteora_client/instructions/initializeBinArrayBitmapExtension.js +23 -0
- package/dist/meteora_client/instructions/initializeBinArrayBitmapExtension.js.map +1 -0
- package/dist/meteora_client/instructions/initializeLbPair.d.ts +23 -0
- package/dist/meteora_client/instructions/initializeLbPair.js +66 -0
- package/dist/meteora_client/instructions/initializeLbPair.js.map +1 -0
- package/dist/meteora_client/instructions/initializePermissionLbPair.d.ts +23 -0
- package/dist/meteora_client/instructions/initializePermissionLbPair.js +65 -0
- package/dist/meteora_client/instructions/initializePermissionLbPair.js.map +1 -0
- package/dist/meteora_client/instructions/initializePosition.d.ts +17 -0
- package/dist/meteora_client/instructions/initializePosition.js +56 -0
- package/dist/meteora_client/instructions/initializePosition.js.map +1 -0
- package/dist/meteora_client/instructions/initializePositionByOperator.d.ts +21 -0
- package/dist/meteora_client/instructions/initializePositionByOperator.js +61 -0
- package/dist/meteora_client/instructions/initializePositionByOperator.js.map +1 -0
- package/dist/meteora_client/instructions/initializePositionPda.d.ts +19 -0
- package/dist/meteora_client/instructions/initializePositionPda.js +57 -0
- package/dist/meteora_client/instructions/initializePositionPda.js.map +1 -0
- package/dist/meteora_client/instructions/initializePresetParameter.d.ts +13 -0
- package/dist/meteora_client/instructions/initializePresetParameter.js +49 -0
- package/dist/meteora_client/instructions/initializePresetParameter.js.map +1 -0
- package/dist/meteora_client/instructions/initializeReward.d.ts +20 -0
- package/dist/meteora_client/instructions/initializeReward.js +59 -0
- package/dist/meteora_client/instructions/initializeReward.js.map +1 -0
- package/dist/meteora_client/instructions/migrateBinArray.d.ts +5 -0
- package/dist/meteora_client/instructions/migrateBinArray.js +15 -0
- package/dist/meteora_client/instructions/migrateBinArray.js.map +1 -0
- package/dist/meteora_client/instructions/migratePosition.d.ts +14 -0
- package/dist/meteora_client/instructions/migratePosition.js +24 -0
- package/dist/meteora_client/instructions/migratePosition.js.map +1 -0
- package/dist/meteora_client/instructions/removeAllLiquidity.d.ts +20 -0
- package/dist/meteora_client/instructions/removeAllLiquidity.js +34 -0
- package/dist/meteora_client/instructions/removeAllLiquidity.js.map +1 -0
- package/dist/meteora_client/instructions/removeLiquidity.d.ts +25 -0
- package/dist/meteora_client/instructions/removeLiquidity.js +67 -0
- package/dist/meteora_client/instructions/removeLiquidity.js.map +1 -0
- package/dist/meteora_client/instructions/removeLiquidityByRange.d.ts +26 -0
- package/dist/meteora_client/instructions/removeLiquidityByRange.js +70 -0
- package/dist/meteora_client/instructions/removeLiquidityByRange.js.map +1 -0
- package/dist/meteora_client/instructions/setActivationSlot.d.ts +11 -0
- package/dist/meteora_client/instructions/setActivationSlot.js +46 -0
- package/dist/meteora_client/instructions/setActivationSlot.js.map +1 -0
- package/dist/meteora_client/instructions/setLockReleaseSlot.d.ts +14 -0
- package/dist/meteora_client/instructions/setLockReleaseSlot.js +49 -0
- package/dist/meteora_client/instructions/setLockReleaseSlot.js.map +1 -0
- package/dist/meteora_client/instructions/setPreActivationSlotDuration.d.ts +10 -0
- package/dist/meteora_client/instructions/setPreActivationSlotDuration.js +46 -0
- package/dist/meteora_client/instructions/setPreActivationSlotDuration.js.map +1 -0
- package/dist/meteora_client/instructions/setPreActivationSwapAddress.d.ts +10 -0
- package/dist/meteora_client/instructions/setPreActivationSwapAddress.js +48 -0
- package/dist/meteora_client/instructions/setPreActivationSwapAddress.js.map +1 -0
- package/dist/meteora_client/instructions/swap.d.ts +25 -0
- package/dist/meteora_client/instructions/swap.js +67 -0
- package/dist/meteora_client/instructions/swap.js.map +1 -0
- package/dist/meteora_client/instructions/togglePairStatus.d.ts +6 -0
- package/dist/meteora_client/instructions/togglePairStatus.js +16 -0
- package/dist/meteora_client/instructions/togglePairStatus.js.map +1 -0
- package/dist/meteora_client/instructions/updateFeeOwner.d.ts +7 -0
- package/dist/meteora_client/instructions/updateFeeOwner.js +17 -0
- package/dist/meteora_client/instructions/updateFeeOwner.js.map +1 -0
- package/dist/meteora_client/instructions/updateFeeParameters.d.ts +13 -0
- package/dist/meteora_client/instructions/updateFeeParameters.js +49 -0
- package/dist/meteora_client/instructions/updateFeeParameters.js.map +1 -0
- package/dist/meteora_client/instructions/updateFeesAndRewards.d.ts +9 -0
- package/dist/meteora_client/instructions/updateFeesAndRewards.js +19 -0
- package/dist/meteora_client/instructions/updateFeesAndRewards.js.map +1 -0
- package/dist/meteora_client/instructions/updatePositionOperator.d.ts +12 -0
- package/dist/meteora_client/instructions/updatePositionOperator.js +48 -0
- package/dist/meteora_client/instructions/updatePositionOperator.js.map +1 -0
- package/dist/meteora_client/instructions/updateRewardDuration.d.ts +15 -0
- package/dist/meteora_client/instructions/updateRewardDuration.js +53 -0
- package/dist/meteora_client/instructions/updateRewardDuration.js.map +1 -0
- package/dist/meteora_client/instructions/updateRewardFunder.d.ts +14 -0
- package/dist/meteora_client/instructions/updateRewardFunder.js +52 -0
- package/dist/meteora_client/instructions/updateRewardFunder.js.map +1 -0
- package/dist/meteora_client/instructions/updateWhitelistedWallet.d.ts +10 -0
- package/dist/meteora_client/instructions/updateWhitelistedWallet.js +46 -0
- package/dist/meteora_client/instructions/updateWhitelistedWallet.js.map +1 -0
- package/dist/meteora_client/instructions/withdrawIneligibleReward.d.ts +18 -0
- package/dist/meteora_client/instructions/withdrawIneligibleReward.js +53 -0
- package/dist/meteora_client/instructions/withdrawIneligibleReward.js.map +1 -0
- package/dist/meteora_client/instructions/withdrawProtocolFee.d.ts +19 -0
- package/dist/meteora_client/instructions/withdrawProtocolFee.js +54 -0
- package/dist/meteora_client/instructions/withdrawProtocolFee.js.map +1 -0
- package/dist/meteora_client/programId.d.ts +5 -0
- package/dist/meteora_client/programId.js +15 -0
- package/dist/meteora_client/programId.js.map +1 -0
- package/dist/meteora_client/types/AddLiquiditySingleSidePreciseParameter.d.ts +33 -0
- package/dist/meteora_client/types/AddLiquiditySingleSidePreciseParameter.js +74 -0
- package/dist/meteora_client/types/AddLiquiditySingleSidePreciseParameter.js.map +1 -0
- package/dist/meteora_client/types/Bin.d.ts +89 -0
- package/dist/meteora_client/types/Bin.js +115 -0
- package/dist/meteora_client/types/Bin.js.map +1 -0
- package/dist/meteora_client/types/BinLiquidityDistribution.d.ts +40 -0
- package/dist/meteora_client/types/BinLiquidityDistribution.js +75 -0
- package/dist/meteora_client/types/BinLiquidityDistribution.js.map +1 -0
- package/dist/meteora_client/types/BinLiquidityDistributionByWeight.d.ts +32 -0
- package/dist/meteora_client/types/BinLiquidityDistributionByWeight.js +66 -0
- package/dist/meteora_client/types/BinLiquidityDistributionByWeight.js.map +1 -0
- package/dist/meteora_client/types/BinLiquidityReduction.d.ts +26 -0
- package/dist/meteora_client/types/BinLiquidityReduction.js +66 -0
- package/dist/meteora_client/types/BinLiquidityReduction.js.map +1 -0
- package/dist/meteora_client/types/CompressedBinDepositAmount.d.ts +26 -0
- package/dist/meteora_client/types/CompressedBinDepositAmount.js +66 -0
- package/dist/meteora_client/types/CompressedBinDepositAmount.js.map +1 -0
- package/dist/meteora_client/types/FeeInfo.d.ts +37 -0
- package/dist/meteora_client/types/FeeInfo.js +85 -0
- package/dist/meteora_client/types/FeeInfo.js.map +1 -0
- package/dist/meteora_client/types/FeeParameter.d.ts +32 -0
- package/dist/meteora_client/types/FeeParameter.js +66 -0
- package/dist/meteora_client/types/FeeParameter.js.map +1 -0
- package/dist/meteora_client/types/InitPermissionPairIx.d.ts +47 -0
- package/dist/meteora_client/types/InitPermissionPairIx.js +97 -0
- package/dist/meteora_client/types/InitPermissionPairIx.js.map +1 -0
- package/dist/meteora_client/types/InitPresetParametersIx.d.ts +96 -0
- package/dist/meteora_client/types/InitPresetParametersIx.js +117 -0
- package/dist/meteora_client/types/InitPresetParametersIx.js.map +1 -0
- package/dist/meteora_client/types/LayoutVersion.d.ts +31 -0
- package/dist/meteora_client/types/LayoutVersion.js +99 -0
- package/dist/meteora_client/types/LayoutVersion.js.map +1 -0
- package/dist/meteora_client/types/LiquidityOneSideParameter.d.ts +55 -0
- package/dist/meteora_client/types/LiquidityOneSideParameter.js +86 -0
- package/dist/meteora_client/types/LiquidityOneSideParameter.js.map +1 -0
- package/dist/meteora_client/types/LiquidityParameter.d.ts +49 -0
- package/dist/meteora_client/types/LiquidityParameter.js +80 -0
- package/dist/meteora_client/types/LiquidityParameter.js.map +1 -0
- package/dist/meteora_client/types/LiquidityParameterByStrategy.d.ts +103 -0
- package/dist/meteora_client/types/LiquidityParameterByStrategy.js +92 -0
- package/dist/meteora_client/types/LiquidityParameterByStrategy.js.map +1 -0
- package/dist/meteora_client/types/LiquidityParameterByStrategyOneSide.d.ts +95 -0
- package/dist/meteora_client/types/LiquidityParameterByStrategyOneSide.js +86 -0
- package/dist/meteora_client/types/LiquidityParameterByStrategyOneSide.js.map +1 -0
- package/dist/meteora_client/types/LiquidityParameterByWeight.d.ts +63 -0
- package/dist/meteora_client/types/LiquidityParameterByWeight.js +92 -0
- package/dist/meteora_client/types/LiquidityParameterByWeight.js.map +1 -0
- package/dist/meteora_client/types/Observation.d.ts +41 -0
- package/dist/meteora_client/types/Observation.js +79 -0
- package/dist/meteora_client/types/Observation.js.map +1 -0
- package/dist/meteora_client/types/PairStatus.d.ts +31 -0
- package/dist/meteora_client/types/PairStatus.js +102 -0
- package/dist/meteora_client/types/PairStatus.js.map +1 -0
- package/dist/meteora_client/types/PairType.d.ts +31 -0
- package/dist/meteora_client/types/PairType.js +102 -0
- package/dist/meteora_client/types/PairType.js.map +1 -0
- package/dist/meteora_client/types/ProtocolFee.d.ts +27 -0
- package/dist/meteora_client/types/ProtocolFee.js +70 -0
- package/dist/meteora_client/types/ProtocolFee.js.map +1 -0
- package/dist/meteora_client/types/RewardInfo.d.ts +83 -0
- package/dist/meteora_client/types/RewardInfo.js +112 -0
- package/dist/meteora_client/types/RewardInfo.js.map +1 -0
- package/dist/meteora_client/types/Rounding.d.ts +31 -0
- package/dist/meteora_client/types/Rounding.js +99 -0
- package/dist/meteora_client/types/Rounding.js.map +1 -0
- package/dist/meteora_client/types/StaticParameters.d.ts +97 -0
- package/dist/meteora_client/types/StaticParameters.js +118 -0
- package/dist/meteora_client/types/StaticParameters.js.map +1 -0
- package/dist/meteora_client/types/StrategyParameters.d.ts +84 -0
- package/dist/meteora_client/types/StrategyParameters.js +82 -0
- package/dist/meteora_client/types/StrategyParameters.js.map +1 -0
- package/dist/meteora_client/types/StrategyType.d.ts +122 -0
- package/dist/meteora_client/types/StrategyType.js +284 -0
- package/dist/meteora_client/types/StrategyType.js.map +1 -0
- package/dist/meteora_client/types/UserRewardInfo.d.ts +27 -0
- package/dist/meteora_client/types/UserRewardInfo.js +73 -0
- package/dist/meteora_client/types/UserRewardInfo.js.map +1 -0
- package/dist/meteora_client/types/VariableParameters.d.ts +75 -0
- package/dist/meteora_client/types/VariableParameters.js +98 -0
- package/dist/meteora_client/types/VariableParameters.js.map +1 -0
- package/dist/meteora_client/types/index.d.ts +67 -0
- package/dist/meteora_client/types/index.js +81 -0
- package/dist/meteora_client/types/index.js.map +1 -0
- package/dist/models/EnrichedScopePrice.d.ts +28 -0
- package/dist/models/EnrichedScopePrice.js +3 -0
- package/dist/models/EnrichedScopePrice.js.map +1 -0
- package/dist/models/Holdings.d.ts +13 -0
- package/dist/models/Holdings.js +3 -0
- package/dist/models/Holdings.js.map +1 -0
- package/dist/models/KaminoPosition.d.ts +10 -0
- package/dist/models/KaminoPosition.js +3 -0
- package/dist/models/KaminoPosition.js.map +1 -0
- package/dist/models/KaminoStrategyWithShareMint.d.ts +8 -0
- package/dist/models/KaminoStrategyWithShareMint.js +3 -0
- package/dist/models/KaminoStrategyWithShareMint.js.map +1 -0
- package/dist/models/KaminoToken.d.ts +5 -0
- package/dist/models/KaminoToken.js +3 -0
- package/dist/models/KaminoToken.js.map +1 -0
- package/dist/models/LbPairWithAddress.d.ts +7 -0
- package/dist/models/LbPairWithAddress.js +3 -0
- package/dist/models/LbPairWithAddress.js.map +1 -0
- package/dist/models/MultipleAccountsResponse.d.ts +42 -0
- package/dist/models/MultipleAccountsResponse.js +3 -0
- package/dist/models/MultipleAccountsResponse.js.map +1 -0
- package/dist/models/PoolSimulationResponseData.d.ts +27 -0
- package/dist/models/PoolSimulationResponseData.js +3 -0
- package/dist/models/PoolSimulationResponseData.js.map +1 -0
- package/dist/models/PriceData.d.ts +15 -0
- package/dist/models/PriceData.js +3 -0
- package/dist/models/PriceData.js.map +1 -0
- package/dist/models/RaydiumPoolWithAddress.d.ts +7 -0
- package/dist/models/RaydiumPoolWithAddress.js +3 -0
- package/dist/models/RaydiumPoolWithAddress.js.map +1 -0
- package/dist/models/ShareData.d.ts +15 -0
- package/dist/models/ShareData.js +25 -0
- package/dist/models/ShareData.js.map +1 -0
- package/dist/models/StrategyBalances.d.ts +14 -0
- package/dist/models/StrategyBalances.js +3 -0
- package/dist/models/StrategyBalances.js.map +1 -0
- package/dist/models/StrategyHolder.d.ts +6 -0
- package/dist/models/StrategyHolder.js +3 -0
- package/dist/models/StrategyHolder.js.map +1 -0
- package/dist/models/StrategyPrices.d.ts +10 -0
- package/dist/models/StrategyPrices.js +3 -0
- package/dist/models/StrategyPrices.js.map +1 -0
- package/dist/models/StrategyProgramAddress.d.ts +13 -0
- package/dist/models/StrategyProgramAddress.js +3 -0
- package/dist/models/StrategyProgramAddress.js.map +1 -0
- package/dist/models/StrategyVaultBalances.d.ts +5 -0
- package/dist/models/StrategyVaultBalances.js +3 -0
- package/dist/models/StrategyVaultBalances.js.map +1 -0
- package/dist/models/StrategyVaultTokens.d.ts +12 -0
- package/dist/models/StrategyVaultTokens.js +3 -0
- package/dist/models/StrategyVaultTokens.js.map +1 -0
- package/dist/models/StrategyWithAddress.d.ts +7 -0
- package/dist/models/StrategyWithAddress.js +3 -0
- package/dist/models/StrategyWithAddress.js.map +1 -0
- package/dist/models/StrategyWithPendingFees.d.ts +6 -0
- package/dist/models/StrategyWithPendingFees.js +3 -0
- package/dist/models/StrategyWithPendingFees.js.map +1 -0
- package/dist/models/TokenAmounts.d.ts +5 -0
- package/dist/models/TokenAmounts.js +3 -0
- package/dist/models/TokenAmounts.js.map +1 -0
- package/dist/models/TreasuryFeeVault.d.ts +7 -0
- package/dist/models/TreasuryFeeVault.js +3 -0
- package/dist/models/TreasuryFeeVault.js.map +1 -0
- package/dist/models/WhirlpoolWithAddress.d.ts +7 -0
- package/dist/models/WhirlpoolWithAddress.js +3 -0
- package/dist/models/WhirlpoolWithAddress.js.map +1 -0
- package/dist/models/index.d.ts +19 -0
- package/dist/models/index.js +36 -0
- package/dist/models/index.js.map +1 -0
- package/dist/raydium_client/accounts/AmmConfig.d.ts +46 -0
- package/dist/raydium_client/accounts/AmmConfig.js +145 -0
- package/dist/raydium_client/accounts/AmmConfig.js.map +1 -0
- package/dist/raydium_client/accounts/ObservationState.d.ts +29 -0
- package/dist/raydium_client/accounts/ObservationState.js +116 -0
- package/dist/raydium_client/accounts/ObservationState.js.map +1 -0
- package/dist/raydium_client/accounts/OperationState.d.ts +24 -0
- package/dist/raydium_client/accounts/OperationState.js +106 -0
- package/dist/raydium_client/accounts/OperationState.js.map +1 -0
- package/dist/raydium_client/accounts/PersonalPositionState.d.ts +53 -0
- package/dist/raydium_client/accounts/PersonalPositionState.js +156 -0
- package/dist/raydium_client/accounts/PersonalPositionState.js.map +1 -0
- package/dist/raydium_client/accounts/PoolState.d.ts +128 -0
- package/dist/raydium_client/accounts/PoolState.js +281 -0
- package/dist/raydium_client/accounts/PoolState.js.map +1 -0
- package/dist/raydium_client/accounts/ProtocolPositionState.d.ts +49 -0
- package/dist/raydium_client/accounts/ProtocolPositionState.js +150 -0
- package/dist/raydium_client/accounts/ProtocolPositionState.js.map +1 -0
- package/dist/raydium_client/accounts/TickArrayBitmapExtension.d.ts +25 -0
- package/dist/raydium_client/accounts/TickArrayBitmapExtension.js +110 -0
- package/dist/raydium_client/accounts/TickArrayBitmapExtension.js.map +1 -0
- package/dist/raydium_client/accounts/TickArrayState.d.ts +31 -0
- package/dist/raydium_client/accounts/TickArrayState.js +117 -0
- package/dist/raydium_client/accounts/TickArrayState.js.map +1 -0
- package/dist/raydium_client/accounts/index.d.ts +16 -0
- package/dist/raydium_client/accounts/index.js +20 -0
- package/dist/raydium_client/accounts/index.js.map +1 -0
- package/dist/raydium_client/errors/anchor.d.ts +434 -0
- package/dist/raydium_client/errors/anchor.js +713 -0
- package/dist/raydium_client/errors/anchor.js.map +1 -0
- package/dist/raydium_client/errors/custom.d.ts +338 -0
- package/dist/raydium_client/errors/custom.js +556 -0
- package/dist/raydium_client/errors/custom.js.map +1 -0
- package/dist/raydium_client/errors/index.d.ts +5 -0
- package/dist/raydium_client/errors/index.js +70 -0
- package/dist/raydium_client/errors/index.js.map +1 -0
- package/dist/raydium_client/index.d.ts +4 -0
- package/dist/raydium_client/index.js +21 -0
- package/dist/raydium_client/index.js.map +1 -0
- package/dist/raydium_client/instructions/closePosition.d.ts +10 -0
- package/dist/raydium_client/instructions/closePosition.js +20 -0
- package/dist/raydium_client/instructions/closePosition.js.map +1 -0
- package/dist/raydium_client/instructions/collectFundFee.d.ts +21 -0
- package/dist/raydium_client/instructions/collectFundFee.js +67 -0
- package/dist/raydium_client/instructions/collectFundFee.js.map +1 -0
- package/dist/raydium_client/instructions/collectProtocolFee.d.ts +21 -0
- package/dist/raydium_client/instructions/collectProtocolFee.js +67 -0
- package/dist/raydium_client/instructions/collectProtocolFee.js.map +1 -0
- package/dist/raydium_client/instructions/collectRemainingRewards.d.ts +16 -0
- package/dist/raydium_client/instructions/collectRemainingRewards.js +52 -0
- package/dist/raydium_client/instructions/collectRemainingRewards.js.map +1 -0
- package/dist/raydium_client/instructions/createAmmConfig.d.ts +15 -0
- package/dist/raydium_client/instructions/createAmmConfig.js +57 -0
- package/dist/raydium_client/instructions/createAmmConfig.js.map +1 -0
- package/dist/raydium_client/instructions/createOperationAccount.d.ts +7 -0
- package/dist/raydium_client/instructions/createOperationAccount.js +17 -0
- package/dist/raydium_client/instructions/createOperationAccount.js.map +1 -0
- package/dist/raydium_client/instructions/createPool.d.ts +23 -0
- package/dist/raydium_client/instructions/createPool.js +61 -0
- package/dist/raydium_client/instructions/createPool.js.map +1 -0
- package/dist/raydium_client/instructions/decreaseLiquidity.d.ts +23 -0
- package/dist/raydium_client/instructions/decreaseLiquidity.js +70 -0
- package/dist/raydium_client/instructions/decreaseLiquidity.js.map +1 -0
- package/dist/raydium_client/instructions/decreaseLiquidityV2.d.ts +27 -0
- package/dist/raydium_client/instructions/decreaseLiquidityV2.js +74 -0
- package/dist/raydium_client/instructions/decreaseLiquidityV2.js.map +1 -0
- package/dist/raydium_client/instructions/increaseLiquidity.d.ts +23 -0
- package/dist/raydium_client/instructions/increaseLiquidity.js +62 -0
- package/dist/raydium_client/instructions/increaseLiquidity.js.map +1 -0
- package/dist/raydium_client/instructions/increaseLiquidityV2.d.ts +27 -0
- package/dist/raydium_client/instructions/increaseLiquidityV2.js +67 -0
- package/dist/raydium_client/instructions/increaseLiquidityV2.js.map +1 -0
- package/dist/raydium_client/instructions/index.d.ts +46 -0
- package/dist/raydium_client/instructions/index.js +50 -0
- package/dist/raydium_client/instructions/index.js.map +1 -0
- package/dist/raydium_client/instructions/initializeReward.d.ts +19 -0
- package/dist/raydium_client/instructions/initializeReward.js +57 -0
- package/dist/raydium_client/instructions/initializeReward.js.map +1 -0
- package/dist/raydium_client/instructions/openPosition.d.ts +34 -0
- package/dist/raydium_client/instructions/openPosition.js +81 -0
- package/dist/raydium_client/instructions/openPosition.js.map +1 -0
- package/dist/raydium_client/instructions/openPositionV2.d.ts +39 -0
- package/dist/raydium_client/instructions/openPositionV2.js +88 -0
- package/dist/raydium_client/instructions/openPositionV2.js.map +1 -0
- package/dist/raydium_client/instructions/setRewardParams.d.ts +18 -0
- package/dist/raydium_client/instructions/setRewardParams.js +58 -0
- package/dist/raydium_client/instructions/setRewardParams.js.map +1 -0
- package/dist/raydium_client/instructions/swap.d.ts +22 -0
- package/dist/raydium_client/instructions/swap.js +62 -0
- package/dist/raydium_client/instructions/swap.js.map +1 -0
- package/dist/raydium_client/instructions/swapRouterBaseIn.d.ts +16 -0
- package/dist/raydium_client/instructions/swapRouterBaseIn.js +54 -0
- package/dist/raydium_client/instructions/swapRouterBaseIn.js.map +1 -0
- package/dist/raydium_client/instructions/swapV2.d.ts +25 -0
- package/dist/raydium_client/instructions/swapV2.js +65 -0
- package/dist/raydium_client/instructions/swapV2.js.map +1 -0
- package/dist/raydium_client/instructions/transferRewardOwner.d.ts +10 -0
- package/dist/raydium_client/instructions/transferRewardOwner.js +46 -0
- package/dist/raydium_client/instructions/transferRewardOwner.js.map +1 -0
- package/dist/raydium_client/instructions/updateAmmConfig.d.ts +11 -0
- package/dist/raydium_client/instructions/updateAmmConfig.js +47 -0
- package/dist/raydium_client/instructions/updateAmmConfig.js.map +1 -0
- package/dist/raydium_client/instructions/updateOperationAccount.d.ts +12 -0
- package/dist/raydium_client/instructions/updateOperationAccount.js +51 -0
- package/dist/raydium_client/instructions/updateOperationAccount.js.map +1 -0
- package/dist/raydium_client/instructions/updatePoolStatus.d.ts +10 -0
- package/dist/raydium_client/instructions/updatePoolStatus.js +46 -0
- package/dist/raydium_client/instructions/updatePoolStatus.js.map +1 -0
- package/dist/raydium_client/instructions/updateRewardInfos.d.ts +5 -0
- package/dist/raydium_client/instructions/updateRewardInfos.js +15 -0
- package/dist/raydium_client/instructions/updateRewardInfos.js.map +1 -0
- package/dist/raydium_client/programId.d.ts +5 -0
- package/dist/raydium_client/programId.js +15 -0
- package/dist/raydium_client/programId.js.map +1 -0
- package/dist/raydium_client/types/InitializeRewardParam.d.ts +32 -0
- package/dist/raydium_client/types/InitializeRewardParam.js +79 -0
- package/dist/raydium_client/types/InitializeRewardParam.js.map +1 -0
- package/dist/raydium_client/types/Observation.d.ts +37 -0
- package/dist/raydium_client/types/Observation.js +85 -0
- package/dist/raydium_client/types/Observation.js.map +1 -0
- package/dist/raydium_client/types/PoolStatusBitFlag.d.ts +31 -0
- package/dist/raydium_client/types/PoolStatusBitFlag.js +102 -0
- package/dist/raydium_client/types/PoolStatusBitFlag.js.map +1 -0
- package/dist/raydium_client/types/PoolStatusBitIndex.d.ts +70 -0
- package/dist/raydium_client/types/PoolStatusBitIndex.js +180 -0
- package/dist/raydium_client/types/PoolStatusBitIndex.js.map +1 -0
- package/dist/raydium_client/types/PositionRewardInfo.d.ts +27 -0
- package/dist/raydium_client/types/PositionRewardInfo.js +70 -0
- package/dist/raydium_client/types/PositionRewardInfo.js.map +1 -0
- package/dist/raydium_client/types/RewardInfo.d.ts +73 -0
- package/dist/raydium_client/types/RewardInfo.js +128 -0
- package/dist/raydium_client/types/RewardInfo.js.map +1 -0
- package/dist/raydium_client/types/RewardState.d.ts +57 -0
- package/dist/raydium_client/types/RewardState.js +154 -0
- package/dist/raydium_client/types/RewardState.js.map +1 -0
- package/dist/raydium_client/types/TickArryBitmap.d.ts +0 -0
- package/dist/raydium_client/types/TickArryBitmap.js +2 -0
- package/dist/raydium_client/types/TickArryBitmap.js.map +1 -0
- package/dist/raydium_client/types/TickState.d.ts +52 -0
- package/dist/raydium_client/types/TickState.js +103 -0
- package/dist/raydium_client/types/TickState.js.map +1 -0
- package/dist/raydium_client/types/index.d.ts +22 -0
- package/dist/raydium_client/types/index.js +43 -0
- package/dist/raydium_client/types/index.js.map +1 -0
- package/dist/rebalance_methods/autodriftRebalance.d.ts +20 -0
- package/dist/rebalance_methods/autodriftRebalance.js +220 -0
- package/dist/rebalance_methods/autodriftRebalance.js.map +1 -0
- package/dist/rebalance_methods/consts.d.ts +1 -0
- package/dist/rebalance_methods/consts.js +5 -0
- package/dist/rebalance_methods/consts.js.map +1 -0
- package/dist/rebalance_methods/driftRebalance.d.ts +17 -0
- package/dist/rebalance_methods/driftRebalance.js +180 -0
- package/dist/rebalance_methods/driftRebalance.js.map +1 -0
- package/dist/rebalance_methods/expanderRebalance.d.ts +18 -0
- package/dist/rebalance_methods/expanderRebalance.js +283 -0
- package/dist/rebalance_methods/expanderRebalance.js.map +1 -0
- package/dist/rebalance_methods/index.d.ts +7 -0
- package/dist/rebalance_methods/index.js +24 -0
- package/dist/rebalance_methods/index.js.map +1 -0
- package/dist/rebalance_methods/manualRebalance.d.ts +5 -0
- package/dist/rebalance_methods/manualRebalance.js +35 -0
- package/dist/rebalance_methods/manualRebalance.js.map +1 -0
- package/dist/rebalance_methods/math_utils.d.ts +4 -0
- package/dist/rebalance_methods/math_utils.js +18 -0
- package/dist/rebalance_methods/math_utils.js.map +1 -0
- package/dist/rebalance_methods/periodicRebalance.d.ts +14 -0
- package/dist/rebalance_methods/periodicRebalance.js +92 -0
- package/dist/rebalance_methods/periodicRebalance.js.map +1 -0
- package/dist/rebalance_methods/pricePercentageRebalance.d.ts +13 -0
- package/dist/rebalance_methods/pricePercentageRebalance.js +150 -0
- package/dist/rebalance_methods/pricePercentageRebalance.js.map +1 -0
- package/dist/rebalance_methods/pricePercentageWithResetRebalance.d.ts +14 -0
- package/dist/rebalance_methods/pricePercentageWithResetRebalance.js +233 -0
- package/dist/rebalance_methods/pricePercentageWithResetRebalance.js.map +1 -0
- package/dist/rebalance_methods/takeProfitRebalance.d.ts +14 -0
- package/dist/rebalance_methods/takeProfitRebalance.js +99 -0
- package/dist/rebalance_methods/takeProfitRebalance.js.map +1 -0
- package/dist/rebalance_methods/utils.d.ts +10 -0
- package/dist/rebalance_methods/utils.js +103 -0
- package/dist/rebalance_methods/utils.js.map +1 -0
- package/dist/services/JupService.d.ts +22 -0
- package/dist/services/JupService.js +130 -0
- package/dist/services/JupService.js.map +1 -0
- package/dist/services/MeteoraService.d.ts +24 -0
- package/dist/services/MeteoraService.js +193 -0
- package/dist/services/MeteoraService.js.map +1 -0
- package/dist/services/OrcaService.d.ts +36 -0
- package/dist/services/OrcaService.js +290 -0
- package/dist/services/OrcaService.js.map +1 -0
- package/dist/services/OrcaWhirlpoolsResponse.d.ts +105 -0
- package/dist/services/OrcaWhirlpoolsResponse.js +3 -0
- package/dist/services/OrcaWhirlpoolsResponse.js.map +1 -0
- package/dist/services/PoolSimulationService.d.ts +20 -0
- package/dist/services/PoolSimulationService.js +30 -0
- package/dist/services/PoolSimulationService.js.map +1 -0
- package/dist/services/RaydiumPoolsResponse.d.ts +85 -0
- package/dist/services/RaydiumPoolsResponse.js +3 -0
- package/dist/services/RaydiumPoolsResponse.js.map +1 -0
- package/dist/services/RaydiumService.d.ts +18 -0
- package/dist/services/RaydiumService.js +202 -0
- package/dist/services/RaydiumService.js.map +1 -0
- package/dist/services/WhirlpoolAprApy.d.ts +13 -0
- package/dist/services/WhirlpoolAprApy.js +3 -0
- package/dist/services/WhirlpoolAprApy.js.map +1 -0
- package/dist/services/index.d.ts +5 -0
- package/dist/services/index.js +22 -0
- package/dist/services/index.js.map +1 -0
- package/dist/utils/CreationParameters.d.ts +32 -0
- package/dist/utils/CreationParameters.js +81 -0
- package/dist/utils/CreationParameters.js.map +1 -0
- package/dist/utils/anchorUtils.d.ts +5 -0
- package/dist/utils/anchorUtils.js +27 -0
- package/dist/utils/anchorUtils.js.map +1 -0
- package/dist/utils/batch.d.ts +2 -0
- package/dist/utils/batch.js +24 -0
- package/dist/utils/batch.js.map +1 -0
- package/dist/utils/index.d.ts +8 -0
- package/dist/utils/index.js +25 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/instructions.d.ts +6 -0
- package/dist/utils/instructions.js +40 -0
- package/dist/utils/instructions.js.map +1 -0
- package/dist/utils/lookupTable.d.ts +4 -0
- package/dist/utils/lookupTable.js +51 -0
- package/dist/utils/lookupTable.js.map +1 -0
- package/dist/utils/math.d.ts +3 -0
- package/dist/utils/math.js +16 -0
- package/dist/utils/math.js.map +1 -0
- package/dist/utils/meteora.d.ts +20 -0
- package/dist/utils/meteora.js +80 -0
- package/dist/utils/meteora.js.map +1 -0
- package/dist/utils/orca.d.ts +2 -0
- package/dist/utils/orca.js +8 -0
- package/dist/utils/orca.js.map +1 -0
- package/dist/utils/priceReferenceTypes.d.ts +3 -0
- package/dist/utils/priceReferenceTypes.js +12 -0
- package/dist/utils/priceReferenceTypes.js.map +1 -0
- package/dist/utils/pubkey.d.ts +65 -0
- package/dist/utils/pubkey.js +218 -0
- package/dist/utils/pubkey.js.map +1 -0
- package/dist/utils/raydium.d.ts +1 -0
- package/dist/utils/raydium.js +15 -0
- package/dist/utils/raydium.js.map +1 -0
- package/dist/utils/tokenUtils.d.ts +47 -0
- package/dist/utils/tokenUtils.js +185 -0
- package/dist/utils/tokenUtils.js.map +1 -0
- package/dist/utils/transactions.d.ts +13 -0
- package/dist/utils/transactions.js +147 -0
- package/dist/utils/transactions.js.map +1 -0
- package/dist/utils/types.d.ts +178 -0
- package/dist/utils/types.js +110 -0
- package/dist/utils/types.js.map +1 -0
- package/dist/utils/utils.d.ts +36 -0
- package/dist/utils/utils.js +313 -0
- package/dist/utils/utils.js.map +1 -0
- package/dist/whirlpools-client/accounts/FeeTier.d.ts +24 -0
- package/dist/whirlpools-client/accounts/FeeTier.js +106 -0
- package/dist/whirlpools-client/accounts/FeeTier.js.map +1 -0
- package/dist/whirlpools-client/accounts/Position.d.ts +47 -0
- package/dist/whirlpools-client/accounts/Position.js +146 -0
- package/dist/whirlpools-client/accounts/Position.js.map +1 -0
- package/dist/whirlpools-client/accounts/PositionBundle.d.ts +21 -0
- package/dist/whirlpools-client/accounts/PositionBundle.js +101 -0
- package/dist/whirlpools-client/accounts/PositionBundle.js.map +1 -0
- package/dist/whirlpools-client/accounts/TickArray.d.ts +25 -0
- package/dist/whirlpools-client/accounts/TickArray.js +107 -0
- package/dist/whirlpools-client/accounts/TickArray.js.map +1 -0
- package/dist/whirlpools-client/accounts/TokenBadge.d.ts +21 -0
- package/dist/whirlpools-client/accounts/TokenBadge.js +101 -0
- package/dist/whirlpools-client/accounts/TokenBadge.js.map +1 -0
- package/dist/whirlpools-client/accounts/Whirlpool.d.ts +74 -0
- package/dist/whirlpools-client/accounts/Whirlpool.js +191 -0
- package/dist/whirlpools-client/accounts/Whirlpool.js.map +1 -0
- package/dist/whirlpools-client/accounts/WhirlpoolsConfig.d.ts +27 -0
- package/dist/whirlpools-client/accounts/WhirlpoolsConfig.js +111 -0
- package/dist/whirlpools-client/accounts/WhirlpoolsConfig.js.map +1 -0
- package/dist/whirlpools-client/accounts/WhirlpoolsConfigExtension.d.ts +24 -0
- package/dist/whirlpools-client/accounts/WhirlpoolsConfigExtension.js +106 -0
- package/dist/whirlpools-client/accounts/WhirlpoolsConfigExtension.js.map +1 -0
- package/dist/whirlpools-client/accounts/index.d.ts +16 -0
- package/dist/whirlpools-client/accounts/index.js +20 -0
- package/dist/whirlpools-client/accounts/index.js.map +1 -0
- package/dist/whirlpools-client/errors/anchor.d.ts +434 -0
- package/dist/whirlpools-client/errors/anchor.js +713 -0
- package/dist/whirlpools-client/errors/anchor.js.map +1 -0
- package/dist/whirlpools-client/errors/custom.d.ts +434 -0
- package/dist/whirlpools-client/errors/custom.js +713 -0
- package/dist/whirlpools-client/errors/custom.js.map +1 -0
- package/dist/whirlpools-client/errors/index.d.ts +5 -0
- package/dist/whirlpools-client/errors/index.js +70 -0
- package/dist/whirlpools-client/errors/index.js.map +1 -0
- package/dist/whirlpools-client/index.d.ts +4 -0
- package/dist/whirlpools-client/index.js +21 -0
- package/dist/whirlpools-client/index.js.map +1 -0
- package/dist/whirlpools-client/instructions/closeBundledPosition.d.ts +13 -0
- package/dist/whirlpools-client/instructions/closeBundledPosition.js +57 -0
- package/dist/whirlpools-client/instructions/closeBundledPosition.js.map +1 -0
- package/dist/whirlpools-client/instructions/closePosition.d.ts +10 -0
- package/dist/whirlpools-client/instructions/closePosition.js +24 -0
- package/dist/whirlpools-client/instructions/closePosition.js.map +1 -0
- package/dist/whirlpools-client/instructions/collectFees.d.ts +13 -0
- package/dist/whirlpools-client/instructions/collectFees.js +27 -0
- package/dist/whirlpools-client/instructions/collectFees.js.map +1 -0
- package/dist/whirlpools-client/instructions/collectFeesV2.d.ts +22 -0
- package/dist/whirlpools-client/instructions/collectFeesV2.js +66 -0
- package/dist/whirlpools-client/instructions/collectFeesV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/collectProtocolFees.d.ts +12 -0
- package/dist/whirlpools-client/instructions/collectProtocolFees.js +26 -0
- package/dist/whirlpools-client/instructions/collectProtocolFees.js.map +1 -0
- package/dist/whirlpools-client/instructions/collectProtocolFeesV2.d.ts +21 -0
- package/dist/whirlpools-client/instructions/collectProtocolFeesV2.js +65 -0
- package/dist/whirlpools-client/instructions/collectProtocolFeesV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/collectReward.d.ts +15 -0
- package/dist/whirlpools-client/instructions/collectReward.js +55 -0
- package/dist/whirlpools-client/instructions/collectReward.js.map +1 -0
- package/dist/whirlpools-client/instructions/collectRewardV2.d.ts +19 -0
- package/dist/whirlpools-client/instructions/collectRewardV2.js +64 -0
- package/dist/whirlpools-client/instructions/collectRewardV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/decreaseLiquidity.d.ts +22 -0
- package/dist/whirlpools-client/instructions/decreaseLiquidity.js +65 -0
- package/dist/whirlpools-client/instructions/decreaseLiquidity.js.map +1 -0
- package/dist/whirlpools-client/instructions/decreaseLiquidityV2.d.ts +28 -0
- package/dist/whirlpools-client/instructions/decreaseLiquidityV2.js +74 -0
- package/dist/whirlpools-client/instructions/decreaseLiquidityV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/deletePositionBundle.d.ts +10 -0
- package/dist/whirlpools-client/instructions/deletePositionBundle.js +24 -0
- package/dist/whirlpools-client/instructions/deletePositionBundle.js.map +1 -0
- package/dist/whirlpools-client/instructions/deleteTokenBadge.d.ts +10 -0
- package/dist/whirlpools-client/instructions/deleteTokenBadge.js +24 -0
- package/dist/whirlpools-client/instructions/deleteTokenBadge.js.map +1 -0
- package/dist/whirlpools-client/instructions/increaseLiquidity.d.ts +22 -0
- package/dist/whirlpools-client/instructions/increaseLiquidity.js +65 -0
- package/dist/whirlpools-client/instructions/increaseLiquidity.js.map +1 -0
- package/dist/whirlpools-client/instructions/increaseLiquidityV2.d.ts +28 -0
- package/dist/whirlpools-client/instructions/increaseLiquidityV2.js +74 -0
- package/dist/whirlpools-client/instructions/increaseLiquidityV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/index.d.ts +92 -0
- package/dist/whirlpools-client/instructions/index.js +96 -0
- package/dist/whirlpools-client/instructions/index.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeConfig.d.ts +14 -0
- package/dist/whirlpools-client/instructions/initializeConfig.js +55 -0
- package/dist/whirlpools-client/instructions/initializeConfig.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeConfigExtension.d.ts +9 -0
- package/dist/whirlpools-client/instructions/initializeConfigExtension.js +19 -0
- package/dist/whirlpools-client/instructions/initializeConfigExtension.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeFeeTier.d.ts +14 -0
- package/dist/whirlpools-client/instructions/initializeFeeTier.js +53 -0
- package/dist/whirlpools-client/instructions/initializeFeeTier.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializePool.d.ts +23 -0
- package/dist/whirlpools-client/instructions/initializePool.js +62 -0
- package/dist/whirlpools-client/instructions/initializePool.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializePoolV2.d.ts +24 -0
- package/dist/whirlpools-client/instructions/initializePoolV2.js +62 -0
- package/dist/whirlpools-client/instructions/initializePoolV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializePositionBundle.d.ts +13 -0
- package/dist/whirlpools-client/instructions/initializePositionBundle.js +35 -0
- package/dist/whirlpools-client/instructions/initializePositionBundle.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializePositionBundleWithMetadata.d.ts +16 -0
- package/dist/whirlpools-client/instructions/initializePositionBundleWithMetadata.js +42 -0
- package/dist/whirlpools-client/instructions/initializePositionBundleWithMetadata.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeReward.d.ts +16 -0
- package/dist/whirlpools-client/instructions/initializeReward.js +52 -0
- package/dist/whirlpools-client/instructions/initializeReward.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeRewardV2.d.ts +17 -0
- package/dist/whirlpools-client/instructions/initializeRewardV2.js +53 -0
- package/dist/whirlpools-client/instructions/initializeRewardV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeTickArray.d.ts +12 -0
- package/dist/whirlpools-client/instructions/initializeTickArray.js +48 -0
- package/dist/whirlpools-client/instructions/initializeTickArray.js.map +1 -0
- package/dist/whirlpools-client/instructions/initializeTokenBadge.d.ts +11 -0
- package/dist/whirlpools-client/instructions/initializeTokenBadge.js +25 -0
- package/dist/whirlpools-client/instructions/initializeTokenBadge.js.map +1 -0
- package/dist/whirlpools-client/instructions/openBundledPosition.d.ts +18 -0
- package/dist/whirlpools-client/instructions/openBundledPosition.js +66 -0
- package/dist/whirlpools-client/instructions/openBundledPosition.js.map +1 -0
- package/dist/whirlpools-client/instructions/openPosition.d.ts +21 -0
- package/dist/whirlpools-client/instructions/openPosition.js +69 -0
- package/dist/whirlpools-client/instructions/openPosition.js.map +1 -0
- package/dist/whirlpools-client/instructions/openPositionWithMetadata.d.ts +24 -0
- package/dist/whirlpools-client/instructions/openPositionWithMetadata.js +76 -0
- package/dist/whirlpools-client/instructions/openPositionWithMetadata.js.map +1 -0
- package/dist/whirlpools-client/instructions/setCollectProtocolFeesAuthority.d.ts +7 -0
- package/dist/whirlpools-client/instructions/setCollectProtocolFeesAuthority.js +25 -0
- package/dist/whirlpools-client/instructions/setCollectProtocolFeesAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/setConfigExtensionAuthority.d.ts +8 -0
- package/dist/whirlpools-client/instructions/setConfigExtensionAuthority.js +30 -0
- package/dist/whirlpools-client/instructions/setConfigExtensionAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/setDefaultFeeRate.d.ts +11 -0
- package/dist/whirlpools-client/instructions/setDefaultFeeRate.js +47 -0
- package/dist/whirlpools-client/instructions/setDefaultFeeRate.js.map +1 -0
- package/dist/whirlpools-client/instructions/setDefaultProtocolFeeRate.d.ts +10 -0
- package/dist/whirlpools-client/instructions/setDefaultProtocolFeeRate.js +46 -0
- package/dist/whirlpools-client/instructions/setDefaultProtocolFeeRate.js.map +1 -0
- package/dist/whirlpools-client/instructions/setFeeAuthority.d.ts +7 -0
- package/dist/whirlpools-client/instructions/setFeeAuthority.js +17 -0
- package/dist/whirlpools-client/instructions/setFeeAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/setFeeRate.d.ts +11 -0
- package/dist/whirlpools-client/instructions/setFeeRate.js +47 -0
- package/dist/whirlpools-client/instructions/setFeeRate.js.map +1 -0
- package/dist/whirlpools-client/instructions/setProtocolFeeRate.d.ts +11 -0
- package/dist/whirlpools-client/instructions/setProtocolFeeRate.js +47 -0
- package/dist/whirlpools-client/instructions/setProtocolFeeRate.js.map +1 -0
- package/dist/whirlpools-client/instructions/setRewardAuthority.d.ts +11 -0
- package/dist/whirlpools-client/instructions/setRewardAuthority.js +47 -0
- package/dist/whirlpools-client/instructions/setRewardAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/setRewardAuthorityBySuperAuthority.d.ts +12 -0
- package/dist/whirlpools-client/instructions/setRewardAuthorityBySuperAuthority.js +52 -0
- package/dist/whirlpools-client/instructions/setRewardAuthorityBySuperAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/setRewardEmissions.d.ts +13 -0
- package/dist/whirlpools-client/instructions/setRewardEmissions.js +51 -0
- package/dist/whirlpools-client/instructions/setRewardEmissions.js.map +1 -0
- package/dist/whirlpools-client/instructions/setRewardEmissionsSuperAuthority.d.ts +7 -0
- package/dist/whirlpools-client/instructions/setRewardEmissionsSuperAuthority.js +25 -0
- package/dist/whirlpools-client/instructions/setRewardEmissionsSuperAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/setRewardEmissionsV2.d.ts +13 -0
- package/dist/whirlpools-client/instructions/setRewardEmissionsV2.js +51 -0
- package/dist/whirlpools-client/instructions/setRewardEmissionsV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/setTokenBadgeAuthority.d.ts +8 -0
- package/dist/whirlpools-client/instructions/setTokenBadgeAuthority.js +30 -0
- package/dist/whirlpools-client/instructions/setTokenBadgeAuthority.js.map +1 -0
- package/dist/whirlpools-client/instructions/swap.d.ts +24 -0
- package/dist/whirlpools-client/instructions/swap.js +65 -0
- package/dist/whirlpools-client/instructions/swap.js.map +1 -0
- package/dist/whirlpools-client/instructions/swapV2.d.ts +30 -0
- package/dist/whirlpools-client/instructions/swapV2.js +74 -0
- package/dist/whirlpools-client/instructions/swapV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/twoHopSwap.d.ts +35 -0
- package/dist/whirlpools-client/instructions/twoHopSwap.js +94 -0
- package/dist/whirlpools-client/instructions/twoHopSwap.js.map +1 -0
- package/dist/whirlpools-client/instructions/twoHopSwapV2.d.ts +41 -0
- package/dist/whirlpools-client/instructions/twoHopSwapV2.js +111 -0
- package/dist/whirlpools-client/instructions/twoHopSwapV2.js.map +1 -0
- package/dist/whirlpools-client/instructions/updateFeesAndRewards.d.ts +8 -0
- package/dist/whirlpools-client/instructions/updateFeesAndRewards.js +18 -0
- package/dist/whirlpools-client/instructions/updateFeesAndRewards.js.map +1 -0
- package/dist/whirlpools-client/programId.d.ts +5 -0
- package/dist/whirlpools-client/programId.js +15 -0
- package/dist/whirlpools-client/programId.js.map +1 -0
- package/dist/whirlpools-client/shim/remove-liquidity.d.ts +15 -0
- package/dist/whirlpools-client/shim/remove-liquidity.js +72 -0
- package/dist/whirlpools-client/shim/remove-liquidity.js.map +1 -0
- package/dist/whirlpools-client/types/AccountsType.d.ts +83 -0
- package/dist/whirlpools-client/types/AccountsType.js +206 -0
- package/dist/whirlpools-client/types/AccountsType.js.map +1 -0
- package/dist/whirlpools-client/types/CurrIndex.d.ts +44 -0
- package/dist/whirlpools-client/types/CurrIndex.js +128 -0
- package/dist/whirlpools-client/types/CurrIndex.js.map +1 -0
- package/dist/whirlpools-client/types/Direction.d.ts +31 -0
- package/dist/whirlpools-client/types/Direction.js +102 -0
- package/dist/whirlpools-client/types/Direction.js.map +1 -0
- package/dist/whirlpools-client/types/OpenPositionBumps.d.ts +21 -0
- package/dist/whirlpools-client/types/OpenPositionBumps.js +61 -0
- package/dist/whirlpools-client/types/OpenPositionBumps.js.map +1 -0
- package/dist/whirlpools-client/types/OpenPositionWithMetadataBumps.d.ts +26 -0
- package/dist/whirlpools-client/types/OpenPositionWithMetadataBumps.js +66 -0
- package/dist/whirlpools-client/types/OpenPositionWithMetadataBumps.js.map +1 -0
- package/dist/whirlpools-client/types/PositionRewardInfo.d.ts +27 -0
- package/dist/whirlpools-client/types/PositionRewardInfo.js +70 -0
- package/dist/whirlpools-client/types/PositionRewardInfo.js.map +1 -0
- package/dist/whirlpools-client/types/RemainingAccountsInfo.d.ts +51 -0
- package/dist/whirlpools-client/types/RemainingAccountsInfo.js +62 -0
- package/dist/whirlpools-client/types/RemainingAccountsInfo.js.map +1 -0
- package/dist/whirlpools-client/types/RemainingAccountsSlice.d.ts +50 -0
- package/dist/whirlpools-client/types/RemainingAccountsSlice.js +67 -0
- package/dist/whirlpools-client/types/RemainingAccountsSlice.js.map +1 -0
- package/dist/whirlpools-client/types/Tick.d.ts +47 -0
- package/dist/whirlpools-client/types/Tick.js +97 -0
- package/dist/whirlpools-client/types/Tick.js.map +1 -0
- package/dist/whirlpools-client/types/TickLabel.d.ts +31 -0
- package/dist/whirlpools-client/types/TickLabel.js +102 -0
- package/dist/whirlpools-client/types/TickLabel.js.map +1 -0
- package/dist/whirlpools-client/types/WhirlpoolBumps.d.ts +21 -0
- package/dist/whirlpools-client/types/WhirlpoolBumps.js +61 -0
- package/dist/whirlpools-client/types/WhirlpoolBumps.js.map +1 -0
- package/dist/whirlpools-client/types/WhirlpoolRewardInfo.d.ts +43 -0
- package/dist/whirlpools-client/types/WhirlpoolRewardInfo.js +92 -0
- package/dist/whirlpools-client/types/WhirlpoolRewardInfo.js.map +1 -0
- package/dist/whirlpools-client/types/index.d.ts +32 -0
- package/dist/whirlpools-client/types/index.js +51 -0
- package/dist/whirlpools-client/types/index.js.map +1 -0
- package/package.json +92 -0
|
@@ -0,0 +1,103 @@
|
|
|
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.getRebalanceTypeFromRebalanceFields = getRebalanceTypeFromRebalanceFields;
|
|
7
|
+
exports.rebalanceTypeToRebalanceMethod = rebalanceTypeToRebalanceMethod;
|
|
8
|
+
exports.getRebalanceMethodFromRebalanceFields = getRebalanceMethodFromRebalanceFields;
|
|
9
|
+
exports.upsertRebalanceFieldInfo = upsertRebalanceFieldInfo;
|
|
10
|
+
exports.upsertManyRebalanceFieldInfos = upsertManyRebalanceFieldInfos;
|
|
11
|
+
exports.extractPricesFromDeserializedState = extractPricesFromDeserializedState;
|
|
12
|
+
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
13
|
+
const RebalanceType_1 = require("../kamino-client/types/RebalanceType");
|
|
14
|
+
const CreationParameters_1 = require("../utils/CreationParameters");
|
|
15
|
+
const autodriftRebalance_1 = require("./autodriftRebalance");
|
|
16
|
+
const driftRebalance_1 = require("./driftRebalance");
|
|
17
|
+
const expanderRebalance_1 = require("./expanderRebalance");
|
|
18
|
+
const manualRebalance_1 = require("./manualRebalance");
|
|
19
|
+
const periodicRebalance_1 = require("./periodicRebalance");
|
|
20
|
+
const pricePercentageRebalance_1 = require("./pricePercentageRebalance");
|
|
21
|
+
const pricePercentageWithResetRebalance_1 = require("./pricePercentageWithResetRebalance");
|
|
22
|
+
const takeProfitRebalance_1 = require("./takeProfitRebalance");
|
|
23
|
+
function getRebalanceTypeFromRebalanceFields(rebalanceFieldInfos) {
|
|
24
|
+
const rebalanceTypeField = rebalanceFieldInfos.find((field) => field.label === 'rebalanceType');
|
|
25
|
+
if (!rebalanceTypeField) {
|
|
26
|
+
throw new Error('Rebalance type field not found');
|
|
27
|
+
}
|
|
28
|
+
switch (rebalanceTypeField.value) {
|
|
29
|
+
case manualRebalance_1.ManualRebalanceTypeName:
|
|
30
|
+
return new RebalanceType_1.Manual();
|
|
31
|
+
case pricePercentageRebalance_1.PricePercentageRebalanceTypeName:
|
|
32
|
+
return new RebalanceType_1.PricePercentage();
|
|
33
|
+
case pricePercentageWithResetRebalance_1.PricePercentageWithResetRebalanceTypeName:
|
|
34
|
+
return new RebalanceType_1.PricePercentageWithReset();
|
|
35
|
+
case driftRebalance_1.DriftRebalanceTypeName:
|
|
36
|
+
return new RebalanceType_1.Drift();
|
|
37
|
+
case takeProfitRebalance_1.TakeProfitRebalanceTypeName:
|
|
38
|
+
return new RebalanceType_1.TakeProfit();
|
|
39
|
+
case periodicRebalance_1.PeriodicRebalanceTypeName:
|
|
40
|
+
return new RebalanceType_1.PeriodicRebalance();
|
|
41
|
+
case expanderRebalance_1.ExpanderRebalanceTypeName:
|
|
42
|
+
return new RebalanceType_1.Expander();
|
|
43
|
+
case autodriftRebalance_1.AutodriftRebalanceTypeName:
|
|
44
|
+
return new RebalanceType_1.Autodrift();
|
|
45
|
+
default:
|
|
46
|
+
throw new Error(`Invalid rebalance type ${rebalanceTypeField.value}`);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
function rebalanceTypeToRebalanceMethod(rebalanceType) {
|
|
50
|
+
switch (rebalanceType.kind) {
|
|
51
|
+
case RebalanceType_1.Manual.kind:
|
|
52
|
+
return CreationParameters_1.ManualRebalanceMethod;
|
|
53
|
+
case RebalanceType_1.PricePercentage.kind:
|
|
54
|
+
return CreationParameters_1.PricePercentageRebalanceMethod;
|
|
55
|
+
case RebalanceType_1.PricePercentageWithReset.kind:
|
|
56
|
+
return CreationParameters_1.PricePercentageWithResetRangeRebalanceMethod;
|
|
57
|
+
case RebalanceType_1.Drift.kind:
|
|
58
|
+
return CreationParameters_1.DriftRebalanceMethod;
|
|
59
|
+
case RebalanceType_1.TakeProfit.kind:
|
|
60
|
+
return CreationParameters_1.TakeProfitMethod;
|
|
61
|
+
case RebalanceType_1.PeriodicRebalance.kind:
|
|
62
|
+
return CreationParameters_1.PeriodicRebalanceMethod;
|
|
63
|
+
case RebalanceType_1.Expander.kind:
|
|
64
|
+
return CreationParameters_1.ExpanderMethod;
|
|
65
|
+
case RebalanceType_1.Autodrift.kind:
|
|
66
|
+
return CreationParameters_1.AutodriftMethod;
|
|
67
|
+
default:
|
|
68
|
+
throw new Error(`Invalid rebalance type ${rebalanceType}`);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
function getRebalanceMethodFromRebalanceFields(rebalanceFieldInfos) {
|
|
72
|
+
const rebalanceType = getRebalanceTypeFromRebalanceFields(rebalanceFieldInfos);
|
|
73
|
+
return rebalanceTypeToRebalanceMethod(rebalanceType);
|
|
74
|
+
}
|
|
75
|
+
function upsertRebalanceFieldInfo(rebalanceFieldInfos, newFieldInfo) {
|
|
76
|
+
const newRebalanceFieldInfoIndex = rebalanceFieldInfos.findIndex((fieldInfo) => fieldInfo.label === newFieldInfo.label);
|
|
77
|
+
// if the field is not found, add it
|
|
78
|
+
if (newRebalanceFieldInfoIndex === -1) {
|
|
79
|
+
return [...rebalanceFieldInfos, newFieldInfo];
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
// if the field is found, update it
|
|
83
|
+
const newRebalanceFieldInfos = [...rebalanceFieldInfos];
|
|
84
|
+
newRebalanceFieldInfos[newRebalanceFieldInfoIndex] = newFieldInfo;
|
|
85
|
+
return newRebalanceFieldInfos;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
function upsertManyRebalanceFieldInfos(rebalanceFieldInfos, newFieldInfos) {
|
|
89
|
+
let updatedFieldInfos = [...rebalanceFieldInfos];
|
|
90
|
+
for (const newFieldInfo of newFieldInfos) {
|
|
91
|
+
updatedFieldInfos = upsertRebalanceFieldInfo(updatedFieldInfos, newFieldInfo);
|
|
92
|
+
}
|
|
93
|
+
return updatedFieldInfos;
|
|
94
|
+
}
|
|
95
|
+
function extractPricesFromDeserializedState(state) {
|
|
96
|
+
const resetPriceLower = state.find((param) => param.label == 'resetPriceLower');
|
|
97
|
+
const resetPriceUpper = state.find((param) => param.label == 'resetPriceUpper');
|
|
98
|
+
if (resetPriceLower === undefined || resetPriceUpper === undefined) {
|
|
99
|
+
throw new Error('Expected strategy to have resetPriceLower and resetPriceUpper in the field infos');
|
|
100
|
+
}
|
|
101
|
+
return [new decimal_js_1.default(resetPriceLower.value.toString()), new decimal_js_1.default(resetPriceUpper.value.toString())];
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/rebalance_methods/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import Decimal from 'decimal.js';\nimport { RebalanceTypeKind } from '../kamino-client/types';\nimport {\n Manual,\n PricePercentage,\n PricePercentageWithReset,\n Expander,\n Drift,\n TakeProfit,\n PeriodicRebalance,\n Autodrift,\n} from '../kamino-client/types/RebalanceType';\nimport { RebalanceFieldInfo } from '../utils';\nimport {\n AutodriftMethod,\n DriftRebalanceMethod,\n ExpanderMethod,\n ManualRebalanceMethod,\n PeriodicRebalanceMethod,\n PricePercentageRebalanceMethod,\n PricePercentageWithResetRangeRebalanceMethod,\n RebalanceMethod,\n TakeProfitMethod,\n} from '../utils/CreationParameters';\nimport { AutodriftRebalanceTypeName } from './autodriftRebalance';\nimport { DriftRebalanceTypeName } from './driftRebalance';\nimport { ExpanderRebalanceTypeName } from './expanderRebalance';\nimport { ManualRebalanceTypeName } from './manualRebalance';\nimport { PeriodicRebalanceTypeName } from './periodicRebalance';\nimport { PricePercentageRebalanceTypeName } from './pricePercentageRebalance';\nimport { PricePercentageWithResetRebalanceTypeName } from './pricePercentageWithResetRebalance';\nimport { TakeProfitRebalanceTypeName } from './takeProfitRebalance';\n\nexport function getRebalanceTypeFromRebalanceFields(rebalanceFieldInfos: RebalanceFieldInfo[]): RebalanceTypeKind {\n const rebalanceTypeField = rebalanceFieldInfos.find((field) => field.label === 'rebalanceType');\n if (!rebalanceTypeField) {\n throw new Error('Rebalance type field not found');\n }\n\n switch (rebalanceTypeField.value) {\n case ManualRebalanceTypeName:\n return new Manual();\n case PricePercentageRebalanceTypeName:\n return new PricePercentage();\n case PricePercentageWithResetRebalanceTypeName:\n return new PricePercentageWithReset();\n case DriftRebalanceTypeName:\n return new Drift();\n case TakeProfitRebalanceTypeName:\n return new TakeProfit();\n case PeriodicRebalanceTypeName:\n return new PeriodicRebalance();\n case ExpanderRebalanceTypeName:\n return new Expander();\n case AutodriftRebalanceTypeName:\n return new Autodrift();\n default:\n throw new Error(`Invalid rebalance type ${rebalanceTypeField.value}`);\n }\n}\n\nexport function rebalanceTypeToRebalanceMethod(rebalanceType: RebalanceTypeKind): RebalanceMethod {\n switch (rebalanceType.kind) {\n case Manual.kind:\n return ManualRebalanceMethod;\n case PricePercentage.kind:\n return PricePercentageRebalanceMethod;\n case PricePercentageWithReset.kind:\n return PricePercentageWithResetRangeRebalanceMethod;\n case Drift.kind:\n return DriftRebalanceMethod;\n case TakeProfit.kind:\n return TakeProfitMethod;\n case PeriodicRebalance.kind:\n return PeriodicRebalanceMethod;\n case Expander.kind:\n return ExpanderMethod;\n case Autodrift.kind:\n return AutodriftMethod;\n default:\n throw new Error(`Invalid rebalance type ${rebalanceType}`);\n }\n}\n\nexport function getRebalanceMethodFromRebalanceFields(rebalanceFieldInfos: RebalanceFieldInfo[]): RebalanceMethod {\n const rebalanceType = getRebalanceTypeFromRebalanceFields(rebalanceFieldInfos);\n return rebalanceTypeToRebalanceMethod(rebalanceType);\n}\n\nexport function upsertRebalanceFieldInfo(\n rebalanceFieldInfos: RebalanceFieldInfo[],\n newFieldInfo: RebalanceFieldInfo\n): RebalanceFieldInfo[] {\n const newRebalanceFieldInfoIndex = rebalanceFieldInfos.findIndex(\n (fieldInfo) => fieldInfo.label === newFieldInfo.label\n );\n\n // if the field is not found, add it\n if (newRebalanceFieldInfoIndex === -1) {\n return [...rebalanceFieldInfos, newFieldInfo];\n } else {\n // if the field is found, update it\n const newRebalanceFieldInfos = [...rebalanceFieldInfos];\n newRebalanceFieldInfos[newRebalanceFieldInfoIndex] = newFieldInfo;\n return newRebalanceFieldInfos;\n }\n}\n\nexport function upsertManyRebalanceFieldInfos(\n rebalanceFieldInfos: RebalanceFieldInfo[],\n newFieldInfos: RebalanceFieldInfo[]\n): RebalanceFieldInfo[] {\n let updatedFieldInfos = [...rebalanceFieldInfos];\n for (const newFieldInfo of newFieldInfos) {\n updatedFieldInfos = upsertRebalanceFieldInfo(updatedFieldInfos, newFieldInfo);\n }\n\n return updatedFieldInfos;\n}\n\nexport function extractPricesFromDeserializedState(state: RebalanceFieldInfo[]): [Decimal, Decimal] {\n const resetPriceLower = state.find((param) => param.label == 'resetPriceLower');\n const resetPriceUpper = state.find((param) => param.label == 'resetPriceUpper');\n if (resetPriceLower === undefined || resetPriceUpper === undefined) {\n throw new Error('Expected strategy to have resetPriceLower and resetPriceUpper in the field infos');\n }\n return [new Decimal(resetPriceLower.value.toString()), new Decimal(resetPriceUpper.value.toString())];\n}\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Connection, PublicKey, Transaction } from '@solana/web3.js';
|
|
2
|
+
import { SolanaCluster } from '@hubbleprotocol/hubble-config';
|
|
3
|
+
import Decimal from 'decimal.js';
|
|
4
|
+
import { DeserializedVersionedTransaction } from '../utils';
|
|
5
|
+
import { QuoteResponse, SwapInstructionsResponse, SwapResponse } from '@jup-ag/api';
|
|
6
|
+
export type SwapTransactionsResponse = {
|
|
7
|
+
setupTransaction: string | undefined;
|
|
8
|
+
swapTransaction: string;
|
|
9
|
+
cleanupTransaction: string | undefined;
|
|
10
|
+
};
|
|
11
|
+
export declare class JupService {
|
|
12
|
+
private readonly _connection;
|
|
13
|
+
private readonly _cluster;
|
|
14
|
+
constructor(connection: Connection, cluster: SolanaCluster);
|
|
15
|
+
static getBestRouteV6: (userPublicKey: PublicKey, amount: Decimal, inputMint: PublicKey, outputMint: PublicKey, slippageBps: number, asLegacyTransaction?: boolean, maxAccounts?: number, onlyDirectRoutes?: boolean) => Promise<SwapResponse>;
|
|
16
|
+
static getBestRouteQuoteV6: (amount: Decimal, inputMint: PublicKey, outputMint: PublicKey, slippageBps: number, asLegacyTransaction?: boolean, maxAccounts?: number, onlyDirectRoutes?: boolean) => Promise<QuoteResponse>;
|
|
17
|
+
static getSwapIxsFromQuote: (userPublicKey: PublicKey, quote: QuoteResponse, wrapUnwrapSOL?: boolean, asLegacyTransaction?: boolean) => Promise<SwapInstructionsResponse>;
|
|
18
|
+
static getPrice: (inputMint: PublicKey | string, outputMint: PublicKey | string) => Promise<number>;
|
|
19
|
+
static buildTransactionsFromSerialized: (serializedTransactions: Array<string | undefined>) => Transaction[];
|
|
20
|
+
static deserealizeVersionedTransactions: (connection: Connection, serializedTransactions: Array<string | undefined>) => Promise<DeserializedVersionedTransaction>;
|
|
21
|
+
static getLookupTableAccount: (connection: Connection, address: string | PublicKey) => Promise<import("@solana/web3.js").AddressLookupTableAccount | null>;
|
|
22
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
var _a;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.JupService = void 0;
|
|
17
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
18
|
+
const axios_1 = __importDefault(require("axios"));
|
|
19
|
+
const api_1 = require("@jup-ag/api");
|
|
20
|
+
class JupService {
|
|
21
|
+
constructor(connection, cluster) {
|
|
22
|
+
this._connection = connection;
|
|
23
|
+
this._cluster = cluster;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
exports.JupService = JupService;
|
|
27
|
+
_a = JupService;
|
|
28
|
+
// the amounts has to be in lamports
|
|
29
|
+
JupService.getBestRouteV6 = (userPublicKey, amount, inputMint, outputMint, slippageBps, asLegacyTransaction, maxAccounts, onlyDirectRoutes) => __awaiter(void 0, void 0, void 0, function* () {
|
|
30
|
+
try {
|
|
31
|
+
const jupiterQuoteApi = (0, api_1.createJupiterApiClient)(); // config is optional
|
|
32
|
+
// quote-api.jup.ag/v6/quote?inputMint=7dHbWXmci3dT8UFYWYZweBLXgycu7Y3iL6trKn1Y7ARj&outputMint=mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So&amount=71101983&slippageBps=10&onlyDirectRoutes=false&asLegacyTransaction=false&maxAccounts=33
|
|
33
|
+
const res = yield _a.getBestRouteQuoteV6(amount, inputMint, outputMint, slippageBps, asLegacyTransaction, maxAccounts, onlyDirectRoutes);
|
|
34
|
+
const transaction = yield jupiterQuoteApi.swapPost({
|
|
35
|
+
swapRequest: {
|
|
36
|
+
quoteResponse: res,
|
|
37
|
+
userPublicKey: userPublicKey.toString(),
|
|
38
|
+
wrapAndUnwrapSol: false,
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
return transaction;
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
console.log('getBestRouteV6 error', error);
|
|
45
|
+
throw error;
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
JupService.getBestRouteQuoteV6 = (amount, inputMint, outputMint, slippageBps, asLegacyTransaction, maxAccounts, onlyDirectRoutes) => __awaiter(void 0, void 0, void 0, function* () {
|
|
49
|
+
try {
|
|
50
|
+
const jupiterQuoteApi = (0, api_1.createJupiterApiClient)(); // config is optional
|
|
51
|
+
const params = {
|
|
52
|
+
inputMint: inputMint.toString(),
|
|
53
|
+
outputMint: outputMint.toString(),
|
|
54
|
+
amount: amount.floor().toNumber(),
|
|
55
|
+
slippageBps,
|
|
56
|
+
onlyDirectRoutes: onlyDirectRoutes,
|
|
57
|
+
asLegacyTransaction,
|
|
58
|
+
maxAccounts,
|
|
59
|
+
};
|
|
60
|
+
return yield jupiterQuoteApi.quoteGet(params);
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
console.log('getBestRouteQuoteV6 error', error);
|
|
64
|
+
throw error;
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
JupService.getSwapIxsFromQuote = (userPublicKey_1, quote_1, ...args_1) => __awaiter(void 0, [userPublicKey_1, quote_1, ...args_1], void 0, function* (userPublicKey, quote, wrapUnwrapSOL = true, asLegacyTransaction) {
|
|
68
|
+
try {
|
|
69
|
+
const jupiterQuoteApi = (0, api_1.createJupiterApiClient)(); // config is optional
|
|
70
|
+
return yield jupiterQuoteApi.swapInstructionsPost({
|
|
71
|
+
swapRequest: {
|
|
72
|
+
quoteResponse: quote,
|
|
73
|
+
userPublicKey: userPublicKey.toString(),
|
|
74
|
+
wrapAndUnwrapSol: wrapUnwrapSOL,
|
|
75
|
+
asLegacyTransaction: asLegacyTransaction,
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
catch (error) {
|
|
80
|
+
console.log('getSwapTxFromQuote error', error);
|
|
81
|
+
throw error;
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
JupService.getPrice = (inputMint, outputMint) => __awaiter(void 0, void 0, void 0, function* () {
|
|
85
|
+
const params = {
|
|
86
|
+
ids: inputMint.toString(),
|
|
87
|
+
vsToken: outputMint.toString(),
|
|
88
|
+
vsAmount: 1,
|
|
89
|
+
};
|
|
90
|
+
// BONK token
|
|
91
|
+
if (outputMint.toString() === 'DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263') {
|
|
92
|
+
params.vsAmount = 100;
|
|
93
|
+
}
|
|
94
|
+
const res = yield axios_1.default.get('https://quote-api.jup.ag/v6/price', { params });
|
|
95
|
+
return res.data.data[inputMint.toString()].price;
|
|
96
|
+
});
|
|
97
|
+
JupService.buildTransactionsFromSerialized = (serializedTransactions) => {
|
|
98
|
+
return serializedTransactions.filter(Boolean).map((tx) => {
|
|
99
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
100
|
+
return web3_js_1.Transaction.from(Buffer.from(tx, 'base64'));
|
|
101
|
+
});
|
|
102
|
+
};
|
|
103
|
+
JupService.deserealizeVersionedTransactions = (connection, serializedTransactions) => __awaiter(void 0, void 0, void 0, function* () {
|
|
104
|
+
const filtered = serializedTransactions.filter(Boolean);
|
|
105
|
+
const result = [];
|
|
106
|
+
let lookupTablesAddresses = [];
|
|
107
|
+
for (let i = 0; i < filtered.length; i++) {
|
|
108
|
+
const tx = filtered[i];
|
|
109
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
110
|
+
// safe to use as it is filtered above at 120 line
|
|
111
|
+
const buffer = Buffer.from(tx, 'base64');
|
|
112
|
+
const versionedTx = web3_js_1.VersionedTransaction.deserialize(buffer);
|
|
113
|
+
const { addressTableLookups } = versionedTx.message;
|
|
114
|
+
lookupTablesAddresses = [...lookupTablesAddresses, ...addressTableLookups.map((item) => item.accountKey)];
|
|
115
|
+
const lookupTableAccountsRequests = addressTableLookups.map((item) => {
|
|
116
|
+
return _a.getLookupTableAccount(connection, item.accountKey);
|
|
117
|
+
});
|
|
118
|
+
const lookupTableAccounts = yield Promise.all(lookupTableAccountsRequests);
|
|
119
|
+
const decompiledMessage = web3_js_1.TransactionMessage.decompile(versionedTx.message, {
|
|
120
|
+
// @ts-ignore
|
|
121
|
+
addressLookupTableAccounts: lookupTableAccounts,
|
|
122
|
+
});
|
|
123
|
+
result.push(decompiledMessage);
|
|
124
|
+
}
|
|
125
|
+
return { txMessage: result, lookupTablesAddresses };
|
|
126
|
+
});
|
|
127
|
+
JupService.getLookupTableAccount = (connection, address) => __awaiter(void 0, void 0, void 0, function* () {
|
|
128
|
+
return connection.getAddressLookupTable(new web3_js_1.PublicKey(address)).then((res) => res.value);
|
|
129
|
+
});
|
|
130
|
+
//# sourceMappingURL=JupService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"JupService.js","sourceRoot":"","sources":["../../src/services/JupService.ts"],"names":[],"mappings":"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","sourcesContent":["import { Connection, PublicKey, Transaction, TransactionMessage, VersionedTransaction } from '@solana/web3.js';\nimport { SolanaCluster } from '@hubbleprotocol/hubble-config';\nimport axios from 'axios';\nimport Decimal from 'decimal.js';\nimport { DeserializedVersionedTransaction } from '../utils';\nimport { QuoteResponse, SwapInstructionsResponse, SwapResponse, createJupiterApiClient } from '@jup-ag/api';\n\nexport type SwapTransactionsResponse = {\n setupTransaction: string | undefined;\n swapTransaction: string;\n cleanupTransaction: string | undefined;\n};\n\nexport class JupService {\n private readonly _connection: Connection;\n private readonly _cluster: SolanaCluster;\n\n constructor(connection: Connection, cluster: SolanaCluster) {\n this._connection = connection;\n this._cluster = cluster;\n }\n\n // the amounts has to be in lamports\n static getBestRouteV6 = async (\n userPublicKey: PublicKey,\n amount: Decimal,\n inputMint: PublicKey,\n outputMint: PublicKey,\n slippageBps: number,\n asLegacyTransaction?: boolean,\n maxAccounts?: number,\n onlyDirectRoutes?: boolean\n ): Promise<SwapResponse> => {\n try {\n const jupiterQuoteApi = createJupiterApiClient(); // config is optional\n\n // quote-api.jup.ag/v6/quote?inputMint=7dHbWXmci3dT8UFYWYZweBLXgycu7Y3iL6trKn1Y7ARj&outputMint=mSoLzYCxHdYgdzU16g5QSh3i5K3z3KZK7ytfqcJm7So&amount=71101983&slippageBps=10&onlyDirectRoutes=false&asLegacyTransaction=false&maxAccounts=33\n\n const res = await this.getBestRouteQuoteV6(\n amount,\n inputMint,\n outputMint,\n slippageBps,\n asLegacyTransaction,\n maxAccounts,\n onlyDirectRoutes\n );\n\n const transaction: SwapResponse = await jupiterQuoteApi.swapPost({\n swapRequest: {\n quoteResponse: res,\n userPublicKey: userPublicKey.toString(),\n wrapAndUnwrapSol: false,\n },\n });\n\n return transaction;\n } catch (error) {\n console.log('getBestRouteV6 error', error);\n throw error;\n }\n };\n\n static getBestRouteQuoteV6 = async (\n amount: Decimal,\n inputMint: PublicKey,\n outputMint: PublicKey,\n slippageBps: number,\n asLegacyTransaction?: boolean,\n maxAccounts?: number,\n onlyDirectRoutes?: boolean\n ): Promise<QuoteResponse> => {\n try {\n const jupiterQuoteApi = createJupiterApiClient(); // config is optional\n\n const params = {\n inputMint: inputMint.toString(),\n outputMint: outputMint.toString(),\n amount: amount.floor().toNumber(),\n slippageBps,\n onlyDirectRoutes: onlyDirectRoutes,\n asLegacyTransaction,\n maxAccounts,\n };\n\n return await jupiterQuoteApi.quoteGet(params);\n } catch (error) {\n console.log('getBestRouteQuoteV6 error', error);\n throw error;\n }\n };\n\n static getSwapIxsFromQuote = async (\n userPublicKey: PublicKey,\n quote: QuoteResponse,\n wrapUnwrapSOL = true,\n asLegacyTransaction?: boolean\n ): Promise<SwapInstructionsResponse> => {\n try {\n const jupiterQuoteApi = createJupiterApiClient(); // config is optional\n\n return await jupiterQuoteApi.swapInstructionsPost({\n swapRequest: {\n quoteResponse: quote,\n userPublicKey: userPublicKey.toString(),\n wrapAndUnwrapSol: wrapUnwrapSOL,\n asLegacyTransaction: asLegacyTransaction,\n },\n });\n } catch (error) {\n console.log('getSwapTxFromQuote error', error);\n throw error;\n }\n };\n\n static getPrice = async (inputMint: PublicKey | string, outputMint: PublicKey | string): Promise<number> => {\n const params = {\n ids: inputMint.toString(),\n vsToken: outputMint.toString(),\n vsAmount: 1,\n };\n\n // BONK token\n if (outputMint.toString() === 'DezXAZ8z7PnrnRJjz3wXBoRgixCa6xjnB7YaB1pPB263') {\n params.vsAmount = 100;\n }\n\n const res = await axios.get('https://quote-api.jup.ag/v6/price', { params });\n return res.data.data[inputMint.toString()].price;\n };\n\n static buildTransactionsFromSerialized = (serializedTransactions: Array<string | undefined>): Transaction[] => {\n return serializedTransactions.filter(Boolean).map((tx) => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return Transaction.from(Buffer.from(tx!, 'base64'));\n });\n };\n\n static deserealizeVersionedTransactions = async (\n connection: Connection,\n serializedTransactions: Array<string | undefined>\n ): Promise<DeserializedVersionedTransaction> => {\n const filtered = serializedTransactions.filter(Boolean);\n const result: TransactionMessage[] = [];\n let lookupTablesAddresses: PublicKey[] = [];\n\n for (let i = 0; i < filtered.length; i++) {\n const tx = filtered[i];\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n // safe to use as it is filtered above at 120 line\n const buffer = Buffer.from(tx!, 'base64');\n\n const versionedTx = VersionedTransaction.deserialize(buffer);\n const { addressTableLookups } = versionedTx.message;\n lookupTablesAddresses = [...lookupTablesAddresses, ...addressTableLookups.map((item) => item.accountKey)];\n\n const lookupTableAccountsRequests = addressTableLookups.map((item) => {\n return JupService.getLookupTableAccount(connection, item.accountKey);\n });\n\n const lookupTableAccounts = await Promise.all(lookupTableAccountsRequests);\n\n const decompiledMessage = TransactionMessage.decompile(versionedTx.message, {\n // @ts-ignore\n addressLookupTableAccounts: lookupTableAccounts,\n });\n result.push(decompiledMessage);\n }\n\n return { txMessage: result, lookupTablesAddresses };\n };\n\n static getLookupTableAccount = async (connection: Connection, address: string | PublicKey) => {\n return connection.getAddressLookupTable(new PublicKey(address)).then((res) => res.value);\n };\n}\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Connection, PublicKey } from '@solana/web3.js';
|
|
2
|
+
import Decimal from 'decimal.js';
|
|
3
|
+
import { WhirlpoolStrategy } from '../kamino-client/accounts';
|
|
4
|
+
import { GenericPoolInfo, LiquidityDistribution } from '../utils';
|
|
5
|
+
import { LbPair, PositionV2 } from '../meteora_client/accounts';
|
|
6
|
+
import { WhirlpoolAprApy } from './WhirlpoolAprApy';
|
|
7
|
+
export interface MeteoraPool {
|
|
8
|
+
key: PublicKey;
|
|
9
|
+
pool: LbPair;
|
|
10
|
+
}
|
|
11
|
+
export declare class MeteoraService {
|
|
12
|
+
private readonly _connection;
|
|
13
|
+
private readonly _globalConfig;
|
|
14
|
+
constructor(connection: Connection, globalConfig: PublicKey);
|
|
15
|
+
getPool(poolAddress: PublicKey): Promise<LbPair | null>;
|
|
16
|
+
getPosition(position: PublicKey): Promise<PositionV2 | null>;
|
|
17
|
+
getMeteoraPools(): Promise<MeteoraPool[]>;
|
|
18
|
+
getStrategyMeteoraPoolAprApy(strategy: WhirlpoolStrategy): Promise<WhirlpoolAprApy>;
|
|
19
|
+
getMeteoraLiquidityDistribution(poolKey: PublicKey, keepOrder?: boolean, lowestTick?: number, highestTick?: number): Promise<LiquidityDistribution>;
|
|
20
|
+
getMeteoraPositionAprApy(poolPubkey: PublicKey, priceLower: Decimal, priceUpper: Decimal): Promise<WhirlpoolAprApy>;
|
|
21
|
+
getGenericPoolInfo(poolPubkey: PublicKey): Promise<GenericPoolInfo>;
|
|
22
|
+
getPositionsCountByPool(pool: PublicKey): Promise<number>;
|
|
23
|
+
}
|
|
24
|
+
export declare function computeMeteoraFee(pool: LbPair): Decimal;
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.MeteoraService = void 0;
|
|
16
|
+
exports.computeMeteoraFee = computeMeteoraFee;
|
|
17
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
18
|
+
const decimal_js_1 = __importDefault(require("decimal.js"));
|
|
19
|
+
const utils_1 = require("../utils");
|
|
20
|
+
const accounts_1 = require("../meteora_client/accounts");
|
|
21
|
+
const programId_1 = require("../meteora_client/programId");
|
|
22
|
+
const meteora_1 = require("../utils/meteora");
|
|
23
|
+
class MeteoraService {
|
|
24
|
+
constructor(connection, globalConfig) {
|
|
25
|
+
this._connection = connection;
|
|
26
|
+
this._globalConfig = globalConfig;
|
|
27
|
+
}
|
|
28
|
+
getPool(poolAddress) {
|
|
29
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
30
|
+
return yield accounts_1.LbPair.fetch(this._connection, poolAddress);
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
getPosition(position) {
|
|
34
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
35
|
+
return yield accounts_1.PositionV2.fetch(this._connection, position);
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
getMeteoraPools() {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
const rawPools = yield this._connection.getProgramAccounts(programId_1.METEORA_PROGRAM_ID, {
|
|
41
|
+
commitment: 'confirmed',
|
|
42
|
+
filters: [{ dataSize: 904 }],
|
|
43
|
+
});
|
|
44
|
+
const pools = [];
|
|
45
|
+
for (let i = 0; i < rawPools.length; i++) {
|
|
46
|
+
try {
|
|
47
|
+
const lbPair = accounts_1.LbPair.decode(rawPools[i].account.data);
|
|
48
|
+
pools.push({ pool: lbPair, key: rawPools[i].pubkey });
|
|
49
|
+
}
|
|
50
|
+
catch (e) {
|
|
51
|
+
console.log(e);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return pools;
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
getStrategyMeteoraPoolAprApy(strategy) {
|
|
58
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
59
|
+
const position = yield this.getPosition(strategy.position);
|
|
60
|
+
const pool = yield this.getPool(strategy.pool);
|
|
61
|
+
const decimalsX = strategy.tokenAMintDecimals.toNumber();
|
|
62
|
+
const decimalsY = strategy.tokenBMintDecimals.toNumber();
|
|
63
|
+
let priceLower = new decimal_js_1.default(0);
|
|
64
|
+
let priceUpper = new decimal_js_1.default(0);
|
|
65
|
+
if (position && pool) {
|
|
66
|
+
const priceRange = (0, utils_1.getMeteoraPriceLowerUpper)(position.lowerBinId, position.upperBinId, pool.binStep, decimalsX, decimalsY);
|
|
67
|
+
priceLower = priceRange.priceLower;
|
|
68
|
+
priceUpper = priceRange.priceUpper;
|
|
69
|
+
}
|
|
70
|
+
let priceRange = { priceLower, poolPrice: new decimal_js_1.default(0), priceUpper, strategyOutOfRange: true };
|
|
71
|
+
if (pool && position) {
|
|
72
|
+
priceRange = (0, utils_1.getStrategyPriceRangeMeteora)(priceLower, priceUpper, pool.activeId, pool.binStep, decimalsX, decimalsY);
|
|
73
|
+
}
|
|
74
|
+
if (priceRange.strategyOutOfRange) {
|
|
75
|
+
return Object.assign(Object.assign({}, priceRange), { rewardsApy: [], rewardsApr: [], feeApy: utils_1.ZERO, feeApr: utils_1.ZERO, totalApy: utils_1.ZERO, totalApr: utils_1.ZERO });
|
|
76
|
+
}
|
|
77
|
+
// TODO: fix this
|
|
78
|
+
const totalApr = new decimal_js_1.default(0);
|
|
79
|
+
const feeApr = new decimal_js_1.default(0);
|
|
80
|
+
const rewardsApr = [new decimal_js_1.default(0)];
|
|
81
|
+
return Object.assign({ totalApr, totalApy: (0, utils_1.aprToApy)(totalApr, 365), feeApr, feeApy: (0, utils_1.aprToApy)(feeApr, 365), rewardsApr, rewardsApy: rewardsApr.map((x) => (0, utils_1.aprToApy)(x, 365)) }, priceRange);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
// strongly recommended to pass lowestTick and highestTick because fetching the lowest and highest existent takes very long
|
|
85
|
+
getMeteoraLiquidityDistribution(poolKey_1) {
|
|
86
|
+
return __awaiter(this, arguments, void 0, function* (poolKey, keepOrder = true, lowestTick, highestTick) {
|
|
87
|
+
// trick the linter
|
|
88
|
+
(() => {
|
|
89
|
+
return { keepOrder, highestTick, lowestTick };
|
|
90
|
+
})();
|
|
91
|
+
//TODO: fix this
|
|
92
|
+
const pool = yield this.getPool(poolKey);
|
|
93
|
+
if (!pool) {
|
|
94
|
+
// if the pool doesn't exist, return empty distribution
|
|
95
|
+
return {
|
|
96
|
+
currentPrice: new decimal_js_1.default(0),
|
|
97
|
+
currentTickIndex: 0,
|
|
98
|
+
distribution: [],
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
const currentTickIndex = pool.activeId;
|
|
102
|
+
const tokenXDecimals = yield (0, utils_1.getMintDecimals)(this._connection, pool.tokenXMint);
|
|
103
|
+
const tokenYDecimals = yield (0, utils_1.getMintDecimals)(this._connection, pool.tokenYMint);
|
|
104
|
+
const currentPrice = (0, meteora_1.getPriceOfBinByBinIdWithDecimals)(currentTickIndex, pool.binStep, tokenXDecimals, tokenYDecimals);
|
|
105
|
+
// TODO: add actual distribution
|
|
106
|
+
return {
|
|
107
|
+
currentPrice,
|
|
108
|
+
currentTickIndex,
|
|
109
|
+
distribution: [],
|
|
110
|
+
};
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
getMeteoraPositionAprApy(poolPubkey, priceLower, priceUpper) {
|
|
114
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
115
|
+
const pool = yield this.getPool(poolPubkey);
|
|
116
|
+
if (!pool) {
|
|
117
|
+
return {
|
|
118
|
+
priceLower: utils_1.ZERO,
|
|
119
|
+
priceUpper: utils_1.ZERO,
|
|
120
|
+
poolPrice: utils_1.ZERO,
|
|
121
|
+
strategyOutOfRange: true,
|
|
122
|
+
rewardsApy: [],
|
|
123
|
+
rewardsApr: [],
|
|
124
|
+
feeApy: utils_1.ZERO,
|
|
125
|
+
feeApr: utils_1.ZERO,
|
|
126
|
+
totalApy: utils_1.ZERO,
|
|
127
|
+
totalApr: utils_1.ZERO,
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
const tokenXDecimals = yield (0, utils_1.getMintDecimals)(this._connection, pool.tokenXMint);
|
|
131
|
+
const tokenYDecimals = yield (0, utils_1.getMintDecimals)(this._connection, pool.tokenYMint);
|
|
132
|
+
const priceRange = (0, utils_1.getStrategyPriceRangeMeteora)(priceLower, priceUpper, pool.activeId, pool.binStep, tokenXDecimals, tokenYDecimals);
|
|
133
|
+
if (priceRange.strategyOutOfRange) {
|
|
134
|
+
return Object.assign(Object.assign({}, priceRange), { rewardsApy: [], rewardsApr: [], feeApy: utils_1.ZERO, feeApr: utils_1.ZERO, totalApy: utils_1.ZERO, totalApr: utils_1.ZERO });
|
|
135
|
+
}
|
|
136
|
+
const totalApr = new decimal_js_1.default(0);
|
|
137
|
+
const feeApr = new decimal_js_1.default(0);
|
|
138
|
+
const rewardsApr = [new decimal_js_1.default(0)];
|
|
139
|
+
return Object.assign({ totalApr, totalApy: (0, utils_1.aprToApy)(totalApr, 365), feeApr, feeApy: (0, utils_1.aprToApy)(feeApr, 365), rewardsApr, rewardsApy: rewardsApr.map((x) => (0, utils_1.aprToApy)(x, 365)) }, priceRange);
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
getGenericPoolInfo(poolPubkey) {
|
|
143
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
144
|
+
const pool = yield this.getPool(poolPubkey);
|
|
145
|
+
if (!pool) {
|
|
146
|
+
return {
|
|
147
|
+
dex: 'METEORA',
|
|
148
|
+
address: new web3_js_1.PublicKey(0),
|
|
149
|
+
tokenMintA: new web3_js_1.PublicKey(0),
|
|
150
|
+
tokenMintB: new web3_js_1.PublicKey(0),
|
|
151
|
+
price: new decimal_js_1.default(0),
|
|
152
|
+
feeRate: new decimal_js_1.default(0),
|
|
153
|
+
volumeOnLast7d: new decimal_js_1.default(0),
|
|
154
|
+
tvl: new decimal_js_1.default(0),
|
|
155
|
+
tickSpacing: new decimal_js_1.default(0),
|
|
156
|
+
positions: new decimal_js_1.default(0),
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
const tokenXDecimals = yield (0, utils_1.getMintDecimals)(this._connection, pool.tokenXMint);
|
|
160
|
+
const tokenYDecimals = yield (0, utils_1.getMintDecimals)(this._connection, pool.tokenYMint);
|
|
161
|
+
const price = (0, meteora_1.getPriceOfBinByBinIdWithDecimals)(pool.activeId, pool.binStep, tokenXDecimals, tokenYDecimals);
|
|
162
|
+
const poolInfo = {
|
|
163
|
+
dex: 'METEORA',
|
|
164
|
+
address: new web3_js_1.PublicKey(poolPubkey),
|
|
165
|
+
tokenMintA: pool.tokenXMint,
|
|
166
|
+
tokenMintB: pool.tokenYMint,
|
|
167
|
+
price,
|
|
168
|
+
feeRate: computeMeteoraFee(pool),
|
|
169
|
+
// TODO: add these
|
|
170
|
+
volumeOnLast7d: new decimal_js_1.default(0),
|
|
171
|
+
tvl: new decimal_js_1.default(0),
|
|
172
|
+
tickSpacing: new decimal_js_1.default(pool.binStep),
|
|
173
|
+
// todo(Silviu): get real amount of positions
|
|
174
|
+
positions: new decimal_js_1.default(yield this.getPositionsCountByPool(poolPubkey)),
|
|
175
|
+
};
|
|
176
|
+
return poolInfo;
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
getPositionsCountByPool(pool) {
|
|
180
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
181
|
+
const rawPositions = yield this._connection.getProgramAccounts(programId_1.METEORA_PROGRAM_ID, {
|
|
182
|
+
commitment: 'confirmed',
|
|
183
|
+
filters: [{ dataSize: 8120 }, { memcmp: { bytes: pool.toBase58(), offset: 8 } }],
|
|
184
|
+
});
|
|
185
|
+
return rawPositions.length;
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
exports.MeteoraService = MeteoraService;
|
|
190
|
+
function computeMeteoraFee(pool) {
|
|
191
|
+
return new decimal_js_1.default(pool.parameters.baseFactor).mul(new decimal_js_1.default(pool.binStep)).div(new decimal_js_1.default(1e6));
|
|
192
|
+
}
|
|
193
|
+
//# sourceMappingURL=MeteoraService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MeteoraService.js","sourceRoot":"","sources":["../../src/services/MeteoraService.ts"],"names":[],"mappings":"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","sourcesContent":["import { Connection, PublicKey } from '@solana/web3.js';\nimport Decimal from 'decimal.js';\nimport { WhirlpoolStrategy } from '../kamino-client/accounts';\nimport {\n aprToApy,\n GenericPoolInfo,\n getMeteoraPriceLowerUpper,\n getMintDecimals,\n getStrategyPriceRangeMeteora,\n LiquidityDistribution,\n ZERO,\n} from '../utils';\nimport { LbPair, PositionV2 } from '../meteora_client/accounts';\nimport { WhirlpoolAprApy } from './WhirlpoolAprApy';\nimport { METEORA_PROGRAM_ID } from '../meteora_client/programId';\nimport { getPriceOfBinByBinIdWithDecimals } from '../utils/meteora';\n\nexport interface MeteoraPool {\n key: PublicKey;\n pool: LbPair;\n}\n\nexport class MeteoraService {\n private readonly _connection: Connection;\n private readonly _globalConfig: PublicKey;\n\n constructor(connection: Connection, globalConfig: PublicKey) {\n this._connection = connection;\n this._globalConfig = globalConfig;\n }\n\n async getPool(poolAddress: PublicKey): Promise<LbPair | null> {\n return await LbPair.fetch(this._connection, poolAddress);\n }\n\n async getPosition(position: PublicKey): Promise<PositionV2 | null> {\n return await PositionV2.fetch(this._connection, position);\n }\n\n async getMeteoraPools(): Promise<MeteoraPool[]> {\n const rawPools = await this._connection.getProgramAccounts(METEORA_PROGRAM_ID, {\n commitment: 'confirmed',\n filters: [{ dataSize: 904 }],\n });\n const pools: MeteoraPool[] = [];\n for (let i = 0; i < rawPools.length; i++) {\n try {\n const lbPair = LbPair.decode(rawPools[i].account.data);\n pools.push({ pool: lbPair, key: rawPools[i].pubkey });\n } catch (e) {\n console.log(e);\n }\n }\n return pools;\n }\n\n async getStrategyMeteoraPoolAprApy(strategy: WhirlpoolStrategy): Promise<WhirlpoolAprApy> {\n const position = await this.getPosition(strategy.position);\n\n const pool = await this.getPool(strategy.pool);\n\n const decimalsX = strategy.tokenAMintDecimals.toNumber();\n const decimalsY = strategy.tokenBMintDecimals.toNumber();\n let priceLower: Decimal = new Decimal(0);\n let priceUpper: Decimal = new Decimal(0);\n if (position && pool) {\n const priceRange = getMeteoraPriceLowerUpper(\n position.lowerBinId,\n position.upperBinId,\n pool.binStep,\n decimalsX,\n decimalsY\n );\n priceLower = priceRange.priceLower;\n priceUpper = priceRange.priceUpper;\n }\n\n let priceRange = { priceLower, poolPrice: new Decimal(0), priceUpper, strategyOutOfRange: true };\n if (pool && position) {\n priceRange = getStrategyPriceRangeMeteora(\n priceLower,\n priceUpper,\n pool.activeId,\n pool.binStep,\n decimalsX,\n decimalsY\n );\n }\n\n if (priceRange.strategyOutOfRange) {\n return {\n ...priceRange,\n rewardsApy: [],\n rewardsApr: [],\n feeApy: ZERO,\n feeApr: ZERO,\n totalApy: ZERO,\n totalApr: ZERO,\n };\n }\n\n // TODO: fix this\n const totalApr = new Decimal(0);\n const feeApr = new Decimal(0);\n const rewardsApr = [new Decimal(0)];\n return {\n totalApr,\n totalApy: aprToApy(totalApr, 365),\n feeApr,\n feeApy: aprToApy(feeApr, 365),\n rewardsApr,\n rewardsApy: rewardsApr.map((x) => aprToApy(x, 365)),\n ...priceRange,\n };\n }\n\n // strongly recommended to pass lowestTick and highestTick because fetching the lowest and highest existent takes very long\n async getMeteoraLiquidityDistribution(\n poolKey: PublicKey,\n keepOrder: boolean = true,\n lowestTick?: number,\n highestTick?: number\n ): Promise<LiquidityDistribution> {\n // trick the linter\n (() => {\n return { keepOrder, highestTick, lowestTick };\n })();\n //TODO: fix this\n const pool = await this.getPool(poolKey);\n if (!pool) {\n // if the pool doesn't exist, return empty distribution\n return {\n currentPrice: new Decimal(0),\n currentTickIndex: 0,\n distribution: [],\n };\n }\n\n const currentTickIndex = pool.activeId;\n const tokenXDecimals = await getMintDecimals(this._connection, pool.tokenXMint);\n const tokenYDecimals = await getMintDecimals(this._connection, pool.tokenYMint);\n const currentPrice = getPriceOfBinByBinIdWithDecimals(\n currentTickIndex,\n pool.binStep,\n tokenXDecimals,\n tokenYDecimals\n );\n // TODO: add actual distribution\n return {\n currentPrice,\n currentTickIndex,\n distribution: [],\n };\n }\n\n async getMeteoraPositionAprApy(\n poolPubkey: PublicKey,\n priceLower: Decimal,\n priceUpper: Decimal\n ): Promise<WhirlpoolAprApy> {\n const pool = await this.getPool(poolPubkey);\n if (!pool) {\n return {\n priceLower: ZERO,\n priceUpper: ZERO,\n poolPrice: ZERO,\n strategyOutOfRange: true,\n rewardsApy: [],\n rewardsApr: [],\n feeApy: ZERO,\n feeApr: ZERO,\n totalApy: ZERO,\n totalApr: ZERO,\n };\n }\n const tokenXDecimals = await getMintDecimals(this._connection, pool.tokenXMint);\n const tokenYDecimals = await getMintDecimals(this._connection, pool.tokenYMint);\n const priceRange = getStrategyPriceRangeMeteora(\n priceLower,\n priceUpper,\n pool.activeId,\n pool.binStep,\n tokenXDecimals,\n tokenYDecimals\n );\n if (priceRange.strategyOutOfRange) {\n return {\n ...priceRange,\n rewardsApy: [],\n rewardsApr: [],\n feeApy: ZERO,\n feeApr: ZERO,\n totalApy: ZERO,\n totalApr: ZERO,\n };\n }\n const totalApr = new Decimal(0);\n const feeApr = new Decimal(0);\n const rewardsApr = [new Decimal(0)];\n return {\n totalApr,\n totalApy: aprToApy(totalApr, 365),\n feeApr,\n feeApy: aprToApy(feeApr, 365),\n rewardsApr,\n rewardsApy: rewardsApr.map((x) => aprToApy(x, 365)),\n ...priceRange,\n };\n }\n\n async getGenericPoolInfo(poolPubkey: PublicKey): Promise<GenericPoolInfo> {\n const pool = await this.getPool(poolPubkey);\n if (!pool) {\n return {\n dex: 'METEORA',\n address: new PublicKey(0),\n tokenMintA: new PublicKey(0),\n tokenMintB: new PublicKey(0),\n price: new Decimal(0),\n feeRate: new Decimal(0),\n volumeOnLast7d: new Decimal(0),\n tvl: new Decimal(0),\n tickSpacing: new Decimal(0),\n positions: new Decimal(0),\n };\n }\n const tokenXDecimals = await getMintDecimals(this._connection, pool.tokenXMint);\n const tokenYDecimals = await getMintDecimals(this._connection, pool.tokenYMint);\n const price = getPriceOfBinByBinIdWithDecimals(pool.activeId, pool.binStep, tokenXDecimals, tokenYDecimals);\n\n const poolInfo: GenericPoolInfo = {\n dex: 'METEORA',\n address: new PublicKey(poolPubkey),\n tokenMintA: pool.tokenXMint,\n tokenMintB: pool.tokenYMint,\n price,\n feeRate: computeMeteoraFee(pool),\n // TODO: add these\n volumeOnLast7d: new Decimal(0),\n tvl: new Decimal(0),\n tickSpacing: new Decimal(pool.binStep),\n // todo(Silviu): get real amount of positions\n positions: new Decimal(await this.getPositionsCountByPool(poolPubkey)),\n };\n return poolInfo;\n }\n\n async getPositionsCountByPool(pool: PublicKey): Promise<number> {\n const rawPositions = await this._connection.getProgramAccounts(METEORA_PROGRAM_ID, {\n commitment: 'confirmed',\n filters: [{ dataSize: 8120 }, { memcmp: { bytes: pool.toBase58(), offset: 8 } }],\n });\n\n return rawPositions.length;\n }\n}\n\nexport function computeMeteoraFee(pool: LbPair): Decimal {\n return new Decimal(pool.parameters.baseFactor).mul(new Decimal(pool.binStep)).div(new Decimal(1e6));\n}\n"]}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Connection, PublicKey } from '@solana/web3.js';
|
|
2
|
+
import Decimal from 'decimal.js';
|
|
3
|
+
import { PoolData } from '@orca-so/whirlpool-sdk';
|
|
4
|
+
import { OrcaWhirlpoolsResponse, Whirlpool } from './OrcaWhirlpoolsResponse';
|
|
5
|
+
import { SolanaCluster } from '@hubbleprotocol/hubble-config';
|
|
6
|
+
import { WhirlpoolStrategy } from '../kamino-client/accounts';
|
|
7
|
+
import { WhirlpoolAprApy } from './WhirlpoolAprApy';
|
|
8
|
+
import { GenericPoolInfo, LiquidityDistribution } from '../utils';
|
|
9
|
+
import { CollateralInfo } from '../kamino-client/types';
|
|
10
|
+
import { KaminoPrices } from '../models';
|
|
11
|
+
export declare class OrcaService {
|
|
12
|
+
private readonly _connection;
|
|
13
|
+
private readonly _cluster;
|
|
14
|
+
private readonly _orcaNetwork;
|
|
15
|
+
private readonly _orcaApiUrl;
|
|
16
|
+
private readonly _globalConfig;
|
|
17
|
+
private readonly _kaminoProgramId;
|
|
18
|
+
constructor(connection: Connection, cluster: SolanaCluster, globalConfig: PublicKey, kaminoProgramId?: PublicKey);
|
|
19
|
+
getOrcaWhirlpools(): Promise<OrcaWhirlpoolsResponse>;
|
|
20
|
+
/**
|
|
21
|
+
* Get token prices for a strategy - for use with orca sdk
|
|
22
|
+
* @param strategy
|
|
23
|
+
* @param prices
|
|
24
|
+
* @param collateralInfos
|
|
25
|
+
* @returns {Record<string, Decimal>} - token prices by mint string
|
|
26
|
+
* @private
|
|
27
|
+
*/
|
|
28
|
+
private getTokenPrices;
|
|
29
|
+
private getPoolTokensPrices;
|
|
30
|
+
getPool(poolAddress: PublicKey): Promise<PoolData | null>;
|
|
31
|
+
getStrategyWhirlpoolPoolAprApy(strategy: WhirlpoolStrategy, collateralInfos: CollateralInfo[], prices: KaminoPrices, whirlpools?: Whirlpool[]): Promise<WhirlpoolAprApy>;
|
|
32
|
+
getWhirlpoolLiquidityDistribution(pool: PublicKey, keepOrder?: boolean, lowestTick?: number, highestTick?: number): Promise<LiquidityDistribution>;
|
|
33
|
+
getWhirlpoolPositionAprApy(poolPubkey: PublicKey, priceLower: Decimal, priceUpper: Decimal, prices: KaminoPrices, whirlpools?: Whirlpool[]): Promise<WhirlpoolAprApy>;
|
|
34
|
+
getGenericPoolInfo(poolPubkey: PublicKey, whirlpools?: Whirlpool[]): Promise<GenericPoolInfo>;
|
|
35
|
+
getPositionsCountByPool(pool: PublicKey): Promise<number>;
|
|
36
|
+
}
|