@bsv/sdk 1.0.12 → 1.0.14

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.
Files changed (119) hide show
  1. package/dist/cjs/package.json +1 -1
  2. package/dist/cjs/src/compat/BSM.js.map +1 -1
  3. package/dist/cjs/src/compat/ECIES.js +105 -76
  4. package/dist/cjs/src/compat/ECIES.js.map +1 -1
  5. package/dist/cjs/src/compat/HD.js +65 -65
  6. package/dist/cjs/src/compat/HD.js.map +1 -1
  7. package/dist/cjs/src/compat/Mnemonic.js +79 -79
  8. package/dist/cjs/src/compat/Mnemonic.js.map +1 -1
  9. package/dist/cjs/src/compat/bip-39-wordlist-en.js +2 -2
  10. package/dist/cjs/src/compat/bip-39-wordlist-en.js.map +1 -1
  11. package/dist/cjs/src/primitives/AESGCM.js.map +1 -1
  12. package/dist/cjs/src/primitives/BigNumber.js.map +1 -1
  13. package/dist/cjs/src/primitives/DRBG.js.map +1 -1
  14. package/dist/cjs/src/primitives/ECDSA.js.map +1 -1
  15. package/dist/cjs/src/primitives/Hash.js +26 -13
  16. package/dist/cjs/src/primitives/Hash.js.map +1 -1
  17. package/dist/cjs/src/primitives/PrivateKey.js +3 -2
  18. package/dist/cjs/src/primitives/PrivateKey.js.map +1 -1
  19. package/dist/cjs/src/primitives/PublicKey.js +1 -2
  20. package/dist/cjs/src/primitives/PublicKey.js.map +1 -1
  21. package/dist/cjs/src/primitives/Random.js +2 -2
  22. package/dist/cjs/src/primitives/Random.js.map +1 -1
  23. package/dist/cjs/src/primitives/Signature.js +141 -4
  24. package/dist/cjs/src/primitives/Signature.js.map +1 -1
  25. package/dist/cjs/src/primitives/SymmetricKey.js.map +1 -1
  26. package/dist/cjs/src/primitives/TransactionSignature.js.map +1 -1
  27. package/dist/cjs/src/primitives/utils.js +14 -9
  28. package/dist/cjs/src/primitives/utils.js.map +1 -1
  29. package/dist/cjs/src/script/Spend.js.map +1 -1
  30. package/dist/cjs/src/script/templates/P2PKH.js +1 -1
  31. package/dist/cjs/src/script/templates/P2PKH.js.map +1 -1
  32. package/dist/cjs/src/transaction/MerklePath.js +3 -3
  33. package/dist/cjs/src/transaction/MerklePath.js.map +1 -1
  34. package/dist/cjs/src/transaction/Transaction.js +15 -4
  35. package/dist/cjs/src/transaction/Transaction.js.map +1 -1
  36. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  37. package/dist/esm/src/compat/BSM.js.map +1 -1
  38. package/dist/esm/src/compat/ECIES.js +105 -76
  39. package/dist/esm/src/compat/ECIES.js.map +1 -1
  40. package/dist/esm/src/compat/HD.js +65 -65
  41. package/dist/esm/src/compat/HD.js.map +1 -1
  42. package/dist/esm/src/compat/Mnemonic.js +79 -79
  43. package/dist/esm/src/compat/Mnemonic.js.map +1 -1
  44. package/dist/esm/src/compat/bip-39-wordlist-en.js +2 -2
  45. package/dist/esm/src/compat/bip-39-wordlist-en.js.map +1 -1
  46. package/dist/esm/src/primitives/AESGCM.js.map +1 -1
  47. package/dist/esm/src/primitives/BigNumber.js.map +1 -1
  48. package/dist/esm/src/primitives/DRBG.js.map +1 -1
  49. package/dist/esm/src/primitives/ECDSA.js.map +1 -1
  50. package/dist/esm/src/primitives/Hash.js +26 -13
  51. package/dist/esm/src/primitives/Hash.js.map +1 -1
  52. package/dist/esm/src/primitives/PrivateKey.js +3 -2
  53. package/dist/esm/src/primitives/PrivateKey.js.map +1 -1
  54. package/dist/esm/src/primitives/PublicKey.js +1 -2
  55. package/dist/esm/src/primitives/PublicKey.js.map +1 -1
  56. package/dist/esm/src/primitives/Random.js +2 -2
  57. package/dist/esm/src/primitives/Random.js.map +1 -1
  58. package/dist/esm/src/primitives/Signature.js +141 -4
  59. package/dist/esm/src/primitives/Signature.js.map +1 -1
  60. package/dist/esm/src/primitives/SymmetricKey.js.map +1 -1
  61. package/dist/esm/src/primitives/TransactionSignature.js.map +1 -1
  62. package/dist/esm/src/primitives/utils.js +14 -9
  63. package/dist/esm/src/primitives/utils.js.map +1 -1
  64. package/dist/esm/src/script/Spend.js.map +1 -1
  65. package/dist/esm/src/script/templates/P2PKH.js +1 -1
  66. package/dist/esm/src/script/templates/P2PKH.js.map +1 -1
  67. package/dist/esm/src/transaction/MerklePath.js +3 -3
  68. package/dist/esm/src/transaction/MerklePath.js.map +1 -1
  69. package/dist/esm/src/transaction/Transaction.js +16 -4
  70. package/dist/esm/src/transaction/Transaction.js.map +1 -1
  71. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  72. package/dist/types/src/compat/ECIES.d.ts +36 -36
  73. package/dist/types/src/compat/ECIES.d.ts.map +1 -1
  74. package/dist/types/src/compat/HD.d.ts +65 -65
  75. package/dist/types/src/compat/HD.d.ts.map +1 -1
  76. package/dist/types/src/compat/Mnemonic.d.ts +79 -79
  77. package/dist/types/src/compat/Mnemonic.d.ts.map +1 -1
  78. package/dist/types/src/primitives/AESGCM.d.ts.map +1 -1
  79. package/dist/types/src/primitives/BigNumber.d.ts.map +1 -1
  80. package/dist/types/src/primitives/Hash.d.ts.map +1 -1
  81. package/dist/types/src/primitives/PrivateKey.d.ts.map +1 -1
  82. package/dist/types/src/primitives/PublicKey.d.ts.map +1 -1
  83. package/dist/types/src/primitives/Signature.d.ts +62 -0
  84. package/dist/types/src/primitives/Signature.d.ts.map +1 -1
  85. package/dist/types/src/primitives/SymmetricKey.d.ts.map +1 -1
  86. package/dist/types/src/primitives/TransactionSignature.d.ts.map +1 -1
  87. package/dist/types/src/primitives/utils.d.ts.map +1 -1
  88. package/dist/types/src/script/Spend.d.ts.map +1 -1
  89. package/dist/types/src/transaction/Transaction.d.ts +1 -0
  90. package/dist/types/src/transaction/Transaction.d.ts.map +1 -1
  91. package/dist/types/tsconfig.types.tsbuildinfo +1 -1
  92. package/docs/compat.md +4 -4
  93. package/docs/primitives.md +288 -79
  94. package/package.json +1 -1
  95. package/src/compat/BSM.ts +12 -12
  96. package/src/compat/ECIES.ts +417 -418
  97. package/src/compat/HD.ts +228 -228
  98. package/src/compat/Mnemonic.ts +173 -173
  99. package/src/compat/__tests/BSM.test.ts +13 -2
  100. package/src/compat/bip-39-wordlist-en.ts +2052 -2052
  101. package/src/primitives/AESGCM.ts +30 -30
  102. package/src/primitives/BigNumber.ts +0 -1
  103. package/src/primitives/DRBG.ts +5 -5
  104. package/src/primitives/ECDSA.ts +1 -1
  105. package/src/primitives/Hash.ts +278 -293
  106. package/src/primitives/PrivateKey.ts +18 -19
  107. package/src/primitives/PublicKey.ts +9 -10
  108. package/src/primitives/Random.ts +4 -4
  109. package/src/primitives/Signature.ts +158 -14
  110. package/src/primitives/SymmetricKey.ts +3 -3
  111. package/src/primitives/TransactionSignature.ts +9 -9
  112. package/src/primitives/index.ts +1 -1
  113. package/src/primitives/utils.ts +60 -64
  114. package/src/script/Spend.ts +12 -12
  115. package/src/script/index.ts +1 -1
  116. package/src/script/templates/P2PKH.ts +1 -1
  117. package/src/transaction/MerklePath.ts +3 -3
  118. package/src/transaction/Transaction.ts +36 -26
  119. package/src/transaction/__tests/Transaction.test.ts +5 -5
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bsv/sdk",
3
- "version": "1.0.11",
3
+ "version": "1.0.13",
4
4
  "type": "commonjs",
5
5
  "description": "BSV Blockchain Standard Development Kit",
6
6
  "files": [
@@ -1 +1 @@
1
- {"version":3,"file":"BSM.js","sourceRoot":"","sources":["../../../../src/compat/BSM.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,8EAAkD;AAClD,qDAAwD;AACxD,8DAA+C;AAC/C,4DAA6C;AAK7C,MAAM,MAAM,GAAG,2BAA2B,CAAA;AAE1C;;;;;GAKG;AACI,MAAM,SAAS,GAAG,CAAC,UAAoB,EAAY,EAAE;IACxD,MAAM,EAAE,GAAG,IAAI,iBAAM,EAAE,CAAA;IACvB,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAChC,EAAE,CAAC,KAAK,CAAC,IAAA,kBAAO,EAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAA;IACjC,EAAE,CAAC,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IACpC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;IACpB,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,EAAE,CAAA;IACxB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAa,CAAA;IAC7C,OAAO,OAAO,CAAA;AAClB,CAAC,CAAA;AATY,QAAA,SAAS,aASrB;AAED;;;;;;GAMG;AACI,MAAM,IAAI,GAAG,CAAC,OAAiB,EAAE,UAAsB,EAAa,EAAE;IACzE,MAAM,OAAO,GAAG,IAAA,iBAAS,EAAC,OAAO,CAAC,CAAA;IAClC,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,sBAAS,CAAC,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,CAAA;AAC/D,CAAC,CAAA;AAHY,QAAA,IAAI,QAGhB;AAED;;;;;;;GAOG;AACI,MAAM,MAAM,GAAG,CAAC,OAAiB,EAAE,GAAc,EAAE,MAAiB,EAAW,EAAE;IACpF,MAAM,OAAO,GAAG,IAAA,iBAAS,EAAC,OAAO,CAAC,CAAA;IAClC,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,sBAAS,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAA;AAC5D,CAAC,CAAA;AAHY,QAAA,MAAM,UAGlB"}
1
+ {"version":3,"file":"BSM.js","sourceRoot":"","sources":["../../../../src/compat/BSM.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,8EAAkD;AAClD,qDAAwD;AACxD,8DAA+C;AAC/C,4DAA6C;AAK7C,MAAM,MAAM,GAAG,2BAA2B,CAAA;AAE1C;;;;;GAKG;AACI,MAAM,SAAS,GAAG,CAAC,UAAoB,EAAY,EAAE;IAC1D,MAAM,EAAE,GAAG,IAAI,iBAAM,EAAE,CAAA;IACvB,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAChC,EAAE,CAAC,KAAK,CAAC,IAAA,kBAAO,EAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAA;IACjC,EAAE,CAAC,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IACpC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;IACpB,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,EAAE,CAAA;IACxB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;IACjC,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AATY,QAAA,SAAS,aASrB;AAED;;;;;;GAMG;AACI,MAAM,IAAI,GAAG,CAAC,OAAiB,EAAE,UAAsB,EAAa,EAAE;IAC3E,MAAM,OAAO,GAAG,IAAA,iBAAS,EAAC,OAAO,CAAC,CAAA;IAClC,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,sBAAS,CAAC,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,CAAA;AAC7D,CAAC,CAAA;AAHY,QAAA,IAAI,QAGhB;AAED;;;;;;;GAOG;AACI,MAAM,MAAM,GAAG,CAAC,OAAiB,EAAE,GAAc,EAAE,MAAiB,EAAW,EAAE;IACtF,MAAM,OAAO,GAAG,IAAA,iBAAS,EAAC,OAAO,CAAC,CAAA;IAClC,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,sBAAS,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAA;AAC1D,CAAC,CAAA;AAHY,QAAA,MAAM,UAGlB"}
@@ -36,13 +36,13 @@ const utils_js_1 = require("../primitives/utils.js");
36
36
  function AES(key) {
37
37
  if (!this._tables[0][0][0])
38
38
  this._precompute();
39
- var tmp, encKey, decKey;
40
- var sbox = this._tables[0][4];
41
- var decTable = this._tables[1];
42
- var keyLen = key.length;
43
- var rcon = 1;
39
+ let tmp, encKey, decKey;
40
+ const sbox = this._tables[0][4];
41
+ const decTable = this._tables[1];
42
+ const keyLen = key.length;
43
+ let rcon = 1;
44
44
  if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {
45
- throw new Error("invalid aes key size");
45
+ throw new Error('invalid aes key size');
46
46
  }
47
47
  this._key = [encKey = key.slice(0), decKey = []];
48
48
  // schedule encryption keys
@@ -60,7 +60,7 @@ function AES(key) {
60
60
  encKey[i] = encKey[i - keyLen] ^ tmp;
61
61
  }
62
62
  // schedule decryption keys
63
- for (var j = 0; i; j++, i--) {
63
+ for (let j = 0; i; j++, i--) {
64
64
  tmp = encKey[j & 3 ? i : i - 4];
65
65
  if (i <= 4 || j < 4) {
66
66
  decKey[j] = tmp;
@@ -75,36 +75,50 @@ function AES(key) {
75
75
  }
76
76
  AES.prototype = {
77
77
  /**
78
- * Encrypt an array of 4 big-endian words.
79
- * @param {Array} data The plaintext.
80
- * @return {Array} The ciphertext.
81
- */
78
+ * Encrypt an array of 4 big-endian words.
79
+ * @param {Array} data The plaintext.
80
+ * @return {Array} The ciphertext.
81
+ */
82
82
  encrypt: function (data) { return this._crypt(data, 0); },
83
83
  /**
84
- * Decrypt an array of 4 big-endian words.
85
- * @param {Array} data The ciphertext.
86
- * @return {Array} The plaintext.
87
- */
84
+ * Decrypt an array of 4 big-endian words.
85
+ * @param {Array} data The ciphertext.
86
+ * @return {Array} The plaintext.
87
+ */
88
88
  decrypt: function (data) { return this._crypt(data, 1); },
89
89
  /**
90
- * The expanded S-box and inverse S-box tables. These will be computed
91
- * on the client so that we don't have to send them down the wire.
92
- *
93
- * There are two tables, _tables[0] is for encryption and
94
- * _tables[1] is for decryption.
95
- *
96
- * The first 4 sub-tables are the expanded S-box with MixColumns. The
97
- * last (_tables[01][4]) is the S-box itself.
98
- *
99
- * @private
100
- */
90
+ * The expanded S-box and inverse S-box tables. These will be computed
91
+ * on the client so that we don't have to send them down the wire.
92
+ *
93
+ * There are two tables, _tables[0] is for encryption and
94
+ * _tables[1] is for decryption.
95
+ *
96
+ * The first 4 sub-tables are the expanded S-box with MixColumns. The
97
+ * last (_tables[01][4]) is the S-box itself.
98
+ *
99
+ * @private
100
+ */
101
101
  _tables: [
102
102
  [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)],
103
103
  [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)]
104
104
  ],
105
- //Expand the S-box tables.
105
+ // Expand the S-box tables.
106
106
  _precompute: function () {
107
- var encTable = this._tables[0], decTable = this._tables[1], sbox = encTable[4], sboxInv = decTable[4], i, x, xInv, d = new Uint8Array(256), th = new Uint8Array(256), x2, x4, x8, s, tEnc, tDec;
107
+ const encTable = this._tables[0];
108
+ const decTable = this._tables[1];
109
+ const sbox = encTable[4];
110
+ const sboxInv = decTable[4];
111
+ let i;
112
+ let x;
113
+ let xInv;
114
+ const d = new Uint8Array(256);
115
+ const th = new Uint8Array(256);
116
+ let x2;
117
+ let x4;
118
+ let x8;
119
+ let s;
120
+ let tEnc;
121
+ let tDec;
108
122
  // Compute double and third tables
109
123
  for (i = 0; i < 256; i++) {
110
124
  th[(d[i] = i << 1 ^ (i >> 7) * 283) ^ i] = i;
@@ -126,22 +140,37 @@ AES.prototype = {
126
140
  }
127
141
  },
128
142
  /**
129
- * Encryption and decryption core.
130
- * @param {Array} input Four words to be encrypted or decrypted.
131
- * @param dir The direction, 0 for encrypt and 1 for decrypt.
132
- * @return {Array} The four encrypted or decrypted words.
133
- * @private
134
- */
143
+ * Encryption and decryption core.
144
+ * @param {Array} input Four words to be encrypted or decrypted.
145
+ * @param dir The direction, 0 for encrypt and 1 for decrypt.
146
+ * @return {Array} The four encrypted or decrypted words.
147
+ * @private
148
+ */
135
149
  _crypt: function (input, dir) {
136
150
  if (input.length !== 4) {
137
- throw new Error("invalid aes block size");
151
+ throw new Error('invalid aes block size');
138
152
  }
139
- var key = this._key[dir],
153
+ const key = this._key[dir];
140
154
  // state variables a,b,c,d are loaded with pre-whitened data
141
- a = input[0] ^ key[0], b = input[dir ? 3 : 1] ^ key[1], c = input[2] ^ key[2], d = input[dir ? 1 : 3] ^ key[3], a2, b2, c2, nInnerRounds = key.length / 4 - 2, i, kIndex = 4, out = new Uint32Array(4), // <--- this is slower in Node.js, about the same in Chrome */
142
- table = this._tables[dir],
155
+ let a = input[0] ^ key[0];
156
+ let b = input[dir ? 3 : 1] ^ key[1];
157
+ let c = input[2] ^ key[2];
158
+ let d = input[dir ? 1 : 3] ^ key[3];
159
+ let a2;
160
+ let b2;
161
+ let c2;
162
+ const nInnerRounds = key.length / 4 - 2;
163
+ let i;
164
+ let kIndex = 4;
165
+ const out = new Uint32Array(4);
166
+ const // <--- this is slower in Node.js, about the same in Chrome */
167
+ table = this._tables[dir];
143
168
  // load up the tables
144
- t0 = table[0], t1 = table[1], t2 = table[2], t3 = table[3], sbox = table[4];
169
+ const t0 = table[0];
170
+ const t1 = table[1];
171
+ const t2 = table[2];
172
+ const t3 = table[3];
173
+ const sbox = table[4];
145
174
  // Inner rounds. Cribbed from OpenSSL.
146
175
  for (i = 0; i < nInnerRounds; i++) {
147
176
  a2 = t0[a >>> 24] ^ t1[b >> 16 & 255] ^ t2[c >> 8 & 255] ^ t3[d & 255] ^ key[kIndex];
@@ -341,13 +370,13 @@ class AESCBC {
341
370
  */
342
371
  class ECIES {
343
372
  /**
344
- * Generates the initialization vector (iv), encryption key (kE), and MAC key (kM)
345
- * using the sender's private key and receiver's public key.
346
- *
347
- * @param {PrivateKey} privKey - The sender's private key.
348
- * @param {PublicKey} pubKey - The receiver's public key.
349
- * @returns {Object} An object containing the iv, kE, and kM as number arrays.
350
- */
373
+ * Generates the initialization vector (iv), encryption key (kE), and MAC key (kM)
374
+ * using the sender's private key and receiver's public key.
375
+ *
376
+ * @param {PrivateKey} privKey - The sender's private key.
377
+ * @param {PublicKey} pubKey - The receiver's public key.
378
+ * @returns {Object} An object containing the iv, kE, and kM as number arrays.
379
+ */
351
380
  static ivkEkM(privKey, pubKey) {
352
381
  const r = privKey;
353
382
  const KB = pubKey;
@@ -358,18 +387,18 @@ class ECIES {
358
387
  return {
359
388
  iv: hash.slice(0, 16),
360
389
  kE: hash.slice(16, 32),
361
- kM: hash.slice(32, 64),
390
+ kM: hash.slice(32, 64)
362
391
  };
363
392
  }
364
393
  /**
365
- * Encrypts a given message using the Electrum ECIES method.
366
- *
367
- * @param {number[]} messageBuf - The message to be encrypted, in number array format.
368
- * @param {PublicKey} toPublicKey - The public key of the recipient.
369
- * @param {PrivateKey} [fromPrivateKey] - The private key of the sender. If not provided, a random private key is used.
370
- * @param {boolean} [noKey=false] - If true, does not include the sender's public key in the encrypted message.
371
- * @returns {number[]} The encrypted message as a number array.
372
- */
394
+ * Encrypts a given message using the Electrum ECIES method.
395
+ *
396
+ * @param {number[]} messageBuf - The message to be encrypted, in number array format.
397
+ * @param {PublicKey} toPublicKey - The public key of the recipient.
398
+ * @param {PrivateKey} [fromPrivateKey] - The private key of the sender. If not provided, a random private key is used.
399
+ * @param {boolean} [noKey=false] - If true, does not include the sender's public key in the encrypted message.
400
+ * @returns {number[]} The encrypted message as a number array.
401
+ */
373
402
  static electrumEncrypt(messageBuf, toPublicKey, fromPrivateKey, noKey = false) {
374
403
  let Rbuf;
375
404
  if (fromPrivateKey === null) {
@@ -392,13 +421,13 @@ class ECIES {
392
421
  return [...encBuf, ...hmac];
393
422
  }
394
423
  /**
395
- * Decrypts a message encrypted using the Electrum ECIES method.
396
- *
397
- * @param {number[]} encBuf - The encrypted message buffer.
398
- * @param {PrivateKey} toPrivateKey - The private key of the recipient.
399
- * @param {PublicKey} [fromPublicKey=null] - The public key of the sender. If not provided, it is extracted from the message.
400
- * @returns {number[]} The decrypted message as a number array.
401
- */
424
+ * Decrypts a message encrypted using the Electrum ECIES method.
425
+ *
426
+ * @param {number[]} encBuf - The encrypted message buffer.
427
+ * @param {PrivateKey} toPrivateKey - The private key of the recipient.
428
+ * @param {PublicKey} [fromPublicKey=null] - The public key of the sender. If not provided, it is extracted from the message.
429
+ * @returns {number[]} The decrypted message as a number array.
430
+ */
402
431
  static electrumDecrypt(encBuf, toPrivateKey, fromPublicKey = null) {
403
432
  const tagLength = 32;
404
433
  const magic = encBuf.slice(0, 4);
@@ -422,14 +451,14 @@ class ECIES {
422
451
  return AESCBC.decrypt(ciphertext, kE, iv);
423
452
  }
424
453
  /**
425
- * Encrypts a given message using the Bitcore variant of ECIES.
426
- *
427
- * @param {number[]} messageBuf - The message to be encrypted, in number array format.
428
- * @param {PublicKey} toPublicKey - The public key of the recipient.
429
- * @param {PrivateKey} [fromPrivateKey] - The private key of the sender. If not provided, a random private key is used.
430
- * @param {number[]} [ivBuf] - The initialization vector for encryption. If not provided, a random IV is used.
431
- * @returns {number[]} The encrypted message as a number array.
432
- */
454
+ * Encrypts a given message using the Bitcore variant of ECIES.
455
+ *
456
+ * @param {number[]} messageBuf - The message to be encrypted, in number array format.
457
+ * @param {PublicKey} toPublicKey - The public key of the recipient.
458
+ * @param {PrivateKey} [fromPrivateKey] - The private key of the sender. If not provided, a random private key is used.
459
+ * @param {number[]} [ivBuf] - The initialization vector for encryption. If not provided, a random IV is used.
460
+ * @returns {number[]} The encrypted message as a number array.
461
+ */
433
462
  static bitcoreEncrypt(messageBuf, toPublicKey, fromPrivateKey, ivBuf) {
434
463
  if (!fromPrivateKey) {
435
464
  fromPrivateKey = PrivateKey_js_1.default.fromRandom();
@@ -450,12 +479,12 @@ class ECIES {
450
479
  return encBuf;
451
480
  }
452
481
  /**
453
- * Decrypts a message encrypted using the Bitcore variant of ECIES.
454
- *
455
- * @param {number[]} encBuf - The encrypted message buffer.
456
- * @param {PrivateKey} toPrivateKey - The private key of the recipient.
457
- * @returns {number[]} The decrypted message as a number array.
458
- */
482
+ * Decrypts a message encrypted using the Bitcore variant of ECIES.
483
+ *
484
+ * @param {number[]} encBuf - The encrypted message buffer.
485
+ * @param {PrivateKey} toPrivateKey - The private key of the recipient.
486
+ * @returns {number[]} The decrypted message as a number array.
487
+ */
459
488
  static bitcoreDecrypt(encBuf, toPrivateKey) {
460
489
  const kB = toPrivateKey;
461
490
  const fromPublicKey = PublicKey_js_1.default.fromString((0, utils_js_1.toHex)(encBuf.slice(0, 33)));
@@ -1 +1 @@
1
- {"version":3,"file":"ECIES.js","sourceRoot":"","sources":["../../../../src/compat/ECIES.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ECIES.js","sourceRoot":"","sources":["../../../../src/compat/ECIES.ts"],"names":[],"mappings":"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"}
@@ -45,16 +45,16 @@ const BigNumber_js_1 = __importDefault(require("../primitives/BigNumber.js"));
45
45
  */
46
46
  class HD {
47
47
  /**
48
- * Constructor for the BIP32 HD wallet.
49
- * Initializes an HD wallet with optional parameters for version bytes, depth, parent fingerprint, child index, chain code, private key, and public key.
50
- * @param versionBytesNum - Version bytes number for the wallet.
51
- * @param depth - Depth of the key in the hierarchy.
52
- * @param parentFingerPrint - Fingerprint of the parent key.
53
- * @param childIndex - Index of the child key.
54
- * @param chainCode - Chain code for key derivation.
55
- * @param privKey - Private key of the wallet.
56
- * @param pubKey - Public key of the wallet.
57
- */
48
+ * Constructor for the BIP32 HD wallet.
49
+ * Initializes an HD wallet with optional parameters for version bytes, depth, parent fingerprint, child index, chain code, private key, and public key.
50
+ * @param versionBytesNum - Version bytes number for the wallet.
51
+ * @param depth - Depth of the key in the hierarchy.
52
+ * @param parentFingerPrint - Fingerprint of the parent key.
53
+ * @param childIndex - Index of the child key.
54
+ * @param chainCode - Chain code for key derivation.
55
+ * @param privKey - Private key of the wallet.
56
+ * @param pubKey - Public key of the wallet.
57
+ */
58
58
  constructor(versionBytesNum, depth, parentFingerPrint, childIndex, chainCode, privKey, pubKey) {
59
59
  this.constants = {
60
60
  pubKey: 0x0488b21e,
@@ -69,10 +69,10 @@ class HD {
69
69
  this.pubKey = pubKey;
70
70
  }
71
71
  /**
72
- * Generates a new HD wallet with random keys.
73
- * This method creates a root HD wallet with randomly generated private and public keys.
74
- * @returns {HD} The current HD instance with generated keys.
75
- */
72
+ * Generates a new HD wallet with random keys.
73
+ * This method creates a root HD wallet with randomly generated private and public keys.
74
+ * @returns {HD} The current HD instance with generated keys.
75
+ */
76
76
  fromRandom() {
77
77
  this.versionBytesNum = this.constants.privKey;
78
78
  this.depth = 0x00;
@@ -84,39 +84,39 @@ class HD {
84
84
  return this;
85
85
  }
86
86
  /**
87
- * Generates a new HD wallet with random keys.
88
- * This method creates a root HD wallet with randomly generated private and public keys.
89
- * @returns {HD} A new HD instance with generated keys.
90
- * @static
91
- */
87
+ * Generates a new HD wallet with random keys.
88
+ * This method creates a root HD wallet with randomly generated private and public keys.
89
+ * @returns {HD} A new HD instance with generated keys.
90
+ * @static
91
+ */
92
92
  static fromRandom() {
93
93
  return new this().fromRandom();
94
94
  }
95
95
  /**
96
- * Initializes the HD wallet from a given base58 encoded string.
97
- * This method decodes a provided string to set up the HD wallet's properties.
98
- * @param str - A base58 encoded string representing the wallet.
99
- * @returns {HD} The current instance with properties set from the string.
100
- */
96
+ * Initializes the HD wallet from a given base58 encoded string.
97
+ * This method decodes a provided string to set up the HD wallet's properties.
98
+ * @param str - A base58 encoded string representing the wallet.
99
+ * @returns {HD} The current instance with properties set from the string.
100
+ */
101
101
  fromString(str) {
102
102
  const decoded = (0, utils_js_1.fromBase58Check)(str);
103
103
  return this.fromBinary([...decoded.prefix, ...decoded.data]);
104
104
  }
105
105
  /**
106
- * Converts the HD wallet to a base58 encoded string.
107
- * This method provides a string representation of the HD wallet's current state.
108
- * @returns {string} A base58 encoded string of the HD wallet.
109
- */
106
+ * Converts the HD wallet to a base58 encoded string.
107
+ * This method provides a string representation of the HD wallet's current state.
108
+ * @returns {string} A base58 encoded string of the HD wallet.
109
+ */
110
110
  toString() {
111
111
  const bin = this.toBinary();
112
112
  return (0, utils_js_1.toBase58Check)(bin, []);
113
113
  }
114
114
  /**
115
- * Initializes the HD wallet from a seed.
116
- * This method generates keys and other properties from a given seed, conforming to the BIP32 specification.
117
- * @param bytes - An array of bytes representing the seed.
118
- * @returns {HD} The current instance with properties set from the seed.
119
- */
115
+ * Initializes the HD wallet from a seed.
116
+ * This method generates keys and other properties from a given seed, conforming to the BIP32 specification.
117
+ * @param bytes - An array of bytes representing the seed.
118
+ * @returns {HD} The current instance with properties set from the seed.
119
+ */
120
120
  fromSeed(bytes) {
121
121
  if (bytes.length < 128 / 8) {
122
122
  throw new Error('Need more than 128 bits of entropy');
@@ -135,20 +135,20 @@ class HD {
135
135
  return this;
136
136
  }
137
137
  /**
138
- * Initializes the HD wallet from a seed.
139
- * This method generates keys and other properties from a given seed, conforming to the BIP32 specification.
140
- * @param bytes - An array of bytes representing the seed.
141
- * @returns {HD} The current instance with properties set from the seed.
142
- */
138
+ * Initializes the HD wallet from a seed.
139
+ * This method generates keys and other properties from a given seed, conforming to the BIP32 specification.
140
+ * @param bytes - An array of bytes representing the seed.
141
+ * @returns {HD} The current instance with properties set from the seed.
142
+ */
143
143
  static fromSeed(bytes) {
144
144
  return new this().fromSeed(bytes);
145
145
  }
146
146
  /**
147
- * Initializes the HD wallet from a binary buffer.
148
- * Parses a binary buffer to set up the wallet's properties.
149
- * @param buf - A buffer containing the wallet data.
150
- * @returns {HD} The current instance with properties set from the buffer.
151
- */
147
+ * Initializes the HD wallet from a binary buffer.
148
+ * Parses a binary buffer to set up the wallet's properties.
149
+ * @param buf - A buffer containing the wallet data.
150
+ * @returns {HD} The current instance with properties set from the buffer.
151
+ */
152
152
  fromBinary(buf) {
153
153
  // Both pub and private extended keys are 78 buf
154
154
  if (buf.length !== 78) {
@@ -176,11 +176,11 @@ class HD {
176
176
  return this;
177
177
  }
178
178
  /**
179
- * Derives a child HD wallet based on a given path.
180
- * The path specifies the hierarchy of the child key to be derived.
181
- * @param path - A string representing the derivation path (e.g., 'm/0'/1).
182
- * @returns {HD} A new HD instance representing the derived child wallet.
183
- */
179
+ * Derives a child HD wallet based on a given path.
180
+ * The path specifies the hierarchy of the child key to be derived.
181
+ * @param path - A string representing the derivation path (e.g., 'm/0'/1).
182
+ * @returns {HD} A new HD instance representing the derived child wallet.
183
+ */
184
184
  derive(path) {
185
185
  if (path === 'm') {
186
186
  return this;
@@ -209,11 +209,11 @@ class HD {
209
209
  return bip32;
210
210
  }
211
211
  /**
212
- * Derives a child HD wallet from the current wallet based on an index.
213
- * This method generates either a private or public child key depending on the current wallet's state.
214
- * @param i - The index of the child key to derive.
215
- * @returns {HD} A new HD instance representing the derived child wallet.
216
- */
212
+ * Derives a child HD wallet from the current wallet based on an index.
213
+ * This method generates either a private or public child key depending on the current wallet's state.
214
+ * @param i - The index of the child key to derive.
215
+ * @returns {HD} A new HD instance representing the derived child wallet.
216
+ */
217
217
  deriveChild(i) {
218
218
  if (typeof i !== 'number') {
219
219
  throw new Error('i must be a number');
@@ -270,10 +270,10 @@ class HD {
270
270
  return ret;
271
271
  }
272
272
  /**
273
- * Converts the current HD wallet to a public-only wallet.
274
- * This method strips away the private key information, leaving only the public part.
275
- * @returns {HD} A new HD instance representing the public-only wallet.
276
- */
273
+ * Converts the current HD wallet to a public-only wallet.
274
+ * This method strips away the private key information, leaving only the public part.
275
+ * @returns {HD} A new HD instance representing the public-only wallet.
276
+ */
277
277
  toPublic() {
278
278
  const bip32 = new HD(this.versionBytesNum, this.depth, this.parentFingerPrint, this.childIndex, this.chainCode, this.privKey, this.pubKey);
279
279
  bip32.versionBytesNum = this.constants.pubKey;
@@ -281,10 +281,10 @@ class HD {
281
281
  return bip32;
282
282
  }
283
283
  /**
284
- * Converts the HD wallet into a binary representation.
285
- * This method serializes the wallet's properties into a binary format.
286
- * @returns {number[]} An array of numbers representing the binary data of the wallet.
287
- */
284
+ * Converts the HD wallet into a binary representation.
285
+ * This method serializes the wallet's properties into a binary format.
286
+ * @returns {number[]} An array of numbers representing the binary data of the wallet.
287
+ */
288
288
  toBinary() {
289
289
  const isPrivate = this.versionBytesNum === this.constants.privKey;
290
290
  const isPublic = this.versionBytesNum === this.constants.pubKey;
@@ -314,10 +314,10 @@ class HD {
314
314
  }
315
315
  }
316
316
  /**
317
- * Checks if the HD wallet contains a private key.
318
- * This method determines whether the wallet is a private key wallet or a public key only wallet.
319
- * @returns {boolean} A boolean value indicating whether the wallet has a private key (true) or not (false).
320
- */
317
+ * Checks if the HD wallet contains a private key.
318
+ * This method determines whether the wallet is a private key wallet or a public key only wallet.
319
+ * @returns {boolean} A boolean value indicating whether the wallet has a private key (true) or not (false).
320
+ */
321
321
  isPrivate() {
322
322
  return this.versionBytesNum === this.constants.privKey;
323
323
  }
@@ -1 +1 @@
1
- {"version":3,"file":"HD.js","sourceRoot":"","sources":["../../../../src/compat/HD.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"HD.js","sourceRoot":"","sources":["../../../../src/compat/HD.ts"],"names":[],"mappings":"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"}