forked from bitpay/bitcore
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathaddress.ts
110 lines (86 loc) · 5.17 KB
/
address.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import { expect } from 'chai';
import { Deriver } from '../src';
describe('Address Derivation', () => {
it('should be able to generate a valid BTC address', () => {
const xPub = 'xpub6A4DRTebM6TS5f6cUt5YAxKXikhDZd6ANwbyomHhFFkjJApdAwnADvMRfimdaKXf1xk1LTrPuRo7eGCGYARApdytZ18SqoUv6MTYtbCx4Xv';
// 'select scout crash enforce riot rival spring whale hollow radar rule sentence';
const path = Deriver.pathFor('BTC', 'mainnet');
expect(path).to.equal("m/44'/0'/0'");
const address = Deriver.deriveAddress('BTC', 'mainnet', xPub, 0, false);
const expectedAddress = '1EDh8HXc2jwbyDPLEyDDnYea48f2D8z3ER';
expect(address).to.equal(expectedAddress);
});
it('should be able to generate a valid BCH address', () => {
const xPub = 'xpub6BM8E3eh3homN5uvHh12P4HQEP1QrXCuCA32JRgTTeR7Y7ChML4iV12TfSVV3KHnCGPB1kkDU26EnDHYqw3Koab2a2GjxHQuUVXE3fvcpek';
// 'select scout crash enforce riot rival spring whale hollow radar rule sentence';
const path = Deriver.pathFor('BCH', 'mainnet');
expect(path).to.equal("m/44'/145'/0'");
const address = Deriver.deriveAddress('BCH', 'mainnet', xPub, 0, false);
const expectedAddress = 'qzltyqgzd3hvj7fvfdymzk6e47zrrczvzc9y37nnrr';
expect(address).to.equal(expectedAddress);
});
it('should be able to generate a valid DOGE address', () => {
const xPub = 'tpubDCs1d9wgHkn2LYY8KrWozaUwG7a3XSkiaGtn8isiNWmLhepenSdqgH1JCMwCLW9eeRZW37D14tpBjxvb3rjkMzak4ub1qHyF4tLbQDNXZ8K';
// 'select scout crash enforce riot rival spring whale hollow radar rule sentence';
const path = Deriver.pathFor('DOGE', 'mainnet');
expect(path).to.equal("m/44'/3'/0'");
const address = Deriver.deriveAddress('DOGE', 'mainnet', xPub, 0, false);
const expectedAddress = 'DQnSpKaUdXYZz8Q4WUBCdaGBSthiAJbWBr';
expect(address).to.equal(expectedAddress);
});
it('should be able to generate a valid LTC address', () => {
const xPub = 'tpubDCetVaW8PG7S6SuLjRGmmyVA4QtXyXTUsqXySaC4WV44igJ3aJNQgYedjL1FX12a1tDctnh3kRPybKTMUjdi9mzUm4wJF3GNSjf8GwDUHpp';
// 'select scout crash enforce riot rival spring whale hollow radar rule sentence';
const path = Deriver.pathFor('LTC', 'mainnet');
expect(path).to.equal("m/44'/2'/0'");
const address = Deriver.deriveAddress('LTC', 'mainnet', xPub, 0, false);
const expectedAddress = 'LYgDcZ3oW3aZBhZUyiC84fb99hyUPVxLwB';
expect(address).to.equal(expectedAddress);
});
it('should be able to generate a valid ETH address', () => {
const xPub = 'xpub6D8rChqkgFuaZULuq2n6VrS4zB5Cmv24gcRc889dFRRgYAH1CGQmQZ9kcPfMAfWGPnyMd1X5foBYFmJ5ZPfvwhm6tXjaY13ao1rQHRtkKDv';
// 'select scout crash enforce riot rival spring whale hollow radar rule sentence';
const path = Deriver.pathFor('ETH', 'mainnet');
expect(path).to.equal("m/44'/60'/0'");
const address = Deriver.deriveAddress('ETH', 'mainnet', xPub, 0, false);
const expectedAddress = '0x9dbfE221A6EEa27a0e2f52961B339e95426931F9';
expect(address).to.equal(expectedAddress);
});
it('should be able to generate a valid XRP address', () => {
const xPub = 'xpub6J8BBe8QHMMiVQK1F8hLpRKnmkwNTa7tkg753KWjkafzcxfWVFBMkpbPjfY9Fz4bgSvn6jiUYg1ivpeF5HjE6jvrdHm6Se7HKgEAjPFGFfr';
// 'select scout crash enforce riot rival spring whale hollow radar rule sentence';
const path = Deriver.pathFor('XRP', 'mainnet');
expect(path).to.equal("m/44'/144'/0'");
const address = Deriver.deriveAddress('XRP', 'mainnet', xPub, 0, false);
const expectedAddress = 'r9dmAJBfBe7JL2RRLiFWGJ8kM4CHEeTpgN';
expect(address).to.equal(expectedAddress);
});
it('should be able to generate a valid ETH address, privKey, pubKey', () => {
const privKey = 'xprv9ypBjKErGMqCdzd44hfSdy1Vk6PGtU3si8ogZcow7rA23HTxMi9XfT99EKmiNdLMr9BAZ9S8ZKCYfN1eCmzYSmXYHje1jnYQseV1VJDDfdS';
const path = Deriver.pathFor('ETH', 'mainnet');
expect(path).to.equal("m/44'/60'/0'");
const result = Deriver.derivePrivateKey('ETH', 'mainnet', privKey, 0, false);
const expectedResult = {
address: '0xb497281830dE4F19a3482AbF3D5C35c514e6fB36',
privKey: '62b8311c71f355c5c07f6bffe9b1ae60aa20d90e2e2ec93ec11b6014b2ae6340',
pubKey: '0386d153aad9395924631dbc78fa560107123a759eaa3e105958248c60cd4472ad'
};
expect(result.address).to.equal(expectedResult.address);
expect(result.privKey).to.equal(expectedResult.privKey);
expect(result.pubKey).to.equal(expectedResult.pubKey);
});
it('should be able to generate a valid XRP address, privKey, pubKey', () => {
const privKey = 'xprvA58pn8bWSyoRGvEY97ALTHP4Dj6t47Q3PTBUEw78CF91kALMwhs7D2GutQSvpRN6ACR4RX4HbF3KmF7zDf48gR8nwG7DqLp6ezUcMiPHDtV';
const path = Deriver.pathFor('XRP', 'mainnet');
expect(path).to.equal("m/44'/144'/0'");
const result = Deriver.derivePrivateKey('XRP', 'mainnet', privKey, 0, false);
const expectedResult = {
address: 'r9dmAJBfBe7JL2RRLiFWGJ8kM4CHEeTpgN',
privKey: 'd02c6801d8f328ff2ead51d01f9580af36c8d74e2bd463963ac4adbe51ae5f2c',
pubKey: '03dbeec5e9e76da09c5b502a67136bc2d73423e8902a7c35a8cbc0c5a6ac0469e8'
};
expect(result.address).to.equal(expectedResult.address);
expect(result.privKey).to.equal(expectedResult.privKey.toUpperCase());
expect(result.pubKey).to.equal(expectedResult.pubKey.toUpperCase());
});
});