[Release 3.2] [Domain control] Enable, disable or reset their 2FA#82135
[Release 3.2] [Domain control] Enable, disable or reset their 2FA#82135war-in wants to merge 39 commits intoExpensify:mainfrom
Conversation
…' into war-in/add-2FA-toggle-to-member-details # Conflicts: # src/ROUTES.ts # src/SCREENS.ts # src/libs/Navigation/AppNavigator/ModalStackNavigators/index.tsx # src/libs/Navigation/linkingConfig/RELATIONS/DOMAIN_TO_RHP.ts # src/libs/Navigation/linkingConfig/config.ts # src/libs/Navigation/types.ts # src/pages/domain/Members/DomainMembersPage.tsx
…to war-in/add-2FA-toggle-to-member-details # Conflicts: # src/languages/en.ts # src/libs/Navigation/linkingConfig/RELATIONS/DOMAIN_TO_RHP.ts # src/libs/actions/Domain.ts # src/pages/domain/Admins/DomainAdminDetailsPage.tsx # src/pages/domain/BaseDomainMembersPage.tsx
…etails_page' into war-in/add-2FA-toggle-to-member-details # Conflicts: # src/libs/Navigation/AppNavigator/ModalStackNavigators/index.tsx # src/pages/domain/Admins/DomainAdminDetailsPage.tsx # src/pages/domain/BaseDomainMemberDetailsComponent.tsx
…dd-2FA-toggle-to-member-details # Conflicts: # src/ROUTES.ts # src/SCREENS.ts # src/libs/Navigation/AppNavigator/ModalStackNavigators/index.tsx # src/libs/Navigation/linkingConfig/RELATIONS/DOMAIN_TO_RHP.ts # src/libs/Navigation/linkingConfig/config.ts # src/libs/Navigation/types.ts
…dd-2FA-toggle-to-member-details # Conflicts: # src/languages/en.ts # src/pages/domain/Members/DomainRequireTwoFactorAuthPage.tsx
…dd-2FA-toggle-to-member-details # Conflicts: # src/libs/Navigation/linkingConfig/RELATIONS/DOMAIN_TO_RHP.ts
…dd-2FA-toggle-to-member-details
…dd-2FA-toggle-to-member-details # Conflicts: # src/ROUTES.ts # src/languages/en.ts # src/libs/Navigation/AppNavigator/ModalStackNavigators/index.tsx # src/libs/Navigation/linkingConfig/RELATIONS/DOMAIN_TO_RHP.ts # src/pages/domain/BaseDomainMembersPage.tsx # src/pages/domain/Members/DomainMembersPage.tsx # src/types/onyx/DomainErrors.ts # src/types/onyx/DomainPendingActions.ts
…dd-2FA-toggle-to-member-details # Conflicts: # src/pages/domain/Members/DomainMembersSettingsPage.tsx # src/pages/domain/Members/DomainRequireTwoFactorAuthPage.tsx
…dd-2FA-toggle-to-member-details
…dd-2FA-toggle-to-member-details
…dd-2FA-toggle-to-member-details # Conflicts: # src/libs/actions/Domain.ts # src/pages/domain/BaseDomainMembersPage.tsx # src/pages/domain/Members/DomainMemberDetailsPage.tsx # src/pages/domain/Members/DomainMembersPage.tsx
…etails # Conflicts: # src/pages/domain/Admins/DomainAdminsPage.tsx # src/pages/domain/Members/DomainMembersPage.tsx # src/pages/domain/Members/DomainMembersSettingsPage.tsx # src/pages/domain/Members/DomainRequireTwoFactorAuthPage.tsx
|
Hey, I noticed you changed If you want to automatically generate translations for other locales, an Expensify employee will have to:
Alternatively, if you are an external contributor, you can run the translation script locally with your own OpenAI API key. To learn more, try running: npx ts-node ./scripts/generateTranslations.ts --helpTypically, you'd want to translate only what you changed by running |
…etails # Conflicts: # src/pages/domain/BaseDomainMembersPage.tsx # src/pages/domain/Members/DomainMembersPage.tsx
|
@codex review |
src/pages/domain/Members/TwoFactorAuth/DomainMemberResetTwoFactorAuthPage.tsx
Outdated
Show resolved
Hide resolved
There was a problem hiding this comment.
💡 Codex Review
Here are some automated review suggestions for this pull request.
Reviewed commit: 435557791f
ℹ️ About Codex in GitHub
Codex has been enabled to automatically review pull requests in this repo. Reviews are triggered when you
- Open a pull request for review
- Mark a draft as ready
- Comment "@codex review".
If Codex has suggestions, it will comment; otherwise it will react with 👍.
When you sign up for Codex through ChatGPT, Codex can also answer questions or update the PR, like "@codex address that feedback".
src/pages/domain/Members/TwoFactorAuth/DomainMemberForceTwoFactorAuthPage.tsx
Outdated
Show resolved
Hide resolved
# Conflicts: # src/languages/de.ts # src/languages/en.ts # src/languages/es.ts # src/languages/fr.ts # src/languages/it.ts # src/languages/ja.ts # src/languages/nl.ts # src/languages/pl.ts # src/languages/pt-BR.ts # src/languages/zh-hans.ts # src/libs/API/parameters/index.ts # src/libs/DomainUtils.ts # src/libs/Navigation/linkingConfig/RELATIONS/DOMAIN_TO_RHP.ts # src/libs/Navigation/types.ts # src/libs/actions/Domain.ts # src/pages/domain/Members/DomainMemberDetailsPage.tsx # src/pages/domain/Members/DomainMembersPage.tsx # src/types/onyx/DomainErrors.ts
Reviewer Checklist
Screenshots/VideosAndroid: HybridAppAndroid: mWeb ChromeiOS: HybridAppiOS: mWeb SafariMacOS: Chrome / Safari2026-02-20.13.37.10.mov |
There was a problem hiding this comment.
💡 Codex Review
Here are some automated review suggestions for this pull request.
Reviewed commit: 5036e4ebb0
ℹ️ About Codex in GitHub
Codex has been enabled to automatically review pull requests in this repo. Reviews are triggered when you
- Open a pull request for review
- Mark a draft as ready
- Comment "@codex review".
If Codex has suggestions, it will comment; otherwise it will react with 👍.
When you sign up for Codex through ChatGPT, Codex can also answer questions or update the PR, like "@codex address that feedback".
|
Changes look good |
@ZhenjaHorbach Those are only exempt emails, so when the toggle is on, the member is not in the exempt array and if the domain requires 2FA they'll have to set it up We don't consider SAML in this flow (like we don't in OD) Screen.Recording.2026-02-20.at.14.02.01.mov |
|
Small issue 2026-02-20.14.05.07.mov2026-02-20.14.06.14.mov |
Oh |
|
For some reason, after resetting 2FA, I was logged out 2026-02-20.13.37.10.mov |
Are you sure it's related? Have you been able to reproduce it again? |
|
Hmm, so you're resetting 2FA for yourself, right? Could you verify what happens in OD in this flow? |
|
Hmm ok, it looks like in OD you can't do it for admins 🤔 |
|
Actually yes |
|
@ZhenjaHorbach comments addressed |

Explanation of Change
PR implements
Force two-factor authenticationtoggle andReset two-factor authenticationbuttonFixed Issues
$ #79569
PROPOSAL:
Tests
domain/<domainID>/membersForce two-factor authenticationtoggle andReset two-factor authenticationentries in RHP4.1 When toggle was disabled - verify it's now enabled
4.2 If toggle is enabled
Reset two-factor authenticationReset two-factor authenticationitem in member detailsOffline tests
QA Steps
domain/<domainID>/membersForce two-factor authenticationtoggle andReset two-factor authenticationentries in RHP4.1 When toggle was disabled - verify it's now enabled
4.2 If toggle is enabled
Reset two-factor authenticationReset two-factor authenticationitem in member detailsPR Author Checklist
### Fixed Issuessection aboveTestssectionOffline stepssectionQA stepssectioncanBeMissingparam foruseOnyxtoggleReportand notonIconClick)src/languages/*files and using the translation methodSTYLE.md) were followedAvatar, I verified the components usingAvatarare working as expected)StyleUtils.getBackgroundAndBorderStyle(theme.componentBG))npm run compress-svg)Avataris modified, I verified thatAvataris working as expected in all cases)Designlabel and/or tagged@Expensify/designso the design team can review the changes.ScrollViewcomponent to make it scrollable when more elements are added to the page.mainbranch was merged into this PR after a review, I tested again and verified the outcome was still expected according to theTeststeps.Screenshots/Videos
Android: Native
Android: mWeb Chrome
iOS: Native
iOS: mWeb Safari
MacOS: Chrome / Safari
Reset 2FA flow:
Screen.Recording.2026-02-13.at.13.53.12.mov
Force 2FA flow:
Screen.Recording.2026-02-13.at.13.55.36.mov