@walletconnect/ethereum-provider 2.4.10 → 2.5.1

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.
package/README.md CHANGED
@@ -5,7 +5,7 @@ Ethereum Provider for WalletConnect Protocol.
5
5
  ## Installation
6
6
 
7
7
  ```
8
- npm i @walletconnect/ethereum-provider
8
+ npm i @walletconnect/ethereum-provider @web3modal/standalone
9
9
  ```
10
10
 
11
11
  ## Initialization
@@ -20,7 +20,8 @@ const provider = await EthereumProvider.init({
20
20
  events, // OPTIONAL ethereum events
21
21
  rpcMap, // OPTIONAL rpc urls for each chain
22
22
  metadata, // OPTIONAL metadata of your app
23
- showQrModal, // OPTIONAL - `true` by default
23
+ showQrModal, // OPTIONAL - `true` by default,
24
+ qrModalOptions, // OPTIONAL - `undefined` by default, see https://docs.walletconnect.com/2.0/web3modal/theming
24
25
  });
25
26
  ```
26
27
 
package/dist/index.cjs.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var P=require("events"),h=require("@walletconnect/utils"),T=require("@walletconnect/universal-provider");function R(i){if(i&&i.__esModule)return i;var t=Object.create(null);return i&&Object.keys(i).forEach(function(e){if(e!=="default"){var s=Object.getOwnPropertyDescriptor(i,e);Object.defineProperty(t,e,s.get?s:{enumerable:!0,get:function(){return i[e]}})}}),t.default=i,Object.freeze(t)}const S="wc",j="ethereum_provider",N=`${S}@${2}:${j}:`,D="https://rpc.walletconnect.com/v1/",u=["eth_sendTransaction","personal_sign"],q=["eth_accounts","eth_requestAccounts","eth_call","eth_getBalance","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode"],m=["chainChanged","accountsChanged"],$=["message","disconnect","connect"];var U=Object.defineProperty,L=Object.defineProperties,Q=Object.getOwnPropertyDescriptors,_=Object.getOwnPropertySymbols,V=Object.prototype.hasOwnProperty,H=Object.prototype.propertyIsEnumerable,w=(i,t,e)=>t in i?U(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,O=(i,t)=>{for(var e in t||(t={}))V.call(t,e)&&w(i,e,t[e]);if(_)for(var e of _(t))H.call(t,e)&&w(i,e,t[e]);return i},y=(i,t)=>L(i,Q(t));function I(i){return Number(i[0].split(":")[1])}function C(i){return`0x${i.toString(16)}`}function z(i){const{chains:t,optionalChains:e,methods:s,optionalMethods:n,events:a,optionalEvents:l,rpcMap:c}=i;if(!h.isValidArray(t))throw new Error("Invalid chains");const o=t,r=s||u,f=a||m,b={[I(o)]:c[I(o)]},E={chains:o,methods:r,events:f,rpcMap:b},d=a?.filter(v=>!m.includes(v)),p=s?.filter(v=>!u.includes(v));if(!e&&!l&&!n&&!(d!=null&&d.length)&&!(p!=null&&p.length))return{required:E};const A=d?.length&&p?.length||!e,M={chains:[...new Set(A?o.concat(e||[]):e)],methods:[...new Set(r.concat(n||[]))],events:[...new Set(f.concat(l||[]))],rpcMap:c};return{required:E,optional:M}}class g{constructor(){this.events=new P.EventEmitter,this.namespace="eip155",this.accounts=[],this.chainId=1,this.STORAGE_KEY=N,this.on=(t,e)=>(this.events.on(t,e),this),this.once=(t,e)=>(this.events.once(t,e),this),this.removeListener=(t,e)=>(this.events.removeListener(t,e),this),this.off=(t,e)=>(this.events.off(t,e),this),this.parseAccount=t=>this.isCompatibleChainId(t)?this.parseAccountId(t).address:t,this.signer={},this.rpc={}}static async init(t){const e=new g;return await e.initialize(t),e}async request(t){return await this.signer.request(t,this.formatChainId(this.chainId))}sendAsync(t,e){this.signer.sendAsync(t,e,this.formatChainId(this.chainId))}get connected(){return this.signer.client?this.signer.client.core.relayer.connected:!1}get connecting(){return this.signer.client?this.signer.client.core.relayer.connecting:!1}async enable(){return this.session||await this.connect(),await this.request({method:"eth_requestAccounts"})}async connect(t){if(!this.signer.client)throw new Error("Provider not initialized. Call init() first");this.loadConnectOpts(t);const{required:e,optional:s}=z(this.rpc);try{const n=await new Promise(async(l,c)=>{var o;this.rpc.showQrModal&&((o=this.modal)==null||o.subscribeModal(r=>{!r.open&&!this.signer.session&&(this.signer.abortPairingAttempt(),c(new Error("Connection request reset. Please try again.")))})),await this.signer.connect(y(O({namespaces:{[this.namespace]:e}},s&&{optionalNamespaces:{[this.namespace]:s}}),{pairingTopic:t?.pairingTopic})).then(r=>{l(r)}).catch(r=>{c(new Error(r.message))})});if(!n)return;this.setChainIds(this.rpc.chains);const a=h.getAccountsFromNamespaces(n.namespaces,[this.namespace]);this.setAccounts(a),this.events.emit("connect",{chainId:C(this.chainId)})}catch(n){throw this.signer.logger.error(n),n}finally{this.modal&&this.modal.closeModal()}}async disconnect(){this.session&&await this.signer.disconnect(),this.reset()}get isWalletConnect(){return!0}get session(){return this.signer.session}registerEventListeners(){this.signer.on("session_event",t=>{const{params:e}=t,{event:s}=e;s.name==="accountsChanged"?(this.accounts=this.parseAccounts(s.data),this.events.emit("accountsChanged",this.accounts)):s.name==="chainChanged"?this.setChainId(this.formatChainId(s.data)):this.events.emit(s.name,s.data),this.events.emit("session_event",t)}),this.signer.on("chainChanged",t=>{const e=parseInt(t);this.chainId=e,this.events.emit("chainChanged",C(this.chainId)),this.persist()}),this.signer.on("session_update",t=>{this.events.emit("session_update",t)}),this.signer.on("session_delete",t=>{this.reset(),this.events.emit("session_delete",t),this.events.emit("disconnect",y(O({},h.getSdkError("USER_DISCONNECTED")),{data:t.topic,name:"USER_DISCONNECTED"}))}),this.signer.on("display_uri",t=>{var e,s;this.rpc.showQrModal&&((e=this.modal)==null||e.closeModal(),(s=this.modal)==null||s.openModal({uri:t})),this.events.emit("display_uri",t)})}setHttpProvider(t){this.request({method:"wallet_switchEthereumChain",params:[{chainId:t.toString(16)}]})}isCompatibleChainId(t){return typeof t=="string"?t.startsWith(`${this.namespace}:`):!1}formatChainId(t){return`${this.namespace}:${t}`}parseChainId(t){return Number(t.split(":")[1])}setChainIds(t){const e=t.filter(s=>this.isCompatibleChainId(s)).map(s=>this.parseChainId(s));e.length&&(this.chainId=e[0],this.events.emit("chainChanged",C(this.chainId)),this.persist())}setChainId(t){if(this.isCompatibleChainId(t)){const e=this.parseChainId(t);this.chainId=e,this.setHttpProvider(e)}}parseAccountId(t){const[e,s,n]=t.split(":");return{chainId:`${e}:${s}`,address:n}}setAccounts(t){this.accounts=t.filter(e=>this.parseChainId(this.parseAccountId(e).chainId)===this.chainId).map(e=>this.parseAccountId(e).address),this.events.emit("accountsChanged",this.accounts)}getRpcConfig(t){var e,s;return{chains:((e=t.chains)==null?void 0:e.map(n=>this.formatChainId(n)))||[`${this.namespace}:1`],optionalChains:t.optionalChains?t.optionalChains.map(n=>this.formatChainId(n)):void 0,methods:t?.methods||u,events:t?.events||m,optionalMethods:t?.optionalMethods||[],optionalEvents:t?.optionalEvents||[],rpcMap:t?.rpcMap||this.buildRpcMap(t.chains.concat(t.optionalChains||[]),t.projectId),showQrModal:(s=t?.showQrModal)!=null?s:!0,projectId:t.projectId,metadata:t.metadata}}buildRpcMap(t,e){const s={};return t.forEach(n=>{s[n]=this.getRpcUrl(n,e)}),s}async initialize(t){if(this.rpc=this.getRpcConfig(t),this.chainId=I(this.rpc.chains),this.signer=await T.UniversalProvider.init({projectId:this.rpc.projectId,metadata:this.rpc.metadata}),this.registerEventListeners(),await this.loadPersistedSession(),this.rpc.showQrModal){const{Web3Modal:e}=await Promise.resolve().then(function(){return R(require("@web3modal/standalone"))});this.modal=new e({walletConnectVersion:2,projectId:this.rpc.projectId,standaloneChains:this.rpc.chains})}}loadConnectOpts(t){if(!t)return;const{chains:e,optionalChains:s,rpcMap:n}=t;e&&h.isValidArray(e)&&(this.rpc.chains=e.map(a=>this.formatChainId(a)),e.forEach(a=>{this.rpc.rpcMap[a]=n?.[a]||this.getRpcUrl(a)})),s&&h.isValidArray(s)&&(this.rpc.optionalChains=[],this.rpc.optionalChains=s?.map(a=>this.formatChainId(a)),s.forEach(a=>{this.rpc.rpcMap[a]=n?.[a]||this.getRpcUrl(a)}))}getRpcUrl(t,e){var s;return((s=this.rpc.rpcMap)==null?void 0:s[t])||`${D}?chainId=eip155:${t}&projectId=${e||this.rpc.projectId}`}async loadPersistedSession(){if(!this.session)return;const t=await this.signer.client.core.storage.getItem(`${this.STORAGE_KEY}/chainId`);this.setChainIds(t?[this.formatChainId(t)]:this.session.namespaces[this.namespace].accounts),this.setAccounts(this.session.namespaces[this.namespace].accounts)}reset(){this.chainId=1,this.accounts=[]}persist(){this.session&&this.signer.client.core.storage.setItem(`${this.STORAGE_KEY}/chainId`,this.chainId)}parseAccounts(t){return typeof t=="string"||t instanceof String?[this.parseAccount(t)]:t.map(e=>this.parseAccount(e))}}const G=g;exports.EthereumProvider=G,exports.OPTIONAL_EVENTS=$,exports.OPTIONAL_METHODS=q,exports.REQUIRED_EVENTS=m,exports.REQUIRED_METHODS=u,exports.default=g;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var T=require("events"),h=require("@walletconnect/utils"),P=require("@walletconnect/universal-provider");function R(n){if(n&&n.__esModule)return n;var t=Object.create(null);return n&&Object.keys(n).forEach(function(e){if(e!=="default"){var s=Object.getOwnPropertyDescriptor(n,e);Object.defineProperty(t,e,s.get?s:{enumerable:!0,get:function(){return n[e]}})}}),t.default=n,Object.freeze(t)}const S="wc",j="ethereum_provider",N=`${S}@${2}:${j}:`,q="https://rpc.walletconnect.com/v1/",u=["eth_sendTransaction","personal_sign"],D=["eth_accounts","eth_requestAccounts","eth_call","eth_getBalance","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode"],m=["chainChanged","accountsChanged"],$=["message","disconnect","connect"];var U=Object.defineProperty,Q=Object.defineProperties,L=Object.getOwnPropertyDescriptors,w=Object.getOwnPropertySymbols,V=Object.prototype.hasOwnProperty,H=Object.prototype.propertyIsEnumerable,_=(n,t,e)=>t in n?U(n,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):n[t]=e,O=(n,t)=>{for(var e in t||(t={}))V.call(t,e)&&_(n,e,t[e]);if(w)for(var e of w(t))H.call(t,e)&&_(n,e,t[e]);return n},y=(n,t)=>Q(n,L(t));function I(n){return Number(n[0].split(":")[1])}function C(n){return`0x${n.toString(16)}`}function z(n){const{chains:t,optionalChains:e,methods:s,optionalMethods:i,events:a,optionalEvents:l,rpcMap:c}=n;if(!h.isValidArray(t))throw new Error("Invalid chains");const o=t,r=s||u,E=a||m,b={[I(o)]:c[I(o)]},f={chains:o,methods:r,events:E,rpcMap:b},d=a?.filter(v=>!m.includes(v)),p=s?.filter(v=>!u.includes(v));if(!e&&!l&&!i&&!(d!=null&&d.length)&&!(p!=null&&p.length))return{required:f};const M=d?.length&&p?.length||!e,A={chains:[...new Set(M?o.concat(e||[]):e)],methods:[...new Set(r.concat(i||[]))],events:[...new Set(E.concat(l||[]))],rpcMap:c};return{required:f,optional:A}}class g{constructor(){this.events=new T.EventEmitter,this.namespace="eip155",this.accounts=[],this.chainId=1,this.STORAGE_KEY=N,this.on=(t,e)=>(this.events.on(t,e),this),this.once=(t,e)=>(this.events.once(t,e),this),this.removeListener=(t,e)=>(this.events.removeListener(t,e),this),this.off=(t,e)=>(this.events.off(t,e),this),this.parseAccount=t=>this.isCompatibleChainId(t)?this.parseAccountId(t).address:t,this.signer={},this.rpc={}}static async init(t){const e=new g;return await e.initialize(t),e}async request(t){return await this.signer.request(t,this.formatChainId(this.chainId))}sendAsync(t,e){this.signer.sendAsync(t,e,this.formatChainId(this.chainId))}get connected(){return this.signer.client?this.signer.client.core.relayer.connected:!1}get connecting(){return this.signer.client?this.signer.client.core.relayer.connecting:!1}async enable(){return this.session||await this.connect(),await this.request({method:"eth_requestAccounts"})}async connect(t){if(!this.signer.client)throw new Error("Provider not initialized. Call init() first");this.loadConnectOpts(t);const{required:e,optional:s}=z(this.rpc);try{const i=await new Promise(async(l,c)=>{var o;this.rpc.showQrModal&&((o=this.modal)==null||o.subscribeModal(r=>{!r.open&&!this.signer.session&&(this.signer.abortPairingAttempt(),c(new Error("Connection request reset. Please try again.")))})),await this.signer.connect(y(O({namespaces:{[this.namespace]:e}},s&&{optionalNamespaces:{[this.namespace]:s}}),{pairingTopic:t?.pairingTopic})).then(r=>{l(r)}).catch(r=>{c(new Error(r.message))})});if(!i)return;this.setChainIds(this.rpc.chains);const a=h.getAccountsFromNamespaces(i.namespaces,[this.namespace]);this.setAccounts(a),this.events.emit("connect",{chainId:C(this.chainId)})}catch(i){throw this.signer.logger.error(i),i}finally{this.modal&&this.modal.closeModal()}}async disconnect(){this.session&&await this.signer.disconnect(),this.reset()}get isWalletConnect(){return!0}get session(){return this.signer.session}registerEventListeners(){this.signer.on("session_event",t=>{const{params:e}=t,{event:s}=e;s.name==="accountsChanged"?(this.accounts=this.parseAccounts(s.data),this.events.emit("accountsChanged",this.accounts)):s.name==="chainChanged"?this.setChainId(this.formatChainId(s.data)):this.events.emit(s.name,s.data),this.events.emit("session_event",t)}),this.signer.on("chainChanged",t=>{const e=parseInt(t);this.chainId=e,this.events.emit("chainChanged",C(this.chainId)),this.persist()}),this.signer.on("session_update",t=>{this.events.emit("session_update",t)}),this.signer.on("session_delete",t=>{this.reset(),this.events.emit("session_delete",t),this.events.emit("disconnect",y(O({},h.getSdkError("USER_DISCONNECTED")),{data:t.topic,name:"USER_DISCONNECTED"}))}),this.signer.on("display_uri",t=>{var e,s;this.rpc.showQrModal&&((e=this.modal)==null||e.closeModal(),(s=this.modal)==null||s.openModal({uri:t})),this.events.emit("display_uri",t)})}setHttpProvider(t){this.request({method:"wallet_switchEthereumChain",params:[{chainId:t.toString(16)}]})}isCompatibleChainId(t){return typeof t=="string"?t.startsWith(`${this.namespace}:`):!1}formatChainId(t){return`${this.namespace}:${t}`}parseChainId(t){return Number(t.split(":")[1])}setChainIds(t){const e=t.filter(s=>this.isCompatibleChainId(s)).map(s=>this.parseChainId(s));e.length&&(this.chainId=e[0],this.events.emit("chainChanged",C(this.chainId)),this.persist())}setChainId(t){if(this.isCompatibleChainId(t)){const e=this.parseChainId(t);this.chainId=e,this.setHttpProvider(e)}}parseAccountId(t){const[e,s,i]=t.split(":");return{chainId:`${e}:${s}`,address:i}}setAccounts(t){this.accounts=t.filter(e=>this.parseChainId(this.parseAccountId(e).chainId)===this.chainId).map(e=>this.parseAccountId(e).address),this.events.emit("accountsChanged",this.accounts)}getRpcConfig(t){var e,s;return{chains:((e=t.chains)==null?void 0:e.map(i=>this.formatChainId(i)))||[`${this.namespace}:1`],optionalChains:t.optionalChains?t.optionalChains.map(i=>this.formatChainId(i)):void 0,methods:t?.methods||u,events:t?.events||m,optionalMethods:t?.optionalMethods||[],optionalEvents:t?.optionalEvents||[],rpcMap:t?.rpcMap||this.buildRpcMap(t.chains.concat(t.optionalChains||[]),t.projectId),showQrModal:(s=t?.showQrModal)!=null?s:!0,projectId:t.projectId,metadata:t.metadata}}buildRpcMap(t,e){const s={};return t.forEach(i=>{s[i]=this.getRpcUrl(i,e)}),s}async initialize(t){var e,s;if(this.rpc=this.getRpcConfig(t),this.chainId=I(this.rpc.chains),this.signer=await P.UniversalProvider.init({projectId:this.rpc.projectId,metadata:this.rpc.metadata}),this.registerEventListeners(),await this.loadPersistedSession(),this.rpc.showQrModal)try{const{Web3Modal:i}=await Promise.resolve().then(function(){return R(require("@web3modal/standalone"))});this.modal=new i({walletConnectVersion:2,projectId:this.rpc.projectId,standaloneChains:this.rpc.chains,themeMode:(e=this.rpc.qrModalOptions)==null?void 0:e.themeMode,themeVariables:(s=this.rpc.qrModalOptions)==null?void 0:s.themeVariables})}catch{throw new Error("To use QR modal, please install @web3modal/standalone package")}}loadConnectOpts(t){if(!t)return;const{chains:e,optionalChains:s,rpcMap:i}=t;e&&h.isValidArray(e)&&(this.rpc.chains=e.map(a=>this.formatChainId(a)),e.forEach(a=>{this.rpc.rpcMap[a]=i?.[a]||this.getRpcUrl(a)})),s&&h.isValidArray(s)&&(this.rpc.optionalChains=[],this.rpc.optionalChains=s?.map(a=>this.formatChainId(a)),s.forEach(a=>{this.rpc.rpcMap[a]=i?.[a]||this.getRpcUrl(a)}))}getRpcUrl(t,e){var s;return((s=this.rpc.rpcMap)==null?void 0:s[t])||`${q}?chainId=eip155:${t}&projectId=${e||this.rpc.projectId}`}async loadPersistedSession(){if(!this.session)return;const t=await this.signer.client.core.storage.getItem(`${this.STORAGE_KEY}/chainId`);this.setChainIds(t?[this.formatChainId(t)]:this.session.namespaces[this.namespace].accounts),this.setAccounts(this.session.namespaces[this.namespace].accounts)}reset(){this.chainId=1,this.accounts=[]}persist(){this.session&&this.signer.client.core.storage.setItem(`${this.STORAGE_KEY}/chainId`,this.chainId)}parseAccounts(t){return typeof t=="string"||t instanceof String?[this.parseAccount(t)]:t.map(e=>this.parseAccount(e))}}const G=g;exports.EthereumProvider=G,exports.OPTIONAL_EVENTS=$,exports.OPTIONAL_METHODS=D,exports.REQUIRED_EVENTS=m,exports.REQUIRED_METHODS=u,exports.default=g;
2
2
  //# sourceMappingURL=index.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.js","sources":["../src/constants/values.ts","../src/constants/rpc.ts","../src/EthereumProvider.ts","../src/index.ts"],"sourcesContent":["export const PROTOCOL = \"wc\";\nexport const WC_VERSION = 2;\nexport const CONTEXT = \"ethereum_provider\";\nexport const STORAGE_KEY = `${PROTOCOL}@${WC_VERSION}:${CONTEXT}:`;\nexport const RPC_URL = \"https://rpc.walletconnect.com/v1/\";\n","export const REQUIRED_METHODS = [\"eth_sendTransaction\", \"personal_sign\"];\nexport const OPTIONAL_METHODS = [\n \"eth_accounts\",\n \"eth_requestAccounts\",\n \"eth_call\",\n \"eth_getBalance\",\n \"eth_sendRawTransaction\",\n \"eth_sign\",\n \"eth_signTransaction\",\n \"eth_signTypedData\",\n \"eth_signTypedData_v3\",\n \"eth_signTypedData_v4\",\n \"wallet_switchEthereumChain\",\n \"wallet_addEthereumChain\",\n \"wallet_getPermissions\",\n \"wallet_requestPermissions\",\n \"wallet_registerOnboarding\",\n \"wallet_watchAsset\",\n \"wallet_scanQRCode\",\n];\nexport const REQUIRED_EVENTS = [\"chainChanged\", \"accountsChanged\"];\nexport const OPTIONAL_EVENTS = [\"message\", \"disconnect\", \"connect\"];\n","import { EventEmitter } from \"events\";\nimport { getAccountsFromNamespaces, getSdkError, isValidArray } from \"@walletconnect/utils\";\nimport {\n IEthereumProvider as IProvider,\n IEthereumProviderEvents,\n ProviderAccounts,\n RequestArguments,\n} from \"./types\";\nimport { Metadata, Namespace, UniversalProvider } from \"@walletconnect/universal-provider\";\nimport type { Web3Modal } from \"@web3modal/standalone\";\nimport { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport { STORAGE_KEY, REQUIRED_METHODS, REQUIRED_EVENTS, RPC_URL } from \"./constants\";\n\nexport type RpcMethod =\n | \"personal_sign\"\n | \"eth_sendTransaction\"\n | \"eth_accounts\"\n | \"eth_requestAccounts\"\n | \"eth_call\"\n | \"eth_getBalance\"\n | \"eth_sendRawTransaction\"\n | \"eth_sign\"\n | \"eth_signTransaction\"\n | \"eth_signTypedData\"\n | \"eth_signTypedData_v3\"\n | \"eth_signTypedData_v4\"\n | \"wallet_switchEthereumChain\"\n | \"wallet_addEthereumChain\"\n | \"wallet_getPermissions\"\n | \"wallet_requestPermissions\"\n | \"wallet_registerOnboarding\"\n | \"wallet_watchAsset\"\n | \"wallet_scanQRCode\";\n\nexport type RpcEvent = \"accountsChanged\" | \"chainChanged\" | \"message\" | \"disconnect\" | \"connect\";\n\nexport interface EthereumRpcMap {\n [chainId: string]: string;\n}\n\nexport interface SessionEvent {\n event: { name: string; data: any };\n chainId: string;\n}\n\nexport interface EthereumRpcConfig {\n chains: string[];\n optionalChains?: string[];\n methods: string[];\n optionalMethods?: string[];\n /**\n * @description Events that the wallet MUST support or the connection will be rejected\n */\n events: string[];\n optionalEvents?: string[];\n rpcMap: EthereumRpcMap;\n projectId: string;\n metadata?: Metadata;\n showQrModal: boolean;\n}\nexport interface ConnectOps {\n chains?: number[];\n optionalChains?: number[];\n rpcMap?: EthereumRpcMap;\n pairingTopic?: string;\n}\n\nexport interface IEthereumProvider extends IProvider {\n connect(opts?: ConnectOps | undefined): Promise<void>;\n}\n\nexport function getRpcUrl(chainId: string, rpc: EthereumRpcConfig): string | undefined {\n let rpcUrl: string | undefined;\n if (rpc.rpcMap) {\n rpcUrl = rpc.rpcMap[getEthereumChainId([chainId])];\n }\n return rpcUrl;\n}\n\nexport function getEthereumChainId(chains: string[]): number {\n return Number(chains[0].split(\":\")[1]);\n}\n\nexport function toHexChainId(chainId: number): string {\n return `0x${chainId.toString(16)}`;\n}\n\nexport type NamespacesParams = {\n chains: EthereumRpcConfig[\"chains\"];\n optionalChains?: EthereumRpcConfig[\"optionalChains\"];\n methods?: EthereumRpcConfig[\"methods\"];\n optionalMethods?: EthereumRpcConfig[\"methods\"];\n events?: EthereumRpcConfig[\"events\"];\n rpcMap: EthereumRpcConfig[\"rpcMap\"];\n optionalEvents?: EthereumRpcConfig[\"events\"];\n};\n\nexport function buildNamespaces(params: NamespacesParams): {\n required: Namespace;\n optional?: Namespace;\n} {\n const { chains, optionalChains, methods, optionalMethods, events, optionalEvents, rpcMap } =\n params;\n if (!isValidArray(chains)) {\n throw new Error(\"Invalid chains\");\n }\n\n const requiredChains = chains;\n const requriedMethods = methods || REQUIRED_METHODS;\n const requiredEvents = events || REQUIRED_EVENTS;\n const requiredRpcMap = {\n [getEthereumChainId(requiredChains)]: rpcMap[getEthereumChainId(requiredChains)],\n };\n\n const required: Namespace = {\n chains: requiredChains,\n methods: requriedMethods,\n events: requiredEvents,\n rpcMap: requiredRpcMap,\n };\n\n // make a list of events and methods that require additional permissions\n // so we know if we should to include the required chains in the optional namespace\n const eventsRequiringPermissions = events?.filter((event) => !REQUIRED_EVENTS.includes(event));\n const methodsRequiringPermissions = methods?.filter((event) => !REQUIRED_METHODS.includes(event));\n\n if (\n !optionalChains &&\n !optionalEvents &&\n !optionalMethods &&\n !eventsRequiringPermissions?.length &&\n !methodsRequiringPermissions?.length\n ) {\n return { required };\n }\n\n /*\n * decides whether or not to include the required chains in the optional namespace\n * use case: if there is a single chain as required but additonal methods/events as optional\n */\n const shouldIncludeRequiredChains =\n (eventsRequiringPermissions?.length && methodsRequiringPermissions?.length) || !optionalChains;\n\n const optional: Namespace = {\n chains: [\n ...new Set(\n shouldIncludeRequiredChains ? requiredChains.concat(optionalChains || []) : optionalChains,\n ),\n ],\n methods: [...new Set(requriedMethods.concat(optionalMethods || []))],\n events: [...new Set(requiredEvents.concat(optionalEvents || []))],\n rpcMap,\n };\n\n return { required, optional };\n}\nexport interface EthereumProviderOptions {\n projectId: string;\n /**\n * @note Chains that your app intents to use and the peer MUST support. If the peer does not support these chains, the connection will be rejected.\n * @default [1]\n * @example [1, 3, 4, 5, 42]\n */\n chains: number[];\n /**\n * @note Optional chains that your app MAY attempt to use and the peer MAY support. If the peer does not support these chains, the connection will still be established.\n * @default [1]\n * @example [1, 3, 4, 5, 42]\n */\n optionalChains?: number[];\n /**\n * @note Methods that your app intents to use and the peer MUST support. If the peer does not support these methods, the connection will be rejected.\n * @default [\"eth_sendTransaction\", \"personal_sign\"]\n */\n methods?: string[];\n /**\n * @note Methods that your app MAY attempt to use and the peer MAY support. If the peer does not support these methods, the connection will still be established.\n */\n optionalMethods?: string[];\n events?: string[];\n optionalEvents?: string[];\n rpcMap?: EthereumRpcMap;\n metadata?: Metadata;\n showQrModal?: boolean;\n}\n\nexport class EthereumProvider implements IEthereumProvider {\n public events = new EventEmitter();\n public namespace = \"eip155\";\n public accounts: string[] = [];\n public signer: InstanceType<typeof UniversalProvider>;\n public chainId = 1;\n public modal?: Web3Modal;\n\n private rpc: EthereumRpcConfig;\n private readonly STORAGE_KEY = STORAGE_KEY;\n\n constructor() {\n // assigned during initialize\n this.signer = {} as InstanceType<typeof UniversalProvider>;\n this.rpc = {} as EthereumRpcConfig;\n }\n\n static async init(opts: EthereumProviderOptions): Promise<EthereumProvider> {\n const provider = new EthereumProvider();\n await provider.initialize(opts);\n return provider;\n }\n\n public async request<T = unknown>(args: RequestArguments): Promise<T> {\n return await this.signer.request(args, this.formatChainId(this.chainId));\n }\n\n public sendAsync(\n args: RequestArguments,\n callback: (error: Error | null, response: any) => void,\n ): void {\n this.signer.sendAsync(args, callback, this.formatChainId(this.chainId));\n }\n\n get connected(): boolean {\n if (!this.signer.client) return false;\n return this.signer.client.core.relayer.connected;\n }\n\n get connecting(): boolean {\n if (!this.signer.client) return false;\n return this.signer.client.core.relayer.connecting;\n }\n\n public async enable(): Promise<ProviderAccounts> {\n if (!this.session) await this.connect();\n const accounts = await this.request({ method: \"eth_requestAccounts\" });\n return accounts as ProviderAccounts;\n }\n\n public async connect(opts?: ConnectOps): Promise<void> {\n if (!this.signer.client) {\n throw new Error(\"Provider not initialized. Call init() first\");\n }\n\n this.loadConnectOpts(opts);\n const { required, optional } = buildNamespaces(this.rpc);\n try {\n const session = await new Promise<SessionTypes.Struct | undefined>(\n async (resolve, reject) => {\n if (this.rpc.showQrModal) {\n this.modal?.subscribeModal((state) => {\n // the modal was closed so reject the promise\n if (!state.open && !this.signer.session) {\n this.signer.abortPairingAttempt();\n reject(new Error(\"Connection request reset. Please try again.\"));\n }\n });\n }\n await this.signer\n .connect({\n namespaces: {\n [this.namespace]: required,\n },\n ...(optional && {\n optionalNamespaces: {\n [this.namespace]: optional,\n },\n }),\n pairingTopic: opts?.pairingTopic,\n })\n .then((session) => {\n resolve(session);\n })\n .catch((error: Error) => {\n reject(new Error(error.message));\n });\n },\n );\n\n if (!session) return;\n this.setChainIds(this.rpc.chains);\n const accounts = getAccountsFromNamespaces(session.namespaces, [this.namespace]);\n this.setAccounts(accounts);\n this.events.emit(\"connect\", { chainId: toHexChainId(this.chainId) });\n } catch (error) {\n this.signer.logger.error(error);\n throw error;\n } finally {\n if (this.modal) this.modal.closeModal();\n }\n }\n\n public async disconnect(): Promise<void> {\n if (this.session) {\n await this.signer.disconnect();\n }\n this.reset();\n }\n\n public on: IEthereumProviderEvents[\"on\"] = (event, listener) => {\n this.events.on(event, listener);\n return this;\n };\n\n public once: IEthereumProviderEvents[\"once\"] = (event, listener) => {\n this.events.once(event, listener);\n return this;\n };\n\n public removeListener: IEthereumProviderEvents[\"removeListener\"] = (event, listener) => {\n this.events.removeListener(event, listener);\n return this;\n };\n\n public off: IEthereumProviderEvents[\"off\"] = (event, listener) => {\n this.events.off(event, listener);\n return this;\n };\n\n get isWalletConnect() {\n return true;\n }\n\n get session() {\n return this.signer.session;\n }\n // ---------- Private ----------------------------------------------- //\n\n private registerEventListeners() {\n this.signer.on(\"session_event\", (payload: SignClientTypes.EventArguments[\"session_event\"]) => {\n const { params } = payload;\n const { event } = params;\n if (event.name === \"accountsChanged\") {\n this.accounts = this.parseAccounts(event.data);\n this.events.emit(\"accountsChanged\", this.accounts);\n } else if (event.name === \"chainChanged\") {\n this.setChainId(this.formatChainId(event.data));\n } else {\n this.events.emit(event.name as any, event.data);\n }\n this.events.emit(\"session_event\", payload);\n });\n\n this.signer.on(\"chainChanged\", (chainId: string) => {\n const chain = parseInt(chainId);\n this.chainId = chain;\n this.events.emit(\"chainChanged\", toHexChainId(this.chainId));\n this.persist();\n });\n\n this.signer.on(\n \"session_update\",\n (payload: SignClientTypes.EventArguments[\"session_update\"]) => {\n this.events.emit(\"session_update\", payload);\n },\n );\n\n this.signer.on(\n \"session_delete\",\n (payload: SignClientTypes.EventArguments[\"session_delete\"]) => {\n this.reset();\n this.events.emit(\"session_delete\", payload);\n this.events.emit(\"disconnect\", {\n ...getSdkError(\"USER_DISCONNECTED\"),\n data: payload.topic,\n name: \"USER_DISCONNECTED\",\n });\n },\n );\n\n this.signer.on(\"display_uri\", (uri: string) => {\n if (this.rpc.showQrModal) {\n // to refresh the QR we have to close the modal and open it again\n // until proper API is provided by web3modal\n this.modal?.closeModal();\n this.modal?.openModal({ uri });\n }\n this.events.emit(\"display_uri\", uri);\n });\n }\n\n private setHttpProvider(chainId: number): void {\n this.request({\n method: \"wallet_switchEthereumChain\",\n params: [{ chainId: chainId.toString(16) }],\n });\n }\n\n private isCompatibleChainId(chainId: string): boolean {\n return typeof chainId === \"string\" ? chainId.startsWith(`${this.namespace}:`) : false;\n }\n\n private formatChainId(chainId: number): string {\n return `${this.namespace}:${chainId}`;\n }\n\n private parseChainId(chainId: string): number {\n return Number(chainId.split(\":\")[1]);\n }\n\n private setChainIds(chains: string[]) {\n const compatible = chains.filter((x) => this.isCompatibleChainId(x));\n const chainIds = compatible.map((c) => this.parseChainId(c));\n if (chainIds.length) {\n this.chainId = chainIds[0];\n this.events.emit(\"chainChanged\", toHexChainId(this.chainId));\n this.persist();\n }\n }\n\n private setChainId(chain: string) {\n if (this.isCompatibleChainId(chain)) {\n const chainId = this.parseChainId(chain);\n this.chainId = chainId;\n this.setHttpProvider(chainId);\n }\n }\n\n private parseAccountId(account: string): { chainId: string; address: string } {\n const [namespace, reference, address] = account.split(\":\");\n const chainId = `${namespace}:${reference}`;\n return { chainId, address };\n }\n\n private setAccounts(accounts: string[]) {\n this.accounts = accounts\n .filter((x) => this.parseChainId(this.parseAccountId(x).chainId) === this.chainId)\n .map((x) => this.parseAccountId(x).address);\n this.events.emit(\"accountsChanged\", this.accounts);\n }\n\n private getRpcConfig(opts: EthereumProviderOptions): EthereumRpcConfig {\n return {\n chains: opts.chains?.map((chain) => this.formatChainId(chain)) || [`${this.namespace}:1`],\n optionalChains: opts.optionalChains\n ? opts.optionalChains.map((chain) => this.formatChainId(chain))\n : undefined,\n methods: opts?.methods || REQUIRED_METHODS,\n events: opts?.events || REQUIRED_EVENTS,\n optionalMethods: opts?.optionalMethods || [],\n optionalEvents: opts?.optionalEvents || [],\n rpcMap:\n opts?.rpcMap ||\n this.buildRpcMap(opts.chains.concat(opts.optionalChains || []), opts.projectId),\n showQrModal: opts?.showQrModal ?? true,\n projectId: opts.projectId,\n metadata: opts.metadata,\n };\n }\n\n private buildRpcMap(chains: number[], projectId: string): EthereumRpcMap {\n const map: EthereumRpcMap = {};\n chains.forEach((chain) => {\n map[chain] = this.getRpcUrl(chain, projectId);\n });\n return map;\n }\n\n private async initialize(opts: EthereumProviderOptions) {\n this.rpc = this.getRpcConfig(opts);\n this.chainId = getEthereumChainId(this.rpc.chains);\n this.signer = await UniversalProvider.init({\n projectId: this.rpc.projectId,\n metadata: this.rpc.metadata,\n });\n this.registerEventListeners();\n await this.loadPersistedSession();\n if (this.rpc.showQrModal) {\n const { Web3Modal } = await import(\"@web3modal/standalone\");\n this.modal = new Web3Modal({\n walletConnectVersion: 2,\n projectId: this.rpc.projectId,\n standaloneChains: this.rpc.chains,\n });\n }\n }\n\n private loadConnectOpts(opts?: ConnectOps) {\n if (!opts) return;\n const { chains, optionalChains, rpcMap } = opts;\n if (chains && isValidArray(chains)) {\n this.rpc.chains = chains.map((chain) => this.formatChainId(chain));\n chains.forEach((chain) => {\n this.rpc.rpcMap[chain] = rpcMap?.[chain] || this.getRpcUrl(chain);\n });\n }\n if (optionalChains && isValidArray(optionalChains)) {\n this.rpc.optionalChains = [];\n this.rpc.optionalChains = optionalChains?.map((chain) => this.formatChainId(chain));\n optionalChains.forEach((chain) => {\n this.rpc.rpcMap[chain] = rpcMap?.[chain] || this.getRpcUrl(chain);\n });\n }\n }\n\n private getRpcUrl(chainId: number, projectId?: string): string {\n const providedRpc = this.rpc.rpcMap?.[chainId];\n return (\n providedRpc ||\n `${RPC_URL}?chainId=eip155:${chainId}&projectId=${projectId || this.rpc.projectId}`\n );\n }\n\n private async loadPersistedSession() {\n if (!this.session) return;\n const chainId = await this.signer.client.core.storage.getItem(`${this.STORAGE_KEY}/chainId`);\n this.setChainIds(\n chainId ? [this.formatChainId(chainId)] : this.session.namespaces[this.namespace].accounts,\n );\n this.setAccounts(this.session.namespaces[this.namespace].accounts);\n }\n\n private reset() {\n this.chainId = 1;\n this.accounts = [];\n }\n\n private persist() {\n if (!this.session) return;\n this.signer.client.core.storage.setItem(`${this.STORAGE_KEY}/chainId`, this.chainId);\n }\n\n private parseAccounts(payload: string | string[]): string[] {\n if (typeof payload === \"string\" || payload instanceof String) {\n return [this.parseAccount(payload)];\n }\n return payload.map((account: string) => this.parseAccount(account));\n }\n\n private parseAccount = (payload: any): string => {\n return this.isCompatibleChainId(payload) ? this.parseAccountId(payload).address : payload;\n };\n}\n\nexport default EthereumProvider;\n","import { EthereumProvider as Provider } from \"./EthereumProvider\";\nexport const EthereumProvider = Provider;\nexport type { RpcEvent, RpcMethod } from \"./EthereumProvider\";\nexport * from \"./constants/rpc\";\nexport default Provider;\n"],"names":["chains","chainId","params","optionalChains","methods","optionalMethods","events","optionalEvents","rpcMap","isValidArray","requiredChains","requriedMethods","REQUIRED_METHODS","requiredEvents","REQUIRED_EVENTS","requiredRpcMap","required","eventsRequiringPermissions","event","methodsRequiringPermissions","shouldIncludeRequiredChains","optional","EthereumProvider","EventEmitter","STORAGE_KEY","listener","payload","opts","provider","args","callback","session","resolve","reject","_a","state","__spreadProps","__spreadValues","error","accounts","getAccountsFromNamespaces","chain","getSdkError","uri","_b","chainIds","x","c","account","namespace","reference","address","projectId","map","UniversalProvider","Web3Modal","RPC_URL","Provider"],"mappings":"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"}
1
+ {"version":3,"file":"index.cjs.js","sources":["../src/constants/values.ts","../src/constants/rpc.ts","../src/EthereumProvider.ts","../src/index.ts"],"sourcesContent":["export const PROTOCOL = \"wc\";\nexport const WC_VERSION = 2;\nexport const CONTEXT = \"ethereum_provider\";\nexport const STORAGE_KEY = `${PROTOCOL}@${WC_VERSION}:${CONTEXT}:`;\nexport const RPC_URL = \"https://rpc.walletconnect.com/v1/\";\n","export const REQUIRED_METHODS = [\"eth_sendTransaction\", \"personal_sign\"];\nexport const OPTIONAL_METHODS = [\n \"eth_accounts\",\n \"eth_requestAccounts\",\n \"eth_call\",\n \"eth_getBalance\",\n \"eth_sendRawTransaction\",\n \"eth_sign\",\n \"eth_signTransaction\",\n \"eth_signTypedData\",\n \"eth_signTypedData_v3\",\n \"eth_signTypedData_v4\",\n \"wallet_switchEthereumChain\",\n \"wallet_addEthereumChain\",\n \"wallet_getPermissions\",\n \"wallet_requestPermissions\",\n \"wallet_registerOnboarding\",\n \"wallet_watchAsset\",\n \"wallet_scanQRCode\",\n];\nexport const REQUIRED_EVENTS = [\"chainChanged\", \"accountsChanged\"];\nexport const OPTIONAL_EVENTS = [\"message\", \"disconnect\", \"connect\"];\n","import { EventEmitter } from \"events\";\nimport { getAccountsFromNamespaces, getSdkError, isValidArray } from \"@walletconnect/utils\";\nimport {\n IEthereumProvider as IProvider,\n IEthereumProviderEvents,\n ProviderAccounts,\n RequestArguments,\n} from \"./types\";\nimport { Metadata, Namespace, UniversalProvider } from \"@walletconnect/universal-provider\";\nimport type { Web3Modal } from \"@web3modal/standalone\";\nimport { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport { STORAGE_KEY, REQUIRED_METHODS, REQUIRED_EVENTS, RPC_URL } from \"./constants\";\n\nexport type RpcMethod =\n | \"personal_sign\"\n | \"eth_sendTransaction\"\n | \"eth_accounts\"\n | \"eth_requestAccounts\"\n | \"eth_call\"\n | \"eth_getBalance\"\n | \"eth_sendRawTransaction\"\n | \"eth_sign\"\n | \"eth_signTransaction\"\n | \"eth_signTypedData\"\n | \"eth_signTypedData_v3\"\n | \"eth_signTypedData_v4\"\n | \"wallet_switchEthereumChain\"\n | \"wallet_addEthereumChain\"\n | \"wallet_getPermissions\"\n | \"wallet_requestPermissions\"\n | \"wallet_registerOnboarding\"\n | \"wallet_watchAsset\"\n | \"wallet_scanQRCode\";\n\nexport type RpcEvent = \"accountsChanged\" | \"chainChanged\" | \"message\" | \"disconnect\" | \"connect\";\n\nexport interface EthereumRpcMap {\n [chainId: string]: string;\n}\n\nexport interface SessionEvent {\n event: { name: string; data: any };\n chainId: string;\n}\n\nexport interface EthereumRpcConfig {\n chains: string[];\n optionalChains?: string[];\n methods: string[];\n optionalMethods?: string[];\n /**\n * @description Events that the wallet MUST support or the connection will be rejected\n */\n events: string[];\n optionalEvents?: string[];\n rpcMap: EthereumRpcMap;\n projectId: string;\n metadata?: Metadata;\n showQrModal: boolean;\n qrModalOptions?: Parameters<Web3Modal[\"setTheme\"]>[0];\n}\nexport interface ConnectOps {\n chains?: number[];\n optionalChains?: number[];\n rpcMap?: EthereumRpcMap;\n pairingTopic?: string;\n}\n\nexport interface IEthereumProvider extends IProvider {\n connect(opts?: ConnectOps | undefined): Promise<void>;\n}\n\nexport function getRpcUrl(chainId: string, rpc: EthereumRpcConfig): string | undefined {\n let rpcUrl: string | undefined;\n if (rpc.rpcMap) {\n rpcUrl = rpc.rpcMap[getEthereumChainId([chainId])];\n }\n return rpcUrl;\n}\n\nexport function getEthereumChainId(chains: string[]): number {\n return Number(chains[0].split(\":\")[1]);\n}\n\nexport function toHexChainId(chainId: number): string {\n return `0x${chainId.toString(16)}`;\n}\n\nexport type NamespacesParams = {\n chains: EthereumRpcConfig[\"chains\"];\n optionalChains?: EthereumRpcConfig[\"optionalChains\"];\n methods?: EthereumRpcConfig[\"methods\"];\n optionalMethods?: EthereumRpcConfig[\"methods\"];\n events?: EthereumRpcConfig[\"events\"];\n rpcMap: EthereumRpcConfig[\"rpcMap\"];\n optionalEvents?: EthereumRpcConfig[\"events\"];\n};\n\nexport function buildNamespaces(params: NamespacesParams): {\n required: Namespace;\n optional?: Namespace;\n} {\n const { chains, optionalChains, methods, optionalMethods, events, optionalEvents, rpcMap } =\n params;\n if (!isValidArray(chains)) {\n throw new Error(\"Invalid chains\");\n }\n\n const requiredChains = chains;\n const requriedMethods = methods || REQUIRED_METHODS;\n const requiredEvents = events || REQUIRED_EVENTS;\n const requiredRpcMap = {\n [getEthereumChainId(requiredChains)]: rpcMap[getEthereumChainId(requiredChains)],\n };\n\n const required: Namespace = {\n chains: requiredChains,\n methods: requriedMethods,\n events: requiredEvents,\n rpcMap: requiredRpcMap,\n };\n\n // make a list of events and methods that require additional permissions\n // so we know if we should to include the required chains in the optional namespace\n const eventsRequiringPermissions = events?.filter((event) => !REQUIRED_EVENTS.includes(event));\n const methodsRequiringPermissions = methods?.filter((event) => !REQUIRED_METHODS.includes(event));\n\n if (\n !optionalChains &&\n !optionalEvents &&\n !optionalMethods &&\n !eventsRequiringPermissions?.length &&\n !methodsRequiringPermissions?.length\n ) {\n return { required };\n }\n\n /*\n * decides whether or not to include the required chains in the optional namespace\n * use case: if there is a single chain as required but additonal methods/events as optional\n */\n const shouldIncludeRequiredChains =\n (eventsRequiringPermissions?.length && methodsRequiringPermissions?.length) || !optionalChains;\n\n const optional: Namespace = {\n chains: [\n ...new Set(\n shouldIncludeRequiredChains ? requiredChains.concat(optionalChains || []) : optionalChains,\n ),\n ],\n methods: [...new Set(requriedMethods.concat(optionalMethods || []))],\n events: [...new Set(requiredEvents.concat(optionalEvents || []))],\n rpcMap,\n };\n\n return { required, optional };\n}\nexport interface EthereumProviderOptions {\n projectId: string;\n /**\n * @note Chains that your app intents to use and the peer MUST support. If the peer does not support these chains, the connection will be rejected.\n * @default [1]\n * @example [1, 3, 4, 5, 42]\n */\n chains: number[];\n /**\n * @note Optional chains that your app MAY attempt to use and the peer MAY support. If the peer does not support these chains, the connection will still be established.\n * @default [1]\n * @example [1, 3, 4, 5, 42]\n */\n optionalChains?: number[];\n /**\n * @note Methods that your app intents to use and the peer MUST support. If the peer does not support these methods, the connection will be rejected.\n * @default [\"eth_sendTransaction\", \"personal_sign\"]\n */\n methods?: string[];\n /**\n * @note Methods that your app MAY attempt to use and the peer MAY support. If the peer does not support these methods, the connection will still be established.\n */\n optionalMethods?: string[];\n events?: string[];\n optionalEvents?: string[];\n rpcMap?: EthereumRpcMap;\n metadata?: Metadata;\n showQrModal?: boolean;\n qrModalOptions?: Parameters<Web3Modal[\"setTheme\"]>[0];\n}\n\nexport class EthereumProvider implements IEthereumProvider {\n public events = new EventEmitter();\n public namespace = \"eip155\";\n public accounts: string[] = [];\n public signer: InstanceType<typeof UniversalProvider>;\n public chainId = 1;\n public modal?: Web3Modal;\n\n private rpc: EthereumRpcConfig;\n private readonly STORAGE_KEY = STORAGE_KEY;\n\n constructor() {\n // assigned during initialize\n this.signer = {} as InstanceType<typeof UniversalProvider>;\n this.rpc = {} as EthereumRpcConfig;\n }\n\n static async init(opts: EthereumProviderOptions): Promise<EthereumProvider> {\n const provider = new EthereumProvider();\n await provider.initialize(opts);\n return provider;\n }\n\n public async request<T = unknown>(args: RequestArguments): Promise<T> {\n return await this.signer.request(args, this.formatChainId(this.chainId));\n }\n\n public sendAsync(\n args: RequestArguments,\n callback: (error: Error | null, response: any) => void,\n ): void {\n this.signer.sendAsync(args, callback, this.formatChainId(this.chainId));\n }\n\n get connected(): boolean {\n if (!this.signer.client) return false;\n return this.signer.client.core.relayer.connected;\n }\n\n get connecting(): boolean {\n if (!this.signer.client) return false;\n return this.signer.client.core.relayer.connecting;\n }\n\n public async enable(): Promise<ProviderAccounts> {\n if (!this.session) await this.connect();\n const accounts = await this.request({ method: \"eth_requestAccounts\" });\n return accounts as ProviderAccounts;\n }\n\n public async connect(opts?: ConnectOps): Promise<void> {\n if (!this.signer.client) {\n throw new Error(\"Provider not initialized. Call init() first\");\n }\n\n this.loadConnectOpts(opts);\n const { required, optional } = buildNamespaces(this.rpc);\n try {\n const session = await new Promise<SessionTypes.Struct | undefined>(\n async (resolve, reject) => {\n if (this.rpc.showQrModal) {\n this.modal?.subscribeModal((state) => {\n // the modal was closed so reject the promise\n if (!state.open && !this.signer.session) {\n this.signer.abortPairingAttempt();\n reject(new Error(\"Connection request reset. Please try again.\"));\n }\n });\n }\n await this.signer\n .connect({\n namespaces: {\n [this.namespace]: required,\n },\n ...(optional && {\n optionalNamespaces: {\n [this.namespace]: optional,\n },\n }),\n pairingTopic: opts?.pairingTopic,\n })\n .then((session) => {\n resolve(session);\n })\n .catch((error: Error) => {\n reject(new Error(error.message));\n });\n },\n );\n\n if (!session) return;\n this.setChainIds(this.rpc.chains);\n const accounts = getAccountsFromNamespaces(session.namespaces, [this.namespace]);\n this.setAccounts(accounts);\n this.events.emit(\"connect\", { chainId: toHexChainId(this.chainId) });\n } catch (error) {\n this.signer.logger.error(error);\n throw error;\n } finally {\n if (this.modal) this.modal.closeModal();\n }\n }\n\n public async disconnect(): Promise<void> {\n if (this.session) {\n await this.signer.disconnect();\n }\n this.reset();\n }\n\n public on: IEthereumProviderEvents[\"on\"] = (event, listener) => {\n this.events.on(event, listener);\n return this;\n };\n\n public once: IEthereumProviderEvents[\"once\"] = (event, listener) => {\n this.events.once(event, listener);\n return this;\n };\n\n public removeListener: IEthereumProviderEvents[\"removeListener\"] = (event, listener) => {\n this.events.removeListener(event, listener);\n return this;\n };\n\n public off: IEthereumProviderEvents[\"off\"] = (event, listener) => {\n this.events.off(event, listener);\n return this;\n };\n\n get isWalletConnect() {\n return true;\n }\n\n get session() {\n return this.signer.session;\n }\n // ---------- Private ----------------------------------------------- //\n\n private registerEventListeners() {\n this.signer.on(\"session_event\", (payload: SignClientTypes.EventArguments[\"session_event\"]) => {\n const { params } = payload;\n const { event } = params;\n if (event.name === \"accountsChanged\") {\n this.accounts = this.parseAccounts(event.data);\n this.events.emit(\"accountsChanged\", this.accounts);\n } else if (event.name === \"chainChanged\") {\n this.setChainId(this.formatChainId(event.data));\n } else {\n this.events.emit(event.name as any, event.data);\n }\n this.events.emit(\"session_event\", payload);\n });\n\n this.signer.on(\"chainChanged\", (chainId: string) => {\n const chain = parseInt(chainId);\n this.chainId = chain;\n this.events.emit(\"chainChanged\", toHexChainId(this.chainId));\n this.persist();\n });\n\n this.signer.on(\n \"session_update\",\n (payload: SignClientTypes.EventArguments[\"session_update\"]) => {\n this.events.emit(\"session_update\", payload);\n },\n );\n\n this.signer.on(\n \"session_delete\",\n (payload: SignClientTypes.EventArguments[\"session_delete\"]) => {\n this.reset();\n this.events.emit(\"session_delete\", payload);\n this.events.emit(\"disconnect\", {\n ...getSdkError(\"USER_DISCONNECTED\"),\n data: payload.topic,\n name: \"USER_DISCONNECTED\",\n });\n },\n );\n\n this.signer.on(\"display_uri\", (uri: string) => {\n if (this.rpc.showQrModal) {\n // to refresh the QR we have to close the modal and open it again\n // until proper API is provided by web3modal\n this.modal?.closeModal();\n this.modal?.openModal({ uri });\n }\n this.events.emit(\"display_uri\", uri);\n });\n }\n\n private setHttpProvider(chainId: number): void {\n this.request({\n method: \"wallet_switchEthereumChain\",\n params: [{ chainId: chainId.toString(16) }],\n });\n }\n\n private isCompatibleChainId(chainId: string): boolean {\n return typeof chainId === \"string\" ? chainId.startsWith(`${this.namespace}:`) : false;\n }\n\n private formatChainId(chainId: number): string {\n return `${this.namespace}:${chainId}`;\n }\n\n private parseChainId(chainId: string): number {\n return Number(chainId.split(\":\")[1]);\n }\n\n private setChainIds(chains: string[]) {\n const compatible = chains.filter((x) => this.isCompatibleChainId(x));\n const chainIds = compatible.map((c) => this.parseChainId(c));\n if (chainIds.length) {\n this.chainId = chainIds[0];\n this.events.emit(\"chainChanged\", toHexChainId(this.chainId));\n this.persist();\n }\n }\n\n private setChainId(chain: string) {\n if (this.isCompatibleChainId(chain)) {\n const chainId = this.parseChainId(chain);\n this.chainId = chainId;\n this.setHttpProvider(chainId);\n }\n }\n\n private parseAccountId(account: string): { chainId: string; address: string } {\n const [namespace, reference, address] = account.split(\":\");\n const chainId = `${namespace}:${reference}`;\n return { chainId, address };\n }\n\n private setAccounts(accounts: string[]) {\n this.accounts = accounts\n .filter((x) => this.parseChainId(this.parseAccountId(x).chainId) === this.chainId)\n .map((x) => this.parseAccountId(x).address);\n this.events.emit(\"accountsChanged\", this.accounts);\n }\n\n private getRpcConfig(opts: EthereumProviderOptions): EthereumRpcConfig {\n return {\n chains: opts.chains?.map((chain) => this.formatChainId(chain)) || [`${this.namespace}:1`],\n optionalChains: opts.optionalChains\n ? opts.optionalChains.map((chain) => this.formatChainId(chain))\n : undefined,\n methods: opts?.methods || REQUIRED_METHODS,\n events: opts?.events || REQUIRED_EVENTS,\n optionalMethods: opts?.optionalMethods || [],\n optionalEvents: opts?.optionalEvents || [],\n rpcMap:\n opts?.rpcMap ||\n this.buildRpcMap(opts.chains.concat(opts.optionalChains || []), opts.projectId),\n showQrModal: opts?.showQrModal ?? true,\n projectId: opts.projectId,\n metadata: opts.metadata,\n };\n }\n\n private buildRpcMap(chains: number[], projectId: string): EthereumRpcMap {\n const map: EthereumRpcMap = {};\n chains.forEach((chain) => {\n map[chain] = this.getRpcUrl(chain, projectId);\n });\n return map;\n }\n\n private async initialize(opts: EthereumProviderOptions) {\n this.rpc = this.getRpcConfig(opts);\n this.chainId = getEthereumChainId(this.rpc.chains);\n this.signer = await UniversalProvider.init({\n projectId: this.rpc.projectId,\n metadata: this.rpc.metadata,\n });\n this.registerEventListeners();\n await this.loadPersistedSession();\n if (this.rpc.showQrModal) {\n try {\n const { Web3Modal } = await import(\"@web3modal/standalone\");\n this.modal = new Web3Modal({\n walletConnectVersion: 2,\n projectId: this.rpc.projectId,\n standaloneChains: this.rpc.chains,\n themeMode: this.rpc.qrModalOptions?.themeMode,\n themeVariables: this.rpc.qrModalOptions?.themeVariables,\n });\n } catch {\n throw new Error(\"To use QR modal, please install @web3modal/standalone package\");\n }\n }\n }\n\n private loadConnectOpts(opts?: ConnectOps) {\n if (!opts) return;\n const { chains, optionalChains, rpcMap } = opts;\n if (chains && isValidArray(chains)) {\n this.rpc.chains = chains.map((chain) => this.formatChainId(chain));\n chains.forEach((chain) => {\n this.rpc.rpcMap[chain] = rpcMap?.[chain] || this.getRpcUrl(chain);\n });\n }\n if (optionalChains && isValidArray(optionalChains)) {\n this.rpc.optionalChains = [];\n this.rpc.optionalChains = optionalChains?.map((chain) => this.formatChainId(chain));\n optionalChains.forEach((chain) => {\n this.rpc.rpcMap[chain] = rpcMap?.[chain] || this.getRpcUrl(chain);\n });\n }\n }\n\n private getRpcUrl(chainId: number, projectId?: string): string {\n const providedRpc = this.rpc.rpcMap?.[chainId];\n return (\n providedRpc ||\n `${RPC_URL}?chainId=eip155:${chainId}&projectId=${projectId || this.rpc.projectId}`\n );\n }\n\n private async loadPersistedSession() {\n if (!this.session) return;\n const chainId = await this.signer.client.core.storage.getItem(`${this.STORAGE_KEY}/chainId`);\n this.setChainIds(\n chainId ? [this.formatChainId(chainId)] : this.session.namespaces[this.namespace].accounts,\n );\n this.setAccounts(this.session.namespaces[this.namespace].accounts);\n }\n\n private reset() {\n this.chainId = 1;\n this.accounts = [];\n }\n\n private persist() {\n if (!this.session) return;\n this.signer.client.core.storage.setItem(`${this.STORAGE_KEY}/chainId`, this.chainId);\n }\n\n private parseAccounts(payload: string | string[]): string[] {\n if (typeof payload === \"string\" || payload instanceof String) {\n return [this.parseAccount(payload)];\n }\n return payload.map((account: string) => this.parseAccount(account));\n }\n\n private parseAccount = (payload: any): string => {\n return this.isCompatibleChainId(payload) ? this.parseAccountId(payload).address : payload;\n };\n}\n\nexport default EthereumProvider;\n","import { EthereumProvider as Provider } from \"./EthereumProvider\";\nexport const EthereumProvider = Provider;\nexport type { RpcEvent, RpcMethod } from \"./EthereumProvider\";\nexport * from \"./constants/rpc\";\nexport default Provider;\n"],"names":["chains","chainId","params","optionalChains","methods","optionalMethods","events","optionalEvents","rpcMap","isValidArray","requiredChains","requriedMethods","REQUIRED_METHODS","requiredEvents","REQUIRED_EVENTS","requiredRpcMap","required","eventsRequiringPermissions","event","methodsRequiringPermissions","shouldIncludeRequiredChains","optional","EthereumProvider","EventEmitter","STORAGE_KEY","listener","payload","opts","provider","args","callback","session","resolve","reject","_a","state","__spreadProps","__spreadValues","error","accounts","getAccountsFromNamespaces","chain","getSdkError","uri","_b","chainIds","x","c","account","namespace","reference","address","projectId","map","UniversalProvider","Web3Modal","e","RPC_URL","Provider"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAa,MAAA,QAAA,CAAW,IACX,CACA,OAAA,CAAU,mBACV,CAAA,WAAA,CAAc,CAAG,EAAA,QAAA,CAAA,CAAA,EAAY,CAAc,CAAA,CAAA,EAAA,OAAA,CAAA,CAAA,CAAA,CAC3C,OAAU,CAAA;;ACJhB,MAAM,gBAAmB,CAAA,CAAC,qBAAuB,CAAA,eAAe,EAC1D,gBAAmB,CAAA,CAC9B,cACA,CAAA,qBAAA,CACA,WACA,gBACA,CAAA,wBAAA,CACA,UACA,CAAA,qBAAA,CACA,oBACA,sBACA,CAAA,sBAAA,CACA,4BACA,CAAA,yBAAA,CACA,uBACA,CAAA,2BAAA,CACA,2BACA,CAAA,mBAAA,CACA,mBACF,CACa,CAAA,eAAA,CAAkB,CAAC,cAAA,CAAgB,iBAAiB,CACpD,CAAA,eAAA,CAAkB,CAAC,SAAA,CAAW,aAAc,SAAS;;ACrBlE,IAAA,CAAA,CAAA,MAAA,CAAA,cAAA,CAAA,CAAA,CAAA,MAAA,CAAA,gBAAA,CAAA,IAAA,CAAA,CAAA,MAAA,CAAA,yBAAA,CAAA,IAAA,CAAA,CAAA,MAAA,CAAA,qBAAA,CAAA,IAAA,CAAA,CAAA,MAAA,CAAA,SAAA,CAAA,cAAA,CAAA,CAAA,CAAA,MAAA,CAAA,SAAA,CAAA,oBAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,UAAA,CAAA,CAAA,CAAA,CAAA,YAAA,CAAA,CAAA,CAAA,CAAA,QAAA,CAAA,CAAA,CAAA,CAAA,KAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,IAAA,IAAA,CAAA,IAAA,CAAA,GAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,IAAA,IAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,CAAA,EAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,OAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAgFgB,SAAA,kBAAA,CAAmBA,EAA0B,CAC3D,OAAO,OAAOA,CAAO,CAAA,CAAC,CAAE,CAAA,KAAA,CAAM,GAAG,CAAE,CAAA,CAAC,CAAC,CACvC,UAEgB,YAAaC,CAAAA,CAAAA,CAAyB,CACpD,OAAO,KAAKA,CAAQ,CAAA,QAAA,CAAS,EAAE,CACjC,CAAA,CAAA,UAYgB,eAAgBC,CAAAA,CAAAA,CAG9B,CACA,KAAM,CAAE,OAAAF,CAAQ,CAAA,cAAA,CAAAG,EAAgB,OAAAC,CAAAA,CAAAA,CAAS,gBAAAC,CAAiB,CAAA,MAAA,CAAAC,CAAQ,CAAA,cAAA,CAAAC,EAAgB,MAAAC,CAAAA,CAAO,EACvFN,CACF,CAAA,GAAI,CAACO,kBAAaT,CAAAA,CAAM,CACtB,CAAA,MAAM,IAAI,KAAM,CAAA,gBAAgB,EAGlC,MAAMU,CAAAA,CAAiBV,EACjBW,CAAkBP,CAAAA,CAAAA,EAAWQ,gBAC7BC,CAAAA,CAAAA,CAAiBP,GAAUQ,eAC3BC,CAAAA,CAAAA,CAAiB,CACrB,CAAC,kBAAA,CAAmBL,CAAc,CAAC,EAAGF,EAAO,kBAAmBE,CAAAA,CAAc,CAAC,CACjF,CAAA,CAEMM,EAAsB,CAC1B,MAAA,CAAQN,EACR,OAASC,CAAAA,CAAAA,CACT,MAAQE,CAAAA,CAAAA,CACR,OAAQE,CACV,CAAA,CAIME,EAA6BX,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAQ,MAAQY,CAAAA,CAAAA,EAAU,CAACJ,eAAgB,CAAA,QAAA,CAASI,CAAK,CACtFC,CAAAA,CAAAA,CAAAA,CAA8Bf,GAAA,IAAAA,CAAAA,KAAAA,CAAAA,CAAAA,CAAAA,CAAS,OAAQc,CAAU,EAAA,CAACN,gBAAiB,CAAA,QAAA,CAASM,CAAK,CAE/F,CAAA,CAAA,GACE,CAACf,CACD,EAAA,CAACI,GACD,CAACF,CAAAA,EACD,EAACY,CAAA,EAAA,IAAA,EAAAA,EAA4B,MAC7B,CAAA,EAAA,EAACE,GAAA,IAAAA,EAAAA,CAAAA,CAA6B,QAE9B,OAAO,CAAE,QAAAH,CAAAA,CAAS,EAOpB,MAAMI,CAAAA,CAAAA,CACHH,GAAA,IAAAA,CAAAA,KAAAA,CAAAA,CAAAA,CAAAA,CAA4B,UAAUE,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,CAA6B,CAAA,MAAA,CAAA,EAAW,CAAChB,CAE5EkB,CAAAA,CAAAA,CAAsB,CAC1B,MAAQ,CAAA,CACN,GAAG,IAAI,GAAA,CACLD,CAA8BV,CAAAA,CAAAA,CAAe,OAAOP,CAAkB,EAAA,EAAE,CAAIA,CAAAA,CAC9E,CACF,CACA,CAAA,OAAA,CAAS,CAAC,GAAG,IAAI,IAAIQ,CAAgB,CAAA,MAAA,CAAON,GAAmB,EAAE,CAAC,CAAC,CAAA,CACnE,MAAQ,CAAA,CAAC,GAAG,IAAI,GAAA,CAAIQ,EAAe,MAAON,CAAAA,CAAAA,EAAkB,EAAE,CAAC,CAAC,CAAA,CAChE,OAAAC,CACF,CAAA,CAEA,OAAO,CAAE,QAAA,CAAAQ,EAAU,QAAAK,CAAAA,CAAS,CAC9B,OAgCaC,kBAA8C,CAWzD,aAAc,CAVd,IAAA,CAAO,OAAS,IAAIC,mBAAAA,CACpB,KAAO,SAAY,CAAA,QAAA,CACnB,KAAO,QAAqB,CAAA,GAE5B,IAAO,CAAA,OAAA,CAAU,EAIjB,IAAiB,CAAA,WAAA,CAAcC,WAqG/B,CAAA,IAAA,CAAO,GAAoC,CAACN,CAAAA,CAAOO,KACjD,IAAK,CAAA,MAAA,CAAO,GAAGP,CAAOO,CAAAA,CAAQ,CACvB,CAAA,IAAA,CAAA,CAGT,KAAO,IAAwC,CAAA,CAACP,EAAOO,CACrD,IAAA,IAAA,CAAK,OAAO,IAAKP,CAAAA,CAAAA,CAAOO,CAAQ,CAAA,CACzB,MAGT,IAAO,CAAA,cAAA,CAA4D,CAACP,CAAOO,CAAAA,CAAAA,IACzE,KAAK,MAAO,CAAA,cAAA,CAAeP,EAAOO,CAAQ,CAAA,CACnC,MAGT,IAAO,CAAA,GAAA,CAAsC,CAACP,CAAOO,CAAAA,CAAAA,IACnD,KAAK,MAAO,CAAA,GAAA,CAAIP,CAAOO,CAAAA,CAAQ,EACxB,IA2NT,CAAA,CAAA,IAAA,CAAQ,aAAgBC,CACf,EAAA,IAAA,CAAK,oBAAoBA,CAAO,CAAA,CAAI,KAAK,cAAeA,CAAAA,CAAO,EAAE,OAAUA,CAAAA,CAAAA,CA9UlF,KAAK,MAAS,CAAA,GACd,IAAK,CAAA,GAAA,CAAM,GACb,CAEA,aAAa,IAAA,CAAKC,EAA0D,CAC1E,MAAMC,EAAW,IAAIN,kBAAA,CACrB,aAAMM,CAAS,CAAA,UAAA,CAAWD,CAAI,CACvBC,CAAAA,CACT,CAEA,MAAa,OAAA,CAAqBC,EAAoC,CACpE,OAAO,MAAM,IAAA,CAAK,OAAO,OAAQA,CAAAA,CAAAA,CAAM,KAAK,aAAc,CAAA,IAAA,CAAK,OAAO,CAAC,CACzE,CAEO,SAAA,CACLA,EACAC,CACM,CAAA,CACN,KAAK,MAAO,CAAA,SAAA,CAAUD,EAAMC,CAAU,CAAA,IAAA,CAAK,aAAc,CAAA,IAAA,CAAK,OAAO,CAAC,EACxE,CAEA,IAAI,SAAA,EAAqB,CACvB,OAAK,IAAA,CAAK,OAAO,MACV,CAAA,IAAA,CAAK,OAAO,MAAO,CAAA,IAAA,CAAK,QAAQ,SADP,CAAA,CAAA,CAElC,CAEA,IAAI,UAAA,EAAsB,CACxB,OAAK,KAAK,MAAO,CAAA,MAAA,CACV,KAAK,MAAO,CAAA,MAAA,CAAO,KAAK,OAAQ,CAAA,UAAA,CADP,CAElC,CAAA,CAEA,MAAa,MAAoC,EAAA,CAC/C,OAAK,IAAK,CAAA,OAAA,EAAS,MAAM,IAAK,CAAA,OAAA,EACb,CAAA,MAAM,KAAK,OAAQ,CAAA,CAAE,OAAQ,qBAAsB,CAAC,CAEvE,CAEA,MAAa,QAAQH,CAAkC,CAAA,CACrD,GAAI,CAAC,IAAA,CAAK,OAAO,MACf,CAAA,MAAM,IAAI,KAAM,CAAA,6CAA6C,CAG/D,CAAA,IAAA,CAAK,gBAAgBA,CAAI,CAAA,CACzB,KAAM,CAAE,QAAA,CAAAX,EAAU,QAAAK,CAAAA,CAAS,CAAI,CAAA,eAAA,CAAgB,KAAK,GAAG,CAAA,CACvD,GAAI,CACF,MAAMU,EAAU,MAAM,IAAI,OACxB,CAAA,MAAOC,EAASC,CAAW,GAAA,CAvPnC,IAAAC,CAwPc,CAAA,IAAA,CAAK,IAAI,WACXA,GAAAA,CAAAA,CAAAA,CAAA,KAAK,KAAL,GAAA,IAAA,EAAAA,EAAY,cAAgBC,CAAAA,CAAAA,EAAU,CAEhC,CAACA,CAAAA,CAAM,MAAQ,CAAC,IAAA,CAAK,MAAO,CAAA,OAAA,GAC9B,KAAK,MAAO,CAAA,mBAAA,GACZF,CAAO,CAAA,IAAI,MAAM,6CAA6C,CAAC,GAEnE,CAEF,CAAA,CAAA,CAAA,MAAM,KAAK,MACR,CAAA,OAAA,CAAQG,EAAAC,CAAA,CAAA,CACP,WAAY,CACV,CAAC,IAAK,CAAA,SAAS,EAAGrB,CACpB,CAAA,CAAA,CACIK,GAAY,CACd,kBAAA,CAAoB,CAClB,CAAC,IAAA,CAAK,SAAS,EAAGA,CACpB,CACF,CARO,CAAA,CAAA,CASP,aAAcM,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAM,YACtB,CAAA,CAAC,CACA,CAAA,IAAA,CAAMI,GAAY,CACjBC,CAAAA,CAAQD,CAAO,EACjB,CAAC,EACA,KAAOO,CAAAA,CAAAA,EAAiB,CACvBL,CAAAA,CAAO,IAAI,KAAMK,CAAAA,CAAAA,CAAM,OAAO,CAAC,EACjC,CAAC,EACL,CACF,CAEA,CAAA,GAAI,CAACP,CAAS,CAAA,OACd,KAAK,WAAY,CAAA,IAAA,CAAK,IAAI,MAAM,CAAA,CAChC,MAAMQ,CAAWC,CAAAA,+BAAAA,CAA0BT,EAAQ,UAAY,CAAA,CAAC,KAAK,SAAS,CAAC,EAC/E,IAAK,CAAA,WAAA,CAAYQ,CAAQ,CAAA,CACzB,KAAK,MAAO,CAAA,IAAA,CAAK,UAAW,CAAE,OAAA,CAAS,aAAa,IAAK,CAAA,OAAO,CAAE,CAAC,EACrE,CAASD,MAAAA,CAAAA,CAAP,CACA,MAAK,IAAA,CAAA,MAAA,CAAO,OAAO,KAAMA,CAAAA,CAAK,CACxBA,CAAAA,CACR,QAAE,CACI,IAAA,CAAK,OAAO,IAAK,CAAA,KAAA,CAAM,aAC7B,CACF,CAEA,MAAa,UAAA,EAA4B,CACnC,IAAK,CAAA,OAAA,EACP,MAAM,IAAK,CAAA,MAAA,CAAO,YAEpB,CAAA,IAAA,CAAK,KAAM,GACb,CAsBA,IAAI,eAAA,EAAkB,CACpB,OAAO,CAAA,CACT,CAEA,IAAI,OAAA,EAAU,CACZ,OAAO,KAAK,MAAO,CAAA,OACrB,CAGQ,sBAAyB,EAAA,CAC/B,KAAK,MAAO,CAAA,EAAA,CAAG,eAAkBZ,CAAAA,CAAAA,EAA6D,CAC5F,KAAM,CAAE,OAAAxB,CAAO,CAAA,CAAIwB,EACb,CAAE,KAAA,CAAAR,CAAM,CAAIhB,CAAAA,CAAAA,CACdgB,EAAM,IAAS,GAAA,iBAAA,EACjB,KAAK,QAAW,CAAA,IAAA,CAAK,cAAcA,CAAM,CAAA,IAAI,CAC7C,CAAA,IAAA,CAAK,OAAO,IAAK,CAAA,iBAAA,CAAmB,KAAK,QAAQ,CAAA,EACxCA,EAAM,IAAS,GAAA,cAAA,CACxB,KAAK,UAAW,CAAA,IAAA,CAAK,cAAcA,CAAM,CAAA,IAAI,CAAC,CAE9C,CAAA,IAAA,CAAK,OAAO,IAAKA,CAAAA,CAAAA,CAAM,IAAaA,CAAAA,CAAAA,CAAM,IAAI,CAEhD,CAAA,IAAA,CAAK,OAAO,IAAK,CAAA,eAAA,CAAiBQ,CAAO,EAC3C,CAAC,EAED,IAAK,CAAA,MAAA,CAAO,GAAG,cAAiBzB,CAAAA,CAAAA,EAAoB,CAClD,MAAMwC,CAAAA,CAAQ,SAASxC,CAAO,CAAA,CAC9B,IAAK,CAAA,OAAA,CAAUwC,EACf,IAAK,CAAA,MAAA,CAAO,KAAK,cAAgB,CAAA,YAAA,CAAa,KAAK,OAAO,CAAC,CAC3D,CAAA,IAAA,CAAK,UACP,CAAC,EAED,IAAK,CAAA,MAAA,CAAO,GACV,gBACCf,CAAAA,CAAAA,EAA8D,CAC7D,IAAA,CAAK,OAAO,IAAK,CAAA,gBAAA,CAAkBA,CAAO,EAC5C,CACF,EAEA,IAAK,CAAA,MAAA,CAAO,GACV,gBACCA,CAAAA,CAAAA,EAA8D,CAC7D,IAAK,CAAA,KAAA,GACL,IAAK,CAAA,MAAA,CAAO,KAAK,gBAAkBA,CAAAA,CAAO,CAC1C,CAAA,IAAA,CAAK,OAAO,IAAK,CAAA,YAAA,CAAcU,EAAAC,CAAA,CAAA,EAAA,CAC1BK,kBAAY,mBAAmB,CAAA,CAAA,CADL,CAE7B,IAAA,CAAMhB,EAAQ,KACd,CAAA,IAAA,CAAM,mBACR,CAAC,CAAA,EACH,CACF,CAEA,CAAA,IAAA,CAAK,MAAO,CAAA,EAAA,CAAG,cAAgBiB,CAAgB,EAAA,CAjXnD,IAAAT,CAAAU,CAAAA,CAAAA,CAkXU,KAAK,GAAI,CAAA,WAAA,GAAA,CAGXV,EAAA,IAAK,CAAA,KAAA,GAAL,MAAAA,CAAY,CAAA,UAAA,EAAA,CAAA,CACZU,EAAA,IAAK,CAAA,KAAA,GAAL,MAAAA,CAAY,CAAA,SAAA,CAAU,CAAE,GAAA,CAAAD,CAAI,CAE9B,CAAA,CAAA,CAAA,IAAA,CAAK,OAAO,IAAK,CAAA,aAAA,CAAeA,CAAG,EACrC,CAAC,EACH,CAEQ,gBAAgB1C,CAAuB,CAAA,CAC7C,KAAK,OAAQ,CAAA,CACX,OAAQ,4BACR,CAAA,MAAA,CAAQ,CAAC,CAAE,QAASA,CAAQ,CAAA,QAAA,CAAS,EAAE,CAAE,CAAC,CAC5C,CAAC,EACH,CAEQ,mBAAoBA,CAAAA,CAAAA,CAA0B,CACpD,OAAO,OAAOA,GAAY,QAAWA,CAAAA,CAAAA,CAAQ,WAAW,CAAG,EAAA,IAAA,CAAK,SAAY,CAAA,CAAA,CAAA,CAAA,CAAI,EAClF,CAEQ,aAAA,CAAcA,EAAyB,CAC7C,OAAO,GAAG,IAAK,CAAA,SAAA,CAAA,CAAA,EAAaA,GAC9B,CAEQ,YAAA,CAAaA,EAAyB,CAC5C,OAAO,OAAOA,CAAQ,CAAA,KAAA,CAAM,GAAG,CAAE,CAAA,CAAC,CAAC,CACrC,CAEQ,WAAYD,CAAAA,CAAAA,CAAkB,CAEpC,MAAM6C,CAAAA,CADa7C,EAAO,MAAQ8C,CAAAA,CAAAA,EAAM,KAAK,mBAAoBA,CAAAA,CAAC,CAAC,CACvC,CAAA,GAAA,CAAKC,GAAM,IAAK,CAAA,YAAA,CAAaA,CAAC,CAAC,CAAA,CACvDF,CAAS,CAAA,MAAA,GACX,KAAK,OAAUA,CAAAA,CAAAA,CAAS,CAAC,CACzB,CAAA,IAAA,CAAK,OAAO,IAAK,CAAA,cAAA,CAAgB,YAAa,CAAA,IAAA,CAAK,OAAO,CAAC,CAAA,CAC3D,KAAK,OAAQ,EAAA,EAEjB,CAEQ,UAAWJ,CAAAA,CAAAA,CAAe,CAChC,GAAI,KAAK,mBAAoBA,CAAAA,CAAK,EAAG,CACnC,MAAMxC,EAAU,IAAK,CAAA,YAAA,CAAawC,CAAK,CACvC,CAAA,IAAA,CAAK,QAAUxC,CACf,CAAA,IAAA,CAAK,gBAAgBA,CAAO,EAC9B,CACF,CAEQ,cAAA,CAAe+C,CAAuD,CAAA,CAC5E,KAAM,CAACC,CAAAA,CAAWC,EAAWC,CAAO,CAAA,CAAIH,EAAQ,KAAM,CAAA,GAAG,CAEzD,CAAA,OAAO,CAAE,OADO,CAAA,CAAA,EAAGC,KAAaC,CACd,CAAA,CAAA,CAAA,OAAA,CAAAC,CAAQ,CAC5B,CAEQ,WAAYZ,CAAAA,CAAAA,CAAoB,CACtC,IAAK,CAAA,QAAA,CAAWA,EACb,MAAQO,CAAAA,CAAAA,EAAM,KAAK,YAAa,CAAA,IAAA,CAAK,eAAeA,CAAC,CAAA,CAAE,OAAO,CAAM,GAAA,IAAA,CAAK,OAAO,CAChF,CAAA,GAAA,CAAKA,GAAM,IAAK,CAAA,cAAA,CAAeA,CAAC,CAAA,CAAE,OAAO,CAC5C,CAAA,IAAA,CAAK,OAAO,IAAK,CAAA,iBAAA,CAAmB,KAAK,QAAQ,EACnD,CAEQ,YAAA,CAAanB,EAAkD,CA9azE,IAAAO,EAAAU,CA+aI,CAAA,OAAO,CACL,MAAQV,CAAAA,CAAAA,CAAAA,CAAAA,CAAAP,CAAK,CAAA,MAAA,GAAL,YAAAO,CAAa,CAAA,GAAA,CAAKO,GAAU,IAAK,CAAA,aAAA,CAAcA,CAAK,CAAM,CAAA,GAAA,CAAC,GAAG,IAAK,CAAA,SAAA,CAAA,EAAA,CAAa,EACxF,cAAgBd,CAAAA,CAAAA,CAAK,eACjBA,CAAK,CAAA,cAAA,CAAe,IAAKc,CAAU,EAAA,IAAA,CAAK,aAAcA,CAAAA,CAAK,CAAC,CAC5D,CAAA,KAAA,CAAA,CACJ,SAASd,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAM,OAAWf,GAAAA,gBAAAA,CAC1B,QAAQe,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAM,MAAUb,GAAAA,eAAAA,CACxB,iBAAiBa,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAM,eAAmB,GAAA,EAC1C,CAAA,cAAA,CAAA,CAAgBA,GAAA,IAAAA,CAAAA,KAAAA,CAAAA,CAAAA,CAAAA,CAAM,iBAAkB,EAAC,CACzC,QACEA,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAM,MACN,GAAA,IAAA,CAAK,YAAYA,CAAK,CAAA,MAAA,CAAO,OAAOA,CAAK,CAAA,cAAA,EAAkB,EAAE,CAAA,CAAGA,CAAK,CAAA,SAAS,EAChF,WAAaiB,CAAAA,CAAAA,CAAAA,CAAAjB,GAAA,IAAAA,CAAAA,KAAAA,CAAAA,CAAAA,CAAAA,CAAM,cAAN,IAAAiB,CAAAA,CAAAA,CAAqB,CAClC,CAAA,CAAA,SAAA,CAAWjB,EAAK,SAChB,CAAA,QAAA,CAAUA,EAAK,QACjB,CACF,CAEQ,WAAY3B,CAAAA,CAAAA,CAAkBoD,CAAmC,CAAA,CACvE,MAAMC,CAAsB,CAAA,GAC5B,OAAArD,CAAAA,CAAO,QAASyC,CAAU,EAAA,CACxBY,EAAIZ,CAAK,CAAA,CAAI,KAAK,SAAUA,CAAAA,CAAAA,CAAOW,CAAS,EAC9C,CAAC,EACMC,CACT,CAEA,MAAc,UAAA,CAAW1B,EAA+B,CAzc1D,IAAAO,EAAAU,CAkdI,CAAA,GARA,KAAK,GAAM,CAAA,IAAA,CAAK,YAAajB,CAAAA,CAAI,EACjC,IAAK,CAAA,OAAA,CAAU,mBAAmB,IAAK,CAAA,GAAA,CAAI,MAAM,CACjD,CAAA,IAAA,CAAK,MAAS,CAAA,MAAM2B,oCAAkB,IAAK,CAAA,CACzC,UAAW,IAAK,CAAA,GAAA,CAAI,UACpB,QAAU,CAAA,IAAA,CAAK,IAAI,QACrB,CAAC,EACD,IAAK,CAAA,sBAAA,GACL,MAAM,IAAA,CAAK,sBACP,CAAA,IAAA,CAAK,GAAI,CAAA,WAAA,CACX,GAAI,CACF,KAAM,CAAE,SAAAC,CAAAA,CAAU,EAAI,MAAM,mFAAO,uBAAuB,MAAA,CAC1D,KAAK,KAAQ,CAAA,IAAIA,EAAU,CACzB,oBAAA,CAAsB,EACtB,SAAW,CAAA,IAAA,CAAK,GAAI,CAAA,SAAA,CACpB,iBAAkB,IAAK,CAAA,GAAA,CAAI,OAC3B,SAAWrB,CAAAA,CAAAA,CAAAA,CAAA,KAAK,GAAI,CAAA,cAAA,GAAT,YAAAA,CAAyB,CAAA,SAAA,CACpC,gBAAgBU,CAAA,CAAA,IAAA,CAAK,IAAI,cAAT,GAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAyB,cAC3C,CAAC,EACH,CAAA,MAAQY,EAAN,CACA,MAAM,IAAI,KAAM,CAAA,+DAA+D,CACjF,CAEJ,CAEQ,gBAAgB7B,CAAmB,CAAA,CACzC,GAAI,CAACA,CAAAA,CAAM,OACX,KAAM,CAAE,OAAA3B,CAAQ,CAAA,cAAA,CAAAG,CAAgB,CAAA,MAAA,CAAAK,CAAO,CAAImB,CAAAA,CAAAA,CACvC3B,GAAUS,kBAAaT,CAAAA,CAAM,IAC/B,IAAK,CAAA,GAAA,CAAI,OAASA,CAAO,CAAA,GAAA,CAAKyC,GAAU,IAAK,CAAA,aAAA,CAAcA,CAAK,CAAC,CAAA,CACjEzC,EAAO,OAASyC,CAAAA,CAAAA,EAAU,CACxB,IAAA,CAAK,IAAI,MAAOA,CAAAA,CAAK,GAAIjC,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAASiC,CAAU,CAAA,GAAA,IAAA,CAAK,SAAUA,CAAAA,CAAK,EAClE,CAAC,CAAA,CAAA,CAECtC,GAAkBM,kBAAaN,CAAAA,CAAc,IAC/C,IAAK,CAAA,GAAA,CAAI,cAAiB,CAAA,GAC1B,IAAK,CAAA,GAAA,CAAI,eAAiBA,CAAA,EAAA,IAAA,CAAA,KAAA,CAAA,CAAAA,EAAgB,GAAKsC,CAAAA,CAAAA,EAAU,KAAK,aAAcA,CAAAA,CAAK,GACjFtC,CAAe,CAAA,OAAA,CAASsC,GAAU,CAChC,IAAA,CAAK,IAAI,MAAOA,CAAAA,CAAK,CAAIjC,CAAAA,CAAAA,CAAAA,EAAA,YAAAA,CAASiC,CAAAA,CAAAA,CAAAA,GAAU,KAAK,SAAUA,CAAAA,CAAK,EAClE,CAAC,CAAA,EAEL,CAEQ,SAAUxC,CAAAA,CAAAA,CAAiBmD,EAA4B,CApfjE,IAAAlB,EAsfI,OADoBA,CAAAA,CAAAA,CAAAA,CAAA,KAAK,GAAI,CAAA,MAAA,GAAT,IAAAA,CAAAA,KAAAA,CAAAA,CAAAA,CAAAA,CAAkBjC,KAGpC,CAAGwD,EAAAA,OAAAA,CAAAA,gBAAAA,EAA0BxD,eAAqBmD,CAAa,EAAA,IAAA,CAAK,IAAI,SAE5E,CAAA,CAAA,CAEA,MAAc,oBAAuB,EAAA,CACnC,GAAI,CAAC,IAAA,CAAK,QAAS,OACnB,MAAMnD,EAAU,MAAM,IAAA,CAAK,MAAO,CAAA,MAAA,CAAO,KAAK,OAAQ,CAAA,OAAA,CAAQ,GAAG,IAAK,CAAA,WAAA,CAAA,QAAA,CAAqB,EAC3F,IAAK,CAAA,WAAA,CACHA,CAAU,CAAA,CAAC,KAAK,aAAcA,CAAAA,CAAO,CAAC,CAAI,CAAA,IAAA,CAAK,QAAQ,UAAW,CAAA,IAAA,CAAK,SAAS,CAAA,CAAE,QACpF,CACA,CAAA,IAAA,CAAK,YAAY,IAAK,CAAA,OAAA,CAAQ,WAAW,IAAK,CAAA,SAAS,EAAE,QAAQ,EACnE,CAEQ,KAAQ,EAAA,CACd,KAAK,OAAU,CAAA,CAAA,CACf,KAAK,QAAW,CAAA,GAClB,CAEQ,SAAU,CACX,IAAA,CAAK,SACV,IAAK,CAAA,MAAA,CAAO,OAAO,IAAK,CAAA,OAAA,CAAQ,QAAQ,CAAG,EAAA,IAAA,CAAK,sBAAuB,IAAK,CAAA,OAAO,EACrF,CAEQ,aAAA,CAAcyB,EAAsC,CAC1D,OAAI,OAAOA,CAAAA,EAAY,UAAYA,CAAmB,YAAA,MAAA,CAC7C,CAAC,IAAK,CAAA,YAAA,CAAaA,CAAO,CAAC,CAAA,CAE7BA,EAAQ,GAAKsB,CAAAA,CAAAA,EAAoB,KAAK,YAAaA,CAAAA,CAAO,CAAC,CACpE,CAKF;;ACxhBO,MAAM,iBAAmBU;;;;;;;;;"}
package/dist/index.es.js CHANGED
@@ -1,2 +1,344 @@
1
- import{EventEmitter as R}from"events";import{getAccountsFromNamespaces as S,getSdkError as T,isValidArray as v}from"@walletconnect/utils";import{UniversalProvider as P}from"@walletconnect/universal-provider";const j="wc",$="ethereum_provider",N=`${j}@${2}:${$}:`,D="https://rpc.walletconnect.com/v1/",p=["eth_sendTransaction","personal_sign"],q=["eth_accounts","eth_requestAccounts","eth_call","eth_getBalance","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode"],u=["chainChanged","accountsChanged"],U=["message","disconnect","connect"];var L=Object.defineProperty,Q=Object.defineProperties,H=Object.getOwnPropertyDescriptors,E=Object.getOwnPropertySymbols,G=Object.prototype.hasOwnProperty,K=Object.prototype.propertyIsEnumerable,_=(a,t,s)=>t in a?L(a,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):a[t]=s,y=(a,t)=>{for(var s in t||(t={}))G.call(t,s)&&_(a,s,t[s]);if(E)for(var s of E(t))K.call(t,s)&&_(a,s,t[s]);return a},O=(a,t)=>Q(a,H(t));function I(a){return Number(a[0].split(":")[1])}function C(a){return`0x${a.toString(16)}`}function V(a){const{chains:t,optionalChains:s,methods:i,optionalMethods:e,events:n,optionalEvents:c,rpcMap:h}=a;if(!v(t))throw new Error("Invalid chains");const o=t,r=i||p,w=n||u,b={[I(o)]:h[I(o)]},f={chains:o,methods:r,events:w,rpcMap:b},d=n?.filter(g=>!u.includes(g)),l=i?.filter(g=>!p.includes(g));if(!s&&!c&&!e&&!(d!=null&&d.length)&&!(l!=null&&l.length))return{required:f};const A=d?.length&&l?.length||!s,M={chains:[...new Set(A?o.concat(s||[]):s)],methods:[...new Set(r.concat(e||[]))],events:[...new Set(w.concat(c||[]))],rpcMap:h};return{required:f,optional:M}}class m{constructor(){this.events=new R,this.namespace="eip155",this.accounts=[],this.chainId=1,this.STORAGE_KEY=N,this.on=(t,s)=>(this.events.on(t,s),this),this.once=(t,s)=>(this.events.once(t,s),this),this.removeListener=(t,s)=>(this.events.removeListener(t,s),this),this.off=(t,s)=>(this.events.off(t,s),this),this.parseAccount=t=>this.isCompatibleChainId(t)?this.parseAccountId(t).address:t,this.signer={},this.rpc={}}static async init(t){const s=new m;return await s.initialize(t),s}async request(t){return await this.signer.request(t,this.formatChainId(this.chainId))}sendAsync(t,s){this.signer.sendAsync(t,s,this.formatChainId(this.chainId))}get connected(){return this.signer.client?this.signer.client.core.relayer.connected:!1}get connecting(){return this.signer.client?this.signer.client.core.relayer.connecting:!1}async enable(){return this.session||await this.connect(),await this.request({method:"eth_requestAccounts"})}async connect(t){if(!this.signer.client)throw new Error("Provider not initialized. Call init() first");this.loadConnectOpts(t);const{required:s,optional:i}=V(this.rpc);try{const e=await new Promise(async(c,h)=>{var o;this.rpc.showQrModal&&((o=this.modal)==null||o.subscribeModal(r=>{!r.open&&!this.signer.session&&(this.signer.abortPairingAttempt(),h(new Error("Connection request reset. Please try again.")))})),await this.signer.connect(O(y({namespaces:{[this.namespace]:s}},i&&{optionalNamespaces:{[this.namespace]:i}}),{pairingTopic:t?.pairingTopic})).then(r=>{c(r)}).catch(r=>{h(new Error(r.message))})});if(!e)return;this.setChainIds(this.rpc.chains);const n=S(e.namespaces,[this.namespace]);this.setAccounts(n),this.events.emit("connect",{chainId:C(this.chainId)})}catch(e){throw this.signer.logger.error(e),e}finally{this.modal&&this.modal.closeModal()}}async disconnect(){this.session&&await this.signer.disconnect(),this.reset()}get isWalletConnect(){return!0}get session(){return this.signer.session}registerEventListeners(){this.signer.on("session_event",t=>{const{params:s}=t,{event:i}=s;i.name==="accountsChanged"?(this.accounts=this.parseAccounts(i.data),this.events.emit("accountsChanged",this.accounts)):i.name==="chainChanged"?this.setChainId(this.formatChainId(i.data)):this.events.emit(i.name,i.data),this.events.emit("session_event",t)}),this.signer.on("chainChanged",t=>{const s=parseInt(t);this.chainId=s,this.events.emit("chainChanged",C(this.chainId)),this.persist()}),this.signer.on("session_update",t=>{this.events.emit("session_update",t)}),this.signer.on("session_delete",t=>{this.reset(),this.events.emit("session_delete",t),this.events.emit("disconnect",O(y({},T("USER_DISCONNECTED")),{data:t.topic,name:"USER_DISCONNECTED"}))}),this.signer.on("display_uri",t=>{var s,i;this.rpc.showQrModal&&((s=this.modal)==null||s.closeModal(),(i=this.modal)==null||i.openModal({uri:t})),this.events.emit("display_uri",t)})}setHttpProvider(t){this.request({method:"wallet_switchEthereumChain",params:[{chainId:t.toString(16)}]})}isCompatibleChainId(t){return typeof t=="string"?t.startsWith(`${this.namespace}:`):!1}formatChainId(t){return`${this.namespace}:${t}`}parseChainId(t){return Number(t.split(":")[1])}setChainIds(t){const s=t.filter(i=>this.isCompatibleChainId(i)).map(i=>this.parseChainId(i));s.length&&(this.chainId=s[0],this.events.emit("chainChanged",C(this.chainId)),this.persist())}setChainId(t){if(this.isCompatibleChainId(t)){const s=this.parseChainId(t);this.chainId=s,this.setHttpProvider(s)}}parseAccountId(t){const[s,i,e]=t.split(":");return{chainId:`${s}:${i}`,address:e}}setAccounts(t){this.accounts=t.filter(s=>this.parseChainId(this.parseAccountId(s).chainId)===this.chainId).map(s=>this.parseAccountId(s).address),this.events.emit("accountsChanged",this.accounts)}getRpcConfig(t){var s,i;return{chains:((s=t.chains)==null?void 0:s.map(e=>this.formatChainId(e)))||[`${this.namespace}:1`],optionalChains:t.optionalChains?t.optionalChains.map(e=>this.formatChainId(e)):void 0,methods:t?.methods||p,events:t?.events||u,optionalMethods:t?.optionalMethods||[],optionalEvents:t?.optionalEvents||[],rpcMap:t?.rpcMap||this.buildRpcMap(t.chains.concat(t.optionalChains||[]),t.projectId),showQrModal:(i=t?.showQrModal)!=null?i:!0,projectId:t.projectId,metadata:t.metadata}}buildRpcMap(t,s){const i={};return t.forEach(e=>{i[e]=this.getRpcUrl(e,s)}),i}async initialize(t){if(this.rpc=this.getRpcConfig(t),this.chainId=I(this.rpc.chains),this.signer=await P.init({projectId:this.rpc.projectId,metadata:this.rpc.metadata}),this.registerEventListeners(),await this.loadPersistedSession(),this.rpc.showQrModal){const{Web3Modal:s}=await import("@web3modal/standalone");this.modal=new s({walletConnectVersion:2,projectId:this.rpc.projectId,standaloneChains:this.rpc.chains})}}loadConnectOpts(t){if(!t)return;const{chains:s,optionalChains:i,rpcMap:e}=t;s&&v(s)&&(this.rpc.chains=s.map(n=>this.formatChainId(n)),s.forEach(n=>{this.rpc.rpcMap[n]=e?.[n]||this.getRpcUrl(n)})),i&&v(i)&&(this.rpc.optionalChains=[],this.rpc.optionalChains=i?.map(n=>this.formatChainId(n)),i.forEach(n=>{this.rpc.rpcMap[n]=e?.[n]||this.getRpcUrl(n)}))}getRpcUrl(t,s){var i;return((i=this.rpc.rpcMap)==null?void 0:i[t])||`${D}?chainId=eip155:${t}&projectId=${s||this.rpc.projectId}`}async loadPersistedSession(){if(!this.session)return;const t=await this.signer.client.core.storage.getItem(`${this.STORAGE_KEY}/chainId`);this.setChainIds(t?[this.formatChainId(t)]:this.session.namespaces[this.namespace].accounts),this.setAccounts(this.session.namespaces[this.namespace].accounts)}reset(){this.chainId=1,this.accounts=[]}persist(){this.session&&this.signer.client.core.storage.setItem(`${this.STORAGE_KEY}/chainId`,this.chainId)}parseAccounts(t){return typeof t=="string"||t instanceof String?[this.parseAccount(t)]:t.map(s=>this.parseAccount(s))}}const Y=m;export{Y as EthereumProvider,U as OPTIONAL_EVENTS,q as OPTIONAL_METHODS,u as REQUIRED_EVENTS,p as REQUIRED_METHODS,m as default};
1
+ import { EventEmitter as R } from "events";
2
+ import {
3
+ getAccountsFromNamespaces as T,
4
+ getSdkError as P,
5
+ isValidArray as v,
6
+ } from "@walletconnect/utils";
7
+ import { UniversalProvider as S } from "@walletconnect/universal-provider";
8
+ const j = "wc",
9
+ $ = "ethereum_provider",
10
+ N = `${j}@${2}:${$}:`,
11
+ q = "https://rpc.walletconnect.com/v1/",
12
+ p = ["eth_sendTransaction", "personal_sign"],
13
+ D = [
14
+ "eth_accounts",
15
+ "eth_requestAccounts",
16
+ "eth_call",
17
+ "eth_getBalance",
18
+ "eth_sendRawTransaction",
19
+ "eth_sign",
20
+ "eth_signTransaction",
21
+ "eth_signTypedData",
22
+ "eth_signTypedData_v3",
23
+ "eth_signTypedData_v4",
24
+ "wallet_switchEthereumChain",
25
+ "wallet_addEthereumChain",
26
+ "wallet_getPermissions",
27
+ "wallet_requestPermissions",
28
+ "wallet_registerOnboarding",
29
+ "wallet_watchAsset",
30
+ "wallet_scanQRCode",
31
+ ],
32
+ u = ["chainChanged", "accountsChanged"],
33
+ U = ["message", "disconnect", "connect"];
34
+ var Q = Object.defineProperty,
35
+ L = Object.defineProperties,
36
+ V = Object.getOwnPropertyDescriptors,
37
+ E = Object.getOwnPropertySymbols,
38
+ H = Object.prototype.hasOwnProperty,
39
+ G = Object.prototype.propertyIsEnumerable,
40
+ _ = (a, t, s) =>
41
+ t in a ? Q(a, t, { enumerable: !0, configurable: !0, writable: !0, value: s }) : (a[t] = s),
42
+ y = (a, t) => {
43
+ for (var s in t || (t = {})) H.call(t, s) && _(a, s, t[s]);
44
+ if (E) for (var s of E(t)) G.call(t, s) && _(a, s, t[s]);
45
+ return a;
46
+ },
47
+ M = (a, t) => L(a, V(t));
48
+ function I(a) {
49
+ return Number(a[0].split(":")[1]);
50
+ }
51
+ function C(a) {
52
+ return `0x${a.toString(16)}`;
53
+ }
54
+ function K(a) {
55
+ const {
56
+ chains: t,
57
+ optionalChains: s,
58
+ methods: i,
59
+ optionalMethods: e,
60
+ events: n,
61
+ optionalEvents: c,
62
+ rpcMap: h,
63
+ } = a;
64
+ if (!v(t)) throw new Error("Invalid chains");
65
+ const o = t,
66
+ r = i || p,
67
+ w = n || u,
68
+ b = { [I(o)]: h[I(o)] },
69
+ f = { chains: o, methods: r, events: w, rpcMap: b },
70
+ l = n?.filter((g) => !u.includes(g)),
71
+ d = i?.filter((g) => !p.includes(g));
72
+ if (!s && !c && !e && !(l != null && l.length) && !(d != null && d.length))
73
+ return { required: f };
74
+ const O = (l?.length && d?.length) || !s,
75
+ A = {
76
+ chains: [...new Set(O ? o.concat(s || []) : s)],
77
+ methods: [...new Set(r.concat(e || []))],
78
+ events: [...new Set(w.concat(c || []))],
79
+ rpcMap: h,
80
+ };
81
+ return { required: f, optional: A };
82
+ }
83
+ class m {
84
+ constructor() {
85
+ (this.events = new R()),
86
+ (this.namespace = "eip155"),
87
+ (this.accounts = []),
88
+ (this.chainId = 1),
89
+ (this.STORAGE_KEY = N),
90
+ (this.on = (t, s) => (this.events.on(t, s), this)),
91
+ (this.once = (t, s) => (this.events.once(t, s), this)),
92
+ (this.removeListener = (t, s) => (this.events.removeListener(t, s), this)),
93
+ (this.off = (t, s) => (this.events.off(t, s), this)),
94
+ (this.parseAccount = (t) =>
95
+ this.isCompatibleChainId(t) ? this.parseAccountId(t).address : t),
96
+ (this.signer = {}),
97
+ (this.rpc = {});
98
+ }
99
+ static async init(t) {
100
+ const s = new m();
101
+ return await s.initialize(t), s;
102
+ }
103
+ async request(t) {
104
+ return await this.signer.request(t, this.formatChainId(this.chainId));
105
+ }
106
+ sendAsync(t, s) {
107
+ this.signer.sendAsync(t, s, this.formatChainId(this.chainId));
108
+ }
109
+ get connected() {
110
+ return this.signer.client ? this.signer.client.core.relayer.connected : !1;
111
+ }
112
+ get connecting() {
113
+ return this.signer.client ? this.signer.client.core.relayer.connecting : !1;
114
+ }
115
+ async enable() {
116
+ return (
117
+ this.session || (await this.connect()), await this.request({ method: "eth_requestAccounts" })
118
+ );
119
+ }
120
+ async connect(t) {
121
+ if (!this.signer.client) throw new Error("Provider not initialized. Call init() first");
122
+ this.loadConnectOpts(t);
123
+ const { required: s, optional: i } = K(this.rpc);
124
+ try {
125
+ const e = await new Promise(async (c, h) => {
126
+ var o;
127
+ this.rpc.showQrModal &&
128
+ ((o = this.modal) == null ||
129
+ o.subscribeModal((r) => {
130
+ !r.open &&
131
+ !this.signer.session &&
132
+ (this.signer.abortPairingAttempt(),
133
+ h(new Error("Connection request reset. Please try again.")));
134
+ })),
135
+ await this.signer
136
+ .connect(
137
+ M(
138
+ y(
139
+ { namespaces: { [this.namespace]: s } },
140
+ i && { optionalNamespaces: { [this.namespace]: i } },
141
+ ),
142
+ { pairingTopic: t?.pairingTopic },
143
+ ),
144
+ )
145
+ .then((r) => {
146
+ c(r);
147
+ })
148
+ .catch((r) => {
149
+ h(new Error(r.message));
150
+ });
151
+ });
152
+ if (!e) return;
153
+ this.setChainIds(this.rpc.chains);
154
+ const n = T(e.namespaces, [this.namespace]);
155
+ this.setAccounts(n), this.events.emit("connect", { chainId: C(this.chainId) });
156
+ } catch (e) {
157
+ throw (this.signer.logger.error(e), e);
158
+ } finally {
159
+ this.modal && this.modal.closeModal();
160
+ }
161
+ }
162
+ async disconnect() {
163
+ this.session && (await this.signer.disconnect()), this.reset();
164
+ }
165
+ get isWalletConnect() {
166
+ return !0;
167
+ }
168
+ get session() {
169
+ return this.signer.session;
170
+ }
171
+ registerEventListeners() {
172
+ this.signer.on("session_event", (t) => {
173
+ const { params: s } = t,
174
+ { event: i } = s;
175
+ i.name === "accountsChanged"
176
+ ? ((this.accounts = this.parseAccounts(i.data)),
177
+ this.events.emit("accountsChanged", this.accounts))
178
+ : i.name === "chainChanged"
179
+ ? this.setChainId(this.formatChainId(i.data))
180
+ : this.events.emit(i.name, i.data),
181
+ this.events.emit("session_event", t);
182
+ }),
183
+ this.signer.on("chainChanged", (t) => {
184
+ const s = parseInt(t);
185
+ (this.chainId = s), this.events.emit("chainChanged", C(this.chainId)), this.persist();
186
+ }),
187
+ this.signer.on("session_update", (t) => {
188
+ this.events.emit("session_update", t);
189
+ }),
190
+ this.signer.on("session_delete", (t) => {
191
+ this.reset(),
192
+ this.events.emit("session_delete", t),
193
+ this.events.emit(
194
+ "disconnect",
195
+ M(y({}, P("USER_DISCONNECTED")), { data: t.topic, name: "USER_DISCONNECTED" }),
196
+ );
197
+ }),
198
+ this.signer.on("display_uri", (t) => {
199
+ var s, i;
200
+ this.rpc.showQrModal &&
201
+ ((s = this.modal) == null || s.closeModal(),
202
+ (i = this.modal) == null || i.openModal({ uri: t })),
203
+ this.events.emit("display_uri", t);
204
+ });
205
+ }
206
+ setHttpProvider(t) {
207
+ this.request({ method: "wallet_switchEthereumChain", params: [{ chainId: t.toString(16) }] });
208
+ }
209
+ isCompatibleChainId(t) {
210
+ return typeof t == "string" ? t.startsWith(`${this.namespace}:`) : !1;
211
+ }
212
+ formatChainId(t) {
213
+ return `${this.namespace}:${t}`;
214
+ }
215
+ parseChainId(t) {
216
+ return Number(t.split(":")[1]);
217
+ }
218
+ setChainIds(t) {
219
+ const s = t.filter((i) => this.isCompatibleChainId(i)).map((i) => this.parseChainId(i));
220
+ s.length &&
221
+ ((this.chainId = s[0]), this.events.emit("chainChanged", C(this.chainId)), this.persist());
222
+ }
223
+ setChainId(t) {
224
+ if (this.isCompatibleChainId(t)) {
225
+ const s = this.parseChainId(t);
226
+ (this.chainId = s), this.setHttpProvider(s);
227
+ }
228
+ }
229
+ parseAccountId(t) {
230
+ const [s, i, e] = t.split(":");
231
+ return { chainId: `${s}:${i}`, address: e };
232
+ }
233
+ setAccounts(t) {
234
+ (this.accounts = t
235
+ .filter((s) => this.parseChainId(this.parseAccountId(s).chainId) === this.chainId)
236
+ .map((s) => this.parseAccountId(s).address)),
237
+ this.events.emit("accountsChanged", this.accounts);
238
+ }
239
+ getRpcConfig(t) {
240
+ var s, i;
241
+ return {
242
+ chains: ((s = t.chains) == null ? void 0 : s.map((e) => this.formatChainId(e))) || [
243
+ `${this.namespace}:1`,
244
+ ],
245
+ optionalChains: t.optionalChains
246
+ ? t.optionalChains.map((e) => this.formatChainId(e))
247
+ : void 0,
248
+ methods: t?.methods || p,
249
+ events: t?.events || u,
250
+ optionalMethods: t?.optionalMethods || [],
251
+ optionalEvents: t?.optionalEvents || [],
252
+ rpcMap: t?.rpcMap || this.buildRpcMap(t.chains.concat(t.optionalChains || []), t.projectId),
253
+ showQrModal: (i = t?.showQrModal) != null ? i : !0,
254
+ projectId: t.projectId,
255
+ metadata: t.metadata,
256
+ };
257
+ }
258
+ buildRpcMap(t, s) {
259
+ const i = {};
260
+ return (
261
+ t.forEach((e) => {
262
+ i[e] = this.getRpcUrl(e, s);
263
+ }),
264
+ i
265
+ );
266
+ }
267
+ async initialize(t) {
268
+ var s, i;
269
+ if (
270
+ ((this.rpc = this.getRpcConfig(t)),
271
+ (this.chainId = I(this.rpc.chains)),
272
+ (this.signer = await S.init({ projectId: this.rpc.projectId, metadata: this.rpc.metadata })),
273
+ this.registerEventListeners(),
274
+ await this.loadPersistedSession(),
275
+ this.rpc.showQrModal)
276
+ )
277
+ try {
278
+ const { Web3Modal: e } = await import("@web3modal/standalone");
279
+ this.modal = new e({
280
+ walletConnectVersion: 2,
281
+ projectId: this.rpc.projectId,
282
+ standaloneChains: this.rpc.chains,
283
+ themeMode: (s = this.rpc.qrModalOptions) == null ? void 0 : s.themeMode,
284
+ themeVariables: (i = this.rpc.qrModalOptions) == null ? void 0 : i.themeVariables,
285
+ });
286
+ } catch {
287
+ throw new Error("To use QR modal, please install @web3modal/standalone package");
288
+ }
289
+ }
290
+ loadConnectOpts(t) {
291
+ if (!t) return;
292
+ const { chains: s, optionalChains: i, rpcMap: e } = t;
293
+ s &&
294
+ v(s) &&
295
+ ((this.rpc.chains = s.map((n) => this.formatChainId(n))),
296
+ s.forEach((n) => {
297
+ this.rpc.rpcMap[n] = e?.[n] || this.getRpcUrl(n);
298
+ })),
299
+ i &&
300
+ v(i) &&
301
+ ((this.rpc.optionalChains = []),
302
+ (this.rpc.optionalChains = i?.map((n) => this.formatChainId(n))),
303
+ i.forEach((n) => {
304
+ this.rpc.rpcMap[n] = e?.[n] || this.getRpcUrl(n);
305
+ }));
306
+ }
307
+ getRpcUrl(t, s) {
308
+ var i;
309
+ return (
310
+ ((i = this.rpc.rpcMap) == null ? void 0 : i[t]) ||
311
+ `${q}?chainId=eip155:${t}&projectId=${s || this.rpc.projectId}`
312
+ );
313
+ }
314
+ async loadPersistedSession() {
315
+ if (!this.session) return;
316
+ const t = await this.signer.client.core.storage.getItem(`${this.STORAGE_KEY}/chainId`);
317
+ this.setChainIds(
318
+ t ? [this.formatChainId(t)] : this.session.namespaces[this.namespace].accounts,
319
+ ),
320
+ this.setAccounts(this.session.namespaces[this.namespace].accounts);
321
+ }
322
+ reset() {
323
+ (this.chainId = 1), (this.accounts = []);
324
+ }
325
+ persist() {
326
+ this.session &&
327
+ this.signer.client.core.storage.setItem(`${this.STORAGE_KEY}/chainId`, this.chainId);
328
+ }
329
+ parseAccounts(t) {
330
+ return typeof t == "string" || t instanceof String
331
+ ? [this.parseAccount(t)]
332
+ : t.map((s) => this.parseAccount(s));
333
+ }
334
+ }
335
+ const Y = m;
336
+ export {
337
+ Y as EthereumProvider,
338
+ U as OPTIONAL_EVENTS,
339
+ D as OPTIONAL_METHODS,
340
+ u as REQUIRED_EVENTS,
341
+ p as REQUIRED_METHODS,
342
+ m as default,
343
+ };
2
344
  //# sourceMappingURL=index.es.js.map