alfresco-community-repo/source/java/org/alfresco/repo/domain/DbAccessControlEntryContext.java
Paul Holmes-Higgin cefda8c965 Updated header to LGPL
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18931 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
2010-03-01 22:48:39 +00:00

100 lines
2.6 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.domain;
/**
* Context for permission evaluation
*
* @author andyh
*
*/
public interface DbAccessControlEntryContext
{
/**
* Get the id for this object
* @return
*/
public Long getId();
/**
* Get the version for this object
* @return
*/
public Long getVersion();
/**
* Get the class context.
*
* This is a space separated list of QNames
* with an optional + or minus
*
* +QName => Must be of this type or have the aspect
* -Qname => Must not be of this type or have the aspect
* +QName +QName +QName => Must have all of these types
* -QName -Qname => Must not have any of these types
* QName QName QName => Must have one of the types
* QName => requires exact type match
* QName~ => requires a match on the type or subtype
*
* Supports () for grouping
*
* @return
*/
public String getClassContext();
/**
* Set the class context - as described above
*
* @param classContext
*/
public void setClassContext(String classContext);
/**
* Get the property context
*
* QName QName Qname => property types to which it applies
*
* @return
*/
public String getPropertyContext();
/**
* Get the property context strin as a above
* @param propertyContext
*/
public void setPropertyContext(String propertyContext);
/**
* Get the key value pair context
*
* Serialized Map
*
* @return
*/
public String getKvpContext();
/**
* Get the key value pair context
* @param kvpContext
*/
public void setKvpContext(String kvpContext);
}