mirror of
git://erdgeist.org/opentracker
synced 2025-01-14 08:50:10 +00:00
Copy request before expanding url-encoded bytes
This commit is contained in:
parent
2d0215d793
commit
4fc8dd75be
@ -40,6 +40,9 @@ static char static_scratch[8192];
|
|||||||
#ifdef _DEBUG_FDS
|
#ifdef _DEBUG_FDS
|
||||||
static char fd_debug_space[0x10000];
|
static char fd_debug_space[0x10000];
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef _DEBUG_HTTPERROR
|
||||||
|
static char debug_request[8192];
|
||||||
|
#endif
|
||||||
|
|
||||||
static void carp(const char* routine) {
|
static void carp(const char* routine) {
|
||||||
buffer_puts(buffer_2,routine);
|
buffer_puts(buffer_2,routine);
|
||||||
@ -135,7 +138,7 @@ void httperror(int64 s,struct http_data* h,const char* title,const char* message
|
|||||||
size_t reply_size = sprintf( static_scratch, "HTTP/1.0 %s\r\nContent-Type: text/html\r\nConnection: close\r\nContent-Length: %zd\r\n\r\n<title>%s</title>\n",
|
size_t reply_size = sprintf( static_scratch, "HTTP/1.0 %s\r\nContent-Type: text/html\r\nConnection: close\r\nContent-Length: %zd\r\n\r\n<title>%s</title>\n",
|
||||||
title, strlen(message)+strlen(title)+16-4,title+4);
|
title, strlen(message)+strlen(title)+16-4,title+4);
|
||||||
#ifdef _DEBUG_HTTPERROR
|
#ifdef _DEBUG_HTTPERROR
|
||||||
fprintf( stderr, "DEBUG: invalid request was: %s\n", (char*)array_start( &h->r ) );
|
fprintf( stderr, "DEBUG: invalid request was: %s\n", debug_request );
|
||||||
#endif
|
#endif
|
||||||
senddata(s,h,static_scratch,reply_size);
|
senddata(s,h,static_scratch,reply_size);
|
||||||
}
|
}
|
||||||
@ -169,6 +172,10 @@ void httpresponse(int64 s,struct http_data* h)
|
|||||||
array_cat0(&h->r);
|
array_cat0(&h->r);
|
||||||
c = array_start(&h->r);
|
c = array_start(&h->r);
|
||||||
|
|
||||||
|
#ifdef _DEBUG_HTTPERROR
|
||||||
|
memcpy( debug_request, array_start(&h->r), array_bytes(&h->r) );
|
||||||
|
#endif
|
||||||
|
|
||||||
if (byte_diff(c,4,"GET ")) {
|
if (byte_diff(c,4,"GET ")) {
|
||||||
e400:
|
e400:
|
||||||
return httperror(s,h,"400 Invalid Request","This server only understands GET.");
|
return httperror(s,h,"400 Invalid Request","This server only understands GET.");
|
||||||
@ -481,6 +488,10 @@ void handle_read( int64 clientsocket ) {
|
|||||||
|
|
||||||
array_catb(&h->r,static_scratch,l);
|
array_catb(&h->r,static_scratch,l);
|
||||||
|
|
||||||
|
#ifdef _DEBUG_HTTPERROR
|
||||||
|
memcpy( debug_request, "500!\0", 5 );
|
||||||
|
#endif
|
||||||
|
|
||||||
if( array_failed(&h->r))
|
if( array_failed(&h->r))
|
||||||
httperror(clientsocket,h,"500 Server Error","Request too long.");
|
httperror(clientsocket,h,"500 Server Error","Request too long.");
|
||||||
else if (array_bytes(&h->r)>8192)
|
else if (array_bytes(&h->r)>8192)
|
||||||
|
Loading…
Reference in New Issue
Block a user