@samyan/hd-wallet 1.0.3 → 1.1.0
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/{.babelrc → babel.config.json} +28 -29
- package/build/index.js +55 -46
- package/build/{index.d.ts → src/index.d.ts} +63 -62
- package/docker-compose.yml +8 -0
- package/package.json +22 -16
- package/test/hd-wallet.test.ts +120 -0
- package/tsconfig.json +27 -20
|
@@ -1,29 +1,28 @@
|
|
|
1
|
-
{
|
|
2
|
-
"presets": [
|
|
3
|
-
[
|
|
4
|
-
"@babel/preset-env",
|
|
5
|
-
{
|
|
6
|
-
"targets": {
|
|
7
|
-
"node": "current"
|
|
8
|
-
}
|
|
9
|
-
}
|
|
10
|
-
],
|
|
11
|
-
"@babel/preset-typescript",
|
|
12
|
-
"minify"
|
|
13
|
-
],
|
|
14
|
-
"plugins": [
|
|
15
|
-
[
|
|
16
|
-
"@babel/plugin-proposal-decorators",
|
|
17
|
-
{
|
|
18
|
-
"
|
|
19
|
-
}
|
|
20
|
-
],
|
|
21
|
-
[
|
|
22
|
-
"@babel/plugin-transform-runtime"
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
]
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"presets": [
|
|
3
|
+
[
|
|
4
|
+
"@babel/preset-env",
|
|
5
|
+
{
|
|
6
|
+
"targets": {
|
|
7
|
+
"node": "current"
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
],
|
|
11
|
+
"@babel/preset-typescript",
|
|
12
|
+
"minify"
|
|
13
|
+
],
|
|
14
|
+
"plugins": [
|
|
15
|
+
[
|
|
16
|
+
"@babel/plugin-proposal-decorators",
|
|
17
|
+
{
|
|
18
|
+
"version": "2023-11"
|
|
19
|
+
}
|
|
20
|
+
],
|
|
21
|
+
[
|
|
22
|
+
"@babel/plugin-transform-runtime"
|
|
23
|
+
],
|
|
24
|
+
[
|
|
25
|
+
"@babel/plugin-transform-class-properties"
|
|
26
|
+
]
|
|
27
|
+
]
|
|
28
|
+
}
|
package/build/index.js
CHANGED
|
@@ -1,52 +1,61 @@
|
|
|
1
|
-
"use strict";var _interopRequireDefault=require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _defineProperty2=_interopRequireDefault(require("@babel/runtime/helpers/defineProperty")),_baseX=_interopRequireDefault(require("base-x")),_bip=_interopRequireDefault(require("bip32")),_bip2=require("bip39"),_bitcoinjsLib=require("bitcoinjs-lib"),
|
|
2
|
-
* Constructor
|
|
3
|
-
*
|
|
4
|
-
* @param {string} protocol
|
|
5
|
-
* @param {string} mnemonicWord
|
|
6
|
-
* @param {boolean} [includePrivateKey=false]
|
|
7
|
-
* @param {boolean} [log=false]
|
|
8
|
-
* @memberof HDWallet
|
|
9
|
-
*/constructor(a,b,c=!1,d=!1){(0,_defineProperty2.default)(this,"segwitParameters",{bitcoin:{messagePrefix:"\x18Bitcoin Signed Message:\n",bech32:"bc",bip32:{public:78792518,private:78791436},pubKeyHash:0,scriptHash:5,wif:128},bitcoinRegTest:{messagePrefix:"\x18Bitcoin Signed Message:\n",bech32:"bcrt",bip32:{public:70617039,private:70615956},pubKeyHash:111,scriptHash:196,wif:239},litecoin:{messagePrefix:"\x19Litecoin Signed Message:\n",bech32:"ltc",bip32:{public:78792518,private:78791436},pubKeyHash:48,scriptHash:50,wif:176}}),(0,_defineProperty2.default)(this,"rootKey",void 0),(0,_defineProperty2.default)(this,"accountExtendedKey",void 0),(0,_defineProperty2.default)(this,"protocol",void 0),(0,_defineProperty2.default)(this,"mnemonicWord",void 0),(0,_defineProperty2.default)(this,"includePrivateKey",void 0),(0,_defineProperty2.default)(this,"seed",void 0),(0,_defineProperty2.default)(this,"log",void 0),this.protocol=a,this.mnemonicWord=b,this.includePrivateKey=c,this.seed=(0,_bip2.mnemonicToSeedSync)(this.mnemonicWord),this.log=d}/**
|
|
10
|
-
* Generate
|
|
11
|
-
*
|
|
12
|
-
* @param {string} path
|
|
13
|
-
* @param {number} index
|
|
14
|
-
* @return {*} {string}
|
|
15
|
-
* @memberof HDWallet
|
|
1
|
+
"use strict";var _interopRequireDefault=require("@babel/runtime/helpers/interopRequireDefault");Object.defineProperty(exports,"__esModule",{value:!0}),exports.default=void 0;var _defineProperty2=_interopRequireDefault(require("@babel/runtime/helpers/defineProperty")),_util=require("@ethereumjs/util"),_baseX=_interopRequireDefault(require("base-x")),_bip=_interopRequireDefault(require("bip32")),_bip2=require("bip39"),_bitcoinjsLib=require("bitcoinjs-lib"),_hdkey=_interopRequireDefault(require("hdkey")),ecc=_interopRequireWildcard(require("tiny-secp256k1"));function _interopRequireWildcard(a,b){if("function"==typeof WeakMap)var c=new WeakMap,d=new WeakMap;return(_interopRequireWildcard=function(a,b){if(!b&&a&&a.__esModule)return a;var e,g,h={__proto__:null,default:a};if(null===a||"object"!=typeof a&&"function"!=typeof a)return h;if(e=b?d:c){if(e.has(a))return e.get(a);e.set(a,h)}for(const c in a)"default"!=c&&{}.hasOwnProperty.call(a,c)&&((g=(e=Object.defineProperty)&&Object.getOwnPropertyDescriptor(a,c))&&(g.get||g.set)?e(h,c,g):h[c]=a[c]);return h})(a,b)}class HDWallet{/**
|
|
2
|
+
* Constructor
|
|
3
|
+
*
|
|
4
|
+
* @param {string} protocol
|
|
5
|
+
* @param {string} mnemonicWord
|
|
6
|
+
* @param {boolean} [includePrivateKey=false]
|
|
7
|
+
* @param {boolean} [log=false]
|
|
8
|
+
* @memberof HDWallet
|
|
9
|
+
*/constructor(a,b,c=!1,d=!1){(0,_defineProperty2.default)(this,"segwitParameters",{bitcoin:{messagePrefix:"\x18Bitcoin Signed Message:\n",bech32:"bc",bip32:{public:78792518,private:78791436},pubKeyHash:0,scriptHash:5,wif:128},bitcoinRegTest:{messagePrefix:"\x18Bitcoin Signed Message:\n",bech32:"bcrt",bip32:{public:70617039,private:70615956},pubKeyHash:111,scriptHash:196,wif:239},litecoin:{messagePrefix:"\x19Litecoin Signed Message:\n",bech32:"ltc",bip32:{public:78792518,private:78791436},pubKeyHash:48,scriptHash:50,wif:176}}),(0,_defineProperty2.default)(this,"rootKey",void 0),(0,_defineProperty2.default)(this,"accountExtendedKey",void 0),(0,_defineProperty2.default)(this,"protocol",void 0),(0,_defineProperty2.default)(this,"mnemonicWord",void 0),(0,_defineProperty2.default)(this,"includePrivateKey",void 0),(0,_defineProperty2.default)(this,"seed",void 0),(0,_defineProperty2.default)(this,"log",void 0),this.protocol=a,this.mnemonicWord=b,this.includePrivateKey=c,this.seed=(0,_bip2.mnemonicToSeedSync)(this.mnemonicWord),this.log=d}/**
|
|
10
|
+
* Generate
|
|
11
|
+
*
|
|
12
|
+
* @param {string} path
|
|
13
|
+
* @param {number} index
|
|
14
|
+
* @return {*} {string}
|
|
15
|
+
* @memberof HDWallet
|
|
16
16
|
*/generate(a,b){// Concatenamos
|
|
17
17
|
const c="m/"+a;this.log&&(console.log("========================="),console.log("Mnemonic: %s",this.mnemonicWord),console.log("HD Path: %s\r\n",c));// Obtenemos la red si es el caso
|
|
18
18
|
const d=this.segwitParameters[this.protocol],e=(0,_bip.default)(ecc);// Instanciamos
|
|
19
|
+
// Obtenemos la root key
|
|
19
20
|
if(this.rootKey=e.fromSeed(this.seed,d),this.accountExtendedKey=this.calcBip32ExtendedKey(this.rootKey,c),this.log){// Obtenemos la clave privada y pública
|
|
20
21
|
const a=this.accountExtendedKey.toBase58(),b=this.accountExtendedKey.neutered().toBase58();console.log("Account Extended Private Key: %s \r\nAccount Extended Public Key: %s\r\n",a,b)}// Obtenemos el wallet
|
|
21
22
|
const f=this.accountExtendedKey.derive(b);switch(this.protocol){case"bitcoin":case"bitcoinRegTest":case"litecoin":{// Extraemos la dirección
|
|
22
|
-
const{address:a}=_bitcoinjsLib.payments.p2wpkh({pubkey:f.publicKey,network:d})
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
*
|
|
38
|
-
*
|
|
39
|
-
* @private
|
|
40
|
-
* @param {
|
|
41
|
-
* @
|
|
42
|
-
* @
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
*
|
|
46
|
-
*
|
|
47
|
-
* @
|
|
48
|
-
* @param {string}
|
|
49
|
-
* @
|
|
50
|
-
* @memberof HDWallet
|
|
51
|
-
*/
|
|
52
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HDWallet","constructor","protocol","mnemonicWord","includePrivateKey","log","_defineProperty2","default","bitcoin","messagePrefix","bech32","bip32","public","private","pubKeyHash","scriptHash","wif","bitcoinRegTest","litecoin","seed","mnemonicToSeedSync","generate","path","index","hdPath","console","network","segwitParameters","BIP32Factory","ecc","rootKey","fromSeed","accountExtendedKey","calcBip32ExtendedKey","accountXprv","toBase58","accountXpub","neutered","keyPair","derive","address","p2wpkhAddress","payments","p2wpkh","pubkey","publicKey","printWallet","toWIF","toString","privateKey","ethereumWallet","hdkey","fromMasterSeed","derivePath","deriveChild","getWallet","getAddressString","getPrivateKeyString","getPublicKeyString","xrpAddress","p2pkh","convertRippleAdrr","ethPubKey","importPublic","addressBuffer","publicToAddress","bitcoinjsAddress","toBase58Check","bip32RootKey","extendedKey","pathBits","split","i","length","bit","parseInt","isNaN","hardened","deriveHardened","basex","encode","decode","prvKey","pubKey","_default","exports"],"sources":["../src/index.ts"],"sourcesContent":["import basex from 'base-x';\r\nimport BIP32Factory, { BIP32API, BIP32Interface } from 'bip32';\r\nimport { mnemonicToSeedSync } from 'bip39';\r\nimport { address as bitcoinjsAddress, payments } from 'bitcoinjs-lib';\r\nimport { importPublic, publicToAddress } from 'ethereumjs-util';\r\nimport { hdkey } from 'ethereumjs-wallet';\r\nimport * as ecc from 'tiny-secp256k1';\r\n\r\nclass HDWallet {\r\n\tprivate segwitParameters: { [key: string]: any } = {\r\n\t\tbitcoin: {\r\n\t\t\tmessagePrefix: '\\x18Bitcoin Signed Message:\\n',\r\n\t\t\tbech32: 'bc',\r\n\t\t\tbip32: {\r\n\t\t\t\tpublic: 0x04b24746,\r\n\t\t\t\tprivate: 0x04b2430c,\r\n\t\t\t},\r\n\t\t\tpubKeyHash: 0x00,\r\n\t\t\tscriptHash: 0x05,\r\n\t\t\twif: 0x80,\r\n\t\t},\r\n\t\tbitcoinRegTest: {\r\n\t\t\tmessagePrefix: '\\x18Bitcoin Signed Message:\\n',\r\n\t\t\tbech32: 'bcrt',\r\n\t\t\tbip32: {\r\n\t\t\t\tpublic: 0x043587cf,\r\n\t\t\t\tprivate: 0x04358394,\r\n\t\t\t},\r\n\t\t\tpubKeyHash: 0x6f,\r\n\t\t\tscriptHash: 0xc4,\r\n\t\t\twif: 0xef,\r\n\t\t},\r\n\t\tlitecoin: {\r\n\t\t\tmessagePrefix: '\\x19Litecoin Signed Message:\\n',\r\n\t\t\tbech32: 'ltc',\r\n\t\t\tbip32: {\r\n\t\t\t\tpublic: 0x04b24746,\r\n\t\t\t\tprivate: 0x04b2430c,\r\n\t\t\t},\r\n\t\t\tpubKeyHash: 0x30,\r\n\t\t\tscriptHash: 0x32,\r\n\t\t\twif: 0xb0,\r\n\t\t},\r\n\t};\r\n\r\n\tprivate rootKey: BIP32Interface;\r\n\tprivate accountExtendedKey: BIP32Interface;\r\n\r\n\tprivate protocol: string;\r\n\tprivate mnemonicWord: string;\r\n\tprivate includePrivateKey: boolean;\r\n\tprivate seed: Buffer;\r\n\r\n\tprivate log: boolean;\r\n\r\n\t/**\r\n\t * Constructor\r\n\t *\r\n\t * @param {string} protocol\r\n\t * @param {string} mnemonicWord\r\n\t * @param {boolean} [includePrivateKey=false]\r\n\t * @param {boolean} [log=false]\r\n\t * @memberof HDWallet\r\n\t */\r\n\tconstructor(protocol: string, mnemonicWord: string, includePrivateKey: boolean = false, log: boolean = false) {\r\n\t\tthis.protocol = protocol;\r\n\t\tthis.mnemonicWord = mnemonicWord;\r\n\t\tthis.includePrivateKey = includePrivateKey;\r\n\t\tthis.seed = mnemonicToSeedSync(this.mnemonicWord);\r\n\t\tthis.log = log;\r\n\t}\r\n\r\n\t/**\r\n\t * Generate\r\n\t *\r\n\t * @param {string} path\r\n\t * @param {number} index\r\n\t * @return {*}  {string}\r\n\t * @memberof HDWallet\r\n\t */\r\n\tpublic generate(path: string, index: number): { publicKey: string; privateKey?: string } {\r\n\t\t// Concatenamos\r\n\t\tconst hdPath: string = 'm/' + path;\r\n\r\n\t\tif (this.log) {\r\n\t\t\tconsole.log('=========================');\r\n\t\t\tconsole.log('Mnemonic: %s', this.mnemonicWord);\r\n\t\t\tconsole.log('HD Path: %s\\r\\n', hdPath);\r\n\t\t}\r\n\r\n\t\t// Obtenemos la red si es el caso\r\n\t\tconst network: any = this.segwitParameters[this.protocol];\r\n\t\t// Instanciamos\r\n\t\tconst bip32: BIP32API = BIP32Factory(ecc);\r\n\t\t// Obtenemos la root key\r\n\t\tthis.rootKey = bip32.fromSeed(this.seed, network);\r\n\t\t// Obtenemos la clave extendida de la cuenta\r\n\t\tthis.accountExtendedKey = this.calcBip32ExtendedKey(this.rootKey, hdPath);\r\n\r\n\t\tif (this.log) {\r\n\t\t\t// Obtenemos la clave privada y pública\r\n\t\t\tconst accountXprv: string = this.accountExtendedKey.toBase58();\r\n\t\t\tconst accountXpub: string = this.accountExtendedKey.neutered().toBase58();\r\n\r\n\t\t\tconsole.log('Account Extended Private Key: %s \\r\\nAccount Extended Public Key: %s\\r\\n', accountXprv, accountXpub);\r\n\t\t}\r\n\r\n\t\t// Obtenemos el wallet\r\n\t\tconst keyPair: BIP32Interface = this.accountExtendedKey.derive(index);\r\n\r\n\t\tswitch (this.protocol) {\r\n\t\t\tcase 'bitcoin':\r\n\t\t\tcase 'bitcoinRegTest':\r\n\t\t\tcase 'litecoin': {\r\n\t\t\t\t// Extraemos la dirección\r\n\t\t\t\tconst { address: p2wpkhAddress } = payments.p2wpkh({ pubkey: keyPair.publicKey, network });\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(p2wpkhAddress, keyPair.toWIF(), keyPair.publicKey.toString('hex'));\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { publicKey: p2wpkhAddress, privateKey: keyPair.toWIF() };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { publicKey: p2wpkhAddress };\r\n\t\t\t}\r\n\t\t\tcase 'ethereum': {\r\n\t\t\t\t// Obtenemos el wallet\r\n\t\t\t\tconst ethereumWallet = hdkey.fromMasterSeed(this.seed).derivePath(hdPath).deriveChild(index).getWallet();\r\n\r\n\t\t\t\t// Obtenemos la dirección\r\n\t\t\t\tconst address: string = ethereumWallet.getAddressString();\r\n\t\t\t\t// Obtenemos la clave privada\r\n\t\t\t\tconst privateKey: string = ethereumWallet.getPrivateKeyString();\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(address, privateKey, ethereumWallet.getPublicKeyString());\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { publicKey: address, privateKey };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { publicKey: address };\r\n\t\t\t}\r\n\t\t\tcase 'ripple': {\r\n\t\t\t\t// Extraemos la dirección\r\n\t\t\t\tconst { address: xrpAddress } = payments.p2pkh({ pubkey: keyPair.publicKey });\r\n\r\n\t\t\t\t// Obtenemos la dirección\r\n\t\t\t\tconst address = this.convertRippleAdrr(xrpAddress);\r\n\t\t\t\t// Obtenemos la clave privada\r\n\t\t\t\tconst privateKey: string = keyPair.privateKey.toString('hex');\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(address, privateKey, keyPair.publicKey.toString('hex'));\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { publicKey: address, privateKey };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { publicKey: address };\r\n\t\t\t}\r\n\t\t\tcase 'tron': {\r\n\t\t\t\t// Obtenemos la clave pública en formato de ethereum\r\n\t\t\t\tconst ethPubKey: Buffer = importPublic(keyPair.publicKey);\r\n\r\n\t\t\t\t// Clave pública a dirección\r\n\t\t\t\tconst addressBuffer: Buffer = publicToAddress(ethPubKey);\r\n\t\t\t\t// Obtenemos la dirección\r\n\t\t\t\tconst address: string = bitcoinjsAddress.toBase58Check(addressBuffer, 0x41);\r\n\r\n\t\t\t\t// Obtenemos la clave privada\r\n\t\t\t\tconst privateKey: string = keyPair.privateKey.toString('hex');\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(address, privateKey, keyPair.publicKey.toString('hex'));\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { publicKey: address, privateKey };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { publicKey: address };\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * Calculate bip32 extended key by root key\r\n\t *\r\n\t * @private\r\n\t * @param {BIP32Interface} bip32RootKey\r\n\t * @param {string} path\r\n\t * @return {*}  {BIP32Interface}\r\n\t * @memberof HDWallet\r\n\t */\r\n\tprivate calcBip32ExtendedKey(bip32RootKey: BIP32Interface, path: string): BIP32Interface {\r\n\t\tlet extendedKey: BIP32Interface = bip32RootKey;\r\n\t\tconst pathBits: string[] = path.split('/');\r\n\r\n\t\tfor (let i = 0; i < pathBits.length; i++) {\r\n\t\t\tconst bit: string = pathBits[i];\r\n\t\t\tconst index: number = parseInt(bit);\r\n\r\n\t\t\tif (isNaN(index)) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\r\n\t\t\tconst hardened: boolean = bit[bit.length - 1] === \"'\";\r\n\r\n\t\t\tif (hardened) {\r\n\t\t\t\textendedKey = extendedKey.deriveHardened(index);\r\n\t\t\t} else {\r\n\t\t\t\textendedKey = extendedKey.derive(index);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\treturn extendedKey;\r\n\t}\r\n\r\n\t/**\r\n\t * Convert address to Ripple address\r\n\t *\r\n\t * @private\r\n\t * @param {string} address\r\n\t * @return {*}  {string}\r\n\t * @memberof HDWallet\r\n\t */\r\n\tprivate convertRippleAdrr(address: string): string {\r\n\t\treturn basex('rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz').encode(\r\n\t\t\tbasex('123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz').decode(address)\r\n\t\t);\r\n\t}\r\n\r\n\t/**\r\n\t * Print wallet\r\n\t *\r\n\t * @private\r\n\t * @param {string} address\r\n\t * @param {string} prvKey\r\n\t * @param {string} pubKey\r\n\t * @memberof HDWallet\r\n\t */\r\n\tprivate printWallet(address: string, prvKey: string, pubKey: string): void {\r\n\t\tconsole.log('Address: %s \\r\\nPrivate Key: %s \\r\\nPublic Key: %s \\r\\n=========================\\r\\n\\r\\n', address, prvKey, pubKey);\r\n\t}\r\n}\r\n\r\nexport default HDWallet;\r\n"],"mappings":"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"}
|
|
23
|
+
const{address:a}=_bitcoinjsLib.payments.p2wpkh({pubkey:f.publicKey,network:d}),b=f.publicKey.toString();// Obtenemos la clave pública
|
|
24
|
+
return this.log&&this.printWallet(a,f.toWIF(),b),this.includePrivateKey?{address:a,publicKey:b,privateKey:f.toWIF()}:{address:a,publicKey:b}}case"ethereum":{// Obtenemos el wallet
|
|
25
|
+
const a=_hdkey.default.fromMasterSeed(this.seed).derive(c).deriveChild(b),d="0x"+a.publicKey.toString("hex"),e="0x"+a.privateKey.toString("hex"),f=(0,_util.publicToAddress)(a.publicKey,!0),g=(0,_util.toChecksumAddress)("0x"+Buffer.from(f).toString("hex"));// Obtenemos la clave pública
|
|
26
|
+
// Obtenemos la clave privada
|
|
27
|
+
// Obtenemos la dirección
|
|
28
|
+
return this.log&&this.printWallet(g,e,d),this.includePrivateKey?{address:g,publicKey:d,privateKey:e}:{address:g,publicKey:d}}case"ripple":{// Extraemos la dirección
|
|
29
|
+
const{address:a}=_bitcoinjsLib.payments.p2pkh({pubkey:f.publicKey}),b=f.publicKey.toString(),c=f.privateKey.toString(),d=this.convertRippleAdrr(a);// Obtenemos la clave pública
|
|
30
|
+
// Obtenemos la clave privada
|
|
31
|
+
// Obtenemos la dirección
|
|
32
|
+
return this.log&&this.printWallet(d,c,b),this.includePrivateKey?{address:d,publicKey:b,privateKey:c}:{address:d,publicKey:b}}case"tron":{// Obtenemos la clave pública en formato de ethereum
|
|
33
|
+
const a=(0,_util.importPublic)(f.publicKey),b=f.publicKey.toString(),c=f.privateKey.toString(),d=(0,_util.publicToAddress)(a),e=_bitcoinjsLib.address.toBase58Check(d,65);// Obtenemos la clave pública
|
|
34
|
+
// Obtenemos la clave privada
|
|
35
|
+
// Clave pública a dirección
|
|
36
|
+
// Obtenemos la dirección
|
|
37
|
+
return this.log&&this.printWallet(e,c,b),this.includePrivateKey?{address:e,publicKey:b,privateKey:c}:{address:e,publicKey:b}}}}/**
|
|
38
|
+
* Calculate bip32 extended key by root key
|
|
39
|
+
*
|
|
40
|
+
* @private
|
|
41
|
+
* @param {BIP32Interface} bip32RootKey
|
|
42
|
+
* @param {string} path
|
|
43
|
+
* @return {*} {BIP32Interface}
|
|
44
|
+
* @memberof HDWallet
|
|
45
|
+
*/calcBip32ExtendedKey(a,b){let c=a;const d=b.split("/");for(let e=0;e<d.length;e++){const a=d[e],b=parseInt(a);if(isNaN(b))continue;const f="'"===a[a.length-1];c=f?c.deriveHardened(b):c.derive(b)}return c;}/**
|
|
46
|
+
* Convert address to Ripple address
|
|
47
|
+
*
|
|
48
|
+
* @private
|
|
49
|
+
* @param {string} address
|
|
50
|
+
* @return {*} {string}
|
|
51
|
+
* @memberof HDWallet
|
|
52
|
+
*/convertRippleAdrr(a){return(0,_baseX.default)("rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz").encode((0,_baseX.default)("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz").decode(a));}/**
|
|
53
|
+
* Print wallet
|
|
54
|
+
*
|
|
55
|
+
* @private
|
|
56
|
+
* @param {string} address
|
|
57
|
+
* @param {string} prvKey
|
|
58
|
+
* @param {string} pubKey
|
|
59
|
+
* @memberof HDWallet
|
|
60
|
+
*/printWallet(a,b,c){console.log("Address: %s \r\nPrivate Key: %s \r\nPublic Key: %s \r\n=========================\r\n\r\n",a,b,c)}}var _default=exports.default=HDWallet;
|
|
61
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HDWallet","constructor","protocol","mnemonicWord","includePrivateKey","log","_defineProperty2","default","bitcoin","messagePrefix","bech32","bip32","public","private","pubKeyHash","scriptHash","wif","bitcoinRegTest","litecoin","seed","mnemonicToSeedSync","generate","path","index","hdPath","console","network","segwitParameters","BIP32Factory","ecc","rootKey","fromSeed","accountExtendedKey","calcBip32ExtendedKey","accountXprv","toBase58","accountXpub","neutered","keyPair","derive","address","p2wpkhAddress","payments","p2wpkh","pubkey","publicKey","toString","printWallet","toWIF","privateKey","ethereumWallet","hdkey","fromMasterSeed","deriveChild","addressBuffer","publicToAddress","toChecksumAddress","Buffer","from","xrpAddress","p2pkh","convertRippleAdrr","ethPubKey","importPublic","bitcoinjsAddress","toBase58Check","bip32RootKey","extendedKey","pathBits","split","i","length","bit","parseInt","isNaN","hardened","deriveHardened","basex","encode","decode","prvKey","pubKey","_default","exports"],"sources":["../src/index.ts"],"sourcesContent":["import { importPublic, publicToAddress, toChecksumAddress } from '@ethereumjs/util';\nimport basex from 'base-x';\nimport BIP32Factory, { BIP32API, BIP32Interface } from 'bip32';\nimport { mnemonicToSeedSync } from 'bip39';\nimport { address as bitcoinjsAddress, payments } from 'bitcoinjs-lib';\nimport hdkey from 'hdkey';\nimport * as ecc from 'tiny-secp256k1';\n\nclass HDWallet {\n\tprivate segwitParameters: { [key: string]: any } = {\n\t\tbitcoin: {\n\t\t\tmessagePrefix: '\\x18Bitcoin Signed Message:\\n',\n\t\t\tbech32: 'bc',\n\t\t\tbip32: {\n\t\t\t\tpublic: 0x04b24746,\n\t\t\t\tprivate: 0x04b2430c,\n\t\t\t},\n\t\t\tpubKeyHash: 0x00,\n\t\t\tscriptHash: 0x05,\n\t\t\twif: 0x80,\n\t\t},\n\t\tbitcoinRegTest: {\n\t\t\tmessagePrefix: '\\x18Bitcoin Signed Message:\\n',\n\t\t\tbech32: 'bcrt',\n\t\t\tbip32: {\n\t\t\t\tpublic: 0x043587cf,\n\t\t\t\tprivate: 0x04358394,\n\t\t\t},\n\t\t\tpubKeyHash: 0x6f,\n\t\t\tscriptHash: 0xc4,\n\t\t\twif: 0xef,\n\t\t},\n\t\tlitecoin: {\n\t\t\tmessagePrefix: '\\x19Litecoin Signed Message:\\n',\n\t\t\tbech32: 'ltc',\n\t\t\tbip32: {\n\t\t\t\tpublic: 0x04b24746,\n\t\t\t\tprivate: 0x04b2430c,\n\t\t\t},\n\t\t\tpubKeyHash: 0x30,\n\t\t\tscriptHash: 0x32,\n\t\t\twif: 0xb0,\n\t\t},\n\t};\n\n\tprivate rootKey: BIP32Interface;\n\tprivate accountExtendedKey: BIP32Interface;\n\n\tprivate protocol: string;\n\tprivate mnemonicWord: string;\n\tprivate includePrivateKey: boolean;\n\tprivate seed: Buffer;\n\n\tprivate log: boolean;\n\n\t/**\n\t * Constructor\n\t *\n\t * @param {string} protocol\n\t * @param {string} mnemonicWord\n\t * @param {boolean} [includePrivateKey=false]\n\t * @param {boolean} [log=false]\n\t * @memberof HDWallet\n\t */\n\tconstructor(protocol: string, mnemonicWord: string, includePrivateKey: boolean = false, log: boolean = false) {\n\t\tthis.protocol = protocol;\n\t\tthis.mnemonicWord = mnemonicWord;\n\t\tthis.includePrivateKey = includePrivateKey;\n\t\tthis.seed = mnemonicToSeedSync(this.mnemonicWord);\n\t\tthis.log = log;\n\t}\n\n\t/**\n\t * Generate\n\t *\n\t * @param {string} path\n\t * @param {number} index\n\t * @return {*}  {string}\n\t * @memberof HDWallet\n\t */\n\tpublic generate(path: string, index: number): { address: string; publicKey: string; privateKey?: string } {\n\t\t// Concatenamos\n\t\tconst hdPath: string = 'm/' + path;\n\n\t\tif (this.log) {\n\t\t\tconsole.log('=========================');\n\t\t\tconsole.log('Mnemonic: %s', this.mnemonicWord);\n\t\t\tconsole.log('HD Path: %s\\r\\n', hdPath);\n\t\t}\n\n\t\t// Obtenemos la red si es el caso\n\t\tconst network: any = this.segwitParameters[this.protocol];\n\t\t// Instanciamos\n\t\tconst bip32: BIP32API = BIP32Factory(ecc);\n\t\t// Obtenemos la root key\n\t\tthis.rootKey = bip32.fromSeed(this.seed, network);\n\t\t// Obtenemos la clave extendida de la cuenta\n\t\tthis.accountExtendedKey = this.calcBip32ExtendedKey(this.rootKey, hdPath);\n\n\t\tif (this.log) {\n\t\t\t// Obtenemos la clave privada y pública\n\t\t\tconst accountXprv: string = this.accountExtendedKey.toBase58();\n\t\t\tconst accountXpub: string = this.accountExtendedKey.neutered().toBase58();\n\n\t\t\tconsole.log('Account Extended Private Key: %s \\r\\nAccount Extended Public Key: %s\\r\\n', accountXprv, accountXpub);\n\t\t}\n\n\t\t// Obtenemos el wallet\n\t\tconst keyPair: BIP32Interface = this.accountExtendedKey.derive(index);\n\n\t\tswitch (this.protocol) {\n\t\t\tcase 'bitcoin':\n\t\t\tcase 'bitcoinRegTest':\n\t\t\tcase 'litecoin': {\n\t\t\t\t// Extraemos la dirección\n\t\t\t\tconst { address: p2wpkhAddress } = payments.p2wpkh({ pubkey: keyPair.publicKey, network });\n\n\t\t\t\t// Obtenemos la clave pública\n\t\t\t\tconst publicKey = keyPair.publicKey.toString();\n\n\t\t\t\tif (this.log) {\n\t\t\t\t\tthis.printWallet(p2wpkhAddress, keyPair.toWIF(), publicKey);\n\t\t\t\t}\n\n\t\t\t\tif (this.includePrivateKey) {\n\t\t\t\t\treturn { address: p2wpkhAddress, publicKey, privateKey: keyPair.toWIF() };\n\t\t\t\t}\n\n\t\t\t\treturn { address: p2wpkhAddress, publicKey };\n\t\t\t}\n\t\t\tcase 'ethereum': {\n\t\t\t\t// Obtenemos el wallet\n\t\t\t\tconst ethereumWallet = hdkey.fromMasterSeed(this.seed).derive(hdPath).deriveChild(index);\n\n\t\t\t\t// Obtenemos la clave pública\n\t\t\t\tconst publicKey = '0x' + ethereumWallet.publicKey.toString('hex');\n\n\t\t\t\t// Obtenemos la clave privada\n\t\t\t\tconst privateKey: string = '0x' + ethereumWallet.privateKey.toString('hex');\n\n\t\t\t\t// Obtenemos la dirección\n\t\t\t\tconst addressBuffer = publicToAddress(ethereumWallet.publicKey, true);\n\t\t\t\tconst address: string = toChecksumAddress('0x' + Buffer.from(addressBuffer).toString('hex'));\n\n\t\t\t\tif (this.log) {\n\t\t\t\t\tthis.printWallet(address, privateKey, publicKey);\n\t\t\t\t}\n\n\t\t\t\tif (this.includePrivateKey) {\n\t\t\t\t\treturn { address, publicKey, privateKey };\n\t\t\t\t}\n\n\t\t\t\treturn { address, publicKey };\n\t\t\t}\n\t\t\tcase 'ripple': {\n\t\t\t\t// Extraemos la dirección\n\t\t\t\tconst { address: xrpAddress } = payments.p2pkh({ pubkey: keyPair.publicKey });\n\n\t\t\t\t// Obtenemos la clave pública\n\t\t\t\tconst publicKey = keyPair.publicKey.toString();\n\n\t\t\t\t// Obtenemos la clave privada\n\t\t\t\tconst privateKey: string = keyPair.privateKey.toString();\n\n\t\t\t\t// Obtenemos la dirección\n\t\t\t\tconst address = this.convertRippleAdrr(xrpAddress);\n\n\t\t\t\tif (this.log) {\n\t\t\t\t\tthis.printWallet(address, privateKey, publicKey);\n\t\t\t\t}\n\n\t\t\t\tif (this.includePrivateKey) {\n\t\t\t\t\treturn { address, publicKey, privateKey };\n\t\t\t\t}\n\n\t\t\t\treturn { address, publicKey };\n\t\t\t}\n\t\t\tcase 'tron': {\n\t\t\t\t// Obtenemos la clave pública en formato de ethereum\n\t\t\t\tconst ethPubKey = importPublic(keyPair.publicKey);\n\n\t\t\t\t// Obtenemos la clave pública\n\t\t\t\tconst publicKey = keyPair.publicKey.toString();\n\n\t\t\t\t// Obtenemos la clave privada\n\t\t\t\tconst privateKey: string = keyPair.privateKey.toString();\n\n\t\t\t\t// Clave pública a dirección\n\t\t\t\tconst addressBuffer = publicToAddress(ethPubKey);\n\t\t\t\t// Obtenemos la dirección\n\t\t\t\tconst address: string = bitcoinjsAddress.toBase58Check(addressBuffer, 0x41);\n\n\t\t\t\tif (this.log) {\n\t\t\t\t\tthis.printWallet(address, privateKey, publicKey);\n\t\t\t\t}\n\n\t\t\t\tif (this.includePrivateKey) {\n\t\t\t\t\treturn { address, publicKey, privateKey };\n\t\t\t\t}\n\n\t\t\t\treturn { address, publicKey };\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Calculate bip32 extended key by root key\n\t *\n\t * @private\n\t * @param {BIP32Interface} bip32RootKey\n\t * @param {string} path\n\t * @return {*}  {BIP32Interface}\n\t * @memberof HDWallet\n\t */\n\tprivate calcBip32ExtendedKey(bip32RootKey: BIP32Interface, path: string): BIP32Interface {\n\t\tlet extendedKey: BIP32Interface = bip32RootKey;\n\t\tconst pathBits: string[] = path.split('/');\n\n\t\tfor (let i = 0; i < pathBits.length; i++) {\n\t\t\tconst bit: string = pathBits[i];\n\t\t\tconst index: number = parseInt(bit);\n\n\t\t\tif (isNaN(index)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tconst hardened: boolean = bit[bit.length - 1] === \"'\";\n\n\t\t\tif (hardened) {\n\t\t\t\textendedKey = extendedKey.deriveHardened(index);\n\t\t\t} else {\n\t\t\t\textendedKey = extendedKey.derive(index);\n\t\t\t}\n\t\t}\n\n\t\treturn extendedKey;\n\t}\n\n\t/**\n\t * Convert address to Ripple address\n\t *\n\t * @private\n\t * @param {string} address\n\t * @return {*}  {string}\n\t * @memberof HDWallet\n\t */\n\tprivate convertRippleAdrr(address: string): string {\n\t\treturn basex('rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz').encode(\n\t\t\tbasex('123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz').decode(address),\n\t\t);\n\t}\n\n\t/**\n\t * Print wallet\n\t *\n\t * @private\n\t * @param {string} address\n\t * @param {string} prvKey\n\t * @param {string} pubKey\n\t * @memberof HDWallet\n\t */\n\tprivate printWallet(address: string, prvKey: string, pubKey: string): void {\n\t\tconsole.log('Address: %s \\r\\nPrivate Key: %s \\r\\nPublic Key: %s \\r\\n=========================\\r\\n\\r\\n', address, prvKey, pubKey);\n\t}\n}\n\nexport default HDWallet;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,62 +1,63 @@
|
|
|
1
|
-
declare class HDWallet {
|
|
2
|
-
private segwitParameters;
|
|
3
|
-
private rootKey;
|
|
4
|
-
private accountExtendedKey;
|
|
5
|
-
private protocol;
|
|
6
|
-
private mnemonicWord;
|
|
7
|
-
private includePrivateKey;
|
|
8
|
-
private seed;
|
|
9
|
-
private log;
|
|
10
|
-
/**
|
|
11
|
-
* Constructor
|
|
12
|
-
*
|
|
13
|
-
* @param {string} protocol
|
|
14
|
-
* @param {string} mnemonicWord
|
|
15
|
-
* @param {boolean} [includePrivateKey=false]
|
|
16
|
-
* @param {boolean} [log=false]
|
|
17
|
-
* @memberof HDWallet
|
|
18
|
-
*/
|
|
19
|
-
constructor(protocol: string, mnemonicWord: string, includePrivateKey?: boolean, log?: boolean);
|
|
20
|
-
/**
|
|
21
|
-
* Generate
|
|
22
|
-
*
|
|
23
|
-
* @param {string} path
|
|
24
|
-
* @param {number} index
|
|
25
|
-
* @return {*} {string}
|
|
26
|
-
* @memberof HDWallet
|
|
27
|
-
*/
|
|
28
|
-
generate(path: string, index: number): {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
*
|
|
35
|
-
*
|
|
36
|
-
* @
|
|
37
|
-
* @param {
|
|
38
|
-
* @
|
|
39
|
-
* @
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
*
|
|
45
|
-
*
|
|
46
|
-
* @
|
|
47
|
-
* @
|
|
48
|
-
* @
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
*
|
|
54
|
-
*
|
|
55
|
-
* @
|
|
56
|
-
* @param {string}
|
|
57
|
-
* @param {string}
|
|
58
|
-
* @
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
1
|
+
declare class HDWallet {
|
|
2
|
+
private segwitParameters;
|
|
3
|
+
private rootKey;
|
|
4
|
+
private accountExtendedKey;
|
|
5
|
+
private protocol;
|
|
6
|
+
private mnemonicWord;
|
|
7
|
+
private includePrivateKey;
|
|
8
|
+
private seed;
|
|
9
|
+
private log;
|
|
10
|
+
/**
|
|
11
|
+
* Constructor
|
|
12
|
+
*
|
|
13
|
+
* @param {string} protocol
|
|
14
|
+
* @param {string} mnemonicWord
|
|
15
|
+
* @param {boolean} [includePrivateKey=false]
|
|
16
|
+
* @param {boolean} [log=false]
|
|
17
|
+
* @memberof HDWallet
|
|
18
|
+
*/
|
|
19
|
+
constructor(protocol: string, mnemonicWord: string, includePrivateKey?: boolean, log?: boolean);
|
|
20
|
+
/**
|
|
21
|
+
* Generate
|
|
22
|
+
*
|
|
23
|
+
* @param {string} path
|
|
24
|
+
* @param {number} index
|
|
25
|
+
* @return {*} {string}
|
|
26
|
+
* @memberof HDWallet
|
|
27
|
+
*/
|
|
28
|
+
generate(path: string, index: number): {
|
|
29
|
+
address: string;
|
|
30
|
+
publicKey: string;
|
|
31
|
+
privateKey?: string;
|
|
32
|
+
};
|
|
33
|
+
/**
|
|
34
|
+
* Calculate bip32 extended key by root key
|
|
35
|
+
*
|
|
36
|
+
* @private
|
|
37
|
+
* @param {BIP32Interface} bip32RootKey
|
|
38
|
+
* @param {string} path
|
|
39
|
+
* @return {*} {BIP32Interface}
|
|
40
|
+
* @memberof HDWallet
|
|
41
|
+
*/
|
|
42
|
+
private calcBip32ExtendedKey;
|
|
43
|
+
/**
|
|
44
|
+
* Convert address to Ripple address
|
|
45
|
+
*
|
|
46
|
+
* @private
|
|
47
|
+
* @param {string} address
|
|
48
|
+
* @return {*} {string}
|
|
49
|
+
* @memberof HDWallet
|
|
50
|
+
*/
|
|
51
|
+
private convertRippleAdrr;
|
|
52
|
+
/**
|
|
53
|
+
* Print wallet
|
|
54
|
+
*
|
|
55
|
+
* @private
|
|
56
|
+
* @param {string} address
|
|
57
|
+
* @param {string} prvKey
|
|
58
|
+
* @param {string} pubKey
|
|
59
|
+
* @memberof HDWallet
|
|
60
|
+
*/
|
|
61
|
+
private printWallet;
|
|
62
|
+
}
|
|
63
|
+
export default HDWallet;
|
package/package.json
CHANGED
|
@@ -1,11 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@samyan/hd-wallet",
|
|
3
|
-
"version": "1.0
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "build/index.js",
|
|
6
6
|
"scripts": {
|
|
7
7
|
"build": "babel src --out-dir build --extensions \".ts\" --source-maps inline",
|
|
8
|
-
"build-ts": "tsc"
|
|
8
|
+
"build-ts": "tsc",
|
|
9
|
+
"test": "vitest",
|
|
10
|
+
"test:watch": "vitest --watch",
|
|
11
|
+
"prepublishOnly": "npm run build && npm test"
|
|
9
12
|
},
|
|
10
13
|
"keywords": [
|
|
11
14
|
"crypto",
|
|
@@ -15,22 +18,25 @@
|
|
|
15
18
|
"author": "samyan",
|
|
16
19
|
"license": "ISC",
|
|
17
20
|
"devDependencies": {
|
|
18
|
-
"@babel/cli": "^7.
|
|
19
|
-
"@babel/core": "^7.
|
|
20
|
-
"@babel/plugin-proposal-decorators": "^7.
|
|
21
|
-
"@babel/plugin-transform-runtime": "^7.
|
|
22
|
-
"@babel/preset-env": "^7.
|
|
23
|
-
"@babel/preset-typescript": "^7.
|
|
21
|
+
"@babel/cli": "^7.28.6",
|
|
22
|
+
"@babel/core": "^7.29.0",
|
|
23
|
+
"@babel/plugin-proposal-decorators": "^7.29.0",
|
|
24
|
+
"@babel/plugin-transform-runtime": "^7.29.0",
|
|
25
|
+
"@babel/preset-env": "^7.29.2",
|
|
26
|
+
"@babel/preset-typescript": "^7.28.5",
|
|
27
|
+
"@types/hdkey": "^2.1.0",
|
|
28
|
+
"@types/node": "^25.5.0",
|
|
24
29
|
"babel-preset-minify": "^0.5.2",
|
|
25
|
-
"typescript": "^
|
|
30
|
+
"typescript": "^6.0.2",
|
|
31
|
+
"vitest": "^4.1.2"
|
|
26
32
|
},
|
|
27
33
|
"dependencies": {
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"
|
|
31
|
-
"
|
|
32
|
-
"
|
|
33
|
-
"
|
|
34
|
-
"tiny-secp256k1": "^2.2.
|
|
34
|
+
"@ethereumjs/util": "^10.1.1",
|
|
35
|
+
"base-x": "^5.0.1",
|
|
36
|
+
"bip32": "^5.0.1",
|
|
37
|
+
"bip39": "^3.1.0",
|
|
38
|
+
"bitcoinjs-lib": "^7.0.1",
|
|
39
|
+
"hdkey": "^2.1.0",
|
|
40
|
+
"tiny-secp256k1": "^2.2.4"
|
|
35
41
|
}
|
|
36
42
|
}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import HDWallet from '../src/index';
|
|
3
|
+
|
|
4
|
+
const MNEMONIC = 'test test test test test test test test test test test junk';
|
|
5
|
+
|
|
6
|
+
describe('HDWallet', () => {
|
|
7
|
+
describe('Ethereum', () => {
|
|
8
|
+
it('deriva siempre la misma direccion (determinismo)', () => {
|
|
9
|
+
const wallet1 = new HDWallet('ethereum', MNEMONIC);
|
|
10
|
+
|
|
11
|
+
const result1 = wallet1.generate("44'/60'/0'/0", 0);
|
|
12
|
+
|
|
13
|
+
expect(result1.address).toBe('0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266');
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
it('genera direccion valida (formato 0x)', () => {
|
|
17
|
+
const wallet = new HDWallet('ethereum', MNEMONIC);
|
|
18
|
+
|
|
19
|
+
const { address } = wallet.generate("44'/60'/0'/0", 0);
|
|
20
|
+
|
|
21
|
+
expect(address.startsWith('0x')).toBe(true);
|
|
22
|
+
expect(address.length).toBe(42);
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('incluye privateKey cuando includePrivateKey=true', () => {
|
|
26
|
+
const wallet = new HDWallet('ethereum', MNEMONIC, true, true);
|
|
27
|
+
|
|
28
|
+
const result = wallet.generate("44'/60'/0'/0", 0);
|
|
29
|
+
|
|
30
|
+
expect(result.privateKey).toBeDefined();
|
|
31
|
+
expect(result.privateKey?.length).toBeGreaterThan(0);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('genera publicKey válida', () => {
|
|
35
|
+
const wallet = new HDWallet('ethereum', MNEMONIC);
|
|
36
|
+
|
|
37
|
+
const { publicKey } = wallet.generate("44'/60'/0'/0", 0);
|
|
38
|
+
|
|
39
|
+
expect(publicKey).toMatch(/^0x[0-9a-fA-F]+$/);
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
describe('Bitcoin (SegWit)', () => {
|
|
44
|
+
it('genera direccion bech32 valida', () => {
|
|
45
|
+
const wallet = new HDWallet('bitcoin', MNEMONIC);
|
|
46
|
+
|
|
47
|
+
const { address } = wallet.generate("84'/0'/0'/0", 0);
|
|
48
|
+
|
|
49
|
+
expect(address.startsWith('bc1')).toBe(true);
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
it('determinismo bitcoin', () => {
|
|
53
|
+
const wallet = new HDWallet('bitcoin', MNEMONIC);
|
|
54
|
+
|
|
55
|
+
const a = wallet.generate("84'/0'/0'/0", 0);
|
|
56
|
+
const b = wallet.generate("84'/0'/0'/0", 0);
|
|
57
|
+
|
|
58
|
+
expect(a.address).toBe(b.address);
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
describe('Litecoin', () => {
|
|
63
|
+
it('genera direccion valida', () => {
|
|
64
|
+
const wallet = new HDWallet('litecoin', MNEMONIC);
|
|
65
|
+
|
|
66
|
+
const { address } = wallet.generate("84'/2'/0'/0", 0);
|
|
67
|
+
|
|
68
|
+
expect(address).toBeDefined();
|
|
69
|
+
expect(address.length).toBeGreaterThan(0);
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
describe('Tron', () => {
|
|
74
|
+
it('genera direccion valida (Base58 tron)', () => {
|
|
75
|
+
const wallet = new HDWallet('tron', MNEMONIC);
|
|
76
|
+
|
|
77
|
+
const { address } = wallet.generate("44'/195'/0'/0", 0);
|
|
78
|
+
|
|
79
|
+
expect(address.startsWith('T')).toBe(true);
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
it('deriva siempre la misma direccion (determinismo)', () => {
|
|
83
|
+
const wallet1 = new HDWallet('tron', MNEMONIC);
|
|
84
|
+
|
|
85
|
+
const result1 = wallet1.generate("44'/195'/0'/0", 0);
|
|
86
|
+
|
|
87
|
+
expect(result1.address).toBe('TWer2Ygk5TEheHp3TPuYeqxmB6SsGZmaL6');
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
describe('Ripple', () => {
|
|
92
|
+
it('genera direccion ripple valida', () => {
|
|
93
|
+
const wallet = new HDWallet('ripple', MNEMONIC);
|
|
94
|
+
|
|
95
|
+
const { address } = wallet.generate("44'/144'/0'/0", 0);
|
|
96
|
+
|
|
97
|
+
expect(address.startsWith('r')).toBe(true);
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
|
|
101
|
+
describe('Edge cases', () => {
|
|
102
|
+
it('indices distintos generan direcciones distintas', () => {
|
|
103
|
+
const wallet = new HDWallet('ethereum', MNEMONIC);
|
|
104
|
+
|
|
105
|
+
const a = wallet.generate("44'/60'/0'/0", 0);
|
|
106
|
+
const b = wallet.generate("44'/60'/0'/0", 1);
|
|
107
|
+
|
|
108
|
+
expect(a.address).not.toBe(b.address);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('paths distintos generan direcciones distintas', () => {
|
|
112
|
+
const wallet = new HDWallet('ethereum', MNEMONIC);
|
|
113
|
+
|
|
114
|
+
const a = wallet.generate("44'/60'/0'/0", 0);
|
|
115
|
+
const b = wallet.generate("44'/60'/1'/0", 0);
|
|
116
|
+
|
|
117
|
+
expect(a.address).not.toBe(b.address);
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
});
|
package/tsconfig.json
CHANGED
|
@@ -1,20 +1,27 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"module": "commonjs",
|
|
4
|
-
"esModuleInterop": true,
|
|
5
|
-
"target": "es2016",
|
|
6
|
-
"lib": [
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
"
|
|
10
|
-
"
|
|
11
|
-
"
|
|
12
|
-
"
|
|
13
|
-
"
|
|
14
|
-
"
|
|
15
|
-
"
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"module": "commonjs",
|
|
4
|
+
"esModuleInterop": true,
|
|
5
|
+
"target": "es2016",
|
|
6
|
+
"lib": [
|
|
7
|
+
"es2016"
|
|
8
|
+
],
|
|
9
|
+
"strict": false,
|
|
10
|
+
"declaration": true,
|
|
11
|
+
"emitDeclarationOnly": true,
|
|
12
|
+
"moduleResolution": "node",
|
|
13
|
+
"forceConsistentCasingInFileNames": true,
|
|
14
|
+
"sourceMap": true,
|
|
15
|
+
"outDir": "build",
|
|
16
|
+
"baseUrl": ".",
|
|
17
|
+
"paths": {
|
|
18
|
+
"*": [
|
|
19
|
+
"node_modules/*",
|
|
20
|
+
"src/types/*"
|
|
21
|
+
]
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
"include": [
|
|
25
|
+
"src/**/*"
|
|
26
|
+
]
|
|
27
|
+
}
|