input/curl: pass additional request headers to constructor
Prepare to allow callers to pass custom request headers.
This commit is contained in:
parent
3fe5b42b2b
commit
f392e13077
@ -78,6 +78,7 @@ class CurlInputStream final : public AsyncInputStream, CurlResponseHandler {
|
|||||||
public:
|
public:
|
||||||
template<typename I>
|
template<typename I>
|
||||||
CurlInputStream(EventLoop &event_loop, const char *_url,
|
CurlInputStream(EventLoop &event_loop, const char *_url,
|
||||||
|
const std::multimap<std::string, std::string> &headers,
|
||||||
I &&_icy,
|
I &&_icy,
|
||||||
Mutex &_mutex, Cond &_cond);
|
Mutex &_mutex, Cond &_cond);
|
||||||
|
|
||||||
@ -86,7 +87,9 @@ public:
|
|||||||
CurlInputStream(const CurlInputStream &) = delete;
|
CurlInputStream(const CurlInputStream &) = delete;
|
||||||
CurlInputStream &operator=(const CurlInputStream &) = delete;
|
CurlInputStream &operator=(const CurlInputStream &) = delete;
|
||||||
|
|
||||||
static InputStreamPtr Open(const char *url, Mutex &mutex, Cond &cond);
|
static InputStreamPtr Open(const char *url,
|
||||||
|
const std::multimap<std::string, std::string> &headers,
|
||||||
|
Mutex &mutex, Cond &cond);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/**
|
/**
|
||||||
@ -344,6 +347,7 @@ input_curl_finish() noexcept
|
|||||||
template<typename I>
|
template<typename I>
|
||||||
inline
|
inline
|
||||||
CurlInputStream::CurlInputStream(EventLoop &event_loop, const char *_url,
|
CurlInputStream::CurlInputStream(EventLoop &event_loop, const char *_url,
|
||||||
|
const std::multimap<std::string, std::string> &headers,
|
||||||
I &&_icy,
|
I &&_icy,
|
||||||
Mutex &_mutex, Cond &_cond)
|
Mutex &_mutex, Cond &_cond)
|
||||||
:AsyncInputStream(event_loop, _url, _mutex, _cond,
|
:AsyncInputStream(event_loop, _url, _mutex, _cond,
|
||||||
@ -352,6 +356,9 @@ CurlInputStream::CurlInputStream(EventLoop &event_loop, const char *_url,
|
|||||||
icy(std::forward<I>(_icy))
|
icy(std::forward<I>(_icy))
|
||||||
{
|
{
|
||||||
request_headers.Append("Icy-Metadata: 1");
|
request_headers.Append("Icy-Metadata: 1");
|
||||||
|
|
||||||
|
for (const auto &i : headers)
|
||||||
|
request_headers.Append((i.first + ":" + i.second).c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
CurlInputStream::~CurlInputStream() noexcept
|
CurlInputStream::~CurlInputStream() noexcept
|
||||||
@ -442,12 +449,14 @@ CurlInputStream::DoSeek(offset_type new_offset)
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline InputStreamPtr
|
inline InputStreamPtr
|
||||||
CurlInputStream::Open(const char *url, Mutex &mutex, Cond &cond)
|
CurlInputStream::Open(const char *url,
|
||||||
|
const std::multimap<std::string, std::string> &headers,
|
||||||
|
Mutex &mutex, Cond &cond)
|
||||||
{
|
{
|
||||||
auto icy = std::make_shared<IcyMetaDataParser>();
|
auto icy = std::make_shared<IcyMetaDataParser>();
|
||||||
|
|
||||||
auto c = std::make_unique<CurlInputStream>((*curl_init)->GetEventLoop(),
|
auto c = std::make_unique<CurlInputStream>((*curl_init)->GetEventLoop(),
|
||||||
url,
|
url, headers,
|
||||||
icy,
|
icy,
|
||||||
mutex, cond);
|
mutex, cond);
|
||||||
|
|
||||||
@ -466,7 +475,7 @@ input_curl_open(const char *url, Mutex &mutex, Cond &cond)
|
|||||||
strncmp(url, "https://", 8) != 0)
|
strncmp(url, "https://", 8) != 0)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
return CurlInputStream::Open(url, mutex, cond);
|
return CurlInputStream::Open(url, {}, mutex, cond);
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct InputPlugin input_plugin_curl = {
|
const struct InputPlugin input_plugin_curl = {
|
||||||
|
Loading…
Reference in New Issue
Block a user