mirror of
https://github.com/SimpleMobileTools/Simple-Notes.git
synced 2025-04-04 18:51:14 +02:00
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:
commit
578e845e1d
@ -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'
|
||||||
|
|
||||||
|
@ -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"
|
||||||
|
@ -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()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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(
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
|
@ -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()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user