@xyo-network/metamask-connector 2.74.4 → 2.75.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/browser/MetaMaskConnector.cjs +131 -0
- package/dist/browser/MetaMaskConnector.cjs.map +1 -0
- package/dist/browser/MetaMaskConnector.d.mts +34 -0
- package/dist/browser/MetaMaskConnector.d.mts.map +1 -0
- package/dist/browser/MetaMaskConnector.d.ts +34 -0
- package/dist/browser/MetaMaskConnector.d.ts.map +1 -0
- package/dist/browser/MetaMaskConnector.js +110 -0
- package/dist/browser/MetaMaskConnector.js.map +1 -0
- package/dist/browser/global.d.cjs +2 -0
- package/dist/browser/global.d.cjs.map +1 -0
- package/dist/browser/global.d.js +1 -0
- package/dist/browser/global.d.js.map +1 -0
- package/dist/{index.js → browser/index.cjs} +53 -19
- package/dist/browser/index.cjs.map +1 -0
- package/dist/{index.d.mts.map → browser/index.d.mts.map} +1 -1
- package/dist/{index.d.ts.map → browser/index.d.ts.map} +1 -1
- package/dist/{index.mjs → browser/index.js} +53 -15
- package/dist/browser/index.js.map +1 -0
- package/dist/node/MetaMaskConnector.d.mts +34 -0
- package/dist/node/MetaMaskConnector.d.mts.map +1 -0
- package/dist/node/MetaMaskConnector.d.ts +34 -0
- package/dist/node/MetaMaskConnector.d.ts.map +1 -0
- package/dist/node/MetaMaskConnector.js +133 -0
- package/dist/node/MetaMaskConnector.js.map +1 -0
- package/dist/node/MetaMaskConnector.mjs +109 -0
- package/dist/node/MetaMaskConnector.mjs.map +1 -0
- package/dist/node/global.d.js +2 -0
- package/dist/node/global.d.js.map +1 -0
- package/dist/node/global.d.mjs +1 -0
- package/dist/node/global.d.mjs.map +1 -0
- package/dist/node/index.d.mts +2 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +2 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +23 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/index.mjs +2 -0
- package/dist/node/index.mjs.map +1 -0
- package/package.json +24 -21
- package/src/MetaMaskConnector.ts +54 -8
- package/dist/MetaMaskConnector.d.mts +0 -19
- package/dist/MetaMaskConnector.d.mts.map +0 -1
- package/dist/MetaMaskConnector.d.ts +0 -19
- package/dist/MetaMaskConnector.d.ts.map +0 -1
- package/dist/docs.json +0 -866
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- /package/dist/{index.d.mts → browser/index.d.mts} +0 -0
- /package/dist/{index.d.ts → browser/index.d.ts} +0 -0
|
@@ -0,0 +1,131 @@
|
|
|
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/MetaMaskConnector.ts
|
|
21
|
+
var MetaMaskConnector_exports = {};
|
|
22
|
+
__export(MetaMaskConnector_exports, {
|
|
23
|
+
MetaMaskConnector: () => MetaMaskConnector
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(MetaMaskConnector_exports);
|
|
26
|
+
var import_providers = require("@ethersproject/providers");
|
|
27
|
+
var MetaMaskConnector = class {
|
|
28
|
+
account = "";
|
|
29
|
+
ethereum = window.ethereum;
|
|
30
|
+
listeners = [];
|
|
31
|
+
provider;
|
|
32
|
+
providerListeners = [];
|
|
33
|
+
constructor(provider) {
|
|
34
|
+
if (provider) {
|
|
35
|
+
this.provider = provider;
|
|
36
|
+
} else if (this.ethereum) {
|
|
37
|
+
this.provider = new import_providers.Web3Provider(window.ethereum);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
get chainId() {
|
|
41
|
+
return this.ethereum?.networkVersion;
|
|
42
|
+
}
|
|
43
|
+
get currentAccount() {
|
|
44
|
+
return this.ethereum?.selectedAddress;
|
|
45
|
+
}
|
|
46
|
+
async connectWallet() {
|
|
47
|
+
if (!this.provider) {
|
|
48
|
+
this.logProviderMissing();
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const accounts = await this.provider.send("eth_requestAccounts", []);
|
|
52
|
+
if (accounts.length !== 0) {
|
|
53
|
+
this.account = accounts[0];
|
|
54
|
+
console.log("Connected: ", this.account);
|
|
55
|
+
} else {
|
|
56
|
+
console.log("No authorized account found.");
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
isMetaMaskInstalled() {
|
|
60
|
+
return this.ethereum && this.ethereum.isMetaMask;
|
|
61
|
+
}
|
|
62
|
+
isWalletIsConnected = () => {
|
|
63
|
+
if (this.currentAccount) {
|
|
64
|
+
console.log("Found an authorized account: ", this.ethereum?.selectedAddress);
|
|
65
|
+
return true;
|
|
66
|
+
}
|
|
67
|
+
return false;
|
|
68
|
+
};
|
|
69
|
+
/**
|
|
70
|
+
* EIP-1193 Event Listeners
|
|
71
|
+
*
|
|
72
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
73
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
74
|
+
*/
|
|
75
|
+
providerOnAccountsChanged(listener) {
|
|
76
|
+
this.ethereum?.on("accountsChanged", listener);
|
|
77
|
+
this.providerListeners.push(["accountsChanged", listener]);
|
|
78
|
+
}
|
|
79
|
+
providerOnChainChanged(listener) {
|
|
80
|
+
this.ethereum?.on("chainChanged", listener);
|
|
81
|
+
this.providerListeners.push(["chainChanged", listener]);
|
|
82
|
+
}
|
|
83
|
+
providerOnConnect(listener) {
|
|
84
|
+
this.ethereum?.on("connect", listener);
|
|
85
|
+
this.providerListeners.push(["connect", listener]);
|
|
86
|
+
}
|
|
87
|
+
providerOnDisconnect(listener) {
|
|
88
|
+
this.ethereum?.on("disconnect", listener);
|
|
89
|
+
this.providerListeners.push(["disconnect", listener]);
|
|
90
|
+
}
|
|
91
|
+
providerRemoveListener(event, listener) {
|
|
92
|
+
this.ethereum?.removeListener(event, listener);
|
|
93
|
+
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
94
|
+
}
|
|
95
|
+
providerRemoveListeners() {
|
|
96
|
+
this.providerListeners.forEach(([event, listener]) => this.ethereum?.removeListener(event, listener));
|
|
97
|
+
}
|
|
98
|
+
async requestAccounts() {
|
|
99
|
+
if (!this.provider) {
|
|
100
|
+
this.logProviderMissing();
|
|
101
|
+
return null;
|
|
102
|
+
}
|
|
103
|
+
return await this.provider.send("eth_requestAccounts", []);
|
|
104
|
+
}
|
|
105
|
+
async signMessage(message) {
|
|
106
|
+
if (!this.provider) {
|
|
107
|
+
this.logProviderMissing();
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
const signer = this.provider.getSigner();
|
|
111
|
+
await signer.getAddress();
|
|
112
|
+
const signature = await signer.signMessage(message);
|
|
113
|
+
return signature;
|
|
114
|
+
}
|
|
115
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
116
|
+
web3ProviderOn(event, listener) {
|
|
117
|
+
this.provider?.on(event, listener);
|
|
118
|
+
this.listeners.push(listener);
|
|
119
|
+
}
|
|
120
|
+
web3ProviderRemoveListener(event, listener) {
|
|
121
|
+
this.provider?.removeListener(event, listener);
|
|
122
|
+
this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
|
|
123
|
+
}
|
|
124
|
+
web3ProviderRemoveListeners() {
|
|
125
|
+
this.provider?.removeAllListeners();
|
|
126
|
+
}
|
|
127
|
+
logProviderMissing() {
|
|
128
|
+
console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
//# sourceMappingURL=MetaMaskConnector.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { Listener, Web3Provider } from '@ethersproject/providers'\nimport { MetaMaskInpageProvider } from '@metamask/providers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: Web3Provider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: Web3Provider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new Web3Provider(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 this.providerListeners.forEach(([event, listener]) => 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 = this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\n }\n\n private logProviderMissing() {\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":[]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Listener, Web3Provider } from '@ethersproject/providers';
|
|
2
|
+
export declare class MetaMaskConnector {
|
|
3
|
+
private account;
|
|
4
|
+
private ethereum;
|
|
5
|
+
private listeners;
|
|
6
|
+
private provider;
|
|
7
|
+
private providerListeners;
|
|
8
|
+
constructor(provider?: Web3Provider);
|
|
9
|
+
get chainId(): string | null;
|
|
10
|
+
get currentAccount(): string | null;
|
|
11
|
+
connectWallet(): Promise<void>;
|
|
12
|
+
isMetaMaskInstalled(): true;
|
|
13
|
+
isWalletIsConnected: () => boolean;
|
|
14
|
+
/**
|
|
15
|
+
* EIP-1193 Event Listeners
|
|
16
|
+
*
|
|
17
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
18
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
19
|
+
*/
|
|
20
|
+
providerOnAccountsChanged(listener: Listener): void;
|
|
21
|
+
providerOnChainChanged(listener: Listener): void;
|
|
22
|
+
providerOnConnect(listener: Listener): void;
|
|
23
|
+
providerOnDisconnect(listener: Listener): void;
|
|
24
|
+
providerRemoveListener(event: string, listener: Listener): void;
|
|
25
|
+
providerRemoveListeners(): void;
|
|
26
|
+
requestAccounts(): Promise<string[] | null>;
|
|
27
|
+
signMessage(message: string): Promise<string | undefined>;
|
|
28
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
29
|
+
web3ProviderOn(event: string, listener: Listener): void;
|
|
30
|
+
web3ProviderRemoveListener(event: string, listener: Listener): void;
|
|
31
|
+
web3ProviderRemoveListeners(): void;
|
|
32
|
+
private logProviderMissing;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=MetaMaskConnector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAGjE,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA0B;IAC1C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,YAAY;IAQnC,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;IAYjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKhD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAK5D,2BAA2B;IAI3B,OAAO,CAAC,kBAAkB;CAG3B"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Listener, Web3Provider } from '@ethersproject/providers';
|
|
2
|
+
export declare class MetaMaskConnector {
|
|
3
|
+
private account;
|
|
4
|
+
private ethereum;
|
|
5
|
+
private listeners;
|
|
6
|
+
private provider;
|
|
7
|
+
private providerListeners;
|
|
8
|
+
constructor(provider?: Web3Provider);
|
|
9
|
+
get chainId(): string | null;
|
|
10
|
+
get currentAccount(): string | null;
|
|
11
|
+
connectWallet(): Promise<void>;
|
|
12
|
+
isMetaMaskInstalled(): true;
|
|
13
|
+
isWalletIsConnected: () => boolean;
|
|
14
|
+
/**
|
|
15
|
+
* EIP-1193 Event Listeners
|
|
16
|
+
*
|
|
17
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
18
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
19
|
+
*/
|
|
20
|
+
providerOnAccountsChanged(listener: Listener): void;
|
|
21
|
+
providerOnChainChanged(listener: Listener): void;
|
|
22
|
+
providerOnConnect(listener: Listener): void;
|
|
23
|
+
providerOnDisconnect(listener: Listener): void;
|
|
24
|
+
providerRemoveListener(event: string, listener: Listener): void;
|
|
25
|
+
providerRemoveListeners(): void;
|
|
26
|
+
requestAccounts(): Promise<string[] | null>;
|
|
27
|
+
signMessage(message: string): Promise<string | undefined>;
|
|
28
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
29
|
+
web3ProviderOn(event: string, listener: Listener): void;
|
|
30
|
+
web3ProviderRemoveListener(event: string, listener: Listener): void;
|
|
31
|
+
web3ProviderRemoveListeners(): void;
|
|
32
|
+
private logProviderMissing;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=MetaMaskConnector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAGjE,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA0B;IAC1C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,YAAY;IAQnC,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;IAYjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKhD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAK5D,2BAA2B;IAI3B,OAAO,CAAC,kBAAkB;CAG3B"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
// src/MetaMaskConnector.ts
|
|
2
|
+
import { Web3Provider } from "@ethersproject/providers";
|
|
3
|
+
var MetaMaskConnector = class {
|
|
4
|
+
account = "";
|
|
5
|
+
ethereum = window.ethereum;
|
|
6
|
+
listeners = [];
|
|
7
|
+
provider;
|
|
8
|
+
providerListeners = [];
|
|
9
|
+
constructor(provider) {
|
|
10
|
+
if (provider) {
|
|
11
|
+
this.provider = provider;
|
|
12
|
+
} else if (this.ethereum) {
|
|
13
|
+
this.provider = new Web3Provider(window.ethereum);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
get chainId() {
|
|
17
|
+
return this.ethereum?.networkVersion;
|
|
18
|
+
}
|
|
19
|
+
get currentAccount() {
|
|
20
|
+
return this.ethereum?.selectedAddress;
|
|
21
|
+
}
|
|
22
|
+
async connectWallet() {
|
|
23
|
+
if (!this.provider) {
|
|
24
|
+
this.logProviderMissing();
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
const accounts = await this.provider.send("eth_requestAccounts", []);
|
|
28
|
+
if (accounts.length !== 0) {
|
|
29
|
+
this.account = accounts[0];
|
|
30
|
+
console.log("Connected: ", this.account);
|
|
31
|
+
} else {
|
|
32
|
+
console.log("No authorized account found.");
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
isMetaMaskInstalled() {
|
|
36
|
+
return this.ethereum && this.ethereum.isMetaMask;
|
|
37
|
+
}
|
|
38
|
+
isWalletIsConnected = () => {
|
|
39
|
+
if (this.currentAccount) {
|
|
40
|
+
console.log("Found an authorized account: ", this.ethereum?.selectedAddress);
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
return false;
|
|
44
|
+
};
|
|
45
|
+
/**
|
|
46
|
+
* EIP-1193 Event Listeners
|
|
47
|
+
*
|
|
48
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
49
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
50
|
+
*/
|
|
51
|
+
providerOnAccountsChanged(listener) {
|
|
52
|
+
this.ethereum?.on("accountsChanged", listener);
|
|
53
|
+
this.providerListeners.push(["accountsChanged", listener]);
|
|
54
|
+
}
|
|
55
|
+
providerOnChainChanged(listener) {
|
|
56
|
+
this.ethereum?.on("chainChanged", listener);
|
|
57
|
+
this.providerListeners.push(["chainChanged", listener]);
|
|
58
|
+
}
|
|
59
|
+
providerOnConnect(listener) {
|
|
60
|
+
this.ethereum?.on("connect", listener);
|
|
61
|
+
this.providerListeners.push(["connect", listener]);
|
|
62
|
+
}
|
|
63
|
+
providerOnDisconnect(listener) {
|
|
64
|
+
this.ethereum?.on("disconnect", listener);
|
|
65
|
+
this.providerListeners.push(["disconnect", listener]);
|
|
66
|
+
}
|
|
67
|
+
providerRemoveListener(event, listener) {
|
|
68
|
+
this.ethereum?.removeListener(event, listener);
|
|
69
|
+
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
70
|
+
}
|
|
71
|
+
providerRemoveListeners() {
|
|
72
|
+
this.providerListeners.forEach(([event, listener]) => this.ethereum?.removeListener(event, listener));
|
|
73
|
+
}
|
|
74
|
+
async requestAccounts() {
|
|
75
|
+
if (!this.provider) {
|
|
76
|
+
this.logProviderMissing();
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
return await this.provider.send("eth_requestAccounts", []);
|
|
80
|
+
}
|
|
81
|
+
async signMessage(message) {
|
|
82
|
+
if (!this.provider) {
|
|
83
|
+
this.logProviderMissing();
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
const signer = this.provider.getSigner();
|
|
87
|
+
await signer.getAddress();
|
|
88
|
+
const signature = await signer.signMessage(message);
|
|
89
|
+
return signature;
|
|
90
|
+
}
|
|
91
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
92
|
+
web3ProviderOn(event, listener) {
|
|
93
|
+
this.provider?.on(event, listener);
|
|
94
|
+
this.listeners.push(listener);
|
|
95
|
+
}
|
|
96
|
+
web3ProviderRemoveListener(event, listener) {
|
|
97
|
+
this.provider?.removeListener(event, listener);
|
|
98
|
+
this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
|
|
99
|
+
}
|
|
100
|
+
web3ProviderRemoveListeners() {
|
|
101
|
+
this.provider?.removeAllListeners();
|
|
102
|
+
}
|
|
103
|
+
logProviderMissing() {
|
|
104
|
+
console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
|
|
105
|
+
}
|
|
106
|
+
};
|
|
107
|
+
export {
|
|
108
|
+
MetaMaskConnector
|
|
109
|
+
};
|
|
110
|
+
//# sourceMappingURL=MetaMaskConnector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { Listener, Web3Provider } from '@ethersproject/providers'\nimport { MetaMaskInpageProvider } from '@metamask/providers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: Web3Provider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: Web3Provider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new Web3Provider(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 this.providerListeners.forEach(([event, listener]) => 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 = this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\n }\n\n private logProviderMissing() {\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":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=global.d.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -29,8 +29,9 @@ var import_providers = require("@ethersproject/providers");
|
|
|
29
29
|
var MetaMaskConnector = class {
|
|
30
30
|
account = "";
|
|
31
31
|
ethereum = window.ethereum;
|
|
32
|
-
provider;
|
|
33
32
|
listeners = [];
|
|
33
|
+
provider;
|
|
34
|
+
providerListeners = [];
|
|
34
35
|
constructor(provider) {
|
|
35
36
|
if (provider) {
|
|
36
37
|
this.provider = provider;
|
|
@@ -38,22 +39,11 @@ var MetaMaskConnector = class {
|
|
|
38
39
|
this.provider = new import_providers.Web3Provider(window.ethereum);
|
|
39
40
|
}
|
|
40
41
|
}
|
|
41
|
-
get currentAccount() {
|
|
42
|
-
return this.ethereum?.selectedAddress;
|
|
43
|
-
}
|
|
44
42
|
get chainId() {
|
|
45
43
|
return this.ethereum?.networkVersion;
|
|
46
44
|
}
|
|
47
|
-
|
|
48
|
-
this.
|
|
49
|
-
this.listeners.push(listener);
|
|
50
|
-
}
|
|
51
|
-
removeListener(event, listener) {
|
|
52
|
-
this.provider.removeListener(event, listener);
|
|
53
|
-
this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
|
|
54
|
-
}
|
|
55
|
-
removeListeners() {
|
|
56
|
-
this.provider.removeAllListeners();
|
|
45
|
+
get currentAccount() {
|
|
46
|
+
return this.ethereum?.selectedAddress;
|
|
57
47
|
}
|
|
58
48
|
async connectWallet() {
|
|
59
49
|
if (!this.provider) {
|
|
@@ -78,6 +68,42 @@ var MetaMaskConnector = class {
|
|
|
78
68
|
}
|
|
79
69
|
return false;
|
|
80
70
|
};
|
|
71
|
+
/**
|
|
72
|
+
* EIP-1193 Event Listeners
|
|
73
|
+
*
|
|
74
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
75
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
76
|
+
*/
|
|
77
|
+
providerOnAccountsChanged(listener) {
|
|
78
|
+
this.ethereum?.on("accountsChanged", listener);
|
|
79
|
+
this.providerListeners.push(["accountsChanged", listener]);
|
|
80
|
+
}
|
|
81
|
+
providerOnChainChanged(listener) {
|
|
82
|
+
this.ethereum?.on("chainChanged", listener);
|
|
83
|
+
this.providerListeners.push(["chainChanged", listener]);
|
|
84
|
+
}
|
|
85
|
+
providerOnConnect(listener) {
|
|
86
|
+
this.ethereum?.on("connect", listener);
|
|
87
|
+
this.providerListeners.push(["connect", listener]);
|
|
88
|
+
}
|
|
89
|
+
providerOnDisconnect(listener) {
|
|
90
|
+
this.ethereum?.on("disconnect", listener);
|
|
91
|
+
this.providerListeners.push(["disconnect", listener]);
|
|
92
|
+
}
|
|
93
|
+
providerRemoveListener(event, listener) {
|
|
94
|
+
this.ethereum?.removeListener(event, listener);
|
|
95
|
+
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
96
|
+
}
|
|
97
|
+
providerRemoveListeners() {
|
|
98
|
+
this.providerListeners.forEach(([event, listener]) => this.ethereum?.removeListener(event, listener));
|
|
99
|
+
}
|
|
100
|
+
async requestAccounts() {
|
|
101
|
+
if (!this.provider) {
|
|
102
|
+
this.logProviderMissing();
|
|
103
|
+
return null;
|
|
104
|
+
}
|
|
105
|
+
return await this.provider.send("eth_requestAccounts", []);
|
|
106
|
+
}
|
|
81
107
|
async signMessage(message) {
|
|
82
108
|
if (!this.provider) {
|
|
83
109
|
this.logProviderMissing();
|
|
@@ -88,12 +114,20 @@ var MetaMaskConnector = class {
|
|
|
88
114
|
const signature = await signer.signMessage(message);
|
|
89
115
|
return signature;
|
|
90
116
|
}
|
|
117
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
118
|
+
web3ProviderOn(event, listener) {
|
|
119
|
+
this.provider?.on(event, listener);
|
|
120
|
+
this.listeners.push(listener);
|
|
121
|
+
}
|
|
122
|
+
web3ProviderRemoveListener(event, listener) {
|
|
123
|
+
this.provider?.removeListener(event, listener);
|
|
124
|
+
this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
|
|
125
|
+
}
|
|
126
|
+
web3ProviderRemoveListeners() {
|
|
127
|
+
this.provider?.removeAllListeners();
|
|
128
|
+
}
|
|
91
129
|
logProviderMissing() {
|
|
92
130
|
console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
|
|
93
131
|
}
|
|
94
132
|
};
|
|
95
|
-
|
|
96
|
-
0 && (module.exports = {
|
|
97
|
-
MetaMaskConnector
|
|
98
|
-
});
|
|
99
|
-
//# sourceMappingURL=index.js.map
|
|
133
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { Listener, Web3Provider } from '@ethersproject/providers'\nimport { MetaMaskInpageProvider } from '@metamask/providers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: Web3Provider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: Web3Provider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new Web3Provider(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 this.providerListeners.forEach(([event, listener]) => 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 = this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\n }\n\n private logProviderMissing() {\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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA"}
|
|
@@ -3,8 +3,9 @@ import { Web3Provider } from "@ethersproject/providers";
|
|
|
3
3
|
var MetaMaskConnector = class {
|
|
4
4
|
account = "";
|
|
5
5
|
ethereum = window.ethereum;
|
|
6
|
-
provider;
|
|
7
6
|
listeners = [];
|
|
7
|
+
provider;
|
|
8
|
+
providerListeners = [];
|
|
8
9
|
constructor(provider) {
|
|
9
10
|
if (provider) {
|
|
10
11
|
this.provider = provider;
|
|
@@ -12,22 +13,11 @@ var MetaMaskConnector = class {
|
|
|
12
13
|
this.provider = new Web3Provider(window.ethereum);
|
|
13
14
|
}
|
|
14
15
|
}
|
|
15
|
-
get currentAccount() {
|
|
16
|
-
return this.ethereum?.selectedAddress;
|
|
17
|
-
}
|
|
18
16
|
get chainId() {
|
|
19
17
|
return this.ethereum?.networkVersion;
|
|
20
18
|
}
|
|
21
|
-
|
|
22
|
-
this.
|
|
23
|
-
this.listeners.push(listener);
|
|
24
|
-
}
|
|
25
|
-
removeListener(event, listener) {
|
|
26
|
-
this.provider.removeListener(event, listener);
|
|
27
|
-
this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
|
|
28
|
-
}
|
|
29
|
-
removeListeners() {
|
|
30
|
-
this.provider.removeAllListeners();
|
|
19
|
+
get currentAccount() {
|
|
20
|
+
return this.ethereum?.selectedAddress;
|
|
31
21
|
}
|
|
32
22
|
async connectWallet() {
|
|
33
23
|
if (!this.provider) {
|
|
@@ -52,6 +42,42 @@ var MetaMaskConnector = class {
|
|
|
52
42
|
}
|
|
53
43
|
return false;
|
|
54
44
|
};
|
|
45
|
+
/**
|
|
46
|
+
* EIP-1193 Event Listeners
|
|
47
|
+
*
|
|
48
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
49
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
50
|
+
*/
|
|
51
|
+
providerOnAccountsChanged(listener) {
|
|
52
|
+
this.ethereum?.on("accountsChanged", listener);
|
|
53
|
+
this.providerListeners.push(["accountsChanged", listener]);
|
|
54
|
+
}
|
|
55
|
+
providerOnChainChanged(listener) {
|
|
56
|
+
this.ethereum?.on("chainChanged", listener);
|
|
57
|
+
this.providerListeners.push(["chainChanged", listener]);
|
|
58
|
+
}
|
|
59
|
+
providerOnConnect(listener) {
|
|
60
|
+
this.ethereum?.on("connect", listener);
|
|
61
|
+
this.providerListeners.push(["connect", listener]);
|
|
62
|
+
}
|
|
63
|
+
providerOnDisconnect(listener) {
|
|
64
|
+
this.ethereum?.on("disconnect", listener);
|
|
65
|
+
this.providerListeners.push(["disconnect", listener]);
|
|
66
|
+
}
|
|
67
|
+
providerRemoveListener(event, listener) {
|
|
68
|
+
this.ethereum?.removeListener(event, listener);
|
|
69
|
+
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
70
|
+
}
|
|
71
|
+
providerRemoveListeners() {
|
|
72
|
+
this.providerListeners.forEach(([event, listener]) => this.ethereum?.removeListener(event, listener));
|
|
73
|
+
}
|
|
74
|
+
async requestAccounts() {
|
|
75
|
+
if (!this.provider) {
|
|
76
|
+
this.logProviderMissing();
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
return await this.provider.send("eth_requestAccounts", []);
|
|
80
|
+
}
|
|
55
81
|
async signMessage(message) {
|
|
56
82
|
if (!this.provider) {
|
|
57
83
|
this.logProviderMissing();
|
|
@@ -62,6 +88,18 @@ var MetaMaskConnector = class {
|
|
|
62
88
|
const signature = await signer.signMessage(message);
|
|
63
89
|
return signature;
|
|
64
90
|
}
|
|
91
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
92
|
+
web3ProviderOn(event, listener) {
|
|
93
|
+
this.provider?.on(event, listener);
|
|
94
|
+
this.listeners.push(listener);
|
|
95
|
+
}
|
|
96
|
+
web3ProviderRemoveListener(event, listener) {
|
|
97
|
+
this.provider?.removeListener(event, listener);
|
|
98
|
+
this.listeners = this.listeners.filter((savedListener) => listener !== savedListener);
|
|
99
|
+
}
|
|
100
|
+
web3ProviderRemoveListeners() {
|
|
101
|
+
this.provider?.removeAllListeners();
|
|
102
|
+
}
|
|
65
103
|
logProviderMissing() {
|
|
66
104
|
console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
|
|
67
105
|
}
|
|
@@ -69,4 +107,4 @@ var MetaMaskConnector = class {
|
|
|
69
107
|
export {
|
|
70
108
|
MetaMaskConnector
|
|
71
109
|
};
|
|
72
|
-
//# sourceMappingURL=index.
|
|
110
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { Listener, Web3Provider } from '@ethersproject/providers'\nimport { MetaMaskInpageProvider } from '@metamask/providers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: Web3Provider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: Web3Provider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new Web3Provider(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 this.providerListeners.forEach(([event, listener]) => 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 = this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\n }\n\n private logProviderMissing() {\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":[]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Listener, Web3Provider } from '@ethersproject/providers';
|
|
2
|
+
export declare class MetaMaskConnector {
|
|
3
|
+
private account;
|
|
4
|
+
private ethereum;
|
|
5
|
+
private listeners;
|
|
6
|
+
private provider;
|
|
7
|
+
private providerListeners;
|
|
8
|
+
constructor(provider?: Web3Provider);
|
|
9
|
+
get chainId(): string | null;
|
|
10
|
+
get currentAccount(): string | null;
|
|
11
|
+
connectWallet(): Promise<void>;
|
|
12
|
+
isMetaMaskInstalled(): true;
|
|
13
|
+
isWalletIsConnected: () => boolean;
|
|
14
|
+
/**
|
|
15
|
+
* EIP-1193 Event Listeners
|
|
16
|
+
*
|
|
17
|
+
* .on in Web3Provider does not understand EIP-1193 events
|
|
18
|
+
* see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
|
|
19
|
+
*/
|
|
20
|
+
providerOnAccountsChanged(listener: Listener): void;
|
|
21
|
+
providerOnChainChanged(listener: Listener): void;
|
|
22
|
+
providerOnConnect(listener: Listener): void;
|
|
23
|
+
providerOnDisconnect(listener: Listener): void;
|
|
24
|
+
providerRemoveListener(event: string, listener: Listener): void;
|
|
25
|
+
providerRemoveListeners(): void;
|
|
26
|
+
requestAccounts(): Promise<string[] | null>;
|
|
27
|
+
signMessage(message: string): Promise<string | undefined>;
|
|
28
|
+
/** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */
|
|
29
|
+
web3ProviderOn(event: string, listener: Listener): void;
|
|
30
|
+
web3ProviderRemoveListener(event: string, listener: Listener): void;
|
|
31
|
+
web3ProviderRemoveListeners(): void;
|
|
32
|
+
private logProviderMissing;
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=MetaMaskConnector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MetaMaskConnector.d.ts","sourceRoot":"","sources":["../../src/MetaMaskConnector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAGjE,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAK;IACpB,OAAO,CAAC,QAAQ,CAA4C;IAE5D,OAAO,CAAC,SAAS,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAA0B;IAC1C,OAAO,CAAC,iBAAiB,CAA4C;gBAEzD,QAAQ,CAAC,EAAE,YAAY;IAQnC,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;IAYjC,mGAAmG;IACnG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAKhD,0BAA0B,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ;IAK5D,2BAA2B;IAI3B,OAAO,CAAC,kBAAkB;CAG3B"}
|