From de4ab195ab55fba7eb003a3830dba46118affd65 Mon Sep 17 00:00:00 2001 From: Matthew Slowe Date: Fri, 29 May 2020 13:50:41 +0100 Subject: [PATCH] Save input and grids to a database --- schema.sql | 1 + war/build.jsp | 52 ++++++++++++++++++++++++++++++++++++++++++--------- 2 files changed, 44 insertions(+), 9 deletions(-) create mode 100644 schema.sql diff --git a/schema.sql b/schema.sql new file mode 100644 index 0000000..48618b2 --- /dev/null +++ b/schema.sql @@ -0,0 +1 @@ +CREATE TABLE grids (id integer primary key, ts timestamp default current_timestamp, remotehost varchar, input, size_x int, size_y int, simple tinyint, result varchar); diff --git a/war/build.jsp b/war/build.jsp index b558f56..18bd516 100755 --- a/war/build.jsp +++ b/war/build.jsp @@ -9,6 +9,9 @@ <%@ page import="java.util.*" %> <%@ page import="org.apache.commons.lang.StringUtils" %> <%@ page import="org.apache.commons.lang.StringEscapeUtils" %> +<%@ page import="java.sql.*" %> +<%@ page import="org.sqlite.*" %> + <%@ page errorPage="error.jsp" %> <% @@ -24,22 +27,53 @@ for ( String line : request.getParameter("words").split("\r\n")) { words.add(line.trim().toLowerCase()); } - Collections.sort(words); + Collections.sort(words); - char[][] grid = GridFactory.makeGrid(words, height, width, simple); + Connection conn = DriverManager.getConnection( + "jdbc:sqlite:" + getServletContext().getInitParameter("sqlite_db")); + PreparedStatement stmt = conn.prepareStatement( + "INSERT INTO grids (remotehost, input, size_x, size_y, simple) VALUES (?, ?, ?, ?, ?)", + Statement.RETURN_GENERATED_KEYS); + // PreparedStatement getlastid = conn.prepareStatement("select last_insert_rowid();"); + PreparedStatement stmt2 = conn.prepareStatement("UPDATE grids SET result=? WHERE id=?"); - String csv = ""; + stmt.setString(1, request.getRemoteHost()); + stmt.setString(2, words.toString()); + stmt.setInt(3, height); + stmt.setInt(4, width); + stmt.setBoolean(5, simple); + stmt.executeUpdate(); + ResultSet record_id_rs = stmt.getGeneratedKeys(); + int record_id = -1; + if(record_id_rs.next()){ + record_id = record_id_rs.getInt(1); + } + + // Actually generate the grid + char[][] grid = GridFactory.makeGrid(words, height, width, simple); + + StringBuilder _csv = new StringBuilder(); + for (char[] cs : grid) { + for(char c : cs) { + _csv.append(c); + _csv.append(","); + } + _csv.append("\r\n"); + } + + String csv = _csv.toString(); + + stmt2.setString(1, csv); + stmt2.setInt(2, record_id); + stmt2.executeUpdate(); + conn.close(); %>

<%= name %>

- [ Start again | Download CSV ] + [ Start again | Download CSV ]
- +