Changes CSV to DB

Updates all of the appropriate functions,
updates the release version of the isbn-lookup
This commit is contained in:
SuperNovaa41 2024-01-31 18:24:10 -05:00
parent 5ec581f0bc
commit 444f49e85d
6 changed files with 44 additions and 78 deletions

View File

@ -1,5 +1,5 @@
all: api/*.cpp all: api/*.cpp
g++ api/main.cpp api/csv.cpp api/isbn-interaction.cpp -o manager g++ api/main.cpp api/isbn-interaction.cpp -lsqlite3 -o manager
mkdir -p bin mkdir -p bin
mv manager bin/ mv manager bin/
clean: clean:

View File

@ -1,39 +0,0 @@
#include "csv.h"
#include <iostream>
std::string strip_quotes(std::string input)
{
if (input[0] != '"')
return input;
return input.substr(1, input.size() - 2);
}
int get_next_comma(std::string input)
{
int i;
bool in_string = false;
for (i = 0; i < input.size(); i++) {
if (input[i] == '"')
in_string = !in_string;
if (input[i] == ',' && !in_string)
return i;
}
return -1;
}
std::vector<std::string> get_csv_as_vector(std::string input)
{
std::vector<std::string> output;
int next_comma;
std::string current_string;
while ((next_comma = get_next_comma(input)) != -1) {
output.push_back(strip_quotes(input.substr(0, next_comma)));
input = input.substr(next_comma + 1, input.size());
}
output.push_back(input);
return output;
}

View File

@ -1,15 +0,0 @@
#ifndef CSV_H
#define CSV_H
#include <string>
#include <vector>
std::string strip_quotes(std::string input);
int get_next_comma(std::string input);
std::vector<std::string> get_csv_as_vector(std::string input);
#endif

View File

@ -1,15 +1,13 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include <fstream> #include <fstream>
#include <sqlite3.h>
#include <sys/wait.h> #include <sys/wait.h>
#include <unistd.h> #include <unistd.h>
#include <stdlib.h> #include <stdlib.h>
#include "isbn-interaction.h" #include "isbn-interaction.h"
#include "csv.h"
#define BOOK_FILENAME "books.csv"
std::string book_vec_to_json(std::vector<std::string> headers, std::vector<std::string> book) std::string book_vec_to_json(std::vector<std::string> headers, std::vector<std::string> book)
{ int i; { int i;
@ -23,38 +21,63 @@ std::string book_vec_to_json(std::vector<std::string> headers, std::vector<std::
out.pop_back(); out.pop_back();
return out + "}"; return out + "}";
}
std::vector<std::string> get_db_headers(sqlite3* db)
{
int i;
std::vector<std::string> res;
sqlite3_stmt* getmsgs;
sqlite3_prepare(db, "SELECT * FROM books;", -1, &getmsgs, NULL);
sqlite3_step(getmsgs);
for (i = 0; i < sqlite3_column_count(getmsgs); i++)
res.push_back(sqlite3_column_name(getmsgs, i));
sqlite3_finalize(getmsgs);
return res;
} }
std::string get_all_books() std::string get_all_books()
{ {
std::ifstream file; int rc, i;
int file_exists; sqlite3* db;
std::string line, total_lines; char* text;
std::string total_lines;
std::vector<std::string> book_vec; std::vector<std::string> book_vec;
std::vector<std::string> header_vec; std::vector<std::string> header_vec;
std::ifstream file("books.db");
if (!file.is_open())
return "No books found!\n";
file.close();
file.open(BOOK_FILENAME); rc = sqlite3_open("books.db", &db);
if (rc != SQLITE_OK) {
fprintf(stderr, "Cannot open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
if (!file.good()) { exit(EXIT_FAILURE);
fprintf(stderr, "Theres no books available!\n");
return "No books saved!";
} }
std::getline(file, line); total_lines += "{\"books\": [";
// this contains the headers so that we can fill the json file header_vec = get_db_headers(db);
header_vec = get_csv_as_vector(line);
total_lines = "{ \"books\": [";
while (std::getline(file, line)) {
book_vec = get_csv_as_vector(line);
sqlite3_stmt* getmsgs;
sqlite3_prepare(db, "SELECT * FROM books;", -1, &getmsgs, NULL);
while(sqlite3_step(getmsgs) == SQLITE_ROW) {
book_vec.clear();
for (i = 0; i < sqlite3_column_count(getmsgs); i++) {
text = (char*) sqlite3_column_text(getmsgs, i);
book_vec.push_back(std::string(text));
}
total_lines += book_vec_to_json(header_vec, book_vec) + ","; total_lines += book_vec_to_json(header_vec, book_vec) + ",";
} }
sqlite3_finalize(getmsgs);
sqlite3_close(db);
// remove the trailing comma // remove trailing comma
total_lines.pop_back(); total_lines.pop_back();

View File

@ -2,8 +2,6 @@
#include <crow/app.h> #include <crow/app.h>
#include <fstream> #include <fstream>
#include "csv.h"
#include "isbn-interaction.h" #include "isbn-interaction.h"
std::string print_hello() std::string print_hello()
@ -37,5 +35,4 @@ int main()
app.port(18080).run(); app.port(18080).run();
} }

View File

@ -5,7 +5,7 @@ cd ../
mkdir -p bin mkdir -p bin
cd bin cd bin
wget https://github.com/SuperNovaa41/isbn-lookup/releases/download/0.0.4/isbn wget https://github.com/SuperNovaa41/isbn-lookup/releases/download/0.0.5/isbn
chmod +x isbn chmod +x isbn
cd ../ cd ../