You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
203 lines
5.3 KiB
203 lines
5.3 KiB
/*
|
|
This file is part of ethereum.js.
|
|
|
|
ethereum.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.
|
|
|
|
ethereum.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 ethereum.js. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
/** @file formatters.js
|
|
* @authors:
|
|
* Marek Kotewicz <marek@ethdev.com>
|
|
* Fabian Vogelsteller <fabian@ethdev.com>
|
|
* @date 2015
|
|
*/
|
|
|
|
var utils = require('../utils/utils');
|
|
|
|
/**
|
|
* Should the input to a big number
|
|
*
|
|
* @method convertToBigNumber
|
|
* @param {String|Number|BigNumber}
|
|
* @returns {BigNumber} object
|
|
*/
|
|
var convertToBigNumber = function (value) {
|
|
return utils.toBigNumber(value);
|
|
};
|
|
|
|
/**
|
|
* Formats the input of a transaction and converts all values to HEX
|
|
*
|
|
* @method inputTransactionFormatter
|
|
* @param {Object} transaction options
|
|
* @returns object
|
|
*/
|
|
var inputTransactionFormatter = function (options){
|
|
|
|
// make code -> data
|
|
if (options.code) {
|
|
options.data = options.code;
|
|
delete options.code;
|
|
}
|
|
|
|
['gasPrice', 'gas', 'value'].forEach(function(key){
|
|
options[key] = utils.fromDecimal(options[key]);
|
|
});
|
|
|
|
return options;
|
|
};
|
|
|
|
/**
|
|
* Formats the output of a transaction to its proper values
|
|
*
|
|
* @method outputTransactionFormatter
|
|
* @param {Object} transaction
|
|
* @returns {Object} transaction
|
|
*/
|
|
var outputTransactionFormatter = function (tx){
|
|
tx.gas = utils.toDecimal(tx.gas);
|
|
tx.gasPrice = utils.toBigNumber(tx.gasPrice);
|
|
tx.value = utils.toBigNumber(tx.value);
|
|
return tx;
|
|
};
|
|
|
|
/**
|
|
* Formats the input of a call and converts all values to HEX
|
|
*
|
|
* @method inputCallFormatter
|
|
* @param {Object} transaction options
|
|
* @returns object
|
|
*/
|
|
var inputCallFormatter = function (options){
|
|
|
|
// make code -> data
|
|
if (options.code) {
|
|
options.data = options.code;
|
|
delete options.code;
|
|
}
|
|
|
|
return options;
|
|
};
|
|
|
|
|
|
/**
|
|
* Formats the output of a block to its proper values
|
|
*
|
|
* @method outputBlockFormatter
|
|
* @param {Object} block object
|
|
* @returns {Object} block object
|
|
*/
|
|
var outputBlockFormatter = function(block){
|
|
|
|
// transform to number
|
|
block.gasLimit = utils.toDecimal(block.gasLimit);
|
|
block.gasUsed = utils.toDecimal(block.gasUsed);
|
|
block.size = utils.toDecimal(block.size);
|
|
block.timestamp = utils.toDecimal(block.timestamp);
|
|
block.number = utils.toDecimal(block.number);
|
|
|
|
block.minGasPrice = utils.toBigNumber(block.minGasPrice);
|
|
block.difficulty = utils.toBigNumber(block.difficulty);
|
|
block.totalDifficulty = utils.toBigNumber(block.totalDifficulty);
|
|
|
|
if(block.transactions instanceof Array) {
|
|
block.transactions.forEach(function(item){
|
|
if(!utils.isString(item))
|
|
return outputTransactionFormatter(item);
|
|
});
|
|
}
|
|
|
|
return block;
|
|
};
|
|
|
|
/**
|
|
* Formats the output of a log
|
|
*
|
|
* @method outputLogFormatter
|
|
* @param {Object} log object
|
|
* @returns {Object} log
|
|
*/
|
|
var outputLogFormatter = function(log){
|
|
log.blockNumber = utils.toDecimal(log.blockNumber);
|
|
log.transactionIndex = utils.toDecimal(log.transactionIndex);
|
|
log.logIndex = utils.toDecimal(log.logIndex);
|
|
|
|
return log;
|
|
};
|
|
|
|
|
|
/**
|
|
* Formats the input of a whisper post and converts all values to HEX
|
|
*
|
|
* @method inputPostFormatter
|
|
* @param {Object} transaction object
|
|
* @returns {Object}
|
|
*/
|
|
var inputPostFormatter = function(post){
|
|
|
|
post.payload = utils.toHex(post.payload);
|
|
post.ttl = utils.fromDecimal(post.ttl);
|
|
post.priority = utils.fromDecimal(post.priority);
|
|
|
|
if(!(post.topics instanceof Array))
|
|
post.topics = [post.topics];
|
|
|
|
|
|
// format the following options
|
|
post.topics = post.topics.map(function(topic){
|
|
return utils.fromAscii(topic);
|
|
});
|
|
|
|
return post;
|
|
};
|
|
|
|
/**
|
|
* Formats the output of a received post message
|
|
*
|
|
* @method outputPostFormatter
|
|
* @param {Object}
|
|
* @returns {Object}
|
|
*/
|
|
var outputPostFormatter = function(post){
|
|
|
|
post.expiry = utils.toDecimal(post.expiry);
|
|
post.sent = utils.toDecimal(post.sent);
|
|
post.ttl = utils.toDecimal(post.ttl);
|
|
post.workProved = utils.toDecimal(post.workProved);
|
|
post.payloadRaw = post.payload;
|
|
post.payload = utils.toAscii(post.payload);
|
|
|
|
if(post.payload.indexOf('{') === 0 || post.payload.indexOf('[') === 0) {
|
|
try {
|
|
post.payload = JSON.parse(post.payload);
|
|
} catch (e) { }
|
|
}
|
|
|
|
// format the following options
|
|
post.topics = post.topics.map(function(topic){
|
|
return utils.toAscii(topic);
|
|
});
|
|
|
|
return post;
|
|
};
|
|
|
|
module.exports = {
|
|
convertToBigNumber: convertToBigNumber,
|
|
inputTransactionFormatter: inputTransactionFormatter,
|
|
outputTransactionFormatter: outputTransactionFormatter,
|
|
inputCallFormatter: inputCallFormatter,
|
|
outputBlockFormatter: outputBlockFormatter,
|
|
outputLogFormatter: outputLogFormatter,
|
|
inputPostFormatter: inputPostFormatter,
|
|
outputPostFormatter: outputPostFormatter
|
|
};
|
|
|
|
|