X-Git-Url: https://code.wpia.club/?p=gigi.git;a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2FdbObjects%2FEmailAddress.java;fp=src%2Forg%2Fcacert%2Fgigi%2FdbObjects%2FEmailAddress.java;h=7847035914140891a829d1e18daedbd968b1fd0e;hp=b2106d8bff71c901c3e51c1bfe9e6b3d8f160c8c;hb=34daecdb56cd063819e3e2913b9b17a6dc0229d2;hpb=23e2727d841afbae173cf3cfa4d8784a10db25df diff --git a/src/org/cacert/gigi/dbObjects/EmailAddress.java b/src/org/cacert/gigi/dbObjects/EmailAddress.java index b2106d8b..78470359 100644 --- a/src/org/cacert/gigi/dbObjects/EmailAddress.java +++ b/src/org/cacert/gigi/dbObjects/EmailAddress.java @@ -95,6 +95,15 @@ public class EmailAddress implements IdCachable, Verifyable { return address; } + public synchronized boolean isVerifyable(String hash) throws GigiApiException { + try (GigiPreparedStatement stmt = new GigiPreparedStatement("SELECT 1 FROM `emailPinglog` WHERE `email`=? AND `uid`=? AND `type`='active' AND `challenge`=? AND `status`='open'::`pingState`")) { + stmt.setString(1, address); + stmt.setInt(2, owner.getId()); + stmt.setString(3, hash); + return stmt.executeQuery().next(); + } + } + public synchronized void verify(String hash) throws GigiApiException { try (GigiPreparedStatement stmt = new GigiPreparedStatement("UPDATE `emailPinglog` SET `status`='success'::`pingState` WHERE `email`=? AND `uid`=? AND `type`='active' AND `challenge`=? AND `status`='open'::`pingState`")) { stmt.setString(1, address);