diff options
author | Jesse Morgan <jesse@jesterpm.net> | 2014-02-13 22:49:46 -0800 |
---|---|---|
committer | Jesse Morgan <jesse@jesterpm.net> | 2014-02-13 22:49:46 -0800 |
commit | 9fd23c11d28911d2ea8f66e648d01c4733c81380 (patch) | |
tree | d67e33f925e2bc287b0e30ae3a33c37fc8f6863f | |
parent | c91558898921c2063762c3b346eaa36a259b6391 (diff) |
Adding New Believer resource.
5 files changed, 120 insertions, 8 deletions
diff --git a/src/com/p4square/grow/backend/resources/TrainingRecordResource.java b/src/com/p4square/grow/backend/resources/TrainingRecordResource.java index 2a0d3f0..3d9d67f 100644 --- a/src/com/p4square/grow/backend/resources/TrainingRecordResource.java +++ b/src/com/p4square/grow/backend/resources/TrainingRecordResource.java @@ -143,7 +143,7 @@ public class TrainingRecordResource extends ServerResource { switch (mRequestType) { case VIDEO: try { - JacksonRepresentation<VideoRecord> representation = + JacksonRepresentation<VideoRecord> representation = new JacksonRepresentation<>(entity, VideoRecord.class); representation.setObjectMapper(JsonEncodedProvider.MAPPER); VideoRecord update = representation.getObject(); @@ -181,7 +181,7 @@ public class TrainingRecordResource extends ServerResource { */ private void skipAssessedChapters(String userId, TrainingRecord record) { // Get the user's score. - double assessedScore; + double assessedScore = 0; try { String summaryString = mDb.getKey("assessments", userId, "summary"); @@ -190,7 +190,10 @@ public class TrainingRecordResource extends ServerResource { return; } Map<?,?> summary = MAPPER.readValue(summaryString, Map.class); - assessedScore = (Double) summary.get("score"); + + if (summary.containsKey("score")) { + assessedScore = (Double) summary.get("score"); + } } catch (IOException e) { LOG.error("IOException fetching assessment record for " + userId, e); diff --git a/src/com/p4square/grow/frontend/AccountRedirectResource.java b/src/com/p4square/grow/frontend/AccountRedirectResource.java index 0dd903b..25467cd 100644 --- a/src/com/p4square/grow/frontend/AccountRedirectResource.java +++ b/src/com/p4square/grow/frontend/AccountRedirectResource.java @@ -4,6 +4,7 @@ package com.p4square.grow.frontend; +import java.util.HashMap; import java.util.Map; import org.restlet.data.Status; @@ -54,7 +55,8 @@ public class AccountRedirectResource extends ServerResource { @Override protected Representation get() { try { - Map<?, ?> account = null; + // Fetch account Map. + Map account = new HashMap(); try { JsonResponse response = backendGet("/accounts/" + mUserId); if (response.getStatus().isSuccess()) { @@ -64,12 +66,15 @@ public class AccountRedirectResource extends ServerResource { } - String landing = null; - - if (account != null) { - landing = (String) account.get("landing"); + // Check for the new believers cookie + String cookie = getRequest().getCookies().getFirstValue(NewBelieverResource.COOKIE_NAME); + if (cookie != null && cookie.length() != 0) { + account.put("landing", "training"); + account.put("newbeliever", "true"); + backendPut("/accounts/" + mUserId, account); } + String landing = (String) account.get("landing"); if (landing == null) { landing = "assessment"; } @@ -107,4 +112,16 @@ public class AccountRedirectResource extends ServerResource { return response; } + + protected JsonResponse backendPut(final String uri, final Map data) { + LOG.debug("Sending backend PUT " + uri); + + final JsonResponse response = mJsonClient.put(getBackendEndpoint() + uri, data); + final Status status = response.getStatus(); + if (!status.isSuccess() && !Status.CLIENT_ERROR_NOT_FOUND.equals(status)) { + LOG.warn("Error making backend request for '" + uri + "'. status = " + response.getStatus().toString()); + } + + return response; + } } diff --git a/src/com/p4square/grow/frontend/GrowFrontend.java b/src/com/p4square/grow/frontend/GrowFrontend.java index 1db123f..540d5a7 100644 --- a/src/com/p4square/grow/frontend/GrowFrontend.java +++ b/src/com/p4square/grow/frontend/GrowFrontend.java @@ -95,6 +95,7 @@ public class GrowFrontend extends FMFacade { router.attach("/", new Redirector(getContext(), "index.html", Redirector.MODE_CLIENT_PERMANENT)); router.attach("/login.html", LoginPageResource.class); router.attach("/newaccount.html", NewAccountResource.class); + router.attach("/newbeliever", NewBelieverResource.class); final Router accountRouter = new Router(getContext()); accountRouter.attach("/authenticate", AuthenticatedResource.class); diff --git a/src/com/p4square/grow/frontend/NewBelieverResource.java b/src/com/p4square/grow/frontend/NewBelieverResource.java new file mode 100644 index 0000000..8fe078a --- /dev/null +++ b/src/com/p4square/grow/frontend/NewBelieverResource.java @@ -0,0 +1,72 @@ +/* + * Copyright 2014 Jesse Morgan + */ + +package com.p4square.grow.frontend; + +import freemarker.template.Template; + +import org.restlet.data.CookieSetting; +import org.restlet.data.MediaType; +import org.restlet.data.Status; +import org.restlet.representation.Representation; +import org.restlet.ext.freemarker.TemplateRepresentation; + +import org.apache.log4j.Logger; + +import com.p4square.fmfacade.FreeMarkerPageResource; + +/** + * This resource displays the transitional page between chapters. + * + * @author Jesse Morgan <jesse@jesterpm.net> + */ +public class NewBelieverResource extends FreeMarkerPageResource { + private static final Logger LOG = Logger.getLogger(NewBelieverResource.class); + + public static final String COOKIE_NAME = "seeker"; + + private GrowFrontend mGrowFrontend; + + @Override + public void doInit() { + super.doInit(); + + mGrowFrontend = (GrowFrontend) getApplication(); + } + + /** + * Display the New Believer page. + * + * The New Believer page creates a cookie to remember the user, + * explains what's going on, and then asks the user to go to the login + * page. + * + * When the user hits the {@link AccountRedirectResource} the cookie + * is read and the user is moved ahead to the training section. + */ + @Override + protected Representation get() { + Template t = mGrowFrontend.getTemplate("templates/newbeliever.ftl"); + + try { + if (t == null) { + setStatus(Status.CLIENT_ERROR_NOT_FOUND); + return ErrorPage.TEMPLATE_NOT_FOUND; + } + + // Set the new believer cookie + CookieSetting cookie = new CookieSetting(COOKIE_NAME, "true"); + cookie.setPath("/"); + getRequest().getCookies().add(cookie); + getResponse().getCookieSettings().add(cookie); + + return new TemplateRepresentation(t, getRootObject(), MediaType.TEXT_HTML); + + } catch (Exception e) { + LOG.fatal("Could not render page: " + e.getMessage(), e); + setStatus(Status.SERVER_ERROR_INTERNAL); + return ErrorPage.RENDER_ERROR; + } + } +} diff --git a/src/templates/templates/newbeliever.ftl b/src/templates/templates/newbeliever.ftl new file mode 100644 index 0000000..e58425d --- /dev/null +++ b/src/templates/templates/newbeliever.ftl @@ -0,0 +1,19 @@ +<#include "/macros/common.ftl"> +<#include "/macros/common-page.ftl"> + +<@commonpage> + <@noticebox> + </@noticebox> + + <@content class="text"> + <h1>New Believers</h1> + + Welcome! When you click the getting started button below you will + be asked to login or create a login. After you have logged in, you + will be taken directly to the Seeker section of the site. + + </@content> + + <#include "/templates/getstarted-button.ftl"> +</@commonpage> + |