echo http protocol version on CONNECT request response

while at it, the function doing it was renamed from the misleading
ssl name to what it actually does.
also inlined the strings that were previously defined as macros.

addressing #152
This commit is contained in:
rofl0r 2022-07-15 23:43:13 +00:00
parent 8b373f804e
commit 121be4a74e

View File

@ -301,21 +301,16 @@ establish_http_connection (struct conn_s *connptr, struct request_s *request)
} }
/* /*
* These two defines are for the SSL tunnelling. * Send the appropriate response to the client to establish a
* connection via CONNECT method.
*/ */
#define SSL_CONNECTION_RESPONSE "HTTP/1.0 200 Connection established" static int send_connect_method_response (struct conn_s *connptr)
#define PROXY_AGENT "Proxy-agent: " PACKAGE "/" VERSION
/*
* Send the appropriate response to the client to establish a SSL
* connection.
*/
static int send_ssl_response (struct conn_s *connptr)
{ {
return write_message (connptr->client_fd, return write_message (connptr->client_fd,
"%s\r\n" "HTTP/1.%u 200 Connection established\r\n"
"%s\r\n" "Proxy-agent: " PACKAGE "/" VERSION "\r\n"
"\r\n", SSL_CONNECTION_RESPONSE, PROXY_AGENT); "\r\n", connptr->protocol.major != 1 ? 0 :
connptr->protocol.minor);
} }
/* /*
@ -1762,10 +1757,10 @@ e401:
HC_FAIL(); HC_FAIL();
} }
} else { } else {
if (send_ssl_response (connptr) < 0) { if (send_connect_method_response (connptr) < 0) {
log_message (LOG_ERR, log_message (LOG_ERR,
"handle_connection: Could not send SSL greeting " "handle_connection: Could not send CONNECT"
"to client."); " method greeting to client.");
update_stats (STAT_BADCONN); update_stats (STAT_BADCONN);
HC_FAIL(); HC_FAIL();
} }