@dynamic-labs/ethereum 3.0.0-alpha.8 → 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 (39) hide show
  1. package/CHANGELOG.md +622 -0
  2. package/package.json +8 -10
  3. package/src/coinbase/coinbase.cjs +4 -5
  4. package/src/coinbase/coinbase.d.ts +2 -2
  5. package/src/coinbase/coinbase.js +2 -3
  6. package/src/coinbase/types.d.ts +1 -1
  7. package/src/ethProviderHelper.cjs +3 -3
  8. package/src/ethProviderHelper.d.ts +2 -1
  9. package/src/ethProviderHelper.js +2 -2
  10. package/src/index.cjs +5 -7
  11. package/src/index.d.ts +2 -3
  12. package/src/index.js +1 -4
  13. package/src/injected/ExodusEvm.d.ts +1 -1
  14. package/src/injected/FallbackEvmConnector.d.ts +1 -1
  15. package/src/injected/InjectedWalletBase.cjs +5 -4
  16. package/src/injected/InjectedWalletBase.d.ts +2 -2
  17. package/src/injected/InjectedWalletBase.js +4 -3
  18. package/src/injected/PhantomEvm.cjs +4 -0
  19. package/src/injected/PhantomEvm.d.ts +2 -1
  20. package/src/injected/PhantomEvm.js +4 -0
  21. package/src/injected/UnknownInjected.d.ts +1 -1
  22. package/src/types.d.ts +1 -0
  23. package/src/walletConnect/walletConnect.cjs +3 -4
  24. package/src/walletConnect/walletConnect.d.ts +1 -1
  25. package/src/walletConnect/walletConnect.js +1 -2
  26. package/src/EthWalletConnector.cjs +0 -240
  27. package/src/EthWalletConnector.d.ts +0 -3086
  28. package/src/EthWalletConnector.js +0 -236
  29. package/src/utils/findEvmNetwork.cjs +0 -21
  30. package/src/utils/findEvmNetwork.d.ts +0 -6
  31. package/src/utils/findEvmNetwork.js +0 -17
  32. package/src/utils/getNameservice.cjs +0 -46
  33. package/src/utils/getNameservice.d.ts +0 -6
  34. package/src/utils/getNameservice.js +0 -42
  35. package/src/utils/index.d.ts +0 -2
  36. package/src/utils/isEthWalletConnector/index.d.ts +0 -1
  37. package/src/utils/isEthWalletConnector/isEthWalletConnector.cjs +0 -8
  38. package/src/utils/isEthWalletConnector/isEthWalletConnector.d.ts +0 -3
  39. 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,6 +0,0 @@
1
- import { EvmNetwork } from '@dynamic-labs/types';
2
- export declare const findEvmNetwork: ({ chainId, name, networks, }: {
3
- chainId?: number;
4
- name?: string;
5
- networks: EvmNetwork[];
6
- }) => EvmNetwork | undefined;
@@ -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,6 +0,0 @@
1
- import { PublicClient } from 'viem';
2
- import { NameServiceData } from '@dynamic-labs/sdk-api-core';
3
- export declare const getNameservice: ({ rpcProvider, address, }: {
4
- rpcProvider: PublicClient;
5
- address: string;
6
- }) => Promise<NameServiceData>;
@@ -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 };
@@ -1,2 +0,0 @@
1
- export * from './isEthWalletConnector';
2
- export * from './getNameservice';
@@ -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;
@@ -1,3 +0,0 @@
1
- import { WalletConnector } from '@dynamic-labs/wallet-connector-core';
2
- import { EthWalletConnector } from '../..';
3
- export declare const isEthWalletConnector: (connector: WalletConnector | EthWalletConnector) => connector is EthWalletConnector;
@@ -1,4 +0,0 @@
1
- 'use client'
2
- const isEthWalletConnector = (connector) => Boolean(connector === null || connector === void 0 ? void 0 : connector.getActiveAccount);
3
-
4
- export { isEthWalletConnector };