From 83ca28259a7d960ee6441c7f863241c4e0f3207e Mon Sep 17 00:00:00 2001 From: Imbus <> Date: Sun, 21 Apr 2024 16:48:33 +0200 Subject: [PATCH 1/2] Git module for sql script --- .gitmodules | 3 +++ app/CrustyCookies | 1 + 2 files changed, 4 insertions(+) create mode 100644 .gitmodules create mode 160000 app/CrustyCookies diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 0000000..4dd2e1b --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "app/CrustyCookies"] + path = app/CrustyCookies + url = https://git.silversoft.se/Imbus/CrustyCookies.git diff --git a/app/CrustyCookies b/app/CrustyCookies new file mode 160000 index 0000000..be904a7 --- /dev/null +++ b/app/CrustyCookies @@ -0,0 +1 @@ +Subproject commit be904a7ab3925f7bbf3b54126e25480476ae49e8 From 8a88e8b45aa6d2cc6b42e2e395afb21c9bf9aee7 Mon Sep 17 00:00:00 2001 From: Imbus <> Date: Sun, 21 Apr 2024 16:49:41 +0200 Subject: [PATCH 2/2] Migrating the databse --- app/src/main/java/krusty/Database.java | 87 ++++++++++++++++++------ app/src/main/java/krusty/ServerMain.java | 3 + 2 files changed, 68 insertions(+), 22 deletions(-) diff --git a/app/src/main/java/krusty/Database.java b/app/src/main/java/krusty/Database.java index ce6c69d..53d2cd3 100644 --- a/app/src/main/java/krusty/Database.java +++ b/app/src/main/java/krusty/Database.java @@ -3,32 +3,27 @@ package krusty; import spark.Request; import spark.Response; +// Likely dependencies for db operations import java.sql.Connection; import java.sql.DriverManager; +import java.sql.ResultSet; +import java.sql.SQLException; +import java.sql.Statement; + +// Likely dependencies for general operations +import java.io.File; +import java.util.StringJoiner; +import java.io.IOException; +import java.io.FileNotFoundException; +import java.util.Scanner; public class Database { - private static final String jdbcString = "jdbc:sqlite:krusty.sqlite3"; - - public void connect() { - Connection conn = null; - - try { - conn = DriverManager.getConnection(jdbcString); - System.out.println("Connection to SQLite has been established."); - } catch (Exception e) { - System.out.println(e.getMessage()); - } finally { - try { - if (conn != null) { - conn.close(); - } - } catch (Exception e) { - System.out.println(e.getMessage()); - } - } - } - - // TODO: Implement and change output in all methods below! + // Here, we use an in-memory database. This string could be changed to + // "jdbc:sqlite:.sqlite3" to use a file-based database instead. + // Nore that ":memory:" is an **SQLite specific** magic string that tells the + // underlying SQLite engine to store the database in memory. + private static final String jdbcString = "jdbc:sqlite::memory:"; + private Connection conn = null; public String getCustomers(Request req, Response res) { return "{}"; @@ -57,4 +52,52 @@ public class Database { public String createPallet(Request req, Response res) { return "{}"; } + + /** Connects to the database using the configured jdbcString. */ + public void connect() { + try { + conn = DriverManager.getConnection(jdbcString); + } catch (Exception e) { + System.out.println(e.getMessage()); + } finally { + System.out.println("Connection to SQLite has been established."); + } + } + + // The script location is relative to the gradle + // build script ("build.gradle.kts", in this case). + /** Reads an sql script into the database */ + public void migrateScript(String filename) { + // Open the file + StringBuilder script = new StringBuilder(); + try { + File myObj = new File(filename); + Scanner myReader = new Scanner(myObj); + + while (myReader.hasNextLine()) { + String data = myReader.nextLine(); + script.append(data); + } + myReader.close(); + } catch (FileNotFoundException e) { + System.out.println("Migration script not found..."); + e.printStackTrace(); + } finally { + System.out.println("Migration script read successfully..."); + } + + // Execute the script + try { + conn.setAutoCommit(false); + Statement stmt = conn.createStatement(); + stmt.execute(script.toString()); + conn.commit(); + conn.setAutoCommit(true); + } catch (SQLException e) { + System.out.println("Error executing migration script..."); + e.printStackTrace(); + } finally { + System.out.println("Migration script executed successfully..."); + } + } } diff --git a/app/src/main/java/krusty/ServerMain.java b/app/src/main/java/krusty/ServerMain.java index 404ae58..e310558 100644 --- a/app/src/main/java/krusty/ServerMain.java +++ b/app/src/main/java/krusty/ServerMain.java @@ -18,6 +18,9 @@ public class ServerMain { db = new Database(); db.connect(); + // Here, we can migrate an arbitrary number of SQL scripts. + db.migrateScript("CrustyCookies/Migrations/0010_users.sql"); + port(PORT); enableCORS();