♻️ Move throwing redirect exception into method
[Sone.git] / src / main / kotlin / net / pterodactylus / sone / web / pages / LikePage.kt
index 9f6191e..c8369e9 100644 (file)
@@ -1,29 +1,29 @@
 package net.pterodactylus.sone.web.pages
 
-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 like [net.pterodactylus.sone.data.Post]s and [net.pterodactylus.sone.data.Reply]s.
  */
-class LikePage(template: Template, webInterface: WebInterface)
-       : SoneTemplatePage("like.html", template, "Page.Like.Title", webInterface, true) {
+@ToadletPath("like.html")
+class LikePage @Inject constructor(webInterface: WebInterface, loaders: Loaders, templateRenderer: TemplateRenderer) :
+               LoggedInPage("Page.Like.Title", webInterface, loaders, templateRenderer) {
 
-       override fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) {
-               if (request.isPOST) {
-                       getCurrentSone(request.toadletContext)!!.let { currentSone ->
-                               request.parameters["type", 16]?.also { type ->
-                                       when(type) {
-                                               "post" -> currentSone.addLikedPostId(request.parameters["post", 36]!!)
-                                               "reply" -> currentSone.addLikedReplyId(request.parameters["reply", 36]!!)
-                                       }
+       override fun handleRequest(soneRequest: SoneRequest, currentSone: Sone, templateContext: TemplateContext) {
+               if (soneRequest.isPOST) {
+                       soneRequest.parameters["type", 16]?.also { type ->
+                               when (type) {
+                                       "post" -> currentSone.addLikedPostId(soneRequest.parameters["post", 36]!!)
+                                       "reply" -> currentSone.addLikedReplyId(soneRequest.parameters["reply", 36]!!)
                                }
-                               throw RedirectException(request.parameters["returnPage", 256]!!)
                        }
+                       redirectTo(soneRequest.parameters["returnPage", 256]!!)
                }
        }