List of usage examples for com.google.gson JsonArray JsonArray
public JsonArray()
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); }