@xyo-network/metamask-connector 4.0.3 → 4.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{dist/types → build/browser}/MetaMaskConnector.d.ts +7 -3
- package/build/browser/MetaMaskConnector.d.ts.map +1 -0
- package/dist/browser/index.d.ts +40 -0
- package/dist/browser/index.mjs +3 -2
- package/dist/browser/index.mjs.map +1 -1
- package/package.json +7 -6
- package/src/MetaMaskConnector.ts +8 -3
- package/dist/types/MetaMaskConnector.d.ts.map +0 -1
- /package/{dist/types → build/browser}/index.d.ts +0 -0
- /package/{dist/types → build/browser}/index.d.ts.map +0 -0
|
@@ -1,5 +1,9 @@
|
|
|
1
|
+
import type { MetaMaskInpageProvider } from '@metamask/providers';
|
|
1
2
|
import type { Listener } from 'ethers';
|
|
2
3
|
import { BrowserProvider } from 'ethers';
|
|
4
|
+
declare global {
|
|
5
|
+
var ethereum: MetaMaskInpageProvider | undefined;
|
|
6
|
+
}
|
|
3
7
|
export declare class MetaMaskConnector {
|
|
4
8
|
private account;
|
|
5
9
|
private ethereum;
|
|
@@ -7,10 +11,10 @@ export declare class MetaMaskConnector {
|
|
|
7
11
|
private provider;
|
|
8
12
|
private providerListeners;
|
|
9
13
|
constructor(provider?: BrowserProvider);
|
|
10
|
-
get chainId(): string | null;
|
|
11
|
-
get currentAccount(): string | null;
|
|
14
|
+
get chainId(): string | null | undefined;
|
|
15
|
+
get currentAccount(): string | null | undefined;
|
|
12
16
|
connectWallet(): Promise<void>;
|
|
13
|
-
isMetaMaskInstalled(): true;
|
|
17
|
+
isMetaMaskInstalled(): true | undefined;
|
|
14
18
|
isWalletIsConnected: () => boolean;
|
|
15
19
|
/**
|
|
16
20
|
* EIP-1193 Event Listeners
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAA;AAGjE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAA;AAExC,OAAO,CAAC,MAAM,CAAC;IACb,IAAI,QAAQ,EAAE,sBAAsB,GAAG,SAAS,CAAA;CACjD;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAAsB;IAEtC,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,eAAe;IAQtC,IAAI,OAAO,8BAEV;IAED,IAAI,cAAc,8BAEjB;IAEK,aAAa;IAgBnB,mBAAmB;IAInB,mBAAmB,gBAMlB;IAED;;;;;OAKG;IACH,yBAAyB,CAAC,QAAQ,EAAE,QAAQ;IAK5C,sBAAsB,CAAC,QAAQ,EAAE,QAAQ;IAKzC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ;IAKpC,oBAAoB,CAAC,QAAQ,EAAE,QAAQ;IAKvC,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKxD,uBAAuB;IAIjB,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC;IAS3C,WAAW,CAAC,OAAO,EAAE,MAAM;IAWjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOvD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOnE,2BAA2B,IAAI,IAAI;IAMnC,OAAO,CAAC,kBAAkB;CAG3B"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { MetaMaskInpageProvider } from '@metamask/providers';
|
|
2
|
+
import { BrowserProvider, Listener } from 'ethers';
|
|
3
|
+
|
|
4
|
+
declare global {
|
|
5
|
+
var ethereum: MetaMaskInpageProvider | undefined;
|
|
6
|
+
}
|
|
7
|
+
declare class MetaMaskConnector {
|
|
8
|
+
private account;
|
|
9
|
+
private ethereum;
|
|
10
|
+
private listeners;
|
|
11
|
+
private provider;
|
|
12
|
+
private providerListeners;
|
|
13
|
+
constructor(provider?: BrowserProvider);
|
|
14
|
+
get chainId(): string | null | undefined;
|
|
15
|
+
get currentAccount(): string | null | undefined;
|
|
16
|
+
connectWallet(): Promise<void>;
|
|
17
|
+
isMetaMaskInstalled(): true | undefined;
|
|
18
|
+
isWalletIsConnected: () => boolean;
|
|
19
|
+
/**
|
|
20
|
+
* EIP-1193 Event Listeners
|
|
21
|
+
*
|
|
22
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
23
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
24
|
+
*/
|
|
25
|
+
providerOnAccountsChanged(listener: Listener): void;
|
|
26
|
+
providerOnChainChanged(listener: Listener): void;
|
|
27
|
+
providerOnConnect(listener: Listener): void;
|
|
28
|
+
providerOnDisconnect(listener: Listener): void;
|
|
29
|
+
providerRemoveListener(event: string, listener: Listener): void;
|
|
30
|
+
providerRemoveListeners(): void;
|
|
31
|
+
requestAccounts(): Promise<string[] | null>;
|
|
32
|
+
signMessage(message: string): Promise<string | undefined>;
|
|
33
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
34
|
+
web3ProviderOn(event: string, listener: Listener): void;
|
|
35
|
+
web3ProviderRemoveListener(event: string, listener: Listener): void;
|
|
36
|
+
web3ProviderRemoveListeners(): void;
|
|
37
|
+
private logProviderMissing;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export { MetaMaskConnector };
|
package/dist/browser/index.mjs
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
// src/MetaMaskConnector.ts
|
|
2
2
|
import { forget } from "@xylabs/forget";
|
|
3
|
+
import { isString } from "@xylabs/typeof";
|
|
3
4
|
import { BrowserProvider } from "ethers";
|
|
4
5
|
var MetaMaskConnector = class {
|
|
5
6
|
account = "";
|
|
@@ -11,7 +12,7 @@ var MetaMaskConnector = class {
|
|
|
11
12
|
if (provider) {
|
|
12
13
|
this.provider = provider;
|
|
13
14
|
} else if (this.ethereum) {
|
|
14
|
-
this.provider = new BrowserProvider(
|
|
15
|
+
this.provider = new BrowserProvider(this.ethereum);
|
|
15
16
|
}
|
|
16
17
|
}
|
|
17
18
|
get chainId() {
|
|
@@ -37,7 +38,7 @@ var MetaMaskConnector = class {
|
|
|
37
38
|
return this.ethereum && this.ethereum.isMetaMask;
|
|
38
39
|
}
|
|
39
40
|
isWalletIsConnected = () => {
|
|
40
|
-
if (this.currentAccount) {
|
|
41
|
+
if (isString(this.currentAccount)) {
|
|
41
42
|
console.log("Found an authorized account:", this.ethereum?.selectedAddress);
|
|
42
43
|
return true;
|
|
43
44
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import type { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport type { Listener } from 'ethers'\nimport { BrowserProvider } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = globalThis.ethereum
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import type { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { isString } from '@xylabs/typeof'\nimport type { Listener } from 'ethers'\nimport { BrowserProvider } from 'ethers'\n\ndeclare global {\n var ethereum: MetaMaskInpageProvider | undefined\n}\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = globalThis.ethereum\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(this.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (isString(this.currentAccount)) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n // this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n // for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n return await signer.signMessage(message)\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener): void {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener): void {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter(savedListener => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners(): void {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing(): void {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":"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","names":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/metamask-connector",
|
|
3
|
-
"version": "4.0
|
|
3
|
+
"version": "4.1.0",
|
|
4
4
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -21,21 +21,22 @@
|
|
|
21
21
|
"type": "module",
|
|
22
22
|
"exports": {
|
|
23
23
|
".": {
|
|
24
|
-
"types": "./dist/
|
|
24
|
+
"types": "./dist/browser/index.d.ts",
|
|
25
25
|
"default": "./dist/browser/index.mjs"
|
|
26
26
|
},
|
|
27
27
|
"./package.json": "./package.json"
|
|
28
28
|
},
|
|
29
29
|
"module": "dist/browser/index.mjs",
|
|
30
|
-
"types": "dist/
|
|
30
|
+
"types": "dist/browser/index.d.ts",
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@xylabs/forget": "^4.13.
|
|
32
|
+
"@xylabs/forget": "^4.13.15",
|
|
33
|
+
"@xylabs/typeof": "^4.13.15",
|
|
33
34
|
"ethers": "^6.15.0"
|
|
34
35
|
},
|
|
35
36
|
"devDependencies": {
|
|
36
37
|
"@metamask/providers": "^22.1.0",
|
|
37
|
-
"@xylabs/ts-scripts-yarn3": "^
|
|
38
|
-
"@xylabs/tsconfig-dom": "^
|
|
38
|
+
"@xylabs/ts-scripts-yarn3": "^7.0.0-rc.20",
|
|
39
|
+
"@xylabs/tsconfig-dom": "^7.0.0-rc.20",
|
|
39
40
|
"typescript": "^5.8.3"
|
|
40
41
|
},
|
|
41
42
|
"publishConfig": {
|
package/src/MetaMaskConnector.ts
CHANGED
|
@@ -1,11 +1,16 @@
|
|
|
1
1
|
import type { MetaMaskInpageProvider } from '@metamask/providers'
|
|
2
2
|
import { forget } from '@xylabs/forget'
|
|
3
|
+
import { isString } from '@xylabs/typeof'
|
|
3
4
|
import type { Listener } from 'ethers'
|
|
4
5
|
import { BrowserProvider } from 'ethers'
|
|
5
6
|
|
|
7
|
+
declare global {
|
|
8
|
+
var ethereum: MetaMaskInpageProvider | undefined
|
|
9
|
+
}
|
|
10
|
+
|
|
6
11
|
export class MetaMaskConnector {
|
|
7
12
|
private account = ''
|
|
8
|
-
private ethereum = globalThis.ethereum
|
|
13
|
+
private ethereum = globalThis.ethereum
|
|
9
14
|
|
|
10
15
|
private listeners: Listener[] = []
|
|
11
16
|
private provider: BrowserProvider | undefined
|
|
@@ -15,7 +20,7 @@ export class MetaMaskConnector {
|
|
|
15
20
|
if (provider) {
|
|
16
21
|
this.provider = provider
|
|
17
22
|
} else if (this.ethereum) {
|
|
18
|
-
this.provider = new BrowserProvider(
|
|
23
|
+
this.provider = new BrowserProvider(this.ethereum)
|
|
19
24
|
}
|
|
20
25
|
}
|
|
21
26
|
|
|
@@ -48,7 +53,7 @@ export class MetaMaskConnector {
|
|
|
48
53
|
}
|
|
49
54
|
|
|
50
55
|
isWalletIsConnected = () => {
|
|
51
|
-
if (this.currentAccount) {
|
|
56
|
+
if (isString(this.currentAccount)) {
|
|
52
57
|
console.log('Found an authorized account:', this.ethereum?.selectedAddress)
|
|
53
58
|
return true
|
|
54
59
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAA;AAExC,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAAgD;IAEhE,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,eAAe;IAQtC,IAAI,OAAO,kBAEV;IAED,IAAI,cAAc,kBAEjB;IAEK,aAAa;IAgBnB,mBAAmB;IAInB,mBAAmB,gBAMlB;IAED;;;;;OAKG;IACH,yBAAyB,CAAC,QAAQ,EAAE,QAAQ;IAK5C,sBAAsB,CAAC,QAAQ,EAAE,QAAQ;IAKzC,iBAAiB,CAAC,QAAQ,EAAE,QAAQ;IAKpC,oBAAoB,CAAC,QAAQ,EAAE,QAAQ;IAKvC,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKxD,uBAAuB;IAIjB,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC;IAS3C,WAAW,CAAC,OAAO,EAAE,MAAM;IAWjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOvD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAOnE,2BAA2B,IAAI,IAAI;IAMnC,OAAO,CAAC,kBAAkB;CAG3B"}
|
|
File without changes
|
|
File without changes
|