diff options
| author | Jesse Morgan <jesse@jesterpm.net> | 2014-09-21 15:01:40 -0700 | 
|---|---|---|
| committer | Jesse Morgan <jesse@jesterpm.net> | 2014-09-21 15:01:40 -0700 | 
| commit | d01b3c8e49251c85cfa9c426064b841233c6c8e4 (patch) | |
| tree | 755dbbf4ecc373b84f55f81d9de83e7d03454c49 /src/com/p4square/grow | |
| parent | c2feb363e513c0dea83d507eb9ba1918748d4e8e (diff) | |
Adding Support for Assigning Attributes in F1.
Adding a new interface, F1API for F1 APIs which require a valid access
token. This is now used by AssessmentResultsPage to assign an attribute
each time someone completes the assessment.
Also adding an AttributeTool to list all attributes and assign
attributes to users.
Diffstat (limited to 'src/com/p4square/grow')
| -rw-r--r-- | src/com/p4square/grow/GrowProcessComponent.java | 1 | ||||
| -rw-r--r-- | src/com/p4square/grow/frontend/AssessmentResultsPage.java | 25 | ||||
| -rw-r--r-- | src/com/p4square/grow/tools/AttributeTool.java | 143 | 
3 files changed, 166 insertions, 3 deletions
| diff --git a/src/com/p4square/grow/GrowProcessComponent.java b/src/com/p4square/grow/GrowProcessComponent.java index 18b3d5b..791f177 100644 --- a/src/com/p4square/grow/GrowProcessComponent.java +++ b/src/com/p4square/grow/GrowProcessComponent.java @@ -10,7 +10,6 @@ import java.io.IOException;  import org.apache.log4j.Logger;  import org.restlet.Application; -import org.restlet.Client;  import org.restlet.Component;  import org.restlet.Restlet;  import org.restlet.data.ChallengeScheme; diff --git a/src/com/p4square/grow/frontend/AssessmentResultsPage.java b/src/com/p4square/grow/frontend/AssessmentResultsPage.java index c205503..ff1832c 100644 --- a/src/com/p4square/grow/frontend/AssessmentResultsPage.java +++ b/src/com/p4square/grow/frontend/AssessmentResultsPage.java @@ -4,6 +4,7 @@  package com.p4square.grow.frontend; +import java.util.Date;  import java.util.Map;  import freemarker.template.Template; @@ -22,9 +23,12 @@ import com.p4square.fmfacade.json.JsonRequestClient;  import com.p4square.fmfacade.json.JsonResponse;  import com.p4square.fmfacade.json.ClientException; +import com.p4square.f1oauth.Attribute; +import com.p4square.f1oauth.F1API;  import com.p4square.f1oauth.F1User;  import com.p4square.grow.config.Config; +import com.p4square.grow.provider.JsonEncodedProvider;  /**   * This page fetches the user's final score and displays the transitional page between @@ -105,7 +109,23 @@ public class AssessmentResultsPage extends FreeMarkerPageResource {          F1User user = (F1User) getRequest().getClientInfo().getUser(); -        // TODO: Update the attribute. +        // Update the attribute. +        String attributeName = "Assessment Complete - " + results.get("result"); + +        try { +            Attribute attribute = new Attribute(); +            attribute.setStartDate(new Date()); +            attribute.setComment(JsonEncodedProvider.MAPPER.writeValueAsString(results)); + +            F1API f1 = mGrowFrontend.getF1Access().getAuthenticatedApi(user); +            if (!f1.addAttribute(user.getIdentifier(), attributeName, attribute)) { +                LOG.error("addAttribute failed for " + user.getIdentifier()  +                        + " with attribute " + attributeName); +            } +        } catch (Exception e) { +            LOG.error("addAttribute failed for " + user.getIdentifier()  +                    + " with attribute " + attributeName, e); +        }      }      /** @@ -124,7 +144,8 @@ public class AssessmentResultsPage extends FreeMarkerPageResource {          final JsonResponse response = mJsonClient.get(getBackendEndpoint() + uri);          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()); +            LOG.warn("Error making backend request for '" + uri + "'. status = " +                    + response.getStatus().toString());          }          return response; diff --git a/src/com/p4square/grow/tools/AttributeTool.java b/src/com/p4square/grow/tools/AttributeTool.java new file mode 100644 index 0000000..0775087 --- /dev/null +++ b/src/com/p4square/grow/tools/AttributeTool.java @@ -0,0 +1,143 @@ +/* + * Copyright 2014 Jesse Morgan + */ + +package com.p4square.grow.tools; + +import java.util.Arrays; +import java.util.Date; +import java.util.Map; + +import org.restlet.Client; +import org.restlet.Context; +import org.restlet.data.Protocol; + +import com.p4square.grow.config.Config; +import com.p4square.f1oauth.Attribute; +import com.p4square.f1oauth.F1Access; +import com.p4square.f1oauth.F1API; +import com.p4square.f1oauth.F1Exception; +import com.p4square.restlet.oauth.OAuthUser; + +/** + * Tool for manipulating F1 Attributes. + * + * @author Jesse Morgan <jesse@jesterpm.net> + */ +public class AttributeTool { + +    private static Config mConfig; +    private static F1API mF1API; + +    public static void usage() { +        System.out.println("java com.p4square.grow.tools.AttributeTool <command>...\n"); +        System.out.println("Commands:"); +        System.out.println("\t--domain <domain>                           Set config domain"); +        System.out.println("\t--dev                                       Set config domain to dev"); +        System.out.println("\t--config <file>                             Merge in config file"); +        System.out.println("\t--list                                      List all attributes"); +        System.out.println("\t--assign <user> <attribute> <comment>       Assign an attribute"); +    } + +    public static void main(String... args) { +        if (args.length == 0) { +            usage(); +            System.exit(1); +        } + +        mConfig = new Config(); + +        try { +            mConfig.updateConfig(AttributeTool.class.getResourceAsStream("/grow.properties")); + +            int offset = 0; +            while (offset < args.length) { +                if ("--domain".equals(args[offset])) { +                    mConfig.setDomain(args[offset + 1]); +                    mF1API = null; +                    offset += 2; + +                } else if ("--dev".equals(args[offset])) { +                    mConfig.setDomain("dev"); +                    mF1API = null; +                    offset += 1; + +                } else if ("--config".equals(args[offset])) { +                    mConfig.updateConfig(args[offset + 1]); +                    mF1API = null; +                    offset += 2; + +                } else if ("--list".equals(args[offset])) { +                    offset = list(args, ++offset); + +                } else if ("--assign".equals(args[offset])) { +                    offset = assign(args, ++offset); + +                } else { +                    throw new IllegalArgumentException("Unknown command " + args[offset]); +                } +            } +        } catch (Exception e) { +            e.printStackTrace(); +            System.exit(2); +        } +    } + +    private static F1API getF1API() throws Exception { +        if (mF1API == null) { +            Context context = new Context(); +            Client client = new Client(context, Arrays.asList(Protocol.HTTP, Protocol.HTTPS)); +            context.setClientDispatcher(client); + +            F1Access f1Access = new F1Access(context, +                    mConfig.getString("f1ConsumerKey"), +                    mConfig.getString("f1ConsumerSecret"), +                    mConfig.getString("f1BaseUrl"), +                    mConfig.getString("f1ChurchCode"), +                    F1Access.UserType.WEBLINK); + +            // Gather Username and Password +            String username = System.console().readLine("F1 Username: "); +            char[] password = System.console().readPassword("F1 Password: "); + +            OAuthUser user = f1Access.getAccessToken(username, new String(password)); +            Arrays.fill(password, ' '); // Lost cause, but I'll still try. + +            mF1API = f1Access.getAuthenticatedApi(user); +        } + +        return mF1API; +    } + +    private static int list(String[] args, int offset) throws Exception { +        final F1API f1 = getF1API(); + +        final Map<String, String> attributes = f1.getAttributeList(); +        System.out.printf("%7s %s\n", "ID", "Name"); +        for (Map.Entry<String, String> entry : attributes.entrySet()) { +            System.out.printf("%7s %s\n", entry.getValue(), entry.getKey()); +        } + +        return offset; +    } + +    private static int assign(String[] args, int offset) throws Exception { +        final String userId = args[offset++]; +        final String attributeName = args[offset++]; +        final String comment = args[offset++]; + +        final F1API f1 = getF1API(); + +        Attribute attribute = new Attribute(); +        attribute.setStartDate(new Date()); +        attribute.setComment(comment); + +        if (f1.addAttribute(userId, attributeName, attribute)) { +            System.out.println("Added attribute " + attributeName + " for " + userId); +        } else { +            System.out.println("Failed to add attribute " + attributeName + " for " + userId); +        } + +        return offset; +    } +} | 
