@walletconnect/ethereum-provider 2.5.1 → 2.5.2

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
@@ -16,19 +16,19 @@ import { EthereumProvider } from "@walletconnect/ethereum-provider";
16
16
  const provider = await EthereumProvider.init({
17
17
  projectId, // REQUIRED your projectId
18
18
  chains, // REQUIRED chain ids
19
+ showQrModal, // REQUIRED set to "true" to use @web3modal/standalone,
19
20
  methods, // OPTIONAL ethereum methods
20
21
  events, // OPTIONAL ethereum events
21
22
  rpcMap, // OPTIONAL rpc urls for each chain
22
23
  metadata, // OPTIONAL metadata of your app
23
- showQrModal, // OPTIONAL - `true` by default,
24
- qrModalOptions, // OPTIONAL - `undefined` by default, see https://docs.walletconnect.com/2.0/web3modal/theming
24
+ qrModalOptions, // OPTIONAL - `undefined` by default, see https://docs.walletconnect.com/2.0/web3modal/options
25
25
  });
26
26
  ```
27
27
 
28
28
  ## Display Web3Modal with QR code / Handle connection URI
29
29
 
30
30
  ```typescript
31
- // Web3Modal is enabled by default and will display a QR code modal
31
+ // Web3Modal is disabled by default, enable it during init() to display a QR code modal
32
32
  await provider.connect({
33
33
  chains, // OPTIONAL chain ids
34
34
  rpcMap, // OPTIONAL rpc urls
@@ -39,7 +39,7 @@ await provider.enable();
39
39
  ```
40
40
 
41
41
  ```typescript
42
- // If you wish to disable the built-in modal via `showQrModal`,
42
+ // If you are not using Web3Modal,
43
43
  // you can subscribe to the `display_uri` event and handle the URI yourself.
44
44
  provider.on("display_uri", (uri: string) => {
45
45
  // ... custom logic
@@ -76,3 +76,18 @@ provider.on("display_uri", handler);
76
76
  // session disconnect
77
77
  provider.on("disconnect", handler);
78
78
  ```
79
+
80
+ ## Supported Web3Modal options (qrModalOptions)
81
+
82
+ - [themeMode](https://docs.walletconnect.com/2.0/web3modal/options#thememode-optional)
83
+ - [themeVariables](https://docs.walletconnect.com/2.0/web3modal/options#themevariables-optional)
84
+ - [chainImages](https://docs.walletconnect.com/2.0/web3modal/options#chainimages-optional)
85
+ - [tokenImages](https://docs.walletconnect.com/2.0/web3modal/options#tokenimages-optional)
86
+ - [walletImages](https://docs.walletconnect.com/2.0/web3modal/options#walletimages-optional)
87
+ - [desktopWallets](https://docs.walletconnect.com/2.0/web3modal/options#desktopwallets-optional)
88
+ - [mobileWallets](https://docs.walletconnect.com/2.0/web3modal/options#mobilewallets-optional)
89
+ - [enableExplorer](https://docs.walletconnect.com/2.0/web3modal/options#enableexplorer-optional)
90
+ - [explorerAllowList](https://docs.walletconnect.com/2.0/web3modal/options#explorerallowlist-optional)
91
+ - [explorerDenyList](https://docs.walletconnect.com/2.0/web3modal/options#explorerdenylist-optional)
92
+ - [privacyPolicyUrl](https://docs.walletconnect.com/2.0/web3modal/options#privacypolicyurl-optional)
93
+ - [termsOfServiceUrl](https://docs.walletconnect.com/2.0/web3modal/options#privacypolicyurl-optional)
package/dist/index.cjs.js CHANGED
@@ -1,2 +1,2 @@
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;
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}:`,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,_=Object.getOwnPropertySymbols,V=Object.prototype.hasOwnProperty,H=Object.prototype.propertyIsEnumerable,O=(i,t,e)=>t in i?U(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,I=(i,t)=>{for(var e in t||(t={}))V.call(t,e)&&O(i,e,t[e]);if(_)for(var e of _(t))H.call(t,e)&&O(i,e,t[e]);return i},y=(i,t)=>Q(i,L(t));function C(i){return Number(i[0].split(":")[1])}function E(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={[C(o)]:c[C(o)]},w={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:w};const M=d?.length&&p?.length||!e,A={chains:[...new Set(M?o.concat(e||[]):e)],methods:[...new Set(r.concat(n||[]))],events:[...new Set(f.concat(l||[]))],rpcMap:c};return{required:w,optional:A}}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(I({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:E(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",E(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(I({},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",E(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:Boolean(t?.showQrModal),qrModalOptions:(s=t?.qrModalOptions)!=null?s:void 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=C(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)try{const{Web3Modal:e}=await Promise.resolve().then(function(){return R(require("@web3modal/standalone"))});this.modal=new e(I({walletConnectVersion:2,projectId:this.rpc.projectId,standaloneChains:this.rpc.chains},this.rpc.qrModalOptions))}catch{throw new Error("To use QR modal, please install @web3modal/standalone package")}}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])||`${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 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":"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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 { Web3ModalConfig, Web3Modal } from \"@web3modal/standalone\";\nimport { SessionTypes, SignClientTypes } from \"@walletconnect/types\";\nimport { STORAGE_KEY, REQUIRED_METHODS, REQUIRED_EVENTS, RPC_URL } from \"./constants\";\n\nexport type QrModalOptions = Pick<\n Web3ModalConfig,\n | \"themeMode\"\n | \"themeVariables\"\n | \"chainImages\"\n | \"desktopWallets\"\n | \"enableExplorer\"\n | \"explorerAllowList\"\n | \"explorerDenyList\"\n | \"mobileWallets\"\n | \"privacyPolicyUrl\"\n | \"termsOfServiceUrl\"\n | \"tokenImages\"\n | \"walletImages\"\n>;\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?: QrModalOptions;\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?: QrModalOptions;\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: Boolean(opts?.showQrModal),\n qrModalOptions: opts?.qrModalOptions ?? undefined,\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 ...this.rpc.qrModalOptions,\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":"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"}
package/dist/index.es.js CHANGED
@@ -1,344 +1,2 @@
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
- };
1
+ import{EventEmitter as R}from"events";import{getAccountsFromNamespaces as T,getSdkError as S,isValidArray as v}from"@walletconnect/utils";import{UniversalProvider as P}from"@walletconnect/universal-provider";const j="wc",$="ethereum_provider",q=`${j}@${2}:${$}:`,N="https://rpc.walletconnect.com/v1/",p=["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"],u=["chainChanged","accountsChanged"],U=["message","disconnect","connect"];var Q=Object.defineProperty,L=Object.defineProperties,H=Object.getOwnPropertyDescriptors,_=Object.getOwnPropertySymbols,G=Object.prototype.hasOwnProperty,K=Object.prototype.propertyIsEnumerable,y=(a,t,s)=>t in a?Q(a,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):a[t]=s,I=(a,t)=>{for(var s in t||(t={}))G.call(t,s)&&y(a,s,t[s]);if(_)for(var s of _(t))K.call(t,s)&&y(a,s,t[s]);return a},O=(a,t)=>L(a,H(t));function C(a){return Number(a[0].split(":")[1])}function w(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,f=n||u,M={[C(o)]:h[C(o)]},E={chains:o,methods:r,events:f,rpcMap:M},l=n?.filter(g=>!u.includes(g)),d=i?.filter(g=>!p.includes(g));if(!s&&!c&&!e&&!(l!=null&&l.length)&&!(d!=null&&d.length))return{required:E};const b=l?.length&&d?.length||!s,A={chains:[...new Set(b?o.concat(s||[]):s)],methods:[...new Set(r.concat(e||[]))],events:[...new Set(f.concat(c||[]))],rpcMap:h};return{required:E,optional:A}}class m{constructor(){this.events=new R,this.namespace="eip155",this.accounts=[],this.chainId=1,this.STORAGE_KEY=q,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(I({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=T(e.namespaces,[this.namespace]);this.setAccounts(n),this.events.emit("connect",{chainId:w(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",w(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(I({},S("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",w(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:Boolean(t?.showQrModal),qrModalOptions:(i=t?.qrModalOptions)!=null?i:void 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=C(this.rpc.chains),this.signer=await P.init({projectId:this.rpc.projectId,metadata:this.rpc.metadata}),this.registerEventListeners(),await this.loadPersistedSession(),this.rpc.showQrModal)try{const{Web3Modal:s}=await import("@web3modal/standalone");this.modal=new s(I({walletConnectVersion:2,projectId:this.rpc.projectId,standaloneChains:this.rpc.chains},this.rpc.qrModalOptions))}catch{throw new Error("To use QR modal, please install @web3modal/standalone package")}}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])||`${N}?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,D as OPTIONAL_METHODS,u as REQUIRED_EVENTS,p as REQUIRED_METHODS,m as default};
344
2
  //# sourceMappingURL=index.es.js.map