Improvements for Windows client/tool-side code. r=bryner

- Allow Windows sender to use https (#41).
 - HTTPUpload not proxy-friendly (#46).
 - Check http status codes (sort of #44).
 - Allow symupload to work with versionless files (prints a warning, server
   may still reject).

http://groups.google.com/group/airbag-dev/browse_thread/thread/5a12a72dffc5999c


git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@41 4c0a9323-5329-0410-9bdc-e9ce6186880e
This commit is contained in:
mmentovai 2006-10-19 21:48:51 +00:00
parent 181f307ffe
commit 5afd60b067
2 changed files with 32 additions and 14 deletions

View file

@ -83,12 +83,15 @@ bool HTTPUpload::SendRequest(const wstring &url,
0, &components)) { 0, &components)) {
return false; return false;
} }
if (wcscmp(scheme, L"http") != 0) { bool secure = false;
if (wcscmp(scheme, L"https") == 0) {
secure = true;
} else if (wcscmp(scheme, L"http") != 0) {
return false; return false;
} }
AutoInternetHandle internet(InternetOpen(kUserAgent, AutoInternetHandle internet(InternetOpen(kUserAgent,
INTERNET_OPEN_TYPE_DIRECT, INTERNET_OPEN_TYPE_PRECONFIG,
NULL, // proxy name NULL, // proxy name
NULL, // proxy bypass NULL, // proxy bypass
0)); // flags 0)); // flags
@ -108,13 +111,14 @@ bool HTTPUpload::SendRequest(const wstring &url,
return false; return false;
} }
DWORD http_open_flags = secure ? INTERNET_FLAG_SECURE : 0;
AutoInternetHandle request(HttpOpenRequest(connection.get(), AutoInternetHandle request(HttpOpenRequest(connection.get(),
L"POST", L"POST",
path, path,
NULL, // version NULL, // version
NULL, // referer NULL, // referer
NULL, // agent type NULL, // agent type
0, // flags http_open_flags,
NULL)); // context NULL)); // context
if (!request.get()) { if (!request.get()) {
return false; return false;
@ -130,10 +134,22 @@ bool HTTPUpload::SendRequest(const wstring &url,
GenerateRequestBody(parameters, upload_file, GenerateRequestBody(parameters, upload_file,
file_part_name, boundary, &request_body); file_part_name, boundary, &request_body);
// The explicit comparison to TRUE avoids a warning (C4800). if (!HttpSendRequest(request.get(), NULL, 0,
return (HttpSendRequest(request.get(), NULL, 0,
const_cast<char *>(request_body.data()), const_cast<char *>(request_body.data()),
static_cast<DWORD>(request_body.size())) == TRUE); static_cast<DWORD>(request_body.size()))) {
return false;
}
// The server indicates a successful upload with HTTP status 200.
wchar_t http_status[4];
DWORD http_status_size = sizeof(http_status);
if (!HttpQueryInfo(request.get(), HTTP_QUERY_STATUS_CODE,
static_cast<LPVOID>(&http_status), &http_status_size,
0)) {
return false;
}
return (wcscmp(http_status, L"200") == 0);
} }
// static // static

View file

@ -148,12 +148,6 @@ int wmain(int argc, wchar_t *argv[]) {
const wchar_t *module = argv[1], *url = argv[2]; const wchar_t *module = argv[1], *url = argv[2];
wstring module_basename = GetBaseName(module); wstring module_basename = GetBaseName(module);
wstring file_version;
if (!GetFileVersionString(module, &file_version)) {
fwprintf(stderr, L"Could not get file version for %s\n", module);
return 1;
}
wstring symbol_file, module_guid; wstring symbol_file, module_guid;
if (!DumpSymbolsToTempFile(module, &symbol_file, &module_guid)) { if (!DumpSymbolsToTempFile(module, &symbol_file, &module_guid)) {
fwprintf(stderr, L"Could not get symbol data from %s\n", module); fwprintf(stderr, L"Could not get symbol data from %s\n", module);
@ -162,9 +156,17 @@ int wmain(int argc, wchar_t *argv[]) {
map<wstring, wstring> parameters; map<wstring, wstring> parameters;
parameters[L"module"] = module_basename; parameters[L"module"] = module_basename;
parameters[L"version"] = file_version;
parameters[L"guid"] = module_guid; parameters[L"guid"] = module_guid;
// Don't make a missing version a hard error. Issue a warning, and let the
// server decide whether to reject files without versions.
wstring file_version;
if (GetFileVersionString(module, &file_version)) {
parameters[L"version"] = file_version;
} else {
fwprintf(stderr, L"Warning: Could not get file version for %s\n", module);
}
bool success = HTTPUpload::SendRequest(url, parameters, bool success = HTTPUpload::SendRequest(url, parameters,
symbol_file, L"symbol_file"); symbol_file, L"symbol_file");
_wunlink(symbol_file.c_str()); _wunlink(symbol_file.c_str());