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