package net.pterodactylus.sone.web.pages
-import net.pterodactylus.sone.utils.also
-import net.pterodactylus.sone.utils.isPOST
-import net.pterodactylus.sone.utils.parameters
-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.utils.*
+import net.pterodactylus.sone.web.*
+import net.pterodactylus.sone.web.page.*
+import net.pterodactylus.util.template.*
+import javax.inject.*
/**
* Page that lets the user untrust another Sone. This will remove all trust
* assignments for an identity.
*/
-class UntrustPage(template: Template, webInterface: WebInterface):
- SoneTemplatePage("untrust.html", template, "Page.Untrust.Title", webInterface, true) {
+@ToadletPath("untrust.html")
+class UntrustPage @Inject constructor(webInterface: WebInterface, loaders: Loaders, templateRenderer: TemplateRenderer) :
+ LoggedInPage("Page.Untrust.Title", webInterface, loaders, templateRenderer) {
- override fun handleRequest(freenetRequest: FreenetRequest, templateContext: TemplateContext) {
- if (freenetRequest.isPOST) {
- getCurrentSone(freenetRequest.toadletContext)!!.also { currentSone ->
- freenetRequest.parameters["sone", 44]
- .let(webInterface.core::getSone)
- .also { webInterface.core.untrustSone(currentSone, it) }
- }
- throw RedirectException(freenetRequest.parameters["returnPage", 256])
+ override fun handleRequest(soneRequest: SoneRequest, currentSone: Sone, templateContext: TemplateContext) {
+ if (soneRequest.isPOST) {
+ soneRequest.parameters["sone", 44]!!
+ .let(soneRequest.core::getSone)
+ ?.also { soneRequest.core.untrustSone(currentSone, it) }
+ throw RedirectException(soneRequest.parameters["returnPage", 256])
}
}