fix: add sendAndConfirmRawTransaction()

This commit is contained in:
Michael Vines 2018-11-28 11:56:50 -08:00
parent 9f0713d3a7
commit 2962eef2c7
5 changed files with 59 additions and 5 deletions

View File

@ -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>;
} }

View File

@ -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);
} }

View File

@ -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';

View File

@ -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})`);
}

View File

@ -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;
} }