Mercurial > pidgin.yaz
comparison libpurple/proxy.c @ 29052:f2a69bee9ef6
Don't send Proxy-Authorization headers until we've received a
`407 Proxy Authentication Required` response from the server. Fixes #2910,
which has an additional component about using existing kerberos tickets that
should be moved to a new trac ticket.
committer: John Bailey <rekkanoryo@rekkanoryo.org>
author | thecrux@gmail.com |
---|---|
date | Sun, 29 Nov 2009 16:14:36 +0000 |
parents | 30497d814cb9 |
children | 0aa6080a6379 c01d4a1c7ee5 |
comparison
equal
deleted
inserted
replaced
29051:39a48c780bcb | 29052:f2a69bee9ef6 |
---|---|
1096 request = g_string_sized_new(4096); | 1096 request = g_string_sized_new(4096); |
1097 g_string_append_printf(request, | 1097 g_string_append_printf(request, |
1098 "CONNECT %s:%d HTTP/1.1\r\nHost: %s:%d\r\n", | 1098 "CONNECT %s:%d HTTP/1.1\r\nHost: %s:%d\r\n", |
1099 connect_data->host, connect_data->port, | 1099 connect_data->host, connect_data->port, |
1100 connect_data->host, connect_data->port); | 1100 connect_data->host, connect_data->port); |
1101 | |
1102 if (purple_proxy_info_get_username(connect_data->gpi) != NULL) | |
1103 { | |
1104 char *t1, *t2, *ntlm_type1; | |
1105 char hostname[256]; | |
1106 | |
1107 ret = gethostname(hostname, sizeof(hostname)); | |
1108 hostname[sizeof(hostname) - 1] = '\0'; | |
1109 if (ret < 0 || hostname[0] == '\0') { | |
1110 purple_debug_warning("proxy", "gethostname() failed -- is your hostname set?"); | |
1111 strcpy(hostname, "localhost"); | |
1112 } | |
1113 | |
1114 t1 = g_strdup_printf("%s:%s", | |
1115 purple_proxy_info_get_username(connect_data->gpi), | |
1116 purple_proxy_info_get_password(connect_data->gpi) ? | |
1117 purple_proxy_info_get_password(connect_data->gpi) : ""); | |
1118 t2 = purple_base64_encode((const guchar *)t1, strlen(t1)); | |
1119 g_free(t1); | |
1120 | |
1121 ntlm_type1 = purple_ntlm_gen_type1(hostname, ""); | |
1122 | |
1123 g_string_append_printf(request, | |
1124 "Proxy-Authorization: Basic %s\r\n" | |
1125 "Proxy-Authorization: NTLM %s\r\n" | |
1126 "Proxy-Connection: Keep-Alive\r\n", | |
1127 t2, ntlm_type1); | |
1128 g_free(ntlm_type1); | |
1129 g_free(t2); | |
1130 } | |
1131 | 1101 |
1132 g_string_append(request, "\r\n"); | 1102 g_string_append(request, "\r\n"); |
1133 | 1103 |
1134 connect_data->write_buf_len = request->len; | 1104 connect_data->write_buf_len = request->len; |
1135 connect_data->write_buffer = (guchar *)g_string_free(request, FALSE); | 1105 connect_data->write_buffer = (guchar *)g_string_free(request, FALSE); |