]> WPIA git - gigi.git/blob - src/org/cacert/gigi/ping/DomainPinger.java
942334920fc0432b434913379b0cb641959046e2
[gigi.git] / src / org / cacert / gigi / ping / DomainPinger.java
1 package org.cacert.gigi.ping;
2
3 import org.cacert.gigi.database.GigiPreparedStatement;
4 import org.cacert.gigi.dbObjects.CertificateOwner;
5 import org.cacert.gigi.dbObjects.Domain;
6
7 public abstract class DomainPinger {
8
9     public static final String PING_STILL_PENDING = null;
10
11     public static final String PING_SUCCEDED = "";
12
13     public abstract void ping(Domain domain, String configuration, CertificateOwner target, int confId);
14
15     protected static void enterPingResult(int configId, String state, String result, String token) {
16         try (GigiPreparedStatement enterPingResult = new GigiPreparedStatement("INSERT INTO `domainPinglog` SET `configId`=?, `state`=?::`pingState`, `result`=?, `challenge`=?")) {
17             enterPingResult.setInt(1, configId);
18             enterPingResult.setString(2, DomainPinger.PING_STILL_PENDING == state ? "open" : DomainPinger.PING_SUCCEDED.equals(state) ? "success" : "failed");
19             enterPingResult.setString(3, result);
20             enterPingResult.setString(4, token);
21             enterPingResult.execute();
22         }
23
24     }
25
26     protected static void updatePingResult(int configId, String state, String result, String token) {
27         try (GigiPreparedStatement updatePingResult = new GigiPreparedStatement("UPDATE `domainPinglog` SET `state`=?::`pingState`, `result`=? WHERE `configId`=? AND `challenge`=?")) {
28             updatePingResult.setString(1, DomainPinger.PING_STILL_PENDING == state ? "open" : DomainPinger.PING_SUCCEDED.equals(state) ? "success" : "failed");
29             updatePingResult.setString(2, result);
30             updatePingResult.setInt(3, configId);
31             updatePingResult.setString(4, token);
32             updatePingResult.execute();
33         }
34
35     }
36 }