@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,390 @@
1
+ import { WalletApp } from '@ksangkuk10/wallet-types';
2
+ import Connector from '@walletconnect/core';
3
+ import * as cryptoLib from '@walletconnect/iso-crypto';
4
+ import { uuid } from '@walletconnect/utils';
5
+ import { BehaviorSubject } from 'rxjs';
6
+ import { isMobile } from '../../utils/browser-check';
7
+ import { WalletConnectCreateTxFailed, WalletConnectTimeout, WalletConnectTxFailed, WalletConnectTxUnspecifiedError, WalletConnectUserDenied, WalletConnectSignUnspecifiedError, WalletConnectSignBytesUnspecifiedError } from './errors';
8
+ import SocketTransport from './impl/socket-transport';
9
+ import { XplaWalletconnectQrcodeModal } from './modal';
10
+ import { WalletConnectSessionStatus, } from './types';
11
+ const WALLETCONNECT_STORAGE_KEY = 'walletconnect';
12
+ export function connectIfSessionExists(options = {}) {
13
+ const storedSession = localStorage.getItem(WALLETCONNECT_STORAGE_KEY);
14
+ if (typeof storedSession === 'string') {
15
+ return connect(options, true);
16
+ }
17
+ return null;
18
+ }
19
+ export function connect(options = {}, useCachedSession = false, walletApp) {
20
+ var _a, _b;
21
+ let connector = null;
22
+ let sessionSubject = new BehaviorSubject({
23
+ status: WalletConnectSessionStatus.DISCONNECTED,
24
+ });
25
+ const qrcodeModal = (_b = (_a = options.connectorOpts) === null || _a === void 0 ? void 0 : _a.qrcodeModal) !== null && _b !== void 0 ? _b : new XplaWalletconnectQrcodeModal(walletApp);
26
+ const connectorOpts = {
27
+ bridge: 'https://walletconnect.xpla.io/',
28
+ qrcodeModal,
29
+ ...options.connectorOpts,
30
+ };
31
+ const pushServerOpts = options.pushServerOpts;
32
+ // ---------------------------------------------
33
+ // event listeners
34
+ // ---------------------------------------------
35
+ function initEvents() {
36
+ if (!connector) {
37
+ throw new Error(`WalletConnect is not defined!`);
38
+ }
39
+ connector.on('session_update', async (error, payload) => {
40
+ if (error)
41
+ throw error;
42
+ sessionSubject.next({
43
+ status: WalletConnectSessionStatus.CONNECTED,
44
+ peerMeta: payload.params[0].peerMeta,
45
+ xplaAddress: payload.params[0].accounts[0],
46
+ chainId: payload.params[0].chainId,
47
+ });
48
+ console.log('WALLETCONNECT SESSION UPDATED:', payload.params[0]);
49
+ });
50
+ connector.on('connect', (error, payload) => {
51
+ if (error)
52
+ throw error;
53
+ sessionSubject.next({
54
+ status: WalletConnectSessionStatus.CONNECTED,
55
+ peerMeta: payload.params[0].peerMeta,
56
+ xplaAddress: payload.params[0].accounts[0],
57
+ chainId: payload.params[0].chainId,
58
+ });
59
+ });
60
+ connector.on('disconnect', (error, payload) => {
61
+ if (error)
62
+ throw error;
63
+ sessionSubject.next({
64
+ status: WalletConnectSessionStatus.DISCONNECTED,
65
+ });
66
+ });
67
+ }
68
+ // ---------------------------------------------
69
+ // initialize
70
+ // ---------------------------------------------
71
+ const cachedSession = localStorage.getItem('walletconnect');
72
+ if (typeof cachedSession === 'string' && useCachedSession) {
73
+ const cachedSessionObject = JSON.parse(cachedSession);
74
+ const clientId = cachedSessionObject.clientId;
75
+ const draftConnector = new Connector({
76
+ connectorOpts: {
77
+ ...connectorOpts,
78
+ session: JSON.parse(cachedSession),
79
+ },
80
+ pushServerOpts,
81
+ cryptoLib,
82
+ transport: new SocketTransport({
83
+ protocol: 'wc',
84
+ version: 1,
85
+ url: connectorOpts.bridge,
86
+ subscriptions: [clientId],
87
+ }),
88
+ });
89
+ draftConnector.clientId = clientId;
90
+ connector = draftConnector;
91
+ initEvents();
92
+ sessionSubject.next({
93
+ status: WalletConnectSessionStatus.CONNECTED,
94
+ peerMeta: draftConnector.peerMeta,
95
+ xplaAddress: draftConnector.accounts[0],
96
+ chainId: draftConnector.chainId,
97
+ });
98
+ }
99
+ else {
100
+ const clientId = uuid();
101
+ const draftConnector = new Connector({
102
+ connectorOpts,
103
+ pushServerOpts,
104
+ cryptoLib,
105
+ transport: new SocketTransport({
106
+ protocol: 'wc',
107
+ version: 1,
108
+ url: connectorOpts.bridge,
109
+ subscriptions: [clientId],
110
+ }),
111
+ });
112
+ draftConnector.clientId = clientId;
113
+ connector = draftConnector;
114
+ if (!draftConnector.connected) {
115
+ draftConnector.createSession().catch(console.error);
116
+ if (qrcodeModal instanceof XplaWalletconnectQrcodeModal) {
117
+ qrcodeModal.setCloseCallback(() => {
118
+ sessionSubject.next({
119
+ status: WalletConnectSessionStatus.DISCONNECTED,
120
+ });
121
+ });
122
+ }
123
+ initEvents();
124
+ sessionSubject.next({
125
+ status: WalletConnectSessionStatus.REQUESTED,
126
+ });
127
+ }
128
+ }
129
+ // ---------------------------------------------
130
+ // methods
131
+ // ---------------------------------------------
132
+ function disconnect() {
133
+ if (connector && connector.connected) {
134
+ try {
135
+ connector.killSession();
136
+ }
137
+ catch (_a) { }
138
+ }
139
+ sessionSubject.next({
140
+ status: WalletConnectSessionStatus.DISCONNECTED,
141
+ });
142
+ }
143
+ function session() {
144
+ return sessionSubject.asObservable();
145
+ }
146
+ function getLatestSession() {
147
+ return sessionSubject.getValue();
148
+ }
149
+ /**
150
+ * post transaction
151
+ *
152
+ * @param tx transaction data
153
+ * @param walletApp wallet type, default is XPLA Vault
154
+ * @throws { WalletConnectUserDenied }
155
+ * @throws { WalletConnectCreateTxFailed }
156
+ * @throws { WalletConnectTxFailed }
157
+ * @throws { WalletConnectTimeout }
158
+ * @throws { WalletConnectTxUnspecifiedError }
159
+ */
160
+ function post(tx, _walletApp) {
161
+ var _a, _b, _c;
162
+ if (!connector || !connector.connected) {
163
+ throw new Error(`WalletConnect is not connected!`);
164
+ }
165
+ const id = Date.now();
166
+ const serializedTxOptions = {
167
+ msgs: tx.msgs.map((msg) => msg.toJSON()),
168
+ fee: (_a = tx.fee) === null || _a === void 0 ? void 0 : _a.toJSON(),
169
+ memo: tx.memo,
170
+ gas: tx.gas,
171
+ gasPrices: (_b = tx.gasPrices) === null || _b === void 0 ? void 0 : _b.toString(),
172
+ gasAdjustment: (_c = tx.gasAdjustment) === null || _c === void 0 ? void 0 : _c.toString(),
173
+ //account_number: tx.account_number,
174
+ //sequence: tx.sequence,
175
+ feeDenoms: tx.feeDenoms,
176
+ timeoutHeight: tx.timeoutHeight,
177
+ };
178
+ if (isMobile()) {
179
+ const payload = btoa(JSON.stringify({
180
+ id,
181
+ handshakeTopic: connector.handshakeTopic,
182
+ method: 'post',
183
+ params: serializedTxOptions,
184
+ }));
185
+ confirm(payload, walletApp);
186
+ }
187
+ return connector
188
+ .sendCustomRequest({
189
+ id,
190
+ method: 'post',
191
+ params: [serializedTxOptions],
192
+ })
193
+ .catch((error) => {
194
+ let throwError = error;
195
+ try {
196
+ const { code, txhash, message, raw_message } = JSON.parse(error.message);
197
+ switch (code) {
198
+ case 1:
199
+ throwError = new WalletConnectUserDenied();
200
+ break;
201
+ case 2:
202
+ throwError = new WalletConnectCreateTxFailed(message);
203
+ break;
204
+ case 3:
205
+ throwError = new WalletConnectTxFailed(txhash, message, raw_message);
206
+ break;
207
+ case 4:
208
+ throwError = new WalletConnectTimeout(message);
209
+ break;
210
+ case 99:
211
+ throwError = new WalletConnectTxUnspecifiedError(message);
212
+ break;
213
+ }
214
+ }
215
+ catch (_a) {
216
+ throwError = new WalletConnectTxUnspecifiedError(error.message);
217
+ }
218
+ throw throwError;
219
+ });
220
+ }
221
+ /**
222
+ * sign transaction
223
+ *
224
+ * @param bytes: Buffer
225
+ * @param walletApp wallet type, default is XPLA Vault
226
+ * @throws { WalletConnectUserDenied }
227
+ * @throws { WalletConnectTimeout }
228
+ * @throws { WalletConnectSignBytesUnspecifiedError }
229
+ */
230
+ function sign(tx, _walletApp) {
231
+ var _a, _b, _c;
232
+ if (!connector || !connector.connected) {
233
+ throw new Error(`WalletConnect is not connected!`);
234
+ }
235
+ const id = Date.now();
236
+ const serializedTxOptions = {
237
+ msgs: tx.msgs.map((msg) => msg.toJSON()),
238
+ fee: (_a = tx.fee) === null || _a === void 0 ? void 0 : _a.toJSON(),
239
+ memo: tx.memo,
240
+ gas: tx.gas,
241
+ gasPrices: (_b = tx.gasPrices) === null || _b === void 0 ? void 0 : _b.toString(),
242
+ gasAdjustment: (_c = tx.gasAdjustment) === null || _c === void 0 ? void 0 : _c.toString(),
243
+ //account_number: tx.account_number,
244
+ //sequence: tx.sequence,
245
+ feeDenoms: tx.feeDenoms,
246
+ timeoutHeight: tx.timeoutHeight,
247
+ sequence: tx.sequence,
248
+ accountNumber: tx.accountNumber,
249
+ signMode: tx.signMode
250
+ };
251
+ if (isMobile()) {
252
+ const payload = btoa(JSON.stringify({
253
+ id,
254
+ handshakeTopic: connector.handshakeTopic,
255
+ method: 'sign',
256
+ params: serializedTxOptions,
257
+ }));
258
+ confirm(payload, _walletApp);
259
+ }
260
+ return connector
261
+ .sendCustomRequest({
262
+ id,
263
+ method: 'sign',
264
+ params: [serializedTxOptions],
265
+ })
266
+ .catch((error) => {
267
+ let throwError = error;
268
+ try {
269
+ const { code, txhash, message, raw_message } = JSON.parse(error.message);
270
+ switch (code) {
271
+ case 1:
272
+ throwError = new WalletConnectUserDenied();
273
+ break;
274
+ case 2:
275
+ throwError = new WalletConnectCreateTxFailed(message);
276
+ break;
277
+ case 3:
278
+ throwError = new WalletConnectTxFailed(txhash, message, raw_message);
279
+ break;
280
+ case 4:
281
+ throwError = new WalletConnectTimeout(message);
282
+ break;
283
+ case 99:
284
+ throwError = new WalletConnectSignUnspecifiedError(message);
285
+ break;
286
+ }
287
+ }
288
+ catch (_a) {
289
+ throwError = new WalletConnectSignUnspecifiedError(error.message);
290
+ }
291
+ throw throwError;
292
+ });
293
+ }
294
+ /**
295
+ * signBytes transaction
296
+ *
297
+ * @param bytes: Buffer
298
+ * @param bytes: WalletApp | boolean
299
+ * @throws { WalletConnectUserDenied }
300
+ * @throws { WalletConnectTimeout }
301
+ * @throws { WalletConnectSignBytesUnspecifiedError }
302
+ */
303
+ function signBytes(bytes, _walletApp) {
304
+ if (!connector || !connector.connected) {
305
+ throw new Error(`WalletConnect is not connected!`);
306
+ }
307
+ const id = Date.now();
308
+ if (isMobile()) {
309
+ const payload = btoa(JSON.stringify({
310
+ id,
311
+ handshakeTopic: connector.handshakeTopic,
312
+ method: 'signBytes',
313
+ params: bytes,
314
+ }));
315
+ confirm(payload, _walletApp);
316
+ }
317
+ return connector
318
+ .sendCustomRequest({
319
+ id,
320
+ method: 'signBytes',
321
+ params: [bytes],
322
+ })
323
+ .catch((error) => {
324
+ let throwError = error;
325
+ try {
326
+ const { code, message } = JSON.parse(error.message);
327
+ switch (code) {
328
+ case 1:
329
+ throwError = new WalletConnectUserDenied();
330
+ break;
331
+ case 4:
332
+ throwError = new WalletConnectTimeout(message);
333
+ break;
334
+ case 99:
335
+ throwError = new WalletConnectSignBytesUnspecifiedError(message);
336
+ break;
337
+ }
338
+ }
339
+ catch (_a) {
340
+ throwError = new WalletConnectSignBytesUnspecifiedError(error.message);
341
+ }
342
+ throw throwError;
343
+ });
344
+ }
345
+ /**
346
+ * mobile confirm
347
+ *
348
+ * @param payload paylaod
349
+ * @param _walletApp wallet type, default is XPLA Vault
350
+ */
351
+ function confirm(payload, _walletApp) {
352
+ if (!_walletApp || typeof _walletApp === 'boolean') {
353
+ if (_walletApp) {
354
+ window.location.href = `c2xvault://walletconnect_confirm/?payload=${payload}`;
355
+ }
356
+ else {
357
+ window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;
358
+ }
359
+ }
360
+ else {
361
+ if (_walletApp === WalletApp.XPLA_VAULT) {
362
+ window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;
363
+ }
364
+ else if (_walletApp === WalletApp.XPLA_GAMES) {
365
+ window.location.href = `c2xvault://walletconnect_confirm/?payload=${payload}`;
366
+ }
367
+ else if (_walletApp === WalletApp.XPLA_GAMES_NEW) {
368
+ window.location.href = `xgameswallet://walletconnect_confirm/?payload=${payload}`;
369
+ }
370
+ else if (_walletApp === WalletApp.XPLAYZ) {
371
+ window.location.href = `xplayz://walletconnect_confirm/?payload=${payload}`;
372
+ }
373
+ else {
374
+ window.location.href = `xplavault://walletconnect_confirm/?payload=${payload}`;
375
+ }
376
+ }
377
+ }
378
+ // ---------------------------------------------
379
+ // return
380
+ // ---------------------------------------------
381
+ return {
382
+ session,
383
+ getLatestSession,
384
+ post,
385
+ sign,
386
+ signBytes,
387
+ disconnect,
388
+ };
389
+ }
390
+ //# 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,22 @@
1
+ export declare class WalletConnectUserDenied extends Error {
2
+ }
3
+ export declare class WalletConnectCreateTxFailed extends Error {
4
+ constructor(message: string);
5
+ }
6
+ export declare class WalletConnectTxFailed extends Error {
7
+ readonly txhash: string;
8
+ readonly raw_message: any;
9
+ constructor(txhash: string, message: string, raw_message: any);
10
+ }
11
+ export declare class WalletConnectTimeout extends Error {
12
+ constructor(message: string);
13
+ }
14
+ export declare class WalletConnectTxUnspecifiedError extends Error {
15
+ constructor(message: string);
16
+ }
17
+ export declare class WalletConnectSignUnspecifiedError extends Error {
18
+ constructor(message: string);
19
+ }
20
+ export declare class WalletConnectSignBytesUnspecifiedError extends Error {
21
+ constructor(message: string);
22
+ }
@@ -0,0 +1,41 @@
1
+ export class WalletConnectUserDenied extends Error {
2
+ }
3
+ export class WalletConnectCreateTxFailed extends Error {
4
+ constructor(message) {
5
+ super(message);
6
+ this.name = 'WalletConnectCreateTxFailed';
7
+ }
8
+ }
9
+ export class WalletConnectTxFailed extends Error {
10
+ constructor(txhash, message, raw_message) {
11
+ super(message);
12
+ this.txhash = txhash;
13
+ this.raw_message = raw_message;
14
+ this.name = 'WalletConnectTxFailed';
15
+ }
16
+ }
17
+ export class WalletConnectTimeout extends Error {
18
+ constructor(message) {
19
+ super(message);
20
+ this.name = 'WalletConnectTimeout';
21
+ }
22
+ }
23
+ export class WalletConnectTxUnspecifiedError extends Error {
24
+ constructor(message) {
25
+ super(message);
26
+ this.name = 'WalletConnectTxUnspecifiedError';
27
+ }
28
+ }
29
+ export class WalletConnectSignUnspecifiedError extends Error {
30
+ constructor(message) {
31
+ super(message);
32
+ this.name = 'WalletConnectSignUnspecifiedError';
33
+ }
34
+ }
35
+ export class WalletConnectSignBytesUnspecifiedError extends Error {
36
+ constructor(message) {
37
+ super(message);
38
+ this.name = 'WalletConnectSignBytesUnspecifiedError';
39
+ }
40
+ }
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL0Brc2FuZ2t1azEwL3dhbGxldC1jb250cm9sbGVyL21vZHVsZXMvd2FsbGV0Y29ubmVjdC9lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLHVCQUF3QixTQUFRLEtBQUs7Q0FBRztBQUVyRCxNQUFNLE9BQU8sMkJBQTRCLFNBQVEsS0FBSztJQUNwRCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyw2QkFBNkIsQ0FBQztJQUM1QyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8scUJBQXNCLFNBQVEsS0FBSztJQUM5QyxZQUNrQixNQUFjLEVBQzlCLE9BQWUsRUFDQyxXQUFnQjtRQUVoQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFKQyxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBRWQsZ0JBQVcsR0FBWCxXQUFXLENBQUs7UUFHaEMsSUFBSSxDQUFDLElBQUksR0FBRyx1QkFBdUIsQ0FBQztJQUN0QyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsS0FBSztJQUM3QyxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxzQkFBc0IsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sK0JBQWdDLFNBQVEsS0FBSztJQUN4RCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxpQ0FBaUMsQ0FBQztJQUNoRCxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8saUNBQWtDLFNBQVEsS0FBSztJQUMxRCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxtQ0FBbUMsQ0FBQztJQUNsRCxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sc0NBQXVDLFNBQVEsS0FBSztJQUMvRCxZQUFZLE9BQWU7UUFDekIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyx3Q0FBd0MsQ0FBQztJQUN2RCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdFVzZXJEZW5pZWQgZXh0ZW5kcyBFcnJvciB7fVxuXG5leHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdENyZWF0ZVR4RmFpbGVkIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnV2FsbGV0Q29ubmVjdENyZWF0ZVR4RmFpbGVkJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdFR4RmFpbGVkIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgcmVhZG9ubHkgdHhoYXNoOiBzdHJpbmcsXG4gICAgbWVzc2FnZTogc3RyaW5nLFxuICAgIHB1YmxpYyByZWFkb25seSByYXdfbWVzc2FnZTogYW55LFxuICApIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnV2FsbGV0Q29ubmVjdFR4RmFpbGVkJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdFRpbWVvdXQgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXYWxsZXRDb25uZWN0VGltZW91dCc7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFdhbGxldENvbm5lY3RUeFVuc3BlY2lmaWVkRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXYWxsZXRDb25uZWN0VHhVbnNwZWNpZmllZEVycm9yJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdFNpZ25VbnNwZWNpZmllZEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlOiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSAnV2FsbGV0Q29ubmVjdFNpZ25VbnNwZWNpZmllZEVycm9yJztcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgV2FsbGV0Q29ubmVjdFNpZ25CeXRlc1Vuc3BlY2lmaWVkRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U6IHN0cmluZykge1xuICAgIHN1cGVyKG1lc3NhZ2UpO1xuICAgIHRoaXMubmFtZSA9ICdXYWxsZXRDb25uZWN0U2lnbkJ5dGVzVW5zcGVjaWZpZWRFcnJvcic7XG4gIH1cbn0iXX0=
@@ -0,0 +1,39 @@
1
+ import { ITransportLib, ISocketTransportOptions } from '@walletconnect/types';
2
+ declare class SocketTransport implements ITransportLib {
3
+ private opts;
4
+ private _protocol;
5
+ private _version;
6
+ private _url;
7
+ private _netMonitor;
8
+ private _socket;
9
+ private _nextSocket;
10
+ private _queue;
11
+ private _events;
12
+ private _subscriptions;
13
+ constructor(opts: ISocketTransportOptions);
14
+ set readyState(value: number);
15
+ get readyState(): number;
16
+ set connecting(value: boolean);
17
+ get connecting(): boolean;
18
+ set connected(value: boolean);
19
+ get connected(): boolean;
20
+ set closing(value: boolean);
21
+ get closing(): boolean;
22
+ set closed(value: boolean);
23
+ get closed(): boolean;
24
+ open: () => void;
25
+ close: () => void;
26
+ send: (message: string, topic?: string, silent?: boolean) => void;
27
+ subscribe: (topic: string) => void;
28
+ on: (event: string, callback: (payload: any) => void) => void;
29
+ private _socketCreate;
30
+ private _socketOpen;
31
+ private _socketClose;
32
+ private _socketSend;
33
+ private _socketReceive;
34
+ private _socketError;
35
+ private _queueSubscriptions;
36
+ private _setToQueue;
37
+ private _pushQueue;
38
+ }
39
+ export default SocketTransport;