Merge branch 'release-0.9.7'
[Sone.git] / src / main / kotlin / net / pterodactylus / sone / web / ajax / LockSoneAjaxPage.kt
1 package net.pterodactylus.sone.web.ajax
2
3 import net.pterodactylus.sone.utils.parameters
4 import net.pterodactylus.sone.web.WebInterface
5 import net.pterodactylus.sone.web.page.FreenetRequest
6
7 /**
8  * Lets the user [lock][net.pterodactylus.sone.core.Core.lockSone] a [Sone][net.pterodactylus.sone.data.Sone].
9  */
10 class LockSoneAjaxPage(webInterface: WebInterface) : JsonPage("lockSone.ajax", webInterface) {
11
12         override val requiresLogin = false
13
14         override fun createJsonObject(request: FreenetRequest) =
15                         request.parameters["sone"]
16                                         .let(core::getLocalSone)
17                                         ?.let(core::lockSone)
18                                         ?.let { createSuccessJsonObject() }
19                                         ?: createErrorJsonObject("invalid-sone-id")
20
21 }