X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=blobdiff_plain;f=src%2Fmain%2Fkotlin%2Fnet%2Fpterodactylus%2Fsone%2Fweb%2Fpages%2FDeleteReplyPage.kt;h=909f6452886cafc1ea1d67c80cf7e8163a21ed5c;hp=0b922b0af08ef949b0f4c6f65dcbbc22ae04cb21;hb=110a933c2724aba6a604fc5eed6372ff1e1e6144;hpb=05fb821e72072bde52f383bdc5a988da67f66d0c diff --git a/src/main/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPage.kt b/src/main/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPage.kt index 0b922b0..909f645 100644 --- a/src/main/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPage.kt +++ b/src/main/kotlin/net/pterodactylus/sone/web/pages/DeleteReplyPage.kt @@ -1,39 +1,41 @@ package net.pterodactylus.sone.web.pages +import net.pterodactylus.sone.data.Sone +import net.pterodactylus.sone.main.* import net.pterodactylus.sone.utils.isPOST -import net.pterodactylus.sone.web.pages.SoneTemplatePage import net.pterodactylus.sone.web.WebInterface -import net.pterodactylus.sone.web.page.FreenetRequest -import net.pterodactylus.util.template.Template +import net.pterodactylus.sone.web.page.* import net.pterodactylus.util.template.TemplateContext +import javax.inject.Inject /** * This page lets the user delete a reply. */ -class DeleteReplyPage(template: Template, webInterface: WebInterface): - SoneTemplatePage("deleteReply.html", template, "Page.DeleteReply.Title", webInterface, true) { +@TemplatePath("/templates/deleteReply.html") +class DeleteReplyPage @Inject constructor(webInterface: WebInterface, loaders: Loaders, templateRenderer: TemplateRenderer): + LoggedInPage("deleteReply.html", "Page.DeleteReply.Title", webInterface, loaders, templateRenderer) { - override fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) { - if (request.isPOST) { - val replyId = request.httpRequest.getPartAsStringFailsafe("reply", 36) - val reply = webInterface.core.getPostReply(replyId).orNull() ?: throw RedirectException("noPermission.html") + override fun handleRequest(soneRequest: SoneRequest, currentSone: Sone, templateContext: TemplateContext) { + if (soneRequest.isPOST) { + val replyId = soneRequest.httpRequest.getPartAsStringFailsafe("reply", 36) + val reply = soneRequest.core.getPostReply(replyId) ?: throw RedirectException("noPermission.html") if (!reply.sone.isLocal) { throw RedirectException("noPermission.html") } - val returnPage = request.httpRequest.getPartAsStringFailsafe("returnPage", 256) - if (request.httpRequest.isPartSet("confirmDelete")) { - webInterface.core.deleteReply(reply) + val returnPage = soneRequest.httpRequest.getPartAsStringFailsafe("returnPage", 256) + if (soneRequest.httpRequest.isPartSet("confirmDelete")) { + soneRequest.core.deleteReply(reply) throw RedirectException(returnPage) } - if (request.httpRequest.isPartSet("abortDelete")) { + if (soneRequest.httpRequest.isPartSet("abortDelete")) { throw RedirectException(returnPage) } templateContext["reply"] = replyId templateContext["returnPage"] = returnPage return } - templateContext["reply"] = request.httpRequest.getParam("reply") - templateContext["returnPage"] = request.httpRequest.getParam("returnPage") + templateContext["reply"] = soneRequest.httpRequest.getParam("reply") + templateContext["returnPage"] = soneRequest.httpRequest.getParam("returnPage") } }