@samyan/hd-wallet 1.0.4 → 1.1.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.
@@ -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
- "legacy": true
19
- }
20
- ],
21
- [
22
- "@babel/plugin-transform-runtime",
23
- {
24
- "regenerator": true
25
- }
26
- ],
27
- "@babel/plugin-proposal-class-properties"
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.d.ts CHANGED
@@ -1,63 +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
- 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;
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/build/index.js CHANGED
@@ -1,53 +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"),_ethereumjsUtil=require("ethereumjs-util"),_ethereumjsWallet=require("ethereumjs-wallet"),ecc=_interopRequireWildcard(require("tiny-secp256k1"));function _getRequireWildcardCache(a){if("function"!=typeof WeakMap)return null;var b=new WeakMap,c=new WeakMap;return(_getRequireWildcardCache=function(a){return a?c:b})(a)}function _interopRequireWildcard(a,b){if(!b&&a&&a.__esModule)return a;if(null===a||"object"!=typeof a&&"function"!=typeof a)return{default:a};var c=_getRequireWildcardCache(b);if(c&&c.has(a))return c.get(a);var d={},e=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var f in a)if("default"!=f&&Object.prototype.hasOwnProperty.call(a,f)){var g=e?Object.getOwnPropertyDescriptor(a,f):null;g&&(g.get||g.set)?Object.defineProperty(d,f,g):d[f]=a[f]}return d.default=a,c&&c.set(a,d),d}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
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}),b=f.publicKey.toString("hex");// Obtenemos la clave pública
23
+ const{address:a}=_bitcoinjsLib.payments.p2wpkh({pubkey:f.publicKey,network:d}),b=f.publicKey.toString();// Obtenemos la clave pública
23
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
24
- const a=_ethereumjsWallet.hdkey.fromMasterSeed(this.seed).derivePath(c).deriveChild(b).getWallet(),d=a.getPublicKeyString(),e=a.getPrivateKeyString(),f=a.getAddressString();// Obtenemos la clave pública
25
- return this.log&&this.printWallet(f,e,d),this.includePrivateKey?{address:f,publicKey:d,privateKey:e}:{address:f,publicKey:d}}case"ripple":{// Extraemos la dirección
26
- const{address:a}=_bitcoinjsLib.payments.p2pkh({pubkey:f.publicKey}),b=f.publicKey.toString("hex"),c=f.privateKey.toString("hex"),d=this.convertRippleAdrr(a);// Obtenemos la clave pública
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
27
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
28
- const a=(0,_ethereumjsUtil.importPublic)(f.publicKey),b=f.publicKey.toString("hex"),c=f.privateKey.toString("hex"),d=(0,_ethereumjsUtil.publicToAddress)(a),e=_bitcoinjsLib.address.toBase58Check(d,65);// Obtenemos la clave pública
29
- return this.log&&this.printWallet(e,c,f.publicKey.toString("hex")),this.includePrivateKey?{address:e,publicKey:b,privateKey:c}:{address:e,publicKey:b}}}}/**
30
- * Calculate bip32 extended key by root key
31
- *
32
- * @private
33
- * @param {BIP32Interface} bip32RootKey
34
- * @param {string} path
35
- * @return {*} {BIP32Interface}
36
- * @memberof HDWallet
37
- */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}/**
38
- * Convert address to Ripple address
39
- *
40
- * @private
41
- * @param {string} address
42
- * @return {*} {string}
43
- * @memberof HDWallet
44
- */convertRippleAdrr(a){return(0,_baseX.default)("rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz").encode((0,_baseX.default)("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz").decode(a))}/**
45
- * Print wallet
46
- *
47
- * @private
48
- * @param {string} address
49
- * @param {string} prvKey
50
- * @param {string} pubKey
51
- * @memberof HDWallet
52
- */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=HDWallet;exports.default=_default;
53
- //# 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","derivePath","deriveChild","getWallet","getPublicKeyString","getPrivateKeyString","getAddressString","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): { address: string; 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\t// Obtenemos la clave pública\r\n\t\t\t\tconst publicKey = keyPair.publicKey.toString('hex');\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(p2wpkhAddress, keyPair.toWIF(), publicKey);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { address: p2wpkhAddress, publicKey, privateKey: keyPair.toWIF() };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { address: p2wpkhAddress, publicKey };\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 clave pública\r\n\t\t\t\tconst publicKey = ethereumWallet.getPublicKeyString();\r\n\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\t// Obtenemos la dirección\r\n\t\t\t\tconst address: string = ethereumWallet.getAddressString();\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(address, privateKey, publicKey);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { address, publicKey, privateKey };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { address, publicKey };\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 clave pública\r\n\t\t\t\tconst publicKey = keyPair.publicKey.toString('hex');\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\t// Obtenemos la dirección\r\n\t\t\t\tconst address = this.convertRippleAdrr(xrpAddress);\r\n\r\n\t\t\t\tif (this.log) {\r\n\t\t\t\t\tthis.printWallet(address, privateKey, publicKey);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif (this.includePrivateKey) {\r\n\t\t\t\t\treturn { address, publicKey, privateKey };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { address, publicKey };\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// Obtenemos la clave pública\r\n\t\t\t\tconst publicKey = keyPair.publicKey.toString('hex');\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\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\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 { address, publicKey, privateKey };\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn { address, publicKey };\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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"}
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":[]}
@@ -0,0 +1,8 @@
1
+ services:
2
+ hd-wallet:
3
+ image: node:20-alpine
4
+ container_name: hd-wallet
5
+ working_dir: /app
6
+ command: sh -c "npm install -g npm@latest && tail -f /dev/null"
7
+ volumes:
8
+ - .:/app
package/package.json CHANGED
@@ -1,11 +1,14 @@
1
1
  {
2
2
  "name": "@samyan/hd-wallet",
3
- "version": "1.0.4",
3
+ "version": "1.1.1",
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.21.0",
19
- "@babel/core": "^7.21.0",
20
- "@babel/plugin-proposal-decorators": "^7.21.0",
21
- "@babel/plugin-transform-runtime": "^7.21.0",
22
- "@babel/preset-env": "^7.20.2",
23
- "@babel/preset-typescript": "^7.21.0",
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": "^4.9.5"
30
+ "typescript": "^6.0.2",
31
+ "vitest": "^4.1.2"
26
32
  },
27
33
  "dependencies": {
28
- "base-x": "^4.0.0",
29
- "bip32": "^3.1.0",
30
- "bip39": "^3.0.4",
31
- "bitcoinjs-lib": "^6.1.0",
32
- "ethereumjs-util": "^7.1.5",
33
- "ethereumjs-wallet": "^1.0.2",
34
- "tiny-secp256k1": "^2.2.1"
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": ["es2016"],
7
- "strict": false,
8
- "declaration": true,
9
- "emitDeclarationOnly": true,
10
- "moduleResolution": "node",
11
- "forceConsistentCasingInFileNames": true,
12
- "sourceMap": true,
13
- "outDir": "build",
14
- "baseUrl": ".",
15
- "paths": {
16
- "*": ["node_modules/*", "src/types/*"]
17
- }
18
- },
19
- "include": ["src/**/*"]
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
+ }