summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/connection.cpp14
-rw-r--r--src/curl_wrapper.cpp18
2 files changed, 31 insertions, 1 deletions
diff --git a/src/connection.cpp b/src/connection.cpp
index f74a816..9cde7d3 100644
--- a/src/connection.cpp
+++ b/src/connection.cpp
@@ -61,6 +61,20 @@ answer_type Connection::post(const endpoint_variant &endpoint,
endpoint_to_uri(endpoint), parameters);
}
+answer_type Connection::patch(const endpoint_variant &endpoint,
+ const parametermap &parameters)
+{
+ return make_request(http_method::PATCH,
+ endpoint_to_uri(endpoint), parameters);
+}
+
+answer_type Connection::put(const endpoint_variant &endpoint,
+ const parametermap &parameters)
+{
+ return make_request(http_method::PUT,
+ endpoint_to_uri(endpoint), parameters);
+}
+
string Connection::get_new_stream_contents()
{
buffer_mutex.lock();
diff --git a/src/curl_wrapper.cpp b/src/curl_wrapper.cpp
index 047b799..7b2b352 100644
--- a/src/curl_wrapper.cpp
+++ b/src/curl_wrapper.cpp
@@ -111,14 +111,30 @@ answer_type CURLWrapper::make_request(const http_method &method, string uri,
}
case http_method::PATCH:
{
+ if (!parameters.empty())
+ {
+ curl_mime *mime{parameters_to_curl_mime(uri, parameters)};
+ // NOLINTNEXTLINE(cppcoreguidelines-pro-type-vararg)
+ code = curl_easy_setopt(_connection, CURLOPT_MIMEPOST, mime);
+ }
+
// NOLINTNEXTLINE(cppcoreguidelines-pro-type-vararg)
code = curl_easy_setopt(_connection, CURLOPT_CUSTOMREQUEST, "PATCH");
+
break;
}
case http_method::PUT:
{
+ if (!parameters.empty())
+ {
+ curl_mime *mime{parameters_to_curl_mime(uri, parameters)};
+ // NOLINTNEXTLINE(cppcoreguidelines-pro-type-vararg)
+ code = curl_easy_setopt(_connection, CURLOPT_MIMEPOST, mime);
+ }
+
// NOLINTNEXTLINE(cppcoreguidelines-pro-type-vararg)
- code = curl_easy_setopt(_connection, CURLOPT_UPLOAD, 1L);
+ code = curl_easy_setopt(_connection, CURLOPT_CUSTOMREQUEST, "PUT");
+
break;
}
case http_method::DELETE: