+ public boolean canAssure() throws SQLException {
+ if (getAssurancePoints() < 100) {
+ return false;
+ }
+
+ return hasPassedCATS();
+
+ }
+
+ public boolean hasPassedCATS() throws SQLException {
+ PreparedStatement query = DatabaseConnection.getInstance().prepare(
+ "SELECT 1 FROM `cats_passed` where `user_id`=?");
+ query.setInt(1, id);
+ ResultSet rs = query.executeQuery();
+ if (rs.next()) {
+ return true;
+ } else {
+ return false;
+ }
+ }
+
+ public int getAssurancePoints() throws SQLException {
+ PreparedStatement query = DatabaseConnection.getInstance().prepare(
+ "SELECT sum(points) FROM `notary` where `to`=? AND `deleted`=0");
+ query.setInt(1, id);
+ ResultSet rs = query.executeQuery();
+ int points = 0;
+ if (rs.next()) {
+ points = rs.getInt(1);
+ }
+ rs.close();
+ return points;
+ }
+
+ public int getExperiencePoints() throws SQLException {
+ PreparedStatement query = DatabaseConnection.getInstance().prepare(
+ "SELECT count(*) FROM `notary` where `from`=? AND `deleted`=0");
+ query.setInt(1, id);
+ ResultSet rs = query.executeQuery();
+ int points = 0;
+ if (rs.next()) {
+ points = rs.getInt(1) * 2;
+ }
+ rs.close();
+ return points;
+ }
+
+ @Override
+ public boolean equals(Object obj) {
+ if (!(obj instanceof User)) {
+ return false;
+ }
+ User s = (User) obj;
+ return name.equals(s.name) && email.equals(s.email) && dob.toString().equals(s.dob.toString()); // This
+ // is
+ // due
+ // to
+ // day
+ // cutoff
+ }
+
+ /**
+ * Gets the maximum allowed points NOW. Note that an assurance needs to
+ * re-check PoJam as it has taken place in the past.
+ *
+ * @return the maximal points
+ * @throws SQLException
+ */
+ public int getMaxAssurePoints() throws SQLException {
+ int exp = getExperiencePoints();
+ int points = 10;
+ Calendar c = Calendar.getInstance();
+ c.setTime(dob);
+ int year = c.get(Calendar.YEAR);
+ int month = c.get(Calendar.MONTH);
+ int day = c.get(Calendar.DAY_OF_MONTH);
+ c.set(year + 18, month, day);
+ if (System.currentTimeMillis() < c.getTime().getTime()) {
+ return points; // not 18 Years old.
+ }
+
+ if (exp >= 10) {
+ points += 5;
+ }
+ if (exp >= 20) {
+ points += 5;
+ }
+ if (exp >= 30) {
+ points += 5;
+ }
+ if (exp >= 40) {
+ points += 5;
+ }
+ if (exp >= 50) {
+ points += 5;
+ }
+ return points;
+ }
+
+ public static User getById(int id) {
+ return new User(id);
+ }
+
+ public EmailAddress[] getEmails() {
+ try {
+ PreparedStatement ps = DatabaseConnection.getInstance().prepare("SELECT id FROM email WHERE memid=?");
+ ps.setInt(1, id);
+ ResultSet rs = ps.executeQuery();
+ rs.last();
+ int count = rs.getRow();
+ EmailAddress[] data = new EmailAddress[count];
+ rs.beforeFirst();
+ for (int i = 0; i < data.length; i++) {
+ if (!rs.next()) {
+ throw new Error("Internal sql api violation.");
+ }
+ data[i] = EmailAddress.getById(rs.getInt(1));
+ }
+ rs.close();
+ return data;
+ } catch (SQLException e) {
+ e.printStackTrace();
+ }
+
+ return null;
+ }