Merge branch 'next' into profile-fields
[Sone.git] / src / main / java / net / pterodactylus / sone / web / LoginPage.java
1 /*
2  * FreenetSone - 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.DataProvider;
30 import net.pterodactylus.util.template.Template;
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, DataProvider dataProvider) throws RedirectException {
65                 super.processTemplate(request, dataProvider);
66                 /* get all own identities. */
67                 List<Sone> localSones = new ArrayList<Sone>(webInterface.getCore().getLocalSones());
68                 Collections.sort(localSones, Sone.NICE_NAME_COMPARATOR);
69                 dataProvider.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                                 throw new RedirectException("index.html");
76                         }
77                 }
78                 List<OwnIdentity> ownIdentitiesWithoutSone = CreateSonePage.getOwnIdentitiesWithoutSone(webInterface.getCore());
79                 dataProvider.set("identitiesWithoutSone", ownIdentitiesWithoutSone);
80         }
81
82         /**
83          * {@inheritDoc}
84          */
85         @Override
86         protected String getRedirectTarget(Request request) {
87                 if (getCurrentSone(request.getToadletContext()) != null) {
88                         return "index.html";
89                 }
90                 return null;
91         }
92
93         //
94         // SONETEMPLATEPAGE METHODS
95         //
96
97         /**
98          * {@inheritDoc}
99          */
100         @Override
101         public boolean isEnabled(ToadletContext toadletContext) {
102                 return getCurrentSone(toadletContext) == null;
103         }
104
105 }