Skip to content

Conversation

@ccharly
Copy link
Contributor

@ccharly ccharly commented Dec 11, 2025

Explanation

Add a new enabled flag for account discovery to be able to enable/disable it through the provider config.

References

N/A

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

Note

Adds a discovery.enabled flag across providers and introduces default config constants; discovery is skipped when disabled and tests updated accordingly.

  • Config:
    • Add config.discovery.enabled to SnapAccountProviderConfig and EvmAccountProviderConfig (default to true).
    • Add default config exports: EVM_ACCOUNT_PROVIDER_DEFAULT_CONFIG, SOL_ACCOUNT_PROVIDER_DEFAULT_CONFIG, BTC_ACCOUNT_PROVIDER_DEFAULT_CONFIG, TRX_ACCOUNT_PROVIDER_DEFAULT_CONFIG.
  • Providers:
    • Respect discovery.enabled by early-returning in discoverAccounts for EvmAccountProvider, SolAccountProvider, BtcAccountProvider, and TrxAccountProvider.
    • Constructors now use new default configs; normalize provider name constants to plain strings.
  • Tests:
    • Add/adjust tests to pass custom provider configs and assert discovery is not run when disabled.
    • Update constructor expectations to use provider name constants where needed.
  • Changelog:
    • Document new discovery.enabled option and default config exports.

Written by Cursor Bugbot for commit cd26c28. This will update automatically on new commits. Configure here.

@ccharly ccharly marked this pull request as ready for review December 11, 2025 14:47
@ccharly ccharly requested review from a team as code owners December 11, 2025 14:47
@ccharly
Copy link
Contributor Author

ccharly commented Dec 11, 2025

@metamaskbot publish-preview

@github-actions
Copy link
Contributor

Preview builds have been published. See these instructions for more information about preview builds.

Expand for full list of packages and versions.
{
  "@metamask-previews/account-tree-controller": "4.0.0-preview-cd26c284",
  "@metamask-previews/accounts-controller": "35.0.0-preview-cd26c284",
  "@metamask-previews/address-book-controller": "7.0.1-preview-cd26c284",
  "@metamask-previews/analytics-controller": "0.0.0-preview-cd26c284",
  "@metamask-previews/announcement-controller": "8.0.0-preview-cd26c284",
  "@metamask-previews/app-metadata-controller": "2.0.0-preview-cd26c284",
  "@metamask-previews/approval-controller": "8.0.0-preview-cd26c284",
  "@metamask-previews/assets-controllers": "94.0.0-preview-cd26c284",
  "@metamask-previews/base-controller": "9.0.0-preview-cd26c284",
  "@metamask-previews/bridge-controller": "64.1.0-preview-cd26c284",
  "@metamask-previews/bridge-status-controller": "64.1.0-preview-cd26c284",
  "@metamask-previews/build-utils": "3.0.4-preview-cd26c284",
  "@metamask-previews/chain-agnostic-permission": "1.3.0-preview-cd26c284",
  "@metamask-previews/claims-controller": "0.2.0-preview-cd26c284",
  "@metamask-previews/composable-controller": "12.0.0-preview-cd26c284",
  "@metamask-previews/controller-utils": "11.16.0-preview-cd26c284",
  "@metamask-previews/core-backend": "5.0.0-preview-cd26c284",
  "@metamask-previews/delegation-controller": "2.0.0-preview-cd26c284",
  "@metamask-previews/earn-controller": "11.0.0-preview-cd26c284",
  "@metamask-previews/eip-5792-middleware": "2.0.0-preview-cd26c284",
  "@metamask-previews/eip-7702-internal-rpc-middleware": "0.1.0-preview-cd26c284",
  "@metamask-previews/eip1193-permission-middleware": "1.0.3-preview-cd26c284",
  "@metamask-previews/ens-controller": "19.0.0-preview-cd26c284",
  "@metamask-previews/error-reporting-service": "3.0.0-preview-cd26c284",
  "@metamask-previews/eth-block-tracker": "15.0.0-preview-cd26c284",
  "@metamask-previews/eth-json-rpc-middleware": "22.0.1-preview-cd26c284",
  "@metamask-previews/eth-json-rpc-provider": "6.0.0-preview-cd26c284",
  "@metamask-previews/foundryup": "1.0.1-preview-cd26c284",
  "@metamask-previews/gas-fee-controller": "26.0.0-preview-cd26c284",
  "@metamask-previews/gator-permissions-controller": "0.8.0-preview-cd26c284",
  "@metamask-previews/json-rpc-engine": "10.2.0-preview-cd26c284",
  "@metamask-previews/json-rpc-middleware-stream": "8.0.8-preview-cd26c284",
  "@metamask-previews/keyring-controller": "25.0.0-preview-cd26c284",
  "@metamask-previews/logging-controller": "7.0.1-preview-cd26c284",
  "@metamask-previews/message-manager": "14.1.0-preview-cd26c284",
  "@metamask-previews/messenger": "0.3.0-preview-cd26c284",
  "@metamask-previews/multichain-account-service": "4.0.1-preview-cd26c284",
  "@metamask-previews/multichain-api-middleware": "1.2.5-preview-cd26c284",
  "@metamask-previews/multichain-network-controller": "3.0.0-preview-cd26c284",
  "@metamask-previews/multichain-transactions-controller": "7.0.0-preview-cd26c284",
  "@metamask-previews/name-controller": "9.0.0-preview-cd26c284",
  "@metamask-previews/network-controller": "27.0.0-preview-cd26c284",
  "@metamask-previews/network-enablement-controller": "4.0.0-preview-cd26c284",
  "@metamask-previews/notification-services-controller": "21.0.0-preview-cd26c284",
  "@metamask-previews/permission-controller": "12.1.1-preview-cd26c284",
  "@metamask-previews/permission-log-controller": "5.0.0-preview-cd26c284",
  "@metamask-previews/phishing-controller": "16.1.0-preview-cd26c284",
  "@metamask-previews/polling-controller": "16.0.0-preview-cd26c284",
  "@metamask-previews/preferences-controller": "22.0.0-preview-cd26c284",
  "@metamask-previews/profile-metrics-controller": "1.0.0-preview-cd26c284",
  "@metamask-previews/profile-sync-controller": "27.0.0-preview-cd26c284",
  "@metamask-previews/rate-limit-controller": "7.0.0-preview-cd26c284",
  "@metamask-previews/remote-feature-flag-controller": "3.0.0-preview-cd26c284",
  "@metamask-previews/sample-controllers": "4.0.0-preview-cd26c284",
  "@metamask-previews/seedless-onboarding-controller": "7.1.0-preview-cd26c284",
  "@metamask-previews/selected-network-controller": "26.0.0-preview-cd26c284",
  "@metamask-previews/shield-controller": "4.0.0-preview-cd26c284",
  "@metamask-previews/signature-controller": "38.0.0-preview-cd26c284",
  "@metamask-previews/storage-service": "0.0.0-preview-cd26c284",
  "@metamask-previews/subscription-controller": "5.4.0-preview-cd26c284",
  "@metamask-previews/token-search-discovery-controller": "4.0.0-preview-cd26c284",
  "@metamask-previews/transaction-controller": "62.6.0-preview-cd26c284",
  "@metamask-previews/transaction-pay-controller": "10.5.0-preview-cd26c284",
  "@metamask-previews/user-operation-controller": "41.0.0-preview-cd26c284"
}

expect(mocks.SolAccountProvider.constructor).toHaveBeenCalledWith(
messenger,
providerConfigs?.[SolAccountProvider.NAME],
providerConfigs?.[SOL_ACCOUNT_PROVIDER_NAME],
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Unrelated to this PR, but I had to make this change to make the linter happy!

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.

2 participants