diff --git a/src/main/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannel.java b/src/main/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannel.java index f336258..3b45836 100644 --- a/src/main/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannel.java +++ b/src/main/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannel.java @@ -1,11 +1,3 @@ -/******************************************************************************* - * Copyright (c) 2016 Sebastian Stenzel and others. - * All rights reserved. This program and the accompanying materials - * are made available under the terms of the accompanying LICENSE.txt. - * - * Contributors: - * Sebastian Stenzel - initial API and implementation - *******************************************************************************/ package org.cryptomator.cryptolib.common; import org.cryptomator.cryptolib.api.Cryptor; @@ -66,10 +58,8 @@ private void writeHeaderOnFirstWrite() throws IOException { private void encryptAndFlushBuffer() throws IOException { cleartextBuffer.flip(); - if (cleartextBuffer.hasRemaining()) { - ByteBuffer ciphertextBuffer = cryptor.fileContentCryptor().encryptChunk(cleartextBuffer, chunkNumber++, header); - delegate.write(ciphertextBuffer); - } + ByteBuffer ciphertextBuffer = cryptor.fileContentCryptor().encryptChunk(cleartextBuffer, chunkNumber++, header); + delegate.write(ciphertextBuffer); cleartextBuffer.clear(); } diff --git a/src/main/java/org/cryptomator/cryptolib/v1/FileContentCryptorImpl.java b/src/main/java/org/cryptomator/cryptolib/v1/FileContentCryptorImpl.java index 6f985f9..f7cf465 100644 --- a/src/main/java/org/cryptomator/cryptolib/v1/FileContentCryptorImpl.java +++ b/src/main/java/org/cryptomator/cryptolib/v1/FileContentCryptorImpl.java @@ -60,7 +60,7 @@ public ByteBuffer encryptChunk(ByteBuffer cleartextChunk, long chunkNumber, File @Override public void encryptChunk(ByteBuffer cleartextChunk, ByteBuffer ciphertextChunk, long chunkNumber, FileHeader header) { - if (cleartextChunk.remaining() <= 0 || cleartextChunk.remaining() > PAYLOAD_SIZE) { + if (cleartextChunk.remaining() < 0 || cleartextChunk.remaining() > PAYLOAD_SIZE) { throw new IllegalArgumentException("Invalid cleartext chunk size: " + cleartextChunk.remaining() + ", expected range [1, " + PAYLOAD_SIZE + "]"); } if (ciphertextChunk.remaining() < CHUNK_SIZE) { diff --git a/src/main/java/org/cryptomator/cryptolib/v2/FileContentCryptorImpl.java b/src/main/java/org/cryptomator/cryptolib/v2/FileContentCryptorImpl.java index 094a951..d0babba 100644 --- a/src/main/java/org/cryptomator/cryptolib/v2/FileContentCryptorImpl.java +++ b/src/main/java/org/cryptomator/cryptolib/v2/FileContentCryptorImpl.java @@ -55,7 +55,7 @@ public ByteBuffer encryptChunk(ByteBuffer cleartextChunk, long chunkNumber, File @Override public void encryptChunk(ByteBuffer cleartextChunk, ByteBuffer ciphertextChunk, long chunkNumber, FileHeader header) { - if (cleartextChunk.remaining() <= 0 || cleartextChunk.remaining() > PAYLOAD_SIZE) { + if (cleartextChunk.remaining() < 0 || cleartextChunk.remaining() > PAYLOAD_SIZE) { throw new IllegalArgumentException("Invalid cleartext chunk size: " + cleartextChunk.remaining() + ", expected range [1, " + PAYLOAD_SIZE + "]"); } if (ciphertextChunk.remaining() < CHUNK_SIZE) { diff --git a/src/test/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannelTest.java b/src/test/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannelTest.java index a900757..396d75c 100644 --- a/src/test/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannelTest.java +++ b/src/test/java/org/cryptomator/cryptolib/common/EncryptingWritableByteChannelTest.java @@ -1,11 +1,3 @@ -/******************************************************************************* - * Copyright (c) 2016 Sebastian Stenzel and others. - * All rights reserved. This program and the accompanying materials - * are made available under the terms of the accompanying LICENSE.txt. - * - * Contributors: - * Sebastian Stenzel - initial API and implementation - *******************************************************************************/ package org.cryptomator.cryptolib.common; import org.cryptomator.cryptolib.api.Cryptor; @@ -49,7 +41,8 @@ public void setup() { Mockito.when(contentCryptor.encryptChunk(Mockito.any(ByteBuffer.class), Mockito.anyLong(), Mockito.any(FileHeader.class))).thenAnswer(invocation -> { ByteBuffer input = invocation.getArgument(0); String inStr = UTF_8.decode(input).toString(); - return ByteBuffer.wrap(inStr.toUpperCase().getBytes(UTF_8)); + String outStr = "<" + inStr.toUpperCase() + ">"; + return UTF_8.encode(outStr); }); } @@ -60,7 +53,7 @@ public void testEncryption() throws IOException { ch.write(UTF_8.encode("hello world 2")); } dstFile.flip(); - Assertions.assertArrayEquals("hhhhhHELLO WORLD 1HELLO WORLD 2".getBytes(), Arrays.copyOfRange(dstFile.array(), 0, dstFile.remaining())); + Assertions.assertEquals("hhhhh", UTF_8.decode(dstFile).toString()); } @Test @@ -69,7 +62,7 @@ public void testEncryptionOfEmptyFile() throws IOException { // empty, so write nothing } dstFile.flip(); - Assertions.assertArrayEquals("hhhhh".getBytes(), Arrays.copyOfRange(dstFile.array(), 0, dstFile.remaining())); + Assertions.assertEquals("hhhhh<>", UTF_8.decode(dstFile).toString()); } } diff --git a/src/test/java/org/cryptomator/cryptolib/v1/FileContentCryptorImplTest.java b/src/test/java/org/cryptomator/cryptolib/v1/FileContentCryptorImplTest.java index 2f1f5a9..f4b11bd 100644 --- a/src/test/java/org/cryptomator/cryptolib/v1/FileContentCryptorImplTest.java +++ b/src/test/java/org/cryptomator/cryptolib/v1/FileContentCryptorImplTest.java @@ -91,7 +91,7 @@ public class Encryption { @DisplayName("encrypt chunk with invalid size") @ParameterizedTest(name = "cleartext size: {0}") - @ValueSource(ints = {0, Constants.PAYLOAD_SIZE + 1}) + @ValueSource(ints = {Constants.PAYLOAD_SIZE + 1}) public void testEncryptChunkOfInvalidSize(int size) { ByteBuffer cleartext = ByteBuffer.allocate(size); diff --git a/src/test/java/org/cryptomator/cryptolib/v2/FileContentCryptorImplTest.java b/src/test/java/org/cryptomator/cryptolib/v2/FileContentCryptorImplTest.java index 81ab860..10b1e69 100644 --- a/src/test/java/org/cryptomator/cryptolib/v2/FileContentCryptorImplTest.java +++ b/src/test/java/org/cryptomator/cryptolib/v2/FileContentCryptorImplTest.java @@ -100,7 +100,7 @@ public void resetGcmNonce() { @DisplayName("encrypt chunk with invalid size") @ParameterizedTest(name = "cleartext size: {0}") - @ValueSource(ints = {0, org.cryptomator.cryptolib.v2.Constants.PAYLOAD_SIZE + 1}) + @ValueSource(ints = {Constants.PAYLOAD_SIZE + 1}) public void testEncryptChunkOfInvalidSize(int size) { ByteBuffer cleartext = ByteBuffer.allocate(size); @@ -184,7 +184,7 @@ public class Decryption { @DisplayName("decrypt chunk with invalid size") @ParameterizedTest(name = "ciphertext size: {0}") - @ValueSource(ints = {0, Constants.GCM_NONCE_SIZE + Constants.GCM_TAG_SIZE - 1, org.cryptomator.cryptolib.v2.Constants.CHUNK_SIZE + 1}) + @ValueSource(ints = {0, Constants.GCM_NONCE_SIZE + Constants.GCM_TAG_SIZE - 1, Constants.CHUNK_SIZE + 1}) public void testDecryptChunkOfInvalidSize(int size) { ByteBuffer ciphertext = ByteBuffer.allocate(size);