X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Fmain%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FLoginPage.kt;h=6647cd4c2f5563a3e3718f4617d7ff386b235184;hp=4313a596d5806f3e0aa6dca04eec45e7fd2c5196;hb=76f3cee76957a00d6cb8f1ebcef9a2af3be7b603;hpb=fc8e9ea5c978d2f5a00894e093364ae62f18934b diff --git a/src/main/kotlin/net/pterodactylus/sone/web/pages/LoginPage.kt b/src/main/kotlin/net/pterodactylus/sone/web/pages/LoginPage.kt index 4313a59..6647cd4 100644 --- a/src/main/kotlin/net/pterodactylus/sone/web/pages/LoginPage.kt +++ b/src/main/kotlin/net/pterodactylus/sone/web/pages/LoginPage.kt @@ -1,40 +1,40 @@ package net.pterodactylus.sone.web.pages -import freenet.clients.http.ToadletContext -import net.pterodactylus.sone.data.Sone -import net.pterodactylus.sone.utils.emptyToNull -import net.pterodactylus.sone.utils.isPOST -import net.pterodactylus.sone.web.WebInterface -import net.pterodactylus.sone.web.page.FreenetRequest -import net.pterodactylus.util.template.Template -import net.pterodactylus.util.template.TemplateContext -import javax.inject.Inject +import net.pterodactylus.sone.data.* +import net.pterodactylus.sone.main.* +import net.pterodactylus.sone.utils.* +import net.pterodactylus.sone.web.* +import net.pterodactylus.sone.web.page.* +import net.pterodactylus.util.template.* +import javax.inject.* /** * The login page lets the user log in. */ -class LoginPage @Inject constructor(template: Template, webInterface: WebInterface): - SoneTemplatePage("login.html", webInterface, template, "Page.Login.Title") { +@MenuName("Login") +@TemplatePath("/templates/login.html") +class LoginPage @Inject constructor(webInterface: WebInterface, loaders: Loaders, templateRenderer: TemplateRenderer) : + SoneTemplatePage("login.html", webInterface, loaders, templateRenderer, pageTitleKey = "Page.Login.Title") { - override fun handleRequest(freenetRequest: FreenetRequest, templateContext: TemplateContext) { - if (freenetRequest.isPOST) { - val soneId = freenetRequest.httpRequest.getPartAsStringFailsafe("sone-id", 43) - webInterface.core.getLocalSone(soneId)?.let { sone -> - setCurrentSone(freenetRequest.toadletContext, sone) - val target = freenetRequest.httpRequest.getParam("target").emptyToNull ?: "index.html" + override fun handleRequest(soneRequest: SoneRequest, templateContext: TemplateContext) { + if (soneRequest.isPOST) { + val soneId = soneRequest.httpRequest.getPartAsStringFailsafe("sone-id", 43) + soneRequest.core.getLocalSone(soneId)?.let { sone -> + setCurrentSone(soneRequest.toadletContext, sone) + val target = soneRequest.httpRequest.getParam("target").emptyToNull ?: "index.html" throw RedirectException(target) } } - templateContext["sones"] = webInterface.core.localSones.sortedWith(Sone.NICE_NAME_COMPARATOR) - templateContext["identitiesWithoutSone"] = webInterface.core.identityManager.allOwnIdentities.filterNot { "Sone" in it.contexts }.sortedBy { "${it.nickname}@${it.id}" } + templateContext["sones"] = soneRequest.core.localSones.sortedWith(Sone.NICE_NAME_COMPARATOR) + templateContext["identitiesWithoutSone"] = soneRequest.core.identityManager.allOwnIdentities.filterNot { "Sone" in it.contexts }.sortedBy { "${it.nickname}@${it.id}" } } - override fun getRedirectTarget(freenetRequest: FreenetRequest) = - getCurrentSone(freenetRequest.toadletContext)?.let { "index.html" } + override fun getRedirectTarget(request: FreenetRequest) = + getCurrentSone(request.toadletContext)?.let { "index.html" } - override fun isEnabled(toadletContext: ToadletContext) = when { - webInterface.core.preferences.requireFullAccess && !toadletContext.isAllowedFullAccess -> false - else -> getCurrentSone(toadletContext, false) == null + override fun isEnabled(soneRequest: SoneRequest) = when { + soneRequest.core.preferences.requireFullAccess && !soneRequest.toadletContext.isAllowedFullAccess -> false + else -> getCurrentSone(soneRequest.toadletContext, false) == null } }