diff options
author | Leonid Logvinov <logvinov.leon@gmail.com> | 2018-06-12 01:48:18 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-12 01:48:18 +0800 |
commit | 7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5 (patch) | |
tree | c8e47e9e42e58febc45411a360224535786cba48 /packages/web3-wrapper | |
parent | 817c332d11835f02726f0609374d1c25c9ab39b5 (diff) | |
parent | 927ccc489c8cd69723bb2b13f81de150d7b255d0 (diff) | |
download | dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.tar dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.tar.gz dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.tar.bz2 dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.tar.lz dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.tar.xz dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.tar.zst dexon-sol-tools-7e5866ce3fffc67633d3ab84cc3d2a6abdd22ce5.zip |
Merge pull request #675 from 0xProject/feature/sol-cov-geth
`ProfilerSubprovider` & Geth-related fixes for `sol-cov`
Diffstat (limited to 'packages/web3-wrapper')
-rw-r--r-- | packages/web3-wrapper/CHANGELOG.json | 12 | ||||
-rw-r--r-- | packages/web3-wrapper/src/web3_wrapper.ts | 52 |
2 files changed, 59 insertions, 5 deletions
diff --git a/packages/web3-wrapper/CHANGELOG.json b/packages/web3-wrapper/CHANGELOG.json index 54a816e23..35a8e2c05 100644 --- a/packages/web3-wrapper/CHANGELOG.json +++ b/packages/web3-wrapper/CHANGELOG.json @@ -3,6 +3,18 @@ "version": "0.7.0", "changes": [ { + "note": "Add `web3Wrapper.getContractCodeAsync`", + "pr": 675 + }, + { + "note": "Add `web3Wrapper.getTransactionTraceAsync`", + "pr": 675 + }, + { + "note": "Add `web3Wrapper.getBlockWithTransactionDataAsync`", + "pr": 675 + }, + { "note": "Add exported uniqueVersionIds object", "pr": 622 }, diff --git a/packages/web3-wrapper/src/web3_wrapper.ts b/packages/web3-wrapper/src/web3_wrapper.ts index 559bf3ea9..780695091 100644 --- a/packages/web3-wrapper/src/web3_wrapper.ts +++ b/packages/web3-wrapper/src/web3_wrapper.ts @@ -2,6 +2,7 @@ import { AbiDecoder, addressUtils, BigNumber, intervalUtils, promisify } from '@ import { BlockParam, BlockWithoutTransactionData, + BlockWithTransactionData, CallData, ContractAbi, FilterObject, @@ -10,8 +11,10 @@ import { LogEntry, Provider, RawLogEntry, + TraceParams, TransactionReceipt, TransactionReceiptWithDecodedLogs, + TransactionTrace, TxData, } from 'ethereum-types'; import * as _ from 'lodash'; @@ -187,12 +190,34 @@ export class Web3Wrapper { * @returns Whether or not contract code was found at the supplied address */ public async doesContractExistAtAddressAsync(address: string): Promise<boolean> { - const code = await promisify<string>(this._web3.eth.getCode)(address); + const code = await this.getContractCodeAsync(address); // Regex matches 0x0, 0x00, 0x in order to accommodate poorly implemented clients const isCodeEmpty = /^0x0{0,40}$/i.test(code); return !isCodeEmpty; } /** + * Gets the contract code by address + * @param address Address of the contract + * @return Code of the contract + */ + public async getContractCodeAsync(address: string): Promise<string> { + const code = await promisify<string>(this._web3.eth.getCode)(address); + return code; + } + /** + * Gets the debug trace of a transaction + * @param txHash Hash of the transactuon to get a trace for + * @param traceParams Config object allowing you to specify if you need memory/storage/stack traces. + * @return Transaction trace + */ + public async getTransactionTraceAsync(txHash: string, traceParams: TraceParams): Promise<TransactionTrace> { + const trace = await this._sendRawPayloadAsync<TransactionTrace>({ + method: 'debug_traceTransaction', + params: [txHash, traceParams], + }); + return trace; + } + /** * Sign a message with a specific address's private key (`eth_sign`) * @param address Address of signer * @param message Message to sign @@ -211,13 +236,30 @@ export class Web3Wrapper { return blockNumber; } /** - * Fetch a specific Ethereum block + * Fetch a specific Ethereum block without transaction data * @param blockParam The block you wish to fetch (blockHash, blockNumber or blockLiteral) * @returns The requested block without transaction data */ public async getBlockAsync(blockParam: string | BlockParam): Promise<BlockWithoutTransactionData> { - const block = await promisify<BlockWithoutTransactionData>(this._web3.eth.getBlock)(blockParam); - return block; + const shouldIncludeTransactionData = false; + const blockWithoutTransactionData = await promisify<BlockWithoutTransactionData>(this._web3.eth.getBlock)( + blockParam, + shouldIncludeTransactionData, + ); + return blockWithoutTransactionData; + } + /** + * Fetch a specific Ethereum block with transaction data + * @param blockParam The block you wish to fetch (blockHash, blockNumber or blockLiteral) + * @returns The requested block with transaction data + */ + public async getBlockWithTransactionDataAsync(blockParam: string | BlockParam): Promise<BlockWithTransactionData> { + const shouldIncludeTransactionData = true; + const blockWithTransactionData = await promisify<BlockWithTransactionData>(this._web3.eth.getBlock)( + blockParam, + shouldIncludeTransactionData, + ); + return blockWithTransactionData; } /** * Fetch a block's timestamp @@ -469,4 +511,4 @@ export class Web3Wrapper { const decimal = this._web3.toDecimal(hex); return decimal; } -} +} // tslint:disable-line:max-file-line-count |