multichain-address-validator 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +10 -0
- package/.travis.yml +11 -0
- package/.vscode/launch.json +23 -0
- package/LICENSE +21 -0
- package/README.md +87 -0
- package/config/esbuild.inject.js +1 -0
- package/config/esbuild.ts +14 -0
- package/dist/chain-validators.d.ts +2 -0
- package/dist/chain-validators.js +98 -0
- package/dist/crypto/base32.d.ts +5 -0
- package/dist/crypto/base32.js +64 -0
- package/dist/crypto/base58.d.ts +4 -0
- package/dist/crypto/base58.js +42 -0
- package/dist/crypto/bech32.d.ts +17 -0
- package/dist/crypto/bech32.js +124 -0
- package/dist/crypto/biginteger.d.ts +57 -0
- package/dist/crypto/biginteger.js +1311 -0
- package/dist/crypto/blake256.d.ts +22 -0
- package/dist/crypto/blake256.js +169 -0
- package/dist/crypto/blake2b.d.ts +13 -0
- package/dist/crypto/blake2b.js +242 -0
- package/dist/crypto/cnBase58.d.ts +7 -0
- package/dist/crypto/cnBase58.js +209 -0
- package/dist/crypto/segwit_addr.d.ts +12 -0
- package/dist/crypto/segwit_addr.js +102 -0
- package/dist/crypto/utils.d.ts +26 -0
- package/dist/crypto/utils.js +123 -0
- package/dist/helpers.d.ts +2 -0
- package/dist/helpers.js +5 -0
- package/dist/multichain-address-validator.bundle.min.js +17 -0
- package/dist/multichain-address-validator.d.ts +2 -0
- package/dist/multichain-address-validator.js +8 -0
- package/dist/types.d.ts +15 -0
- package/dist/types.js +5 -0
- package/dist/validators/algorand_validator.d.ts +5 -0
- package/dist/validators/algorand_validator.js +23 -0
- package/dist/validators/base58_validator.d.ts +4 -0
- package/dist/validators/base58_validator.js +31 -0
- package/dist/validators/bch_validator.d.ts +13 -0
- package/dist/validators/bch_validator.js +50 -0
- package/dist/validators/bip173_validator.d.ts +7 -0
- package/dist/validators/bip173_validator.js +12 -0
- package/dist/validators/bitcoin_validator.d.ts +12 -0
- package/dist/validators/bitcoin_validator.js +68 -0
- package/dist/validators/cardano_validator.d.ts +5 -0
- package/dist/validators/cardano_validator.js +41 -0
- package/dist/validators/eos_validator.d.ts +5 -0
- package/dist/validators/eos_validator.js +10 -0
- package/dist/validators/ethereum_validator.d.ts +6 -0
- package/dist/validators/ethereum_validator.js +30 -0
- package/dist/validators/index.d.ts +16 -0
- package/dist/validators/index.js +16 -0
- package/dist/validators/monero_validator.d.ts +5 -0
- package/dist/validators/monero_validator.js +58 -0
- package/dist/validators/nano_validator.d.ts +6 -0
- package/dist/validators/nano_validator.js +23 -0
- package/dist/validators/nem_validator.d.ts +5 -0
- package/dist/validators/nem_validator.js +14 -0
- package/dist/validators/polkadot_validator.d.ts +5 -0
- package/dist/validators/polkadot_validator.js +49 -0
- package/dist/validators/ripple_validator.d.ts +10 -0
- package/dist/validators/ripple_validator.js +26 -0
- package/dist/validators/sia_validator.d.ts +5 -0
- package/dist/validators/sia_validator.js +27 -0
- package/dist/validators/solana_validator.d.ts +5 -0
- package/dist/validators/solana_validator.js +10 -0
- package/dist/validators/tezos_validator.d.ts +5 -0
- package/dist/validators/tezos_validator.js +30 -0
- package/dist/validators/tron_validator.d.ts +8 -0
- package/dist/validators/tron_validator.js +45 -0
- package/dist/validators/xlm_validator.d.ts +6 -0
- package/dist/validators/xlm_validator.js +32 -0
- package/index.html +12 -0
- package/package.json +353 -0
- package/src/chain-validators.ts +131 -0
- package/src/crypto/base32.ts +66 -0
- package/src/crypto/base58.ts +46 -0
- package/src/crypto/bech32.js +132 -0
- package/src/crypto/biginteger.js +1426 -0
- package/src/crypto/blake256.js +186 -0
- package/src/crypto/blake2b.js +276 -0
- package/src/crypto/cnBase58.js +226 -0
- package/src/crypto/segwit_addr.js +112 -0
- package/src/crypto/utils.ts +133 -0
- package/src/helpers.ts +7 -0
- package/src/multichain-address-validator.ts +11 -0
- package/src/types.ts +18 -0
- package/src/validators/algorand_validator.ts +28 -0
- package/src/validators/base58_validator.ts +32 -0
- package/src/validators/bch_validator.ts +66 -0
- package/src/validators/bip173_validator.ts +19 -0
- package/src/validators/bitcoin_validator.ts +94 -0
- package/src/validators/cardano_validator.ts +50 -0
- package/src/validators/eos_validator.ts +13 -0
- package/src/validators/ethereum_validator.ts +37 -0
- package/src/validators/index.ts +16 -0
- package/src/validators/monero_validator.ts +72 -0
- package/src/validators/nano_validator.ts +32 -0
- package/src/validators/nem_validator.ts +18 -0
- package/src/validators/polkadot_validator.ts +57 -0
- package/src/validators/ripple_validator.ts +36 -0
- package/src/validators/sia_validator.ts +33 -0
- package/src/validators/solana_validator.ts +12 -0
- package/src/validators/tezos_validator.ts +36 -0
- package/src/validators/tron_validator.ts +59 -0
- package/src/validators/xlm_validator.ts +42 -0
- package/test/addresses/addresses.ts +45 -0
- package/test/addresses/algorand.json +6 -0
- package/test/addresses/bch-testnet.json +4 -0
- package/test/addresses/bch.json +12 -0
- package/test/addresses/btc-testnet.json +6 -0
- package/test/addresses/btc.json +14 -0
- package/test/addresses/cardano.json +8 -0
- package/test/addresses/doge.json +7 -0
- package/test/addresses/eos.json +6 -0
- package/test/addresses/evm.json +21 -0
- package/test/addresses/invalid.json +15 -0
- package/test/addresses/ltc-testnet.json +7 -0
- package/test/addresses/ltc.json +9 -0
- package/test/addresses/monero.json +7 -0
- package/test/addresses/nano.json +12 -0
- package/test/addresses/nem.json +4 -0
- package/test/addresses/polkadot.json +8 -0
- package/test/addresses/ripple.json +11 -0
- package/test/addresses/sia.json +6 -0
- package/test/addresses/solana.json +8 -0
- package/test/addresses/tezos.json +9 -0
- package/test/addresses/tron.json +6 -0
- package/test/addresses/xlm.json +12 -0
- package/test/multichain-address-validator.test.ts +1589 -0
- package/tsconfig.json +23 -0
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
2
|
+
import {Address, NetworkType} from '../types.js'
|
|
3
|
+
import {getAddress} from '../helpers.js'
|
|
4
|
+
import cnBase58 from '../crypto/cnBase58.js'
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
const addressRegTest = new RegExp(
|
|
8
|
+
'^[123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz]{95}$'
|
|
9
|
+
)
|
|
10
|
+
const integratedAddressRegTest = new RegExp(
|
|
11
|
+
'^[123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz]{106}$'
|
|
12
|
+
)
|
|
13
|
+
|
|
14
|
+
const types = {
|
|
15
|
+
addressTypes: {mainnet: ['18', '42'], testnet: ['53', '63'], stagenet: ['24']},
|
|
16
|
+
iAddressTypes: {mainnet: ['19'], testnet: ['54'], stagenet: ['25']},
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
function validateNetwork(decoded: string, networkType: NetworkType, addressType: 'standard' | 'integrated') {
|
|
20
|
+
const addressTypes = addressType === 'integrated'
|
|
21
|
+
? types.iAddressTypes[networkType]
|
|
22
|
+
: types.addressTypes[networkType]
|
|
23
|
+
|
|
24
|
+
const at = parseInt(decoded.substr(0, 2), 16).toString()
|
|
25
|
+
|
|
26
|
+
switch (networkType) {
|
|
27
|
+
case 'mainnet':
|
|
28
|
+
return addressTypes.indexOf(at) >= 0
|
|
29
|
+
case 'testnet':
|
|
30
|
+
return addressTypes.indexOf(at) >= 0
|
|
31
|
+
// case 'stagenet':
|
|
32
|
+
// return network.stagenet.indexOf(at) >= 0
|
|
33
|
+
// case 'both':
|
|
34
|
+
// return network.prod.indexOf(at) >= 0 || network.testnet.indexOf(at) >= 0 || network.stagenet.indexOf(at) >= 0
|
|
35
|
+
default:
|
|
36
|
+
return false
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function hextobin(hex: string) {
|
|
41
|
+
if (hex.length % 2 !== 0) return null
|
|
42
|
+
const res = new Uint8Array(hex.length / 2)
|
|
43
|
+
for (let i = 0; i < hex.length / 2; ++i) {
|
|
44
|
+
res[i] = parseInt(hex.slice(i * 2, i * 2 + 2), 16)
|
|
45
|
+
}
|
|
46
|
+
return res
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
export default (networkType: NetworkType) => ({
|
|
51
|
+
isValidAddress(address: Address) {
|
|
52
|
+
const addr = getAddress(address)
|
|
53
|
+
let addressType: 'standard' | 'integrated' = 'standard'
|
|
54
|
+
if (!addressRegTest.test(addr)) {
|
|
55
|
+
if (integratedAddressRegTest.test(addr)) {
|
|
56
|
+
addressType = 'integrated'
|
|
57
|
+
} else {
|
|
58
|
+
return false
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
const decodedAddrStr = cnBase58.decode(addr)
|
|
63
|
+
if (!decodedAddrStr) return false
|
|
64
|
+
|
|
65
|
+
if (!validateNetwork(decodedAddrStr, networkType, addressType)) return false
|
|
66
|
+
|
|
67
|
+
const addrChecksum = decodedAddrStr.slice(-8)
|
|
68
|
+
const hashChecksum = cryptoUtils.keccak256Checksum(hextobin(decodedAddrStr.slice(0, -8)))
|
|
69
|
+
|
|
70
|
+
return addrChecksum === hashChecksum
|
|
71
|
+
}
|
|
72
|
+
})
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import baseX from 'base-x'
|
|
2
|
+
|
|
3
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
4
|
+
import {Address} from '../types.js'
|
|
5
|
+
import {getAddress} from '../helpers.js'
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
const ALLOWED_CHARS = '13456789abcdefghijkmnopqrstuwxyz';
|
|
9
|
+
|
|
10
|
+
const codec = baseX(ALLOWED_CHARS);
|
|
11
|
+
// https://github.com/nanocurrency/raiblocks/wiki/Accounts,-Keys,-Seeds,-and-Wallet-Identifiers
|
|
12
|
+
const regexp = new RegExp('^(xrb|nano)_([' + ALLOWED_CHARS + ']{60})$');
|
|
13
|
+
|
|
14
|
+
export default {
|
|
15
|
+
isValidAddress(address: Address) {
|
|
16
|
+
const addr = getAddress(address)
|
|
17
|
+
if (regexp.test(addr)) {
|
|
18
|
+
return this.verifyChecksum(addr);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
return false;
|
|
22
|
+
},
|
|
23
|
+
|
|
24
|
+
verifyChecksum: function (address: string) {
|
|
25
|
+
const bytes = codec.decode(regexp.exec(address)[2]).slice(-37);
|
|
26
|
+
// https://github.com/nanocurrency/raiblocks/blob/master/rai/lib/numbers.cpp#L73
|
|
27
|
+
const computedChecksum = cryptoUtils.blake2b(cryptoUtils.toHex(bytes.slice(0, -5)), 5);
|
|
28
|
+
const checksum = cryptoUtils.toHex(bytes.slice(-5).reverse());
|
|
29
|
+
|
|
30
|
+
return computedChecksum === checksum
|
|
31
|
+
}
|
|
32
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import {Buffer} from 'buffer'
|
|
2
|
+
|
|
3
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
4
|
+
import {Address} from '../types.js'
|
|
5
|
+
import {getAddress} from '../helpers.js'
|
|
6
|
+
|
|
7
|
+
export default {
|
|
8
|
+
isValidAddress(address: Address) {
|
|
9
|
+
const addr = getAddress(address).toString().toUpperCase().replace(/-/g, '');
|
|
10
|
+
if (!address || addr.length !== 40) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
const decoded = cryptoUtils.toHex(cryptoUtils.base32.b32decode(addr));
|
|
14
|
+
const stepThreeChecksum = cryptoUtils.keccak256Checksum(Buffer.from(decoded.slice(0, 42), 'hex'));
|
|
15
|
+
|
|
16
|
+
return stepThreeChecksum === decoded.slice(42);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
2
|
+
import {Address} from '../types.js'
|
|
3
|
+
import {getAddress} from '../helpers.js'
|
|
4
|
+
|
|
5
|
+
// from https://github.com/paritytech/substrate/wiki/External-Address-Format-(SS58)
|
|
6
|
+
const addressFormats = [
|
|
7
|
+
{addressLength: 3, accountIndexLength: 1, checkSumLength: 1},
|
|
8
|
+
{addressLength: 4, accountIndexLength: 2, checkSumLength: 1},
|
|
9
|
+
{addressLength: 5, accountIndexLength: 2, checkSumLength: 2},
|
|
10
|
+
{addressLength: 6, accountIndexLength: 4, checkSumLength: 1},
|
|
11
|
+
{addressLength: 7, accountIndexLength: 4, checkSumLength: 2},
|
|
12
|
+
{addressLength: 8, accountIndexLength: 4, checkSumLength: 3},
|
|
13
|
+
{addressLength: 9, accountIndexLength: 4, checkSumLength: 4},
|
|
14
|
+
{addressLength: 10, accountIndexLength: 8, checkSumLength: 1},
|
|
15
|
+
{addressLength: 11, accountIndexLength: 8, checkSumLength: 2},
|
|
16
|
+
{addressLength: 12, accountIndexLength: 8, checkSumLength: 3},
|
|
17
|
+
{addressLength: 13, accountIndexLength: 8, checkSumLength: 4},
|
|
18
|
+
{addressLength: 14, accountIndexLength: 8, checkSumLength: 5},
|
|
19
|
+
{addressLength: 15, accountIndexLength: 8, checkSumLength: 6},
|
|
20
|
+
{addressLength: 16, accountIndexLength: 8, checkSumLength: 7},
|
|
21
|
+
{addressLength: 17, accountIndexLength: 8, checkSumLength: 8},
|
|
22
|
+
{addressLength: 34, accountIndexLength: 32, checkSumLength: 2},
|
|
23
|
+
];
|
|
24
|
+
|
|
25
|
+
function verifyChecksum(address: string) {
|
|
26
|
+
try {
|
|
27
|
+
const preImage = '53533538505245'
|
|
28
|
+
const decoded = cryptoUtils.base58(address);
|
|
29
|
+
const addressType = cryptoUtils.byteArray2hexStr(decoded.slice(0, 1));
|
|
30
|
+
const addressAndChecksum = decoded.slice(1)
|
|
31
|
+
|
|
32
|
+
// get the address format
|
|
33
|
+
const addressFormat = addressFormats.find(af => af.addressLength === addressAndChecksum.length);
|
|
34
|
+
|
|
35
|
+
if (!addressFormat) {
|
|
36
|
+
throw new Error('Invalid address length');
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
const decodedAddress = cryptoUtils.byteArray2hexStr(addressAndChecksum.slice(0, addressFormat.accountIndexLength));
|
|
40
|
+
const checksum = cryptoUtils.byteArray2hexStr(addressAndChecksum.slice(-addressFormat.checkSumLength));
|
|
41
|
+
|
|
42
|
+
const calculatedHash = cryptoUtils
|
|
43
|
+
.blake2b(preImage + addressType + decodedAddress, 64)
|
|
44
|
+
.substr(0, addressFormat.checkSumLength * 2)
|
|
45
|
+
.toUpperCase();
|
|
46
|
+
|
|
47
|
+
return calculatedHash == checksum;
|
|
48
|
+
} catch (err) {
|
|
49
|
+
return false;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export default {
|
|
54
|
+
isValidAddress(address: Address) {
|
|
55
|
+
return verifyChecksum(getAddress(address))
|
|
56
|
+
},
|
|
57
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import baseX from 'base-x'
|
|
2
|
+
|
|
3
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
4
|
+
import {Address} from '../types.js'
|
|
5
|
+
import {getAddress} from '../helpers.js'
|
|
6
|
+
|
|
7
|
+
const ALLOWED_CHARS = 'rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz';
|
|
8
|
+
|
|
9
|
+
const codec = baseX(ALLOWED_CHARS);
|
|
10
|
+
const regexp = new RegExp('^r[' + ALLOWED_CHARS + ']{27,35}$');
|
|
11
|
+
|
|
12
|
+
export default {
|
|
13
|
+
/**
|
|
14
|
+
* ripple address validation
|
|
15
|
+
*/
|
|
16
|
+
isValidAddress: function (address: Address) {
|
|
17
|
+
const addr = getAddress(address)
|
|
18
|
+
const destinationTag = (address as any).destinationTag
|
|
19
|
+
|
|
20
|
+
const validAddress = regexp.test(addr) && this.verifyChecksum(addr);
|
|
21
|
+
|
|
22
|
+
return validAddress && this.verifyMemo(destinationTag)
|
|
23
|
+
},
|
|
24
|
+
|
|
25
|
+
verifyMemo(destinationTag: string | null) {
|
|
26
|
+
return !destinationTag || /[0-9]+/.test(destinationTag)
|
|
27
|
+
},
|
|
28
|
+
|
|
29
|
+
verifyChecksum: function (address: string) {
|
|
30
|
+
const bytes = codec.decode(address);
|
|
31
|
+
const computedChecksum = cryptoUtils.sha256Checksum(cryptoUtils.toHex(bytes.slice(0, -4)));
|
|
32
|
+
const checksum = cryptoUtils.toHex(bytes.slice(-4));
|
|
33
|
+
|
|
34
|
+
return computedChecksum === checksum
|
|
35
|
+
}
|
|
36
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import isEqual from 'lodash.isequal'
|
|
2
|
+
|
|
3
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
4
|
+
import {Address} from '../types.js'
|
|
5
|
+
import {getAddress} from '../helpers.js'
|
|
6
|
+
|
|
7
|
+
function hexToBytes(hex: string) {
|
|
8
|
+
const bytes = []
|
|
9
|
+
for (let c = 0; c < hex.length; c += 2) {
|
|
10
|
+
bytes.push(parseInt(hex.substr(c, 2), 16))
|
|
11
|
+
}
|
|
12
|
+
return bytes
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
function verifyChecksum(address: string) {
|
|
16
|
+
const checksumBytes = address.slice(0, 32 * 2)
|
|
17
|
+
const check = address.slice(32 * 2, 38 * 2)
|
|
18
|
+
const blakeHash = cryptoUtils.blake2b(checksumBytes, 32).slice(0, 6 * 2)
|
|
19
|
+
return !!isEqual(blakeHash, check)
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export default {
|
|
23
|
+
isValidAddress: function (address: Address) {
|
|
24
|
+
const addr = getAddress(address)
|
|
25
|
+
if (addr.length !== 76) {
|
|
26
|
+
// Check if it has the basic requirements of an address
|
|
27
|
+
return false
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// Otherwise check each case
|
|
31
|
+
return verifyChecksum(addr)
|
|
32
|
+
},
|
|
33
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import base58Validator from './base58_validator.js';
|
|
2
|
+
import {Address} from '../types.js'
|
|
3
|
+
import {getAddress} from '../helpers.js'
|
|
4
|
+
|
|
5
|
+
export default {
|
|
6
|
+
isValidAddress: function (address: Address) {
|
|
7
|
+
return base58Validator.isValidAddress(getAddress(address), {
|
|
8
|
+
maxLength: 44,
|
|
9
|
+
minLength: 43,
|
|
10
|
+
})
|
|
11
|
+
}
|
|
12
|
+
};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import base58 from '../crypto/base58.js'
|
|
2
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
3
|
+
import {Address} from '../types.js'
|
|
4
|
+
import {getAddress} from '../helpers.js'
|
|
5
|
+
|
|
6
|
+
const prefix = new Uint8Array([6, 161, 159]);
|
|
7
|
+
|
|
8
|
+
function decodeRaw(buffer: any) {
|
|
9
|
+
let payload = buffer.slice(0, -4);
|
|
10
|
+
let checksum = buffer.slice(-4);
|
|
11
|
+
let newChecksum = cryptoUtils.hexStr2byteArray(
|
|
12
|
+
cryptoUtils.sha256x2(cryptoUtils.byteArray2hexStr(payload))
|
|
13
|
+
);
|
|
14
|
+
|
|
15
|
+
if (checksum[0] ^ newChecksum[0] |
|
|
16
|
+
checksum[1] ^ newChecksum[1] |
|
|
17
|
+
checksum[2] ^ newChecksum[2] |
|
|
18
|
+
checksum[3] ^ newChecksum[3])
|
|
19
|
+
return;
|
|
20
|
+
return payload;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export default {
|
|
24
|
+
isValidAddress(address: Address) {
|
|
25
|
+
try {
|
|
26
|
+
let buffer = base58.decode(getAddress(address));
|
|
27
|
+
let payload = decodeRaw(buffer);
|
|
28
|
+
if (!payload)
|
|
29
|
+
return false;
|
|
30
|
+
payload.slice(prefix.length);
|
|
31
|
+
return true;
|
|
32
|
+
} catch (e) {
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import {Address} from '../types.js'
|
|
2
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
3
|
+
import {getAddress} from '../helpers.js'
|
|
4
|
+
|
|
5
|
+
function decodeBase58Address(base58String: string) {
|
|
6
|
+
if (typeof (base58String) !== 'string') {
|
|
7
|
+
return false;
|
|
8
|
+
}
|
|
9
|
+
if (base58String.length !== 34) {
|
|
10
|
+
return false;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
let address: number[]
|
|
14
|
+
try {
|
|
15
|
+
address = cryptoUtils.base58(base58String);
|
|
16
|
+
} catch (e) {
|
|
17
|
+
return false
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const len = address.length;
|
|
21
|
+
const offset = len - 4;
|
|
22
|
+
const checkSum = address.slice(offset);
|
|
23
|
+
address = address.slice(0, offset);
|
|
24
|
+
const hash0 = cryptoUtils.sha256(cryptoUtils.byteArray2hexStr(address));
|
|
25
|
+
const hash1 = cryptoUtils.hexStr2byteArray(cryptoUtils.sha256(hash0));
|
|
26
|
+
const checkSum1 = hash1.slice(0, 4);
|
|
27
|
+
if (checkSum[0] === checkSum1[0] && checkSum[1] === checkSum1[1] && checkSum[2]
|
|
28
|
+
=== checkSum1[2] && checkSum[3] === checkSum1[3]
|
|
29
|
+
) {
|
|
30
|
+
return address;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
interface TronValidatorOpts {
|
|
37
|
+
addressTypes: string[],
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const DefaultTronValidatorOpts: TronValidatorOpts = {
|
|
41
|
+
addressTypes: ['65']
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export default (opts?: TronValidatorOpts) => ({
|
|
45
|
+
isValidAddress: function (address: Address) {
|
|
46
|
+
const _opts = {...DefaultTronValidatorOpts, ...opts}
|
|
47
|
+
const addr = decodeBase58Address(getAddress(address));
|
|
48
|
+
|
|
49
|
+
if (!addr) {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
if (addr.length !== 21) {
|
|
54
|
+
return false;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return _opts.addressTypes.includes(addr[0].toString());
|
|
58
|
+
}
|
|
59
|
+
});
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import baseX from 'base-x'
|
|
2
|
+
import crc from 'crc'
|
|
3
|
+
|
|
4
|
+
import cryptoUtils from '../crypto/utils.js'
|
|
5
|
+
import {Address} from '../types.js'
|
|
6
|
+
import {getAddress} from '../helpers.js'
|
|
7
|
+
|
|
8
|
+
const ALPHABET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567';
|
|
9
|
+
|
|
10
|
+
const base32 = baseX(ALPHABET);
|
|
11
|
+
const regexp = new RegExp('^[' + ALPHABET + ']{56}$');
|
|
12
|
+
const ed25519PublicKeyVersionByte = (6 << 3);
|
|
13
|
+
|
|
14
|
+
function swap16(number: number) {
|
|
15
|
+
const lower = number & 0xFF;
|
|
16
|
+
const upper = (number >> 8) & 0xFF;
|
|
17
|
+
return (lower << 8) | upper;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export default {
|
|
21
|
+
isValidAddress(address: Address) {
|
|
22
|
+
const addr = getAddress(address)
|
|
23
|
+
if (regexp.test(addr)) {
|
|
24
|
+
return this.verifyChecksum(addr);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
return false;
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
verifyChecksum: function (address: string) {
|
|
31
|
+
// based on https://github.com/stellar/js-stellar-base/blob/master/src/strkey.js#L126
|
|
32
|
+
var bytes = base32.decode(address);
|
|
33
|
+
if (bytes[0] !== ed25519PublicKeyVersionByte) {
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
const computedChecksum = cryptoUtils.numberToHex(swap16(crc.crc16xmodem(bytes.slice(0, -2))), 4);
|
|
38
|
+
const checksum = cryptoUtils.toHex(bytes.slice(-2));
|
|
39
|
+
|
|
40
|
+
return computedChecksum === checksum
|
|
41
|
+
}
|
|
42
|
+
};
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import algorand from './algorand.json'
|
|
2
|
+
import bch from './bch.json'
|
|
3
|
+
import bchTestnet from './bch-testnet.json'
|
|
4
|
+
import btc from './btc.json'
|
|
5
|
+
import btcTestnet from './btc-testnet.json'
|
|
6
|
+
import cardano from './cardano.json'
|
|
7
|
+
import doge from './doge.json'
|
|
8
|
+
import eos from './eos.json'
|
|
9
|
+
import evm from './evm.json'
|
|
10
|
+
import ltc from './ltc.json'
|
|
11
|
+
import ltcTestnet from './ltc-testnet.json'
|
|
12
|
+
import monero from './monero.json'
|
|
13
|
+
import nem from './nem.json'
|
|
14
|
+
import nano from './nano.json'
|
|
15
|
+
import polkadot from './polkadot.json'
|
|
16
|
+
import ripple from './ripple.json'
|
|
17
|
+
import sia from './sia.json'
|
|
18
|
+
import solana from './solana.json'
|
|
19
|
+
import tezos from './tezos.json'
|
|
20
|
+
import tron from './tron.json'
|
|
21
|
+
import xlm from './xlm.json'
|
|
22
|
+
|
|
23
|
+
export default {
|
|
24
|
+
algorand,
|
|
25
|
+
bch,
|
|
26
|
+
'bch-testnet': bchTestnet,
|
|
27
|
+
btc,
|
|
28
|
+
'btc-testnet': btcTestnet,
|
|
29
|
+
cardano,
|
|
30
|
+
doge,
|
|
31
|
+
eos,
|
|
32
|
+
evm,
|
|
33
|
+
ltc,
|
|
34
|
+
'ltc-testnet': ltcTestnet,
|
|
35
|
+
monero,
|
|
36
|
+
nem,
|
|
37
|
+
nano,
|
|
38
|
+
polkadot,
|
|
39
|
+
ripple,
|
|
40
|
+
sia,
|
|
41
|
+
solana,
|
|
42
|
+
tezos,
|
|
43
|
+
tron,
|
|
44
|
+
xlm,
|
|
45
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
[
|
|
2
|
+
"12KYrjTdVGjFMtaxERSk3gphreJ5US8aUP",
|
|
3
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
4
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
5
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
6
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
7
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
8
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
9
|
+
"1oNLrsHnBcR6dpaBpwz3LSwutbUNkNSjs",
|
|
10
|
+
"3NJZLcZEEYBpxYEUGewU4knsQRn1WM5Fkt",
|
|
11
|
+
"bitcoincash:qq4v32mtagxac29my6gwj6fd4tmqg8rysu23dax807"
|
|
12
|
+
]
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
[
|
|
2
|
+
"12KYrjTdVGjFMtaxERSk3gphreJ5US8aUP",
|
|
3
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
4
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
5
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
6
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
7
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
8
|
+
"12QeMLzSrB8XH8FvEzPMVoRxVAzTr5XM2y",
|
|
9
|
+
"15uwigGExiNQxTNr1QSZYPXJMp9Px2YnVU",
|
|
10
|
+
"3FyVFsEyyBPzHjD3qUEgX7Jsn4tcHNZFkn",
|
|
11
|
+
"38mKdURe1zcQyrFqRLzR8PRao3iLGEPVsU",
|
|
12
|
+
"BC1QW508D6QEJXTDG4Y5R3ZARVARY0C5XW7KV8F3T4",
|
|
13
|
+
"bc1q2t63ewm3mvh0ztmnmezxm7s0tefknenxlrlwrk"
|
|
14
|
+
]
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
[
|
|
2
|
+
"Ae2tdPwUPEYzs5BRbGcoS3DXvK8mwgggmESz4HqUwMyaS9eNksZGz1LMS9v",
|
|
3
|
+
"Ae2tdPwUPEYxYNJw1He1esdZYvjmr4NtPzUsGTiqL9zd8ohjZYQcwu6kom7",
|
|
4
|
+
"DdzFFzCqrhsfdzUZxvuBkhV8Lpm9p43p9ubh79GCTkxJikAjKh51qhtCFMqUniC5tv5ZExyvSmAte2Du2tGimavSo6qSgXbjiy8qZRTg",
|
|
5
|
+
"Ae2tdPwUPEZKmwoy3AU3cXb5Chnasj6mvVNxV1H11997q3VW5ihbSfQwGpm",
|
|
6
|
+
"4swhHtxKapQbj3TZEipgtp7NQzcRWDYqCxXYoPQWjGyHmhxS1w1TjUEszCQT1sQucGwmPQMYdv1FYs3d51KgoubviPBf",
|
|
7
|
+
"addr1qxy3w62dupy9pzmpdfzxz4k240w5vawyagl5m9djqquyymrtm3grn7gpnjh7rwh2dy62hk8639lt6kzn32yxq960usnq9pexvt"
|
|
8
|
+
]
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
[
|
|
2
|
+
"0xE37c0D48d68da5c5b14E5c1a9f1CFE802776D9FF",
|
|
3
|
+
"0xa00354276d2fC74ee91e37D085d35748613f4748",
|
|
4
|
+
"0xAff4d6793F584a473348EbA058deb8caad77a288",
|
|
5
|
+
"0xc6d9d2cd449a754c494264e1809c50e34d64562b",
|
|
6
|
+
"0x52908400098527886E0F7030069857D2E4169EE7",
|
|
7
|
+
"0x8617E340B3D01FA5F11F306F4090FD50E238070D",
|
|
8
|
+
"0x27b1fdb04752bbc536007a920d24acb045561c26",
|
|
9
|
+
"0x5aAeb6053F3E94C9b9A09f33669435E7Ef1BeAed",
|
|
10
|
+
"0xfB6916095ca1df60bB79Ce92cE3Ea74c37c5d359",
|
|
11
|
+
"0xdbF03B407c01E7cD3CBea99509d93f8DDDC8C6FB",
|
|
12
|
+
"0xD1220A0cf47c7B9Be7A2E6BA89F429762e7b9aDb",
|
|
13
|
+
|
|
14
|
+
"0xE37c0D48d68da5c5b14E5c1a9f1CFE802776D9FF",
|
|
15
|
+
"0xa00354276d2fC74ee91e37D085d35748613f4748",
|
|
16
|
+
"0xAff4d6793F584a473348EbA058deb8caad77a288",
|
|
17
|
+
"0xc6d9d2cd449a754c494264e1809c50e34d64562b",
|
|
18
|
+
"0x52908400098527886E0F7030069857D2E4169EE7",
|
|
19
|
+
"0x8617E340B3D01FA5F11F306F4090FD50E238070D",
|
|
20
|
+
"0xde709f2102306220921060314715629080e2fb77"
|
|
21
|
+
]
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
[
|
|
2
|
+
"tc1qw508d6qejxtdg4y5r3zarvary0c5xw7kg3g4ty",
|
|
3
|
+
"bc1pw508d6qejxtdg4y5r3zarvary0c5xw7kw508d6qejxtdg4y5r3zarvary0c5xw7k7grplx",
|
|
4
|
+
"BC1SW50QA3JX3S",
|
|
5
|
+
"bc1zw508d6qejxtdg4y5r3zarvaryvg6kdaj",
|
|
6
|
+
"bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t5",
|
|
7
|
+
"BC13W508D6QEJXTDG4Y5R3ZARVARY0C5XW7KN40WF2",
|
|
8
|
+
"bc1rw5uspcuh",
|
|
9
|
+
"bc10w508d6qejxtdg4y5r3zarvary0c5xw7kw508d6qejxtdg4y5r3zarvary0c5xw7kw5rljs90",
|
|
10
|
+
"BC1QR508D6QEJXTDG4Y5R3ZARVARYV98GJ9P",
|
|
11
|
+
"tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sL5k7",
|
|
12
|
+
"bc1zw508d6qejxtdg4y5r3zarvaryvqyzf3du",
|
|
13
|
+
"tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3pjxtptv",
|
|
14
|
+
"bc1gmk9yu"
|
|
15
|
+
]
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
[
|
|
2
|
+
"LVg2kJoFNg45Nbpy53h7Fe1wKyeXVRhMH9",
|
|
3
|
+
"LVg2kJoFNg45Nbpy53h7Fe1wKyeXVRhMH9",
|
|
4
|
+
"LTpYZG19YmfvY2bBDYtCKpunVRw7nVgRHW",
|
|
5
|
+
"Lb6wDP2kHGyWC7vrZuZAgV7V4ECyDdH7a6",
|
|
6
|
+
"3NJZLcZEEYBpxYEUGewU4knsQRn1WM5Fkt",
|
|
7
|
+
"ltc1qg42tkwuuxefutzxezdkdel39gfstuap288mfea",
|
|
8
|
+
"ltc1qg42tkwuuxefutzxezdkdel39gfstuap288mfea"
|
|
9
|
+
]
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
[
|
|
2
|
+
"47zQ5LAivg6hNCgijXSEFVLX7mke1bgM6YGLFaANDoJbgXDymcAAZvvMNt2PmMpqEe5qRy2zyfMYXdwpmdyitiFh84xnPG2",
|
|
3
|
+
"48bWuoDG75CXMDHbmPEvUF2hm1vLDic7ZJ7hqRkL65QR9p13AQAX4eEACXNk4YP115Q4KRVZnAvmMBHrcGfv9FvKPZnH6vH",
|
|
4
|
+
"88WB4JKdQVhWfkc8cBT9EEJ6vejSAqKJHbV1dXBAXdpgQovtNDNRxfKCS7wB8rHQ5D5zH2Pd1YkyMNNQDie6ZfeZ311fPgn",
|
|
5
|
+
"4Gd4DLiXzBmbVX2FZZ3Cvu6fUaWACup1qDowprUCje1kSP4FmbftiJMSfV8kWZXNqmVwj4m52xqtgFNUudVmsmGkGvkLcCibWfVUfUFVB7",
|
|
6
|
+
"4J5sF94AzXgFgx8LuWc9dcWkJkGkD3cL3L2AuhX6QA9jFvSxxj6QhHqHXqM2b2Go7G8RyDzEbHxYd9G26XUUbuJChipEyBz9fENMU2Ua9b"
|
|
7
|
+
]
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
[
|
|
2
|
+
"xrb_3t6k35gi95xu6tergt6p69ck76ogmitsa8mnijtpxm9fkcm736xtoncuohr3",
|
|
3
|
+
"xrb_13ezf4od79h1tgj9aiu4djzcmmguendtjfuhwfukhuucboua8cpoihmh8byo",
|
|
4
|
+
"xrb_35jjmmmh81kydepzeuf9oec8hzkay7msr6yxagzxpcht7thwa5bus5tomgz9",
|
|
5
|
+
"xrb_1111111111111111111111111111111111111111111111111111hifc8npp",
|
|
6
|
+
"xrb_1ipx847tk8o46pwxt5qjdbncjqcbwcc1rrmqnkztrfjy5k7z4imsrata9est",
|
|
7
|
+
"xrb_3wm37qz19zhei7nzscjcopbrbnnachs4p1gnwo5oroi3qonw6inwgoeuufdp",
|
|
8
|
+
"xrb_3arg3asgtigae3xckabaaewkx3bzsh7nwz7jkmjos79ihyaxwphhm6qgjps4",
|
|
9
|
+
"xrb_1f5e4w33ndqbkx4bw5jtp13kp5xghebfxcmw9hdt1f7goid1s4373w6tjmgu",
|
|
10
|
+
"xrb_1q79ahdr36uqn38p5tp5sqwkn73rnpj1k8obtuetdbjcx37d5gahhd1u9cuh",
|
|
11
|
+
"nano_1q79ahdr36uqn38p5tp5sqwkn73rnpj1k8obtuetdbjcx37d5gahhd1u9cuh"
|
|
12
|
+
]
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
[
|
|
2
|
+
"1iQPKJmghHbrRhUiMt2cNEuxYbR6S9vYtJKqYvE4PNR9WDB",
|
|
3
|
+
"1FRMM8PEiWXYax7rpS6X4XZX1aAAxSWx1CrKTyrVYhV24fg",
|
|
4
|
+
"5CK8D1sKNwF473wbuBP6NuhQfPaWUetNsWUNAAzVwTfxqjfr",
|
|
5
|
+
"CpjsLDC1JFyrhm3ftC9Gs4QoyrkHKhZKtK7YqGTRFtTafgp",
|
|
6
|
+
"15FKUKXC6kwaXxJ1tXNywmFy4ZY6FoDFCnU3fMbibFdeqwGw",
|
|
7
|
+
"CxDDSH8gS7jecsxaRL9Txf8H5kqesLXAEAEgp76Yz632J9M"
|
|
8
|
+
]
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
[
|
|
2
|
+
"rG1QQv2nh2gr7RCZ1P8YYcBUKCCN633jCn",
|
|
3
|
+
"rG1QQv2nh2gr7RCZ1P8YYcBUKCCN633jCn",
|
|
4
|
+
"r3kmLJN5D28dHuH8vZNUZpMC43pEHpaocV",
|
|
5
|
+
"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh",
|
|
6
|
+
"rDTXLQ7ZKZVKz33zJbHjgVShjsBnqMBhmN",
|
|
7
|
+
{
|
|
8
|
+
"address": "rDTXLQ7ZKZVKz33zJbHjgVShjsBnqMBhmN",
|
|
9
|
+
"destinationTag": 50000
|
|
10
|
+
}
|
|
11
|
+
]
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
[
|
|
2
|
+
"a9b01c85163638682b170d82de02b8bb99ba86092e9ab1b0d25111284fe618e93456915820f1",
|
|
3
|
+
"a9b01c85163638682b170d82de02b8bb99ba86092e9ab1b0d25111284fe618e93456915820f1",
|
|
4
|
+
"ab0c327982abfcc6055a6c9551589167d8a73501aca8769f106371fbc937ad100c955c3b7ba9",
|
|
5
|
+
"ffe1308c044ade30392a0cdc1fd5a4dbe94f9616a95faf888ed36123d9e711557aa497530373"
|
|
6
|
+
]
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
[
|
|
2
|
+
"833XorXTTx5iya5B3Tr6iqEs9GbRuvVfwyLCP2vpdzhq",
|
|
3
|
+
"6ZRCB7AAqGre6c72PRz3MHLC73VMYvJ8bi9KHf1HFpNk",
|
|
4
|
+
"HgyXhqapicB8zoyyFQ23oUwwFrBACDyDc7bqUuvnEELM",
|
|
5
|
+
"833XorXTTx5iya5B3Tr6iqEs9GbRuvVfwyLCP2vpdzhq",
|
|
6
|
+
"69UwBV4LPg7hHUS5JXiXyfgVnESmDKe8KJppsLj8pRU",
|
|
7
|
+
"G4qGCGF4vWGPzYi2pxc2Djvgv3j8NiWaHQMgTVebCX6W"
|
|
8
|
+
]
|