diff options
| author | Jesse Morgan <jesse@jesterpm.net> | 2013-10-01 22:21:19 -0700 | 
|---|---|---|
| committer | Jesse Morgan <jesse@jesterpm.net> | 2013-10-01 22:21:19 -0700 | 
| commit | 45634dc9934813bd88aebf58f39e82bf0254a7d6 (patch) | |
| tree | 36393b9c7393aa9099031985b8315eafe294c4bc /src | |
| parent | 0daa3ec0fa105c5bcbabec35cb61e07a20049e93 (diff) | |
Adding message banner
Diffstat (limited to 'src')
| -rw-r--r-- | src/com/p4square/grow/backend/GrowBackend.java | 3 | ||||
| -rw-r--r-- | src/com/p4square/grow/backend/resources/BannerResource.java | 66 | ||||
| -rw-r--r-- | src/templates/macros/common-page.ftl | 1 | ||||
| -rw-r--r-- | src/templates/pages/index.html.ftl | 1 | ||||
| -rw-r--r-- | src/templates/templates/banner.ftl | 6 | 
5 files changed, 77 insertions, 0 deletions
| diff --git a/src/com/p4square/grow/backend/GrowBackend.java b/src/com/p4square/grow/backend/GrowBackend.java index 7da6fff..533cf09 100644 --- a/src/com/p4square/grow/backend/GrowBackend.java +++ b/src/com/p4square/grow/backend/GrowBackend.java @@ -17,6 +17,7 @@ import com.p4square.grow.config.Config;  import com.p4square.grow.backend.db.CassandraDatabase;  import com.p4square.grow.backend.resources.AccountResource; +import com.p4square.grow.backend.resources.BannerResource;  import com.p4square.grow.backend.resources.SurveyResource;  import com.p4square.grow.backend.resources.SurveyResultsResource;  import com.p4square.grow.backend.resources.TrainingRecordResource; @@ -64,6 +65,8 @@ public class GrowBackend extends Application {          router.attach("/accounts/{userId}/training/videos/{videoId}",                  TrainingRecordResource.class); +        // Misc. +        router.attach("/banner", BannerResource.class);          return router;      } diff --git a/src/com/p4square/grow/backend/resources/BannerResource.java b/src/com/p4square/grow/backend/resources/BannerResource.java new file mode 100644 index 0000000..4551777 --- /dev/null +++ b/src/com/p4square/grow/backend/resources/BannerResource.java @@ -0,0 +1,66 @@ +/* + * Copyright 2013 Jesse Morgan + */ + +package com.p4square.grow.backend.resources; + +import java.io.IOException; + +import org.restlet.data.Status; +import org.restlet.resource.ServerResource; +import org.restlet.representation.Representation; +import org.restlet.representation.StringRepresentation; + +import org.apache.log4j.Logger; + +import com.p4square.grow.backend.GrowBackend; +import com.p4square.grow.backend.db.CassandraDatabase; + +/** + * Fetches or sets the banner string. + * + * @author Jesse Morgan <jesse@jesterpm.net> + */ +public class BannerResource extends ServerResource { +    private static final Logger LOG = Logger.getLogger(BannerResource.class); + +    private CassandraDatabase mDb; + +    @Override +    public void doInit() { +        super.doInit(); + +        final GrowBackend backend = (GrowBackend) getApplication(); +        mDb = backend.getDatabase(); +    } + +    /** +     * Handle GET Requests. +     */ +    @Override +    protected Representation get() { +        String result = mDb.getKey("strings", "banner"); + +        if (result == null || result.length() == 0) { +            result = "{}"; +        } + +        return new StringRepresentation(result); +    } + +    /** +     * Handle PUT requests +     */ +    @Override +    protected Representation put(Representation entity) { +        try { +            mDb.putKey("strings", "banner", entity.getText()); +            setStatus(Status.SUCCESS_NO_CONTENT); + +        } catch (IOException e) { +            setStatus(Status.SERVER_ERROR_INTERNAL); +        } + +        return null; +    } +} diff --git a/src/templates/macros/common-page.ftl b/src/templates/macros/common-page.ftl index 512128b..94cc5e3 100644 --- a/src/templates/macros/common-page.ftl +++ b/src/templates/macros/common-page.ftl @@ -12,6 +12,7 @@      </head>      <body>      <div id="notfooter"> +        <#include "/templates/banner.ftl">          <#include "/templates/header.ftl">          <#nested> diff --git a/src/templates/pages/index.html.ftl b/src/templates/pages/index.html.ftl index 94eaec3..1b59509 100644 --- a/src/templates/pages/index.html.ftl +++ b/src/templates/pages/index.html.ftl @@ -12,6 +12,7 @@  </head>  <body>  <div id="notfooter"> +    <#include "/templates/banner.ftl">      <header>          <h1>              <a href="http://myfoursquarechurch.com"><img src="${staticRoot}/images/foursquarelg.png"></a> diff --git a/src/templates/templates/banner.ftl b/src/templates/templates/banner.ftl new file mode 100644 index 0000000..3a2d23b --- /dev/null +++ b/src/templates/templates/banner.ftl @@ -0,0 +1,6 @@ +<#assign bannerResult = get("bannerData", "riap://component/backend/banner")> +<#if bannerResult.succeeded == true> +    <#if (bannerData.html!"") != ""> +<div id="banner">${bannerData.html}</div> +    </#if> +</#if> | 
