Changed the buffer pointer in safe_write() to be const void* since we're
not changing the values. Instead of building a new request and memory, simply send each part separately. Actually uses less memory _and_ less code.
This commit is contained in:
parent
dab361f764
commit
9c520c7a50
53
src/reqs.c
53
src/reqs.c
@ -1,4 +1,4 @@
|
|||||||
/* $Id: reqs.c,v 1.24 2001-09-14 04:56:29 rjkaes Exp $
|
/* $Id: reqs.c,v 1.25 2001-09-14 19:50:45 rjkaes Exp $
|
||||||
*
|
*
|
||||||
* This is where all the work in tinyproxy is actually done. Incoming
|
* This is where all the work in tinyproxy is actually done. Incoming
|
||||||
* connections have a new thread created for them. The thread then
|
* connections have a new thread created for them. The thread then
|
||||||
@ -46,7 +46,7 @@
|
|||||||
* Write the buffer to the socket. If an EINTR occurs, pick up and try
|
* Write the buffer to the socket. If an EINTR occurs, pick up and try
|
||||||
* again.
|
* again.
|
||||||
*/
|
*/
|
||||||
static ssize_t safe_write(int fd, void *buffer, size_t count)
|
static ssize_t safe_write(int fd, const void *buffer, size_t count)
|
||||||
{
|
{
|
||||||
ssize_t len;
|
ssize_t len;
|
||||||
|
|
||||||
@ -210,42 +210,27 @@ static int establish_http_connection(struct conn_s *connptr,
|
|||||||
const char *protocol,
|
const char *protocol,
|
||||||
struct request_s *request)
|
struct request_s *request)
|
||||||
{
|
{
|
||||||
char *request_line;
|
/*
|
||||||
size_t request_len;
|
* Send the request line
|
||||||
|
*/
|
||||||
request_len = strlen(method) + strlen(protocol) + strlen(request->path) + 13;
|
if (safe_write(connptr->server_fd, method, strlen(method)) < 0)
|
||||||
|
|
||||||
request_line = safemalloc(request_len);
|
|
||||||
if (!request_line) {
|
|
||||||
log_message(LOG_ERR, "Could not allocate memory in 'process_request'");
|
|
||||||
httperr(connptr, 503, HTTP503ERROR);
|
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
if (safe_write(connptr->server_fd, " ", 1) < 0)
|
||||||
|
return -1;
|
||||||
strlcpy(request_line, method, request_len);
|
if (safe_write(connptr->server_fd, request->path, strlen(request->path)) < 0)
|
||||||
strlcat(request_line, " ", request_len);
|
return -1;
|
||||||
strlcat(request_line, request->path, request_len);
|
if (safe_write(connptr->server_fd, " ", 1) < 0)
|
||||||
strlcat(request_line, " ", request_len);
|
return -1;
|
||||||
strlcat(request_line, "HTTP/1.0", request_len);
|
if (safe_write(connptr->server_fd, "HTTP/1.0\r\n", 10) < 0)
|
||||||
strlcat(request_line, "\r\n", request_len);
|
|
||||||
|
|
||||||
if (safe_write(connptr->server_fd, request_line, strlen(request_line)) < 0) {
|
|
||||||
safefree(request_line);
|
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
safefree(request_line);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Send headers
|
* Send headers
|
||||||
*/
|
*/
|
||||||
if (safe_write(connptr->server_fd, "Host: ", 6) < 0) {
|
if (safe_write(connptr->server_fd, "Host: ", 6) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
if (safe_write(connptr->server_fd, request->host, strlen(request->host)) < 0)
|
||||||
if (safe_write(connptr->server_fd, request->host, strlen(request->host)) < 0) {
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
|
||||||
|
|
||||||
if (safe_write(connptr->server_fd, "\r\n", 2) < 0)
|
if (safe_write(connptr->server_fd, "\r\n", 2) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
@ -510,9 +495,8 @@ static int process_client_headers(struct conn_s *connptr)
|
|||||||
char *header;
|
char *header;
|
||||||
long content_length = -1;
|
long content_length = -1;
|
||||||
|
|
||||||
char *skipheaders[] = {
|
static char *skipheaders[] = {
|
||||||
"proxy-connection",
|
"proxy-connection",
|
||||||
"host",
|
|
||||||
"connection"
|
"connection"
|
||||||
};
|
};
|
||||||
int i;
|
int i;
|
||||||
@ -535,6 +519,9 @@ static int process_client_headers(struct conn_s *connptr)
|
|||||||
if (connptr->output_message)
|
if (connptr->output_message)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (!connptr->ssl && strncasecmp(header, "host", 4) ==0)
|
||||||
|
continue;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Don't send certain headers.
|
* Don't send certain headers.
|
||||||
*/
|
*/
|
||||||
@ -831,7 +818,7 @@ internal_proxy:
|
|||||||
safefree(request_line);
|
safefree(request_line);
|
||||||
|
|
||||||
send_error:
|
send_error:
|
||||||
if (!connptr->simple_req && !connptr->ssl) {
|
if (!connptr->simple_req) {
|
||||||
if (process_client_headers(connptr) < 0) {
|
if (process_client_headers(connptr) < 0) {
|
||||||
update_stats(STAT_BADCONN);
|
update_stats(STAT_BADCONN);
|
||||||
destroy_conn(connptr);
|
destroy_conn(connptr);
|
||||||
|
Loading…
Reference in New Issue
Block a user