Revert "fix: Base64 encoder as external library"

This reverts commit 13f2003fed.
This commit is contained in:
J-Jamet 2023-05-14 21:56:11 +02:00
parent 111a77d984
commit 09cf8aabf6
11 changed files with 44 additions and 48 deletions

View file

@ -25,9 +25,9 @@ import com.kunzisoft.keepass.app.database.CipherDatabaseAction
import com.kunzisoft.keepass.app.database.FileDatabaseHistoryAction import com.kunzisoft.keepass.app.database.FileDatabaseHistoryAction
import com.kunzisoft.keepass.database.ContextualDatabase import com.kunzisoft.keepass.database.ContextualDatabase
import com.kunzisoft.keepass.database.MainCredential import com.kunzisoft.keepass.database.MainCredential
import com.kunzisoft.keepass.database.element.binary.BinaryData
import com.kunzisoft.keepass.database.exception.DatabaseInputException import com.kunzisoft.keepass.database.exception.DatabaseInputException
import com.kunzisoft.keepass.database.exception.UnknownDatabaseLocationException import com.kunzisoft.keepass.database.exception.UnknownDatabaseLocationException
import com.kunzisoft.keepass.database.helper.MemoryHelper.canMemoryBeAllocatedInRAM
import com.kunzisoft.keepass.hardware.HardwareKey import com.kunzisoft.keepass.hardware.HardwareKey
import com.kunzisoft.keepass.model.CipherEncryptDatabase import com.kunzisoft.keepass.model.CipherEncryptDatabase
import com.kunzisoft.keepass.settings.PreferencesUtil import com.kunzisoft.keepass.settings.PreferencesUtil
@ -69,7 +69,7 @@ class LoadDatabaseRunnable(
mReadonly, mReadonly,
binaryDir, binaryDir,
{ memoryWanted -> { memoryWanted ->
canMemoryBeAllocatedInRAM(context, memoryWanted) BinaryData.canMemoryBeAllocatedInRAM(context, memoryWanted)
}, },
mFixDuplicateUUID, mFixDuplicateUUID,
progressTaskUpdater progressTaskUpdater

View file

@ -23,9 +23,9 @@ import android.content.Context
import android.net.Uri import android.net.Uri
import com.kunzisoft.keepass.database.ContextualDatabase import com.kunzisoft.keepass.database.ContextualDatabase
import com.kunzisoft.keepass.database.MainCredential import com.kunzisoft.keepass.database.MainCredential
import com.kunzisoft.keepass.database.element.binary.BinaryData
import com.kunzisoft.keepass.database.exception.DatabaseException import com.kunzisoft.keepass.database.exception.DatabaseException
import com.kunzisoft.keepass.database.exception.UnknownDatabaseLocationException import com.kunzisoft.keepass.database.exception.UnknownDatabaseLocationException
import com.kunzisoft.keepass.database.helper.MemoryHelper.canMemoryBeAllocatedInRAM
import com.kunzisoft.keepass.hardware.HardwareKey import com.kunzisoft.keepass.hardware.HardwareKey
import com.kunzisoft.keepass.settings.PreferencesUtil import com.kunzisoft.keepass.settings.PreferencesUtil
import com.kunzisoft.keepass.tasks.ProgressTaskUpdater import com.kunzisoft.keepass.tasks.ProgressTaskUpdater
@ -58,7 +58,7 @@ class MergeDatabaseRunnable(
mDatabaseToMergeMainCredential?.toMasterCredential(contentResolver), mDatabaseToMergeMainCredential?.toMasterCredential(contentResolver),
mDatabaseToMergeChallengeResponseRetriever, mDatabaseToMergeChallengeResponseRetriever,
{ memoryWanted -> { memoryWanted ->
canMemoryBeAllocatedInRAM(context, memoryWanted) BinaryData.canMemoryBeAllocatedInRAM(context, memoryWanted)
}, },
progressTaskUpdater progressTaskUpdater
) )

View file

@ -21,9 +21,9 @@ package com.kunzisoft.keepass.database.action
import android.content.Context import android.content.Context
import com.kunzisoft.keepass.database.ContextualDatabase import com.kunzisoft.keepass.database.ContextualDatabase
import com.kunzisoft.keepass.database.element.binary.BinaryData
import com.kunzisoft.keepass.database.exception.DatabaseException import com.kunzisoft.keepass.database.exception.DatabaseException
import com.kunzisoft.keepass.database.exception.UnknownDatabaseLocationException import com.kunzisoft.keepass.database.exception.UnknownDatabaseLocationException
import com.kunzisoft.keepass.database.helper.MemoryHelper.canMemoryBeAllocatedInRAM
import com.kunzisoft.keepass.settings.PreferencesUtil import com.kunzisoft.keepass.settings.PreferencesUtil
import com.kunzisoft.keepass.tasks.ActionRunnable import com.kunzisoft.keepass.tasks.ActionRunnable
import com.kunzisoft.keepass.tasks.ProgressTaskUpdater import com.kunzisoft.keepass.tasks.ProgressTaskUpdater
@ -51,7 +51,7 @@ class ReloadDatabaseRunnable(
context.contentResolver.getUriInputStream(mDatabase.fileUri) context.contentResolver.getUriInputStream(mDatabase.fileUri)
?: throw UnknownDatabaseLocationException(), ?: throw UnknownDatabaseLocationException(),
{ memoryWanted -> { memoryWanted ->
canMemoryBeAllocatedInRAM(context, memoryWanted) BinaryData.canMemoryBeAllocatedInRAM(context, memoryWanted)
}, },
progressTaskUpdater) progressTaskUpdater)
} catch (e: DatabaseException) { } catch (e: DatabaseException) {

View file

@ -1,19 +0,0 @@
package com.kunzisoft.keepass.database.helper
import android.app.ActivityManager
import android.content.Context
object MemoryHelper {
private const val MAX_BINARY_BYTE = 10485760 // 10 MB
fun canMemoryBeAllocatedInRAM(context: Context, memoryWanted: Long): Boolean {
if (memoryWanted > MAX_BINARY_BYTE)
return false
val memoryInfo = ActivityManager.MemoryInfo()
(context.getSystemService(Context.ACTIVITY_SERVICE)
as? ActivityManager?)?.getMemoryInfo(memoryInfo)
val availableMemory = memoryInfo.availMem
return availableMemory > (memoryWanted * 5)
}
}

View file

Before

Width:  |  Height:  |  Size: 2.7 MiB

After

Width:  |  Height:  |  Size: 2.7 MiB

Before After
Before After

View file

@ -0,0 +1 @@
R.java

View file

@ -1,5 +1,7 @@
package com.kunzisoft.keepass.tests.stream package com.kunzisoft.keepass.tests.stream
import android.content.Context
import androidx.test.platform.app.InstrumentationRegistry
import com.kunzisoft.keepass.database.element.binary.BinaryCache import com.kunzisoft.keepass.database.element.binary.BinaryCache
import com.kunzisoft.keepass.database.element.binary.BinaryFile import com.kunzisoft.keepass.database.element.binary.BinaryFile
import com.kunzisoft.keepass.utils.readAllBytes import com.kunzisoft.keepass.utils.readAllBytes
@ -12,22 +14,19 @@ import kotlin.random.Random
class BinaryDataTest { class BinaryDataTest {
private val fileA = File.createTempFile(TEST_FILE_CACHE_A, null) private val context: Context by lazy {
private val fileB = File.createTempFile(TEST_FILE_CACHE_B, null) InstrumentationRegistry.getInstrumentation().context
private val fileC = File.createTempFile(TEST_FILE_CACHE_C, null) }
private val cacheDirectory = context.filesDir
private val fileA = File(cacheDirectory, TEST_FILE_CACHE_A)
private val fileB = File(cacheDirectory, TEST_FILE_CACHE_B)
private val fileC = File(cacheDirectory, TEST_FILE_CACHE_C)
private val binaryCache = BinaryCache() private val binaryCache = BinaryCache()
private fun buildFile(stringFile: String): File {
return File(javaClass.getResource("/$stringFile")!!.path)
}
private fun buildFileStream(stringFile: String): InputStream {
return javaClass.getResourceAsStream("/$stringFile")!!
}
private fun saveBinary(asset: String, binaryData: BinaryFile) { private fun saveBinary(asset: String, binaryData: BinaryFile) {
buildFileStream(asset).use { assetInputStream -> context.assets.open(asset).use { assetInputStream ->
binaryData.getOutputDataStream(binaryCache).use { binaryOutputStream -> binaryData.getOutputDataStream(binaryCache).use { binaryOutputStream ->
assetInputStream.readAllBytes(DEFAULT_BUFFER_SIZE) { buffer -> assetInputStream.readAllBytes(DEFAULT_BUFFER_SIZE) { buffer ->
binaryOutputStream.write(buffer) binaryOutputStream.write(buffer)
@ -130,7 +129,7 @@ class BinaryDataTest {
fun testReadText() { fun testReadText() {
val binaryA = BinaryFile(fileA) val binaryA = BinaryFile(fileA)
saveBinary(TEST_TEXT_ASSET, binaryA) saveBinary(TEST_TEXT_ASSET, binaryA)
assert(streamAreEquals(buildFileStream(TEST_TEXT_ASSET), assert(streamAreEquals(context.assets.open(TEST_TEXT_ASSET),
binaryA.getInputDataStream(binaryCache))) binaryA.getInputDataStream(binaryCache)))
} }
@ -138,7 +137,7 @@ class BinaryDataTest {
fun testReadImage() { fun testReadImage() {
val binaryA = BinaryFile(fileA) val binaryA = BinaryFile(fileA)
saveBinary(TEST_IMAGE_ASSET, binaryA) saveBinary(TEST_IMAGE_ASSET, binaryA)
assert(streamAreEquals(buildFileStream(TEST_IMAGE_ASSET), assert(streamAreEquals(context.assets.open(TEST_IMAGE_ASSET),
binaryA.getInputDataStream(binaryCache))) binaryA.getInputDataStream(binaryCache)))
} }

View file

@ -21,10 +21,11 @@ package com.kunzisoft.keepass.database.element.binary
import android.os.Parcel import android.os.Parcel
import android.os.Parcelable import android.os.Parcelable
import com.kunzisoft.keepass.database.element.binary.BinaryCache.Companion.UNKNOWN import android.util.Base64
import android.util.Base64InputStream
import android.util.Base64OutputStream
import com.kunzisoft.keepass.utils.readAllBytes import com.kunzisoft.keepass.utils.readAllBytes
import org.apache.commons.codec.binary.Base64InputStream import com.kunzisoft.keepass.database.element.binary.BinaryCache.Companion.UNKNOWN
import org.apache.commons.codec.binary.Base64OutputStream
import java.io.* import java.io.*
import java.util.zip.GZIPOutputStream import java.util.zip.GZIPOutputStream
@ -59,12 +60,12 @@ class BinaryByte : BinaryData {
@Throws(IOException::class) @Throws(IOException::class)
override fun getInputDataStream(binaryCache: BinaryCache): InputStream { override fun getInputDataStream(binaryCache: BinaryCache): InputStream {
return Base64InputStream(ByteArrayInputStream(getByteArray(binaryCache)), false) return Base64InputStream(ByteArrayInputStream(getByteArray(binaryCache)), Base64.NO_WRAP)
} }
@Throws(IOException::class) @Throws(IOException::class)
override fun getOutputDataStream(binaryCache: BinaryCache): OutputStream { override fun getOutputDataStream(binaryCache: BinaryCache): OutputStream {
return BinaryCountingOutputStream(Base64OutputStream(ByteOutputStream(binaryCache), true)) return BinaryCountingOutputStream(Base64OutputStream(ByteOutputStream(binaryCache), Base64.NO_WRAP))
} }
@Throws(IOException::class) @Throws(IOException::class)

View file

@ -19,6 +19,8 @@
*/ */
package com.kunzisoft.keepass.database.element.binary package com.kunzisoft.keepass.database.element.binary
import android.app.ActivityManager
import android.content.Context
import android.os.Parcel import android.os.Parcel
import android.os.Parcelable import android.os.Parcelable
import org.apache.commons.io.output.CountingOutputStream import org.apache.commons.io.output.CountingOutputStream
@ -178,6 +180,17 @@ abstract class BinaryData : Parcelable {
companion object { companion object {
private val TAG = BinaryData::class.java.name private val TAG = BinaryData::class.java.name
private const val MAX_BINARY_BYTE = 10485760 // 10 MB
fun canMemoryBeAllocatedInRAM(context: Context, memoryWanted: Long): Boolean {
if (memoryWanted > MAX_BINARY_BYTE)
return false
val memoryInfo = ActivityManager.MemoryInfo()
(context.getSystemService(Context.ACTIVITY_SERVICE)
as? ActivityManager?)?.getMemoryInfo(memoryInfo)
val availableMemory = memoryInfo.availMem
return availableMemory > (memoryWanted * 5)
}
} }
} }

View file

@ -21,9 +21,10 @@ package com.kunzisoft.keepass.database.element.binary
import android.os.Parcel import android.os.Parcel
import android.os.Parcelable import android.os.Parcelable
import android.util.Base64
import android.util.Base64InputStream
import android.util.Base64OutputStream
import com.kunzisoft.keepass.utils.readAllBytes import com.kunzisoft.keepass.utils.readAllBytes
import org.apache.commons.codec.binary.Base64InputStream
import org.apache.commons.codec.binary.Base64OutputStream
import java.io.* import java.io.*
import java.util.zip.GZIPOutputStream import java.util.zip.GZIPOutputStream
import javax.crypto.Cipher import javax.crypto.Cipher
@ -74,7 +75,7 @@ class BinaryFile : BinaryData {
return when { return when {
file != null && file.length() > 0 -> { file != null && file.length() > 0 -> {
cipherDecryption.init(Cipher.DECRYPT_MODE, cipherKey.key, IvParameterSpec(cipherKey.iv)) cipherDecryption.init(Cipher.DECRYPT_MODE, cipherKey.key, IvParameterSpec(cipherKey.iv))
Base64InputStream(CipherInputStream(FileInputStream(file), cipherDecryption), false) Base64InputStream(CipherInputStream(FileInputStream(file), cipherDecryption), Base64.NO_WRAP)
} }
else -> ByteArrayInputStream(ByteArray(0)) else -> ByteArrayInputStream(ByteArray(0))
} }
@ -86,7 +87,7 @@ class BinaryFile : BinaryData {
return when { return when {
file != null -> { file != null -> {
cipherEncryption.init(Cipher.ENCRYPT_MODE, cipherKey.key, IvParameterSpec(cipherKey.iv)) cipherEncryption.init(Cipher.ENCRYPT_MODE, cipherKey.key, IvParameterSpec(cipherKey.iv))
BinaryCountingOutputStream(Base64OutputStream(CipherOutputStream(FileOutputStream(file), cipherEncryption), true)) BinaryCountingOutputStream(Base64OutputStream(CipherOutputStream(FileOutputStream(file), cipherEncryption), Base64.NO_WRAP))
} }
else -> throw IOException("Unable to write in an unknown file") else -> throw IOException("Unable to write in an unknown file")
} }