mirror of
https://github.com/tornadocash/tornado-relayer
synced 2024-02-02 15:04:06 +01:00
decimals support
This commit is contained in:
parent
7d12e18283
commit
d063bc266b
20
config.js
20
config.js
@ -17,6 +17,16 @@ module.exports = {
|
|||||||
tokenAddress: '0x6b175474e89094c44da98b954eedeac495271d0f',
|
tokenAddress: '0x6b175474e89094c44da98b954eedeac495271d0f',
|
||||||
decimals: 18
|
decimals: 18
|
||||||
},
|
},
|
||||||
|
usdc: {
|
||||||
|
mixerAddress: {
|
||||||
|
'100': undefined,
|
||||||
|
'500': undefined,
|
||||||
|
'1000': undefined,
|
||||||
|
'5000': undefined
|
||||||
|
},
|
||||||
|
tokenAddress: '0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48',
|
||||||
|
decimals: 6
|
||||||
|
},
|
||||||
eth: {
|
eth: {
|
||||||
mixerAddress: {
|
mixerAddress: {
|
||||||
'0.1': '0x12D66f87A04A9E220743712cE6d9bB1B5616B8Fc',
|
'0.1': '0x12D66f87A04A9E220743712cE6d9bB1B5616B8Fc',
|
||||||
@ -38,6 +48,16 @@ module.exports = {
|
|||||||
tokenAddress: '0x8c158c7e57161dd4d3cb02bf1a3a97fcc78b75fd',
|
tokenAddress: '0x8c158c7e57161dd4d3cb02bf1a3a97fcc78b75fd',
|
||||||
decimals: 18
|
decimals: 18
|
||||||
},
|
},
|
||||||
|
usdc: {
|
||||||
|
mixerAddress: {
|
||||||
|
'100': '0x42d096a9194a18DAA2d2D95a70D8dA80DeFFB645',
|
||||||
|
'500': undefined,
|
||||||
|
'1000': undefined,
|
||||||
|
'5000': undefined
|
||||||
|
},
|
||||||
|
tokenAddress: '0x7f5939049c0D7D7dFC484f64600c9306F79a0D3F',
|
||||||
|
decimals: 6
|
||||||
|
},
|
||||||
eth: {
|
eth: {
|
||||||
mixerAddress: {
|
mixerAddress: {
|
||||||
'0.1': '0x8b3f5393bA08c24cc7ff5A66a832562aAB7bC95f',
|
'0.1': '0x8b3f5393bA08c24cc7ff5A66a832562aAB7bC95f',
|
||||||
|
67
src/utils.js
67
src/utils.js
@ -1,4 +1,4 @@
|
|||||||
const { isHexStrict, toBN, toWei } = require('web3-utils')
|
const { isHexStrict, toBN, toWei, BN } = require('web3-utils')
|
||||||
const { netId, mixers, relayerServiceFee } = require('../config')
|
const { netId, mixers, relayerServiceFee } = require('../config')
|
||||||
|
|
||||||
function isValidProof(proof) {
|
function isValidProof(proof) {
|
||||||
@ -59,9 +59,62 @@ function sleep(ms) {
|
|||||||
return new Promise(resolve => setTimeout(resolve, ms))
|
return new Promise(resolve => setTimeout(resolve, ms))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function fromDecimals(value, decimals) {
|
||||||
|
value = value.toString()
|
||||||
|
let ether = value.toString()
|
||||||
|
const base = new BN('10').pow(new BN(decimals))
|
||||||
|
const baseLength = base.toString(10).length - 1 || 1
|
||||||
|
|
||||||
|
const negative = ether.substring(0, 1) === '-'
|
||||||
|
if (negative) {
|
||||||
|
ether = ether.substring(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ether === '.') {
|
||||||
|
throw new Error('[ethjs-unit] while converting number ' + value + ' to wei, invalid value')
|
||||||
|
}
|
||||||
|
|
||||||
|
// Split it into a whole and fractional part
|
||||||
|
const comps = ether.split('.')
|
||||||
|
if (comps.length > 2) {
|
||||||
|
throw new Error(
|
||||||
|
'[ethjs-unit] while converting number ' + value + ' to wei, too many decimal points'
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
let whole = comps[0]
|
||||||
|
let fraction = comps[1]
|
||||||
|
|
||||||
|
if (!whole) {
|
||||||
|
whole = '0'
|
||||||
|
}
|
||||||
|
if (!fraction) {
|
||||||
|
fraction = '0'
|
||||||
|
}
|
||||||
|
if (fraction.length > baseLength) {
|
||||||
|
throw new Error(
|
||||||
|
'[ethjs-unit] while converting number ' + value + ' to wei, too many decimal places'
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
while (fraction.length < baseLength) {
|
||||||
|
fraction += '0'
|
||||||
|
}
|
||||||
|
|
||||||
|
whole = new BN(whole)
|
||||||
|
fraction = new BN(fraction)
|
||||||
|
let wei = whole.mul(base).add(fraction)
|
||||||
|
|
||||||
|
if (negative) {
|
||||||
|
wei = wei.mul(negative)
|
||||||
|
}
|
||||||
|
|
||||||
|
return new BN(wei.toString(10), 10)
|
||||||
|
}
|
||||||
|
|
||||||
function isEnoughFee({ gas, gasPrices, currency, amount, refund, ethPrices, fee }) {
|
function isEnoughFee({ gas, gasPrices, currency, amount, refund, ethPrices, fee }) {
|
||||||
// TODO tokens can have less then 18 decimals
|
const { decimals } = mixers[`netId${netId}`][currency]
|
||||||
const feePercent = toBN(toWei(amount)).mul(toBN(relayerServiceFee * 10)).div(toBN('1000'))
|
const feePercent = toBN(fromDecimals(amount, decimals)).mul(toBN(relayerServiceFee * 10)).div(toBN('1000'))
|
||||||
const expense = toBN(toWei(gasPrices.fast.toString(), 'gwei')).mul(toBN(gas))
|
const expense = toBN(toWei(gasPrices.fast.toString(), 'gwei')).mul(toBN(gas))
|
||||||
let desiredFee
|
let desiredFee
|
||||||
switch (currency) {
|
switch (currency) {
|
||||||
@ -69,16 +122,16 @@ function isEnoughFee({ gas, gasPrices, currency, amount, refund, ethPrices, fee
|
|||||||
desiredFee = expense.add(feePercent)
|
desiredFee = expense.add(feePercent)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
case 'dai': {
|
default: {
|
||||||
desiredFee =
|
desiredFee =
|
||||||
expense.add(refund)
|
expense.add(refund)
|
||||||
.mul(toBN(10 ** 18))
|
.mul(toBN(10 ** decimals))
|
||||||
.div(toBN(ethPrices.dai))
|
.div(toBN(ethPrices[currency]))
|
||||||
desiredFee = desiredFee.add(feePercent)
|
desiredFee = desiredFee.add(feePercent)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
console.log('desired fee, feePercent', desiredFee.toString(), feePercent.toString())
|
console.log('sent fee, desired fee, feePercent', fee.toString(), desiredFee.toString(), feePercent.toString())
|
||||||
if (fee.lt(desiredFee)) {
|
if (fee.lt(desiredFee)) {
|
||||||
return { isEnough: false, reason: 'Not enough fee' }
|
return { isEnough: false, reason: 'Not enough fee' }
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user