mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-09 11:48:00 +01:00
Remove unused CRCingArmoredInputStreamWrapper class
This commit is contained in:
parent
620c1fc96a
commit
3bb25a62a2
3 changed files with 7 additions and 184 deletions
|
@ -1,155 +0,0 @@
|
||||||
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
package org.pgpainless.util;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
|
|
||||||
import org.bouncycastle.bcpg.ArmoredInputStream;
|
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Utility class that causes read(bytes, offset, length) to properly throw exceptions
|
|
||||||
* caused by faulty CRC checksums.
|
|
||||||
*
|
|
||||||
* Furthermore, this class swallows exceptions from BC's ArmoredInputStream that are caused
|
|
||||||
* by missing CRC checksums.
|
|
||||||
*
|
|
||||||
* TODO: Validate whether this class is still needed.
|
|
||||||
*/
|
|
||||||
public class CRCingArmoredInputStreamWrapper extends ArmoredInputStream {
|
|
||||||
|
|
||||||
private final ArmoredInputStream inputStream;
|
|
||||||
|
|
||||||
public CRCingArmoredInputStreamWrapper(ArmoredInputStream inputStream) throws IOException {
|
|
||||||
super(inputStream, false);
|
|
||||||
this.inputStream = inputStream;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isClearText() {
|
|
||||||
return inputStream.isClearText();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isEndOfStream() {
|
|
||||||
return inputStream.isEndOfStream();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String getArmorHeaderLine() {
|
|
||||||
return inputStream.getArmorHeaderLine();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String[] getArmorHeaders() {
|
|
||||||
return inputStream.getArmorHeaders();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int read() throws IOException {
|
|
||||||
try {
|
|
||||||
return inputStream.read();
|
|
||||||
} catch (IOException e) {
|
|
||||||
if (e.getMessage().equals("no crc found in armored message.") || e.getMessage().equals("crc check not found.")) {
|
|
||||||
// swallow exception
|
|
||||||
return -1;
|
|
||||||
} else {
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int read(@Nonnull byte[] b) throws IOException {
|
|
||||||
return read(b, 0, b.length);
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Reads up to <code>len</code> bytes of data from the input stream into
|
|
||||||
* an array of bytes. An attempt is made to read as many as
|
|
||||||
* <code>len</code> bytes, but a smaller number may be read.
|
|
||||||
* The number of bytes actually read is returned as an integer.
|
|
||||||
*
|
|
||||||
* The first byte read is stored into element <code>b[off]</code>, the
|
|
||||||
* next one into <code>b[off+1]</code>, and so on. The number of bytes read
|
|
||||||
* is, at most, equal to <code>len</code>.
|
|
||||||
*
|
|
||||||
* NOTE: We need to override the custom behavior of Java's {@link InputStream#read(byte[], int, int)},
|
|
||||||
* as the upstream method silently swallows {@link IOException IOExceptions}.
|
|
||||||
* This would cause CRC checksum errors to go unnoticed.
|
|
||||||
*
|
|
||||||
* @see <a href="https://github.com/bcgit/bc-java/issues/998">Related BC bug report</a>
|
|
||||||
* @param b byte array
|
|
||||||
* @param off offset at which we start writing data to the array
|
|
||||||
* @param len number of bytes we write into the array
|
|
||||||
* @return total number of bytes read into the buffer
|
|
||||||
*
|
|
||||||
* @throws IOException if an exception happens AT ANY POINT
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public int read(byte[] b, int off, int len) throws IOException {
|
|
||||||
checkIndexSize(b.length, off, len);
|
|
||||||
|
|
||||||
if (len == 0) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int c = read();
|
|
||||||
if (c == -1) {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
b[off] = (byte) c;
|
|
||||||
|
|
||||||
int i = 1;
|
|
||||||
for (; i < len ; i++) {
|
|
||||||
c = read();
|
|
||||||
if (c == -1) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
b[off + i] = (byte) c;
|
|
||||||
}
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void checkIndexSize(int size, int off, int len) {
|
|
||||||
if (off < 0 || len < 0) {
|
|
||||||
throw new IndexOutOfBoundsException("Offset and length cannot be negative.");
|
|
||||||
}
|
|
||||||
if (size < off + len) {
|
|
||||||
throw new IndexOutOfBoundsException("Invalid offset and length.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long skip(long n) throws IOException {
|
|
||||||
return inputStream.skip(n);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int available() throws IOException {
|
|
||||||
return inputStream.available();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void close() throws IOException {
|
|
||||||
inputStream.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public synchronized void mark(int readlimit) {
|
|
||||||
inputStream.mark(readlimit);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public synchronized void reset() throws IOException {
|
|
||||||
inputStream.reset();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean markSupported() {
|
|
||||||
return inputStream.markSupported();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -29,16 +29,14 @@ class ArmoredInputStreamFactory {
|
||||||
@Throws(IOException::class)
|
@Throws(IOException::class)
|
||||||
fun get(inputStream: InputStream, options: ConsumerOptions? = null): ArmoredInputStream {
|
fun get(inputStream: InputStream, options: ConsumerOptions? = null): ArmoredInputStream {
|
||||||
return when (inputStream) {
|
return when (inputStream) {
|
||||||
is CRCingArmoredInputStreamWrapper -> inputStream
|
is ArmoredInputStream -> inputStream
|
||||||
is ArmoredInputStream -> CRCingArmoredInputStreamWrapper(inputStream)
|
|
||||||
else ->
|
else ->
|
||||||
CRCingArmoredInputStreamWrapper(
|
|
||||||
ArmoredInputStream.builder()
|
ArmoredInputStream.builder()
|
||||||
.apply {
|
.apply {
|
||||||
setParseForHeaders(true)
|
setParseForHeaders(true)
|
||||||
options?.let { setIgnoreCRC(it.isDisableAsciiArmorCRC) }
|
options?.let { setIgnoreCRC(it.isDisableAsciiArmorCRC) }
|
||||||
}
|
}
|
||||||
.build(inputStream))
|
.build(inputStream)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,8 +11,6 @@ import java.io.ByteArrayInputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
import static org.junit.jupiter.api.Assertions.assertNotNull;
|
||||||
import static org.junit.jupiter.api.Assertions.assertSame;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
|
||||||
|
|
||||||
public class ArmoredInputStreamFactoryTest {
|
public class ArmoredInputStreamFactoryTest {
|
||||||
|
|
||||||
|
@ -30,22 +28,4 @@ public class ArmoredInputStreamFactoryTest {
|
||||||
ArmoredInputStream armorIn = ArmoredInputStreamFactory.get(inputStream);
|
ArmoredInputStream armorIn = ArmoredInputStreamFactory.get(inputStream);
|
||||||
assertNotNull(armorIn);
|
assertNotNull(armorIn);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testGet_willWrapArmoredInputStreamWithCRC() throws IOException {
|
|
||||||
ByteArrayInputStream inputStream = new ByteArrayInputStream(armored.getBytes());
|
|
||||||
ArmoredInputStream plainArmor = new ArmoredInputStream(inputStream);
|
|
||||||
|
|
||||||
ArmoredInputStream armor = ArmoredInputStreamFactory.get(plainArmor);
|
|
||||||
assertTrue(armor instanceof CRCingArmoredInputStreamWrapper);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testGet_onCRCinArmoredInputStream() throws IOException {
|
|
||||||
ByteArrayInputStream inputStream = new ByteArrayInputStream(armored.getBytes());
|
|
||||||
CRCingArmoredInputStreamWrapper crc = new CRCingArmoredInputStreamWrapper(new ArmoredInputStream(inputStream));
|
|
||||||
|
|
||||||
ArmoredInputStream armor = ArmoredInputStreamFactory.get(crc);
|
|
||||||
assertSame(crc, armor);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue