+ public static void may(User assurer, User assuree, AssuranceType t) throws GigiApiException {
+ if (assuree.isInGroup(ASSUREE_BLOCKED)) {
+ throw new GigiApiException("The applicant is blocked.");
+ }
+ if (assurer.isInGroup(ASSURER_BLOCKED)) {
+ throw new GigiApiException("The RA Agent is blocked.");
+ }
+
+ if (t == AssuranceType.NUCLEUS) {
+ if ( !assurer.isInGroup(Group.NUCLEUS_ASSURER)) {
+ throw new GigiApiException("RA Agent needs to be Nucleus RA Agent.");
+ }
+ return;
+ } else if (t == AssuranceType.TTP_ASSISTED) {
+ if ( !assurer.isInGroup(Group.TTP_ASSURER)) {
+ throw new GigiApiException("RA Agent needs to be TTP RA Agent.");
+ }
+ if ( !assuree.isInGroup(Group.TTP_APPLICANT)) {
+ throw new GigiApiException("Applicant needs to be TTP Applicant.");
+ }
+ return;
+ } else if (t == AssuranceType.FACE_TO_FACE) {
+ return;
+ }
+ throw new GigiApiException("Verification type not possible.");
+ }
+
+ private static void assureNucleus(User assurer, User assuree, Name name, int awarded, String location, String date, CountryCode country) throws GigiApiException {
+ may(assurer, assuree, AssuranceType.NUCLEUS);
+ // Do up to 35 points as f2f
+ int f2fPoints = Math.min(assurer.getMaxAssurePoints(), awarded);
+ assureF2F(assurer, assuree, name, f2fPoints, location, date, country);
+
+ awarded -= f2fPoints;
+ if (awarded <= 0) {
+ return;
+ }
+
+ // Assure remaining points as "Nucleus Bonus"
+ // Valid for 4 Weeks = 28 days
+ try (GigiPreparedStatement ps = new GigiPreparedStatement("INSERT INTO `notary` SET `from`=?, `to`=?, `points`=?, `location`=?, `date`=?, `country`=?, `method`='Nucleus Bonus', `expire` = CURRENT_TIMESTAMP + interval '28 days'")) {
+ ps.setInt(1, assurer.getId());
+ ps.setInt(2, name.getId());
+ ps.setInt(3, awarded);
+ ps.setString(4, location);
+ ps.setString(5, date);
+ ps.setString(6, country.getCountryCode());
+ ps.execute();
+ }
+ }
+
+ public synchronized static void assureAll(User assurer, User assuree, DayDate dob, int awarded, String location, String date, AssuranceType type, Name[] toAssure, CountryCode country) throws GigiApiException {
+ if (toAssure.length == 0) {
+ throw new GigiApiException("You must confirm at least one name to verify an account.");
+ }
+ boolean[] hadLessThan50Points = new boolean[toAssure.length];
+ boolean hadTotalLessThan100 = assuree.getAssurancePoints() < 100;
+ for (int i = 0; i < toAssure.length; i++) {
+ hadLessThan50Points[i] = toAssure[i].getAssurancePoints() < 50;
+
+ assure(assurer, assuree, toAssure[i], dob, awarded, location, date, type, country);
+ }
+ sendVerificationNotificationApplicant(assurer, assuree, toAssure, awarded, hadLessThan50Points, hadTotalLessThan100);
+ }
+
+ private static final MailTemplate verificationEntered = new MailTemplate(Notary.class.getResource("VerificationEntered.templ"));
+
+ private static void sendVerificationNotificationApplicant(User assurer, User assuree, Name[] toAssure, final int awarded, final boolean[] hadLessThan50Points, boolean hadTotalLessThan100) {
+ HashMap<String, Object> mailVars = new HashMap<>();
+ mailVars.put("agent", assurer.getPreferredName().toString());
+ mailVars.put("names", new ArrayIterable<Name>(toAssure) {
+
+ @Override
+ public void apply(Name t, Language l, Map<String, Object> vars) {
+ int totalVP = t.getAssurancePoints();
+ vars.put("name", t.toString());
+ vars.put("points", Integer.toString(awarded));
+ vars.put("total", totalVP);
+ if (totalVP < 50) {
+ vars.put("rem", (50 - totalVP));
+ vars.remove("gotGreater");
+ } else if (hadLessThan50Points[i]) {
+ vars.put("gotGreater", true);
+ vars.remove("rem");
+ }
+ }
+
+ });
+
+ int grandTotalVP = assuree.getAssurancePoints();
+ if (grandTotalVP >= 50 && grandTotalVP < 100) {
+ mailVars.put("remAll", (100 - grandTotalVP));
+ mailVars.remove("gotGreaterAll");
+ } else if (hadTotalLessThan100) {
+ mailVars.put("gotGreaterAll", true);
+ mailVars.remove("remAll");
+ }
+ try {
+ verificationEntered.sendMail(Language.getInstance(assuree.getPreferredLocale()), mailVars, assuree.getEmail());
+ } catch (IOException e) {
+ e.printStackTrace();
+ }