From 6173220c2486cbc227c1c54695fadb76856a7f12 Mon Sep 17 00:00:00 2001 From: McSam Date: Fri, 22 Dec 2023 10:42:29 +0800 Subject: [PATCH] fix: getClaimableRewards should not return farm has no rewards --- ts-client/package.json | 2 +- ts-client/src/farm.ts | 35 ++++++++++++++++++----------------- 2 files changed, 19 insertions(+), 18 deletions(-) diff --git a/ts-client/package.json b/ts-client/package.json index 1d3a6a4..7127c91 100644 --- a/ts-client/package.json +++ b/ts-client/package.json @@ -1,6 +1,6 @@ { "name": "@mercurial-finance/farming-sdk", - "version": "1.0.15", + "version": "1.0.16", "description": "", "main": "./dist/index.js", "module": "./dist/index.mjs", diff --git a/ts-client/src/farm.ts b/ts-client/src/farm.ts index 8841171..dabd459 100644 --- a/ts-client/src/farm.ts +++ b/ts-client/src/farm.ts @@ -215,16 +215,17 @@ export class PoolFarmImpl { const chunkedClaimAllTx = chunks(claimAllTxs, MAX_CLAIM_ALL_ALLOWED); + const { blockhash, lastValidBlockHeight } = + await connection.getLatestBlockhash("confirmed"); return Promise.all( chunkedClaimAllTx.map(async (claimAllTx) => { return new Transaction({ feePayer: owner, - ...(await program.provider.connection.getLatestBlockhash( - "finalized" - )), + blockhash, + lastValidBlockHeight, }) - .add(...claimAllTx) - .add(ComputeBudgetProgram.setComputeUnitLimit({ units: 1_400_000 })); + .add(ComputeBudgetProgram.setComputeUnitLimit({ units: 1_400_000 })) + .add(...claimAllTx); }) ); } @@ -462,18 +463,18 @@ export class PoolFarmImpl { onChainTime < rewardDurationEnd ? onChainTime : rewardDurationEnd; const { a, b } = rewardPerToken(poolState, lastTimeRewardApplicable); - const rewardA = userState - ? userState.balanceStaked - .mul(a.sub(userState.rewardAPerTokenComplete)) - .div(new BN(1_000_000_000)) - .add(userState.rewardAPerTokenPending) - : new BN(0); - const rewardB = userState - ? userState.balanceStaked - .mul(b.sub(userState.rewardBPerTokenComplete)) - .div(new BN(1_000_000_000)) - .add(userState.rewardBPerTokenPending) - : new BN(0); + if (!userState || !poolState) return accValue; + + const rewardA: BN = userState.balanceStaked + .mul(a.sub(userState.rewardAPerTokenComplete)) + .div(new BN(1_000_000_000)) + .add(userState.rewardAPerTokenPending); + const rewardB: BN = userState.balanceStaked + .mul(b.sub(userState.rewardBPerTokenComplete)) + .div(new BN(1_000_000_000)) + .add(userState.rewardBPerTokenPending); + + if (rewardA.isZero() && rewardB.isZero()) return accValue; accValue.set(farmMint, { rewardA, rewardB,