X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Faccount%2FMailOverview.java;h=7fd5a7faf2337c65ee7ed5c407127ee303c6a873;hb=2233a655b4ef4c1122a406e83a0e6334b9fd49b6;hp=fa69e8e3f2347d1aa635be5b9b9fc2da3f02cffd;hpb=ae8917f3a8a3b15b279565a7f40556eb1b7de232;p=gigi.git diff --git a/src/org/cacert/gigi/pages/account/MailOverview.java b/src/org/cacert/gigi/pages/account/MailOverview.java index fa69e8e3..7fd5a7fa 100644 --- a/src/org/cacert/gigi/pages/account/MailOverview.java +++ b/src/org/cacert/gigi/pages/account/MailOverview.java @@ -2,18 +2,16 @@ package org.cacert.gigi.pages.account; import java.io.IOException; import java.io.PrintWriter; -import java.sql.PreparedStatement; -import java.sql.ResultSet; -import java.sql.SQLException; import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import org.cacert.gigi.EmailAddress; import org.cacert.gigi.Language; import org.cacert.gigi.User; -import org.cacert.gigi.database.DatabaseConnection; +import org.cacert.gigi.output.Form; import org.cacert.gigi.output.Outputable; import org.cacert.gigi.pages.LoginPage; import org.cacert.gigi.pages.Page; @@ -24,74 +22,81 @@ public class MailOverview extends Page { public MailOverview(String title) { super(title); - t = new MailTable("res", "us"); + t = new MailTable("us"); } @Override public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException { final User us = LoginPage.getUser(req); Language lang = Page.getLanguage(req); - int id = us.getId(); - try { - PreparedStatement ps = DatabaseConnection.getInstance().prepare( - "SELECT * from `email` WHERE `memid`=? AND `deleted`=0"); - ps.setInt(1, id); - ResultSet rs = ps.executeQuery(); - HashMap vars = new HashMap<>(); - vars.put("mailData", t); - vars.put("res", rs); - vars.put("us", us.getEmail()); - getDefaultTemplate().output(resp.getWriter(), lang, vars); - } catch (SQLException e) { - e.printStackTrace(); + HashMap vars = new HashMap<>(); + vars.put("mailData", t); + vars.put("us", us); + vars.put("addForm", new MailAddForm(req, us)); + vars.put("manForm", new MailManagementForm(req, us)); + getDefaultTemplate().output(resp.getWriter(), lang, vars); + } + + @Override + public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException { + PrintWriter out = resp.getWriter(); + if (req.getParameter("addmail") != null) { + MailAddForm f = Form.getForm(req, MailAddForm.class); + if (f.submit(out, req)) { + resp.sendRedirect(MailOverview.DEFAULT_PATH); + } + } else if (req.getParameter("makedefault") != null || req.getParameter("delete") != null) { + MailManagementForm f = Form.getForm(req, MailManagementForm.class); + f.submit(out, req); } + super.doPost(req, resp); } private class MailTable implements Outputable { - private String mails, userMail; + private String user; - public MailTable(String mails, String userMail) { - this.mails = mails; - this.userMail = userMail; + public MailTable(String user) { + this.user = user; } @Override public void output(PrintWriter out, Language l, Map vars) { - try { - ResultSet rs = (ResultSet) vars.get(mails); - String usM = (String) vars.get(userMail); - while (rs.next()) { - out.println(""); - out.println(""); + out.println(""); + out.println(""); + if (emails[i].isVerified()) { + out.print(l.getTranslation("Verified")); + } else { + out.print(l.getTranslation("Unverified")); + } + out.print(""); + out.println(""); + String address = emails[i].getAddress(); + if (usM.equals(address)) { + out.print(l.getTranslation("N/A")); + } else { + out.print(""); - out.println(""); - if (rs.getString(7).isEmpty()) { - out.print(l.getTranslation("Verified")); - } else { - out.print(l.getTranslation("Unverified")); - } - out.print(""); - out.println(""); - String address = rs.getString(3); - if (usM.equals(address)) { - out.print(l.getTranslation("N/A")); - } else { - out.print(""); - } - out.print(""); - out.println(""); - out.print(address); - out.print(""); - out.println(""); + out.print("\"/>"); } - } catch (SQLException e) { - e.printStackTrace(); + out.print(""); + out.println(""); + out.print(address); + out.print(""); + out.println(""); } } - } }