2023-10-04 12:00:32 +02:00
|
|
|
#pragma once
|
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
#if defined(OS_WEB)
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
#include <future>
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
#include <emscripten/fetch.h>
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
namespace hex {
|
|
|
|
template<typename T>
|
|
|
|
std::future<HttpRequest::Result<T>> HttpRequest::downloadFile(const std::fs::path &path) {
|
|
|
|
return std::async(std::launch::async, [this, path] {
|
|
|
|
std::vector<u8> response;
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
// Execute the request
|
|
|
|
auto result = this->executeImpl<T>(response);
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
// Write the result to the file
|
|
|
|
wolv::io::File file(path, wolv::io::File::Mode::Create);
|
|
|
|
file.writeBuffer(reinterpret_cast<const u8*>(result.getData().data()), result.getData().size());
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
return result;
|
|
|
|
});
|
|
|
|
}
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
template<typename T>
|
|
|
|
std::future<HttpRequest::Result<T>> HttpRequest::uploadFile(const std::fs::path &path, const std::string &mimeName) {
|
|
|
|
hex::unused(path, mimeName);
|
|
|
|
throw std::logic_error("Not implemented");
|
|
|
|
}
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
template<typename T>
|
|
|
|
std::future<HttpRequest::Result<T>> HttpRequest::uploadFile(std::vector<u8> data, const std::string &mimeName, const std::fs::path &fileName) {
|
|
|
|
hex::unused(data, mimeName, fileName);
|
|
|
|
throw std::logic_error("Not implemented");
|
|
|
|
}
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
template<typename T>
|
|
|
|
std::future<HttpRequest::Result<T>> HttpRequest::execute() {
|
|
|
|
return std::async(std::launch::async, [this] {
|
|
|
|
std::vector<u8> responseData;
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
return this->executeImpl<T>(responseData);
|
|
|
|
});
|
2023-10-04 12:00:32 +02:00
|
|
|
}
|
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
template<typename T>
|
|
|
|
HttpRequest::Result<T> HttpRequest::executeImpl(std::vector<u8> &data) {
|
|
|
|
strcpy(m_attr.requestMethod, m_method.c_str());
|
|
|
|
m_attr.attributes = EMSCRIPTEN_FETCH_SYNCHRONOUS | EMSCRIPTEN_FETCH_LOAD_TO_MEMORY;
|
|
|
|
|
|
|
|
if (!m_body.empty()) {
|
|
|
|
m_attr.requestData = m_body.c_str();
|
|
|
|
m_attr.requestDataSize = m_body.size();
|
|
|
|
}
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
std::vector<const char*> headers;
|
|
|
|
for (auto it = m_headers.begin(); it != m_headers.end(); it++) {
|
|
|
|
headers.push_back(it->first.c_str());
|
|
|
|
headers.push_back(it->second.c_str());
|
|
|
|
}
|
|
|
|
headers.push_back(nullptr);
|
|
|
|
m_attr.requestHeaders = headers.data();
|
2023-10-04 12:00:32 +02:00
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
// Send request
|
|
|
|
emscripten_fetch_t* fetch = emscripten_fetch(&m_attr, m_url.c_str());
|
|
|
|
|
|
|
|
data.resize(fetch->numBytes);
|
|
|
|
std::copy(fetch->data, fetch->data + fetch->numBytes, data.begin());
|
|
|
|
|
|
|
|
return Result<T>(fetch->status, { data.begin(), data.end() });
|
|
|
|
}
|
2023-10-04 12:00:32 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2024-02-29 18:48:16 +00:00
|
|
|
#endif
|