22 #include <curl/curl.h>
25 #define ERR_NW LOG_STREAM(err, log_network)
26 #define DBG_NW LOG_STREAM(debug, log_network)
32 size_t amount =
size * nmemb;
33 static_cast<std::string*
>(buffer)->append(contents, amount);
34 DBG_NW <<
"Downloaded " << amount <<
" bytes.";
38 void gui_download(
const std::string& url,
const std::string& local_path) {
46 gui2::show_message(
_(
"Download complete"),
_(
"The file has been downloaded."), gui2::dialogs::message::button_style::auto_close);
48 gui2::show_message(
_(
"Download error"),
_(
"An error occurred when downloading the file. Check the game logs for more information."), gui2::dialogs::message::button_style::auto_close);
52 bool download(
const std::string& url,
const std::string& local_path)
54 std::unique_ptr<CURL, decltype(&curl_easy_cleanup)> curl(curl_easy_init(), curl_easy_cleanup);
57 char error[CURL_ERROR_SIZE];
58 std::fill_n(error, CURL_ERROR_SIZE-1,
' ');
59 error[CURL_ERROR_SIZE-1] =
'\0';
62 ERR_NW <<
"curl_easy_init failed initialization, unable to download file.";
67 if((res = curl_easy_setopt(curl.get(), CURLOPT_URL, url.c_str())) != CURLE_OK ||
68 (res = curl_easy_setopt(curl.get(), CURLOPT_WRITEFUNCTION,
write_callback)) != CURLE_OK ||
69 (res = curl_easy_setopt(curl.get(), CURLOPT_WRITEDATA, &buffer)) != CURLE_OK ||
70 (res = curl_easy_setopt(curl.get(), CURLOPT_ERRORBUFFER, error)) != CURLE_OK ||
71 (res = curl_easy_setopt(curl.get(), CURLOPT_FORBID_REUSE, 1L)) != CURLE_OK ||
72 (res = curl_easy_setopt(curl.get(), CURLOPT_FRESH_CONNECT, 1L)) != CURLE_OK ||
73 (res = curl_easy_setopt(curl.get(), CURLOPT_FAILONERROR, 1L)) != CURLE_OK ||
74 (res = curl_easy_setopt(curl.get(), CURLOPT_TIMEOUT_MS, 5000L)) != CURLE_OK ||
75 #
if LIBCURL_VERSION_NUM >= 0x075500
76 (res = curl_easy_setopt(curl.get(), CURLOPT_PROTOCOLS_STR,
"https")) != CURLE_OK
78 (res = curl_easy_setopt(curl.get(), CURLOPT_PROTOCOLS, CURLPROTO_HTTPS)) != CURLE_OK
81 ERR_NW <<
"Error setting curl option: " << curl_easy_strerror(res);
85 res = curl_easy_perform(curl.get());
87 ERR_NW <<
"Error downloading file from url `" << url <<
"`.\n"
88 <<
"Short error: " << curl_easy_strerror(res) <<
"\n"
89 <<
"Long error: " << std::string(error);
95 DBG_NW <<
"Wrote downloaded file to: " << local_path;
97 ERR_NW <<
"io_exception writing downloaded data to file at: " << local_path <<
"\n" <<
e.what() <<
" : " <<
e.message;
@ yes_no_buttons
Shows a yes and no button.
Declarations for File-IO.
static std::string _(const char *str)
Standard logging facilities (interface).
static bool file_exists(const bfs::path &fpath)
void write_file(const std::string &fname, const std::string &data, std::ios_base::openmode mode)
Throws io_exception if an error occurs.
void show_message(const std::string &title, const std::string &msg, const std::string &button_caption, const bool auto_close, const bool message_use_markup, const bool title_use_markup)
Shows a message to the user.
@ OK
Dialog was closed with the OK button.
High level network layer for config object transport.
void gui_download(const std::string &url, const std::string &local_path)
Initiates a standalone download of a single file from an HTTPS URL.
bool download(const std::string &url, const std::string &local_path)
static size_t write_callback(char *contents, size_t size, size_t nmemb, void *buffer)
std::size_t size(std::string_view str)
Length in characters of a UTF-8 string.
static lg::log_domain log_network("network")
An exception object used when an IO error occurs.