diff options
Diffstat (limited to 'src/main')
-rw-r--r-- | src/main/kotlin/CryptoHandler.kt | 13 | ||||
-rw-r--r-- | src/main/kotlin/DatabaseController.kt | 19 | ||||
-rw-r--r-- | src/main/kotlin/FileController.kt | 29 |
3 files changed, 24 insertions, 37 deletions
diff --git a/src/main/kotlin/CryptoHandler.kt b/src/main/kotlin/CryptoHandler.kt index 03396f2..145f3e6 100644 --- a/src/main/kotlin/CryptoHandler.kt +++ b/src/main/kotlin/CryptoHandler.kt @@ -10,24 +10,25 @@ internal constructor(private val secretKey: SecretKey, cipher: String) { private val cipher: Cipher = Cipher.getInstance(cipher) @Throws(InvalidKeyException::class, IOException::class) - internal fun encrypt(content: String, fileName: String): ByteArray { + internal fun encrypt(content: String, fileName: String) { cipher.init(Cipher.ENCRYPT_MODE, secretKey) - val iv: ByteArray = cipher.iv + val iv = cipher.iv FileOutputStream(fileName).use { fileOut -> + fileOut.write(iv) CipherOutputStream(fileOut, cipher).use { cipherOut -> cipherOut.write(content.toByteArray()) } } - - return iv } @Throws(InvalidAlgorithmParameterException::class, InvalidKeyException::class, IOException::class) - internal fun decrypt(fileName: String, iv: ByteArray): String { + internal fun decrypt(fileName: String): String { var content = "" FileInputStream(fileName).use { fileIn -> + val iv = ByteArray(16) + fileIn.read(iv) cipher.init(Cipher.DECRYPT_MODE, secretKey, IvParameterSpec(iv)) CipherInputStream(fileIn, cipher).use { cipherIn -> @@ -45,6 +46,6 @@ internal constructor(private val secretKey: SecretKey, cipher: String) { } } - return content + return content // TODO: Fix char handling as 1 byte in decryption } } diff --git a/src/main/kotlin/DatabaseController.kt b/src/main/kotlin/DatabaseController.kt index d60f278..5316bb0 100644 --- a/src/main/kotlin/DatabaseController.kt +++ b/src/main/kotlin/DatabaseController.kt @@ -25,7 +25,6 @@ class DatabaseController { val userId = integer("userId").references(UserData.id) val accessId = varchar("accessId", 64).uniqueIndex() val isShared = bool("isShared").default(false) - val encryptIV = binary("iv", 16) // empty if directory } /** @@ -317,7 +316,7 @@ class DatabaseController { /** * Adds the uploaded file to the database */ - fun addFile(fileLocation: String, usersId: Int, isDirectoryBool: Boolean = false, iv: ByteArray = ByteArray(16)): Boolean { + fun addFile(fileLocation: String, usersId: Int, isDirectoryBool: Boolean = false): Boolean { return transaction { try { if (FileLocation.select { (FileLocation.path eq fileLocation) and (FileLocation.userId eq usersId) }.empty()) { @@ -326,7 +325,6 @@ class DatabaseController { it[userId] = usersId it[accessId] = generateRandomString() it[isDirectory] = isDirectoryBool - it[encryptIV] = iv } true } else { @@ -355,19 +353,6 @@ class DatabaseController { } /** - * Returns IV of given file - */ - fun getFileIV(fileLocation: String, userId: Int): ByteArray { - return transaction { - try { - FileLocation.select { (FileLocation.path eq fileLocation) and (FileLocation.userId eq userId) }.map { it[FileLocation.encryptIV] }[0] - } catch (err: Exception) { - ByteArray(16) - } - } - } - - /** * Returns the accessId of the given file */ fun getAccessId(fileLocation: String, userId: Int): String { @@ -519,7 +504,7 @@ class DatabaseController { } } -data class ReturnFileData ( +data class ReturnFileData( val userId: Int, val fileLocation: String, val isDirectory: Boolean diff --git a/src/main/kotlin/FileController.kt b/src/main/kotlin/FileController.kt index 38fdd4e..d37c552 100644 --- a/src/main/kotlin/FileController.kt +++ b/src/main/kotlin/FileController.kt @@ -27,14 +27,14 @@ class FileController { val fileLocation = "$usersFileHome/$firstParam" File(fileLocation).mkdirs() when { - ctx.queryParam("raw") != null -> ctx.result(decrypt(fileLocation, userId)) + ctx.queryParam("raw") != null -> ctx.result(decrypt(fileLocation)) File(fileLocation).isDirectory -> { val files = ArrayList<Array<String>>() Files.list(Paths.get("$usersFileHome/$firstParam/")).forEach { val filename = it.toString() .drop(usersFileHome.length + (if (firstParam.isNotEmpty()) firstParam.length + 2 else 1)) val filePath = "$usersFileHome${it.toString().drop(usersFileHome.length)}" - files.add(addToFileListing(filePath, filename, ctx)) + files.add(addToFileListing(filePath, filename)) } files.sortWith(compareBy { it.first() }) ctx.render( @@ -46,10 +46,11 @@ class FileController { ) ) } - isHumanReadable(decrypt(fileLocation, userId).toByteArray()) -> handleHumanReadableFile(fileLocation, ctx) + // TODO: Fix decrypting every file when crawling (human readable flag in db?) + isHumanReadable(decrypt(fileLocation).toByteArray()) -> handleHumanReadableFile(fileLocation, ctx) else -> { ctx.contentType(Files.probeContentType(Paths.get(fileLocation))) - ctx.result(decrypt(fileLocation, userId)) + ctx.result(decrypt(fileLocation)) } } } catch (err: Exception) { @@ -59,11 +60,11 @@ class FileController { } /** - * Decrypts a file using the [filePath] and the crypto helping class + * Decrypts a file using the [fileLocation] and the crypto helping class */ - private fun decrypt(fileLocation: String, userId: Int): String { + private fun decrypt(fileLocation: String): String { val cryptoHandler = CryptoHandler(secretKey, "AES/CBC/PKCS5Padding") - return cryptoHandler.decrypt(fileLocation, databaseController.getFileIV(fileLocation, userId)) + return cryptoHandler.decrypt(fileLocation) } /** @@ -121,8 +122,8 @@ class FileController { } val cryptoHandler = CryptoHandler(secretKey, "AES/CBC/PKCS5Padding") - val iv = cryptoHandler.encrypt(stringContent, fileLocation) - databaseController.addFile(fixedName, userId, false, iv) + cryptoHandler.encrypt(stringContent, fileLocation) + databaseController.addFile(fixedName, userId, false) } ctx.json("success") @@ -200,7 +201,7 @@ class FileController { if (sharedFileData.userId > 0 && fileLocation.isNotEmpty()) { val sharedFileLocation = "$fileHome/${sharedFileData.userId}/$fileLocation" if (!sharedFileData.isDirectory) { - if (isHumanReadable(decrypt(fileLocation, userHandler.getVerifiedUserId(ctx)).toByteArray())) + if (isHumanReadable(decrypt(sharedFileLocation).toByteArray())) handleHumanReadableFile(sharedFileLocation, ctx) else { // TODO: Fix name of downloaded file ("shared") @@ -213,7 +214,7 @@ class FileController { val filename = it.toString() .drop(sharedFileLocation.length) val filePath = "$sharedFileLocation$filename" - files.add(addToFileListing(filePath, filename, ctx)) + files.add(addToFileListing(filePath, filename)) } files.sortWith(compareBy { it.first() }) ctx.render( @@ -234,7 +235,7 @@ class FileController { /** * Adds a file to the file array used in the file listing view */ - private fun addToFileListing(fileLocation: String, filename: String, ctx: Context): Array<String> { + private fun addToFileListing(fileLocation: String, filename: String): Array<String> { val file = File(fileLocation) val fileSize = if (file.isDirectory) getDirectorySize(file) else file.length() return arrayOf( @@ -243,7 +244,7 @@ class FileController { humanReadableBytes(fileSize), SimpleDateFormat("MM/dd/yyyy HH:mm:ss").format(file.lastModified()).toString(), if (file.isDirectory) "true" - else isHumanReadable(decrypt(fileLocation, userHandler.getVerifiedUserId(ctx)).toByteArray()).toString(), + else isHumanReadable(decrypt(fileLocation).toByteArray()).toString(), file.isDirectory.toString(), fileSize.toString(), // unformatted file size file.lastModified().toString() // unformatted last modified date @@ -254,7 +255,7 @@ class FileController { * Handles the rendering of human readable files */ private fun handleHumanReadableFile(fileLocation: String, ctx: Context) { - val content = decrypt(fileLocation, userHandler.getVerifiedUserId(ctx)) + val content = decrypt(fileLocation) ctx.render( "fileview.rocker.html", model( "content", content, |