From d1793df1eda463b10107d41785ad1d7f055ed476 Mon Sep 17 00:00:00 2001 From: ilotterytea Date: Sat, 18 May 2024 14:48:12 +0500 Subject: upd: moved the bot part to a relative subfolder --- src/api/twitch/helix_client.cpp | 144 ---------------------------------------- 1 file changed, 144 deletions(-) delete mode 100644 src/api/twitch/helix_client.cpp (limited to 'src/api/twitch/helix_client.cpp') diff --git a/src/api/twitch/helix_client.cpp b/src/api/twitch/helix_client.cpp deleted file mode 100644 index 04d630b..0000000 --- a/src/api/twitch/helix_client.cpp +++ /dev/null @@ -1,144 +0,0 @@ -#include "helix_client.hpp" - -#include -#include -#include - -#include "cpr/api.h" -#include "cpr/bearer.h" -#include "cpr/cprtypes.h" -#include "cpr/response.h" -#include "schemas/stream.hpp" -#include "schemas/user.hpp" - -namespace bot::api::twitch { - HelixClient::HelixClient(const std::string &token, - const std::string &client_id) { - this->token = token; - this->client_id = client_id; - } - - std::vector HelixClient::get_users( - const std::vector &logins) const { - std::string s; - - for (auto i = logins.begin(); i != logins.end(); i++) { - std::string start; - if (i == logins.begin()) { - start = "?"; - } else { - start = "&"; - } - - s += start + "login=" + *i; - } - - return this->get_users_by_query(s); - } - - std::vector HelixClient::get_users( - const std::vector &ids) const { - std::string s; - - for (auto i = ids.begin(); i != ids.end(); i++) { - std::string start; - if (i == ids.begin()) { - start = "?"; - } else { - start = "&"; - } - - s += start + "id=" + std::to_string(*i); - } - - return this->get_users_by_query(s); - } - - std::vector HelixClient::get_users_by_query( - const std::string &query) const { - cpr::Response response = cpr::Get( - cpr::Url{this->base_url + "/users" + query}, cpr::Bearer{this->token}, - cpr::Header{{"Client-Id", this->client_id.c_str()}}); - - if (response.status_code != 200) { - return {}; - } - - std::vector users; - - nlohmann::json j = nlohmann::json::parse(response.text); - - for (const auto &d : j["data"]) { - schemas::User u{std::stoi(d["id"].get()), d["login"]}; - - users.push_back(u); - } - - return users; - } - - std::vector HelixClient::get_chatters( - const int &broadcaster_id, const int &moderator_id) const { - cpr::Response response = - cpr::Get(cpr::Url{this->base_url + "/chat/chatters?broadcaster_id=" + - std::to_string(broadcaster_id) + - "&moderator_id=" + std::to_string(moderator_id)}, - cpr::Bearer{this->token}, - cpr::Header{{"Client-Id", this->client_id.c_str()}}); - - if (response.status_code != 200) { - return {}; - } - - std::vector users; - - nlohmann::json j = nlohmann::json::parse(response.text); - - for (const auto &d : j["data"]) { - schemas::User u{std::stoi(d["user_id"].get()), - d["user_login"]}; - - users.push_back(u); - } - - return users; - } - - std::vector HelixClient::get_streams( - const std::vector &ids) const { - std::string s; - - for (auto i = ids.begin(); i != ids.end(); i++) { - std::string start; - if (i == ids.begin()) { - start = "?"; - } else { - start = "&"; - } - - s += start + "user_id=" + std::to_string(*i); - } - - cpr::Response response = cpr::Get( - cpr::Url{this->base_url + "/streams" + s}, cpr::Bearer{this->token}, - cpr::Header{{"Client-Id", this->client_id.c_str()}}); - - if (response.status_code != 200) { - return {}; - } - - std::vector streams; - - nlohmann::json j = nlohmann::json::parse(response.text); - - for (const auto &d : j["data"]) { - schemas::Stream u{std::stoi(d["user_id"].get()), - d["user_login"], d["game_name"], d["title"], - d["started_at"]}; - - streams.push_back(u); - } - - return streams; - } -} -- cgit v1.2.3