summaryrefslogtreecommitdiffstats
path: root/examples
diff options
context:
space:
mode:
Diffstat (limited to 'examples')
-rw-r--r--examples/example01_instance_info.cpp83
1 files changed, 83 insertions, 0 deletions
diff --git a/examples/example01_instance_info.cpp b/examples/example01_instance_info.cpp
new file mode 100644
index 0000000..6d371f3
--- /dev/null
+++ b/examples/example01_instance_info.cpp
@@ -0,0 +1,83 @@
+/* This file is part of mastodonpp.
+ * Copyright © 2020 tastytea <tastytea@tastytea.de>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
+ * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
+ * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
+ * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+// Print information about an instance (/api/v1/instance).
+
+#include <mastodonpp.hpp>
+
+#include <iostream>
+#include <string>
+#include <string_view>
+#include <vector>
+
+namespace masto = mastodonpp;
+using std::cout;
+using std::cerr;
+using std::endl;
+using std::to_string;
+using std::string_view;
+using std::vector;
+
+int main(int argc, char *argv[])
+{
+ const vector<string_view> args(argv, argv + argc);
+ if (args.size() <= 1)
+ {
+ cerr << "Usage: " << args[0] << " <instance hostname>\n";
+ return 1;
+ }
+
+ try
+ {
+ // Initialize an Instance.
+ masto::Instance instance{args[1], {}};
+
+ // Get maximum allowed characters per post.
+ const auto max_chars{instance.get_max_chars()};
+ cout << "Maximum characters per post: " << max_chars << "\n\n";
+
+ // Initialize a Connection.
+ masto::Connection connection{instance};
+
+ // Get information about the instance.
+ masto::answer_type answer{connection.get(masto::API::v1::instance)};
+ if (answer)
+ {
+ cout << answer << endl;
+ }
+ else
+ {
+ if (answer.curl_error_code == 0)
+ {
+ // If it is no libcurl error, it must be an HTTP error.
+ cerr << "HTTP status: " << answer.http_status << endl;
+ }
+ else
+ {
+ // Network errors like “Couldn't resolve host.”.
+ cerr << "libcurl error " << to_string(answer.curl_error_code)
+ << ": " << answer.error_message << endl;
+ }
+ }
+ }
+ catch (const masto::CURLException &e)
+ {
+ // Only libcurl errors that are not network errors will be thrown.
+ // There went probably something wrong with the initialization.
+ cerr << e.what() << endl;
+ }
+
+ return 0;
+}