@witnet/sdk 1.1.3 → 1.2.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.
Files changed (192) hide show
  1. package/.env_witnet +13 -1
  2. package/dist/package.json +31 -24
  3. package/dist/src/bin/helpers.d.ts +59 -49
  4. package/dist/src/bin/helpers.d.ts.map +1 -1
  5. package/dist/src/bin/helpers.js +228 -229
  6. package/dist/src/index.d.ts +3 -4
  7. package/dist/src/index.d.ts.map +1 -1
  8. package/dist/src/index.js +4 -47
  9. package/dist/src/lib/crypto/account.d.ts +3 -3
  10. package/dist/src/lib/crypto/account.d.ts.map +1 -1
  11. package/dist/src/lib/crypto/account.js +31 -25
  12. package/dist/src/lib/crypto/coinbase.d.ts +4 -4
  13. package/dist/src/lib/crypto/coinbase.d.ts.map +1 -1
  14. package/dist/src/lib/crypto/coinbase.js +8 -13
  15. package/dist/src/lib/crypto/index.d.ts +7 -7
  16. package/dist/src/lib/crypto/index.d.ts.map +1 -1
  17. package/dist/src/lib/crypto/index.js +7 -30
  18. package/dist/src/lib/crypto/interfaces.d.ts +5 -5
  19. package/dist/src/lib/crypto/interfaces.d.ts.map +1 -1
  20. package/dist/src/lib/crypto/interfaces.js +2 -3
  21. package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts +5 -5
  22. package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -1
  23. package/dist/src/lib/crypto/payloads/DataRequestPayload.js +107 -95
  24. package/dist/src/lib/crypto/payloads/StakePayload.d.ts +3 -4
  25. package/dist/src/lib/crypto/payloads/StakePayload.d.ts.map +1 -1
  26. package/dist/src/lib/crypto/payloads/StakePayload.js +81 -71
  27. package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts +4 -5
  28. package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -1
  29. package/dist/src/lib/crypto/payloads/UnstakePayload.js +36 -43
  30. package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts +3 -4
  31. package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -1
  32. package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +46 -48
  33. package/dist/src/lib/crypto/payloads.d.ts +5 -5
  34. package/dist/src/lib/crypto/payloads.d.ts.map +1 -1
  35. package/dist/src/lib/crypto/payloads.js +44 -45
  36. package/dist/src/lib/crypto/signer.d.ts +3 -3
  37. package/dist/src/lib/crypto/signer.d.ts.map +1 -1
  38. package/dist/src/lib/crypto/signer.js +45 -88
  39. package/dist/src/lib/crypto/transmitters/DataRequests.d.ts +6 -6
  40. package/dist/src/lib/crypto/transmitters/DataRequests.d.ts.map +1 -1
  41. package/dist/src/lib/crypto/transmitters/DataRequests.js +6 -10
  42. package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts +5 -5
  43. package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -1
  44. package/dist/src/lib/crypto/transmitters/StakeDeposits.js +7 -11
  45. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts +6 -7
  46. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -1
  47. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +9 -13
  48. package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts +5 -5
  49. package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -1
  50. package/dist/src/lib/crypto/transmitters/ValueTransfers.js +6 -10
  51. package/dist/src/lib/crypto/transmitters.d.ts +6 -6
  52. package/dist/src/lib/crypto/transmitters.d.ts.map +1 -1
  53. package/dist/src/lib/crypto/transmitters.js +88 -76
  54. package/dist/src/lib/crypto/types.d.ts +1 -2
  55. package/dist/src/lib/crypto/types.d.ts.map +1 -1
  56. package/dist/src/lib/crypto/types.js +71 -67
  57. package/dist/src/lib/crypto/utils.d.ts +5 -5
  58. package/dist/src/lib/crypto/utils.d.ts.map +1 -1
  59. package/dist/src/lib/crypto/utils.js +48 -66
  60. package/dist/src/lib/crypto/wallet.d.ts +3 -3
  61. package/dist/src/lib/crypto/wallet.d.ts.map +1 -1
  62. package/dist/src/lib/crypto/wallet.js +72 -89
  63. package/dist/src/lib/index.d.ts +5 -4
  64. package/dist/src/lib/index.d.ts.map +1 -1
  65. package/dist/src/lib/index.js +6 -44
  66. package/dist/src/lib/radon/ccdr/eth.d.ts +1 -1
  67. package/dist/src/lib/radon/ccdr/eth.d.ts.map +1 -1
  68. package/dist/src/lib/radon/ccdr/eth.js +95 -83
  69. package/dist/src/lib/radon/ccdr/index.d.ts +2 -2
  70. package/dist/src/lib/radon/ccdr/index.d.ts.map +1 -1
  71. package/dist/src/lib/radon/ccdr/index.js +3 -39
  72. package/dist/src/lib/radon/ccdr/wit.d.ts +2 -2
  73. package/dist/src/lib/radon/ccdr/wit.d.ts.map +1 -1
  74. package/dist/src/lib/radon/ccdr/wit.js +17 -19
  75. package/dist/src/lib/radon/filters.d.ts.map +1 -1
  76. package/dist/src/lib/radon/filters.js +23 -19
  77. package/dist/src/lib/radon/index.d.ts +10 -11
  78. package/dist/src/lib/radon/index.d.ts.map +1 -1
  79. package/dist/src/lib/radon/index.js +205 -187
  80. package/dist/src/lib/radon/reducers.d.ts +2 -2
  81. package/dist/src/lib/radon/reducers.d.ts.map +1 -1
  82. package/dist/src/lib/radon/reducers.js +48 -34
  83. package/dist/src/lib/radon/types.d.ts +2 -2
  84. package/dist/src/lib/radon/types.d.ts.map +1 -1
  85. package/dist/src/lib/radon/types.js +80 -110
  86. package/dist/src/lib/radon/utils.d.ts +3 -3
  87. package/dist/src/lib/radon/utils.d.ts.map +1 -1
  88. package/dist/src/lib/radon/utils.js +49 -52
  89. package/dist/src/lib/rest/kermit.d.ts +20 -0
  90. package/dist/src/lib/rest/kermit.d.ts.map +1 -0
  91. package/dist/src/lib/rest/kermit.js +68 -0
  92. package/dist/src/lib/rest/types.d.ts +5 -0
  93. package/dist/src/lib/rest/types.d.ts.map +1 -0
  94. package/dist/src/lib/rest/types.js +2 -0
  95. package/dist/src/lib/rpc/index.d.ts +2 -2
  96. package/dist/src/lib/rpc/index.d.ts.map +1 -1
  97. package/dist/src/lib/rpc/index.js +3 -19
  98. package/dist/src/lib/rpc/nodes.d.ts +13 -13
  99. package/dist/src/lib/rpc/nodes.d.ts.map +1 -1
  100. package/dist/src/lib/rpc/nodes.js +69 -98
  101. package/dist/src/lib/rpc/provider.d.ts +4 -4
  102. package/dist/src/lib/rpc/provider.d.ts.map +1 -1
  103. package/dist/src/lib/rpc/provider.js +111 -125
  104. package/dist/src/lib/rpc/types.d.ts +2 -2
  105. package/dist/src/lib/rpc/types.d.ts.map +1 -1
  106. package/dist/src/lib/rpc/types.js +13 -16
  107. package/dist/src/lib/types.d.ts +5 -4
  108. package/dist/src/lib/types.d.ts.map +1 -1
  109. package/dist/src/lib/types.js +3 -9
  110. package/dist/src/lib/utils.d.ts +5 -5
  111. package/dist/src/lib/utils.d.ts.map +1 -1
  112. package/dist/src/lib/utils.js +40 -99
  113. package/dist/witnet/assets/index.cjs +6 -0
  114. package/dist/witnet/assets/index.d.cts +29 -0
  115. package/dist/witnet/assets/index.d.cts.map +1 -0
  116. package/dist/witnet/assets/modals/index.cjs +9 -0
  117. package/dist/witnet/assets/modals/index.d.cts +16 -0
  118. package/dist/witnet/assets/modals/index.d.cts.map +1 -0
  119. package/dist/witnet/assets/modals/web3/eth.cjs +23 -0
  120. package/dist/witnet/assets/modals/web3/eth.d.cts +4 -0
  121. package/dist/witnet/assets/modals/web3/eth.d.cts.map +1 -0
  122. package/dist/witnet/assets/modals/web3/ipfs.cjs +18 -0
  123. package/dist/witnet/assets/modals/web3/ipfs.d.cts +3 -0
  124. package/dist/witnet/assets/modals/web3/ipfs.d.cts.map +1 -0
  125. package/dist/witnet/assets/modals/web3/wit.cjs +24 -0
  126. package/dist/witnet/assets/modals/web3/wit.d.cts +3 -0
  127. package/dist/witnet/assets/modals/web3/wit.d.cts.map +1 -0
  128. package/dist/witnet/assets/requests.cjs +43 -0
  129. package/dist/witnet/assets/requests.d.cts +10 -0
  130. package/dist/witnet/assets/requests.d.cts.map +1 -0
  131. package/package.json +31 -24
  132. package/src/bin/bots/watcher.cjs +354 -0
  133. package/src/bin/cli/history.cjs +31 -0
  134. package/src/bin/cli/inspect.js +545 -471
  135. package/src/bin/cli/network.js +658 -557
  136. package/src/bin/cli/nodes.js +392 -332
  137. package/src/bin/cli/radon.js +1071 -844
  138. package/src/bin/cli/wallet.js +1317 -1074
  139. package/src/bin/helpers.js +969 -868
  140. package/src/bin/index.js +329 -0
  141. package/witnet/assets/_index.cjs +5 -0
  142. package/witnet/assets/_requests.cjs +25 -0
  143. package/witnet/assets/_sources.cjs +36 -0
  144. package/witnet/assets/_templates.cjs +36 -0
  145. package/witnet/assets/index.cjs +4 -0
  146. package/witnet/assets/modals/index.cjs +7 -0
  147. package/witnet/assets/modals/web3/eth.cjs +27 -0
  148. package/witnet/assets/modals/web3/ipfs.cjs +22 -0
  149. package/witnet/assets/modals/web3/wit.cjs +28 -0
  150. package/witnet/assets/requests.cjs +49 -0
  151. package/witnet/witnet copy.proto +457 -0
  152. package/witnet/witnet.proto +456 -0
  153. package/witnet/witnet_toolkit-1.6.7-x86_64-pc-windows-msvc.exe +0 -0
  154. package/witnet/witnet_toolkit-1.7.1-x86_64-pc-windows-msvc.exe +0 -0
  155. package/witnet/witnet_toolkit-2.0.0-rc.7-x86_64-pc-windows-msvc.exe +0 -0
  156. package/witnet/witnet_toolkit-2.0.2-x86_64-pc-windows-msvc.exe +0 -0
  157. package/witnet/witnet_toolkit-2.0.21-x86_64-pc-windows-msvc.exe +0 -0
  158. package/witnet/witnet_toolkit-2.0.7-x86_64-pc-windows-msvc.exe +0 -0
  159. package/witnet/witnet_toolkit-2.0.8-x86_64-pc-windows-msvc.exe +0 -0
  160. package/dist/witnet/assets/index.d.ts +0 -29
  161. package/dist/witnet/assets/index.d.ts.map +0 -1
  162. package/dist/witnet/assets/index.js +0 -6
  163. package/dist/witnet/assets/modals/index.d.ts +0 -16
  164. package/dist/witnet/assets/modals/index.d.ts.map +0 -1
  165. package/dist/witnet/assets/modals/index.js +0 -11
  166. package/dist/witnet/assets/modals/web3/eth.d.ts +0 -5
  167. package/dist/witnet/assets/modals/web3/eth.d.ts.map +0 -1
  168. package/dist/witnet/assets/modals/web3/eth.js +0 -26
  169. package/dist/witnet/assets/modals/web3/ipfs.d.ts +0 -4
  170. package/dist/witnet/assets/modals/web3/ipfs.d.ts.map +0 -1
  171. package/dist/witnet/assets/modals/web3/ipfs.js +0 -18
  172. package/dist/witnet/assets/modals/web3/wit.d.ts +0 -4
  173. package/dist/witnet/assets/modals/web3/wit.d.ts.map +0 -1
  174. package/dist/witnet/assets/modals/web3/wit.js +0 -17
  175. package/dist/witnet/assets/requests.d.ts +0 -11
  176. package/dist/witnet/assets/requests.d.ts.map +0 -1
  177. package/dist/witnet/assets/requests.js +0 -43
  178. package/src/bin/cli/history.js +0 -31
  179. package/src/bin/postinstall.js +0 -9
  180. package/src/bin/toolkit.js +0 -290
  181. package/witnet/assets/_index.js +0 -8
  182. package/witnet/assets/_requests.js +0 -25
  183. package/witnet/assets/_sources.js +0 -36
  184. package/witnet/assets/_templates.js +0 -36
  185. package/witnet/assets/index.js +0 -4
  186. package/witnet/assets/modals/index.js +0 -9
  187. package/witnet/assets/modals/web3/eth.js +0 -29
  188. package/witnet/assets/modals/web3/ipfs.js +0 -22
  189. package/witnet/assets/modals/web3/wit.js +0 -21
  190. package/witnet/assets/requests.js +0 -49
  191. /package/witnet/assets/modals/web3/{btc.js → btc.cjs} +0 -0
  192. /package/witnet/assets/modals/web3/{sol.js → sol.cjs} +0 -0
@@ -1,4 +1,4 @@
1
- import { Balance, Epoch, Hash, HexString, UtxoMetadata } from "../types";
1
+ import type { Balance, Epoch, Hash, HexString, UtxoMetadata } from "../types.js";
2
2
  export declare class Coins {
3
3
  protected coins: bigint;
4
4
  static fromBalance(balance: Balance): Coins;
@@ -146,7 +146,6 @@ declare abstract class TransactionError extends Error {
146
146
  constructor(receipt: TransactionReceipt, message?: string);
147
147
  }
148
148
  export declare class MempoolError extends TransactionError {
149
- constructor(receipt: TransactionReceipt, message?: string);
150
149
  }
151
150
  export declare class TimeoutError extends TransactionError {
152
151
  readonly msecs: number;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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"}
@@ -1,15 +1,11 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TransmissionError = exports.TimeoutError = exports.MempoolError = exports.RecoverableSignature = exports.Signature = exports.PublicKeyHash = exports.PublicKey = exports.UtxoSelectionStrategy = exports.TransactionPriority = exports.Coins = void 0;
4
- const secp256k1 = require('secp256k1');
5
- const bech32_1 = require("bech32");
6
- const helpers_1 = require("../../bin/helpers");
7
- const utils_1 = require("./utils");
8
- class Coins {
1
+ import { bech32 } from "bech32";
2
+ import secp256k1 from "secp256k1";
3
+ import { fromHexString, isHexString, toHexString, whole_wits, } from "../../bin/helpers.js";
4
+ import { sha256 } from "./utils.js";
5
+ export class Coins {
6
+ coins;
9
7
  static fromBalance(balance) {
10
- return Coins.fromPedros(balance.locked
11
- + balance.staked
12
- + balance.unlocked);
8
+ return Coins.fromPedros(balance.locked + balance.staked + balance.unlocked);
13
9
  }
14
10
  static fromNanowits(nanowits) {
15
11
  return new Coins(nanowits);
@@ -19,10 +15,10 @@ class Coins {
19
15
  }
20
16
  static fromWits(wits) {
21
17
  if (wits > Number.MAX_SAFE_INTEGER) {
22
- throw new TypeError(`${this.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`);
18
+ throw new TypeError(`${Coins.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`);
23
19
  }
24
- return new Coins(BigInt(Math.floor(wits)) * 10n ** 9n
25
- + BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000)));
20
+ return new Coins(BigInt(Math.floor(wits)) * 10n ** 9n +
21
+ BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000)));
26
22
  }
27
23
  static zero() {
28
24
  return new Coins(0n);
@@ -45,29 +41,30 @@ class Coins {
45
41
  return Number(quotient) + rest;
46
42
  }
47
43
  toString(decimals = 9) {
48
- return (0, helpers_1.whole_wits)(this.coins, decimals);
44
+ return whole_wits(this.coins, decimals);
49
45
  }
50
46
  }
51
- exports.Coins = Coins;
52
- var TransactionPriority;
47
+ export var TransactionPriority;
53
48
  (function (TransactionPriority) {
54
49
  TransactionPriority["Stinky"] = "stinky";
55
50
  TransactionPriority["Low"] = "low";
56
51
  TransactionPriority["Medium"] = "medium";
57
52
  TransactionPriority["High"] = "high";
58
53
  TransactionPriority["Opulent"] = "opulent";
59
- })(TransactionPriority || (exports.TransactionPriority = TransactionPriority = {}));
60
- var UtxoSelectionStrategy;
54
+ })(TransactionPriority || (TransactionPriority = {}));
55
+ export var UtxoSelectionStrategy;
61
56
  (function (UtxoSelectionStrategy) {
62
57
  UtxoSelectionStrategy["BigFirst"] = "big-first";
63
58
  UtxoSelectionStrategy["Random"] = "random";
64
59
  UtxoSelectionStrategy["SlimFit"] = "slim-fit";
65
60
  UtxoSelectionStrategy["SmallFirst"] = "small-first";
66
- })(UtxoSelectionStrategy || (exports.UtxoSelectionStrategy = UtxoSelectionStrategy = {}));
61
+ })(UtxoSelectionStrategy || (UtxoSelectionStrategy = {}));
67
62
  ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
68
- /// EXPORTED CLASSES
63
+ /// EXPORTED CLASSES
69
64
  /// ===================================================================================================================
70
- class PublicKey {
65
+ export class PublicKey {
66
+ compressed;
67
+ bytes;
71
68
  static fromProtobuf(protobuf) {
72
69
  return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes));
73
70
  }
@@ -76,8 +73,8 @@ class PublicKey {
76
73
  }
77
74
  static recoverFrom(recoverable, msg) {
78
75
  let bytes;
79
- if ((0, helpers_1.isHexString)(recoverable)) {
80
- bytes = (0, helpers_1.fromHexString)(recoverable);
76
+ if (isHexString(recoverable)) {
77
+ bytes = fromHexString(recoverable);
81
78
  }
82
79
  else if (recoverable instanceof Buffer) {
83
80
  bytes = Uint8Array.from(recoverable.buffer);
@@ -89,7 +86,7 @@ class PublicKey {
89
86
  throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`);
90
87
  }
91
88
  if (bytes.length !== 65) {
92
- throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${(0, helpers_1.toHexString)(bytes)}`);
89
+ throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`);
93
90
  }
94
91
  const [recoveryId, signature] = [bytes[0], bytes.slice(1)];
95
92
  return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg));
@@ -99,39 +96,38 @@ class PublicKey {
99
96
  this.bytes = bytes;
100
97
  }
101
98
  equals(pubKey) {
102
- return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes);
99
+ return (pubKey.compressed === this.compressed &&
100
+ matchingUint8Arrays(pubKey.bytes, pubKey.bytes));
103
101
  }
104
102
  hash() {
105
103
  return PublicKeyHash.fromPublicKey(this);
106
104
  }
107
105
  toHexString() {
108
- return (0, helpers_1.toHexString)([this.compressed, ...this.bytes]);
106
+ return toHexString([this.compressed, ...this.bytes]);
109
107
  }
110
108
  toUint8Array() {
111
109
  return Uint8Array.from([this.compressed, ...this.bytes]);
112
110
  }
113
111
  }
114
- exports.PublicKey = PublicKey;
115
- ;
116
112
  /// ===================================================================================================================
117
- class PublicKeyHash {
113
+ export class PublicKeyHash {
118
114
  static fromHash(hash) {
119
- return new PublicKeyHash(bech32_1.bech32.toWords(hash));
115
+ return new PublicKeyHash(bech32.toWords(hash));
120
116
  }
121
117
  static fromHexString(hash) {
122
- return PublicKeyHash.fromHash((0, helpers_1.fromHexString)(hash));
118
+ return PublicKeyHash.fromHash(fromHexString(hash));
123
119
  }
124
120
  static fromPublicKey(pk) {
125
- return PublicKeyHash.fromHash((0, utils_1.sha256)(Buffer.from([pk.compressed, ...pk.bytes])).subarray(0, 20));
121
+ return PublicKeyHash.fromHash(sha256(Buffer.from([pk.compressed, ...pk.bytes])).subarray(0, 20));
126
122
  }
127
123
  static fromBech32(pkh) {
128
124
  try {
129
125
  pkh = pkh.toLowerCase();
130
- if (pkh.startsWith('wit')) {
131
- return new PublicKeyHash(bech32_1.bech32.decode(pkh, 66).words);
126
+ if (pkh.startsWith("wit")) {
127
+ return new PublicKeyHash(bech32.decode(pkh, 66).words);
132
128
  }
133
- else if (pkh.startsWith('twit')) {
134
- return new PublicKeyHash(bech32_1.bech32.decode(pkh, 67).words);
129
+ else if (pkh.startsWith("twit")) {
130
+ return new PublicKeyHash(bech32.decode(pkh, 67).words);
135
131
  }
136
132
  else {
137
133
  throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);
@@ -141,45 +137,47 @@ class PublicKeyHash {
141
137
  throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);
142
138
  }
143
139
  }
140
+ words;
144
141
  constructor(words) {
145
142
  this.words = words;
146
143
  }
147
144
  toBech32(network = "mainnet") {
148
- return network === "mainnet" ? bech32_1.bech32.encode('wit', this.words, 66) : bech32_1.bech32.encode('twit', this.words, 67);
145
+ return network === "mainnet"
146
+ ? bech32.encode("wit", this.words, 66)
147
+ : bech32.encode("twit", this.words, 67);
149
148
  }
150
149
  toBytes20() {
151
- return Uint8Array.from(bech32_1.bech32.fromWords(this.words).slice(0, 20));
150
+ return Uint8Array.from(bech32.fromWords(this.words).slice(0, 20));
152
151
  }
153
152
  toBytes32() {
154
153
  return Uint8Array.from([
155
- ...bech32_1.bech32.fromWords(this.words).slice(0, 20),
154
+ ...bech32.fromWords(this.words).slice(0, 20),
156
155
  ...new Array(12).fill(0),
157
156
  ]);
158
157
  }
159
158
  toHexString() {
160
- return (0, helpers_1.toHexString)(this.toBytes20());
159
+ return toHexString(this.toBytes20());
161
160
  }
162
161
  }
163
- exports.PublicKeyHash = PublicKeyHash;
164
162
  /// ===================================================================================================================
165
- class Signature {
163
+ export class Signature {
166
164
  static fromHexString(hex) {
167
- return new Signature((0, helpers_1.fromHexString)(hex));
165
+ return new Signature(fromHexString(hex));
168
166
  }
167
+ bytes;
169
168
  constructor(bytes) {
170
169
  this.bytes = bytes;
171
170
  }
172
171
  toHexString() {
173
- return (0, helpers_1.toHexString)(this.bytes);
172
+ return toHexString(this.bytes);
174
173
  }
175
174
  }
176
- exports.Signature = Signature;
177
175
  /// ===================================================================================================================
178
- class RecoverableSignature extends Signature {
176
+ export class RecoverableSignature extends Signature {
179
177
  static from(recoverable, msg) {
180
178
  let bytes;
181
- if ((0, helpers_1.isHexString)(recoverable)) {
182
- bytes = (0, helpers_1.fromHexString)(recoverable).slice(1);
179
+ if (isHexString(recoverable)) {
180
+ bytes = fromHexString(recoverable).slice(1);
183
181
  }
184
182
  else if (recoverable instanceof Buffer) {
185
183
  bytes = Uint8Array.from(recoverable.buffer).slice(1);
@@ -191,13 +189,16 @@ class RecoverableSignature extends Signature {
191
189
  throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`);
192
190
  }
193
191
  if (bytes.length !== 64) {
194
- throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${(0, helpers_1.toHexString)(bytes)}`);
192
+ throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`);
195
193
  }
196
194
  return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg);
197
195
  }
198
196
  static fromKeyedSignature(ks, msg) {
199
197
  return new RecoverableSignature(PublicKey.fromProtobuf(ks.public_key), secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)), msg);
200
198
  }
199
+ message;
200
+ pubKey;
201
+ recoveryId;
201
202
  constructor(pubKey, bytes, msg) {
202
203
  super(bytes);
203
204
  const pubKeyRaw = pubKey.toUint8Array();
@@ -216,46 +217,50 @@ class RecoverableSignature extends Signature {
216
217
  this.recoveryId = recoveryId;
217
218
  }
218
219
  toHexString(prefix0x = false) {
219
- return (0, helpers_1.toHexString)([this.recoveryId, ...this.bytes], prefix0x);
220
+ return toHexString([this.recoveryId, ...this.bytes], prefix0x);
220
221
  }
221
222
  toKeyedSignature() {
222
223
  return {
223
- signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) } },
224
+ signature: {
225
+ Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) },
226
+ },
224
227
  public_key: {
225
228
  bytes: Array.from(this.pubKey.bytes),
226
229
  compressed: this.pubKey.compressed,
227
- }
230
+ },
228
231
  };
229
232
  }
230
233
  toProtobuf() {
231
234
  return {
232
- signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) } },
233
- publicKey: { publicKey: Array.from([this.pubKey.compressed, ...this.pubKey.bytes]) },
235
+ signature: {
236
+ Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) },
237
+ },
238
+ publicKey: {
239
+ publicKey: Array.from([this.pubKey.compressed, ...this.pubKey.bytes]),
240
+ },
234
241
  };
235
242
  }
236
243
  }
237
- exports.RecoverableSignature = RecoverableSignature;
238
244
  /// ===================================================================================================================
239
245
  class TransactionError extends Error {
246
+ receipt;
240
247
  constructor(receipt, message) {
241
248
  super(message);
242
249
  this.receipt = receipt;
243
250
  }
244
251
  }
245
- class MempoolError extends TransactionError {
246
- constructor(receipt, message) {
247
- super(receipt, message);
248
- }
252
+ export class MempoolError extends TransactionError {
249
253
  }
250
- exports.MempoolError = MempoolError;
251
- class TimeoutError extends TransactionError {
254
+ export class TimeoutError extends TransactionError {
255
+ msecs;
252
256
  constructor(msecs, receipt, message) {
253
257
  super(receipt, message);
254
258
  this.msecs = msecs;
255
259
  }
256
260
  }
257
- exports.TimeoutError = TimeoutError;
258
- class TransmissionError extends Error {
261
+ export class TransmissionError extends Error {
262
+ error;
263
+ inFlight;
259
264
  constructor(inFlight, error) {
260
265
  super(JSON.stringify(error));
261
266
  delete error?.stack;
@@ -263,10 +268,9 @@ class TransmissionError extends Error {
263
268
  this.inFlight = inFlight;
264
269
  }
265
270
  }
266
- exports.TransmissionError = TransmissionError;
267
271
  /// -------------------------------------------------------------------------------------------------------------------
268
- /// --- Internal functions
272
+ /// --- Internal functions
269
273
  function matchingUint8Arrays(a, b) {
270
274
  return a.length === b.length && a.every((value, index) => value === b[index]);
271
275
  }
272
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require('secp256k1')\r\nimport { bech32 } from 'bech32'\r\nimport { Balance, Epoch, Hash, HexString, UtxoMetadata } from \"../types\"\r\n\r\nimport { fromHexString, isHexString, toHexString, whole_wits } from \"../../bin/helpers\"\r\nimport { sha256 } from \"./utils\"\r\n\r\nexport class Coins {\r\n    protected coins: bigint;\r\n    public static fromBalance(balance: Balance): Coins {\r\n        return Coins.fromPedros(\r\n            balance.locked\r\n                + balance.staked\r\n                + balance.unlocked\r\n        )\r\n    }\r\n    public static fromNanowits(nanowits: bigint): Coins {\r\n        return new Coins(nanowits)\r\n    }\r\n    public static fromPedros(pedros: bigint): Coins {\r\n        return new Coins(pedros)\r\n    }\r\n    public static fromWits(wits: number): Coins {\r\n        if (wits > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        return new Coins(\r\n            BigInt(Math.floor(wits)) * 10n ** 9n\r\n                + BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000))\r\n        )\r\n    }\r\n    public static zero(): Coins {\r\n        return new Coins(0n)\r\n    }\r\n    constructor (pedros: bigint) {\r\n        this.coins = pedros\r\n    }\r\n    public get pedros(): bigint {\r\n        return this.coins\r\n    }\r\n    public get nanowits(): bigint {\r\n        return this.coins\r\n    }\r\n    public get wits(): number {\r\n        const quotient = BigInt(this.coins) / 1000000000n\r\n        if (Number(quotient) > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        const rest = Number(BigInt(this.coins) - quotient * 1000000000n) / 1000000000\r\n        return Number(quotient) + rest\r\n    }\r\n    public toString(decimals = 9): string {\r\n        return whole_wits(this.coins, decimals)\r\n    }\r\n}\r\n\r\nexport type KeyPath = Array<number>\r\n\r\nexport type KeyedSignature = {\r\n    signature: { Secp256k1: { der: Array<number> }},\r\n    public_key: {\r\n        bytes: Array<number>;\r\n        compressed: number,\r\n    },\r\n};\r\n\r\nexport type PublicKeyHashString = HexString\r\n\r\ninterface Key {\r\n    bytes: Uint8Array;\r\n}\r\n\r\nexport interface PrivateKey extends Key {\r\n    type: \"private\";\r\n}\r\n\r\nexport interface PublicKey extends Key {\r\n    type: \"public\";\r\n}\r\n\r\nexport type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any\r\n\r\nexport type TransactionParams = {\r\n    deadline?: Epoch,\r\n    fees?: TransactionPriority | Coins,\r\n}\r\n\r\nexport enum TransactionPriority {\r\n    Stinky = \"stinky\",\r\n    Low = \"low\",\r\n    Medium = \"medium\",\r\n    High = \"high\",\r\n    Opulent = \"opulent\",\r\n}\r\n\r\nexport type TransactionReceipt = {\r\n    authorization?: HexString;\r\n    blockEpoch?: Epoch,\r\n    blockHash?: Hash,\r\n    blockMiner?: PublicKeyHashString,\r\n    blockTimestamp?: number,\r\n    confirmations?: number;\r\n    change?: Coins;\r\n    droHash?: Hash;\r\n    error?: Error,\r\n    fees: Coins;\r\n    from?: Array<PublicKeyHashString> | PublicKeyHashString;\r\n    hash: Hash;\r\n    outputLock?: number;\r\n    radArgs?: any;\r\n    radHash?: HexString;\r\n    recipients?: Array<[PublicKeyHashString, Coins]>;\r\n    status: string;\r\n    timestamp: number;\r\n    type: string;\r\n    tx?: any;\r\n    validator?: PublicKeyHashString;\r\n    value?: Coins;\r\n    weight: number;\r\n    withdrawer?: PublicKeyHashString;\r\n    witnesses?: number | Record<PublicKeyHashString, Coins>;\r\n}\r\n\r\nexport type TransactionStatus = \"signed\" | \"pending\" | \"relayed\" | \"removed\" | \"mined\" | \"confirmed\" | \"finalized\";\r\n\r\nexport type Transmission = {\r\n    bytecode?: Uint8Array,\r\n    hash?: Hash;\r\n    message: any;\r\n}\r\n\r\nexport type Utxo = UtxoMetadata & { signer: PublicKeyHashString }\r\n\r\nexport type UtxoCacheInfo = {\r\n    // total amount of expendable funds with currently cached UTXOs\r\n    expendable: bigint, \r\n    // number of cached UTXOs\r\n    size: number, \r\n    // earliest of all timelocks in the caché\r\n    timelock: number,\r\n}\r\n\r\nexport type UtxoPointer = {\r\n    // transaction identifier\r\n    transaction_id: Hash;\r\n    // output index within referred transaction\r\n    output_index: number;\r\n};\r\n\r\nexport enum UtxoSelectionStrategy {\r\n    BigFirst = \"big-first\",\r\n    Random = \"random\",\r\n    SlimFit = \"slim-fit\",\r\n    SmallFirst = \"small-first\",\r\n}\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n/// EXPORTED CLASSES \r\n\r\n/// ===================================================================================================================\r\nexport class PublicKey implements Key {\r\n    \r\n    public readonly compressed: number;\r\n    public readonly bytes: Uint8Array;\r\n\r\n    static fromProtobuf(protobuf: { compressed: number, bytes: Array<number> }): PublicKey {\r\n        return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes))\r\n    }\r\n\r\n    static fromUint8Array(uint8Array: Uint8Array): PublicKey {\r\n        return new PublicKey(\r\n            uint8Array[0],\r\n            uint8Array.slice(1),\r\n        );\r\n    }\r\n\r\n    static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable\r\n        } else {\r\n            throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 65) {\r\n            throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        const [ recoveryId, signature ] = [ bytes[0], bytes.slice(1) ]\r\n        return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg))\r\n    }\r\n\r\n    constructor(compressed: number, bytes: Uint8Array) {\r\n        this.compressed = compressed\r\n        this.bytes = bytes\r\n    }\r\n\r\n    public equals(pubKey: PublicKey): boolean {\r\n        return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes)\r\n    }\r\n\r\n    public hash(): PublicKeyHash {\r\n        return PublicKeyHash.fromPublicKey(this)\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString([this.compressed, ...this.bytes])\r\n    }\r\n\r\n    public toUint8Array(): Uint8Array {\r\n        return Uint8Array.from([this.compressed, ...this.bytes])\r\n    }\r\n};\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class PublicKeyHash {\r\n\r\n    static fromHash(hash: Uint8Array): PublicKeyHash {\r\n        return new PublicKeyHash(bech32.toWords(hash));\r\n    }\r\n\r\n    static fromHexString(hash: HexString): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(fromHexString(hash))\r\n    }\r\n    \r\n    static fromPublicKey(pk: PublicKey): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(\r\n            sha256(\r\n                Buffer.from([pk.compressed, ...pk.bytes])\r\n            ).subarray(0, 20)\r\n        );\r\n    }\r\n    \r\n    static fromBech32(pkh: string): PublicKeyHash {\r\n        try {\r\n            pkh = pkh.toLowerCase()\r\n            if (pkh.startsWith('wit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 66).words)\r\n            } else if (pkh.startsWith('twit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 67).words)\r\n            } else {\r\n                throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n            }\r\n        } catch {\r\n            throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n        }\r\n    }\r\n\r\n    protected words: number[];\r\n    \r\n    constructor(words: number[]) {\r\n        this.words = words\r\n    }\r\n\r\n    public toBech32(network = \"mainnet\"): string {\r\n        return network === \"mainnet\" ? bech32.encode('wit', this.words, 66) : bech32.encode('twit', this.words, 67);\r\n    }\r\n\r\n    public toBytes20(): Uint8Array {\r\n        return Uint8Array.from(bech32.fromWords(this.words).slice(0, 20))\r\n    }\r\n\r\n    public toBytes32(): Uint8Array {\r\n        return Uint8Array.from([\r\n            ...bech32.fromWords(this.words).slice(0, 20),\r\n            ...new Array(12).fill(0),\r\n        ]);\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString(this.toBytes20())\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class Signature {\r\n\r\n    static fromHexString(hex: string): Signature {\r\n        return new Signature(fromHexString(hex))\r\n    }\r\n\r\n    public readonly bytes: Uint8Array;\r\n\r\n    constructor (bytes: Uint8Array) {\r\n        this.bytes = bytes\r\n    }\r\n    \r\n    public toHexString(): string {\r\n        return toHexString(this.bytes)\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class RecoverableSignature extends Signature {\r\n\r\n    static from(recoverable: any, msg: Uint8Array): RecoverableSignature {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable).slice(1)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer).slice(1)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable.slice(1)\r\n        } else {\r\n            throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 64) {\r\n            throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg)\r\n    }\r\n\r\n    static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature {\r\n        return new RecoverableSignature(\r\n            PublicKey.fromProtobuf(ks.public_key),\r\n            secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)),\r\n            msg\r\n        )   \r\n    }\r\n\r\n    public readonly message: Uint8Array\r\n    public readonly pubKey: PublicKey\r\n    public readonly recoveryId: number\r\n    \r\n    constructor (pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array) {\r\n        super(bytes)\r\n        const pubKeyRaw = pubKey.toUint8Array()\r\n        let recoveryId: number;\r\n        for (recoveryId = 0; recoveryId < 4; recoveryId ++) {\r\n            let recovered \r\n            try {\r\n              recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg)\r\n              if (matchingUint8Arrays(recovered, pubKeyRaw)) break;\r\n            } catch {}\r\n        }\r\n        this.message = msg\r\n        this.pubKey = pubKey\r\n        this.recoveryId = recoveryId\r\n    }\r\n\r\n    public toHexString(prefix0x = false): string {\r\n        return toHexString([this.recoveryId, ...this.bytes], prefix0x)\r\n    }\r\n\r\n    public toKeyedSignature(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            public_key: {\r\n                bytes: Array.from(this.pubKey.bytes),\r\n                compressed: this.pubKey.compressed,\r\n            }\r\n        }\r\n    }\r\n\r\n    public toProtobuf(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            publicKey: { publicKey: Array.from([ this.pubKey.compressed, ...this.pubKey.bytes ]) },\r\n        }\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\n\r\nabstract class TransactionError extends Error {\r\n    readonly receipt: TransactionReceipt\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(message)\r\n        this.receipt = receipt\r\n    }\r\n}\r\nexport class MempoolError extends TransactionError {\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n    }\r\n}\r\n\r\nexport class TimeoutError extends TransactionError {\r\n    readonly msecs: number;\r\n    constructor (msecs: number, receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n        this.msecs = msecs\r\n    }\r\n}\r\n    \r\n\r\nexport class TransmissionError extends Error {\r\n    readonly error?: any;\r\n    readonly inFlight: Transmission;\r\n    constructor(inFlight: Transmission, error?: any) {\r\n        super(JSON.stringify(error))\r\n        delete error?.stack\r\n        this.error = error\r\n        this.inFlight = inFlight\r\n    }\r\n}\r\n\r\n\r\n/// -------------------------------------------------------------------------------------------------------------------\r\n/// --- Internal functions \r\n\r\nfunction matchingUint8Arrays(a: Uint8Array, b: Uint8Array) {\r\n    return a.length === b.length && a.every((value, index) => value === b[index])\r\n}\r\n"]}
276
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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","sourcesContent":["import { bech32 } from \"bech32\";\r\nimport secp256k1 from \"secp256k1\";\r\nimport {\r\n\tfromHexString,\r\n\tisHexString,\r\n\ttoHexString,\r\n\twhole_wits,\r\n} from \"../../bin/helpers.js\";\r\nimport type {\r\n\tBalance,\r\n\tEpoch,\r\n\tHash,\r\n\tHexString,\r\n\tUtxoMetadata,\r\n} from \"../types.js\";\r\nimport { sha256 } from \"./utils.js\";\r\n\r\nexport class Coins {\r\n\tprotected coins: bigint;\r\n\tpublic static fromBalance(balance: Balance): Coins {\r\n\t\treturn Coins.fromPedros(balance.locked + balance.staked + balance.unlocked);\r\n\t}\r\n\tpublic static fromNanowits(nanowits: bigint): Coins {\r\n\t\treturn new Coins(nanowits);\r\n\t}\r\n\tpublic static fromPedros(pedros: bigint): Coins {\r\n\t\treturn new Coins(pedros);\r\n\t}\r\n\tpublic static fromWits(wits: number): Coins {\r\n\t\tif (wits > Number.MAX_SAFE_INTEGER) {\r\n\t\t\tthrow new TypeError(\r\n\t\t\t\t`${Coins.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`,\r\n\t\t\t);\r\n\t\t}\r\n\t\treturn new Coins(\r\n\t\t\tBigInt(Math.floor(wits)) * 10n ** 9n +\r\n\t\t\t\tBigInt(Math.floor((wits - Math.floor(wits)) * 1000000000)),\r\n\t\t);\r\n\t}\r\n\tpublic static zero(): Coins {\r\n\t\treturn new Coins(0n);\r\n\t}\r\n\tconstructor(pedros: bigint) {\r\n\t\tthis.coins = pedros;\r\n\t}\r\n\tpublic get pedros(): bigint {\r\n\t\treturn this.coins;\r\n\t}\r\n\tpublic get nanowits(): bigint {\r\n\t\treturn this.coins;\r\n\t}\r\n\tpublic get wits(): number {\r\n\t\tconst quotient = BigInt(this.coins) / 1000000000n;\r\n\t\tif (Number(quotient) > Number.MAX_SAFE_INTEGER) {\r\n\t\t\tthrow new TypeError(\r\n\t\t\t\t`${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`,\r\n\t\t\t);\r\n\t\t}\r\n\t\tconst rest =\r\n\t\t\tNumber(BigInt(this.coins) - quotient * 1000000000n) / 1000000000;\r\n\t\treturn Number(quotient) + rest;\r\n\t}\r\n\tpublic toString(decimals = 9): string {\r\n\t\treturn whole_wits(this.coins, decimals);\r\n\t}\r\n}\r\n\r\nexport type KeyPath = Array<number>;\r\n\r\nexport type KeyedSignature = {\r\n\tsignature: { Secp256k1: { der: Array<number> } };\r\n\tpublic_key: {\r\n\t\tbytes: Array<number>;\r\n\t\tcompressed: number;\r\n\t};\r\n};\r\n\r\nexport type PublicKeyHashString = HexString;\r\n\r\ninterface Key {\r\n\tbytes: Uint8Array;\r\n}\r\n\r\nexport interface PrivateKey extends Key {\r\n\ttype: \"private\";\r\n}\r\n\r\nexport interface PublicKey extends Key {\r\n\ttype: \"public\";\r\n}\r\n\r\nexport type TransactionCallback = (\r\n\treceipt: TransactionReceipt,\r\n\terror?: any,\r\n) => any;\r\n\r\nexport type TransactionParams = {\r\n\tdeadline?: Epoch;\r\n\tfees?: TransactionPriority | Coins;\r\n};\r\n\r\nexport enum TransactionPriority {\r\n\tStinky = \"stinky\",\r\n\tLow = \"low\",\r\n\tMedium = \"medium\",\r\n\tHigh = \"high\",\r\n\tOpulent = \"opulent\",\r\n}\r\n\r\nexport type TransactionReceipt = {\r\n\tauthorization?: HexString;\r\n\tblockEpoch?: Epoch;\r\n\tblockHash?: Hash;\r\n\tblockMiner?: PublicKeyHashString;\r\n\tblockTimestamp?: number;\r\n\tconfirmations?: number;\r\n\tchange?: Coins;\r\n\tdroHash?: Hash;\r\n\terror?: Error;\r\n\tfees: Coins;\r\n\tfrom?: Array<PublicKeyHashString> | PublicKeyHashString;\r\n\thash: Hash;\r\n\toutputLock?: number;\r\n\tradArgs?: any;\r\n\tradHash?: HexString;\r\n\trecipients?: Array<[PublicKeyHashString, Coins]>;\r\n\tstatus: string;\r\n\ttimestamp: number;\r\n\ttype: string;\r\n\ttx?: any;\r\n\tvalidator?: PublicKeyHashString;\r\n\tvalue?: Coins;\r\n\tweight: number;\r\n\twithdrawer?: PublicKeyHashString;\r\n\twitnesses?: number | Record<PublicKeyHashString, Coins>;\r\n};\r\n\r\nexport type TransactionStatus =\r\n\t| \"signed\"\r\n\t| \"pending\"\r\n\t| \"relayed\"\r\n\t| \"removed\"\r\n\t| \"mined\"\r\n\t| \"confirmed\"\r\n\t| \"finalized\";\r\n\r\nexport type Transmission = {\r\n\tbytecode?: Uint8Array;\r\n\thash?: Hash;\r\n\tmessage: any;\r\n};\r\n\r\nexport type Utxo = UtxoMetadata & { signer: PublicKeyHashString };\r\n\r\nexport type UtxoCacheInfo = {\r\n\t// total amount of expendable funds with currently cached UTXOs\r\n\texpendable: bigint;\r\n\t// number of cached UTXOs\r\n\tsize: number;\r\n\t// earliest of all timelocks in the caché\r\n\ttimelock: number;\r\n};\r\n\r\nexport type UtxoPointer = {\r\n\t// transaction identifier\r\n\ttransaction_id: Hash;\r\n\t// output index within referred transaction\r\n\toutput_index: number;\r\n};\r\n\r\nexport enum UtxoSelectionStrategy {\r\n\tBigFirst = \"big-first\",\r\n\tRandom = \"random\",\r\n\tSlimFit = \"slim-fit\",\r\n\tSmallFirst = \"small-first\",\r\n}\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n/// EXPORTED CLASSES\r\n\r\n/// ===================================================================================================================\r\nexport class PublicKey implements Key {\r\n\tpublic readonly compressed: number;\r\n\tpublic readonly bytes: Uint8Array;\r\n\r\n\tstatic fromProtobuf(protobuf: {\r\n\t\tcompressed: number;\r\n\t\tbytes: Array<number>;\r\n\t}): PublicKey {\r\n\t\treturn new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes));\r\n\t}\r\n\r\n\tstatic fromUint8Array(uint8Array: Uint8Array): PublicKey {\r\n\t\treturn new PublicKey(uint8Array[0], uint8Array.slice(1));\r\n\t}\r\n\r\n\tstatic recoverFrom(recoverable: any, msg: Uint8Array): PublicKey {\r\n\t\tlet bytes;\r\n\t\tif (isHexString(recoverable)) {\r\n\t\t\tbytes = fromHexString(recoverable);\r\n\t\t} else if (recoverable instanceof Buffer) {\r\n\t\t\tbytes = Uint8Array.from(recoverable.buffer);\r\n\t\t} else if (recoverable instanceof Uint8Array) {\r\n\t\t\tbytes = recoverable;\r\n\t\t} else {\r\n\t\t\tthrow new TypeError(\r\n\t\t\t\t`PublicKey: unsupported recoverable signature format: ${recoverable}`,\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (bytes.length !== 65) {\r\n\t\t\tthrow new TypeError(\r\n\t\t\t\t`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`,\r\n\t\t\t);\r\n\t\t}\r\n\t\tconst [recoveryId, signature] = [bytes[0], bytes.slice(1)];\r\n\t\treturn PublicKey.fromUint8Array(\r\n\t\t\tsecp256k1.ecdsaRecover(signature, recoveryId, msg),\r\n\t\t);\r\n\t}\r\n\r\n\tconstructor(compressed: number, bytes: Uint8Array) {\r\n\t\tthis.compressed = compressed;\r\n\t\tthis.bytes = bytes;\r\n\t}\r\n\r\n\tpublic equals(pubKey: PublicKey): boolean {\r\n\t\treturn (\r\n\t\t\tpubKey.compressed === this.compressed &&\r\n\t\t\tmatchingUint8Arrays(pubKey.bytes, pubKey.bytes)\r\n\t\t);\r\n\t}\r\n\r\n\tpublic hash(): PublicKeyHash {\r\n\t\treturn PublicKeyHash.fromPublicKey(this);\r\n\t}\r\n\r\n\tpublic toHexString(): string {\r\n\t\treturn toHexString([this.compressed, ...this.bytes]);\r\n\t}\r\n\r\n\tpublic toUint8Array(): Uint8Array {\r\n\t\treturn Uint8Array.from([this.compressed, ...this.bytes]);\r\n\t}\r\n}\r\n\r\n/// ===================================================================================================================\r\nexport class PublicKeyHash {\r\n\tstatic fromHash(hash: Uint8Array): PublicKeyHash {\r\n\t\treturn new PublicKeyHash(bech32.toWords(hash));\r\n\t}\r\n\r\n\tstatic fromHexString(hash: HexString): PublicKeyHash {\r\n\t\treturn PublicKeyHash.fromHash(fromHexString(hash));\r\n\t}\r\n\r\n\tstatic fromPublicKey(pk: PublicKey): PublicKeyHash {\r\n\t\treturn PublicKeyHash.fromHash(\r\n\t\t\tsha256(Buffer.from([pk.compressed, ...pk.bytes])).subarray(0, 20),\r\n\t\t);\r\n\t}\r\n\r\n\tstatic fromBech32(pkh: string): PublicKeyHash {\r\n\t\ttry {\r\n\t\t\tpkh = pkh.toLowerCase();\r\n\t\t\tif (pkh.startsWith(\"wit\")) {\r\n\t\t\t\treturn new PublicKeyHash(bech32.decode(pkh, 66).words);\r\n\t\t\t} else if (pkh.startsWith(\"twit\")) {\r\n\t\t\t\treturn new PublicKeyHash(bech32.decode(pkh, 67).words);\r\n\t\t\t} else {\r\n\t\t\t\tthrow new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n\t\t\t}\r\n\t\t} catch {\r\n\t\t\tthrow new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n\t\t}\r\n\t}\r\n\r\n\tprotected words: number[];\r\n\r\n\tconstructor(words: number[]) {\r\n\t\tthis.words = words;\r\n\t}\r\n\r\n\tpublic toBech32(network = \"mainnet\"): string {\r\n\t\treturn network === \"mainnet\"\r\n\t\t\t? bech32.encode(\"wit\", this.words, 66)\r\n\t\t\t: bech32.encode(\"twit\", this.words, 67);\r\n\t}\r\n\r\n\tpublic toBytes20(): Uint8Array {\r\n\t\treturn Uint8Array.from(bech32.fromWords(this.words).slice(0, 20));\r\n\t}\r\n\r\n\tpublic toBytes32(): Uint8Array {\r\n\t\treturn Uint8Array.from([\r\n\t\t\t...bech32.fromWords(this.words).slice(0, 20),\r\n\t\t\t...new Array(12).fill(0),\r\n\t\t]);\r\n\t}\r\n\r\n\tpublic toHexString(): string {\r\n\t\treturn toHexString(this.toBytes20());\r\n\t}\r\n}\r\n\r\n/// ===================================================================================================================\r\nexport class Signature {\r\n\tstatic fromHexString(hex: string): Signature {\r\n\t\treturn new Signature(fromHexString(hex));\r\n\t}\r\n\r\n\tpublic readonly bytes: Uint8Array;\r\n\r\n\tconstructor(bytes: Uint8Array) {\r\n\t\tthis.bytes = bytes;\r\n\t}\r\n\r\n\tpublic toHexString(): string {\r\n\t\treturn toHexString(this.bytes);\r\n\t}\r\n}\r\n\r\n/// ===================================================================================================================\r\nexport class RecoverableSignature extends Signature {\r\n\tstatic from(recoverable: any, msg: Uint8Array): RecoverableSignature {\r\n\t\tlet bytes;\r\n\t\tif (isHexString(recoverable)) {\r\n\t\t\tbytes = fromHexString(recoverable).slice(1);\r\n\t\t} else if (recoverable instanceof Buffer) {\r\n\t\t\tbytes = Uint8Array.from(recoverable.buffer).slice(1);\r\n\t\t} else if (recoverable instanceof Uint8Array) {\r\n\t\t\tbytes = recoverable.slice(1);\r\n\t\t} else {\r\n\t\t\tthrow new TypeError(\r\n\t\t\t\t`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`,\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (bytes.length !== 64) {\r\n\t\t\tthrow new TypeError(\r\n\t\t\t\t`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`,\r\n\t\t\t);\r\n\t\t}\r\n\t\treturn new RecoverableSignature(\r\n\t\t\tPublicKey.recoverFrom(recoverable, msg),\r\n\t\t\tbytes,\r\n\t\t\tmsg,\r\n\t\t);\r\n\t}\r\n\r\n\tstatic fromKeyedSignature(\r\n\t\tks: KeyedSignature,\r\n\t\tmsg: Uint8Array,\r\n\t): RecoverableSignature {\r\n\t\treturn new RecoverableSignature(\r\n\t\t\tPublicKey.fromProtobuf(ks.public_key),\r\n\t\t\tsecp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)),\r\n\t\t\tmsg,\r\n\t\t);\r\n\t}\r\n\r\n\tpublic readonly message: Uint8Array;\r\n\tpublic readonly pubKey: PublicKey;\r\n\tpublic readonly recoveryId: number;\r\n\r\n\tconstructor(pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array) {\r\n\t\tsuper(bytes);\r\n\t\tconst pubKeyRaw = pubKey.toUint8Array();\r\n\t\tlet recoveryId: number;\r\n\t\tfor (recoveryId = 0; recoveryId < 4; recoveryId++) {\r\n\t\t\tlet recovered;\r\n\t\t\ttry {\r\n\t\t\t\trecovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg);\r\n\t\t\t\tif (matchingUint8Arrays(recovered, pubKeyRaw)) break;\r\n\t\t\t} catch {}\r\n\t\t}\r\n\t\tthis.message = msg;\r\n\t\tthis.pubKey = pubKey;\r\n\t\tthis.recoveryId = recoveryId;\r\n\t}\r\n\r\n\tpublic toHexString(prefix0x = false): string {\r\n\t\treturn toHexString([this.recoveryId, ...this.bytes], prefix0x);\r\n\t}\r\n\r\n\tpublic toKeyedSignature(): any {\r\n\t\treturn {\r\n\t\t\tsignature: {\r\n\t\t\t\tSecp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) },\r\n\t\t\t},\r\n\t\t\tpublic_key: {\r\n\t\t\t\tbytes: Array.from(this.pubKey.bytes),\r\n\t\t\t\tcompressed: this.pubKey.compressed,\r\n\t\t\t},\r\n\t\t};\r\n\t}\r\n\r\n\tpublic toProtobuf(): any {\r\n\t\treturn {\r\n\t\t\tsignature: {\r\n\t\t\t\tSecp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) },\r\n\t\t\t},\r\n\t\t\tpublicKey: {\r\n\t\t\t\tpublicKey: Array.from([this.pubKey.compressed, ...this.pubKey.bytes]),\r\n\t\t\t},\r\n\t\t};\r\n\t}\r\n}\r\n\r\n/// ===================================================================================================================\r\n\r\nabstract class TransactionError extends Error {\r\n\treadonly receipt: TransactionReceipt;\r\n\tconstructor(receipt: TransactionReceipt, message?: string) {\r\n\t\tsuper(message);\r\n\t\tthis.receipt = receipt;\r\n\t}\r\n}\r\nexport class MempoolError extends TransactionError {}\r\n\r\nexport class TimeoutError extends TransactionError {\r\n\treadonly msecs: number;\r\n\tconstructor(msecs: number, receipt: TransactionReceipt, message?: string) {\r\n\t\tsuper(receipt, message);\r\n\t\tthis.msecs = msecs;\r\n\t}\r\n}\r\n\r\nexport class TransmissionError extends Error {\r\n\treadonly error?: any;\r\n\treadonly inFlight: Transmission;\r\n\tconstructor(inFlight: Transmission, error?: any) {\r\n\t\tsuper(JSON.stringify(error));\r\n\t\tdelete error?.stack;\r\n\t\tthis.error = error;\r\n\t\tthis.inFlight = inFlight;\r\n\t}\r\n}\r\n\r\n/// -------------------------------------------------------------------------------------------------------------------\r\n/// --- Internal functions\r\n\r\nfunction matchingUint8Arrays(a: Uint8Array, b: Uint8Array) {\r\n\treturn a.length === b.length && a.every((value, index) => value === b[index]);\r\n}\r\n"]}
@@ -1,7 +1,7 @@
1
- import { Balance, HexString } from '../types';
2
- import { Coins, Utxo, UtxoSelectionStrategy } from './types';
3
- export { bech32 } from 'bech32';
4
- export { PrivateKey, PublicKey, PublicKeyHash, KeyedSignature, RecoverableSignature, Signature } from "./types";
1
+ import type { Balance, HexString } from "../types.js";
2
+ import { Coins, type Utxo, UtxoSelectionStrategy } from "./types.js";
3
+ export { bech32 } from "bech32";
4
+ export { KeyedSignature, PrivateKey, PublicKey, PublicKeyHash, RecoverableSignature, Signature, } from "./types.js";
5
5
  export declare const BigMath: {
6
6
  max(value: bigint, ...values: bigint[]): bigint;
7
7
  };
@@ -17,6 +17,6 @@ export declare function selectUtxos(specs: {
17
17
  value?: Coins;
18
18
  strategy?: UtxoSelectionStrategy;
19
19
  }): Array<Utxo>;
20
- export declare function sha256(buffer: any): Buffer<ArrayBufferLike>;
20
+ export declare function sha256(buffer: any): NonSharedBuffer;
21
21
  export declare function totalCoins(balance: Balance): Coins;
22
22
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAC7C,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAG5D,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAE/B,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAE/G,eAAO,MAAM,OAAO;eACL,MAAM,aAAa,MAAM,EAAE,GAAG,MAAM;CAKlD,CAAA;AAqBD,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAcnE;AAED,wBAAgB,WAAW,CACvB,GAAG,EAAE,MAAM,CAAC,eAAe,CAAC,EAC5B,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,GACrB,OAAO,CAOT;AAED,eAAO,MAAM,SAAS,GAAI,QAAQ,MAAM,KAAG;IACvC,SAAS,EAAE,UAAU,CAAC;IACtB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAyD1B,CAAC;AAEF,wBAAgB,WAAW,CAAC,KAAK,EAAE;IAC/B,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,QAAQ,CAAC,EAAE,qBAAqB,CAAC;CACpC,GAAG,KAAK,CAAC,IAAI,CAAC,CA6Cd;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,GAAG,2BAIjC;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK,CAMlD"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAEtD,OAAO,EAAE,KAAK,EAAE,KAAK,IAAI,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAErE,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,OAAO,EACN,cAAc,EACd,UAAU,EACV,SAAS,EACT,aAAa,EACb,oBAAoB,EACpB,SAAS,GACT,MAAM,YAAY,CAAC;AAEpB,eAAO,MAAM,OAAO;eACR,MAAM,aAAa,MAAM,EAAE,GAAG,MAAM;CAI/C,CAAC;AAgBF,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAcnE;AAED,wBAAgB,WAAW,CAC1B,GAAG,EAAE,MAAM,CAAC,eAAe,CAAC,EAC5B,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,GAClB,OAAO,CAMT;AAED,eAAO,MAAM,SAAS,GACrB,QAAQ,MAAM,KACZ;IACF,SAAS,EAAE,UAAU,CAAC;IACtB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAoEvB,CAAC;AAEF,wBAAgB,WAAW,CAAC,KAAK,EAAE;IAClC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,QAAQ,CAAC,EAAE,qBAAqB,CAAC;CACjC,GAAG,KAAK,CAAC,IAAI,CAAC,CAoDd;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,GAAG,mBAIjC;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK,CAIlD"}