Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix issue: The web_proxy doesn't work when set proxy with uri #1780

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
55 changes: 55 additions & 0 deletions Release/src/http/client/http_client_winhttp.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -992,6 +992,8 @@ class winhttp_client final : public _http_client_communicator
return;
}

auto config = client_config();
auto proxy = config.proxy();
if (m_proxy_auto_config)
{
WINHTTP_AUTOPROXY_OPTIONS autoproxy_options {};
Expand All @@ -1018,6 +1020,45 @@ class winhttp_client final : public _http_client_communicator
// Failure to download the auto-configuration script is not fatal. Fall back to the default proxy.
}
}
else
{

bool isproxyspecified = proxy.is_specified();
if (isproxyspecified)
{

const web::uri uri = config.proxy().address();
utility::string_t proxy_str = uri.host();
if (uri.port() > 0)
{
proxy_str.push_back(_XPLATSTR(':'));
proxy_str.append(::utility::conversions::details::to_string_t(uri.port()));
}

if (proxy_str.c_str() != NULL)
{


memset(&info, 0, sizeof(info));
TCHAR* proxy_dupstr = (TCHAR*)::GlobalAlloc(GMEM_FIXED, (proxy_str.length() + 1) * sizeof(TCHAR));//(TCHAR*)malloc((proxy_str.length() + 1) * sizeof(TCHAR));//new TCHAR[proxy_str.length() + 1];
memset(proxy_dupstr, 0, (proxy_str.length() + 1) * sizeof(TCHAR));
memcpy(proxy_dupstr, proxy_str.c_str(), proxy_str.length() * sizeof(TCHAR));
info.lpszProxy = proxy_dupstr;

//web_proxy has no setting for bypass list,so just set an empty buffer
//setting bypass list just for destructor of proxy_info to release the pointer
TCHAR* proxybypass_dupstr = (TCHAR*)::GlobalAlloc(GMEM_FIXED, 256 * sizeof(TCHAR)); //(TCHAR*)malloc(256 * sizeof(TCHAR));
memset(proxybypass_dupstr, 0, 256 * sizeof(TCHAR));
info.lpszProxyBypass = proxybypass_dupstr;

info.dwAccessType = WINHTTP_ACCESS_TYPE_NAMED_PROXY;
DWORD proxy_info_size = sizeof(info);

proxy_info_required = true;

}
}
}

// Need to form uri path, query, and fragment for this request.
// Make sure to keep any path that was specified with the uri when the http_client was created.
Expand Down Expand Up @@ -1066,6 +1107,20 @@ class winhttp_client final : public _http_client_communicator
request->report_error(errorCode, build_error_msg(errorCode, "Setting proxy options"));
return;
}

auto credentials = proxy.credentials();
TCHAR* username = const_cast<TCHAR*>(credentials.username().c_str());
if (username != NULL)
{
WinHttpSetOption(winhttp_context->m_request_handle, WINHTTP_OPTION_PROXY_USERNAME, username, (DWORD)wcslen(username));

utility::string_t password_str = *(credentials._internal_decrypt());

TCHAR* password = const_cast<TCHAR*>(password_str.c_str());
if (password != NULL)
WinHttpSetOption(winhttp_context->m_request_handle, WINHTTP_OPTION_PROXY_PASSWORD, password, (DWORD)wcslen(password));

}
}

// If credentials are specified, use autologon policy: WINHTTP_AUTOLOGON_SECURITY_LEVEL_HIGH
Expand Down