Skip to content

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

Merged
mathieuartu merged 3 commits into
mainfrom
fix/dedupe-pairing-calls
Jun 4, 2026
Merged

fix(profile-sync-controller): deduplicate identical pairing calls#8984
mathieuartu merged 3 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 SDK caching around pairing; failures are not cached, preserving existing retry behavior with reduced duplicate traffic.

Overview
SRPJwtBearerAuth.pairSrpProfiles no longer fires a separate POST /api/v2/profile/pair for every overlapping caller. It now keys an in-memory cache by the sorted access-token set (order-insensitive), merges concurrent calls on one in-flight promise, and reuses a successful response for 30s (PAIR_DEDUPE_TTL_MS). Failed pair attempts are not cached so needsProfilePairing retries still hit the API.

Changelog and unit tests cover concurrent/sequential dedupe, token-order equivalence, TTL expiry, failure retry, and distinct token sets.

Reviewed by Cursor Bugbot for commit c792f2b. 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


await auth.pairSrpProfiles(['a', 'b'], 'a');
// Advance beyond the 30s dedupe window.
jest.setSystemTime(Date.now() + 30_001);
Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

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

WDYT about exporting PAIR_DEDUPE_TTL_MS and use PAIR_DEDUPE_TTL_MS + 1 here?

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.

Great idea! done here c792f2b

Copy link
Copy Markdown
Contributor

@ccharly ccharly left a comment

Choose a reason for hiding this comment

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

Perfect 💪

@mathieuartu mathieuartu added this pull request to the merge queue Jun 4, 2026
Merged via the queue into main with commit 4fa37b3 Jun 4, 2026
370 checks passed
@mathieuartu mathieuartu deleted the fix/dedupe-pairing-calls branch June 4, 2026 12:47
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.

2 participants