package net.pterodactylus.sone.web;
import net.pterodactylus.sone.data.Sone;
+import net.pterodactylus.sone.web.page.Page.Request.Method;
import net.pterodactylus.util.template.Template;
+import net.pterodactylus.util.template.TemplateContext;
/**
* This page lets the user unfollow another Sone.
* The Sone web interface
*/
public UnfollowSonePage(Template template, WebInterface webInterface) {
- super("unfollowSone.html", template, "Page.UnfollowSone.Title", webInterface);
+ super("unfollowSone.html", template, "Page.UnfollowSone.Title", webInterface, true);
}
//
* {@inheritDoc}
*/
@Override
- protected void processTemplate(Request request, Template template) throws RedirectException {
- super.processTemplate(request, template);
- String soneId = request.getHttpRequest().getParam("sone");
- Sone currentSone = getCurrentSone(request.getToadletContext());
- Sone sone = webInterface.core().getSone(soneId);
- if (!sone.equals(currentSone)) {
- currentSone.removeFriend(sone);
+ protected void processTemplate(Request request, TemplateContext templateContext) throws RedirectException {
+ super.processTemplate(request, templateContext);
+ if (request.getMethod() == Method.POST) {
+ String soneId = request.getHttpRequest().getPartAsStringFailsafe("sone", 44);
+ String returnPage = request.getHttpRequest().getPartAsStringFailsafe("returnPage", 256);
+ Sone currentSone = getCurrentSone(request.getToadletContext());
+ currentSone.removeFriend(soneId);
+ webInterface.getCore().saveSone(currentSone);
+ throw new RedirectException(returnPage);
}
- throw new RedirectException("viewSone.html?sone=" + soneId);
- }
-
- //
- // SONETEMPLATEPAGE METHODS
- //
-
- /**
- * {@inheritDoc}
- */
- @Override
- protected boolean requiresLogin() {
- return true;
}
}