♻️ Copy session-handling code to FreenetRequest
[Sone.git] / src / main / kotlin / net / pterodactylus / sone / web / pages / CreateSonePage.kt
1 package net.pterodactylus.sone.web.pages
2
3 import freenet.clients.http.ToadletContext
4 import net.pterodactylus.sone.data.Sone
5 import net.pterodactylus.sone.utils.isPOST
6 import net.pterodactylus.sone.web.WebInterface
7 import net.pterodactylus.sone.web.page.*
8 import net.pterodactylus.util.template.Template
9 import net.pterodactylus.util.template.TemplateContext
10 import java.util.logging.Level
11 import java.util.logging.Logger
12 import javax.inject.Inject
13
14 /**
15  * The “create Sone” page lets the user create a new Sone.
16  */
17 class CreateSonePage @Inject constructor(template: Template, webInterface: WebInterface):
18                 SoneTemplatePage("createSone.html", webInterface, template, "Page.CreateSone.Title") {
19
20         private val logger = Logger.getLogger(CreateSonePage::class.java.name)
21
22         override fun handleRequest(soneRequest: SoneRequest, templateContext: TemplateContext) {
23                 templateContext["sones"] = soneRequest.core.localSones.sortedWith(Sone.NICE_NAME_COMPARATOR)
24                 templateContext["identitiesWithoutSone"] = soneRequest.core.identityManager.allOwnIdentities.filterNot { "Sone" in it.contexts }.sortedBy { "${it.nickname}@${it.id}".toLowerCase() }
25                 if (soneRequest.isPOST) {
26                         val identity = soneRequest.httpRequest.getPartAsStringFailsafe("identity", 43)
27                         soneRequest.core.identityManager.allOwnIdentities.firstOrNull { it.id == identity }?.let { ownIdentity ->
28                                 val sone = soneRequest.core.createSone(ownIdentity)
29                                 if (sone == null) {
30                                         logger.log(Level.SEVERE, "Could not create Sone for OwnIdentity: $ownIdentity")
31                                 }
32                                 setCurrentSone(soneRequest.toadletContext, sone)
33                                 throw RedirectException("index.html")
34                         }
35                         templateContext["errorNoIdentity"] = true
36                 }
37         }
38
39         override fun isEnabled(soneRequest: SoneRequest) =
40                         if (soneRequest.core.preferences.requireFullAccess && !soneRequest.toadletContext.isAllowedFullAccess) {
41                                 false
42                         } else {
43                                 (getCurrentSone(soneRequest.toadletContext) == null) || (soneRequest.core.localSones.size == 1)
44                         }
45
46 }