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