From 7af01ffb1771e5e5e16f21e885924a8e744049f5 Mon Sep 17 00:00:00 2001 From: tastytea Date: Sun, 12 Jan 2020 16:28:11 +0100 Subject: [PATCH] Add ObtainToken-example. --- examples/example08_obtain_token.cpp | 111 ++++++++++++++++++++++++++++ include/mastodonpp.hpp | 1 + 2 files changed, 112 insertions(+) create mode 100644 examples/example08_obtain_token.cpp diff --git a/examples/example08_obtain_token.cpp b/examples/example08_obtain_token.cpp new file mode 100644 index 0000000..8c78aef --- /dev/null +++ b/examples/example08_obtain_token.cpp @@ -0,0 +1,111 @@ +/* This file is part of mastodonpp. + * Copyright © 2020 tastytea + * + * 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. + */ + +// Obtain an access token and verify that it works. + +#include "mastodonpp.hpp" + +#include +#include +#include +#include +#include + +namespace masto = mastodonpp; +using std::exit; +using std::cout; +using std::cerr; +using std::endl; +using std::cin; +using std::string; +using std::to_string; +using std::string_view; +using std::vector; + +void handle_error(const masto::answer_type &answer); + +int main(int argc, char *argv[]) +{ + const vector args(argv, argv + argc); + if (args.size() <= 1) + { + cerr << "Usage: " << args[0] << " \n"; + return 1; + } + + try + { + // Initialize Instance and Instance::ObtainToken. + masto::Instance instance{args[1], {}}; + masto::Instance::ObtainToken token{instance}; + + // Create an “Application” (/api/v1/apps), + // and get URI for the authorization code (/oauth/authorize). + auto answer{token.step_1("Testclient", "read:blocks read:mutes", + "https://tastytea.de/")}; + if (!answer) + { + handle_error(answer); + } + + cout << "Please visit " << answer << "\nand paste the code here: "; + string code; + cin >> code; + + // Obtain the token (/oauth/token). + answer = token.step_2(code); + if (!answer) + { + handle_error(answer); + } + + cout << "Your access token is: " << answer << endl; + + // Test if the token works. + masto::Connection connection{instance}; + answer = connection.get(masto::API::v1::apps_verify_credentials); + if (!answer) + { + handle_error(answer); + } + + cout << answer << 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; +} + +void handle_error(const masto::answer_type &answer) +{ + 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; + } + + exit(1); +} diff --git a/include/mastodonpp.hpp b/include/mastodonpp.hpp index d6f8564..ca396d7 100644 --- a/include/mastodonpp.hpp +++ b/include/mastodonpp.hpp @@ -105,6 +105,7 @@ * @example example05_update_notification_settings.cpp * @example example06_update_name.cpp * @example example07_delete_status.cpp + * @example example08_obtain_token.cpp */ /*!