From: David ‘Bombe’ Roden Date: Sat, 3 Jun 2017 16:11:15 +0000 (+0200) Subject: Replace trust page with Kotlin version X-Git-Tag: 0.9.7^2~182 X-Git-Url: https://git.pterodactylus.net/?p=Sone.git;a=commitdiff_plain;h=d28f8a019901ca427b89f8829444bf8198c2dc49 Replace trust page with Kotlin version --- diff --git a/src/main/java/net/pterodactylus/sone/web/pages/TrustPage.java b/src/main/java/net/pterodactylus/sone/web/pages/TrustPage.java deleted file mode 100644 index 55929d7..0000000 --- a/src/main/java/net/pterodactylus/sone/web/pages/TrustPage.java +++ /dev/null @@ -1,72 +0,0 @@ -/* - * Sone - TrustPage.java - Copyright © 2011–2016 David Roden - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program. If not, see . - */ - -package net.pterodactylus.sone.web.pages; - -import com.google.common.base.Optional; - -import net.pterodactylus.sone.core.Core; -import net.pterodactylus.sone.data.Sone; -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.util.web.Method; - -/** - * Page that lets the user trust another Sone. This will assign a configurable - * amount of trust to an identity. - * - * @see Core#trustSone(Sone, Sone) - * @author David ‘Bombe’ Roden - */ -public class TrustPage extends SoneTemplatePage { - - /** - * Creates a new “trust Sone” page. - * - * @param template - * The template to render - * @param webInterface - * The Sone web interface - */ - public TrustPage(Template template, WebInterface webInterface) { - super("trust.html", template, "Page.Trust.Title", webInterface, true); - } - - // - // SONETEMPLATEPAGE METHODS - // - - /** - * {@inheritDoc} - */ - @Override - protected void handleRequest(FreenetRequest request, TemplateContext templateContext) throws RedirectException { - if (request.getMethod() == Method.POST) { - String returnPage = request.getHttpRequest().getPartAsStringFailsafe("returnPage", 256); - String identity = request.getHttpRequest().getPartAsStringFailsafe("sone", 44); - Sone currentSone = getCurrentSone(request.getToadletContext()); - Optional sone = webInterface.getCore().getSone(identity); - if (sone.isPresent()) { - webInterface.getCore().trustSone(currentSone, sone.get()); - } - throw new RedirectException(returnPage); - } - } - -} diff --git a/src/main/kotlin/net/pterodactylus/sone/web/pages/TrustPage.kt b/src/main/kotlin/net/pterodactylus/sone/web/pages/TrustPage.kt new file mode 100644 index 0000000..a93dc2e --- /dev/null +++ b/src/main/kotlin/net/pterodactylus/sone/web/pages/TrustPage.kt @@ -0,0 +1,29 @@ +package net.pterodactylus.sone.web.pages + +import net.pterodactylus.sone.utils.isPOST +import net.pterodactylus.sone.utils.let +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 + +/** + * Page that lets the user trust another Sone. This will assign a configurable + * amount of trust to an identity. + */ +class TrustPage(template: Template, webInterface: WebInterface): + SoneTemplatePage("trust.html", template, "Page.Trust.Title", webInterface, true) { + + override fun handleRequest(request: FreenetRequest, templateContext: TemplateContext) { + if (request.isPOST) { + getCurrentSone(request.toadletContext)?.also { currentSone -> + webInterface.core.getSone(request.parameters["sone"]).let { sone -> + webInterface.core.trustSone(currentSone, sone) + } + } + throw RedirectException(request.parameters["returnPage", 256]) + } + } + +}