*/
@MenuName("Login")
@TemplatePath("/templates/login.html")
+@ToadletPath("login.html")
class LoginPage @Inject constructor(webInterface: WebInterface, loaders: Loaders, templateRenderer: TemplateRenderer) :
- SoneTemplatePage("login.html", webInterface, loaders, templateRenderer, pageTitleKey = "Page.Login.Title") {
+ SoneTemplatePage(webInterface, loaders, templateRenderer, pageTitleKey = "Page.Login.Title") {
override fun handleRequest(soneRequest: SoneRequest, templateContext: TemplateContext) {
if (soneRequest.isPOST) {
soneRequest.core.getLocalSone(soneId)?.let { sone ->
setCurrentSone(soneRequest.toadletContext, sone)
val target = soneRequest.httpRequest.getParam("target").emptyToNull ?: "index.html"
- throw RedirectException(target)
+ redirectTo(target)
}
}
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(soneRequest: SoneRequest) = when {
soneRequest.core.preferences.requireFullAccess && !soneRequest.toadletContext.isAllowedFullAccess -> false