Merge branch 'release-0.6.2'
[Sone.git] / src / main / java / net / pterodactylus / sone / web / LoginPage.java
1 /*
2  * Sone - LoginPage.java - Copyright © 2010 David Roden
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  */
17
18 package net.pterodactylus.sone.web;
19
20 import java.util.ArrayList;
21 import java.util.Collections;
22 import java.util.List;
23 import java.util.logging.Logger;
24
25 import net.pterodactylus.sone.data.Sone;
26 import net.pterodactylus.sone.freenet.wot.OwnIdentity;
27 import net.pterodactylus.sone.web.page.Page.Request.Method;
28 import net.pterodactylus.util.logging.Logging;
29 import net.pterodactylus.util.template.Template;
30 import net.pterodactylus.util.template.TemplateContext;
31 import freenet.clients.http.ToadletContext;
32
33 /**
34  * The login page manages logging the user in.
35  *
36  * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
37  */
38 public class LoginPage extends SoneTemplatePage {
39
40         /** The logger. */
41         @SuppressWarnings("unused")
42         private static final Logger logger = Logging.getLogger(LoginPage.class);
43
44         /**
45          * Creates a new login page.
46          *
47          * @param template
48          *            The template to render
49          * @param webInterface
50          *            The Sone web interface
51          */
52         public LoginPage(Template template, WebInterface webInterface) {
53                 super("login.html", template, "Page.Login.Title", webInterface, false);
54         }
55
56         //
57         // TEMPLATEPAGE METHODS
58         //
59
60         /**
61          * {@inheritDoc}
62          */
63         @Override
64         protected void processTemplate(Request request, TemplateContext templateContext) throws RedirectException {
65                 super.processTemplate(request, templateContext);
66                 /* get all own identities. */
67                 List<Sone> localSones = new ArrayList<Sone>(webInterface.getCore().getLocalSones());
68                 Collections.sort(localSones, Sone.NICE_NAME_COMPARATOR);
69                 templateContext.set("sones", localSones);
70                 if (request.getMethod() == Method.POST) {
71                         String soneId = request.getHttpRequest().getPartAsStringFailsafe("sone-id", 100);
72                         Sone selectedSone = webInterface.getCore().getLocalSone(soneId, false);
73                         if (selectedSone != null) {
74                                 setCurrentSone(request.getToadletContext(), selectedSone);
75                                 String target = request.getHttpRequest().getParam("target");
76                                 if ((target == null) || (target.length() == 0)) {
77                                         target = "index.html";
78                                 }
79                                 throw new RedirectException(target);
80                         }
81                 }
82                 List<OwnIdentity> ownIdentitiesWithoutSone = CreateSonePage.getOwnIdentitiesWithoutSone(webInterface.getCore());
83                 templateContext.set("identitiesWithoutSone", ownIdentitiesWithoutSone);
84         }
85
86         /**
87          * {@inheritDoc}
88          */
89         @Override
90         protected String getRedirectTarget(Request request) {
91                 if (getCurrentSone(request.getToadletContext(), false) != null) {
92                         return "index.html";
93                 }
94                 return null;
95         }
96
97         //
98         // SONETEMPLATEPAGE METHODS
99         //
100
101         /**
102          * {@inheritDoc}
103          */
104         @Override
105         public boolean isEnabled(ToadletContext toadletContext) {
106                 return getCurrentSone(toadletContext, false) == null;
107         }
108
109 }