Skip to content

Commit

Permalink
fix login crash
Browse files Browse the repository at this point in the history
  • Loading branch information
hermannakos committed Nov 29, 2023
1 parent 0996bb1 commit 2bbc135
Show file tree
Hide file tree
Showing 10 changed files with 164 additions and 17 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
/*
* Copyright (C) 2023 - present Instructure, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*
*/

package com.instructure.student.di

import com.instructure.pandautils.utils.LogoutHelper
import com.instructure.student.util.StudentLogoutHelper
import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.components.SingletonComponent

@Module
@InstallIn(SingletonComponent::class)
class ApplicationModule {

@Provides
fun provideLogoutHelper(): LogoutHelper {
return StudentLogoutHelper()
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
/*
* Copyright (C) 2023 - present Instructure, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*
*/

package com.instructure.student.util

import com.instructure.loginapi.login.tasks.LogoutTask
import com.instructure.pandautils.room.offline.DatabaseProvider
import com.instructure.pandautils.utils.LogoutHelper
import com.instructure.student.tasks.StudentLogoutTask

class StudentLogoutHelper : LogoutHelper {
override fun logout(databaseProvider: DatabaseProvider) {
StudentLogoutTask(LogoutTask.Type.LOGOUT, databaseProvider = databaseProvider).execute()
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,12 +16,13 @@
*/
package com.instructure.teacher.di

import com.instructure.pandautils.utils.LogoutHelper
import com.instructure.teacher.utils.TeacherLogoutHelper
import com.instructure.teacher.utils.TeacherPrefs
import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
import dagger.hilt.components.SingletonComponent
import javax.inject.Singleton

/**
* Module that provides all the application scope dependencies, that are not related to other module.
Expand All @@ -34,4 +35,9 @@ class ApplicationModule {
fun provideTeacherPrefs(): TeacherPrefs {
return TeacherPrefs
}

@Provides
fun provideLogoutHelper(): LogoutHelper {
return TeacherLogoutHelper()
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
/*
* Copyright (C) 2023 - present Instructure, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*
*/

package com.instructure.teacher.utils

import com.instructure.loginapi.login.tasks.LogoutTask
import com.instructure.pandautils.room.offline.DatabaseProvider
import com.instructure.pandautils.utils.LogoutHelper
import com.instructure.teacher.tasks.TeacherLogoutTask

class TeacherLogoutHelper : LogoutHelper {

override fun logout(databaseProvider: DatabaseProvider) {
TeacherLogoutTask(LogoutTask.Type.LOGOUT).execute()
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ object ApiPrefs : PrefManager(PREFERENCE_FILE_NAME) {

/* Non-masquerading Prefs */
internal var originalDomain by StringPref("", "domain")
private var originalUser: User? by GsonPref(User::class.java, null, "user")
private var originalUser: User? by GsonPref(User::class.java, null, "user", false)

var selectedLocale by StringPref(ACCOUNT_LOCALE)

Expand All @@ -84,7 +84,7 @@ object ApiPrefs : PrefManager(PREFERENCE_FILE_NAME) {
var isMasqueradingFromQRCode by BooleanPref()
var masqueradeId by LongPref(-1L)
internal var masqueradeDomain by StringPref()
internal var masqueradeUser: User? by GsonPref(User::class.java, null, "masq-user")
internal var masqueradeUser: User? by GsonPref(User::class.java, null, "masq-user", false)

// Used to determine if a student can generate a pairing code, saved during splash
var canGeneratePairingCode by NBooleanPref()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -390,7 +390,8 @@ class ColorPref(@ColorRes defaultValue: Int, keyName: String? = null) : Pref<Int
class GsonPref<T>(
private val klazz: Class<T>,
defaultValue: T? = null,
keyName: String? = null
private val keyName: String? = null,
private val async: Boolean = true
) : Pref<T?>(defaultValue, keyName) {

private var cachedObject: T? = null
Expand All @@ -413,6 +414,14 @@ class GsonPref<T>(
}
return this
}

override fun setValue(thisRef: PrefManager, property: KProperty<*>, value: T?) {
if (async) {
super.setValue(thisRef, property, value)
} else {
thisRef.editor.setValue(keyName ?: property.name, value).commit()
}
}
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@ class LoginViewModel @Inject constructor(
fun checkLogin(checkToken: Boolean, checkElementary: Boolean): LiveData<Event<LoginResultAction>> {
viewModelScope.launch {
try {
waitForUser()
val offlineEnabled = featureFlagProvider.offlineEnabled()
val offlineLogin = offlineEnabled && !networkStateProvider.isOnline()
if (checkToken && !offlineLogin) {
Expand All @@ -71,14 +70,6 @@ class LoginViewModel @Inject constructor(
return loginResultAction
}

// We need to wait for the user to be set in ApiPrefs
private suspend fun waitForUser() {
repeat(30) {
if (apiPrefs.user != null) return
delay(100)
}
}

private suspend fun checkTermsAcceptance(canvasForElementary: Boolean, offlineLogin: Boolean = false) {
val authenticatedSession = oauthManager.getAuthenticatedSessionAsync("${apiPrefs.fullDomain}/users/self").await()
val requiresTermsAcceptance = authenticatedSession.dataOrNull?.requiresTermsAcceptance ?: false
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,10 @@
package com.instructure.pandautils.di

import android.content.Context
import com.google.firebase.crashlytics.FirebaseCrashlytics
import com.instructure.pandautils.room.offline.DatabaseProvider
import com.instructure.pandautils.room.offline.OfflineDatabaseProvider
import com.instructure.pandautils.utils.LogoutHelper
import dagger.Module
import dagger.Provides
import dagger.hilt.InstallIn
Expand All @@ -34,7 +36,7 @@ class OfflineDatabaseProviderModule {

@Provides
@Singleton
fun provideOfflineDatabaseProvider(@ApplicationContext context: Context): DatabaseProvider {
return OfflineDatabaseProvider(context)
fun provideOfflineDatabaseProvider(@ApplicationContext context: Context, logoutHelper: LogoutHelper, firebaseCrashlytics: FirebaseCrashlytics): DatabaseProvider {
return OfflineDatabaseProvider(context, logoutHelper, firebaseCrashlytics)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,32 @@
package com.instructure.pandautils.room.offline

import android.content.Context
import android.widget.Toast
import androidx.appcompat.app.AlertDialog
import androidx.room.Room
import com.google.firebase.crashlytics.FirebaseCrashlytics
import com.instructure.pandautils.R
import com.instructure.pandautils.utils.LogoutHelper
import com.instructure.pandautils.utils.toast

private const val OFFLINE_DB_PREFIX = "offline-db-"

class OfflineDatabaseProvider(private val context: Context) : DatabaseProvider {
class OfflineDatabaseProvider(
private val context: Context,
private val logoutHelper: LogoutHelper,
private val firebaseCrashlytics: FirebaseCrashlytics
) : DatabaseProvider {

private val dbMap = mutableMapOf<Long, OfflineDatabase>()

override fun getDatabase(userId: Long?): OfflineDatabase {
if (userId == null) throw IllegalStateException("You can't access the database while logged out")
if (userId == null) {
logoutHelper.logout(this)
firebaseCrashlytics.recordException(IllegalStateException("You can't access the database while logged out"))
return Room.databaseBuilder(context, OfflineDatabase::class.java, "dummy-db")
.addMigrations(*offlineDatabaseMigrations)
.build()
}

return dbMap.getOrPut(userId) {
Room.databaseBuilder(context, OfflineDatabase::class.java, "$OFFLINE_DB_PREFIX$userId")
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
/*
* Copyright (C) 2023 - present Instructure, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*
*/

package com.instructure.pandautils.utils

import com.instructure.pandautils.room.offline.DatabaseProvider

interface LogoutHelper {

fun logout(databaseProvider: DatabaseProvider)
}

0 comments on commit 2bbc135

Please sign in to comment.