im.pidgin.pidgin: 30ee89e929f7bc81f4ba11c947dadce9cc07579c
datallah at pidgin.im
datallah at pidgin.im
Tue Feb 19 22:10:39 EST 2008
-----------------------------------------------------------------
Revision: 30ee89e929f7bc81f4ba11c947dadce9cc07579c
Ancestor: 67192a3b4815097039aec94f315695a7f27048c1
Author: datallah at pidgin.im
Date: 2008-02-20T03:04:47
Branch: im.pidgin.pidgin
URL: http://d.pidgin.im/viewmtn/revision/info/30ee89e929f7bc81f4ba11c947dadce9cc07579c
Modified files:
libpurple/proxy.c
ChangeLog:
Patch from eperez to plug a leak in the ntlm proxy authentication. Fixes #4702
-------------- next part --------------
============================================================
--- libpurple/proxy.c 6b297275886e775dc5f55f37d82a918af8ff8f55
+++ libpurple/proxy.c 45e4aac50312fd1e9ef984a960f6ec0b93a071ce
@@ -737,6 +737,7 @@ http_canread(gpointer data, gint source,
proxy_do_write(connect_data, connect_data->fd, cond);
return;
} else if((ntlm = g_strrstr((const char *)connect_data->read_buffer, "Proxy-Authenticate: NTLM"))) { /* Empty message */
+ gchar *ntlm_type1;
gchar request[2048];
gchar *domain = (gchar*) purple_proxy_info_get_username(connect_data->gpi);
gchar *username = NULL;
@@ -759,11 +760,13 @@ http_canread(gpointer data, gint source,
connect_data->host, connect_data->port);
g_return_if_fail(request_len < sizeof(request));
+ ntlm_type1 = purple_ntlm_gen_type1(hostname, domain);
request_len += g_snprintf(request + request_len,
sizeof(request) - request_len,
"Proxy-Authorization: NTLM %s\r\n"
"Proxy-Connection: Keep-Alive\r\n\r\n",
- purple_ntlm_gen_type1(hostname, domain));
+ ntlm_type1);
+ g_free(ntlm_type1);
*username = '\\';
purple_input_remove(connect_data->inpa);
@@ -847,7 +850,7 @@ http_canwrite(gpointer data, gint source
if (purple_proxy_info_get_username(connect_data->gpi) != NULL)
{
- char *t1, *t2;
+ char *t1, *t2, *ntlm_type1;
char hostname[256];
ret = gethostname(hostname, sizeof(hostname));
@@ -864,11 +867,14 @@ http_canwrite(gpointer data, gint source
t2 = purple_base64_encode((const guchar *)t1, strlen(t1));
g_free(t1);
+ ntlm_type1 = purple_ntlm_gen_type1(hostname, "");
+
g_string_append_printf(request,
"Proxy-Authorization: Basic %s\r\n"
"Proxy-Authorization: NTLM %s\r\n"
"Proxy-Connection: Keep-Alive\r\n",
- t2, purple_ntlm_gen_type1(hostname, ""));
+ t2, ntlm_type1);
+ g_free(ntlm_type1);
g_free(t2);
}
More information about the Commits
mailing list