essential-eth 0.5.1 → 0.5.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/classes/Contract.d.ts +3 -2
- package/lib/cjs/classes/Contract.js +3 -2
- package/lib/cjs/classes/utils/clean-transaction-receipt.d.ts +5 -0
- package/lib/cjs/classes/utils/clean-transaction-receipt.js +55 -0
- package/lib/cjs/classes/utils/encode-decode-transaction.d.ts +1 -0
- package/lib/cjs/classes/utils/encode-decode-transaction.js +4 -4
- package/lib/cjs/classes/utils/fetchers.d.ts +1 -1
- package/lib/cjs/index.d.ts +12 -4
- package/lib/cjs/index.js +16 -1
- package/lib/cjs/logger/package-version.d.ts +1 -1
- package/lib/cjs/logger/package-version.js +1 -1
- package/lib/cjs/providers/BaseProvider.d.ts +284 -0
- package/lib/cjs/providers/BaseProvider.js +380 -0
- package/lib/cjs/providers/FallthroughProvider.d.ts +24 -0
- package/lib/cjs/providers/FallthroughProvider.js +65 -0
- package/lib/cjs/providers/JsonRpcProvider.d.ts +4 -200
- package/lib/cjs/providers/JsonRpcProvider.js +11 -263
- package/lib/cjs/providers/test/rpc-urls.d.ts +1 -0
- package/lib/cjs/providers/test/rpc-urls.js +1 -0
- package/lib/cjs/providers/utils/chains-info.d.ts +20 -0
- package/lib/cjs/providers/utils/chains-info.js +62 -2
- package/lib/cjs/shared/tiny-big/tiny-big.d.ts +2 -2
- package/lib/cjs/shared/tiny-big/tiny-big.js +2 -2
- package/lib/cjs/types/Transaction.types.d.ts +53 -0
- package/lib/cjs/utils/bytes.d.ts +86 -4
- package/lib/cjs/utils/bytes.js +83 -3
- package/lib/cjs/utils/compute-address.d.ts +8 -0
- package/lib/cjs/utils/compute-address.js +24 -0
- package/lib/cjs/utils/compute-public-key.d.ts +9 -0
- package/lib/cjs/utils/compute-public-key.js +17 -0
- package/lib/cjs/utils/hash-message.d.ts +12 -0
- package/lib/cjs/utils/hash-message.js +26 -0
- package/lib/cjs/utils/keccak256.d.ts +2 -0
- package/lib/cjs/utils/keccak256.js +17 -0
- package/lib/cjs/utils/solidity-keccak256.d.ts +0 -1
- package/lib/cjs/utils/solidity-keccak256.js +5 -12
- package/lib/cjs/utils/split-signature.d.ts +26 -0
- package/lib/cjs/utils/split-signature.js +165 -0
- package/lib/cjs/utils/to-utf8-bytes.d.ts +1 -0
- package/lib/cjs/utils/to-utf8-bytes.js +7 -0
- package/lib/esm/classes/Contract.js +1 -1
- package/lib/esm/classes/utils/clean-transaction-receipt.d.ts +2 -0
- package/lib/esm/classes/utils/clean-transaction-receipt.js +48 -0
- package/lib/esm/classes/utils/encode-decode-transaction.d.ts +1 -0
- package/lib/esm/classes/utils/encode-decode-transaction.js +2 -2
- package/lib/esm/classes/utils/fetchers.d.ts +1 -1
- package/lib/esm/index.d.ts +12 -4
- package/lib/esm/index.js +10 -2
- package/lib/esm/logger/package-version.d.ts +1 -1
- package/lib/esm/logger/package-version.js +1 -1
- package/lib/esm/providers/BaseProvider.d.ts +19 -0
- package/lib/esm/providers/BaseProvider.js +107 -0
- package/lib/esm/providers/FallthroughProvider.d.ts +11 -0
- package/lib/esm/providers/FallthroughProvider.js +41 -0
- package/lib/esm/providers/JsonRpcProvider.d.ts +4 -12
- package/lib/esm/providers/JsonRpcProvider.js +8 -69
- package/lib/esm/providers/test/rpc-urls.d.ts +1 -0
- package/lib/esm/providers/test/rpc-urls.js +1 -0
- package/lib/esm/providers/utils/chains-info.d.ts +20 -0
- package/lib/esm/providers/utils/chains-info.js +62 -2
- package/lib/esm/types/Transaction.types.d.ts +45 -0
- package/lib/esm/utils/bytes.d.ts +5 -4
- package/lib/esm/utils/bytes.js +2 -2
- package/lib/esm/utils/compute-address.d.ts +1 -0
- package/lib/esm/utils/compute-address.js +11 -0
- package/lib/esm/utils/compute-public-key.d.ts +2 -0
- package/lib/esm/utils/compute-public-key.js +6 -0
- package/lib/esm/utils/hash-message.d.ts +2 -0
- package/lib/esm/utils/hash-message.js +12 -0
- package/lib/esm/utils/keccak256.d.ts +2 -0
- package/lib/esm/utils/keccak256.js +13 -0
- package/lib/esm/utils/solidity-keccak256.d.ts +0 -1
- package/lib/esm/utils/solidity-keccak256.js +4 -10
- package/lib/esm/utils/split-signature.d.ts +2 -0
- package/lib/esm/utils/split-signature.js +126 -0
- package/lib/esm/utils/to-utf8-bytes.d.ts +1 -0
- package/lib/esm/utils/to-utf8-bytes.js +3 -0
- package/package.json +19 -14
- package/readme.md +648 -95
|
@@ -18,8 +18,9 @@ export declare class BaseContract {
|
|
|
18
18
|
*/
|
|
19
19
|
export declare function defineReadOnly<T>(object: T, name: string, value: any): void;
|
|
20
20
|
/**
|
|
21
|
+
* @alpha
|
|
21
22
|
* Only accepts ABIS in JSON format. This allows for stronger typing and assurances of data-types
|
|
22
|
-
*
|
|
23
|
+
* * Only read-only function calls currently supported.
|
|
23
24
|
* @example
|
|
24
25
|
* ```typescript
|
|
25
26
|
* import { Contract, JsonRpcProvider } from 'essential-eth';
|
|
@@ -65,7 +66,7 @@ export declare function defineReadOnly<T>(object: T, name: string, value: any):
|
|
|
65
66
|
*/
|
|
66
67
|
export declare class Contract extends BaseContract {
|
|
67
68
|
/**
|
|
68
|
-
* The
|
|
69
|
+
* The function names on any given contract. Like "isClaimed", "merkleRoot", etc.
|
|
69
70
|
*/
|
|
70
71
|
readonly [key: string]: any;
|
|
71
72
|
}
|
|
@@ -51,7 +51,7 @@ class BaseContract {
|
|
|
51
51
|
? estimateGas(data)
|
|
52
52
|
: null;
|
|
53
53
|
const req = () => __awaiter(this, void 0, void 0, function* () {
|
|
54
|
-
return yield (0, fetchers_1.post)(this._provider.
|
|
54
|
+
return yield (0, fetchers_1.post)(this._provider.selectRpcUrl(), (0, fetchers_1.buildRPCPostBody)('eth_call', [
|
|
55
55
|
Object.assign({ to: this._address.toLowerCase(), data }, (decimalGas
|
|
56
56
|
? { gas: `0x${decimalGas.toString(16)}` }
|
|
57
57
|
: {})),
|
|
@@ -78,8 +78,9 @@ function defineReadOnly(object, name, value) {
|
|
|
78
78
|
}
|
|
79
79
|
exports.defineReadOnly = defineReadOnly;
|
|
80
80
|
/**
|
|
81
|
+
* @alpha
|
|
81
82
|
* Only accepts ABIS in JSON format. This allows for stronger typing and assurances of data-types
|
|
82
|
-
*
|
|
83
|
+
* * Only read-only function calls currently supported.
|
|
83
84
|
* @example
|
|
84
85
|
* ```typescript
|
|
85
86
|
* import { Contract, JsonRpcProvider } from 'essential-eth';
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { RPCTransactionReceipt, TransactionReceipt } from '../../types/Transaction.types';
|
|
2
|
+
/**
|
|
3
|
+
* Converts RPC transaction receipt response to more JS-friendly format
|
|
4
|
+
*/
|
|
5
|
+
export declare function cleanTransactionReceipt(transactionReceipt: RPCTransactionReceipt): TransactionReceipt;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.cleanTransactionReceipt = void 0;
|
|
4
|
+
const __1 = require("../..");
|
|
5
|
+
const clean_transaction_1 = require("./clean-transaction");
|
|
6
|
+
const hex_to_decimal_1 = require("./hex-to-decimal");
|
|
7
|
+
/**
|
|
8
|
+
* Converts RPC transaction receipt response to more JS-friendly format
|
|
9
|
+
*/
|
|
10
|
+
function cleanTransactionReceipt(transactionReceipt) {
|
|
11
|
+
const cleanedTransaction = (0, clean_transaction_1.cleanTransaction)(transactionReceipt);
|
|
12
|
+
const cleanedTransactionReceipt = Object.assign({}, cleanedTransaction);
|
|
13
|
+
Object.keys(transactionReceipt).forEach((key) => {
|
|
14
|
+
if (!transactionReceipt[key])
|
|
15
|
+
return;
|
|
16
|
+
switch (key) {
|
|
17
|
+
case 'status':
|
|
18
|
+
cleanedTransactionReceipt[key] = Number((0, hex_to_decimal_1.hexToDecimal)(transactionReceipt[key]));
|
|
19
|
+
break;
|
|
20
|
+
case 'contractAddress':
|
|
21
|
+
if (transactionReceipt[key]) {
|
|
22
|
+
cleanedTransactionReceipt[key] = (0, __1.toChecksumAddress)(transactionReceipt[key]);
|
|
23
|
+
}
|
|
24
|
+
break;
|
|
25
|
+
case 'cumulativeGasUsed':
|
|
26
|
+
case 'effectiveGasPrice':
|
|
27
|
+
case 'gasUsed':
|
|
28
|
+
cleanedTransactionReceipt[key] = (0, __1.tinyBig)((0, hex_to_decimal_1.hexToDecimal)(transactionReceipt[key]));
|
|
29
|
+
break;
|
|
30
|
+
case 'logs':
|
|
31
|
+
transactionReceipt[key].forEach((log, index) => {
|
|
32
|
+
Object.keys(log).forEach((logKey) => {
|
|
33
|
+
switch (logKey) {
|
|
34
|
+
case 'address':
|
|
35
|
+
cleanedTransactionReceipt[key][index][logKey] =
|
|
36
|
+
(0, __1.toChecksumAddress)(log[logKey]);
|
|
37
|
+
break;
|
|
38
|
+
case 'blockNumber':
|
|
39
|
+
case 'logIndex':
|
|
40
|
+
case 'transactionIndex':
|
|
41
|
+
cleanedTransactionReceipt[key][index][logKey] = Number((0, hex_to_decimal_1.hexToDecimal)(log[logKey]));
|
|
42
|
+
break;
|
|
43
|
+
case 'removed':
|
|
44
|
+
delete log[logKey];
|
|
45
|
+
break;
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
cleanedTransactionReceipt.byzantium =
|
|
52
|
+
cleanedTransactionReceipt.blockNumber >= 4370000;
|
|
53
|
+
return cleanedTransactionReceipt;
|
|
54
|
+
}
|
|
55
|
+
exports.cleanTransactionReceipt = cleanTransactionReceipt;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
import { JSONABIArgument } from '../../types/Contract.types';
|
|
2
|
+
export declare const hexFalse: string;
|
|
2
3
|
export declare function encodeData(jsonABIArgument: JSONABIArgument, args: any[]): string;
|
|
3
4
|
export declare function decodeRPCResponse(jsonABIArgument: JSONABIArgument, nodeResponse: string): string | number | boolean | import("../..").TinyBig | (string | number | boolean | import("../..").TinyBig)[];
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.decodeRPCResponse = exports.encodeData = void 0;
|
|
3
|
+
exports.decodeRPCResponse = exports.encodeData = exports.hexFalse = void 0;
|
|
4
4
|
const sha3_1 = require("sha3");
|
|
5
5
|
const __1 = require("../..");
|
|
6
6
|
const hex_to_decimal_1 = require("./hex-to-decimal");
|
|
7
|
-
|
|
8
|
-
const
|
|
7
|
+
exports.hexFalse = '0'.repeat(64);
|
|
8
|
+
const hexTrue = '0'.repeat(63) + '1';
|
|
9
9
|
function expandType(type) {
|
|
10
10
|
// https://docs.soliditylang.org/en/v0.8.7/types.html#integers
|
|
11
11
|
if (type === 'uint[]') {
|
|
@@ -50,7 +50,7 @@ function encodeData(jsonABIArgument, args) {
|
|
|
50
50
|
let rawArg = arg;
|
|
51
51
|
switch (inputType) {
|
|
52
52
|
case 'bool':
|
|
53
|
-
return arg ? hexTrue : hexFalse;
|
|
53
|
+
return arg ? hexTrue : exports.hexFalse;
|
|
54
54
|
case 'address':
|
|
55
55
|
// remove leading "0x"
|
|
56
56
|
rawArg = arg.replace(/^0x/g, '').toLowerCase();
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export declare function post(url: string, body: Record<string, unknown>): Promise<any>;
|
|
2
|
-
declare type RPCMethodName = 'eth_getBlockByNumber' | 'eth_call' | 'eth_chainId' | 'eth_gasPrice' | 'eth_getBalance' | 'eth_getTransactionByHash';
|
|
2
|
+
declare type RPCMethodName = 'eth_getBlockByNumber' | 'eth_getBlockByHash' | 'eth_call' | 'eth_chainId' | 'eth_gasPrice' | 'eth_getBalance' | 'eth_getTransactionByHash' | 'eth_getTransactionReceipt' | 'eth_getTransactionCount' | 'eth_blockNumber';
|
|
3
3
|
export declare function buildRPCPostBody(method: RPCMethodName, params: unknown[]): {
|
|
4
4
|
jsonrpc: string;
|
|
5
5
|
id: number;
|
package/lib/cjs/index.d.ts
CHANGED
|
@@ -1,16 +1,24 @@
|
|
|
1
|
-
import { Contract } from './classes/Contract';
|
|
1
|
+
import { BaseContract, Contract } from './classes/Contract';
|
|
2
|
+
import { ConstructorOptions, FallthroughProvider } from './providers/FallthroughProvider';
|
|
2
3
|
import { JsonRpcProvider, jsonRpcProvider } from './providers/JsonRpcProvider';
|
|
3
4
|
import { tinyBig, TinyBig } from './shared/tiny-big/tiny-big';
|
|
4
|
-
import { BlockResponse } from './types/Block.types';
|
|
5
|
+
import { BlockResponse, BlockTag, RPCBlock } from './types/Block.types';
|
|
5
6
|
import { ContractTypes, JSONABI, JSONABIArgument } from './types/Contract.types';
|
|
6
7
|
import { Network } from './types/Network.types';
|
|
7
|
-
import { TransactionResponse } from './types/Transaction.types';
|
|
8
|
+
import { BlockTransactionResponse, Log, RPCLog, RPCTransaction, RPCTransactionReceipt, TransactionReceipt, TransactionResponse } from './types/Transaction.types';
|
|
9
|
+
import { computeAddress } from './utils/compute-address';
|
|
10
|
+
import { computePublicKey } from './utils/compute-public-key';
|
|
8
11
|
import { etherToGwei } from './utils/ether-to-gwei';
|
|
9
12
|
import { etherToWei } from './utils/ether-to-wei';
|
|
10
13
|
import { gweiToEther } from './utils/gwei-to-ether';
|
|
14
|
+
import { hashMessage } from './utils/hash-message';
|
|
11
15
|
import { isAddress } from './utils/is-address';
|
|
16
|
+
import { splitSignature } from './utils/split-signature';
|
|
12
17
|
import { toChecksumAddress } from './utils/to-checksum-address';
|
|
18
|
+
import { toUtf8Bytes } from './utils/to-utf8-bytes';
|
|
13
19
|
import { weiToEther } from './utils/wei-to-ether';
|
|
14
20
|
export * from './utils/bytes';
|
|
21
|
+
export * from './utils/hash-message';
|
|
22
|
+
export * from './utils/keccak256';
|
|
15
23
|
export * from './utils/solidity-keccak256';
|
|
16
|
-
export { etherToWei, etherToGwei, isAddress, jsonRpcProvider, JsonRpcProvider, tinyBig, toChecksumAddress, weiToEther, gweiToEther, Contract, TinyBig, BlockResponse, ContractTypes, JSONABI, JSONABIArgument, Network, TransactionResponse, };
|
|
24
|
+
export { etherToWei, etherToGwei, isAddress, jsonRpcProvider, JsonRpcProvider, FallthroughProvider, tinyBig, toChecksumAddress, weiToEther, gweiToEther, hashMessage, splitSignature, toUtf8Bytes, computeAddress, computePublicKey, Contract, TinyBig, BaseContract, BlockResponse, ContractTypes, JSONABI, JSONABIArgument, Network, TransactionResponse, RPCBlock, RPCTransaction, RPCTransactionReceipt, TransactionReceipt, BlockTag, RPCLog, Log, BlockTransactionResponse, ConstructorOptions, };
|
package/lib/cjs/index.js
CHANGED
|
@@ -14,26 +14,41 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.TinyBig = exports.Contract = exports.gweiToEther = exports.weiToEther = exports.toChecksumAddress = exports.tinyBig = exports.JsonRpcProvider = exports.jsonRpcProvider = exports.isAddress = exports.etherToGwei = exports.etherToWei = void 0;
|
|
17
|
+
exports.BaseContract = exports.TinyBig = exports.Contract = exports.computePublicKey = exports.computeAddress = exports.toUtf8Bytes = exports.splitSignature = exports.hashMessage = exports.gweiToEther = exports.weiToEther = exports.toChecksumAddress = exports.tinyBig = exports.FallthroughProvider = exports.JsonRpcProvider = exports.jsonRpcProvider = exports.isAddress = exports.etherToGwei = exports.etherToWei = void 0;
|
|
18
18
|
const Contract_1 = require("./classes/Contract");
|
|
19
|
+
Object.defineProperty(exports, "BaseContract", { enumerable: true, get: function () { return Contract_1.BaseContract; } });
|
|
19
20
|
Object.defineProperty(exports, "Contract", { enumerable: true, get: function () { return Contract_1.Contract; } });
|
|
21
|
+
const FallthroughProvider_1 = require("./providers/FallthroughProvider");
|
|
22
|
+
Object.defineProperty(exports, "FallthroughProvider", { enumerable: true, get: function () { return FallthroughProvider_1.FallthroughProvider; } });
|
|
20
23
|
const JsonRpcProvider_1 = require("./providers/JsonRpcProvider");
|
|
21
24
|
Object.defineProperty(exports, "JsonRpcProvider", { enumerable: true, get: function () { return JsonRpcProvider_1.JsonRpcProvider; } });
|
|
22
25
|
Object.defineProperty(exports, "jsonRpcProvider", { enumerable: true, get: function () { return JsonRpcProvider_1.jsonRpcProvider; } });
|
|
23
26
|
const tiny_big_1 = require("./shared/tiny-big/tiny-big");
|
|
24
27
|
Object.defineProperty(exports, "tinyBig", { enumerable: true, get: function () { return tiny_big_1.tinyBig; } });
|
|
25
28
|
Object.defineProperty(exports, "TinyBig", { enumerable: true, get: function () { return tiny_big_1.TinyBig; } });
|
|
29
|
+
const compute_address_1 = require("./utils/compute-address");
|
|
30
|
+
Object.defineProperty(exports, "computeAddress", { enumerable: true, get: function () { return compute_address_1.computeAddress; } });
|
|
31
|
+
const compute_public_key_1 = require("./utils/compute-public-key");
|
|
32
|
+
Object.defineProperty(exports, "computePublicKey", { enumerable: true, get: function () { return compute_public_key_1.computePublicKey; } });
|
|
26
33
|
const ether_to_gwei_1 = require("./utils/ether-to-gwei");
|
|
27
34
|
Object.defineProperty(exports, "etherToGwei", { enumerable: true, get: function () { return ether_to_gwei_1.etherToGwei; } });
|
|
28
35
|
const ether_to_wei_1 = require("./utils/ether-to-wei");
|
|
29
36
|
Object.defineProperty(exports, "etherToWei", { enumerable: true, get: function () { return ether_to_wei_1.etherToWei; } });
|
|
30
37
|
const gwei_to_ether_1 = require("./utils/gwei-to-ether");
|
|
31
38
|
Object.defineProperty(exports, "gweiToEther", { enumerable: true, get: function () { return gwei_to_ether_1.gweiToEther; } });
|
|
39
|
+
const hash_message_1 = require("./utils/hash-message");
|
|
40
|
+
Object.defineProperty(exports, "hashMessage", { enumerable: true, get: function () { return hash_message_1.hashMessage; } });
|
|
32
41
|
const is_address_1 = require("./utils/is-address");
|
|
33
42
|
Object.defineProperty(exports, "isAddress", { enumerable: true, get: function () { return is_address_1.isAddress; } });
|
|
43
|
+
const split_signature_1 = require("./utils/split-signature");
|
|
44
|
+
Object.defineProperty(exports, "splitSignature", { enumerable: true, get: function () { return split_signature_1.splitSignature; } });
|
|
34
45
|
const to_checksum_address_1 = require("./utils/to-checksum-address");
|
|
35
46
|
Object.defineProperty(exports, "toChecksumAddress", { enumerable: true, get: function () { return to_checksum_address_1.toChecksumAddress; } });
|
|
47
|
+
const to_utf8_bytes_1 = require("./utils/to-utf8-bytes");
|
|
48
|
+
Object.defineProperty(exports, "toUtf8Bytes", { enumerable: true, get: function () { return to_utf8_bytes_1.toUtf8Bytes; } });
|
|
36
49
|
const wei_to_ether_1 = require("./utils/wei-to-ether");
|
|
37
50
|
Object.defineProperty(exports, "weiToEther", { enumerable: true, get: function () { return wei_to_ether_1.weiToEther; } });
|
|
38
51
|
__exportStar(require("./utils/bytes"), exports);
|
|
52
|
+
__exportStar(require("./utils/hash-message"), exports);
|
|
53
|
+
__exportStar(require("./utils/keccak256"), exports);
|
|
39
54
|
__exportStar(require("./utils/solidity-keccak256"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const version = "0.5.
|
|
1
|
+
export declare const version = "0.5.5";
|
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
import { TinyBig } from '../shared/tiny-big/tiny-big';
|
|
2
|
+
import { BlockResponse, BlockTag } from '../types/Block.types';
|
|
3
|
+
import { Network } from '../types/Network.types';
|
|
4
|
+
import { TransactionReceipt, TransactionResponse } from '../types/Transaction.types';
|
|
5
|
+
export declare abstract class BaseProvider {
|
|
6
|
+
/**
|
|
7
|
+
* ignore
|
|
8
|
+
*/
|
|
9
|
+
abstract selectRpcUrl(): string;
|
|
10
|
+
abstract post(body: Record<string, unknown>): Promise<any>;
|
|
11
|
+
/**
|
|
12
|
+
* @ignore
|
|
13
|
+
*/
|
|
14
|
+
readonly _rpcUrls: string[];
|
|
15
|
+
/**
|
|
16
|
+
* @ignore
|
|
17
|
+
*/
|
|
18
|
+
protected _post: (body: Record<string, unknown>) => Promise<any>;
|
|
19
|
+
/**
|
|
20
|
+
* @param rpcUrl The URL to your Eth node. Consider POKT or Infura
|
|
21
|
+
*/
|
|
22
|
+
constructor(rpcUrls: string[]);
|
|
23
|
+
/**
|
|
24
|
+
* Returns the network this provider is connected to
|
|
25
|
+
*/
|
|
26
|
+
getNetwork(): Promise<Network>;
|
|
27
|
+
/**
|
|
28
|
+
* Gets the number of the most recently mined block on the network the provider is connected to
|
|
29
|
+
*
|
|
30
|
+
* * Identical to [`ethers.provider.getBlockNumber`](https://docs.ethers.io/v5/api/providers/provider/#Provider-getBlockNumber)
|
|
31
|
+
* * Identical to [`web3.eth.getBlockNumber`](https://web3js.readthedocs.io/en/v1.7.3/web3-eth.html#getblocknumber)
|
|
32
|
+
*
|
|
33
|
+
* @returns the number of the most recently mined block
|
|
34
|
+
* @example
|
|
35
|
+
* ```js
|
|
36
|
+
* await provider.getBlockNumber();
|
|
37
|
+
* // 1053312
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
getBlockNumber(): Promise<number>;
|
|
41
|
+
/**
|
|
42
|
+
* * Similar to [`ethers.provider.getTransaction`](https://docs.ethers.io/v5/api/providers/provider/#Provider-getTransaction), some information not included
|
|
43
|
+
*
|
|
44
|
+
* @returns information about one transaction
|
|
45
|
+
* @example
|
|
46
|
+
* ```js
|
|
47
|
+
* await provider.getTransaction('0x9014ae6ef92464338355a79e5150e542ff9a83e2323318b21f40d6a3e65b4789');
|
|
48
|
+
* {
|
|
49
|
+
* accessList: [],
|
|
50
|
+
* blockHash: '0x876810a013dbcd140f6fd6048c1dc33abbb901f1f96b394c2fa63aef3cb40b5d',
|
|
51
|
+
* blockNumber: 14578286,
|
|
52
|
+
* chainId: 1,
|
|
53
|
+
* from: '0xdfD9dE5f6FA60BD70636c0900752E93a6144AEd4',
|
|
54
|
+
* gas: Big {
|
|
55
|
+
* s: 1,
|
|
56
|
+
* e: 5,
|
|
57
|
+
* c: [ 1, 1, 2, 1, 6, 3 ],
|
|
58
|
+
* constructor: <ref *1> [Function: Big] {
|
|
59
|
+
* DP: 20,
|
|
60
|
+
* RM: 1,
|
|
61
|
+
* NE: -7,
|
|
62
|
+
* PE: 21,
|
|
63
|
+
* strict: false,
|
|
64
|
+
* roundDown: 0,
|
|
65
|
+
* roundHalfUp: 1,
|
|
66
|
+
* roundHalfEven: 2,
|
|
67
|
+
* roundUp: 3,
|
|
68
|
+
* Big: [Circular *1],
|
|
69
|
+
* default: [Circular *1]
|
|
70
|
+
* }
|
|
71
|
+
* },
|
|
72
|
+
* gasPrice: Big {
|
|
73
|
+
* s: 1,
|
|
74
|
+
* e: 10,
|
|
75
|
+
* c: [
|
|
76
|
+
* 4, 8, 5, 9, 2,
|
|
77
|
+
* 4, 2, 6, 8, 5,
|
|
78
|
+
* 8
|
|
79
|
+
* ],
|
|
80
|
+
* constructor: <ref *1> [Function: Big] {
|
|
81
|
+
* DP: 20,
|
|
82
|
+
* RM: 1,
|
|
83
|
+
* NE: -7,
|
|
84
|
+
* PE: 21,
|
|
85
|
+
* strict: false,
|
|
86
|
+
* roundDown: 0,
|
|
87
|
+
* roundHalfUp: 1,
|
|
88
|
+
* roundHalfEven: 2,
|
|
89
|
+
* roundUp: 3,
|
|
90
|
+
* Big: [Circular *1],
|
|
91
|
+
* default: [Circular *1]
|
|
92
|
+
* }
|
|
93
|
+
* },
|
|
94
|
+
* hash: '0x9014ae6ef92464338355a79e5150e542ff9a83e2323318b21f40d6a3e65b4789',
|
|
95
|
+
* input: '0x83259f170000000000000000000000000000000000000000000000000000000000000080000000000000000000000000dfd9de5f6fa60bd70636c0900752e93a6144aed400000000000000000000000000000000000000000000000000000000000000c0000000000000000000000000000000000000000000000000000000000000024000000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000003000000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000009e99ad11a214fd016b19dc3648678c5944859ae292b21c24ca94f857836c4596f1950c82dd0c23dd621af4763edc2f66466e63c5df9de0c1107b1cd16bf460fe93e43fd308e3444bc79c3d88a4cb961dc8367ab6ad048867afc76d193bca99cf3a068864ed4a7df1dbf1d4c52238eced3e5e05644b4040fc2b3ccb8557b0e99fff6131305a0ea2b8061b90bd418db5bbdd2e92129f52d93f90531465e309c4caec5b85285822b6196398d36f16f511811b61bbda6461e80e29210cd303118bdcee8df6fa0505ffbe8642094fd2ba4dd458496fe3b459ac880bbf71877c713e969ccf5ed7efab8a84ebc07e3939901371ca427e1192e455a8f35a6a1d7ad09e1475dd1758b36fa631dab5d70e99316b23c4c43094188d360cd9c3457355904e07c00000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000162074a7047f',
|
|
96
|
+
* maxFeePerGas: Big {
|
|
97
|
+
* s: 1,
|
|
98
|
+
* e: 10,
|
|
99
|
+
* c: [
|
|
100
|
+
* 6, 7, 6, 8, 1,
|
|
101
|
+
* 2, 6, 1, 6, 1,
|
|
102
|
+
* 8
|
|
103
|
+
* ],
|
|
104
|
+
* constructor: <ref *1> [Function: Big] {
|
|
105
|
+
* DP: 20,
|
|
106
|
+
* RM: 1,
|
|
107
|
+
* NE: -7,
|
|
108
|
+
* PE: 21,
|
|
109
|
+
* strict: false,
|
|
110
|
+
* roundDown: 0,
|
|
111
|
+
* roundHalfUp: 1,
|
|
112
|
+
* roundHalfEven: 2,
|
|
113
|
+
* roundUp: 3,
|
|
114
|
+
* Big: [Circular *1],
|
|
115
|
+
* default: [Circular *1]
|
|
116
|
+
* }
|
|
117
|
+
* },
|
|
118
|
+
* maxPriorityFeePerGas: Big {
|
|
119
|
+
* s: 1,
|
|
120
|
+
* e: 9,
|
|
121
|
+
* c: [ 1, 5 ],
|
|
122
|
+
* constructor: <ref *1> [Function: Big] {
|
|
123
|
+
* DP: 20,
|
|
124
|
+
* RM: 1,
|
|
125
|
+
* NE: -7,
|
|
126
|
+
* PE: 21,
|
|
127
|
+
* strict: false,
|
|
128
|
+
* roundDown: 0,
|
|
129
|
+
* roundHalfUp: 1,
|
|
130
|
+
* roundHalfEven: 2,
|
|
131
|
+
* roundUp: 3,
|
|
132
|
+
* Big: [Circular *1],
|
|
133
|
+
* default: [Circular *1]
|
|
134
|
+
* }
|
|
135
|
+
* },
|
|
136
|
+
* nonce: 129,
|
|
137
|
+
* r: '0x59a7c15b12c18cd68d6c440963d959bff3e73831ffc938e75ecad07f7ee43fbc',
|
|
138
|
+
* s: '0x1ebaf05f0d9273b16c2a7748b150a79d22533a8cd74552611cbe620fee3dcf1c',
|
|
139
|
+
* to: '0x39B72d136ba3e4ceF35F48CD09587ffaB754DD8B',
|
|
140
|
+
* transactionIndex: 29,
|
|
141
|
+
* type: 2,
|
|
142
|
+
* v: 0,
|
|
143
|
+
* value: Big {
|
|
144
|
+
* s: 1,
|
|
145
|
+
* e: 0,
|
|
146
|
+
* c: [ 0 ],
|
|
147
|
+
* constructor: <ref *1> [Function: Big] {
|
|
148
|
+
* DP: 20,
|
|
149
|
+
* RM: 1,
|
|
150
|
+
* NE: -7,
|
|
151
|
+
* PE: 21,
|
|
152
|
+
* strict: false,
|
|
153
|
+
* roundDown: 0,
|
|
154
|
+
* roundHalfUp: 1,
|
|
155
|
+
* roundHalfEven: 2,
|
|
156
|
+
* roundUp: 3,
|
|
157
|
+
* Big: [Circular *1],
|
|
158
|
+
* default: [Circular *1]
|
|
159
|
+
* }
|
|
160
|
+
* },
|
|
161
|
+
* confirmations: 1210
|
|
162
|
+
* }
|
|
163
|
+
* ```
|
|
164
|
+
*/
|
|
165
|
+
getTransaction(transactionHash: string): Promise<TransactionResponse>;
|
|
166
|
+
/**
|
|
167
|
+
* Gives information about a transaction that has already been mined. Includes additional information beyond what's provided by `getTransaction()`
|
|
168
|
+
*
|
|
169
|
+
* * Similar to [`ethers.provider.getTransactionReceipt`](https://docs.ethers.io/v5/api/providers/provider/#Provider-getTransactionReceipt), some information not included
|
|
170
|
+
*
|
|
171
|
+
* @param transactionHash the hash of the transaction to get information about
|
|
172
|
+
*
|
|
173
|
+
*/
|
|
174
|
+
getTransactionReceipt(transactionHash: string): Promise<TransactionReceipt>;
|
|
175
|
+
/**
|
|
176
|
+
* Returns the transaction count from genesis up to specified blockTag
|
|
177
|
+
*
|
|
178
|
+
* * Same as `ethers.provider.getTransactionCount`
|
|
179
|
+
* * Same as `web3.eth.getTransactionCount`
|
|
180
|
+
*
|
|
181
|
+
* @example
|
|
182
|
+
* ```js
|
|
183
|
+
* const address = '0x71660c4005ba85c37ccec55d0c4493e66fe775d3';
|
|
184
|
+
* await provider
|
|
185
|
+
* .getTransactionCount(address, 'latest')
|
|
186
|
+
* // 1060000
|
|
187
|
+
* ```
|
|
188
|
+
*
|
|
189
|
+
* @example
|
|
190
|
+
* ```js
|
|
191
|
+
* await provider
|
|
192
|
+
* .getTransactionCount(address)
|
|
193
|
+
* // 1053312
|
|
194
|
+
* ```
|
|
195
|
+
*
|
|
196
|
+
* @example
|
|
197
|
+
* ```js
|
|
198
|
+
* await provider
|
|
199
|
+
* .getTransactionCount(address, 14649390)
|
|
200
|
+
* // 1053312
|
|
201
|
+
* ```
|
|
202
|
+
*/
|
|
203
|
+
getTransactionCount(address: string, blockTag?: BlockTag): Promise<number>;
|
|
204
|
+
/**
|
|
205
|
+
* Gets information about a certain block.
|
|
206
|
+
* Same as `web3.eth.getBlock` and `ethers.providers.getBlock`
|
|
207
|
+
*
|
|
208
|
+
* @param timeFrame The number, hash, or text-based description ('latest', 'earliest', or 'pending') of the block to collect information on.
|
|
209
|
+
*
|
|
210
|
+
* @param returnTransactionObjects Whether to also return data about the transactions on the block.
|
|
211
|
+
*
|
|
212
|
+
* @returns A BlockResponse object with information about the specified block
|
|
213
|
+
*
|
|
214
|
+
* @example
|
|
215
|
+
* ```js
|
|
216
|
+
* await provider.getBlock(14645431);
|
|
217
|
+
* ```
|
|
218
|
+
*
|
|
219
|
+
* @example
|
|
220
|
+
* ```js
|
|
221
|
+
* await provider.getBlock('0x3e5cea9c2be7e0ab4b0aa04c24dafddc37571db2d2d345caf7f88b3366ece0cf');
|
|
222
|
+
* ```
|
|
223
|
+
*
|
|
224
|
+
* @example
|
|
225
|
+
* ```js
|
|
226
|
+
* await provider.getBlock('latest');
|
|
227
|
+
* {
|
|
228
|
+
* number: 4232826,
|
|
229
|
+
* hash: '0x93211a1cd17e154b183565ec685254a03f844a8e34824a46ce1bdd6753dcb669',
|
|
230
|
+
* parentHash: '0x1b32bfcba1bb2a57f56e166a3bb06875a1978992999dfc8828397b4c1526f472',
|
|
231
|
+
* sha3Uncles: '0x0fb399c67bb5a071ec8a22549223215ab76b7d4009941c9c37aa3c3936010463',
|
|
232
|
+
* logsBloom: '0x00000000000000000000101000000000020000000000000000000000000000000000400000010000000000000000000000000000010000000008800000000800000000200000000000000000000000000000000000000000000002000000000000000000000000000040000000000040000000000000000000000000000000000000000000000001000000000004000000000010000000000000000020000000000000000200100020000000000000000080000000000080001000000000000000000001040000000000000000008000000020010100000000200000100000000000000000000000002000000080000000020400000000002000200000000000',
|
|
233
|
+
* transactionsRoot: '0xc43b3f13e1fe810e34d3a26ffe465b72c7063a5c70a02de2c78e91e4d10bd9fb',
|
|
234
|
+
* stateRoot: '0x04d7bc816537ea7ef3a16e76c9879d29f34f99d4154273c2e98e012a31bad745',
|
|
235
|
+
* receiptsRoot: '0x89c6f781ceac0bd49c4d9aa9115df4a5d4dd0e0220ff7668012f15bc04222c6b',
|
|
236
|
+
* miner: '0x31fe561eb2c628cD32Ec52573D7c4b7E4C278Bfa',
|
|
237
|
+
* difficulty: '1300907486001755331049',
|
|
238
|
+
* totalDifficulty: '5989929395521171616186006183',
|
|
239
|
+
* extraData: '0xce018c495249532d62613031656132',
|
|
240
|
+
* size: 5416,
|
|
241
|
+
* gasLimit: 6800000,
|
|
242
|
+
* gasUsed: 202955,
|
|
243
|
+
* timestamp: 1649884910,
|
|
244
|
+
* transactions: [
|
|
245
|
+
* '0x6b34a59c7b9aead24fa6dad782f8a3ad84ed4a23ee09bcbf0bcf880840fbbe20',
|
|
246
|
+
* '0x9a3851ca24d5336c6a0d48aba2c4b4769d7a672c9b01729c5eb9924efd1b19a7',
|
|
247
|
+
* '0xc3ed3d198b62f2f3427ebfa3bbd0fcada4e3c0c189e4464e7eeceb403c75981e'
|
|
248
|
+
* ],
|
|
249
|
+
* uncles: [
|
|
250
|
+
* '0x0c567c054e98153f10d651fbbc018891c1dd9d62a9ffd998e87678803e95b6ed',
|
|
251
|
+
* '0xb7d69389dbfb057c6fcb4bc0582d46a2ba01170703f0dadf8cd1462b83e88753',
|
|
252
|
+
* '0xd5f74ccd0ad4c58b3161e8c2c507c264231e5f28925061b809c02e5e4bb6db28'
|
|
253
|
+
* ],
|
|
254
|
+
* minimumGasPrice: '0x387ee40',
|
|
255
|
+
* bitcoinMergedMiningHeader: '0x04000020e8567ed3d2480e15a1dd1b4335e4732ae343c037e4fd03000000000000000000ed10a8340d163d3e813bdd430f902f4e5a56828dc62313b2e23797c0be6b8516eb3e576297d8091735884f42',
|
|
256
|
+
* bitcoinMergedMiningCoinbaseTransaction: '0x0000000000000140e910128fda7bac502dc5e0573bbaf12de8e2524f70c22f7bd160dedcb19a2521002b6a2952534b424c4f434b3ae493303f597fa368c0ccc4f8aceabf1c315bb7c9a07605c073a89f260040967aace6a7d9',
|
|
257
|
+
* bitcoinMergedMiningMerkleProof: '0xdf63a3d7eb6fbcfb301311faa46e9a15b0408bb1a04e284daee86c273c1dfd65ede23f3170f806e9e0f4cef7ba6b56aa37470d9c23f96ec8e43d08b58645919c5e10bcb892897a731f8f9ce79c72dc0e390896bcd6c67bb38c0bdb72982b6cf05519968d76673572c3f3ef3a08b0ddb464863f1788f7cdbaad3fe44a8a8af576d430ac282fe28852c16df198ca96cc5f71a50695912efe1a836e8442be69e31b6d6f973da2818bce9a3a1c2d9be0671aee9a7776e398d6a03d1e178e20d84646004a3d03c0501334e629d9146aa6a01316dcbaa289df6e6c5e3090cadaddff22699cfc7ff09512fc0d65c5062f17c98561ce3c9510de210d9d654cf99f8d756ff37c9fa21e7122ee8cadb923341690845d572921425f2bd7e044558b7e07983ac4df28928028b0c13c3624dc7a965af8091b0cecc845bf7da5308c03b2c97d607f6706a599f802025894435f1d76ea4e67cc2fc4e1559f1206f559a24633de0f',
|
|
258
|
+
* hashForMergedMining: '0xe493303f597fa368c0ccc4f8aceabf1c315bb7c9a07605c073a89f260040967a',
|
|
259
|
+
* paidFees: '0xc0744dcb7a0',
|
|
260
|
+
* cumulativeDifficulty: '0x1190930db285269e582'
|
|
261
|
+
* }
|
|
262
|
+
*```
|
|
263
|
+
*/
|
|
264
|
+
getBlock(timeFrame?: BlockTag, returnTransactionObjects?: boolean): Promise<BlockResponse>;
|
|
265
|
+
/**
|
|
266
|
+
* Returns the current gas price in wei as TinyBig
|
|
267
|
+
* Same as `ethers.provider.getGasPrice`
|
|
268
|
+
*/
|
|
269
|
+
getGasPrice(): Promise<TinyBig>;
|
|
270
|
+
/**
|
|
271
|
+
* Returns the balance of the account in wei as TinyBig
|
|
272
|
+
* * Same as [`ethers.provider.getBalance`](https://docs.ethers.io/v5/api/providers/provider/#Provider-getBalance)
|
|
273
|
+
* * Same as `web3.eth.getBalance`
|
|
274
|
+
*
|
|
275
|
+
* @example
|
|
276
|
+
* ```js
|
|
277
|
+
* await provider
|
|
278
|
+
* .getBalance('0x7cB57B5A97eAbe94205C07890BE4c1aD31E486A8')
|
|
279
|
+
* .then((balance) => console.log(balance.toString()));
|
|
280
|
+
* // "28798127851528138"
|
|
281
|
+
* ```
|
|
282
|
+
*/
|
|
283
|
+
getBalance(address: string, blockTag?: BlockTag): Promise<TinyBig>;
|
|
284
|
+
}
|