--- /dev/null
+/*
+ * Sone - BlockSonePage.java - Copyright © 2010 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 <http://www.gnu.org/licenses/>.
+ */
+
+package net.pterodactylus.sone.web;
+
+import net.pterodactylus.sone.web.page.Page.Request.Method;
+import net.pterodactylus.util.template.Template;
+
+/**
+ * This page lets the user block a Sone for propagation.
+ *
+ * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
+ */
+public class BlockSonePage extends SoneTemplatePage {
+
+ /**
+ * Creates a new “block Sone” page.
+ *
+ * @param template
+ * The template to render
+ * @param webInterface
+ * The Sone web interface
+ */
+ public BlockSonePage(Template template, WebInterface webInterface) {
+ super("blockSone.html", template, "Page.BlockSone.Title", webInterface);
+ }
+
+ //
+ // TEMPLATEPAGE METHODS
+ //
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ protected void processTemplate(Request request, Template template) throws RedirectException {
+ super.processTemplate(request, template);
+ String soneId = request.getHttpRequest().getPartAsStringFailsafe("sone", 36);
+ if (request.getMethod() == Method.POST) {
+ getCurrentSone(request.getToadletContext()).addBlockedSoneId(soneId);
+ }
+ throw new RedirectException("viewSone.html?sone=" + soneId);
+ }
+
+ //
+ // SONETEMPLATEPAGE METHODS
+ //
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ protected boolean requiresLogin() {
+ // TODO Auto-generated method stub
+ return super.requiresLogin();
+ }
+
+}
--- /dev/null
+/*
+ * Sone - BlockSonePage.java - Copyright © 2010 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 <http://www.gnu.org/licenses/>.
+ */
+
+package net.pterodactylus.sone.web;
+
+import net.pterodactylus.sone.web.page.Page.Request.Method;
+import net.pterodactylus.util.template.Template;
+
+/**
+ * This page lets the user unblock a Sone for propagation.
+ *
+ * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
+ */
+public class UnblockSonePage extends SoneTemplatePage {
+
+ /**
+ * Creates a new “unblock Sone” page.
+ *
+ * @param template
+ * The template to render
+ * @param webInterface
+ * The Sone web interface
+ */
+ public UnblockSonePage(Template template, WebInterface webInterface) {
+ super("unblockSone.html", template, "Page.UnblockSone.Title", webInterface);
+ }
+
+ //
+ // TEMPLATEPAGE METHODS
+ //
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ protected void processTemplate(Request request, Template template) throws RedirectException {
+ super.processTemplate(request, template);
+ String soneId = request.getHttpRequest().getPartAsStringFailsafe("sone", 36);
+ if (request.getMethod() == Method.POST) {
+ getCurrentSone(request.getToadletContext()).removeBlockedSoneId(soneId);
+ }
+ throw new RedirectException("viewSone.html?sone=" + soneId);
+ }
+
+ //
+ // SONETEMPLATEPAGE METHODS
+ //
+
+ /**
+ * {@inheritDoc}
+ */
+ @Override
+ protected boolean requiresLogin() {
+ // TODO Auto-generated method stub
+ return super.requiresLogin();
+ }
+
+}
Template viewSoneTemplate = templateFactory.createTemplate(createReader("/templates/viewSone.html"));
viewSoneTemplate.set("formPassword", formPassword);
+ Template blockSoneTemplate = templateFactory.createTemplate(createReader("/templates/blockSone.html"));
+ blockSoneTemplate.set("formPassword", formPassword);
+
+ Template unblockSoneTemplate = templateFactory.createTemplate(createReader("/templates/unblockSone.html"));
+ unblockSoneTemplate.set("formPassword", formPassword);
+
Template viewPostTemplate = templateFactory.createTemplate(createReader("/templates/viewPost.html"));
viewPostTemplate.set("formPassword", formPassword);
pageToadlets.add(pageToadletFactory.createPageToadlet(new CreatePostPage(createPostTemplate, this)));
pageToadlets.add(pageToadletFactory.createPageToadlet(new CreateReplyPage(createReplyTemplate, this)));
pageToadlets.add(pageToadletFactory.createPageToadlet(new ViewSonePage(viewSoneTemplate, this)));
+ pageToadlets.add(pageToadletFactory.createPageToadlet(new BlockSonePage(blockSoneTemplate, this)));
+ pageToadlets.add(pageToadletFactory.createPageToadlet(new UnblockSonePage(unblockSoneTemplate, this)));
pageToadlets.add(pageToadletFactory.createPageToadlet(new ViewPostPage(viewPostTemplate, this)));
pageToadlets.add(pageToadletFactory.createPageToadlet(new DeletePostPage(deletePostTemplate, this)));
pageToadlets.add(pageToadletFactory.createPageToadlet(new FollowSonePage(followSoneTemplate, this)));
Page.ViewSone.Following.Title=This Sone follows
Page.ViewSone.Following.FollowingNone.Text=Apparently, this Sone does not yet follow any other Sone.
+Page.BlockSone.Title=Block Sone - Sone
+
+Page.UnblockSone.Title=Block Sone - Sone
+
Page.ViewPost.Title=View Post - Sone
Page.ViewPost.Page.Title=View Post by {sone}
Page.ViewPost.Button.PostReply=Post Reply!
--- /dev/null
+<%include include/head.html>
+
+<%include include/tail.html>
<div id="known-sones">
<%foreach knownSones sone>
- <div><a href="viewSone.html?sone=<% sone.id>"><% sone.niceName|html></a> (<% sone.requestUri|html>)</div>
+ <div>
+ <div class="profile-link"><a href="viewSone.html?sone=<% sone.id>"><% sone.niceName|html></a></div>
+ <div>(<% sone.requestUri|html>)</div>
+ <%if sone.isBlocked>
+ <div class="unblock-link"><a href="unblockSone.html?sone=<% sone.id>">unblock</a></div>
+ <%else>
+ <div class="block-link"><a href="blockSone.html?sone=<% sone.id>">block</a></div>
+ <%/if>
+ </div>
<%foreachelse>
<div><%= Page.KnownSones.Text.NoKnownSones|l10n|html></div>
<%/foreach>
--- /dev/null
+<%include include/head.html>
+
+<%include include/tail.html>