diff options
author | kumavis <kumavis@users.noreply.github.com> | 2017-03-08 10:09:05 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-08 10:09:05 +0800 |
commit | dba261db255d48f936eb2955bcb2cdb712768dd4 (patch) | |
tree | dbcfabf5934fd0cf5bd27a0388d5bddef9c1b89b /app | |
parent | 719be93f97570b758450be8c70b78cda08f3d07a (diff) | |
parent | f0a35cefd3e07dfb40a8cfb0c5e003a98725d23e (diff) | |
download | tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.tar tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.tar.gz tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.tar.bz2 tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.tar.lz tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.tar.xz tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.tar.zst tangerine-wallet-browser-dba261db255d48f936eb2955bcb2cdb712768dd4.zip |
Merge pull request #1185 from MetaMask/i#1032
Fix issue where account import allows for duplicates
Diffstat (limited to 'app')
-rw-r--r-- | app/scripts/keyring-controller.js | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/app/scripts/keyring-controller.js b/app/scripts/keyring-controller.js index e1b1c4335..7669b9f8f 100644 --- a/app/scripts/keyring-controller.js +++ b/app/scripts/keyring-controller.js @@ -164,8 +164,11 @@ class KeyringController extends EventEmitter { return keyring.getAccounts() }) .then((accounts) => { + return this.checkForDuplicate(type, accounts) + }) + .then((checkedAccounts) => { this.keyrings.push(keyring) - return this.setupAccounts(accounts) + return this.setupAccounts(checkedAccounts) }) .then(() => this.persistAllKeyrings()) .then(() => this.fullUpdate()) @@ -175,6 +178,24 @@ class KeyringController extends EventEmitter { }) } + // For now just checks for simple key pairs + // but in the future + // should possibly add HD and other types + // + checkForDuplicate (type, newAccount) { + return this.getAccounts() + .then((accounts) => { + switch (type) { + case 'Simple Key Pair': + let isNotIncluded = !accounts.find((key) => key === newAccount[0] || key === ethUtil.stripHexPrefix(newAccount[0])) + return (isNotIncluded) ? Promise.resolve(newAccount) : Promise.reject(new Error('The account your are trying to import is a duplicate')) + default: + return Promise.resolve(newAccount) + } + }) + } + + // Add New Account // @number keyRingNum // |