@dynamic-labs/ethereum 2.1.0-alpha.3 → 2.1.0-alpha.31
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/CHANGELOG.md +263 -0
- package/package.json +11 -11
- package/src/EthWalletConnector.cjs +5 -1
- package/src/EthWalletConnector.d.ts +2786 -6
- package/src/EthWalletConnector.js +5 -1
- package/src/coinbase/coinbase.cjs +57 -71
- package/src/coinbase/coinbase.d.ts +6893 -291
- package/src/coinbase/coinbase.js +58 -72
- package/src/coinbase/helpers.cjs +35 -0
- package/src/coinbase/helpers.d.ts +3 -0
- package/src/coinbase/helpers.js +31 -0
- package/src/coinbase/types.d.ts +21 -0
- package/src/index.cjs +3 -0
- package/src/index.js +3 -0
- package/src/injected/PhantomEvm.cjs +1 -1
- package/src/injected/PhantomEvm.js +1 -1
- package/src/injected/UnknownInjected.cjs +21 -0
- package/src/injected/UnknownInjected.d.ts +8 -0
- package/src/injected/UnknownInjected.js +17 -0
- package/src/injected/fetchInjectedWalletConnectors.cjs +0 -3
- package/src/injected/fetchInjectedWalletConnectors.js +0 -3
- package/src/injected/index.d.ts +1 -0
- package/src/walletConnect/walletConnect.d.ts +6883 -17
- package/src/coinbase/client/client.cjs +0 -73
- package/src/coinbase/client/client.d.ts +0 -7
- package/src/coinbase/client/client.js +0 -66
- package/src/coinbase/client/index.d.ts +0 -2
- package/src/coinbase/client/types.d.ts +0 -17
- package/src/injected/Zerion.cjs +0 -39
- package/src/injected/Zerion.d.ts +0 -10
- package/src/injected/Zerion.js +0 -35
|
@@ -139,7 +139,11 @@ class EthWalletConnector extends WalletConnectorBase {
|
|
|
139
139
|
if (!this.supportsNetworkSwitching()) {
|
|
140
140
|
throw new DynamicError('Network switching is not supported');
|
|
141
141
|
}
|
|
142
|
-
|
|
142
|
+
yield provider.switchChain(getOrMapViemChain(network));
|
|
143
|
+
if (this.key === 'magiceden') {
|
|
144
|
+
const newChainId = yield provider.getChainId();
|
|
145
|
+
this.emit('chainChange', { chain: newChainId.toString() });
|
|
146
|
+
}
|
|
143
147
|
}
|
|
144
148
|
catch (error) {
|
|
145
149
|
// we need to check for unrecognized chain error first because it also contains 'rejected' in message
|
|
@@ -5,103 +5,89 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
5
5
|
|
|
6
6
|
var _tslib = require('../../_virtual/_tslib.cjs');
|
|
7
7
|
var viem = require('viem');
|
|
8
|
-
var walletBook = require('@dynamic-labs/wallet-book');
|
|
9
8
|
var walletConnectorCore = require('@dynamic-labs/wallet-connector-core');
|
|
10
|
-
var
|
|
9
|
+
var viemUtils = require('@dynamic-labs/viem-utils');
|
|
11
10
|
var EthWalletConnector = require('../EthWalletConnector.cjs');
|
|
12
|
-
var
|
|
11
|
+
var helpers = require('./helpers.cjs');
|
|
13
12
|
|
|
14
13
|
class Coinbase extends EthWalletConnector.EthWalletConnector {
|
|
15
14
|
constructor(_a) {
|
|
16
|
-
var { appName, appLogoUrl, evmNetworks } = _a, props = _tslib.__rest(_a, ["appName", "appLogoUrl", "evmNetworks"]);
|
|
15
|
+
var { appName, appLogoUrl, evmNetworks, coinbaseWalletPreference } = _a, props = _tslib.__rest(_a, ["appName", "appLogoUrl", "evmNetworks", "coinbaseWalletPreference"]);
|
|
17
16
|
super(Object.assign({ evmNetworks }, props));
|
|
18
17
|
this.name = 'Coinbase';
|
|
19
18
|
this.overrideKey = 'coinbase';
|
|
20
19
|
this.supportedChains = ['EVM', 'ETH'];
|
|
21
20
|
this.connectedChain = 'EVM';
|
|
22
|
-
this.canConnectViaQrCode =
|
|
23
|
-
this.
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
this.ethProviderHelper = new ethProviderHelper.EthProviderHelper(wallet, this);
|
|
32
|
-
}
|
|
33
|
-
setupEventListeners() {
|
|
34
|
-
var _a, _b, _c;
|
|
35
|
-
if (!this.isInstalledOnBrowser()) {
|
|
36
|
-
this.setupCoinbaseProviderEventListeners();
|
|
37
|
-
return;
|
|
38
|
-
}
|
|
39
|
-
const provider = (_a = this.ethProviderHelper) === null || _a === void 0 ? void 0 : _a.findProvider();
|
|
40
|
-
if (!provider) {
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
const setupResponse = (_c = (_b = this.ethProviderHelper) === null || _b === void 0 ? void 0 : _b._setupEventListeners) === null || _c === void 0 ? void 0 : _c.call(_b, this);
|
|
44
|
-
if (!(setupResponse === null || setupResponse === void 0 ? void 0 : setupResponse.tearDownEventListeners))
|
|
45
|
-
return;
|
|
46
|
-
this.teardownEventListeners = setupResponse.tearDownEventListeners;
|
|
47
|
-
}
|
|
48
|
-
getWalletClient(chainId) {
|
|
49
|
-
var _a;
|
|
50
|
-
if (this.isInstalledOnBrowser()) {
|
|
51
|
-
return (_a = this.ethProviderHelper) === null || _a === void 0 ? void 0 : _a.findWalletClient(chainId);
|
|
52
|
-
}
|
|
53
|
-
return viem.createWalletClient({
|
|
54
|
-
transport: viem.custom(client.getCoinbaseClient({
|
|
55
|
-
opts: this.coinbaseProviderOpts,
|
|
56
|
-
}).provider),
|
|
21
|
+
this.canConnectViaQrCode = false;
|
|
22
|
+
this.canConnectViaCustodialService = true;
|
|
23
|
+
this.coinbaseProvider = helpers.getCoinbaseProvider({
|
|
24
|
+
opts: {
|
|
25
|
+
appLogoUrl: appLogoUrl,
|
|
26
|
+
appName: appName,
|
|
27
|
+
evmNetworks: evmNetworks,
|
|
28
|
+
walletPreference: coinbaseWalletPreference,
|
|
29
|
+
},
|
|
57
30
|
});
|
|
58
31
|
}
|
|
59
|
-
|
|
60
|
-
var _a;
|
|
61
|
-
return ((_a = this.ethProviderHelper) === null || _a === void 0 ? void 0 : _a.findProvider()) !== undefined;
|
|
62
|
-
}
|
|
63
|
-
getAddress(opts) {
|
|
32
|
+
getConnectedAccounts() {
|
|
64
33
|
return _tslib.__awaiter(this, void 0, void 0, function* () {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
34
|
+
try {
|
|
35
|
+
const accounts = yield this.coinbaseProvider.request({
|
|
36
|
+
method: 'eth_accounts',
|
|
37
|
+
});
|
|
38
|
+
if (accounts[0]) {
|
|
39
|
+
this.setActiveAccount(accounts[0]);
|
|
40
|
+
}
|
|
41
|
+
return accounts;
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
return [];
|
|
68
45
|
}
|
|
69
|
-
return client.getAddress(this.coinbaseProviderOpts, opts);
|
|
70
46
|
});
|
|
71
47
|
}
|
|
72
|
-
|
|
48
|
+
getAddress() {
|
|
73
49
|
return _tslib.__awaiter(this, void 0, void 0, function* () {
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
return
|
|
50
|
+
const [address] = yield this.coinbaseProvider.request({
|
|
51
|
+
method: 'eth_requestAccounts',
|
|
52
|
+
});
|
|
53
|
+
this.setActiveAccount(address);
|
|
54
|
+
return address;
|
|
79
55
|
});
|
|
80
56
|
}
|
|
81
|
-
|
|
57
|
+
signMessage(messageToSign) {
|
|
82
58
|
return _tslib.__awaiter(this, void 0, void 0, function* () {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
59
|
+
const [address] = yield this.coinbaseProvider.request({
|
|
60
|
+
method: 'eth_requestAccounts',
|
|
61
|
+
});
|
|
62
|
+
try {
|
|
63
|
+
return yield this.coinbaseProvider.request({
|
|
64
|
+
method: 'personal_sign',
|
|
65
|
+
params: [viem.toHex(viem.toBytes(messageToSign)), address.toLowerCase()],
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
catch (err) {
|
|
69
|
+
return undefined;
|
|
70
|
+
}
|
|
86
71
|
});
|
|
87
72
|
}
|
|
88
|
-
|
|
89
|
-
const { provider } = client.getCoinbaseClient({
|
|
90
|
-
opts: this.coinbaseProviderOpts,
|
|
91
|
-
});
|
|
92
|
-
if (!provider) {
|
|
93
|
-
return;
|
|
94
|
-
}
|
|
73
|
+
setupEventListeners() {
|
|
95
74
|
const { handleAccountChange, handleChainChange, handleDisconnect } = walletConnectorCore.eventListenerHandlers(this);
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
75
|
+
this.coinbaseProvider.on('accountsChanged', handleAccountChange);
|
|
76
|
+
this.coinbaseProvider.on('chainChanged', handleChainChange);
|
|
77
|
+
this.coinbaseProvider.on('disconnect', handleDisconnect);
|
|
99
78
|
this.teardownEventListeners = () => {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
79
|
+
this.coinbaseProvider.removeListener('accountsChanged', handleAccountChange);
|
|
80
|
+
this.coinbaseProvider.removeListener('chainChanged', handleChainChange);
|
|
81
|
+
this.coinbaseProvider.removeListener('disconnect', handleDisconnect);
|
|
103
82
|
};
|
|
104
83
|
}
|
|
84
|
+
getWalletClient(chainId) {
|
|
85
|
+
return viem.createWalletClient({
|
|
86
|
+
account: this.getActiveAccount(),
|
|
87
|
+
chain: chainId ? viemUtils.chainsMap[chainId] : undefined,
|
|
88
|
+
transport: viem.custom(this.coinbaseProvider),
|
|
89
|
+
});
|
|
90
|
+
}
|
|
105
91
|
}
|
|
106
92
|
|
|
107
93
|
exports.Coinbase = Coinbase;
|