fix: add sendAndConfirmRawTransaction()
This commit is contained in:
parent
9f0713d3a7
commit
2962eef2c7
|
@ -255,4 +255,10 @@ declare module '@solana/web3.js' {
|
||||||
transaction: Transaction,
|
transaction: Transaction,
|
||||||
...signers: Array<Account>
|
...signers: Array<Account>
|
||||||
): Promise<TransactionSignature>;
|
): Promise<TransactionSignature>;
|
||||||
|
|
||||||
|
// === src/util/send-and-confirm-raw-transaction.js ===
|
||||||
|
declare export function sendAndConfirmRawTransaction(
|
||||||
|
connection: Connection,
|
||||||
|
wireTransaction: Buffer,
|
||||||
|
): Promise<TransactionSignature>;
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,7 +142,7 @@ const RequestAirdropRpcResult = jsonRpcResult('string');
|
||||||
/**
|
/**
|
||||||
* Expected JSON RPC response for the "sendTransaction" message
|
* Expected JSON RPC response for the "sendTransaction" message
|
||||||
*/
|
*/
|
||||||
const SendTokensRpcResult = jsonRpcResult('string');
|
const SendTransactionRpcResult = jsonRpcResult('string');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Information describing an account
|
* Information describing an account
|
||||||
|
@ -429,12 +429,12 @@ export class Connection {
|
||||||
* wire format
|
* wire format
|
||||||
*/
|
*/
|
||||||
async sendRawTransaction(
|
async sendRawTransaction(
|
||||||
wireTransaction: Buffer,
|
rawTransaction: Buffer,
|
||||||
): Promise<TransactionSignature> {
|
): Promise<TransactionSignature> {
|
||||||
const unsafeRes = await this._rpcRequest('sendTransaction', [
|
const unsafeRes = await this._rpcRequest('sendTransaction', [
|
||||||
[...wireTransaction],
|
[...rawTransaction],
|
||||||
]);
|
]);
|
||||||
const res = SendTokensRpcResult(unsafeRes);
|
const res = SendTransactionRpcResult(unsafeRes);
|
||||||
if (res.error) {
|
if (res.error) {
|
||||||
throw new Error(res.error.message);
|
throw new Error(res.error.message);
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,3 +10,6 @@ export {SystemProgram} from './system-program';
|
||||||
export {Token, TokenAmount} from './token-program';
|
export {Token, TokenAmount} from './token-program';
|
||||||
export {Transaction, TransactionInstruction} from './transaction';
|
export {Transaction, TransactionInstruction} from './transaction';
|
||||||
export {sendAndConfirmTransaction} from './util/send-and-confirm-transaction';
|
export {sendAndConfirmTransaction} from './util/send-and-confirm-transaction';
|
||||||
|
export {
|
||||||
|
sendAndConfirmRawTransaction,
|
||||||
|
} from './util/send-and-confirm-raw-transaction';
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
// @flow
|
||||||
|
|
||||||
|
import {Connection} from '../connection';
|
||||||
|
import {sleep} from './sleep';
|
||||||
|
import type {TransactionSignature} from '../transaction';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sign, send and confirm a raw transaction
|
||||||
|
*/
|
||||||
|
export async function sendAndConfirmRawTransaction(
|
||||||
|
connection: Connection,
|
||||||
|
rawTransaction: Buffer,
|
||||||
|
): Promise<TransactionSignature> {
|
||||||
|
const start = Date.now();
|
||||||
|
let signature = await connection.sendRawTransaction(rawTransaction);
|
||||||
|
|
||||||
|
// Wait up to a couple seconds for a confirmation
|
||||||
|
let status = '';
|
||||||
|
let statusRetries = 4;
|
||||||
|
for (;;) {
|
||||||
|
status = await connection.getSignatureStatus(signature);
|
||||||
|
if (status !== 'SignatureNotFound') {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
await sleep(500);
|
||||||
|
if (--statusRetries <= 0) {
|
||||||
|
const duration = (Date.now() - start) / 1000;
|
||||||
|
throw new Error(
|
||||||
|
`Raw Transaction '${signature}' was not confirmed in ${duration.toFixed(
|
||||||
|
2,
|
||||||
|
)} seconds (${status})`,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status === 'Confirmed') {
|
||||||
|
return signature;
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Error(`Raw transaction ${signature} failed (${status})`);
|
||||||
|
}
|
|
@ -1,5 +1,7 @@
|
||||||
// @flow
|
// @flow
|
||||||
|
|
||||||
|
import invariant from 'assert';
|
||||||
|
|
||||||
import {Connection} from '../connection';
|
import {Connection} from '../connection';
|
||||||
import {Transaction} from '../transaction';
|
import {Transaction} from '../transaction';
|
||||||
import {sleep} from './sleep';
|
import {sleep} from './sleep';
|
||||||
|
@ -13,7 +15,7 @@ export async function sendAndConfirmTransaction(
|
||||||
connection: Connection,
|
connection: Connection,
|
||||||
transaction: Transaction,
|
transaction: Transaction,
|
||||||
...signers: Array<Account>
|
...signers: Array<Account>
|
||||||
): Promise<?TransactionSignature> {
|
): Promise<TransactionSignature> {
|
||||||
let sendRetries = 10;
|
let sendRetries = 10;
|
||||||
let signature;
|
let signature;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
@ -52,5 +54,6 @@ export async function sendAndConfirmTransaction(
|
||||||
await sleep(Math.random() * 100);
|
await sleep(Math.random() * 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
invariant(signature !== undefined);
|
||||||
return signature;
|
return signature;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue