This commit is contained in:
		
							parent
							
								
									bd01b506f0
								
							
						
					
					
						commit
						4ba8710a71
					
				| @ -8,6 +8,7 @@ | ||||
| #include <string> | ||||
| #include <termios.h> | ||||
| #include <unistd.h> | ||||
| #include "color.h" | ||||
| 
 | ||||
| void safe_exit(int code) { | ||||
|   switch (code) { | ||||
| @ -26,7 +27,7 @@ void safe_exit(int code) { | ||||
| 
 | ||||
|   case SIGSEGV: | ||||
|     std::cerr << "\nreceived SIGSEGV(segmentaiton fault) exiting...\nIf this " | ||||
|                  "repeats please report it as bug\n"; | ||||
|                  "repeats please report it as a bug\n"; | ||||
|     break; | ||||
| 
 | ||||
|   default: | ||||
| @ -68,10 +69,16 @@ std::string SoRAuthFile(bool save, std::string data) { | ||||
|     return ""; | ||||
|   } else { | ||||
|     std::ifstream authfile(authfile_path); | ||||
|     authfile >> data; | ||||
|     if (authfile.is_open()) { | ||||
|         data.assign((std::istreambuf_iterator<char>(authfile)),  | ||||
|                     std::istreambuf_iterator<char>()); | ||||
|         authfile.close(); | ||||
|     return data; | ||||
|     } else { | ||||
|         std::cerr << RED "[ERROR] " << RESET << "Failed to open auth file\n"; | ||||
|         safe_exit(-2); | ||||
|     } | ||||
|     return data; | ||||
| } | ||||
| } | ||||
| 
 | ||||
| void get_input_and_login() { | ||||
| @ -80,10 +87,10 @@ void get_input_and_login() { | ||||
|   std::cin >> username; | ||||
|   std::string password; | ||||
| 
 | ||||
|   password = getpass("enter password: "); | ||||
|   // password = getpass("enter password: ");
 | ||||
|   // DEBUG
 | ||||
|   // std::cout << "\nenter password: ";
 | ||||
|   // std::cin >> password;
 | ||||
|   std::cout << "\nenter password: "; | ||||
|   std::cin >> password; | ||||
| 
 | ||||
|   bakaapi::login(username, password); | ||||
| } | ||||
|  | ||||
| @ -25,8 +25,8 @@ int main(int argc, char **argv) { | ||||
|   // error signal handlers
 | ||||
|   signal(SIGSEGV, safe_exit); | ||||
| 
 | ||||
|   marks_page(); | ||||
|   /*
 | ||||
|   // marks_page();
 | ||||
|    | ||||
| 
 | ||||
|   { | ||||
|     std::string savedir_path = std::getenv("HOME"); | ||||
| @ -64,6 +64,6 @@ int main(int argc, char **argv) { | ||||
|     get_input_and_login(); | ||||
|   } | ||||
|   main_menu(); | ||||
|   */ | ||||
|    | ||||
|   return 0; | ||||
| } | ||||
| @ -6,13 +6,18 @@ | ||||
| #include <curses.h> | ||||
| #include <menu.h> | ||||
| 
 | ||||
| #include "marks.h" | ||||
| 
 | ||||
| #define ARRAY_SIZE(a) (sizeof(a) / sizeof(a[0])) | ||||
| #define CTRLD 4 | ||||
| 
 | ||||
| char *choices[] = { | ||||
|     "login",    "Grades",  "shedule", "Komens", | ||||
|     "login",    "Marks",  "shedule", "Komens", | ||||
|     "Homework", "Absence", "Exit",    (char *)NULL, | ||||
| }; | ||||
| void (*choicesFuncs[])() = { | ||||
|   NULL, marks_page, NULL, NULL, NULL, NULL, NULL, NULL | ||||
| }; | ||||
| 
 | ||||
| void main_menu() { | ||||
|   ITEM **my_items; | ||||
| @ -85,10 +90,7 @@ void main_menu() { | ||||
|       menu_driver(my_menu, REQ_UP_ITEM); | ||||
|       break; | ||||
|     case 10: // ENTER
 | ||||
|       move(20, 0); | ||||
|       clrtoeol(); | ||||
|       mvprintw(20, 0, "Item selected is : %s", | ||||
|                item_name(current_item(my_menu))); | ||||
|       choicesFuncs[item_index(current_item(my_menu))](); | ||||
|       pos_menu_cursor(my_menu); | ||||
|       break; | ||||
|     } | ||||
|  | ||||
| @ -13,6 +13,7 @@ | ||||
| #include <panel.h> | ||||
| #include <string> | ||||
| #include <algorithm> | ||||
| #include "net.h" | ||||
| 
 | ||||
| using nlohmann::json; | ||||
| 
 | ||||
| @ -56,9 +57,9 @@ void win_show(WINDOW *win, char *label, int label_color, int width, int height, | ||||
| 
 | ||||
| void marks_page() { | ||||
|   // DONT FORGET TO UNCOMMENT
 | ||||
|   // json resp_from_api = bakaapi::get_grades();
 | ||||
|   std::ifstream f("test-data/marks3.json"); | ||||
|   json resp_from_api = json::parse(f); | ||||
|   json resp_from_api = bakaapi::get_grades(); | ||||
|   // std::ifstream f("test-data/marks3.json");
 | ||||
|   // json resp_from_api = json::parse(f);
 | ||||
| 
 | ||||
|   WINDOW **my_wins; | ||||
|   size_t size_my_wins = resp_from_api["Subjects"].size(); | ||||
| @ -104,12 +105,12 @@ void marks_page() { | ||||
| 
 | ||||
|   update_panels(); | ||||
|   attron(COLOR_PAIR(4)); | ||||
|   mvprintw(LINES - 2, 0, "Use tab/tilde to switch windows | Arrows/j/k to scroll | F1 to exit"); | ||||
|   mvprintw(LINES - 2, 0, "Arrows/j/k to scroll | F1 to exit"); | ||||
|   attroff(COLOR_PAIR(4)); | ||||
|   doupdate(); | ||||
| 
 | ||||
|   top = my_panels[size_my_panels - 1]; | ||||
|   int y_offset = 0; | ||||
|   long y_offset = 0; | ||||
| 
 | ||||
|   // Main loop
 | ||||
|   while ((ch = getch()) != KEY_F(1)) { | ||||
| @ -232,7 +233,7 @@ void win_show(WINDOW *win, char *label, int label_color, int width, int height, | ||||
|         marks_json["Subjects"][SubjectIndex]["Marks"][i]["MarkText"] | ||||
|             .get<std::string>(), | ||||
|         marks_json["Subjects"][SubjectIndex]["Marks"][i]["Weight"].get<int>())); | ||||
|     strncpy(CaptionBuf, Caption.c_str(), sizeof(CaptionBuf)); | ||||
|     strncpy(CaptionBuf, Caption.c_str(), sizeof(CaptionBuf)-1); | ||||
|     print_in_middle(win, 3 + i + AdditionalOffset, 0, width, CaptionBuf, | ||||
|                     COLOR_PAIR(label_color)); | ||||
| 
 | ||||
| @ -240,7 +241,7 @@ void win_show(WINDOW *win, char *label, int label_color, int width, int height, | ||||
|             rm_tr_le_whitespace(marks_json["Subjects"][SubjectIndex]["Marks"][i]["Theme"] | ||||
|                 .get<std::string>()) | ||||
|                 .c_str(), | ||||
|             sizeof(ThemeBuf)); | ||||
|             sizeof(ThemeBuf)-1); | ||||
|     print_in_middle(win, 3 + i + 1 + AdditionalOffset, 0, width, ThemeBuf, | ||||
|                     COLOR_PAIR(label_color)); | ||||
|     AdditionalOffset++; | ||||
|  | ||||
							
								
								
									
										23
									
								
								src/net.cpp
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/net.cpp
									
									
									
									
									
								
							| @ -2,6 +2,7 @@ | ||||
| #include "color.h" | ||||
| #include "helper_funcs.h" | ||||
| #include "main.h" | ||||
| #include <cerrno> | ||||
| #include <cmath> | ||||
| #include <cstddef> | ||||
| #include <cstdlib> | ||||
| @ -18,6 +19,10 @@ | ||||
| 
 | ||||
| using nlohmann::json; | ||||
| 
 | ||||
| // metods
 | ||||
| #define GET 0 | ||||
| #define POST 1 | ||||
| 
 | ||||
| CURL *curl = curl_easy_init(); | ||||
| 
 | ||||
| // Callback function to write data into a std::string
 | ||||
| @ -29,7 +34,7 @@ size_t WriteCallback(void *contents, size_t size, size_t nmemb, | ||||
| } | ||||
| 
 | ||||
| std::tuple<std::string, int> send_curl_request(std::string endpoint, | ||||
|                                                std::string type, | ||||
|                                                uint8_t type, | ||||
|                                                std::string req_data) { | ||||
|   std::string response; | ||||
|   std::string url = baka_api_url + endpoint; | ||||
| @ -50,8 +55,16 @@ std::tuple<std::string, int> send_curl_request(std::string endpoint, | ||||
|         headers, "Content-Type: application/x-www-form-urlencoded"); | ||||
|     curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers); | ||||
| 
 | ||||
|     if (type == "POST") { | ||||
|     switch (type) { | ||||
|       case GET: | ||||
|         curl_easy_setopt(curl, CURLOPT_HTTPGET, 1L); | ||||
|         break; | ||||
|       case POST: | ||||
|         curl_easy_setopt(curl, CURLOPT_POST, 1L); | ||||
|         break; | ||||
|       default: | ||||
|         std::cerr << RED "[ERROR] " << RESET "invalid metod\n"; | ||||
|         safe_exit(EINVAL); | ||||
|     } | ||||
| 
 | ||||
|   } else { | ||||
| @ -77,7 +90,7 @@ void login(std::string username, std::string password) { | ||||
|       std::format("client_id=ANDR&grant_type=password&username={}&password={}", | ||||
|                   username, password); | ||||
| 
 | ||||
|   auto [response, http_code] = send_curl_request("api/login", "POST", req_data); | ||||
|   auto [response, http_code] = send_curl_request("api/login", POST, req_data); | ||||
|   if (http_code != 200) { | ||||
|     std::cerr << RED "[ERROR] " << RESET << "login failed " << http_code | ||||
|               << " is non 200 response\n"; | ||||
| @ -116,7 +129,7 @@ void refresh_access_token() { | ||||
|                   "token&refresh_token={}", | ||||
|                   refresh_token); | ||||
| 
 | ||||
|   auto [response, http_code] = send_curl_request("api/login", "POST", req_data); | ||||
|   auto [response, http_code] = send_curl_request("api/login", POST, req_data); | ||||
|   if (http_code != 200) { | ||||
|     std::cerr << RED "[ERROR] " << RESET << http_code | ||||
|               << "is non 200 response\n"; | ||||
| @ -139,7 +152,7 @@ json get_grades() { | ||||
|       std::format("Authorization=Bearer&access_token={}", | ||||
|                   access_token); | ||||
| 
 | ||||
|     auto [response, http_code] = send_curl_request("api/3/marks", "GET", req_data); | ||||
|     auto [response, http_code] = send_curl_request("api/3/marks", GET, req_data); | ||||
| 
 | ||||
|     if(http_code != 200) { | ||||
|       refresh_access_token(); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user