X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Fmain%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FLogoutPage.kt;h=69787393e269d5a0b90a7d3a8b0a1b7991b79d10;hp=12cf8b402cb9a9b8abd8384c57c7772f5c9ebe43;hb=5479681d7a9aa211a775ca448d568f81ec12df7a;hpb=e4d9435bddb75a0d5c238518766d76b17d494d34 diff --git a/src/main/kotlin/net/pterodactylus/sone/web/pages/LogoutPage.kt b/src/main/kotlin/net/pterodactylus/sone/web/pages/LogoutPage.kt index 12cf8b4..6978739 100644 --- a/src/main/kotlin/net/pterodactylus/sone/web/pages/LogoutPage.kt +++ b/src/main/kotlin/net/pterodactylus/sone/web/pages/LogoutPage.kt @@ -1,26 +1,29 @@ package net.pterodactylus.sone.web.pages import freenet.clients.http.ToadletContext +import net.pterodactylus.sone.data.Sone import net.pterodactylus.sone.web.WebInterface -import net.pterodactylus.sone.web.page.FreenetRequest +import net.pterodactylus.sone.web.page.* import net.pterodactylus.util.template.Template import net.pterodactylus.util.template.TemplateContext +import javax.inject.Inject /** * Logs a user out. */ -class LogoutPage(template: Template, webInterface: WebInterface): - SoneTemplatePage("logout.html", template, "Page.Logout.Title", webInterface, true) { +@MenuName("Logout") +class LogoutPage @Inject constructor(template: Template, webInterface: WebInterface): + LoggedInPage("logout.html", template, "Page.Logout.Title", webInterface) { - override fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) { - setCurrentSone(request.toadletContext, null) + override fun handleRequest(soneRequest: SoneRequest, currentSone: Sone, templateContext: TemplateContext) { + setCurrentSone(soneRequest.toadletContext, null) throw RedirectException("index.html") } - override fun isEnabled(toadletContext: ToadletContext): Boolean = - if (webInterface.core.preferences.isRequireFullAccess && !toadletContext.isAllowedFullAccess) { + override fun isEnabled(soneRequest: SoneRequest): Boolean = + if (soneRequest.core.preferences.requireFullAccess && !soneRequest.toadletContext.isAllowedFullAccess) { false } else - getCurrentSone(toadletContext) != null && webInterface.core.localSones.size != 1 + getCurrentSone(soneRequest.toadletContext) != null && soneRequest.core.localSones.size != 1 }