mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Use eth-contract-metadata data if the token symbol or decimals fail on retrieval
This commit is contained in:
parent
25eac2334b
commit
7924dbc0c9
@ -1,8 +1,99 @@
|
|||||||
const log = require('loglevel')
|
const log = require('loglevel')
|
||||||
const util = require('./util')
|
const util = require('./util')
|
||||||
const BigNumber = require('bignumber.js')
|
const BigNumber = require('bignumber.js')
|
||||||
|
import contractMap from 'eth-contract-metadata'
|
||||||
|
|
||||||
function tokenInfoGetter () {
|
const casedContractMap = Object.keys(contractMap).reduce((acc, base) => {
|
||||||
|
return {
|
||||||
|
...acc,
|
||||||
|
[base.toLowerCase()]: contractMap[base],
|
||||||
|
}
|
||||||
|
}, {})
|
||||||
|
|
||||||
|
const DEFAULT_SYMBOL = ''
|
||||||
|
const DEFAULT_DECIMALS = '0'
|
||||||
|
|
||||||
|
async function getSymbolFromContract (tokenAddress) {
|
||||||
|
const token = util.getContractAtAddress(tokenAddress)
|
||||||
|
|
||||||
|
try {
|
||||||
|
const result = await token.symbol()
|
||||||
|
return result[0]
|
||||||
|
} catch (error) {
|
||||||
|
log.warn(`symbol() call for token at address ${tokenAddress} resulted in error:`, error)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getDecimalsFromContract (tokenAddress) {
|
||||||
|
const token = util.getContractAtAddress(tokenAddress)
|
||||||
|
|
||||||
|
try {
|
||||||
|
const result = await token.decimals()
|
||||||
|
const decimalsBN = result[0]
|
||||||
|
return decimalsBN && decimalsBN.toString()
|
||||||
|
} catch (error) {
|
||||||
|
log.warn(`decimals() call for token at address ${tokenAddress} resulted in error:`, error)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getContractMetadata (tokenAddress) {
|
||||||
|
return tokenAddress && casedContractMap[tokenAddress.toLowerCase()]
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getSymbol (tokenAddress) {
|
||||||
|
let symbol = await getSymbolFromContract(tokenAddress)
|
||||||
|
|
||||||
|
if (!symbol) {
|
||||||
|
const contractMetadataInfo = getContractMetadata(tokenAddress)
|
||||||
|
|
||||||
|
if (contractMetadataInfo) {
|
||||||
|
symbol = contractMetadataInfo.symbol
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return symbol
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getDecimals (tokenAddress) {
|
||||||
|
let decimals = await getDecimalsFromContract(tokenAddress)
|
||||||
|
|
||||||
|
if (!decimals || decimals === '0') {
|
||||||
|
const contractMetadataInfo = getContractMetadata(tokenAddress)
|
||||||
|
|
||||||
|
if (contractMetadataInfo) {
|
||||||
|
decimals = contractMetadataInfo.decimals
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return decimals
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function getSymbolAndDecimals (tokenAddress, existingTokens = []) {
|
||||||
|
const existingToken = existingTokens.find(({ address }) => tokenAddress === address)
|
||||||
|
|
||||||
|
if (existingToken) {
|
||||||
|
return {
|
||||||
|
symbol: existingToken.symbol,
|
||||||
|
decimals: existingToken.decimals,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let symbol, decimals
|
||||||
|
|
||||||
|
try {
|
||||||
|
symbol = await getSymbol(tokenAddress)
|
||||||
|
decimals = await getDecimals(tokenAddress)
|
||||||
|
} catch (error) {
|
||||||
|
log.warn(`symbol() and decimal() calls for token at address ${tokenAddress} resulted in error:`, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
symbol: symbol || DEFAULT_SYMBOL,
|
||||||
|
decimals: decimals || DEFAULT_DECIMALS,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function tokenInfoGetter () {
|
||||||
const tokens = {}
|
const tokens = {}
|
||||||
|
|
||||||
return async (address) => {
|
return async (address) => {
|
||||||
@ -16,40 +107,7 @@ function tokenInfoGetter () {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getSymbolAndDecimals (tokenAddress, existingTokens = []) {
|
export function calcTokenAmount (value, decimals) {
|
||||||
const existingToken = existingTokens.find(({ address }) => tokenAddress === address)
|
|
||||||
if (existingToken) {
|
|
||||||
return existingToken
|
|
||||||
}
|
|
||||||
|
|
||||||
let result = []
|
|
||||||
try {
|
|
||||||
const token = util.getContractAtAddress(tokenAddress)
|
|
||||||
|
|
||||||
result = await Promise.all([
|
|
||||||
token.symbol(),
|
|
||||||
token.decimals(),
|
|
||||||
])
|
|
||||||
} catch (err) {
|
|
||||||
log.warn(`symbol() and decimal() calls for token at address ${tokenAddress} resulted in error:`, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
const [ symbol = [], decimals = [] ] = result
|
|
||||||
|
|
||||||
return {
|
|
||||||
symbol: symbol[0] || null,
|
|
||||||
decimals: decimals[0] && decimals[0].toString() || null,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function calcTokenAmount (value, decimals) {
|
|
||||||
const multiplier = Math.pow(10, Number(decimals || 0))
|
const multiplier = Math.pow(10, Number(decimals || 0))
|
||||||
return new BigNumber(String(value)).div(multiplier).toNumber()
|
return new BigNumber(String(value)).div(multiplier).toNumber()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
tokenInfoGetter,
|
|
||||||
calcTokenAmount,
|
|
||||||
getSymbolAndDecimals,
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user