summaryrefslogtreecommitdiff
path: root/chat/bitlbee/patches
diff options
context:
space:
mode:
Diffstat (limited to 'chat/bitlbee/patches')
-rw-r--r--chat/bitlbee/patches/patch-lib_http__client.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/chat/bitlbee/patches/patch-lib_http__client.c b/chat/bitlbee/patches/patch-lib_http__client.c
new file mode 100644
index 00000000000..96e0c8ef99d
--- /dev/null
+++ b/chat/bitlbee/patches/patch-lib_http__client.c
@@ -0,0 +1,66 @@
+$NetBSD: patch-lib_http__client.c,v 1.1 2011/11/18 21:06:19 tonio Exp $
+
+Fix for MSN login troubles
+
+--- lib/http_client.c (revision devel,783)
++++ lib/http_client.c (revision devel,825)
+@@ -314,5 +314,5 @@
+ }
+
+- if( ( req->status_code == 301 || req->status_code == 302 ) && req->redir_ttl-- > 0 )
++ if( ( req->status_code >= 301 && req->status_code <= 303 ) && req->redir_ttl-- > 0 )
+ {
+ char *loc, *new_request, *new_host;
+@@ -354,4 +354,5 @@
+ url_t *url;
+ char *s;
++ const char *new_method;
+
+ s = strstr( loc, "\r\n" );
+@@ -369,25 +370,34 @@
+ }
+
+- /* Okay, this isn't fun! We have to rebuild the request... :-( */
+- new_request = g_malloc( req->request_length + strlen( url->file ) );
+-
+- /* So, now I just allocated enough memory, so I'm
+- going to use strcat(), whether you like it or not. :-) */
+-
+- sprintf( new_request, "GET %s HTTP/1.0", url->file );
+-
+- s = strstr( req->request, "\r\n" );
+- if( s == NULL )
++ /* Find all headers and, if necessary, the POST request contents.
++ Skip the old Host: header though. This crappy code here means
++ anything using this http_client MUST put the Host: header at
++ the top. */
++ if( !( ( s = strstr( req->request, "\r\nHost: " ) ) &&
++ ( s = strstr( s + strlen( "\r\nHost: " ), "\r\n" ) ) ) )
+ {
+ req->status_string = g_strdup( "Error while rebuilding request string" );
+- g_free( new_request );
+ g_free( url );
+ goto cleanup;
+ }
+
+- strcat( new_request, s );
++ /* More or less HTTP/1.0 compliant, from my reading of RFC 2616.
++ Always perform a GET request unless we received a 301. 303 was
++ meant for this but it's HTTP/1.1-only and we're specifically
++ speaking HTTP/1.0. */
++ new_method = req->status_code != 301 || req->request[0] == 'G' ? "GET" : "POST";
++
++ /* Okay, this isn't fun! We have to rebuild the request... :-( */
++ new_request = g_strdup_printf( "%s %s HTTP/1.0\r\nHost: %s%s",
++ new_method, url->file, url->host, s );
++
+ new_host = g_strdup( url->host );
+ new_port = url->port;
+ new_proto = url->proto;
++
++ /* If we went from POST to GET, truncate the request content. */
++ if( new_request[0] != req->request[0] && new_request[0] == 'G' &&
++ ( s = strstr( new_request, "\r\n\r\n" ) ) )
++ s[4] = '\0';
+
+ g_free( url );