/**
* Base page for the Sone web interface.
*/
-open class SoneTemplatePage(
+open class SoneTemplatePage @JvmOverloads constructor(
path: String,
protected val webInterface: WebInterface,
template: Template,
private val pageTitleKey: String? = null,
- private val requiresLogin: Boolean = true
+ private val requiresLogin: Boolean = false,
+ private val pageTitle: (FreenetRequest) -> String = { pageTitleKey?.let(webInterface.l10n::getString) ?: "" }
) : FreenetTemplatePage(path, webInterface.templateContextFactory, template, "noPermission.html") {
- @JvmOverloads
- constructor(path: String, template: Template, pageTitleKey: String?, webInterface: WebInterface, requireLogin: Boolean = false) :
- this(path, webInterface, template, pageTitleKey, requireLogin)
-
- constructor(path: String, template: Template, webInterface: WebInterface, requireLogin: Boolean = true) :
- this(path, webInterface, template, null, requireLogin)
-
private val core = webInterface.core
protected val sessionProvider: SessionProvider = webInterface
fun requiresLogin() = requiresLogin
- override public fun getPageTitle(request: FreenetRequest) =
- pageTitleKey?.let(webInterface.l10n::getString) ?: ""
+ override public fun getPageTitle(freenetRequest: FreenetRequest) = pageTitle(freenetRequest)
override public fun getStyleSheets() =
listOf("css/sone.css")
handleRequest(freenetRequest, templateContext)
}
- internal open fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) {
+ internal open fun handleRequest(freenetRequest: FreenetRequest, templateContext: TemplateContext) {
}
- override public fun getRedirectTarget(request: FreenetRequest): String? {
- if (requiresLogin && getCurrentSone(request.toadletContext) == null) {
- val parameters = request.httpRequest.parameterNames
- .flatMap { name -> request.httpRequest.getMultipleParam(name).map { name to it } }
+ override public fun getRedirectTarget(freenetRequest: FreenetRequest): String? {
+ if (requiresLogin && getCurrentSone(freenetRequest.toadletContext) == null) {
+ val parameters = freenetRequest.httpRequest.parameterNames
+ .flatMap { name -> freenetRequest.httpRequest.getMultipleParam(name).map { name to it } }
.joinToString("&") { "${it.first.urlEncode}=${it.second.urlEncode}" }
.emptyToNull
- return "login.html?target=${request.httpRequest.path}${parameters?.let { ("?" + it).urlEncode } ?: ""}"
+ return "login.html?target=${freenetRequest.httpRequest.path}${parameters?.let { ("?" + it).urlEncode } ?: ""}"
}
return null
}
override fun isEnabled(toadletContext: ToadletContext) = when {
requiresLogin && getCurrentSone(toadletContext) == null -> false
- core.preferences.isRequireFullAccess && !toadletContext.isAllowedFullAccess -> false
+ core.preferences.requireFullAccess && !toadletContext.isAllowedFullAccess -> false
else -> true
}