Migrate google_converter to v2 upload API.

Change-Id: If045809cfa3a3601b93725b6b2b45089e7558eb3
Reviewed-on: https://chromium-review.googlesource.com/c/breakpad/breakpad/+/3657059
Reviewed-by: Ivan Penkov <ivanpe@chromium.org>
This commit is contained in:
Nelson Billing 2022-05-20 14:56:42 -07:00
parent c34fc86972
commit bee636cea4

View file

@ -39,12 +39,13 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include "common/windows/http_upload.h"
#include "common/windows/string_utils-inl.h"
#include "common/windows/sym_upload_v2_protocol.h"
#include "tools/windows/converter/ms_symbol_server_converter.h"
#include "tools/windows/converter_exe/escaping.h" #include "tools/windows/converter_exe/escaping.h"
#include "tools/windows/converter_exe/http_download.h" #include "tools/windows/converter_exe/http_download.h"
#include "tools/windows/converter_exe/tokenizer.h" #include "tools/windows/converter_exe/tokenizer.h"
#include "common/windows/http_upload.h"
#include "common/windows/string_utils-inl.h"
#include "tools/windows/converter/ms_symbol_server_converter.h"
using strings::WebSafeBase64Unescape; using strings::WebSafeBase64Unescape;
using strings::WebSafeBase64Escape; using strings::WebSafeBase64Escape;
@ -208,28 +209,37 @@ static bool MissingSymbolInfoToParameters(const MissingSymbolInfo& missing_info,
// to the symbol server rooted at |upload_symbol_url|. Returns true on // to the symbol server rooted at |upload_symbol_url|. Returns true on
// success and false on failure, printing an error message. // success and false on failure, printing an error message.
static bool UploadSymbolFile(const wstring& upload_symbol_url, static bool UploadSymbolFile(const wstring& upload_symbol_url,
const wstring& api_key,
const MissingSymbolInfo& missing_info, const MissingSymbolInfo& missing_info,
const string& converted_file) { const string& converted_file) {
map<wstring, wstring> parameters; wstring debug_file_w;
if (!MissingSymbolInfoToParameters(missing_info,& parameters)) { if (!WindowsStringUtils::safe_mbstowcs(missing_info.debug_file,
// MissingSymbolInfoToParameters or a callee will have printed an error. &debug_file_w)) {
FprintfFlush(stderr, "UploadSymbolFile: safe_mbstowcs failed for %s\n",
converted_file.c_str());
return false;
}
wstring debug_id_w;
if (!WindowsStringUtils::safe_mbstowcs(missing_info.debug_identifier,
&debug_id_w)) {
FprintfFlush(stderr, "UploadSymbolFile: safe_mbstowcs failed for %s\n",
converted_file.c_str());
return false; return false;
} }
wstring converted_file_w; wstring converted_file_w;
if (!WindowsStringUtils::safe_mbstowcs(converted_file, &converted_file_w)) { if (!WindowsStringUtils::safe_mbstowcs(converted_file, &converted_file_w)) {
FprintfFlush(stderr, "UploadSymbolFile: safe_mbstowcs failed for %s\n", FprintfFlush(stderr, "UploadSymbolFile: safe_mbstowcs failed for %s\n",
converted_file.c_str()); converted_file.c_str());
return false; return false;
} }
map<wstring, wstring> files;
files[L"symbol_file"] = converted_file_w;
int timeout_ms = 60 * 1000;
FprintfFlush(stderr, "Uploading %s\n", converted_file.c_str()); FprintfFlush(stderr, "Uploading %s\n", converted_file.c_str());
if (!HTTPUpload::SendMultipartPostRequest( if (!google_breakpad::SymUploadV2ProtocolSend(
upload_symbol_url, parameters, upload_symbol_url.c_str(), api_key.c_str(), &timeout_ms, debug_file_w,
files, NULL, NULL, NULL)) { debug_id_w, converted_file_w, true)) {
FprintfFlush(stderr, "UploadSymbolFile: HTTPUpload::SendRequest failed " FprintfFlush(stderr, "UploadSymbolFile: HTTPUpload::SendRequest failed "
"for %s %s %s\n", "for %s %s %s\n",
missing_info.debug_file.c_str(), missing_info.debug_file.c_str(),
@ -319,6 +329,9 @@ struct ConverterOptions {
// URL for uploading symbols. // URL for uploading symbols.
wstring upload_symbols_url; wstring upload_symbols_url;
// API key to use when uploading symbols.
wstring api_key;
// URL to fetch list of missing symbols. // URL to fetch list of missing symbols.
wstring missing_symbols_url; wstring missing_symbols_url;
@ -413,8 +426,8 @@ static void ConvertMissingSymbolFile(const MissingSymbolInfo& missing_info,
// If it fails, something will print an error message indicating // If it fails, something will print an error message indicating
// the cause of the failure, and the item will remain on the // the cause of the failure, and the item will remain on the
// missing symbol list. // missing symbol list.
UploadSymbolFile(options.upload_symbols_url, missing_info, UploadSymbolFile(options.upload_symbols_url, options.api_key,
converted_file); missing_info, converted_file);
remove(converted_file.c_str()); remove(converted_file.c_str());
// Note: this does leave some directories behind that could be // Note: this does leave some directories behind that could be
@ -495,8 +508,8 @@ static void ConvertMissingSymbolFile(const MissingSymbolInfo& missing_info,
// If it fails, something will print an error message indicating // If it fails, something will print an error message indicating
// the cause of the failure, and the item will remain on the // the cause of the failure, and the item will remain on the
// missing symbol list. // missing symbol list.
UploadSymbolFile(options.upload_symbols_url, missing_info, UploadSymbolFile(options.upload_symbols_url, options.api_key,
converted_file); missing_info, converted_file);
remove(converted_file.c_str()); remove(converted_file.c_str());
// Note: this does leave some directories behind that could be // Note: this does leave some directories behind that could be
@ -648,12 +661,14 @@ static bool ConvertMissingSymbolsList(const ConverterOptions& options) {
// usage prints the usage message. It returns 1 as a convenience, to be used // usage prints the usage message. It returns 1 as a convenience, to be used
// as a return value from main. // as a return value from main.
static int usage(const char* program_name) { static int usage(const char* program_name) {
FprintfFlush(stderr, FprintfFlush(
stderr,
"usage: %s [options]\n" "usage: %s [options]\n"
" -f <full_msss_server> MS servers to ask for all symbols\n" " -f <full_msss_server> MS servers to ask for all symbols\n"
" -n <no_exe_msss_server> same, but prevent asking for EXEs\n" " -n <no_exe_msss_server> same, but prevent asking for EXEs\n"
" -l <local_cache_path> Temporary local storage for symbols\n" " -l <local_cache_path> Temporary local storage for symbols\n"
" -s <upload_url> URL for uploading symbols\n" " -s <upload_url> URL for uploading symbols\n"
" -k <api_key> API key to use when uploading symbols\n"
" -m <missing_symbols_url> URL to fetch list of missing symbols\n" " -m <missing_symbols_url> URL to fetch list of missing symbols\n"
" -mf <missing_symbols_file> File containing the list of missing\n" " -mf <missing_symbols_file> File containing the list of missing\n"
" symbols. Fetch failures are not\n" " symbols. Fetch failures are not\n"
@ -729,6 +744,12 @@ int main(int argc, char** argv) {
value.c_str()); value.c_str());
return 1; return 1;
} }
} else if (option == "-k") {
if (!WindowsStringUtils::safe_mbstowcs(value, &options.api_key)) {
FprintfFlush(stderr, "main: safe_mbstowcs failed for %s\n",
value.c_str());
return 1;
}
} else if (option == "-m") { } else if (option == "-m") {
if (!WindowsStringUtils::safe_mbstowcs(value, if (!WindowsStringUtils::safe_mbstowcs(value,
& options.missing_symbols_url)) { & options.missing_symbols_url)) {
@ -780,6 +801,10 @@ int main(int argc, char** argv) {
FprintfFlush(stderr, "No upload symbols URL specified.\n"); FprintfFlush(stderr, "No upload symbols URL specified.\n");
return usage(argv[0]); return usage(argv[0]);
} }
if (options.api_key.empty()) {
FprintfFlush(stderr, "No API key specified.\n");
return usage(argv[0]);
}
if (options.missing_symbols_url.empty() && if (options.missing_symbols_url.empty() &&
options.missing_symbols_file.empty()) { options.missing_symbols_file.empty()) {
FprintfFlush(stderr, "No missing symbols URL or file specified.\n"); FprintfFlush(stderr, "No missing symbols URL or file specified.\n");