diff options
| author | Jesse Morgan <jesse@jesterpm.net> | 2013-09-01 15:56:37 -0700 | 
|---|---|---|
| committer | Jesse Morgan <jesse@jesterpm.net> | 2013-09-01 15:56:37 -0700 | 
| commit | 5e3dc2047ed9b0b59989bba9f0d86a28aa25613b (patch) | |
| tree | 653f3be99e9187355b592d3893e8cccb1b3f855c /src/com/p4square | |
| parent | e2acdba7796aaa2bd66b0577e296bb0c54dd8c95 (diff) | |
Adding ErrorPage representation for error messages
Diffstat (limited to 'src/com/p4square')
| -rw-r--r-- | src/com/p4square/grow/frontend/ErrorPage.java | 56 | ||||
| -rw-r--r-- | src/com/p4square/grow/frontend/GrowFrontend.java | 8 | 
2 files changed, 57 insertions, 7 deletions
| diff --git a/src/com/p4square/grow/frontend/ErrorPage.java b/src/com/p4square/grow/frontend/ErrorPage.java index 4a9380f..b57cc49 100644 --- a/src/com/p4square/grow/frontend/ErrorPage.java +++ b/src/com/p4square/grow/frontend/ErrorPage.java @@ -4,22 +4,64 @@  package com.p4square.grow.frontend; +import java.util.HashMap; +import java.util.Map; + +import java.io.IOException; +import java.io.Writer; + +import freemarker.template.Template; + +import org.restlet.data.MediaType; +import org.restlet.ext.freemarker.TemplateRepresentation; +import org.restlet.representation.Representation;  import org.restlet.representation.StringRepresentation; +import org.restlet.representation.WriterRepresentation;  /** + * ErrorPage wraps a String or Template Representation and displays the given + * error message.   *   * @author Jesse Morgan <jesse@jesterpm.net>   */ -public class ErrorPage extends StringRepresentation { -    public static final ErrorPage TEMPLATE_NOT_FOUND = new ErrorPage(); -    public static final ErrorPage RENDER_ERROR = new ErrorPage(); +public class ErrorPage extends WriterRepresentation { +    public static final ErrorPage TEMPLATE_NOT_FOUND = +        new ErrorPage("Could not find the requested page template."); + +    public static final ErrorPage RENDER_ERROR = +        new ErrorPage("Error rendering page."); + +    private static Template cTemplate = null; + +    private final String mMessage; + +    public ErrorPage(String msg) { +        this(msg, MediaType.TEXT_HTML); +    } + +    public ErrorPage(String msg, MediaType mediaType) { +        super(mediaType); + +        mMessage = msg; +    } + +    public static synchronized void setTemplate(Template template) { +        cTemplate = template; +    } +    protected Representation getRepresentation() { +        if (cTemplate == null) { +            return new StringRepresentation(mMessage); -    public ErrorPage() { -        super("TODO"); +        } else { +            Map<String, Object> root = new HashMap<String, Object>(); +            root.put("errorMessage", mMessage); +            return new TemplateRepresentation(cTemplate, root, MediaType.TEXT_HTML); +        }      } -    public ErrorPage(String s) { -        super(s); +    @Override +    public void write(Writer writer) throws IOException { +        getRepresentation().write(writer);      }  } diff --git a/src/com/p4square/grow/frontend/GrowFrontend.java b/src/com/p4square/grow/frontend/GrowFrontend.java index f8cbdd2..dd83491 100644 --- a/src/com/p4square/grow/frontend/GrowFrontend.java +++ b/src/com/p4square/grow/frontend/GrowFrontend.java @@ -10,6 +10,8 @@ import java.io.IOException;  import java.util.Arrays;  import java.util.UUID; +import freemarker.template.Template; +  import org.restlet.Application;  import org.restlet.Component;  import org.restlet.Client; @@ -74,6 +76,11 @@ public class GrowFrontend extends FMFacade {              mConfig.updateConfig(configFilename);          } +        Template errorTemplate = getTemplate("templates/error.ftl"); +        if (errorTemplate != null) { +            ErrorPage.setTemplate(errorTemplate); +        } +          super.start();      } @@ -97,6 +104,7 @@ public class GrowFrontend extends FMFacade {          defaultGuard.setNext(FreeMarkerPageResource.class);          router.attachDefault(defaultGuard);          router.attach("/login.html", LoginPageResource.class); +        router.attach("/newaccount.html", NewAccountResource.class);          final Router accountRouter = new Router(getContext());          accountRouter.attach("/authenticate", AuthenticatedResource.class); | 
