diff options
Diffstat (limited to 'src/com')
-rw-r--r-- | src/com/p4square/f1oauth/F1OAuthHelper.java | 19 | ||||
-rw-r--r-- | src/com/p4square/grow/frontend/NewAccountResource.java | 20 |
2 files changed, 28 insertions, 11 deletions
diff --git a/src/com/p4square/f1oauth/F1OAuthHelper.java b/src/com/p4square/f1oauth/F1OAuthHelper.java index 4f55043..f6f736f 100644 --- a/src/com/p4square/f1oauth/F1OAuthHelper.java +++ b/src/com/p4square/f1oauth/F1OAuthHelper.java @@ -13,7 +13,9 @@ import org.restlet.Response; import org.restlet.Request; import org.restlet.data.ChallengeResponse; import org.restlet.data.ChallengeScheme; +import org.restlet.data.MediaType; import org.restlet.data.Method; +import org.restlet.data.Status; import org.restlet.engine.util.Base64; import org.restlet.representation.StringRepresentation; @@ -108,21 +110,28 @@ public class F1OAuthHelper extends OAuthHelper { return processAccessTokenRequest(request); } - public void createAccount(String firstname, String lastname, String email, String redirect) + public boolean createAccount(String firstname, String lastname, String email, String redirect) throws OAuthException { String req = String.format("{\n\"account\":{\n\"firstName\":\"%s\",\n" + "\"lastName\":\"%s\",\n\"email\":\"%s\",\n" + "\"urlRedirect\":\"%s\"\n}\n}", firstname, lastname, email, redirect); - Request request = new Request(Method.POST, mBaseUrl + "/Accounts"); + Request request = new Request(Method.POST, mBaseUrl + "Accounts"); request.setChallengeResponse(new ChallengeResponse(ChallengeScheme.HTTP_OAUTH)); - request.setEntity(new StringRepresentation(req)); + request.setEntity(new StringRepresentation(req, MediaType.APPLICATION_JSON)); Response response = getResponse(request); - if (!response.getStatus().isSuccess()) { - throw new OAuthException(response.getStatus()); + Status status = response.getStatus(); + if (Status.SUCCESS_NO_CONTENT.equals(status)) { + return true; + + } else if (Status.CLIENT_ERROR_CONFLICT.equals(status)) { + return false; + + } else { + throw new OAuthException(status); } } } diff --git a/src/com/p4square/grow/frontend/NewAccountResource.java b/src/com/p4square/grow/frontend/NewAccountResource.java index e0b857a..f37a33e 100644 --- a/src/com/p4square/grow/frontend/NewAccountResource.java +++ b/src/com/p4square/grow/frontend/NewAccountResource.java @@ -46,10 +46,12 @@ public class NewAccountResource extends FreeMarkerPageResource { mGrowFrontend = (GrowFrontend) getApplication(); mHelper = mGrowFrontend.getHelper(); - mErrorMessage = null; + mErrorMessage = ""; - mLoginPageUrl = ""; - mVerificationPage = ""; + mLoginPageUrl = mGrowFrontend.getConfig().getString("postAccountCreationPage", + getRequest().getRootRef().toString()); + mVerificationPage = mGrowFrontend.getConfig().getString("dynamicRoot", "") + + "/verification.html"; } /** @@ -66,7 +68,9 @@ public class NewAccountResource extends FreeMarkerPageResource { } Map<String, Object> root = getRootObject(); - root.put("errorMessage", mErrorMessage); + if (mErrorMessage.length() > 0) { + root.put("errorMessage", mErrorMessage); + } return new TemplateRepresentation(t, root, MediaType.TEXT_HTML); @@ -100,7 +104,11 @@ public class NewAccountResource extends FreeMarkerPageResource { } try { - mHelper.createAccount(firstname, lastname, email, mLoginPageUrl); + if (!mHelper.createAccount(firstname, lastname, email, mLoginPageUrl)) { + mErrorMessage = "An account with that address already exists."; + return get(); + } + getResponse().redirectSeeOther(mVerificationPage); return new StringRepresentation("Redirecting to " + mVerificationPage); @@ -110,6 +118,6 @@ public class NewAccountResource extends FreeMarkerPageResource { } private boolean isEmpty(String s) { - return s != null && s.trim().length() > 0; + return s == null || s.trim().length() == 0; } } |