lib/curl/Easy: add setter functions

This commit is contained in:
Max Kellermann 2019-08-19 21:16:51 +02:00
parent 4c46ca6b59
commit 402f429b17
3 changed files with 87 additions and 17 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2016-2018 Max Kellermann <max.kellermann@gmail.com> * Copyright 2016-2018 Max Kellermann <max.kellermann@gmail.com>
* *
* Redistribution and use in source and binary forms, with or without * Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions * modification, are permitted provided that the following conditions
@ -88,6 +88,78 @@ public:
throw std::runtime_error(curl_easy_strerror(code)); throw std::runtime_error(curl_easy_strerror(code));
} }
void SetPrivate(void *pointer) {
SetOption(CURLOPT_PRIVATE, pointer);
}
void SetErrorBuffer(char *buf) {
SetOption(CURLOPT_ERRORBUFFER, buf);
}
void SetURL(const char *value) {
SetOption(CURLOPT_URL, value);
}
void SetUserAgent(const char *value) {
SetOption(CURLOPT_USERAGENT, value);
}
void SetRequestHeaders(struct curl_slist *headers) {
SetOption(CURLOPT_HTTPHEADER, headers);
}
void SetBasicAuth(const char *userpwd) {
SetOption(CURLOPT_USERPWD, userpwd);
}
void SetNoProgress(bool value=true) {
SetOption(CURLOPT_NOPROGRESS, (long)value);
}
void SetNoSignal(bool value=true) {
SetOption(CURLOPT_NOSIGNAL, (long)value);
}
void SetFailOnError(bool value=true) {
SetOption(CURLOPT_FAILONERROR, (long)value);
}
void SetConnectTimeout(long timeout) {
SetOption(CURLOPT_CONNECTTIMEOUT, timeout);
}
void SetHeaderFunction(size_t (*function)(char *buffer, size_t size,
size_t nitems,
void *userdata),
void *userdata) {
SetOption(CURLOPT_HEADERFUNCTION, function);
SetOption(CURLOPT_HEADERDATA, userdata);
}
void SetWriteFunction(size_t (*function)(char *ptr, size_t size,
size_t nmemb, void *userdata),
void *userdata) {
SetOption(CURLOPT_WRITEFUNCTION, function);
SetOption(CURLOPT_WRITEDATA, userdata);
}
void SetNoBody(bool value=true) {
SetOption(CURLOPT_NOBODY, (long)value);
}
void SetPost(bool value=true) {
SetOption(CURLOPT_POST, (long)value);
}
void SetRequestBody(const void *data, size_t size) {
SetOption(CURLOPT_POSTFIELDS, data);
SetOption(CURLOPT_POSTFIELDSIZE, (long)size);
}
void SetHttpPost(const struct curl_httppost *post) {
SetOption(CURLOPT_HTTPPOST, post);
}
char *Escape(const char *string, int length=0) const noexcept { char *Escape(const char *string, int length=0) const noexcept {
return curl_easy_escape(handle, string, length); return curl_easy_escape(handle, string, length);
} }

View File

@ -53,17 +53,15 @@ CurlRequest::CurlRequest(CurlGlobal &_global,
{ {
error_buffer[0] = 0; error_buffer[0] = 0;
easy.SetOption(CURLOPT_PRIVATE, (void *)this); easy.SetPrivate((void *)this);
easy.SetOption(CURLOPT_USERAGENT, "Music Player Daemon " VERSION); easy.SetUserAgent("Music Player Daemon " VERSION);
easy.SetOption(CURLOPT_HEADERFUNCTION, _HeaderFunction); easy.SetHeaderFunction(_HeaderFunction, this);
easy.SetOption(CURLOPT_WRITEHEADER, this); easy.SetWriteFunction(WriteFunction, this);
easy.SetOption(CURLOPT_WRITEFUNCTION, WriteFunction);
easy.SetOption(CURLOPT_WRITEDATA, this);
easy.SetOption(CURLOPT_NETRC, 1l); easy.SetOption(CURLOPT_NETRC, 1l);
easy.SetOption(CURLOPT_ERRORBUFFER, error_buffer); easy.SetErrorBuffer(error_buffer);
easy.SetOption(CURLOPT_NOPROGRESS, 1l); easy.SetNoProgress();
easy.SetOption(CURLOPT_NOSIGNAL, 1l); easy.SetNoSignal();
easy.SetOption(CURLOPT_CONNECTTIMEOUT, 10l); easy.SetConnectTimeout(10);
easy.SetOption(CURLOPT_HTTPAUTH, (long) CURLAUTH_ANY); easy.SetOption(CURLOPT_HTTPAUTH, (long) CURLAUTH_ANY);
} }
@ -227,14 +225,14 @@ CurlRequest::HeaderFunction(StringView s) noexcept
} }
size_t size_t
CurlRequest::_HeaderFunction(void *ptr, size_t size, size_t nmemb, CurlRequest::_HeaderFunction(char *ptr, size_t size, size_t nmemb,
void *stream) noexcept void *stream) noexcept
{ {
CurlRequest &c = *(CurlRequest *)stream; CurlRequest &c = *(CurlRequest *)stream;
size *= nmemb; size *= nmemb;
c.HeaderFunction({(const char *)ptr, size}); c.HeaderFunction({ptr, size});
return size; return size;
} }
@ -261,7 +259,7 @@ CurlRequest::DataReceived(const void *ptr, size_t received_size) noexcept
} }
size_t size_t
CurlRequest::WriteFunction(void *ptr, size_t size, size_t nmemb, CurlRequest::WriteFunction(char *ptr, size_t size, size_t nmemb,
void *stream) noexcept void *stream) noexcept
{ {
CurlRequest &c = *(CurlRequest *)stream; CurlRequest &c = *(CurlRequest *)stream;

View File

@ -127,7 +127,7 @@ public:
} }
void SetUrl(const char *url) { void SetUrl(const char *url) {
easy.SetOption(CURLOPT_URL, url); easy.SetURL(url);
} }
/** /**
@ -160,11 +160,11 @@ private:
void OnPostponeError() noexcept; void OnPostponeError() noexcept;
/** called by curl when new data is available */ /** called by curl when new data is available */
static size_t _HeaderFunction(void *ptr, size_t size, size_t nmemb, static size_t _HeaderFunction(char *ptr, size_t size, size_t nmemb,
void *stream) noexcept; void *stream) noexcept;
/** called by curl when new data is available */ /** called by curl when new data is available */
static size_t WriteFunction(void *ptr, size_t size, size_t nmemb, static size_t WriteFunction(char *ptr, size_t size, size_t nmemb,
void *stream) noexcept; void *stream) noexcept;
}; };