From aa12026ef089ca91515dc924583c9fd4eb4c5a31 Mon Sep 17 00:00:00 2001 From: Armin Novak Date: Thu, 6 Dec 2018 10:07:15 +0100 Subject: [PATCH] Added additional gateway error logging. --- libfreerdp/core/gateway/http.c | 54 ++++++++++++++++++---------- libfreerdp/core/gateway/rpc.c | 1 + libfreerdp/core/gateway/rpc_client.c | 40 ++++++++++++--------- 3 files changed, 60 insertions(+), 35 deletions(-) diff --git a/libfreerdp/core/gateway/http.c b/libfreerdp/core/gateway/http.c index 5e34302ef..addae204c 100644 --- a/libfreerdp/core/gateway/http.c +++ b/libfreerdp/core/gateway/http.c @@ -500,26 +500,27 @@ void http_request_free(HttpRequest* request) free(request); } -static BOOL http_response_parse_header_status_line(HttpResponse* response, char* status_line) +static BOOL http_response_parse_header_status_line(HttpResponse* response, const char* status_line) { + BOOL rc = FALSE; char* separator = NULL; char* status_code; char* reason_phrase; if (!response) - return FALSE; + goto fail; if (status_line) separator = strchr(status_line, ' '); if (!separator) - return FALSE; + goto fail; status_code = separator + 1; separator = strchr(status_code, ' '); if (!separator) - return FALSE; + goto fail; reason_phrase = separator + 1; *separator = '\0'; @@ -528,17 +529,23 @@ static BOOL http_response_parse_header_status_line(HttpResponse* response, char* long val = strtol(status_code, NULL, 0); if ((errno != 0) || (val < 0) || (val > INT16_MAX)) - return FALSE; + goto fail; response->StatusCode = strtol(status_code, NULL, 0); } response->ReasonPhrase = reason_phrase; if (!response->ReasonPhrase) - return FALSE; + goto fail; *separator = ' '; - return TRUE; + rc = TRUE; +fail: + + if (!rc) + WLog_ERR(TAG, "http_response_parse_header_status_line failed [%s]", status_line); + + return rc; } static BOOL http_response_parse_header_field(HttpResponse* response, const char* name, @@ -607,6 +614,7 @@ static BOOL http_response_parse_header_field(HttpResponse* response, const char* static BOOL http_response_parse_header(HttpResponse* response) { + BOOL rc = FALSE; char c; size_t count; char* line; @@ -617,13 +625,13 @@ static BOOL http_response_parse_header(HttpResponse* response) char end_of_header_char; if (!response) - return FALSE; + goto fail; if (!response->lines) - return FALSE; + goto fail; if (!http_response_parse_header_status_line(response, response->lines[0])) - return FALSE; + goto fail; for (count = 1; count < response->count; count++) { @@ -656,7 +664,7 @@ static BOOL http_response_parse_header(HttpResponse* response) } if (end_of_header == line) - return FALSE; + goto fail; end_of_header_char = *end_of_header; *end_of_header = '\0'; @@ -670,12 +678,18 @@ static BOOL http_response_parse_header(HttpResponse* response) } if (!http_response_parse_header_field(response, name, value)) - return FALSE; + goto fail; *end_of_header = end_of_header_char; } - return TRUE; + rc = TRUE; +fail: + + if (!rc) + WLog_ERR(TAG, "%s: parsing failed", __FUNCTION__); + + return rc; } BOOL http_response_print(HttpResponse* response) @@ -752,7 +766,10 @@ HttpResponse* http_response_recv(rdpTls* tls, BOOL readContentLength) if (status <= 0) { if (!BIO_should_retry(tls->bio)) + { + WLog_ERR(TAG, "%s: Retries exceeded", __FUNCTION__); goto out_error; + } USleep(100); continue; @@ -815,10 +832,6 @@ HttpResponse* http_response_recv(rdpTls* tls, BOOL readContentLength) while (line && (response->count > count)) { response->lines[count] = line; - - if (!response->lines[count]) - goto out_error; - line = strtok(NULL, "\r\n"); count++; } @@ -866,7 +879,10 @@ HttpResponse* http_response_recv(rdpTls* tls, BOOL readContentLength) if (status <= 0) { if (!BIO_should_retry(tls->bio)) + { + WLog_ERR(TAG, "%s: Retries exceeded", __FUNCTION__); goto out_error; + } USleep(100); continue; @@ -887,8 +903,8 @@ HttpResponse* http_response_recv(rdpTls* tls, BOOL readContentLength) if (bodyLength != response->BodyLength) { - WLog_WARN(TAG, "http_response_recv: %s unexpected body length: actual: %d, expected: %d", - response->ContentType, response->BodyLength, bodyLength); + WLog_WARN(TAG, "%s: %s unexpected body length: actual: %d, expected: %d", + __FUNCTION__, response->ContentType, response->BodyLength, bodyLength); if (bodyLength > 0) response->BodyLength = MIN(bodyLength, response->BodyLength); diff --git a/libfreerdp/core/gateway/rpc.c b/libfreerdp/core/gateway/rpc.c index 54f35a4bc..1cea31a3f 100644 --- a/libfreerdp/core/gateway/rpc.c +++ b/libfreerdp/core/gateway/rpc.c @@ -345,6 +345,7 @@ SSIZE_T rpc_channel_read(RpcChannel* channel, wStream* s, size_t length) if (BIO_should_retry(channel->tls->bio)) return 0; + WLog_ERR(TAG, "rpc_channel_read: Out of retries"); return -1; } diff --git a/libfreerdp/core/gateway/rpc_client.c b/libfreerdp/core/gateway/rpc_client.c index 382296b49..5523e8fa6 100644 --- a/libfreerdp/core/gateway/rpc_client.c +++ b/libfreerdp/core/gateway/rpc_client.c @@ -650,33 +650,41 @@ static int rpc_client_nondefault_out_channel_recv(rdpRpc* rpc) if (response) { - if (nextOutChannel->State == CLIENT_OUT_CHANNEL_STATE_SECURITY) + switch (nextOutChannel->State) { - if (rpc_ncacn_http_recv_out_channel_response(&nextOutChannel->common, response)) - { - if (rpc_ncacn_http_send_out_channel_request(&nextOutChannel->common, TRUE)) + case CLIENT_OUT_CHANNEL_STATE_SECURITY: + if (rpc_ncacn_http_recv_out_channel_response(&nextOutChannel->common, response)) { - rpc_ncacn_http_ntlm_uninit(&nextOutChannel->common); - status = rts_send_OUT_R1_A3_pdu(rpc); - - if (status >= 0) + if (rpc_ncacn_http_send_out_channel_request(&nextOutChannel->common, TRUE)) { - rpc_out_channel_transition_to_state(nextOutChannel, CLIENT_OUT_CHANNEL_STATE_OPENED_A6W); + rpc_ncacn_http_ntlm_uninit(&nextOutChannel->common); + status = rts_send_OUT_R1_A3_pdu(rpc); + + if (status >= 0) + { + rpc_out_channel_transition_to_state(nextOutChannel, CLIENT_OUT_CHANNEL_STATE_OPENED_A6W); + } + else + { + WLog_ERR(TAG, "rts_send_OUT_R1/A3_pdu failure"); + } } else { - WLog_ERR(TAG, "rts_send_OUT_R1/A3_pdu failure"); + WLog_ERR(TAG, "rpc_ncacn_http_send_out_channel_request failure"); } } else { - WLog_ERR(TAG, "rpc_ncacn_http_send_out_channel_request failure"); + WLog_ERR(TAG, "rpc_ncacn_http_recv_out_channel_response failure"); } - } - else - { - WLog_ERR(TAG, "rpc_ncacn_http_recv_out_channel_response failure"); - } + + break; + + default: + WLog_ERR(TAG, "rpc_client_nondefault_out_channel_recv: Unexpected message %08"PRIx32, + nextOutChannel->State); + return -1; } http_response_free(response);