From 37ccf3707197e160979a340475f4fb1ec04d9eee Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Luka=20=C5=BDivanovi=C4=87?= <125874670+LukaStreamflow@users.noreply.github.com> Date: Tue, 26 Mar 2024 18:18:56 +0100 Subject: [PATCH] optimise tx confirmation (#149) --- lerna.json | 2 +- packages/stream/package.json | 2 +- packages/stream/solana/StreamClient.ts | 24 +++++++++--------------- packages/stream/solana/utils.ts | 8 +++++++- 4 files changed, 18 insertions(+), 18 deletions(-) diff --git a/lerna.json b/lerna.json index f1937036..309f4fc7 100644 --- a/lerna.json +++ b/lerna.json @@ -2,6 +2,6 @@ "packages": [ "packages/*" ], - "version": "5.11.3", + "version": "5.11.4", "$schema": "node_modules/lerna/schemas/lerna-schema.json" } \ No newline at end of file diff --git a/packages/stream/package.json b/packages/stream/package.json index 346cc2ba..a8b485d7 100644 --- a/packages/stream/package.json +++ b/packages/stream/package.json @@ -1,6 +1,6 @@ { "name": "@streamflow/stream", - "version": "5.11.3", + "version": "5.11.4", "description": "JavaScript SDK to interact with Streamflow protocol.", "homepage": "https://github.com/streamflow-finance/js-sdk/", "main": "dist/index.js", diff --git a/packages/stream/solana/StreamClient.ts b/packages/stream/solana/StreamClient.ts index 86d2fc4e..41ecb930 100644 --- a/packages/stream/solana/StreamClient.ts +++ b/packages/stream/solana/StreamClient.ts @@ -146,7 +146,8 @@ export default class SolanaStreamClient extends BaseStreamClient { this.connection, ixs, extParams.sender.publicKey, - this.getCommitment(), + undefined, + metadata ); const signature = await signAndExecuteTransaction(this.connection, extParams.sender, tx, hash); @@ -288,7 +289,7 @@ export default class SolanaStreamClient extends BaseStreamClient { this.connection, ixs, extParams.sender.publicKey, - this.getCommitment(), + undefined, metadata ); const signature = await signAndExecuteTransaction(this.connection, extParams.sender, tx, hash); @@ -457,9 +458,7 @@ export default class SolanaStreamClient extends BaseStreamClient { instructionsBatch.push({ ixs, metadata, recipient: recipientData.recipient }); } - const commitment = - typeof this.commitment == "string" ? this.commitment : this.commitment.commitment; - const hash = await this.connection.getLatestBlockhash(commitment); + const hash = await this.connection.getLatestBlockhash(); for (const { ixs, metadata, recipient } of instructionsBatch) { const tx = new Transaction({ @@ -554,8 +553,7 @@ export default class SolanaStreamClient extends BaseStreamClient { const { tx, hash } = await prepareTransaction( this.connection, ixs, - extParams.invoker.publicKey, - this.getCommitment() + extParams.invoker.publicKey ); const signature = await signAndExecuteTransaction(this.connection, extParams.invoker, tx, hash); @@ -619,8 +617,7 @@ export default class SolanaStreamClient extends BaseStreamClient { const { tx, hash } = await prepareTransaction( this.connection, ixs, - extParams.invoker.publicKey, - this.getCommitment() + extParams.invoker.publicKey ); const signature = await signAndExecuteTransaction(this.connection, extParams.invoker, tx, hash); @@ -691,8 +688,7 @@ export default class SolanaStreamClient extends BaseStreamClient { const { tx, hash } = await prepareTransaction( this.connection, ixs, - extParams.invoker.publicKey, - this.getCommitment() + extParams.invoker.publicKey ); const signature = await signAndExecuteTransaction(this.connection, extParams.invoker, tx, hash); @@ -756,8 +752,7 @@ export default class SolanaStreamClient extends BaseStreamClient { const { tx, hash } = await prepareTransaction( this.connection, ixs, - extParams.invoker.publicKey, - this.getCommitment() + extParams.invoker.publicKey ); const signature = await signAndExecuteTransaction(this.connection, extParams.invoker, tx, hash); @@ -884,8 +879,7 @@ export default class SolanaStreamClient extends BaseStreamClient { const { tx, hash } = await prepareTransaction( this.connection, ixs, - extParams.invoker.publicKey, - this.getCommitment() + extParams.invoker.publicKey ); const signature = await signAndExecuteTransaction(this.connection, extParams.invoker, tx, hash); diff --git a/packages/stream/solana/utils.ts b/packages/stream/solana/utils.ts index 957f8e1f..8cc7b65a 100644 --- a/packages/stream/solana/utils.ts +++ b/packages/stream/solana/utils.ts @@ -126,7 +126,13 @@ export function isSignerKeypair( } /** - * Creates a Transaction with given instructions and optionally signs it + * Creates a Transaction with given instructions and optionally signs it. + * Be careful when passing `commitment` as for `confirmed` blockhash it always returns blockheight + 300 in `lastValidBlockHeight` + * And if you use this blockheight to confirm the transaction it could happen so that transaction is successfully executed + * But because `confirmTransaction` waits for only a minute it considers tx as expired as it could be that 300 blocks won't pass in a minute + * https://solana.stackexchange.com/questions/6238/why-is-lastvalidblockheight-300-blocks-ahead-than-current-blockheight-if-hashes + * https://solana.com/docs/core/transactions/retry + * It might be better to rely on `commitment` level that you pass to `Connection` instance of Solana client as it will be used when fetching blockheight on transaction confirmation * @param connection - Solana client connection * @param ixs - Instructions to add to the Transaction * @param payer - PublicKey of payer