mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
remove generating blocked accounts and use a config file instead
This commit is contained in:
parent
3e489ea165
commit
1dda0c6469
@ -160,8 +160,8 @@ class TransactionController extends EventEmitter {
|
||||
this.emit('newUnapprovedTx', txMeta)
|
||||
|
||||
try {
|
||||
// check whether recipient account is public
|
||||
await recipientBlacklistChecker.checkAccount(txMeta.metamaskNetworkId, normalizedTxParams.to)
|
||||
// check whether recipient account is blacklisted
|
||||
recipientBlacklistChecker.checkAccount(txMeta.metamaskNetworkId, normalizedTxParams.to)
|
||||
// add default tx params
|
||||
txMeta = await this.addTxGasDefaults(txMeta)
|
||||
} catch (error) {
|
||||
|
@ -1,4 +1,4 @@
|
||||
const KeyringController = require('eth-keyring-controller')
|
||||
const Config = require('./recipient-blacklist-config.json')
|
||||
|
||||
/** @module*/
|
||||
module.exports = {
|
||||
@ -10,27 +10,15 @@ module.exports = {
|
||||
@param networkId {number}
|
||||
@param account {string}
|
||||
*/
|
||||
async function checkAccount (networkId, account) {
|
||||
function checkAccount (networkId, account) {
|
||||
|
||||
const mainnetId = 1
|
||||
if (networkId !== mainnetId) {
|
||||
return
|
||||
}
|
||||
|
||||
const damnedMnemonic = 'candy maple cake sugar pudding cream honey rich smooth crumble sweet treat'
|
||||
const keyringController = new KeyringController({})
|
||||
const Keyring = keyringController.getKeyringClassForType('HD Key Tree')
|
||||
const opts = {
|
||||
mnemonic: damnedMnemonic,
|
||||
numberOfAccounts: 10,
|
||||
}
|
||||
|
||||
const accountToCheck = account.toLowerCase()
|
||||
const keyring = new Keyring(opts)
|
||||
const damnedAccounts = await keyring.getAccounts()
|
||||
for (let i = 0; i < damnedAccounts.length; i++) {
|
||||
if (damnedAccounts[i].toLowerCase() === accountToCheck) {
|
||||
throw new Error('Recipient is a public account')
|
||||
}
|
||||
if (Config.blacklist.includes(accountToCheck)) {
|
||||
throw new Error('Recipient is a public account')
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,14 @@
|
||||
{
|
||||
"blacklist": [
|
||||
"0x627306090abab3a6e1400e9345bc60c78a8bef57",
|
||||
"0xf17f52151ebef6c7334fad080c5704d77216b732",
|
||||
"0xc5fdf4076b8f3a5357c5e395ab970b5b54098fef",
|
||||
"0x821aea9a577a9b44299b9c15c88cf3087f3b5544",
|
||||
"0x0d1d4e623d10f9fba5db95830f7d3839406c6af2",
|
||||
"0x2932b7a2355d6fecc4b5c0b6bd44cc31df247a2e",
|
||||
"0x2191ef87e392377ec08e7c08eb105ef5448eced5",
|
||||
"0x0f4f2ac550a1b4e2280d04c21cea7ebd822934b5",
|
||||
"0x6330a553fc93768f612722bb8c2ec78ac90b3bbc",
|
||||
"0x5aeda56215b167893e80b4fe645ba6d5bab767de"
|
||||
]
|
||||
}
|
@ -25,39 +25,38 @@ describe('Recipient Blacklist Checker', function () {
|
||||
})
|
||||
|
||||
describe('#checkAccount', function () {
|
||||
it('does not fail on test networks', async function () {
|
||||
it('does not fail on test networks', function () {
|
||||
let callCount = 0
|
||||
const networks = [ROPSTEN_CODE, RINKEYBY_CODE, KOVAN_CODE]
|
||||
for (let networkId in networks) {
|
||||
await Promise.all(publicAccounts.map(async (account) => {
|
||||
await recipientBlackListChecker.checkAccount(networkId, account)
|
||||
callCount++
|
||||
publicAccounts.forEach((account) => {
|
||||
recipientBlackListChecker.checkAccount(networkId, account)
|
||||
callCount++
|
||||
})
|
||||
)
|
||||
}
|
||||
assert.equal(callCount, 30)
|
||||
})
|
||||
|
||||
it('fails on mainnet', async function () {
|
||||
it('fails on mainnet', function () {
|
||||
const mainnetId = 1
|
||||
let callCount = 0
|
||||
await Promise.all(publicAccounts.map(async (account) => {
|
||||
publicAccounts.forEach((account) => {
|
||||
try {
|
||||
await recipientBlackListChecker.checkAccount(mainnetId, account)
|
||||
recipientBlackListChecker.checkAccount(mainnetId, account)
|
||||
assert.fail('function should have thrown an error')
|
||||
} catch (err) {
|
||||
assert.equal(err.message, 'Recipient is a public account')
|
||||
}
|
||||
callCount++
|
||||
}))
|
||||
})
|
||||
assert.equal(callCount, 10)
|
||||
})
|
||||
|
||||
it('fails for public account - uppercase', async function () {
|
||||
it('fails for public account - uppercase', function () {
|
||||
const mainnetId = 1
|
||||
const publicAccount = '0X0D1D4E623D10F9FBA5DB95830F7D3839406C6AF2'
|
||||
try {
|
||||
await recipientBlackListChecker.checkAccount(mainnetId, publicAccount)
|
||||
recipientBlackListChecker.checkAccount(mainnetId, publicAccount)
|
||||
assert.fail('function should have thrown an error')
|
||||
} catch (err) {
|
||||
assert.equal(err.message, 'Recipient is a public account')
|
||||
|
Loading…
x
Reference in New Issue
Block a user