Fix bug in login page
[Sone.git] / src / main / kotlin / net / pterodactylus / sone / web / pages / LoginPage.kt
1 package net.pterodactylus.sone.web.pages
2
3 import freenet.clients.http.ToadletContext
4 import net.pterodactylus.sone.data.Sone
5 import net.pterodactylus.sone.utils.emptyToNull
6 import net.pterodactylus.sone.utils.isPOST
7 import net.pterodactylus.sone.web.pages.SoneTemplatePage
8 import net.pterodactylus.sone.web.WebInterface
9 import net.pterodactylus.sone.web.page.FreenetRequest
10 import net.pterodactylus.util.template.Template
11 import net.pterodactylus.util.template.TemplateContext
12
13 /**
14  * The login page lets the user log in.
15  */
16 class LoginPage(template: Template, webInterface: WebInterface):
17                 SoneTemplatePage("login.html", template, "Page.Login.Title", webInterface) {
18
19         override fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) {
20                 if (request.isPOST) {
21                         val soneId = request.httpRequest.getPartAsStringFailsafe("sone-id", 43)
22                         webInterface.core.getLocalSone(soneId)?.let { sone ->
23                                 setCurrentSone(request.toadletContext, sone)
24                                 val target = request.httpRequest.getParam("target").emptyToNull ?: "index.html"
25                                 throw RedirectException(target)
26                         }
27                 }
28                 templateContext["sones"] = webInterface.core.localSones.sortedWith(Sone.NICE_NAME_COMPARATOR)
29                 templateContext["identitiesWithoutSone"] = webInterface.core.identityManager.allOwnIdentities.filterNot { "Sone" in it.contexts }.sortedBy { "${it.nickname}@${it.id}" }
30         }
31
32         override public fun getRedirectTarget(request: FreenetRequest) =
33                         getCurrentSone(request.toadletContext)?.let { "index.html" }
34
35         override fun isEnabled(toadletContext: ToadletContext) = when {
36                 webInterface.core.preferences.isRequireFullAccess && !toadletContext.isAllowedFullAccess -> false
37                 else -> getCurrentSone(toadletContext, false) == null
38         }
39
40 }