mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-29 15:21:53 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			140 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| package org.alfresco.repo.template;
 | |
| 
 | |
| import java.util.ArrayList;
 | |
| import java.util.List;
 | |
| import java.util.Set;
 | |
| 
 | |
| import org.alfresco.service.cmr.security.AccessPermission;
 | |
| import org.alfresco.service.cmr.security.AccessStatus;
 | |
| import org.alfresco.service.cmr.security.PermissionService;
 | |
| 
 | |
| /**
 | |
|  * Base class for Template API objects that support permissions.
 | |
|  * 
 | |
|  * @author Kevin Roast
 | |
|  */
 | |
| public abstract class BasePermissionsNode extends BaseContentNode implements TemplatePermissions
 | |
| {
 | |
|     private List<String> permissions = null;
 | |
|     private List<String> directPermissions = null;
 | |
|     private List<String> fullPermissions = null;
 | |
|     
 | |
|     // ------------------------------------------------------------------------------
 | |
|     // Security API 
 | |
|     
 | |
|     /**
 | |
|      * @return List of permissions applied to this Node, including inherited.
 | |
|      *         Strings returned are of the format [ALLOWED|DENIED];[USERNAME|GROUPNAME];PERMISSION for example
 | |
|      *         ALLOWED;kevinr;Consumer so can be easily tokenized on the ';' character.
 | |
|      */
 | |
|     public List<String> getPermissions()
 | |
|     {
 | |
|         if (this.permissions == null)
 | |
|         {
 | |
|             this.permissions = retrieveAllSetPermissions(false, false);
 | |
|         }
 | |
|         return this.permissions;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return List of permissions applied to this Node (does not include inherited).
 | |
|      *         Strings returned are of the format [ALLOWED|DENIED];[USERNAME|GROUPNAME];PERMISSION for example
 | |
|      *         ALLOWED;kevinr;Consumer so can be easily tokenized on the ';' character.
 | |
|      */
 | |
|     public List<String> getDirectPermissions()
 | |
|     {
 | |
|         if (this.directPermissions == null)
 | |
|         {
 | |
|             this.directPermissions = retrieveAllSetPermissions(true, false);
 | |
|         }
 | |
|         return this.directPermissions;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @return List of permissions applied to this Node, including inherited.
 | |
|      *         Strings returned are of the format [ALLOWED|DENIED];[USERNAME|GROUPNAME];PERMISSION;[INHERITED|DIRECT] for example
 | |
|      *         ALLOWED;kevinr;Consumer so can be easily tokenized on the ';' character.
 | |
|      */
 | |
|     public List<String> getFullPermissions()
 | |
|     {
 | |
|         if (this.fullPermissions == null)
 | |
|         {
 | |
|             this.fullPermissions = retrieveAllSetPermissions(false, true);
 | |
|         }
 | |
|         return this.fullPermissions;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Helper to construct the response object for the various getPermissions() calls.
 | |
|      * 
 | |
|      * @param direct    True to only retrieve direct permissions, false to get inherited also
 | |
|      * @param full      True to retrieve full data string with [INHERITED|DIRECT] element
 | |
|      *                  This exists to maintain backward compatibility with existing permission APIs.
 | |
|      * 
 | |
|      * @return List<String> of permissions.
 | |
|      */
 | |
|     private List<String> retrieveAllSetPermissions(boolean direct, boolean full)
 | |
|     {
 | |
|         String userName = this.services.getAuthenticationService().getCurrentUserName();
 | |
|         List<String> permissions = new ArrayList<String>(4);
 | |
|         if (hasPermission(PermissionService.READ_PERMISSIONS))
 | |
|         {
 | |
|             Set<AccessPermission> acls = this.services.getPermissionService().getAllSetPermissions(getNodeRef());
 | |
|             for (AccessPermission permission : acls)
 | |
|             {
 | |
|                 if (!direct || permission.isSetDirectly())
 | |
|                 {
 | |
|                     StringBuilder buf = new StringBuilder(64);
 | |
|                     buf.append(permission.getAccessStatus())
 | |
|                         .append(';')
 | |
|                         .append(permission.getAuthority())
 | |
|                         .append(';')
 | |
|                         .append(permission.getPermission());
 | |
|                     if (full)
 | |
|                     {
 | |
|                         buf.append(';').append(permission.isSetDirectly() ? "DIRECT" : "INHERITED");
 | |
|                     }
 | |
|                     permissions.add(buf.toString());
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         return permissions;
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * @return true if this node inherits permissions from its parent node, false otherwise.
 | |
|      */
 | |
|     public boolean getInheritsPermissions()
 | |
|     {
 | |
|         return this.services.getPermissionService().getInheritParentPermissions(getNodeRef());
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * @param permission        Permission name to test
 | |
|      * 
 | |
|      * @return true if the current user is granted the specified permission on the node
 | |
|      */
 | |
|     public boolean hasPermission(String permission)
 | |
|     {
 | |
|         return (this.services.getPermissionService().hasPermission(getNodeRef(), permission) == AccessStatus.ALLOWED);
 | |
|     }
 | |
| }
 |