Package com.jalios.jcms.policy
Class BasicRightPolicyFilter
- java.lang.Object
- 
- com.jalios.jcms.policy.AbstractPolicyFilter
- 
- com.jalios.jcms.policy.BasicRightPolicyFilter
 
 
- 
- All Implemented Interfaces:
- PluginComponent,- PolicyFilter,- RightPolicyFilter,- java.lang.Comparable
 - Direct Known Subclasses:
- DefaultApplicationRightPolicyFilter,- FileDocumentReferrerRightPolicyFilter,- FormRightPolicyFilter,- ParentReadRightPolicyFilter,- QuotaPolicyFilter,- ShortcutRightPolicyFilter,- TrashRightPolicyFilter,- UnzipRightPolicyFilter
 
 public class BasicRightPolicyFilter extends AbstractPolicyFilter implements RightPolicyFilter, PluginComponent Default implementation of RightPolicyFilter- Since:
- jcms-5.7.0
- Author:
- Jean-Philippe Encausse
- See Also:
- RightPolicyFilter
 
- 
- 
Field Summary- 
Fields inherited from class com.jalios.jcms.policy.AbstractPolicyFilterorder
 - 
Fields inherited from interface com.jalios.jcms.policy.RightPolicyFilterCTXT_CATEGORIES
 
- 
 - 
Constructor SummaryConstructors Constructor Description BasicRightPolicyFilter()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description booleancallCanBeReadBy(PublicationCriteria pubCriteria)booleancallCanBeReadBy(java.lang.Class clazz)This convenient method is a simplfied version ofcallCanBeReadBy(PublicationCriteria).booleancanBeReadBy(boolean isAuthorized, Category cat, Group grp, boolean checkAncestors)Deprecated.since JCMS-8579booleancanBeReadBy(boolean isAuthorized, Category cat, Member mbr, boolean searchInGroups, boolean checkAncestors)booleancanBeReadBy(boolean isAuthorized, Group grp, Member mbr)Called byData.canBeReadBy(Member).booleancanBeReadBy(boolean isAuthorized, Member mbrToRead, Member mbrReading)Checks if a member can read the specified Member.booleancanBeReadBy(boolean isAuthorized, Publication pub, Group grp)Deprecated.since JCMS-8577booleancanBeReadBy(boolean isAuthorized, Publication pub, Member mbr, boolean searchInGroups)Called byPublication.canBeReadBy(Member, boolean).booleancanBeReadBy(boolean isAuthorized, Workspace ws, Member mbr)Checks if a member can read the specified Workspace.booleancanCreateContact(boolean isAuthorized, Member mbr)Check if the given member can create a new contact.booleancanCreateWorkspace(boolean isAuthorized, Member mbr, Workspace model)Check if this member can create workspace : - ex nihilo if model is null; - by copiing model if model is not null.booleancanDeleteOther(boolean isAuthorized, Member mbr, Data data)Check if this member can delete-other this instance.booleancanDeleteOther(boolean isAuthorized, Member mbr, java.lang.Class clazz, Workspace ws)Check if this member can delete-other this clazz in at least one of the given workspace.booleancanManageCategory(boolean isAuthorized, Member mbr, Category cat, boolean searchInGroups, boolean searchInParent)booleancanPublish(boolean isAuthorized, Member mbr, java.lang.Class clazz, java.util.Set wsSet)Check if this member can publish this clazz in at least one of the given workspace.booleancanUpdateOther(boolean isAuthorized, Member mbr, Data data)Check if this member can update-other this instance.booleancanUpdateOther(boolean isAuthorized, Member mbr, java.lang.Class clazz, Workspace ws)Check if this member can update-other this clazz in at least one of the given workspace.booleancanUseCategory(boolean isAuthorized, Member mbr, Category cat, boolean searchInGroups, boolean searchInParent)booleancanWorkOn(boolean isAuthorized, Publication pub, Member member)Called byMember.canWorkOn(Publication).ControllerStatuscanWorkOn(ControllerStatus status, int op, Member mbr, Member member)java.lang.BooleancheckAccess(Member member, java.lang.String resource, java.util.Map<java.lang.String,java.lang.Object> context)ThecheckAccessimplementation of the BasicRightPolicyFilter does not modify the default behavior of the AccessControlManager so ACL will be applied as defined (ie : it returns null).booleancheckAfterUpload(DocUploadInfo info)Checks if the uploaded file must be accepted or rejected.booleancheckBeforeUpload(java.lang.String fieldName, java.lang.String contentType, java.lang.String fileName)Checks if the uploaded file must be accepted or rejected.ControllerStatuscheckHtml(java.lang.String str, java.lang.String field)This method is called to check if the given string does not contain forbidden HTML codejava.util.Set<Workspace>getWorkspaceSet(java.util.Set<Workspace> workspaceSet, Member mbr)Retrieve the workspace set of the specified Member.booleaninit(Plugin plugin)Initialize the component with the given plugin configurationbooleanisAdmin(boolean isAdmin, Member member, Workspace ws)Called byWorkspace.isAdmin(Member).booleanisWorker(boolean isWorker, Member member, Workspace ws)Called byMember.isWorker(Workspace)andMember.isWorker().- 
Methods inherited from class com.jalios.jcms.policy.AbstractPolicyFiltercompareTo, equals, getOrder, setOrder
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface com.jalios.jcms.policy.RightPolicyFiltergetOrder
 
- 
 
- 
- 
- 
Method Detail- 
initpublic boolean init(Plugin plugin) Description copied from interface:PluginComponentInitialize the component with the given plugin configuration- Specified by:
- initin interface- PluginComponent
- Parameters:
- plugin- the calling plugin
- Returns:
- true if the component has been correctly initialized.
- Since:
- jcms-5.7.1
- See Also:
- PluginComponent.init(Plugin)
 
 - 
canUpdateOtherpublic boolean canUpdateOther(boolean isAuthorized, Member mbr, Data data)Description copied from interface:RightPolicyFilterCheck if this member can update-other this instance. This method is called byMember.canUpdateOther(Data)- Specified by:
- canUpdateOtherin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- data- the data to check
- Returns:
- true it the given member can update given instances
- See Also:
- RightPolicyFilter.canUpdateOther(boolean, Member, Data)
 
 - 
canDeleteOtherpublic boolean canDeleteOther(boolean isAuthorized, Member mbr, Data data)Description copied from interface:RightPolicyFilterCheck if this member can delete-other this instance. This method is called byMember.canDeleteOther(Data)- Specified by:
- canDeleteOtherin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- data- the data to check
- Returns:
- true it the given member can delete given instances
- See Also:
- RightPolicyFilter.canDeleteOther(boolean, Member, Data)
 
 - 
callCanBeReadBypublic boolean callCanBeReadBy(PublicationCriteria pubCriteria) Description copied from interface:RightPolicyFilterCall byHibernateUtil.queryPublication(PublicationCriteria). It checks if the methodRightPolicyFilter.canBeReadBy(boolean, Publication, Member, boolean)must be called on the results of the query.- Specified by:
- callCanBeReadByin interface- RightPolicyFilter
- Parameters:
- pubCriteria- the criteria of the query.
- Returns:
- true if method RightPolicyFilter.canBeReadBy(boolean, Publication, Member, boolean)must be called.
- See Also:
- RightPolicyFilter.callCanBeReadBy(PublicationCriteria)
 
 - 
callCanBeReadBypublic boolean callCanBeReadBy(java.lang.Class clazz) This convenient method is a simplfied version ofcallCanBeReadBy(PublicationCriteria).- Parameters:
- clazz- the class to check (never null)
- Returns:
- true if the method canBeReadBy(boolean, Publication, Member, boolean)must be called for the given class.
- Since:
- jcms-7.0.0
 
 - 
canBeReadBypublic boolean canBeReadBy(boolean isAuthorized, Publication pub, Member mbr, boolean searchInGroups)Description copied from interface:RightPolicyFilterCalled byPublication.canBeReadBy(Member, boolean). It checks if a member can read the given publication. WARNING: HIGHLY SENSIBLE, do not modify without being sure of what you do, can dramatically impact performance and can break existing rights behaviour.- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- pub- the publication to check
- mbr- the member to check
- searchInGroups- if true check if one of the group this member belongs to is authorized to read this publication.
- Returns:
- true if the member can read this publication
- See Also:
- RightPolicyFilter.canBeReadBy(boolean, Publication, Member, boolean)
 
 - 
canBeReadBy@Deprecated public boolean canBeReadBy(boolean isAuthorized, Publication pub, Group grp)Deprecated.since JCMS-8577Description copied from interface:RightPolicyFilterCalled byPublication.canBeReadBy(Group). It checks if a group can read this publication.- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- pub- the publication to check
- grp- the group to check
- Returns:
- true if the group can read this publication
- See Also:
- RightPolicyFilter.canBeReadBy(boolean, Publication, Group)
 
 - 
canWorkOnpublic boolean canWorkOn(boolean isAuthorized, Publication pub, Member member)Description copied from interface:RightPolicyFilterCalled byMember.canWorkOn(Publication). It checks if the given member can work on the given publication (ie, if it has the rights and if it is in a state the member can work in).- Specified by:
- canWorkOnin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- pub- the publication to check
- member- the member to check
- Returns:
- true if the member can work on the publication
- See Also:
- RightPolicyFilter.canWorkOn(boolean, Publication, Member)
 
 - 
canWorkOnpublic ControllerStatus canWorkOn(ControllerStatus status, int op, Member mbr, Member member) Description copied from interface:RightPolicyFilterCalled byMember.checkMember(int, Member, java.util.Map). It checks if the given member can work on the given member.- Specified by:
- canWorkOnin interface- RightPolicyFilter
- Parameters:
- status- the internal JCMS controller status.
- op- the operation (OP_CREATE, OP_UPDATE, OP_DELETE)
- mbr- the member to work on
- member- the member to check
- Returns:
- true if the member can work on the other member
- See Also:
- RightPolicyFilter.canWorkOn(ControllerStatus, int, Member, Member)
 
 - 
isWorkerpublic boolean isWorker(boolean isWorker, Member member, Workspace ws)Description copied from interface:RightPolicyFilterCalled byMember.isWorker(Workspace)andMember.isWorker(). It checks if the given Member is a Worker for the site or the given workspace- Specified by:
- isWorkerin interface- RightPolicyFilter
- Parameters:
- isWorker- true if internal JCMS control authorized the member to perform this action
- member- the member to check
- ws- the workspace to check or null if caller is- Member.isWorker()
- Returns:
- true if given Member is a Worker
- See Also:
- RightPolicyFilter.isWorker(boolean, Member, Workspace)
 
 - 
canPublishpublic boolean canPublish(boolean isAuthorized, Member mbr, java.lang.Class clazz, java.util.Set wsSet)Description copied from interface:RightPolicyFilterCheck if this member can publish this clazz in at least one of the given workspace. This method is called byMember.canPublish(Class, Set)- Specified by:
- canPublishin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- clazz- the class to check
- wsSet- the Set of workspace to work with
- Returns:
- true it the given member can publish the given class
- See Also:
- RightPolicyFilter.canPublish(boolean, Member, Class, Set)
 
 - 
canUpdateOtherpublic boolean canUpdateOther(boolean isAuthorized, Member mbr, java.lang.Class clazz, Workspace ws)Description copied from interface:RightPolicyFilterCheck if this member can update-other this clazz in at least one of the given workspace. This method is called byMember.canUpdateOther(Class, Workspace)- Specified by:
- canUpdateOtherin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- clazz- the class to check
- ws- the Workspace to check
- Returns:
- true it the given member can update instances of the given class
- See Also:
- RightPolicyFilter.canUpdateOther(boolean, Member, Class, Workspace)
 
 - 
canDeleteOtherpublic boolean canDeleteOther(boolean isAuthorized, Member mbr, java.lang.Class clazz, Workspace ws)Description copied from interface:RightPolicyFilterCheck if this member can delete-other this clazz in at least one of the given workspace. This method is called byMember.canDeleteOther(Class, Workspace)- Specified by:
- canDeleteOtherin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- clazz- the class to check
- ws- the Workspace to check
- Returns:
- true it the given member can delete instances of the given class
- See Also:
- RightPolicyFilter.canDeleteOther(boolean, Member, Class, Workspace)
 
 - 
canBeReadBypublic boolean canBeReadBy(boolean isAuthorized, Category cat, Member mbr, boolean searchInGroups, boolean checkAncestors)Description copied from interface:RightPolicyFilterCalled byCategory.canBeReadBy(Member, boolean, boolean). It checks if a member can read the given category.- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- cat- the category to check
- mbr- the member to check
- searchInGroups- if true check if one of the group this member belongs to is authorized to read this category.
- checkAncestors- if true checks the read rights of the ancestors of this category.
- Returns:
- true if the member can read this category
- See Also:
- RightPolicyFilter.canBeReadBy(boolean, Category, Member, boolean, boolean)
 
 - 
canBeReadBy@Deprecated public boolean canBeReadBy(boolean isAuthorized, Category cat, Group grp, boolean checkAncestors)Deprecated.since JCMS-8579Description copied from interface:RightPolicyFilterCalled byCategory.canBeReadBy(Group, boolean). It checks if a group can read this category.- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- cat- the category to check
- grp- the group to check
- checkAncestors- if true checks the read rights of the ancestors of this category.
- Returns:
- true if the group can read this category
- See Also:
- RightPolicyFilter.canBeReadBy(boolean, Category, Group, boolean)
 
 - 
canUseCategorypublic boolean canUseCategory(boolean isAuthorized, Member mbr, Category cat, boolean searchInGroups, boolean searchInParent)Description copied from interface:RightPolicyFilterCalled byMember.canUseCategory(Category, boolean, boolean). It check if a category can be used by given Member. Note In current implementation:- Always true for admin
- Not called if can not read category
 - Specified by:
- canUseCategoryin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- cat- the category to check
- searchInGroups- if true check if one of the group this
- searchInParent- if true check in parent category
- Returns:
- true if the member can use (check) this category
- Since:
- jcms-5.7.1
- See Also:
- RightPolicyFilter.canUseCategory(boolean, Member, Category, boolean, boolean)
 
 - 
canManageCategorypublic boolean canManageCategory(boolean isAuthorized, Member mbr, Category cat, boolean searchInGroups, boolean searchInParent)Description copied from interface:RightPolicyFilterCalled byMember.canManageCategory(Category, boolean, boolean). It check if a category can be managed by given Member- Specified by:
- canManageCategoryin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- cat- the category to check
- searchInGroups- if true check if one of the group this
- searchInParent- if true check in parent category
- Returns:
- true if the member can manage (edit/update) this category branch
- Since:
- jcms-5.7.1
- See Also:
- RightPolicyFilter.canManageCategory(boolean, Member, Category, boolean, boolean)
 
 - 
canCreateWorkspacepublic boolean canCreateWorkspace(boolean isAuthorized, Member mbr, Workspace model)Description copied from interface:RightPolicyFilterCheck if this member can create workspace : - ex nihilo if model is null; - by copiing model if model is not null. This method is called byMember.canCreateWorkspace(Workspace)- Specified by:
- canCreateWorkspacein interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- model- the workspace to duplicate or null if the workspace has to be created ex nihilo
- Returns:
- true if a workspace can be created by member false otherwise.
- Since:
- jcms-5.7.3
- See Also:
- RightPolicyFilter.canCreateWorkspace(boolean, Member, Workspace)
 
 - 
getWorkspaceSetpublic java.util.Set<Workspace> getWorkspaceSet(java.util.Set<Workspace> workspaceSet, Member mbr) Description copied from interface:RightPolicyFilterRetrieve the workspace set of the specified Member.This method is called by Member.getWorkspaceSet().
 You MUST NOT (and cannot) modify the workspaceSet received in parameters, create a new TreeSet of workspace and return it.- Specified by:
- getWorkspaceSetin interface- RightPolicyFilter
- Parameters:
- workspaceSet- the workspace set computed by internal JCMS routine
- mbr- the member for which the workspace set is computed
- Returns:
- the new workspace set to use
- Since:
- jcms-7.0.2
- See Also:
- RightPolicyFilter.getWorkspaceSet(Set, Member)
 
 - 
isAdminpublic boolean isAdmin(boolean isAdmin, Member member, Workspace ws)Description copied from interface:RightPolicyFilterCalled byWorkspace.isAdmin(Member). It checks if the given Member is an administrator for the specified workspace.If you change the default behavior for a Member, you should also implement get RightPolicyFilter.getWorkspaceSet(Set, Member)(see issue JCMS-2601 for a implementation example).- Specified by:
- isAdminin interface- RightPolicyFilter
- Parameters:
- isAdmin- true if internal JCMS control found member as admin of workspace
- member- the member to check
- ws- the workspace to check, never null
- Returns:
- true if given Member is an admin
- Since:
- jcms-7.1 jcms-7.0.4
- See Also:
- RightPolicyFilter.isAdmin(boolean, Member, Workspace)
 
 - 
canCreateContactpublic boolean canCreateContact(boolean isAuthorized, Member mbr)Description copied from interface:RightPolicyFilterCheck if the given member can create a new contact.- Specified by:
- canCreateContactin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbr- the member to check
- Returns:
- true if the given member can create a new contact.
 
 - 
canBeReadBypublic boolean canBeReadBy(boolean isAuthorized, Group grp, Member mbr)Description copied from interface:RightPolicyFilterCalled byData.canBeReadBy(Member). It checks if a member can read this group.- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- grp- the group
- mbr- the member
- Returns:
- true if the member can read this group
 
 - 
canBeReadBypublic boolean canBeReadBy(boolean isAuthorized, Member mbrToRead, Member mbrReading)Description copied from interface:RightPolicyFilterChecks if a member can read the specified Member.Invoked by internal implementation of Data.canBeReadBy(Member).- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- mbrToRead- the Member that would be read
- mbrReading- the Member performing the read operation
- Returns:
- true if the member can read the Member, false otherwise
 
 - 
canBeReadBypublic boolean canBeReadBy(boolean isAuthorized, Workspace ws, Member mbr)Description copied from interface:RightPolicyFilterChecks if a member can read the specified Workspace.Invoked by internal implementation of Data.canBeReadBy(Member).- Specified by:
- canBeReadByin interface- RightPolicyFilter
- Parameters:
- isAuthorized- true if internal JCMS control authorized the member to perform this action
- ws- the Workspace that would be read
- mbr- the Member performing the read operation
- Returns:
- true if the member can read the Workspace, false otherwise
 
 - 
checkBeforeUploadpublic boolean checkBeforeUpload(java.lang.String fieldName, java.lang.String contentType, java.lang.String fileName)Description copied from interface:RightPolicyFilterChecks if the uploaded file must be accepted or rejected. This method is called by sub classes of MultiPartFilter AFTER InitFilter BUT BEFORE doInitPage.jsp. The file has not been uploaded. The JcmsContext returned by Channel.getCurrentJcmsContext() is not completly initialized.- Specified by:
- checkBeforeUploadin interface- RightPolicyFilter
- Parameters:
- fieldName- the name of the field for the given file
- contentType- the content type of the file
- fileName- the name of the file
- Returns:
- true if the file is accepted
- See Also:
- RightPolicyFilter.checkBeforeUpload(String, String, String)
 
 - 
checkAfterUploadpublic boolean checkAfterUpload(DocUploadInfo info) Description copied from interface:RightPolicyFilterChecks if the uploaded file must be accepted or rejected. This method is called by DocUploadInfo.doUpload() called by DocUploadHandler and EditDataHandler for MultiPartRequest BEFORE JavaBean validation. The method Channel.getCurrentJcmsContext() must be called to get more information about Member and Workspace.A DataController must be used to check Document during validation.- Specified by:
- checkAfterUploadin interface- RightPolicyFilter
- Parameters:
- info- information about the uploaded file
- Returns:
- true if the file is accepted
- See Also:
- RightPolicyFilter.checkAfterUpload(DocUploadInfo)
 
 - 
checkHtmlpublic ControllerStatus checkHtml(java.lang.String str, java.lang.String field) Description copied from interface:RightPolicyFilterThis method is called to check if the given string does not contain forbidden HTML code- Specified by:
- checkHtmlin interface- RightPolicyFilter
- Parameters:
- str- the String to be checked
- field- the name of the field which is checked
- Returns:
- a ControllerStatus
- See Also:
- RightPolicyFilter.checkHtml(String, String)
 
 - 
checkAccesspublic java.lang.Boolean checkAccess(Member member, java.lang.String resource, java.util.Map<java.lang.String,java.lang.Object> context) ThecheckAccessimplementation of the BasicRightPolicyFilter does not modify the default behavior of the AccessControlManager so ACL will be applied as defined (ie : it returns null).- Specified by:
- checkAccessin interface- RightPolicyFilter
- Parameters:
- member- the Member for which access right is verified
- resource- a resource URI using a path representation, eg "admin/dev/store-cleaner"
- context- an optional context map containing relevant information such as workspace or data
- Returns:
- null if you don't want to interfer with default behavior, true to grant authorization, false to deny authorization
- See Also:
- RightPolicyFilter.checkAccess(Member, String, Map)
 
 
- 
 
-