Skip to content

fix assetId in token selector#8356

Draft
bergarces wants to merge 16 commits intomainfrom
token-selectors-assetid-fix
Draft

fix assetId in token selector#8356
bergarces wants to merge 16 commits intomainfrom
token-selectors-assetid-fix

Conversation

@bergarces
Copy link
Copy Markdown
Contributor

@bergarces bergarces commented Apr 1, 2026

Explanation

assetId is being populated with the evm address for evm assets, which is both confusing and makes it cumbersome to extract the real assetId in the clients.

References

Checklist

  • I've updated the test suite for new or updated code as appropriate
  • I've updated documentation (JSDoc, Markdown, etc.) for new or updated code as appropriate
  • I've communicated my changes to consumers by updating changelogs for packages I've changed
  • I've introduced breaking changes in this PR and have prepared draft pull requests for clients and consumer packages to resolve them

@bergarces
Copy link
Copy Markdown
Contributor Author

@metamaskbot publish-preview

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Apr 1, 2026

Preview builds have been published. Learn how to use preview builds in other projects.

Expand for full list of packages and versions.
@metamask-previews/account-tree-controller@7.0.0-preview-4014adf
@metamask-previews/accounts-controller@37.1.1-preview-4014adf
@metamask-previews/address-book-controller@7.1.1-preview-4014adf
@metamask-previews/ai-controllers@0.6.3-preview-4014adf
@metamask-previews/analytics-controller@1.0.1-preview-4014adf
@metamask-previews/analytics-data-regulation-controller@0.0.0-preview-4014adf
@metamask-previews/announcement-controller@8.1.0-preview-4014adf
@metamask-previews/app-metadata-controller@2.0.1-preview-4014adf
@metamask-previews/approval-controller@9.0.1-preview-4014adf
@metamask-previews/assets-controller@3.2.1-preview-4014adf
@metamask-previews/assets-controllers@103.0.0-preview-4014adf
@metamask-previews/base-controller@9.0.1-preview-4014adf
@metamask-previews/base-data-service@0.1.1-preview-4014adf
@metamask-previews/bridge-controller@70.0.0-preview-4014adf
@metamask-previews/bridge-status-controller@70.0.4-preview-4014adf
@metamask-previews/build-utils@3.0.4-preview-4014adf
@metamask-previews/chain-agnostic-permission@1.5.0-preview-4014adf
@metamask-previews/claims-controller@0.5.0-preview-4014adf
@metamask-previews/client-controller@1.0.1-preview-4014adf
@metamask-previews/compliance-controller@1.0.2-preview-4014adf
@metamask-previews/composable-controller@12.0.1-preview-4014adf
@metamask-previews/config-registry-controller@0.2.0-preview-4014adf
@metamask-previews/connectivity-controller@0.2.0-preview-4014adf
@metamask-previews/controller-utils@11.20.0-preview-4014adf
@metamask-previews/core-backend@6.2.1-preview-4014adf
@metamask-previews/delegation-controller@2.1.0-preview-4014adf
@metamask-previews/earn-controller@11.2.1-preview-4014adf
@metamask-previews/eip-5792-middleware@3.0.2-preview-4014adf
@metamask-previews/eip-7702-internal-rpc-middleware@0.1.0-preview-4014adf
@metamask-previews/eip1193-permission-middleware@1.0.3-preview-4014adf
@metamask-previews/ens-controller@19.1.1-preview-4014adf
@metamask-previews/eth-block-tracker@15.0.1-preview-4014adf
@metamask-previews/eth-json-rpc-middleware@23.1.1-preview-4014adf
@metamask-previews/eth-json-rpc-provider@6.0.1-preview-4014adf
@metamask-previews/foundryup@1.0.1-preview-4014adf
@metamask-previews/gas-fee-controller@26.1.1-preview-4014adf
@metamask-previews/gator-permissions-controller@3.0.0-preview-4014adf
@metamask-previews/geolocation-controller@0.1.2-preview-4014adf
@metamask-previews/json-rpc-engine@10.2.4-preview-4014adf
@metamask-previews/json-rpc-middleware-stream@8.0.8-preview-4014adf
@metamask-previews/keyring-controller@25.1.1-preview-4014adf
@metamask-previews/logging-controller@8.0.1-preview-4014adf
@metamask-previews/message-manager@14.1.1-preview-4014adf
@metamask-previews/messenger@1.0.0-preview-4014adf
@metamask-previews/multichain-account-service@8.0.1-preview-4014adf
@metamask-previews/multichain-api-middleware@2.0.0-preview-4014adf
@metamask-previews/multichain-network-controller@3.0.6-preview-4014adf
@metamask-previews/multichain-transactions-controller@7.0.4-preview-4014adf
@metamask-previews/name-controller@9.1.1-preview-4014adf
@metamask-previews/network-controller@30.0.1-preview-4014adf
@metamask-previews/network-enablement-controller@5.0.1-preview-4014adf
@metamask-previews/notification-services-controller@23.0.1-preview-4014adf
@metamask-previews/permission-controller@12.3.0-preview-4014adf
@metamask-previews/permission-log-controller@5.1.0-preview-4014adf
@metamask-previews/perps-controller@2.0.0-preview-4014adf
@metamask-previews/phishing-controller@17.1.0-preview-4014adf
@metamask-previews/polling-controller@16.0.4-preview-4014adf
@metamask-previews/preferences-controller@23.1.0-preview-4014adf
@metamask-previews/profile-metrics-controller@3.1.2-preview-4014adf
@metamask-previews/profile-sync-controller@28.0.2-preview-4014adf
@metamask-previews/ramps-controller@12.1.0-preview-4014adf
@metamask-previews/rate-limit-controller@7.0.1-preview-4014adf
@metamask-previews/react-data-query@0.2.0-preview-4014adf
@metamask-previews/remote-feature-flag-controller@4.2.0-preview-4014adf
@metamask-previews/sample-controllers@4.0.4-preview-4014adf
@metamask-previews/seedless-onboarding-controller@9.1.0-preview-4014adf
@metamask-previews/selected-network-controller@26.1.0-preview-4014adf
@metamask-previews/shield-controller@5.1.0-preview-4014adf
@metamask-previews/signature-controller@39.1.2-preview-4014adf
@metamask-previews/social-controllers@0.0.0-preview-4014adf
@metamask-previews/storage-service@1.0.1-preview-4014adf
@metamask-previews/subscription-controller@6.1.1-preview-4014adf
@metamask-previews/transaction-controller@63.3.1-preview-4014adf
@metamask-previews/transaction-pay-controller@19.0.1-preview-4014adf
@metamask-previews/user-operation-controller@41.1.1-preview-4014adf

@bergarces
Copy link
Copy Markdown
Contributor Author

@metamaskbot publish-preview

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Apr 1, 2026

Preview builds have been published. Learn how to use preview builds in other projects.

Expand for full list of packages and versions.
@metamask-previews/account-tree-controller@7.0.0-preview-3d4e0a05f
@metamask-previews/accounts-controller@37.1.1-preview-3d4e0a05f
@metamask-previews/address-book-controller@7.1.1-preview-3d4e0a05f
@metamask-previews/ai-controllers@0.6.3-preview-3d4e0a05f
@metamask-previews/analytics-controller@1.0.1-preview-3d4e0a05f
@metamask-previews/analytics-data-regulation-controller@0.0.0-preview-3d4e0a05f
@metamask-previews/announcement-controller@8.1.0-preview-3d4e0a05f
@metamask-previews/app-metadata-controller@2.0.1-preview-3d4e0a05f
@metamask-previews/approval-controller@9.0.1-preview-3d4e0a05f
@metamask-previews/assets-controller@3.3.0-preview-3d4e0a05f
@metamask-previews/assets-controllers@103.1.0-preview-3d4e0a05f
@metamask-previews/base-controller@9.0.1-preview-3d4e0a05f
@metamask-previews/base-data-service@0.1.1-preview-3d4e0a05f
@metamask-previews/bridge-controller@70.0.0-preview-3d4e0a05f
@metamask-previews/bridge-status-controller@70.0.4-preview-3d4e0a05f
@metamask-previews/build-utils@3.0.4-preview-3d4e0a05f
@metamask-previews/chain-agnostic-permission@1.5.0-preview-3d4e0a05f
@metamask-previews/claims-controller@0.5.0-preview-3d4e0a05f
@metamask-previews/client-controller@1.0.1-preview-3d4e0a05f
@metamask-previews/compliance-controller@1.0.2-preview-3d4e0a05f
@metamask-previews/composable-controller@12.0.1-preview-3d4e0a05f
@metamask-previews/config-registry-controller@0.2.0-preview-3d4e0a05f
@metamask-previews/connectivity-controller@0.2.0-preview-3d4e0a05f
@metamask-previews/controller-utils@11.20.0-preview-3d4e0a05f
@metamask-previews/core-backend@6.2.1-preview-3d4e0a05f
@metamask-previews/delegation-controller@2.1.0-preview-3d4e0a05f
@metamask-previews/earn-controller@11.2.1-preview-3d4e0a05f
@metamask-previews/eip-5792-middleware@3.0.2-preview-3d4e0a05f
@metamask-previews/eip-7702-internal-rpc-middleware@0.1.0-preview-3d4e0a05f
@metamask-previews/eip1193-permission-middleware@1.0.3-preview-3d4e0a05f
@metamask-previews/ens-controller@19.1.1-preview-3d4e0a05f
@metamask-previews/eth-block-tracker@15.0.1-preview-3d4e0a05f
@metamask-previews/eth-json-rpc-middleware@23.1.1-preview-3d4e0a05f
@metamask-previews/eth-json-rpc-provider@6.0.1-preview-3d4e0a05f
@metamask-previews/foundryup@1.0.1-preview-3d4e0a05f
@metamask-previews/gas-fee-controller@26.1.1-preview-3d4e0a05f
@metamask-previews/gator-permissions-controller@3.0.0-preview-3d4e0a05f
@metamask-previews/geolocation-controller@0.1.2-preview-3d4e0a05f
@metamask-previews/json-rpc-engine@10.2.4-preview-3d4e0a05f
@metamask-previews/json-rpc-middleware-stream@8.0.8-preview-3d4e0a05f
@metamask-previews/keyring-controller@25.1.1-preview-3d4e0a05f
@metamask-previews/logging-controller@8.0.1-preview-3d4e0a05f
@metamask-previews/message-manager@14.1.1-preview-3d4e0a05f
@metamask-previews/messenger@1.0.0-preview-3d4e0a05f
@metamask-previews/multichain-account-service@8.0.1-preview-3d4e0a05f
@metamask-previews/multichain-api-middleware@2.0.0-preview-3d4e0a05f
@metamask-previews/multichain-network-controller@3.0.6-preview-3d4e0a05f
@metamask-previews/multichain-transactions-controller@7.0.4-preview-3d4e0a05f
@metamask-previews/name-controller@9.1.1-preview-3d4e0a05f
@metamask-previews/network-controller@30.0.1-preview-3d4e0a05f
@metamask-previews/network-enablement-controller@5.0.1-preview-3d4e0a05f
@metamask-previews/notification-services-controller@23.0.1-preview-3d4e0a05f
@metamask-previews/permission-controller@12.3.0-preview-3d4e0a05f
@metamask-previews/permission-log-controller@5.1.0-preview-3d4e0a05f
@metamask-previews/perps-controller@2.0.0-preview-3d4e0a05f
@metamask-previews/phishing-controller@17.1.0-preview-3d4e0a05f
@metamask-previews/polling-controller@16.0.4-preview-3d4e0a05f
@metamask-previews/preferences-controller@23.1.0-preview-3d4e0a05f
@metamask-previews/profile-metrics-controller@3.1.2-preview-3d4e0a05f
@metamask-previews/profile-sync-controller@28.0.2-preview-3d4e0a05f
@metamask-previews/ramps-controller@12.1.0-preview-3d4e0a05f
@metamask-previews/rate-limit-controller@7.0.1-preview-3d4e0a05f
@metamask-previews/react-data-query@0.2.0-preview-3d4e0a05f
@metamask-previews/remote-feature-flag-controller@4.2.0-preview-3d4e0a05f
@metamask-previews/sample-controllers@4.0.4-preview-3d4e0a05f
@metamask-previews/seedless-onboarding-controller@9.1.0-preview-3d4e0a05f
@metamask-previews/selected-network-controller@26.1.0-preview-3d4e0a05f
@metamask-previews/shield-controller@5.1.0-preview-3d4e0a05f
@metamask-previews/signature-controller@39.1.2-preview-3d4e0a05f
@metamask-previews/social-controllers@0.0.0-preview-3d4e0a05f
@metamask-previews/storage-service@1.0.1-preview-3d4e0a05f
@metamask-previews/subscription-controller@6.1.1-preview-3d4e0a05f
@metamask-previews/transaction-controller@63.3.1-preview-3d4e0a05f
@metamask-previews/transaction-pay-controller@19.0.1-preview-3d4e0a05f
@metamask-previews/user-operation-controller@41.1.1-preview-3d4e0a05f

@bergarces
Copy link
Copy Markdown
Contributor Author

@metamaskbot publish-previews

| {
accountType: EvmAccountType;
assetId: Hex; // This is also the address for EVM tokens
assetId: CaipAssetType;
Copy link
Copy Markdown
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a breaking change result from the bad decision in BIP44 days of setting assetId as the address for evm assets, which is very confusing and means we have no access to the assetId at all.

This is the main change of this PR.

chainId: `${string}:${string}`;
assetId: CaipAssetType;
address: CaipAssetType;
chainId: CaipChainId;
Copy link
Copy Markdown
Contributor Author

@bergarces bergarces Apr 15, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No breaking changes here, just using the correct type.

Added address here too, because otherwise the type is annoying to handle (it won't let you access asset.address as it doesn't always exist. The PRs implementing this breaking change show how this can simplify the code.

hexToNumber(chainId).toString(),
'erc20',
ZERO_ADDRESS,
),
Copy link
Copy Markdown
Contributor Author

@bergarces bergarces Apr 15, 2026

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We need a default here, and erc20:0x0000...0000 is a better default than slip44:60, as it usually works even when there is a slip44 entry and it doesn't assume it's ETH. It does assume that the native token is the zero address, but there is only a handful of chains for which that is not the case, and we hopefully have the captured in the settings.

@bergarces
Copy link
Copy Markdown
Contributor Author

@metamaskbot publish-previews

@github-actions
Copy link
Copy Markdown
Contributor

Preview builds have been published. Learn how to use preview builds in other projects.

Expand for full list of packages and versions.
@metamask-previews/account-tree-controller@7.1.0-preview-5d0317d14
@metamask-previews/accounts-controller@37.2.0-preview-5d0317d14
@metamask-previews/address-book-controller@7.1.1-preview-5d0317d14
@metamask-previews/ai-controllers@0.6.3-preview-5d0317d14
@metamask-previews/analytics-controller@1.0.1-preview-5d0317d14
@metamask-previews/analytics-data-regulation-controller@0.0.0-preview-5d0317d14
@metamask-previews/announcement-controller@8.1.0-preview-5d0317d14
@metamask-previews/app-metadata-controller@2.0.1-preview-5d0317d14
@metamask-previews/approval-controller@9.0.1-preview-5d0317d14
@metamask-previews/assets-controller@6.0.0-preview-5d0317d14
@metamask-previews/assets-controllers@104.0.0-preview-5d0317d14
@metamask-previews/base-controller@9.1.0-preview-5d0317d14
@metamask-previews/base-data-service@0.1.1-preview-5d0317d14
@metamask-previews/bridge-controller@70.1.1-preview-5d0317d14
@metamask-previews/bridge-status-controller@70.0.5-preview-5d0317d14
@metamask-previews/build-utils@3.0.4-preview-5d0317d14
@metamask-previews/chain-agnostic-permission@1.5.0-preview-5d0317d14
@metamask-previews/claims-controller@0.5.0-preview-5d0317d14
@metamask-previews/client-controller@1.0.1-preview-5d0317d14
@metamask-previews/compliance-controller@2.0.0-preview-5d0317d14
@metamask-previews/composable-controller@12.0.1-preview-5d0317d14
@metamask-previews/config-registry-controller@0.2.0-preview-5d0317d14
@metamask-previews/connectivity-controller@0.2.0-preview-5d0317d14
@metamask-previews/controller-utils@11.20.0-preview-5d0317d14
@metamask-previews/core-backend@6.2.1-preview-5d0317d14
@metamask-previews/delegation-controller@3.0.0-preview-5d0317d14
@metamask-previews/earn-controller@12.0.0-preview-5d0317d14
@metamask-previews/eip-5792-middleware@3.0.3-preview-5d0317d14
@metamask-previews/eip-7702-internal-rpc-middleware@0.1.0-preview-5d0317d14
@metamask-previews/eip1193-permission-middleware@1.0.3-preview-5d0317d14
@metamask-previews/ens-controller@19.1.1-preview-5d0317d14
@metamask-previews/eth-block-tracker@15.0.1-preview-5d0317d14
@metamask-previews/eth-json-rpc-middleware@23.1.1-preview-5d0317d14
@metamask-previews/eth-json-rpc-provider@6.0.1-preview-5d0317d14
@metamask-previews/foundryup@1.0.1-preview-5d0317d14
@metamask-previews/gas-fee-controller@26.1.1-preview-5d0317d14
@metamask-previews/gator-permissions-controller@4.0.0-preview-5d0317d14
@metamask-previews/geolocation-controller@0.1.2-preview-5d0317d14
@metamask-previews/json-rpc-engine@10.2.4-preview-5d0317d14
@metamask-previews/json-rpc-middleware-stream@8.0.8-preview-5d0317d14
@metamask-previews/keyring-controller@25.2.0-preview-5d0317d14
@metamask-previews/logging-controller@8.0.1-preview-5d0317d14
@metamask-previews/message-manager@14.1.1-preview-5d0317d14
@metamask-previews/messenger@1.1.1-preview-5d0317d14
@metamask-previews/messenger-cli@0.1.0-preview-5d0317d14
@metamask-previews/money-account-balance-service@0.1.0-preview-5d0317d14
@metamask-previews/money-account-controller@0.1.0-preview-5d0317d14
@metamask-previews/multichain-account-service@8.0.1-preview-5d0317d14
@metamask-previews/multichain-api-middleware@2.0.0-preview-5d0317d14
@metamask-previews/multichain-network-controller@3.0.6-preview-5d0317d14
@metamask-previews/multichain-transactions-controller@7.0.4-preview-5d0317d14
@metamask-previews/name-controller@9.1.1-preview-5d0317d14
@metamask-previews/network-controller@30.0.1-preview-5d0317d14
@metamask-previews/network-enablement-controller@5.0.2-preview-5d0317d14
@metamask-previews/notification-services-controller@23.1.0-preview-5d0317d14
@metamask-previews/permission-controller@12.3.0-preview-5d0317d14
@metamask-previews/permission-log-controller@5.1.0-preview-5d0317d14
@metamask-previews/perps-controller@3.1.1-preview-5d0317d14
@metamask-previews/phishing-controller@17.1.1-preview-5d0317d14
@metamask-previews/polling-controller@16.0.4-preview-5d0317d14
@metamask-previews/preferences-controller@23.1.0-preview-5d0317d14
@metamask-previews/profile-metrics-controller@3.1.3-preview-5d0317d14
@metamask-previews/profile-sync-controller@28.0.2-preview-5d0317d14
@metamask-previews/ramps-controller@13.2.0-preview-5d0317d14
@metamask-previews/rate-limit-controller@7.0.1-preview-5d0317d14
@metamask-previews/react-data-query@0.2.0-preview-5d0317d14
@metamask-previews/remote-feature-flag-controller@4.2.0-preview-5d0317d14
@metamask-previews/sample-controllers@4.0.4-preview-5d0317d14
@metamask-previews/seedless-onboarding-controller@9.1.0-preview-5d0317d14
@metamask-previews/selected-network-controller@26.1.0-preview-5d0317d14
@metamask-previews/shield-controller@5.1.1-preview-5d0317d14
@metamask-previews/signature-controller@39.2.0-preview-5d0317d14
@metamask-previews/social-controllers@0.2.0-preview-5d0317d14
@metamask-previews/storage-service@1.0.1-preview-5d0317d14
@metamask-previews/subscription-controller@6.1.2-preview-5d0317d14
@metamask-previews/transaction-controller@64.2.0-preview-5d0317d14
@metamask-previews/transaction-pay-controller@19.1.3-preview-5d0317d14
@metamask-previews/user-operation-controller@41.2.0-preview-5d0317d14

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant