From: INOPIAE Date: Sat, 21 Sep 2019 04:11:19 +0000 (+0200) Subject: add: new function to set a challenge expired via test manager X-Git-Url: https://code.wpia.club/?p=gigi.git;a=commitdiff_plain;h=0c07a64ca0c633fa1e4c867c4d5d12ef19ac23c2 add: new function to set a challenge expired via test manager The function is added to enable testing with expired challenges. Change-Id: I36f71a23e12aecc0870f95c15b20818b444322f9 --- diff --git a/util-testing/club/wpia/gigi/pages/Manager.java b/util-testing/club/wpia/gigi/pages/Manager.java index cdde36f2..c9dba62f 100644 --- a/util-testing/club/wpia/gigi/pages/Manager.java +++ b/util-testing/club/wpia/gigi/pages/Manager.java @@ -7,6 +7,7 @@ import java.security.GeneralSecurityException; import java.security.KeyPair; import java.security.KeyPairGenerator; import java.security.Signature; +import java.sql.Timestamp; import java.text.SimpleDateFormat; import java.util.Base64; import java.util.Calendar; @@ -31,6 +32,7 @@ import club.wpia.gigi.Gigi; import club.wpia.gigi.GigiApiException; import club.wpia.gigi.crypto.SPKAC; import club.wpia.gigi.database.GigiPreparedStatement; +import club.wpia.gigi.database.GigiResultSet; import club.wpia.gigi.dbObjects.CATS; import club.wpia.gigi.dbObjects.CATS.CATSType; import club.wpia.gigi.dbObjects.Certificate; @@ -170,6 +172,24 @@ public class Manager extends Page { CATS.enterResult(u, t, new Date(System.currentTimeMillis()), "en_EN", "1"); } + private void expireCATS(User u, CATSType t) { + try (GigiPreparedStatement ps = new GigiPreparedStatement("SELECT `id` FROM `cats_passed` WHERE `user_id`=? AND `variant_id`=? AND `pass_date`>?")) { + ps.setInt(1, u.getId()); + ps.setInt(2, t.getId()); + ps.setTimestamp(3, new Timestamp(System.currentTimeMillis() - DayDate.MILLI_DAY * 366)); + ps.execute(); + GigiResultSet rs = ps.executeQuery(); + while (rs.next()) { + GigiPreparedStatement ps1 = new GigiPreparedStatement("UPDATE `cats_passed` SET `pass_date`=? WHERE `id`=?"); + ps1.setTimestamp(1, new Timestamp(System.currentTimeMillis() - DayDate.MILLI_DAY * 367)); + ps1.setInt(2, rs.getInt(1)); + ps1.execute(); + ps1.close(); + } + } + + } + private static Manager instance; private static final Template t = new Template(Manager.class.getResource("ManagerMails.templ")); @@ -360,6 +380,21 @@ public class Manager extends Page { CATSType test = CATSType.values()[Integer.parseInt(testId)]; passCATS(byEmail, test); resp.getWriter().println("Test '" + test.getDisplayName() + "' was added to user account."); + } else if (req.getParameter("catsexpire") != null) { + String mail = req.getParameter("catsEmail"); + String testId = req.getParameter("catsType"); + User byEmail = User.getByEmail(mail); + if (byEmail == null) { + resp.getWriter().println("User not found."); + return; + } + if (testId == null) { + resp.getWriter().println("No test given."); + return; + } + CATSType test = CATSType.values()[Integer.parseInt(testId)]; + expireCATS(byEmail, test); + resp.getWriter().println("Test '" + test.getDisplayName() + "' is set expired for user account."); } else if (req.getParameter("verify") != null) { String mail = req.getParameter("verifyEmail"); String verificationPoints = req.getParameter("verificationPoints"); diff --git a/util-testing/club/wpia/gigi/pages/Manager.templ b/util-testing/club/wpia/gigi/pages/Manager.templ index 19f7e6bd..857a6d18 100644 --- a/util-testing/club/wpia/gigi/pages/Manager.templ +++ b/util-testing/club/wpia/gigi/pages/Manager.templ @@ -50,6 +50,7 @@ Email: + Add 100 Verification Points: