-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add getMostRecentServerUrl function #5440
Conversation
@migbot: Adding the "do-not-merge/release-note-label-needed" label because no release-note block was detected, please follow our release note process to remove it. I understand the commands that are listed here |
1 similar comment
@migbot: Adding the "do-not-merge/release-note-label-needed" label because no release-note block was detected, please follow our release note process to remove it. I understand the commands that are listed here |
I like the idea about having a timestamp, but we should also track if the user is logged in or not. I can see how that will be more beneficial than the current implementation, as it would allow us to select the db we want based on the timestamps and it will also be easier to maintain. Do we want to merge this in the meantime while we do the necesary changes? |
@avinashlng1080 Can I merge as is and would you be able to take care of the changes for tests as well as adding a timestamp field to the Server model? |
I updated the code before looking at this PR. The
Let's agree on the final naming conventions to be used and I will rename them.
Yes I can tackle this one and it is a better solution. It will impact the schema, model, database manager and data operators/handlers. We'll need to update this value each time the user switches server.
Let's see first if you can use the refactored method. |
/release-note-none |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Apart from that one comment, the PR is good. I also tested manually on simulator and verified if the databases were being created and populated.
Assuming that Avinash would approve after the small typo fix. Going to merge now so I can get the |
* MM_35115: ADDED select_server screen * MM_35115: ADDED select_server screen * MM_35115: ADDED files on which select_server is dependent * MM_35115: ADDED react-native-button * MM_35115: Fixing TS issues [IN PROGRESS] * MM_35115: Started withObservables [IN PROGRESS] * MM_35115: Started withObservables [IN PROGRESS] * MM_35115: withObservables - defaulting when no connection is available [IN PROGRESS] * MM_35115: withObservables - some code clean up [IN PROGRESS] * MM_35115: withObservables - some code clean up [IN PROGRESS] * MM_35115: withObservables - some code clean up [IN PROGRESS] * MM_35115: Substituting mapDispatchToProps [IN PROGRESS] * MM_35115: Substituting mapDispatchToProps [IN PROGRESS] * MM_35115: Substituting mapDispatchToProps [IN PROGRESS] * MM_35115: Removed resetPing action [IN PROGRESS] * MM_35115: ADDED app/client * MM_35115: Preparing scheduleExpiredNotification * MM_35115: Adding some todos * Server & LoginOptions * Use default server if available and autoconnect if configured * Fix login header & manual server url * MM_35115: Login Options[IN PROGRESS] * MM_35115: Login screen - email [IN PROGRESS] * MM_35115: Login screen - email [IN PROGRESS] * MM_35115: Login screen - email - login api call [IN PROGRESS] * MM_35115: Login screen - email - login api call [IN PROGRESS] * MM_35115: Login screen - email - saving to server db [IN PROGRESS] * MM_35115: Login screen - email - saving to System, Preferences to db [IN PROGRESS] * MM_35115: Login screen - enforcing unique check on System entity [IN PROGRESS] * MM_35115: Login screen - writing TeamMembership [IN PROGRESS] * MM_35115: Login screen - writing Teams [IN PROGRESS] * MM_35115: Login screen [IN PROGRESS] * MM_35115: Login screen- Refactored DataOperator handlers [IN PROGRESS] * MM_35115: Login screen - Proper clean up [IN PROGRESS] * MM_35115: Login screen - completeLogin [IN PROGRESS] * MM_35115: Improving DataOperator * MM_35115: Improving DataOperator * MM_35115: 80% DONE - login with email and password - some todos * MM_35115: 80% DONE - login with email and password - some todos * MM_35115: 80% DONE - login with email and password - some todos * MM_35115: Removing unused app/queries folder * MM_35115: Clean up * MM_35115: Clean up * MM_35115: Clean up * MM_35115: Clean up * MM_35115: Clean up * MM_35115: Adding roles for MYTEAM * MM_35115: Code clean up * MM_35115: Code clean up * MM_35115: Code clean up * MM_35115: Adding rn-fetch-blob for Android * MM_35115: Code clean up * MM_35115: Code clean up * MM_35115: Added test setup * MM_35115: Fix database utils * MM_35115: ADDED loadRolesIfNeeded * MM_35115: Fix TS issue * MM_35115: ADDED Tests setup * MM_35115: Fix TS issues * MM_35115: Fix TS issues * MM_35115: Fix TS issues * MM_35115: Added alternative to site name * MM_35115: Added alternative to site name * MM_35115: Removed hardcoded values * MM_35115: Clean up * MM_35115 - Fixed Android platform check instead of hermes * MM_35115 - Replaced emptyErrorHandlingFunction with emptyFunction * MM_35115 : Implemented TS fixes * Update index.ts * MM-35115 - Fix react-test-renderer issue * MM_35115 - Optimizing DatabaseManager * MM_35115 : Implemented getDatabaseConnection * MM_35115 : Refactoring set/getActiveDatabase to use flag record * MM_35115 : Refactored active database to use flag in Global entity * MM_35115 : Updated manual database manager test * MM_35115 : Fix operator/utils/test * MM_35115 : Fix for base_handler * MM_35115 : Fix test issues with Handlers * MM_35115 : Fix test issues with prepareRecords * MM_35115 : Fix wrapper test issue * MM_35115 : Updated getMostRecentServerConnection to return the serverUrl as well as the connection * MM_35115 : Refactored the way we call DataOperator * MM_35115 : Updated database manager mock * Add getMostRecentServerUrl function (#5440) * fix: add getMostRecentServerUrl func * fix: add ts and tsx to editorconfig * fix: rename functions * fix: return type * Fix unit test setup * fix login screen unit tests * MM-36205 [GEKIDOU] Login Flow SSO (#5454) * MM_35115: Starting LoginOptions SSO * MM_36205: SSO [IN PROGRESS] * MM_36205 : SSO [ IN PROGRESS ] * Update sso_with_redirect_url.tsx * MM_36205 : SSO Tests [ IN PROGRESS ] * MM_36205 : Passing serverUrl to SSO screen * Update sso.test.tsx * Fix ViewTypes imports and keyMirror method * MM_36205 : Code clean up * Fix : Clean up imports * Update: Aligning with PR 5452 * Fix: AndroidManifest file to include redirection ofr scheme mmauthbeta * refactor: SSO Login method via Gitlab now navigates to Channel screen * refactor: SSO Login without redirectURL is also working * feat: SSO - main test completed * feat: ADDED test for sso_with_redirect_url * fix : eslint correction * fix: Updated Loading component name * fix : code clean up from reviews * fix: reviews check * fix: Added mmauthbeta into info.plist * Revert "fix: Added mmauthbeta into info.plist" This reverts commit d87cc23. * Update Info.plist * Update AppDelegate.m * feat: ADDED Forgot Password - Test [ IN PROGRESS ] * feat: Forgot Password - Completed & Tested * fix: Including MFA screen [ IN PROGRESS ] * MFA - Properly tested * Properly testing forgot_password screen * Fix login.test.tsx * Fix SSO method calls chain * Update index.tsx * Sort imports for sceen/navigation * fix: Reviews * Update signing + act in test * Removed todo comment on MFA * feedback review * fix login tests Co-authored-by: Avinash Lingaloo <> Co-authored-by: Elias Nahum <nahumhbl@gmail.com> * App initialization refactor (#5430) * fix: initial init refactor * fix: await isServerPresent * fix: more refactor * fix: move out launch functions * fix: remove comment * fix: update credential functions * fix: refactor launch functions * fix: deep link parsing * fix: lint change * fix: update deeplink and notification handlers * fix: indentation * fix: add relaunchApp * fix eslint * refactor launchProps and autoconnect server for deeplink * fix: use undefined * fix: define OptionalLaunchProps * fix: Android - handle server URL in push notification * fix: rename func * fix: use boolean launchError instead * fix: use DatabaseModule * fix: use DatabaseHelper instead * fix: remove unnecessary null check * fix: iOS - support for serverUrl * fix: iOS - extract serverUrl in reply action * fix: iOS - expose objc specific func * fix: remove unnecessary deviceToken param * fix: return if device is untrusted Co-authored-by: Elias Nahum <nahumhbl@gmail.com> * fix: bye bye modulePaths * fix: ios build * chore: remove unused aliases from babel.config * chore: fix dependency format in package-lock.json * chore: remove transparent window background color for android AppTheme * chore: remove mattermost.js and use index.ts as app entry * fix: login flow screens theme * fix: Launch types * chore: remove OptionalLaunchProps type * fix: url utils unit tests * chore: update en.json Co-authored-by: Elias Nahum <nahumhbl@gmail.com> Co-authored-by: Avinash Lingaloo <> Co-authored-by: Elias Nahum <nahumhbl@gmail.com> Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
In the init process I need to know what the active server URL is. I extracted out querying of that value into
getMostRecentServerUrl
and then used that function ingetMostRecentServerDatabase
which used to be calledgetMostRecentServerConnection
. There's more work to be done here (like tests and mocks) but wanted your thoughts. Regarding the term "connection" in the previous method, I'd rather use "database" as that's what is actually being returned. Regarding the term "most recent", I think we should use "active" instead, at least in the functions here. More broadly, maybe we can get rid of theRECENTLY_VIEWED_SERVERS
and instead add some timestamp field (ie, lastViewed) to the Server model. We could then query for active server.