summaryrefslogtreecommitdiffstats
path: root/libxrdp/xrdp_rdp.c
diff options
context:
space:
mode:
authorKoichiro IWAO <meta@vmeta.jp>2016-09-09 15:42:04 +0900
committerKoichiro IWAO <meta@vmeta.jp>2016-11-22 10:50:30 +0900
commit40e8194122ea914be0679b8c21f2d4aa30b47b96 (patch)
tree0184c9e2d4544ad93ddda9bcd26c928ed716cca9 /libxrdp/xrdp_rdp.c
parenta59645d3c5bb143764bab538fa83a8483a2157d8 (diff)
downloadxrdp-proprietary-40e8194122ea914be0679b8c21f2d4aa30b47b96.tar.gz
xrdp-proprietary-40e8194122ea914be0679b8c21f2d4aa30b47b96.zip
TLS: log TLS version and cipher
Diffstat (limited to 'libxrdp/xrdp_rdp.c')
-rw-r--r--libxrdp/xrdp_rdp.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/libxrdp/xrdp_rdp.c b/libxrdp/xrdp_rdp.c
index 6aff5830..a66b6d0d 100644
--- a/libxrdp/xrdp_rdp.c
+++ b/libxrdp/xrdp_rdp.c
@@ -811,6 +811,9 @@ xrdp_rdp_send_data_update_sync(struct xrdp_rdp *self)
int APP_CC
xrdp_rdp_incoming(struct xrdp_rdp *self)
{
+ struct xrdp_iso *iso;
+ iso = self->sec_layer->mcs_layer->iso_layer;
+
DEBUG(("in xrdp_rdp_incoming"));
if (xrdp_sec_incoming(self->sec_layer) != 0)
@@ -820,12 +823,22 @@ xrdp_rdp_incoming(struct xrdp_rdp *self)
self->mcs_channel = self->sec_layer->mcs_layer->userid +
MCS_USERCHANNEL_BASE;
DEBUG(("out xrdp_rdp_incoming mcs channel %d", self->mcs_channel));
- g_strncpy(self->client_info.client_addr,
- self->sec_layer->mcs_layer->iso_layer->trans->addr,
+ g_strncpy(self->client_info.client_addr, iso->trans->addr,
sizeof(self->client_info.client_addr) - 1);
- g_strncpy(self->client_info.client_port,
- self->sec_layer->mcs_layer->iso_layer->trans->port,
+ g_strncpy(self->client_info.client_port, iso->trans->port,
sizeof(self->client_info.client_port) - 1);
+
+ /* log TLS version and cipher when TLS is used */
+ /* TODO: client_addr, client_port is empty when IPv6 enabled */
+ if (iso->selectedProtocol > PROTOCOL_RDP)
+ {
+ log_message(LOG_LEVEL_INFO,
+ "TLS connection established from %s: %s with cipher %s",
+ self->client_info.client_addr,
+ iso->trans->ssl_protocol,
+ iso->trans->cipher_name);
+ }
+
return 0;
}