aboutsummaryrefslogtreecommitdiffstats
path: root/ui/app/helpers
diff options
context:
space:
mode:
authorDan J Miller <danjm.com@gmail.com>2019-04-17 03:37:47 +0800
committerGitHub <noreply@github.com>2019-04-17 03:37:47 +0800
commit09f2a2a5476c4c119c7294f496f6590156d8d07a (patch)
tree53425045a54f29863bf4db7fbc7b0b50b4925771 /ui/app/helpers
parent92c03bdff2281b5901151ad0840b83e40dad73bc (diff)
downloadtangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.tar
tangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.tar.gz
tangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.tar.bz2
tangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.tar.lz
tangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.tar.xz
tangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.tar.zst
tangerine-wallet-browser-09f2a2a5476c4c119c7294f496f6590156d8d07a.zip
Adds 4byte registry fallback to getMethodData() (#6435)
* Get contract method data from 4byte if we can't get it from eth-method-registry * Clarify token method name fallback code in getMethodData * Bugfix: don't attempt to translate falsy actionKeys in confirm-transaction-base.component.js * Rewrite getMethodFrom4Byte with async-await * Call four byte and method-registry requests in parallel in getMethodData()
Diffstat (limited to 'ui/app/helpers')
-rw-r--r--ui/app/helpers/utils/transactions.util.js30
1 files changed, 27 insertions, 3 deletions
diff --git a/ui/app/helpers/utils/transactions.util.js b/ui/app/helpers/utils/transactions.util.js
index cb6c9536c..8d96b1487 100644
--- a/ui/app/helpers/utils/transactions.util.js
+++ b/ui/app/helpers/utils/transactions.util.js
@@ -30,6 +30,21 @@ export function getTokenData (data = '') {
return abiDecoder.decodeMethod(data)
}
+async function getMethodFrom4Byte (fourBytePrefix) {
+ const fourByteResponse = (await fetch(`https://www.4byte.directory/api/v1/signatures/?hex_signature=${fourBytePrefix}`, {
+ referrerPolicy: 'no-referrer-when-downgrade',
+ body: null,
+ method: 'GET',
+ mode: 'cors',
+ })).json()
+
+ if (fourByteResponse.count === 1) {
+ return fourByteResponse.results[0].text_signature
+ } else {
+ return null
+ }
+}
+
const registry = new MethodRegistry({ provider: global.ethereumProvider })
/**
@@ -43,7 +58,16 @@ const registry = new MethodRegistry({ provider: global.ethereumProvider })
const fourBytePrefix = prefixedData.slice(0, 10)
try {
- const sig = await registry.lookup(fourBytePrefix)
+ const fourByteSig = getMethodFrom4Byte(fourBytePrefix).catch((e) => {
+ log.error(e)
+ return null
+ })
+
+ let sig = await registry.lookup(fourBytePrefix)
+
+ if (!sig) {
+ sig = await fourByteSig
+ }
if (!sig) {
return {}
@@ -57,8 +81,8 @@ const registry = new MethodRegistry({ provider: global.ethereumProvider })
}
} catch (error) {
log.error(error)
- const contractData = getTokenData(data)
- const { name } = contractData || {}
+ const tokenData = getTokenData(data)
+ const { name } = tokenData || {}
return { name }
}