@xyo-network/metamask-connector 2.111.2 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/dist/browser/index.d.ts +29 -2
  2. package/package.json +8 -27
  3. package/xy.config.ts +10 -0
  4. package/dist/browser/MetaMaskConnector.d.cts +0 -27
  5. package/dist/browser/MetaMaskConnector.d.cts.map +0 -1
  6. package/dist/browser/MetaMaskConnector.d.mts +0 -27
  7. package/dist/browser/MetaMaskConnector.d.mts.map +0 -1
  8. package/dist/browser/MetaMaskConnector.d.ts +0 -27
  9. package/dist/browser/MetaMaskConnector.d.ts.map +0 -1
  10. package/dist/browser/index.cjs +0 -137
  11. package/dist/browser/index.cjs.map +0 -1
  12. package/dist/browser/index.d.cts +0 -2
  13. package/dist/browser/index.d.cts.map +0 -1
  14. package/dist/browser/index.d.mts +0 -2
  15. package/dist/browser/index.d.mts.map +0 -1
  16. package/dist/browser/index.d.ts.map +0 -1
  17. package/dist/neutral/MetaMaskConnector.d.cts +0 -27
  18. package/dist/neutral/MetaMaskConnector.d.cts.map +0 -1
  19. package/dist/neutral/MetaMaskConnector.d.mts +0 -27
  20. package/dist/neutral/MetaMaskConnector.d.mts.map +0 -1
  21. package/dist/neutral/MetaMaskConnector.d.ts +0 -27
  22. package/dist/neutral/MetaMaskConnector.d.ts.map +0 -1
  23. package/dist/neutral/index.cjs +0 -137
  24. package/dist/neutral/index.cjs.map +0 -1
  25. package/dist/neutral/index.d.cts +0 -2
  26. package/dist/neutral/index.d.cts.map +0 -1
  27. package/dist/neutral/index.d.mts +0 -2
  28. package/dist/neutral/index.d.mts.map +0 -1
  29. package/dist/neutral/index.d.ts +0 -2
  30. package/dist/neutral/index.d.ts.map +0 -1
  31. package/dist/neutral/index.mjs +0 -114
  32. package/dist/neutral/index.mjs.map +0 -1
  33. package/dist/node/MetaMaskConnector.d.cts +0 -27
  34. package/dist/node/MetaMaskConnector.d.cts.map +0 -1
  35. package/dist/node/MetaMaskConnector.d.mts +0 -27
  36. package/dist/node/MetaMaskConnector.d.mts.map +0 -1
  37. package/dist/node/MetaMaskConnector.d.ts +0 -27
  38. package/dist/node/MetaMaskConnector.d.ts.map +0 -1
  39. package/dist/node/index.cjs +0 -148
  40. package/dist/node/index.cjs.map +0 -1
  41. package/dist/node/index.d.cts +0 -2
  42. package/dist/node/index.d.cts.map +0 -1
  43. package/dist/node/index.d.mts +0 -2
  44. package/dist/node/index.d.mts.map +0 -1
  45. package/dist/node/index.d.ts +0 -2
  46. package/dist/node/index.d.ts.map +0 -1
  47. package/dist/node/index.mjs +0 -121
  48. package/dist/node/index.mjs.map +0 -1
@@ -1,2 +1,29 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
1
+ import { BrowserProvider, Listener } from 'ethers';
2
+
3
+ declare class MetaMaskConnector {
4
+ private account;
5
+ private ethereum;
6
+ private listeners;
7
+ private provider;
8
+ private providerListeners;
9
+ constructor(provider?: BrowserProvider);
10
+ get chainId(): string | null;
11
+ get currentAccount(): string | null;
12
+ connectWallet(): Promise<void>;
13
+ isMetaMaskInstalled(): true;
14
+ isWalletIsConnected: () => boolean;
15
+ providerOnAccountsChanged(listener: Listener): void;
16
+ providerOnChainChanged(listener: Listener): void;
17
+ providerOnConnect(listener: Listener): void;
18
+ providerOnDisconnect(listener: Listener): void;
19
+ providerRemoveListener(event: string, listener: Listener): void;
20
+ providerRemoveListeners(): void;
21
+ requestAccounts(): Promise<string[] | null>;
22
+ signMessage(message: string): Promise<string | undefined>;
23
+ web3ProviderOn(event: string, listener: Listener): void;
24
+ web3ProviderRemoveListener(event: string, listener: Listener): void;
25
+ web3ProviderRemoveListeners(): void;
26
+ private logProviderMissing;
27
+ }
28
+
29
+ export { MetaMaskConnector };
package/package.json CHANGED
@@ -10,43 +10,24 @@
10
10
  },
11
11
  "dependencies": {
12
12
  "@metamask/providers": "^17.1.2",
13
- "@xylabs/forget": "^3.6.8",
13
+ "@xylabs/forget": "^3.6.12",
14
14
  "ethers": "6.13.2"
15
15
  },
16
16
  "description": "Primary SDK for using XYO Protocol 2.0",
17
17
  "devDependencies": {
18
- "@xylabs/ts-scripts-yarn3": "^3.15.13",
19
- "@xylabs/tsconfig-dom": "^3.15.13",
18
+ "@xylabs/ts-scripts-yarn3": "next",
19
+ "@xylabs/tsconfig-dom": "next",
20
20
  "typescript": "^5.5.4"
21
21
  },
22
22
  "exports": {
23
23
  ".": {
24
- "browser": {
25
- "require": {
26
- "types": "./dist/browser/index.d.cts",
27
- "default": "./dist/browser/index.cjs"
28
- },
29
- "import": {
30
- "types": "./dist/browser/index.d.mts",
31
- "default": "./dist/browser/index.mjs"
32
- }
33
- },
34
- "node": {
35
- "require": {
36
- "types": "./dist/node/index.d.cts",
37
- "default": "./dist/node/index.cjs"
38
- },
39
- "import": {
40
- "types": "./dist/node/index.d.mts",
41
- "default": "./dist/node/index.mjs"
42
- }
43
- }
24
+ "types": "./dist/browser/index.d.ts",
25
+ "default": "./dist/browser/index.mjs"
44
26
  },
45
27
  "./package.json": "./package.json"
46
28
  },
47
- "main": "dist/node/index.cjs",
48
- "module": "dist/node/index.mjs",
49
- "types": "dist/node/index.d.mts",
29
+ "module": "dist/browser/index.mjs",
30
+ "types": "dist/browser/index.d.ts",
50
31
  "homepage": "https://xyo.network",
51
32
  "license": "LGPL-3.0-only",
52
33
  "name": "@xyo-network/metamask-connector",
@@ -58,6 +39,6 @@
58
39
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
59
40
  },
60
41
  "sideEffects": false,
61
- "version": "2.111.2",
42
+ "version": "3.0.0",
62
43
  "type": "module"
63
44
  }
package/xy.config.ts ADDED
@@ -0,0 +1,10 @@
1
+ import { XyTsupConfig } from '@xylabs/ts-scripts-yarn3'
2
+ const config: XyTsupConfig = {
3
+ compile: {
4
+ browser: { src: true },
5
+ neutral: {},
6
+ node: {},
7
+ },
8
+ }
9
+
10
+ export default config
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,137 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- MetaMaskConnector: () => MetaMaskConnector
24
- });
25
- module.exports = __toCommonJS(src_exports);
26
-
27
- // src/MetaMaskConnector.ts
28
- var import_forget = require("@xylabs/forget");
29
- var import_ethers = require("ethers");
30
- var MetaMaskConnector = class {
31
- account = "";
32
- ethereum = window.ethereum;
33
- listeners = [];
34
- provider;
35
- providerListeners = [];
36
- constructor(provider) {
37
- if (provider) {
38
- this.provider = provider;
39
- } else if (this.ethereum) {
40
- this.provider = new import_ethers.BrowserProvider(window.ethereum);
41
- }
42
- }
43
- get chainId() {
44
- return this.ethereum?.networkVersion;
45
- }
46
- get currentAccount() {
47
- return this.ethereum?.selectedAddress;
48
- }
49
- async connectWallet() {
50
- if (!this.provider) {
51
- this.logProviderMissing();
52
- return;
53
- }
54
- const accounts = await this.provider.send("eth_requestAccounts", []);
55
- if (accounts.length > 0) {
56
- this.account = accounts[0];
57
- console.log("Connected:", this.account);
58
- } else {
59
- console.log("No authorized account found.");
60
- }
61
- }
62
- isMetaMaskInstalled() {
63
- return this.ethereum && this.ethereum.isMetaMask;
64
- }
65
- isWalletIsConnected = () => {
66
- if (this.currentAccount) {
67
- console.log("Found an authorized account:", this.ethereum?.selectedAddress);
68
- return true;
69
- }
70
- return false;
71
- };
72
- /**
73
- * EIP-1193 Event Listeners
74
- *
75
- * .on in Web3Provider does not understand EIP-1193 events
76
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
77
- */
78
- providerOnAccountsChanged(listener) {
79
- this.ethereum?.on("accountsChanged", listener);
80
- this.providerListeners.push(["accountsChanged", listener]);
81
- }
82
- providerOnChainChanged(listener) {
83
- this.ethereum?.on("chainChanged", listener);
84
- this.providerListeners.push(["chainChanged", listener]);
85
- }
86
- providerOnConnect(listener) {
87
- this.ethereum?.on("connect", listener);
88
- this.providerListeners.push(["connect", listener]);
89
- }
90
- providerOnDisconnect(listener) {
91
- this.ethereum?.on("disconnect", listener);
92
- this.providerListeners.push(["disconnect", listener]);
93
- }
94
- providerRemoveListener(event, listener) {
95
- this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
96
- }
97
- providerRemoveListeners() {
98
- }
99
- async requestAccounts() {
100
- if (!this.provider) {
101
- this.logProviderMissing();
102
- return null;
103
- }
104
- return await this.provider.send("eth_requestAccounts", []);
105
- }
106
- async signMessage(message) {
107
- if (!this.provider) {
108
- this.logProviderMissing();
109
- return;
110
- }
111
- const signer = await this.provider.getSigner();
112
- await signer.getAddress();
113
- return await signer.signMessage(message);
114
- }
115
- /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
116
- web3ProviderOn(event, listener) {
117
- if (this.provider) {
118
- (0, import_forget.forget)(this.provider.on(event, listener));
119
- }
120
- this.listeners.push(listener);
121
- }
122
- web3ProviderRemoveListener(event, listener) {
123
- if (this.provider) {
124
- (0, import_forget.forget)(this.provider.removeListener(event, listener));
125
- }
126
- this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
127
- }
128
- web3ProviderRemoveListeners() {
129
- if (this.provider) {
130
- (0, import_forget.forget)(this.provider.removeAllListeners());
131
- }
132
- }
133
- logProviderMissing() {
134
- console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
135
- }
136
- };
137
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector.ts'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\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(window.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 (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":[]}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,137 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- MetaMaskConnector: () => MetaMaskConnector
24
- });
25
- module.exports = __toCommonJS(src_exports);
26
-
27
- // src/MetaMaskConnector.ts
28
- var import_forget = require("@xylabs/forget");
29
- var import_ethers = require("ethers");
30
- var MetaMaskConnector = class {
31
- account = "";
32
- ethereum = window.ethereum;
33
- listeners = [];
34
- provider;
35
- providerListeners = [];
36
- constructor(provider) {
37
- if (provider) {
38
- this.provider = provider;
39
- } else if (this.ethereum) {
40
- this.provider = new import_ethers.BrowserProvider(window.ethereum);
41
- }
42
- }
43
- get chainId() {
44
- return this.ethereum?.networkVersion;
45
- }
46
- get currentAccount() {
47
- return this.ethereum?.selectedAddress;
48
- }
49
- async connectWallet() {
50
- if (!this.provider) {
51
- this.logProviderMissing();
52
- return;
53
- }
54
- const accounts = await this.provider.send("eth_requestAccounts", []);
55
- if (accounts.length > 0) {
56
- this.account = accounts[0];
57
- console.log("Connected:", this.account);
58
- } else {
59
- console.log("No authorized account found.");
60
- }
61
- }
62
- isMetaMaskInstalled() {
63
- return this.ethereum && this.ethereum.isMetaMask;
64
- }
65
- isWalletIsConnected = () => {
66
- if (this.currentAccount) {
67
- console.log("Found an authorized account:", this.ethereum?.selectedAddress);
68
- return true;
69
- }
70
- return false;
71
- };
72
- /**
73
- * EIP-1193 Event Listeners
74
- *
75
- * .on in Web3Provider does not understand EIP-1193 events
76
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
77
- */
78
- providerOnAccountsChanged(listener) {
79
- this.ethereum?.on("accountsChanged", listener);
80
- this.providerListeners.push(["accountsChanged", listener]);
81
- }
82
- providerOnChainChanged(listener) {
83
- this.ethereum?.on("chainChanged", listener);
84
- this.providerListeners.push(["chainChanged", listener]);
85
- }
86
- providerOnConnect(listener) {
87
- this.ethereum?.on("connect", listener);
88
- this.providerListeners.push(["connect", listener]);
89
- }
90
- providerOnDisconnect(listener) {
91
- this.ethereum?.on("disconnect", listener);
92
- this.providerListeners.push(["disconnect", listener]);
93
- }
94
- providerRemoveListener(event, listener) {
95
- this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
96
- }
97
- providerRemoveListeners() {
98
- }
99
- async requestAccounts() {
100
- if (!this.provider) {
101
- this.logProviderMissing();
102
- return null;
103
- }
104
- return await this.provider.send("eth_requestAccounts", []);
105
- }
106
- async signMessage(message) {
107
- if (!this.provider) {
108
- this.logProviderMissing();
109
- return;
110
- }
111
- const signer = await this.provider.getSigner();
112
- await signer.getAddress();
113
- return await signer.signMessage(message);
114
- }
115
- /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
116
- web3ProviderOn(event, listener) {
117
- if (this.provider) {
118
- (0, import_forget.forget)(this.provider.on(event, listener));
119
- }
120
- this.listeners.push(listener);
121
- }
122
- web3ProviderRemoveListener(event, listener) {
123
- if (this.provider) {
124
- (0, import_forget.forget)(this.provider.removeListener(event, listener));
125
- }
126
- this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
127
- }
128
- web3ProviderRemoveListeners() {
129
- if (this.provider) {
130
- (0, import_forget.forget)(this.provider.removeAllListeners());
131
- }
132
- }
133
- logProviderMissing() {
134
- console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
135
- }
136
- };
137
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector.ts'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\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(window.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 (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":[]}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,114 +0,0 @@
1
- // src/MetaMaskConnector.ts
2
- import { forget } from "@xylabs/forget";
3
- import { BrowserProvider } from "ethers";
4
- var MetaMaskConnector = class {
5
- account = "";
6
- ethereum = window.ethereum;
7
- listeners = [];
8
- provider;
9
- providerListeners = [];
10
- constructor(provider) {
11
- if (provider) {
12
- this.provider = provider;
13
- } else if (this.ethereum) {
14
- this.provider = new BrowserProvider(window.ethereum);
15
- }
16
- }
17
- get chainId() {
18
- return this.ethereum?.networkVersion;
19
- }
20
- get currentAccount() {
21
- return this.ethereum?.selectedAddress;
22
- }
23
- async connectWallet() {
24
- if (!this.provider) {
25
- this.logProviderMissing();
26
- return;
27
- }
28
- const accounts = await this.provider.send("eth_requestAccounts", []);
29
- if (accounts.length > 0) {
30
- this.account = accounts[0];
31
- console.log("Connected:", this.account);
32
- } else {
33
- console.log("No authorized account found.");
34
- }
35
- }
36
- isMetaMaskInstalled() {
37
- return this.ethereum && this.ethereum.isMetaMask;
38
- }
39
- isWalletIsConnected = () => {
40
- if (this.currentAccount) {
41
- console.log("Found an authorized account:", this.ethereum?.selectedAddress);
42
- return true;
43
- }
44
- return false;
45
- };
46
- /**
47
- * EIP-1193 Event Listeners
48
- *
49
- * .on in Web3Provider does not understand EIP-1193 events
50
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
51
- */
52
- providerOnAccountsChanged(listener) {
53
- this.ethereum?.on("accountsChanged", listener);
54
- this.providerListeners.push(["accountsChanged", listener]);
55
- }
56
- providerOnChainChanged(listener) {
57
- this.ethereum?.on("chainChanged", listener);
58
- this.providerListeners.push(["chainChanged", listener]);
59
- }
60
- providerOnConnect(listener) {
61
- this.ethereum?.on("connect", listener);
62
- this.providerListeners.push(["connect", listener]);
63
- }
64
- providerOnDisconnect(listener) {
65
- this.ethereum?.on("disconnect", listener);
66
- this.providerListeners.push(["disconnect", listener]);
67
- }
68
- providerRemoveListener(event, listener) {
69
- this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
70
- }
71
- providerRemoveListeners() {
72
- }
73
- async requestAccounts() {
74
- if (!this.provider) {
75
- this.logProviderMissing();
76
- return null;
77
- }
78
- return await this.provider.send("eth_requestAccounts", []);
79
- }
80
- async signMessage(message) {
81
- if (!this.provider) {
82
- this.logProviderMissing();
83
- return;
84
- }
85
- const signer = await this.provider.getSigner();
86
- await signer.getAddress();
87
- return await signer.signMessage(message);
88
- }
89
- /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
90
- web3ProviderOn(event, listener) {
91
- if (this.provider) {
92
- forget(this.provider.on(event, listener));
93
- }
94
- this.listeners.push(listener);
95
- }
96
- web3ProviderRemoveListener(event, listener) {
97
- if (this.provider) {
98
- forget(this.provider.removeListener(event, listener));
99
- }
100
- this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
101
- }
102
- web3ProviderRemoveListeners() {
103
- if (this.provider) {
104
- forget(this.provider.removeAllListeners());
105
- }
106
- }
107
- logProviderMissing() {
108
- console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
109
- }
110
- };
111
- export {
112
- MetaMaskConnector
113
- };
114
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\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(window.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 (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":[]}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,27 +0,0 @@
1
- import { BrowserProvider, Listener } from 'ethers';
2
- export declare class MetaMaskConnector {
3
- private account;
4
- private ethereum;
5
- private listeners;
6
- private provider;
7
- private providerListeners;
8
- constructor(provider?: BrowserProvider);
9
- get chainId(): string | null;
10
- get currentAccount(): string | null;
11
- connectWallet(): Promise<void>;
12
- isMetaMaskInstalled(): true;
13
- isWalletIsConnected: () => boolean;
14
- providerOnAccountsChanged(listener: Listener): void;
15
- providerOnChainChanged(listener: Listener): void;
16
- providerOnConnect(listener: Listener): void;
17
- providerOnDisconnect(listener: Listener): void;
18
- providerRemoveListener(event: string, listener: Listener): void;
19
- providerRemoveListeners(): void;
20
- requestAccounts(): Promise<string[] | null>;
21
- signMessage(message: string): Promise<string | undefined>;
22
- web3ProviderOn(event: string, listener: Listener): void;
23
- web3ProviderRemoveListener(event: string, listener: Listener): void;
24
- web3ProviderRemoveListeners(): void;
25
- private logProviderMissing;
26
- }
27
- //# sourceMappingURL=MetaMaskConnector.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAElD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,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;IAQD,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;IAYjC,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"}
@@ -1,148 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- MetaMaskConnector: () => MetaMaskConnector
24
- });
25
- module.exports = __toCommonJS(src_exports);
26
-
27
- // src/MetaMaskConnector.ts
28
- var import_forget = require("@xylabs/forget");
29
- var import_ethers = require("ethers");
30
- var MetaMaskConnector = class {
31
- account = "";
32
- ethereum = window.ethereum;
33
- listeners = [];
34
- provider;
35
- providerListeners = [];
36
- constructor(provider) {
37
- if (provider) {
38
- this.provider = provider;
39
- } else if (this.ethereum) {
40
- this.provider = new import_ethers.BrowserProvider(window.ethereum);
41
- }
42
- }
43
- get chainId() {
44
- var _a;
45
- return (_a = this.ethereum) == null ? void 0 : _a.networkVersion;
46
- }
47
- get currentAccount() {
48
- var _a;
49
- return (_a = this.ethereum) == null ? void 0 : _a.selectedAddress;
50
- }
51
- async connectWallet() {
52
- if (!this.provider) {
53
- this.logProviderMissing();
54
- return;
55
- }
56
- const accounts = await this.provider.send("eth_requestAccounts", []);
57
- if (accounts.length > 0) {
58
- this.account = accounts[0];
59
- console.log("Connected:", this.account);
60
- } else {
61
- console.log("No authorized account found.");
62
- }
63
- }
64
- isMetaMaskInstalled() {
65
- return this.ethereum && this.ethereum.isMetaMask;
66
- }
67
- isWalletIsConnected = () => {
68
- var _a;
69
- if (this.currentAccount) {
70
- console.log("Found an authorized account:", (_a = this.ethereum) == null ? void 0 : _a.selectedAddress);
71
- return true;
72
- }
73
- return false;
74
- };
75
- /**
76
- * EIP-1193 Event Listeners
77
- *
78
- * .on in Web3Provider does not understand EIP-1193 events
79
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
80
- */
81
- providerOnAccountsChanged(listener) {
82
- var _a;
83
- (_a = this.ethereum) == null ? void 0 : _a.on("accountsChanged", listener);
84
- this.providerListeners.push(["accountsChanged", listener]);
85
- }
86
- providerOnChainChanged(listener) {
87
- var _a;
88
- (_a = this.ethereum) == null ? void 0 : _a.on("chainChanged", listener);
89
- this.providerListeners.push(["chainChanged", listener]);
90
- }
91
- providerOnConnect(listener) {
92
- var _a;
93
- (_a = this.ethereum) == null ? void 0 : _a.on("connect", listener);
94
- this.providerListeners.push(["connect", listener]);
95
- }
96
- providerOnDisconnect(listener) {
97
- var _a;
98
- (_a = this.ethereum) == null ? void 0 : _a.on("disconnect", listener);
99
- this.providerListeners.push(["disconnect", listener]);
100
- }
101
- providerRemoveListener(event, listener) {
102
- this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
103
- }
104
- providerRemoveListeners() {
105
- }
106
- async requestAccounts() {
107
- if (!this.provider) {
108
- this.logProviderMissing();
109
- return null;
110
- }
111
- return await this.provider.send("eth_requestAccounts", []);
112
- }
113
- async signMessage(message) {
114
- if (!this.provider) {
115
- this.logProviderMissing();
116
- return;
117
- }
118
- const signer = await this.provider.getSigner();
119
- await signer.getAddress();
120
- return await signer.signMessage(message);
121
- }
122
- /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
123
- web3ProviderOn(event, listener) {
124
- if (this.provider) {
125
- (0, import_forget.forget)(this.provider.on(event, listener));
126
- }
127
- this.listeners.push(listener);
128
- }
129
- web3ProviderRemoveListener(event, listener) {
130
- if (this.provider) {
131
- (0, import_forget.forget)(this.provider.removeListener(event, listener));
132
- }
133
- this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
134
- }
135
- web3ProviderRemoveListeners() {
136
- if (this.provider) {
137
- (0, import_forget.forget)(this.provider.removeAllListeners());
138
- }
139
- }
140
- logProviderMissing() {
141
- console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
142
- }
143
- };
144
- // Annotate the CommonJS export names for ESM import in node:
145
- 0 && (module.exports = {
146
- MetaMaskConnector
147
- });
148
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector.ts'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\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(window.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 (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":[]}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,2 +0,0 @@
1
- export * from './MetaMaskConnector.ts';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
@@ -1,121 +0,0 @@
1
- // src/MetaMaskConnector.ts
2
- import { forget } from "@xylabs/forget";
3
- import { BrowserProvider } from "ethers";
4
- var MetaMaskConnector = class {
5
- account = "";
6
- ethereum = window.ethereum;
7
- listeners = [];
8
- provider;
9
- providerListeners = [];
10
- constructor(provider) {
11
- if (provider) {
12
- this.provider = provider;
13
- } else if (this.ethereum) {
14
- this.provider = new BrowserProvider(window.ethereum);
15
- }
16
- }
17
- get chainId() {
18
- var _a;
19
- return (_a = this.ethereum) == null ? void 0 : _a.networkVersion;
20
- }
21
- get currentAccount() {
22
- var _a;
23
- return (_a = this.ethereum) == null ? void 0 : _a.selectedAddress;
24
- }
25
- async connectWallet() {
26
- if (!this.provider) {
27
- this.logProviderMissing();
28
- return;
29
- }
30
- const accounts = await this.provider.send("eth_requestAccounts", []);
31
- if (accounts.length > 0) {
32
- this.account = accounts[0];
33
- console.log("Connected:", this.account);
34
- } else {
35
- console.log("No authorized account found.");
36
- }
37
- }
38
- isMetaMaskInstalled() {
39
- return this.ethereum && this.ethereum.isMetaMask;
40
- }
41
- isWalletIsConnected = () => {
42
- var _a;
43
- if (this.currentAccount) {
44
- console.log("Found an authorized account:", (_a = this.ethereum) == null ? void 0 : _a.selectedAddress);
45
- return true;
46
- }
47
- return false;
48
- };
49
- /**
50
- * EIP-1193 Event Listeners
51
- *
52
- * .on in Web3Provider does not understand EIP-1193 events
53
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
54
- */
55
- providerOnAccountsChanged(listener) {
56
- var _a;
57
- (_a = this.ethereum) == null ? void 0 : _a.on("accountsChanged", listener);
58
- this.providerListeners.push(["accountsChanged", listener]);
59
- }
60
- providerOnChainChanged(listener) {
61
- var _a;
62
- (_a = this.ethereum) == null ? void 0 : _a.on("chainChanged", listener);
63
- this.providerListeners.push(["chainChanged", listener]);
64
- }
65
- providerOnConnect(listener) {
66
- var _a;
67
- (_a = this.ethereum) == null ? void 0 : _a.on("connect", listener);
68
- this.providerListeners.push(["connect", listener]);
69
- }
70
- providerOnDisconnect(listener) {
71
- var _a;
72
- (_a = this.ethereum) == null ? void 0 : _a.on("disconnect", listener);
73
- this.providerListeners.push(["disconnect", listener]);
74
- }
75
- providerRemoveListener(event, listener) {
76
- this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
77
- }
78
- providerRemoveListeners() {
79
- }
80
- async requestAccounts() {
81
- if (!this.provider) {
82
- this.logProviderMissing();
83
- return null;
84
- }
85
- return await this.provider.send("eth_requestAccounts", []);
86
- }
87
- async signMessage(message) {
88
- if (!this.provider) {
89
- this.logProviderMissing();
90
- return;
91
- }
92
- const signer = await this.provider.getSigner();
93
- await signer.getAddress();
94
- return await signer.signMessage(message);
95
- }
96
- /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
97
- web3ProviderOn(event, listener) {
98
- if (this.provider) {
99
- forget(this.provider.on(event, listener));
100
- }
101
- this.listeners.push(listener);
102
- }
103
- web3ProviderRemoveListener(event, listener) {
104
- if (this.provider) {
105
- forget(this.provider.removeListener(event, listener));
106
- }
107
- this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
108
- }
109
- web3ProviderRemoveListeners() {
110
- if (this.provider) {
111
- forget(this.provider.removeAllListeners());
112
- }
113
- }
114
- logProviderMissing() {
115
- console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
116
- }
117
- };
118
- export {
119
- MetaMaskConnector
120
- };
121
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\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(window.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 (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":[]}