aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib/util.js
diff options
context:
space:
mode:
authorDan <danjm.com@gmail.com>2018-04-17 01:08:04 +0800
committerDan <danjm.com@gmail.com>2018-04-17 01:08:04 +0800
commit20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6 (patch)
tree2c07e403438905ec0ab758d55b59922fbd8daeba /app/scripts/lib/util.js
parent8fb1237d6425655b88d0bca6ef000d7b77939617 (diff)
downloadtangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.tar
tangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.tar.gz
tangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.tar.bz2
tangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.tar.lz
tangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.tar.xz
tangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.tar.zst
tangerine-wallet-browser-20a075657f9c8133b65ea9cf6e8f1f633bc8a8e6.zip
Documentation for various controllers and libs
Diffstat (limited to 'app/scripts/lib/util.js')
-rw-r--r--app/scripts/lib/util.js40
1 files changed, 40 insertions, 0 deletions
diff --git a/app/scripts/lib/util.js b/app/scripts/lib/util.js
index 6dee9edf0..11565790f 100644
--- a/app/scripts/lib/util.js
+++ b/app/scripts/lib/util.js
@@ -10,11 +10,28 @@ module.exports = {
BnMultiplyByFraction,
}
+/**
+ * Generates an example stack trace
+ *
+ * @returns {string} A stack trace
+ *
+ */
function getStack () {
const stack = new Error('Stack trace generator - not an error').stack
return stack
}
+/**
+ * Checks whether a given balance of ETH, represented as a hex string, is sufficient to pay a value plus a gas fee
+ *
+ * @param {object} txParams Contains data about a transaction
+ * @param {string} txParams.gas The gas for a transaction
+ * @param {string} txParams.gasPrice The price per gas for the transaction
+ * @param {string} txParams.value The value of ETH to send
+ * @param {string} hexBalance A balance of ETH represented as a hex string
+ * @returns {boolean} Whether the balance is greater than or equal to the value plus the value of gas times gasPrice
+ *
+ */
function sufficientBalance (txParams, hexBalance) {
// validate hexBalance is a hex string
assert.equal(typeof hexBalance, 'string', 'sufficientBalance - hexBalance is not a hex string')
@@ -29,14 +46,37 @@ function sufficientBalance (txParams, hexBalance) {
return balance.gte(maxCost)
}
+/**
+ * Converts a BN object to a hex string with a '0x' prefix
+ *
+ * @param {BN} inputBn Description
+ * @returns {string} A hex string
+ *
+ */
function bnToHex (inputBn) {
return ethUtil.addHexPrefix(inputBn.toString(16))
}
+/**
+ * Converts a hex string to a BN object
+ *
+ * @param {string} inputHex A number represented as a hex string
+ * @returns {Object} A BN object
+ *
+ */
function hexToBn (inputHex) {
return new BN(ethUtil.stripHexPrefix(inputHex), 16)
}
+/**
+ * Used to multiply a BN by a fraction
+ *
+ * @param {BN} targetBN The number to multiply by a fraction
+ * @param {number|string} numerator
+ * @param {number|string} denominator
+ * @returns {BN} The product of the multiplication
+ *
+ */
function BnMultiplyByFraction (targetBN, numerator, denominator) {
const numBN = new BN(numerator)
const denomBN = new BN(denominator)