Skip to content

Conversation

@mikesposito
Copy link
Member

@mikesposito mikesposito commented Jan 14, 2026

Explanation

ProfileMetricsController is being overhauled to rely on a timestamp-based delay for the first sending of metrics, rather than waiting for a second App Unlock event. This change ensures that metrics are sent even if the user only unlocks the app once during a session.

The delay is skipped immediately if:

  • A transaction is submitted
  • The user is already opted-in when KeyringController:unlock is fired (this covers both users who have opted-in in a previous session, and users who just onboarded and opted-in during onboarding).

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

@mikesposito

This comment was marked as outdated.

@mikesposito

This comment has been minimized.

@github-actions

This comment has been minimized.

@mikesposito mikesposito changed the title feat: add time-based delay for first metrics sending feat!: add time-based delay for first metrics sending Jan 14, 2026
@mikesposito

This comment has been minimized.

@github-actions

This comment has been minimized.

@mikesposito
Copy link
Member Author

@metamaskbot publish-previews

@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-2d6574b9",
  "@metamask-previews/accounts-controller": "35.0.1-preview-2d6574b9",
  "@metamask-previews/address-book-controller": "7.0.1-preview-2d6574b9",
  "@metamask-previews/analytics-controller": "1.0.0-preview-2d6574b9",
  "@metamask-previews/announcement-controller": "8.0.0-preview-2d6574b9",
  "@metamask-previews/app-metadata-controller": "2.0.0-preview-2d6574b9",
  "@metamask-previews/approval-controller": "8.0.0-preview-2d6574b9",
  "@metamask-previews/assets-controller": "0.0.0-preview-2d6574b9",
  "@metamask-previews/assets-controllers": "95.2.0-preview-2d6574b9",
  "@metamask-previews/base-controller": "9.0.0-preview-2d6574b9",
  "@metamask-previews/bridge-controller": "64.5.0-preview-2d6574b9",
  "@metamask-previews/bridge-status-controller": "64.4.2-preview-2d6574b9",
  "@metamask-previews/build-utils": "3.0.4-preview-2d6574b9",
  "@metamask-previews/chain-agnostic-permission": "1.4.0-preview-2d6574b9",
  "@metamask-previews/claims-controller": "0.4.1-preview-2d6574b9",
  "@metamask-previews/composable-controller": "12.0.0-preview-2d6574b9",
  "@metamask-previews/controller-utils": "11.18.0-preview-2d6574b9",
  "@metamask-previews/core-backend": "5.0.0-preview-2d6574b9",
  "@metamask-previews/delegation-controller": "2.0.0-preview-2d6574b9",
  "@metamask-previews/earn-controller": "11.0.0-preview-2d6574b9",
  "@metamask-previews/eip-5792-middleware": "2.1.0-preview-2d6574b9",
  "@metamask-previews/eip-7702-internal-rpc-middleware": "0.1.0-preview-2d6574b9",
  "@metamask-previews/eip1193-permission-middleware": "1.0.3-preview-2d6574b9",
  "@metamask-previews/ens-controller": "19.0.1-preview-2d6574b9",
  "@metamask-previews/error-reporting-service": "3.0.1-preview-2d6574b9",
  "@metamask-previews/eth-block-tracker": "15.0.0-preview-2d6574b9",
  "@metamask-previews/eth-json-rpc-middleware": "22.0.1-preview-2d6574b9",
  "@metamask-previews/eth-json-rpc-provider": "6.0.0-preview-2d6574b9",
  "@metamask-previews/foundryup": "1.0.1-preview-2d6574b9",
  "@metamask-previews/gas-fee-controller": "26.0.1-preview-2d6574b9",
  "@metamask-previews/gator-permissions-controller": "0.8.0-preview-2d6574b9",
  "@metamask-previews/json-rpc-engine": "10.2.0-preview-2d6574b9",
  "@metamask-previews/json-rpc-middleware-stream": "8.0.8-preview-2d6574b9",
  "@metamask-previews/keyring-controller": "25.0.0-preview-2d6574b9",
  "@metamask-previews/logging-controller": "7.0.1-preview-2d6574b9",
  "@metamask-previews/message-manager": "14.1.0-preview-2d6574b9",
  "@metamask-previews/messenger": "0.3.0-preview-2d6574b9",
  "@metamask-previews/multichain-account-service": "5.0.0-preview-2d6574b9",
  "@metamask-previews/multichain-api-middleware": "1.2.5-preview-2d6574b9",
  "@metamask-previews/multichain-network-controller": "3.0.1-preview-2d6574b9",
  "@metamask-previews/multichain-transactions-controller": "7.0.0-preview-2d6574b9",
  "@metamask-previews/name-controller": "9.0.0-preview-2d6574b9",
  "@metamask-previews/network-controller": "28.0.0-preview-2d6574b9",
  "@metamask-previews/network-enablement-controller": "4.0.0-preview-2d6574b9",
  "@metamask-previews/notification-services-controller": "21.0.0-preview-2d6574b9",
  "@metamask-previews/permission-controller": "12.2.0-preview-2d6574b9",
  "@metamask-previews/permission-log-controller": "5.0.0-preview-2d6574b9",
  "@metamask-previews/phishing-controller": "16.1.0-preview-2d6574b9",
  "@metamask-previews/polling-controller": "16.0.1-preview-2d6574b9",
  "@metamask-previews/preferences-controller": "22.0.0-preview-2d6574b9",
  "@metamask-previews/profile-metrics-controller": "2.0.0-preview-2d6574b9",
  "@metamask-previews/profile-sync-controller": "27.0.0-preview-2d6574b9",
  "@metamask-previews/ramps-controller": "3.0.0-preview-2d6574b9",
  "@metamask-previews/rate-limit-controller": "7.0.0-preview-2d6574b9",
  "@metamask-previews/remote-feature-flag-controller": "4.0.0-preview-2d6574b9",
  "@metamask-previews/sample-controllers": "4.0.1-preview-2d6574b9",
  "@metamask-previews/seedless-onboarding-controller": "7.1.0-preview-2d6574b9",
  "@metamask-previews/selected-network-controller": "26.0.1-preview-2d6574b9",
  "@metamask-previews/shield-controller": "4.1.0-preview-2d6574b9",
  "@metamask-previews/signature-controller": "38.0.1-preview-2d6574b9",
  "@metamask-previews/storage-service": "0.0.1-preview-2d6574b9",
  "@metamask-previews/subscription-controller": "5.4.0-preview-2d6574b9",
  "@metamask-previews/token-search-discovery-controller": "4.0.0-preview-2d6574b9",
  "@metamask-previews/transaction-controller": "62.9.1-preview-2d6574b9",
  "@metamask-previews/transaction-pay-controller": "11.0.1-preview-2d6574b9",
  "@metamask-previews/user-operation-controller": "41.0.1-preview-2d6574b9"
}

@mikesposito
Copy link
Member Author

@metamaskbot publish-previews

@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-fdf20ce5",
  "@metamask-previews/accounts-controller": "35.0.1-preview-fdf20ce5",
  "@metamask-previews/address-book-controller": "7.0.1-preview-fdf20ce5",
  "@metamask-previews/analytics-controller": "1.0.0-preview-fdf20ce5",
  "@metamask-previews/announcement-controller": "8.0.0-preview-fdf20ce5",
  "@metamask-previews/app-metadata-controller": "2.0.0-preview-fdf20ce5",
  "@metamask-previews/approval-controller": "8.0.0-preview-fdf20ce5",
  "@metamask-previews/assets-controller": "0.0.0-preview-fdf20ce5",
  "@metamask-previews/assets-controllers": "95.2.0-preview-fdf20ce5",
  "@metamask-previews/base-controller": "9.0.0-preview-fdf20ce5",
  "@metamask-previews/bridge-controller": "64.5.0-preview-fdf20ce5",
  "@metamask-previews/bridge-status-controller": "64.4.2-preview-fdf20ce5",
  "@metamask-previews/build-utils": "3.0.4-preview-fdf20ce5",
  "@metamask-previews/chain-agnostic-permission": "1.4.0-preview-fdf20ce5",
  "@metamask-previews/claims-controller": "0.4.1-preview-fdf20ce5",
  "@metamask-previews/composable-controller": "12.0.0-preview-fdf20ce5",
  "@metamask-previews/controller-utils": "11.18.0-preview-fdf20ce5",
  "@metamask-previews/core-backend": "5.0.0-preview-fdf20ce5",
  "@metamask-previews/delegation-controller": "2.0.0-preview-fdf20ce5",
  "@metamask-previews/earn-controller": "11.0.0-preview-fdf20ce5",
  "@metamask-previews/eip-5792-middleware": "2.1.0-preview-fdf20ce5",
  "@metamask-previews/eip-7702-internal-rpc-middleware": "0.1.0-preview-fdf20ce5",
  "@metamask-previews/eip1193-permission-middleware": "1.0.3-preview-fdf20ce5",
  "@metamask-previews/ens-controller": "19.0.1-preview-fdf20ce5",
  "@metamask-previews/error-reporting-service": "3.0.1-preview-fdf20ce5",
  "@metamask-previews/eth-block-tracker": "15.0.0-preview-fdf20ce5",
  "@metamask-previews/eth-json-rpc-middleware": "22.0.1-preview-fdf20ce5",
  "@metamask-previews/eth-json-rpc-provider": "6.0.0-preview-fdf20ce5",
  "@metamask-previews/foundryup": "1.0.1-preview-fdf20ce5",
  "@metamask-previews/gas-fee-controller": "26.0.1-preview-fdf20ce5",
  "@metamask-previews/gator-permissions-controller": "0.8.0-preview-fdf20ce5",
  "@metamask-previews/json-rpc-engine": "10.2.0-preview-fdf20ce5",
  "@metamask-previews/json-rpc-middleware-stream": "8.0.8-preview-fdf20ce5",
  "@metamask-previews/keyring-controller": "25.0.0-preview-fdf20ce5",
  "@metamask-previews/logging-controller": "7.0.1-preview-fdf20ce5",
  "@metamask-previews/message-manager": "14.1.0-preview-fdf20ce5",
  "@metamask-previews/messenger": "0.3.0-preview-fdf20ce5",
  "@metamask-previews/multichain-account-service": "5.0.0-preview-fdf20ce5",
  "@metamask-previews/multichain-api-middleware": "1.2.5-preview-fdf20ce5",
  "@metamask-previews/multichain-network-controller": "3.0.1-preview-fdf20ce5",
  "@metamask-previews/multichain-transactions-controller": "7.0.0-preview-fdf20ce5",
  "@metamask-previews/name-controller": "9.0.0-preview-fdf20ce5",
  "@metamask-previews/network-controller": "28.0.0-preview-fdf20ce5",
  "@metamask-previews/network-enablement-controller": "4.0.0-preview-fdf20ce5",
  "@metamask-previews/notification-services-controller": "21.0.0-preview-fdf20ce5",
  "@metamask-previews/permission-controller": "12.2.0-preview-fdf20ce5",
  "@metamask-previews/permission-log-controller": "5.0.0-preview-fdf20ce5",
  "@metamask-previews/phishing-controller": "16.1.0-preview-fdf20ce5",
  "@metamask-previews/polling-controller": "16.0.1-preview-fdf20ce5",
  "@metamask-previews/preferences-controller": "22.0.0-preview-fdf20ce5",
  "@metamask-previews/profile-metrics-controller": "2.0.0-preview-fdf20ce5",
  "@metamask-previews/profile-sync-controller": "27.0.0-preview-fdf20ce5",
  "@metamask-previews/ramps-controller": "3.0.0-preview-fdf20ce5",
  "@metamask-previews/rate-limit-controller": "7.0.0-preview-fdf20ce5",
  "@metamask-previews/remote-feature-flag-controller": "4.0.0-preview-fdf20ce5",
  "@metamask-previews/sample-controllers": "4.0.1-preview-fdf20ce5",
  "@metamask-previews/seedless-onboarding-controller": "7.1.0-preview-fdf20ce5",
  "@metamask-previews/selected-network-controller": "26.0.1-preview-fdf20ce5",
  "@metamask-previews/shield-controller": "4.1.0-preview-fdf20ce5",
  "@metamask-previews/signature-controller": "38.0.1-preview-fdf20ce5",
  "@metamask-previews/storage-service": "0.0.1-preview-fdf20ce5",
  "@metamask-previews/subscription-controller": "5.4.0-preview-fdf20ce5",
  "@metamask-previews/token-search-discovery-controller": "4.0.0-preview-fdf20ce5",
  "@metamask-previews/transaction-controller": "62.9.1-preview-fdf20ce5",
  "@metamask-previews/transaction-pay-controller": "11.0.1-preview-fdf20ce5",
  "@metamask-previews/user-operation-controller": "41.0.1-preview-fdf20ce5"
}

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