]> WPIA git - gigi.git/blob - src/org/cacert/gigi/dbObjects/CertificateOwner.java
fix: SQL change database call pattern
[gigi.git] / src / org / cacert / gigi / dbObjects / CertificateOwner.java
1 package org.cacert.gigi.dbObjects;
2
3 import java.util.LinkedList;
4 import java.util.List;
5
6 import org.cacert.gigi.database.GigiPreparedStatement;
7 import org.cacert.gigi.database.GigiResultSet;
8
9 public abstract class CertificateOwner implements IdCachable {
10
11     private static final ObjectCache<CertificateOwner> myCache = new ObjectCache<>();
12
13     private int id;
14
15     protected CertificateOwner(int id) {
16         this.id = id;
17     }
18
19     protected CertificateOwner() {
20         try (GigiPreparedStatement ps = new GigiPreparedStatement("INSERT INTO `certOwners` DEFAULT VALUES")) {
21             ps.execute();
22             id = ps.lastInsertId();
23         }
24         myCache.put(this);
25     }
26
27     public int getId() {
28         return id;
29     }
30
31     public static synchronized CertificateOwner getById(int id) {
32         CertificateOwner u = myCache.get(id);
33         if (u == null) {
34             try (GigiPreparedStatement ps = new GigiPreparedStatement("SELECT *, `users`.`id` AS uid, `organisations`.`id` AS oid FROM `certOwners` LEFT JOIN `users` ON `users`.`id`=`certOwners`.`id` LEFT JOIN `organisations` ON `organisations`.`id` = `certOwners`.`id` WHERE `certOwners`.`id`=? AND `deleted` is null")) {
35                 ps.setInt(1, id);
36                 try (GigiResultSet rs = ps.executeQuery()) {
37                     if ( !rs.next()) {
38                         return null;
39                     }
40                     if (rs.getString("uid") != null) {
41                         myCache.put(u = new User(rs));
42                     } else if (rs.getString("oid") != null) {
43                         myCache.put(u = new Organisation(rs));
44                     } else {
45                         System.err.print("Malformed cert owner: " + id);
46                     }
47                 }
48             }
49         }
50         return u;
51     }
52
53     public Domain[] getDomains() {
54         try (GigiPreparedStatement ps = new GigiPreparedStatement("SELECT `id` FROM `domains` WHERE `memid`=? AND `deleted` IS NULL")) {
55             ps.setInt(1, getId());
56
57             try (GigiResultSet rs = ps.executeQuery()) {
58                 LinkedList<Domain> data = new LinkedList<Domain>();
59
60                 while (rs.next()) {
61                     data.add(Domain.getById(rs.getInt(1)));
62                 }
63
64                 return data.toArray(new Domain[0]);
65             }
66         }
67     }
68
69     public Certificate[] getCertificates(boolean includeRevoked) {
70         try (GigiPreparedStatement ps = new GigiPreparedStatement(includeRevoked ? "SELECT id FROM certs WHERE memid=?" : "SELECT id FROM certs WHERE memid=? AND revoked IS NULL")) {
71             ps.setInt(1, getId());
72
73             GigiResultSet rs = ps.executeQuery();
74             LinkedList<Certificate> data = new LinkedList<Certificate>();
75
76             while (rs.next()) {
77                 data.add(Certificate.getById(rs.getInt(1)));
78             }
79
80             return data.toArray(new Certificate[0]);
81         }
82     }
83
84     public boolean isValidDomain(String domainname) {
85         for (Domain d : getDomains()) {
86             String sfx = d.getSuffix();
87             if (domainname.equals(sfx) || domainname.endsWith("." + sfx)) {
88                 return d.isVerified();
89             }
90         }
91
92         return false;
93     }
94
95     public abstract boolean isValidEmail(String email);
96
97     public void delete() {
98         try (GigiPreparedStatement ps = new GigiPreparedStatement("UPDATE `certOwners` SET `deleted`=NOW() WHERE `id`=?")) {
99             ps.setInt(1, getId());
100             ps.execute();
101         }
102         myCache.remove(this);
103     }
104
105     public String[] getAdminLog() {
106         try (GigiPreparedStatement prep = new GigiPreparedStatement("SELECT `when`, type, information FROM `adminLog` WHERE uid=? ORDER BY `when` ASC")) {
107             prep.setInt(1, getId());
108             GigiResultSet res = prep.executeQuery();
109             List<String> entries = new LinkedList<String>();
110
111             while (res.next()) {
112                 entries.add(res.getString(2) + " (" + res.getString(3) + ")");
113             }
114             return entries.toArray(new String[0]);
115         }
116     }
117
118     public static CertificateOwner getByEnabledSerial(String serial) {
119         try (GigiPreparedStatement prep = new GigiPreparedStatement("SELECT `memid` FROM `certs` WHERE serial=? AND `disablelogin`='0' AND `revoked` is NULL")) {
120             prep.setString(1, serial.toLowerCase());
121             GigiResultSet res = prep.executeQuery();
122             if (res.next()) {
123                 return getById(res.getInt(1));
124             }
125             return null;
126         }
127     }
128 }