summaryrefslogtreecommitdiffstats
path: root/include/answer.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'include/answer.hpp')
-rw-r--r--include/answer.hpp106
1 files changed, 106 insertions, 0 deletions
diff --git a/include/answer.hpp b/include/answer.hpp
new file mode 100644
index 0000000..2eb05aa
--- /dev/null
+++ b/include/answer.hpp
@@ -0,0 +1,106 @@
+/* This file is part of mastodonpp.
+ * Copyright © 2020 tastytea <tastytea@tastytea.de>
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, version 3.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef MASTODONPP_ANSWER_HPP
+#define MASTODONPP_ANSWER_HPP
+
+#include <cstdint>
+#include <string>
+#include <string_view>
+
+namespace mastodonpp
+{
+
+using std::uint8_t;
+using std::uint16_t;
+using std::string;
+using std::string_view;
+
+/*!
+ * @brief Return type for Request%s.
+ *
+ * @since 0.1.0
+ *
+ * @headerfile answer.hpp mastodonpp/answer.hpp
+ *
+ */
+struct answer_type
+{
+ /*!
+ * @brief The error code returned by libcurl.
+ *
+ * For more information consult
+ * [libcurl-errors(3)](https://curl.haxx.se/libcurl/c/libcurl-errors.html).
+ *
+ * @since 0.1.0
+ */
+ uint8_t curl_error_code{0};
+
+ /*!
+ * @brief The error message.
+ *
+ * @since 0.1.0
+ */
+ string error_message;
+
+ /*!
+ * @brief HTTP status code.
+ *
+ * @since 0.1.0
+ */
+ uint16_t http_status{0};
+
+ /*!
+ * @brief The headers of the response from the server.
+ *
+ * @since 0.1.0
+ */
+ string headers;
+
+ /*!
+ * @brief The response from the server, usually JSON.
+ *
+ * @since 0.1.0
+ */
+ string body;
+
+ /*!
+ * @brief Returns true if #curl_error_code is 0 and #http_status is 200,
+ * false otherwise.
+ *
+ * @since 0.1.0
+ */
+ explicit operator bool() const;
+
+ /*!
+ * @brief Returns #body as `std::string_view`.
+ *
+ * @since 0.1.0
+ */
+ explicit operator string_view() const;
+
+ /*!
+ * @brief Returns #body as `std::ostream`.
+ *
+ * @since 0.1.0
+ */
+ friend std::ostream &operator <<(std::ostream &out,
+ const answer_type &answer);
+};
+
+} // namespace mastodonpp
+
+#endif // MASTODONPP_ANSWER_HPP