Render templates in a thread-safe way.
[Sone.git] / src / main / java / net / pterodactylus / sone / web / EditProfilePage.java
index 181c454..01d4815 100644 (file)
@@ -20,6 +20,8 @@ package net.pterodactylus.sone.web;
 import net.pterodactylus.sone.data.Profile;
 import net.pterodactylus.sone.data.Sone;
 import net.pterodactylus.sone.web.page.Page.Request.Method;
+import net.pterodactylus.util.number.Numbers;
+import net.pterodactylus.util.template.DataProvider;
 import net.pterodactylus.util.template.Template;
 import freenet.clients.http.ToadletContext;
 
@@ -39,7 +41,7 @@ public class EditProfilePage extends SoneTemplatePage {
         *            The Sone web interface
         */
        public EditProfilePage(Template template, WebInterface webInterface) {
-               super("editProfile.html", template, "Page.EditProfile.Title", webInterface);
+               super("editProfile.html", template, "Page.EditProfile.Title", webInterface, true);
        }
 
        //
@@ -50,41 +52,39 @@ public class EditProfilePage extends SoneTemplatePage {
         * {@inheritDoc}
         */
        @Override
-       protected void processTemplate(Request request, Template template) throws RedirectException {
-               super.processTemplate(request, template);
+       protected void processTemplate(Request request, DataProvider dataProvider) throws RedirectException {
+               super.processTemplate(request, dataProvider);
                ToadletContext toadletContenxt = request.getToadletContext();
                Sone currentSone = getCurrentSone(toadletContenxt);
                Profile profile = currentSone.getProfile();
                String firstName = profile.getFirstName();
                String middleName = profile.getMiddleName();
                String lastName = profile.getLastName();
+               Integer birthDay = profile.getBirthDay();
+               Integer birthMonth = profile.getBirthMonth();
+               Integer birthYear = profile.getBirthYear();
                if (request.getMethod() == Method.POST) {
                        firstName = request.getHttpRequest().getPartAsStringFailsafe("first-name", 256).trim();
                        middleName = request.getHttpRequest().getPartAsStringFailsafe("middle-name", 256).trim();
                        lastName = request.getHttpRequest().getPartAsStringFailsafe("last-name", 256).trim();
+                       birthDay = Numbers.safeParseInteger(request.getHttpRequest().getPartAsStringFailsafe("birth-day", 256).trim());
+                       birthMonth = Numbers.safeParseInteger(request.getHttpRequest().getPartAsStringFailsafe("birth-month", 256).trim());
+                       birthYear = Numbers.safeParseInteger(request.getHttpRequest().getPartAsStringFailsafe("birth-year", 256).trim());
                        profile.setFirstName(firstName.length() > 0 ? firstName : null);
                        profile.setMiddleName(middleName.length() > 0 ? middleName : null);
                        profile.setLastName(lastName.length() > 0 ? lastName : null);
+                       profile.setBirthDay(birthDay).setBirthMonth(birthMonth).setBirthYear(birthYear);
                        if (profile.isModified()) {
                                currentSone.setProfile(profile);
                        }
                        throw new RedirectException("index.html");
                }
-               template.set("firstName", firstName);
-               template.set("middleName", middleName);
-               template.set("lastName", lastName);
-       }
-
-       //
-       // SONETEMPLATEPAGE METHODS
-       //
-
-       /**
-        * {@inheritDoc}
-        */
-       @Override
-       protected boolean requiresLogin() {
-               return true;
+               dataProvider.set("firstName", firstName);
+               dataProvider.set("middleName", middleName);
+               dataProvider.set("lastName", lastName);
+               dataProvider.set("birthDay", birthDay);
+               dataProvider.set("birthMonth", birthMonth);
+               dataProvider.set("birthYear", birthYear);
        }
 
 }