@metamask-previews/assets-controllers 58.0.0-preview-530f9e5 → 58.0.0-preview-f2d81961
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 +2 -8
- package/dist/TokensController.cjs +63 -40
- package/dist/TokensController.cjs.map +1 -1
- package/dist/TokensController.d.cts +8 -9
- package/dist/TokensController.d.cts.map +1 -1
- package/dist/TokensController.d.mts +8 -9
- package/dist/TokensController.d.mts.map +1 -1
- package/dist/TokensController.mjs +63 -40
- package/dist/TokensController.mjs.map +1 -1
- package/package.json +1 -1
@@ -63,7 +63,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
63
63
|
* @param options.state - Initial state to set on this controller.
|
64
64
|
* @param options.messenger - The messenger.
|
65
65
|
*/
|
66
|
-
constructor({ provider, state, messenger, }: {
|
66
|
+
constructor({ chainId: initialChainId, provider, state, messenger, }: {
|
67
67
|
chainId: Hex;
|
68
68
|
provider: Provider;
|
69
69
|
state?: Partial<TokensControllerState>;
|
@@ -89,7 +89,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
89
89
|
name?: string;
|
90
90
|
image?: string;
|
91
91
|
interactingAddress?: string;
|
92
|
-
networkClientId
|
92
|
+
networkClientId?: NetworkClientId;
|
93
93
|
}): Promise<Token[]>;
|
94
94
|
/**
|
95
95
|
* Add a batch of tokens.
|
@@ -97,14 +97,14 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
97
97
|
* @param tokensToImport - Array of tokens to import.
|
98
98
|
* @param networkClientId - Optional network client ID used to determine interacting chain ID.
|
99
99
|
*/
|
100
|
-
addTokens(tokensToImport: Token[], networkClientId
|
100
|
+
addTokens(tokensToImport: Token[], networkClientId?: NetworkClientId): Promise<void>;
|
101
101
|
/**
|
102
102
|
* Ignore a batch of tokens.
|
103
103
|
*
|
104
104
|
* @param tokenAddressesToIgnore - Array of token addresses to ignore.
|
105
105
|
* @param networkClientId - Optional network client ID used to determine interacting chain ID.
|
106
106
|
*/
|
107
|
-
ignoreTokens(tokenAddressesToIgnore: string[], networkClientId
|
107
|
+
ignoreTokens(tokenAddressesToIgnore: string[], networkClientId?: NetworkClientId): void;
|
108
108
|
/**
|
109
109
|
* Adds a batch of detected tokens to the stored token list.
|
110
110
|
*
|
@@ -113,8 +113,8 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
113
113
|
* @param detectionDetails.selectedAddress - the account address on which the incomingDetectedTokens were detected.
|
114
114
|
* @param detectionDetails.chainId - the chainId on which the incomingDetectedTokens were detected.
|
115
115
|
*/
|
116
|
-
addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails
|
117
|
-
selectedAddress
|
116
|
+
addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails?: {
|
117
|
+
selectedAddress: string;
|
118
118
|
chainId: Hex;
|
119
119
|
}): Promise<void>;
|
120
120
|
/**
|
@@ -122,10 +122,9 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
122
122
|
* were previously added which do not yet had isERC721 field.
|
123
123
|
*
|
124
124
|
* @param tokenAddress - The contract address of the token requiring the isERC721 field added.
|
125
|
-
* @param networkClientId - The network client ID of the network on which the token is detected.
|
126
125
|
* @returns The new token object with the added isERC721 field.
|
127
126
|
*/
|
128
|
-
updateTokenType(tokenAddress: string
|
127
|
+
updateTokenType(tokenAddress: string): Promise<{
|
129
128
|
isERC721: any;
|
130
129
|
address: string;
|
131
130
|
decimals: number;
|
@@ -150,7 +149,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
150
149
|
asset: Token;
|
151
150
|
type: string;
|
152
151
|
interactingAddress?: string;
|
153
|
-
networkClientId
|
152
|
+
networkClientId?: NetworkClientId;
|
154
153
|
}): Promise<void>;
|
155
154
|
/**
|
156
155
|
* Removes all tokens from the ignored list.
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"TokensController.d.cts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,kCAAkC,EAClC,0CAA0C,EAC1C,+CAA+C,EAChD,sCAAsC;AACvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,sCAAsC;AACxE,OAAO,KAAK,EACV,mBAAmB,EACnB,wBAAwB,EACxB,0BAA0B,EAC3B,kCAAkC;AACnC,OAAO,EAAE,cAAc,EAAE,kCAAkC;AAe3D,OAAO,KAAK,EACV,eAAe,EACf,2CAA2C,EAC3C,sCAAsC,EACtC,iCAAiC,EAEjC,QAAQ,EACT,qCAAqC;AAEtC,OAAO,KAAK,EAAE,GAAG,EAAE,wBAAwB;AAa3C,OAAO,KAAK,EACV,oBAAoB,EAErB,kCAA8B;AAC/B,OAAO,KAAK,EAAE,KAAK,EAAE,mCAA+B;AAoBpD;;;;;;;GAOG;AACH,MAAM,MAAM,qBAAqB,GAAG;IAClC,SAAS,EAAE;QAAE,CAAC,OAAO,EAAE,GAAG,GAAG;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,EAAE,CAAA;SAAE,CAAA;KAAE,CAAC;IAC1D,gBAAgB,EAAE;QAAE,CAAC,OAAO,EAAE,GAAG,GAAG;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;SAAE,CAAA;KAAE,CAAC;IAClE,iBAAiB,EAAE;QAAE,CAAC,OAAO,EAAE,GAAG,GAAG;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,EAAE,CAAA;SAAE,CAAA;KAAE,CAAC;CACnE,CAAC;AAiBF,QAAA,MAAM,cAAc,qBAAqB,CAAC;AAE1C,MAAM,MAAM,uBAAuB,GAC/B,8BAA8B,GAC9B,uCAAuC,CAAC;AAE5C,MAAM,MAAM,8BAA8B,GAAG,wBAAwB,CACnE,OAAO,cAAc,EACrB,qBAAqB,CACtB,CAAC;AAEF,MAAM,MAAM,uCAAuC,GAAG;IACpD,IAAI,EAAE,GAAG,OAAO,cAAc,oBAAoB,CAAC;IACnD,OAAO,EAAE,gBAAgB,CAAC,mBAAmB,CAAC,CAAC;CAChD,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GACtB,kBAAkB,GAClB,2CAA2C,GAC3C,kCAAkC,GAClC,0CAA0C,CAAC;AAE/C,MAAM,MAAM,gCAAgC,GAAG,0BAA0B,CACvE,OAAO,cAAc,EACrB,qBAAqB,CACtB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,gCAAgC,CAAC;AAEtE,MAAM,MAAM,aAAa,GACrB,iCAAiC,GACjC,sCAAsC,GACtC,oBAAoB,GACpB,+CAA+C,CAAC;AAEpD;;GAEG;AACH,MAAM,MAAM,yBAAyB,GAAG,mBAAmB,CACzD,OAAO,cAAc,EACrB,uBAAuB,GAAG,cAAc,EACxC,sBAAsB,GAAG,aAAa,EACtC,cAAc,CAAC,MAAM,CAAC,EACtB,aAAa,CAAC,MAAM,CAAC,CACtB,CAAC;AAEF,eAAO,MAAM,qBAAqB,QAAO,qBAMxC,CAAC;AAEF;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,cAAc,CAClD,OAAO,cAAc,EACrB,qBAAqB,EACrB,yBAAyB,CAC1B;;
|
1
|
+
{"version":3,"file":"TokensController.d.cts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"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"}
|
@@ -63,7 +63,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
63
63
|
* @param options.state - Initial state to set on this controller.
|
64
64
|
* @param options.messenger - The messenger.
|
65
65
|
*/
|
66
|
-
constructor({ provider, state, messenger, }: {
|
66
|
+
constructor({ chainId: initialChainId, provider, state, messenger, }: {
|
67
67
|
chainId: Hex;
|
68
68
|
provider: Provider;
|
69
69
|
state?: Partial<TokensControllerState>;
|
@@ -89,7 +89,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
89
89
|
name?: string;
|
90
90
|
image?: string;
|
91
91
|
interactingAddress?: string;
|
92
|
-
networkClientId
|
92
|
+
networkClientId?: NetworkClientId;
|
93
93
|
}): Promise<Token[]>;
|
94
94
|
/**
|
95
95
|
* Add a batch of tokens.
|
@@ -97,14 +97,14 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
97
97
|
* @param tokensToImport - Array of tokens to import.
|
98
98
|
* @param networkClientId - Optional network client ID used to determine interacting chain ID.
|
99
99
|
*/
|
100
|
-
addTokens(tokensToImport: Token[], networkClientId
|
100
|
+
addTokens(tokensToImport: Token[], networkClientId?: NetworkClientId): Promise<void>;
|
101
101
|
/**
|
102
102
|
* Ignore a batch of tokens.
|
103
103
|
*
|
104
104
|
* @param tokenAddressesToIgnore - Array of token addresses to ignore.
|
105
105
|
* @param networkClientId - Optional network client ID used to determine interacting chain ID.
|
106
106
|
*/
|
107
|
-
ignoreTokens(tokenAddressesToIgnore: string[], networkClientId
|
107
|
+
ignoreTokens(tokenAddressesToIgnore: string[], networkClientId?: NetworkClientId): void;
|
108
108
|
/**
|
109
109
|
* Adds a batch of detected tokens to the stored token list.
|
110
110
|
*
|
@@ -113,8 +113,8 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
113
113
|
* @param detectionDetails.selectedAddress - the account address on which the incomingDetectedTokens were detected.
|
114
114
|
* @param detectionDetails.chainId - the chainId on which the incomingDetectedTokens were detected.
|
115
115
|
*/
|
116
|
-
addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails
|
117
|
-
selectedAddress
|
116
|
+
addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails?: {
|
117
|
+
selectedAddress: string;
|
118
118
|
chainId: Hex;
|
119
119
|
}): Promise<void>;
|
120
120
|
/**
|
@@ -122,10 +122,9 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
122
122
|
* were previously added which do not yet had isERC721 field.
|
123
123
|
*
|
124
124
|
* @param tokenAddress - The contract address of the token requiring the isERC721 field added.
|
125
|
-
* @param networkClientId - The network client ID of the network on which the token is detected.
|
126
125
|
* @returns The new token object with the added isERC721 field.
|
127
126
|
*/
|
128
|
-
updateTokenType(tokenAddress: string
|
127
|
+
updateTokenType(tokenAddress: string): Promise<{
|
129
128
|
isERC721: any;
|
130
129
|
address: string;
|
131
130
|
decimals: number;
|
@@ -150,7 +149,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
|
|
150
149
|
asset: Token;
|
151
150
|
type: string;
|
152
151
|
interactingAddress?: string;
|
153
|
-
networkClientId
|
152
|
+
networkClientId?: NetworkClientId;
|
154
153
|
}): Promise<void>;
|
155
154
|
/**
|
156
155
|
* Removes all tokens from the ignored list.
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"TokensController.d.mts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,kCAAkC,EAClC,0CAA0C,EAC1C,+CAA+C,EAChD,sCAAsC;AACvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,sCAAsC;AACxE,OAAO,KAAK,EACV,mBAAmB,EACnB,wBAAwB,EACxB,0BAA0B,EAC3B,kCAAkC;AACnC,OAAO,EAAE,cAAc,EAAE,kCAAkC;AAe3D,OAAO,KAAK,EACV,eAAe,EACf,2CAA2C,EAC3C,sCAAsC,EACtC,iCAAiC,EAEjC,QAAQ,EACT,qCAAqC;AAEtC,OAAO,KAAK,EAAE,GAAG,EAAE,wBAAwB;AAa3C,OAAO,KAAK,EACV,oBAAoB,EAErB,kCAA8B;AAC/B,OAAO,KAAK,EAAE,KAAK,EAAE,mCAA+B;AAoBpD;;;;;;;GAOG;AACH,MAAM,MAAM,qBAAqB,GAAG;IAClC,SAAS,EAAE;QAAE,CAAC,OAAO,EAAE,GAAG,GAAG;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,EAAE,CAAA;SAAE,CAAA;KAAE,CAAC;IAC1D,gBAAgB,EAAE;QAAE,CAAC,OAAO,EAAE,GAAG,GAAG;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;SAAE,CAAA;KAAE,CAAC;IAClE,iBAAiB,EAAE;QAAE,CAAC,OAAO,EAAE,GAAG,GAAG;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,KAAK,EAAE,CAAA;SAAE,CAAA;KAAE,CAAC;CACnE,CAAC;AAiBF,QAAA,MAAM,cAAc,qBAAqB,CAAC;AAE1C,MAAM,MAAM,uBAAuB,GAC/B,8BAA8B,GAC9B,uCAAuC,CAAC;AAE5C,MAAM,MAAM,8BAA8B,GAAG,wBAAwB,CACnE,OAAO,cAAc,EACrB,qBAAqB,CACtB,CAAC;AAEF,MAAM,MAAM,uCAAuC,GAAG;IACpD,IAAI,EAAE,GAAG,OAAO,cAAc,oBAAoB,CAAC;IACnD,OAAO,EAAE,gBAAgB,CAAC,mBAAmB,CAAC,CAAC;CAChD,CAAC;AAEF;;GAEG;AACH,MAAM,MAAM,cAAc,GACtB,kBAAkB,GAClB,2CAA2C,GAC3C,kCAAkC,GAClC,0CAA0C,CAAC;AAE/C,MAAM,MAAM,gCAAgC,GAAG,0BAA0B,CACvE,OAAO,cAAc,EACrB,qBAAqB,CACtB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,gCAAgC,CAAC;AAEtE,MAAM,MAAM,aAAa,GACrB,iCAAiC,GACjC,sCAAsC,GACtC,oBAAoB,GACpB,+CAA+C,CAAC;AAEpD;;GAEG;AACH,MAAM,MAAM,yBAAyB,GAAG,mBAAmB,CACzD,OAAO,cAAc,EACrB,uBAAuB,GAAG,cAAc,EACxC,sBAAsB,GAAG,aAAa,EACtC,cAAc,CAAC,MAAM,CAAC,EACtB,aAAa,CAAC,MAAM,CAAC,CACtB,CAAC;AAEF,eAAO,MAAM,qBAAqB,QAAO,qBAMxC,CAAC;AAEF;;GAEG;AACH,qBAAa,gBAAiB,SAAQ,cAAc,CAClD,OAAO,cAAc,EACrB,qBAAqB,EACrB,yBAAyB,CAC1B;;
|
1
|
+
{"version":3,"file":"TokensController.d.mts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"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"}
|
@@ -9,7 +9,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
9
9
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
10
10
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
11
11
|
};
|
12
|
-
var _TokensController_instances, _TokensController_mutex, _TokensController_selectedAccountId, _TokensController_provider, _TokensController_abortController, _TokensController_onNetworkStateChange, _TokensController_onSelectedAccountChange, _TokensController_fetchTokenMetadata, _TokensController_detectIsERC721, _TokensController_getProvider, _TokensController_createEthersContract, _TokensController_generateRandomId, _TokensController_getNewAllTokensState, _TokensController_getAddressOrSelectedAddress, _TokensController_requestApproval, _TokensController_getSelectedAccount, _TokensController_getSelectedAddress;
|
12
|
+
var _TokensController_instances, _TokensController_mutex, _TokensController_chainId, _TokensController_selectedAccountId, _TokensController_provider, _TokensController_abortController, _TokensController_onNetworkDidChange, _TokensController_onNetworkStateChange, _TokensController_onSelectedAccountChange, _TokensController_fetchTokenMetadata, _TokensController_detectIsERC721, _TokensController_getProvider, _TokensController_createEthersContract, _TokensController_generateRandomId, _TokensController_getNewAllTokensState, _TokensController_getAddressOrSelectedAddress, _TokensController_requestApproval, _TokensController_getSelectedAccount, _TokensController_getSelectedAddress;
|
13
13
|
function $importDefault(module) {
|
14
14
|
if (module?.__esModule) {
|
15
15
|
return module.default;
|
@@ -66,7 +66,7 @@ export class TokensController extends BaseController {
|
|
66
66
|
* @param options.state - Initial state to set on this controller.
|
67
67
|
* @param options.messenger - The messenger.
|
68
68
|
*/
|
69
|
-
constructor({ provider, state, messenger, }) {
|
69
|
+
constructor({ chainId: initialChainId, provider, state, messenger, }) {
|
70
70
|
super({
|
71
71
|
name: controllerName,
|
72
72
|
metadata,
|
@@ -78,14 +78,17 @@ export class TokensController extends BaseController {
|
|
78
78
|
});
|
79
79
|
_TokensController_instances.add(this);
|
80
80
|
_TokensController_mutex.set(this, new Mutex());
|
81
|
+
_TokensController_chainId.set(this, void 0);
|
81
82
|
_TokensController_selectedAccountId.set(this, void 0);
|
82
83
|
_TokensController_provider.set(this, void 0);
|
83
84
|
_TokensController_abortController.set(this, void 0);
|
85
|
+
__classPrivateFieldSet(this, _TokensController_chainId, initialChainId, "f");
|
84
86
|
__classPrivateFieldSet(this, _TokensController_provider, provider, "f");
|
85
87
|
__classPrivateFieldSet(this, _TokensController_selectedAccountId, __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAccount).call(this).id, "f");
|
86
88
|
__classPrivateFieldSet(this, _TokensController_abortController, new AbortController(), "f");
|
87
89
|
this.messagingSystem.registerActionHandler(`${controllerName}:addDetectedTokens`, this.addDetectedTokens.bind(this));
|
88
90
|
this.messagingSystem.subscribe('AccountsController:selectedEvmAccountChange', __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_onSelectedAccountChange).bind(this));
|
91
|
+
this.messagingSystem.subscribe('NetworkController:networkDidChange', __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_onNetworkDidChange).bind(this));
|
89
92
|
this.messagingSystem.subscribe('NetworkController:stateChange', __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_onNetworkStateChange).bind(this));
|
90
93
|
this.messagingSystem.subscribe('TokenListController:stateChange', ({ tokensChainsCache }) => {
|
91
94
|
const { allTokens } = this.state;
|
@@ -129,28 +132,37 @@ export class TokensController extends BaseController {
|
|
129
132
|
* @returns Current token list.
|
130
133
|
*/
|
131
134
|
async addToken({ address, symbol, decimals, name, image, interactingAddress, networkClientId, }) {
|
135
|
+
// TODO: remove this once this method is fully parameterized by chainId
|
136
|
+
const chainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
|
132
137
|
const releaseLock = await __classPrivateFieldGet(this, _TokensController_mutex, "f").acquire();
|
133
138
|
const { allTokens, allIgnoredTokens, allDetectedTokens } = this.state;
|
134
|
-
|
139
|
+
let currentChainId = chainId;
|
140
|
+
if (networkClientId) {
|
141
|
+
currentChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
|
142
|
+
}
|
135
143
|
const accountAddress = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getAddressOrSelectedAddress).call(this, interactingAddress);
|
136
144
|
try {
|
137
145
|
address = toChecksumHexAddress(address);
|
138
|
-
const tokens = allTokens[
|
139
|
-
const ignoredTokens = allIgnoredTokens[
|
140
|
-
const detectedTokens = allDetectedTokens[
|
146
|
+
const tokens = allTokens[currentChainId]?.[accountAddress] || [];
|
147
|
+
const ignoredTokens = allIgnoredTokens[currentChainId]?.[accountAddress] || [];
|
148
|
+
const detectedTokens = allDetectedTokens[currentChainId]?.[accountAddress] || [];
|
141
149
|
const newTokens = [...tokens];
|
142
150
|
const [isERC721, tokenMetadata] = await Promise.all([
|
143
151
|
__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_detectIsERC721).call(this, address, networkClientId),
|
144
152
|
// TODO parameterize the token metadata fetch by networkClientId
|
145
|
-
__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_fetchTokenMetadata).call(this, address
|
153
|
+
__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_fetchTokenMetadata).call(this, address),
|
146
154
|
]);
|
155
|
+
// TODO remove this once this method is fully parameterized by networkClientId
|
156
|
+
if (!networkClientId && currentChainId !== __classPrivateFieldGet(this, _TokensController_chainId, "f")) {
|
157
|
+
throw new Error('TokensController Error: Switched networks while adding token');
|
158
|
+
}
|
147
159
|
const newEntry = {
|
148
160
|
address,
|
149
161
|
symbol,
|
150
162
|
decimals,
|
151
163
|
image: image ||
|
152
164
|
formatIconUrlWithProxy({
|
153
|
-
chainId:
|
165
|
+
chainId: currentChainId,
|
154
166
|
tokenAddress: address,
|
155
167
|
}),
|
156
168
|
isERC721,
|
@@ -171,7 +183,7 @@ export class TokensController extends BaseController {
|
|
171
183
|
newIgnoredTokens,
|
172
184
|
newDetectedTokens,
|
173
185
|
interactingAddress: accountAddress,
|
174
|
-
interactingChainId:
|
186
|
+
interactingChainId: currentChainId,
|
175
187
|
});
|
176
188
|
const newState = {
|
177
189
|
allTokens: newAllTokens,
|
@@ -197,7 +209,10 @@ export class TokensController extends BaseController {
|
|
197
209
|
const releaseLock = await __classPrivateFieldGet(this, _TokensController_mutex, "f").acquire();
|
198
210
|
const { allTokens, allIgnoredTokens, allDetectedTokens } = this.state;
|
199
211
|
const importedTokensMap = {};
|
200
|
-
|
212
|
+
let interactingChainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
|
213
|
+
if (networkClientId) {
|
214
|
+
interactingChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
|
215
|
+
}
|
201
216
|
// Used later to dedupe imported tokens
|
202
217
|
const newTokensMap = [
|
203
218
|
...(allTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAccount).call(this).address] ||
|
@@ -224,7 +239,7 @@ export class TokensController extends BaseController {
|
|
224
239
|
return formattedToken;
|
225
240
|
});
|
226
241
|
const newTokens = Object.values(newTokensMap);
|
227
|
-
const newIgnoredTokens = allIgnoredTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)]?.filter((tokenAddress) => !newTokensMap[tokenAddress.toLowerCase()]);
|
242
|
+
const newIgnoredTokens = allIgnoredTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)]?.filter((tokenAddress) => !newTokensMap[tokenAddress.toLowerCase()]);
|
228
243
|
const detectedTokensForGivenChain = interactingChainId
|
229
244
|
? allDetectedTokens?.[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)]
|
230
245
|
: [];
|
@@ -252,13 +267,16 @@ export class TokensController extends BaseController {
|
|
252
267
|
* @param networkClientId - Optional network client ID used to determine interacting chain ID.
|
253
268
|
*/
|
254
269
|
ignoreTokens(tokenAddressesToIgnore, networkClientId) {
|
255
|
-
|
270
|
+
let interactingChainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
|
271
|
+
if (networkClientId) {
|
272
|
+
interactingChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
|
273
|
+
}
|
256
274
|
const { allTokens, allDetectedTokens, allIgnoredTokens } = this.state;
|
257
275
|
const ignoredTokensMap = {};
|
258
|
-
const ignoredTokens = allIgnoredTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
|
276
|
+
const ignoredTokens = allIgnoredTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
|
259
277
|
let newIgnoredTokens = [...ignoredTokens];
|
260
|
-
const tokens = allTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
|
261
|
-
const detectedTokens = allDetectedTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
|
278
|
+
const tokens = allTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
|
279
|
+
const detectedTokens = allDetectedTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
|
262
280
|
const checksummedTokenAddresses = tokenAddressesToIgnore.map((address) => {
|
263
281
|
const checksumAddress = toChecksumHexAddress(address);
|
264
282
|
ignoredTokensMap[address.toLowerCase()] = true;
|
@@ -289,7 +307,7 @@ export class TokensController extends BaseController {
|
|
289
307
|
*/
|
290
308
|
async addDetectedTokens(incomingDetectedTokens, detectionDetails) {
|
291
309
|
const releaseLock = await __classPrivateFieldGet(this, _TokensController_mutex, "f").acquire();
|
292
|
-
const
|
310
|
+
const chainId = detectionDetails?.chainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f");
|
293
311
|
// Previously selectedAddress could be an empty string. This is to preserve the behaviour
|
294
312
|
const accountAddress = detectionDetails?.selectedAddress ?? __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this);
|
295
313
|
const { allTokens, allDetectedTokens, allIgnoredTokens } = this.state;
|
@@ -339,9 +357,9 @@ export class TokensController extends BaseController {
|
|
339
357
|
// We may be detecting tokens on a different chain/account pair than are currently configured.
|
340
358
|
// Re-point `tokens` and `detectedTokens` to keep them referencing the current chain/account.
|
341
359
|
const selectedAddress = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this);
|
342
|
-
newTokens = newAllTokens?.[
|
360
|
+
newTokens = newAllTokens?.[__classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[selectedAddress] || [];
|
343
361
|
newDetectedTokens =
|
344
|
-
newAllDetectedTokens?.[
|
362
|
+
newAllDetectedTokens?.[__classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[selectedAddress] || [];
|
345
363
|
this.update((state) => {
|
346
364
|
state.allTokens = newAllTokens;
|
347
365
|
state.allDetectedTokens = newAllDetectedTokens;
|
@@ -356,21 +374,20 @@ export class TokensController extends BaseController {
|
|
356
374
|
* were previously added which do not yet had isERC721 field.
|
357
375
|
*
|
358
376
|
* @param tokenAddress - The contract address of the token requiring the isERC721 field added.
|
359
|
-
* @param networkClientId - The network client ID of the network on which the token is detected.
|
360
377
|
* @returns The new token object with the added isERC721 field.
|
361
378
|
*/
|
362
|
-
async updateTokenType(tokenAddress
|
363
|
-
const
|
364
|
-
const
|
379
|
+
async updateTokenType(tokenAddress) {
|
380
|
+
const isERC721 = await __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_detectIsERC721).call(this, tokenAddress);
|
381
|
+
const chainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
|
365
382
|
const accountAddress = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this);
|
366
|
-
const tokens = [...this.state.allTokens[
|
383
|
+
const tokens = [...this.state.allTokens[chainId][accountAddress]];
|
367
384
|
const tokenIndex = tokens.findIndex((token) => {
|
368
385
|
return token.address.toLowerCase() === tokenAddress.toLowerCase();
|
369
386
|
});
|
370
387
|
const updatedToken = { ...tokens[tokenIndex], isERC721 };
|
371
388
|
tokens[tokenIndex] = updatedToken;
|
372
389
|
this.update((state) => {
|
373
|
-
state.allTokens[
|
390
|
+
state.allTokens[chainId][accountAddress] = tokens;
|
374
391
|
});
|
375
392
|
return updatedToken;
|
376
393
|
}
|
@@ -494,7 +511,13 @@ export class TokensController extends BaseController {
|
|
494
511
|
});
|
495
512
|
}
|
496
513
|
}
|
497
|
-
_TokensController_mutex = new WeakMap(), _TokensController_selectedAccountId = new WeakMap(), _TokensController_provider = new WeakMap(), _TokensController_abortController = new WeakMap(), _TokensController_instances = new WeakSet(),
|
514
|
+
_TokensController_mutex = new WeakMap(), _TokensController_chainId = new WeakMap(), _TokensController_selectedAccountId = new WeakMap(), _TokensController_provider = new WeakMap(), _TokensController_abortController = new WeakMap(), _TokensController_instances = new WeakSet(), _TokensController_onNetworkDidChange = function _TokensController_onNetworkDidChange({ selectedNetworkClientId }) {
|
515
|
+
const selectedNetworkClient = this.messagingSystem.call('NetworkController:getNetworkClientById', selectedNetworkClientId);
|
516
|
+
const { chainId } = selectedNetworkClient.configuration;
|
517
|
+
__classPrivateFieldGet(this, _TokensController_abortController, "f").abort();
|
518
|
+
__classPrivateFieldSet(this, _TokensController_abortController, new AbortController(), "f");
|
519
|
+
__classPrivateFieldSet(this, _TokensController_chainId, chainId, "f");
|
520
|
+
}, _TokensController_onNetworkStateChange = function _TokensController_onNetworkStateChange(_, patches) {
|
498
521
|
// Remove state for deleted networks
|
499
522
|
for (const patch of patches) {
|
500
523
|
if (patch.op === 'remove' &&
|
@@ -514,12 +537,11 @@ _TokensController_mutex = new WeakMap(), _TokensController_selectedAccountId = n
|
|
514
537
|
* Fetch metadata for a token.
|
515
538
|
*
|
516
539
|
* @param tokenAddress - The address of the token.
|
517
|
-
* @param chainId - The chain ID of the network on which the token is detected.
|
518
540
|
* @returns The token metadata.
|
519
541
|
*/
|
520
|
-
async function _TokensController_fetchTokenMetadata(tokenAddress
|
542
|
+
async function _TokensController_fetchTokenMetadata(tokenAddress) {
|
521
543
|
try {
|
522
|
-
const token = await fetchTokenMetadata(
|
544
|
+
const token = await fetchTokenMetadata(__classPrivateFieldGet(this, _TokensController_chainId, "f"), tokenAddress, __classPrivateFieldGet(this, _TokensController_abortController, "f").signal);
|
523
545
|
return token;
|
524
546
|
}
|
525
547
|
catch (error) {
|
@@ -573,52 +595,53 @@ async function _TokensController_detectIsERC721(tokenAddress, networkClientId) {
|
|
573
595
|
const { newTokens, newIgnoredTokens, newDetectedTokens, interactingAddress, interactingChainId, } = params;
|
574
596
|
const { allTokens, allIgnoredTokens, allDetectedTokens } = this.state;
|
575
597
|
const userAddressToAddTokens = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getAddressOrSelectedAddress).call(this, interactingAddress);
|
598
|
+
const chainIdToAddTokens = interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f");
|
576
599
|
let newAllTokens = allTokens;
|
577
600
|
if (newTokens?.length ||
|
578
601
|
(newTokens &&
|
579
602
|
allTokens &&
|
580
|
-
allTokens[
|
581
|
-
allTokens[
|
582
|
-
const networkTokens = allTokens[
|
603
|
+
allTokens[chainIdToAddTokens] &&
|
604
|
+
allTokens[chainIdToAddTokens][userAddressToAddTokens])) {
|
605
|
+
const networkTokens = allTokens[chainIdToAddTokens];
|
583
606
|
const newNetworkTokens = {
|
584
607
|
...networkTokens,
|
585
608
|
...{ [userAddressToAddTokens]: newTokens },
|
586
609
|
};
|
587
610
|
newAllTokens = {
|
588
611
|
...allTokens,
|
589
|
-
...{ [
|
612
|
+
...{ [chainIdToAddTokens]: newNetworkTokens },
|
590
613
|
};
|
591
614
|
}
|
592
615
|
let newAllIgnoredTokens = allIgnoredTokens;
|
593
616
|
if (newIgnoredTokens?.length ||
|
594
617
|
(newIgnoredTokens &&
|
595
618
|
allIgnoredTokens &&
|
596
|
-
allIgnoredTokens[
|
597
|
-
allIgnoredTokens[
|
598
|
-
const networkIgnoredTokens = allIgnoredTokens[
|
619
|
+
allIgnoredTokens[chainIdToAddTokens] &&
|
620
|
+
allIgnoredTokens[chainIdToAddTokens][userAddressToAddTokens])) {
|
621
|
+
const networkIgnoredTokens = allIgnoredTokens[chainIdToAddTokens];
|
599
622
|
const newIgnoredNetworkTokens = {
|
600
623
|
...networkIgnoredTokens,
|
601
624
|
...{ [userAddressToAddTokens]: newIgnoredTokens },
|
602
625
|
};
|
603
626
|
newAllIgnoredTokens = {
|
604
627
|
...allIgnoredTokens,
|
605
|
-
...{ [
|
628
|
+
...{ [chainIdToAddTokens]: newIgnoredNetworkTokens },
|
606
629
|
};
|
607
630
|
}
|
608
631
|
let newAllDetectedTokens = allDetectedTokens;
|
609
632
|
if (newDetectedTokens?.length ||
|
610
633
|
(newDetectedTokens &&
|
611
634
|
allDetectedTokens &&
|
612
|
-
allDetectedTokens[
|
613
|
-
allDetectedTokens[
|
614
|
-
const networkDetectedTokens = allDetectedTokens[
|
635
|
+
allDetectedTokens[chainIdToAddTokens] &&
|
636
|
+
allDetectedTokens[chainIdToAddTokens][userAddressToAddTokens])) {
|
637
|
+
const networkDetectedTokens = allDetectedTokens[chainIdToAddTokens];
|
615
638
|
const newDetectedNetworkTokens = {
|
616
639
|
...networkDetectedTokens,
|
617
640
|
...{ [userAddressToAddTokens]: newDetectedTokens },
|
618
641
|
};
|
619
642
|
newAllDetectedTokens = {
|
620
643
|
...allDetectedTokens,
|
621
|
-
...{ [
|
644
|
+
...{ [chainIdToAddTokens]: newDetectedNetworkTokens },
|
622
645
|
};
|
623
646
|
}
|
624
647
|
return { newAllTokens, newAllIgnoredTokens, newAllDetectedTokens };
|