Example usage for com.google.gson JsonArray JsonArray

List of usage examples for com.google.gson JsonArray JsonArray

Introduction

In this page you can find the example usage for com.google.gson JsonArray JsonArray.

Prototype

public JsonArray() 

Source Link

Document

Creates an empty JsonArray.

Usage

From source file:com.confighub.api.repository.user.files.GetRepoFiles.java

License:Open Source License

@GET
@Path("/{account}/{repository}")
@Produces("application/json")
public Response get(@PathParam("account") String account, @PathParam("repository") String repositoryName,
        @QueryParam("context") String contextString, @QueryParam("all") boolean all, @QueryParam("ts") Long ts,
        @QueryParam("tag") String tagLabel, @QueryParam("searchTerm") String searchTerm,
        @QueryParam("searchResolved") boolean searchResolved, @HeaderParam("Authorization") String token) {
    JsonObject json = new JsonObject();
    Gson gson = new Gson();
    Store store = new Store();

    try {/*from w ww  .ja v a  2  s.  c om*/
        int status = validate(account, repositoryName, token, store, false);
        if (0 != status)
            return Response.status(status).build();

        Date dateObj = DateTimeUtils.dateFromTsOrTag(
                Utils.isBlank(tagLabel) ? null : store.getTag(repository.getId(), tagLabel), ts,
                repository.getCreateDate());

        if (null != dateObj)
            repository = store.getRepository(repository.getId(), dateObj);

        Collection<CtxLevel> ctx = ContextParser.parseAndCreate(contextString, repository, store, user, dateObj,
                true);
        Context context = new Context(store, repository, ctx, dateObj, all);

        Map<AbsoluteFilePath, Collection<RepoFile>> resolved = context.resolveFiles(user, searchTerm,
                searchResolved);

        Map<String, JsonObject> directoryMap = new HashMap<>();
        Set<String> absPaths = new HashSet<>();

        AccessRuleWrapper rulesWrapper = repository.getRulesWrapper(user);

        for (AbsoluteFilePath absoluteFilePath : resolved.keySet()) {
            absPaths.add(absoluteFilePath.getPath());

            JsonObject directory = directoryMap.get(absoluteFilePath.getPath());
            if (null == directory) {
                directory = new JsonObject();
                String folderName;
                int index = -1;
                if (null != absoluteFilePath.getPath())
                    index = absoluteFilePath.getPath().lastIndexOf("/");
                if (-1 == index)
                    folderName = absoluteFilePath.getPath();
                else
                    folderName = absoluteFilePath.getPath().substring(index + 1,
                            absoluteFilePath.getPath().length());

                directory.addProperty("name", folderName);
                directory.addProperty("path", absoluteFilePath.getPath());
                directory.add("files", new JsonArray());
                directoryMap.put(absoluteFilePath.getPath(), directory);
            }

            JsonArray files = directory.getAsJsonArray("files");

            resolved.get(absoluteFilePath).stream().forEach(f -> {
                JsonObject file = new JsonObject();

                file.addProperty("id", f.getId());
                file.addProperty("name", absoluteFilePath.getFilename());
                file.addProperty("fullPath", absoluteFilePath.getAbsPath());

                if (repository.isAccessControlEnabled()) {
                    if (null == rulesWrapper)
                        file.addProperty("editable", false);
                    else {
                        rulesWrapper.executeRuleFor(f);
                        file.addProperty("editable", f.isEditable);
                    }
                } else
                    file.addProperty("editable", true);

                if (f.isSecure())
                    file.addProperty("spName", f.getSecurityProfile().getName());

                file.add("levels", gson.fromJson(f.getContextJson(), JsonArray.class));
                file.addProperty("active", f.isActive());
                file.addProperty("score", f.getContextWeight());

                files.add(file);
            });
        }

        // Fill in the blank paths
        absPaths.stream().forEach(path -> {
            if (!Utils.isBlank(path)) {
                String[] folders = path.split("/");
                String folder = "";

                for (int i = 0; i < folders.length; i++) {
                    if (i == 0)
                        folder = folders[0];
                    else
                        folder += "/" + folders[i];

                    if (!directoryMap.containsKey(folder)) {
                        JsonObject directory = new JsonObject();
                        directory.addProperty("name", folders[i]);
                        directory.addProperty("path", folder);
                        directory.add("files", new JsonArray());

                        directoryMap.put(folder, directory);
                    }
                }
            }
        });

        JsonArray directories = new JsonArray();
        directoryMap.values().stream().forEach(d -> directories.add(d));
        json.add("data", directories);
        json.addProperty("success", true);

    } catch (ConfigException e) {
        e.printStackTrace();

        if (e.getErrorCode().equals(Error.Code.CONTEXT_SCOPE_MISMATCH))
            json.addProperty("resetContext", true);

        json.addProperty("success", false);
        json.addProperty("message", e.getMessage());
    } finally {
        store.close();
    }

    return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
}

From source file:com.confighub.api.repository.user.files.GetRepoKeys.java

License:Open Source License

@GET
@Path("/{account}/{repository}")
@Produces("application/json")
public Response add(@PathParam("account") String account, @PathParam("repository") String repositoryName,
        @HeaderParam("Authorization") String token) {
    JsonArray json = new JsonArray();
    Gson gson = new Gson();
    Store store = new Store();

    try {/*from  w  w w. j  a  v a  2s.  co  m*/
        int status = validate(account, repositoryName, token, store, false);
        if (0 != status)
            return Response.status(status).build();

        Set<PropertyKey> keys = repository.getKeys();
        if (null != keys)
            keys.stream().forEach(k -> json.add(k.getKey()));
    } catch (ConfigException e) {
        e.printStackTrace();
    } finally {
        store.close();
    }

    return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
}

From source file:com.confighub.api.repository.user.security.GetSecurityGroup.java

License:Open Source License

@POST
@Path("/{account}/{repository}")
@Produces("application/json")
public Response update(@HeaderParam("Authorization") String userToken, @PathParam("account") String account,
        @PathParam("repository") String repositoryName, @FormParam("profile") String profile,
        @FormParam("all") boolean allKeys) {
    JsonObject json = new JsonObject();
    Gson gson = new GsonBuilder().serializeNulls().create();
    Store store = new Store();

    try {/* w  ww  .  ja va  2s .  com*/
        int status = validate(account, repositoryName, userToken, store);
        if (0 != status)
            return Response.status(status).build();

        SecurityProfile ep = store.getSecurityProfile(user, repository, null, profile);
        if (null == ep) {
            json.addProperty("message", "Unable to find specified profile");
            json.addProperty("success", false);

            return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
        }

        json.add("profile", GsonHelper.toJson(ep, profile, null));
        json.addProperty("privAcc", repository.isOwner(user));

        JsonArray files = new JsonArray();
        if (null != ep.getFiles()) {
            for (RepoFile file : ep.getFiles()) {

                JsonObject fileJson = file.toJson();
                fileJson.addProperty("fullPath", file.getAbsPath());
                files.add(fileJson);
            }
        }

        json.add("files", files);

        JsonArray tokens = new JsonArray();
        if (null != ep.getTokens())
            for (Token token : ep.getTokens())
                tokens.add(GsonHelper.tokenToJson(token, false));
        json.add("tokens", tokens);

        json.addProperty("success", true);
        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } catch (ConfigException e) {
        json.addProperty("message", e.getMessage());
        json.addProperty("success", false);

        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } finally {
        store.close();
    }
}

From source file:com.confighub.api.repository.user.security.GetSecurityProfiles.java

License:Open Source License

@GET
@Path("/{account}/{repository}")
@Produces("application/json")
public Response get(@HeaderParam("Authorization") String token, @PathParam("account") String account,
        @PathParam("repository") String repositoryName) {
    JsonObject json = new JsonObject();
    Gson gson = new Gson();
    SecurityStore store = new SecurityStore();

    try {//  ww w. j  a va2 s  .c o  m
        int status = validate(account, repositoryName, token, store);
        if (0 != status)
            return Response.status(status).build();

        Collection<SecurityProfile> groups = store.getAllRepoEncryptionProfiles(user, repository);
        JsonArray groupJson = new JsonArray();

        for (SecurityProfile group : groups) {
            JsonObject g = new JsonObject();
            g.addProperty("name", group.getName());
            g.addProperty("cipher", null == group.getCipher() ? "" : group.getCipher().getName());
            g.addProperty("tokens", null == group.getTokens() ? 0 : group.getTokens().size());
            g.addProperty("files", null == group.getFiles() ? 0 : group.getFiles().size());
            g.addProperty("keys", null == group.getKeys() ? 0 : group.getKeys().size());
            groupJson.add(g);
        }

        json.add("groups", groupJson);
        json.addProperty("success", true);

        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } catch (ConfigException e) {
        json.addProperty("message", e.getMessage());
        json.addProperty("success", false);

        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } finally {
        store.close();
    }
}

From source file:com.confighub.api.repository.user.tags.GetTags.java

License:Open Source License

@GET
@Path("/{account}/{repository}")
@Produces("application/json")
public Response get(@HeaderParam("Authorization") String token, @PathParam("account") String account,
        @PathParam("repository") String repositoryName) {
    JsonObject json = new JsonObject();
    Gson gson = new Gson();
    TagStore store = new TagStore();

    try {/*from w  ww .j a  v  a  2  s .c  o  m*/
        int status = validate(account, repositoryName, token, store);
        if (0 != status)
            return Response.status(status).build();

        JsonArray tagsArr = new JsonArray();
        Set<Tag> tags = repository.getTags();
        if (null != tags)
            tags.forEach(tag -> tagsArr.add(tag.toJson()));

        json.add("tags", tagsArr);
        json.addProperty("success", true);
        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } catch (ConfigException e) {
        store.rollback();

        json.addProperty("message", e.getMessage());
        json.addProperty("success", false);

        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } finally {
        store.close();
    }
}

From source file:com.confighub.api.repository.user.team.TeamInfo.java

License:Open Source License

@GET
@Path("/{account}/{repository}/{team}")
@Produces("application/json")
public Response get(@PathParam("account") String account, @PathParam("repository") String repositoryName,
        @PathParam("team") String teamName, @HeaderParam("Authorization") String userToken) {
    JsonObject json = new JsonObject();
    Gson gson = new GsonBuilder().serializeNulls().create();
    Store store = new Store();

    try {//from   w w w .  j a v  a2s  .c  o m
        int status = validate(account, repositoryName, userToken, store);
        if (0 != status)
            return Response.status(status).build();

        Team team = repository.getTeam(teamName);
        if (null == team) {
            json.addProperty("message", "Failed to find the requested team: " + teamName);
            json.addProperty("success", false);
            return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
        }

        json.addProperty("success", true);
        json.add("team", GsonHelper.teamToJson(team));

        JsonArray tokens = new JsonArray();
        if (null != team.getTokens())
            for (Token token : team.getTokens())
                tokens.add(GsonHelper.tokenToJson(token, false));
        json.add("tokens", tokens);

    } finally {
        store.close();
    }

    return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
}

From source file:com.confighub.api.repository.user.tokens.TokenFetchAll.java

License:Open Source License

@GET
@Path("/{account}/{repository}")
@Produces("application/json")
public Response get(@PathParam("account") String account, @PathParam("repository") String repositoryName,
        @QueryParam("all") boolean all, @HeaderParam("Authorization") String token) {
    JsonObject json = new JsonObject();
    Gson gson = new Gson();
    SecurityStore store = new SecurityStore();

    try {//from   w ww  . ja  va2  s.  com
        int status = validate(account, repositoryName, token, store);
        if (0 != status)
            return Response.status(status).build();

        Collection<Token> tokens = store.getTokens(repository);
        JsonArray tokensJson = new JsonArray();

        if (null != tokens && tokens.size() > 0) {
            for (Token t : tokens) {
                boolean isAllowedToEdit = t.isAllowedToEdit(user);
                boolean viewable = t.isAllowedToViewToken(user);

                if (all || viewable) {
                    JsonObject tkJson = GsonHelper.tokenToJson(t, viewable);

                    tkJson.addProperty("editable", isAllowedToEdit);
                    tkJson.addProperty("deletable", t.isAllowedToDelete(user));
                    tokensJson.add(tkJson);
                }
            }
        }
        json.add("tokens", tokensJson);

        if (repository.isSecurityProfilesEnabled()) {
            Collection<SecurityProfile> groups = store.getAllRepoEncryptionProfiles(user, repository);
            JsonArray groupJson = new JsonArray();

            boolean hasEncryptedGroups = false;
            for (SecurityProfile group : groups) {
                if (group.encryptionEnabled()) {
                    hasEncryptedGroups = true;

                    JsonObject g = new JsonObject();
                    g.addProperty("name", group.getName());
                    g.addProperty("cipher", null == group.getCipher() ? "" : group.getCipher().getName());
                    groupJson.add(g);
                }
            }

            if (hasEncryptedGroups)
                json.add("groups", groupJson);
        }

        JsonObject teamsJson = new JsonObject();
        if (null != repository.getTeams() && repository.getTeams().size() > 0) {
            for (Team team : repository.getTeams()) {
                JsonObject teamJson = new JsonObject();
                teamJson.addProperty("memberCount", team.getMemberCount());
                teamJson.addProperty("ruleCount", team.getRuleCount());

                teamsJson.add(team.getName(), teamJson);
            }
        }
        json.add("teams", teamsJson);

        Team userTeam = store.getTeamForMember(repository, user);
        json.addProperty("isAdmin", repository.isAdminOrOwner(user));
        json.addProperty("accessControlEnabled", repository.isAccessControlEnabled());
        json.addProperty("teamMember", null == userTeam ? null : userTeam.getName());

        json.addProperty("success", true);
        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } catch (ConfigException e) {
        json.addProperty("success", false);
        json.addProperty("message", e.getMessage());
        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } finally {
        store.close();
    }
}

From source file:com.confighub.api.user.dashboard.GetDashboardElements.java

License:Open Source License

@GET
@Produces("application/json")
public Response get(@FormParam("startingId") Long startingId, @HeaderParam("Authorization") String token) {
    JsonObject json = new JsonObject();

    Store store = new Store();
    Gson gson = new Gson();

    try {//  w w  w.j  a  v  a 2s .  com
        UserAccount user = TokenState.getUser(token, store);
        if (null == user)
            return Response.status(401).build();

        Set<Repository> repositories = new HashSet<>();

        repositories.addAll(user.getRepositories());
        Set<Organization> organizations = user.getOrganizations();

        if (null != organizations)
            organizations.forEach(o -> repositories.addAll(o.getRepositories()));

        if (repositories.size() > 0) {
            JsonArray repositoriesMap = new JsonArray();
            repositories.forEach(r -> repositoriesMap.add(toJson(r)));
            json.add("repositories", repositoriesMap);
        }

        json.addProperty("success", true);
    } catch (ConfigException e) {
        json.addProperty("success", false);
        json.addProperty("message", e.getMessage());
    } finally {
        store.close();
    }

    return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
}

From source file:com.confighub.api.user.dashboard.MyRepositories.java

License:Open Source License

@GET
@Produces("application/json")
public Response getAssignments(@HeaderParam("Authorization") String token) {
    JsonArray json = new JsonArray();
    Store store = new Store();

    try {//  ww w  .  j  av a  2s  .c  om
        UserAccount user = TokenState.getUser(token, store);
        if (null == user)
            return Response.status(401).build();

        if (null != user.getRepositories()) {
            for (Repository repository : user.getRepositories()) {
                JsonObject repositoryJ = new JsonObject();

                repositoryJ.addProperty("name", repository.getName());
                repositoryJ.addProperty("description",
                        null == repository.getDescription() ? "" : repository.getDescription());
                repositoryJ.addProperty("owner", repository.getAccountName());
                repositoryJ.addProperty("isPrivate", repository.isPrivate());
                repositoryJ.addProperty("userCount", repository.getUserCount());

                json.add(repositoryJ);
            }
        }

        // if a user is registered as admin/owner of an organization, then
        // they have access to all their repositories
        Set<Organization> orgs = user.getOrganizations();
        if (null != orgs) {
            for (Organization org : orgs) {
                Set<Repository> orgRepos = org.getRepositories();
                if (null == orgRepos)
                    continue;

                for (Repository repository : orgRepos) {
                    JsonObject repositoryJ = new JsonObject();

                    repositoryJ.addProperty("name", repository.getName());
                    repositoryJ.addProperty("description",
                            null == repository.getDescription() ? "" : repository.getDescription());
                    repositoryJ.addProperty("owner", repository.getAccountName());
                    repositoryJ.addProperty("isPrivate", repository.isPrivate());
                    repositoryJ.addProperty("userCount", repository.getUserCount());

                    json.add(repositoryJ);
                }
            }
        }

        Gson gson = new Gson();
        return Response.ok(gson.toJson(json), MediaType.APPLICATION_JSON).build();
    } finally {
        store.close();
    }
}

From source file:com.confighub.api.user.GetAccount.java

License:Open Source License

private void getPersonalAccountData(JsonObject json, UserAccount loggedInUser, Account account, Store store)
        throws ConfigException {
    UserAccount accUser = account.getUser();

    json.addProperty("t", "u");
    json.addProperty("name", accUser.getName());
    json.addProperty("creationTs", accUser.getCreateDate().getTime());

    boolean isLoggedInUsersViewingPersonalAccount = null == loggedInUser ? false
            : loggedInUser.getAccount().equals(account);
    json.addProperty("own", isLoggedInUsersViewingPersonalAccount);

    if (isLoggedInUsersViewingPersonalAccount) {
        json.addProperty("email", accUser.getEmail());
        json.addProperty("blogSub", accUser.isEmailBlog());
        json.addProperty("repoSub", accUser.isEmailRepoCritical());
    }/*from   w  w w  .  j a v  a 2 s.co  m*/

    // Organizations
    if (isLoggedInUsersViewingPersonalAccount && null != accUser.getOrganizations()) {
        JsonArray organizationsJson = new JsonArray();
        for (Organization o : accUser.getOrganizations()) {
            JsonObject oj = new JsonObject();
            oj.addProperty("un", o.getAccountName());
            oj.addProperty("name", o.getName());
            oj.addProperty("id", o.getId());
            oj.addProperty("creationTs", o.getCreateDate().getTime());
            oj.addProperty("role", o.isOwner(accUser) ? "Owner" : "Admin");

            getOrganizationManagement(oj, o);

            if (null != o.getRepositories()) {
                JsonArray repos = new JsonArray();
                o.getRepositories().parallelStream().forEach(r -> repos.add(r.getName()));
                oj.add("repos", repos);
            }

            organizationsJson.add(oj);
        }
        json.add("orgs", organizationsJson);

    }

    // Repositories
    Set<Repository> repositories = new HashSet<>();
    repositories.addAll(accUser.getRepositories());
    Set<Organization> organizations = accUser.getOrganizations();

    if (null != organizations)
        organizations.forEach(o -> repositories.addAll(o.getRepositories()));

    JsonArray repos = new JsonArray();
    if (null != repositories) {
        for (Repository repo : repositories) {

            if (repo.hasReadAccess(loggedInUser)) {
                JsonObject rj = getRepoJson(repo);

                if (repo.isOwner(accUser))
                    rj.addProperty("role", "Owner");
                else if (repo.isAdmin(accUser))
                    rj.addProperty("role", "Admin");
                else if (repo.isMember(loggedInUser))
                    rj.addProperty("role", "Team Member");

                if (isLoggedInUsersViewingPersonalAccount)
                    rj.addProperty("canLeave", !repo.isAdminOrOwner(accUser));

                rj.addProperty("ut", repo.getUserType(loggedInUser).name());
                rj.addProperty("demo", repo.isDemo());

                Team team = store.getTeamForMember(repo, accUser);
                if (null != team)
                    rj.add("team", GsonHelper.teamToJson(team));

                repos.add(rj);
            }
        }
    }

    json.add("repos", repos);
}