🚧 Add Loaders to all template-using pages
[Sone.git] / src / main / kotlin / net / pterodactylus / sone / web / pages / LoginPage.kt
index c6c50bb..70b96fc 100644 (file)
@@ -2,10 +2,11 @@ package net.pterodactylus.sone.web.pages
 
 import freenet.clients.http.ToadletContext
 import net.pterodactylus.sone.data.Sone
 
 import freenet.clients.http.ToadletContext
 import net.pterodactylus.sone.data.Sone
+import net.pterodactylus.sone.main.*
 import net.pterodactylus.sone.utils.emptyToNull
 import net.pterodactylus.sone.utils.isPOST
 import net.pterodactylus.sone.web.WebInterface
 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.sone.web.page.*
 import net.pterodactylus.util.template.Template
 import net.pterodactylus.util.template.TemplateContext
 import javax.inject.Inject
 import net.pterodactylus.util.template.Template
 import net.pterodactylus.util.template.TemplateContext
 import javax.inject.Inject
@@ -13,28 +14,29 @@ import javax.inject.Inject
 /**
  * The login page lets the user log in.
  */
 /**
  * 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")
+class LoginPage @Inject constructor(template: Template, webInterface: WebInterface, loaders: Loaders):
+               SoneTemplatePage("login.html", webInterface, loaders, template = template, 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)
                        }
                }
                                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(freenetRequest: FreenetRequest) =
                        getCurrentSone(freenetRequest.toadletContext)?.let { "index.html" }
 
-       override fun isEnabled(toadletContext: ToadletContext) = when {
-               webInterface.core.preferences.isRequireFullAccess && !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
        }
 
 }
        }
 
 }