Add refresh header to rescue page.
[Sone.git] / src / main / java / net / pterodactylus / sone / web / RescuePage.java
index 40b03f1..1ba86e9 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Sone - RescuePage.java - Copyright © 2011 David Roden
+ * Sone - RescuePage.java - Copyright © 2011–2013 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
 
 package net.pterodactylus.sone.web;
 
+import static net.pterodactylus.sone.utils.NumberParsers.parseLong;
+
+import java.util.Arrays;
+import java.util.Collections;
+
 import net.pterodactylus.sone.core.SoneRescuer;
-import net.pterodactylus.sone.data.Sone;
-import net.pterodactylus.sone.web.page.Page.Request.Method;
-import net.pterodactylus.util.number.Numbers;
+import net.pterodactylus.sone.data.LocalSone;
+import net.pterodactylus.sone.web.page.FreenetRequest;
 import net.pterodactylus.util.template.Template;
 import net.pterodactylus.util.template.TemplateContext;
+import net.pterodactylus.util.web.Header;
+import net.pterodactylus.util.web.Method;
 
 /**
  * Page that lets the user control the rescue mode for a Sone.
@@ -52,13 +58,13 @@ public class RescuePage extends SoneTemplatePage {
         * {@inheritDoc}
         */
        @Override
-       protected void processTemplate(Request request, TemplateContext templateContext) throws RedirectException {
+       protected void processTemplate(FreenetRequest request, TemplateContext templateContext) throws RedirectException {
                super.processTemplate(request, templateContext);
-               Sone currentSone = getCurrentSone(request.getToadletContext(), false);
+               LocalSone currentSone = getCurrentSone(request.getToadletContext(), false).get();
                SoneRescuer soneRescuer = webInterface.getCore().getSoneRescuer(currentSone);
                if (request.getMethod() == Method.POST) {
                        if ("true".equals(request.getHttpRequest().getPartAsStringFailsafe("fetch", 4))) {
-                               long edition = Numbers.safeParseLong(request.getHttpRequest().getPartAsStringFailsafe("edition", 8), -1L);
+                               long edition = parseLong(request.getHttpRequest().getPartAsStringFailsafe("edition", 8), -1L);
                                if (edition > -1) {
                                        soneRescuer.setEdition(edition);
                                }
@@ -69,4 +75,16 @@ public class RescuePage extends SoneTemplatePage {
                templateContext.set("soneRescuer", soneRescuer);
        }
 
+       @Override
+       protected Iterable<Header> getAdditionalHeaders(FreenetRequest request) {
+               LocalSone currentSone = getCurrentSone(request.getToadletContext(), false).get();
+               SoneRescuer soneRescuer = webInterface.getCore().getSoneRescuer(currentSone);
+               if ((request.getMethod() == Method.GET) && soneRescuer.isFetching()) {
+                       final Header header = new Header("Refresh");
+                       header.addValue("5; url=rescue.html");
+                       return Arrays.asList(header);
+               }
+               return Collections.emptyList();
+       }
+
 }