Skip to content

Account switching migration service#1741

Merged
mpbw2 merged 1 commit intoaccountswitchingfrom
accountswitching-migration-service
Jan 31, 2022
Merged

Account switching migration service#1741
mpbw2 merged 1 commit intoaccountswitchingfrom
accountswitching-migration-service

Conversation

@mpbw2
Copy link
Copy Markdown
Contributor

@mpbw2 mpbw2 commented Jan 31, 2022

Type of change

  • Bug fix
  • New feature development
  • Tech debt (refactoring, code cleanup, dependency upgrades, etc)
  • Build/deploy pipeline (DevOps)
  • Other

Objective

Migrate existing user data to the new multi-account storage pattern upon app update.

Code changes

  • MainApplication.cs: Init StateMigrationService with the required storage services
  • LockPage.xaml.cs: Remove avatar appearance condition since it will always been shown here
  • GroupingsPage.xaml.xs: Remove old v1-to-v2 migration code (some of which was moved to StateMigrationService)
  • BaseContentPage.cs: Change avatar appearance condition to the presence of any active account, which should only ever be false before the very first login
  • MobileStorageService.cs: Remove old migration keys & logic, add key for state version
  • AppIdService.cs: Reverted to pre-multi-account state due to infinite loop during migration when it was using the state service (this particular value isn't user-specific so it's ok if it isn't managed by the state service)
  • StateMigrationService.cs: Service that performs the migration. As the mobile app had a previous migration, that was moved here as the "1 to 2" migration. The multi-account migration was added as "2 to 3".
  • StateService.cs: Removed unused methods, added migration check and trigger, changed ProtectedPin to default storage (was never in secure storage), changed account removal to clean house since it felt dirty to have settings restored when logging back in after previously removing an account (doesn't apply to logout as a vault timeout action), set new account theme to the current theme to avoid the jarring effect of possible theme change when adding a new account
  • ServiceContainer.cs: Restore storageService to appIdService
  • Constants.cs: Add/remove appropriate keys
  • iOSCoreHelpers.cs: Init StateMigrationService with the required storage services

Testing requirements

Create account with previous (non-account-switching build) then update to account switching build and confirm all data and settings is still intact

Before you submit

  • I have added unit tests where it makes sense to do so (encouraged but not required)
  • This change requires a documentation update (notify the documentation team)
  • This change has particular deployment requirements (notify the DevOps team)

@mpbw2 mpbw2 requested review from a team and fedemkr January 31, 2022 15:04
Copy link
Copy Markdown
Member

@fedemkr fedemkr left a comment

Choose a reason for hiding this comment

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

I think it looks good, but I would split the StateMigrationService into the service coordinator itself and each migration in a different file:
StateMigrationFrom1To2.cs and StateMigrationFrom2To3.cs so that we have more cohesion on what each class has and does and the service just stays there as a coordinator between the different migrations. Furthermore, it prevents the file to be gigantic when more migrations are added, and to be more organized. Maybe I'm over-engineering this at this point and this could be looked at when we have more migrations, what do you think?

@mpbw2
Copy link
Copy Markdown
Contributor Author

mpbw2 commented Jan 31, 2022

Makes sense though I doubt we'll see a migration of this magnitude again any time soon. I'm for revisiting when it's time for another migration.

@mpbw2 mpbw2 merged commit 206c3a3 into accountswitching Jan 31, 2022
@mpbw2 mpbw2 deleted the accountswitching-migration-service branch January 31, 2022 19:47
fedemkr added a commit that referenced this pull request Jan 31, 2022
…dismiss

* accountswitching:
  single account migration to multi-account on app update (#1741)
  Cleared About information about push registration, just left it in DEBUG mode (#1742)
  Cleared Console.WriteLine for iOS push notifications issue (#1739)
  Autosync the updated translations (#1734)
mpbw2 added a commit that referenced this pull request Feb 23, 2022
* Account Switching (#1720)

* Account switching

* WIP

* wip

* wip

* updates to send test logic

* fixed Send tests

* fixes for theme handling on account switching and re-adding existing account

* switch fixes

* fixes

* fixes

* cleanup

* vault timeout fixes

* account list status enhancements

* logout fixes and token handling improvements

* merge latest (#1727)

* remove duplicate dependency

* fix for initial login token storage paradox (#1730)

* Fix avatar color update toolbar item issue on iOS for account switching (#1735)

* Updated account switching menu UI (#1733)

* updated account switching menu UI

* additional changes

* add key suffix to constant

* GetFirstLetters method tweaks

* Fix crash on account switching when logging out when having more than user at a time (#1740)

* single account migration to multi-account on app update (#1741)

* Account Switching Tap to dismiss (#1743)

* Added tap to dismiss on the Account switching overlay and improved a bit the code

* Fix account switching overlay background transparent on the proper place

* Fixed transparent background and the shadow on the account switching overlay

* Fix iOS top space on Account switching list overlay after modal (#1746)

* Fix top space added to Account switching list overlay after closing modal

* Fix top space added to Account switching list overlay after closing modal on lock, login and home views just in case we add modals in the future there as well

* Usability: dismiss account list on certain events (#1748)

* dismiss account list on certain events

* use new FireAndForget method for back button logic

* Create and use Account Switching overlay control (#1753)

* Added Account switching overlay control and its own ViewModel and refactored accordingly

* Fix account switching Accounts list binding update

* Implemented dismiss account switching overlay when changing tabs and when selecting the same tab. Also updated the deprecated listener on CustomTabbedRenderer on Android (#1755)

* Overriden Equals on AvatarImageSource so it doesn't get set multiple times when it's the same image thus producing blinking on tab chaged (#1756)

* Usability improvements for logout on vault timeout (#1781)

* accountswitching fixes (#1784)

* Fix for invalid PIN lock state when switching accounts (#1792)

* fix for pin lock flow

* named tuple values and updated async

* clear send service cache on account switch (#1796)

* Global theme and account removal (#1793)

* Global theme and account removal

* remove redundant call to hide account list overlay

* cleanup and additional tweaks

* add try/catch to remove account dialog flow

Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
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