mirror of
https://github.com/SimpleMobileTools/Simple-Notes.git
synced 2025-04-04 02:31:08 +02:00
Remove note protection if biometric id is no longer available
This check is done to avoid user not being able to unlock the note if he removes biometric id from phone settings.
This commit is contained in:
parent
e9131cabe5
commit
a2faa7107f
@ -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.isBiometricLockUnavailable(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()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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.isBiometricLockUnavailable(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.isBiometricLockUnavailable(this)) {
|
||||||
updateCurrentNote(note)
|
updateCurrentNote(note)
|
||||||
} else {
|
} else {
|
||||||
performSecurityCheck(
|
performSecurityCheck(
|
||||||
|
@ -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,8 @@ 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)
|
||||||
|
@ -176,6 +176,8 @@ 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 +265,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 +289,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
|
||||||
|
@ -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 isBiometricLockUnavailable(context: Context): Boolean {
|
||||||
|
return protectionType == PROTECTION_FINGERPRINT && !context.isBiometricIdAvailable()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user