@metamask/assets-controllers 36.0.0 → 38.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 +86 -1
- package/dist/AssetsContractController.js +6 -6
- package/dist/AssetsContractController.mjs +5 -5
- package/dist/CurrencyRateController.js +3 -3
- package/dist/CurrencyRateController.mjs +2 -2
- package/dist/NftController.js +3 -3
- package/dist/NftController.mjs +2 -2
- package/dist/NftDetectionController.js +3 -3
- package/dist/NftDetectionController.mjs +2 -2
- package/dist/RatesController/RatesController.js +3 -3
- package/dist/RatesController/RatesController.mjs +2 -2
- package/dist/RatesController/index.js +3 -3
- package/dist/RatesController/index.mjs +2 -2
- 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 +4 -4
- package/dist/TokenRatesController.mjs +3 -3
- package/dist/TokensController.js +6 -6
- package/dist/TokensController.mjs +5 -5
- package/dist/assetsUtil.js +2 -2
- package/dist/assetsUtil.mjs +1 -1
- package/dist/{chunk-HTIZ4JKG.js → chunk-2TZK6YZA.js} +66 -43
- package/dist/chunk-2TZK6YZA.js.map +1 -0
- package/dist/{chunk-2J3CVSQ5.js → chunk-3LPQTUGG.js} +5 -5
- package/dist/{chunk-7H2V5SW4.mjs → chunk-3QDXAE2D.mjs} +2 -2
- package/dist/{chunk-PPJTMDXC.mjs → chunk-46KUC5FH.mjs} +2 -2
- package/dist/{chunk-K6DUHENW.mjs → chunk-4QZESU46.mjs} +3 -3
- package/dist/chunk-4QZESU46.mjs.map +1 -0
- package/dist/{chunk-B46K3T54.js → chunk-5QLC2MHV.js} +5 -5
- package/dist/{chunk-5IMEJ2FS.mjs → chunk-AX522TDL.mjs} +2 -2
- package/dist/{chunk-62HDABFM.mjs → chunk-AZSIKIMK.mjs} +136 -79
- package/dist/chunk-AZSIKIMK.mjs.map +1 -0
- package/dist/{chunk-Z6NCPTNT.js → chunk-BBCZM5P4.js} +3 -3
- package/dist/{chunk-24HGVPDI.mjs → chunk-BZEAPSD5.mjs} +5 -5
- package/dist/chunk-BZEAPSD5.mjs.map +1 -0
- package/dist/{chunk-RI6LDZPC.mjs → chunk-C7LNCQXM.mjs} +2 -2
- package/dist/{chunk-JTXPJ6TK.mjs → chunk-FWKV5FGP.mjs} +5 -2
- package/dist/chunk-FWKV5FGP.mjs.map +1 -0
- package/dist/{chunk-ZG5MS2TO.js → chunk-GDFLKKDY.js} +5 -2
- package/dist/chunk-GDFLKKDY.js.map +1 -0
- package/dist/{chunk-SBWPU4VT.mjs → chunk-GW6RE66P.mjs} +28 -22
- package/dist/chunk-GW6RE66P.mjs.map +1 -0
- package/dist/{chunk-4U2L56TY.js → chunk-ISK2VSBB.js} +4 -4
- package/dist/{chunk-DOCJ35CC.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-T5ZX5BV7.js → chunk-JMZ7KWJS.js} +3 -3
- package/dist/{chunk-OJLB6FID.js → chunk-K7A3EOIM.js} +3 -3
- package/dist/{chunk-A7VI64MA.mjs → chunk-KPBNX6GP.mjs} +2 -2
- package/dist/{chunk-IJS7EZU2.js → chunk-LKVWPNXY.js} +139 -82
- package/dist/chunk-LKVWPNXY.js.map +1 -0
- package/dist/{chunk-R4HATJKU.js → chunk-MZI3SDQN.js} +7 -7
- package/dist/chunk-MZI3SDQN.js.map +1 -0
- package/dist/{chunk-TPUVGGNO.js → chunk-NDUMUEE6.js} +11 -12
- package/dist/chunk-NDUMUEE6.js.map +1 -0
- package/dist/{chunk-2YFZGRUL.mjs → chunk-S5CFNNOM.mjs} +2 -2
- package/dist/{chunk-OCV7GPA2.mjs → chunk-SK2B36Q4.mjs} +63 -40
- package/dist/chunk-SK2B36Q4.mjs.map +1 -0
- package/dist/{chunk-ZWZZUFO5.mjs → chunk-TFLYM4PY.mjs} +3 -3
- package/dist/{chunk-F6L3DFOZ.js → chunk-TIFLP53R.js} +29 -23
- package/dist/chunk-TIFLP53R.js.map +1 -0
- package/dist/{chunk-HJ5GXVDT.mjs → chunk-UKXD6WUT.mjs} +2 -2
- package/dist/{chunk-DSDI75PJ.js → chunk-UUF4E7OG.js} +6 -6
- package/dist/chunk-UUF4E7OG.js.map +1 -0
- package/dist/{chunk-RXBDSHHH.mjs → chunk-XMQA5NLX.mjs} +5 -6
- package/dist/chunk-XMQA5NLX.mjs.map +1 -0
- package/dist/{chunk-NHFZIY2K.js → chunk-YGGUAMHV.js} +7 -10
- package/dist/chunk-YGGUAMHV.js.map +1 -0
- package/dist/{chunk-3QLHZOXA.js → chunk-ZAR4BIOC.js} +7 -7
- package/dist/crypto-compare-service/crypto-compare.js +2 -2
- package/dist/crypto-compare-service/crypto-compare.mjs +1 -1
- package/dist/crypto-compare-service/index.js +2 -2
- package/dist/crypto-compare-service/index.mjs +1 -1
- package/dist/index.js +17 -19
- package/dist/index.mjs +16 -18
- 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 +94 -56
- package/dist/types/AssetsContractController.d.ts.map +1 -1
- package/dist/types/NftController.d.ts +13 -15
- package/dist/types/NftController.d.ts.map +1 -1
- package/dist/types/RatesController/RatesController.d.ts +2 -2
- package/dist/types/RatesController/RatesController.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/TokenRatesController.d.ts +1 -1
- package/dist/types/TokenRatesController.d.ts.map +1 -1
- package/dist/types/TokensController.d.ts +1 -1
- package/dist/types/TokensController.d.ts.map +1 -1
- package/dist/types/assetsUtil.d.ts +3 -3
- package/dist/types/assetsUtil.d.ts.map +1 -1
- package/dist/types/crypto-compare-service/crypto-compare.d.ts.map +1 -1
- package/dist/types/index.d.ts +4 -3
- package/dist/types/index.d.ts.map +1 -1
- package/package.json +22 -20
- package/dist/chunk-24HGVPDI.mjs.map +0 -1
- package/dist/chunk-62HDABFM.mjs.map +0 -1
- package/dist/chunk-6VQJFTNC.mjs.map +0 -1
- package/dist/chunk-DSDI75PJ.js.map +0 -1
- package/dist/chunk-F6L3DFOZ.js.map +0 -1
- package/dist/chunk-HTIZ4JKG.js.map +0 -1
- package/dist/chunk-IJS7EZU2.js.map +0 -1
- package/dist/chunk-JTXPJ6TK.mjs.map +0 -1
- package/dist/chunk-K6DUHENW.mjs.map +0 -1
- package/dist/chunk-NHFZIY2K.js.map +0 -1
- package/dist/chunk-OCV7GPA2.mjs.map +0 -1
- package/dist/chunk-R4HATJKU.js.map +0 -1
- package/dist/chunk-RXBDSHHH.mjs.map +0 -1
- package/dist/chunk-SBWPU4VT.mjs.map +0 -1
- package/dist/chunk-TPUVGGNO.js.map +0 -1
- package/dist/chunk-ZG5MS2TO.js.map +0 -1
- /package/dist/{chunk-2J3CVSQ5.js.map → chunk-3LPQTUGG.js.map} +0 -0
- /package/dist/{chunk-7H2V5SW4.mjs.map → chunk-3QDXAE2D.mjs.map} +0 -0
- /package/dist/{chunk-PPJTMDXC.mjs.map → chunk-46KUC5FH.mjs.map} +0 -0
- /package/dist/{chunk-B46K3T54.js.map → chunk-5QLC2MHV.js.map} +0 -0
- /package/dist/{chunk-5IMEJ2FS.mjs.map → chunk-AX522TDL.mjs.map} +0 -0
- /package/dist/{chunk-Z6NCPTNT.js.map → chunk-BBCZM5P4.js.map} +0 -0
- /package/dist/{chunk-RI6LDZPC.mjs.map → chunk-C7LNCQXM.mjs.map} +0 -0
- /package/dist/{chunk-4U2L56TY.js.map → chunk-ISK2VSBB.js.map} +0 -0
- /package/dist/{chunk-DOCJ35CC.js.map → chunk-JCR4H6YL.js.map} +0 -0
- /package/dist/{chunk-T5ZX5BV7.js.map → chunk-JMZ7KWJS.js.map} +0 -0
- /package/dist/{chunk-OJLB6FID.js.map → chunk-K7A3EOIM.js.map} +0 -0
- /package/dist/{chunk-A7VI64MA.mjs.map → chunk-KPBNX6GP.mjs.map} +0 -0
- /package/dist/{chunk-2YFZGRUL.mjs.map → chunk-S5CFNNOM.mjs.map} +0 -0
- /package/dist/{chunk-ZWZZUFO5.mjs.map → chunk-TFLYM4PY.mjs.map} +0 -0
- /package/dist/{chunk-HJ5GXVDT.mjs.map → chunk-UKXD6WUT.mjs.map} +0 -0
- /package/dist/{chunk-3QLHZOXA.js.map → chunk-ZAR4BIOC.js.map} +0 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
3
|
|
|
4
|
-
var
|
|
4
|
+
var _chunkMZI3SDQNjs = require('./chunk-MZI3SDQN.js');
|
|
5
5
|
|
|
6
6
|
// src/Standards/NftStandards/ERC1155/ERC1155Standard.ts
|
|
7
7
|
var _contracts = require('@ethersproject/contracts');
|
|
@@ -73,7 +73,7 @@ var ERC1155Standard = class {
|
|
|
73
73
|
async getBalanceOf(contractAddress, address, tokenId) {
|
|
74
74
|
const contract = new (0, _contracts.Contract)(contractAddress, _metamaskethabis.abiERC1155, this.provider);
|
|
75
75
|
const balance = await contract.balanceOf(address, tokenId);
|
|
76
|
-
return
|
|
76
|
+
return _chunkMZI3SDQNjs.ethersBigNumberToBN.call(void 0, balance);
|
|
77
77
|
}
|
|
78
78
|
/**
|
|
79
79
|
* Transfer single ERC1155 token.
|
|
@@ -184,7 +184,7 @@ var ERC1155Standard = class {
|
|
|
184
184
|
_controllerutils.safelyExecute.call(void 0, () => this.getAssetName(address)),
|
|
185
185
|
tokenId ? _controllerutils.safelyExecute.call(void 0,
|
|
186
186
|
() => this.getTokenURI(address, tokenId).then(
|
|
187
|
-
(uri) => uri.startsWith("ipfs://") ?
|
|
187
|
+
(uri) => uri.startsWith("ipfs://") ? _chunkMZI3SDQNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
|
|
188
188
|
)
|
|
189
189
|
) : void 0
|
|
190
190
|
]);
|
|
@@ -194,7 +194,7 @@ var ERC1155Standard = class {
|
|
|
194
194
|
const object = await response.json();
|
|
195
195
|
image = object?.image;
|
|
196
196
|
if (image?.startsWith("ipfs://")) {
|
|
197
|
-
image =
|
|
197
|
+
image = _chunkMZI3SDQNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
|
|
198
198
|
}
|
|
199
199
|
} catch {
|
|
200
200
|
}
|
|
@@ -212,4 +212,4 @@ var ERC1155Standard = class {
|
|
|
212
212
|
|
|
213
213
|
|
|
214
214
|
exports.ERC1155Standard = ERC1155Standard;
|
|
215
|
-
//# sourceMappingURL=chunk-
|
|
215
|
+
//# sourceMappingURL=chunk-5QLC2MHV.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
isTokenListSupportedForNetwork
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-BZEAPSD5.mjs";
|
|
4
4
|
|
|
5
5
|
// src/token-service.ts
|
|
6
6
|
import {
|
|
@@ -82,4 +82,4 @@ export {
|
|
|
82
82
|
fetchTokenListByChainId,
|
|
83
83
|
fetchTokenMetadata
|
|
84
84
|
};
|
|
85
|
-
//# sourceMappingURL=chunk-
|
|
85
|
+
//# sourceMappingURL=chunk-AX522TDL.mjs.map
|
|
@@ -1,18 +1,24 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ERC721Standard
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-3QDXAE2D.mjs";
|
|
4
4
|
import {
|
|
5
5
|
ERC20Standard
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-S5CFNNOM.mjs";
|
|
7
7
|
import {
|
|
8
8
|
ERC1155Standard
|
|
9
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-KPBNX6GP.mjs";
|
|
10
|
+
import {
|
|
11
|
+
__privateAdd,
|
|
12
|
+
__privateGet,
|
|
13
|
+
__privateMethod,
|
|
14
|
+
__privateSet
|
|
15
|
+
} from "./chunk-XUI43LEZ.mjs";
|
|
10
16
|
|
|
11
17
|
// src/AssetsContractController.ts
|
|
12
18
|
import { Contract } from "@ethersproject/contracts";
|
|
13
19
|
import { Web3Provider } from "@ethersproject/providers";
|
|
14
|
-
import { BaseControllerV1 } from "@metamask/base-controller";
|
|
15
20
|
import { IPFS_DEFAULT_GATEWAY_URL } from "@metamask/controller-utils";
|
|
21
|
+
import { getKnownPropertyNames } from "@metamask/utils";
|
|
16
22
|
import abiSingleCallBalancesContract from "single-call-balance-checker-abi";
|
|
17
23
|
var SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = {
|
|
18
24
|
["0x1" /* mainnet */]: "0xb1f8e55c7f64d203c1400b9d8555d050f94adf39",
|
|
@@ -35,85 +41,61 @@ 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
|
+
__privateAdd(this, _registerActionHandlers);
|
|
60
|
+
__privateAdd(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
|
-
this
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
this
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
chainId: selectedNetworkClient.configuration.chainId
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
});
|
|
67
|
+
__privateAdd(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
|
+
__privateAdd(this, _getCorrectChainId);
|
|
75
|
+
this.name = name;
|
|
76
|
+
__privateAdd(this, _provider, void 0);
|
|
77
|
+
__privateAdd(this, _ipfsGateway, void 0);
|
|
78
|
+
__privateAdd(this, _chainId, void 0);
|
|
79
|
+
this.messagingSystem = messenger;
|
|
80
|
+
__privateSet(this, _provider, void 0);
|
|
81
|
+
__privateSet(this, _ipfsGateway, IPFS_DEFAULT_GATEWAY_URL);
|
|
82
|
+
__privateSet(this, _chainId, initialChainId);
|
|
83
|
+
__privateMethod(this, _registerActionHandlers, registerActionHandlers_fn).call(this);
|
|
84
|
+
__privateMethod(this, _registerEventSubscriptions, registerEventSubscriptions_fn).call(this);
|
|
82
85
|
}
|
|
83
86
|
/**
|
|
84
87
|
* Sets a new provider.
|
|
85
88
|
*
|
|
86
|
-
*
|
|
87
|
-
*
|
|
88
|
-
* @property provider - Provider used to create a new underlying Web3 instance
|
|
89
|
+
* @param provider - Provider used to create a new underlying Web3 instance
|
|
89
90
|
*/
|
|
90
|
-
|
|
91
|
-
this
|
|
92
|
-
}
|
|
93
|
-
get provider() {
|
|
94
|
-
throw new Error("Property only used for setting");
|
|
91
|
+
setProvider(provider) {
|
|
92
|
+
__privateSet(this, _provider, provider);
|
|
95
93
|
}
|
|
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 Web3Provider(provider);
|
|
94
|
+
get ipfsGateway() {
|
|
95
|
+
return __privateGet(this, _ipfsGateway);
|
|
108
96
|
}
|
|
109
|
-
|
|
110
|
-
|
|
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;
|
|
97
|
+
get chainId() {
|
|
98
|
+
return __privateGet(this, _chainId);
|
|
117
99
|
}
|
|
118
100
|
/**
|
|
119
101
|
* Get a ERC20Standard instance using the relevant provider instance.
|
|
@@ -122,7 +104,7 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
122
104
|
* @returns ERC20Standard instance.
|
|
123
105
|
*/
|
|
124
106
|
getERC20Standard(networkClientId) {
|
|
125
|
-
const provider = this.
|
|
107
|
+
const provider = __privateMethod(this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
126
108
|
return new ERC20Standard(provider);
|
|
127
109
|
}
|
|
128
110
|
/**
|
|
@@ -132,7 +114,7 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
132
114
|
* @returns ERC721Standard instance.
|
|
133
115
|
*/
|
|
134
116
|
getERC721Standard(networkClientId) {
|
|
135
|
-
const provider = this.
|
|
117
|
+
const provider = __privateMethod(this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
136
118
|
return new ERC721Standard(provider);
|
|
137
119
|
}
|
|
138
120
|
/**
|
|
@@ -142,7 +124,7 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
142
124
|
* @returns ERC1155Standard instance.
|
|
143
125
|
*/
|
|
144
126
|
getERC1155Standard(networkClientId) {
|
|
145
|
-
const provider = this.
|
|
127
|
+
const provider = __privateMethod(this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
146
128
|
return new ERC1155Standard(provider);
|
|
147
129
|
}
|
|
148
130
|
/**
|
|
@@ -188,7 +170,7 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
188
170
|
* @param networkClientId - Network Client ID to fetch the provider with.
|
|
189
171
|
* @returns Promise resolving to token identifier for the 'index'th asset assigned to 'selectedAddress'.
|
|
190
172
|
*/
|
|
191
|
-
getERC721NftTokenId(address, selectedAddress, index, networkClientId) {
|
|
173
|
+
async getERC721NftTokenId(address, selectedAddress, index, networkClientId) {
|
|
192
174
|
const erc721Standard = this.getERC721Standard(networkClientId);
|
|
193
175
|
return erc721Standard.getNftTokenId(address, selectedAddress, index);
|
|
194
176
|
}
|
|
@@ -202,14 +184,13 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
202
184
|
* @returns Promise resolving to an object containing the token standard and a set of details which depend on which standard the token supports.
|
|
203
185
|
*/
|
|
204
186
|
async getTokenStandardAndDetails(tokenAddress, userAddress, tokenId, networkClientId) {
|
|
205
|
-
this.
|
|
206
|
-
const { ipfsGateway } = this.config;
|
|
187
|
+
__privateMethod(this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
207
188
|
try {
|
|
208
189
|
const erc721Standard = this.getERC721Standard(networkClientId);
|
|
209
190
|
return {
|
|
210
191
|
...await erc721Standard.getDetails(
|
|
211
192
|
tokenAddress,
|
|
212
|
-
|
|
193
|
+
__privateGet(this, _ipfsGateway),
|
|
213
194
|
tokenId
|
|
214
195
|
)
|
|
215
196
|
};
|
|
@@ -220,7 +201,7 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
220
201
|
return {
|
|
221
202
|
...await erc1155Standard.getDetails(
|
|
222
203
|
tokenAddress,
|
|
223
|
-
|
|
204
|
+
__privateGet(this, _ipfsGateway),
|
|
224
205
|
tokenId
|
|
225
206
|
)
|
|
226
207
|
};
|
|
@@ -337,9 +318,9 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
337
318
|
* @returns The list of non-zero token balances.
|
|
338
319
|
*/
|
|
339
320
|
async getBalancesInSingleCall(selectedAddress, tokensToDetect, networkClientId) {
|
|
340
|
-
const chainId = this.
|
|
341
|
-
const provider = this.
|
|
342
|
-
if (!(
|
|
321
|
+
const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, networkClientId);
|
|
322
|
+
const provider = __privateMethod(this, _getCorrectProvider, getCorrectProvider_fn).call(this, networkClientId);
|
|
323
|
+
if (!((id) => id in SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID)(chainId)) {
|
|
343
324
|
return {};
|
|
344
325
|
}
|
|
345
326
|
const contractAddress = SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID[chainId];
|
|
@@ -361,6 +342,82 @@ var AssetsContractController = class extends BaseControllerV1 {
|
|
|
361
342
|
return nonZeroBalances;
|
|
362
343
|
}
|
|
363
344
|
};
|
|
345
|
+
_provider = new WeakMap();
|
|
346
|
+
_ipfsGateway = new WeakMap();
|
|
347
|
+
_chainId = new WeakMap();
|
|
348
|
+
_registerActionHandlers = new WeakSet();
|
|
349
|
+
registerActionHandlers_fn = function() {
|
|
350
|
+
const methodsExcludedFromMessenger = [
|
|
351
|
+
"constructor",
|
|
352
|
+
"messagingSystem",
|
|
353
|
+
"setProvider",
|
|
354
|
+
"provider",
|
|
355
|
+
"ipfsGateway",
|
|
356
|
+
"chainId"
|
|
357
|
+
];
|
|
358
|
+
getKnownPropertyNames(Object.getPrototypeOf(this)).forEach(
|
|
359
|
+
(method) => {
|
|
360
|
+
if (((key) => !methodsExcludedFromMessenger.find((e) => e === key) && typeof this[key] === "function")(method)) {
|
|
361
|
+
this.messagingSystem.registerActionHandler(
|
|
362
|
+
`${name}:${method}`,
|
|
363
|
+
// TODO: Write a generic for-loop implementation that iterates over an input union type in tandem with the input array.
|
|
364
|
+
// @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
|
|
365
|
+
this[method].bind(this)
|
|
366
|
+
);
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
);
|
|
370
|
+
};
|
|
371
|
+
_registerEventSubscriptions = new WeakSet();
|
|
372
|
+
registerEventSubscriptions_fn = function() {
|
|
373
|
+
this.messagingSystem.subscribe(
|
|
374
|
+
`PreferencesController:stateChange`,
|
|
375
|
+
({ ipfsGateway }) => {
|
|
376
|
+
__privateSet(this, _ipfsGateway, ipfsGateway);
|
|
377
|
+
}
|
|
378
|
+
);
|
|
379
|
+
this.messagingSystem.subscribe(
|
|
380
|
+
`NetworkController:networkDidChange`,
|
|
381
|
+
({ selectedNetworkClientId }) => {
|
|
382
|
+
const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, selectedNetworkClientId);
|
|
383
|
+
if (__privateGet(this, _chainId) !== chainId) {
|
|
384
|
+
__privateSet(this, _chainId, chainId);
|
|
385
|
+
__privateSet(this, _provider, __privateMethod(this, _getCorrectProvider, getCorrectProvider_fn).call(this));
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
);
|
|
389
|
+
};
|
|
390
|
+
_getCorrectProvider = new WeakSet();
|
|
391
|
+
getCorrectProvider_fn = function(networkClientId) {
|
|
392
|
+
const provider = networkClientId ? this.messagingSystem.call(
|
|
393
|
+
`NetworkController:getNetworkClientById`,
|
|
394
|
+
networkClientId
|
|
395
|
+
).provider : this.messagingSystem.call("NetworkController:getSelectedNetworkClient")?.provider ?? __privateGet(this, _provider);
|
|
396
|
+
if (provider === void 0) {
|
|
397
|
+
throw new Error(MISSING_PROVIDER_ERROR);
|
|
398
|
+
}
|
|
399
|
+
return new Web3Provider(provider);
|
|
400
|
+
};
|
|
401
|
+
_getCorrectChainId = new WeakSet();
|
|
402
|
+
getCorrectChainId_fn = function(networkClientId) {
|
|
403
|
+
if (networkClientId) {
|
|
404
|
+
const networkClientConfiguration = this.messagingSystem.call(
|
|
405
|
+
"NetworkController:getNetworkConfigurationByNetworkClientId",
|
|
406
|
+
networkClientId
|
|
407
|
+
);
|
|
408
|
+
if (networkClientConfiguration) {
|
|
409
|
+
return networkClientConfiguration.chainId;
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
const { selectedNetworkClientId } = this.messagingSystem.call(
|
|
413
|
+
"NetworkController:getState"
|
|
414
|
+
);
|
|
415
|
+
const networkClient = this.messagingSystem.call(
|
|
416
|
+
"NetworkController:getNetworkClientById",
|
|
417
|
+
selectedNetworkClientId
|
|
418
|
+
);
|
|
419
|
+
return networkClient.configuration?.chainId ?? __privateGet(this, _chainId);
|
|
420
|
+
};
|
|
364
421
|
var AssetsContractController_default = AssetsContractController;
|
|
365
422
|
|
|
366
423
|
export {
|
|
@@ -369,4 +426,4 @@ export {
|
|
|
369
426
|
AssetsContractController,
|
|
370
427
|
AssetsContractController_default
|
|
371
428
|
};
|
|
372
|
-
//# sourceMappingURL=chunk-
|
|
429
|
+
//# sourceMappingURL=chunk-AZSIKIMK.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/AssetsContractController.ts"],"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 readonly name: typeof name = name;\n\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"],"mappings":";;;;;;;;;;;;;;;;;AAAA,SAAS,gBAAgB;AACzB,SAAS,oBAAoB;AAK7B,SAAS,gCAAgC;AAWzC,SAAS,6BAAuC;AAEhD,OAAO,mCAAmC;AAanC,IAAM,0CAA0C;AAAA,EACrD,oBAAwC,GACtC;AAAA,EACF,iBAAoC,GAClC;AAAA,EACF,qBAAwC,GACtC;AAAA,EACF,oBAAqC,GACnC;AAAA,EACF,0BAAuC,GACrC;AAAA,EACF,4BAA6C,GAC3C;AAAA,EACF,6BAA8C,GAC5C;AAAA,EACF,wBAAyC,GACvC;AAAA,EACF,qBAAyC,GACvC;AAAA,EACF,oBAAqC,GACnC;AAAA,EACF,qBAAuC,GACrC;AAAA,EACF,oBAAuC,GACrC;AAAA,EACF,oBAAqC,GACnC;AAAA,EACF,oBAAuC,GACrC;AAAA,EACF,oBAAuC,GACrC;AAAA,EACF,4BAA8C,GAC5C;AAAA,EACF,uBAAyC,GACvC;AAAA,EACF,wBAA0C,GACxC;AACJ;AAEO,IAAM,yBACX;AAeF,IAAM,OAAO;AAvFb;AA0MO,IAAM,2BAAN,MAA+B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBpC,YAAY;AAAA,IACV;AAAA,IACA,SAAS;AAAA,EACX,GAGG;AAWH;AAAA;AA4BA;AA6CA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAsBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAjIA,SAAS,OAAoB;AAI7B;AAEA;AAEA;AAgBE,SAAK,kBAAkB;AACvB,uBAAK,WAAY;AACjB,uBAAK,cAAe;AACpB,uBAAK,UAAW;AAEhB,0BAAK,oDAAL;AACA,0BAAK,4DAAL;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA0DA,YAAY,UAAgC;AAC1C,uBAAK,WAAY;AAAA,EACnB;AAAA,EAEA,IAAI,cAAc;AAChB,WAAO,mBAAK;AAAA,EACd;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,mBAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwDA,iBAAiB,iBAAkD;AACjE,UAAM,WAAW,sBAAK,4CAAL,WAAyB;AAC1C,WAAO,IAAI,cAAc,QAAQ;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,kBAAkB,iBAAmD;AACnE,UAAM,WAAW,sBAAK,4CAAL,WAAyB;AAC1C,WAAO,IAAI,eAAe,QAAQ;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,mBAAmB,iBAAoD;AACrE,UAAM,WAAW,sBAAK,4CAAL,WAAyB;AAC1C,WAAO,IAAI,gBAAgB,QAAQ;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAM,kBACJ,SACA,iBACA,iBACa;AACb,UAAM,gBAAgB,KAAK,iBAAiB,eAAe;AAC3D,WAAO,cAAc,aAAa,SAAS,eAAe;AAAA,EAC5D;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,sBACJ,SACA,iBACiB;AACjB,UAAM,gBAAgB,KAAK,iBAAiB,eAAe;AAC3D,WAAO,cAAc,iBAAiB,OAAO;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,kBACJ,SACA,iBACiB;AACjB,UAAM,gBAAgB,KAAK,iBAAiB,eAAe;AAC3D,WAAO,cAAc,aAAa,OAAO;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,MAAM,oBACJ,SACA,iBACA,OACA,iBACiB;AACjB,UAAM,iBAAiB,KAAK,kBAAkB,eAAe;AAC7D,WAAO,eAAe,cAAc,SAAS,iBAAiB,KAAK;AAAA,EACrE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,MAAM,2BACJ,cACA,aACA,SACA,iBAQC;AAED,0BAAK,4CAAL,WAAyB;AAGzB,QAAI;AACF,YAAM,iBAAiB,KAAK,kBAAkB,eAAe;AAC7D,aAAO;AAAA,QACL,GAAI,MAAM,eAAe;AAAA,UACvB;AAAA,UACA,mBAAK;AAAA,UACL;AAAA,QACF;AAAA,MACF;AAAA,IACF,QAAQ;AAAA,IAER;AAGA,QAAI;AACF,YAAM,kBAAkB,KAAK,mBAAmB,eAAe;AAC/D,aAAO;AAAA,QACL,GAAI,MAAM,gBAAgB;AAAA,UACxB;AAAA,UACA,mBAAK;AAAA,UACL;AAAA,QACF;AAAA,MACF;AAAA,IACF,QAAQ;AAAA,IAER;AAGA,QAAI;AACF,YAAM,gBAAgB,KAAK,iBAAiB,eAAe;AAC3D,aAAO;AAAA,QACL,GAAI,MAAM,cAAc,WAAW,cAAc,WAAW;AAAA,MAC9D;AAAA,IACF,QAAQ;AAAA,IAER;AAEA,UAAM,IAAI,MAAM,uCAAuC;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAM,kBACJ,SACA,SACA,iBACiB;AACjB,UAAM,iBAAiB,KAAK,kBAAkB,eAAe;AAC7D,WAAO,eAAe,YAAY,SAAS,OAAO;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,mBACJ,SACA,iBACiB;AACjB,UAAM,iBAAiB,KAAK,kBAAkB,eAAe;AAC7D,WAAO,eAAe,aAAa,OAAO;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,qBACJ,SACA,iBACiB;AACjB,UAAM,iBAAiB,KAAK,kBAAkB,eAAe;AAC7D,WAAO,eAAe,eAAe,OAAO;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAM,iBACJ,SACA,SACA,iBACiB;AACjB,UAAM,iBAAiB,KAAK,kBAAkB,eAAe;AAC7D,WAAO,eAAe,WAAW,SAAS,OAAO;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAM,mBACJ,SACA,SACA,iBACiB;AACjB,UAAM,kBAAkB,KAAK,mBAAmB,eAAe;AAC/D,WAAO,gBAAgB,YAAY,SAAS,OAAO;AAAA,EACrD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,MAAM,oBACJ,aACA,YACA,OACA,iBACa;AACb,UAAM,kBAAkB,KAAK,mBAAmB,eAAe;AAC/D,WAAO,gBAAgB,aAAa,YAAY,aAAa,KAAK;AAAA,EACpE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,MAAM,sBACJ,YACA,eACA,kBACA,OACA,KACA,iBACe;AACf,UAAM,kBAAkB,KAAK,mBAAmB,eAAe;AAC/D,WAAO,gBAAgB;AAAA,MACrB;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWA,MAAM,wBACJ,iBACA,gBACA,iBACA;AACA,UAAM,UAAU,sBAAK,0CAAL,WAAwB;AACxC,UAAM,WAAW,sBAAK,4CAAL,WAAyB;AAC1C,QACE,EAAE,CAAC,OACD,MAAM,yCAAyC,OAAO,GACxD;AAEA,aAAO,CAAC;AAAA,IACV;AACA,UAAM,kBAAkB,wCAAwC,OAAO;AAEvE,UAAM,WAAW,IAAI;AAAA,MACnB;AAAA,MACA;AAAA,MACA;AAAA,IACF;AACA,UAAM,SAAS,MAAM,SAAS,SAAS,CAAC,eAAe,GAAG,cAAc;AACxE,UAAM,kBAA8B,CAAC;AAErC,QAAI,OAAO,SAAS,GAAG;AACrB,qBAAe,QAAQ,CAAC,cAAc,UAAU;AAC9C,cAAM,UAAc,OAAO,KAAK;AAEhC,YAAI,OAAO,OAAO,MAAM,KAAK;AAC3B,0BAAgB,YAAY,IAAI;AAAA,QAClC;AAAA,MACF,CAAC;AAAA,IACH;AACA,WAAO;AAAA,EACT;AACF;AAneE;AAEA;AAEA;AA0BA;AAAA,4BAAuB,WAAG;AACxB,QAAM,+BAA+B;AAAA,IACnC;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAEA,wBAAkC,OAAO,eAAe,IAAI,CAAC,EAAE;AAAA,IAC7D,CAAC,WAAW;AACV,WACG,CAAC,QACA,CAAC,6BAA6B,KAAK,CAAC,MAAM,MAAM,GAAG,KACnD,OAAO,KAAK,GAAG,MAAM,YAAY,MAAM,GACzC;AACA,aAAK,gBAAgB;AAAA,UACnB,GAAG,IAAI,IAAI,MAAM;AAAA;AAAA;AAAA,UAGjB,KAAK,MAAM,EAAE,KAAK,IAAI;AAAA,QACxB;AAAA,MACF;AAAA,IACF;AAAA,EACF;AACF;AAEA;AAAA,gCAA2B,WAAG;AAC5B,OAAK,gBAAgB;AAAA,IACnB;AAAA,IACA,CAAC,EAAE,YAAY,MAAM;AACnB,yBAAK,cAAe;AAAA,IACtB;AAAA,EACF;AAEA,OAAK,gBAAgB;AAAA,IACnB;AAAA,IACA,CAAC,EAAE,wBAAwB,MAAM;AAC/B,YAAM,UAAU,sBAAK,0CAAL,WAAwB;AAExC,UAAI,mBAAK,cAAa,SAAS;AAC7B,2BAAK,UAAW;AAEhB,2BAAK,WAAY,sBAAK,4CAAL;AAAA,MACnB;AAAA,IACF;AAAA,EACF;AACF;AAyBA;AAAA,wBAAmB,SAAC,iBAAiD;AACnE,QAAM,WAAW,kBACb,KAAK,gBAAgB;AAAA,IACnB;AAAA,IACA;AAAA,EACF,EAAE,WACF,KAAK,gBAAgB,KAAK,4CAA4C,GAClE,YAAY,mBAAK;AAEzB,MAAI,aAAa,QAAW;AAC1B,UAAM,IAAI,MAAM,sBAAsB;AAAA,EACxC;AAEA,SAAO,IAAI,aAAa,QAAQ;AAClC;AAQA;AAAA,uBAAkB,SAAC,iBAAwC;AACzD,MAAI,iBAAiB;AACnB,UAAM,6BAA6B,KAAK,gBAAgB;AAAA,MACtD;AAAA,MACA;AAAA,IACF;AACA,QAAI,4BAA4B;AAC9B,aAAO,2BAA2B;AAAA,IACpC;AAAA,EACF;AACA,QAAM,EAAE,wBAAwB,IAAI,KAAK,gBAAgB;AAAA,IACvD;AAAA,EACF;AACA,QAAM,gBAAgB,KAAK,gBAAgB;AAAA,IACzC;AAAA,IACA;AAAA,EACF;AACA,SAAO,cAAc,eAAe,WAAW,mBAAK;AACtD;AAsVF,IAAO,mCAAQ;","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
|
|
|
6
6
|
|
|
@@ -150,7 +150,7 @@ var NftDetectionController = class extends _basecontroller.BaseController {
|
|
|
150
150
|
return acc;
|
|
151
151
|
}, []);
|
|
152
152
|
if (collections.length !== 0) {
|
|
153
|
-
const collectionResponse = await
|
|
153
|
+
const collectionResponse = await _chunkMZI3SDQNjs.reduceInBatchesSerially.call(void 0, {
|
|
154
154
|
values: collections,
|
|
155
155
|
batchSize: MAX_GET_COLLECTION_BATCH_SIZE,
|
|
156
156
|
eachBatch: async (allResponses, batch) => {
|
|
@@ -297,4 +297,4 @@ var NftDetectionController_default = NftDetectionController;
|
|
|
297
297
|
|
|
298
298
|
|
|
299
299
|
exports.BlockaidResultType = BlockaidResultType; exports.MAX_GET_COLLECTION_BATCH_SIZE = MAX_GET_COLLECTION_BATCH_SIZE; exports.NftDetectionController = NftDetectionController; exports.NftDetectionController_default = NftDetectionController_default;
|
|
300
|
-
//# sourceMappingURL=chunk-
|
|
300
|
+
//# sourceMappingURL=chunk-BBCZM5P4.js.map
|
|
@@ -5,7 +5,6 @@ import {
|
|
|
5
5
|
} from "@metamask/controller-utils";
|
|
6
6
|
import { remove0x } from "@metamask/utils";
|
|
7
7
|
import BN from "bn.js";
|
|
8
|
-
import { CID } from "multiformats/cid";
|
|
9
8
|
var TOKEN_PRICES_BATCH_SIZE = 30;
|
|
10
9
|
function compareNftMetadata(newNftMetadata, nft) {
|
|
11
10
|
const keys = [
|
|
@@ -107,20 +106,21 @@ function removeIpfsProtocolPrefix(ipfsUrl) {
|
|
|
107
106
|
}
|
|
108
107
|
throw new Error("this method should not be used with non ipfs urls");
|
|
109
108
|
}
|
|
110
|
-
function getIpfsCIDv1AndPath(ipfsUrl) {
|
|
109
|
+
async function getIpfsCIDv1AndPath(ipfsUrl) {
|
|
111
110
|
const url = removeIpfsProtocolPrefix(ipfsUrl);
|
|
112
111
|
const index = url.indexOf("/");
|
|
113
112
|
const cid = index !== -1 ? url.substring(0, index) : url;
|
|
114
113
|
const path = index !== -1 ? url.substring(index) : void 0;
|
|
114
|
+
const { CID } = await import("multiformats");
|
|
115
115
|
return {
|
|
116
116
|
cid: CID.parse(cid).toV1().toString(),
|
|
117
117
|
path
|
|
118
118
|
};
|
|
119
119
|
}
|
|
120
|
-
function getFormattedIpfsUrl(ipfsGateway, ipfsUrl, subdomainSupported) {
|
|
120
|
+
async function getFormattedIpfsUrl(ipfsGateway, ipfsUrl, subdomainSupported) {
|
|
121
121
|
const { host, protocol, origin } = new URL(addUrlProtocolPrefix(ipfsGateway));
|
|
122
122
|
if (subdomainSupported) {
|
|
123
|
-
const { cid, path } = getIpfsCIDv1AndPath(ipfsUrl);
|
|
123
|
+
const { cid, path } = await getIpfsCIDv1AndPath(ipfsUrl);
|
|
124
124
|
return `${protocol}//${cid}.ipfs.${host}${path ?? ""}`;
|
|
125
125
|
}
|
|
126
126
|
const cidAndPath = removeIpfsProtocolPrefix(ipfsUrl);
|
|
@@ -212,4 +212,4 @@ export {
|
|
|
212
212
|
reduceInBatchesSerially,
|
|
213
213
|
fetchTokenContractExchangeRates
|
|
214
214
|
};
|
|
215
|
-
//# sourceMappingURL=chunk-
|
|
215
|
+
//# sourceMappingURL=chunk-BZEAPSD5.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/assetsUtil.ts"],"sourcesContent":["import type { BigNumber } from '@ethersproject/bignumber';\nimport {\n convertHexToDecimal,\n toChecksumHexAddress,\n} from '@metamask/controller-utils';\nimport type { Hex } from '@metamask/utils';\nimport { remove0x } from '@metamask/utils';\nimport BN from 'bn.js';\n\nimport type { Nft, NftMetadata } from './NftController';\nimport type { AbstractTokenPricesService } from './token-prices-service';\nimport { type ContractExchangeRates } from './TokenRatesController';\n\n/**\n * The maximum number of token addresses that should be sent to the Price API in\n * a single request.\n */\nexport const TOKEN_PRICES_BATCH_SIZE = 30;\n\n/**\n * Compares nft metadata entries to any nft entry.\n * We need this method when comparing a new fetched nft metadata, in case a entry changed to a defined value,\n * there's a need to update the nft in state.\n *\n * @param newNftMetadata - Nft metadata object.\n * @param nft - Nft object to compare with.\n * @returns Whether there are differences.\n */\nexport function compareNftMetadata(newNftMetadata: NftMetadata, nft: Nft) {\n const keys: (keyof NftMetadata)[] = [\n 'image',\n 'backgroundColor',\n 'imagePreview',\n 'imageThumbnail',\n 'imageOriginal',\n 'animation',\n 'animationOriginal',\n 'externalLink',\n 'tokenURI',\n ];\n const differentValues = keys.reduce((value, key) => {\n if (newNftMetadata[key] && newNftMetadata[key] !== nft[key]) {\n return value + 1;\n }\n return value;\n }, 0);\n return differentValues > 0;\n}\n\n/**\n * Checks whether the existing nft object has all the keys of the new incoming nft metadata object\n * @param newNftMetadata - New nft metadata object\n * @param nft - Existing nft object to compare with\n * @returns Whether the existing nft object has all the new keys from the new Nft metadata object\n */\nexport function hasNewCollectionFields(\n newNftMetadata: NftMetadata,\n nft: Nft,\n): boolean {\n const keysNewNftMetadata = Object.keys(newNftMetadata.collection ?? {});\n const keysExistingNft = new Set(Object.keys(nft.collection ?? {}));\n\n return keysNewNftMetadata.some((key) => !keysExistingNft.has(key));\n}\n\nconst aggregatorNameByKey: Record<string, string> = {\n aave: 'Aave',\n bancor: 'Bancor',\n cmc: 'CMC',\n cryptocom: 'Crypto.com',\n coinGecko: 'CoinGecko',\n oneInch: '1inch',\n paraswap: 'Paraswap',\n pmm: 'PMM',\n zapper: 'Zapper',\n zerion: 'Zerion',\n zeroEx: '0x',\n synthetix: 'Synthetix',\n yearn: 'Yearn',\n apeswap: 'ApeSwap',\n binanceDex: 'BinanceDex',\n pancakeTop100: 'PancakeTop100',\n pancakeExtended: 'PancakeExtended',\n balancer: 'Balancer',\n quickswap: 'QuickSwap',\n matcha: 'Matcha',\n pangolinDex: 'PangolinDex',\n pangolinDexStableCoin: 'PangolinDexStableCoin',\n pangolinDexAvaxBridge: 'PangolinDexAvaxBridge',\n traderJoe: 'TraderJoe',\n airswapLight: 'AirswapLight',\n kleros: 'Kleros',\n};\n\n/**\n * Formats aggregator names to presentable format.\n *\n * @param aggregators - List of token list names in camelcase.\n * @returns Formatted aggregator names.\n */\nexport const formatAggregatorNames = (aggregators: string[]) => {\n return aggregators.map(\n (key) =>\n aggregatorNameByKey[key] ||\n `${key[0].toUpperCase()}${key.substring(1, key.length)}`,\n );\n};\n\n/**\n * Format token list assets to use image proxy from Codefi.\n *\n * @param params - Object that contains chainID and tokenAddress.\n * @param params.chainId - ChainID of network in 0x-prefixed hexadecimal format.\n * @param params.tokenAddress - Address of token in mixed or lowercase.\n * @returns Formatted image url\n */\nexport const formatIconUrlWithProxy = ({\n chainId,\n tokenAddress,\n}: {\n chainId: Hex;\n tokenAddress: string;\n}) => {\n const chainIdDecimal = convertHexToDecimal(chainId).toString();\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n return `https://static.cx.metamask.io/api/v1/tokenIcons/${chainIdDecimal}/${tokenAddress.toLowerCase()}.png`;\n};\n\n/**\n * Networks where token detection is supported - Values are in hex format\n */\nexport enum SupportedTokenDetectionNetworks {\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n mainnet = '0x1', // decimal: 1\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n bsc = '0x38', // decimal: 56\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n polygon = '0x89', // decimal: 137\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n avax = '0xa86a', // decimal: 43114\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n aurora = '0x4e454152', // decimal: 1313161554\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n linea_goerli = '0xe704', // decimal: 59140\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n linea_mainnet = '0xe708', // decimal: 59144\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n arbitrum = '0xa4b1', // decimal: 42161\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n optimism = '0xa', // decimal: 10\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n base = '0x2105', // decimal: 8453\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n zksync = '0x144', // decimal: 324\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n cronos = '0x19', // decimal: 25\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n celo = '0xa4ec', // decimal: 42220\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n gnosis = '0x64', // decimal: 100\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n fantom = '0xfa', // decimal: 250\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n polygon_zkevm = '0x44d', // decimal: 1101\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n moonbeam = '0x504', // decimal: 1284\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n moonriver = '0x505', // decimal: 1285\n}\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 function isTokenDetectionSupportedForNetwork(chainId: Hex): boolean {\n return Object.values<Hex>(SupportedTokenDetectionNetworks).includes(chainId);\n}\n\n/**\n * Check if token list polling is enabled for a given network.\n * Currently this method is used to support e2e testing for consumers of this package.\n *\n * @param chainId - ChainID of network\n * @returns Whether the current network supports tokenlists\n */\nexport function isTokenListSupportedForNetwork(chainId: Hex): boolean {\n return isTokenDetectionSupportedForNetwork(chainId);\n}\n\n/**\n * Removes IPFS protocol prefix from input string.\n *\n * @param ipfsUrl - An IPFS url (e.g. ipfs://{content id})\n * @returns IPFS content identifier and (possibly) path in a string\n * @throws Will throw if the url passed is not IPFS.\n */\nexport function removeIpfsProtocolPrefix(ipfsUrl: string) {\n if (ipfsUrl.startsWith('ipfs://ipfs/')) {\n return ipfsUrl.replace('ipfs://ipfs/', '');\n } else if (ipfsUrl.startsWith('ipfs://')) {\n return ipfsUrl.replace('ipfs://', '');\n }\n // this method should not be used with non-ipfs urls (i.e. startsWith('ipfs://') === true)\n throw new Error('this method should not be used with non ipfs urls');\n}\n\n/**\n * Extracts content identifier and path from an input string.\n *\n * @param ipfsUrl - An IPFS URL minus the IPFS protocol prefix\n * @returns IFPS content identifier (cid) and sub path as string.\n * @throws Will throw if the url passed is not ipfs.\n */\nexport async function getIpfsCIDv1AndPath(ipfsUrl: string): Promise<{\n cid: string;\n path?: string;\n}> {\n const url = removeIpfsProtocolPrefix(ipfsUrl);\n\n // check if there is a path\n // (CID is everything preceding first forward slash, path is everything after)\n const index = url.indexOf('/');\n const cid = index !== -1 ? url.substring(0, index) : url;\n const path = index !== -1 ? url.substring(index) : undefined;\n\n const { CID } = await import('multiformats');\n // We want to ensure that the CID is v1 (https://docs.ipfs.io/concepts/content-addressing/#identifier-formats)\n // because most cid v0s appear to be incompatible with IPFS subdomains\n return {\n cid: CID.parse(cid).toV1().toString(),\n path,\n };\n}\n\n/**\n * Formats URL correctly for use retrieving assets hosted on IPFS.\n *\n * @param ipfsGateway - The users preferred IPFS gateway (full URL or just host).\n * @param ipfsUrl - The IFPS URL pointed at the asset.\n * @param subdomainSupported - Boolean indicating whether the URL should be formatted with subdomains or not.\n * @returns A formatted URL, with the user's preferred IPFS gateway and format (subdomain or not), pointing to an asset hosted on IPFS.\n */\nexport async function getFormattedIpfsUrl(\n ipfsGateway: string,\n ipfsUrl: string,\n subdomainSupported: boolean,\n): Promise<string> {\n const { host, protocol, origin } = new URL(addUrlProtocolPrefix(ipfsGateway));\n if (subdomainSupported) {\n const { cid, path } = await getIpfsCIDv1AndPath(ipfsUrl);\n return `${protocol}//${cid}.ipfs.${host}${path ?? ''}`;\n }\n const cidAndPath = removeIpfsProtocolPrefix(ipfsUrl);\n return `${origin}/ipfs/${cidAndPath}`;\n}\n\n/**\n * Adds URL protocol prefix to input URL string if missing.\n *\n * @param urlString - An IPFS URL.\n * @returns A URL with a https:// prepended.\n */\nexport function addUrlProtocolPrefix(urlString: string): string {\n if (!urlString.match(/(^http:\\/\\/)|(^https:\\/\\/)/u)) {\n return `https://${urlString}`;\n }\n return urlString;\n}\n\n/**\n * Converts an Ethers BigNumber to a BN.\n *\n * @param bigNumber - An Ethers BigNumber instance.\n * @returns A BN object.\n */\nexport function ethersBigNumberToBN(bigNumber: BigNumber): BN {\n return new BN(remove0x(bigNumber.toHexString()), 'hex');\n}\n\n/**\n * Partitions a list of values into groups that are at most `batchSize` in\n * length.\n *\n * @param values - The list of values.\n * @param args - The remaining arguments.\n * @param args.batchSize - The desired maximum number of values per batch.\n * @returns The list of batches.\n */\nexport function divideIntoBatches<Value>(\n values: Value[],\n { batchSize }: { batchSize: number },\n): Value[][] {\n const batches = [];\n for (let i = 0; i < values.length; i += batchSize) {\n batches.push(values.slice(i, i + batchSize));\n }\n return batches;\n}\n\n/**\n * Constructs an object from processing batches of the given values\n * sequentially.\n *\n * @param args - The arguments to this function.\n * @param args.values - A list of values to iterate over.\n * @param args.batchSize - The maximum number of values in each batch.\n * @param args.eachBatch - A function to call for each batch. This function is\n * similar to the function that `Array.prototype.reduce` takes, in that it\n * receives the object that is being built, each batch in the list of batches\n * and the index, and should return an updated version of the object.\n * @param args.initialResult - The initial value of the final data structure,\n * i.e., the value that will be fed into the first call of `eachBatch`.\n * @returns The built object.\n */\nexport async function reduceInBatchesSerially<\n Value,\n Result extends Record<PropertyKey, unknown>,\n>({\n values,\n batchSize,\n eachBatch,\n initialResult,\n}: {\n values: Value[];\n batchSize: number;\n eachBatch: (\n workingResult: Partial<Result>,\n batch: Value[],\n index: number,\n ) => Partial<Result> | Promise<Partial<Result>>;\n initialResult: Partial<Result>;\n}): Promise<Result> {\n const batches = divideIntoBatches(values, { batchSize });\n let workingResult = initialResult;\n for (const [index, batch] of batches.entries()) {\n workingResult = await eachBatch(workingResult, batch, index);\n }\n // There's no way around this — we have to assume that in the end, the result\n // matches the intended type.\n const finalResult = workingResult as Result;\n return finalResult;\n}\n\n/**\n * Retrieves token prices for a set of contract addresses in a specific currency and chainId.\n *\n * @param args - The arguments to function.\n * @param args.tokenPricesService - An object in charge of retrieving token prices.\n * @param args.nativeCurrency - The native currency to request price in.\n * @param args.tokenAddresses - The list of contract addresses.\n * @param args.chainId - The chainId of the tokens.\n * @returns The prices for the requested tokens.\n */\nexport async function fetchTokenContractExchangeRates({\n tokenPricesService,\n nativeCurrency,\n tokenAddresses,\n chainId,\n}: {\n tokenPricesService: AbstractTokenPricesService;\n nativeCurrency: string;\n tokenAddresses: Hex[];\n chainId: Hex;\n}): Promise<ContractExchangeRates> {\n const isChainIdSupported =\n tokenPricesService.validateChainIdSupported(chainId);\n const isCurrencySupported =\n tokenPricesService.validateCurrencySupported(nativeCurrency);\n\n if (!isChainIdSupported || !isCurrencySupported) {\n return {};\n }\n\n const tokenPricesByTokenAddress = await reduceInBatchesSerially<\n Hex,\n Awaited<ReturnType<AbstractTokenPricesService['fetchTokenPrices']>>\n >({\n values: [...tokenAddresses].sort(),\n batchSize: TOKEN_PRICES_BATCH_SIZE,\n eachBatch: async (allTokenPricesByTokenAddress, batch) => {\n const tokenPricesByTokenAddressForBatch =\n await tokenPricesService.fetchTokenPrices({\n tokenAddresses: batch,\n chainId,\n currency: nativeCurrency,\n });\n\n return {\n ...allTokenPricesByTokenAddress,\n ...tokenPricesByTokenAddressForBatch,\n };\n },\n initialResult: {},\n });\n\n return Object.entries(tokenPricesByTokenAddress).reduce(\n (obj, [tokenAddress, tokenPrice]) => {\n return {\n ...obj,\n [toChecksumHexAddress(tokenAddress)]: tokenPrice?.price,\n };\n },\n {},\n );\n}\n"],"mappings":"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","names":["SupportedTokenDetectionNetworks"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
reduceInBatchesSerially
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-BZEAPSD5.mjs";
|
|
4
4
|
import {
|
|
5
5
|
__privateAdd,
|
|
6
6
|
__privateGet,
|
|
@@ -297,4 +297,4 @@ export {
|
|
|
297
297
|
NftDetectionController,
|
|
298
298
|
NftDetectionController_default
|
|
299
299
|
};
|
|
300
|
-
//# sourceMappingURL=chunk-
|
|
300
|
+
//# sourceMappingURL=chunk-C7LNCQXM.mjs.map
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
// src/crypto-compare-service/crypto-compare.ts
|
|
2
2
|
import { handleFetch } from "@metamask/controller-utils";
|
|
3
|
-
var nativeSymbolOverrides = /* @__PURE__ */ new Map([
|
|
3
|
+
var nativeSymbolOverrides = /* @__PURE__ */ new Map([
|
|
4
|
+
["MNT", "MANTLE"],
|
|
5
|
+
["OMNI", "OMNINET"]
|
|
6
|
+
]);
|
|
4
7
|
var CRYPTO_COMPARE_DOMAIN = "https://min-api.cryptocompare.com";
|
|
5
8
|
function getPricingURL(currentCurrency, nativeCurrency, includeUSDRate) {
|
|
6
9
|
nativeCurrency = nativeCurrency.toUpperCase();
|
|
@@ -65,4 +68,4 @@ export {
|
|
|
65
68
|
fetchExchangeRate,
|
|
66
69
|
fetchMultiExchangeRate
|
|
67
70
|
};
|
|
68
|
-
//# sourceMappingURL=chunk-
|
|
71
|
+
//# sourceMappingURL=chunk-FWKV5FGP.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/crypto-compare-service/crypto-compare.ts"],"sourcesContent":["import { handleFetch } from '@metamask/controller-utils';\n\n/**\n * A map from native currency symbol to CryptoCompare identifier.\n * This is only needed when the values don't match.\n */\nconst nativeSymbolOverrides = new Map([\n ['MNT', 'MANTLE'],\n ['OMNI', 'OMNINET'],\n]);\n\nconst CRYPTO_COMPARE_DOMAIN = 'https://min-api.cryptocompare.com';\n\n/**\n * Get the CryptoCompare API URL for getting the conversion rate from the given native currency to\n * the given currency. Optionally, the conversion rate from the native currency to USD can also be\n * included in the response.\n *\n * @param currentCurrency - The currency to get a conversion rate for.\n * @param nativeCurrency - The native currency to convert from.\n * @param includeUSDRate - Whether or not the native currency to USD conversion rate should be\n * included in the response as well.\n * @returns The API URL for getting the conversion rate.\n */\nfunction getPricingURL(\n currentCurrency: string,\n nativeCurrency: string,\n includeUSDRate?: boolean,\n) {\n nativeCurrency = nativeCurrency.toUpperCase();\n const fsym = nativeSymbolOverrides.get(nativeCurrency) ?? nativeCurrency;\n return (\n `${CRYPTO_COMPARE_DOMAIN}/data/price?fsym=` +\n `${fsym}&tsyms=${currentCurrency.toUpperCase()}` +\n `${includeUSDRate && currentCurrency.toUpperCase() !== 'USD' ? ',USD' : ''}`\n );\n}\n\n/**\n * Get the CryptoCompare API URL for getting the conversion rate from a given array of native currencies\n * to the given currency. Optionally, the conversion rate from the native currency to USD can also be\n * included in the response.\n *\n * @param fsyms - The native currencies to get conversion rates for.\n * @param tsyms - The currency to convert to.\n * @param includeUSDRate - Whether or not the native currency to USD conversion rate should be included.\n * @returns The API URL for getting the conversion rates.\n */\nfunction getMultiPricingURL(\n fsyms: string,\n tsyms: string,\n includeUSDRate = false,\n) {\n const updatedTsyms =\n includeUSDRate && !tsyms.includes('USD') ? `${tsyms},USD` : tsyms;\n\n const params = new URLSearchParams();\n params.append('fsyms', fsyms);\n params.append('tsyms', updatedTsyms);\n\n const url = new URL(`${CRYPTO_COMPARE_DOMAIN}/data/pricemulti`);\n url.search = params.toString();\n\n return url.toString();\n}\n\n/**\n * Handles an error response from the CryptoCompare API.\n * Expected error response format\n * { Response: \"Error\", Message: \"...\", HasWarning: false }\n *\n * @param json - The JSON response from the CryptoCompare API.\n * @param json.Response - The response status.\n * @param json.Message - The error message.\n */\n// TODO: Either fix this lint violation or explain why it's necessary to ignore.\n// eslint-disable-next-line @typescript-eslint/naming-convention\nfunction handleErrorResponse(json: { Response?: string; Message?: string }) {\n if (json.Response === 'Error') {\n throw new Error(json.Message);\n }\n}\n\n/**\n * Fetches the exchange rate for a given currency.\n *\n * @param currency - ISO 4217 currency code.\n * @param nativeCurrency - Symbol for base asset.\n * @param includeUSDRate - Whether to add the USD rate to the fetch.\n * @returns Promise resolving to exchange rate for given currency.\n */\nexport async function fetchExchangeRate(\n currency: string,\n nativeCurrency: string,\n includeUSDRate?: boolean,\n): Promise<{\n conversionRate: number;\n usdConversionRate: number;\n}> {\n const json = await handleFetch(\n getPricingURL(currency, nativeCurrency, includeUSDRate),\n );\n\n handleErrorResponse(json);\n const conversionRate = Number(json[currency.toUpperCase()]);\n\n const usdConversionRate = Number(json.USD);\n if (!Number.isFinite(conversionRate)) {\n throw new Error(\n `Invalid response for ${currency.toUpperCase()}: ${\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n json[currency.toUpperCase()]\n }`,\n );\n }\n\n if (includeUSDRate && !Number.isFinite(usdConversionRate)) {\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new Error(`Invalid response for usdConversionRate: ${json.USD}`);\n }\n\n return {\n conversionRate,\n usdConversionRate,\n };\n}\n\n/**\n * Fetches the exchange rates for multiple currencies.\n *\n * @param fiatCurrency - The currency of the rates (ISO 4217).\n * @param cryptocurrencies - The cryptocurrencies to get conversion rates for. Min length: 1. Max length: 300.\n * @param includeUSDRate - Whether to add the USD rate to the fetch.\n * @returns Promise resolving to exchange rates for given currencies.\n */\nexport async function fetchMultiExchangeRate(\n fiatCurrency: string,\n cryptocurrencies: string[],\n includeUSDRate: boolean,\n): Promise<Record<string, Record<string, string>>> {\n const url = getMultiPricingURL(\n Object.values(cryptocurrencies).join(','),\n fiatCurrency,\n includeUSDRate,\n );\n const response = await handleFetch(url);\n handleErrorResponse(response);\n\n const rates: Record<string, Record<string, string>> = {};\n for (const [cryptocurrency, values] of Object.entries(response) as [\n string,\n Record<string, string>,\n ][]) {\n rates[cryptocurrency.toLowerCase()] = {\n [fiatCurrency.toLowerCase()]: values[fiatCurrency.toUpperCase()],\n ...(includeUSDRate && { usd: values.USD }),\n };\n }\n\n return rates;\n}\n"],"mappings":";AAAA,SAAS,mBAAmB;AAM5B,IAAM,wBAAwB,oBAAI,IAAI;AAAA,EACpC,CAAC,OAAO,QAAQ;AAAA,EAChB,CAAC,QAAQ,SAAS;AACpB,CAAC;AAED,IAAM,wBAAwB;AAa9B,SAAS,cACP,iBACA,gBACA,gBACA;AACA,mBAAiB,eAAe,YAAY;AAC5C,QAAM,OAAO,sBAAsB,IAAI,cAAc,KAAK;AAC1D,SACE,GAAG,qBAAqB,oBACrB,IAAI,UAAU,gBAAgB,YAAY,CAAC,GAC3C,kBAAkB,gBAAgB,YAAY,MAAM,QAAQ,SAAS,EAAE;AAE9E;AAYA,SAAS,mBACP,OACA,OACA,iBAAiB,OACjB;AACA,QAAM,eACJ,kBAAkB,CAAC,MAAM,SAAS,KAAK,IAAI,GAAG,KAAK,SAAS;AAE9D,QAAM,SAAS,IAAI,gBAAgB;AACnC,SAAO,OAAO,SAAS,KAAK;AAC5B,SAAO,OAAO,SAAS,YAAY;AAEnC,QAAM,MAAM,IAAI,IAAI,GAAG,qBAAqB,kBAAkB;AAC9D,MAAI,SAAS,OAAO,SAAS;AAE7B,SAAO,IAAI,SAAS;AACtB;AAaA,SAAS,oBAAoB,MAA+C;AAC1E,MAAI,KAAK,aAAa,SAAS;AAC7B,UAAM,IAAI,MAAM,KAAK,OAAO;AAAA,EAC9B;AACF;AAUA,eAAsB,kBACpB,UACA,gBACA,gBAIC;AACD,QAAM,OAAO,MAAM;AAAA,IACjB,cAAc,UAAU,gBAAgB,cAAc;AAAA,EACxD;AAEA,sBAAoB,IAAI;AACxB,QAAM,iBAAiB,OAAO,KAAK,SAAS,YAAY,CAAC,CAAC;AAE1D,QAAM,oBAAoB,OAAO,KAAK,GAAG;AACzC,MAAI,CAAC,OAAO,SAAS,cAAc,GAAG;AACpC,UAAM,IAAI;AAAA,MACR,wBAAwB,SAAS,YAAY,CAAC;AAAA;AAAA,MAG5C,KAAK,SAAS,YAAY,CAAC,CAC7B;AAAA,IACF;AAAA,EACF;AAEA,MAAI,kBAAkB,CAAC,OAAO,SAAS,iBAAiB,GAAG;AAGzD,UAAM,IAAI,MAAM,2CAA2C,KAAK,GAAG,EAAE;AAAA,EACvE;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,EACF;AACF;AAUA,eAAsB,uBACpB,cACA,kBACA,gBACiD;AACjD,QAAM,MAAM;AAAA,IACV,OAAO,OAAO,gBAAgB,EAAE,KAAK,GAAG;AAAA,IACxC;AAAA,IACA;AAAA,EACF;AACA,QAAM,WAAW,MAAM,YAAY,GAAG;AACtC,sBAAoB,QAAQ;AAE5B,QAAM,QAAgD,CAAC;AACvD,aAAW,CAAC,gBAAgB,MAAM,KAAK,OAAO,QAAQ,QAAQ,GAGzD;AACH,UAAM,eAAe,YAAY,CAAC,IAAI;AAAA,MACpC,CAAC,aAAa,YAAY,CAAC,GAAG,OAAO,aAAa,YAAY,CAAC;AAAA,MAC/D,GAAI,kBAAkB,EAAE,KAAK,OAAO,IAAI;AAAA,IAC1C;AAAA,EACF;AAEA,SAAO;AACT;","names":[]}
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/crypto-compare-service/crypto-compare.ts
|
|
2
2
|
var _controllerutils = require('@metamask/controller-utils');
|
|
3
|
-
var nativeSymbolOverrides = /* @__PURE__ */ new Map([
|
|
3
|
+
var nativeSymbolOverrides = /* @__PURE__ */ new Map([
|
|
4
|
+
["MNT", "MANTLE"],
|
|
5
|
+
["OMNI", "OMNINET"]
|
|
6
|
+
]);
|
|
4
7
|
var CRYPTO_COMPARE_DOMAIN = "https://min-api.cryptocompare.com";
|
|
5
8
|
function getPricingURL(currentCurrency, nativeCurrency, includeUSDRate) {
|
|
6
9
|
nativeCurrency = nativeCurrency.toUpperCase();
|
|
@@ -65,4 +68,4 @@ async function fetchMultiExchangeRate(fiatCurrency, cryptocurrencies, includeUSD
|
|
|
65
68
|
|
|
66
69
|
|
|
67
70
|
exports.fetchExchangeRate = fetchExchangeRate; exports.fetchMultiExchangeRate = fetchMultiExchangeRate;
|
|
68
|
-
//# sourceMappingURL=chunk-
|
|
71
|
+
//# sourceMappingURL=chunk-GDFLKKDY.js.map
|