1 /* 2 * Copyright (C) 2005 Alfresco, Inc. 3 * 4 * Licensed under the Mozilla Public License version 1.1 5 * with a permitted attribution clause. You may obtain a 6 * copy of the License at 7 * 8 * http://www.alfresco.org/legal/license.txt 9 * 10 * Unless required by applicable law or agreed to in writing, 11 * software distributed under the License is distributed on an 12 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 13 * either express or implied. See the License for the specific 14 * language governing permissions and limitations under the 15 * License. 16 */ 17 package org.alfresco.repo.security.permissions; 18 19 import org.alfresco.service.cmr.repository.NodeRef; 20 21 /** 22 * The interface for a dynamic authority provider e.g. for the owner of a node 23 * or any other authority that is determined by the context rather than just a 24 * node. 25 * 26 * @author Andy Hind 27 */ 28 public interface DynamicAuthority 29 { 30 /** 31 * Is this authority granted to the given user for this node ref? 32 * 33 * @param nodeRef 34 * @param userName 35 * @return 36 */ 37 public boolean hasAuthority(NodeRef nodeRef, String userName); 38 39 /** 40 * If this authority is granted this method provides the string 41 * representation of the granted authority. 42 * 43 * @return 44 */ 45 public String getAuthority(); 46 } 47