X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Faccount%2FChangeForm.java;h=5458b63d9f5ef9d94a9db148cccee44634194410;hb=562f4e5fabe180a8dfc4894241a89cae0d1655ee;hp=3d2d45dbf83c91ffacf67eb028e514e2d32a5048;hpb=5778f9cb59077a91b5fd56da88d56f378f771b1b;p=gigi.git diff --git a/src/org/cacert/gigi/pages/account/ChangeForm.java b/src/org/cacert/gigi/pages/account/ChangeForm.java index 3d2d45db..5458b63d 100644 --- a/src/org/cacert/gigi/pages/account/ChangeForm.java +++ b/src/org/cacert/gigi/pages/account/ChangeForm.java @@ -5,13 +5,19 @@ import java.util.Map; import javax.servlet.http.HttpServletRequest; +import org.cacert.gigi.GigiApiException; import org.cacert.gigi.Language; +import org.cacert.gigi.User; import org.cacert.gigi.output.Form; -import org.cacert.gigi.output.Template; +import org.cacert.gigi.output.template.Template; +import org.cacert.gigi.pages.Page; public class ChangeForm extends Form { - public ChangeForm(HttpServletRequest hsr) { + User target; + + public ChangeForm(HttpServletRequest hsr, User target) { super(hsr); + this.target = target; } private static Template t; @@ -26,7 +32,28 @@ public class ChangeForm extends Form { @Override public boolean submit(PrintWriter out, HttpServletRequest req) { - return false; + String oldpassword = req.getParameter("oldpassword"); + String p1 = req.getParameter("pword1"); + String p2 = req.getParameter("pword2"); + GigiApiException error = new GigiApiException(); + if (oldpassword == null || p1 == null || p2 == null) { + new GigiApiException("All fields are required.").format(out, Page.getLanguage(req)); + return false; + } + if (!p1.equals(p2)) { + new GigiApiException("New passwords do not match.").format(out, Page.getLanguage(req)); + return false; + } + try { + target.changePassword(oldpassword, p1); + } catch (GigiApiException e) { + error.mergeInto(e); + } + if (!error.isEmpty()) { + error.format(out, Page.getLanguage(req)); + return false; + } + return true; } }