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=a7722d4550294eab002a6dbe5e534c7884f87a84;hp=12cf8b402cb9a9b8abd8384c57c7772f5c9ebe43;hb=faf66247a34f64946990a985d2ea3003465969cb;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..a7722d4 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.web.WebInterface -import net.pterodactylus.sone.web.page.FreenetRequest -import net.pterodactylus.util.template.Template -import net.pterodactylus.util.template.TemplateContext +import net.pterodactylus.sone.data.* +import net.pterodactylus.sone.main.* +import net.pterodactylus.sone.web.* +import net.pterodactylus.sone.web.page.* +import net.pterodactylus.util.template.* +import javax.inject.* /** * Logs a user out. */ -class LogoutPage(template: Template, webInterface: WebInterface): - SoneTemplatePage("logout.html", template, "Page.Logout.Title", webInterface, true) { +@MenuName("Logout") +@ToadletPath("logout.html") +class LogoutPage @Inject constructor(webInterface: WebInterface, loaders: Loaders, templateRenderer: TemplateRenderer) : + LoggedInPage("Page.Logout.Title", webInterface, loaders, templateRenderer) { - override fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) { - setCurrentSone(request.toadletContext, null) - throw RedirectException("index.html") + override fun handleRequest(soneRequest: SoneRequest, currentSone: Sone, templateContext: TemplateContext) { + setCurrentSone(soneRequest.toadletContext, null) + redirectTo("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 }