Merge pull request #442 from qwertyfinger/fix-biometric-permanent-lock

Remove note protection if biometric id is no longer available
This commit is contained in:
Tibor Kaputa 2021-09-08 09:54:06 +02:00 committed by GitHub
commit 578e845e1d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 65 additions and 39 deletions

View File

@ -56,7 +56,7 @@ android {
} }
dependencies { dependencies {
implementation 'com.github.SimpleMobileTools:Simple-Commons:dc3f4b619e' implementation 'com.github.SimpleMobileTools:Simple-Commons:8979ca8187'
implementation 'androidx.constraintlayout:constraintlayout:2.1.0' implementation 'androidx.constraintlayout:constraintlayout:2.1.0'
implementation 'androidx.documentfile:documentfile:1.0.1' implementation 'androidx.documentfile:documentfile:1.0.1'

View File

@ -11,8 +11,6 @@
android:name="android.hardware.faketouch" android:name="android.hardware.faketouch"
android:required="false" /> android:required="false" />
<uses-permission android:name="android.permission.USE_BIOMETRIC" />
<application <application
android:name=".App" android:name=".App"
android:allowBackup="true" android:allowBackup="true"

View File

@ -316,8 +316,11 @@ class MainActivity : SimpleActivity() {
} }
private fun initViewPager(wantedNoteId: Long? = null) { private fun initViewPager(wantedNoteId: Long? = null) {
NotesHelper(this).getNotes { NotesHelper(this).getNotes { notes ->
mNotes = it notes.filter { it.shouldBeUnlocked(this) }
.forEach(::removeProtection)
mNotes = notes
invalidateOptionsMenu() invalidateOptionsMenu()
mCurrentNote = mNotes[0] mCurrentNote = mNotes[0]
mAdapter = NotesPagerAdapter(supportFragmentManager, mNotes, this) mAdapter = NotesPagerAdapter(supportFragmentManager, mNotes, this)
@ -1084,19 +1087,21 @@ class MainActivity : SimpleActivity() {
performSecurityCheck( performSecurityCheck(
protectionType = mCurrentNote.protectionType, protectionType = mCurrentNote.protectionType,
requiredHash = mCurrentNote.protectionHash, requiredHash = mCurrentNote.protectionHash,
successCallback = { _, _ -> removeProtection() } successCallback = { _, _ -> removeProtection(mCurrentNote) }
) )
} }
private fun removeProtection() { private fun removeProtection(note: Note) {
mCurrentNote.protectionHash = "" note.protectionHash = ""
mCurrentNote.protectionType = PROTECTION_NONE note.protectionType = PROTECTION_NONE
NotesHelper(this).insertOrUpdateNote(mCurrentNote) { NotesHelper(this).insertOrUpdateNote(note) {
getCurrentFragment()?.apply { if (note == mCurrentNote) {
shouldShowLockedContent = true getCurrentFragment()?.apply {
checkLockState() shouldShowLockedContent = true
checkLockState()
}
invalidateOptionsMenu()
} }
invalidateOptionsMenu()
} }
} }

View File

@ -104,16 +104,18 @@ class WidgetConfigureActivity : SimpleActivity() {
if (mNotes.size == 1 && note == null) { if (mNotes.size == 1 && note == null) {
note = mNotes.first() note = mNotes.first()
performSecurityCheck( if (note.shouldBeUnlocked(this)) {
protectionType = note.protectionType,
requiredHash = note.protectionHash,
successCallback = { _, _ -> updateCurrentNote(note) },
failureCallback = { finish() }
)
} else {
if (note != null) {
updateCurrentNote(note) updateCurrentNote(note)
} else {
performSecurityCheck(
protectionType = note.protectionType,
requiredHash = note.protectionHash,
successCallback = { _, _ -> updateCurrentNote(note) },
failureCallback = { finish() }
)
} }
} else if (note != null) {
updateCurrentNote(note)
} }
} }
} }
@ -127,7 +129,7 @@ class WidgetConfigureActivity : SimpleActivity() {
RadioGroupDialog(this, items, mCurrentNoteId.toInt()) { RadioGroupDialog(this, items, mCurrentNoteId.toInt()) {
val selectedId = it as Int val selectedId = it as Int
val note = mNotes.firstOrNull { it.id!!.toInt() == selectedId } ?: return@RadioGroupDialog val note = mNotes.firstOrNull { it.id!!.toInt() == selectedId } ?: return@RadioGroupDialog
if (note.protectionType == PROTECTION_NONE) { if (note.protectionType == PROTECTION_NONE || note.shouldBeUnlocked(this)) {
updateCurrentNote(note) updateCurrentNote(note)
} else { } else {
performSecurityCheck( performSecurityCheck(

View File

@ -78,11 +78,13 @@ class ChecklistFragment : NoteFragment(), ChecklistItemsListener {
items.clear() items.clear()
note.value.split("\n").map { it.trim() }.filter { it.isNotBlank() }.forEachIndexed { index, value -> note.value.split("\n").map { it.trim() }.filter { it.isNotBlank() }.forEachIndexed { index, value ->
items.add(ChecklistItem( items.add(
id = index, ChecklistItem(
title = value, id = index,
isDone = false title = value,
)) isDone = false
)
)
} }
saveChecklist() saveChecklist()
@ -120,6 +122,10 @@ class ChecklistFragment : NoteFragment(), ChecklistItemsListener {
} }
override fun checkLockState() { override fun checkLockState() {
if (note == null) {
return
}
view.apply { view.apply {
checklist_content_holder.beVisibleIf(!note!!.isLocked() || shouldShowLockedContent) checklist_content_holder.beVisibleIf(!note!!.isLocked() || shouldShowLockedContent)
checklist_fab.beVisibleIf(!note!!.isLocked() || shouldShowLockedContent) checklist_fab.beVisibleIf(!note!!.isLocked() || shouldShowLockedContent)

View File

@ -176,6 +176,10 @@ class TextFragment : NoteFragment() {
fun removeTextWatcher() = view.text_note_view.removeTextChangedListener(textWatcher) fun removeTextWatcher() = view.text_note_view.removeTextChangedListener(textWatcher)
override fun checkLockState() { override fun checkLockState() {
if (note == null) {
return
}
view.apply { view.apply {
notes_counter.beVisibleIf((!note!!.isLocked() || shouldShowLockedContent) && config!!.showWordCount) notes_counter.beVisibleIf((!note!!.isLocked() || shouldShowLockedContent) && config!!.showWordCount)
notes_scrollview.beVisibleIf(!note!!.isLocked() || shouldShowLockedContent) notes_scrollview.beVisibleIf(!note!!.isLocked() || shouldShowLockedContent)
@ -263,11 +267,13 @@ class TextFragment : NoteFragment() {
text.removeSpan(span) text.removeSpan(span)
} }
Selection.setSelection(text, if (edit.before == null) { Selection.setSelection(
start text, if (edit.before == null) {
} else { start
start + edit.before.length } else {
}) start + edit.before.length
}
)
} }
fun redo() { fun redo() {
@ -285,11 +291,13 @@ class TextFragment : NoteFragment() {
text.removeSpan(o) text.removeSpan(o)
} }
Selection.setSelection(text, if (edit.after == null) { Selection.setSelection(
start text, if (edit.after == null) {
} else { start
start + edit.after.length } else {
}) start + edit.after.length
}
)
} }
fun isUndoAvailable() = textHistory.position > 0 fun isUndoAvailable() = textHistory.position > 0

View File

@ -6,6 +6,8 @@ import androidx.room.ColumnInfo
import androidx.room.Entity import androidx.room.Entity
import androidx.room.Index import androidx.room.Index
import androidx.room.PrimaryKey import androidx.room.PrimaryKey
import com.simplemobiletools.commons.extensions.isBiometricIdAvailable
import com.simplemobiletools.commons.helpers.PROTECTION_FINGERPRINT
import com.simplemobiletools.commons.helpers.PROTECTION_NONE import com.simplemobiletools.commons.helpers.PROTECTION_NONE
import java.io.File import java.io.File
@ -17,7 +19,8 @@ data class Note(
@ColumnInfo(name = "type") var type: Int, @ColumnInfo(name = "type") var type: Int,
@ColumnInfo(name = "path") var path: String, @ColumnInfo(name = "path") var path: String,
@ColumnInfo(name = "protection_type") var protectionType: Int, @ColumnInfo(name = "protection_type") var protectionType: Int,
@ColumnInfo(name = "protection_hash") var protectionHash: String) { @ColumnInfo(name = "protection_hash") var protectionHash: String
) {
fun getNoteStoredValue(context: Context): String? { fun getNoteStoredValue(context: Context): String? {
return if (path.isNotEmpty()) { return if (path.isNotEmpty()) {
@ -37,4 +40,8 @@ data class Note(
} }
fun isLocked() = protectionType != PROTECTION_NONE fun isLocked() = protectionType != PROTECTION_NONE
fun shouldBeUnlocked(context: Context): Boolean {
return protectionType == PROTECTION_FINGERPRINT && !context.isBiometricIdAvailable()
}
} }