diff options
author | Leonid Logvinov <logvinov.leon@gmail.com> | 2017-12-11 19:43:19 +0800 |
---|---|---|
committer | Leonid Logvinov <logvinov.leon@gmail.com> | 2017-12-11 19:43:19 +0800 |
commit | a14424ae5f45784db5e75c2d6a9098dc96914c9e (patch) | |
tree | e0cc054713cc7fff81269c4065883629f117a590 /packages/utils/src | |
parent | f1e7ea118b0c8c9a9a013b09d0e63bdd3694b21a (diff) | |
download | dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.tar dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.tar.gz dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.tar.bz2 dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.tar.lz dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.tar.xz dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.tar.zst dexon-0x-contracts-a14424ae5f45784db5e75c2d6a9098dc96914c9e.zip |
Move isAddress to shared utils and remove all dependencies on ethereum-address
Diffstat (limited to 'packages/utils/src')
-rw-r--r-- | packages/utils/src/address_utils.ts | 34 | ||||
-rw-r--r-- | packages/utils/src/index.ts | 1 |
2 files changed, 35 insertions, 0 deletions
diff --git a/packages/utils/src/address_utils.ts b/packages/utils/src/address_utils.ts new file mode 100644 index 000000000..bdbcd3a89 --- /dev/null +++ b/packages/utils/src/address_utils.ts @@ -0,0 +1,34 @@ +import * as jsSHA3 from 'js-sha3'; + +const BASIC_ADDRESS_REGEX = /^(0x)?[0-9a-f]{40}$/i; +const SAME_CASE_ADDRESS_REGEX = /^(0x)?([0-9a-f]{40}|[0-9A-F]{40})$/; + +export const addressUtils = { + isChecksumAddress(address: string): boolean { + // Check each case + const unprefixedAddress = address.replace('0x', ''); + const addressHash = jsSHA3.keccak256(unprefixedAddress.toLowerCase()); + + for (let i = 0; i < 40; i++) { + // The nth letter should be uppercase if the nth digit of casemap is 1 + if ((parseInt(addressHash[i], 16) > 7 && unprefixedAddress[i].toUpperCase() !== unprefixedAddress[i]) || + (parseInt(addressHash[i], 16) <= 7 && unprefixedAddress[i].toLowerCase() !== unprefixedAddress[i])) { + return false; + } + } + return true; + }, + isAddress(address: string): boolean { + if (!BASIC_ADDRESS_REGEX.test(address)) { + // Check if it has the basic requirements of an address + return false; + } else if (SAME_CASE_ADDRESS_REGEX.test(address)) { + // If it's all small caps or all all caps, return true + return true; + } else { + // Otherwise check each case + const isValidChecksummedAddress = addressUtils.isChecksumAddress(address); + return isValidChecksummedAddress; + } + }, +}; diff --git a/packages/utils/src/index.ts b/packages/utils/src/index.ts index a61f04ad2..edfd192b2 100644 --- a/packages/utils/src/index.ts +++ b/packages/utils/src/index.ts @@ -1 +1,2 @@ export {promisify} from './promisify'; +export {addressUtils} from './address_utils'; |