@metamask/assets-controllers 35.0.0 → 37.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.
- package/CHANGELOG.md +84 -1
- package/dist/AssetsContractController.js +6 -6
- package/dist/AssetsContractController.mjs +5 -5
- package/dist/NftController.js +3 -3
- package/dist/NftController.mjs +2 -2
- package/dist/NftDetectionController.js +5 -2
- package/dist/NftDetectionController.mjs +4 -1
- package/dist/Standards/ERC20Standard.js +3 -3
- package/dist/Standards/ERC20Standard.mjs +2 -2
- package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js +3 -3
- package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs +2 -2
- package/dist/Standards/NftStandards/ERC721/ERC721Standard.js +3 -3
- package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs +2 -2
- package/dist/TokenBalancesController.js +2 -2
- package/dist/TokenBalancesController.mjs +1 -1
- package/dist/TokenDetectionController.js +3 -3
- package/dist/TokenDetectionController.mjs +2 -2
- package/dist/TokenListController.js +4 -4
- package/dist/TokenListController.mjs +3 -3
- package/dist/TokenRatesController.js +3 -3
- package/dist/TokenRatesController.mjs +2 -2
- package/dist/TokensController.js +6 -6
- package/dist/TokensController.mjs +5 -5
- package/dist/assetsUtil.js +4 -2
- package/dist/assetsUtil.mjs +3 -1
- package/dist/{chunk-3GGCHDRG.js → chunk-2TZK6YZA.js} +92 -45
- package/dist/chunk-2TZK6YZA.js.map +1 -0
- package/dist/{chunk-GHKGU6GK.js → chunk-3LPQTUGG.js} +5 -5
- package/dist/{chunk-JEIAMJGS.mjs → chunk-3QDXAE2D.mjs} +2 -2
- package/dist/{chunk-2TSAUGE7.mjs → chunk-46KUC5FH.mjs} +2 -2
- package/dist/{chunk-4JLB5OIJ.mjs → chunk-54JUUBXY.mjs} +5 -5
- package/dist/{chunk-JBF4XEGR.js → chunk-5QLC2MHV.js} +5 -5
- package/dist/{chunk-2NQRWANM.js → chunk-ADJ3IFJH.js} +11 -11
- package/dist/{chunk-47CRHAUE.mjs → chunk-AX522TDL.mjs} +2 -2
- package/dist/{chunk-354SINOH.js → chunk-BBCZM5P4.js} +67 -3
- package/dist/chunk-BBCZM5P4.js.map +1 -0
- package/dist/{chunk-VELPHITE.mjs → chunk-BZEAPSD5.mjs} +11 -5
- package/dist/chunk-BZEAPSD5.mjs.map +1 -0
- package/dist/{chunk-2IIQTSLV.mjs → chunk-C7LNCQXM.mjs} +67 -3
- package/dist/chunk-C7LNCQXM.mjs.map +1 -0
- package/dist/{chunk-OMNBGY7O.mjs → chunk-CN53OZAM.mjs} +135 -79
- package/dist/chunk-CN53OZAM.mjs.map +1 -0
- package/dist/{chunk-GJCTAKK5.mjs → chunk-CUFSPB7T.mjs} +2 -2
- package/dist/{chunk-RIMQ5DR3.js → chunk-GHG3DOUK.js} +138 -82
- package/dist/chunk-GHG3DOUK.js.map +1 -0
- package/dist/{chunk-LBJTMJFA.js → chunk-ISK2VSBB.js} +4 -4
- package/dist/{chunk-6PPM4ETZ.js → chunk-JCR4H6YL.js} +3 -3
- package/dist/{chunk-6VQJFTNC.mjs → chunk-JJX7TMH5.mjs} +8 -11
- package/dist/chunk-JJX7TMH5.mjs.map +1 -0
- package/dist/{chunk-X4RMS365.js → chunk-K7A3EOIM.js} +3 -3
- package/dist/{chunk-UYH6NWKB.mjs → chunk-KPBNX6GP.mjs} +2 -2
- package/dist/{chunk-NYVA7ZTQ.js → chunk-MZI3SDQN.js} +14 -8
- package/dist/chunk-MZI3SDQN.js.map +1 -0
- package/dist/{chunk-56O7BVZV.mjs → chunk-S5CFNNOM.mjs} +2 -2
- package/dist/{chunk-ZX5G3X74.mjs → chunk-SK2B36Q4.mjs} +92 -45
- package/dist/chunk-SK2B36Q4.mjs.map +1 -0
- package/dist/{chunk-Y45HQET7.mjs → chunk-TFLYM4PY.mjs} +3 -3
- package/dist/{chunk-RPQ737HL.js → chunk-X2HRAVDO.js} +4 -4
- package/dist/{chunk-NHFZIY2K.js → chunk-YGGUAMHV.js} +7 -10
- package/dist/chunk-YGGUAMHV.js.map +1 -0
- package/dist/{chunk-7OZL6IDY.js → chunk-ZAR4BIOC.js} +7 -7
- package/dist/index.js +14 -16
- package/dist/index.mjs +13 -15
- package/dist/token-service.js +3 -3
- package/dist/token-service.mjs +2 -2
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/AssetsContractController.d.ts +93 -56
- package/dist/types/AssetsContractController.d.ts.map +1 -1
- package/dist/types/NftController.d.ts +18 -18
- package/dist/types/NftController.d.ts.map +1 -1
- package/dist/types/NftDetectionController.d.ts +35 -1
- package/dist/types/NftDetectionController.d.ts.map +1 -1
- package/dist/types/TokenBalancesController.d.ts +6 -8
- package/dist/types/TokenBalancesController.d.ts.map +1 -1
- package/dist/types/assetsUtil.d.ts +10 -3
- package/dist/types/assetsUtil.d.ts.map +1 -1
- package/dist/types/index.d.ts +3 -2
- package/dist/types/index.d.ts.map +1 -1
- package/package.json +21 -20
- package/dist/chunk-2IIQTSLV.mjs.map +0 -1
- package/dist/chunk-354SINOH.js.map +0 -1
- package/dist/chunk-3GGCHDRG.js.map +0 -1
- package/dist/chunk-6VQJFTNC.mjs.map +0 -1
- package/dist/chunk-NHFZIY2K.js.map +0 -1
- package/dist/chunk-NYVA7ZTQ.js.map +0 -1
- package/dist/chunk-OMNBGY7O.mjs.map +0 -1
- package/dist/chunk-RIMQ5DR3.js.map +0 -1
- package/dist/chunk-VELPHITE.mjs.map +0 -1
- package/dist/chunk-ZX5G3X74.mjs.map +0 -1
- /package/dist/{chunk-GHKGU6GK.js.map → chunk-3LPQTUGG.js.map} +0 -0
- /package/dist/{chunk-JEIAMJGS.mjs.map → chunk-3QDXAE2D.mjs.map} +0 -0
- /package/dist/{chunk-2TSAUGE7.mjs.map → chunk-46KUC5FH.mjs.map} +0 -0
- /package/dist/{chunk-4JLB5OIJ.mjs.map → chunk-54JUUBXY.mjs.map} +0 -0
- /package/dist/{chunk-JBF4XEGR.js.map → chunk-5QLC2MHV.js.map} +0 -0
- /package/dist/{chunk-2NQRWANM.js.map → chunk-ADJ3IFJH.js.map} +0 -0
- /package/dist/{chunk-47CRHAUE.mjs.map → chunk-AX522TDL.mjs.map} +0 -0
- /package/dist/{chunk-GJCTAKK5.mjs.map → chunk-CUFSPB7T.mjs.map} +0 -0
- /package/dist/{chunk-LBJTMJFA.js.map → chunk-ISK2VSBB.js.map} +0 -0
- /package/dist/{chunk-6PPM4ETZ.js.map → chunk-JCR4H6YL.js.map} +0 -0
- /package/dist/{chunk-X4RMS365.js.map → chunk-K7A3EOIM.js.map} +0 -0
- /package/dist/{chunk-UYH6NWKB.mjs.map → chunk-KPBNX6GP.mjs.map} +0 -0
- /package/dist/{chunk-56O7BVZV.mjs.map → chunk-S5CFNNOM.mjs.map} +0 -0
- /package/dist/{chunk-Y45HQET7.mjs.map → chunk-TFLYM4PY.mjs.map} +0 -0
- /package/dist/{chunk-RPQ737HL.js.map → chunk-X2HRAVDO.js.map} +0 -0
- /package/dist/{chunk-7OZL6IDY.js.map → chunk-ZAR4BIOC.js.map} +0 -0
|
@@ -1,18 +1,24 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkISK2VSBBjs = require('./chunk-ISK2VSBB.js');
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
var
|
|
6
|
+
var _chunkJCR4H6YLjs = require('./chunk-JCR4H6YL.js');
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
var
|
|
9
|
+
var _chunk5QLC2MHVjs = require('./chunk-5QLC2MHV.js');
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
var _chunkZ4BLTVTBjs = require('./chunk-Z4BLTVTB.js');
|
|
10
16
|
|
|
11
17
|
// src/AssetsContractController.ts
|
|
12
18
|
var _contracts = require('@ethersproject/contracts');
|
|
13
19
|
var _providers = require('@ethersproject/providers');
|
|
14
|
-
var _basecontroller = require('@metamask/base-controller');
|
|
15
20
|
var _controllerutils = require('@metamask/controller-utils');
|
|
21
|
+
var _utils = require('@metamask/utils');
|
|
16
22
|
var _singlecallbalancecheckerabi = require('single-call-balance-checker-abi'); var _singlecallbalancecheckerabi2 = _interopRequireDefault(_singlecallbalancecheckerabi);
|
|
17
23
|
var SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = {
|
|
18
24
|
["0x1" /* mainnet */]: "0xb1f8e55c7f64d203c1400b9d8555d050f94adf39",
|
|
@@ -35,85 +41,60 @@ var SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = {
|
|
|
35
41
|
["0x505" /* moonriver */]: "0x6aa75276052d96696134252587894ef5ffa520af"
|
|
36
42
|
};
|
|
37
43
|
var MISSING_PROVIDER_ERROR = "AssetsContractController failed to set the provider correctly. A provider must be set for this method to be available";
|
|
38
|
-
var
|
|
44
|
+
var name = "AssetsContractController";
|
|
45
|
+
var _provider, _ipfsGateway, _chainId, _registerActionHandlers, registerActionHandlers_fn, _registerEventSubscriptions, registerEventSubscriptions_fn, _getCorrectProvider, getCorrectProvider_fn, _getCorrectChainId, getCorrectChainId_fn;
|
|
46
|
+
var AssetsContractController = class {
|
|
39
47
|
/**
|
|
40
48
|
* Creates a AssetsContractController instance.
|
|
41
49
|
*
|
|
42
50
|
* @param options - The controller options.
|
|
51
|
+
* @param options.messenger - The controller messenger.
|
|
43
52
|
* @param options.chainId - The chain ID of the current network.
|
|
44
|
-
* @param options.onPreferencesStateChange - Allows subscribing to preference controller state changes.
|
|
45
|
-
* @param options.onNetworkDidChange - Allows subscribing to network controller networkDidChange events.
|
|
46
|
-
* @param options.getNetworkClientById - Gets the network client with the given id from the NetworkController.
|
|
47
|
-
* @param config - Initial options used to configure this controller.
|
|
48
|
-
* @param state - Initial state to set on this controller.
|
|
49
53
|
*/
|
|
50
54
|
constructor({
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
55
|
+
messenger,
|
|
56
|
+
chainId: initialChainId
|
|
57
|
+
}) {
|
|
58
|
+
// TODO: Expand into base-controller utility function that batch registers action handlers.
|
|
59
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _registerActionHandlers);
|
|
60
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _registerEventSubscriptions);
|
|
57
61
|
/**
|
|
58
|
-
*
|
|
62
|
+
* Get the relevant provider instance.
|
|
63
|
+
*
|
|
64
|
+
* @param networkClientId - Network Client ID.
|
|
65
|
+
* @returns Web3Provider instance.
|
|
59
66
|
*/
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
this.configure({
|
|
78
|
-
chainId: selectedNetworkClient.configuration.chainId
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
});
|
|
67
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getCorrectProvider);
|
|
68
|
+
/**
|
|
69
|
+
* Get the relevant chain ID.
|
|
70
|
+
*
|
|
71
|
+
* @param networkClientId - Network Client ID used to get the provider.
|
|
72
|
+
* @returns Hex chain ID.
|
|
73
|
+
*/
|
|
74
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getCorrectChainId);
|
|
75
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _provider, void 0);
|
|
76
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _ipfsGateway, void 0);
|
|
77
|
+
_chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _chainId, void 0);
|
|
78
|
+
this.messagingSystem = messenger;
|
|
79
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _provider, void 0);
|
|
80
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _ipfsGateway, _controllerutils.IPFS_DEFAULT_GATEWAY_URL);
|
|
81
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _chainId, initialChainId);
|
|
82
|
+
_chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _registerActionHandlers, registerActionHandlers_fn).call(this);
|
|
83
|
+
_chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _registerEventSubscriptions, registerEventSubscriptions_fn).call(this);
|
|
82
84
|
}
|
|
83
85
|
/**
|
|
84
86
|
* Sets a new provider.
|
|
85
87
|
*
|
|
86
|
-
*
|
|
87
|
-
*
|
|
88
|
-
* @property provider - Provider used to create a new underlying Web3 instance
|
|
88
|
+
* @param provider - Provider used to create a new underlying Web3 instance
|
|
89
89
|
*/
|
|
90
|
-
|
|
91
|
-
this
|
|
90
|
+
setProvider(provider) {
|
|
91
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _provider, provider);
|
|
92
92
|
}
|
|
93
|
-
get
|
|
94
|
-
|
|
93
|
+
get ipfsGateway() {
|
|
94
|
+
return _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _ipfsGateway);
|
|
95
95
|
}
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
*
|
|
99
|
-
* @param networkClientId - Network Client ID.
|
|
100
|
-
* @returns Web3Provider instance.
|
|
101
|
-
*/
|
|
102
|
-
getProvider(networkClientId) {
|
|
103
|
-
const provider = networkClientId ? this.getNetworkClientById(networkClientId).provider : this._provider;
|
|
104
|
-
if (provider === void 0) {
|
|
105
|
-
throw new Error(MISSING_PROVIDER_ERROR);
|
|
106
|
-
}
|
|
107
|
-
return new (0, _providers.Web3Provider)(provider);
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Get the relevant chain ID.
|
|
111
|
-
*
|
|
112
|
-
* @param networkClientId - Network Client ID used to get the provider.
|
|
113
|
-
* @returns Hex chain ID.
|
|
114
|
-
*/
|
|
115
|
-
getChainId(networkClientId) {
|
|
116
|
-
return networkClientId ? this.getNetworkClientById(networkClientId).configuration.chainId : this.config.chainId;
|
|
96
|
+
get chainId() {
|
|
97
|
+
return _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId);
|
|
117
98
|
}
|
|
118
99
|
/**
|
|
119
100
|
* Get a ERC20Standard instance using the relevant provider instance.
|
|
@@ -122,8 +103,8 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
122
103
|
* @returns ERC20Standard instance.
|
|
123
104
|
*/
|
|
124
105
|
getERC20Standard(networkClientId) {
|
|
125
|
-
const provider = this.
|
|
126
|
-
return new (0,
|
|
106
|
+
const provider = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
107
|
+
return new (0, _chunkJCR4H6YLjs.ERC20Standard)(provider);
|
|
127
108
|
}
|
|
128
109
|
/**
|
|
129
110
|
* Get a ERC721Standard instance using the relevant provider instance.
|
|
@@ -132,8 +113,8 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
132
113
|
* @returns ERC721Standard instance.
|
|
133
114
|
*/
|
|
134
115
|
getERC721Standard(networkClientId) {
|
|
135
|
-
const provider = this.
|
|
136
|
-
return new (0,
|
|
116
|
+
const provider = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
117
|
+
return new (0, _chunkISK2VSBBjs.ERC721Standard)(provider);
|
|
137
118
|
}
|
|
138
119
|
/**
|
|
139
120
|
* Get a ERC1155Standard instance using the relevant provider instance.
|
|
@@ -142,8 +123,8 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
142
123
|
* @returns ERC1155Standard instance.
|
|
143
124
|
*/
|
|
144
125
|
getERC1155Standard(networkClientId) {
|
|
145
|
-
const provider = this.
|
|
146
|
-
return new (0,
|
|
126
|
+
const provider = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
127
|
+
return new (0, _chunk5QLC2MHVjs.ERC1155Standard)(provider);
|
|
147
128
|
}
|
|
148
129
|
/**
|
|
149
130
|
* Get balance or count for current account on specific asset contract.
|
|
@@ -188,7 +169,7 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
188
169
|
* @param networkClientId - Network Client ID to fetch the provider with.
|
|
189
170
|
* @returns Promise resolving to token identifier for the 'index'th asset assigned to 'selectedAddress'.
|
|
190
171
|
*/
|
|
191
|
-
getERC721NftTokenId(address, selectedAddress, index, networkClientId) {
|
|
172
|
+
async getERC721NftTokenId(address, selectedAddress, index, networkClientId) {
|
|
192
173
|
const erc721Standard = this.getERC721Standard(networkClientId);
|
|
193
174
|
return erc721Standard.getNftTokenId(address, selectedAddress, index);
|
|
194
175
|
}
|
|
@@ -202,14 +183,13 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
202
183
|
* @returns Promise resolving to an object containing the token standard and a set of details which depend on which standard the token supports.
|
|
203
184
|
*/
|
|
204
185
|
async getTokenStandardAndDetails(tokenAddress, userAddress, tokenId, networkClientId) {
|
|
205
|
-
this.
|
|
206
|
-
const { ipfsGateway } = this.config;
|
|
186
|
+
_chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
207
187
|
try {
|
|
208
188
|
const erc721Standard = this.getERC721Standard(networkClientId);
|
|
209
189
|
return {
|
|
210
190
|
...await erc721Standard.getDetails(
|
|
211
191
|
tokenAddress,
|
|
212
|
-
|
|
192
|
+
_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _ipfsGateway),
|
|
213
193
|
tokenId
|
|
214
194
|
)
|
|
215
195
|
};
|
|
@@ -220,7 +200,7 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
220
200
|
return {
|
|
221
201
|
...await erc1155Standard.getDetails(
|
|
222
202
|
tokenAddress,
|
|
223
|
-
|
|
203
|
+
_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _ipfsGateway),
|
|
224
204
|
tokenId
|
|
225
205
|
)
|
|
226
206
|
};
|
|
@@ -337,9 +317,9 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
337
317
|
* @returns The list of non-zero token balances.
|
|
338
318
|
*/
|
|
339
319
|
async getBalancesInSingleCall(selectedAddress, tokensToDetect, networkClientId) {
|
|
340
|
-
const chainId = this.
|
|
341
|
-
const provider = this.
|
|
342
|
-
if (!(
|
|
320
|
+
const chainId = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectChainId, getCorrectChainId_fn).call(this, networkClientId);
|
|
321
|
+
const provider = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
322
|
+
if (!((id) => id in SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID)(chainId)) {
|
|
343
323
|
return {};
|
|
344
324
|
}
|
|
345
325
|
const contractAddress = SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID[chainId];
|
|
@@ -361,6 +341,82 @@ var AssetsContractController = class extends _basecontroller.BaseControllerV1 {
|
|
|
361
341
|
return nonZeroBalances;
|
|
362
342
|
}
|
|
363
343
|
};
|
|
344
|
+
_provider = new WeakMap();
|
|
345
|
+
_ipfsGateway = new WeakMap();
|
|
346
|
+
_chainId = new WeakMap();
|
|
347
|
+
_registerActionHandlers = new WeakSet();
|
|
348
|
+
registerActionHandlers_fn = function() {
|
|
349
|
+
const methodsExcludedFromMessenger = [
|
|
350
|
+
"constructor",
|
|
351
|
+
"messagingSystem",
|
|
352
|
+
"setProvider",
|
|
353
|
+
"provider",
|
|
354
|
+
"ipfsGateway",
|
|
355
|
+
"chainId"
|
|
356
|
+
];
|
|
357
|
+
_utils.getKnownPropertyNames.call(void 0, Object.getPrototypeOf(this)).forEach(
|
|
358
|
+
(method) => {
|
|
359
|
+
if (((key) => !methodsExcludedFromMessenger.find((e) => e === key) && typeof this[key] === "function")(method)) {
|
|
360
|
+
this.messagingSystem.registerActionHandler(
|
|
361
|
+
`${name}:${method}`,
|
|
362
|
+
// TODO: Write a generic for-loop implementation that iterates over an input union type in tandem with the input array.
|
|
363
|
+
// @ts-expect-error Both assigned argument and assignee parameter are using the entire union type for `method` instead of the type for the current element
|
|
364
|
+
this[method].bind(this)
|
|
365
|
+
);
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
);
|
|
369
|
+
};
|
|
370
|
+
_registerEventSubscriptions = new WeakSet();
|
|
371
|
+
registerEventSubscriptions_fn = function() {
|
|
372
|
+
this.messagingSystem.subscribe(
|
|
373
|
+
`PreferencesController:stateChange`,
|
|
374
|
+
({ ipfsGateway }) => {
|
|
375
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _ipfsGateway, ipfsGateway);
|
|
376
|
+
}
|
|
377
|
+
);
|
|
378
|
+
this.messagingSystem.subscribe(
|
|
379
|
+
`NetworkController:networkDidChange`,
|
|
380
|
+
({ selectedNetworkClientId }) => {
|
|
381
|
+
const chainId = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectChainId, getCorrectChainId_fn).call(this, selectedNetworkClientId);
|
|
382
|
+
if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId) !== chainId) {
|
|
383
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _chainId, chainId);
|
|
384
|
+
_chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _provider, _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectProvider, getCorrectProvider_fn).call(this));
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
);
|
|
388
|
+
};
|
|
389
|
+
_getCorrectProvider = new WeakSet();
|
|
390
|
+
getCorrectProvider_fn = function(networkClientId) {
|
|
391
|
+
const provider = networkClientId ? this.messagingSystem.call(
|
|
392
|
+
`NetworkController:getNetworkClientById`,
|
|
393
|
+
networkClientId
|
|
394
|
+
).provider : this.messagingSystem.call("NetworkController:getSelectedNetworkClient")?.provider ?? _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _provider);
|
|
395
|
+
if (provider === void 0) {
|
|
396
|
+
throw new Error(MISSING_PROVIDER_ERROR);
|
|
397
|
+
}
|
|
398
|
+
return new (0, _providers.Web3Provider)(provider);
|
|
399
|
+
};
|
|
400
|
+
_getCorrectChainId = new WeakSet();
|
|
401
|
+
getCorrectChainId_fn = function(networkClientId) {
|
|
402
|
+
if (networkClientId) {
|
|
403
|
+
const networkClientConfiguration = this.messagingSystem.call(
|
|
404
|
+
"NetworkController:getNetworkConfigurationByNetworkClientId",
|
|
405
|
+
networkClientId
|
|
406
|
+
);
|
|
407
|
+
if (networkClientConfiguration) {
|
|
408
|
+
return networkClientConfiguration.chainId;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
const { selectedNetworkClientId } = this.messagingSystem.call(
|
|
412
|
+
"NetworkController:getState"
|
|
413
|
+
);
|
|
414
|
+
const networkClient = this.messagingSystem.call(
|
|
415
|
+
"NetworkController:getNetworkClientById",
|
|
416
|
+
selectedNetworkClientId
|
|
417
|
+
);
|
|
418
|
+
return networkClient.configuration?.chainId ?? _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId);
|
|
419
|
+
};
|
|
364
420
|
var AssetsContractController_default = AssetsContractController;
|
|
365
421
|
|
|
366
422
|
|
|
@@ -369,4 +425,4 @@ var AssetsContractController_default = AssetsContractController;
|
|
|
369
425
|
|
|
370
426
|
|
|
371
427
|
exports.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID; exports.MISSING_PROVIDER_ERROR = MISSING_PROVIDER_ERROR; exports.AssetsContractController = AssetsContractController; exports.AssetsContractController_default = AssetsContractController_default;
|
|
372
|
-
//# sourceMappingURL=chunk-
|
|
428
|
+
//# sourceMappingURL=chunk-GHG3DOUK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/AssetsContractController.ts"],"names":[],"mappings":"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","sourcesContent":["import { Contract } from '@ethersproject/contracts';\nimport { Web3Provider } from '@ethersproject/providers';\nimport type {\n ActionConstraint,\n RestrictedControllerMessenger,\n} from '@metamask/base-controller';\nimport { IPFS_DEFAULT_GATEWAY_URL } from '@metamask/controller-utils';\nimport type {\n NetworkClientId,\n NetworkControllerGetNetworkClientByIdAction,\n NetworkControllerGetNetworkConfigurationByNetworkClientId,\n NetworkControllerGetSelectedNetworkClientAction,\n NetworkControllerGetStateAction,\n NetworkControllerNetworkDidChangeEvent,\n Provider,\n} from '@metamask/network-controller';\nimport type { PreferencesControllerStateChangeEvent } from '@metamask/preferences-controller';\nimport { getKnownPropertyNames, type Hex } from '@metamask/utils';\nimport type BN from 'bn.js';\nimport abiSingleCallBalancesContract from 'single-call-balance-checker-abi';\n\nimport { SupportedTokenDetectionNetworks } from './assetsUtil';\nimport { ERC20Standard } from './Standards/ERC20Standard';\nimport { ERC1155Standard } from './Standards/NftStandards/ERC1155/ERC1155Standard';\nimport { ERC721Standard } from './Standards/NftStandards/ERC721/ERC721Standard';\n\n/**\n * Check if token detection is enabled for certain networks\n *\n * @param chainId - ChainID of network\n * @returns Whether the current network supports token detection\n */\nexport const SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = {\n [SupportedTokenDetectionNetworks.mainnet]:\n '0xb1f8e55c7f64d203c1400b9d8555d050f94adf39',\n [SupportedTokenDetectionNetworks.bsc]:\n '0x2352c63A83f9Fd126af8676146721Fa00924d7e4',\n [SupportedTokenDetectionNetworks.polygon]:\n '0x2352c63A83f9Fd126af8676146721Fa00924d7e4',\n [SupportedTokenDetectionNetworks.avax]:\n '0xD023D153a0DFa485130ECFdE2FAA7e612EF94818',\n [SupportedTokenDetectionNetworks.aurora]:\n '0x1286415D333855237f89Df27D388127181448538',\n [SupportedTokenDetectionNetworks.linea_goerli]:\n '0x10dAd7Ca3921471f616db788D9300DC97Db01783',\n [SupportedTokenDetectionNetworks.linea_mainnet]:\n '0xF62e6a41561b3650a69Bb03199C735e3E3328c0D',\n [SupportedTokenDetectionNetworks.arbitrum]:\n '0x151E24A486D7258dd7C33Fb67E4bB01919B7B32c',\n [SupportedTokenDetectionNetworks.optimism]:\n '0xB1c568e9C3E6bdaf755A60c7418C269eb11524FC',\n [SupportedTokenDetectionNetworks.base]:\n '0x6AA75276052D96696134252587894ef5FFA520af',\n [SupportedTokenDetectionNetworks.zksync]:\n '0x458fEd3144680a5b8bcfaa0F9594aa19B4Ea2D34',\n [SupportedTokenDetectionNetworks.cronos]:\n '0x768ca200f0fc702ac9ea502498c18f5eff176378',\n [SupportedTokenDetectionNetworks.celo]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.gnosis]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.fantom]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.polygon_zkevm]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.moonbeam]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.moonriver]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n} as const satisfies Record<Hex, string>;\n\nexport const MISSING_PROVIDER_ERROR =\n 'AssetsContractController failed to set the provider correctly. A provider must be set for this method to be available';\n\n/**\n * @type BalanceMap\n *\n * Key value object containing the balance for each tokenAddress\n * @property [tokenAddress] - Address of the token\n */\nexport type BalanceMap = {\n [tokenAddress: string]: BN;\n};\n\n/**\n * The name of the {@link AssetsContractController}\n */\nconst name = 'AssetsContractController';\n\n/**\n * A utility type that derives the public method names of a given messenger consumer class,\n * and uses it to generate the class's internal messenger action types.\n * @template Controller - A messenger consumer class.\n */\n// TODO: Figure out generic constraint and move to base-controller\ntype ControllerActionsMap<Controller> = {\n [ClassMethod in keyof Controller as Controller[ClassMethod] extends ActionConstraint['handler']\n ? ClassMethod\n : never]: {\n type: `${typeof name}:${ClassMethod & string}`;\n handler: Controller[ClassMethod];\n };\n};\n\ntype AssetsContractControllerActionsMap =\n ControllerActionsMap<AssetsContractController>;\n\n/**\n * The union of all public class method names of {@link AssetsContractController}.\n */\ntype AssetsContractControllerMethodName =\n keyof AssetsContractControllerActionsMap;\n\n/**\n * The union of all internal messenger actions available to the {@link AssetsContractControllerMessenger}.\n */\nexport type AssetsContractControllerActions =\n AssetsContractControllerActionsMap[AssetsContractControllerMethodName];\n\nexport type AssetsContractControllerGetERC20StandardAction =\n AssetsContractControllerActionsMap['getERC20Standard'];\n\nexport type AssetsContractControllerGetERC721StandardAction =\n AssetsContractControllerActionsMap['getERC721Standard'];\n\nexport type AssetsContractControllerGetERC1155StandardAction =\n AssetsContractControllerActionsMap['getERC1155Standard'];\n\nexport type AssetsContractControllerGetERC20BalanceOfAction =\n AssetsContractControllerActionsMap['getERC20BalanceOf'];\n\nexport type AssetsContractControllerGetERC20TokenDecimalsAction =\n AssetsContractControllerActionsMap['getERC20TokenDecimals'];\n\nexport type AssetsContractControllerGetERC20TokenNameAction =\n AssetsContractControllerActionsMap['getERC20TokenName'];\n\nexport type AssetsContractControllerGetERC721NftTokenIdAction =\n AssetsContractControllerActionsMap['getERC721NftTokenId'];\n\nexport type AssetsContractControllerGetERC721TokenURIAction =\n AssetsContractControllerActionsMap['getERC721TokenURI'];\n\nexport type AssetsContractControllerGetERC721AssetNameAction =\n AssetsContractControllerActionsMap['getERC721AssetName'];\n\nexport type AssetsContractControllerGetERC721AssetSymbolAction =\n AssetsContractControllerActionsMap['getERC721AssetSymbol'];\n\nexport type AssetsContractControllerGetERC721OwnerOfAction =\n AssetsContractControllerActionsMap['getERC721OwnerOf'];\n\nexport type AssetsContractControllerGetERC1155TokenURIAction =\n AssetsContractControllerActionsMap['getERC1155TokenURI'];\n\nexport type AssetsContractControllerGetERC1155BalanceOfAction =\n AssetsContractControllerActionsMap['getERC1155BalanceOf'];\n\nexport type AssetsContractControllerTransferSingleERC1155Action =\n AssetsContractControllerActionsMap['transferSingleERC1155'];\n\nexport type AssetsContractControllerGetTokenStandardAndDetailsAction =\n AssetsContractControllerActionsMap['getTokenStandardAndDetails'];\n\nexport type AssetsContractControllerGetBalancesInSingleCallAction =\n AssetsContractControllerActionsMap['getBalancesInSingleCall'];\n\n/**\n * The union of all internal messenger events available to the {@link AssetsContractControllerMessenger}.\n */\nexport type AssetsContractControllerEvents = never;\n\n/**\n * The union of all external messenger actions that must be allowed by the {@link AssetsContractControllerMessenger}.\n */\nexport type AllowedActions =\n | NetworkControllerGetNetworkClientByIdAction\n | NetworkControllerGetNetworkConfigurationByNetworkClientId\n | NetworkControllerGetSelectedNetworkClientAction\n | NetworkControllerGetStateAction;\n\n/**\n * The union of all external messenger event that must be allowed by the {@link AssetsContractControllerMessenger}.\n */\nexport type AllowedEvents =\n | PreferencesControllerStateChangeEvent\n | NetworkControllerNetworkDidChangeEvent;\n\n/**\n * The messenger of the {@link AssetsContractController}.\n */\nexport type AssetsContractControllerMessenger = RestrictedControllerMessenger<\n typeof name,\n AssetsContractControllerActions | AllowedActions,\n AssetsContractControllerEvents | AllowedEvents,\n AllowedActions['type'],\n AllowedEvents['type']\n>;\n\n/**\n * Controller that interacts with contracts on mainnet through web3\n */\nexport class AssetsContractController {\n protected messagingSystem: AssetsContractControllerMessenger;\n\n #provider: Provider | undefined;\n\n #ipfsGateway: string;\n\n #chainId: Hex;\n\n /**\n * Creates a AssetsContractController instance.\n *\n * @param options - The controller options.\n * @param options.messenger - The controller messenger.\n * @param options.chainId - The chain ID of the current network.\n */\n constructor({\n messenger,\n chainId: initialChainId,\n }: {\n messenger: AssetsContractControllerMessenger;\n chainId: Hex;\n }) {\n this.messagingSystem = messenger;\n this.#provider = undefined;\n this.#ipfsGateway = IPFS_DEFAULT_GATEWAY_URL;\n this.#chainId = initialChainId;\n\n this.#registerActionHandlers();\n this.#registerEventSubscriptions();\n }\n\n // TODO: Expand into base-controller utility function that batch registers action handlers.\n #registerActionHandlers() {\n const methodsExcludedFromMessenger = [\n 'constructor',\n 'messagingSystem',\n 'setProvider',\n 'provider',\n 'ipfsGateway',\n 'chainId',\n ];\n\n getKnownPropertyNames<keyof this>(Object.getPrototypeOf(this)).forEach(\n (method) => {\n if (\n ((key: keyof this): key is AssetsContractControllerMethodName =>\n !methodsExcludedFromMessenger.find((e) => e === key) &&\n typeof this[key] === 'function')(method)\n ) {\n this.messagingSystem.registerActionHandler(\n `${name}:${method}`,\n // TODO: Write a generic for-loop implementation that iterates over an input union type in tandem with the input array.\n // @ts-expect-error Both assigned argument and assignee parameter are using the entire union type for `method` instead of the type for the current element\n this[method].bind(this),\n );\n }\n },\n );\n }\n\n #registerEventSubscriptions() {\n this.messagingSystem.subscribe(\n `PreferencesController:stateChange`,\n ({ ipfsGateway }) => {\n this.#ipfsGateway = ipfsGateway;\n },\n );\n\n this.messagingSystem.subscribe(\n `NetworkController:networkDidChange`,\n ({ selectedNetworkClientId }) => {\n const chainId = this.#getCorrectChainId(selectedNetworkClientId);\n\n if (this.#chainId !== chainId) {\n this.#chainId = chainId;\n // @ts-expect-error TODO: remove this annotation once the `Eip1193Provider` class is released\n this.#provider = this.#getCorrectProvider();\n }\n },\n );\n }\n\n /**\n * Sets a new provider.\n *\n * @param provider - Provider used to create a new underlying Web3 instance\n */\n setProvider(provider: Provider | undefined) {\n this.#provider = provider;\n }\n\n get ipfsGateway() {\n return this.#ipfsGateway;\n }\n\n get chainId() {\n return this.#chainId;\n }\n\n /**\n * Get the relevant provider instance.\n *\n * @param networkClientId - Network Client ID.\n * @returns Web3Provider instance.\n */\n #getCorrectProvider(networkClientId?: NetworkClientId): Web3Provider {\n const provider = networkClientId\n ? this.messagingSystem.call(\n `NetworkController:getNetworkClientById`,\n networkClientId,\n ).provider\n : this.messagingSystem.call('NetworkController:getSelectedNetworkClient')\n ?.provider ?? this.#provider;\n\n if (provider === undefined) {\n throw new Error(MISSING_PROVIDER_ERROR);\n }\n\n return new Web3Provider(provider);\n }\n\n /**\n * Get the relevant chain ID.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns Hex chain ID.\n */\n #getCorrectChainId(networkClientId?: NetworkClientId): Hex {\n if (networkClientId) {\n const networkClientConfiguration = this.messagingSystem.call(\n 'NetworkController:getNetworkConfigurationByNetworkClientId',\n networkClientId,\n );\n if (networkClientConfiguration) {\n return networkClientConfiguration.chainId;\n }\n }\n const { selectedNetworkClientId } = this.messagingSystem.call(\n 'NetworkController:getState',\n );\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n selectedNetworkClientId,\n );\n return networkClient.configuration?.chainId ?? this.#chainId;\n }\n\n /**\n * Get a ERC20Standard instance using the relevant provider instance.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns ERC20Standard instance.\n */\n getERC20Standard(networkClientId?: NetworkClientId): ERC20Standard {\n const provider = this.#getCorrectProvider(networkClientId);\n return new ERC20Standard(provider);\n }\n\n /**\n * Get a ERC721Standard instance using the relevant provider instance.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns ERC721Standard instance.\n */\n getERC721Standard(networkClientId?: NetworkClientId): ERC721Standard {\n const provider = this.#getCorrectProvider(networkClientId);\n return new ERC721Standard(provider);\n }\n\n /**\n * Get a ERC1155Standard instance using the relevant provider instance.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns ERC1155Standard instance.\n */\n getERC1155Standard(networkClientId?: NetworkClientId): ERC1155Standard {\n const provider = this.#getCorrectProvider(networkClientId);\n return new ERC1155Standard(provider);\n }\n\n /**\n * Get balance or count for current account on specific asset contract.\n *\n * @param address - Asset ERC20 contract address.\n * @param selectedAddress - Current account public address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to BN object containing balance for current account on specific asset contract.\n */\n async getERC20BalanceOf(\n address: string,\n selectedAddress: string,\n networkClientId?: NetworkClientId,\n ): Promise<BN> {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return erc20Standard.getBalanceOf(address, selectedAddress);\n }\n\n /**\n * Query for the decimals for a given ERC20 asset.\n *\n * @param address - ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'decimals'.\n */\n async getERC20TokenDecimals(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return erc20Standard.getTokenDecimals(address);\n }\n\n /**\n * Query for the name for a given ERC20 asset.\n *\n * @param address - ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'decimals'.\n */\n async getERC20TokenName(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return erc20Standard.getTokenName(address);\n }\n\n /**\n * Enumerate assets assigned to an owner.\n *\n * @param address - ERC721 asset contract address.\n * @param selectedAddress - Current account public address.\n * @param index - An NFT counter less than `balanceOf(selectedAddress)`.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to token identifier for the 'index'th asset assigned to 'selectedAddress'.\n */\n async getERC721NftTokenId(\n address: string,\n selectedAddress: string,\n index: number,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getNftTokenId(address, selectedAddress, index);\n }\n\n /**\n * Enumerate assets assigned to an owner.\n *\n * @param tokenAddress - ERC721 asset contract address.\n * @param userAddress - Current account public address.\n * @param tokenId - ERC721 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to an object containing the token standard and a set of details which depend on which standard the token supports.\n */\n async getTokenStandardAndDetails(\n tokenAddress: string,\n userAddress?: string,\n tokenId?: string,\n networkClientId?: NetworkClientId,\n ): Promise<{\n standard: string;\n tokenURI?: string | undefined;\n symbol?: string | undefined;\n name?: string | undefined;\n decimals?: string | undefined;\n balance?: BN | undefined;\n }> {\n // Asserts provider is available\n this.#getCorrectProvider(networkClientId);\n\n // ERC721\n try {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return {\n ...(await erc721Standard.getDetails(\n tokenAddress,\n this.#ipfsGateway,\n tokenId,\n )),\n };\n } catch {\n // Ignore\n }\n\n // ERC1155\n try {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return {\n ...(await erc1155Standard.getDetails(\n tokenAddress,\n this.#ipfsGateway,\n tokenId,\n )),\n };\n } catch {\n // Ignore\n }\n\n // ERC20\n try {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return {\n ...(await erc20Standard.getDetails(tokenAddress, userAddress)),\n };\n } catch {\n // Ignore\n }\n\n throw new Error('Unable to determine contract standard');\n }\n\n /**\n * Query for tokenURI for a given ERC721 asset.\n *\n * @param address - ERC721 asset contract address.\n * @param tokenId - ERC721 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'tokenURI'.\n */\n async getERC721TokenURI(\n address: string,\n tokenId: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getTokenURI(address, tokenId);\n }\n\n /**\n * Query for name for a given asset.\n *\n * @param address - ERC721 or ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'name'.\n */\n async getERC721AssetName(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getAssetName(address);\n }\n\n /**\n * Query for symbol for a given asset.\n *\n * @param address - ERC721 or ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'symbol'.\n */\n async getERC721AssetSymbol(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getAssetSymbol(address);\n }\n\n /**\n * Query for owner for a given ERC721 asset.\n *\n * @param address - ERC721 asset contract address.\n * @param tokenId - ERC721 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the owner address.\n */\n async getERC721OwnerOf(\n address: string,\n tokenId: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getOwnerOf(address, tokenId);\n }\n\n /**\n * Query for tokenURI for a given asset.\n *\n * @param address - ERC1155 asset contract address.\n * @param tokenId - ERC1155 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'tokenURI'.\n */\n async getERC1155TokenURI(\n address: string,\n tokenId: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return erc1155Standard.getTokenURI(address, tokenId);\n }\n\n /**\n * Query for balance of a given ERC 1155 token.\n *\n * @param userAddress - Wallet public address.\n * @param nftAddress - ERC1155 asset contract address.\n * @param nftId - ERC1155 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'balanceOf'.\n */\n async getERC1155BalanceOf(\n userAddress: string,\n nftAddress: string,\n nftId: string,\n networkClientId?: NetworkClientId,\n ): Promise<BN> {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return erc1155Standard.getBalanceOf(nftAddress, userAddress, nftId);\n }\n\n /**\n * Transfer single ERC1155 token.\n *\n * @param nftAddress - ERC1155 token address.\n * @param senderAddress - ERC1155 token sender.\n * @param recipientAddress - ERC1155 token recipient.\n * @param nftId - ERC1155 token id.\n * @param qty - Quantity of tokens to be sent.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'transferSingle' ERC1155 token.\n */\n async transferSingleERC1155(\n nftAddress: string,\n senderAddress: string,\n recipientAddress: string,\n nftId: string,\n qty: string,\n networkClientId?: NetworkClientId,\n ): Promise<void> {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return erc1155Standard.transferSingle(\n nftAddress,\n senderAddress,\n recipientAddress,\n nftId,\n qty,\n );\n }\n\n /**\n * Get the token balance for a list of token addresses in a single call. Only non-zero balances\n * are returned.\n *\n * @param selectedAddress - The address to check token balances for.\n * @param tokensToDetect - The token addresses to detect balances for.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns The list of non-zero token balances.\n */\n async getBalancesInSingleCall(\n selectedAddress: string,\n tokensToDetect: string[],\n networkClientId?: NetworkClientId,\n ) {\n const chainId = this.#getCorrectChainId(networkClientId);\n const provider = this.#getCorrectProvider(networkClientId);\n if (\n !((id): id is keyof typeof SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID =>\n id in SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID)(chainId)\n ) {\n // Only fetch balance if contract address exists\n return {};\n }\n const contractAddress = SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID[chainId];\n\n const contract = new Contract(\n contractAddress,\n abiSingleCallBalancesContract,\n provider,\n );\n const result = await contract.balances([selectedAddress], tokensToDetect);\n const nonZeroBalances: BalanceMap = {};\n /* istanbul ignore else */\n if (result.length > 0) {\n tokensToDetect.forEach((tokenAddress, index) => {\n const balance: BN = result[index];\n /* istanbul ignore else */\n if (String(balance) !== '0') {\n nonZeroBalances[tokenAddress] = balance;\n }\n });\n }\n return nonZeroBalances;\n }\n}\n\nexport default AssetsContractController;\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkMZI3SDQNjs = require('./chunk-MZI3SDQN.js');
|
|
4
4
|
|
|
5
5
|
// src/Standards/NftStandards/ERC721/ERC721Standard.ts
|
|
6
6
|
var _contracts = require('@ethersproject/contracts');
|
|
@@ -133,7 +133,7 @@ var ERC721Standard = class {
|
|
|
133
133
|
_controllerutils.safelyExecute.call(void 0, () => this.getAssetName(address)),
|
|
134
134
|
tokenId ? _controllerutils.safelyExecute.call(void 0,
|
|
135
135
|
() => this.getTokenURI(address, tokenId).then(
|
|
136
|
-
(uri) => uri.startsWith("ipfs://") ?
|
|
136
|
+
(uri) => uri.startsWith("ipfs://") ? _chunkMZI3SDQNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
|
|
137
137
|
)
|
|
138
138
|
) : void 0
|
|
139
139
|
]);
|
|
@@ -144,7 +144,7 @@ var ERC721Standard = class {
|
|
|
144
144
|
const object = await response.json();
|
|
145
145
|
image = object?.image;
|
|
146
146
|
if (image?.startsWith("ipfs://")) {
|
|
147
|
-
image =
|
|
147
|
+
image = _chunkMZI3SDQNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
|
|
148
148
|
}
|
|
149
149
|
} catch {
|
|
150
150
|
}
|
|
@@ -175,4 +175,4 @@ var ERC721Standard = class {
|
|
|
175
175
|
|
|
176
176
|
|
|
177
177
|
exports.ERC721Standard = ERC721Standard;
|
|
178
|
-
//# sourceMappingURL=chunk-
|
|
178
|
+
//# sourceMappingURL=chunk-ISK2VSBB.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkMZI3SDQNjs = require('./chunk-MZI3SDQN.js');
|
|
4
4
|
|
|
5
5
|
// src/Standards/ERC20Standard.ts
|
|
6
6
|
var _util = require('@ethereumjs/util');
|
|
@@ -23,7 +23,7 @@ var ERC20Standard = class {
|
|
|
23
23
|
async getBalanceOf(address, selectedAddress) {
|
|
24
24
|
const contract = new (0, _contracts.Contract)(address, _metamaskethabis.abiERC20, this.provider);
|
|
25
25
|
const balance = await contract.balanceOf(selectedAddress);
|
|
26
|
-
return
|
|
26
|
+
return _chunkMZI3SDQNjs.ethersBigNumberToBN.call(void 0, balance);
|
|
27
27
|
}
|
|
28
28
|
/**
|
|
29
29
|
* Query for the decimals for a given ERC20 asset.
|
|
@@ -112,4 +112,4 @@ var ERC20Standard = class {
|
|
|
112
112
|
|
|
113
113
|
|
|
114
114
|
exports.ERC20Standard = ERC20Standard;
|
|
115
|
-
//# sourceMappingURL=chunk-
|
|
115
|
+
//# sourceMappingURL=chunk-JCR4H6YL.js.map
|
|
@@ -5,9 +5,7 @@ import {
|
|
|
5
5
|
} from "./chunk-XUI43LEZ.mjs";
|
|
6
6
|
|
|
7
7
|
// src/TokenBalancesController.ts
|
|
8
|
-
import {
|
|
9
|
-
BaseController
|
|
10
|
-
} from "@metamask/base-controller";
|
|
8
|
+
import { BaseController } from "@metamask/base-controller";
|
|
11
9
|
import { safelyExecute, toHex } from "@metamask/controller-utils";
|
|
12
10
|
var DEFAULT_INTERVAL = 18e4;
|
|
13
11
|
var controllerName = "TokenBalancesController";
|
|
@@ -19,7 +17,7 @@ function getDefaultTokenBalancesState() {
|
|
|
19
17
|
contractBalances: {}
|
|
20
18
|
};
|
|
21
19
|
}
|
|
22
|
-
var _handle,
|
|
20
|
+
var _handle, _interval, _tokens, _disabled;
|
|
23
21
|
var TokenBalancesController = class extends BaseController {
|
|
24
22
|
/**
|
|
25
23
|
* Construct a Token Balances Controller.
|
|
@@ -28,7 +26,6 @@ var TokenBalancesController = class extends BaseController {
|
|
|
28
26
|
* @param options.interval - Polling interval used to fetch new token balances.
|
|
29
27
|
* @param options.tokens - List of tokens to track balances for.
|
|
30
28
|
* @param options.disabled - If set to true, all tracked tokens contract balances updates are blocked.
|
|
31
|
-
* @param options.getERC20BalanceOf - Gets the balance of the given account at the given contract address.
|
|
32
29
|
* @param options.state - Initial state to set on this controller.
|
|
33
30
|
* @param options.messenger - The controller restricted messenger.
|
|
34
31
|
*/
|
|
@@ -36,7 +33,6 @@ var TokenBalancesController = class extends BaseController {
|
|
|
36
33
|
interval = DEFAULT_INTERVAL,
|
|
37
34
|
tokens = [],
|
|
38
35
|
disabled = false,
|
|
39
|
-
getERC20BalanceOf,
|
|
40
36
|
messenger,
|
|
41
37
|
state = {}
|
|
42
38
|
}) {
|
|
@@ -50,7 +46,6 @@ var TokenBalancesController = class extends BaseController {
|
|
|
50
46
|
}
|
|
51
47
|
});
|
|
52
48
|
__privateAdd(this, _handle, void 0);
|
|
53
|
-
__privateAdd(this, _getERC20BalanceOf, void 0);
|
|
54
49
|
__privateAdd(this, _interval, void 0);
|
|
55
50
|
__privateAdd(this, _tokens, void 0);
|
|
56
51
|
__privateAdd(this, _disabled, void 0);
|
|
@@ -64,7 +59,6 @@ var TokenBalancesController = class extends BaseController {
|
|
|
64
59
|
this.updateBalances();
|
|
65
60
|
}
|
|
66
61
|
);
|
|
67
|
-
__privateSet(this, _getERC20BalanceOf, getERC20BalanceOf);
|
|
68
62
|
this.poll();
|
|
69
63
|
}
|
|
70
64
|
/**
|
|
@@ -110,7 +104,11 @@ var TokenBalancesController = class extends BaseController {
|
|
|
110
104
|
for (const token of __privateGet(this, _tokens)) {
|
|
111
105
|
const { address } = token;
|
|
112
106
|
try {
|
|
113
|
-
const balance = await
|
|
107
|
+
const balance = await this.messagingSystem.call(
|
|
108
|
+
"AssetsContractController:getERC20BalanceOf",
|
|
109
|
+
address,
|
|
110
|
+
selectedInternalAccount.address
|
|
111
|
+
);
|
|
114
112
|
newContractBalances[address] = toHex(balance);
|
|
115
113
|
token.hasBalanceError = false;
|
|
116
114
|
} catch (error) {
|
|
@@ -124,7 +122,6 @@ var TokenBalancesController = class extends BaseController {
|
|
|
124
122
|
}
|
|
125
123
|
};
|
|
126
124
|
_handle = new WeakMap();
|
|
127
|
-
_getERC20BalanceOf = new WeakMap();
|
|
128
125
|
_interval = new WeakMap();
|
|
129
126
|
_tokens = new WeakMap();
|
|
130
127
|
_disabled = new WeakMap();
|
|
@@ -135,4 +132,4 @@ export {
|
|
|
135
132
|
TokenBalancesController,
|
|
136
133
|
TokenBalancesController_default
|
|
137
134
|
};
|
|
138
|
-
//# sourceMappingURL=chunk-
|
|
135
|
+
//# sourceMappingURL=chunk-JJX7TMH5.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/TokenBalancesController.ts"],"sourcesContent":["import type { AccountsControllerGetSelectedAccountAction } from '@metamask/accounts-controller';\nimport type {\n RestrictedControllerMessenger,\n ControllerGetStateAction,\n ControllerStateChangeEvent,\n} from '@metamask/base-controller';\nimport { BaseController } from '@metamask/base-controller';\nimport { safelyExecute, toHex } from '@metamask/controller-utils';\n\nimport type { AssetsContractControllerGetERC20BalanceOfAction } from './AssetsContractController';\nimport type { Token } from './TokenRatesController';\nimport type { TokensControllerStateChangeEvent } from './TokensController';\n\nconst DEFAULT_INTERVAL = 180000;\n\nconst controllerName = 'TokenBalancesController';\n\nconst metadata = {\n contractBalances: { persist: true, anonymous: false },\n};\n\n/**\n * Token balances controller options\n * @property interval - Polling interval used to fetch new token balances.\n * @property tokens - List of tokens to track balances for.\n * @property disabled - If set to true, all tracked tokens contract balances updates are blocked.\n */\ntype TokenBalancesControllerOptions = {\n interval?: number;\n tokens?: Token[];\n disabled?: boolean;\n messenger: TokenBalancesControllerMessenger;\n state?: Partial<TokenBalancesControllerState>;\n};\n\n/**\n * Represents a mapping of hash token contract addresses to their balances.\n */\ntype ContractBalances = Record<string, string>;\n\n/**\n * Token balances controller state\n * @property contractBalances - Hash of token contract addresses to balances\n */\nexport type TokenBalancesControllerState = {\n contractBalances: ContractBalances;\n};\n\nexport type TokenBalancesControllerGetStateAction = ControllerGetStateAction<\n typeof controllerName,\n TokenBalancesControllerState\n>;\n\nexport type TokenBalancesControllerActions =\n TokenBalancesControllerGetStateAction;\n\nexport type AllowedActions =\n | AccountsControllerGetSelectedAccountAction\n | AssetsContractControllerGetERC20BalanceOfAction;\n\nexport type TokenBalancesControllerStateChangeEvent =\n ControllerStateChangeEvent<\n typeof controllerName,\n TokenBalancesControllerState\n >;\n\nexport type TokenBalancesControllerEvents =\n TokenBalancesControllerStateChangeEvent;\n\nexport type AllowedEvents = TokensControllerStateChangeEvent;\n\nexport type TokenBalancesControllerMessenger = RestrictedControllerMessenger<\n typeof controllerName,\n TokenBalancesControllerActions | AllowedActions,\n TokenBalancesControllerEvents | AllowedEvents,\n AllowedActions['type'],\n AllowedEvents['type']\n>;\n\n/**\n * Get the default TokenBalancesController state.\n *\n * @returns The default TokenBalancesController state.\n */\nexport function getDefaultTokenBalancesState(): TokenBalancesControllerState {\n return {\n contractBalances: {},\n };\n}\n\n/**\n * Controller that passively polls on a set interval token balances\n * for tokens stored in the TokensController\n */\nexport class TokenBalancesController extends BaseController<\n typeof controllerName,\n TokenBalancesControllerState,\n TokenBalancesControllerMessenger\n> {\n #handle?: ReturnType<typeof setTimeout>;\n\n #interval: number;\n\n #tokens: Token[];\n\n #disabled: boolean;\n\n /**\n * Construct a Token Balances Controller.\n *\n * @param options - The controller options.\n * @param options.interval - Polling interval used to fetch new token balances.\n * @param options.tokens - List of tokens to track balances for.\n * @param options.disabled - If set to true, all tracked tokens contract balances updates are blocked.\n * @param options.state - Initial state to set on this controller.\n * @param options.messenger - The controller restricted messenger.\n */\n constructor({\n interval = DEFAULT_INTERVAL,\n tokens = [],\n disabled = false,\n messenger,\n state = {},\n }: TokenBalancesControllerOptions) {\n super({\n name: controllerName,\n metadata,\n messenger,\n state: {\n ...getDefaultTokenBalancesState(),\n ...state,\n },\n });\n\n this.#disabled = disabled;\n this.#interval = interval;\n this.#tokens = tokens;\n\n this.messagingSystem.subscribe(\n 'TokensController:stateChange',\n ({ tokens: newTokens, detectedTokens }) => {\n this.#tokens = [...newTokens, ...detectedTokens];\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.updateBalances();\n },\n );\n\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.poll();\n }\n\n /**\n * Allows controller to update tracked tokens contract balances.\n */\n enable() {\n this.#disabled = false;\n }\n\n /**\n * Blocks controller from updating tracked tokens contract balances.\n */\n disable() {\n this.#disabled = true;\n }\n\n /**\n * Starts a new polling interval.\n *\n * @param interval - Polling interval used to fetch new token balances.\n */\n async poll(interval?: number): Promise<void> {\n if (interval) {\n this.#interval = interval;\n }\n\n if (this.#handle) {\n clearTimeout(this.#handle);\n }\n\n await safelyExecute(() => this.updateBalances());\n\n this.#handle = setTimeout(() => {\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.poll(this.#interval);\n }, this.#interval);\n }\n\n /**\n * Updates balances for all tokens.\n */\n async updateBalances() {\n if (this.#disabled) {\n return;\n }\n const selectedInternalAccount = this.messagingSystem.call(\n 'AccountsController:getSelectedAccount',\n );\n\n const newContractBalances: ContractBalances = {};\n for (const token of this.#tokens) {\n const { address } = token;\n try {\n const balance = await this.messagingSystem.call(\n 'AssetsContractController:getERC20BalanceOf',\n address,\n selectedInternalAccount.address,\n );\n newContractBalances[address] = toHex(balance);\n token.hasBalanceError = false;\n } catch (error) {\n newContractBalances[address] = toHex(0);\n token.hasBalanceError = true;\n }\n }\n\n this.update((state) => {\n state.contractBalances = newContractBalances;\n });\n }\n}\n\nexport default TokenBalancesController;\n"],"mappings":";;;;;;;AAMA,SAAS,sBAAsB;AAC/B,SAAS,eAAe,aAAa;AAMrC,IAAM,mBAAmB;AAEzB,IAAM,iBAAiB;AAEvB,IAAM,WAAW;AAAA,EACf,kBAAkB,EAAE,SAAS,MAAM,WAAW,MAAM;AACtD;AAiEO,SAAS,+BAA6D;AAC3E,SAAO;AAAA,IACL,kBAAkB,CAAC;AAAA,EACrB;AACF;AAxFA;AA8FO,IAAM,0BAAN,cAAsC,eAI3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAmBA,YAAY;AAAA,IACV,WAAW;AAAA,IACX,SAAS,CAAC;AAAA,IACV,WAAW;AAAA,IACX;AAAA,IACA,QAAQ,CAAC;AAAA,EACX,GAAmC;AACjC,UAAM;AAAA,MACJ,MAAM;AAAA,MACN;AAAA,MACA;AAAA,MACA,OAAO;AAAA,QACL,GAAG,6BAA6B;AAAA,QAChC,GAAG;AAAA,MACL;AAAA,IACF,CAAC;AAjCH;AAEA;AAEA;AAEA;AA6BE,uBAAK,WAAY;AACjB,uBAAK,WAAY;AACjB,uBAAK,SAAU;AAEf,SAAK,gBAAgB;AAAA,MACnB;AAAA,MACA,CAAC,EAAE,QAAQ,WAAW,eAAe,MAAM;AACzC,2BAAK,SAAU,CAAC,GAAG,WAAW,GAAG,cAAc;AAG/C,aAAK,eAAe;AAAA,MACtB;AAAA,IACF;AAIA,SAAK,KAAK;AAAA,EACZ;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS;AACP,uBAAK,WAAY;AAAA,EACnB;AAAA;AAAA;AAAA;AAAA,EAKA,UAAU;AACR,uBAAK,WAAY;AAAA,EACnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,MAAM,KAAK,UAAkC;AAC3C,QAAI,UAAU;AACZ,yBAAK,WAAY;AAAA,IACnB;AAEA,QAAI,mBAAK,UAAS;AAChB,mBAAa,mBAAK,QAAO;AAAA,IAC3B;AAEA,UAAM,cAAc,MAAM,KAAK,eAAe,CAAC;AAE/C,uBAAK,SAAU,WAAW,MAAM;AAG9B,WAAK,KAAK,mBAAK,UAAS;AAAA,IAC1B,GAAG,mBAAK,UAAS;AAAA,EACnB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,iBAAiB;AACrB,QAAI,mBAAK,YAAW;AAClB;AAAA,IACF;AACA,UAAM,0BAA0B,KAAK,gBAAgB;AAAA,MACnD;AAAA,IACF;AAEA,UAAM,sBAAwC,CAAC;AAC/C,eAAW,SAAS,mBAAK,UAAS;AAChC,YAAM,EAAE,QAAQ,IAAI;AACpB,UAAI;AACF,cAAM,UAAU,MAAM,KAAK,gBAAgB;AAAA,UACzC;AAAA,UACA;AAAA,UACA,wBAAwB;AAAA,QAC1B;AACA,4BAAoB,OAAO,IAAI,MAAM,OAAO;AAC5C,cAAM,kBAAkB;AAAA,MAC1B,SAAS,OAAO;AACd,4BAAoB,OAAO,IAAI,MAAM,CAAC;AACtC,cAAM,kBAAkB;AAAA,MAC1B;AAAA,IACF;AAEA,SAAK,OAAO,CAAC,UAAU;AACrB,YAAM,mBAAmB;AAAA,IAC3B,CAAC;AAAA,EACH;AACF;AA3HE;AAEA;AAEA;AAEA;AAuHF,IAAO,kCAAQ;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkMZI3SDQNjs = require('./chunk-MZI3SDQN.js');
|
|
4
4
|
|
|
5
5
|
// src/token-service.ts
|
|
6
6
|
|
|
@@ -38,7 +38,7 @@ async function fetchTokenListByChainId(chainId, abortSignal, { timeout = default
|
|
|
38
38
|
return void 0;
|
|
39
39
|
}
|
|
40
40
|
async function fetchTokenMetadata(chainId, tokenAddress, abortSignal, { timeout = defaultTimeout } = {}) {
|
|
41
|
-
if (!
|
|
41
|
+
if (!_chunkMZI3SDQNjs.isTokenListSupportedForNetwork.call(void 0, chainId)) {
|
|
42
42
|
throw new Error(TOKEN_METADATA_NO_SUPPORT_ERROR);
|
|
43
43
|
}
|
|
44
44
|
const tokenMetadataURL = getTokenMetadataURL(chainId, tokenAddress);
|
|
@@ -82,4 +82,4 @@ async function parseJsonResponse(apiResponse) {
|
|
|
82
82
|
|
|
83
83
|
|
|
84
84
|
exports.TOKEN_END_POINT_API = TOKEN_END_POINT_API; exports.TOKEN_METADATA_NO_SUPPORT_ERROR = TOKEN_METADATA_NO_SUPPORT_ERROR; exports.fetchTokenListByChainId = fetchTokenListByChainId; exports.fetchTokenMetadata = fetchTokenMetadata;
|
|
85
|
-
//# sourceMappingURL=chunk-
|
|
85
|
+
//# sourceMappingURL=chunk-K7A3EOIM.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ethersBigNumberToBN,
|
|
3
3
|
getFormattedIpfsUrl
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-BZEAPSD5.mjs";
|
|
5
5
|
|
|
6
6
|
// src/Standards/NftStandards/ERC1155/ERC1155Standard.ts
|
|
7
7
|
import { Contract } from "@ethersproject/contracts";
|
|
@@ -212,4 +212,4 @@ var ERC1155Standard = class {
|
|
|
212
212
|
export {
|
|
213
213
|
ERC1155Standard
|
|
214
214
|
};
|
|
215
|
-
//# sourceMappingURL=chunk-
|
|
215
|
+
//# sourceMappingURL=chunk-KPBNX6GP.mjs.map
|
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }// src/assetsUtil.ts
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }// src/assetsUtil.ts
|
|
2
2
|
|
|
3
3
|
|
|
4
4
|
|
|
5
5
|
var _controllerutils = require('@metamask/controller-utils');
|
|
6
6
|
var _utils = require('@metamask/utils');
|
|
7
7
|
var _bnjs = require('bn.js'); var _bnjs2 = _interopRequireDefault(_bnjs);
|
|
8
|
-
var _cid = require('multiformats/cid');
|
|
9
8
|
var TOKEN_PRICES_BATCH_SIZE = 30;
|
|
10
9
|
function compareNftMetadata(newNftMetadata, nft) {
|
|
11
10
|
const keys = [
|
|
@@ -27,6 +26,11 @@ function compareNftMetadata(newNftMetadata, nft) {
|
|
|
27
26
|
}, 0);
|
|
28
27
|
return differentValues > 0;
|
|
29
28
|
}
|
|
29
|
+
function hasNewCollectionFields(newNftMetadata, nft) {
|
|
30
|
+
const keysNewNftMetadata = Object.keys(newNftMetadata.collection ?? {});
|
|
31
|
+
const keysExistingNft = new Set(Object.keys(nft.collection ?? {}));
|
|
32
|
+
return keysNewNftMetadata.some((key) => !keysExistingNft.has(key));
|
|
33
|
+
}
|
|
30
34
|
var aggregatorNameByKey = {
|
|
31
35
|
aave: "Aave",
|
|
32
36
|
bancor: "Bancor",
|
|
@@ -102,20 +106,21 @@ function removeIpfsProtocolPrefix(ipfsUrl) {
|
|
|
102
106
|
}
|
|
103
107
|
throw new Error("this method should not be used with non ipfs urls");
|
|
104
108
|
}
|
|
105
|
-
function getIpfsCIDv1AndPath(ipfsUrl) {
|
|
109
|
+
async function getIpfsCIDv1AndPath(ipfsUrl) {
|
|
106
110
|
const url = removeIpfsProtocolPrefix(ipfsUrl);
|
|
107
111
|
const index = url.indexOf("/");
|
|
108
112
|
const cid = index !== -1 ? url.substring(0, index) : url;
|
|
109
113
|
const path = index !== -1 ? url.substring(index) : void 0;
|
|
114
|
+
const { CID } = await Promise.resolve().then(() => _interopRequireWildcard(require("multiformats")));
|
|
110
115
|
return {
|
|
111
|
-
cid:
|
|
116
|
+
cid: CID.parse(cid).toV1().toString(),
|
|
112
117
|
path
|
|
113
118
|
};
|
|
114
119
|
}
|
|
115
|
-
function getFormattedIpfsUrl(ipfsGateway, ipfsUrl, subdomainSupported) {
|
|
120
|
+
async function getFormattedIpfsUrl(ipfsGateway, ipfsUrl, subdomainSupported) {
|
|
116
121
|
const { host, protocol, origin } = new URL(addUrlProtocolPrefix(ipfsGateway));
|
|
117
122
|
if (subdomainSupported) {
|
|
118
|
-
const { cid, path } = getIpfsCIDv1AndPath(ipfsUrl);
|
|
123
|
+
const { cid, path } = await getIpfsCIDv1AndPath(ipfsUrl);
|
|
119
124
|
return `${protocol}//${cid}.ipfs.${host}${path ?? ""}`;
|
|
120
125
|
}
|
|
121
126
|
const cidAndPath = removeIpfsProtocolPrefix(ipfsUrl);
|
|
@@ -205,5 +210,6 @@ async function fetchTokenContractExchangeRates({
|
|
|
205
210
|
|
|
206
211
|
|
|
207
212
|
|
|
208
|
-
|
|
209
|
-
|
|
213
|
+
|
|
214
|
+
exports.TOKEN_PRICES_BATCH_SIZE = TOKEN_PRICES_BATCH_SIZE; exports.compareNftMetadata = compareNftMetadata; exports.hasNewCollectionFields = hasNewCollectionFields; exports.formatAggregatorNames = formatAggregatorNames; exports.formatIconUrlWithProxy = formatIconUrlWithProxy; exports.SupportedTokenDetectionNetworks = SupportedTokenDetectionNetworks; exports.isTokenDetectionSupportedForNetwork = isTokenDetectionSupportedForNetwork; exports.isTokenListSupportedForNetwork = isTokenListSupportedForNetwork; exports.removeIpfsProtocolPrefix = removeIpfsProtocolPrefix; exports.getIpfsCIDv1AndPath = getIpfsCIDv1AndPath; exports.getFormattedIpfsUrl = getFormattedIpfsUrl; exports.addUrlProtocolPrefix = addUrlProtocolPrefix; exports.ethersBigNumberToBN = ethersBigNumberToBN; exports.divideIntoBatches = divideIntoBatches; exports.reduceInBatchesSerially = reduceInBatchesSerially; exports.fetchTokenContractExchangeRates = fetchTokenContractExchangeRates;
|
|
215
|
+
//# sourceMappingURL=chunk-MZI3SDQN.js.map
|