aboutsummaryrefslogtreecommitdiffstats
path: root/packages/assert/src
diff options
context:
space:
mode:
authorLeonid Logvinov <logvinov.leon@gmail.com>2017-12-08 18:58:33 +0800
committerLeonid Logvinov <logvinov.leon@gmail.com>2017-12-11 19:21:44 +0800
commitf1e7ea118b0c8c9a9a013b09d0e63bdd3694b21a (patch)
tree4816997b033912fd517a77dc2149bf0efac395a3 /packages/assert/src
parenta6f97181310c9acba176b2a28ffba1ca7d53727d (diff)
downloaddexon-0x-contracts-f1e7ea118b0c8c9a9a013b09d0e63bdd3694b21a.tar.gz
dexon-0x-contracts-f1e7ea118b0c8c9a9a013b09d0e63bdd3694b21a.tar.zst
dexon-0x-contracts-f1e7ea118b0c8c9a9a013b09d0e63bdd3694b21a.zip
Remove ethereum-address dependency and add this logic to the repo
Diffstat (limited to 'packages/assert/src')
-rw-r--r--packages/assert/src/address_utils.ts34
-rw-r--r--packages/assert/src/index.ts7
2 files changed, 38 insertions, 3 deletions
diff --git a/packages/assert/src/address_utils.ts b/packages/assert/src/address_utils.ts
new file mode 100644
index 000000000..bdbcd3a89
--- /dev/null
+++ b/packages/assert/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/assert/src/index.ts b/packages/assert/src/index.ts
index 92bcf6f03..94900074a 100644
--- a/packages/assert/src/index.ts
+++ b/packages/assert/src/index.ts
@@ -3,10 +3,11 @@ import {
SchemaValidator,
} from '@0xproject/json-schemas';
import BigNumber from 'bignumber.js';
-import * as ethereum_address from 'ethereum-address';
import * as _ from 'lodash';
import * as validUrl from 'valid-url';
+import {addressUtils} from './address_utils';
+
const HEX_REGEX = /^0x[0-9A-F]*$/i;
export const assert = {
@@ -35,9 +36,9 @@ export const assert = {
this.typeAssertionMessage(variableName, 'HexString', value));
},
isETHAddressHex(variableName: string, value: string): void {
- this.assert(ethereum_address.isAddress(value), this.typeAssertionMessage(variableName, 'ETHAddressHex', value));
+ this.assert(addressUtils.isAddress(value), this.typeAssertionMessage(variableName, 'ETHAddressHex', value));
this.assert(
- ethereum_address.isAddress(value) && value.toLowerCase() === value,
+ addressUtils.isAddress(value) && value.toLowerCase() === value,
`Checksummed addresses are not supported. Convert ${variableName} to lower case before passing`,
);
},