Skip to content

fix(profile-sync-controller): deduplicate identical pairing calls#8984

Open
mathieuartu wants to merge 2 commits into
mainfrom
fix/dedupe-pairing-calls
Open

fix(profile-sync-controller): deduplicate identical pairing calls#8984
mathieuartu wants to merge 2 commits into
mainfrom
fix/dedupe-pairing-calls

Conversation

@mathieuartu
Copy link
Copy Markdown
Contributor

@mathieuartu mathieuartu commented Jun 3, 2026

Explanation

References

Related to: https://consensyssoftware.atlassian.net/browse/MUL-1865

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

Low Risk
Localized deduplication around an existing pairing API call; failures are uncached and successful cache is short-lived, so pairing semantics and retries stay the same aside from fewer duplicate requests.

Overview
SRPJwtBearerAuth.pairSrpProfiles no longer issues a separate POST /api/v2/profile/pair for every overlapping trigger. It builds an order-insensitive cache key from the access-token set, coalesces concurrent callers on one in-flight promise, and reuses a successful result for 30 seconds so rapid sequential retries (unlock, multiple UI surfaces, performSignIn) collapse to a single request.

Failed pair attempts are not cached, so the existing needsProfilePairing retry path can still hit the API on the next try. Tests and the package changelog document the behavior.

Reviewed by Cursor Bugbot for commit 3a34409. Bugbot is set up for automated code reviews on this repo. Configure here.

@mathieuartu mathieuartu self-assigned this Jun 3, 2026
@mathieuartu mathieuartu requested a review from a team as a code owner June 3, 2026 10:16
@mathieuartu mathieuartu requested a review from a team as a code owner June 3, 2026 10:16
@mathieuartu
Copy link
Copy Markdown
Contributor Author

@metamaskbot publish-preview

@github-actions
Copy link
Copy Markdown
Contributor

github-actions Bot commented Jun 3, 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.5.0-preview-3a34409
@metamask-previews/accounts-controller@38.1.2-preview-3a34409
@metamask-previews/address-book-controller@7.1.2-preview-3a34409
@metamask-previews/ai-controllers@0.7.0-preview-3a34409
@metamask-previews/analytics-controller@1.1.0-preview-3a34409
@metamask-previews/analytics-data-regulation-controller@0.0.0-preview-3a34409
@metamask-previews/announcement-controller@8.1.0-preview-3a34409
@metamask-previews/app-metadata-controller@2.0.1-preview-3a34409
@metamask-previews/approval-controller@9.0.1-preview-3a34409
@metamask-previews/assets-controller@8.3.0-preview-3a34409
@metamask-previews/assets-controllers@108.4.0-preview-3a34409
@metamask-previews/authenticated-user-storage@2.0.0-preview-3a34409
@metamask-previews/base-controller@9.1.0-preview-3a34409
@metamask-previews/base-data-service@0.1.3-preview-3a34409
@metamask-previews/bridge-controller@73.2.0-preview-3a34409
@metamask-previews/bridge-status-controller@72.0.0-preview-3a34409
@metamask-previews/build-utils@3.0.4-preview-3a34409
@metamask-previews/chain-agnostic-permission@1.6.1-preview-3a34409
@metamask-previews/chomp-api-service@3.1.0-preview-3a34409
@metamask-previews/claims-controller@0.5.2-preview-3a34409
@metamask-previews/client-controller@1.0.1-preview-3a34409
@metamask-previews/compliance-controller@2.1.0-preview-3a34409
@metamask-previews/composable-controller@12.0.1-preview-3a34409
@metamask-previews/config-registry-controller@0.4.0-preview-3a34409
@metamask-previews/connectivity-controller@0.2.0-preview-3a34409
@metamask-previews/controller-utils@12.1.0-preview-3a34409
@metamask-previews/core-backend@6.3.1-preview-3a34409
@metamask-previews/delegation-controller@3.0.1-preview-3a34409
@metamask-previews/earn-controller@12.2.0-preview-3a34409
@metamask-previews/eip-5792-middleware@3.0.4-preview-3a34409
@metamask-previews/eip-7702-internal-rpc-middleware@0.1.1-preview-3a34409
@metamask-previews/eip1193-permission-middleware@2.0.1-preview-3a34409
@metamask-previews/ens-controller@19.1.3-preview-3a34409
@metamask-previews/eth-block-tracker@15.0.1-preview-3a34409
@metamask-previews/eth-json-rpc-middleware@23.1.3-preview-3a34409
@metamask-previews/eth-json-rpc-provider@6.0.1-preview-3a34409
@metamask-previews/foundryup@1.0.1-preview-3a34409
@metamask-previews/gas-fee-controller@26.2.2-preview-3a34409
@metamask-previews/gator-permissions-controller@4.2.0-preview-3a34409
@metamask-previews/geolocation-controller@0.1.3-preview-3a34409
@metamask-previews/json-rpc-engine@10.5.0-preview-3a34409
@metamask-previews/json-rpc-middleware-stream@8.0.8-preview-3a34409
@metamask-previews/keyring-controller@26.0.0-preview-3a34409
@metamask-previews/logging-controller@8.0.2-preview-3a34409
@metamask-previews/message-manager@14.1.2-preview-3a34409
@metamask-previews/messenger@1.2.0-preview-3a34409
@metamask-previews/messenger-cli@0.2.0-preview-3a34409
@metamask-previews/money-account-balance-service@1.0.2-preview-3a34409
@metamask-previews/money-account-controller@0.3.1-preview-3a34409
@metamask-previews/money-account-upgrade-controller@2.0.3-preview-3a34409
@metamask-previews/multichain-account-service@10.0.1-preview-3a34409
@metamask-previews/multichain-api-middleware@3.1.2-preview-3a34409
@metamask-previews/multichain-network-controller@3.1.2-preview-3a34409
@metamask-previews/multichain-transactions-controller@7.1.0-preview-3a34409
@metamask-previews/name-controller@9.1.2-preview-3a34409
@metamask-previews/network-controller@32.0.0-preview-3a34409
@metamask-previews/network-enablement-controller@5.2.0-preview-3a34409
@metamask-previews/notification-services-controller@24.1.2-preview-3a34409
@metamask-previews/passkey-controller@2.0.1-preview-3a34409
@metamask-previews/permission-controller@13.1.1-preview-3a34409
@metamask-previews/permission-log-controller@5.1.0-preview-3a34409
@metamask-previews/perps-controller@7.0.0-preview-3a34409
@metamask-previews/phishing-controller@17.2.0-preview-3a34409
@metamask-previews/polling-controller@16.0.6-preview-3a34409
@metamask-previews/preferences-controller@23.1.0-preview-3a34409
@metamask-previews/profile-metrics-controller@3.1.5-preview-3a34409
@metamask-previews/profile-sync-controller@28.1.1-preview-3a34409
@metamask-previews/ramps-controller@14.1.0-preview-3a34409
@metamask-previews/rate-limit-controller@7.0.1-preview-3a34409
@metamask-previews/react-data-query@0.2.1-preview-3a34409
@metamask-previews/remote-feature-flag-controller@4.2.1-preview-3a34409
@metamask-previews/sample-controllers@5.0.1-preview-3a34409
@metamask-previews/seedless-onboarding-controller@10.0.0-preview-3a34409
@metamask-previews/selected-network-controller@26.1.3-preview-3a34409
@metamask-previews/shield-controller@5.1.2-preview-3a34409
@metamask-previews/signature-controller@39.2.3-preview-3a34409
@metamask-previews/snap-account-service@0.2.1-preview-3a34409
@metamask-previews/social-controllers@2.2.1-preview-3a34409
@metamask-previews/storage-service@1.0.1-preview-3a34409
@metamask-previews/subscription-controller@6.1.3-preview-3a34409
@metamask-previews/transaction-controller@66.0.0-preview-3a34409
@metamask-previews/transaction-pay-controller@23.1.0-preview-3a34409
@metamask-previews/user-operation-controller@41.2.3-preview-3a34409
@metamask-previews/wallet@2.0.0-preview-3a34409

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

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant