@dynamic-labs/ethereum 3.0.0-alpha.9 → 3.0.1
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 +628 -0
- package/package.json +8 -10
- package/src/coinbase/coinbase.cjs +4 -5
- package/src/coinbase/coinbase.d.ts +2 -2
- package/src/coinbase/coinbase.js +2 -3
- package/src/coinbase/types.d.ts +1 -1
- package/src/ethProviderHelper.cjs +3 -3
- package/src/ethProviderHelper.d.ts +2 -1
- package/src/ethProviderHelper.js +2 -2
- package/src/index.cjs +5 -7
- package/src/index.d.ts +2 -3
- package/src/index.js +1 -4
- package/src/injected/ExodusEvm.d.ts +1 -1
- package/src/injected/FallbackEvmConnector.d.ts +1 -1
- package/src/injected/InjectedWalletBase.cjs +5 -4
- package/src/injected/InjectedWalletBase.d.ts +2 -2
- package/src/injected/InjectedWalletBase.js +4 -3
- package/src/injected/PhantomEvm.cjs +4 -0
- package/src/injected/PhantomEvm.d.ts +2 -1
- package/src/injected/PhantomEvm.js +4 -0
- package/src/injected/UnknownInjected.d.ts +1 -1
- package/src/types.d.ts +1 -0
- package/src/walletConnect/walletConnect.cjs +3 -4
- package/src/walletConnect/walletConnect.d.ts +1 -1
- package/src/walletConnect/walletConnect.js +1 -2
- package/src/EthWalletConnector.cjs +0 -240
- package/src/EthWalletConnector.d.ts +0 -3086
- package/src/EthWalletConnector.js +0 -236
- package/src/utils/findEvmNetwork.cjs +0 -21
- package/src/utils/findEvmNetwork.d.ts +0 -6
- package/src/utils/findEvmNetwork.js +0 -17
- package/src/utils/getNameservice.cjs +0 -46
- package/src/utils/getNameservice.d.ts +0 -6
- package/src/utils/getNameservice.js +0 -42
- package/src/utils/index.d.ts +0 -2
- package/src/utils/isEthWalletConnector/index.d.ts +0 -1
- package/src/utils/isEthWalletConnector/isEthWalletConnector.cjs +0 -8
- package/src/utils/isEthWalletConnector/isEthWalletConnector.d.ts +0 -3
- package/src/utils/isEthWalletConnector/isEthWalletConnector.js +0 -4
|
@@ -1,236 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
import { __awaiter } from '../_virtual/_tslib.js';
|
|
3
|
-
import { getAddress, formatEther } from 'viem';
|
|
4
|
-
import { toAccount } from 'viem/accounts';
|
|
5
|
-
import { parseEvmNetworks, retryableFn, FALLBACK_UNDEFINED, DynamicError } from '@dynamic-labs/utils';
|
|
6
|
-
import { chainsMap, getOrMapViemChain, createViemUiTransaction } from '@dynamic-labs/viem-utils';
|
|
7
|
-
import { WalletConnectorBase, logger } from '@dynamic-labs/wallet-connector-core';
|
|
8
|
-
import { findEvmNetwork } from './utils/findEvmNetwork.js';
|
|
9
|
-
import { getNameservice } from './utils/getNameservice.js';
|
|
10
|
-
|
|
11
|
-
class EthWalletConnector extends WalletConnectorBase {
|
|
12
|
-
getPublicClient() {
|
|
13
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
14
|
-
var _a, _b;
|
|
15
|
-
const networkId = (_a = (yield this.getNetwork())) !== null && _a !== void 0 ? _a : 1;
|
|
16
|
-
if (this.evmNetworks.length === 0) {
|
|
17
|
-
return undefined;
|
|
18
|
-
}
|
|
19
|
-
const configurations = {
|
|
20
|
-
cosmos: [],
|
|
21
|
-
evm: this.evmNetworks,
|
|
22
|
-
solana: [],
|
|
23
|
-
starknet: undefined,
|
|
24
|
-
};
|
|
25
|
-
if (!this.chainRpcProviders)
|
|
26
|
-
return undefined;
|
|
27
|
-
const providers = this.chainRpcProviders.getProviders(configurations);
|
|
28
|
-
return (_b = this.chainRpcProviders.getEvmProviderByChainId(providers, networkId)) === null || _b === void 0 ? void 0 : _b.provider;
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
constructor(props) {
|
|
32
|
-
var _a;
|
|
33
|
-
super(props);
|
|
34
|
-
this.evmNetworkRpcMap = () => this.evmNetworks.reduce((acc, network) => {
|
|
35
|
-
var _a;
|
|
36
|
-
[acc[network.chainId]] = ((_a = network === null || network === void 0 ? void 0 : network.privateCustomerRpcUrls) === null || _a === void 0 ? void 0 : _a.length)
|
|
37
|
-
? network.privateCustomerRpcUrls
|
|
38
|
-
: network.rpcUrls;
|
|
39
|
-
return acc;
|
|
40
|
-
}, {});
|
|
41
|
-
this.evmNetworks = parseEvmNetworks(props.evmNetworks);
|
|
42
|
-
this.chainRpcProviders = props.chainRpcProviders;
|
|
43
|
-
(_a = this.chainRpcProviders) === null || _a === void 0 ? void 0 : _a.registerEvmProviders();
|
|
44
|
-
}
|
|
45
|
-
getNetwork() {
|
|
46
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
-
const provider = this.getWalletClient();
|
|
48
|
-
if (!this.supportsNetworkSwitching || !provider) {
|
|
49
|
-
return Promise.resolve(undefined);
|
|
50
|
-
}
|
|
51
|
-
const chainId = yield retryableFn(provider.getChainId, {
|
|
52
|
-
fallbackValue: FALLBACK_UNDEFINED,
|
|
53
|
-
/**
|
|
54
|
-
* The timeout is set to 1 second because the getChainId method
|
|
55
|
-
* takes around 500ms to resolve on Brave. If the timeout is not set
|
|
56
|
-
* it will use 100ms by default and the method will fail.
|
|
57
|
-
* QNTM-815
|
|
58
|
-
*/
|
|
59
|
-
timeoutMs: 1000,
|
|
60
|
-
});
|
|
61
|
-
this.setActiveChain(chainsMap[chainId]);
|
|
62
|
-
return chainId;
|
|
63
|
-
});
|
|
64
|
-
}
|
|
65
|
-
getNameService() {
|
|
66
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
-
const [[address], rpcProvider] = yield Promise.all([
|
|
68
|
-
this.getConnectedAccounts(),
|
|
69
|
-
this.getPublicClient(),
|
|
70
|
-
]);
|
|
71
|
-
if (!address || !rpcProvider) {
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
return getNameservice({ address, rpcProvider });
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
isTestnet() {
|
|
78
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
79
|
-
var _a, _b, _c;
|
|
80
|
-
return (_c = (_b = (_a = (yield this.getPublicClient())) === null || _a === void 0 ? void 0 : _a.chain) === null || _b === void 0 ? void 0 : _b.testnet) !== null && _c !== void 0 ? _c : false;
|
|
81
|
-
});
|
|
82
|
-
}
|
|
83
|
-
parseAddress(address) {
|
|
84
|
-
try {
|
|
85
|
-
// Ensures the address follows the EIP55 format.
|
|
86
|
-
// see: https://eips.ethereum.org/EIPS/eip-55
|
|
87
|
-
return getAddress(address);
|
|
88
|
-
}
|
|
89
|
-
catch (err) {
|
|
90
|
-
logger.debug(`Failed to parse EVM address into EIP55 format: error getting checksum, returning default ${address}`, err);
|
|
91
|
-
}
|
|
92
|
-
return address;
|
|
93
|
-
}
|
|
94
|
-
getSigner() {
|
|
95
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
96
|
-
return this.getWalletClient();
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
getBalance() {
|
|
100
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
101
|
-
// This is equivalent to getSigner().getAddress() but does not crash
|
|
102
|
-
// if the signer is not available
|
|
103
|
-
const [address] = yield this.getConnectedAccounts();
|
|
104
|
-
if (!address)
|
|
105
|
-
return;
|
|
106
|
-
const client = yield this.getPublicClient();
|
|
107
|
-
const result = yield (client === null || client === void 0 ? void 0 : client.getBalance({
|
|
108
|
-
address: address,
|
|
109
|
-
}));
|
|
110
|
-
if (!result && result !== BigInt(0))
|
|
111
|
-
return;
|
|
112
|
-
return formatEther(result);
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
supportsNetworkSwitching() {
|
|
116
|
-
return true;
|
|
117
|
-
}
|
|
118
|
-
switchNetwork(_a) {
|
|
119
|
-
return __awaiter(this, arguments, void 0, function* ({ networkName, networkChainId, }) {
|
|
120
|
-
const network = findEvmNetwork({
|
|
121
|
-
chainId: networkChainId,
|
|
122
|
-
name: networkName,
|
|
123
|
-
networks: this.evmNetworks,
|
|
124
|
-
});
|
|
125
|
-
if (!network) {
|
|
126
|
-
throw new DynamicError(`Could not find network mapping for chain ${networkName ? networkName : networkChainId}`);
|
|
127
|
-
}
|
|
128
|
-
if (!this.supportsNetworkSwitching()) {
|
|
129
|
-
throw new DynamicError('Network switching is not supported');
|
|
130
|
-
}
|
|
131
|
-
const provider = this.getWalletClient();
|
|
132
|
-
if (!provider) {
|
|
133
|
-
throw new DynamicError('Provider not found');
|
|
134
|
-
}
|
|
135
|
-
return this.providerSwitchNetwork({ network, provider });
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
getConnectedAccounts() {
|
|
139
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
140
|
-
const provider = this.getWalletClient();
|
|
141
|
-
if (!provider)
|
|
142
|
-
return [];
|
|
143
|
-
const addresses = yield retryableFn(provider.getAddresses, {
|
|
144
|
-
fallbackValue: [],
|
|
145
|
-
timeoutMs: 500,
|
|
146
|
-
});
|
|
147
|
-
if (addresses.length) {
|
|
148
|
-
this.setActiveAccount(addresses[0]);
|
|
149
|
-
}
|
|
150
|
-
return addresses;
|
|
151
|
-
});
|
|
152
|
-
}
|
|
153
|
-
providerSwitchNetwork(_a) {
|
|
154
|
-
return __awaiter(this, arguments, void 0, function* ({ network, provider, }) {
|
|
155
|
-
var _b, _c, _d, _e;
|
|
156
|
-
const { chainId } = network;
|
|
157
|
-
const currentNetworkId = yield this.getNetwork();
|
|
158
|
-
if (currentNetworkId && currentNetworkId === chainId) {
|
|
159
|
-
return;
|
|
160
|
-
}
|
|
161
|
-
try {
|
|
162
|
-
if (!this.supportsNetworkSwitching()) {
|
|
163
|
-
throw new DynamicError('Network switching is not supported');
|
|
164
|
-
}
|
|
165
|
-
const viemChain = getOrMapViemChain(network);
|
|
166
|
-
yield provider.switchChain(viemChain);
|
|
167
|
-
if (this.key === 'magiceden') {
|
|
168
|
-
const newChainId = yield provider.getChainId();
|
|
169
|
-
this.emit('chainChange', { chain: newChainId.toString() });
|
|
170
|
-
}
|
|
171
|
-
else {
|
|
172
|
-
this.setActiveChain(viemChain);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
catch (error) {
|
|
176
|
-
// we need to check for unrecognized chain error first because it also contains 'rejected' in message
|
|
177
|
-
if (error.code === 4902 ||
|
|
178
|
-
((_b = error.message) === null || _b === void 0 ? void 0 : _b.includes('Unrecognized chain')) ||
|
|
179
|
-
// https://github.com/MetaMask/metamask-mobile/issues/3312#issuecomment-1065923294
|
|
180
|
-
((_d = (_c = error.data) === null || _c === void 0 ? void 0 : _c.orginalError) === null || _d === void 0 ? void 0 : _d.code) === 4902) {
|
|
181
|
-
// error code indicates the chain has not been added yet
|
|
182
|
-
// https://docs.metamask.io/guide/rpc-api.html#usage-with-wallet-switchethereumchain
|
|
183
|
-
return this.providerAddNetwork({ network, provider });
|
|
184
|
-
}
|
|
185
|
-
else if (((_e = error.message) === null || _e === void 0 ? void 0 : _e.includes('rejected')) ||
|
|
186
|
-
(typeof error === 'string' && error.includes('rejected'))) {
|
|
187
|
-
throw new DynamicError("User rejected the wallet's request to switch network");
|
|
188
|
-
}
|
|
189
|
-
else {
|
|
190
|
-
throw error;
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
});
|
|
194
|
-
}
|
|
195
|
-
providerAddNetwork(_a) {
|
|
196
|
-
return __awaiter(this, arguments, void 0, function* ({ network, provider, }) {
|
|
197
|
-
var _b;
|
|
198
|
-
try {
|
|
199
|
-
return yield provider.addChain({ chain: getOrMapViemChain(network) });
|
|
200
|
-
}
|
|
201
|
-
catch (error) {
|
|
202
|
-
if (((_b = error.message) === null || _b === void 0 ? void 0 : _b.includes('rejected')) ||
|
|
203
|
-
(typeof error === 'string' && error.includes('rejected'))) {
|
|
204
|
-
throw new DynamicError("User rejected the wallet's request to add network");
|
|
205
|
-
}
|
|
206
|
-
else {
|
|
207
|
-
throw error;
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
});
|
|
211
|
-
}
|
|
212
|
-
setActiveAccount(account) {
|
|
213
|
-
this.activeAccount = account ? toAccount(account) : undefined;
|
|
214
|
-
}
|
|
215
|
-
getActiveAccount() {
|
|
216
|
-
return this.activeAccount;
|
|
217
|
-
}
|
|
218
|
-
setActiveChain(chain) {
|
|
219
|
-
this.activeChain = chain;
|
|
220
|
-
}
|
|
221
|
-
getActiveChain() {
|
|
222
|
-
return this.activeChain;
|
|
223
|
-
}
|
|
224
|
-
createUiTransaction(from) {
|
|
225
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
226
|
-
const walletClient = yield this.getWalletClient();
|
|
227
|
-
const publicClient = yield this.getPublicClient();
|
|
228
|
-
if (!publicClient || !walletClient) {
|
|
229
|
-
throw new DynamicError('No public client available');
|
|
230
|
-
}
|
|
231
|
-
return createViemUiTransaction({ from, publicClient, walletClient });
|
|
232
|
-
});
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
export { EthWalletConnector };
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
'use strict';
|
|
3
|
-
|
|
4
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
5
|
-
|
|
6
|
-
const findEvmNetwork = ({ chainId, name, networks, }) => {
|
|
7
|
-
if (!chainId && !name) {
|
|
8
|
-
return undefined;
|
|
9
|
-
}
|
|
10
|
-
if (chainId && name) {
|
|
11
|
-
return networks.find((network) => network.chainId === chainId && network.name === name);
|
|
12
|
-
}
|
|
13
|
-
else if (chainId) {
|
|
14
|
-
return networks.find((network) => network.chainId === chainId);
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
return networks.find((network) => network.name === name);
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
exports.findEvmNetwork = findEvmNetwork;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
const findEvmNetwork = ({ chainId, name, networks, }) => {
|
|
3
|
-
if (!chainId && !name) {
|
|
4
|
-
return undefined;
|
|
5
|
-
}
|
|
6
|
-
if (chainId && name) {
|
|
7
|
-
return networks.find((network) => network.chainId === chainId && network.name === name);
|
|
8
|
-
}
|
|
9
|
-
else if (chainId) {
|
|
10
|
-
return networks.find((network) => network.chainId === chainId);
|
|
11
|
-
}
|
|
12
|
-
else {
|
|
13
|
-
return networks.find((network) => network.name === name);
|
|
14
|
-
}
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
export { findEvmNetwork };
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
'use strict';
|
|
3
|
-
|
|
4
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
5
|
-
|
|
6
|
-
var _tslib = require('../../_virtual/_tslib.cjs');
|
|
7
|
-
var walletConnectorCore = require('@dynamic-labs/wallet-connector-core');
|
|
8
|
-
|
|
9
|
-
const getNameservice = (_a) => _tslib.__awaiter(void 0, [_a], void 0, function* ({ rpcProvider, address, }) {
|
|
10
|
-
var _b;
|
|
11
|
-
const nsData = {
|
|
12
|
-
avatar: undefined,
|
|
13
|
-
name: undefined,
|
|
14
|
-
};
|
|
15
|
-
const network = yield rpcProvider.getChainId();
|
|
16
|
-
if (!network) {
|
|
17
|
-
return nsData;
|
|
18
|
-
}
|
|
19
|
-
// Handle Base name service requests
|
|
20
|
-
if (network === 8453) {
|
|
21
|
-
try {
|
|
22
|
-
const response = yield fetch(`https://resolver-api.basename.app/v1/addresses/${address}`);
|
|
23
|
-
if (response.ok) {
|
|
24
|
-
const data = yield response.json();
|
|
25
|
-
nsData.name = (_b = data.name) !== null && _b !== void 0 ? _b : undefined;
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
catch (e) {
|
|
29
|
-
walletConnectorCore.logger.debug('Failed to fetch ens data', e);
|
|
30
|
-
}
|
|
31
|
-
return nsData;
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
nsData.name = (yield rpcProvider.getEnsName({
|
|
35
|
-
address: address,
|
|
36
|
-
}));
|
|
37
|
-
nsData.avatar = nsData.name
|
|
38
|
-
? (yield rpcProvider.getEnsAvatar({
|
|
39
|
-
name: nsData.name,
|
|
40
|
-
}))
|
|
41
|
-
: undefined;
|
|
42
|
-
}
|
|
43
|
-
return nsData;
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
exports.getNameservice = getNameservice;
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
import { __awaiter } from '../../_virtual/_tslib.js';
|
|
3
|
-
import { logger } from '@dynamic-labs/wallet-connector-core';
|
|
4
|
-
|
|
5
|
-
const getNameservice = (_a) => __awaiter(void 0, [_a], void 0, function* ({ rpcProvider, address, }) {
|
|
6
|
-
var _b;
|
|
7
|
-
const nsData = {
|
|
8
|
-
avatar: undefined,
|
|
9
|
-
name: undefined,
|
|
10
|
-
};
|
|
11
|
-
const network = yield rpcProvider.getChainId();
|
|
12
|
-
if (!network) {
|
|
13
|
-
return nsData;
|
|
14
|
-
}
|
|
15
|
-
// Handle Base name service requests
|
|
16
|
-
if (network === 8453) {
|
|
17
|
-
try {
|
|
18
|
-
const response = yield fetch(`https://resolver-api.basename.app/v1/addresses/${address}`);
|
|
19
|
-
if (response.ok) {
|
|
20
|
-
const data = yield response.json();
|
|
21
|
-
nsData.name = (_b = data.name) !== null && _b !== void 0 ? _b : undefined;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
catch (e) {
|
|
25
|
-
logger.debug('Failed to fetch ens data', e);
|
|
26
|
-
}
|
|
27
|
-
return nsData;
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
nsData.name = (yield rpcProvider.getEnsName({
|
|
31
|
-
address: address,
|
|
32
|
-
}));
|
|
33
|
-
nsData.avatar = nsData.name
|
|
34
|
-
? (yield rpcProvider.getEnsAvatar({
|
|
35
|
-
name: nsData.name,
|
|
36
|
-
}))
|
|
37
|
-
: undefined;
|
|
38
|
-
}
|
|
39
|
-
return nsData;
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
export { getNameservice };
|
package/src/utils/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { isEthWalletConnector } from './isEthWalletConnector';
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
'use client'
|
|
2
|
-
'use strict';
|
|
3
|
-
|
|
4
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
5
|
-
|
|
6
|
-
const isEthWalletConnector = (connector) => Boolean(connector === null || connector === void 0 ? void 0 : connector.getActiveAccount);
|
|
7
|
-
|
|
8
|
-
exports.isEthWalletConnector = isEthWalletConnector;
|