import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
-import java.util.Date;
+import java.sql.Date;
+import java.util.Calendar;
import org.cacert.gigi.database.DatabaseConnection;
import org.cacert.gigi.util.PasswordHash;
public class User {
private int id;
- Name name = new Name(null, null);
+ Name name = new Name(null, null, null, null);
Date dob;
String email;
public User(int id) {
this.id = id;
try {
- PreparedStatement ps = DatabaseConnection
- .getInstance()
- .prepare(
- "SELECT `fname`, `lname`, `dob`, `email` FROM `users` WHERE id=?");
+ PreparedStatement ps = DatabaseConnection.getInstance().prepare(
+ "SELECT `fname`, `lname`,`mname`, `suffix`, `dob`, `email` FROM `users` WHERE id=?");
ps.setInt(1, id);
ResultSet rs = ps.executeQuery();
if (rs.next()) {
- name = new Name(rs.getString(1), rs.getString(2));
- dob = rs.getDate(3);
- email = rs.getString(4);
+ name = new Name(rs.getString(1), rs.getString(2), rs.getString(3), rs.getString(4));
+ dob = rs.getDate(5);
+ email = rs.getString(6);
}
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
+
public User() {
}
+
public int getId() {
return id;
}
+
public String getFname() {
return name.fname;
}
+
public String getLname() {
return name.lname;
}
+
public String getMname() {
return name.mname;
}
+
public Name getName() {
return name;
}
+
public void setMname(String mname) {
this.name.mname = mname;
}
+
public String getSuffix() {
return name.suffix;
}
+
public void setSuffix(String suffix) {
this.name.suffix = suffix;
}
+
public Date getDob() {
return dob;
}
+
public void setDob(Date dob) {
this.dob = dob;
}
+
public String getEmail() {
return email;
}
+
public void setEmail(String email) {
this.email = email;
}
+
public void setId(int id) {
this.id = id;
}
+
public void setFname(String fname) {
this.name.fname = fname;
}
+
public void setLname(String lname) {
this.name.lname = lname;
}
+
public void insert(String password) throws SQLException {
if (id != 0) {
throw new Error("refusing to insert");
}
PreparedStatement query = DatabaseConnection.getInstance().prepare(
- "insert into `users` set `email`=?, `password`=?, "
- + "`fname`=?, `mname`=?, `lname`=?, "
- + "`suffix`=?, `dob`=?, `created`=NOW(), locked=0");
+ "insert into `users` set `email`=?, `password`=?, " + "`fname`=?, `mname`=?, `lname`=?, "
+ + "`suffix`=?, `dob`=?, `created`=NOW(), locked=0");
query.setString(1, email);
query.setString(2, PasswordHash.hash(password));
query.setString(3, name.fname);
return hasPassedCATS();
}
+
public boolean hasPassedCATS() throws SQLException {
PreparedStatement query = DatabaseConnection.getInstance().prepare(
- "SELECT 1 FROM `cats_passed` where `user_id`=?");
+ "SELECT 1 FROM `cats_passed` where `user_id`=?");
query.setInt(1, id);
ResultSet rs = query.executeQuery();
if (rs.next()) {
return false;
}
}
+
public int getAssurancePoints() throws SQLException {
- PreparedStatement query = DatabaseConnection
- .getInstance()
- .prepare(
- "SELECT sum(points) FROM `notary` where `to`=? AND `deleted`=0");
+ 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;
rs.close();
return points;
}
+
public int getExperiencePoints() throws SQLException {
PreparedStatement query = DatabaseConnection.getInstance().prepare(
- "SELECT count(*) FROM `notary` where `from`=? AND `deleted`=0");
+ "SELECT count(*) FROM `notary` where `from`=? AND `deleted`=0");
query.setInt(1, id);
ResultSet rs = query.executeQuery();
int points = 0;
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.equals(s.dob);
+ 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;
}