summaryrefslogtreecommitdiffstats
path: root/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java
diff options
context:
space:
mode:
authorSimon Rettberg2023-05-22 17:58:10 +0200
committerSimon Rettberg2023-05-22 17:58:10 +0200
commit189efc3254cf41b878ba69a6a48f1e2d9d31d6ea (patch)
treeac826a7220b2bc0c223ff2688cd0da37c0e66529 /dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java
parent[server] Add one second timeout to cache updates (diff)
downloadtutor-module-189efc3254cf41b878ba69a6a48f1e2d9d31d6ea.tar.gz
tutor-module-189efc3254cf41b878ba69a6a48f1e2d9d31d6ea.tar.xz
tutor-module-189efc3254cf41b878ba69a6a48f1e2d9d31d6ea.zip
[server] Restore Java 1.8 compat for now
Since this is really the only place so far, refactor to support older Java. Let's move to 11+ after the next release.
Diffstat (limited to 'dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java')
-rw-r--r--dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java10
1 files changed, 9 insertions, 1 deletions
diff --git a/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java b/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java
index 55c09756..cec5dd5f 100644
--- a/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java
+++ b/dozentenmodulserver/src/main/java/org/openslx/bwlp/sat/thrift/JsonHttpListener.java
@@ -57,7 +57,15 @@ public class JsonHttpListener extends NanoHTTPD {
return new Response(Response.Status.BAD_REQUEST, "text/plain; charset=UTF-8",
"No Content-Length provided");
- byte[] buffer = session.getInputStream().readNBytes(len);
+ byte[] buffer = new byte[len];
+ int pos = 0;
+ while (pos < len) {
+ int ret = session.getInputStream().read(buffer, pos, len - pos);
+ if (ret <= 0)
+ return new Response(Response.Status.BAD_REQUEST, "text/plain; charset=UTF-8",
+ "Request content truncated (" + pos + "/" + len + ")");
+ pos += ret;
+ }
TMemoryBuffer inbuffer = new TMemoryBuffer(buffer.length);
inbuffer.write(buffer);
TProtocol inprotocol = new TJSONProtocol(inbuffer);