diff --git a/Source/Core/Common/HttpRequest.cpp b/Source/Core/Common/HttpRequest.cpp index 63e4e85878..cee9d7434c 100644 --- a/Source/Core/Common/HttpRequest.cpp +++ b/Source/Core/Common/HttpRequest.cpp @@ -30,6 +30,7 @@ public: bool IsValid() const; void SetCookies(const std::string& cookies); void UseIPv4(); + void FollowRedirects(long max); Response Fetch(const std::string& url, Method method, const Headers& headers, const u8* payload, size_t size); @@ -68,6 +69,11 @@ void HttpRequest::UseIPv4() m_impl->UseIPv4(); } +void HttpRequest::FollowRedirects(long max) +{ + m_impl->FollowRedirects(max); +} + HttpRequest::Response HttpRequest::Get(const std::string& url, const Headers& headers) { return m_impl->Fetch(url, Impl::Method::GET, headers, nullptr, 0); @@ -147,6 +153,12 @@ void HttpRequest::Impl::UseIPv4() curl_easy_setopt(m_curl.get(), CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4); } +void HttpRequest::Impl::FollowRedirects(long max) +{ + curl_easy_setopt(m_curl.get(), CURLOPT_FOLLOWLOCATION, 1); + curl_easy_setopt(m_curl.get(), CURLOPT_MAXREDIRS, max); +} + static size_t CurlWriteCallback(char* data, size_t size, size_t nmemb, void* userdata) { auto* buffer = static_cast*>(userdata); diff --git a/Source/Core/Common/HttpRequest.h b/Source/Core/Common/HttpRequest.h index 94916f5c3c..17e31ff354 100644 --- a/Source/Core/Common/HttpRequest.h +++ b/Source/Core/Common/HttpRequest.h @@ -33,6 +33,7 @@ public: void SetCookies(const std::string& cookies); void UseIPv4(); + void FollowRedirects(long max = 1); Response Get(const std::string& url, const Headers& headers = {}); Response Post(const std::string& url, const std::vector& payload, const Headers& headers = {});