@witnet/sdk 1.0.0-beta.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 (149) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +103 -0
  3. package/dist/package.json +72 -0
  4. package/dist/src/bin/helpers.d.ts +91 -0
  5. package/dist/src/bin/helpers.d.ts.map +1 -0
  6. package/dist/src/bin/helpers.js +816 -0
  7. package/dist/src/index.d.ts +5 -0
  8. package/dist/src/index.d.ts.map +1 -0
  9. package/dist/src/index.js +47 -0
  10. package/dist/src/lib/crypto/account.d.ts +32 -0
  11. package/dist/src/lib/crypto/account.d.ts.map +1 -0
  12. package/dist/src/lib/crypto/account.js +106 -0
  13. package/dist/src/lib/crypto/coinbase.d.ts +10 -0
  14. package/dist/src/lib/crypto/coinbase.d.ts.map +1 -0
  15. package/dist/src/lib/crypto/coinbase.js +28 -0
  16. package/dist/src/lib/crypto/index.d.ts +8 -0
  17. package/dist/src/lib/crypto/index.d.ts.map +1 -0
  18. package/dist/src/lib/crypto/index.js +30 -0
  19. package/dist/src/lib/crypto/interfaces.d.ts +85 -0
  20. package/dist/src/lib/crypto/interfaces.d.ts.map +1 -0
  21. package/dist/src/lib/crypto/interfaces.js +3 -0
  22. package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts +55 -0
  23. package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -0
  24. package/dist/src/lib/crypto/payloads/DataRequestPayload.js +339 -0
  25. package/dist/src/lib/crypto/payloads/StakePayload.d.ts +28 -0
  26. package/dist/src/lib/crypto/payloads/StakePayload.d.ts.map +1 -0
  27. package/dist/src/lib/crypto/payloads/StakePayload.js +142 -0
  28. package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts +36 -0
  29. package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -0
  30. package/dist/src/lib/crypto/payloads/UnstakePayload.js +154 -0
  31. package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts +25 -0
  32. package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -0
  33. package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +128 -0
  34. package/dist/src/lib/crypto/payloads.d.ts +57 -0
  35. package/dist/src/lib/crypto/payloads.d.ts.map +1 -0
  36. package/dist/src/lib/crypto/payloads.js +170 -0
  37. package/dist/src/lib/crypto/signer.d.ts +33 -0
  38. package/dist/src/lib/crypto/signer.d.ts.map +1 -0
  39. package/dist/src/lib/crypto/signer.js +194 -0
  40. package/dist/src/lib/crypto/transmitters/DataRequests.d.ts +15 -0
  41. package/dist/src/lib/crypto/transmitters/DataRequests.d.ts.map +1 -0
  42. package/dist/src/lib/crypto/transmitters/DataRequests.js +23 -0
  43. package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts +12 -0
  44. package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -0
  45. package/dist/src/lib/crypto/transmitters/StakeDeposits.js +17 -0
  46. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts +18 -0
  47. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -0
  48. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +53 -0
  49. package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts +11 -0
  50. package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -0
  51. package/dist/src/lib/crypto/transmitters/ValueTransfers.js +16 -0
  52. package/dist/src/lib/crypto/transmitters.d.ts +47 -0
  53. package/dist/src/lib/crypto/transmitters.d.ts.map +1 -0
  54. package/dist/src/lib/crypto/transmitters.js +416 -0
  55. package/dist/src/lib/crypto/types.d.ts +161 -0
  56. package/dist/src/lib/crypto/types.d.ts.map +1 -0
  57. package/dist/src/lib/crypto/types.js +273 -0
  58. package/dist/src/lib/crypto/utils.d.ts +21 -0
  59. package/dist/src/lib/crypto/utils.d.ts.map +1 -0
  60. package/dist/src/lib/crypto/utils.js +156 -0
  61. package/dist/src/lib/crypto/wallet.d.ts +120 -0
  62. package/dist/src/lib/crypto/wallet.d.ts.map +1 -0
  63. package/dist/src/lib/crypto/wallet.js +258 -0
  64. package/dist/src/lib/index.d.ts +5 -0
  65. package/dist/src/lib/index.d.ts.map +1 -0
  66. package/dist/src/lib/index.js +44 -0
  67. package/dist/src/lib/radon/ccdr/eth.d.ts +160 -0
  68. package/dist/src/lib/radon/ccdr/eth.d.ts.map +1 -0
  69. package/dist/src/lib/radon/ccdr/eth.js +272 -0
  70. package/dist/src/lib/radon/ccdr/index.d.ts +14 -0
  71. package/dist/src/lib/radon/ccdr/index.d.ts.map +1 -0
  72. package/dist/src/lib/radon/ccdr/index.js +39 -0
  73. package/dist/src/lib/radon/ccdr/wit.d.ts +23 -0
  74. package/dist/src/lib/radon/ccdr/wit.d.ts.map +1 -0
  75. package/dist/src/lib/radon/ccdr/wit.js +35 -0
  76. package/dist/src/lib/radon/filters.d.ts +14 -0
  77. package/dist/src/lib/radon/filters.d.ts.map +1 -0
  78. package/dist/src/lib/radon/filters.js +45 -0
  79. package/dist/src/lib/radon/index.d.ts +296 -0
  80. package/dist/src/lib/radon/index.d.ts.map +1 -0
  81. package/dist/src/lib/radon/index.js +707 -0
  82. package/dist/src/lib/radon/reducers.d.ts +29 -0
  83. package/dist/src/lib/radon/reducers.d.ts.map +1 -0
  84. package/dist/src/lib/radon/reducers.js +66 -0
  85. package/dist/src/lib/radon/types.d.ts +521 -0
  86. package/dist/src/lib/radon/types.d.ts.map +1 -0
  87. package/dist/src/lib/radon/types.js +936 -0
  88. package/dist/src/lib/radon/utils.d.ts +53 -0
  89. package/dist/src/lib/radon/utils.d.ts.map +1 -0
  90. package/dist/src/lib/radon/utils.js +153 -0
  91. package/dist/src/lib/rpc/index.d.ts +3 -0
  92. package/dist/src/lib/rpc/index.d.ts.map +1 -0
  93. package/dist/src/lib/rpc/index.js +19 -0
  94. package/dist/src/lib/rpc/nodes.d.ts +40 -0
  95. package/dist/src/lib/rpc/nodes.d.ts.map +1 -0
  96. package/dist/src/lib/rpc/nodes.js +293 -0
  97. package/dist/src/lib/rpc/provider.d.ts +88 -0
  98. package/dist/src/lib/rpc/provider.d.ts.map +1 -0
  99. package/dist/src/lib/rpc/provider.js +336 -0
  100. package/dist/src/lib/rpc/reporter.d.ts +18 -0
  101. package/dist/src/lib/rpc/reporter.d.ts.map +1 -0
  102. package/dist/src/lib/rpc/reporter.js +30 -0
  103. package/dist/src/lib/rpc/types.d.ts +409 -0
  104. package/dist/src/lib/rpc/types.d.ts.map +1 -0
  105. package/dist/src/lib/rpc/types.js +81 -0
  106. package/dist/src/lib/types.d.ts +18 -0
  107. package/dist/src/lib/types.d.ts.map +1 -0
  108. package/dist/src/lib/types.js +7 -0
  109. package/dist/src/lib/utils.d.ts +13 -0
  110. package/dist/src/lib/utils.d.ts.map +1 -0
  111. package/dist/src/lib/utils.js +97 -0
  112. package/dist/witnet/assets/index.d.ts +30 -0
  113. package/dist/witnet/assets/index.d.ts.map +1 -0
  114. package/dist/witnet/assets/index.js +6 -0
  115. package/dist/witnet/assets/modals/index.d.ts +18 -0
  116. package/dist/witnet/assets/modals/index.d.ts.map +1 -0
  117. package/dist/witnet/assets/modals/index.js +21 -0
  118. package/dist/witnet/assets/modals/web3/eth.d.ts +5 -0
  119. package/dist/witnet/assets/modals/web3/eth.d.ts.map +1 -0
  120. package/dist/witnet/assets/modals/web3/eth.js +26 -0
  121. package/dist/witnet/assets/modals/web3/wit.d.ts +4 -0
  122. package/dist/witnet/assets/modals/web3/wit.d.ts.map +1 -0
  123. package/dist/witnet/assets/modals/web3/wit.js +20 -0
  124. package/dist/witnet/assets/requests.d.ts +11 -0
  125. package/dist/witnet/assets/requests.d.ts.map +1 -0
  126. package/dist/witnet/assets/requests.js +88 -0
  127. package/dist/witnet/witnet.proto.json +1325 -0
  128. package/package.json +72 -0
  129. package/src/bin/cli/history.js +31 -0
  130. package/src/bin/cli/inspect.js +359 -0
  131. package/src/bin/cli/network.js +592 -0
  132. package/src/bin/cli/nodes.js +364 -0
  133. package/src/bin/cli/radon.js +814 -0
  134. package/src/bin/cli/wallet.js +1000 -0
  135. package/src/bin/helpers.js +829 -0
  136. package/src/bin/postinstall.js +9 -0
  137. package/src/bin/toolkit.js +294 -0
  138. package/witnet/assets/_index.js +8 -0
  139. package/witnet/assets/_requests.js +25 -0
  140. package/witnet/assets/_sources.js +36 -0
  141. package/witnet/assets/_templates.js +36 -0
  142. package/witnet/assets/index.js +4 -0
  143. package/witnet/assets/modals/index.js +25 -0
  144. package/witnet/assets/modals/web3/btc.js +0 -0
  145. package/witnet/assets/modals/web3/eth.js +29 -0
  146. package/witnet/assets/modals/web3/sol.js +0 -0
  147. package/witnet/assets/modals/web3/wit.js +23 -0
  148. package/witnet/assets/requests.js +94 -0
  149. package/witnet/witnet.proto.json +1325 -0
@@ -0,0 +1,336 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.JsonRpcProvider = exports.JsonRpcProviderError = void 0;
37
+ const axios_1 = __importStar(require("axios"));
38
+ const jsonBig = require('json-bigint');
39
+ const protobufjs_1 = require("protobufjs");
40
+ const protoRoot = protobufjs_1.Root.fromJSON(require("../../../witnet/witnet.proto.json"));
41
+ const protoBuf = protoRoot.lookupType("ConsensusConstants");
42
+ const types_1 = require("../crypto/types");
43
+ const utils = __importStar(require("../utils"));
44
+ const types_2 = require("./types");
45
+ class JsonRpcProviderError extends Error {
46
+ constructor(method, params, error) {
47
+ super(`${method}(${JSON.stringify(params)}): ${JSON.stringify(error)})`);
48
+ delete error?.stack;
49
+ this.error = error;
50
+ this.method = method;
51
+ this.params = params;
52
+ }
53
+ }
54
+ exports.JsonRpcProviderError = JsonRpcProviderError;
55
+ class JsonRpcProvider {
56
+ /**
57
+ * Create and initialize a JsonRpcProvider object connected to the default Wit/RPC endpoint.
58
+ * Defaults to https://rpc-01.witnet.io if no WITNET_SDK_PROVIDER_URL envar is settled
59
+ * on the environment.
60
+ */
61
+ static async fromEnv(url) {
62
+ return JsonRpcProvider.fromURL(url || process.env.WITNET_SDK_PROVIDER_URL || "https://rpc-01.witnet.io");
63
+ }
64
+ /**
65
+ * Create and initialize a JsonRpcProvider object connected to the specified Wit/RPC endpoint.
66
+ * @param url Wit/RPC endpoint URL.
67
+ */
68
+ static async fromURL(url) {
69
+ const provider = new JsonRpcProvider(url);
70
+ return provider.constants().then(() => provider);
71
+ }
72
+ constructor(url) {
73
+ this.endpoints = [];
74
+ if (url !== undefined) {
75
+ const urls = url.replaceAll(',', ';').split(';');
76
+ urls.forEach(url => {
77
+ const [schema,] = utils.parseURL(url);
78
+ if (!schema.startsWith("http://") && !schema.startsWith("https://")) {
79
+ throw Error(`Witnet.JsonRpcProvider: unsupported URL schema ${schema}`);
80
+ }
81
+ });
82
+ this.endpoints = urls;
83
+ }
84
+ else {
85
+ this.endpoints.push(process.env.WITNET_SDK_PROVIDER_URL || "https://rpc-01.witnet.io");
86
+ }
87
+ this._headers = new axios_1.AxiosHeaders({
88
+ "Content-Type": "application/json"
89
+ });
90
+ }
91
+ get network() {
92
+ if (this._constants) {
93
+ return this._constants.bootstrapping_committee[0].startsWith('wit') ? "mainnet" : "testnet";
94
+ }
95
+ else {
96
+ return undefined;
97
+ }
98
+ }
99
+ get networkId() {
100
+ if (this._constants) {
101
+ const obj = {};
102
+ obj.activityPeriod = this._constants.activity_period;
103
+ obj.bootstrapHash = { SHA256: Array.from(utils.fromHexString(this._constants.bootstrap_hash)) };
104
+ obj.bootstrappingCommittee = this._constants.bootstrapping_committee;
105
+ obj.checkpointZeroTimestamp = this._constants.checkpoint_zero_timestamp;
106
+ obj.checkpointsPeriod = this._constants.checkpoints_period;
107
+ obj.collateralAge = this._constants.collateral_age;
108
+ obj.collateralMinimum = this._constants.collateral_minimum;
109
+ obj.epochsWithMinimumDifficulty = this._constants.epochs_with_minimum_difficulty;
110
+ obj.extraRounds = this._constants.extra_rounds;
111
+ obj.genesisHash = { SHA256: Array.from(utils.fromHexString(this._constants.genesis_hash)) };
112
+ obj.halvingPeriod = this._constants.halving_period;
113
+ obj.initialBlockReward = this._constants.initial_block_reward;
114
+ obj.maxDrWeight = this._constants.max_dr_weight;
115
+ obj.maxVtWeight = this._constants.max_vt_weight;
116
+ if (this._constants.minimum_difficulty > 0)
117
+ obj.minimumDifficulty = this._constants.minimum_difficulty;
118
+ obj.miningBackupFactor = this._constants.mining_backup_factor;
119
+ obj.miningReplicationFactor = this._constants.mining_replication_factor;
120
+ obj.reputationExpireAlphaDiff = this._constants.reputation_expire_alpha_diff;
121
+ obj.reputationIssuance = this._constants.reputation_issuance;
122
+ obj.reputationIssuanceStop = this._constants.reputation_issuance_stop;
123
+ obj.reputationPenalizationFactor = this._constants.reputation_penalization_factor;
124
+ obj.superblockCommitteeDecreasingPeriod = this._constants.superblock_committee_decreasing_period;
125
+ obj.superblockCommitteeDecreasingStep = this._constants.superblock_committee_decreasing_step;
126
+ obj.superblockPeriod = this._constants.superblock_period;
127
+ obj.superblockSigningCommitteeSize = this._constants.superblock_signing_committee_size;
128
+ // console.log(obj)
129
+ const message = protoBuf.fromObject(obj);
130
+ // console.log(message)
131
+ const buffer = protoBuf.encode(message).finish();
132
+ const hash = utils.toHexString(utils.sha256(buffer));
133
+ // console.log(hash)
134
+ const hex = hash.substring(0, 4);
135
+ return parseInt(hex, 16);
136
+ }
137
+ return undefined;
138
+ }
139
+ nextURL() {
140
+ return this.endpoints[Math.floor(Math.random() * this.endpoints.length)];
141
+ }
142
+ async callApiMethod(method, params) {
143
+ const url = this.nextURL();
144
+ return axios_1.default
145
+ .post(url, {
146
+ jsonrpc: '2.0',
147
+ id: +new Date(),
148
+ method,
149
+ params,
150
+ }, {
151
+ headers: this._headers,
152
+ transformResponse: function (response) { return jsonBig().parse(response); },
153
+ }).then((response) => {
154
+ if (response?.error || response?.data?.error) {
155
+ throw new JsonRpcProviderError(method, params, response?.error || response?.data?.error);
156
+ }
157
+ else
158
+ return response?.data?.result;
159
+ });
160
+ }
161
+ /// ---------------------------------------------------------------------------------------------------------------
162
+ /**
163
+ * Get the list of block hashes within given range, as known by the provider.
164
+ * @param {number} since - First epoch for which to return block hashes. If negative, return block hashes from the last n epochs.
165
+ * @param {number} limit - Number of block hashes to return. If negative, return the last n block hashes from this epoch range.
166
+ */
167
+ async blocks(since = -1, limit = 1) {
168
+ return this.callApiMethod(types_2.Methods.GetBlockChain, [since, limit,]);
169
+ }
170
+ /// Get consensus constants used by the node
171
+ async constants() {
172
+ if (!this._constants) {
173
+ return this
174
+ .callApiMethod(types_2.Methods.GetConsensusConstants)
175
+ .then((constants) => {
176
+ this._constants = constants;
177
+ return constants;
178
+ });
179
+ }
180
+ else {
181
+ return this._constants;
182
+ }
183
+ }
184
+ /// Get limited list of currently top holders, as known by the provider.
185
+ async holders(minBalance = 0, maxBalance) {
186
+ return this
187
+ .callApiMethod(types_2.Methods.GetBalance2, {
188
+ all: {
189
+ minBalance,
190
+ ...maxBalance ? { maxBalance } : {}
191
+ }
192
+ }).then((balances) => {
193
+ const reverseCompare = (a, b) => {
194
+ const a_tot = a.locked + a.unlocked + a.staked;
195
+ const b_tot = b.locked + b.unlocked + b.staked;
196
+ if (a_tot < b_tot)
197
+ return 1;
198
+ else if (a_tot > b_tot)
199
+ return -1;
200
+ else
201
+ return 0;
202
+ };
203
+ return Object.fromEntries(Object.entries(balances)
204
+ .sort((a, b) => reverseCompare(a[1], b[1])));
205
+ });
206
+ }
207
+ /// Get list of known peers
208
+ async knownPeers() {
209
+ return this.callApiMethod(types_2.Methods.KnownPeers);
210
+ }
211
+ /// Get all the pending transactions
212
+ async mempool() {
213
+ return this.callApiMethod(types_2.Methods.GetMempool);
214
+ }
215
+ /// Get priority and time-to-block estimations for different priority tiers.
216
+ async priorities() {
217
+ return this.callApiMethod(types_2.Methods.Priority);
218
+ }
219
+ /// Get information about protocol versions and which version is currently being enforced.
220
+ async protocolInfo() {
221
+ return this.callApiMethod(types_2.Methods.Protocol);
222
+ }
223
+ /// Get a full list of staking powers ordered by rank
224
+ async powers(query) {
225
+ return this.callApiMethod(types_2.Methods.QueryStakingPowers, query);
226
+ }
227
+ /// Get a full list of current stake entries Query the amount of nanowits staked by an address.
228
+ async stakes(query) {
229
+ return this
230
+ .callApiMethod(types_2.Methods.QueryStakes, query)
231
+ .catch(err => {
232
+ if (err?.error?.message && err.error.message.indexOf("not registered") > -1) {
233
+ return [];
234
+ }
235
+ else {
236
+ throw err;
237
+ }
238
+ });
239
+ }
240
+ /// Get node status
241
+ async syncStatus() {
242
+ return this.callApiMethod(types_2.Methods.SyncStatus);
243
+ }
244
+ async wips() {
245
+ return this.callApiMethod(types_2.Methods.SignalingInfo);
246
+ }
247
+ async witnesses(_since) {
248
+ // todo: witnesses estimation should instead be computed in proportion to
249
+ // ratio of validators that have honestly witnessed data requests
250
+ // vs validators that have honestly witnessed data requests and
251
+ // never revealed "i passed" out of majority,
252
+ // within the specified range of epochs.
253
+ let census = 0;
254
+ return this
255
+ .stakes({ params: { distinct: true } }) // todo: implement `count` flag on IJsonRpcProvider.stakes()
256
+ .then(records => {
257
+ census = records.length;
258
+ return this.blocks(-16, 16); // todo: blocks() should return epoch, hash and validator pkh for each block
259
+ })
260
+ .then(records => {
261
+ return Promise.all(records.map(record => this.getBlock(record[1])));
262
+ })
263
+ .then(blocks => {
264
+ const validators = [];
265
+ blocks.map(block => {
266
+ const pkh = types_1.PublicKey.fromProtobuf(block.block_sig.public_key).hash().toBech32(this.network);
267
+ if (!validators.includes(pkh))
268
+ validators.push(pkh);
269
+ });
270
+ return Math.min(validators.length, Math.floor(this.network === "testnet" ? census / 2 : census / 4));
271
+ });
272
+ }
273
+ /// ---------------------------------------------------------------------------------------------------------------
274
+ /// Get balance
275
+ async getBalance(pkh) {
276
+ return this
277
+ .callApiMethod(types_2.Methods.GetBalance2, { pkh })
278
+ .then((balance) => ({
279
+ locked: BigInt(balance.locked),
280
+ staked: BigInt(balance.staked),
281
+ unlocked: BigInt(balance.unlocked),
282
+ }));
283
+ }
284
+ /**
285
+ * Get block info by hash
286
+ * @param {Hash} blockHash - Hash of the block that we are querying.
287
+ * @param {boolean} showTransactionHash - Whether to include an extra field containing array of transaction hashes.
288
+ */
289
+ async getBlock(blockHash, showTransactionHash = false) {
290
+ return this.callApiMethod(types_2.Methods.GetBlock, [blockHash, showTransactionHash,]);
291
+ }
292
+ async getDataRequest(drTxHash) {
293
+ return this.callApiMethod(types_2.Methods.DataRequestReport, [drTxHash,]);
294
+ }
295
+ /// Get the blocks that pertain to the superblock index
296
+ async getSuperblock(epoch) {
297
+ return this.callApiMethod(types_2.Methods.GetSuperblock, { "block_epoch": epoch });
298
+ }
299
+ async getTransaction(txHash) {
300
+ return this.callApiMethod(types_2.Methods.GetTransaction, [txHash,]);
301
+ }
302
+ async getTransactionReceipt(txHash) {
303
+ // todo: fetch/update receipt from provider, if not cached
304
+ return JsonRpcProvider.receipts[txHash];
305
+ }
306
+ /// Get utxos
307
+ async getUtxos(pkh, smallFirst = true) {
308
+ return this
309
+ .callApiMethod(types_2.Methods.GetUtxoInfo, [pkh,])
310
+ .then((result) => {
311
+ const inversor = smallFirst ? 1 : -1;
312
+ return result.utxos.sort((a, b) => {
313
+ if (a.value > b.value)
314
+ return inversor;
315
+ else if (a.value < b.value)
316
+ return -inversor;
317
+ else
318
+ return 0;
319
+ }).map((utxo) => ({
320
+ ...utxo,
321
+ value: BigInt(utxo.value),
322
+ }));
323
+ });
324
+ }
325
+ /// ---------------------------------------------------------------------------------------------------------------
326
+ async sendRawTransaction(transaction) {
327
+ return this.callApiMethod(types_2.Methods.Inventory, { transaction });
328
+ }
329
+ /// Get supply info
330
+ async supplyInfo() {
331
+ return this.callApiMethod(types_2.Methods.GetSupplyInfo);
332
+ }
333
+ }
334
+ exports.JsonRpcProvider = JsonRpcProvider;
335
+ JsonRpcProvider.receipts = {};
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../../src/lib/rpc/provider.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAsD;AACtD,MAAM,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;AACvC,2CAA8C;AAC9C,MAAM,SAAS,GAAG,iBAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,mCAAmC,CAAC,CAAC,CAAA;AAClF,MAAM,QAAQ,GAAG,SAAS,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAA;AAE3D,2CAAoF;AAEpF,gDAAiC;AAEjC,mCAMgB;AA8BhB,MAAa,oBAAqB,SAAQ,KAAK;IAI3C,YAAY,MAAc,EAAE,MAAa,EAAE,KAAW;QAClD,KAAK,CAAC,GAAG,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACxE,OAAO,KAAK,EAAE,KAAK,CAAA;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACxB,CAAC;CACJ;AAXD,oDAWC;AAED,MAAa,eAAe;IASxB;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,GAAY;QAC7B,OAAO,eAAe,CAAC,OAAO,CAAC,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,0BAA0B,CAAC,CAAA;IAC5G,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,GAAW;QAC5B,MAAM,QAAQ,GAAG,IAAI,eAAe,CAAC,GAAG,CAAC,CAAA;QACzC,OAAO,QAAQ,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAA;IACpD,CAAC;IAED,YAAY,GAAY;QACpB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;QACnB,IAAI,GAAG,KAAK,SAAS,EAAE,CAAC;YACpB,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAChD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBACf,MAAM,CAAC,MAAM,EAAG,GAAG,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;gBACtC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;oBAClE,MAAM,KAAK,CAAC,kDAAkD,MAAM,EAAE,CAAC,CAAA;gBAC3E,CAAC;YACL,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;QACzB,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,0BAA0B,CAAC,CAAA;QAC1F,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAY,CAAC;YAC7B,cAAc,EAAE,kBAAkB;SACrC,CAAC,CAAA;IACN,CAAC;IAED,IAAW,OAAO;QACd,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA,CAAC,CAAC,SAAS,CAAA;QAC9F,CAAC;aAAM,CAAC;YACJ,OAAO,SAAS,CAAA;QACpB,CAAC;IACL,CAAC;IAED,IAAW,SAAS;QAChB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,MAAM,GAAG,GAAQ,EAAE,CAAA;YACnB,GAAG,CAAC,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC;YACrD,GAAG,CAAC,aAAa,GAAG,EAAE,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,CAAC,EAAE,CAAA;YAC/F,GAAG,CAAC,sBAAsB,GAAG,IAAI,CAAC,UAAU,CAAC,uBAAuB,CAAA;YACpE,GAAG,CAAC,uBAAuB,GAAG,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAA;YACvE,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAA;YAC1D,GAAG,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc,CAAA;YAClD,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAA;YAC1D,GAAG,CAAC,2BAA2B,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,CAAA;YAChF,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAA;YAC9C,GAAG,CAAC,WAAW,GAAG,EAAE,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,EAAE,CAAA;YAC3F,GAAG,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc,CAAA;YAClD,GAAG,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAA;YAC7D,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAA;YAC/C,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAA;YAC/C,IAAI,IAAI,CAAC,UAAU,CAAC,kBAAkB,GAAG,CAAC;gBAAE,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAA;YACtG,GAAG,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAA;YAC7D,GAAG,CAAC,uBAAuB,GAAG,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAA;YACvE,GAAG,CAAC,yBAAyB,GAAG,IAAI,CAAC,UAAU,CAAC,4BAA4B,CAAA;YAC5E,GAAG,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAA;YAC5D,GAAG,CAAC,sBAAsB,GAAG,IAAI,CAAC,UAAU,CAAC,wBAAwB,CAAA;YACrE,GAAG,CAAC,4BAA4B,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,CAAA;YACjF,GAAG,CAAC,mCAAmC,GAAG,IAAI,CAAC,UAAU,CAAC,sCAAsC,CAAA;YAChG,GAAG,CAAC,iCAAiC,GAAG,IAAI,CAAC,UAAU,CAAC,oCAAoC,CAAA;YAC5F,GAAG,CAAC,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAA;YACxD,GAAG,CAAC,8BAA8B,GAAG,IAAI,CAAC,UAAU,CAAC,iCAAiC,CAAA;YACtF,mBAAmB;YACnB,MAAM,OAAO,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;YACxC,uBAAuB;YACvB,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAA;YAChD,MAAM,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAA;YACpD,oBAAoB;YACpB,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;YAChC,OAAO,QAAQ,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;QAC5B,CAAC;QACD,OAAO,SAAS,CAAA;IACpB,CAAC;IAES,OAAO;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAA;IAC5E,CAAC;IAES,KAAK,CAAC,aAAa,CAAI,MAAc,EAAE,MAAyB;QACtE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAA;QAC1B,OAAO,eAAK;aACP,IAAI,CACD,GAAG,EACH;YACI,OAAO,EAAE,KAAK;YACd,EAAE,EAAE,CAAE,IAAI,IAAI,EAAE;YAChB,MAAM;YACN,MAAM;SACT,EACD;YACI,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,iBAAiB,EAAE,UAAS,QAAQ,IAAI,OAAO,OAAO,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA,CAAC,CAAC;SAC7E,CAEJ,CAAC,IAAI,CAAC,CAAC,QAAa,EAAE,EAAE;YACrB,IAAI,QAAQ,EAAE,KAAK,IAAI,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;gBAC3C,MAAM,IAAI,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,IAAI,QAAQ,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;YAE7F,CAAC;;gBAAM,OAAO,QAAQ,EAAE,IAAI,EAAE,MAAW,CAAC;QAC9C,CAAC,CAAC,CAAA;IACV,CAAC;IAED,mHAAmH;IAEnH;;;;OAIG;IACI,KAAK,CAAC,MAAM,CAAC,QAAgB,CAAC,CAAC,EAAE,QAAgB,CAAC;QACrD,OAAO,IAAI,CAAC,aAAa,CAAiB,eAAO,CAAC,aAAa,EAAE,CAAC,KAAK,EAAE,KAAK,EAAG,CAAC,CAAC;IACvF,CAAC;IAED,4CAA4C;IACrC,KAAK,CAAC,SAAS;QAClB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACnB,OAAO,IAAI;iBACN,aAAa,CAAqB,eAAO,CAAC,qBAAqB,CAAC;iBAChE,IAAI,CAAC,CAAC,SAA6B,EAAE,EAAE;gBACpC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAA;gBAC3B,OAAO,SAAS,CAAA;YACpB,CAAC,CAAC,CAAA;QACV,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,UAAU,CAAA;QAC1B,CAAC;IACL,CAAC;IAED,wEAAwE;IACjE,KAAK,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,EAAE,UAAmB;QACpD,OAAO,IAAI;aACN,aAAa,CAAuC,eAAO,CAAC,WAAW,EAAE;YACtE,GAAG,EAAE;gBACD,UAAU;gBACV,GAAI,UAAU,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,EAAE;aACvC;SACJ,CAAC,CAAC,IAAI,CAAC,CAAC,QAA+C,EAAE,EAAE;YACxD,MAAM,cAAc,GAAG,CAAC,CAAW,EAAE,CAAW,EAAE,EAAE;gBAChD,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAA;gBAC9C,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAA;gBAC9C,IAAI,KAAK,GAAG,KAAK;oBAAE,OAAO,CAAC,CAAC;qBACvB,IAAI,KAAK,GAAG,KAAK;oBAAE,OAAO,CAAC,CAAC,CAAC;;oBAC7B,OAAO,CAAC,CAAC;YAClB,CAAC,CAAA;YACD,OAAO,MAAM,CAAC,WAAW,CACrB,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;iBACnB,IAAI,CAAC,CAAC,CAAwB,EAAE,CAAwB,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAa,EAAE,CAAC,CAAC,CAAC,CAAa,CAAC,CAAC,CACxH,CAAC;QACN,CAAC,CAAC,CAAA;IACV,CAAC;IAED,2BAA2B;IACpB,KAAK,CAAC,UAAU;QACnB,OAAO,IAAI,CAAC,aAAa,CAAkB,eAAO,CAAC,UAAU,CAAC,CAAC;IACnE,CAAC;IAED,oCAAoC;IAC7B,KAAK,CAAC,OAAO;QAChB,OAAO,IAAI,CAAC,aAAa,CAAU,eAAO,CAAC,UAAU,CAAC,CAAC;IAC3D,CAAC;IAED,4EAA4E;IACrE,KAAK,CAAC,UAAU;QACnB,OAAO,IAAI,CAAC,aAAa,CAAa,eAAO,CAAC,QAAQ,CAAC,CAAA;IAC3D,CAAC;IAED,0FAA0F;IACnF,KAAK,CAAC,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAe,eAAO,CAAC,QAAQ,CAAC,CAAA;IAC7D,CAAC;IAED,qDAAqD;IAC9C,KAAK,CAAC,MAAM,CAAC,KAA0B;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAsB,eAAO,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAA;IACrF,CAAC;IAED,gGAAgG;IACzF,KAAK,CAAC,MAAM,CAAC,KAAmB;QACnC,OAAO,IAAI;aACN,aAAa,CAAoB,eAAO,CAAC,WAAW,EAAE,KAAK,CAAC;aAC5D,KAAK,CAAC,GAAG,CAAC,EAAE;YACT,IAAI,GAAG,EAAE,KAAK,EAAE,OAAO,IAAI,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBAC1E,OAAO,EAAE,CAAA;YACb,CAAC;iBAAM,CAAC;gBACJ,MAAM,GAAG,CAAA;YACb,CAAC;QACL,CAAC,CAAC,CAAA;IACV,CAAC;IAED,mBAAmB;IACZ,KAAK,CAAC,UAAU;QACnB,OAAO,IAAI,CAAC,aAAa,CAAa,eAAO,CAAC,UAAU,CAAC,CAAC;IAC9D,CAAC;IAEM,KAAK,CAAC,IAAI;QACb,OAAO,IAAI,CAAC,aAAa,CAAgB,eAAO,CAAC,aAAa,CAAC,CAAA;IACnE,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,MAAe;QAClC,yEAAyE;QACzE,uEAAuE;QACvE,qEAAqE;QACrE,oDAAoD;QACpD,8CAA8C;QAC9C,IAAI,MAAM,GAAG,CAAC,CAAA;QACd,OAAO,IAAI;aACN,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAC,CAAC,CAAC,4DAA4D;aAClG,IAAI,CAAC,OAAO,CAAC,EAAE;YACZ,MAAM,GAAG,OAAO,CAAC,MAAM,CAAA;YACvB,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAA,CAAC,4EAA4E;QAC5G,CAAC,CAAC;aACD,IAAI,CAAC,OAAO,CAAC,EAAE;YACZ,OAAO,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACvE,CAAC,CAAC;aACD,IAAI,CAAC,MAAM,CAAC,EAAE;YACX,MAAM,UAAU,GAA+B,EAAE,CAAA;YACjD,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBACf,MAAM,GAAG,GAAG,iBAAS,CAAC,YAAY,CAAC,KAAK,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;gBAC5F,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC;oBAAE,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxD,CAAC,CAAC,CAAA;YACF,OAAO,IAAI,CAAC,GAAG,CACX,UAAU,CAAC,MAAM,EACjB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CACnE,CAAA;QACL,CAAC,CAAC,CAAA;IACV,CAAC;IAED,mHAAmH;IACnH,eAAe;IACR,KAAK,CAAC,UAAU,CAAC,GAAwB;QAC5C,OAAO,IAAI;aACN,aAAa,CAAW,eAAO,CAAC,WAAW,EAAE,EAAE,GAAG,EAAE,CAAC;aACrD,IAAI,CAAC,CAAC,OAAiB,EAAE,EAAE,CAAC,CAAC;YAC1B,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;YAC9B,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC;YAC9B,QAAQ,EAAE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC;SACrC,CAAC,CAAC,CAAA;IACX,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,QAAQ,CACb,SAAe,EACf,mBAAmB,GAAG,KAAK;QAG/B,OAAO,IAAI,CAAC,aAAa,CAAQ,eAAO,CAAC,QAAQ,EAAE,CAAC,SAAS,EAAE,mBAAmB,EAAG,CAAC,CAAA;IAC1F,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,QAAc;QACtC,OAAO,IAAI,CAAC,aAAa,CAAoB,eAAO,CAAC,iBAAiB,EAAE,CAAC,QAAQ,EAAG,CAAC,CAAA;IACzF,CAAC;IAED,uDAAuD;IAChD,KAAK,CAAC,aAAa,CAAC,KAAY;QACnC,OAAO,IAAI,CAAC,aAAa,CAAmB,eAAO,CAAC,aAAa,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC;IACjG,CAAC;IAEM,KAAK,CAAC,cAAc,CAAC,MAAY;QACpC,OAAO,IAAI,CAAC,aAAa,CAAoB,eAAO,CAAC,cAAc,EAAE,CAAC,MAAM,EAAG,CAAC,CAAC;IACrF,CAAC;IAEM,KAAK,CAAC,qBAAqB,CAAC,MAAY;QAC3C,0DAA0D;QAC1D,OAAO,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;IAC3C,CAAC;IAED,aAAa;IACN,KAAK,CAAC,QAAQ,CAAC,GAAwB,EAAE,UAAU,GAAG,IAAI;QAC7D,OAAO,IAAI;aACN,aAAa,CAAW,eAAO,CAAC,WAAW,EAAE,CAAC,GAAG,EAAG,CAAC;aACrD,IAAI,CAAC,CAAC,MAAgB,EAAE,EAAE;YACvB,MAAM,QAAQ,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACpC,OAAO,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC9B,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK;oBAAE,OAAO,QAAQ,CAAC;qBAClC,IAAI,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK;oBAAE,OAAO,CAAE,QAAQ,CAAC;;oBACzC,OAAO,CAAC,CAAC;YAClB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAkB,EAAE,EAAE,CAAC,CAAC;gBAC5B,GAAG,IAAI;gBACP,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;aAC5B,CAAC,CAAC,CAAA;QACP,CAAC,CAAC,CAAA;IACV,CAAC;IAED,mHAAmH;IAC5G,KAAK,CAAC,kBAAkB,CAAC,WAAgB;QAC5C,OAAO,IAAI,CAAC,aAAa,CAAU,eAAO,CAAC,SAAS,EAAE,EAAE,WAAW,EAAE,CAAC,CAAA;IAC1E,CAAC;IAED,mBAAmB;IACZ,KAAK,CAAC,UAAU;QACnB,OAAO,IAAI,CAAC,aAAa,CAAa,eAAO,CAAC,aAAa,CAAC,CAAA;IAChE,CAAC;;AA1TL,0CA2TC;AAvTiB,wBAAQ,GAAqC,EAAE,CAAC","sourcesContent":["import { default as axios, AxiosHeaders } from \"axios\"\r\nconst jsonBig = require('json-bigint');\r\nimport { Root as ProtoRoot } from \"protobufjs\"\r\nconst protoRoot = ProtoRoot.fromJSON(require(\"../../../witnet/witnet.proto.json\")) \r\nconst protoBuf = protoRoot.lookupType(\"ConsensusConstants\")\r\n\r\nimport { PublicKey, PublicKeyHashString, TransactionReceipt } from \"../crypto/types\"\r\nimport { Epoch, Hash, Network, UtxoMetadata } from \"../types\"\r\nimport * as utils from \"../utils\"\r\n\r\nimport {\r\n    Balance, Balance2, Block, ConsensusConstants, DataRequestReport, \r\n    Mempool, Methods, PeerAddr, Priorities, ProtocolInfo, \r\n    QueryStakes, QueryStakingPowers,\r\n    TransactionReport, SignalingInfo, StakeEntry, StakingPower, \r\n    SuperblockReport, SupplyInfo, SyncStatus, UtxoInfo,\r\n} from \"./types\"\r\n\r\nexport interface IJsonRpcProvider {\r\n    network?: Network;\r\n    networkId?: number;\r\n    \r\n    blocks(since: Epoch, limit: number): Promise<Array<[number, Hash/*, PublicKeyHashString*/]>>;\r\n    constants(): Promise<ConsensusConstants>;\r\n    holders(limit?: number): Promise<Record<PublicKeyHashString, Balance2>> \r\n    mempool(): Promise<Mempool>;\r\n    powers(params?: QueryStakingPowers): Promise<Array<StakingPower>>;\r\n    priorities(): Promise<Priorities>;\r\n    protocolInfo(): Promise<ProtocolInfo>;\r\n    stakes(params: QueryStakes): Promise<Array<StakeEntry>>; \r\n    supplyInfo(): Promise<SupplyInfo>;\r\n    syncStatus(): Promise<any>;\r\n    wips(): Promise<SignalingInfo>;\r\n    witnesses(): Promise<number>;\r\n\r\n    getBalance(pkh: PublicKeyHashString): Promise<Balance2>;\r\n    getBlock(blockHash: Hash, showTransactionHashes?: boolean): Promise<Block>;\r\n    getDataRequest(drTxHash: Hash): Promise<DataRequestReport>;\r\n    getSuperblock(epoch: Epoch): Promise<SuperblockReport>;\r\n    getTransaction(txHash: Hash): Promise<TransactionReport>;\r\n    getTransactionReceipt(txHash: Hash): Promise<TransactionReceipt>;\r\n    getUtxos(pkh: PublicKeyHashString, smallestFirst?: boolean): Promise<Array<UtxoMetadata>>;\r\n        \r\n    sendRawTransaction(tx: any): Promise<boolean>;\r\n}\r\n\r\nexport class JsonRpcProviderError extends Error {\r\n    readonly error?: any;\r\n    readonly method: string;\r\n    readonly params: any[];\r\n    constructor(method: string, params: any[], error?: any) {\r\n        super(`${method}(${JSON.stringify(params)}): ${JSON.stringify(error)})`)\r\n        delete error?.stack\r\n        this.error = error\r\n        this.method = method\r\n        this.params = params\r\n    }\r\n}\r\n\r\nexport class JsonRpcProvider implements IJsonRpcProvider {\r\n    \r\n    public readonly endpoints: string[]\r\n\r\n    public static receipts: Record<Hash, TransactionReceipt> = {};\r\n\r\n    protected _constants?: ConsensusConstants\r\n    protected _headers: AxiosHeaders;\r\n    \r\n    /**\r\n     * Create and initialize a JsonRpcProvider object connected to the default Wit/RPC endpoint.\r\n     * Defaults to https://rpc-01.witnet.io if no WITNET_SDK_PROVIDER_URL envar is settled\r\n     * on the environment.\r\n     */\r\n    static async fromEnv(url?: string): Promise<JsonRpcProvider> {\r\n        return JsonRpcProvider.fromURL(url || process.env.WITNET_SDK_PROVIDER_URL || \"https://rpc-01.witnet.io\")\r\n    }\r\n    \r\n    /**\r\n     * Create and initialize a JsonRpcProvider object connected to the specified Wit/RPC endpoint.\r\n     * @param url Wit/RPC endpoint URL.\r\n     */\r\n    static async fromURL(url: string): Promise<JsonRpcProvider> {\r\n        const provider = new JsonRpcProvider(url)\r\n        return provider.constants().then(() => provider)\r\n    }\r\n\r\n    constructor(url?: string) {\r\n        this.endpoints = []\r\n        if (url !== undefined) {\r\n            const urls = url.replaceAll(',', ';').split(';')\r\n            urls.forEach(url => {\r\n                const [schema, ] = utils.parseURL(url)\r\n                if (!schema.startsWith(\"http://\") && !schema.startsWith(\"https://\")) {\r\n                    throw Error(`Witnet.JsonRpcProvider: unsupported URL schema ${schema}`)\r\n                }\r\n            })\r\n            this.endpoints = urls\r\n        } else {\r\n            this.endpoints.push(process.env.WITNET_SDK_PROVIDER_URL || \"https://rpc-01.witnet.io\")\r\n        }\r\n        this._headers = new AxiosHeaders({ \r\n            \"Content-Type\": \"application/json\" \r\n        })\r\n    }\r\n\r\n    public get network(): Network | undefined {\r\n        if (this._constants) {\r\n            return this._constants.bootstrapping_committee[0].startsWith('wit') ? \"mainnet\": \"testnet\"\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    public get networkId(): number | undefined {\r\n        if (this._constants) {\r\n            const obj: any = {}\r\n            obj.activityPeriod = this._constants.activity_period;\r\n            obj.bootstrapHash = { SHA256: Array.from(utils.fromHexString(this._constants.bootstrap_hash)) }\r\n            obj.bootstrappingCommittee = this._constants.bootstrapping_committee\r\n            obj.checkpointZeroTimestamp = this._constants.checkpoint_zero_timestamp\r\n            obj.checkpointsPeriod = this._constants.checkpoints_period\r\n            obj.collateralAge = this._constants.collateral_age\r\n            obj.collateralMinimum = this._constants.collateral_minimum\r\n            obj.epochsWithMinimumDifficulty = this._constants.epochs_with_minimum_difficulty\r\n            obj.extraRounds = this._constants.extra_rounds\r\n            obj.genesisHash = { SHA256: Array.from(utils.fromHexString(this._constants.genesis_hash)) }\r\n            obj.halvingPeriod = this._constants.halving_period\r\n            obj.initialBlockReward = this._constants.initial_block_reward\r\n            obj.maxDrWeight = this._constants.max_dr_weight\r\n            obj.maxVtWeight = this._constants.max_vt_weight\r\n            if (this._constants.minimum_difficulty > 0) obj.minimumDifficulty = this._constants.minimum_difficulty\r\n            obj.miningBackupFactor = this._constants.mining_backup_factor\r\n            obj.miningReplicationFactor = this._constants.mining_replication_factor\r\n            obj.reputationExpireAlphaDiff = this._constants.reputation_expire_alpha_diff\r\n            obj.reputationIssuance = this._constants.reputation_issuance\r\n            obj.reputationIssuanceStop = this._constants.reputation_issuance_stop\r\n            obj.reputationPenalizationFactor = this._constants.reputation_penalization_factor\r\n            obj.superblockCommitteeDecreasingPeriod = this._constants.superblock_committee_decreasing_period\r\n            obj.superblockCommitteeDecreasingStep = this._constants.superblock_committee_decreasing_step\r\n            obj.superblockPeriod = this._constants.superblock_period\r\n            obj.superblockSigningCommitteeSize = this._constants.superblock_signing_committee_size\r\n            // console.log(obj)\r\n            const message = protoBuf.fromObject(obj)\r\n            // console.log(message)\r\n            const buffer = protoBuf.encode(message).finish()\r\n            const hash = utils.toHexString(utils.sha256(buffer)) \r\n            // console.log(hash)\r\n            const hex = hash.substring(0, 4)\r\n            return parseInt(hex, 16)\r\n        } \r\n        return undefined\r\n    }\r\n    \r\n    protected nextURL(): string {\r\n        return this.endpoints[Math.floor(Math.random() * this.endpoints.length)]\r\n    }\r\n    \r\n    protected async callApiMethod<T>(method: string, params?: Array<any> | any ): Promise<Error | any> {\r\n        const url = this.nextURL()\r\n        return axios\r\n            .post(\r\n                url,\r\n                {\r\n                    jsonrpc: '2.0',\r\n                    id: + new Date(),\r\n                    method,\r\n                    params,\r\n                },\r\n                {\r\n                    headers: this._headers,\r\n                    transformResponse: function(response) { return jsonBig().parse(response) },\r\n                },\r\n            \r\n            ).then((response: any) => {\r\n                if (response?.error || response?.data?.error) {\r\n                    throw new JsonRpcProviderError(method, params, response?.error || response?.data?.error);\r\n\r\n                } else return response?.data?.result as T;\r\n            })\r\n    }\r\n    \r\n    /// ---------------------------------------------------------------------------------------------------------------\r\n   \r\n    /**\r\n     * Get the list of block hashes within given range, as known by the provider.\r\n     * @param {number} since - First epoch for which to return block hashes. If negative, return block hashes from the last n epochs.\r\n         * @param {number} limit - Number of block hashes to return. If negative, return the last n block hashes from this epoch range.\r\n     */\r\n    public async blocks(since: number = -1, limit: number = 1,): Promise<Array<[number, Hash]>> {\r\n        return this.callApiMethod<[Number, Hash]>(Methods.GetBlockChain, [since, limit, ]);\r\n    }\r\n    \r\n    /// Get consensus constants used by the node\r\n    public async constants(): Promise<ConsensusConstants> {\r\n        if (!this._constants) {\r\n            return this\r\n                .callApiMethod<ConsensusConstants>(Methods.GetConsensusConstants)\r\n                .then((constants: ConsensusConstants) => {\r\n                    this._constants = constants\r\n                    return constants\r\n                })\r\n        } else {\r\n            return this._constants\r\n        }    \r\n    }\r\n\r\n    /// Get limited list of currently top holders, as known by the provider.\r\n    public async holders(minBalance = 0, maxBalance?: number): Promise<Record<PublicKeyHashString, Balance2>> {\r\n        return this\r\n            .callApiMethod<Record<PublicKeyHashString, Balance>>(Methods.GetBalance2, {\r\n                all: {\r\n                    minBalance,\r\n                    ... maxBalance ? { maxBalance } : {}\r\n                }\r\n            }).then((balances: Record<PublicKeyHashString, Balance2>) => {\r\n                const reverseCompare = (a: Balance2, b: Balance2) => {\r\n                    const a_tot = a.locked + a.unlocked + a.staked\r\n                    const b_tot = b.locked + b.unlocked + b.staked\r\n                    if (a_tot < b_tot) return 1;\r\n                    else if (a_tot > b_tot) return -1;\r\n                    else return 0;\r\n                }\r\n                return Object.fromEntries(\r\n                    Object.entries(balances)\r\n                        .sort((a: (string | Balance2)[], b: (string | Balance2)[]) => reverseCompare(a[1] as Balance2, b[1] as Balance2))\r\n                );\r\n            })\r\n    }\r\n    \r\n    /// Get list of known peers\r\n    public async knownPeers(): Promise<Array<PeerAddr>> {\r\n        return this.callApiMethod<Array<PeerAddr>>(Methods.KnownPeers);\r\n    }\r\n    \r\n    /// Get all the pending transactions\r\n    public async mempool(): Promise<Mempool> {\r\n        return this.callApiMethod<Mempool>(Methods.GetMempool);\r\n    }    \r\n    \r\n    /// Get priority and time-to-block estimations for different priority tiers.\r\n    public async priorities(): Promise<Priorities> {\r\n        return this.callApiMethod<Priorities>(Methods.Priority)\r\n    }\r\n    \r\n    /// Get information about protocol versions and which version is currently being enforced.\r\n    public async protocolInfo(): Promise<ProtocolInfo> {\r\n        return this.callApiMethod<ProtocolInfo>(Methods.Protocol)\r\n    }\r\n    \r\n    /// Get a full list of staking powers ordered by rank\r\n    public async powers(query?: QueryStakingPowers): Promise<Array<StakingPower>> {\r\n        return this.callApiMethod<Array<StakingPower>>(Methods.QueryStakingPowers, query)\r\n    }\r\n    \r\n    /// Get a full list of current stake entries  Query the amount of nanowits staked by an address.\r\n    public async stakes(query?: QueryStakes): Promise<Array<StakeEntry>> {\r\n        return this\r\n            .callApiMethod<Array<StakeEntry>>(Methods.QueryStakes, query)\r\n            .catch(err => {\r\n                if (err?.error?.message && err.error.message.indexOf(\"not registered\") > -1) {\r\n                    return []\r\n                } else {\r\n                    throw err\r\n                }\r\n            })\r\n    }\r\n    \r\n    /// Get node status\r\n    public async syncStatus(): Promise<SyncStatus> {\r\n        return this.callApiMethod<SyncStatus>(Methods.SyncStatus);\r\n    }\r\n    \r\n    public async wips(): Promise<SignalingInfo> {\r\n        return this.callApiMethod<SignalingInfo>(Methods.SignalingInfo)\r\n    }\r\n\r\n    public async witnesses(_since?: number): Promise<number> {\r\n        // todo: witnesses estimation should instead be computed in proportion to\r\n        //       ratio of validators that have honestly witnessed data requests\r\n        //       vs validators that have honestly witnessed data requests and\r\n        //       never revealed \"i passed\" out of majority, \r\n        //       within the specified range of epochs.\r\n        let census = 0\r\n        return this \r\n            .stakes({ params: { distinct: true }}) // todo: implement `count` flag on IJsonRpcProvider.stakes()\r\n            .then(records => {\r\n                census = records.length\r\n                return this.blocks(-16, 16) // todo: blocks() should return epoch, hash and validator pkh for each block\r\n            })\r\n            .then(records => {\r\n                return Promise.all(records.map(record => this.getBlock(record[1])))\r\n            })\r\n            .then(blocks => {\r\n                const validators: Array<PublicKeyHashString> = []\r\n                blocks.map(block => {\r\n                    const pkh = PublicKey.fromProtobuf(block.block_sig.public_key).hash().toBech32(this.network)\r\n                    if (!validators.includes(pkh)) validators.push(pkh);\r\n                })\r\n                return Math.min(\r\n                    validators.length,\r\n                    Math.floor(this.network === \"testnet\" ? census / 2 : census / 4)\r\n                )\r\n            })\r\n    }\r\n    \r\n    /// ---------------------------------------------------------------------------------------------------------------\r\n    /// Get balance\r\n    public async getBalance(pkh: PublicKeyHashString): Promise<Balance2> {\r\n        return this\r\n            .callApiMethod<Balance2>(Methods.GetBalance2, { pkh })\r\n            .then((balance: Balance2) => ({\r\n                locked: BigInt(balance.locked),\r\n                staked: BigInt(balance.staked),\r\n                unlocked: BigInt(balance.unlocked),\r\n            }))\r\n    }\r\n    \r\n    /**\r\n     * Get block info by hash\r\n     * @param {Hash} blockHash - Hash of the block that we are querying.\r\n     * @param {boolean} showTransactionHash - Whether to include an extra field containing array of transaction hashes.\r\n     */\r\n    public async getBlock(\r\n            blockHash: Hash,\r\n            showTransactionHash = false,\r\n        ): Promise<Block>\r\n    {\r\n        return this.callApiMethod<Block>(Methods.GetBlock, [blockHash, showTransactionHash, ])\r\n    }\r\n    \r\n    public async getDataRequest(drTxHash: Hash): Promise<DataRequestReport> {\r\n        return this.callApiMethod<DataRequestReport>(Methods.DataRequestReport, [drTxHash, ])\r\n    }\r\n    \r\n    /// Get the blocks that pertain to the superblock index\r\n    public async getSuperblock(epoch: Epoch): Promise<SuperblockReport> {\r\n        return this.callApiMethod<SuperblockReport>(Methods.GetSuperblock, { \"block_epoch\": epoch });\r\n    }\r\n    \r\n    public async getTransaction(txHash: Hash): Promise<TransactionReport> {\r\n        return this.callApiMethod<TransactionReport>(Methods.GetTransaction, [txHash, ]);\r\n    }\r\n\r\n    public async getTransactionReceipt(txHash: Hash): Promise<TransactionReceipt> {\r\n        // todo: fetch/update receipt from provider, if not cached\r\n        return JsonRpcProvider.receipts[txHash]\r\n    }\r\n    \r\n    /// Get utxos\r\n    public async getUtxos(pkh: PublicKeyHashString, smallFirst = true): Promise<Array<UtxoMetadata>> {\r\n        return this\r\n            .callApiMethod<UtxoInfo>(Methods.GetUtxoInfo, [pkh, ])\r\n            .then((result: UtxoInfo) => {\r\n                const inversor = smallFirst ? 1 : -1\r\n                return result.utxos.sort((a, b) => {\r\n                    if (a.value > b.value) return inversor;\r\n                    else if (a.value < b.value) return - inversor;\r\n                    else return 0;\r\n                }).map((utxo: UtxoMetadata) => ({\r\n                    ...utxo,\r\n                    value: BigInt(utxo.value),\r\n                }))\r\n            })\r\n    }\r\n    \r\n    /// ---------------------------------------------------------------------------------------------------------------\r\n    public async sendRawTransaction(transaction: any): Promise<boolean> {\r\n        return this.callApiMethod<boolean>(Methods.Inventory, { transaction })\r\n    }\r\n\r\n    /// Get supply info\r\n    public async supplyInfo(): Promise<SupplyInfo> {\r\n        return this.callApiMethod<SupplyInfo>(Methods.GetSupplyInfo)\r\n    }\r\n}"]}
@@ -0,0 +1,18 @@
1
+ import { IJsonRpcProvider, JsonRpcProvider } from "./provider";
2
+ import { DataRequestReport, PeerAddr, SupplyInfo } from "./types";
3
+ import { Hash } from "../types";
4
+ export interface IReporter extends IJsonRpcProvider {
5
+ providers(): Promise<Array<string>>;
6
+ supplyInfo(): Promise<SupplyInfo>;
7
+ getDataRequest(drTxHash: Hash, channel?: string): Promise<DataRequestReport>;
8
+ searchDataRequests(radHash: Hash): Promise<any>;
9
+ }
10
+ export declare class Reporter extends JsonRpcProvider implements IReporter {
11
+ constructor(url?: string);
12
+ peers(): Promise<Array<PeerAddr>>;
13
+ providers(): Promise<Array<string>>;
14
+ supplyInfo(): Promise<SupplyInfo>;
15
+ reportDataRequest(drTxHash: Hash, channel?: string): Promise<DataRequestReport>;
16
+ searchDataRequests(radHash: Hash): Promise<any>;
17
+ }
18
+ //# sourceMappingURL=reporter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reporter.d.ts","sourceRoot":"","sources":["../../../../src/lib/rpc/reporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAC9D,OAAO,EAAE,iBAAiB,EAAW,QAAQ,EAAE,UAAU,EAAG,MAAM,SAAS,CAAA;AAC3E,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAA;AAE/B,MAAM,WAAW,SAAU,SAAQ,gBAAgB;IAC/C,SAAS,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAA;IACnC,UAAU,IAAI,OAAO,CAAC,UAAU,CAAC,CAAC;IAElC,cAAc,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;IAC5E,kBAAkB,CAAC,OAAO,EAAE,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;CACnD;AAED,qBAAa,QAAS,SAAQ,eAAgB,YAAW,SAAS;gBAClD,GAAG,CAAC,EAAE,MAAM;IAKjB,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAI3B,SAAS,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAKnC,UAAU,IAAI,OAAO,CAAC,UAAU,CAAC;IAKjC,iBAAiB,CAAC,QAAQ,EAAE,IAAI,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAI/E,kBAAkB,CAAC,OAAO,EAAE,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC;CAG/D"}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Reporter = void 0;
4
+ const provider_1 = require("./provider");
5
+ const types_1 = require("./types");
6
+ class Reporter extends provider_1.JsonRpcProvider {
7
+ constructor(url) {
8
+ super(url || process.env.WITNET_TOOLKIT_REPORTER_URL || "https://kermit.witnet.io");
9
+ }
10
+ /// ---------------------------------------------------------------------------------------------------------------
11
+ peers() {
12
+ return this.callApiMethod(types_1.Methods.KnownPeers);
13
+ }
14
+ async providers() {
15
+ return this.callApiMethod(types_1.Methods.Providers);
16
+ }
17
+ /// Get supply info
18
+ async supplyInfo() {
19
+ return this.callApiMethod(types_1.Methods.GetSupplyInfo);
20
+ }
21
+ /// ---------------------------------------------------------------------------------------------------------------
22
+ async reportDataRequest(drTxHash, channel) {
23
+ return this.callApiMethod(types_1.Methods.DataRequestReport, [drTxHash, channel,]);
24
+ }
25
+ async searchDataRequests(radHash) {
26
+ return this.callApiMethod(types_1.Methods.SearchDataRequests, [radHash,]);
27
+ }
28
+ }
29
+ exports.Reporter = Reporter;
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3JwYy9yZXBvcnRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5Q0FBOEQ7QUFDOUQsbUNBQTJFO0FBVzNFLE1BQWEsUUFBUyxTQUFRLDBCQUFlO0lBQ3pDLFlBQVksR0FBWTtRQUNwQixLQUFLLENBQUMsR0FBRyxJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsMkJBQTJCLElBQUksMEJBQTBCLENBQUMsQ0FBQTtJQUN2RixDQUFDO0lBRUQsbUhBQW1IO0lBQzVHLEtBQUs7UUFDUixPQUFPLElBQUksQ0FBQyxhQUFhLENBQWtCLGVBQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRU0sS0FBSyxDQUFDLFNBQVM7UUFDbEIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFnQixlQUFPLENBQUMsU0FBUyxDQUFDLENBQUE7SUFDL0QsQ0FBQztJQUVELG1CQUFtQjtJQUNaLEtBQUssQ0FBQyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBYSxlQUFPLENBQUMsYUFBYSxDQUFDLENBQUE7SUFDaEUsQ0FBQztJQUVELG1IQUFtSDtJQUM1RyxLQUFLLENBQUMsaUJBQWlCLENBQUMsUUFBYyxFQUFFLE9BQWdCO1FBQzNELE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBb0IsZUFBTyxDQUFDLGlCQUFpQixFQUFFLENBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRyxDQUFDLENBQUE7SUFDbEcsQ0FBQztJQUVNLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxPQUFhO1FBQ3pDLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBTSxlQUFPLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxPQUFPLEVBQUcsQ0FBQyxDQUFBO0lBQzNFLENBQUM7Q0FDSjtBQTNCRCw0QkEyQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJSnNvblJwY1Byb3ZpZGVyLCBKc29uUnBjUHJvdmlkZXIgfSBmcm9tIFwiLi9wcm92aWRlclwiXHJcbmltcG9ydCB7IERhdGFSZXF1ZXN0UmVwb3J0LCBNZXRob2RzLCBQZWVyQWRkciwgU3VwcGx5SW5mbywgfSBmcm9tIFwiLi90eXBlc1wiXHJcbmltcG9ydCB7IEhhc2ggfSBmcm9tIFwiLi4vdHlwZXNcIlxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJUmVwb3J0ZXIgZXh0ZW5kcyBJSnNvblJwY1Byb3ZpZGVyIHtcclxuICAgIHByb3ZpZGVycygpOiBQcm9taXNlPEFycmF5PHN0cmluZz4+XHJcbiAgICBzdXBwbHlJbmZvKCk6IFByb21pc2U8U3VwcGx5SW5mbz47XHJcblxyXG4gICAgZ2V0RGF0YVJlcXVlc3QoZHJUeEhhc2g6IEhhc2gsIGNoYW5uZWw/OiBzdHJpbmcpOiBQcm9taXNlPERhdGFSZXF1ZXN0UmVwb3J0PlxyXG4gICAgc2VhcmNoRGF0YVJlcXVlc3RzKHJhZEhhc2g6IEhhc2gpOiBQcm9taXNlPGFueT47XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBSZXBvcnRlciBleHRlbmRzIEpzb25ScGNQcm92aWRlciBpbXBsZW1lbnRzIElSZXBvcnRlciB7XHJcbiAgICBjb25zdHJ1Y3Rvcih1cmw/OiBzdHJpbmcpIHtcclxuICAgICAgICBzdXBlcih1cmwgfHwgcHJvY2Vzcy5lbnYuV0lUTkVUX1RPT0xLSVRfUkVQT1JURVJfVVJMIHx8IFwiaHR0cHM6Ly9rZXJtaXQud2l0bmV0LmlvXCIpXHJcbiAgICB9XHJcbiAgICBcclxuICAgIC8vLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cclxuICAgIHB1YmxpYyBwZWVycygpOiBQcm9taXNlPEFycmF5PFBlZXJBZGRyPj4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxBcGlNZXRob2Q8QXJyYXk8UGVlckFkZHI+PihNZXRob2RzLktub3duUGVlcnMpO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICBwdWJsaWMgYXN5bmMgcHJvdmlkZXJzKCk6IFByb21pc2U8QXJyYXk8c3RyaW5nPj4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxBcGlNZXRob2Q8QXJyYXk8c3RyaW5nPj4oTWV0aG9kcy5Qcm92aWRlcnMpXHJcbiAgICB9XHJcbiAgICBcclxuICAgIC8vLyBHZXQgc3VwcGx5IGluZm9cclxuICAgIHB1YmxpYyBhc3luYyBzdXBwbHlJbmZvKCk6IFByb21pc2U8U3VwcGx5SW5mbz4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxBcGlNZXRob2Q8U3VwcGx5SW5mbz4oTWV0aG9kcy5HZXRTdXBwbHlJbmZvKVxyXG4gICAgfVxyXG4gICAgXHJcbiAgICAvLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXHJcbiAgICBwdWJsaWMgYXN5bmMgcmVwb3J0RGF0YVJlcXVlc3QoZHJUeEhhc2g6IEhhc2gsIGNoYW5uZWw/OiBzdHJpbmcpOiBQcm9taXNlPERhdGFSZXF1ZXN0UmVwb3J0PiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuY2FsbEFwaU1ldGhvZDxEYXRhUmVxdWVzdFJlcG9ydD4oTWV0aG9kcy5EYXRhUmVxdWVzdFJlcG9ydCwgW2RyVHhIYXNoLCBjaGFubmVsLCBdKVxyXG4gICAgfVxyXG4gICAgXHJcbiAgICBwdWJsaWMgYXN5bmMgc2VhcmNoRGF0YVJlcXVlc3RzKHJhZEhhc2g6IEhhc2gpOiBQcm9taXNlPGFueT4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNhbGxBcGlNZXRob2Q8YW55PihNZXRob2RzLlNlYXJjaERhdGFSZXF1ZXN0cywgW3JhZEhhc2gsIF0pXHJcbiAgICB9XHJcbn1cclxuIl19