@ksangkuk10/wallet-controller 1.7.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (124) hide show
  1. package/README.md +7 -0
  2. package/_commonjs/controller.js +704 -0
  3. package/_commonjs/env.js +9 -0
  4. package/_commonjs/exception/isError.js +15 -0
  5. package/_commonjs/exception/mapExtensionTxError.js +46 -0
  6. package/_commonjs/exception/mapWalletConnectError.js +69 -0
  7. package/_commonjs/getChainOptions.js +57 -0
  8. package/_commonjs/index.js +22 -0
  9. package/_commonjs/modules/connect-modal/index.js +80 -0
  10. package/_commonjs/modules/connect-modal/style.js +161 -0
  11. package/_commonjs/modules/extension-router/ExtensionRouter.js +241 -0
  12. package/_commonjs/modules/extension-router/index.js +19 -0
  13. package/_commonjs/modules/extension-router/modal.js +80 -0
  14. package/_commonjs/modules/extension-router/modal.style.js +161 -0
  15. package/_commonjs/modules/extension-router/multiChannel.js +18 -0
  16. package/_commonjs/modules/extension-router/session.js +37 -0
  17. package/_commonjs/modules/extension-router/types.js +16 -0
  18. package/_commonjs/modules/legacy-extension/LegacyExtensionConnector.js +143 -0
  19. package/_commonjs/modules/legacy-extension/createFixedExtension.js +236 -0
  20. package/_commonjs/modules/legacy-extension/index.js +19 -0
  21. package/_commonjs/modules/readonly-wallet/connect.js +24 -0
  22. package/_commonjs/modules/readonly-wallet/index.js +20 -0
  23. package/_commonjs/modules/readonly-wallet/modal.js +123 -0
  24. package/_commonjs/modules/readonly-wallet/modal.style.js +204 -0
  25. package/_commonjs/modules/readonly-wallet/storage.js +40 -0
  26. package/_commonjs/modules/readonly-wallet/types.js +3 -0
  27. package/_commonjs/modules/walletconnect/connect.js +421 -0
  28. package/_commonjs/modules/walletconnect/errors.js +51 -0
  29. package/_commonjs/modules/walletconnect/impl/socket-transport/index.js +204 -0
  30. package/_commonjs/modules/walletconnect/impl/socket-transport/network.js +30 -0
  31. package/_commonjs/modules/walletconnect/index.js +22 -0
  32. package/_commonjs/modules/walletconnect/modal.js +147 -0
  33. package/_commonjs/modules/walletconnect/modal.style.js +138 -0
  34. package/_commonjs/modules/walletconnect/types.js +13 -0
  35. package/_commonjs/operators/getExtensions.js +55 -0
  36. package/_commonjs/operators/toConnectedWallet.js +24 -0
  37. package/_commonjs/operators/toLcdClient.js +15 -0
  38. package/_commonjs/utils/browser-check.js +47 -0
  39. package/_commonjs/utils/checkExtensionReady.js +28 -0
  40. package/_commonjs/utils/sortConnections.js +13 -0
  41. package/_commonjs/verifyBytes.js +19 -0
  42. package/controller.d.ts +220 -0
  43. package/controller.js +697 -0
  44. package/env.d.ts +2 -0
  45. package/env.js +5 -0
  46. package/exception/isError.d.ts +3 -0
  47. package/exception/isError.js +11 -0
  48. package/exception/mapExtensionTxError.d.ts +5 -0
  49. package/exception/mapExtensionTxError.js +41 -0
  50. package/exception/mapWalletConnectError.d.ts +6 -0
  51. package/exception/mapWalletConnectError.js +63 -0
  52. package/getChainOptions.d.ts +3 -0
  53. package/getChainOptions.js +53 -0
  54. package/index.d.ts +6 -0
  55. package/index.js +6 -0
  56. package/modules/connect-modal/index.d.ts +2 -0
  57. package/modules/connect-modal/index.js +76 -0
  58. package/modules/connect-modal/style.d.ts +1 -0
  59. package/modules/connect-modal/style.js +158 -0
  60. package/modules/extension-router/ExtensionRouter.d.ts +43 -0
  61. package/modules/extension-router/ExtensionRouter.js +237 -0
  62. package/modules/extension-router/index.d.ts +2 -0
  63. package/modules/extension-router/index.js +3 -0
  64. package/modules/extension-router/modal.d.ts +2 -0
  65. package/modules/extension-router/modal.js +76 -0
  66. package/modules/extension-router/modal.style.d.ts +1 -0
  67. package/modules/extension-router/modal.style.js +158 -0
  68. package/modules/extension-router/multiChannel.d.ts +13 -0
  69. package/modules/extension-router/multiChannel.js +14 -0
  70. package/modules/extension-router/session.d.ts +8 -0
  71. package/modules/extension-router/session.js +31 -0
  72. package/modules/extension-router/types.d.ts +35 -0
  73. package/modules/extension-router/types.js +13 -0
  74. package/modules/legacy-extension/LegacyExtensionConnector.d.ts +30 -0
  75. package/modules/legacy-extension/LegacyExtensionConnector.js +139 -0
  76. package/modules/legacy-extension/createFixedExtension.d.ts +46 -0
  77. package/modules/legacy-extension/createFixedExtension.js +232 -0
  78. package/modules/legacy-extension/index.d.ts +2 -0
  79. package/modules/legacy-extension/index.js +3 -0
  80. package/modules/readonly-wallet/connect.d.ts +8 -0
  81. package/modules/readonly-wallet/connect.js +19 -0
  82. package/modules/readonly-wallet/index.d.ts +3 -0
  83. package/modules/readonly-wallet/index.js +4 -0
  84. package/modules/readonly-wallet/modal.d.ts +7 -0
  85. package/modules/readonly-wallet/modal.js +119 -0
  86. package/modules/readonly-wallet/modal.style.d.ts +1 -0
  87. package/modules/readonly-wallet/modal.style.js +201 -0
  88. package/modules/readonly-wallet/storage.d.ts +4 -0
  89. package/modules/readonly-wallet/storage.js +34 -0
  90. package/modules/readonly-wallet/types.d.ts +5 -0
  91. package/modules/readonly-wallet/types.js +2 -0
  92. package/modules/walletconnect/connect.d.ts +42 -0
  93. package/modules/walletconnect/connect.js +390 -0
  94. package/modules/walletconnect/errors.d.ts +22 -0
  95. package/modules/walletconnect/errors.js +41 -0
  96. package/modules/walletconnect/impl/socket-transport/index.d.ts +39 -0
  97. package/modules/walletconnect/impl/socket-transport/index.js +199 -0
  98. package/modules/walletconnect/impl/socket-transport/network.d.ts +8 -0
  99. package/modules/walletconnect/impl/socket-transport/network.js +28 -0
  100. package/modules/walletconnect/index.d.ts +5 -0
  101. package/modules/walletconnect/index.js +6 -0
  102. package/modules/walletconnect/modal.d.ts +12 -0
  103. package/modules/walletconnect/modal.js +143 -0
  104. package/modules/walletconnect/modal.style.d.ts +1 -0
  105. package/modules/walletconnect/modal.style.js +135 -0
  106. package/modules/walletconnect/types.d.ts +24 -0
  107. package/modules/walletconnect/types.js +10 -0
  108. package/operators/getExtensions.d.ts +9 -0
  109. package/operators/getExtensions.js +51 -0
  110. package/operators/toConnectedWallet.d.ts +4 -0
  111. package/operators/toConnectedWallet.js +20 -0
  112. package/operators/toLcdClient.d.ts +4 -0
  113. package/operators/toLcdClient.js +11 -0
  114. package/package.json +550 -0
  115. package/utils/browser-check.d.ts +3 -0
  116. package/utils/browser-check.js +38 -0
  117. package/utils/checkExtensionReady.d.ts +6 -0
  118. package/utils/checkExtensionReady.js +24 -0
  119. package/utils/sortConnections.d.ts +2 -0
  120. package/utils/sortConnections.js +9 -0
  121. package/verifyBytes.d.ts +4 -0
  122. package/verifyBytes.js +15 -0
  123. package/~/.npm/_cacache/content-v2/sha512/ad/b5/8c87dfae7c208906a88f1997b323933e7efb4e481bcfdc559cb13199d077e1b40abcb161561a293ca59cd98aae224cd0877555e6e7a2e11021bc55ebedf4 +0 -0
  124. package/~/.npm/_cacache/index-v5/6a/39/c03f62d7353a7cc1411e180ec37c393f9fedcfd081fa567f67bf32e6fb68 +2 -0
@@ -0,0 +1,421 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ exports.connect = exports.connectIfSessionExists = void 0;
30
+ const wallet_types_1 = require("@ksangkuk10/wallet-types");
31
+ const core_1 = __importDefault(require("@walletconnect/core"));
32
+ const cryptoLib = __importStar(require("@walletconnect/iso-crypto"));
33
+ const utils_1 = require("@walletconnect/utils");
34
+ const rxjs_1 = require("rxjs");
35
+ const browser_check_1 = require("../../utils/browser-check");
36
+ const errors_1 = require("./errors");
37
+ const socket_transport_1 = __importDefault(require("./impl/socket-transport"));
38
+ const modal_1 = require("./modal");
39
+ const types_1 = require("./types");
40
+ const WALLETCONNECT_STORAGE_KEY = 'walletconnect';
41
+ function connectIfSessionExists(options = {}) {
42
+ const storedSession = localStorage.getItem(WALLETCONNECT_STORAGE_KEY);
43
+ if (typeof storedSession === 'string') {
44
+ return connect(options, true);
45
+ }
46
+ return null;
47
+ }
48
+ exports.connectIfSessionExists = connectIfSessionExists;
49
+ function connect(options = {}, useCachedSession = false, walletApp) {
50
+ var _a, _b;
51
+ let connector = null;
52
+ let sessionSubject = new rxjs_1.BehaviorSubject({
53
+ status: types_1.WalletConnectSessionStatus.DISCONNECTED,
54
+ });
55
+ const qrcodeModal = (_b = (_a = options.connectorOpts) === null || _a === void 0 ? void 0 : _a.qrcodeModal) !== null && _b !== void 0 ? _b : new modal_1.XplaWalletconnectQrcodeModal(walletApp);
56
+ const connectorOpts = {
57
+ bridge: 'https://walletconnect.xpla.io/',
58
+ qrcodeModal,
59
+ ...options.connectorOpts,
60
+ };
61
+ const pushServerOpts = options.pushServerOpts;
62
+ // ---------------------------------------------
63
+ // event listeners
64
+ // ---------------------------------------------
65
+ function initEvents() {
66
+ if (!connector) {
67
+ throw new Error(`WalletConnect is not defined!`);
68
+ }
69
+ connector.on('session_update', async (error, payload) => {
70
+ if (error)
71
+ throw error;
72
+ sessionSubject.next({
73
+ status: types_1.WalletConnectSessionStatus.CONNECTED,
74
+ peerMeta: payload.params[0].peerMeta,
75
+ xplaAddress: payload.params[0].accounts[0],
76
+ chainId: payload.params[0].chainId,
77
+ });
78
+ console.log('WALLETCONNECT SESSION UPDATED:', payload.params[0]);
79
+ });
80
+ connector.on('connect', (error, payload) => {
81
+ if (error)
82
+ throw error;
83
+ sessionSubject.next({
84
+ status: types_1.WalletConnectSessionStatus.CONNECTED,
85
+ peerMeta: payload.params[0].peerMeta,
86
+ xplaAddress: payload.params[0].accounts[0],
87
+ chainId: payload.params[0].chainId,
88
+ });
89
+ });
90
+ connector.on('disconnect', (error, payload) => {
91
+ if (error)
92
+ throw error;
93
+ sessionSubject.next({
94
+ status: types_1.WalletConnectSessionStatus.DISCONNECTED,
95
+ });
96
+ });
97
+ }
98
+ // ---------------------------------------------
99
+ // initialize
100
+ // ---------------------------------------------
101
+ const cachedSession = localStorage.getItem('walletconnect');
102
+ if (typeof cachedSession === 'string' && useCachedSession) {
103
+ const cachedSessionObject = JSON.parse(cachedSession);
104
+ const clientId = cachedSessionObject.clientId;
105
+ const draftConnector = new core_1.default({
106
+ connectorOpts: {
107
+ ...connectorOpts,
108
+ session: JSON.parse(cachedSession),
109
+ },
110
+ pushServerOpts,
111
+ cryptoLib,
112
+ transport: new socket_transport_1.default({
113
+ protocol: 'wc',
114
+ version: 1,
115
+ url: connectorOpts.bridge,
116
+ subscriptions: [clientId],
117
+ }),
118
+ });
119
+ draftConnector.clientId = clientId;
120
+ connector = draftConnector;
121
+ initEvents();
122
+ sessionSubject.next({
123
+ status: types_1.WalletConnectSessionStatus.CONNECTED,
124
+ peerMeta: draftConnector.peerMeta,
125
+ xplaAddress: draftConnector.accounts[0],
126
+ chainId: draftConnector.chainId,
127
+ });
128
+ }
129
+ else {
130
+ const clientId = (0, utils_1.uuid)();
131
+ const draftConnector = new core_1.default({
132
+ connectorOpts,
133
+ pushServerOpts,
134
+ cryptoLib,
135
+ transport: new socket_transport_1.default({
136
+ protocol: 'wc',
137
+ version: 1,
138
+ url: connectorOpts.bridge,
139
+ subscriptions: [clientId],
140
+ }),
141
+ });
142
+ draftConnector.clientId = clientId;
143
+ connector = draftConnector;
144
+ if (!draftConnector.connected) {
145
+ draftConnector.createSession().catch(console.error);
146
+ if (qrcodeModal instanceof modal_1.XplaWalletconnectQrcodeModal) {
147
+ qrcodeModal.setCloseCallback(() => {
148
+ sessionSubject.next({
149
+ status: types_1.WalletConnectSessionStatus.DISCONNECTED,
150
+ });
151
+ });
152
+ }
153
+ initEvents();
154
+ sessionSubject.next({
155
+ status: types_1.WalletConnectSessionStatus.REQUESTED,
156
+ });
157
+ }
158
+ }
159
+ // ---------------------------------------------
160
+ // methods
161
+ // ---------------------------------------------
162
+ function disconnect() {
163
+ if (connector && connector.connected) {
164
+ try {
165
+ connector.killSession();
166
+ }
167
+ catch (_a) { }
168
+ }
169
+ sessionSubject.next({
170
+ status: types_1.WalletConnectSessionStatus.DISCONNECTED,
171
+ });
172
+ }
173
+ function session() {
174
+ return sessionSubject.asObservable();
175
+ }
176
+ function getLatestSession() {
177
+ return sessionSubject.getValue();
178
+ }
179
+ /**
180
+ * post transaction
181
+ *
182
+ * @param tx transaction data
183
+ * @param walletApp wallet type, default is XPLA Vault
184
+ * @throws { WalletConnectUserDenied }
185
+ * @throws { WalletConnectCreateTxFailed }
186
+ * @throws { WalletConnectTxFailed }
187
+ * @throws { WalletConnectTimeout }
188
+ * @throws { WalletConnectTxUnspecifiedError }
189
+ */
190
+ function post(tx, _walletApp) {
191
+ var _a, _b, _c;
192
+ if (!connector || !connector.connected) {
193
+ throw new Error(`WalletConnect is not connected!`);
194
+ }
195
+ const id = Date.now();
196
+ const serializedTxOptions = {
197
+ msgs: tx.msgs.map((msg) => msg.toJSON()),
198
+ fee: (_a = tx.fee) === null || _a === void 0 ? void 0 : _a.toJSON(),
199
+ memo: tx.memo,
200
+ gas: tx.gas,
201
+ gasPrices: (_b = tx.gasPrices) === null || _b === void 0 ? void 0 : _b.toString(),
202
+ gasAdjustment: (_c = tx.gasAdjustment) === null || _c === void 0 ? void 0 : _c.toString(),
203
+ //account_number: tx.account_number,
204
+ //sequence: tx.sequence,
205
+ feeDenoms: tx.feeDenoms,
206
+ timeoutHeight: tx.timeoutHeight,
207
+ };
208
+ if ((0, browser_check_1.isMobile)()) {
209
+ const payload = btoa(JSON.stringify({
210
+ id,
211
+ handshakeTopic: connector.handshakeTopic,
212
+ method: 'post',
213
+ params: serializedTxOptions,
214
+ }));
215
+ confirm(payload, walletApp);
216
+ }
217
+ return connector
218
+ .sendCustomRequest({
219
+ id,
220
+ method: 'post',
221
+ params: [serializedTxOptions],
222
+ })
223
+ .catch((error) => {
224
+ let throwError = error;
225
+ try {
226
+ const { code, txhash, message, raw_message } = JSON.parse(error.message);
227
+ switch (code) {
228
+ case 1:
229
+ throwError = new errors_1.WalletConnectUserDenied();
230
+ break;
231
+ case 2:
232
+ throwError = new errors_1.WalletConnectCreateTxFailed(message);
233
+ break;
234
+ case 3:
235
+ throwError = new errors_1.WalletConnectTxFailed(txhash, message, raw_message);
236
+ break;
237
+ case 4:
238
+ throwError = new errors_1.WalletConnectTimeout(message);
239
+ break;
240
+ case 99:
241
+ throwError = new errors_1.WalletConnectTxUnspecifiedError(message);
242
+ break;
243
+ }
244
+ }
245
+ catch (_a) {
246
+ throwError = new errors_1.WalletConnectTxUnspecifiedError(error.message);
247
+ }
248
+ throw throwError;
249
+ });
250
+ }
251
+ /**
252
+ * sign transaction
253
+ *
254
+ * @param bytes: Buffer
255
+ * @param walletApp wallet type, default is XPLA Vault
256
+ * @throws { WalletConnectUserDenied }
257
+ * @throws { WalletConnectTimeout }
258
+ * @throws { WalletConnectSignBytesUnspecifiedError }
259
+ */
260
+ function sign(tx, _walletApp) {
261
+ var _a, _b, _c;
262
+ if (!connector || !connector.connected) {
263
+ throw new Error(`WalletConnect is not connected!`);
264
+ }
265
+ const id = Date.now();
266
+ const serializedTxOptions = {
267
+ msgs: tx.msgs.map((msg) => msg.toJSON()),
268
+ fee: (_a = tx.fee) === null || _a === void 0 ? void 0 : _a.toJSON(),
269
+ memo: tx.memo,
270
+ gas: tx.gas,
271
+ gasPrices: (_b = tx.gasPrices) === null || _b === void 0 ? void 0 : _b.toString(),
272
+ gasAdjustment: (_c = tx.gasAdjustment) === null || _c === void 0 ? void 0 : _c.toString(),
273
+ //account_number: tx.account_number,
274
+ //sequence: tx.sequence,
275
+ feeDenoms: tx.feeDenoms,
276
+ timeoutHeight: tx.timeoutHeight,
277
+ sequence: tx.sequence,
278
+ accountNumber: tx.accountNumber,
279
+ signMode: tx.signMode
280
+ };
281
+ if ((0, browser_check_1.isMobile)()) {
282
+ const payload = btoa(JSON.stringify({
283
+ id,
284
+ handshakeTopic: connector.handshakeTopic,
285
+ method: 'sign',
286
+ params: serializedTxOptions,
287
+ }));
288
+ confirm(payload, _walletApp);
289
+ }
290
+ return connector
291
+ .sendCustomRequest({
292
+ id,
293
+ method: 'sign',
294
+ params: [serializedTxOptions],
295
+ })
296
+ .catch((error) => {
297
+ let throwError = error;
298
+ try {
299
+ const { code, txhash, message, raw_message } = JSON.parse(error.message);
300
+ switch (code) {
301
+ case 1:
302
+ throwError = new errors_1.WalletConnectUserDenied();
303
+ break;
304
+ case 2:
305
+ throwError = new errors_1.WalletConnectCreateTxFailed(message);
306
+ break;
307
+ case 3:
308
+ throwError = new errors_1.WalletConnectTxFailed(txhash, message, raw_message);
309
+ break;
310
+ case 4:
311
+ throwError = new errors_1.WalletConnectTimeout(message);
312
+ break;
313
+ case 99:
314
+ throwError = new errors_1.WalletConnectSignUnspecifiedError(message);
315
+ break;
316
+ }
317
+ }
318
+ catch (_a) {
319
+ throwError = new errors_1.WalletConnectSignUnspecifiedError(error.message);
320
+ }
321
+ throw throwError;
322
+ });
323
+ }
324
+ /**
325
+ * signBytes transaction
326
+ *
327
+ * @param bytes: Buffer
328
+ * @param bytes: WalletApp | boolean
329
+ * @throws { WalletConnectUserDenied }
330
+ * @throws { WalletConnectTimeout }
331
+ * @throws { WalletConnectSignBytesUnspecifiedError }
332
+ */
333
+ function signBytes(bytes, _walletApp) {
334
+ if (!connector || !connector.connected) {
335
+ throw new Error(`WalletConnect is not connected!`);
336
+ }
337
+ const id = Date.now();
338
+ if ((0, browser_check_1.isMobile)()) {
339
+ const payload = btoa(JSON.stringify({
340
+ id,
341
+ handshakeTopic: connector.handshakeTopic,
342
+ method: 'signBytes',
343
+ params: bytes,
344
+ }));
345
+ confirm(payload, _walletApp);
346
+ }
347
+ return connector
348
+ .sendCustomRequest({
349
+ id,
350
+ method: 'signBytes',
351
+ params: [bytes],
352
+ })
353
+ .catch((error) => {
354
+ let throwError = error;
355
+ try {
356
+ const { code, message } = JSON.parse(error.message);
357
+ switch (code) {
358
+ case 1:
359
+ throwError = new errors_1.WalletConnectUserDenied();
360
+ break;
361
+ case 4:
362
+ throwError = new errors_1.WalletConnectTimeout(message);
363
+ break;
364
+ case 99:
365
+ throwError = new errors_1.WalletConnectSignBytesUnspecifiedError(message);
366
+ break;
367
+ }
368
+ }
369
+ catch (_a) {
370
+ throwError = new errors_1.WalletConnectSignBytesUnspecifiedError(error.message);
371
+ }
372
+ throw throwError;
373
+ });
374
+ }
375
+ /**
376
+ * mobile confirm
377
+ *
378
+ * @param payload paylaod
379
+ * @param _walletApp wallet type, default is XPLA Vault
380
+ */
381
+ function confirm(payload, _walletApp) {
382
+ if (!_walletApp || typeof _walletApp === 'boolean') {
383
+ if (_walletApp) {
384
+ window.location.href = `c2xvault://walletconnect_confirm/?payload=${payload}`;
385
+ }
386
+ else {
387
+ window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;
388
+ }
389
+ }
390
+ else {
391
+ if (_walletApp === wallet_types_1.WalletApp.XPLA_VAULT) {
392
+ window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;
393
+ }
394
+ else if (_walletApp === wallet_types_1.WalletApp.XPLA_GAMES) {
395
+ window.location.href = `c2xvault://walletconnect_confirm/?payload=${payload}`;
396
+ }
397
+ else if (_walletApp === wallet_types_1.WalletApp.XPLA_GAMES_NEW) {
398
+ window.location.href = `xgameswallet://walletconnect_confirm/?payload=${payload}`;
399
+ }
400
+ else if (_walletApp === wallet_types_1.WalletApp.XPLAYZ) {
401
+ window.location.href = `xplayz://walletconnect_confirm/?payload=${payload}`;
402
+ }
403
+ else {
404
+ window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;
405
+ }
406
+ }
407
+ }
408
+ // ---------------------------------------------
409
+ // return
410
+ // ---------------------------------------------
411
+ return {
412
+ session,
413
+ getLatestSession,
414
+ post,
415
+ sign,
416
+ signBytes,
417
+ disconnect,
418
+ };
419
+ }
420
+ exports.connect = connect;
421
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connect.js","sourceRoot":"","sources":["../../../../../../src/@ksangkuk10/wallet-controller/modules/walletconnect/connect.ts"],"names":[],"mappings":"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","sourcesContent":["import { CreateTxOptions, SignMode } from '@xpla/xpla.js';\nimport { WalletApp } from '@ksangkuk10/wallet-types';\nimport Connector from '@walletconnect/core';\nimport * as cryptoLib from '@walletconnect/iso-crypto';\nimport {\n  IPushServerOptions,\n  IWalletConnectOptions,\n} from '@walletconnect/types';\nimport { uuid } from '@walletconnect/utils';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { isMobile } from '../../utils/browser-check';\nimport {\n  WalletConnectCreateTxFailed,\n  WalletConnectTimeout,\n  WalletConnectTxFailed,\n  WalletConnectTxUnspecifiedError,\n  WalletConnectUserDenied,\n  WalletConnectSignUnspecifiedError,\n  WalletConnectSignBytesUnspecifiedError\n} from './errors';\nimport SocketTransport from './impl/socket-transport';\nimport { XplaWalletconnectQrcodeModal } from './modal';\nimport {\n  WalletConnectSession,\n  WalletConnectSessionStatus,\n  WalletConnectTxResult,\n} from './types';\nimport {\n  WebExtensionSignPayload,\n  WebExtensionSignBytesPayload,\n} from '@ksangkuk10/web-extension-interface';\n\nexport interface WalletConnectControllerOptions {\n  /**\n   * Configuration parameter that `new WalletConnect(connectorOpts)`\n   *\n   * @default\n   * ```js\n   * {\n   *   bridge: 'https://walletconnect.xpla.io/',\n   *   qrcodeModal: new XplaWalletconnectQrcodeModal(),\n   * }\n   * ```\n   */\n  connectorOpts?: IWalletConnectOptions;\n\n  /**\n   * Configuration parameter that `new WalletConnect(_, pushServerOpts)`\n   *\n   * @default undefined\n   */\n  pushServerOpts?: IPushServerOptions;\n}\n\nexport interface WalletConnectController {\n  session: () => Observable<WalletConnectSession>;\n  getLatestSession: () => WalletConnectSession;\n  post: (tx: CreateTxOptions, _walletApp?: WalletApp | boolean) => Promise<WalletConnectTxResult>;\n  sign: (\n    tx: CreateTxOptions & {\n      sequence?: number;\n      accountNumber?: number;\n      signMode?: SignMode;\n    }, \n    _walletApp?: WalletApp | boolean\n  ) => Promise<WebExtensionSignPayload>;\n  signBytes: (bytes: Buffer, _walletApp?: WalletApp | boolean) => Promise<WebExtensionSignBytesPayload>;\n  disconnect: () => void;\n}\n\nconst WALLETCONNECT_STORAGE_KEY = 'walletconnect';\n\nexport function connectIfSessionExists(\n  options: WalletConnectControllerOptions = {},\n): WalletConnectController | null {\n  const storedSession = localStorage.getItem(WALLETCONNECT_STORAGE_KEY);\n\n  if (typeof storedSession === 'string') {\n    return connect(options, true);\n  }\n\n  return null;\n}\n\nexport function connect(\n  options: WalletConnectControllerOptions = {},\n  useCachedSession: boolean = false,\n  walletApp?: WalletApp | boolean\n): WalletConnectController {\n  let connector: Connector | null = null;\n\n  let sessionSubject: BehaviorSubject<WalletConnectSession> =\n    new BehaviorSubject<WalletConnectSession>({\n      status: WalletConnectSessionStatus.DISCONNECTED,\n    });\n\n  const qrcodeModal =\n    options.connectorOpts?.qrcodeModal ?? new XplaWalletconnectQrcodeModal(walletApp);\n\n  const connectorOpts: IWalletConnectOptions = {\n    bridge: 'https://walletconnect.xpla.io/',\n    qrcodeModal,\n    ...options.connectorOpts,\n  };\n\n  const pushServerOpts: IPushServerOptions | undefined = options.pushServerOpts;\n\n  // ---------------------------------------------\n  // event listeners\n  // ---------------------------------------------\n  function initEvents() {\n    if (!connector) {\n      throw new Error(`WalletConnect is not defined!`);\n    }\n\n    connector.on('session_update', async (error, payload) => {\n      if (error) throw error;\n\n      sessionSubject.next({\n        status: WalletConnectSessionStatus.CONNECTED,\n        peerMeta: payload.params[0].peerMeta,\n        xplaAddress: payload.params[0].accounts[0],\n        chainId: payload.params[0].chainId,\n      });\n\n      console.log('WALLETCONNECT SESSION UPDATED:', payload.params[0]);\n    });\n\n    connector.on('connect', (error, payload) => {\n      if (error) throw error;\n\n      sessionSubject.next({\n        status: WalletConnectSessionStatus.CONNECTED,\n        peerMeta: payload.params[0].peerMeta,\n        xplaAddress: payload.params[0].accounts[0],\n        chainId: payload.params[0].chainId,\n      });\n    });\n\n    connector.on('disconnect', (error, payload) => {\n      if (error) throw error;\n\n      sessionSubject.next({\n        status: WalletConnectSessionStatus.DISCONNECTED,\n      });\n    });\n  }\n\n  // ---------------------------------------------\n  // initialize\n  // ---------------------------------------------\n  const cachedSession = localStorage.getItem('walletconnect');\n\n  if (typeof cachedSession === 'string' && useCachedSession) {\n    const cachedSessionObject = JSON.parse(cachedSession);\n    const clientId = cachedSessionObject.clientId;\n    const draftConnector = new Connector({\n      connectorOpts: {\n        ...connectorOpts,\n        session: JSON.parse(cachedSession),\n      },\n      pushServerOpts,\n      cryptoLib,\n      transport: new SocketTransport({\n        protocol: 'wc',\n        version: 1,\n        url: connectorOpts.bridge!,\n        subscriptions: [clientId],\n      }),\n    });\n    draftConnector.clientId = clientId;\n\n    connector = draftConnector;\n\n    initEvents();\n\n    sessionSubject.next({\n      status: WalletConnectSessionStatus.CONNECTED,\n      peerMeta: draftConnector.peerMeta!,\n      xplaAddress: draftConnector.accounts[0],\n      chainId: draftConnector.chainId,\n    });\n  } else {\n    const clientId = uuid();\n    const draftConnector = new Connector({\n      connectorOpts,\n      pushServerOpts,\n      cryptoLib,\n      transport: new SocketTransport({\n        protocol: 'wc',\n        version: 1,\n        url: connectorOpts.bridge!,\n        subscriptions: [clientId],\n      }),\n    });\n    draftConnector.clientId = clientId;\n\n    connector = draftConnector;\n\n    if (!draftConnector.connected) {\n      draftConnector.createSession().catch(console.error);\n\n      if (qrcodeModal instanceof XplaWalletconnectQrcodeModal) {\n        qrcodeModal.setCloseCallback(() => {\n          sessionSubject.next({\n            status: WalletConnectSessionStatus.DISCONNECTED,\n          });\n        });\n      }\n\n      initEvents();\n\n      sessionSubject.next({\n        status: WalletConnectSessionStatus.REQUESTED,\n      });\n    }\n  }\n\n  // ---------------------------------------------\n  // methods\n  // ---------------------------------------------\n  function disconnect() {\n    if (connector && connector.connected) {\n      try {\n        connector.killSession();\n      } catch {}\n    }\n\n    sessionSubject.next({\n      status: WalletConnectSessionStatus.DISCONNECTED,\n    });\n  }\n\n  function session(): Observable<WalletConnectSession> {\n    return sessionSubject.asObservable();\n  }\n\n  function getLatestSession(): WalletConnectSession {\n    return sessionSubject.getValue();\n  }\n\n  /**\n   * post transaction\n   *\n   * @param tx transaction data\n   * @param walletApp wallet type, default is XPLA Vault\n   * @throws { WalletConnectUserDenied }\n   * @throws { WalletConnectCreateTxFailed }\n   * @throws { WalletConnectTxFailed }\n   * @throws { WalletConnectTimeout }\n   * @throws { WalletConnectTxUnspecifiedError }\n   */\n  function post(tx: CreateTxOptions, _walletApp?: WalletApp | boolean): Promise<WalletConnectTxResult> {\n    if (!connector || !connector.connected) {\n      throw new Error(`WalletConnect is not connected!`);\n    }\n\n    const id = Date.now();\n\n    const serializedTxOptions = {\n      msgs: tx.msgs.map((msg) => msg.toJSON()),\n      fee: tx.fee?.toJSON(),\n      memo: tx.memo,\n      gas: tx.gas,\n      gasPrices: tx.gasPrices?.toString(),\n      gasAdjustment: tx.gasAdjustment?.toString(),\n      //account_number: tx.account_number,\n      //sequence: tx.sequence,\n      feeDenoms: tx.feeDenoms,\n      timeoutHeight: tx.timeoutHeight,\n    };\n\n    if (isMobile()) {\n      const payload = btoa(\n        JSON.stringify({\n          id,\n          handshakeTopic: connector.handshakeTopic,\n          method: 'post',\n          params: serializedTxOptions,\n        }),\n      );\n\n      confirm(payload, walletApp);\n    }\n\n    return connector\n      .sendCustomRequest({\n        id,\n        method: 'post',\n        params: [serializedTxOptions],\n      })\n      .catch((error) => {\n        let throwError = error;\n\n        try {\n          const { code, txhash, message, raw_message } = JSON.parse(\n            error.message,\n          );\n          switch (code) {\n            case 1:\n              throwError = new WalletConnectUserDenied();\n              break;\n            case 2:\n              throwError = new WalletConnectCreateTxFailed(message);\n              break;\n            case 3:\n              throwError = new WalletConnectTxFailed(\n                txhash,\n                message,\n                raw_message,\n              );\n              break;\n            case 4:\n              throwError = new WalletConnectTimeout(message);\n              break;\n            case 99:\n              throwError = new WalletConnectTxUnspecifiedError(message);\n              break;\n          }\n        } catch {\n          throwError = new WalletConnectTxUnspecifiedError(error.message);\n        }\n\n        throw throwError;\n      });\n  }\n\n  /**\n   * sign transaction\n   *\n   * @param bytes: Buffer\n   * @param walletApp wallet type, default is XPLA Vault\n   * @throws { WalletConnectUserDenied }\n   * @throws { WalletConnectTimeout }\n   * @throws { WalletConnectSignBytesUnspecifiedError }\n   */\n  function sign(\n    tx: CreateTxOptions  & {\n      sequence?: number;\n      accountNumber?: number;\n      signMode?: SignMode;\n    }, \n    _walletApp?: WalletApp | boolean\n  ): Promise<WebExtensionSignPayload> {\n    if (!connector || !connector.connected) {\n      throw new Error(`WalletConnect is not connected!`);\n    }\n\n    const id = Date.now();\n\n    const serializedTxOptions = {\n      msgs: tx.msgs.map((msg) => msg.toJSON()),\n      fee: tx.fee?.toJSON(),\n      memo: tx.memo,\n      gas: tx.gas,\n      gasPrices: tx.gasPrices?.toString(),\n      gasAdjustment: tx.gasAdjustment?.toString(),\n      //account_number: tx.account_number,\n      //sequence: tx.sequence,\n      feeDenoms: tx.feeDenoms,\n      timeoutHeight: tx.timeoutHeight,\n      sequence: tx.sequence,\n      accountNumber: tx.accountNumber,\n      signMode: tx.signMode\n    };\n\n    if (isMobile()) {\n      const payload = btoa(\n        JSON.stringify({\n          id,\n          handshakeTopic: connector.handshakeTopic,\n          method: 'sign',\n          params: serializedTxOptions,\n        }),\n      );\n      confirm(payload, _walletApp);\n    }\n\n    return connector\n      .sendCustomRequest({\n        id,\n        method: 'sign',\n        params: [serializedTxOptions],\n      })\n      .catch((error) => {\n        let throwError = error;\n\n        try {\n          const { code, txhash, message, raw_message } = JSON.parse(\n            error.message,\n          );\n          switch (code) {\n            case 1:\n              throwError = new WalletConnectUserDenied();\n              break;\n            case 2:\n              throwError = new WalletConnectCreateTxFailed(message);\n              break;\n            case 3:\n              throwError = new WalletConnectTxFailed(\n                txhash,\n                message,\n                raw_message,\n              );\n              break;\n            case 4:\n              throwError = new WalletConnectTimeout(message);\n              break;\n            case 99:\n              throwError = new WalletConnectSignUnspecifiedError(message);\n              break;\n          }\n        } catch {\n          throwError = new WalletConnectSignUnspecifiedError(error.message);\n        }\n\n        throw throwError;\n      });\n  }\n\n  /**\n   * signBytes transaction\n   *\n   * @param bytes: Buffer\n   * @param bytes: WalletApp | boolean\n   * @throws { WalletConnectUserDenied }\n   * @throws { WalletConnectTimeout }\n   * @throws { WalletConnectSignBytesUnspecifiedError }\n   */\n  function signBytes(bytes: Buffer, _walletApp?: WalletApp | boolean): Promise<WebExtensionSignBytesPayload> {\n    if (!connector || !connector.connected) {\n      throw new Error(`WalletConnect is not connected!`);\n    }\n\n    const id = Date.now();\n\n    if (isMobile()) {\n      const payload = btoa(\n        JSON.stringify({\n          id,\n          handshakeTopic: connector.handshakeTopic,\n          method: 'signBytes',\n          params: bytes,\n        }),\n      );\n\n      confirm(payload, _walletApp);\n    }\n\n    return connector\n      .sendCustomRequest({\n        id,\n        method: 'signBytes',\n        params: [bytes],\n      })\n      .catch((error) => {\n        let throwError = error;\n\n        try {\n          const { code, message } = JSON.parse(\n            error.message,\n          );\n\n          switch (code) {\n            case 1:\n              throwError = new WalletConnectUserDenied();\n              break;\n            case 4:\n              throwError = new WalletConnectTimeout(message);\n              break;\n            case 99:\n              throwError = new WalletConnectSignBytesUnspecifiedError(message);\n              break;\n          }\n        } catch {\n          throwError = new WalletConnectSignBytesUnspecifiedError(error.message);\n        }\n\n        throw throwError;\n      });\n  }\n\n  /**\n   * mobile confirm\n   * \n   * @param payload paylaod\n   * @param _walletApp wallet type, default is XPLA Vault\n   */\n  function confirm(payload: string, _walletApp?: WalletApp | boolean) {\n    if (!_walletApp || typeof _walletApp === 'boolean') {\n      if (_walletApp) {\n        window.location.href = `c2xvault://walletconnect_confirm/?payload=${payload}`;  \n      } else {\n        window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;\n      }\n    } else {\n      if (_walletApp === WalletApp.XPLA_VAULT) {\n        window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;\n      } else if (_walletApp === WalletApp.XPLA_GAMES) {\n        window.location.href = `c2xvault://walletconnect_confirm/?payload=${payload}`;  \n      } else if (_walletApp === WalletApp.XPLA_GAMES_NEW) {\n        window.location.href = `xgameswallet://walletconnect_confirm/?payload=${payload}`;\n      } else if (_walletApp === WalletApp.XPLAYZ) {\n        window.location.href = `xplayz://walletconnect_confirm/?payload=${payload}`;  \n      } else {\n        window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;\n      }\n    }\n  }\n\n  // ---------------------------------------------\n  // return\n  // ---------------------------------------------\n  return {\n    session,\n    getLatestSession,\n    post,\n    sign,\n    signBytes,\n    disconnect,\n  };\n}\n"]}
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WalletConnectSignBytesUnspecifiedError = exports.WalletConnectSignUnspecifiedError = exports.WalletConnectTxUnspecifiedError = exports.WalletConnectTimeout = exports.WalletConnectTxFailed = exports.WalletConnectCreateTxFailed = exports.WalletConnectUserDenied = void 0;
4
+ class WalletConnectUserDenied extends Error {
5
+ }
6
+ exports.WalletConnectUserDenied = WalletConnectUserDenied;
7
+ class WalletConnectCreateTxFailed extends Error {
8
+ constructor(message) {
9
+ super(message);
10
+ this.name = 'WalletConnectCreateTxFailed';
11
+ }
12
+ }
13
+ exports.WalletConnectCreateTxFailed = WalletConnectCreateTxFailed;
14
+ class WalletConnectTxFailed extends Error {
15
+ constructor(txhash, message, raw_message) {
16
+ super(message);
17
+ this.txhash = txhash;
18
+ this.raw_message = raw_message;
19
+ this.name = 'WalletConnectTxFailed';
20
+ }
21
+ }
22
+ exports.WalletConnectTxFailed = WalletConnectTxFailed;
23
+ class WalletConnectTimeout extends Error {
24
+ constructor(message) {
25
+ super(message);
26
+ this.name = 'WalletConnectTimeout';
27
+ }
28
+ }
29
+ exports.WalletConnectTimeout = WalletConnectTimeout;
30
+ class WalletConnectTxUnspecifiedError extends Error {
31
+ constructor(message) {
32
+ super(message);
33
+ this.name = 'WalletConnectTxUnspecifiedError';
34
+ }
35
+ }
36
+ exports.WalletConnectTxUnspecifiedError = WalletConnectTxUnspecifiedError;
37
+ class WalletConnectSignUnspecifiedError extends Error {
38
+ constructor(message) {
39
+ super(message);
40
+ this.name = 'WalletConnectSignUnspecifiedError';
41
+ }
42
+ }
43
+ exports.WalletConnectSignUnspecifiedError = WalletConnectSignUnspecifiedError;
44
+ class WalletConnectSignBytesUnspecifiedError extends Error {
45
+ constructor(message) {
46
+ super(message);
47
+ this.name = 'WalletConnectSignBytesUnspecifiedError';
48
+ }
49
+ }
50
+ exports.WalletConnectSignBytesUnspecifiedError = WalletConnectSignBytesUnspecifiedError;
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL0Brc2FuZ2t1azEwL3dhbGxldC1jb250cm9sbGVyL21vZHVsZXMvd2FsbGV0Y29ubmVjdC9lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsTUFBYSx1QkFBd0IsU0FBUSxLQUFLO0NBQUc7QUFBckQsMERBQXFEO0FBRXJELE1BQWEsMkJBQTRCLFNBQVEsS0FBSztJQUNwRCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyw2QkFBNkIsQ0FBQztJQUM1QyxDQUFDO0NBQ0Y7QUFMRCxrRUFLQztBQUVELE1BQWEscUJBQXNCLFNBQVEsS0FBSztJQUM5QyxZQUNrQixNQUFjLEVBQzlCLE9BQWUsRUFDQyxXQUFnQjtRQUVoQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFKQyxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBRWQsZ0JBQVcsR0FBWCxXQUFXLENBQUs7UUFHaEMsSUFBSSxDQUFDLElBQUksR0FBRyx1QkFBdUIsQ0FBQztJQUN0QyxDQUFDO0NBQ0Y7QUFURCxzREFTQztBQUVELE1BQWEsb0JBQXFCLFNBQVEsS0FBSztJQUM3QyxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxzQkFBc0IsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFMRCxvREFLQztBQUVELE1BQWEsK0JBQWdDLFNBQVEsS0FBSztJQUN4RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxpQ0FBaUMsQ0FBQztJQUNoRCxDQUFDO0NBQ0Y7QUFMRCwwRUFLQztBQUVELE1BQWEsaUNBQWtDLFNBQVEsS0FBSztJQUMxRCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxtQ0FBbUMsQ0FBQztJQUNsRCxDQUFDO0NBQ0Y7QUFMRCw4RUFLQztBQUVELE1BQWEsc0NBQXVDLFNBQVEsS0FBSztJQUMvRCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyx3Q0FBd0MsQ0FBQztJQUN2RCxDQUFDO0NBQ0Y7QUFMRCx3RkFLQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBXYWxsZXRDb25uZWN0VXNlckRlbmllZCBleHRlbmRzIEVycm9yIHt9XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRDb25uZWN0Q3JlYXRlVHhGYWlsZWQgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXYWxsZXRDb25uZWN0Q3JlYXRlVHhGYWlsZWQnO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRDb25uZWN0VHhGYWlsZWQgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSB0eGhhc2g6IHN0cmluZyxcbiAgICBtZXNzYWdlOiBzdHJpbmcsXG4gICAgcHVibGljIHJlYWRvbmx5IHJhd19tZXNzYWdlOiBhbnksXG4gICkge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXYWxsZXRDb25uZWN0VHhGYWlsZWQnO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRDb25uZWN0VGltZW91dCBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gJ1dhbGxldENvbm5lY3RUaW1lb3V0JztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdFR4VW5zcGVjaWZpZWRFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gJ1dhbGxldENvbm5lY3RUeFVuc3BlY2lmaWVkRXJyb3InO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRDb25uZWN0U2lnblVuc3BlY2lmaWVkRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXYWxsZXRDb25uZWN0U2lnblVuc3BlY2lmaWVkRXJyb3InO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBXYWxsZXRDb25uZWN0U2lnbkJ5dGVzVW5zcGVjaWZpZWRFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZTogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gJ1dhbGxldENvbm5lY3RTaWduQnl0ZXNVbnNwZWNpZmllZEVycm9yJztcbiAgfVxufSJdfQ==