From 5c78e2e6ef0651c2f7f7bad8d1ab018338fd87ff Mon Sep 17 00:00:00 2001 From: Tres Finocchiaro Date: Wed, 24 Jul 2024 11:37:23 -0400 Subject: [PATCH] SocketIO: Fix encoding and endless callbacks (#1283) --- src/qz/communication/SocketIO.java | 6 ++++-- src/qz/utils/SocketUtilities.java | 9 ++++++--- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/src/qz/communication/SocketIO.java b/src/qz/communication/SocketIO.java index 8a86e517f..87640b127 100644 --- a/src/qz/communication/SocketIO.java +++ b/src/qz/communication/SocketIO.java @@ -62,8 +62,10 @@ public String processSocketResponse() throws IOException { } } while(dataIn.available() > 0); - - return new String(ArrayUtils.toPrimitive(fullResponse.toArray(new Byte[0])), encoding); + if(fullResponse.size() > 0) { + return new String(ArrayUtils.toPrimitive(fullResponse.toArray(new Byte[0])), encoding); + } + return null; } public void close() throws IOException { diff --git a/src/qz/utils/SocketUtilities.java b/src/qz/utils/SocketUtilities.java index 0be3563e6..505266144 100644 --- a/src/qz/utils/SocketUtilities.java +++ b/src/qz/utils/SocketUtilities.java @@ -30,9 +30,12 @@ public static void setupSocket(final Session session, String UID, SocketConnecti //TODO - move to dedicated options class? Charset encoding = StandardCharsets.UTF_8; - if (!params.isNull("encoding")) { - try { encoding = Charset.forName(params.getString("encoding")); } - catch(JSONException e) { LoggerUtilities.optionWarn(log, "string", "encoding", params.opt("encoding")); } + if (!params.isNull("options")) { + JSONObject options = params.getJSONObject("options"); + + if (!options.isNull("encoding")) { + encoding = Charset.forName(options.getString("encoding")); + } } try {