@witnet/sdk 1.0.3 → 1.0.4

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 (197) hide show
  1. package/.env_witnet +6 -6
  2. package/LICENSE +21 -21
  3. package/README.md +103 -103
  4. package/dist/bin/helpers.d.ts +88 -0
  5. package/dist/bin/helpers.d.ts.map +1 -0
  6. package/dist/bin/helpers.js +866 -0
  7. package/dist/index.d.ts +4 -0
  8. package/dist/index.d.ts.map +1 -0
  9. package/dist/index.js +42 -0
  10. package/dist/lib/crypto/account.d.ts +18 -0
  11. package/dist/lib/crypto/account.d.ts.map +1 -0
  12. package/dist/lib/crypto/account.js +152 -0
  13. package/dist/lib/crypto/coinbase.d.ts +9 -0
  14. package/dist/lib/crypto/coinbase.d.ts.map +1 -0
  15. package/dist/lib/crypto/coinbase.js +39 -0
  16. package/dist/lib/crypto/index.d.ts +7 -0
  17. package/dist/lib/crypto/index.d.ts.map +1 -0
  18. package/dist/lib/crypto/index.js +28 -0
  19. package/dist/lib/crypto/interfaces.d.ts +80 -0
  20. package/dist/lib/crypto/interfaces.d.ts.map +1 -0
  21. package/dist/lib/crypto/interfaces.js +3 -0
  22. package/dist/lib/crypto/payloads/DataRequestPayload.d.ts +47 -0
  23. package/dist/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -0
  24. package/dist/lib/crypto/payloads/DataRequestPayload.js +384 -0
  25. package/dist/lib/crypto/payloads/StakePayload.d.ts +27 -0
  26. package/dist/lib/crypto/payloads/StakePayload.d.ts.map +1 -0
  27. package/dist/lib/crypto/payloads/StakePayload.js +184 -0
  28. package/dist/lib/crypto/payloads/UnstakePayload.d.ts +35 -0
  29. package/dist/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -0
  30. package/dist/lib/crypto/payloads/UnstakePayload.js +244 -0
  31. package/dist/lib/crypto/payloads/ValueTransferPayload.d.ts +24 -0
  32. package/dist/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -0
  33. package/dist/lib/crypto/payloads/ValueTransferPayload.js +182 -0
  34. package/dist/lib/crypto/payloads.d.ts +54 -0
  35. package/dist/lib/crypto/payloads.d.ts.map +1 -0
  36. package/dist/lib/crypto/payloads.js +224 -0
  37. package/dist/lib/crypto/signer.d.ts +26 -0
  38. package/dist/lib/crypto/signer.d.ts.map +1 -0
  39. package/dist/lib/crypto/signer.js +299 -0
  40. package/dist/lib/crypto/transmitters/DataRequests.d.ts +14 -0
  41. package/dist/lib/crypto/transmitters/DataRequests.d.ts.map +1 -0
  42. package/dist/lib/crypto/transmitters/DataRequests.js +62 -0
  43. package/dist/lib/crypto/transmitters/StakeDeposits.d.ts +11 -0
  44. package/dist/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -0
  45. package/dist/lib/crypto/transmitters/StakeDeposits.js +48 -0
  46. package/dist/lib/crypto/transmitters/StakeWithdrawals.d.ts +17 -0
  47. package/dist/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -0
  48. package/dist/lib/crypto/transmitters/StakeWithdrawals.js +115 -0
  49. package/dist/lib/crypto/transmitters/ValueTransfers.d.ts +10 -0
  50. package/dist/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -0
  51. package/dist/lib/crypto/transmitters/ValueTransfers.js +47 -0
  52. package/dist/lib/crypto/transmitters.d.ts +46 -0
  53. package/dist/lib/crypto/transmitters.d.ts.map +1 -0
  54. package/dist/lib/crypto/transmitters.js +506 -0
  55. package/dist/lib/crypto/types.d.ts +127 -0
  56. package/dist/lib/crypto/types.d.ts.map +1 -0
  57. package/dist/lib/crypto/types.js +261 -0
  58. package/dist/lib/crypto/utils.d.ts +10 -0
  59. package/dist/lib/crypto/utils.d.ts.map +1 -0
  60. package/dist/lib/crypto/utils.js +97 -0
  61. package/dist/lib/crypto/wallet.d.ts +26 -0
  62. package/dist/lib/crypto/wallet.d.ts.map +1 -0
  63. package/dist/lib/crypto/wallet.js +327 -0
  64. package/dist/lib/helpers.d.ts +90 -0
  65. package/dist/lib/helpers.d.ts.map +1 -0
  66. package/dist/lib/helpers.js +1031 -0
  67. package/dist/lib/index.d.ts +5 -0
  68. package/dist/lib/index.d.ts.map +1 -0
  69. package/dist/lib/index.js +21 -0
  70. package/dist/lib/radon/artifacts.d.ts +55 -0
  71. package/dist/lib/radon/artifacts.d.ts.map +1 -0
  72. package/dist/lib/radon/artifacts.js +347 -0
  73. package/dist/lib/radon/ccdr/eth.d.ts +100 -0
  74. package/dist/lib/radon/ccdr/eth.d.ts.map +1 -0
  75. package/dist/lib/radon/ccdr/eth.js +237 -0
  76. package/dist/lib/radon/ccdr/index.d.ts +34 -0
  77. package/dist/lib/radon/ccdr/index.d.ts.map +1 -0
  78. package/dist/lib/radon/ccdr/index.js +63 -0
  79. package/dist/lib/radon/ccdr/wit.d.ts +29 -0
  80. package/dist/lib/radon/ccdr/wit.d.ts.map +1 -0
  81. package/dist/lib/radon/ccdr/wit.js +60 -0
  82. package/dist/lib/radon/filters.d.ts +14 -0
  83. package/dist/lib/radon/filters.d.ts.map +1 -0
  84. package/dist/lib/radon/filters.js +47 -0
  85. package/dist/lib/radon/index.d.ts +36 -0
  86. package/dist/lib/radon/index.d.ts.map +1 -0
  87. package/dist/lib/radon/index.js +154 -0
  88. package/dist/lib/radon/reducers.d.ts +29 -0
  89. package/dist/lib/radon/reducers.d.ts.map +1 -0
  90. package/dist/lib/radon/reducers.js +101 -0
  91. package/dist/lib/radon/retrievals.d.ts +120 -0
  92. package/dist/lib/radon/retrievals.d.ts.map +1 -0
  93. package/dist/lib/radon/retrievals.js +358 -0
  94. package/dist/lib/radon/sources.d.ts +102 -0
  95. package/dist/lib/radon/sources.d.ts.map +1 -0
  96. package/dist/lib/radon/sources.js +294 -0
  97. package/dist/lib/radon/types.d.ts +521 -0
  98. package/dist/lib/radon/types.d.ts.map +1 -0
  99. package/dist/lib/radon/types.js +1066 -0
  100. package/dist/lib/radon/utils.d.ts +55 -0
  101. package/dist/lib/radon/utils.d.ts.map +1 -0
  102. package/dist/lib/radon/utils.js +181 -0
  103. package/dist/lib/rpc/farm.d.ts +66 -0
  104. package/dist/lib/rpc/farm.d.ts.map +1 -0
  105. package/dist/lib/rpc/farm.js +808 -0
  106. package/dist/lib/rpc/index.d.ts +3 -0
  107. package/dist/lib/rpc/index.d.ts.map +1 -0
  108. package/dist/lib/rpc/index.js +19 -0
  109. package/dist/lib/rpc/node.d.ts +38 -0
  110. package/dist/lib/rpc/node.d.ts.map +1 -0
  111. package/dist/lib/rpc/node.js +335 -0
  112. package/dist/lib/rpc/nodes.d.ts +40 -0
  113. package/dist/lib/rpc/nodes.d.ts.map +1 -0
  114. package/dist/lib/rpc/nodes.js +531 -0
  115. package/dist/lib/rpc/provider.d.ts +72 -0
  116. package/dist/lib/rpc/provider.d.ts.map +1 -0
  117. package/dist/lib/rpc/provider.js +402 -0
  118. package/dist/lib/rpc/reporter.d.ts +18 -0
  119. package/dist/lib/rpc/reporter.d.ts.map +1 -0
  120. package/dist/lib/rpc/reporter.js +99 -0
  121. package/dist/lib/rpc/types.d.ts +396 -0
  122. package/dist/lib/rpc/types.d.ts.map +1 -0
  123. package/dist/lib/rpc/types.js +81 -0
  124. package/dist/lib/rpc/wallet.d.ts +72 -0
  125. package/dist/lib/rpc/wallet.d.ts.map +1 -0
  126. package/dist/lib/rpc/wallet.js +41 -0
  127. package/dist/lib/types.d.ts +19 -0
  128. package/dist/lib/types.d.ts.map +1 -0
  129. package/dist/lib/types.js +7 -0
  130. package/dist/lib/utils.d.ts +5 -0
  131. package/dist/lib/utils.d.ts.map +1 -0
  132. package/dist/lib/utils.js +51 -0
  133. package/dist/package.json +1 -1
  134. package/dist/src/bin/helpers.js +1 -1
  135. package/dist/src/index.js +1 -1
  136. package/dist/src/lib/crypto/account.js +1 -1
  137. package/dist/src/lib/crypto/coinbase.js +1 -1
  138. package/dist/src/lib/crypto/index.js +1 -1
  139. package/dist/src/lib/crypto/interfaces.js +1 -1
  140. package/dist/src/lib/crypto/payloads/DataRequestPayload.js +1 -1
  141. package/dist/src/lib/crypto/payloads/StakePayload.js +1 -1
  142. package/dist/src/lib/crypto/payloads/UnstakePayload.js +1 -1
  143. package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +1 -1
  144. package/dist/src/lib/crypto/payloads.js +1 -1
  145. package/dist/src/lib/crypto/signer.js +1 -1
  146. package/dist/src/lib/crypto/transmitters/DataRequests.js +1 -1
  147. package/dist/src/lib/crypto/transmitters/StakeDeposits.js +1 -1
  148. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +1 -1
  149. package/dist/src/lib/crypto/transmitters/ValueTransfers.js +1 -1
  150. package/dist/src/lib/crypto/transmitters.js +1 -1
  151. package/dist/src/lib/crypto/types.js +1 -1
  152. package/dist/src/lib/crypto/utils.js +1 -1
  153. package/dist/src/lib/crypto/wallet.js +1 -1
  154. package/dist/src/lib/index.js +1 -1
  155. package/dist/src/lib/radon/ccdr/eth.js +1 -1
  156. package/dist/src/lib/radon/ccdr/index.js +1 -1
  157. package/dist/src/lib/radon/ccdr/wit.js +1 -1
  158. package/dist/src/lib/radon/filters.js +1 -1
  159. package/dist/src/lib/radon/index.js +1 -1
  160. package/dist/src/lib/radon/reducers.js +1 -1
  161. package/dist/src/lib/radon/types.js +1 -1
  162. package/dist/src/lib/radon/utils.js +1 -1
  163. package/dist/src/lib/rpc/index.js +1 -1
  164. package/dist/src/lib/rpc/nodes.js +1 -1
  165. package/dist/src/lib/rpc/provider.js +1 -1
  166. package/dist/src/lib/rpc/reporter.js +1 -1
  167. package/dist/src/lib/rpc/types.js +1 -1
  168. package/dist/src/lib/types.d.ts +1 -1
  169. package/dist/src/lib/types.d.ts.map +1 -1
  170. package/dist/src/lib/types.js +1 -1
  171. package/dist/src/lib/utils.js +1 -1
  172. package/dist/witnet/assets/index.js +1 -1
  173. package/dist/witnet/assets/modals/index.js +1 -1
  174. package/dist/witnet/assets/modals/web3/eth.js +1 -1
  175. package/dist/witnet/assets/modals/web3/ipfs.js +1 -1
  176. package/dist/witnet/assets/modals/web3/wit.js +1 -1
  177. package/dist/witnet/assets/requests.js +1 -1
  178. package/package.json +1 -1
  179. package/src/bin/cli/history.js +31 -31
  180. package/src/bin/cli/inspect.js +405 -405
  181. package/src/bin/cli/network.js +594 -594
  182. package/src/bin/cli/nodes.js +364 -364
  183. package/src/bin/cli/radon.js +815 -815
  184. package/src/bin/cli/wallet.js +1117 -1117
  185. package/src/bin/helpers.js +840 -840
  186. package/src/bin/postinstall.js +9 -9
  187. package/src/bin/toolkit.js +295 -295
  188. package/witnet/assets/_index.js +8 -8
  189. package/witnet/assets/_requests.js +25 -25
  190. package/witnet/assets/_sources.js +36 -36
  191. package/witnet/assets/_templates.js +36 -36
  192. package/witnet/assets/index.js +4 -4
  193. package/witnet/assets/modals/index.js +9 -9
  194. package/witnet/assets/modals/web3/eth.js +29 -29
  195. package/witnet/assets/modals/web3/ipfs.js +19 -19
  196. package/witnet/assets/modals/web3/wit.js +21 -21
  197. package/witnet/assets/requests.js +95 -95
@@ -0,0 +1,127 @@
1
+ import { Epoch, Hash, HexString, Nanowits } from "../types";
2
+ export type KeyPath = Array<number>;
3
+ export type KeyedSignature = {
4
+ signature: {
5
+ Secp256k1: {
6
+ der: Array<number>;
7
+ };
8
+ };
9
+ public_key: {
10
+ bytes: Array<number>;
11
+ compressed: number;
12
+ };
13
+ };
14
+ export type PublicKeyHashString = HexString;
15
+ interface Key {
16
+ bytes: Uint8Array;
17
+ }
18
+ export interface PrivateKey extends Key {
19
+ type: "private";
20
+ }
21
+ export interface PublicKey extends Key {
22
+ type: "public";
23
+ }
24
+ export type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any;
25
+ export type TransactionParams = {
26
+ deadline?: Epoch;
27
+ fees: Nanowits;
28
+ };
29
+ export type TransactionReceipt = {
30
+ authorization?: HexString;
31
+ blockEpoch?: Epoch;
32
+ blockHash?: Hash;
33
+ blockMiner?: PublicKeyHashString;
34
+ burns?: Nanowits;
35
+ confirmations?: number;
36
+ change?: Nanowits;
37
+ droHash?: Hash;
38
+ error?: Error;
39
+ fees: Nanowits;
40
+ from?: Array<PublicKeyHashString> | PublicKeyHashString;
41
+ hash: Hash;
42
+ outputLock?: number;
43
+ radArgs?: any;
44
+ radHash?: HexString;
45
+ recipients?: Array<[PublicKeyHashString, Nanowits]>;
46
+ status?: TransactionStatus;
47
+ timestamp: number;
48
+ type: string;
49
+ tx?: any;
50
+ value?: Nanowits;
51
+ weight: number;
52
+ withdrawer?: PublicKeyHashString;
53
+ witnesses?: number | Record<PublicKeyHashString, Nanowits>;
54
+ };
55
+ export declare enum TransactionStatus {
56
+ Pending = "pending",
57
+ Confirmed = "confirmed",
58
+ Finalized = "finalized",
59
+ Mined = "mined",
60
+ Relayed = "relayed"
61
+ }
62
+ export type Transmission = {
63
+ bytecode?: Uint8Array;
64
+ hash?: Hash;
65
+ message: any;
66
+ };
67
+ export type UtxoPointer = {
68
+ transaction_id: Hash;
69
+ output_index: number;
70
+ };
71
+ export declare enum UtxoSelectionStrategy {
72
+ BigFirst = "big-first",
73
+ Random = "random",
74
+ SlimFit = "slim-fit",
75
+ SmallFirst = "small-first"
76
+ }
77
+ export declare class PublicKey implements Key {
78
+ readonly compressed: number;
79
+ readonly bytes: Uint8Array;
80
+ static fromProtobuf(protobuf: {
81
+ compressed: number;
82
+ bytes: Array<number>;
83
+ }): PublicKey;
84
+ static fromUint8Array(uint8Array: Uint8Array): PublicKey;
85
+ static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey;
86
+ constructor(compressed: number, bytes: Uint8Array);
87
+ equals(pubKey: PublicKey): boolean;
88
+ hash(): PublicKeyHash;
89
+ toString(): string;
90
+ toUint8Array(): Uint8Array;
91
+ }
92
+ export declare class PublicKeyHash {
93
+ static fromHash(hash: Uint8Array): PublicKeyHash;
94
+ static fromHexString(hash: HexString): PublicKeyHash;
95
+ static fromPublicKey(pk: PublicKey): PublicKeyHash;
96
+ static fromBech32(pkh: string): PublicKeyHash;
97
+ protected words: number[];
98
+ constructor(words: number[]);
99
+ toBech32(network?: string): string;
100
+ toBytes20(): Uint8Array;
101
+ toBytes32(): Uint8Array;
102
+ toHexString(): string;
103
+ }
104
+ export declare class Signature {
105
+ static fromHexString(hex: string): Signature;
106
+ readonly bytes: Uint8Array;
107
+ constructor(bytes: Uint8Array);
108
+ toHexString(): string;
109
+ }
110
+ export declare class RecoverableSignature extends Signature {
111
+ static from(recoverable: any, msg: Uint8Array): RecoverableSignature;
112
+ static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature;
113
+ readonly message: Uint8Array;
114
+ readonly pubKey: PublicKey;
115
+ readonly recoveryId: number;
116
+ constructor(pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array);
117
+ toHexString(): string;
118
+ toKeyedSignature(): any;
119
+ toProtobuf(): any;
120
+ }
121
+ export declare class TransmissionError extends Error {
122
+ readonly error?: any;
123
+ readonly inFlight: Transmission;
124
+ constructor(inFlight: Transmission, error?: any);
125
+ }
126
+ export {};
127
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,261 @@
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ var __read = (this && this.__read) || function (o, n) {
18
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
19
+ if (!m) return o;
20
+ var i = m.call(o), r, ar = [], e;
21
+ try {
22
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
23
+ }
24
+ catch (error) { e = { error: error }; }
25
+ finally {
26
+ try {
27
+ if (r && !r.done && (m = i["return"])) m.call(i);
28
+ }
29
+ finally { if (e) throw e.error; }
30
+ }
31
+ return ar;
32
+ };
33
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
34
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
35
+ if (ar || !(i in from)) {
36
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
37
+ ar[i] = from[i];
38
+ }
39
+ }
40
+ return to.concat(ar || Array.prototype.slice.call(from));
41
+ };
42
+ Object.defineProperty(exports, "__esModule", { value: true });
43
+ exports.TransmissionError = exports.RecoverableSignature = exports.Signature = exports.PublicKeyHash = exports.PublicKey = exports.UtxoSelectionStrategy = exports.TransactionStatus = void 0;
44
+ var secp256k1 = require('secp256k1');
45
+ var bech32_1 = require("bech32");
46
+ var helpers_1 = require("../../bin/helpers");
47
+ var utils_1 = require("./utils");
48
+ var TransactionStatus;
49
+ (function (TransactionStatus) {
50
+ /// Awating to be relayed by the RPC provider
51
+ TransactionStatus["Pending"] = "pending";
52
+ /// Remains on-chain after certain amount of epochs since mined
53
+ TransactionStatus["Confirmed"] = "confirmed";
54
+ /// Remains on-chain after end of next super-epoch to the one on which the tx got mined
55
+ TransactionStatus["Finalized"] = "finalized";
56
+ /// Relayed and allegedly included in a block
57
+ TransactionStatus["Mined"] = "mined";
58
+ /// Relayed to the mempool
59
+ TransactionStatus["Relayed"] = "relayed";
60
+ })(TransactionStatus || (exports.TransactionStatus = TransactionStatus = {}));
61
+ var UtxoSelectionStrategy;
62
+ (function (UtxoSelectionStrategy) {
63
+ UtxoSelectionStrategy["BigFirst"] = "big-first";
64
+ UtxoSelectionStrategy["Random"] = "random";
65
+ UtxoSelectionStrategy["SlimFit"] = "slim-fit";
66
+ UtxoSelectionStrategy["SmallFirst"] = "small-first";
67
+ })(UtxoSelectionStrategy || (exports.UtxoSelectionStrategy = UtxoSelectionStrategy = {}));
68
+ ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
69
+ /// EXPORTED CLASSES
70
+ /// ===================================================================================================================
71
+ var PublicKey = /** @class */ (function () {
72
+ function PublicKey(compressed, bytes) {
73
+ this.compressed = compressed;
74
+ this.bytes = bytes;
75
+ }
76
+ PublicKey.fromProtobuf = function (protobuf) {
77
+ return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes));
78
+ };
79
+ PublicKey.fromUint8Array = function (uint8Array) {
80
+ return new PublicKey(uint8Array[0], uint8Array.slice(1));
81
+ };
82
+ PublicKey.recoverFrom = function (recoverable, msg) {
83
+ var bytes;
84
+ if ((0, helpers_1.isHexString)(recoverable)) {
85
+ bytes = (0, helpers_1.fromHexString)(recoverable);
86
+ }
87
+ else if (recoverable instanceof Buffer) {
88
+ bytes = Uint8Array.from(recoverable.buffer);
89
+ }
90
+ else if (recoverable instanceof Uint8Array) {
91
+ bytes = recoverable;
92
+ }
93
+ else {
94
+ throw new TypeError("PublicKey: unsupported recoverable signature format: ".concat(recoverable));
95
+ }
96
+ if (bytes.length !== 65) {
97
+ throw new TypeError("PublicKey: expected recoverable signature with length 65: ".concat((0, helpers_1.toHexString)(bytes)));
98
+ }
99
+ var _a = __read([bytes[0], bytes.slice(1)], 2), recoveryId = _a[0], signature = _a[1];
100
+ return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg));
101
+ };
102
+ PublicKey.prototype.equals = function (pubKey) {
103
+ return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes);
104
+ };
105
+ PublicKey.prototype.hash = function () {
106
+ return PublicKeyHash.fromPublicKey(this);
107
+ };
108
+ PublicKey.prototype.toString = function () {
109
+ return (0, helpers_1.toHexString)(__spreadArray([this.compressed], __read(this.bytes), false));
110
+ };
111
+ PublicKey.prototype.toUint8Array = function () {
112
+ return Uint8Array.from(__spreadArray([this.compressed], __read(this.bytes), false));
113
+ };
114
+ return PublicKey;
115
+ }());
116
+ exports.PublicKey = PublicKey;
117
+ ;
118
+ /// ===================================================================================================================
119
+ var PublicKeyHash = /** @class */ (function () {
120
+ function PublicKeyHash(words) {
121
+ this.words = words;
122
+ }
123
+ PublicKeyHash.fromHash = function (hash) {
124
+ return new PublicKeyHash(bech32_1.bech32.toWords(hash));
125
+ };
126
+ PublicKeyHash.fromHexString = function (hash) {
127
+ return PublicKeyHash.fromHash((0, helpers_1.fromHexString)(hash));
128
+ };
129
+ PublicKeyHash.fromPublicKey = function (pk) {
130
+ return PublicKeyHash.fromHash((0, utils_1.sha256)(Buffer.from(__spreadArray([pk.compressed], __read(pk.bytes), false))).subarray(0, 20));
131
+ };
132
+ PublicKeyHash.fromBech32 = function (pkh) {
133
+ try {
134
+ pkh = pkh.toLowerCase();
135
+ if (pkh.startsWith('wit')) {
136
+ return new PublicKeyHash(bech32_1.bech32.decode(pkh, 66).words);
137
+ }
138
+ else if (pkh.startsWith('twit')) {
139
+ return new PublicKeyHash(bech32_1.bech32.decode(pkh, 67).words);
140
+ }
141
+ else {
142
+ throw new TypeError("PublicKeyHash: invalid bech32 string: ".concat(pkh));
143
+ }
144
+ }
145
+ catch (_a) {
146
+ throw new TypeError("PublicKeyHash: invalid bech32 string: ".concat(pkh));
147
+ }
148
+ };
149
+ PublicKeyHash.prototype.toBech32 = function (network) {
150
+ if (network === void 0) { network = "mainnet"; }
151
+ return network === "mainnet" ? bech32_1.bech32.encode('wit', this.words, 66) : bech32_1.bech32.encode('twit', this.words, 67);
152
+ };
153
+ PublicKeyHash.prototype.toBytes20 = function () {
154
+ return Uint8Array.from(bech32_1.bech32.fromWords(this.words).slice(0, 20));
155
+ };
156
+ PublicKeyHash.prototype.toBytes32 = function () {
157
+ return Uint8Array.from(__spreadArray(__spreadArray([], __read(bech32_1.bech32.fromWords(this.words).slice(0, 20)), false), __read(new Array(12).fill(0)), false));
158
+ };
159
+ PublicKeyHash.prototype.toHexString = function () {
160
+ return (0, helpers_1.toHexString)(this.toBytes20());
161
+ };
162
+ return PublicKeyHash;
163
+ }());
164
+ exports.PublicKeyHash = PublicKeyHash;
165
+ /// ===================================================================================================================
166
+ var Signature = /** @class */ (function () {
167
+ function Signature(bytes) {
168
+ this.bytes = bytes;
169
+ }
170
+ Signature.fromHexString = function (hex) {
171
+ return new Signature((0, helpers_1.fromHexString)(hex));
172
+ };
173
+ Signature.prototype.toHexString = function () {
174
+ return (0, helpers_1.toHexString)(this.bytes);
175
+ };
176
+ return Signature;
177
+ }());
178
+ exports.Signature = Signature;
179
+ /// ===================================================================================================================
180
+ var RecoverableSignature = /** @class */ (function (_super) {
181
+ __extends(RecoverableSignature, _super);
182
+ function RecoverableSignature(pubKey, bytes, msg) {
183
+ var _this = _super.call(this, bytes) || this;
184
+ var pubKeyRaw = pubKey.toUint8Array();
185
+ var recoveryId;
186
+ for (recoveryId = 0; recoveryId < 4; recoveryId++) {
187
+ var recovered = void 0;
188
+ try {
189
+ recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg);
190
+ if (matchingUint8Arrays(recovered, pubKeyRaw))
191
+ break;
192
+ }
193
+ catch (_a) { }
194
+ }
195
+ _this.message = msg;
196
+ _this.pubKey = pubKey;
197
+ _this.recoveryId = recoveryId;
198
+ return _this;
199
+ }
200
+ RecoverableSignature.from = function (recoverable, msg) {
201
+ var bytes;
202
+ if ((0, helpers_1.isHexString)(recoverable)) {
203
+ bytes = (0, helpers_1.fromHexString)(recoverable).slice(1);
204
+ }
205
+ else if (recoverable instanceof Buffer) {
206
+ bytes = Uint8Array.from(recoverable.buffer).slice(1);
207
+ }
208
+ else if (recoverable instanceof Uint8Array) {
209
+ bytes = recoverable.slice(1);
210
+ }
211
+ else {
212
+ throw new TypeError("RecoverableSignature: unsupported recoverable signature format: ".concat(recoverable));
213
+ }
214
+ if (bytes.length !== 64) {
215
+ throw new TypeError("RecoverableSignatre: expected recoverable signature with length 65: ".concat((0, helpers_1.toHexString)(bytes)));
216
+ }
217
+ return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg);
218
+ };
219
+ RecoverableSignature.fromKeyedSignature = function (ks, msg) {
220
+ return new RecoverableSignature(PublicKey.fromProtobuf(ks.public_key), secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)), msg);
221
+ };
222
+ RecoverableSignature.prototype.toHexString = function () {
223
+ return (0, helpers_1.toHexString)(__spreadArray([this.recoveryId], __read(this.bytes), false));
224
+ };
225
+ RecoverableSignature.prototype.toKeyedSignature = function () {
226
+ return {
227
+ signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) } },
228
+ public_key: {
229
+ bytes: Array.from(this.pubKey.bytes),
230
+ compressed: this.pubKey.compressed,
231
+ }
232
+ };
233
+ };
234
+ RecoverableSignature.prototype.toProtobuf = function () {
235
+ return {
236
+ signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) } },
237
+ publicKey: { publicKey: Array.from(__spreadArray([this.pubKey.compressed], __read(this.pubKey.bytes), false)) },
238
+ };
239
+ };
240
+ return RecoverableSignature;
241
+ }(Signature));
242
+ exports.RecoverableSignature = RecoverableSignature;
243
+ /// ===================================================================================================================
244
+ var TransmissionError = /** @class */ (function (_super) {
245
+ __extends(TransmissionError, _super);
246
+ function TransmissionError(inFlight, error) {
247
+ var _this = _super.call(this, JSON.stringify(error)) || this;
248
+ error === null || error === void 0 ? true : delete error.stack;
249
+ _this.error = error;
250
+ _this.inFlight = inFlight;
251
+ return _this;
252
+ }
253
+ return TransmissionError;
254
+ }(Error));
255
+ exports.TransmissionError = TransmissionError;
256
+ /// -------------------------------------------------------------------------------------------------------------------
257
+ /// --- Internal functions
258
+ function matchingUint8Arrays(a, b) {
259
+ return a.length === b.length && a.every(function (value, index) { return value === b[index]; });
260
+ }
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lib/crypto/types.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAAM,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;AACtC,iCAA+B;AAG/B,6CAA2E;AAC3E,iCAAgC;AA2DhC,IAAY,iBAeX;AAfD,WAAY,iBAAiB;IACzB,6CAA6C;IAC7C,wCAAmB,CAAA;IAEnB,+DAA+D;IAC/D,4CAAuB,CAAA;IAEvB,uFAAuF;IACvF,4CAAuB,CAAA;IAEvB,6CAA6C;IAC7C,oCAAe,CAAA;IAEf,2BAA2B;IAC3B,wCAAmB,CAAA;AACvB,CAAC,EAfW,iBAAiB,iCAAjB,iBAAiB,QAe5B;AAeD,IAAY,qBAKX;AALD,WAAY,qBAAqB;IAC7B,+CAAsB,CAAA;IACtB,0CAAiB,CAAA;IACjB,6CAAoB,CAAA;IACpB,mDAA0B,CAAA;AAC9B,CAAC,EALW,qBAAqB,qCAArB,qBAAqB,QAKhC;AAGD,uHAAuH;AACvH,qBAAqB;AAErB,uHAAuH;AACvH;IAkCI,mBAAY,UAAkB,EAAE,KAAiB;QAC7C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACtB,CAAC;IAhCM,sBAAY,GAAnB,UAAoB,QAAsD;QACtE,OAAO,IAAI,SAAS,CAAC,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAA;IAC9E,CAAC;IAEM,wBAAc,GAArB,UAAsB,UAAsB;QACxC,OAAO,IAAI,SAAS,CAChB,UAAU,CAAC,CAAC,CAAC,EACb,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CACtB,CAAC;IACN,CAAC;IAEM,qBAAW,GAAlB,UAAmB,WAAgB,EAAE,GAAe;QAChD,IAAI,KAAK,CAAA;QACT,IAAI,IAAA,qBAAW,EAAC,WAAW,CAAC,EAAE,CAAC;YAC3B,KAAK,GAAG,IAAA,uBAAa,EAAC,WAAW,CAAC,CAAA;QACtC,CAAC;aAAM,IAAI,WAAW,YAAY,MAAM,EAAE,CAAC;YACvC,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;QAC/C,CAAC;aAAM,IAAI,WAAW,YAAY,UAAU,EAAE,CAAC;YAC3C,KAAK,GAAG,WAAW,CAAA;QACvB,CAAC;aAAM,CAAC;YACJ,MAAM,IAAI,SAAS,CAAC,+DAAwD,WAAW,CAAE,CAAC,CAAA;QAC9F,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YACtB,MAAM,IAAI,SAAS,CAAC,oEAA6D,IAAA,qBAAW,EAAC,KAAK,CAAC,CAAE,CAAC,CAAA;QAC1G,CAAC;QACK,IAAA,KAAA,OAA4B,CAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAE,IAAA,EAAtD,UAAU,QAAA,EAAE,SAAS,QAAiC,CAAA;QAC9D,OAAO,SAAS,CAAC,cAAc,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,EAAE,UAAU,EAAE,GAAG,CAAC,CAAC,CAAA;IACvF,CAAC;IAOM,0BAAM,GAAb,UAAc,MAAiB;QAC3B,OAAO,MAAM,CAAC,UAAU,KAAK,IAAI,CAAC,UAAU,IAAI,mBAAmB,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;IACnG,CAAC;IAEM,wBAAI,GAAX;QACI,OAAO,aAAa,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;IAC5C,CAAC;IAEM,4BAAQ,GAAf;QACI,OAAO,IAAA,qBAAW,iBAAE,IAAI,CAAC,UAAU,UAAK,IAAI,CAAC,KAAK,UAAE,CAAA;IACxD,CAAC;IAEM,gCAAY,GAAnB;QACI,OAAO,UAAU,CAAC,IAAI,gBAAE,IAAI,CAAC,UAAU,UAAK,IAAI,CAAC,KAAK,UAAE,CAAA;IAC5D,CAAC;IACL,gBAAC;AAAD,CAAC,AAtDD,IAsDC;AAtDY,8BAAS;AAsDrB,CAAC;AAGF,uHAAuH;AACvH;IAmCI,uBAAY,KAAe;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACtB,CAAC;IAnCM,sBAAQ,GAAf,UAAgB,IAAgB;QAC5B,OAAO,IAAI,aAAa,CAAC,eAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IACnD,CAAC;IAEM,2BAAa,GAApB,UAAqB,IAAe;QAChC,OAAO,aAAa,CAAC,QAAQ,CAAC,IAAA,uBAAa,EAAC,IAAI,CAAC,CAAC,CAAA;IACtD,CAAC;IAEM,2BAAa,GAApB,UAAqB,EAAa;QAC9B,OAAO,aAAa,CAAC,QAAQ,CACzB,IAAA,cAAM,EACF,MAAM,CAAC,IAAI,gBAAE,EAAE,CAAC,UAAU,UAAK,EAAE,CAAC,KAAK,UAAE,CAC5C,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CACpB,CAAC;IACN,CAAC;IAEM,wBAAU,GAAjB,UAAkB,GAAW;QACzB,IAAI,CAAC;YACD,GAAG,GAAG,GAAG,CAAC,WAAW,EAAE,CAAA;YACvB,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxB,OAAO,IAAI,aAAa,CAAC,eAAM,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAA;YAC1D,CAAC;iBAAM,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;gBAChC,OAAO,IAAI,aAAa,CAAC,eAAM,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAA;YAC1D,CAAC;iBAAM,CAAC;gBACJ,MAAM,IAAI,SAAS,CAAC,gDAAyC,GAAG,CAAE,CAAC,CAAC;YACxE,CAAC;QACL,CAAC;QAAC,WAAM,CAAC;YACL,MAAM,IAAI,SAAS,CAAC,gDAAyC,GAAG,CAAE,CAAC,CAAC;QACxE,CAAC;IACL,CAAC;IAQM,gCAAQ,GAAf,UAAgB,OAAmB;QAAnB,wBAAA,EAAA,mBAAmB;QAC/B,OAAO,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,eAAM,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,eAAM,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IAChH,CAAC;IAEM,iCAAS,GAAhB;QACI,OAAO,UAAU,CAAC,IAAI,CAAC,eAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;IACrE,CAAC;IAEM,iCAAS,GAAhB;QACI,OAAO,UAAU,CAAC,IAAI,wCACf,eAAM,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,kBACzC,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAC1B,CAAC;IACP,CAAC;IAEM,mCAAW,GAAlB;QACI,OAAO,IAAA,qBAAW,EAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;IACxC,CAAC;IACL,oBAAC;AAAD,CAAC,AAzDD,IAyDC;AAzDY,sCAAa;AA4D1B,uHAAuH;AACvH;IAQI,mBAAa,KAAiB;QAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACtB,CAAC;IARM,uBAAa,GAApB,UAAqB,GAAW;QAC5B,OAAO,IAAI,SAAS,CAAC,IAAA,uBAAa,EAAC,GAAG,CAAC,CAAC,CAAA;IAC5C,CAAC;IAQM,+BAAW,GAAlB;QACI,OAAO,IAAA,qBAAW,EAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAClC,CAAC;IACL,gBAAC;AAAD,CAAC,AAfD,IAeC;AAfY,8BAAS;AAkBtB,uHAAuH;AACvH;IAA0C,wCAAS;IA+B/C,8BAAa,MAAiB,EAAE,KAAiB,EAAE,GAAe;QAC9D,YAAA,MAAK,YAAC,KAAK,CAAC,SAAA;QACZ,IAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAA;QACvC,IAAI,UAAkB,CAAC;QACvB,KAAK,UAAU,GAAG,CAAC,EAAE,UAAU,GAAG,CAAC,EAAE,UAAU,EAAG,EAAE,CAAC;YACjD,IAAI,SAAS,SAAA,CAAA;YACb,IAAI,CAAC;gBACH,SAAS,GAAG,SAAS,CAAC,YAAY,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,CAAC,CAAA;gBAC1D,IAAI,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC;oBAAE,MAAM;YACvD,CAAC;YAAC,WAAM,CAAC,CAAA,CAAC;QACd,CAAC;QACD,KAAI,CAAC,OAAO,GAAG,GAAG,CAAA;QAClB,KAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,KAAI,CAAC,UAAU,GAAG,UAAU,CAAA;;IAChC,CAAC;IA3CM,yBAAI,GAAX,UAAY,WAAgB,EAAE,GAAe;QACzC,IAAI,KAAK,CAAA;QACT,IAAI,IAAA,qBAAW,EAAC,WAAW,CAAC,EAAE,CAAC;YAC3B,KAAK,GAAG,IAAA,uBAAa,EAAC,WAAW,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QAC/C,CAAC;aAAM,IAAI,WAAW,YAAY,MAAM,EAAE,CAAC;YACvC,KAAK,GAAG,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QACxD,CAAC;aAAM,IAAI,WAAW,YAAY,UAAU,EAAE,CAAC;YAC3C,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QAChC,CAAC;aAAM,CAAC;YACJ,MAAM,IAAI,SAAS,CAAC,0EAAmE,WAAW,CAAE,CAAC,CAAA;QACzG,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YACtB,MAAM,IAAI,SAAS,CAAC,8EAAuE,IAAA,qBAAW,EAAC,KAAK,CAAC,CAAE,CAAC,CAAA;QACpH,CAAC;QACD,OAAO,IAAI,oBAAoB,CAAC,SAAS,CAAC,WAAW,CAAC,WAAW,EAAE,GAAG,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,CAAA;IACxF,CAAC;IAEM,uCAAkB,GAAzB,UAA0B,EAAkB,EAAE,GAAe;QACzD,OAAO,IAAI,oBAAoB,CAC3B,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,UAAU,CAAC,EACrC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EACtE,GAAG,CACN,CAAA;IACL,CAAC;IAsBM,0CAAW,GAAlB;QACI,OAAO,IAAA,qBAAW,iBAAE,IAAI,CAAC,UAAU,UAAK,IAAI,CAAC,KAAK,UAAE,CAAA;IACxD,CAAC;IAEM,+CAAgB,GAAvB;QACI,OAAO;YACH,SAAS,EAAE,EAAE,SAAS,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAC;YACnF,UAAU,EAAE;gBACR,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;gBACpC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;aACrC;SACJ,CAAA;IACL,CAAC;IAEM,yCAAU,GAAjB;QACI,OAAO;YACH,SAAS,EAAE,EAAE,SAAS,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAC;YACnF,SAAS,EAAE,EAAE,SAAS,EAAE,KAAK,CAAC,IAAI,gBAAG,IAAI,CAAC,MAAM,CAAC,UAAU,UAAK,IAAI,CAAC,MAAM,CAAC,KAAK,UAAG,EAAE;SACzF,CAAA;IACL,CAAC;IACL,2BAAC;AAAD,CAAC,AAnED,CAA0C,SAAS,GAmElD;AAnEY,oDAAoB;AAsEjC,uHAAuH;AACvH;IAAuC,qCAAK;IAGxC,2BAAY,QAAsB,EAAE,KAAW;QAC3C,YAAA,MAAK,YAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,SAAA;QACrB,KAAK,aAAL,KAAK,4BAAL,KAAK,CAAE,KAAK,CAAA;QACnB,KAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,KAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;;IAC5B,CAAC;IACL,wBAAC;AAAD,CAAC,AATD,CAAuC,KAAK,GAS3C;AATY,8CAAiB;AAY9B,uHAAuH;AACvH,2BAA2B;AAE3B,SAAS,mBAAmB,CAAC,CAAa,EAAE,CAAa;IACrD,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,KAAK,CAAC,UAAC,KAAK,EAAE,KAAK,IAAK,OAAA,KAAK,KAAK,CAAC,CAAC,KAAK,CAAC,EAAlB,CAAkB,CAAC,CAAA;AACjF,CAAC","sourcesContent":["const secp256k1 = require('secp256k1')\nimport { bech32 } from 'bech32'\nimport { Epoch, Hash, HexString, Nanowits } from \"../types\"\n\nimport { fromHexString, isHexString, toHexString } from \"../../bin/helpers\"\nimport { sha256 } from \"./utils\"\n\nexport type KeyPath = Array<number>\n\nexport type KeyedSignature = {\n    signature: { Secp256k1: { der: Array<number> }},\n    public_key: {\n        bytes: Array<number>;\n        compressed: number,\n    },\n};\n\nexport type PublicKeyHashString = HexString\n\ninterface Key {\n    bytes: Uint8Array;\n}\n\nexport interface PrivateKey extends Key {\n    type: \"private\";\n}\n\nexport interface PublicKey extends Key {\n    type: \"public\";\n}\n\nexport type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any\n\nexport type TransactionParams = {\n    deadline?: Epoch,\n    fees: Nanowits,\n}\nexport type TransactionReceipt = {\n    authorization?: HexString;\n    blockEpoch?: Epoch;\n    blockHash?: Hash;\n    blockMiner?: PublicKeyHashString;\n    burns?: Nanowits;\n    confirmations?: number;\n    change?: Nanowits;\n    droHash?: Hash;\n    error?: Error,\n    fees: Nanowits;\n    from?: Array<PublicKeyHashString> | PublicKeyHashString;\n    hash: Hash;\n    outputLock?: number;\n    radArgs?: any;\n    radHash?: HexString;\n    recipients?: Array<[PublicKeyHashString, Nanowits]>;\n    status?: TransactionStatus;\n    timestamp: number;\n    type: string;\n    tx?: any;\n    value?: Nanowits;\n    weight: number;\n    withdrawer?: PublicKeyHashString;\n    witnesses?: number | Record<PublicKeyHashString, Nanowits>;\n}\n\nexport enum TransactionStatus {\n    /// Awating to be relayed by the RPC provider\n    Pending = \"pending\", \n\n    /// Remains on-chain after certain amount of epochs since mined\n    Confirmed = \"confirmed\",\n\n    /// Remains on-chain after end of next super-epoch to the one on which the tx got mined\n    Finalized = \"finalized\",\n    \n    /// Relayed and allegedly included in a block\n    Mined = \"mined\",\n    \n    /// Relayed to the mempool \n    Relayed = \"relayed\",\n}\n\nexport type Transmission = {\n    bytecode?: Uint8Array,\n    hash?: Hash;\n    message: any;\n}\n\nexport type UtxoPointer = {\n    // transaction identifier\n    transaction_id: Hash;\n    // output index within referred transaction\n    output_index: number;\n};\n\nexport enum UtxoSelectionStrategy {\n    BigFirst = \"big-first\",\n    Random = \"random\",\n    SlimFit = \"slim-fit\",\n    SmallFirst = \"small-first\",\n}\n\n\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\n/// EXPORTED CLASSES \n\n/// ===================================================================================================================\nexport class PublicKey implements Key {\n    \n    public readonly compressed: number;\n    public readonly bytes: Uint8Array;\n\n    static fromProtobuf(protobuf: { compressed: number, bytes: Array<number> }): PublicKey {\n        return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes))\n    }\n\n    static fromUint8Array(uint8Array: Uint8Array): PublicKey {\n        return new PublicKey(\n            uint8Array[0],\n            uint8Array.slice(1),\n        );\n    }\n\n    static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey {\n        let bytes\n        if (isHexString(recoverable)) {\n            bytes = fromHexString(recoverable)\n        } else if (recoverable instanceof Buffer) {\n            bytes = Uint8Array.from(recoverable.buffer)\n        } else if (recoverable instanceof Uint8Array) {\n            bytes = recoverable\n        } else {\n            throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`)\n        }\n        if (bytes.length !== 65) {\n            throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`)\n        } \n        const [ recoveryId, signature ] = [ bytes[0], bytes.slice(1) ]\n        return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg))\n    }\n\n    constructor(compressed: number, bytes: Uint8Array) {\n        this.compressed = compressed\n        this.bytes = bytes\n    }\n\n    public equals(pubKey: PublicKey): boolean {\n        return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes)\n    }\n\n    public hash(): PublicKeyHash {\n        return PublicKeyHash.fromPublicKey(this)\n    }\n\n    public toString(): string {\n        return toHexString([this.compressed, ...this.bytes])\n    }\n\n    public toUint8Array(): Uint8Array {\n        return Uint8Array.from([this.compressed, ...this.bytes])\n    }\n};\n\n\n/// ===================================================================================================================\nexport class PublicKeyHash {\n\n    static fromHash(hash: Uint8Array): PublicKeyHash {\n        return new PublicKeyHash(bech32.toWords(hash));\n    }\n\n    static fromHexString(hash: HexString): PublicKeyHash {\n        return PublicKeyHash.fromHash(fromHexString(hash))\n    }\n    \n    static fromPublicKey(pk: PublicKey): PublicKeyHash {\n        return PublicKeyHash.fromHash(\n            sha256(\n                Buffer.from([pk.compressed, ...pk.bytes])\n            ).subarray(0, 20)\n        );\n    }\n    \n    static fromBech32(pkh: string): PublicKeyHash {\n        try {\n            pkh = pkh.toLowerCase()\n            if (pkh.startsWith('wit')) {\n                return new PublicKeyHash(bech32.decode(pkh, 66).words)\n            } else if (pkh.startsWith('twit')) {\n                return new PublicKeyHash(bech32.decode(pkh, 67).words)\n            } else {\n                throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\n            }\n        } catch {\n            throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\n        }\n    }\n\n    protected words: number[];\n    \n    constructor(words: number[]) {\n        this.words = words\n    }\n\n    public toBech32(network = \"mainnet\"): string {\n        return network === \"mainnet\" ? bech32.encode('wit', this.words, 66) : bech32.encode('twit', this.words, 67);\n    }\n\n    public toBytes20(): Uint8Array {\n        return Uint8Array.from(bech32.fromWords(this.words).slice(0, 20))\n    }\n\n    public toBytes32(): Uint8Array {\n        return Uint8Array.from([\n            ...bech32.fromWords(this.words).slice(0, 20),\n            ...new Array(12).fill(0),\n        ]);\n    }\n\n    public toHexString(): string {\n        return toHexString(this.toBytes20())\n    }\n}\n\n\n/// ===================================================================================================================\nexport class Signature {\n\n    static fromHexString(hex: string): Signature {\n        return new Signature(fromHexString(hex))\n    }\n\n    public readonly bytes: Uint8Array;\n\n    constructor (bytes: Uint8Array) {\n        this.bytes = bytes\n    }\n    \n    public toHexString(): string {\n        return toHexString(this.bytes)\n    }\n}\n\n\n/// ===================================================================================================================\nexport class RecoverableSignature extends Signature {\n\n    static from(recoverable: any, msg: Uint8Array): RecoverableSignature {\n        let bytes\n        if (isHexString(recoverable)) {\n            bytes = fromHexString(recoverable).slice(1)\n        } else if (recoverable instanceof Buffer) {\n            bytes = Uint8Array.from(recoverable.buffer).slice(1)\n        } else if (recoverable instanceof Uint8Array) {\n            bytes = recoverable.slice(1)\n        } else {\n            throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`)\n        }\n        if (bytes.length !== 64) {\n            throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`)\n        } \n        return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg)\n    }\n\n    static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature {\n        return new RecoverableSignature(\n            PublicKey.fromProtobuf(ks.public_key),\n            secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)),\n            msg\n        )   \n    }\n\n    public readonly message: Uint8Array\n    public readonly pubKey: PublicKey\n    public readonly recoveryId: number\n    \n    constructor (pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array) {\n        super(bytes)\n        const pubKeyRaw = pubKey.toUint8Array()\n        let recoveryId: number;\n        for (recoveryId = 0; recoveryId < 4; recoveryId ++) {\n            let recovered \n            try {\n              recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg)\n              if (matchingUint8Arrays(recovered, pubKeyRaw)) break;\n            } catch {}\n        }\n        this.message = msg\n        this.pubKey = pubKey\n        this.recoveryId = recoveryId\n    }\n\n    public toHexString(): string {\n        return toHexString([this.recoveryId, ...this.bytes])\n    }\n\n    public toKeyedSignature(): any {\n        return {\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\n            public_key: {\n                bytes: Array.from(this.pubKey.bytes),\n                compressed: this.pubKey.compressed,\n            }\n        }\n    }\n\n    public toProtobuf(): any {\n        return {\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\n            publicKey: { publicKey: Array.from([ this.pubKey.compressed, ...this.pubKey.bytes ]) },\n        }\n    }\n}\n\n\n/// ===================================================================================================================\nexport class TransmissionError extends Error {\n    readonly error?: any;\n    readonly inFlight: Transmission;\n    constructor(inFlight: Transmission, error?: any) {\n        super(JSON.stringify(error))\n        delete error?.stack\n        this.error = error\n        this.inFlight = inFlight\n    }\n}\n\n\n/// -------------------------------------------------------------------------------------------------------------------\n/// --- Internal functions \n\nfunction matchingUint8Arrays(a: Uint8Array, b: Uint8Array) {\n    return a.length === b.length && a.every((value, index) => value === b[index])\n}\n"]}
@@ -0,0 +1,10 @@
1
+ export { bech32 } from 'bech32';
2
+ export { PrivateKey, PublicKey, PublicKeyHash, KeyedSignature, RecoverableSignature, Signature } from "./types";
3
+ export declare function decipherXprv(slip32: string, passwd: string): string;
4
+ export declare const parseXprv: (slip32: string) => {
5
+ chainCode: Uint8Array;
6
+ keyPath: Array<number>;
7
+ privateKey: Uint8Array;
8
+ };
9
+ export declare function sha256(buffer: any): Buffer<ArrayBufferLike>;
10
+ //# sourceMappingURL=utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"AAKA,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;AAqB/G,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAcnE;AAED,eAAO,MAAM,SAAS,WAAY,MAAM,KAAG;IACvC,SAAS,EAAE,UAAU,CAAC;IACtB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAyD1B,CAAC;AAEF,wBAAgB,MAAM,CAAC,MAAM,EAAE,GAAG,2BAIjC"}
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parseXprv = exports.Signature = exports.RecoverableSignature = exports.PublicKeyHash = exports.PublicKey = exports.bech32 = void 0;
4
+ exports.decipherXprv = decipherXprv;
5
+ exports.sha256 = sha256;
6
+ var secp256k1 = require("secp256k1");
7
+ var bech32_1 = require("bech32");
8
+ var crypto_1 = require("crypto");
9
+ var bech32_2 = require("bech32");
10
+ Object.defineProperty(exports, "bech32", { enumerable: true, get: function () { return bech32_2.bech32; } });
11
+ var types_1 = require("./types");
12
+ Object.defineProperty(exports, "PublicKey", { enumerable: true, get: function () { return types_1.PublicKey; } });
13
+ Object.defineProperty(exports, "PublicKeyHash", { enumerable: true, get: function () { return types_1.PublicKeyHash; } });
14
+ Object.defineProperty(exports, "RecoverableSignature", { enumerable: true, get: function () { return types_1.RecoverableSignature; } });
15
+ Object.defineProperty(exports, "Signature", { enumerable: true, get: function () { return types_1.Signature; } });
16
+ var CHAIN_CODE_LENGTH = 32;
17
+ var DEPTH_LENGTH = 1;
18
+ var KEY_LENGTH = 33;
19
+ var KEY_PATH_LENGTH = 4;
20
+ var BECH32_LIMIT = (DEPTH_LENGTH
21
+ + ((Math.pow(256, DEPTH_LENGTH) - 1) * KEY_PATH_LENGTH)
22
+ + CHAIN_CODE_LENGTH
23
+ + KEY_LENGTH);
24
+ var getExpectedDataLength = function (depth) { return (DEPTH_LENGTH
25
+ + depth * KEY_PATH_LENGTH
26
+ + CHAIN_CODE_LENGTH
27
+ + KEY_LENGTH); };
28
+ function decipherXprv(slip32, passwd) {
29
+ var _a = bech32_1.bech32.decode(slip32, BECH32_LIMIT), prefix = _a.prefix, words = _a.words;
30
+ if (prefix !== "xprv") {
31
+ throw Error("Invalid XPRV header: \"".concat(prefix, "\" != \"xprv\""));
32
+ }
33
+ var buffer = new Uint8Array(bech32_1.bech32.fromWords(words)).buffer;
34
+ var iv = buffer.slice(0, 16);
35
+ var salt = buffer.slice(16, 48);
36
+ var data = buffer.slice(48);
37
+ var key = (0, crypto_1.pbkdf2Sync)(passwd, Buffer.from(salt), 10000, 32, 'sha256');
38
+ var decipher = (0, crypto_1.createDecipheriv)("aes-256-cbc", key, Buffer.from(iv));
39
+ var decrypted = decipher.update(Buffer.from(data), undefined, 'utf-8');
40
+ decrypted += decipher.final('utf-8');
41
+ return decrypted;
42
+ }
43
+ var parseXprv = function (slip32) {
44
+ // decode slip32 string
45
+ var _a = bech32_1.bech32.decode(slip32, BECH32_LIMIT), prefix = _a.prefix, words = _a.words;
46
+ var bytes = bech32_1.bech32.fromWords(words);
47
+ // check prefix
48
+ if (prefix !== "xprv") {
49
+ throw Error("Invalid XPRV: bad header: \"".concat(prefix, "\" != \"xprv\""));
50
+ }
51
+ // check expected data length
52
+ var depth = bytes[0];
53
+ if (depth !== 0) {
54
+ throw Error("Invalid XPRV: not a master private key (depth: ".concat(depth, ")"));
55
+ }
56
+ var expectedLength = getExpectedDataLength(depth);
57
+ if (bytes.length !== expectedLength) {
58
+ throw Error("Invalid XPRV: bad data length"
59
+ + "(expected: ".concat(expectedLength, ", was: ").concat(bytes.length));
60
+ }
61
+ var buffer = new Uint8Array(bytes).buffer;
62
+ // extract key path (32-bit unsigned integers, big endian)
63
+ var keyPath = [];
64
+ var keyPathView = new DataView(buffer, DEPTH_LENGTH, depth * KEY_PATH_LENGTH);
65
+ for (var i = 0; i < depth; i++) {
66
+ keyPath.push((keyPathView.getUint32(i * KEY_PATH_LENGTH, false)));
67
+ }
68
+ // extract chain code
69
+ var chainCode = new Uint8Array(CHAIN_CODE_LENGTH);
70
+ var chainCodeOffset = DEPTH_LENGTH + depth * KEY_PATH_LENGTH;
71
+ var chainCodeView = new DataView(buffer, chainCodeOffset, CHAIN_CODE_LENGTH);
72
+ for (var i = 0; i < chainCode.length; i++) {
73
+ chainCode[i] = (chainCodeView.getUint8(i));
74
+ }
75
+ // extract key bytes
76
+ var privateKey = new Uint8Array(KEY_LENGTH);
77
+ var privateKeyView = new DataView(buffer, chainCodeOffset + CHAIN_CODE_LENGTH);
78
+ for (var i = 0; i < privateKey.length; i++) {
79
+ privateKey[i] = (privateKeyView.getUint8(i));
80
+ }
81
+ // check if private or public key are valid
82
+ if (privateKey[0] !== 0 || !secp256k1.privateKeyVerify(privateKey.slice(1))) {
83
+ throw Error("Malformed slip32: not a private key");
84
+ }
85
+ return {
86
+ chainCode: chainCode,
87
+ keyPath: keyPath,
88
+ privateKey: privateKey.slice(1),
89
+ };
90
+ };
91
+ exports.parseXprv = parseXprv;
92
+ function sha256(buffer) {
93
+ var hash = (0, crypto_1.createHash)('sha256');
94
+ hash.update(buffer);
95
+ return hash.digest();
96
+ }
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require(\"secp256k1\")\n\nimport { bech32 } from 'bech32'\nimport { createDecipheriv, createHash, pbkdf2Sync } from 'crypto'\n\nexport { bech32 } from 'bech32'\n\nexport { PrivateKey, PublicKey, PublicKeyHash, KeyedSignature, RecoverableSignature, Signature } from \"./types\"\n\nconst CHAIN_CODE_LENGTH = 32\nconst DEPTH_LENGTH = 1\nconst KEY_LENGTH = 33\nconst KEY_PATH_LENGTH = 4\n\nconst BECH32_LIMIT = (\n    DEPTH_LENGTH \n        + ((Math.pow(256, DEPTH_LENGTH) - 1) * KEY_PATH_LENGTH) \n        + CHAIN_CODE_LENGTH \n        + KEY_LENGTH\n);\n\nconst getExpectedDataLength = (depth: number) => (\n    DEPTH_LENGTH\n        + depth * KEY_PATH_LENGTH\n        + CHAIN_CODE_LENGTH\n        + KEY_LENGTH\n);\n\nexport function decipherXprv(slip32: string, passwd: string): string {\n    const { prefix, words } = bech32.decode(slip32, BECH32_LIMIT)\n    if (prefix !== \"xprv\") {\n        throw Error(`Invalid XPRV header: \"${prefix}\" != \"xprv\"`)\n    }\n    const buffer = new Uint8Array(bech32.fromWords(words)).buffer\n    const iv = buffer.slice(0, 16)\n    const salt = buffer.slice(16, 48)\n    const data = buffer.slice(48)\n    const key = pbkdf2Sync(passwd, Buffer.from(salt), 10000, 32, 'sha256')    \n    const decipher = createDecipheriv(\"aes-256-cbc\", key, Buffer.from(iv))\n    let decrypted = decipher.update(Buffer.from(data), undefined, 'utf-8')\n    decrypted += decipher.final('utf-8')\n    return decrypted\n}\n\nexport const parseXprv = (slip32: string): {\n    chainCode: Uint8Array,\n    keyPath: Array<number>,\n    privateKey: Uint8Array,\n} => {\n    // decode slip32 string\n    const { prefix, words } = bech32.decode(slip32, BECH32_LIMIT)\n    const bytes = bech32.fromWords(words)\n\n    // check prefix\n    if (prefix !== \"xprv\") {\n        throw Error(`Invalid XPRV: bad header: \"${prefix}\" != \"xprv\"`)\n    }\n\n    // check expected data length\n    const depth = bytes[0]\n    if (depth !== 0) {\n        throw Error(`Invalid XPRV: not a master private key (depth: ${depth})`)\n    }\n    const expectedLength = getExpectedDataLength(depth)\n    if (bytes.length !== expectedLength) {\n        throw Error(\n            \"Invalid XPRV: bad data length\"\n                + `(expected: ${expectedLength}, was: ${bytes.length}`\n        )\n    }\n    const buffer = new Uint8Array(bytes).buffer\n\n    // extract key path (32-bit unsigned integers, big endian)\n    const keyPath: Array<number> = []\n    const keyPathView = new DataView(buffer, DEPTH_LENGTH, depth * KEY_PATH_LENGTH)\n    for (let i = 0; i < depth; i++) {\n        keyPath.push((keyPathView.getUint32(i * KEY_PATH_LENGTH, false)))\n    }\n\n    // extract chain code\n    const chainCode: Uint8Array = new Uint8Array(CHAIN_CODE_LENGTH)\n    const chainCodeOffset = DEPTH_LENGTH + depth * KEY_PATH_LENGTH\n    const chainCodeView = new DataView(buffer, chainCodeOffset, CHAIN_CODE_LENGTH)\n    for (let i = 0; i < chainCode.length; i++) {\n        chainCode[i] = (chainCodeView.getUint8(i))\n    }\n\n    // extract key bytes\n    const privateKey: Uint8Array = new Uint8Array(KEY_LENGTH)\n    const privateKeyView = new DataView(buffer, chainCodeOffset + CHAIN_CODE_LENGTH)\n    for (let i = 0; i < privateKey.length; i++) {\n        privateKey[i] = (privateKeyView.getUint8(i))\n    }\n\n    // check if private or public key are valid\n    if (privateKey[0] !== 0 || !secp256k1.privateKeyVerify(privateKey.slice(1))) {\n        throw Error(`Malformed slip32: not a private key`)\n    } \n\n    return {\n        chainCode,\n        keyPath,\n        privateKey: privateKey.slice(1),\n    }\n};\n\nexport function sha256(buffer: any) {\n    const hash = createHash('sha256')\n    hash.update(buffer)\n    return hash.digest()\n}\n"]}
@@ -0,0 +1,26 @@
1
+ import { Balance, Network, QueryStakesOrder, StakeEntry } from "../types";
2
+ import { IAccount, IBIP32, ICoinbase, IProvider, ISigner, IWallet } from "./interfaces";
3
+ import { PublicKey, PublicKeyHashString, UtxoSelectionStrategy } from "./types";
4
+ export declare class Wallet implements IWallet {
5
+ protected root: IBIP32;
6
+ protected _accounts: Array<IAccount>;
7
+ readonly coinbase: ICoinbase;
8
+ gap: number;
9
+ readonly provider: IProvider;
10
+ strategy: UtxoSelectionStrategy;
11
+ static fromXprv(xprv: string, provider: IProvider, strategy?: UtxoSelectionStrategy, gap?: number): Promise<Wallet>;
12
+ static fromEncryptedXprv(xprv: string, passwd: string, provider: IProvider, strategy?: UtxoSelectionStrategy, gap?: number): Promise<Wallet>;
13
+ constructor(root: IBIP32, provider: IProvider, strategy?: UtxoSelectionStrategy, gap?: number);
14
+ get accounts(): Array<IAccount> | undefined;
15
+ get network(): Network | undefined;
16
+ get pkh(): PublicKeyHashString;
17
+ get publicKey(): PublicKey;
18
+ get signers(): Array<ISigner>;
19
+ deriveAccounts(limit: number): Array<IAccount>;
20
+ exploreAccounts(limit: number, gap?: number): Promise<Array<IAccount>>;
21
+ findAccount(pkh: PublicKeyHashString, gap?: number): IAccount | undefined;
22
+ countUtxos(reload?: boolean): Promise<number>;
23
+ getBalance(): Promise<Balance>;
24
+ getDelegates(order?: QueryStakesOrder, leftJoin?: boolean): Promise<Array<StakeEntry>>;
25
+ }
26
+ //# sourceMappingURL=wallet.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../../src/lib/crypto/wallet.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAiB,MAAM,UAAU,CAAA;AAGxF,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACvF,OAAO,EAAE,SAAS,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAE/E,qBAAa,MAAO,YAAW,OAAO;IAClC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC;IAEvB,SAAS,CAAC,SAAS,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAM;IAE1C,SAAgB,QAAQ,EAAE,SAAS,CAAC;IAC7B,GAAG,EAAE,MAAM,CAAC;IACnB,SAAgB,QAAQ,EAAE,SAAS,CAAC;IAC7B,QAAQ,EAAE,qBAAqB,CAAC;WAE1B,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,EAAE,qBAAqB,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;WAU5G,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,EAAE,qBAAqB,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;gBAItI,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,EAAE,qBAAqB,EAAE,GAAG,CAAC,EAAE,MAAM;IAQ7F,IAAW,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,SAAS,CAEjD;IAED,IAAW,OAAO,IAAI,OAAO,GAAG,SAAS,CAExC;IAED,IAAW,GAAG,IAAI,mBAAmB,CAEpC;IAED,IAAW,SAAS,IAAI,SAAS,CAEhC;IAED,IAAW,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,CAQnC;IAEM,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC;IAcxC,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAwB5E,WAAW,CAAC,GAAG,EAAE,mBAAmB,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,SAAS;IAmBnE,UAAU,CAAC,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;IAa7C,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC;IAmB9B,YAAY,CAAC,KAAK,CAAC,EAAE,gBAAgB,EAAE,QAAQ,UAAO,GAAG,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;CAqBnG"}