@kamino-finance/klend-sdk 3.2.18 → 3.2.19
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 +42 -0
- package/dist/classes/manager.js +0 -17
- package/dist/classes/manager.js.map +1 -1
- package/dist/classes/market.d.ts +15 -0
- package/dist/classes/market.js +153 -0
- package/dist/classes/market.js.map +1 -1
- package/dist/classes/obligation.js.map +1 -1
- package/dist/classes/reserve.js +0 -45
- package/dist/classes/reserve.js.map +1 -1
- package/dist/client_kamino_manager.d.ts +2 -1
- package/dist/client_kamino_manager.js +22 -21
- package/dist/client_kamino_manager.js.map +1 -1
- package/dist/idl.json +41 -19
- package/dist/idl_codegen/accounts/LendingMarket.d.ts +6 -6
- package/dist/idl_codegen/accounts/LendingMarket.js +5 -5
- package/dist/idl_codegen/accounts/LendingMarket.js.map +1 -1
- package/dist/idl_codegen/errors/custom.d.ts +25 -1
- package/dist/idl_codegen/errors/custom.js +40 -1
- package/dist/idl_codegen/errors/custom.js.map +1 -1
- package/dist/idl_codegen/instructions/flashBorrowReserveLiquidity.d.ts +0 -1
- package/dist/idl_codegen/instructions/flashBorrowReserveLiquidity.js +1 -1
- package/dist/idl_codegen/instructions/flashBorrowReserveLiquidity.js.map +1 -1
- package/dist/idl_codegen/instructions/flashRepayReserveLiquidity.d.ts +0 -1
- package/dist/idl_codegen/instructions/flashRepayReserveLiquidity.js +1 -1
- package/dist/idl_codegen/instructions/flashRepayReserveLiquidity.js.map +1 -1
- package/dist/idl_codegen/instructions/index.d.ts +2 -0
- package/dist/idl_codegen/instructions/index.js +3 -1
- package/dist/idl_codegen/instructions/index.js.map +1 -1
- package/dist/idl_codegen/instructions/refreshReservesBatch.d.ts +6 -0
- package/dist/idl_codegen/instructions/refreshReservesBatch.js +43 -0
- package/dist/idl_codegen/instructions/refreshReservesBatch.js.map +1 -0
- package/dist/idl_codegen/programId.js.map +1 -1
- package/dist/idl_codegen/types/ReserveConfig.d.ts +16 -16
- package/dist/idl_codegen/types/ReserveConfig.js +12 -12
- package/dist/idl_codegen/types/ReserveConfig.js.map +1 -1
- package/dist/idl_codegen/types/UpdateConfigMode.d.ts +14 -14
- package/dist/idl_codegen/types/UpdateConfigMode.js +25 -25
- package/dist/idl_codegen/types/UpdateConfigMode.js.map +1 -1
- package/dist/idl_codegen/types/UpdateLendingMarketMode.d.ts +20 -7
- package/dist/idl_codegen/types/UpdateLendingMarketMode.js +39 -13
- package/dist/idl_codegen/types/UpdateLendingMarketMode.js.map +1 -1
- package/dist/idl_codegen/types/index.d.ts +4 -4
- package/dist/idl_codegen/types/index.js.map +1 -1
- package/dist/utils/instruction.js +0 -1
- package/dist/utils/instruction.js.map +1 -1
- package/dist/utils/managerTypes.js +2 -2
- package/dist/utils/managerTypes.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -83,3 +83,45 @@ $ cp ../kamino-lending/target/deploy/kamino_lending.so deps/programs/kamino_lend
|
|
|
83
83
|
$ cp ../kamino-lending/target/idl/kamino_lending.json src/idl.json
|
|
84
84
|
$ yarn codegen
|
|
85
85
|
```
|
|
86
|
+
|
|
87
|
+
### Getting a vanilla obligation for a user
|
|
88
|
+
```ts
|
|
89
|
+
const kaminoMarket = await KaminoMarket.load(env.provider.connection, marketAddress, DEFAULT_RECENT_SLOT_DURATION_MS, programId);
|
|
90
|
+
|
|
91
|
+
const obligation = await kaminoMarket!.getUserVanillaObligation(user);
|
|
92
|
+
|
|
93
|
+
// to check the reserve is used in the obligation
|
|
94
|
+
const isReservePartOfObligation = kaminoMarket!.isReserveInObligation(obligation, reserve);
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
### Getting a list of user obligations for a specific reserve
|
|
98
|
+
```ts
|
|
99
|
+
const kaminoMarket = await KaminoMarket.load(env.provider.connection, marketAddress, DEFAULT_RECENT_SLOT_DURATION_MS, programId);
|
|
100
|
+
|
|
101
|
+
const obligations = await kaminoMarket!.getAllUserObligationsForReserve(user, reserve);
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
### Getting a list of user obligations for a specific reserve with caching
|
|
105
|
+
1. Fetch all user obligations, this should be cached as it takes longer to fetch
|
|
106
|
+
```ts
|
|
107
|
+
const kaminoMarket = await KaminoMarket.load(env.provider.connection, marketAddress, DEFAULT_RECENT_SLOT_DURATION_MS, programId);
|
|
108
|
+
|
|
109
|
+
const allUserObligations = await kaminoMarket!.getAllUserObligations(user);
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
```ts
|
|
113
|
+
allUserObligations.forEach(obligation => {
|
|
114
|
+
if (obligation !== null) {
|
|
115
|
+
for (const deposits of obligation.deposits.keys()) {
|
|
116
|
+
if (deposits.equals(reserve)) {
|
|
117
|
+
finalObligations.push(obligation);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
for (const borrows of obligation.borrows.keys()) {
|
|
121
|
+
if (borrows.equals(reserve)) {
|
|
122
|
+
finalObligations.push(obligation);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
```
|
package/dist/classes/manager.js
CHANGED
|
@@ -472,16 +472,6 @@ function parseForChangesMarketConfigAndGetIxs(marketWithAddress, newMarket, prog
|
|
|
472
472
|
});
|
|
473
473
|
}
|
|
474
474
|
}
|
|
475
|
-
else if (key === 'multiplierPointsTagBoost') {
|
|
476
|
-
for (let i = 0; i < market.multiplierPointsTagBoost.length; i++) {
|
|
477
|
-
if (market.multiplierPointsTagBoost[i] !== newMarket.multiplierPointsTagBoost[i]) {
|
|
478
|
-
updateLendingMarketIxnsArgs.push({
|
|
479
|
-
mode: types_1.UpdateLendingMarketMode.UpdateMultiplierPoints.discriminator,
|
|
480
|
-
value: updateMarketConfigEncodedValue(types_1.UpdateLendingMarketMode.UpdateMultiplierPoints.discriminator, newMarket.multiplierPointsTagBoost),
|
|
481
|
-
});
|
|
482
|
-
}
|
|
483
|
-
}
|
|
484
|
-
}
|
|
485
475
|
else if (key === 'minNetValueInObligationSf') {
|
|
486
476
|
if (!market.minNetValueInObligationSf.eq(newMarket.minNetValueInObligationSf)) {
|
|
487
477
|
updateLendingMarketIxnsArgs.push({
|
|
@@ -528,7 +518,6 @@ function parseForChangesMarketConfigAndGetIxs(marketWithAddress, newMarket, prog
|
|
|
528
518
|
}
|
|
529
519
|
function updateMarketConfigEncodedValue(discriminator, value) {
|
|
530
520
|
let buffer = Buffer.alloc(72);
|
|
531
|
-
let valueArray = [];
|
|
532
521
|
let pkBuffer;
|
|
533
522
|
let valueBigInt;
|
|
534
523
|
switch (discriminator) {
|
|
@@ -551,12 +540,6 @@ function updateMarketConfigEncodedValue(discriminator, value) {
|
|
|
551
540
|
value = value;
|
|
552
541
|
buffer.writeBigUint64LE(BigInt(value), 0);
|
|
553
542
|
break;
|
|
554
|
-
case types_1.UpdateLendingMarketMode.UpdateMultiplierPoints.discriminator:
|
|
555
|
-
valueArray = value;
|
|
556
|
-
for (let i = 0; i < valueArray.length; i++) {
|
|
557
|
-
buffer.writeUIntLE(valueArray[i], i, 1);
|
|
558
|
-
}
|
|
559
|
-
break;
|
|
560
543
|
case types_1.UpdateLendingMarketMode.UpdateOwner.discriminator:
|
|
561
544
|
case types_1.UpdateLendingMarketMode.UpdateRiskCouncil.discriminator:
|
|
562
545
|
pkBuffer = value.toBuffer();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/classes/manager.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n Connection,\n Keypair,\n PublicKey,\n SystemProgram,\n SYSVAR_RENT_PUBKEY,\n TransactionInstruction,\n} from '@solana/web3.js';\nimport { KaminoVault, KaminoVaultClient, KaminoVaultConfig, kaminoVaultId, ReserveAllocationConfig } from './vault';\nimport {\n AddAssetToMarketParams,\n CreateKaminoMarketParams,\n createReserveIxs,\n DEFAULT_RECENT_SLOT_DURATION_MS,\n ENV,\n getReserveOracleConfigs,\n initLendingMarket,\n InitLendingMarketAccounts,\n InitLendingMarketArgs,\n LendingMarket,\n lendingMarketAuthPda,\n MarketWithAddress,\n parseForChangesReserveConfigAndGetIxs,\n parseOracleType,\n PubkeyHashMap,\n Reserve,\n ReserveWithAddress,\n ScopeOracleConfig,\n updateEntireReserveConfigIx,\n updateLendingMarket,\n UpdateLendingMarketAccounts,\n UpdateLendingMarketArgs,\n updateLendingMarketOwner,\n UpdateLendingMarketOwnerAccounts,\n} from '../lib';\nimport { PROGRAM_ID } from '../idl_codegen/programId';\nimport { Scope, TokenMetadatas, U16_MAX } from '@hubbleprotocol/scope-sdk';\nimport BN from 'bn.js';\nimport { ElevationGroup, ReserveConfig, UpdateLendingMarketMode } from '../idl_codegen/types';\nimport Decimal from 'decimal.js';\nimport * as anchor from '@coral-xyz/anchor';\n\n/**\n * KaminoManager is a class that provides a high-level interface to interact with the Kamino Lend and Kamino Vault programs, in order to create and manage a market, as well as vaults\n */\nexport class KaminoManager {\n private readonly _connection: Connection;\n private readonly _kaminoVaultProgramId: PublicKey;\n private readonly _kaminoLendProgramId: PublicKey;\n private readonly _vaultClient: KaminoVaultClient;\n recentSlotDurationMs: number;\n\n constructor(\n connection: Connection,\n kaminoLendProgramId?: PublicKey,\n kaminoVaultProgramId?: PublicKey,\n recentSlotDurationMs?: number\n ) {\n this._connection = connection;\n this._kaminoVaultProgramId = kaminoVaultProgramId ? kaminoVaultProgramId : kaminoVaultId;\n this._kaminoLendProgramId = kaminoLendProgramId ? kaminoLendProgramId : PROGRAM_ID;\n this.recentSlotDurationMs = recentSlotDurationMs ? recentSlotDurationMs : DEFAULT_RECENT_SLOT_DURATION_MS;\n this._vaultClient = new KaminoVaultClient(\n connection,\n this._kaminoVaultProgramId,\n this._kaminoLendProgramId,\n this.recentSlotDurationMs\n );\n }\n\n getConnection() {\n return this._connection;\n }\n\n getProgramID() {\n return this._kaminoVaultProgramId;\n }\n\n /**\n * This is a function that helps quickly setting up a reserve for an asset with a default config. The config can be modified later on.\n * @param params.admin - the admin of the market\n * @returns market keypair - keypair used for market account creation -> to be signed with when executing the transaction\n * @returns ixns - an array of ixns for creating and initializing the market account\n */\n async createMarketIxs(\n params: CreateKaminoMarketParams\n ): Promise<{ market: Keypair; ixns: TransactionInstruction[] }> {\n const marketAccount = Keypair.generate();\n const size = LendingMarket.layout.span + 8;\n const [lendingMarketAuthority, _] = lendingMarketAuthPda(marketAccount.publicKey, this._kaminoLendProgramId);\n const createMarketIxns: TransactionInstruction[] = [];\n\n createMarketIxns.push(\n SystemProgram.createAccount({\n fromPubkey: params.admin,\n newAccountPubkey: marketAccount.publicKey,\n lamports: await this._connection.getMinimumBalanceForRentExemption(size),\n space: size,\n programId: this._kaminoLendProgramId,\n })\n );\n\n const accounts: InitLendingMarketAccounts = {\n lendingMarketOwner: params.admin,\n lendingMarket: marketAccount.publicKey,\n lendingMarketAuthority: lendingMarketAuthority,\n systemProgram: SystemProgram.programId,\n rent: SYSVAR_RENT_PUBKEY,\n };\n\n const args: InitLendingMarketArgs = {\n quoteCurrency: Array(32).fill(0),\n };\n\n createMarketIxns.push(initLendingMarket(args, accounts, this._kaminoLendProgramId));\n\n return { market: marketAccount, ixns: createMarketIxns };\n }\n\n /**\n * This is a function that helps quickly setting up a reserve for an asset with a default config. The config can be modified later on.\n * @param params.admin - the admin of the reserve\n * @param params.marketAddress - the market to create a reserve for, only the market admin can create a reserve for the market\n * @param params.assetConfig - an object that helps generate a default reserve config with some inputs which have to be configured before calling this function\n * @returns reserve - keypair used for reserve creation -> to be signed with when executing the transaction\n * @returns txnIxns - an array of arrays of ixns -> first array for reserve creation, second for updating it with correct params\n */\n async addAssetToMarketIxs(\n params: AddAssetToMarketParams\n ): Promise<{ reserve: Keypair; txnIxns: TransactionInstruction[][] }> {\n const market = await LendingMarket.fetch(this._connection, params.marketAddress, this._kaminoLendProgramId);\n if (!market) {\n throw new Error('Market not found');\n }\n const marketWithAddress: MarketWithAddress = { address: params.marketAddress, state: market };\n\n const reserveAccount = Keypair.generate();\n\n const createReserveInstructions = await createReserveIxs(\n this._connection,\n params.admin,\n params.marketAddress,\n params.assetConfig.mint,\n reserveAccount.publicKey,\n this._kaminoLendProgramId\n );\n\n const updateReserveInstructions = await this.updateReserveIxs(\n marketWithAddress,\n reserveAccount.publicKey,\n params.assetConfig.getReserveConfig(),\n undefined,\n true\n );\n\n const txnIxns: TransactionInstruction[][] = [];\n txnIxns.push(createReserveInstructions);\n txnIxns.push(updateReserveInstructions);\n\n return { reserve: reserveAccount, txnIxns };\n }\n\n /**\n * This method will create a vault with a given config. The config can be changed later on, but it is recommended to set it up correctly from the start\n * @param vaultConfig - the config object used to create a vault\n * @returns vault - keypair, should be used to sign the transaction which creates the vault account\n * @returns ixns - an array of instructions to create the vault\n */\n async createVaultIxs(vaultConfig: KaminoVaultConfig): Promise<{ vault: Keypair; ixns: TransactionInstruction[] }> {\n return this._vaultClient.createVaultIxs(vaultConfig);\n }\n\n /**\n * This method updates the vault reserve allocation cofnig for an exiting vault reserve, or adds a new reserve to the vault if it does not exist.\n * @param vault - vault to be updated\n * @param reserveAllocationConfig - new reserve allocation config\n * @returns - a list of instructions\n */\n async updateVaultReserveAllocationIxs(\n vault: KaminoVault,\n reserveAllocationConfig: ReserveAllocationConfig\n ): Promise<TransactionInstruction> {\n return this._vaultClient.updateReserveAllocationIxs(vault, reserveAllocationConfig);\n }\n\n /**\n * This method retruns the reserve config for a given reserve\n * @param reserve - reserve to get the config for\n * @returns - the reserve config\n */\n async getReserveConfig(reserve: PublicKey): Promise<ReserveConfig> {\n const reserveState = await Reserve.fetch(this._connection, reserve);\n if (!reserveState) {\n throw new Error('Reserve not found');\n }\n return reserveState.config;\n }\n\n /**\n * This function enables the update of the scope oracle configuration. In order to get a list of scope prices, getScopeOracleConfigs can be used\n * @param market - lending market which owns the reserve\n * @param reserve - reserve which to be updated\n * @param scopeOracleConfig - new scope oracle config\n * @param scopeTwapConfig - new scope twap config\n * @param maxAgeBufferSeconds - buffer to be added to onchain max_age - if oracle price is older than that, txns interacting with the reserve will fail\n * @returns - an array of instructions used update the oracle configuration\n */\n async updateReserveScopeOracleConfigurationIxs(\n market: MarketWithAddress,\n reserve: ReserveWithAddress,\n scopeOracleConfig: ScopeOracleConfig,\n scopeTwapConfig?: ScopeOracleConfig,\n maxAgeBufferSeconds: number = 20\n ): Promise<TransactionInstruction[]> {\n const reserveConfig = reserve.state.config;\n\n let scopeTwapId = U16_MAX;\n if (scopeTwapConfig) {\n scopeTwapId = scopeTwapConfig.oracleId;\n\n // if(scopeTwapConfig.twapSourceId !== scopeOracleConfig.oracleId) {\n // throw new Error('Twap source id must match oracle id');\n // }\n }\n\n const { scopeConfiguration } = getReserveOracleConfigs({\n scopePriceConfigAddress: scopeOracleConfig.scopePriceConfigAddress,\n scopeChain: [scopeOracleConfig.oracleId],\n scopeTwapChain: [scopeTwapId],\n });\n\n const newReserveConfig = new ReserveConfig({\n ...reserveConfig,\n tokenInfo: {\n ...reserveConfig.tokenInfo,\n scopeConfiguration: scopeConfiguration,\n // TODO: Decide if we want to keep this maxAge override for twap & price\n maxAgeTwapSeconds: scopeTwapConfig\n ? new BN(scopeTwapConfig.max_age + maxAgeBufferSeconds)\n : reserveConfig.tokenInfo.maxAgeTwapSeconds,\n maxAgePriceSeconds: new BN(scopeOracleConfig.max_age + maxAgeBufferSeconds),\n },\n });\n\n return this.updateReserveIxs(market, reserve.address, newReserveConfig, reserve.state);\n }\n\n /**\n * This function updates the given reserve with a new config. It can either update the entire reserve config or just update fields which differ between given reserve and existing reserve\n * @param marketWithAddress - the market that owns the reserve to be updated\n * @param reserve - the reserve to be updated\n * @param config - the new reserve configuration to be used for the update\n * @param reserveStateOverride - the reserve state, useful to provide, if already fetched outside this method, in order to avoid an extra rpc call to fetch it. Make sure the reserveConfig has not been updated since fetching the reserveState that you pass in.\n * @param updateEntireConfig - when set to false, it will only update fields that are different between @param config and reserveState.config, set to true it will always update entire reserve config. An entire reserveConfig update might be too large for a multisig transaction\n * @returns - an array of multiple update ixns. If there are many fields that are being updated without the updateEntireConfig=true, multiple transactions might be required to fit all ixns.\n */\n async updateReserveIxs(\n marketWithAddress: MarketWithAddress,\n reserve: PublicKey,\n config: ReserveConfig,\n reserveStateOverride?: Reserve,\n updateEntireConfig: boolean = false\n ): Promise<TransactionInstruction[]> {\n const reserveState = reserveStateOverride\n ? reserveStateOverride\n : (await Reserve.fetch(this._connection, reserve, this._kaminoLendProgramId))!;\n const ixns: TransactionInstruction[] = [];\n\n if (!reserveState || updateEntireConfig) {\n ixns.push(updateEntireReserveConfigIx(marketWithAddress, reserve, config, this._kaminoLendProgramId));\n } else {\n ixns.push(\n ...parseForChangesReserveConfigAndGetIxs(\n marketWithAddress,\n reserveState,\n reserve,\n config,\n this._kaminoLendProgramId\n )\n );\n }\n\n return ixns;\n }\n\n /**\n * This function creates instructions to deposit into a vault. It will also create ATA creation instructions for the vault shares that the user receives in return\n * @param user - user to deposit\n * @param vault - vault to deposit into\n * @param tokenAmount - token amount to be deposited, in decimals (will be converted in lamports)\n * @returns - an array of instructions to be used to be executed\n */\n async depositToVaultIxs(\n user: PublicKey,\n vault: KaminoVault,\n tokenAmount: Decimal\n ): Promise<TransactionInstruction[]> {\n return this._vaultClient.depositIxs(user, vault, tokenAmount);\n }\n\n /**\n * This function will return the missing ATA creation instructions, as well as one or multiple withdraw instructions, based on how many reserves it's needed to withdraw from. This might have to be split in multiple transactions\n * @param user - user to withdraw\n * @param vault - vault to withdraw from\n * @param shareAmount - share amount to withdraw, in order to withdraw everything, any value > user share amount\n * @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault\n * @returns an array of instructions to be executed\n */\n async withdrawFromVaultIxs(\n user: PublicKey,\n vault: KaminoVault,\n shareAmount: Decimal,\n slot: number\n ): Promise<TransactionInstruction[]> {\n return this._vaultClient.withdrawIxs(user, vault, shareAmount, slot);\n }\n\n /**\n * This method calculates the token per share value. This will always change based on interest earned from the vault, but calculating it requires a bunch of rpc requests. Caching this for a short duration would be optimal\n * @param vault - vault to calculate tokensPerShare for\n * @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault\n * @returns - token per share value\n */\n async getTokensPerShareSingleVault(vault: KaminoVault, slot: number): Promise<Decimal> {\n return this._vaultClient.getTokensPerShareSingleVault(vault, slot);\n }\n\n /**\n * This method returns the user shares balance for a given vault\n * @param user - user to calculate the shares balance for\n * @param vault - vault to calculate shares balance for\n * @returns - user share balance in decimal (not lamports)\n */\n async getUserSharesBalanceSingleVault(user: PublicKey, vault: KaminoVault): Promise<Decimal> {\n return this._vaultClient.getUserSharesBalanceSingleVault(user, vault);\n }\n\n /**\n * This method returns the user shares balance for all existing vaults\n * @param user - user to calculate the shares balance for\n * @param vaultsOverride - the kamino vaults if already fetched, in order to reduce rpc calls\n * @returns - hash map with keyh as vault address and value as user share balance in decimal (not lamports)\n */\n async getUserSharesBalanceAllVaults(\n user: PublicKey,\n vaultsOverride: KaminoVault[]\n ): Promise<PubkeyHashMap<PublicKey, Decimal>> {\n return this._vaultClient.getUserSharesBalanceAllVaults(user, vaultsOverride);\n }\n\n /**\n * @returns - the KaminoVault client\n */\n getKaminoVaultClient(): KaminoVaultClient {\n return this._vaultClient;\n }\n\n /**\n * This will trigger invest by balancing, based on weights, the reserve allocations of the vault. It can either withdraw or deposit into reserves to balance them. This is a function that should be cranked\n * @param kaminoVault - vault to invest from\n * @returns - an array of invest instructions for each invest action required for the vault reserves\n */\n async investAllReserves(kaminoVault: KaminoVault): Promise<TransactionInstruction[]> {\n return this._vaultClient.investAllReservesIxs(kaminoVault);\n }\n\n /**\n * This will trigger invest by balancing, based on weights, the reserve allocation of the vault. It can either withdraw or deposit into the given reserve to balance it\n * @param kaminoVault - vault to invest from\n * @param reserve - reserve to invest into or disinvest from\n * @returns - an array of invest instructions for each invest action required for the vault reserves\n */\n async investSingleReserve(\n kaminoVault: KaminoVault,\n reserveWithAddress: ReserveWithAddress\n ): Promise<TransactionInstruction> {\n return this._vaultClient.investSingleReserveIxs(kaminoVault, reserveWithAddress);\n }\n\n /**\n * This retruns an array of scope oracle configs to be used to set the scope price and twap oracles for a reserve\n * @param feed - scope feed to fetch prices from\n * @param cluster - cluster to fetch from, this should be left unchanged unless working on devnet or locally\n * @returns - an array of scope oracle configs\n */\n async getScopeOracleConfigs(\n feed: string = 'hubble',\n cluster: ENV = 'mainnet-beta'\n ): Promise<Array<ScopeOracleConfig>> {\n const scopeOracleConfigs: Array<ScopeOracleConfig> = [];\n\n const scope = new Scope(cluster, this._connection);\n const oracleMappings = await scope.getOracleMappings({ feed: feed });\n const [, feedConfig] = await scope.getFeedConfiguration({ feed: feed });\n const tokenMetadatas = await TokenMetadatas.fetch(this._connection, feedConfig.tokensMetadata);\n const decoder = new TextDecoder('utf-8');\n\n console.log('feedConfig.tokensMetadata', feedConfig.tokensMetadata);\n\n if (tokenMetadatas === null) {\n throw new Error('TokenMetadatas not found');\n }\n\n for (let index = 0; index < oracleMappings.priceInfoAccounts.length; index++) {\n if (!oracleMappings.priceInfoAccounts[index].equals(PublicKey.default)) {\n const name = decoder.decode(Uint8Array.from(tokenMetadatas.metadatasArray[index].name)).replace(/\\0/g, '');\n const oracleType = parseOracleType(oracleMappings.priceTypes[index]);\n\n scopeOracleConfigs.push({\n scopePriceConfigAddress: feedConfig.oraclePrices,\n name: name,\n oracleType: oracleType,\n oracleId: index,\n oracleAccount: oracleMappings.priceInfoAccounts[index],\n twapEnabled: oracleMappings.twapEnabled[index] === 1,\n twapSourceId: oracleMappings.twapSource[index],\n max_age: tokenMetadatas.metadatasArray[index].maxAgePriceSlots.toNumber(),\n });\n }\n }\n\n return scopeOracleConfigs;\n }\n\n /**\n * This retruns an array of instructions to be used to update the lending market configurations\n * @param marketWithAddress - the market address and market state object\n * @param newMarket - the lending market state with the new configuration - to be build we new config options from the previous state\n * @returns - an array of instructions\n */\n updateLendingMarketIxs(marketWithAddress: MarketWithAddress, newMarket: LendingMarket): TransactionInstruction[] {\n return parseForChangesMarketConfigAndGetIxs(marketWithAddress, newMarket, this._kaminoLendProgramId);\n }\n\n /**\n * This retruns an instruction to be used to update the market owner. This can only be executed by the current lendingMarketOwnerCached\n * @param marketWithAddress - the market address and market state object\n * @param newMarket - the lending market state with the new configuration - to be build we new config options from the previous state\n * @returns - an array of instructions\n */\n updateLendingMarketOwnerIxs(marketWithAddress: MarketWithAddress): TransactionInstruction {\n const accounts: UpdateLendingMarketOwnerAccounts = {\n lendingMarketOwnerCached: marketWithAddress.state.lendingMarketOwnerCached,\n lendingMarket: marketWithAddress.address,\n };\n\n return updateLendingMarketOwner(accounts, this._kaminoLendProgramId);\n }\n} // KaminoManager\n\nfunction parseForChangesMarketConfigAndGetIxs(\n marketWithAddress: MarketWithAddress,\n newMarket: LendingMarket,\n programId: PublicKey\n): TransactionInstruction[] {\n const market = marketWithAddress.state;\n const updateLendingMarketIxnsArgs: { mode: number; value: Buffer }[] = [];\n for (const key in market.toJSON()) {\n if (key === 'lendingMarketOwner') {\n if (!market.lendingMarketOwner.equals(newMarket.lendingMarketOwner)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateOwner.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateOwner.discriminator,\n newMarket.lendingMarketOwner\n ),\n });\n }\n } else if (key === 'lendingMarketOwnerCached') {\n if (!market.lendingMarketOwnerCached.equals(newMarket.lendingMarketOwnerCached)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateOwner.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateOwner.discriminator,\n newMarket.lendingMarketOwnerCached\n ),\n });\n }\n } else if (key === 'referralFeeBps') {\n if (market.referralFeeBps !== newMarket.referralFeeBps) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateReferralFeeBps.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateReferralFeeBps.discriminator,\n newMarket.referralFeeBps\n ),\n });\n }\n } else if (key === 'emergencyMode') {\n if (market.emergencyMode !== newMarket.emergencyMode) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateEmergencyMode.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateEmergencyMode.discriminator,\n newMarket.emergencyMode\n ),\n });\n }\n } else if (key === 'autodeleverageEnabled') {\n if (market.autodeleverageEnabled !== newMarket.autodeleverageEnabled) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateAutodeleverageEnabled.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateAutodeleverageEnabled.discriminator,\n newMarket.autodeleverageEnabled\n ),\n });\n }\n } else if (key === 'borrowDisabled') {\n if (market.borrowDisabled !== newMarket.borrowDisabled) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateBorrowingDisabled.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateBorrowingDisabled.discriminator,\n newMarket.borrowDisabled\n ),\n });\n }\n } else if (key === 'priceRefreshTriggerToMaxAgePct') {\n if (market.priceRefreshTriggerToMaxAgePct !== newMarket.priceRefreshTriggerToMaxAgePct) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdatePriceRefreshTriggerToMaxAgePct.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdatePriceRefreshTriggerToMaxAgePct.discriminator,\n newMarket.priceRefreshTriggerToMaxAgePct\n ),\n });\n }\n } else if (key === 'liquidationMaxDebtCloseFactorPct') {\n if (market.liquidationMaxDebtCloseFactorPct !== newMarket.liquidationMaxDebtCloseFactorPct) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateLiquidationCloseFactor.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateLiquidationCloseFactor.discriminator,\n newMarket.liquidationMaxDebtCloseFactorPct\n ),\n });\n }\n } else if (key === 'insolvencyRiskUnhealthyLtvPct') {\n if (market.insolvencyRiskUnhealthyLtvPct !== newMarket.insolvencyRiskUnhealthyLtvPct) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateInsolvencyRiskLtv.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateInsolvencyRiskLtv.discriminator,\n newMarket.insolvencyRiskUnhealthyLtvPct\n ),\n });\n }\n } else if (key === 'minFullLiquidationValueThreshold') {\n if (!market.minFullLiquidationValueThreshold.eq(newMarket.minFullLiquidationValueThreshold)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMinFullLiquidationThreshold.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMinFullLiquidationThreshold.discriminator,\n newMarket.minFullLiquidationValueThreshold.toNumber()\n ),\n });\n }\n } else if (key === 'maxLiquidatableDebtMarketValueAtOnce') {\n if (!market.maxLiquidatableDebtMarketValueAtOnce.eq(newMarket.maxLiquidatableDebtMarketValueAtOnce)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateLiquidationMaxValue.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateLiquidationMaxValue.discriminator,\n newMarket.maxLiquidatableDebtMarketValueAtOnce.toNumber()\n ),\n });\n }\n } else if (key === 'globalUnhealthyBorrowValue') {\n if (!market.globalUnhealthyBorrowValue.eq(newMarket.globalUnhealthyBorrowValue)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateGlobalUnhealthyBorrow.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateGlobalUnhealthyBorrow.discriminator,\n newMarket.globalUnhealthyBorrowValue.toNumber()\n ),\n });\n }\n } else if (key === 'globalAllowedBorrowValue') {\n if (!market.globalAllowedBorrowValue.eq(newMarket.globalAllowedBorrowValue)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateGlobalAllowedBorrow.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateGlobalAllowedBorrow.discriminator,\n newMarket.globalAllowedBorrowValue.toNumber()\n ),\n });\n }\n } else if (key === 'riskCouncil') {\n if (!market.riskCouncil.equals(newMarket.riskCouncil)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateRiskCouncil.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateRiskCouncil.discriminator,\n newMarket.riskCouncil\n ),\n });\n }\n } else if (key === 'multiplierPointsTagBoost') {\n for (let i = 0; i < market.multiplierPointsTagBoost.length; i++) {\n if (market.multiplierPointsTagBoost[i] !== newMarket.multiplierPointsTagBoost[i]) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMultiplierPoints.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMultiplierPoints.discriminator,\n newMarket.multiplierPointsTagBoost\n ),\n });\n }\n }\n } else if (key === 'minNetValueInObligationSf') {\n if (!market.minNetValueInObligationSf.eq(newMarket.minNetValueInObligationSf)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMinNetValueObligationPostAction.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMinNetValueObligationPostAction.discriminator,\n newMarket.minNetValueInObligationSf.toString()\n ),\n });\n }\n } else if (key === 'minValueSkipLiquidationLtvBfChecks') {\n if (!market.minValueSkipLiquidationLtvBfChecks.eq(newMarket.minValueSkipLiquidationLtvBfChecks)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMinValueSkipPriorityLiqCheck.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMinValueSkipPriorityLiqCheck.discriminator,\n newMarket.minValueSkipLiquidationLtvBfChecks.toNumber()\n ),\n });\n }\n } else if (key === 'elevationGroups') {\n let elevationGroupsDiffs = 0;\n for (let i = 0; i < market.elevationGroups.length; i++) {\n if (\n market.elevationGroups[i].id !== newMarket.elevationGroups[i].id ||\n market.elevationGroups[i].maxLiquidationBonusBps !== newMarket.elevationGroups[i].maxLiquidationBonusBps ||\n market.elevationGroups[i].ltvPct !== newMarket.elevationGroups[i].ltvPct ||\n market.elevationGroups[i].liquidationThresholdPct !== newMarket.elevationGroups[i].liquidationThresholdPct ||\n market.elevationGroups[i].allowNewLoans !== newMarket.elevationGroups[i].allowNewLoans ||\n market.elevationGroups[i].maxReservesAsCollateral !== newMarket.elevationGroups[i].maxReservesAsCollateral ||\n !market.elevationGroups[i].debtReserve.equals(newMarket.elevationGroups[i].debtReserve)\n ) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateElevationGroup.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateElevationGroup.discriminator,\n newMarket.elevationGroups[i]\n ),\n });\n elevationGroupsDiffs++;\n }\n }\n if (elevationGroupsDiffs > 1) {\n throw new Error('Can only update 1 elevation group at a time');\n }\n }\n } // for loop\n\n const ixns: TransactionInstruction[] = [];\n\n updateLendingMarketIxnsArgs.forEach((updateLendingMarketConfigArgs) => {\n ixns.push(\n updateMarketConfigIx(\n marketWithAddress,\n updateLendingMarketConfigArgs.mode,\n updateLendingMarketConfigArgs.value,\n programId\n )\n );\n });\n\n return ixns;\n}\n\nfunction updateMarketConfigEncodedValue(\n discriminator: number,\n value: number | number[] | PublicKey | ElevationGroup | string\n): Buffer {\n let buffer: Buffer = Buffer.alloc(72);\n let valueArray: number[] = [];\n let pkBuffer: Buffer;\n let valueBigInt: bigint;\n\n switch (discriminator) {\n case UpdateLendingMarketMode.UpdateEmergencyMode.discriminator:\n case UpdateLendingMarketMode.UpdateLiquidationCloseFactor.discriminator:\n case UpdateLendingMarketMode.UpdateInsolvencyRiskLtv.discriminator:\n case UpdateLendingMarketMode.UpdatePriceRefreshTriggerToMaxAgePct.discriminator:\n case UpdateLendingMarketMode.UpdateAutodeleverageEnabled.discriminator:\n case UpdateLendingMarketMode.UpdateBorrowingDisabled.discriminator:\n buffer.writeUIntLE(value as number, 0, 1);\n break;\n case UpdateLendingMarketMode.UpdateReferralFeeBps.discriminator:\n buffer.writeUInt16LE(value as number, 0);\n break;\n case UpdateLendingMarketMode.UpdateLiquidationMaxValue.discriminator:\n case UpdateLendingMarketMode.UpdateGlobalAllowedBorrow.discriminator:\n case UpdateLendingMarketMode.UpdateGlobalUnhealthyBorrow.discriminator:\n case UpdateLendingMarketMode.UpdateMinFullLiquidationThreshold.discriminator:\n case UpdateLendingMarketMode.UpdateMinValueSkipPriorityLiqCheck.discriminator:\n value = value as number;\n buffer.writeBigUint64LE(BigInt(value), 0);\n break;\n case UpdateLendingMarketMode.UpdateMultiplierPoints.discriminator:\n valueArray = value as number[];\n for (let i = 0; i < valueArray.length; i++) {\n buffer.writeUIntLE(valueArray[i], i, 1);\n }\n break;\n case UpdateLendingMarketMode.UpdateOwner.discriminator:\n case UpdateLendingMarketMode.UpdateRiskCouncil.discriminator:\n pkBuffer = (value as PublicKey).toBuffer();\n pkBuffer.copy(buffer, 0);\n break;\n case UpdateLendingMarketMode.UpdateElevationGroup.discriminator:\n buffer = serializeElevationGroup(value as ElevationGroup);\n break;\n case UpdateLendingMarketMode.UpdateMinNetValueObligationPostAction.discriminator:\n valueBigInt = BigInt(value as string);\n for (let i = 0; i < 16; i++) {\n buffer[15 - i] = Number((valueBigInt >> BigInt(i * 8)) & BigInt(0xff));\n }\n break;\n default:\n break;\n }\n\n return buffer;\n}\n\nfunction updateMarketConfigIx(\n marketWithAddress: MarketWithAddress,\n modeDiscriminator: number,\n value: Buffer,\n programId: PublicKey\n): TransactionInstruction {\n value;\n const accounts: UpdateLendingMarketAccounts = {\n lendingMarketOwner: marketWithAddress.state.lendingMarketOwner,\n lendingMarket: marketWithAddress.address,\n };\n\n const args: UpdateLendingMarketArgs = {\n mode: new anchor.BN(modeDiscriminator),\n value: [...value],\n };\n\n const ix = updateLendingMarket(args, accounts, programId);\n\n return ix;\n}\n\nfunction serializeElevationGroup(elevationGroup: ElevationGroup): Buffer {\n const buffer = Buffer.alloc(72);\n buffer.writeUInt16LE(elevationGroup.maxLiquidationBonusBps, 0);\n buffer.writeUIntLE(elevationGroup.id, 2, 1);\n buffer.writeUIntLE(elevationGroup.ltvPct, 3, 1);\n buffer.writeUIntLE(elevationGroup.liquidationThresholdPct, 4, 1);\n buffer.writeUIntLE(elevationGroup.allowNewLoans, 5, 1);\n buffer.writeUIntLE(elevationGroup.maxReservesAsCollateral, 6, 1);\n buffer.writeUIntLE(elevationGroup.padding0, 7, 1);\n const debtReserveBuffer = elevationGroup.debtReserve.toBuffer();\n debtReserveBuffer.copy(buffer, 8);\n return buffer;\n}\n"]}
|
|
1
|
+
{"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/classes/manager.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n Connection,\n Keypair,\n PublicKey,\n SystemProgram,\n SYSVAR_RENT_PUBKEY,\n TransactionInstruction,\n} from '@solana/web3.js';\nimport { KaminoVault, KaminoVaultClient, KaminoVaultConfig, kaminoVaultId, ReserveAllocationConfig } from './vault';\nimport {\n AddAssetToMarketParams,\n CreateKaminoMarketParams,\n createReserveIxs,\n DEFAULT_RECENT_SLOT_DURATION_MS,\n ENV,\n getReserveOracleConfigs,\n initLendingMarket,\n InitLendingMarketAccounts,\n InitLendingMarketArgs,\n LendingMarket,\n lendingMarketAuthPda,\n MarketWithAddress,\n parseForChangesReserveConfigAndGetIxs,\n parseOracleType,\n PubkeyHashMap,\n Reserve,\n ReserveWithAddress,\n ScopeOracleConfig,\n updateEntireReserveConfigIx,\n updateLendingMarket,\n UpdateLendingMarketAccounts,\n UpdateLendingMarketArgs,\n updateLendingMarketOwner,\n UpdateLendingMarketOwnerAccounts,\n} from '../lib';\nimport { PROGRAM_ID } from '../idl_codegen/programId';\nimport { Scope, TokenMetadatas, U16_MAX } from '@hubbleprotocol/scope-sdk';\nimport BN from 'bn.js';\nimport { ElevationGroup, ReserveConfig, UpdateLendingMarketMode } from '../idl_codegen/types';\nimport Decimal from 'decimal.js';\nimport * as anchor from '@coral-xyz/anchor';\n\n/**\n * KaminoManager is a class that provides a high-level interface to interact with the Kamino Lend and Kamino Vault programs, in order to create and manage a market, as well as vaults\n */\nexport class KaminoManager {\n private readonly _connection: Connection;\n private readonly _kaminoVaultProgramId: PublicKey;\n private readonly _kaminoLendProgramId: PublicKey;\n private readonly _vaultClient: KaminoVaultClient;\n recentSlotDurationMs: number;\n\n constructor(\n connection: Connection,\n kaminoLendProgramId?: PublicKey,\n kaminoVaultProgramId?: PublicKey,\n recentSlotDurationMs?: number\n ) {\n this._connection = connection;\n this._kaminoVaultProgramId = kaminoVaultProgramId ? kaminoVaultProgramId : kaminoVaultId;\n this._kaminoLendProgramId = kaminoLendProgramId ? kaminoLendProgramId : PROGRAM_ID;\n this.recentSlotDurationMs = recentSlotDurationMs ? recentSlotDurationMs : DEFAULT_RECENT_SLOT_DURATION_MS;\n this._vaultClient = new KaminoVaultClient(\n connection,\n this._kaminoVaultProgramId,\n this._kaminoLendProgramId,\n this.recentSlotDurationMs\n );\n }\n\n getConnection() {\n return this._connection;\n }\n\n getProgramID() {\n return this._kaminoVaultProgramId;\n }\n\n /**\n * This is a function that helps quickly setting up a reserve for an asset with a default config. The config can be modified later on.\n * @param params.admin - the admin of the market\n * @returns market keypair - keypair used for market account creation -> to be signed with when executing the transaction\n * @returns ixns - an array of ixns for creating and initializing the market account\n */\n async createMarketIxs(\n params: CreateKaminoMarketParams\n ): Promise<{ market: Keypair; ixns: TransactionInstruction[] }> {\n const marketAccount = Keypair.generate();\n const size = LendingMarket.layout.span + 8;\n const [lendingMarketAuthority, _] = lendingMarketAuthPda(marketAccount.publicKey, this._kaminoLendProgramId);\n const createMarketIxns: TransactionInstruction[] = [];\n\n createMarketIxns.push(\n SystemProgram.createAccount({\n fromPubkey: params.admin,\n newAccountPubkey: marketAccount.publicKey,\n lamports: await this._connection.getMinimumBalanceForRentExemption(size),\n space: size,\n programId: this._kaminoLendProgramId,\n })\n );\n\n const accounts: InitLendingMarketAccounts = {\n lendingMarketOwner: params.admin,\n lendingMarket: marketAccount.publicKey,\n lendingMarketAuthority: lendingMarketAuthority,\n systemProgram: SystemProgram.programId,\n rent: SYSVAR_RENT_PUBKEY,\n };\n\n const args: InitLendingMarketArgs = {\n quoteCurrency: Array(32).fill(0),\n };\n\n createMarketIxns.push(initLendingMarket(args, accounts, this._kaminoLendProgramId));\n\n return { market: marketAccount, ixns: createMarketIxns };\n }\n\n /**\n * This is a function that helps quickly setting up a reserve for an asset with a default config. The config can be modified later on.\n * @param params.admin - the admin of the reserve\n * @param params.marketAddress - the market to create a reserve for, only the market admin can create a reserve for the market\n * @param params.assetConfig - an object that helps generate a default reserve config with some inputs which have to be configured before calling this function\n * @returns reserve - keypair used for reserve creation -> to be signed with when executing the transaction\n * @returns txnIxns - an array of arrays of ixns -> first array for reserve creation, second for updating it with correct params\n */\n async addAssetToMarketIxs(\n params: AddAssetToMarketParams\n ): Promise<{ reserve: Keypair; txnIxns: TransactionInstruction[][] }> {\n const market = await LendingMarket.fetch(this._connection, params.marketAddress, this._kaminoLendProgramId);\n if (!market) {\n throw new Error('Market not found');\n }\n const marketWithAddress: MarketWithAddress = { address: params.marketAddress, state: market };\n\n const reserveAccount = Keypair.generate();\n\n const createReserveInstructions = await createReserveIxs(\n this._connection,\n params.admin,\n params.marketAddress,\n params.assetConfig.mint,\n reserveAccount.publicKey,\n this._kaminoLendProgramId\n );\n\n const updateReserveInstructions = await this.updateReserveIxs(\n marketWithAddress,\n reserveAccount.publicKey,\n params.assetConfig.getReserveConfig(),\n undefined,\n true\n );\n\n const txnIxns: TransactionInstruction[][] = [];\n txnIxns.push(createReserveInstructions);\n txnIxns.push(updateReserveInstructions);\n\n return { reserve: reserveAccount, txnIxns };\n }\n\n /**\n * This method will create a vault with a given config. The config can be changed later on, but it is recommended to set it up correctly from the start\n * @param vaultConfig - the config object used to create a vault\n * @returns vault - keypair, should be used to sign the transaction which creates the vault account\n * @returns ixns - an array of instructions to create the vault\n */\n async createVaultIxs(vaultConfig: KaminoVaultConfig): Promise<{ vault: Keypair; ixns: TransactionInstruction[] }> {\n return this._vaultClient.createVaultIxs(vaultConfig);\n }\n\n /**\n * This method updates the vault reserve allocation cofnig for an exiting vault reserve, or adds a new reserve to the vault if it does not exist.\n * @param vault - vault to be updated\n * @param reserveAllocationConfig - new reserve allocation config\n * @returns - a list of instructions\n */\n async updateVaultReserveAllocationIxs(\n vault: KaminoVault,\n reserveAllocationConfig: ReserveAllocationConfig\n ): Promise<TransactionInstruction> {\n return this._vaultClient.updateReserveAllocationIxs(vault, reserveAllocationConfig);\n }\n\n /**\n * This method retruns the reserve config for a given reserve\n * @param reserve - reserve to get the config for\n * @returns - the reserve config\n */\n async getReserveConfig(reserve: PublicKey): Promise<ReserveConfig> {\n const reserveState = await Reserve.fetch(this._connection, reserve);\n if (!reserveState) {\n throw new Error('Reserve not found');\n }\n return reserveState.config;\n }\n\n /**\n * This function enables the update of the scope oracle configuration. In order to get a list of scope prices, getScopeOracleConfigs can be used\n * @param market - lending market which owns the reserve\n * @param reserve - reserve which to be updated\n * @param scopeOracleConfig - new scope oracle config\n * @param scopeTwapConfig - new scope twap config\n * @param maxAgeBufferSeconds - buffer to be added to onchain max_age - if oracle price is older than that, txns interacting with the reserve will fail\n * @returns - an array of instructions used update the oracle configuration\n */\n async updateReserveScopeOracleConfigurationIxs(\n market: MarketWithAddress,\n reserve: ReserveWithAddress,\n scopeOracleConfig: ScopeOracleConfig,\n scopeTwapConfig?: ScopeOracleConfig,\n maxAgeBufferSeconds: number = 20\n ): Promise<TransactionInstruction[]> {\n const reserveConfig = reserve.state.config;\n\n let scopeTwapId = U16_MAX;\n if (scopeTwapConfig) {\n scopeTwapId = scopeTwapConfig.oracleId;\n\n // if(scopeTwapConfig.twapSourceId !== scopeOracleConfig.oracleId) {\n // throw new Error('Twap source id must match oracle id');\n // }\n }\n\n const { scopeConfiguration } = getReserveOracleConfigs({\n scopePriceConfigAddress: scopeOracleConfig.scopePriceConfigAddress,\n scopeChain: [scopeOracleConfig.oracleId],\n scopeTwapChain: [scopeTwapId],\n });\n\n const newReserveConfig = new ReserveConfig({\n ...reserveConfig,\n tokenInfo: {\n ...reserveConfig.tokenInfo,\n scopeConfiguration: scopeConfiguration,\n // TODO: Decide if we want to keep this maxAge override for twap & price\n maxAgeTwapSeconds: scopeTwapConfig\n ? new BN(scopeTwapConfig.max_age + maxAgeBufferSeconds)\n : reserveConfig.tokenInfo.maxAgeTwapSeconds,\n maxAgePriceSeconds: new BN(scopeOracleConfig.max_age + maxAgeBufferSeconds),\n },\n });\n\n return this.updateReserveIxs(market, reserve.address, newReserveConfig, reserve.state);\n }\n\n /**\n * This function updates the given reserve with a new config. It can either update the entire reserve config or just update fields which differ between given reserve and existing reserve\n * @param marketWithAddress - the market that owns the reserve to be updated\n * @param reserve - the reserve to be updated\n * @param config - the new reserve configuration to be used for the update\n * @param reserveStateOverride - the reserve state, useful to provide, if already fetched outside this method, in order to avoid an extra rpc call to fetch it. Make sure the reserveConfig has not been updated since fetching the reserveState that you pass in.\n * @param updateEntireConfig - when set to false, it will only update fields that are different between @param config and reserveState.config, set to true it will always update entire reserve config. An entire reserveConfig update might be too large for a multisig transaction\n * @returns - an array of multiple update ixns. If there are many fields that are being updated without the updateEntireConfig=true, multiple transactions might be required to fit all ixns.\n */\n async updateReserveIxs(\n marketWithAddress: MarketWithAddress,\n reserve: PublicKey,\n config: ReserveConfig,\n reserveStateOverride?: Reserve,\n updateEntireConfig: boolean = false\n ): Promise<TransactionInstruction[]> {\n const reserveState = reserveStateOverride\n ? reserveStateOverride\n : (await Reserve.fetch(this._connection, reserve, this._kaminoLendProgramId))!;\n const ixns: TransactionInstruction[] = [];\n\n if (!reserveState || updateEntireConfig) {\n ixns.push(updateEntireReserveConfigIx(marketWithAddress, reserve, config, this._kaminoLendProgramId));\n } else {\n ixns.push(\n ...parseForChangesReserveConfigAndGetIxs(\n marketWithAddress,\n reserveState,\n reserve,\n config,\n this._kaminoLendProgramId\n )\n );\n }\n\n return ixns;\n }\n\n /**\n * This function creates instructions to deposit into a vault. It will also create ATA creation instructions for the vault shares that the user receives in return\n * @param user - user to deposit\n * @param vault - vault to deposit into\n * @param tokenAmount - token amount to be deposited, in decimals (will be converted in lamports)\n * @returns - an array of instructions to be used to be executed\n */\n async depositToVaultIxs(\n user: PublicKey,\n vault: KaminoVault,\n tokenAmount: Decimal\n ): Promise<TransactionInstruction[]> {\n return this._vaultClient.depositIxs(user, vault, tokenAmount);\n }\n\n /**\n * This function will return the missing ATA creation instructions, as well as one or multiple withdraw instructions, based on how many reserves it's needed to withdraw from. This might have to be split in multiple transactions\n * @param user - user to withdraw\n * @param vault - vault to withdraw from\n * @param shareAmount - share amount to withdraw, in order to withdraw everything, any value > user share amount\n * @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault\n * @returns an array of instructions to be executed\n */\n async withdrawFromVaultIxs(\n user: PublicKey,\n vault: KaminoVault,\n shareAmount: Decimal,\n slot: number\n ): Promise<TransactionInstruction[]> {\n return this._vaultClient.withdrawIxs(user, vault, shareAmount, slot);\n }\n\n /**\n * This method calculates the token per share value. This will always change based on interest earned from the vault, but calculating it requires a bunch of rpc requests. Caching this for a short duration would be optimal\n * @param vault - vault to calculate tokensPerShare for\n * @param slot - current slot, used to estimate the interest earned in the different reserves with allocation from the vault\n * @returns - token per share value\n */\n async getTokensPerShareSingleVault(vault: KaminoVault, slot: number): Promise<Decimal> {\n return this._vaultClient.getTokensPerShareSingleVault(vault, slot);\n }\n\n /**\n * This method returns the user shares balance for a given vault\n * @param user - user to calculate the shares balance for\n * @param vault - vault to calculate shares balance for\n * @returns - user share balance in decimal (not lamports)\n */\n async getUserSharesBalanceSingleVault(user: PublicKey, vault: KaminoVault): Promise<Decimal> {\n return this._vaultClient.getUserSharesBalanceSingleVault(user, vault);\n }\n\n /**\n * This method returns the user shares balance for all existing vaults\n * @param user - user to calculate the shares balance for\n * @param vaultsOverride - the kamino vaults if already fetched, in order to reduce rpc calls\n * @returns - hash map with keyh as vault address and value as user share balance in decimal (not lamports)\n */\n async getUserSharesBalanceAllVaults(\n user: PublicKey,\n vaultsOverride: KaminoVault[]\n ): Promise<PubkeyHashMap<PublicKey, Decimal>> {\n return this._vaultClient.getUserSharesBalanceAllVaults(user, vaultsOverride);\n }\n\n /**\n * @returns - the KaminoVault client\n */\n getKaminoVaultClient(): KaminoVaultClient {\n return this._vaultClient;\n }\n\n /**\n * This will trigger invest by balancing, based on weights, the reserve allocations of the vault. It can either withdraw or deposit into reserves to balance them. This is a function that should be cranked\n * @param kaminoVault - vault to invest from\n * @returns - an array of invest instructions for each invest action required for the vault reserves\n */\n async investAllReserves(kaminoVault: KaminoVault): Promise<TransactionInstruction[]> {\n return this._vaultClient.investAllReservesIxs(kaminoVault);\n }\n\n /**\n * This will trigger invest by balancing, based on weights, the reserve allocation of the vault. It can either withdraw or deposit into the given reserve to balance it\n * @param kaminoVault - vault to invest from\n * @param reserve - reserve to invest into or disinvest from\n * @returns - an array of invest instructions for each invest action required for the vault reserves\n */\n async investSingleReserve(\n kaminoVault: KaminoVault,\n reserveWithAddress: ReserveWithAddress\n ): Promise<TransactionInstruction> {\n return this._vaultClient.investSingleReserveIxs(kaminoVault, reserveWithAddress);\n }\n\n /**\n * This retruns an array of scope oracle configs to be used to set the scope price and twap oracles for a reserve\n * @param feed - scope feed to fetch prices from\n * @param cluster - cluster to fetch from, this should be left unchanged unless working on devnet or locally\n * @returns - an array of scope oracle configs\n */\n async getScopeOracleConfigs(\n feed: string = 'hubble',\n cluster: ENV = 'mainnet-beta'\n ): Promise<Array<ScopeOracleConfig>> {\n const scopeOracleConfigs: Array<ScopeOracleConfig> = [];\n\n const scope = new Scope(cluster, this._connection);\n const oracleMappings = await scope.getOracleMappings({ feed: feed });\n const [, feedConfig] = await scope.getFeedConfiguration({ feed: feed });\n const tokenMetadatas = await TokenMetadatas.fetch(this._connection, feedConfig.tokensMetadata);\n const decoder = new TextDecoder('utf-8');\n\n console.log('feedConfig.tokensMetadata', feedConfig.tokensMetadata);\n\n if (tokenMetadatas === null) {\n throw new Error('TokenMetadatas not found');\n }\n\n for (let index = 0; index < oracleMappings.priceInfoAccounts.length; index++) {\n if (!oracleMappings.priceInfoAccounts[index].equals(PublicKey.default)) {\n const name = decoder.decode(Uint8Array.from(tokenMetadatas.metadatasArray[index].name)).replace(/\\0/g, '');\n const oracleType = parseOracleType(oracleMappings.priceTypes[index]);\n\n scopeOracleConfigs.push({\n scopePriceConfigAddress: feedConfig.oraclePrices,\n name: name,\n oracleType: oracleType,\n oracleId: index,\n oracleAccount: oracleMappings.priceInfoAccounts[index],\n twapEnabled: oracleMappings.twapEnabled[index] === 1,\n twapSourceId: oracleMappings.twapSource[index],\n max_age: tokenMetadatas.metadatasArray[index].maxAgePriceSlots.toNumber(),\n });\n }\n }\n\n return scopeOracleConfigs;\n }\n\n /**\n * This retruns an array of instructions to be used to update the lending market configurations\n * @param marketWithAddress - the market address and market state object\n * @param newMarket - the lending market state with the new configuration - to be build we new config options from the previous state\n * @returns - an array of instructions\n */\n updateLendingMarketIxs(marketWithAddress: MarketWithAddress, newMarket: LendingMarket): TransactionInstruction[] {\n return parseForChangesMarketConfigAndGetIxs(marketWithAddress, newMarket, this._kaminoLendProgramId);\n }\n\n /**\n * This retruns an instruction to be used to update the market owner. This can only be executed by the current lendingMarketOwnerCached\n * @param marketWithAddress - the market address and market state object\n * @param newMarket - the lending market state with the new configuration - to be build we new config options from the previous state\n * @returns - an array of instructions\n */\n updateLendingMarketOwnerIxs(marketWithAddress: MarketWithAddress): TransactionInstruction {\n const accounts: UpdateLendingMarketOwnerAccounts = {\n lendingMarketOwnerCached: marketWithAddress.state.lendingMarketOwnerCached,\n lendingMarket: marketWithAddress.address,\n };\n\n return updateLendingMarketOwner(accounts, this._kaminoLendProgramId);\n }\n} // KaminoManager\n\nfunction parseForChangesMarketConfigAndGetIxs(\n marketWithAddress: MarketWithAddress,\n newMarket: LendingMarket,\n programId: PublicKey\n): TransactionInstruction[] {\n const market = marketWithAddress.state;\n const updateLendingMarketIxnsArgs: { mode: number; value: Buffer }[] = [];\n for (const key in market.toJSON()) {\n if (key === 'lendingMarketOwner') {\n if (!market.lendingMarketOwner.equals(newMarket.lendingMarketOwner)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateOwner.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateOwner.discriminator,\n newMarket.lendingMarketOwner\n ),\n });\n }\n } else if (key === 'lendingMarketOwnerCached') {\n if (!market.lendingMarketOwnerCached.equals(newMarket.lendingMarketOwnerCached)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateOwner.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateOwner.discriminator,\n newMarket.lendingMarketOwnerCached\n ),\n });\n }\n } else if (key === 'referralFeeBps') {\n if (market.referralFeeBps !== newMarket.referralFeeBps) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateReferralFeeBps.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateReferralFeeBps.discriminator,\n newMarket.referralFeeBps\n ),\n });\n }\n } else if (key === 'emergencyMode') {\n if (market.emergencyMode !== newMarket.emergencyMode) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateEmergencyMode.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateEmergencyMode.discriminator,\n newMarket.emergencyMode\n ),\n });\n }\n } else if (key === 'autodeleverageEnabled') {\n if (market.autodeleverageEnabled !== newMarket.autodeleverageEnabled) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateAutodeleverageEnabled.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateAutodeleverageEnabled.discriminator,\n newMarket.autodeleverageEnabled\n ),\n });\n }\n } else if (key === 'borrowDisabled') {\n if (market.borrowDisabled !== newMarket.borrowDisabled) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateBorrowingDisabled.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateBorrowingDisabled.discriminator,\n newMarket.borrowDisabled\n ),\n });\n }\n } else if (key === 'priceRefreshTriggerToMaxAgePct') {\n if (market.priceRefreshTriggerToMaxAgePct !== newMarket.priceRefreshTriggerToMaxAgePct) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdatePriceRefreshTriggerToMaxAgePct.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdatePriceRefreshTriggerToMaxAgePct.discriminator,\n newMarket.priceRefreshTriggerToMaxAgePct\n ),\n });\n }\n } else if (key === 'liquidationMaxDebtCloseFactorPct') {\n if (market.liquidationMaxDebtCloseFactorPct !== newMarket.liquidationMaxDebtCloseFactorPct) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateLiquidationCloseFactor.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateLiquidationCloseFactor.discriminator,\n newMarket.liquidationMaxDebtCloseFactorPct\n ),\n });\n }\n } else if (key === 'insolvencyRiskUnhealthyLtvPct') {\n if (market.insolvencyRiskUnhealthyLtvPct !== newMarket.insolvencyRiskUnhealthyLtvPct) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateInsolvencyRiskLtv.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateInsolvencyRiskLtv.discriminator,\n newMarket.insolvencyRiskUnhealthyLtvPct\n ),\n });\n }\n } else if (key === 'minFullLiquidationValueThreshold') {\n if (!market.minFullLiquidationValueThreshold.eq(newMarket.minFullLiquidationValueThreshold)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMinFullLiquidationThreshold.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMinFullLiquidationThreshold.discriminator,\n newMarket.minFullLiquidationValueThreshold.toNumber()\n ),\n });\n }\n } else if (key === 'maxLiquidatableDebtMarketValueAtOnce') {\n if (!market.maxLiquidatableDebtMarketValueAtOnce.eq(newMarket.maxLiquidatableDebtMarketValueAtOnce)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateLiquidationMaxValue.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateLiquidationMaxValue.discriminator,\n newMarket.maxLiquidatableDebtMarketValueAtOnce.toNumber()\n ),\n });\n }\n } else if (key === 'globalUnhealthyBorrowValue') {\n if (!market.globalUnhealthyBorrowValue.eq(newMarket.globalUnhealthyBorrowValue)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateGlobalUnhealthyBorrow.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateGlobalUnhealthyBorrow.discriminator,\n newMarket.globalUnhealthyBorrowValue.toNumber()\n ),\n });\n }\n } else if (key === 'globalAllowedBorrowValue') {\n if (!market.globalAllowedBorrowValue.eq(newMarket.globalAllowedBorrowValue)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateGlobalAllowedBorrow.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateGlobalAllowedBorrow.discriminator,\n newMarket.globalAllowedBorrowValue.toNumber()\n ),\n });\n }\n } else if (key === 'riskCouncil') {\n if (!market.riskCouncil.equals(newMarket.riskCouncil)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateRiskCouncil.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateRiskCouncil.discriminator,\n newMarket.riskCouncil\n ),\n });\n }\n } else if (key === 'minNetValueInObligationSf') {\n if (!market.minNetValueInObligationSf.eq(newMarket.minNetValueInObligationSf)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMinNetValueObligationPostAction.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMinNetValueObligationPostAction.discriminator,\n newMarket.minNetValueInObligationSf.toString()\n ),\n });\n }\n } else if (key === 'minValueSkipLiquidationLtvBfChecks') {\n if (!market.minValueSkipLiquidationLtvBfChecks.eq(newMarket.minValueSkipLiquidationLtvBfChecks)) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateMinValueSkipPriorityLiqCheck.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateMinValueSkipPriorityLiqCheck.discriminator,\n newMarket.minValueSkipLiquidationLtvBfChecks.toNumber()\n ),\n });\n }\n } else if (key === 'elevationGroups') {\n let elevationGroupsDiffs = 0;\n for (let i = 0; i < market.elevationGroups.length; i++) {\n if (\n market.elevationGroups[i].id !== newMarket.elevationGroups[i].id ||\n market.elevationGroups[i].maxLiquidationBonusBps !== newMarket.elevationGroups[i].maxLiquidationBonusBps ||\n market.elevationGroups[i].ltvPct !== newMarket.elevationGroups[i].ltvPct ||\n market.elevationGroups[i].liquidationThresholdPct !== newMarket.elevationGroups[i].liquidationThresholdPct ||\n market.elevationGroups[i].allowNewLoans !== newMarket.elevationGroups[i].allowNewLoans ||\n market.elevationGroups[i].maxReservesAsCollateral !== newMarket.elevationGroups[i].maxReservesAsCollateral ||\n !market.elevationGroups[i].debtReserve.equals(newMarket.elevationGroups[i].debtReserve)\n ) {\n updateLendingMarketIxnsArgs.push({\n mode: UpdateLendingMarketMode.UpdateElevationGroup.discriminator,\n value: updateMarketConfigEncodedValue(\n UpdateLendingMarketMode.UpdateElevationGroup.discriminator,\n newMarket.elevationGroups[i]\n ),\n });\n elevationGroupsDiffs++;\n }\n }\n if (elevationGroupsDiffs > 1) {\n throw new Error('Can only update 1 elevation group at a time');\n }\n }\n } // for loop\n\n const ixns: TransactionInstruction[] = [];\n\n updateLendingMarketIxnsArgs.forEach((updateLendingMarketConfigArgs) => {\n ixns.push(\n updateMarketConfigIx(\n marketWithAddress,\n updateLendingMarketConfigArgs.mode,\n updateLendingMarketConfigArgs.value,\n programId\n )\n );\n });\n\n return ixns;\n}\n\nfunction updateMarketConfigEncodedValue(\n discriminator: number,\n value: number | number[] | PublicKey | ElevationGroup | string\n): Buffer {\n let buffer: Buffer = Buffer.alloc(72);\n let pkBuffer: Buffer;\n let valueBigInt: bigint;\n\n switch (discriminator) {\n case UpdateLendingMarketMode.UpdateEmergencyMode.discriminator:\n case UpdateLendingMarketMode.UpdateLiquidationCloseFactor.discriminator:\n case UpdateLendingMarketMode.UpdateInsolvencyRiskLtv.discriminator:\n case UpdateLendingMarketMode.UpdatePriceRefreshTriggerToMaxAgePct.discriminator:\n case UpdateLendingMarketMode.UpdateAutodeleverageEnabled.discriminator:\n case UpdateLendingMarketMode.UpdateBorrowingDisabled.discriminator:\n buffer.writeUIntLE(value as number, 0, 1);\n break;\n case UpdateLendingMarketMode.UpdateReferralFeeBps.discriminator:\n buffer.writeUInt16LE(value as number, 0);\n break;\n case UpdateLendingMarketMode.UpdateLiquidationMaxValue.discriminator:\n case UpdateLendingMarketMode.UpdateGlobalAllowedBorrow.discriminator:\n case UpdateLendingMarketMode.UpdateGlobalUnhealthyBorrow.discriminator:\n case UpdateLendingMarketMode.UpdateMinFullLiquidationThreshold.discriminator:\n case UpdateLendingMarketMode.UpdateMinValueSkipPriorityLiqCheck.discriminator:\n value = value as number;\n buffer.writeBigUint64LE(BigInt(value), 0);\n break;\n case UpdateLendingMarketMode.UpdateOwner.discriminator:\n case UpdateLendingMarketMode.UpdateRiskCouncil.discriminator:\n pkBuffer = (value as PublicKey).toBuffer();\n pkBuffer.copy(buffer, 0);\n break;\n case UpdateLendingMarketMode.UpdateElevationGroup.discriminator:\n buffer = serializeElevationGroup(value as ElevationGroup);\n break;\n case UpdateLendingMarketMode.UpdateMinNetValueObligationPostAction.discriminator:\n valueBigInt = BigInt(value as string);\n for (let i = 0; i < 16; i++) {\n buffer[15 - i] = Number((valueBigInt >> BigInt(i * 8)) & BigInt(0xff));\n }\n break;\n default:\n break;\n }\n\n return buffer;\n}\n\nfunction updateMarketConfigIx(\n marketWithAddress: MarketWithAddress,\n modeDiscriminator: number,\n value: Buffer,\n programId: PublicKey\n): TransactionInstruction {\n value;\n const accounts: UpdateLendingMarketAccounts = {\n lendingMarketOwner: marketWithAddress.state.lendingMarketOwner,\n lendingMarket: marketWithAddress.address,\n };\n\n const args: UpdateLendingMarketArgs = {\n mode: new anchor.BN(modeDiscriminator),\n value: [...value],\n };\n\n const ix = updateLendingMarket(args, accounts, programId);\n\n return ix;\n}\n\nfunction serializeElevationGroup(elevationGroup: ElevationGroup): Buffer {\n const buffer = Buffer.alloc(72);\n buffer.writeUInt16LE(elevationGroup.maxLiquidationBonusBps, 0);\n buffer.writeUIntLE(elevationGroup.id, 2, 1);\n buffer.writeUIntLE(elevationGroup.ltvPct, 3, 1);\n buffer.writeUIntLE(elevationGroup.liquidationThresholdPct, 4, 1);\n buffer.writeUIntLE(elevationGroup.allowNewLoans, 5, 1);\n buffer.writeUIntLE(elevationGroup.maxReservesAsCollateral, 6, 1);\n buffer.writeUIntLE(elevationGroup.padding0, 7, 1);\n const debtReserveBuffer = elevationGroup.debtReserve.toBuffer();\n debtReserveBuffer.copy(buffer, 8);\n return buffer;\n}\n"]}
|
package/dist/classes/market.d.ts
CHANGED
|
@@ -107,6 +107,9 @@ export declare class KaminoMarket {
|
|
|
107
107
|
batchGetAllObligationsForMarket(tag?: number): AsyncGenerator<KaminoObligation[], void, unknown>;
|
|
108
108
|
getAllObligationsByTag(tag: number, market: PublicKey): Promise<KaminoObligation[]>;
|
|
109
109
|
getAllUserObligations(user: PublicKey): Promise<KaminoObligation[]>;
|
|
110
|
+
getAllUserObligationsForReserve(user: PublicKey, reserve: PublicKey): Promise<KaminoObligation[]>;
|
|
111
|
+
getUserVanillaObligation(user: PublicKey): Promise<KaminoObligation>;
|
|
112
|
+
isReserveInObligation(obligation: KaminoObligation, reserve: PublicKey): boolean;
|
|
110
113
|
getUserObligationsByTag(tag: number, user: PublicKey): Promise<KaminoObligation[]>;
|
|
111
114
|
getObligationByAddress(address: PublicKey): Promise<KaminoObligation | null>;
|
|
112
115
|
getMultipleObligationsByAddress(addresses: PublicKey[]): Promise<(KaminoObligation | null)[]>;
|
|
@@ -142,7 +145,19 @@ export declare class KaminoMarket {
|
|
|
142
145
|
getCollateralExchangeRatesByReserve(slot: number): Map<PublicKey, Decimal>;
|
|
143
146
|
private setPriceIfExist;
|
|
144
147
|
getRecentSlotDurationMs(): number;
|
|
148
|
+
isLoanEligibleForElevationGroup(obligation: KaminoObligation, elevationGroup: number): boolean;
|
|
149
|
+
getMarketElevationGroupDescriptions(): ElevationGroupDescription[];
|
|
150
|
+
getElevationGroupsForMintsCombination(collLiquidityMints: PublicKey[], debtLiquidityMint?: PublicKey): ElevationGroupDescription[];
|
|
151
|
+
getElevationGroupsForReservesCombination(collReserves: PublicKey[], debtReserve?: PublicKey): ElevationGroupDescription[];
|
|
152
|
+
getElevationGroupsForObligation(obligation: KaminoObligation): ElevationGroupDescription[];
|
|
145
153
|
}
|
|
154
|
+
export type ElevationGroupDescription = {
|
|
155
|
+
collateralReserves: string[];
|
|
156
|
+
collateralLiquidityMints: string[];
|
|
157
|
+
debtReserve: string;
|
|
158
|
+
debtLiquidityMint: string;
|
|
159
|
+
elevationGroup: number;
|
|
160
|
+
};
|
|
146
161
|
export type KlendPrices = {
|
|
147
162
|
scope: KaminoPrices;
|
|
148
163
|
pyth: KaminoPrices;
|
package/dist/classes/market.js
CHANGED
|
@@ -601,6 +601,69 @@ class KaminoMarket {
|
|
|
601
601
|
});
|
|
602
602
|
});
|
|
603
603
|
}
|
|
604
|
+
getAllUserObligationsForReserve(user, reserve) {
|
|
605
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
606
|
+
const obligationAddresses = [];
|
|
607
|
+
obligationAddresses.push(new utils_1.VanillaObligation(this.programId).toPda(this.getAddress(), user));
|
|
608
|
+
const targetReserve = new utils_1.PubkeyHashMap(Array.from(this.reserves.entries())).get(reserve);
|
|
609
|
+
if (!targetReserve) {
|
|
610
|
+
throw Error('Could not find reserve.');
|
|
611
|
+
}
|
|
612
|
+
for (const [key, kaminoReserve] of this.reserves) {
|
|
613
|
+
if (targetReserve.address.equals(key)) {
|
|
614
|
+
// skip target reserve
|
|
615
|
+
continue;
|
|
616
|
+
}
|
|
617
|
+
obligationAddresses.push(new utils_1.MultiplyObligation(targetReserve.getLiquidityMint(), kaminoReserve.getLiquidityMint(), this.programId).toPda(this.getAddress(), user));
|
|
618
|
+
obligationAddresses.push(new utils_1.MultiplyObligation(kaminoReserve.getLiquidityMint(), targetReserve.getLiquidityMint(), this.programId).toPda(this.getAddress(), user));
|
|
619
|
+
obligationAddresses.push(new utils_1.LeverageObligation(targetReserve.getLiquidityMint(), kaminoReserve.getLiquidityMint(), this.programId).toPda(this.getAddress(), user));
|
|
620
|
+
obligationAddresses.push(new utils_1.LeverageObligation(kaminoReserve.getLiquidityMint(), targetReserve.getLiquidityMint(), this.programId).toPda(this.getAddress(), user));
|
|
621
|
+
}
|
|
622
|
+
const batchSize = 100;
|
|
623
|
+
const finalObligations = [];
|
|
624
|
+
for (let batchStart = 0; batchStart < obligationAddresses.length; batchStart += batchSize) {
|
|
625
|
+
const obligations = yield this.getMultipleObligationsByAddress(obligationAddresses.slice(batchStart, batchStart + batchSize));
|
|
626
|
+
obligations.forEach((obligation) => {
|
|
627
|
+
if (obligation !== null) {
|
|
628
|
+
for (const deposits of obligation.deposits.keys()) {
|
|
629
|
+
if (deposits.equals(reserve)) {
|
|
630
|
+
finalObligations.push(obligation);
|
|
631
|
+
}
|
|
632
|
+
}
|
|
633
|
+
for (const borrows of obligation.borrows.keys()) {
|
|
634
|
+
if (borrows.equals(reserve)) {
|
|
635
|
+
finalObligations.push(obligation);
|
|
636
|
+
}
|
|
637
|
+
}
|
|
638
|
+
}
|
|
639
|
+
});
|
|
640
|
+
}
|
|
641
|
+
return finalObligations;
|
|
642
|
+
});
|
|
643
|
+
}
|
|
644
|
+
getUserVanillaObligation(user) {
|
|
645
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
646
|
+
const vanillaObligationAddress = new utils_1.VanillaObligation(this.programId).toPda(this.getAddress(), user);
|
|
647
|
+
const obligation = yield this.getObligationByAddress(vanillaObligationAddress);
|
|
648
|
+
if (!obligation) {
|
|
649
|
+
throw new Error('Could not find vanilla obligation.');
|
|
650
|
+
}
|
|
651
|
+
return obligation;
|
|
652
|
+
});
|
|
653
|
+
}
|
|
654
|
+
isReserveInObligation(obligation, reserve) {
|
|
655
|
+
for (const deposits of obligation.deposits.keys()) {
|
|
656
|
+
if (deposits.equals(reserve)) {
|
|
657
|
+
return true;
|
|
658
|
+
}
|
|
659
|
+
}
|
|
660
|
+
for (const borrows of obligation.borrows.keys()) {
|
|
661
|
+
if (borrows.equals(reserve)) {
|
|
662
|
+
return true;
|
|
663
|
+
}
|
|
664
|
+
}
|
|
665
|
+
return false;
|
|
666
|
+
}
|
|
604
667
|
getUserObligationsByTag(tag, user) {
|
|
605
668
|
return __awaiter(this, void 0, void 0, function* () {
|
|
606
669
|
const [currentSlot, obligations] = yield Promise.all([
|
|
@@ -873,6 +936,96 @@ class KaminoMarket {
|
|
|
873
936
|
getRecentSlotDurationMs() {
|
|
874
937
|
return this.recentSlotDurationMs;
|
|
875
938
|
}
|
|
939
|
+
/* Returns true if the loan is eligible for the elevation group, including for the default one */
|
|
940
|
+
isLoanEligibleForElevationGroup(obligation, elevationGroup) {
|
|
941
|
+
if (elevationGroup === 0) {
|
|
942
|
+
return true;
|
|
943
|
+
}
|
|
944
|
+
const reserveDeposits = Array.from(obligation.deposits.keys()).map((x) => x.toString());
|
|
945
|
+
const reserveBorrows = Array.from(obligation.borrows.keys()).map((x) => x.toString());
|
|
946
|
+
if (reserveBorrows.length > 1) {
|
|
947
|
+
return false;
|
|
948
|
+
}
|
|
949
|
+
const allElevationGroups = this.getMarketElevationGroupDescriptions();
|
|
950
|
+
const elevationGroupDescription = allElevationGroups[elevationGroup - 1];
|
|
951
|
+
// Has to be a subset
|
|
952
|
+
const allCollsIncluded = reserveDeposits.every((reserve) => elevationGroupDescription.collateralReserves.includes(reserve));
|
|
953
|
+
const allDebtsIncluded = reserveBorrows.length === 0 ||
|
|
954
|
+
(reserveBorrows.length === 1 && elevationGroupDescription.debtReserve === reserveBorrows[0]);
|
|
955
|
+
return allCollsIncluded && allDebtsIncluded;
|
|
956
|
+
}
|
|
957
|
+
/* Returns all elevation groups except the default one */
|
|
958
|
+
getMarketElevationGroupDescriptions() {
|
|
959
|
+
const elevationGroups = [];
|
|
960
|
+
// Partially build
|
|
961
|
+
for (const elevationGroup of this.state.elevationGroups) {
|
|
962
|
+
if (elevationGroup.id === 0) {
|
|
963
|
+
continue;
|
|
964
|
+
}
|
|
965
|
+
elevationGroups.push({
|
|
966
|
+
collateralReserves: [],
|
|
967
|
+
collateralLiquidityMints: [],
|
|
968
|
+
debtReserve: elevationGroup.debtReserve.toString(),
|
|
969
|
+
debtLiquidityMint: '',
|
|
970
|
+
elevationGroup: elevationGroup.id,
|
|
971
|
+
});
|
|
972
|
+
}
|
|
973
|
+
// Fill the remaining
|
|
974
|
+
for (const reserve of this.reserves.values()) {
|
|
975
|
+
const reserveLiquidityMint = reserve.getLiquidityMint();
|
|
976
|
+
const reserveAddress = reserve.address.toString();
|
|
977
|
+
const reserveElevationGroups = reserve.state.config.elevationGroups;
|
|
978
|
+
for (const elevationGroupId of reserveElevationGroups) {
|
|
979
|
+
if (elevationGroupId === 0) {
|
|
980
|
+
continue;
|
|
981
|
+
}
|
|
982
|
+
const elevationGroupDescription = elevationGroups[elevationGroupId - 1];
|
|
983
|
+
if (elevationGroupDescription) {
|
|
984
|
+
if (reserveAddress === elevationGroupDescription.debtReserve) {
|
|
985
|
+
elevationGroups[elevationGroupId - 1].debtLiquidityMint = reserveLiquidityMint.toString();
|
|
986
|
+
}
|
|
987
|
+
else {
|
|
988
|
+
elevationGroups[elevationGroupId - 1].collateralReserves.push(reserveAddress);
|
|
989
|
+
elevationGroups[elevationGroupId - 1].collateralLiquidityMints.push(reserveLiquidityMint.toString());
|
|
990
|
+
}
|
|
991
|
+
}
|
|
992
|
+
else {
|
|
993
|
+
throw new Error(`Invalid elevation group id ${elevationGroupId} at reserve ${reserveAddress}`);
|
|
994
|
+
}
|
|
995
|
+
}
|
|
996
|
+
}
|
|
997
|
+
return elevationGroups;
|
|
998
|
+
}
|
|
999
|
+
/* Returns all elevation groups for a given combination of liquidity mints, except the default one */
|
|
1000
|
+
getElevationGroupsForMintsCombination(collLiquidityMints, debtLiquidityMint) {
|
|
1001
|
+
const allElevationGroups = this.getMarketElevationGroupDescriptions();
|
|
1002
|
+
return allElevationGroups.filter((elevationGroupDescription) => {
|
|
1003
|
+
return (collLiquidityMints.every((mint) => elevationGroupDescription.collateralLiquidityMints.includes(mint.toString())) &&
|
|
1004
|
+
(debtLiquidityMint == undefined || debtLiquidityMint.toString() === elevationGroupDescription.debtLiquidityMint));
|
|
1005
|
+
});
|
|
1006
|
+
}
|
|
1007
|
+
/* Returns all elevation groups for a given combination of reserves, except the default one */
|
|
1008
|
+
getElevationGroupsForReservesCombination(collReserves, debtReserve) {
|
|
1009
|
+
const allElevationGroups = this.getMarketElevationGroupDescriptions();
|
|
1010
|
+
return allElevationGroups.filter((elevationGroupDescription) => {
|
|
1011
|
+
return (collReserves.every((mint) => elevationGroupDescription.collateralReserves.includes(mint.toString())) &&
|
|
1012
|
+
(debtReserve == undefined || debtReserve.toString() === elevationGroupDescription.debtReserve));
|
|
1013
|
+
});
|
|
1014
|
+
}
|
|
1015
|
+
/* Returns all elevation groups for a given obligation, except the default one */
|
|
1016
|
+
getElevationGroupsForObligation(obligation) {
|
|
1017
|
+
if (obligation.borrows.size > 1) {
|
|
1018
|
+
return [];
|
|
1019
|
+
}
|
|
1020
|
+
const collReserves = Array.from(obligation.deposits.keys());
|
|
1021
|
+
if (obligation.borrows.size === 0) {
|
|
1022
|
+
return this.getElevationGroupsForReservesCombination(collReserves);
|
|
1023
|
+
}
|
|
1024
|
+
else {
|
|
1025
|
+
const debtReserve = Array.from(obligation.borrows.keys())[0];
|
|
1026
|
+
return this.getElevationGroupsForReservesCombination(collReserves, debtReserve);
|
|
1027
|
+
}
|
|
1028
|
+
}
|
|
876
1029
|
}
|
|
877
1030
|
exports.KaminoMarket = KaminoMarket;
|
|
878
1031
|
function getReservesForMarket(marketAddress, connection, programId, recentSlotDurationMs) {
|