fix: default timeout protection

This commit is contained in:
Andries Smit 2022-03-18 13:24:01 +01:00
parent 3fe1d2a0d1
commit 2e476b9101
2 changed files with 5 additions and 3 deletions

View file

@ -87,9 +87,9 @@
android:key="@string/key_protection_timeout"
android:title="@string/protection_timeout_title"
android:summary="@string/protection_timeout_summary"
app:defaultValue="0"
app:defaultValue="1"
validate:maxNumber="180"
validate:minNumber="0"
validate:minNumber="1"
validate:testType="numeric" />
</PreferenceCategory>

View file

@ -16,7 +16,6 @@ class ProtectionCheck @Inject constructor(
) {
private var lastAuthorization = mutableListOf(0L, 0L, 0L)
private val timeout = TimeUnit.SECONDS.toMillis(sp.getInt(R.string.key_protection_timeout, 0).toLong())
enum class Protection {
PREFERENCES,
@ -75,6 +74,9 @@ class ProtectionCheck @Inject constructor(
}
private fun activeSession(protection: Protection): Boolean {
var timeout = TimeUnit.SECONDS.toMillis(sp.getInt(R.string.key_protection_timeout, 0).toLong())
// Default timeout to pass the resume check at start of an activity
timeout = if (timeout < 1000) 1000 else timeout
val last = lastAuthorization[protection.ordinal]
val diff = dateUtil.now() - last
return diff < timeout