@depay/web3-wallets-svm 18.0.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.
@@ -0,0 +1,1941 @@
1
+ import { request, estimate, getProvider } from '@depay/web3-client-evm';
2
+ import Blockchains from '@depay/web3-blockchains';
3
+ import { ethers } from 'ethers';
4
+ import { SignClient } from '@depay/walletconnect-v2';
5
+ import { CoinbaseWalletSDK } from '@depay/coinbase-wallet-sdk';
6
+ import { MiniKit, ResponseEvent } from '@depay/worldcoin-precompiled';
7
+
8
+ let supported$1 = ['ethereum', 'bsc', 'polygon', 'fantom', 'arbitrum', 'avalanche', 'gnosis', 'optimism', 'base', 'worldchain'];
9
+ supported$1.evm = ['ethereum', 'bsc', 'polygon', 'fantom', 'arbitrum', 'avalanche', 'gnosis', 'optimism', 'base', 'worldchain'];
10
+ supported$1.svm = [];
11
+
12
+ function _optionalChain$p(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
13
+ class Transaction {
14
+
15
+ constructor({
16
+ blockchain,
17
+ from,
18
+ to,
19
+ value,
20
+ api,
21
+ method,
22
+ params,
23
+ instructions,
24
+ signers,
25
+ alts,
26
+ sent,
27
+ succeeded,
28
+ failed,
29
+ accepted,
30
+ }) {
31
+
32
+ // required
33
+ this.blockchain = blockchain;
34
+ this.from = (from && from.match('0x')) ? ethers.utils.getAddress(from) : from;
35
+ this.to = (to && to.match('0x')) ? ethers.utils.getAddress(to) : to;
36
+
37
+ // optional
38
+ this.value = _optionalChain$p([Transaction, 'access', _ => _.bigNumberify, 'call', _2 => _2(value, blockchain), 'optionalAccess', _3 => _3.toString, 'call', _4 => _4()]);
39
+ this.api = api;
40
+ this.method = method;
41
+ this.params = params;
42
+ this.accepted = accepted;
43
+ this.sent = sent;
44
+ this.succeeded = succeeded;
45
+ this.failed = failed;
46
+ this.instructions = instructions;
47
+ this.signers = signers;
48
+ this.alts = alts;
49
+
50
+ // internal
51
+ this._succeeded = false;
52
+ this._failed = false;
53
+ }
54
+
55
+ async prepare({ wallet }) {
56
+ this.from = await wallet.account(this.blockchain);
57
+ }
58
+
59
+ static bigNumberify(value, blockchain) {
60
+ if (typeof value === 'number') {
61
+ return ethers.utils.parseUnits(value.toString(), Blockchains[blockchain].currency.decimals)
62
+ } else if (value && value.toString) {
63
+ return ethers.BigNumber.from(value.toString())
64
+ } else {
65
+ return value
66
+ }
67
+ }
68
+
69
+ findFragment() {
70
+ return this.getContract().interface.fragments.find((fragment) => {
71
+ return(
72
+ fragment.name == this.method &&
73
+ (fragment.inputs && this.params && typeof(this.params) === 'object' ? fragment.inputs.length == Object.keys(this.params).length : true)
74
+ )
75
+ })
76
+ }
77
+
78
+ getParamType(param) {
79
+ if(_optionalChain$p([param, 'optionalAccess', _5 => _5.components, 'optionalAccess', _6 => _6.length])) {
80
+ return `(${param.components.map((param)=>this.getParamType(param)).join(',')})`
81
+ } else {
82
+ return param.type
83
+ }
84
+ }
85
+
86
+ getMethodNameWithSignature() {
87
+ let fragment = this.findFragment();
88
+ if(fragment.inputs) {
89
+ return `${this.method}(${fragment.inputs.map((param)=>this.getParamType(param)).join(',')})`
90
+ } else {
91
+ return this.method
92
+ }
93
+ }
94
+
95
+ getContractArguments() {
96
+ if(this.params instanceof Array) {
97
+ return this.params
98
+ } else if (this.params instanceof Object) {
99
+ let fragment = this.findFragment();
100
+
101
+ return fragment.inputs.map((input) => {
102
+ return this.params[input.name]
103
+ })
104
+ }
105
+ }
106
+
107
+ getContract() {
108
+ return new ethers.Contract(this.to, this.api)
109
+ }
110
+
111
+ async getData() {
112
+ let contractArguments = this.getContractArguments();
113
+ let populatedTransaction;
114
+ if(contractArguments) {
115
+ populatedTransaction = await this.getContract().populateTransaction[this.getMethodNameWithSignature()].apply(
116
+ null, contractArguments
117
+ );
118
+ } else {
119
+ populatedTransaction = await this.getContract().populateTransaction[this.getMethodNameWithSignature()].apply(null);
120
+ }
121
+
122
+ return populatedTransaction.data
123
+ }
124
+
125
+ success() {
126
+ if (this._succeeded) {
127
+ return Promise.resolve(this)
128
+ }
129
+ return new Promise((resolve, reject) => {
130
+ let originalSucceeded = this.succeeded;
131
+ this.succeeded = (transaction) => {
132
+ if (originalSucceeded) originalSucceeded(transaction);
133
+ resolve(transaction);
134
+ };
135
+ })
136
+ }
137
+
138
+ failure() {
139
+ if (this._failed) {
140
+ return Promise.resolve(this)
141
+ }
142
+ return new Promise((resolve, reject) => {
143
+ let originalFailed = this.failed;
144
+ this.failed = (transaction, reason) => {
145
+ if (originalFailed) originalFailed(transaction, reason);
146
+ resolve(transaction, reason);
147
+ };
148
+ })
149
+ }
150
+ }
151
+
152
+ function _optionalChain$o(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
153
+
154
+ const sendTransaction$2 = async ({ transaction, wallet })=> {
155
+ transaction = new Transaction(transaction);
156
+ if((await wallet.connectedTo(transaction.blockchain)) == false) {
157
+ await wallet.switchTo(transaction.blockchain);
158
+ }
159
+ if((await wallet.connectedTo(transaction.blockchain)) == false) {
160
+ throw({ code: 'WRONG_NETWORK' })
161
+ }
162
+ await transaction.prepare({ wallet });
163
+ let transactionCount = await request({ blockchain: transaction.blockchain, method: 'transactionCount', address: transaction.from });
164
+ transaction.nonce = transactionCount;
165
+ let provider = new ethers.providers.Web3Provider(wallet.getProvider(), 'any');
166
+ let signer = provider.getSigner(0);
167
+ await submit$2({ transaction, provider, signer }).then((sentTransaction)=>{
168
+ if (sentTransaction) {
169
+ transaction.id = sentTransaction.hash;
170
+ transaction.nonce = sentTransaction.nonce || transactionCount;
171
+ transaction.url = Blockchains.findByName(transaction.blockchain).explorerUrlFor({ transaction });
172
+ if (transaction.sent) transaction.sent(transaction);
173
+ retrieveConfirmedTransaction$2(sentTransaction).then(() => {
174
+ transaction._succeeded = true;
175
+ if (transaction.succeeded) transaction.succeeded(transaction);
176
+ }).catch((error)=>{
177
+ if(error && error.code && error.code == 'TRANSACTION_REPLACED') {
178
+ if(error.replacement && error.replacement.hash) {
179
+ transaction.id = error.replacement.hash;
180
+ transaction.url = Blockchains.findByName(transaction.blockchain).explorerUrlFor({ transaction });
181
+ }
182
+ if(error.replacement && error.replacement.hash && error.receipt && error.receipt.status == 1) {
183
+ transaction._succeeded = true;
184
+ if (transaction.succeeded) transaction.succeeded(transaction);
185
+ } else if(error.replacement && error.replacement.hash && error.receipt && error.receipt.status == 0) {
186
+ transaction._failed = true;
187
+ if(transaction.failed) transaction.failed(transaction, error);
188
+ }
189
+ } else {
190
+ transaction._failed = true;
191
+ if(transaction.failed) transaction.failed(transaction, error);
192
+ }
193
+ });
194
+ } else {
195
+ throw('Submitting transaction failed!')
196
+ }
197
+ });
198
+ return transaction
199
+ };
200
+
201
+ const retrieveConfirmedTransaction$2 = (sentTransaction)=>{
202
+ return new Promise((resolve, reject)=>{
203
+ try {
204
+ sentTransaction.wait(1).then(resolve).catch((error)=>{
205
+ if(
206
+ (error && _optionalChain$o([error, 'optionalAccess', _ => _.stack, 'optionalAccess', _2 => _2.match, 'call', _3 => _3('JSON-RPC error')])) ||
207
+ (error && error.toString().match('undefined'))
208
+ ) {
209
+ setTimeout(()=>{
210
+ retrieveConfirmedTransaction$2(sentTransaction)
211
+ .then(resolve)
212
+ .catch(reject);
213
+ }, 500);
214
+ } else {
215
+ reject(error);
216
+ }
217
+ });
218
+ } catch(error) {
219
+ if(
220
+ (error && _optionalChain$o([error, 'optionalAccess', _4 => _4.stack, 'optionalAccess', _5 => _5.match, 'call', _6 => _6('JSON-RPC error')])) ||
221
+ (error && error.toString().match('undefined'))
222
+ ) {
223
+ setTimeout(()=>{
224
+ retrieveConfirmedTransaction$2(sentTransaction)
225
+ .then(resolve)
226
+ .catch(reject);
227
+ }, 500);
228
+ } else {
229
+ reject(error);
230
+ }
231
+ }
232
+ })
233
+ };
234
+
235
+ const submit$2 = ({ transaction, provider, signer }) => {
236
+ if(transaction.method) {
237
+ return submitContractInteraction$2({ transaction, signer, provider })
238
+ } else {
239
+ return submitSimpleTransfer$2({ transaction, signer })
240
+ }
241
+ };
242
+
243
+ const submitContractInteraction$2 = async ({ transaction, signer, provider })=>{
244
+ let contract = new ethers.Contract(transaction.to, transaction.api, provider);
245
+ let contractArguments = transaction.getContractArguments({ contract });
246
+ let method = contract.connect(signer)[transaction.getMethodNameWithSignature()];
247
+ let gas;
248
+ try {
249
+ gas = await estimate(transaction);
250
+ gas = gas.add(gas.div(10));
251
+ } catch (e) {}
252
+ if(contractArguments) {
253
+ return await method(...contractArguments, {
254
+ value: Transaction.bigNumberify(transaction.value, transaction.blockchain),
255
+ gasLimit: _optionalChain$o([gas, 'optionalAccess', _7 => _7.toHexString, 'call', _8 => _8()])
256
+ })
257
+ } else {
258
+ return await method({
259
+ value: Transaction.bigNumberify(transaction.value, transaction.blockchain),
260
+ gasLimit: _optionalChain$o([gas, 'optionalAccess', _9 => _9.toHexString, 'call', _10 => _10()])
261
+ })
262
+ }
263
+ };
264
+
265
+ const submitSimpleTransfer$2 = ({ transaction, signer })=>{
266
+ return signer.sendTransaction({
267
+ to: transaction.to,
268
+ value: Transaction.bigNumberify(transaction.value, transaction.blockchain)
269
+ })
270
+ };
271
+
272
+ function _optionalChain$n(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
273
+
274
+ class WindowEthereum {
275
+
276
+ static __initStatic() {this.info = {
277
+ name: 'Ethereum Wallet',
278
+ logo: "",
279
+ blockchains: supported$1.evm
280
+ };}
281
+
282
+ static __initStatic2() {this.isAvailable = async()=>{
283
+ return (
284
+ _optionalChain$n([window, 'optionalAccess', _38 => _38.ethereum]) &&
285
+ // not MetaMask
286
+ !(_optionalChain$n([window, 'optionalAccess', _39 => _39.ethereum, 'optionalAccess', _40 => _40.isMetaMask]) && Object.keys(window.ethereum).filter((key)=>key.match(/^is(?!Connected)(?!PocketUniverse)(?!RevokeCash)/)).length == 1) &&
287
+ // not Coin98
288
+ !_optionalChain$n([window, 'optionalAccess', _41 => _41.coin98]) &&
289
+ // not Trust Wallet
290
+ !(_optionalChain$n([window, 'optionalAccess', _42 => _42.ethereum, 'optionalAccess', _43 => _43.isTrust]) || _optionalChain$n([window, 'optionalAccess', _44 => _44.ethereum, 'optionalAccess', _45 => _45.isTrustWallet])) &&
291
+ // not crypto.com
292
+ !_optionalChain$n([window, 'optionalAccess', _46 => _46.ethereum, 'optionalAccess', _47 => _47.isDeficonnectProvider]) &&
293
+ // not HyperPay
294
+ !_optionalChain$n([window, 'optionalAccess', _48 => _48.ethereum, 'optionalAccess', _49 => _49.isHyperPay]) &&
295
+ // not Phantom
296
+ !(window.phantom && !window.glow && !_optionalChain$n([window, 'optionalAccess', _50 => _50.solana, 'optionalAccess', _51 => _51.isGlow]) && !['isBitKeep'].some((identifier)=>window.solana && window.solana[identifier])) &&
297
+ // not Rabby
298
+ !_optionalChain$n([window, 'optionalAccess', _52 => _52.ethereum, 'optionalAccess', _53 => _53.isRabby]) &&
299
+ // not Backpack
300
+ !_optionalChain$n([window, 'optionalAccess', _54 => _54.backpack, 'optionalAccess', _55 => _55.isBackpack]) &&
301
+ // not TokenPocket
302
+ !_optionalChain$n([window, 'optionalAccess', _56 => _56.ethereum, 'optionalAccess', _57 => _57.isTokenPocket]) &&
303
+ // not BitKeep
304
+ !_optionalChain$n([window, 'optionalAccess', _58 => _58.ethereum, 'optionalAccess', _59 => _59.isBitKeep]) &&
305
+ // not Coinbase
306
+ !(_optionalChain$n([window, 'optionalAccess', _60 => _60.ethereum, 'optionalAccess', _61 => _61.isCoinbaseWallet]) || _optionalChain$n([window, 'optionalAccess', _62 => _62.ethereum, 'optionalAccess', _63 => _63.isWalletLink])) &&
307
+ // MetaMask through ProviderMap
308
+ !_optionalChain$n([window, 'optionalAccess', _64 => _64.ethereum, 'optionalAccess', _65 => _65.providerMap, 'optionalAccess', _66 => _66.has, 'call', _67 => _67('MetaMask')]) &&
309
+ // Brave Wallet
310
+ !_optionalChain$n([window, 'optionalAccess', _68 => _68.ethereum, 'optionalAccess', _69 => _69.isBraveWallet]) &&
311
+ // Uniswap Wallet
312
+ !_optionalChain$n([window, 'optionalAccess', _70 => _70.ethereum, 'optionalAccess', _71 => _71.isUniswapWallet]) &&
313
+ // Rainbow
314
+ !_optionalChain$n([window, 'optionalAccess', _72 => _72.ethereum, 'optionalAccess', _73 => _73.isRainbow]) &&
315
+ // OKX Wallet
316
+ !_optionalChain$n([window, 'optionalAccess', _74 => _74.okxwallet])
317
+ )
318
+ };}
319
+
320
+ constructor () {
321
+ this.name = this.constructor.info.name;
322
+ this.logo = this.constructor.info.logo;
323
+ this.blockchains = this.constructor.info.blockchains;
324
+ this.sendTransaction = (transaction)=>{
325
+ return sendTransaction$2({
326
+ wallet: this,
327
+ transaction
328
+ })
329
+ };
330
+ }
331
+
332
+ getProvider() { return window.ethereum }
333
+
334
+ async account() {
335
+ if(!this.getProvider()) { return undefined }
336
+ const accounts = (await this.getProvider().request({ method: 'eth_accounts' })).map((address)=>ethers.utils.getAddress(address));
337
+ return accounts[0]
338
+ }
339
+
340
+ async connect() {
341
+ if(!this.getProvider()) { return undefined }
342
+ const accounts = (await this.getProvider().request({ method: 'eth_requestAccounts' })).map((address)=>ethers.utils.getAddress(address));
343
+ return accounts[0]
344
+ }
345
+
346
+ on(event, callback) {
347
+ let internalCallback;
348
+ switch (event) {
349
+ case 'account':
350
+ internalCallback = (accounts) => callback(ethers.utils.getAddress(accounts[0]));
351
+ this.getProvider().on('accountsChanged', internalCallback);
352
+ break
353
+ }
354
+ return internalCallback
355
+ }
356
+
357
+ off(event, internalCallback) {
358
+ switch (event) {
359
+ case 'account':
360
+ this.getProvider().removeListener('accountsChanged', internalCallback);
361
+ break
362
+ }
363
+ return internalCallback
364
+ }
365
+
366
+ async connectedTo(input) {
367
+ const blockchain = Blockchains.findById(await this.getProvider().request({ method: 'eth_chainId' }));
368
+ if(!blockchain) { return false }
369
+ if(input) {
370
+ return input === blockchain.name
371
+ } else {
372
+ return blockchain.name
373
+ }
374
+ }
375
+
376
+ addNetwork(blockchainName) {
377
+ return new Promise((resolve, reject)=>{
378
+ const blockchain = Blockchains.findByName(blockchainName);
379
+ this.getProvider().request({
380
+ method: 'wallet_addEthereumChain',
381
+ params: [{
382
+ chainId: blockchain.id,
383
+ chainName: blockchain.fullName,
384
+ nativeCurrency: {
385
+ name: blockchain.currency.name,
386
+ symbol: blockchain.currency.symbol,
387
+ decimals: blockchain.currency.decimals
388
+ },
389
+ rpcUrls: [blockchain.rpc],
390
+ blockExplorerUrls: [blockchain.explorer],
391
+ iconUrls: [blockchain.logo]
392
+ }],
393
+ }).then(resolve).catch(reject);
394
+ })
395
+ }
396
+
397
+ switchTo(blockchainName) {
398
+ return new Promise((resolve, reject)=>{
399
+ const blockchain = Blockchains.findByName(blockchainName);
400
+ this.getProvider().request({
401
+ method: 'wallet_switchEthereumChain',
402
+ params: [{ chainId: blockchain.id }],
403
+ }).then(resolve).catch((error)=> {
404
+ if(error.code === 4902){ // chain not yet added
405
+ this.addNetwork(blockchainName)
406
+ .then(()=>this.switchTo(blockchainName).then(resolve))
407
+ .catch(reject);
408
+ } else {
409
+ reject(error);
410
+ }
411
+ });
412
+ })
413
+ }
414
+
415
+ transactionCount({ blockchain, address }) {
416
+ return request({ blockchain, method: 'transactionCount', address })
417
+ }
418
+
419
+ async sign(message) {
420
+ if(typeof message === 'object') {
421
+ let provider = this.getProvider();
422
+ let account = await this.account();
423
+ if((await this.connectedTo(Blockchains.findByNetworkId(message.domain.chainId).name)) === false) {
424
+ throw({ code: 'WRONG_NETWORK' })
425
+ }
426
+ let signature = await provider.request({
427
+ method: 'eth_signTypedData_v4',
428
+ params: [account, message],
429
+ from: account,
430
+ });
431
+ return signature
432
+ } else if (typeof message === 'string') {
433
+ await this.account();
434
+ let provider = new ethers.providers.Web3Provider(this.getProvider(), 'any');
435
+ let signer = provider.getSigner(0);
436
+ let signature = await signer.signMessage(message);
437
+ return signature
438
+ }
439
+ }
440
+ } WindowEthereum.__initStatic(); WindowEthereum.__initStatic2();
441
+
442
+ function _optionalChain$m(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
443
+ class Binance extends WindowEthereum {
444
+
445
+ static __initStatic() {this.info = {
446
+ name: 'Binance Wallet',
447
+ logo: "",
448
+ blockchains: supported$1.evm
449
+ };}
450
+
451
+ static __initStatic2() {this.isAvailable = async()=>{
452
+ return _optionalChain$m([window, 'optionalAccess', _2 => _2.BinanceChain]) &&
453
+ !window.coin98 &&
454
+ !window.trustwallet
455
+ };}
456
+
457
+ getProvider() { return window.BinanceChain }
458
+
459
+ } Binance.__initStatic(); Binance.__initStatic2();
460
+
461
+ var logos = {
462
+ exodus: "",
463
+ phantom: "",
464
+ coin98: "",
465
+ coinbase: "",
466
+ trust: "",
467
+ brave: "",
468
+ magicEden: "",
469
+ okx: "",
470
+ };
471
+
472
+ function _optionalChain$l(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
473
+ class BraveEVM extends WindowEthereum {
474
+
475
+ static __initStatic() {this.info = {
476
+ name: 'Brave',
477
+ logo: logos.brave,
478
+ blockchains: supported$1.evm,
479
+ platform: 'evm',
480
+ };}
481
+
482
+ static __initStatic2() {this.isAvailable = async()=>{ return _optionalChain$l([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isBraveWallet]) };}
483
+
484
+ getProvider() {
485
+ return window.ethereum
486
+ }
487
+ } BraveEVM.__initStatic(); BraveEVM.__initStatic2();
488
+
489
+ function _optionalChain$k(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
490
+ class Coin98EVM extends WindowEthereum {
491
+
492
+ static __initStatic() {this.info = {
493
+ name: 'Coin98',
494
+ logo: logos.coin98,
495
+ blockchains: supported$1.evm,
496
+ platform: 'evm',
497
+ };}
498
+
499
+ static __initStatic2() {this.isAvailable = async()=>{ return _optionalChain$k([window, 'optionalAccess', _2 => _2.coin98]) };}
500
+
501
+ getProvider() { return window.coin98.provider }
502
+
503
+ } Coin98EVM.__initStatic(); Coin98EVM.__initStatic2();
504
+
505
+ function _optionalChain$j(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
506
+ class CoinbaseEVM extends WindowEthereum {
507
+
508
+ static __initStatic() {this.info = {
509
+ name: 'Coinbase',
510
+ logo: logos.coinbase,
511
+ blockchains: supported$1.evm,
512
+ platform: 'evm',
513
+ };}
514
+
515
+ getProvider() {
516
+ if(_optionalChain$j([window, 'optionalAccess', _9 => _9.ethereum, 'optionalAccess', _10 => _10.providerMap, 'optionalAccess', _11 => _11.has, 'call', _12 => _12('CoinbaseWallet')])) {
517
+ return _optionalChain$j([window, 'optionalAccess', _13 => _13.ethereum, 'optionalAccess', _14 => _14.providerMap, 'optionalAccess', _15 => _15.get, 'call', _16 => _16('CoinbaseWallet')])
518
+ } else {
519
+ return window.ethereum
520
+ }
521
+ }
522
+
523
+ static __initStatic2() {this.isAvailable = async()=>{
524
+ return(
525
+ (
526
+ _optionalChain$j([window, 'optionalAccess', _17 => _17.ethereum, 'optionalAccess', _18 => _18.isCoinbaseWallet]) || _optionalChain$j([window, 'optionalAccess', _19 => _19.ethereum, 'optionalAccess', _20 => _20.isWalletLink])
527
+ ) || (
528
+ _optionalChain$j([window, 'optionalAccess', _21 => _21.ethereum, 'optionalAccess', _22 => _22.providerMap, 'optionalAccess', _23 => _23.has, 'call', _24 => _24('CoinbaseWallet')])
529
+ )
530
+ )
531
+ };}
532
+ } CoinbaseEVM.__initStatic(); CoinbaseEVM.__initStatic2();
533
+
534
+ function _optionalChain$i(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
535
+ class CryptoCom extends WindowEthereum {
536
+
537
+ static __initStatic() {this.info = {
538
+ name: 'Crypto.com | DeFi Wallet',
539
+ logo: "",
540
+ blockchains: supported$1.evm
541
+ };}
542
+
543
+ static __initStatic2() {this.isAvailable = async()=>{ return _optionalChain$i([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isDeficonnectProvider]) };}
544
+ } CryptoCom.__initStatic(); CryptoCom.__initStatic2();
545
+
546
+ function _optionalChain$h(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
547
+ class ExodusEVM extends WindowEthereum {
548
+
549
+ static __initStatic() {this.info = {
550
+ name: 'Exodus',
551
+ logo: logos.exodus,
552
+ blockchains: supported$1.evm,
553
+ platform: 'evm',
554
+ };}
555
+
556
+ static __initStatic2() {this.isAvailable = async()=>{ return _optionalChain$h([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isExodus]) };}
557
+ } ExodusEVM.__initStatic(); ExodusEVM.__initStatic2();
558
+
559
+ function _optionalChain$g(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
560
+ class HyperPay extends WindowEthereum {
561
+
562
+ static __initStatic() {this.info = {
563
+ name: 'HyperPay',
564
+ logo: "",
565
+ blockchains: supported$1.evm
566
+ };}
567
+
568
+ static __initStatic2() {this.isAvailable = async()=>{ return _optionalChain$g([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isHyperPay]) };}
569
+ } HyperPay.__initStatic(); HyperPay.__initStatic2();
570
+
571
+ function _optionalChain$f(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
572
+ class MagicEdenEVM extends WindowEthereum {
573
+
574
+ static __initStatic() {this.info = {
575
+ name: 'Magic Eden',
576
+ logo: logos.magicEden,
577
+ blockchains: ['ethereum', 'polygon'],
578
+ platform: 'evm',
579
+ };}
580
+
581
+ static __initStatic2() {this.isAvailable = async()=>{
582
+ return (
583
+ _optionalChain$f([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isMagicEden])
584
+ )
585
+ };}
586
+ } MagicEdenEVM.__initStatic(); MagicEdenEVM.__initStatic2();
587
+
588
+ function _optionalChain$e(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
589
+ class MetaMask extends WindowEthereum {
590
+
591
+ static __initStatic() {this.info = {
592
+ name: 'MetaMask',
593
+ logo: "",
594
+ blockchains: supported$1.evm
595
+ };}
596
+
597
+ static __initStatic2() {this.isMetaMask = (provider)=> {
598
+ return(
599
+ _optionalChain$e([provider, 'optionalAccess', _3 => _3.isMetaMask]) &&
600
+ Object.keys(provider).filter((key)=>key.match(/^is(?!Connected)(?!PocketUniverse)(?!WalletGuard)(?!RevokeCash)/)).length == 1
601
+ )
602
+ };}
603
+
604
+ static __initStatic3() {this.getEip6963Provider = ()=>{
605
+ return window['_eip6963Providers'] ? Object.values(window['_eip6963Providers']).find((provider)=>{
606
+ return MetaMask.isMetaMask(provider)
607
+ }) : undefined
608
+ };}
609
+
610
+ static __initStatic4() {this.isAvailable = async()=>{
611
+ return(
612
+ MetaMask.getEip6963Provider() ||
613
+ MetaMask.isMetaMask(_optionalChain$e([window, 'optionalAccess', _4 => _4.ethereum]))
614
+ )
615
+ };}
616
+
617
+ getProvider() {
618
+ return MetaMask.getEip6963Provider() || (MetaMask.isMetaMask(_optionalChain$e([window, 'optionalAccess', _5 => _5.ethereum])) && _optionalChain$e([window, 'optionalAccess', _6 => _6.ethereum]))
619
+ }
620
+ } MetaMask.__initStatic(); MetaMask.__initStatic2(); MetaMask.__initStatic3(); MetaMask.__initStatic4();
621
+
622
+ function _optionalChain$d(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
623
+ class OKXEVM extends WindowEthereum {
624
+
625
+ static __initStatic() {this.info = {
626
+ name: 'OKX',
627
+ logo: logos.okx,
628
+ blockchains: supported$1.evm,
629
+ platform: 'evm',
630
+ };}
631
+
632
+ static __initStatic2() {this.isAvailable = async()=>{
633
+ return (
634
+ _optionalChain$d([window, 'optionalAccess', _2 => _2.okxwallet])
635
+ )
636
+ };}
637
+ } OKXEVM.__initStatic(); OKXEVM.__initStatic2();
638
+
639
+ function _optionalChain$c(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
640
+ class Opera extends WindowEthereum {
641
+
642
+ static __initStatic() {this.info = {
643
+ name: 'Opera',
644
+ logo: "",
645
+ blockchains: supported$1.evm
646
+ };}
647
+
648
+ static __initStatic2() {this.isAvailable = async()=>{ return _optionalChain$c([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isOpera]) };}
649
+ } Opera.__initStatic(); Opera.__initStatic2();
650
+
651
+ function _optionalChain$b(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
652
+ class PhantomEVM extends WindowEthereum {
653
+
654
+ static __initStatic() {this.info = {
655
+ name: 'Phantom',
656
+ logo: logos.phantom,
657
+ blockchains: ['ethereum', 'polygon'],
658
+ platform: 'evm',
659
+ };}
660
+
661
+ static __initStatic2() {this.isAvailable = async()=>{
662
+ return (
663
+ window.phantom &&
664
+ window.phantom.ethereum &&
665
+ ! _optionalChain$b([window, 'optionalAccess', _4 => _4.ethereum, 'optionalAccess', _5 => _5.isMagicEden]) &&
666
+ ! _optionalChain$b([window, 'optionalAccess', _6 => _6.okxwallet])
667
+ )
668
+ };}
669
+
670
+ getProvider() {
671
+ return _optionalChain$b([window, 'optionalAccess', _7 => _7.phantom, 'optionalAccess', _8 => _8.ethereum]) || window.ethereum
672
+ }
673
+ } PhantomEVM.__initStatic(); PhantomEVM.__initStatic2();
674
+
675
+ function _optionalChain$a(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
676
+ class Rabby extends WindowEthereum {
677
+
678
+ static __initStatic() {this.info = {
679
+ name: 'Rabby',
680
+ logo: "",
681
+ blockchains: supported$1.evm
682
+ };}
683
+
684
+ static __initStatic2() {this.isAvailable = async()=>{
685
+ return(
686
+ _optionalChain$a([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isRabby])
687
+ )
688
+ };}
689
+ } Rabby.__initStatic(); Rabby.__initStatic2();
690
+
691
+ function _optionalChain$9(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
692
+ class Rainbow extends WindowEthereum {
693
+
694
+ static __initStatic() {this.info = {
695
+ name: 'Rainbow',
696
+ logo: "",
697
+ blockchains: supported$1.evm
698
+ };}
699
+
700
+ static __initStatic2() {this.getEip6963Provider = ()=>{
701
+ return window['_eip6963Providers'] ? Object.values(window['_eip6963Providers']).find((provider)=>{
702
+ return _optionalChain$9([provider, 'optionalAccess', _4 => _4.isRainbow])
703
+ }) : undefined
704
+ };}
705
+
706
+ static __initStatic3() {this.isAvailable = async()=>{
707
+ return(
708
+ Rainbow.getEip6963Provider() ||
709
+ _optionalChain$9([window, 'optionalAccess', _5 => _5.rainbow, 'optionalAccess', _6 => _6.isRainbow])
710
+ )
711
+ };}
712
+
713
+ getProvider() {
714
+ return Rainbow.getEip6963Provider() || _optionalChain$9([window, 'optionalAccess', _7 => _7.rainbow])
715
+ }
716
+
717
+ } Rainbow.__initStatic(); Rainbow.__initStatic2(); Rainbow.__initStatic3();
718
+
719
+ function _optionalChain$8(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
720
+ class TokenPocket extends WindowEthereum {
721
+
722
+ static __initStatic() {this.info = {
723
+ name: 'TP Wallet (TokenPocket)',
724
+ logo: "",
725
+ blockchains: supported$1.evm
726
+ };}
727
+
728
+ static __initStatic2() {this.isAvailable = async()=>{
729
+ return (
730
+ _optionalChain$8([window, 'optionalAccess', _3 => _3.ethereum, 'optionalAccess', _4 => _4.isTokenPocket])
731
+ )
732
+ };}
733
+ } TokenPocket.__initStatic(); TokenPocket.__initStatic2();
734
+
735
+ function _optionalChain$7(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
736
+ class TrustEVM extends WindowEthereum {
737
+
738
+ static __initStatic() {this.info = {
739
+ name: 'Trust Wallet',
740
+ logo: logos.trust,
741
+ blockchains: supported$1.evm,
742
+ platform: 'evm',
743
+ };}
744
+
745
+ static __initStatic2() {this.isAvailable = async()=>{
746
+ return (
747
+ (_optionalChain$7([window, 'optionalAccess', _5 => _5.ethereum, 'optionalAccess', _6 => _6.isTrust]) || _optionalChain$7([window, 'optionalAccess', _7 => _7.ethereum, 'optionalAccess', _8 => _8.isTrustWallet])) &&
748
+ Object.keys(window.ethereum).filter((key)=>key.match(/^is(?!Connected)(?!Debug)(?!TrustWallet)(?!MetaMask)(?!PocketUniverse)(?!RevokeCash)/)).length == 1
749
+ )
750
+ };}
751
+ } TrustEVM.__initStatic(); TrustEVM.__initStatic2();
752
+
753
+ function _optionalChain$6(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
754
+ class Uniswap extends WindowEthereum {
755
+
756
+ static __initStatic() {this.info = {
757
+ name: 'Uniswap',
758
+ logo: "",
759
+ blockchains: supported$1.evm
760
+ };}
761
+
762
+ static __initStatic2() {this.getEip6963Provider = ()=>{
763
+ return window['_eip6963Providers'] ? Object.values(window['_eip6963Providers']).find((provider)=>{
764
+ return _optionalChain$6([provider, 'optionalAccess', _4 => _4.isUniswapWallet])
765
+ }) : undefined
766
+ };}
767
+
768
+ static __initStatic3() {this.isAvailable = async()=>{
769
+ return(
770
+ Uniswap.getEip6963Provider() ||
771
+ _optionalChain$6([window, 'optionalAccess', _5 => _5.ethereum, 'optionalAccess', _6 => _6.isUniswapWallet])
772
+ )
773
+ };}
774
+
775
+ getProvider() {
776
+ return Uniswap.getEip6963Provider() || (_optionalChain$6([window, 'optionalAccess', _7 => _7.ethereum, 'optionalAccess', _8 => _8.isUniswapWallet]) && _optionalChain$6([window, 'optionalAccess', _9 => _9.ethereum]))
777
+ }
778
+ } Uniswap.__initStatic(); Uniswap.__initStatic2(); Uniswap.__initStatic3();
779
+
780
+ const transactionApiBlockchainNames = {
781
+ 'ethereum': 'mainnet',
782
+ 'bsc': 'bsc',
783
+ 'polygon': 'polygon',
784
+ 'arbitrum': 'arbitrum',
785
+ 'base': 'base',
786
+ 'avalanche': 'avalanche',
787
+ 'gnosis': 'gnosis-chain',
788
+ 'optimism': 'optimism',
789
+ 'worldchain': 'optimism',
790
+ };
791
+
792
+ const explorerBlockchainNames = {
793
+ 'ethereum': 'eth',
794
+ 'bsc': 'bnb',
795
+ 'polygon': 'matic',
796
+ 'arbitrum': 'arb1',
797
+ 'base': 'base',
798
+ 'avalanche': 'avax',
799
+ 'gnosis': 'gno',
800
+ 'optimism': 'oeth',
801
+ 'worldchain': 'oeth',
802
+ };
803
+
804
+ class Safe {
805
+
806
+ constructor ({ address, blockchain }) {
807
+ this.address = address;
808
+ this.blockchain = blockchain;
809
+ }
810
+
811
+ async transactionCount() {
812
+ let transactionCount;
813
+ let jsonResult = await fetch(`https://safe-transaction-${transactionApiBlockchainNames[this.blockchain]}.safe.global/api/v1/safes/${this.address}/all-transactions/`)
814
+ .then((response) => response.json())
815
+ .catch((error) => { console.error('Error:', error); });
816
+ if(jsonResult && jsonResult.results && jsonResult.results.length) {
817
+ transactionCount = jsonResult.results[0].nonce + 1;
818
+ } else {
819
+ transactionCount = parseInt((await request({
820
+ blockchain: this.blockchain,
821
+ address: this.address,
822
+ api: [{"inputs":[],"name":"nonce","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}],
823
+ method: 'nonce',
824
+ })).toString(), 10);
825
+ }
826
+ return transactionCount
827
+ }
828
+
829
+ async retrieveTransaction({ blockchain, tx }) {
830
+ const provider = await getProvider(blockchain);
831
+ let jsonResult = await fetch(`https://safe-transaction-${transactionApiBlockchainNames[blockchain]}.safe.global/api/v1/multisig-transactions/${tx}/`)
832
+ .then((response) => response.json())
833
+ .catch((error) => { console.error('Error:', error); });
834
+ if(jsonResult && jsonResult.isExecuted && jsonResult.transactionHash) {
835
+ return await provider.getTransaction(jsonResult.transactionHash)
836
+ } else {
837
+ return undefined
838
+ }
839
+ }
840
+
841
+ explorerUrlFor({ transaction }) {
842
+ if(transaction) {
843
+ return `https://app.safe.global/${explorerBlockchainNames[transaction.blockchain]}:${transaction.from}/transactions/tx?id=multisig_${transaction.from}_${transaction.id}`
844
+ }
845
+ }
846
+ }
847
+
848
+ const isSmartContractWallet = async(blockchain, address)=>{
849
+ const provider = await getProvider(blockchain);
850
+ const code = await provider.getCode(address);
851
+ return (code != '0x')
852
+ };
853
+
854
+ const identifySmartContractWallet = async (blockchain, address)=>{
855
+ let name;
856
+ try {
857
+ name = await request({
858
+ blockchain,
859
+ address,
860
+ api: [{ "constant": true, "inputs": [], "name": "NAME", "outputs": [{ "internalType": "string", "name": "", "type": "string" }], "payable": false, "stateMutability": "view", "type": "function"}],
861
+ method: 'NAME'
862
+ });
863
+ } catch (e) {}
864
+ if(name == 'Default Callback Handler') { return 'Safe' }
865
+
866
+ };
867
+
868
+ const getSmartContractWallet = async(blockchain, address)=> {
869
+ if(!await isSmartContractWallet(blockchain, address)){ return }
870
+
871
+ const type = await identifySmartContractWallet(blockchain, address);
872
+ if(type == 'Safe') {
873
+ return new Safe({ blockchain, address })
874
+ } else if(type == 'Argent') {
875
+ return new Argent({ blockchain, address })
876
+ } else {
877
+ if(smartContractWallet){ throw({ message: 'Unrecognized smart contract wallet not supported!', code: "SMART_CONTRACT_WALLET_NOT_SUPPORTED" }) }
878
+ }
879
+ };
880
+
881
+ function _optionalChain$5(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
882
+
883
+ const sendTransaction$1 = async ({ transaction, wallet })=> {
884
+ transaction = new Transaction(transaction);
885
+ await transaction.prepare({ wallet });
886
+ let transactionCount = await request({ blockchain: transaction.blockchain, method: 'transactionCount', address: transaction.from });
887
+ transaction.nonce = transactionCount;
888
+ await submit$1({ transaction, wallet }).then(async (response)=>{
889
+ if(typeof response == 'string') {
890
+ let blockchain = Blockchains[transaction.blockchain];
891
+ transaction.id = response;
892
+ transaction.url = blockchain.explorerUrlFor({ transaction });
893
+ if (transaction.sent) transaction.sent(transaction);
894
+ let sentTransaction = await retrieveTransaction(transaction.id, transaction.blockchain);
895
+ transaction.nonce = sentTransaction.nonce || transactionCount;
896
+ if(!sentTransaction) {
897
+ transaction._failed = true;
898
+ if(transaction.failed) transaction.failed(transaction, 'Error retrieving transaction');
899
+ } else {
900
+ retrieveConfirmedTransaction$1(sentTransaction).then(() => {
901
+ transaction._succeeded = true;
902
+ if (transaction.succeeded) transaction.succeeded(transaction);
903
+ }).catch((error)=>{
904
+ if(error && error.code && error.code == 'TRANSACTION_REPLACED') {
905
+ if(error.replacement && error.replacement.hash && error.receipt && error.receipt.status == 1) {
906
+ transaction.id = error.replacement.hash;
907
+ transaction._succeeded = true;
908
+ if (transaction.succeeded) transaction.succeeded(transaction);
909
+ } else if(error.replacement && error.replacement.hash && error.receipt && error.receipt.status == 0) {
910
+ transaction.id = error.replacement.hash;
911
+ transaction._failed = true;
912
+ if(transaction.failed) transaction.failed(transaction, error);
913
+ }
914
+ } else {
915
+ transaction._failed = true;
916
+ if(transaction.failed) transaction.failed(transaction, error);
917
+ }
918
+ });
919
+ }
920
+ } else {
921
+ throw(response)
922
+ }
923
+ });
924
+ return transaction
925
+ };
926
+
927
+ const retrieveConfirmedTransaction$1 = (sentTransaction)=>{
928
+ return new Promise((resolve, reject)=>{
929
+ try {
930
+ sentTransaction.wait(1).then(resolve).catch((error)=>{
931
+ if(
932
+ (error && _optionalChain$5([error, 'optionalAccess', _ => _.stack, 'optionalAccess', _2 => _2.match, 'call', _3 => _3('JSON-RPC error')])) ||
933
+ (error && error.toString().match('undefined'))
934
+ ) {
935
+ setTimeout(()=>{
936
+ retrieveConfirmedTransaction$1(sentTransaction)
937
+ .then(resolve)
938
+ .catch(reject);
939
+ }, 500);
940
+ } else {
941
+ reject(error);
942
+ }
943
+ });
944
+ } catch (error) {
945
+ if(
946
+ (error && _optionalChain$5([error, 'optionalAccess', _4 => _4.stack, 'optionalAccess', _5 => _5.match, 'call', _6 => _6('JSON-RPC error')])) ||
947
+ (error && error.toString().match('undefined'))
948
+ ) {
949
+ setTimeout(()=>{
950
+ retrieveConfirmedTransaction$1(sentTransaction)
951
+ .then(resolve)
952
+ .catch(reject);
953
+ }, 500);
954
+ } else {
955
+ reject(error);
956
+ }
957
+ }
958
+ })
959
+ };
960
+
961
+ const retrieveTransaction = (tx, blockchain)=>{
962
+ return new Promise(async(resolve, reject)=>{
963
+ try {
964
+ let sentTransaction;
965
+ const provider = await getProvider(blockchain);
966
+ sentTransaction = await provider.getTransaction(tx);
967
+ const maxRetries = 120;
968
+ let attempt = 1;
969
+ while (attempt <= maxRetries && !sentTransaction) {
970
+ sentTransaction = await provider.getTransaction(tx);
971
+ await (new Promise((resolve)=>setTimeout(resolve, 5000)));
972
+ attempt++;
973
+ }
974
+ resolve(sentTransaction);
975
+ } catch (error) {
976
+ if(
977
+ (error && _optionalChain$5([error, 'optionalAccess', _7 => _7.stack, 'optionalAccess', _8 => _8.match, 'call', _9 => _9('JSON-RPC error')])) ||
978
+ (error && error.toString().match('undefined'))
979
+ ) {
980
+ setTimeout(()=>{
981
+ retrieveTransaction(tx, blockchain)
982
+ .then(resolve)
983
+ .catch(reject);
984
+ }, 500);
985
+ } else {
986
+ reject(error);
987
+ }
988
+ }
989
+ })
990
+ };
991
+
992
+ const submit$1 = ({ transaction, wallet }) => {
993
+ if(transaction.method) {
994
+ return submitContractInteraction$1({ transaction, wallet })
995
+ } else {
996
+ return submitSimpleTransfer$1({ transaction, wallet })
997
+ }
998
+ };
999
+
1000
+ const submitContractInteraction$1 = async ({ transaction, wallet })=>{
1001
+ const provider = await getProvider(transaction.blockchain);
1002
+ const blockchain = Blockchains[transaction.blockchain];
1003
+ let gas;
1004
+ try {
1005
+ gas = await estimate(transaction);
1006
+ gas = gas.add(gas.div(10));
1007
+ } catch (e2) {}
1008
+ const gasPrice = await provider.getGasPrice();
1009
+ return wallet.signClient.request({
1010
+ topic: wallet.session.topic,
1011
+ chainId: `${blockchain.namespace}:${blockchain.networkId}`,
1012
+ request: {
1013
+ method: 'eth_sendTransaction',
1014
+ params: [{
1015
+ from: transaction.from,
1016
+ to: transaction.to,
1017
+ value: transaction.value ? ethers.BigNumber.from(transaction.value.toString()).toHexString() : undefined,
1018
+ data: await transaction.getData(),
1019
+ gas: _optionalChain$5([gas, 'optionalAccess', _10 => _10.toHexString, 'call', _11 => _11()]),
1020
+ gasLimit: _optionalChain$5([gas, 'optionalAccess', _12 => _12.toHexString, 'call', _13 => _13()]),
1021
+ gasPrice: gasPrice.toHexString(),
1022
+ nonce: ethers.utils.hexlify(transaction.nonce),
1023
+ }]
1024
+ }
1025
+ }).catch((e)=>{console.log('ERROR', e);})
1026
+ };
1027
+
1028
+ const submitSimpleTransfer$1 = async ({ transaction, wallet })=>{
1029
+ const provider = await getProvider(transaction.blockchain);
1030
+ let blockchain = Blockchains[transaction.blockchain];
1031
+ let gas;
1032
+ try {
1033
+ gas = await estimate(transaction);
1034
+ gas = gas.add(gas.div(10));
1035
+ } catch (e3) {}
1036
+ const gasPrice = await provider.getGasPrice();
1037
+ return wallet.signClient.request({
1038
+ topic: wallet.session.topic,
1039
+ chainId: `${blockchain.namespace}:${blockchain.networkId}`,
1040
+ request: {
1041
+ method: 'eth_sendTransaction',
1042
+ params: [{
1043
+ from: transaction.from,
1044
+ to: transaction.to,
1045
+ value: transaction.value ? ethers.BigNumber.from(transaction.value.toString()).toHexString() : undefined,
1046
+ data: '0x0',
1047
+ gas: _optionalChain$5([gas, 'optionalAccess', _14 => _14.toHexString, 'call', _15 => _15()]),
1048
+ gasLimit: _optionalChain$5([gas, 'optionalAccess', _16 => _16.toHexString, 'call', _17 => _17()]),
1049
+ gasPrice: _optionalChain$5([gasPrice, 'optionalAccess', _18 => _18.toHexString, 'call', _19 => _19()]),
1050
+ nonce: ethers.utils.hexlify(transaction.nonce)
1051
+ }]
1052
+ }
1053
+ }).catch((e)=>{console.log('ERROR', e);})
1054
+ };
1055
+
1056
+ function _optionalChain$4(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
1057
+
1058
+ const KEY = 'depay:wallets:wc2';
1059
+
1060
+ const DEFAULT_CONFIGURATION = {
1061
+ events: ['accountsChanged'],
1062
+ methods: [
1063
+ "eth_sendTransaction",
1064
+ "personal_sign",
1065
+ "eth_signTypedData",
1066
+ "eth_signTypedData_v4",
1067
+ ]
1068
+ };
1069
+
1070
+ const getConnectedInstance$1 = async()=>{
1071
+ if(await WalletConnectV2.isAvailable()) { return new WalletConnectV2() }
1072
+ };
1073
+
1074
+ const getLastSession = async(walletName)=>{
1075
+ if(!localStorage[KEY+":projectId"]) { return }
1076
+ if(walletName !== localStorage[KEY+":lastSessionWalletName"]) { return }
1077
+ let signClient = await getSignClient();
1078
+ let existingSessions;
1079
+ try { existingSessions = signClient.find(getWalletConnectV2Config(walletName)); } catch (e) {}
1080
+ const lastSession = existingSessions ? existingSessions[existingSessions.length-1] : undefined;
1081
+ if(lastSession && localStorage[KEY+":lastExpiredSessionTopic"] !== lastSession.topic && lastSession.expiry > Math.ceil(Date.now()/1000)) {
1082
+ const result = await Promise.race([signClient.ping({ topic: lastSession.topic }), new Promise((resolve)=>setTimeout(resolve, 1500))]);
1083
+ if(result) {
1084
+ return lastSession
1085
+ } else {
1086
+ localStorage[KEY+":lastExpiredSessionTopic"] = lastSession.topic;
1087
+ return
1088
+ }
1089
+ }
1090
+ };
1091
+
1092
+ const getWalletConnectV2Config = (walletName)=>{
1093
+ const methods = DEFAULT_CONFIGURATION.methods;
1094
+ const events = DEFAULT_CONFIGURATION.events;
1095
+
1096
+ let requiredNamespaces = {};
1097
+ requiredNamespaces['eip155'] = {
1098
+ chains: [`eip155:1`],
1099
+ };
1100
+ if(requiredNamespaces['eip155']) {
1101
+ requiredNamespaces['eip155'].methods = methods;
1102
+ requiredNamespaces['eip155'].events = events;
1103
+ }
1104
+
1105
+ let optionalNamespaces = {};
1106
+ optionalNamespaces['eip155'] = {
1107
+ chains: supported$1.evm.map((blockchain)=>`${Blockchains[blockchain].namespace}:${Blockchains[blockchain].networkId}`),
1108
+ };
1109
+ if(_optionalChain$4([optionalNamespaces, 'optionalAccess', _ => _.eip155]) && _optionalChain$4([optionalNamespaces, 'optionalAccess', _2 => _2.eip155, 'optionalAccess', _3 => _3.chains, 'optionalAccess', _4 => _4.length])) {
1110
+ optionalNamespaces['eip155'].methods = methods;
1111
+ optionalNamespaces['eip155'].events = events;
1112
+ }
1113
+
1114
+ return { requiredNamespaces, optionalNamespaces }
1115
+ };
1116
+
1117
+ const getSignClient = ()=>{
1118
+ if(window.getSignClientPromise) { return window.getSignClientPromise }
1119
+ window.getSignClientPromise = new Promise(async(resolve)=>{
1120
+ const signClient = await SignClient.init({
1121
+ projectId: localStorage[KEY+":projectId"],
1122
+ metadata: {
1123
+ name: document.title || 'dApp',
1124
+ description: _optionalChain$4([document, 'access', _5 => _5.querySelector, 'call', _6 => _6('meta[name="description"]'), 'optionalAccess', _7 => _7.getAttribute, 'call', _8 => _8('content')]) || document.title || 'dApp',
1125
+ url: location.href,
1126
+ icons: [_optionalChain$4([document, 'access', _9 => _9.querySelector, 'call', _10 => _10("link[rel~='icon'], link[rel~='shortcut icon']"), 'optionalAccess', _11 => _11.href]) || `${location.origin}/favicon.ico`]
1127
+ }
1128
+ });
1129
+ resolve(signClient);
1130
+ });
1131
+
1132
+ return window.getSignClientPromise
1133
+ };
1134
+
1135
+ class WalletConnectV2 {
1136
+
1137
+ static __initStatic() {this.info = {
1138
+ name: 'WalletConnect V2',
1139
+ logo: "",
1140
+ blockchains: supported$1.evm
1141
+ };}
1142
+
1143
+ static __initStatic2() {this.isAvailable = async(options)=>{
1144
+ return !! await getLastSession(_optionalChain$4([options, 'optionalAccess', _13 => _13.walletName]))
1145
+ };}
1146
+
1147
+ constructor() {
1148
+ this.name = (localStorage[KEY+':name'] && localStorage[KEY+':name'] != undefined) ? localStorage[KEY+':name'] : this.constructor.info.name;
1149
+ this.logo = (localStorage[KEY+':logo'] && localStorage[KEY+':logo'] != undefined) ? localStorage[KEY+':logo'] : this.constructor.info.logo;
1150
+ this.sendTransaction = (transaction)=>{
1151
+ return sendTransaction$1({
1152
+ wallet: this,
1153
+ transaction
1154
+ })
1155
+ };
1156
+ }
1157
+
1158
+ async account() {
1159
+ if(_optionalChain$4([this, 'access', _14 => _14.session, 'optionalAccess', _15 => _15.namespaces, 'optionalAccess', _16 => _16.eip155, 'optionalAccess', _17 => _17.accounts, 'optionalAccess', _18 => _18.length])) {
1160
+ return this.session.namespaces.eip155.accounts[0].split(':')[2]
1161
+ }
1162
+ }
1163
+
1164
+ async setSessionBlockchains() {
1165
+ if(!this.session || (!_optionalChain$4([this, 'access', _19 => _19.session, 'optionalAccess', _20 => _20.namespaces, 'optionalAccess', _21 => _21.eip155]) && !_optionalChain$4([this, 'access', _22 => _22.session, 'optionalAccess', _23 => _23.optionalNamespaces, 'optionalAccess', _24 => _24.eip155]))) { return }
1166
+ if(this.session.namespaces.eip155.chains) {
1167
+ this.blockchains = this.session.namespaces.eip155.chains.map((chainIdentifier)=>_optionalChain$4([Blockchains, 'access', _25 => _25.findByNetworkId, 'call', _26 => _26(chainIdentifier.split(':')[1]), 'optionalAccess', _27 => _27.name])).filter(Boolean);
1168
+ } else if(this.session.namespaces.eip155.accounts) {
1169
+ this.blockchains = this.session.namespaces.eip155.accounts.map((accountIdentifier)=>_optionalChain$4([Blockchains, 'access', _28 => _28.findByNetworkId, 'call', _29 => _29(accountIdentifier.split(':')[1]), 'optionalAccess', _30 => _30.name])).filter(Boolean);
1170
+ }
1171
+ }
1172
+
1173
+ async connect(options) {
1174
+
1175
+ let connect = (options && options.connect) ? options.connect : ({uri})=>{};
1176
+
1177
+ try {
1178
+
1179
+ this.walletName = _optionalChain$4([options, 'optionalAccess', _31 => _31.name]);
1180
+
1181
+ // delete localStorage[`wc@2:client:0.3//session`] // DELETE WC SESSIONS
1182
+ this.signClient = await getSignClient();
1183
+
1184
+ this.signClient.on("session_delete", (session)=> {
1185
+ if(_optionalChain$4([session, 'optionalAccess', _32 => _32.topic]) === _optionalChain$4([this, 'access', _33 => _33.session, 'optionalAccess', _34 => _34.topic])) {
1186
+ localStorage[KEY+':name'] = undefined;
1187
+ localStorage[KEY+':logo'] = undefined;
1188
+ this.signClient = undefined;
1189
+ this.session = undefined;
1190
+ }
1191
+ });
1192
+
1193
+ this.signClient.on("session_update", async(session)=> {
1194
+ if(_optionalChain$4([session, 'optionalAccess', _35 => _35.topic]) === _optionalChain$4([this, 'access', _36 => _36.session, 'optionalAccess', _37 => _37.topic])) {
1195
+ this.session = this.signClient.session.get(session.topic);
1196
+ await this.setSessionBlockchains();
1197
+ }
1198
+ });
1199
+
1200
+ this.signClient.on("session_event", (event)=> {
1201
+ if(_optionalChain$4([event, 'optionalAccess', _38 => _38.topic]) === _optionalChain$4([this, 'access', _39 => _39.session, 'optionalAccess', _40 => _40.topic])) {}
1202
+ });
1203
+
1204
+ const connectWallet = async()=>{
1205
+ const { uri, approval } = await this.signClient.connect(getWalletConnectV2Config(this.walletName));
1206
+ await connect({ uri });
1207
+ this.session = await approval();
1208
+ localStorage[KEY+":lastSessionWalletName"] = this.walletName;
1209
+ await new Promise(resolve=>setTimeout(resolve, 500)); // to prevent race condition within WalletConnect
1210
+ };
1211
+
1212
+ const lastSession = _optionalChain$4([this, 'optionalAccess', _41 => _41.walletName, 'optionalAccess', _42 => _42.length]) ? await getLastSession(this.walletName) : undefined;
1213
+ if(lastSession) {
1214
+ this.session = lastSession;
1215
+ } else {
1216
+ await connectWallet();
1217
+ }
1218
+
1219
+ let meta = _optionalChain$4([this, 'access', _43 => _43.session, 'optionalAccess', _44 => _44.peer, 'optionalAccess', _45 => _45.metadata]);
1220
+ if(meta && meta.name) {
1221
+ this.name = meta.name;
1222
+ localStorage[KEY+':name'] = meta.name;
1223
+ if(_optionalChain$4([meta, 'optionalAccess', _46 => _46.icons]) && meta.icons.length) {
1224
+ this.logo = meta.icons[0];
1225
+ localStorage[KEY+':logo'] = this.logo;
1226
+ }
1227
+ }
1228
+ if(_optionalChain$4([options, 'optionalAccess', _47 => _47.name])) { localStorage[KEY+':name'] = this.name = options.name; }
1229
+ if(_optionalChain$4([options, 'optionalAccess', _48 => _48.logo])) { localStorage[KEY+':logo'] = this.logo = options.logo; }
1230
+
1231
+ await this.setSessionBlockchains();
1232
+
1233
+ return await this.account()
1234
+
1235
+ } catch (error) {
1236
+ console.log('WALLETCONNECT ERROR', error);
1237
+ }
1238
+ }
1239
+
1240
+ async connectedTo(input) {
1241
+ if(input) {
1242
+ return this.blockchains.indexOf(input) > -1
1243
+ } else {
1244
+ return this.blockchains
1245
+ }
1246
+ }
1247
+
1248
+ getValidChainId() {
1249
+ return `eip155:${Blockchains[this.blockchains[0]].networkId}`
1250
+ }
1251
+
1252
+ switchTo(blockchainName) {
1253
+ return new Promise((resolve, reject)=>{
1254
+ reject({ code: 'NOT_SUPPORTED' });
1255
+ })
1256
+ }
1257
+
1258
+ addNetwork(blockchainName) {
1259
+ return new Promise((resolve, reject)=>{
1260
+ reject({ code: 'NOT_SUPPORTED' });
1261
+ })
1262
+ }
1263
+
1264
+ on(event, callback) {
1265
+ let internalCallback;
1266
+ switch (event) {
1267
+ case 'account':
1268
+ internalCallback = async(event)=> {
1269
+ if(_optionalChain$4([event, 'optionalAccess', _49 => _49.topic]) === _optionalChain$4([this, 'access', _50 => _50.session, 'optionalAccess', _51 => _51.topic]) && event.params.event.name === 'accountsChanged') {
1270
+ callback(await this.account());
1271
+ }
1272
+ };
1273
+ this.signClient.on("session_event", internalCallback);
1274
+ break
1275
+ }
1276
+ return internalCallback
1277
+ }
1278
+
1279
+ off(event, callback) {
1280
+ switch (event) {
1281
+ case 'account':
1282
+ this.signClient.off("session_event", callback);
1283
+ break
1284
+ }
1285
+ }
1286
+
1287
+ async transactionCount({ blockchain, address }) {
1288
+ const smartContractWallet = await getSmartContractWallet(blockchain, address);
1289
+ if(smartContractWallet) {
1290
+ return await smartContractWallet.transactionCount()
1291
+ } else {
1292
+ return await request({ blockchain, method: 'transactionCount', address })
1293
+ }
1294
+ }
1295
+
1296
+ async sign(message) {
1297
+ if(typeof message === 'object') {
1298
+ let account = await this.account();
1299
+ let signature = await this.signClient.request({
1300
+ topic: this.session.topic,
1301
+ chainId: this.getValidChainId(),
1302
+ request:{
1303
+ method: 'eth_signTypedData_v4',
1304
+ params: [account, JSON.stringify(message)],
1305
+ }
1306
+ });
1307
+ return signature
1308
+ } else if (typeof message === 'string') {
1309
+ const address = await this.account();
1310
+ const params = [ethers.utils.hexlify(ethers.utils.toUtf8Bytes(message)), address];
1311
+ let signature = await this.signClient.request({
1312
+ topic: this.session.topic,
1313
+ chainId: this.getValidChainId(),
1314
+ request:{
1315
+ method: 'personal_sign',
1316
+ params
1317
+ }
1318
+ });
1319
+ if(typeof signature == 'object') {
1320
+ signature = ethers.utils.hexlify(signature);
1321
+ }
1322
+ return signature
1323
+ }
1324
+ }
1325
+ } WalletConnectV2.__initStatic(); WalletConnectV2.__initStatic2();
1326
+
1327
+ WalletConnectV2.getConnectedInstance = getConnectedInstance$1;
1328
+
1329
+ function _optionalChain$3(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
1330
+ const sendTransaction = async ({ transaction, wallet })=> {
1331
+ transaction = new Transaction(transaction);
1332
+ if((await wallet.connectedTo(transaction.blockchain)) == false) {
1333
+ await wallet.switchTo(transaction.blockchain);
1334
+ }
1335
+ if((await wallet.connectedTo(transaction.blockchain)) == false) {
1336
+ throw({ code: 'WRONG_NETWORK' })
1337
+ }
1338
+ await transaction.prepare({ wallet });
1339
+ let provider = new ethers.providers.Web3Provider(wallet.connector, 'any');
1340
+ let signer = provider.getSigner(0);
1341
+ await submit({ transaction, provider, signer }).then((sentTransaction)=>{
1342
+ if (sentTransaction) {
1343
+ transaction.id = sentTransaction.hash;
1344
+ transaction.nonce = sentTransaction.nonce;
1345
+ transaction.url = Blockchains.findByName(transaction.blockchain).explorerUrlFor({ transaction });
1346
+ if (transaction.sent) transaction.sent(transaction);
1347
+ retrieveConfirmedTransaction(sentTransaction).then(() => {
1348
+ transaction._succeeded = true;
1349
+ if (transaction.succeeded) transaction.succeeded(transaction);
1350
+ }).catch((error)=>{
1351
+ if(error && error.code && error.code == 'TRANSACTION_REPLACED') {
1352
+ if(error.replacement && error.replacement.hash) {
1353
+ transaction.id = error.replacement.hash;
1354
+ transaction.url = Blockchains.findByName(transaction.blockchain).explorerUrlFor({ transaction });
1355
+ }
1356
+ if(error.replacement && error.replacement.hash && error.receipt && error.receipt.status == 1) {
1357
+ transaction._succeeded = true;
1358
+ if (transaction.succeeded) transaction.succeeded(transaction);
1359
+ } else if(error.replacement && error.replacement.hash && error.receipt && error.receipt.status == 0) {
1360
+ transaction._failed = true;
1361
+ if(transaction.failed) transaction.failed(transaction, error);
1362
+ }
1363
+ } else {
1364
+ transaction._failed = true;
1365
+ if(transaction.failed) transaction.failed(transaction, error);
1366
+ }
1367
+ });
1368
+ } else {
1369
+ throw('Submitting transaction failed!')
1370
+ }
1371
+ });
1372
+ return transaction
1373
+ };
1374
+
1375
+ const retrieveConfirmedTransaction = (sentTransaction)=>{
1376
+ return new Promise((resolve, reject)=>{
1377
+ try {
1378
+
1379
+ sentTransaction.wait(1).then(resolve).catch((error)=>{
1380
+ if(
1381
+ (error && _optionalChain$3([error, 'optionalAccess', _ => _.stack, 'optionalAccess', _2 => _2.match, 'call', _3 => _3('JSON-RPC error')])) ||
1382
+ (error && error.toString().match('undefined'))
1383
+ ) {
1384
+ setTimeout(()=>{
1385
+ retrieveConfirmedTransaction(sentTransaction)
1386
+ .then(resolve)
1387
+ .catch(reject);
1388
+ }, 500);
1389
+ } else {
1390
+ reject(error);
1391
+ }
1392
+ });
1393
+ } catch(error) {
1394
+ if(
1395
+ (error && _optionalChain$3([error, 'optionalAccess', _4 => _4.stack, 'optionalAccess', _5 => _5.match, 'call', _6 => _6('JSON-RPC error')])) ||
1396
+ (error && error.toString().match('undefined'))
1397
+ ) {
1398
+ setTimeout(()=>{
1399
+ retrieveConfirmedTransaction(sentTransaction)
1400
+ .then(resolve)
1401
+ .catch(reject);
1402
+ }, 500);
1403
+ } else {
1404
+ reject(error);
1405
+ }
1406
+ }
1407
+ })
1408
+ };
1409
+
1410
+ const submit = ({ transaction, provider, signer }) => {
1411
+ if(transaction.method) {
1412
+ return submitContractInteraction({ transaction, signer, provider })
1413
+ } else {
1414
+ return submitSimpleTransfer({ transaction, signer })
1415
+ }
1416
+ };
1417
+
1418
+ const submitContractInteraction = ({ transaction, signer, provider })=>{
1419
+ let contract = new ethers.Contract(transaction.to, transaction.api, provider);
1420
+ let contractArguments = transaction.getContractArguments({ contract });
1421
+ let method = contract.connect(signer)[transaction.getMethodNameWithSignature()];
1422
+ if(contractArguments) {
1423
+ return method(...contractArguments, {
1424
+ value: Transaction.bigNumberify(transaction.value, transaction.blockchain)
1425
+ })
1426
+ } else {
1427
+ return method({
1428
+ value: Transaction.bigNumberify(transaction.value, transaction.blockchain)
1429
+ })
1430
+ }
1431
+ };
1432
+
1433
+ const submitSimpleTransfer = ({ transaction, signer })=>{
1434
+ return signer.sendTransaction({
1435
+ to: transaction.to,
1436
+ value: Transaction.bigNumberify(transaction.value, transaction.blockchain)
1437
+ })
1438
+ };
1439
+
1440
+ function _optionalChain$2(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
1441
+
1442
+ const getConnectedInstance = ()=>{
1443
+ return window._connectedWalletLinkInstance
1444
+ };
1445
+
1446
+ const setConnectedInstance = (value)=>{
1447
+ window._connectedWalletLinkInstance = value;
1448
+ };
1449
+
1450
+ class WalletLink {
1451
+
1452
+ static __initStatic() {this.info = {
1453
+ name: 'Coinbase',
1454
+ logo: logos.coinbase,
1455
+ blockchains: supported$1.evm
1456
+ };}
1457
+
1458
+ static __initStatic2() {this.isAvailable = async()=>{ return getConnectedInstance() != undefined };}
1459
+
1460
+ constructor() {
1461
+ this.name = this.constructor.info.name;
1462
+ this.logo = this.constructor.info.logo;
1463
+ this.blockchains = this.constructor.info.blockchains;
1464
+ // RESET WalletLink (do not recover connections!)
1465
+ Object.keys(localStorage).forEach((key)=>{
1466
+ if(key.match("-walletlink:https://www.walletlink.org")) {
1467
+ delete localStorage[key];
1468
+ }
1469
+ });
1470
+ this.connector = WalletLink.instance || this.newWalletLinkInstance();
1471
+ this.sendTransaction = (transaction)=>{
1472
+ return sendTransaction({
1473
+ wallet: this,
1474
+ transaction
1475
+ })
1476
+ };
1477
+ }
1478
+
1479
+ newWalletLinkInstance() {
1480
+ let instance = new CoinbaseWalletSDK({}).makeWeb3Provider();
1481
+ return instance
1482
+ }
1483
+
1484
+ async account() {
1485
+ if(this.connectedAccounts == undefined) { return }
1486
+ return ethers.utils.getAddress(this.connectedAccounts[0])
1487
+ }
1488
+
1489
+ async connect(options) {
1490
+
1491
+ let connect = (options && options.connect) ? options.connect : ({uri})=>{};
1492
+ await connect({ uri: this.connector.qrUrl });
1493
+
1494
+ _optionalChain$2([document, 'access', _ => _.querySelector, 'call', _2 => _2('.-cbwsdk-css-reset'), 'optionalAccess', _3 => _3.setAttribute, 'call', _4 => _4('style', 'display: none;')]);
1495
+ _optionalChain$2([document, 'access', _5 => _5.querySelector, 'call', _6 => _6('.-cbwsdk-extension-dialog-container'), 'optionalAccess', _7 => _7.setAttribute, 'call', _8 => _8('style', 'display: none;')]);
1496
+ setTimeout(()=>{
1497
+ if(_optionalChain$2([this, 'optionalAccess', _9 => _9.connector, 'optionalAccess', _10 => _10._relay, 'optionalAccess', _11 => _11.ui, 'optionalAccess', _12 => _12.linkFlow, 'optionalAccess', _13 => _13.isOpen])){
1498
+ this.connector._relay.ui.linkFlow.isOpen = false;
1499
+ }
1500
+ }, 10);
1501
+
1502
+ let relay = await this.connector._relayProvider();
1503
+ relay.setConnectDisabled(false);
1504
+
1505
+ let accounts = await this.connector.enable();
1506
+ if(accounts instanceof Array && accounts.length) {
1507
+ setConnectedInstance(this);
1508
+ }
1509
+ accounts = accounts.map((account)=>ethers.utils.getAddress(account));
1510
+ this.connectedAccounts = accounts;
1511
+ this.connectedChainId = await this.connector.getChainId();
1512
+ return accounts[0]
1513
+ }
1514
+
1515
+ async connectedTo(input) {
1516
+ let chainId = await this.connector.getChainId();
1517
+ const blockchain = Blockchains.findByNetworkId(chainId);
1518
+ if(!blockchain) { return false }
1519
+ if(input) {
1520
+ return input === blockchain.name
1521
+ } else {
1522
+ return blockchain.name
1523
+ }
1524
+ }
1525
+
1526
+ switchTo(blockchainName) {
1527
+ return new Promise((resolve, reject)=>{
1528
+ const blockchain = Blockchains.findByName(blockchainName);
1529
+ this.connector.request({
1530
+ method: 'wallet_switchEthereumChain',
1531
+ params: [{ chainId: blockchain.id }],
1532
+ }).then(resolve).catch((error)=> {
1533
+ if(error.code === 4902){ // chain not yet added
1534
+ this.addNetwork(blockchainName)
1535
+ .then(()=>this.switchTo(blockchainName).then(resolve))
1536
+ .catch(reject);
1537
+ } else {
1538
+ reject(error);
1539
+ }
1540
+ });
1541
+ })
1542
+ }
1543
+
1544
+ addNetwork(blockchainName) {
1545
+ return new Promise((resolve, reject)=>{
1546
+ const blockchain = Blockchains.findByName(blockchainName);
1547
+ this.connector.request({
1548
+ method: 'wallet_addEthereumChain',
1549
+ params: [{
1550
+ chainId: blockchain.id,
1551
+ chainName: blockchain.fullName,
1552
+ nativeCurrency: {
1553
+ name: blockchain.currency.name,
1554
+ symbol: blockchain.currency.symbol,
1555
+ decimals: blockchain.currency.decimals
1556
+ },
1557
+ rpcUrls: [blockchain.rpc],
1558
+ blockExplorerUrls: [blockchain.explorer],
1559
+ iconUrls: [blockchain.logo]
1560
+ }],
1561
+ }).then(resolve).catch(reject);
1562
+ })
1563
+ }
1564
+
1565
+ on(event, callback) {
1566
+ let internalCallback;
1567
+ switch (event) {
1568
+ case 'account':
1569
+ internalCallback = (accounts) => callback(ethers.utils.getAddress(accounts[0]));
1570
+ this.connector.on('accountsChanged', internalCallback);
1571
+ break
1572
+ }
1573
+ return internalCallback
1574
+ }
1575
+
1576
+ off(event, internalCallback) {
1577
+ switch (event) {
1578
+ case 'account':
1579
+ this.connector.removeListener('accountsChanged', internalCallback);
1580
+ break
1581
+ }
1582
+ return internalCallback
1583
+ }
1584
+
1585
+ transactionCount({ blockchain, address }) {
1586
+ return request({ blockchain, method: 'transactionCount', address })
1587
+ }
1588
+
1589
+ async sign(message) {
1590
+ if(typeof message === 'object') {
1591
+ let provider = this.connector;
1592
+ let account = await this.account();
1593
+ if((await this.connectedTo(Blockchains.findByNetworkId(message.domain.chainId).name)) === false) {
1594
+ throw({ code: 'WRONG_NETWORK' })
1595
+ }
1596
+ let signature = await provider.request({
1597
+ method: 'eth_signTypedData_v4',
1598
+ params: [account, message],
1599
+ from: account,
1600
+ });
1601
+ return signature
1602
+ } else if (typeof message === 'string') {
1603
+ await this.account();
1604
+ let provider = new ethers.providers.Web3Provider(this.connector, 'any');
1605
+ let signer = provider.getSigner(0);
1606
+ let signature = await signer.signMessage(message);
1607
+ return signature
1608
+ }
1609
+ }
1610
+ } WalletLink.__initStatic(); WalletLink.__initStatic2();
1611
+
1612
+ WalletLink.getConnectedInstance = getConnectedInstance;
1613
+ WalletLink.setConnectedInstance = setConnectedInstance;
1614
+
1615
+ function _optionalChain$1(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
1616
+
1617
+ class WorldApp {
1618
+
1619
+ static __initStatic() {this.info = {
1620
+ name: 'World App',
1621
+ logo: "",
1622
+ blockchains: ["worldchain"]
1623
+ };}
1624
+
1625
+ static __initStatic2() {this.isAvailable = async()=>{
1626
+ return Boolean(
1627
+ _optionalChain$1([window, 'optionalAccess', _2 => _2.WorldApp])
1628
+ )
1629
+ };}
1630
+
1631
+ constructor () {
1632
+ MiniKit.install();
1633
+ this.name = this.constructor.info.name;
1634
+ this.logo = this.constructor.info.logo;
1635
+ this.blockchains = this.constructor.info.blockchains;
1636
+ this.sendTransaction = this.sendTransaction;
1637
+ }
1638
+
1639
+ sendTransaction(transaction) {
1640
+ console.log('sendTransaction', transaction);
1641
+ transaction = new Transaction(transaction);
1642
+ console.log('after transaction wrapping transaction.sent', transaction.sent);
1643
+ console.log('after transaction wrapping transaction.succeeded', transaction.succeeded);
1644
+ console.log('after transaction wrapping transaction.failed', transaction.failed);
1645
+
1646
+ return new Promise(async(resolve, reject)=>{
1647
+ await transaction.prepare({ wallet: this });
1648
+ console.log('after prepare transaction', transaction);
1649
+ transaction.nonce = (await this.transactionCount({ blockchain: 'worldchain', address: transaction.from })).toString();
1650
+ console.log('after nonce transaction', transaction);
1651
+
1652
+ console.log('before MiniKit.subscribe');
1653
+ MiniKit.subscribe(ResponseEvent.MiniAppSendTransaction, (payload)=> {
1654
+ console.log('payload', payload);
1655
+ if (payload.status == "success") {
1656
+ console.log('before transaction.accepted', transaction);
1657
+ if (transaction.accepted) { transaction.accepted(); }
1658
+ console.log('after transaction.accepted', transaction);
1659
+ this.fetchTransaction(transaction, payload).then((transactionHash)=>{
1660
+ if(transactionHash) {
1661
+ resolve(transaction);
1662
+ } else {
1663
+ reject('Fetching transaction failed!');
1664
+ }
1665
+ }).catch(reject);
1666
+ } else {
1667
+ reject('Submitting transaction failed!');
1668
+ }
1669
+ });
1670
+ console.log('after MiniKit.subscribe');
1671
+
1672
+ console.log('before MiniKit.commands.sendTransaction', {
1673
+ transaction: [
1674
+ {
1675
+ address: transaction.to,
1676
+ abi: _optionalChain$1([transaction, 'access', _3 => _3.api, 'optionalAccess', _4 => _4.filter, 'call', _5 => _5((fragment)=>fragment.name === transaction.method && _optionalChain$1([fragment, 'optionalAccess', _6 => _6.inputs, 'optionalAccess', _7 => _7.length]) === _optionalChain$1([transaction, 'access', _8 => _8.params, 'optionalAccess', _9 => _9.args, 'optionalAccess', _10 => _10.length]))]),
1677
+ functionName: transaction.method,
1678
+ args: _optionalChain$1([transaction, 'access', _11 => _11.params, 'optionalAccess', _12 => _12.args])
1679
+ },
1680
+ ],
1681
+ permit2: [_optionalChain$1([transaction, 'access', _13 => _13.params, 'optionalAccess', _14 => _14.permit2])]
1682
+ });
1683
+ MiniKit.commands.sendTransaction({
1684
+ transaction: [
1685
+ {
1686
+ address: transaction.to,
1687
+ abi: _optionalChain$1([transaction, 'access', _15 => _15.api, 'optionalAccess', _16 => _16.filter, 'call', _17 => _17((fragment)=>fragment.name === transaction.method && _optionalChain$1([fragment, 'optionalAccess', _18 => _18.inputs, 'optionalAccess', _19 => _19.length]) === _optionalChain$1([transaction, 'access', _20 => _20.params, 'optionalAccess', _21 => _21.args, 'optionalAccess', _22 => _22.length]))]),
1688
+ functionName: transaction.method,
1689
+ args: _optionalChain$1([transaction, 'access', _23 => _23.params, 'optionalAccess', _24 => _24.args])
1690
+ },
1691
+ ],
1692
+ permit2: [_optionalChain$1([transaction, 'access', _25 => _25.params, 'optionalAccess', _26 => _26.permit2])]
1693
+ });
1694
+ console.log('after MiniKit.commands.sendTransaction');
1695
+ })
1696
+ }
1697
+
1698
+ retryFetchTransaction(transaction, payload, attempt) {
1699
+ console.log('Retry Fetch transaction', attempt);
1700
+ return new Promise((resolve, reject)=>{
1701
+ setTimeout(()=>{
1702
+ this.fetchTransaction(transaction, payload, attempt+1).then(resolve).catch(reject);
1703
+ }, (attempt < 30 ? 500 : 1000));
1704
+ })
1705
+ }
1706
+
1707
+ fetchTransaction(transaction, payload, attempt = 1) {
1708
+ return new Promise((resolve, reject)=>{
1709
+ console.log('Before fetch');
1710
+ fetch(`https://public.depay.com/transactions/worldchain/${payload.transaction_id}`, {
1711
+ headers: { "Content-Type": "application/json" },
1712
+ }).then((response)=>{
1713
+ console.log('After fetch', response);
1714
+ if(response.ok) {
1715
+ console.log('Before json');
1716
+ response.json().then((transactionJSON)=>{
1717
+ console.log('After json', transactionJSON);
1718
+ if(_optionalChain$1([transactionJSON, 'optionalAccess', _27 => _27.external_id])) {
1719
+ transaction.id = _optionalChain$1([transactionJSON, 'optionalAccess', _28 => _28.external_id]);
1720
+ transaction.url = Blockchains['worldchain'].explorerUrlFor({ transaction });
1721
+ console.log('before transaction.sent', transaction.sent);
1722
+ if (transaction.sent) { transaction.sent(transaction); }
1723
+ console.log('Before provider');
1724
+ getProvider('worldchain').then((provider)=>{
1725
+ console.log('After provider', provider);
1726
+ console.log('Before wait transaction', transactionJSON.external_id);
1727
+ provider.waitForTransaction(transactionJSON.external_id).then((receipt)=>{
1728
+ console.log('After receipt', receipt);
1729
+ if(receipt && receipt.status == 1) {
1730
+ transaction._succeeded = true;
1731
+ console.log('before transaction.succeeded', transaction.succeeded);
1732
+ if (transaction.succeeded) { transaction.succeeded(transaction); }
1733
+ resolve(transaction);
1734
+ } else {
1735
+ if (transaction.failed) { transaction.failed(transaction, 'Transaction failed'); }
1736
+ }
1737
+ }).catch(reject);
1738
+ }).catch(reject);
1739
+ } else {
1740
+ this.retryFetchTransaction(transaction, payload, attempt).then(resolve).catch(reject);
1741
+ }
1742
+ }).catch(()=>this.retryFetchTransaction(transaction, payload, attempt).then(resolve).catch(reject));
1743
+ } else {
1744
+ this.retryFetchTransaction(transaction, payload, attempt).then(resolve).catch(reject);
1745
+ }
1746
+ }).catch(()=>this.retryFetchTransaction(transaction, payload, attempt).then(resolve).catch(reject));
1747
+ })
1748
+ }
1749
+
1750
+ getProvider() {
1751
+ return this
1752
+ }
1753
+
1754
+ async account() {
1755
+ if(!this.getProvider()) { return undefined }
1756
+ return MiniKit.walletAddress
1757
+ }
1758
+
1759
+ connect() {
1760
+
1761
+ return new Promise( async(resolve, reject)=>{
1762
+
1763
+ if(MiniKit.walletAddress) {
1764
+ return resolve(MiniKit.walletAddress)
1765
+ }
1766
+
1767
+ MiniKit.subscribe(ResponseEvent.MiniAppWalletAuth, async (payload) => {
1768
+ if (payload.status === "error") {
1769
+ return reject(payload.message)
1770
+ } else {
1771
+ return resolve(MiniKit.walletAddress || _optionalChain$1([window, 'access', _29 => _29.MiniKit, 'optionalAccess', _30 => _30.walletAddress]))
1772
+ }
1773
+ });
1774
+
1775
+ const { finalPayload } = await MiniKit.commandsAsync.walletAuth({
1776
+ nonce: crypto.randomUUID().replace(/-/g, ""),
1777
+ expirationTime: new Date(new Date().getTime() + 7 * 24 * 60 * 60 * 1000),
1778
+ notBefore: new Date(new Date().getTime() - 24 * 60 * 60 * 1000),
1779
+ statement: "Connect World App (v17.6.2)"
1780
+ });
1781
+
1782
+ if(finalPayload.status == 'error') {
1783
+ return reject(finalPayload.message)
1784
+ } else {
1785
+ return resolve(MiniKit.walletAddress || _optionalChain$1([window, 'access', _31 => _31.MiniKit, 'optionalAccess', _32 => _32.walletAddress]))
1786
+ }
1787
+ })
1788
+ }
1789
+
1790
+ on(event, callback) {}
1791
+
1792
+ off(event, internalCallback) {}
1793
+
1794
+ async connectedTo(input) {
1795
+ if(input) {
1796
+ return input === 'worldchain'
1797
+ } else {
1798
+ return 'worldchain'
1799
+ }
1800
+ }
1801
+
1802
+ addNetwork(blockchainName) {
1803
+ return new Promise((resolve, reject)=>{
1804
+ reject({ code: 'NOT_SUPPORTED' });
1805
+ })
1806
+ }
1807
+
1808
+ switchTo(blockchainName) {
1809
+ return new Promise((resolve, reject)=>{
1810
+ reject({ code: 'NOT_SUPPORTED' });
1811
+ })
1812
+ }
1813
+
1814
+ async transactionCount({ blockchain, address }) {
1815
+ if(!_optionalChain$1([MiniKit, 'optionalAccess', _33 => _33.walletAddress])) {
1816
+ return 0
1817
+ } else {
1818
+ return request({
1819
+ blockchain: 'worldchain',
1820
+ address: _optionalChain$1([MiniKit, 'optionalAccess', _34 => _34.walletAddress]),
1821
+ api: [{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"}],"name":"AddedOwner","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"approvedHash","type":"bytes32"},{"indexed":true,"internalType":"address","name":"owner","type":"address"}],"name":"ApproveHash","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"handler","type":"address"}],"name":"ChangedFallbackHandler","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"guard","type":"address"}],"name":"ChangedGuard","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"threshold","type":"uint256"}],"name":"ChangedThreshold","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"module","type":"address"}],"name":"DisabledModule","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"module","type":"address"}],"name":"EnabledModule","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bytes32","name":"txHash","type":"bytes32"},{"indexed":false,"internalType":"uint256","name":"payment","type":"uint256"}],"name":"ExecutionFailure","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"module","type":"address"}],"name":"ExecutionFromModuleFailure","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"module","type":"address"}],"name":"ExecutionFromModuleSuccess","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"bytes32","name":"txHash","type":"bytes32"},{"indexed":false,"internalType":"uint256","name":"payment","type":"uint256"}],"name":"ExecutionSuccess","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"owner","type":"address"}],"name":"RemovedOwner","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"SafeReceived","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"initiator","type":"address"},{"indexed":false,"internalType":"address[]","name":"owners","type":"address[]"},{"indexed":false,"internalType":"uint256","name":"threshold","type":"uint256"},{"indexed":false,"internalType":"address","name":"initializer","type":"address"},{"indexed":false,"internalType":"address","name":"fallbackHandler","type":"address"}],"name":"SafeSetup","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"msgHash","type":"bytes32"}],"name":"SignMsg","type":"event"},{"stateMutability":"nonpayable","type":"fallback"},{"inputs":[],"name":"VERSION","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"_threshold","type":"uint256"}],"name":"addOwnerWithThreshold","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"hashToApprove","type":"bytes32"}],"name":"approveHash","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"bytes32","name":"","type":"bytes32"}],"name":"approvedHashes","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_threshold","type":"uint256"}],"name":"changeThreshold","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"dataHash","type":"bytes32"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"bytes","name":"signatures","type":"bytes"},{"internalType":"uint256","name":"requiredSignatures","type":"uint256"}],"name":"checkNSignatures","outputs":[],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"dataHash","type":"bytes32"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"bytes","name":"signatures","type":"bytes"}],"name":"checkSignatures","outputs":[],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"prevModule","type":"address"},{"internalType":"address","name":"module","type":"address"}],"name":"disableModule","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"domainSeparator","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"module","type":"address"}],"name":"enableModule","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"enumEnum.Operation","name":"operation","type":"uint8"},{"internalType":"uint256","name":"safeTxGas","type":"uint256"},{"internalType":"uint256","name":"baseGas","type":"uint256"},{"internalType":"uint256","name":"gasPrice","type":"uint256"},{"internalType":"address","name":"gasToken","type":"address"},{"internalType":"address","name":"refundReceiver","type":"address"},{"internalType":"uint256","name":"_nonce","type":"uint256"}],"name":"encodeTransactionData","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"enumEnum.Operation","name":"operation","type":"uint8"},{"internalType":"uint256","name":"safeTxGas","type":"uint256"},{"internalType":"uint256","name":"baseGas","type":"uint256"},{"internalType":"uint256","name":"gasPrice","type":"uint256"},{"internalType":"address","name":"gasToken","type":"address"},{"internalType":"addresspayable","name":"refundReceiver","type":"address"},{"internalType":"bytes","name":"signatures","type":"bytes"}],"name":"execTransaction","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"enumEnum.Operation","name":"operation","type":"uint8"}],"name":"execTransactionFromModule","outputs":[{"internalType":"bool","name":"success","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"enumEnum.Operation","name":"operation","type":"uint8"}],"name":"execTransactionFromModuleReturnData","outputs":[{"internalType":"bool","name":"success","type":"bool"},{"internalType":"bytes","name":"returnData","type":"bytes"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getChainId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"start","type":"address"},{"internalType":"uint256","name":"pageSize","type":"uint256"}],"name":"getModulesPaginated","outputs":[{"internalType":"address[]","name":"array","type":"address[]"},{"internalType":"address","name":"next","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getOwners","outputs":[{"internalType":"address[]","name":"","type":"address[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"offset","type":"uint256"},{"internalType":"uint256","name":"length","type":"uint256"}],"name":"getStorageAt","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"enumEnum.Operation","name":"operation","type":"uint8"},{"internalType":"uint256","name":"safeTxGas","type":"uint256"},{"internalType":"uint256","name":"baseGas","type":"uint256"},{"internalType":"uint256","name":"gasPrice","type":"uint256"},{"internalType":"address","name":"gasToken","type":"address"},{"internalType":"address","name":"refundReceiver","type":"address"},{"internalType":"uint256","name":"_nonce","type":"uint256"}],"name":"getTransactionHash","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"module","type":"address"}],"name":"isModuleEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nonce","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"prevOwner","type":"address"},{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"_threshold","type":"uint256"}],"name":"removeOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"enumEnum.Operation","name":"operation","type":"uint8"}],"name":"requiredTxGas","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"handler","type":"address"}],"name":"setFallbackHandler","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"guard","type":"address"}],"name":"setGuard","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"_owners","type":"address[]"},{"internalType":"uint256","name":"_threshold","type":"uint256"},{"internalType":"address","name":"to","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"},{"internalType":"address","name":"fallbackHandler","type":"address"},{"internalType":"address","name":"paymentToken","type":"address"},{"internalType":"uint256","name":"payment","type":"uint256"},{"internalType":"addresspayable","name":"paymentReceiver","type":"address"}],"name":"setup","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"name":"signedMessages","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"targetContract","type":"address"},{"internalType":"bytes","name":"calldataPayload","type":"bytes"}],"name":"simulateAndRevert","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"prevOwner","type":"address"},{"internalType":"address","name":"oldOwner","type":"address"},{"internalType":"address","name":"newOwner","type":"address"}],"name":"swapOwner","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}],
1822
+ method: 'nonce'
1823
+ })
1824
+ }
1825
+ }
1826
+
1827
+ async sign(message) {
1828
+
1829
+ return new Promise((resolve, reject)=>{
1830
+
1831
+ MiniKit.subscribe(ResponseEvent.MiniAppSignMessage, async (payload) => {
1832
+ if (payload.status === "error") {
1833
+ return reject()
1834
+ } else {
1835
+ return resolve(payload.signature)
1836
+ }
1837
+ });
1838
+
1839
+ MiniKit.commands.signMessage({ message });
1840
+
1841
+ })
1842
+ }
1843
+ } WorldApp.__initStatic(); WorldApp.__initStatic2();
1844
+
1845
+ var wallets = {
1846
+ MetaMask,
1847
+ CoinbaseEVM,
1848
+ Binance,
1849
+ TrustEVM,
1850
+ Rabby,
1851
+ Uniswap,
1852
+ Rainbow,
1853
+ BraveEVM,
1854
+ Opera,
1855
+ MagicEdenEVM,
1856
+ OKXEVM,
1857
+ Coin98EVM,
1858
+ CryptoCom,
1859
+ HyperPay,
1860
+ TokenPocket,
1861
+ ExodusEVM,
1862
+ PhantomEVM,
1863
+ WorldApp,
1864
+
1865
+ // standards
1866
+ WindowEthereum,
1867
+ WalletConnectV2,
1868
+ WalletLink
1869
+ };
1870
+
1871
+ function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
1872
+ const getWallets = async(args)=>{
1873
+
1874
+ let drip = (args && typeof args.drip === 'function') ? args.drip : undefined;
1875
+
1876
+ // eip6963
1877
+ window['_eip6963Providers'] = {};
1878
+ const announceProvider = (event)=>{
1879
+ if(_optionalChain([event, 'optionalAccess', _ => _.detail, 'optionalAccess', _2 => _2.info, 'optionalAccess', _3 => _3.uuid])) {
1880
+ window['_eip6963Providers'][_optionalChain([event, 'optionalAccess', _4 => _4.detail, 'optionalAccess', _5 => _5.info, 'optionalAccess', _6 => _6.uuid])] = event.detail.provider;
1881
+ }
1882
+ };
1883
+ window.addEventListener("eip6963:announceProvider", announceProvider);
1884
+ window.dispatchEvent(new Event("eip6963:requestProvider"));
1885
+ window.removeEventListener("eip6963:announceProvider", announceProvider);
1886
+
1887
+ let availableWallets = await Promise.all(
1888
+
1889
+ Object.keys(wallets).map(
1890
+
1891
+ async(key)=>{
1892
+
1893
+ let wallet = wallets[key];
1894
+
1895
+ if(await wallet.isAvailable()) {
1896
+ let instance;
1897
+
1898
+ if(wallet.getConnectedInstance) {
1899
+ instance = await wallet.getConnectedInstance();
1900
+ if(drip && instance) { drip(instance); }
1901
+ return instance
1902
+ } else {
1903
+ if(drip && wallet) { drip(wallet); }
1904
+ return new wallet
1905
+ }
1906
+ }
1907
+ }
1908
+ )
1909
+ );
1910
+
1911
+ return availableWallets.filter(Boolean)
1912
+ };
1913
+
1914
+ const supported = [
1915
+ wallets.MetaMask,
1916
+ wallets.CoinbaseEVM,
1917
+ wallets.Binance,
1918
+ wallets.TrustEVM,
1919
+ wallets.Rabby,
1920
+ wallets.Uniswap,
1921
+ wallets.Rainbow,
1922
+ wallets.PhantomEVM,
1923
+ wallets.BraveEVM,
1924
+ wallets.OKXEvm,
1925
+ wallets.MagicEdenEVM,
1926
+ wallets.Opera,
1927
+ wallets.Coin98EVM,
1928
+ wallets.Coin98SVM,
1929
+ wallets.CryptoCom,
1930
+ wallets.HyperPay,
1931
+ wallets.TokenPocket,
1932
+ wallets.ExodusEVM,
1933
+ wallets.WorldApp,
1934
+
1935
+ // standards
1936
+ wallets.WalletConnectV2,
1937
+ wallets.WalletLink,
1938
+ wallets.WindowEthereum,
1939
+ ];
1940
+
1941
+ export { getWallets, supported, wallets };