import java.io.StringWriter;
import java.util.Collection;
import java.util.Collections;
+import java.util.logging.Level;
+import java.util.logging.Logger;
import net.pterodactylus.sone.web.page.Page.Request.Method;
+import net.pterodactylus.util.logging.Logging;
import net.pterodactylus.util.template.Template;
import freenet.clients.http.LinkEnabledCallback;
import freenet.clients.http.PageMaker;
*/
public class TemplatePage implements Page, LinkEnabledCallback {
+ /** The logger. */
+ private static final Logger logger = Logging.getLogger(TemplatePage.class);
+
/** The path of the page. */
private final String path;
}
try {
+ long start = System.nanoTime();
processTemplate(request, template);
+ long finish = System.nanoTime();
+ logger.log(Level.FINEST, "Template was rendered in " + ((finish - start) / 1000) / 1000.0 + "ms.");
} catch (RedirectException re1) {
return new RedirectResponse(re1.getTarget());
}
template.render(stringWriter);
pageNode.content.addChild("%", stringWriter.toString());
+ postProcess(request, template);
+
return new Response(200, "OK", "text/html", pageNode.outer.generate());
}
}
/**
+ * This method will be called after
+ * {@link #processTemplate(net.pterodactylus.sone.web.page.Page.Request, Template)}
+ * has processed the template and the template was rendered. This method
+ * will not be called if
+ * {@link #processTemplate(net.pterodactylus.sone.web.page.Page.Request, Template)}
+ * throws a {@link RedirectException}!
+ *
+ * @param request
+ * The request being processed
+ * @param template
+ * The template that was rendered
+ */
+ protected void postProcess(Request request, Template template) {
+ /* do nothing. */
+ }
+
+ /**
* Can be overridden to redirect the user to a different page, in case a log
* in is required, or something else is wrong.
*