From 62801f1bd91f7727f4a203b107f3f4b6283866a2 Mon Sep 17 00:00:00 2001 From: TiagoRG Date: Sat, 30 Dec 2023 21:10:58 +0000 Subject: [PATCH] Fix token handling bug Signed-off-by: TiagoRG --- main.cpp | 66 +++++++++++++++++++++++++++++++++++++++----------------- 1 file changed, 46 insertions(+), 20 deletions(-) diff --git a/main.cpp b/main.cpp index 7ce95bf..5e9d8ec 100644 --- a/main.cpp +++ b/main.cpp @@ -8,11 +8,11 @@ int main(int argc, char **argv) { if (argc != 2) { - std::cerr << "Usage: " << argv[0] << " " << std::endl; + std::cerr << "Usage: " << 0[argv] << " " << std::endl; return 1; } - std::ifstream config_file(argv[1]); + std::ifstream config_file(1[argv]); if (!config_file.is_open()) { std::cerr << "Failed to open config.json" << std::endl; return 1; @@ -31,34 +31,50 @@ int main(int argc, char **argv) { nlohmann::json &tokens = config["tokens"]; crow::SimpleApp app; - CROW_ROUTE(app, "/github-webhook") + CROW_ROUTE(app, "/update-files") .methods("POST"_method) ([&repos, &tokens](const crow::request &req) { + nlohmann::json payload; try { // Parse JSON payload from the request body - nlohmann::json payload = nlohmann::json::parse(req.body); - nlohmann::json response; + payload = nlohmann::json::parse(req.body); + } catch (const std::exception &e) { + std::cerr << "Error processing webhook: " << e.what() << std::endl; + nlohmann::json response = { + {"status", 400}, + {"error", "Invalid JSON payload"} + }; + return crow::response(400, response.dump()); + } + try { std::string ref = payload["ref"]; size_t last_slash = ref.find_last_of('/'); if (last_slash != std::string::npos && last_slash + 1 < ref.length()) ref = ref.substr(last_slash + 1); std::string repo = payload["repository"]["full_name"]; bool is_private = payload["repository"]["private"]; - if (is_private && tokens.find(repo) == tokens.end()) { - printf("No token configured for private repo %s\n", repo.c_str()); - response["status"] = 403; - response["error"] = "No token configured for private repo"; - return crow::response(403, response.dump()); + std::string token; + if (is_private) { + if (tokens.find(repo) == tokens.end()) { + printf("No token configured for private repo %s\n", repo.c_str()); + nlohmann::json response = { + {"status", 403}, + {"error", "No token configured for private repo"} + }; + return crow::response(403, response.dump()); + } + token = tokens[repo]; } - std::string token = tokens[repo]; printf("Received push to %s:%s (private: %s)\n", repo.c_str(), ref.c_str(), is_private ? "true" : "false"); if (repos.find(repo) == repos.end()) { printf("No webhook configured for %s\n", repo.c_str()); - response["status"] = 404; - response["error"] = "No webhook configured for repo"; + nlohmann::json response = { + {"status", 404}, + {"error", "No webhook configured for repo"} + }; return crow::response(404, response.dump()); } @@ -74,33 +90,43 @@ int main(int argc, char **argv) { if (!is_valid_branch) { printf("No webhook configured for %s:%s\n", repo.c_str(), ref.c_str()); - response["status"] = 404; - response["error"] = "No webhook configured for branch" + ref; + nlohmann::json response = { + {"status", 404}, + {"error", "No webhook configured for branch" + ref} + }; return crow::response(404, response.dump()); } if (repo_data["files"].empty()) { printf("No files configured for %s:%s\n", repo.c_str(), ref.c_str()); - response["status"] = 404; - response["error"] = "No files configured for branch " + ref; + nlohmann::json response = { + {"status", 404}, + {"error", "No files configured for branch" + ref} + }; return crow::response(404, response.dump()); } - response["updated"] = nlohmann::json::array(); + nlohmann::json response = { + {"status", 200}, + {"file_count", 0}, + {"updated", nlohmann::json::array()} + }; for (auto &commit : payload["commits"]) { for (auto &file : commit["modified"]) { std::string file_path = file; if (repos[repo]["files"].find(file_path) == repos[repo]["files"].end()) continue; std::string path = repos[repo]["files"][file_path]; std::string create_dir = "mkdir -p $(dirname " + path + ")"; - std::string command = "curl -s https://raw.githubusercontent.com/" + repo + "/" + ref + "/" + file_path + " -H 'Authorization: token " + token + "' -o " + path; + std::string command = "curl -s https://raw.githubusercontent.com/" + repo + "/" + ref + "/" + file_path + " -o " + path; + if (is_private) + command += " -H 'Authorization: token " + token + "'"; std::system(create_dir.c_str()); std::system(command.c_str()); printf("Updated %s\n", path.c_str()); + response["file_count"] = response["file_count"].get() + 1; response["updated"].push_back(file_path); } } - response["status"] = 200; return crow::response(200, response.dump()); } catch (const std::exception &e) {