@Override public Set<String> getPermissionsForPrincipal(String principalId) { if (principalId == null) { throw new IllegalArgumentException("Principal must be set!"); } Acl currentAcl = getAcl(); if (currentAcl == null) { throw new IllegalStateException("ACLs are not available!"); } if (isNullOrEmpty(acl.getAces())) { return Collections.emptySet(); } HashSet<String> result = new HashSet<String>(); for (Ace ace : acl.getAces()) { if (principalId.equals(ace.getPrincipalId()) && ace.getPermissions() != null) { result.addAll(ace.getPermissions()); } } return result; }
@Override public Set<String> getPermissionsForPrincipal(String principalId) { if (principalId == null) { throw new IllegalArgumentException("Principal must be set!"); } Acl currentAcl = getAcl(); if (currentAcl == null) { throw new IllegalStateException("ACLs are not available!"); } if (isNullOrEmpty(acl.getAces())) { return Collections.emptySet(); } HashSet<String> result = new HashSet<String>(); for (Ace ace : acl.getAces()) { if (principalId.equals(ace.getPrincipalId()) && ace.getPermissions() != null) { result.addAll(ace.getPermissions()); } } return result; }
@Override public Acl convertAces(List<Ace> aces) { if (aces == null) { return null; } BindingsObjectFactory bof = getBindingsObjectFactory(); List<Ace> bindingAces = new ArrayList<Ace>(); for (Ace ace : aces) { bindingAces.add(bof.createAccessControlEntry(ace.getPrincipalId(), ace.getPermissions())); } return bof.createAccessControlList(bindingAces); }
@Override public Acl convertAces(List<Ace> aces) { if (aces == null) { return null; } BindingsObjectFactory bof = getBindingsObjectFactory(); List<Ace> bindingAces = new ArrayList<Ace>(); for (Ace ace : aces) { bindingAces.add(bof.createAccessControlEntry(ace.getPrincipalId(), ace.getPermissions())); } return bof.createAccessControlList(bindingAces); }
/** * Converts a list of ACEs into Map for better handling. */ private static Map<String, Set<String>> convertAclToMap(Acl acl) { Map<String, Set<String>> result = new HashMap<String, Set<String>>(); if (acl == null || acl.getAces() == null) { return result; } for (Ace ace : acl.getAces()) { // don't consider indirect ACEs - we can't change them if (!ace.isDirect()) { // ignore continue; } // although a principal must not be null, check it if (ace.getPrincipal() == null || ace.getPrincipal().getId() == null) { // ignore continue; } Set<String> permissions = result.get(ace.getPrincipal().getId()); if (permissions == null) { permissions = new HashSet<String>(); result.put(ace.getPrincipal().getId(), permissions); } if (ace.getPermissions() != null) { permissions.addAll(ace.getPermissions()); } } return result; }
/** * Converts a list of ACEs into Map for better handling. */ private static Map<String, Set<String>> convertAclToMap(Acl acl) { Map<String, Set<String>> result = new HashMap<String, Set<String>>(); if (acl == null || acl.getAces() == null) { return result; } for (Ace ace : acl.getAces()) { // don't consider indirect ACEs - we can't change them if (!ace.isDirect()) { // ignore continue; } // although a principal must not be null, check it if (ace.getPrincipal() == null || ace.getPrincipal().getId() == null) { // ignore continue; } Set<String> permissions = result.get(ace.getPrincipal().getId()); if (permissions == null) { permissions = new HashSet<String>(); result.put(ace.getPrincipal().getId(), permissions); } if (ace.getPermissions() != null) { permissions.addAll(ace.getPermissions()); } } return result; }
writer.writeEndElement(); if (ace.getPermissions() != null) { for (String perm : ace.getPermissions()) { XMLUtils.write(writer, PREFIX_CMIS, NAMESPACE_CMIS, TAG_ACE_PERMISSIONS, perm);
if (ace.getPermissions() != null) permissions.addAll(ace.getPermissions());
private void addAcesParameters(Acl acl, String principalControl, String permissionControl) { if (acl == null || acl.getAces() == null) { return; } int idx = 0; for (Ace ace : acl.getAces()) { if (ace.getPrincipalId() != null && isNotEmpty(ace.getPermissions())) { String idxStr = "[" + idx + "]"; addParameter(principalControl + idxStr, ace.getPrincipalId()); int permIdx = 0; for (String perm : ace.getPermissions()) { if (perm != null) { String permIdxStr = "[" + permIdx + "]"; addParameter(permissionControl + idxStr + permIdxStr, perm); permIdx++; } } idx++; } } }
private void addAcesParameters(Acl acl, String principalControl, String permissionControl) { if (acl == null || acl.getAces() == null) { return; } int idx = 0; for (Ace ace : acl.getAces()) { if (ace.getPrincipalId() != null && isNotEmpty(ace.getPermissions())) { String idxStr = "[" + idx + "]"; addParameter(principalControl + idxStr, ace.getPrincipalId()); int permIdx = 0; for (String perm : ace.getPermissions()) { if (perm != null) { String permIdxStr = "[" + permIdx + "]"; addParameter(permissionControl + idxStr + permIdxStr, perm); permIdx++; } } idx++; } } }
if (ace.getPermissions() != null) permissions.addAll(ace.getPermissions());
List<String> permissions = translatePermissionsFromCMIS(ace.getPermissions()); for (String permission : permissions)
List<String> permissions = translatePermissionsFromCMIS(ace.getPermissions()); for (String permission : permissions)
addResult(results, assertEqualLists(expected.getPermissions(), actual.getPermissions(), null, f));
protected CmisTestResult checkACL(Session session, Acl acl, boolean checkExact, String message) { List<CmisTestResult> results = new ArrayList<CmisTestResult>(); CmisTestResult f; f = createResult(FAILURE, "ACL is null!"); addResult(results, assertNotNull(acl, null, f)); if (acl != null) { f = createResult(FAILURE, "List of ACEs is null!"); addResult(results, assertNotNull(acl.getAces(), null, f)); if (acl.getAces() != null) { for (Ace ace : acl.getAces()) { f = createResult(FAILURE, "ACE with empty principal ID!"); addResult(results, assertStringNotEmpty(ace.getPrincipalId(), null, f)); f = createResult(FAILURE, "ACE with empty permission list!"); addResult(results, assertListNotEmpty(ace.getPermissions(), null, f)); if (ace.getPermissions() != null) { for (String permission : ace.getPermissions()) { f = createResult(FAILURE, "ACE with empty permission entry!"); addResult(results, assertStringNotEmpty(permission, null, f)); } } } } CmisTestResultStatus status = checkExact ? WARNING : INFO; f = createResult(status, "ACL is provided but the isExact flag is not set!"); addResult(results, assertNotNull(acl.isExact(), null, f)); } CmisTestResultImpl result = createResult(getWorst(results), message); result.getChildren().addAll(results); return result.getStatus().getLevel() <= OK.getLevel() ? null : result; }
private Document cmisPermission( String id ) { String cmisObjectId = AclObjectId.cmisObjectId(id); String entryId = AclObjectId.entryId(id); DocumentWriter writer = newDocument(ObjectId.toString(ObjectId.Type.PERMISSIONS, id)); writer.setPrimaryType(ModeShapeLexicon.PERMISSION.toString()); writer.setParent(id); Acl acl = session.getObject(cmisObjectId, ctx).getAcl(); List<Ace> entries = acl.getAces(); for (Ace entry : entries) { if (entry.getPrincipalId().equals(entryId)) { String name = entry.getPrincipal().getId(); name = Converter.jcrPrincipal(name); writer.addProperty(ModeShapeLexicon.PERMISSION_PRINCIPAL_NAME.getLocalName(), name); List<String> perms = entry.getPermissions(); writer.addProperty(ModeShapeLexicon.PERMISSION_PRIVILEGES_NAME.getLocalName(), Converter.jcrPermissions(perms)); } } return writer.document(); }
/** * Converts an ACL object with its ACEs. */ public static CmisAccessControlListType convert(Acl acl) { if (acl == null) { return null; } CmisAccessControlListType result = new CmisAccessControlListType(); if (acl.getAces() != null) { for (Ace ace : acl.getAces()) { if (ace == null) { continue; } CmisAccessControlEntryType entry = new CmisAccessControlEntryType(); if (ace.getPrincipal() != null) { CmisAccessControlPrincipalType pincipal = new CmisAccessControlPrincipalType(); pincipal.setPrincipalId(ace.getPrincipal().getId()); convertExtension(pincipal, ace.getPrincipal()); entry.setPrincipal(pincipal); } entry.setDirect(ace.isDirect()); entry.getPermission().addAll(ace.getPermissions()); convertExtension(ace, entry); result.getPermission().add(entry); } } // handle extensions convertExtension(acl, result); return result; }
if (ace.getPermissions() != null) { for (String p : ace.getPermissions()) { permissions.add(p);
writer.endTag(NAMESPACE_CMIS, TAG_ACE_PRINCIPAL); if (ace.getPermissions() != null) { for (String perm : ace.getPermissions()) { XMLUtils.write(writer, PREFIX_CMIS, NAMESPACE_CMIS, TAG_ACE_PERMISSIONS, perm);
if (ace.getPermissions() != null) { for (String p : ace.getPermissions()) { permissions.add(p);