aboutsummaryrefslogtreecommitdiffstats
path: root/common/rdr
diff options
context:
space:
mode:
authorPierre Ossman <ossman@cendio.se>2020-05-20 20:03:11 +0200
committerPierre Ossman <ossman@cendio.se>2020-05-21 11:34:22 +0200
commitf4fdc13f37f7ae67b2ba110c24366f84e1e70734 (patch)
treed5095da09e96b70f0628905f2db8f256315e332c /common/rdr
parent9f623551a7eebfa5d9fa6cc2d369d4b3041fc89d (diff)
downloadtigervnc-f4fdc13f37f7ae67b2ba110c24366f84e1e70734.tar.gz
tigervnc-f4fdc13f37f7ae67b2ba110c24366f84e1e70734.zip
Log I/O errors from TLS streams
Diffstat (limited to 'common/rdr')
-rw-r--r--common/rdr/TLSInStream.cxx7
-rw-r--r--common/rdr/TLSOutStream.cxx4
2 files changed, 10 insertions, 1 deletions
diff --git a/common/rdr/TLSInStream.cxx b/common/rdr/TLSInStream.cxx
index 70303db0..ba20e752 100644
--- a/common/rdr/TLSInStream.cxx
+++ b/common/rdr/TLSInStream.cxx
@@ -25,11 +25,14 @@
#include <rdr/Exception.h>
#include <rdr/TLSException.h>
#include <rdr/TLSInStream.h>
+#include <rfb/LogWriter.h>
#include <errno.h>
#ifdef HAVE_GNUTLS
using namespace rdr;
+static rfb::LogWriter vlog("TLSInStream");
+
ssize_t TLSInStream::pull(gnutls_transport_ptr_t str, void* data, size_t size)
{
TLSInStream* self= (TLSInStream*) str;
@@ -45,8 +48,10 @@ ssize_t TLSInStream::pull(gnutls_transport_ptr_t str, void* data, size_t size)
size = in->avail();
in->readBytes(data, size);
-
+ } catch (EndOfStream&) {
+ return 0;
} catch (Exception& e) {
+ vlog.error("Failure reading TLS data: %s", e.str());
gnutls_transport_set_errno(self->session, EINVAL);
return -1;
}
diff --git a/common/rdr/TLSOutStream.cxx b/common/rdr/TLSOutStream.cxx
index 7d59a9c7..a883fe89 100644
--- a/common/rdr/TLSOutStream.cxx
+++ b/common/rdr/TLSOutStream.cxx
@@ -25,11 +25,14 @@
#include <rdr/Exception.h>
#include <rdr/TLSException.h>
#include <rdr/TLSOutStream.h>
+#include <rfb/LogWriter.h>
#include <errno.h>
#ifdef HAVE_GNUTLS
using namespace rdr;
+static rfb::LogWriter vlog("TLSOutStream");
+
enum { DEFAULT_BUF_SIZE = 16384 };
ssize_t TLSOutStream::push(gnutls_transport_ptr_t str, const void* data,
@@ -42,6 +45,7 @@ ssize_t TLSOutStream::push(gnutls_transport_ptr_t str, const void* data,
out->writeBytes(data, size);
out->flush();
} catch (Exception& e) {
+ vlog.error("Failure sending TLS data: %s", e.str());
gnutls_transport_set_errno(self->session, EINVAL);
return -1;
}