-
Notifications
You must be signed in to change notification settings - Fork 5k
/
GetTransactionCountMethod.js
68 lines (59 loc) · 2.11 KB
/
GetTransactionCountMethod.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/*
This file is part of web3.js.
web3.js is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
web3.js is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with web3.js. If not, see <http://www.gnu.org/licenses/>.
*/
/**
* @file GetTransactionCountMethod.js
* @author Samuel Furter <[email protected]>
* @date 2018
*/
import isFunction from 'lodash/isFunction';
import AbstractCallMethod from '../../../lib/methods/AbstractCallMethod';
export default class GetTransactionCountMethod extends AbstractCallMethod {
/**
* @param {Utils} utils
* @param {Object} formatters
*
* @constructor
*/
constructor(utils, formatters) {
super('eth_getTransactionCount', 2, utils, formatters);
}
/**
* This method will be executed before the effective execution.
*
* @method beforeExecution
*
* @param {AbstractWeb3Module} moduleInstance
*/
beforeExecution(moduleInstance) {
this.parameters[0] = this.formatters.inputAddressFormatter(this.parameters[0]);
// Optional second parameter 'defaultBlock' could also be the callback
if (isFunction(this.parameters[1])) {
this.callback = this.parameters[1];
this.parameters[1] = moduleInstance.defaultBlock;
}
this.parameters[1] = this.formatters.inputDefaultBlockNumberFormatter(this.parameters[1], moduleInstance);
}
/**
* This method will be executed after the RPC request.
*
* @method afterExecution
*
* @param {Object} response
*
* @returns {Number}
*/
afterExecution(response) {
return this.utils.hexToNumber(response);
}
}