import freenet.clients.http.*
import net.pterodactylus.sone.data.Sone
-import net.pterodactylus.sone.main.SonePlugin
+import net.pterodactylus.sone.main.*
import net.pterodactylus.sone.utils.emptyToNull
import net.pterodactylus.sone.web.SessionProvider
import net.pterodactylus.sone.web.WebInterface
*/
open class SoneTemplatePage @JvmOverloads constructor(
path: String,
- protected val webInterface: WebInterface,
+ private val webInterface: WebInterface,
+ loaders: Loaders,
template: Template,
private val pageTitleKey: String? = null,
private val requiresLogin: Boolean = false,
private val pageTitle: (FreenetRequest) -> String = { pageTitleKey?.let(webInterface.l10n::getString) ?: "" }
-) : FreenetTemplatePage(path, webInterface.templateContextFactory, template, "noPermission.html") {
+) : FreenetTemplatePage(path, webInterface.templateContextFactory, loaders, template, "noPermission.html") {
private val core = webInterface.core
- protected val sessionProvider: SessionProvider = webInterface
+ private val sessionProvider: SessionProvider = webInterface
protected fun getCurrentSone(toadletContext: ToadletContext, createSession: Boolean = true) =
sessionProvider.getCurrentSone(toadletContext, createSession)
open fun getPageTitle(soneRequest: SoneRequest) = pageTitle(soneRequest)
- override public fun getStyleSheets() =
- listOf("css/sone.css")
+ override val styleSheets = listOf("css/sone.css")
- override public fun getShortcutIcon() = "images/icon.png"
+ override val shortcutIcon = "images/icon.png"
override public fun getAdditionalLinkNodes(request: FreenetRequest) =
listOf(mapOf(
handleRequest(freenetRequest, templateContext)
}
- internal open fun handleRequest(freenetRequest: FreenetRequest, templateContext: TemplateContext) {
+ open fun handleRequest(freenetRequest: FreenetRequest, templateContext: TemplateContext) {
handleRequest(freenetRequest.toSoneRequest(core, webInterface), templateContext)
}
private val String.urlEncode: String get() = URLEncoder.encode(this, "UTF-8")
override fun isEnabled(toadletContext: ToadletContext) =
- isEnabled(SoneRequest(toadletContext.uri, Method.GET, HTTPRequestImpl(toadletContext.uri, "GET"), toadletContext, webInterface.l10n, core, webInterface))
+ isEnabled(SoneRequest(toadletContext.uri, Method.GET, HTTPRequestImpl(toadletContext.uri, "GET"), toadletContext, webInterface.l10n, webInterface.sessionManager, core, webInterface))
open fun isEnabled(soneRequest: SoneRequest) = when {
requiresLogin && getCurrentSone(soneRequest.toadletContext) == null -> false