* @throws JDOMException
*/
//public XMLValue computeAcl(NodeRevisionDescriptors revisionDescriptors, NodeRevisionDescriptor revisionDescriptor, String contextPath, String serverURL) throws ObjectLockedException, RevisionDescriptorNotFoundException, ServiceAccessException, LinkedObjectNotFoundException, AccessDeniedException, ObjectNotFoundException, LockTokenNotFoundException, JDOMException, VetoException {
public XMLValue computeAcl(NodeRevisionDescriptors revisionDescriptors, NodeRevisionDescriptor revisionDescriptor, String slideContextPath) throws ObjectLockedException, RevisionDescriptorNotFoundException, ServiceAccessException, LinkedObjectNotFoundException, AccessDeniedException, ObjectNotFoundException, LockTokenNotFoundException, JDOMException, VetoException {
// FIXME serverUrl?
XMLValue xmlValue = new XMLValue();
NamespaceConfig config = nsaToken.getNamespaceConfig();
Structure structure = nsaToken.getStructureHelper();
ObjectNode objectNode = structure.retrieve(sToken, revisionDescriptors.getUri());
// check read-acl permission
Security security = nsaToken.getSecurityHelper();
security.checkCredentials(sToken, objectNode, config.getReadPermissionsAction());
String currentSubjectUri = "";
boolean currentNegative = false;
String currentInheritedFrom = "";
Element currentAceElm = null;
Element currentGrantDenyElm = null;
Enumeration permissions = security.enumeratePermissions(sToken, objectNode, true);
while (permissions.hasMoreElements()) {
NodePermission perm = (NodePermission)permissions.nextElement();
if (!perm.getSubjectUri().equals(currentSubjectUri)
|| (perm.isNegative() && !currentNegative || !perm.isNegative() && currentNegative)
|| (!currentInheritedFrom.equals(perm.getInheritedFrom()))) {
// save previous ACE
if (currentAceElm != null) {
xmlValue.add(currentAceElm);
}
// new ACE
currentAceElm = new Element(E_ACE, DNSP);
// principal
if (perm.isInvert()) {
Element invertElm = new Element(E_INVERT, DNSP);
invertElm.addContent(createPrincipalElement(perm.getSubjectUri()));
currentAceElm.addContent(invertElm);
}
else {
currentAceElm.addContent(createPrincipalElement(perm.getSubjectUri()));
}
// grant/deny
currentGrantDenyElm = perm.isNegative()
? new Element(E_DENY, DNSP)
: new Element(E_GRANT, DNSP);
currentAceElm.addContent(currentGrantDenyElm);
// inherited
String inheritedFrom = perm.getInheritedFrom();
if (inheritedFrom != null && inheritedFrom.length() > 0) {
currentAceElm.addContent(createInheritedElement(inheritedFrom));
}
// protected
if (perm.isProtected()) {
currentAceElm.addContent(new Element(E_PROTECTED, DNSP));
}
currentSubjectUri = perm.getSubjectUri();
currentNegative = perm.isNegative();
currentInheritedFrom = inheritedFrom != null ? inheritedFrom : "";
}
currentGrantDenyElm.addContent(createPrivilegeElement(perm.getActionUri()));
}
// save last ACE
if (currentAceElm != null) {
xmlValue.add(currentAceElm);
}
return xmlValue;
}