public class BasicACLVoter extends java.lang.Object implements ACLVoter
Token,
SecuritySystem,
Details,
Permissions| Modifier and Type | Field and Description |
|---|---|
protected CurrentDetails |
currentUser |
protected PolicyService |
policyService |
protected ome.system.Roles |
roles |
protected SecurityFilter |
securityFilter |
protected SystemTypes |
sysTypes |
protected TokenHolder |
tokenHolder |
| Constructor and Description |
|---|
BasicACLVoter(CurrentDetails cd,
SystemTypes sysTypes,
TokenHolder tokenHolder,
SecurityFilter securityFilter) |
BasicACLVoter(CurrentDetails cd,
SystemTypes sysTypes,
TokenHolder tokenHolder,
SecurityFilter securityFilter,
PolicyService policyService)
Deprecated.
|
BasicACLVoter(CurrentDetails cd,
SystemTypes sysTypes,
TokenHolder tokenHolder,
SecurityFilter securityFilter,
PolicyService policyService,
ome.system.Roles roles) |
BasicACLVoter(CurrentDetails cd,
SystemTypes sysTypes,
TokenHolder tokenHolder,
SecurityFilter securityFilter,
PolicyService policyService,
ome.system.Roles roles,
LightAdminPrivileges adminPrivileges,
SessionProvider sessionProvider,
ReadOnlyStatus readOnly,
java.util.Set<java.lang.String> managedRepoUuids,
java.util.Set<java.lang.String> scriptRepoUuids,
java.lang.String fileRepoSecretKey) |
BasicACLVoter(CurrentDetails cd,
SystemTypes sysTypes,
TokenHolder tokenHolder,
SecurityFilter securityFilter,
PolicyService policyService,
ome.system.Roles roles,
SessionProvider sessionProvider,
ReadOnlyStatus readOnly) |
BasicACLVoter(CurrentDetails cd,
SystemTypes sysTypes,
TokenHolder tokenHolder,
SecurityFilter securityFilter,
SessionProvider sessionProvider,
ReadOnlyStatus readOnly) |
| Modifier and Type | Method and Description |
|---|---|
boolean |
allowAnnotate(ome.model.IObject iObject,
ome.model.internal.Details trustedDetails)
test whether the given object should be annotatable given the trusted
details. |
boolean |
allowChmod(ome.model.IObject iObject)
test whether the given object can have its
Permissions changed within the current
security context. |
boolean |
allowCreation(ome.model.IObject iObject)
test whether the given object should be insertable into the DB.
|
boolean |
allowDelete(ome.model.IObject iObject,
ome.model.internal.Details trustedDetails)
test whether the given object should be deleteable given the trusted
details. |
boolean |
allowLoad(org.hibernate.Session session,
java.lang.Class<? extends ome.model.IObject> klass,
ome.model.internal.Details d,
long id)
delegates to SecurityFilter because that is where the logic is defined
for the
read filter
Ignores the id for the moment. |
boolean |
allowUpdate(ome.model.IObject iObject,
ome.model.internal.Details trustedDetails)
test whether the given object should be updateable given the trusted
details. |
void |
postProcess(ome.model.IObject object)
Gives the
ACLVoter instance a chance to act on the IObject
after the transaction but before finishing the AOP stack. |
java.util.Set<java.lang.String> |
restrictions(ome.model.IObject object)
Provide the active restrictions for this
IObject. |
void |
setPermittedClasses(java.util.Map<java.lang.Integer,java.util.Set<java.lang.Class<? extends ome.model.IObject>>> objectClassesPermitted)
Specify object classes based on restriction constants in
Permissions that do not always have those
restrictions. |
void |
throwCreationViolation(ome.model.IObject iObject)
throws a
SecurityViolation based on the given IObject and
the context of the current user. |
void |
throwDeleteViolation(ome.model.IObject iObject)
throws a
SecurityViolation based on the given IObject and
the context of the current user. |
void |
throwLoadViolation(ome.model.IObject iObject)
throws a
SecurityViolation based on the given IObject and
the context of the current user. |
void |
throwUpdateViolation(ome.model.IObject iObject)
throws a
SecurityViolation based on the given IObject and
the context of the current user. |
protected final CurrentDetails currentUser
protected final SystemTypes sysTypes
protected final TokenHolder tokenHolder
protected final SecurityFilter securityFilter
protected final PolicyService policyService
protected final ome.system.Roles roles
public BasicACLVoter(CurrentDetails cd, SystemTypes sysTypes, TokenHolder tokenHolder, SecurityFilter securityFilter)
public BasicACLVoter(CurrentDetails cd, SystemTypes sysTypes, TokenHolder tokenHolder, SecurityFilter securityFilter, SessionProvider sessionProvider, ReadOnlyStatus readOnly)
@Deprecated public BasicACLVoter(CurrentDetails cd, SystemTypes sysTypes, TokenHolder tokenHolder, SecurityFilter securityFilter, PolicyService policyService)
public BasicACLVoter(CurrentDetails cd, SystemTypes sysTypes, TokenHolder tokenHolder, SecurityFilter securityFilter, PolicyService policyService, ome.system.Roles roles)
public BasicACLVoter(CurrentDetails cd, SystemTypes sysTypes, TokenHolder tokenHolder, SecurityFilter securityFilter, PolicyService policyService, ome.system.Roles roles, SessionProvider sessionProvider, ReadOnlyStatus readOnly)
public BasicACLVoter(CurrentDetails cd, SystemTypes sysTypes, TokenHolder tokenHolder, SecurityFilter securityFilter, PolicyService policyService, ome.system.Roles roles, LightAdminPrivileges adminPrivileges, SessionProvider sessionProvider, ReadOnlyStatus readOnly, java.util.Set<java.lang.String> managedRepoUuids, java.util.Set<java.lang.String> scriptRepoUuids, java.lang.String fileRepoSecretKey)
public boolean allowChmod(ome.model.IObject iObject)
ACLVoterPermissions changed within the current
security context.allowChmod in interface ACLVoteriObject - a model objectpublic boolean allowLoad(org.hibernate.Session session,
java.lang.Class<? extends ome.model.IObject> klass,
ome.model.internal.Details d,
long id)
read filter
Ignores the id for the moment.
Though we pass in whether or not a share is active for completeness, a
different ACLVoter implementation will almost certainly be active
for share use.allowLoad in interface ACLVotersession - the Hibernate session to use for the queryklass - a non-null class to test for loadingd - the non-null trusted details (usually from the db) for this
instanceid - the id of the object which will be loaded. As opposed to the
rest of the object, this must be known.ACLEventListener.onPostLoad(org.hibernate.event.PostLoadEvent)public void throwLoadViolation(ome.model.IObject iObject)
throws ome.conditions.SecurityViolation
ACLVoterSecurityViolation based on the given IObject and
the context of the current user.throwLoadViolation in interface ACLVoteriObject - Non-null object which caused this violationome.conditions.SecurityViolationACLEventListener.onPostLoad(org.hibernate.event.PostLoadEvent)public boolean allowCreation(ome.model.IObject iObject)
ACLVoterdetails is passed to this method, since for
transient entities there are no trusted values.
The SecuritySystem implementors will usually call
ACLVoter.throwCreationViolation(IObject) if this method returns false.allowCreation in interface ACLVoteriObject - a non-null entity to test for creation.ACLEventListener.onPreInsert(org.hibernate.event.PreInsertEvent)public void throwCreationViolation(ome.model.IObject iObject)
throws ome.conditions.SecurityViolation
ACLVoterSecurityViolation based on the given IObject and
the context of the current user.throwCreationViolation in interface ACLVoteriObject - Non-null object which caused this violationome.conditions.SecurityViolationACLEventListener.onPreInsert(org.hibernate.event.PreInsertEvent)public boolean allowAnnotate(ome.model.IObject iObject,
ome.model.internal.Details trustedDetails)
ACLVoterdetails. The details will usually be retrieved from the
current state array coming from the database.allowAnnotate in interface ACLVoteriObject - a non-null entity to test for update.trustedDetails - a Details instance that is known to be valid.public boolean allowUpdate(ome.model.IObject iObject,
ome.model.internal.Details trustedDetails)
ACLVoterdetails. The details will usually be retrieved from the
current state array coming from the database.
The SecuritySystem implementors will usually call
ACLVoter.throwUpdateViolation(IObject) if this method returns false.allowUpdate in interface ACLVoteriObject - a non-null entity to test for update.trustedDetails - a Details instance that is known to be valid.ACLEventListener.onPreUpdate(org.hibernate.event.PreUpdateEvent)public void throwUpdateViolation(ome.model.IObject iObject)
throws ome.conditions.SecurityViolation
ACLVoterSecurityViolation based on the given IObject and
the context of the current user.throwUpdateViolation in interface ACLVoteriObject - Non-null object which caused this violationome.conditions.SecurityViolationACLEventListener.onPreUpdate(org.hibernate.event.PreUpdateEvent)public boolean allowDelete(ome.model.IObject iObject,
ome.model.internal.Details trustedDetails)
ACLVoterdetails. The details will usually be retrieved from the
current state array coming from the database.
The SecuritySystem implementors will usually call
ACLVoter.throwDeleteViolation(IObject) if this method returns false.allowDelete in interface ACLVoteriObject - a non-null entity to test for deletion.trustedDetails - a Details instance that is known to be valid.ACLEventListener.onPreDelete(org.hibernate.event.PreDeleteEvent)public void throwDeleteViolation(ome.model.IObject iObject)
throws ome.conditions.SecurityViolation
ACLVoterSecurityViolation based on the given IObject and
the context of the current user.throwDeleteViolation in interface ACLVoteriObject - Non-null object which caused this violationome.conditions.SecurityViolationACLEventListener.onPreDelete(org.hibernate.event.PreDeleteEvent)public java.util.Set<java.lang.String> restrictions(ome.model.IObject object)
ACLVoterIObject.
See PolicyService for further details.restrictions in interface ACLVoterobject - a model objectpublic void setPermittedClasses(java.util.Map<java.lang.Integer,java.util.Set<java.lang.Class<? extends ome.model.IObject>>> objectClassesPermitted)
ACLVoterPermissions that do not always have those
restrictions.
Previously set classes may not be cleared by subsequent calls to this method.setPermittedClasses in interface ACLVoterobjectClassesPermitted - the map from restriction constants to object classes that may not have those restrictionspublic void postProcess(ome.model.IObject object)
ACLVoterACLVoter instance a chance to act on the IObject
after the transaction but before finishing the AOP stack.postProcess in interface ACLVoterobject - a model object