diff --git a/pom.xml b/pom.xml index b4b9049ec..83132d480 100644 --- a/pom.xml +++ b/pom.xml @@ -38,7 +38,7 @@ ${major.version}.${minor.version} 4 1 - 0 + 1 17 4.2.0 diff --git a/src/main/java/org/aksw/iguana/cc/utils/http/StreamEntityProducer.java b/src/main/java/org/aksw/iguana/cc/utils/http/StreamEntityProducer.java index 5996d2b9e..08e41f42c 100644 --- a/src/main/java/org/aksw/iguana/cc/utils/http/StreamEntityProducer.java +++ b/src/main/java/org/aksw/iguana/cc/utils/http/StreamEntityProducer.java @@ -39,13 +39,11 @@ public class StreamEntityProducer implements AsyncEntityProducer { * @param streamSupplier the input stream supplier, should be repeatable * @param chunked whether the entity data should be sent in chunks */ - public StreamEntityProducer(Supplier streamSupplier, boolean chunked, String contentType) throws IOException { + public StreamEntityProducer(Supplier streamSupplier, boolean chunked, String contentType) { this.streamSupplier = streamSupplier; this.chunked = chunked; this.contentType = contentType; - if (!chunked) { - content = (streamSupplier.get() instanceof ByteArrayListInputStream) ? (ByteArrayListInputStream) streamSupplier.get() : null; - } + if (!chunked) loadContent(); } @Override @@ -132,7 +130,8 @@ public int available() { @Override public void produce(DataStreamChannel channel) throws IOException { // handling of non-chunked request - if (content != null) { + if (!chunked) { + if (content == null) loadContent(); // might be necessary if the producer is reused ByteBuffer buffer = content.getCurrentBuffer(); while (channel.write(buffer) > 0) { if (!buffer.hasRemaining()) { @@ -148,7 +147,7 @@ public void produce(DataStreamChannel channel) throws IOException { } // handling of chunked request - if (chunked && currentStream == null) { + if (currentStream == null) { currentStream = streamSupplier.get(); } @@ -162,4 +161,8 @@ public void produce(DataStreamChannel channel) throws IOException { channel.endStream(); } } + + private void loadContent() { + content = (ByteArrayListInputStream) streamSupplier.get(); + } } \ No newline at end of file