public class CachingNamingResolver extends NamingResolverDecorator
NamingResolver.
| Modifier and Type | Field and Description |
|---|---|
static String |
CACHE_HASPRIV |
| Constructor and Description |
|---|
CachingNamingResolver(NamingResolver resolver) |
| Modifier and Type | Method and Description |
|---|---|
void |
flushCache()
flush cache if caching resolver
|
GrouperSession |
getGrouperSession()
get a reference to the session
|
CacheStats |
getStats(String cache) |
void |
grantPrivilege(Stem stem,
Subject subject,
Privilege privilege,
String uuid)
Grant privilege to subject on group.
|
boolean |
hasPrivilege(Stem stem,
Subject subject,
Privilege privilege)
Check whether subject has privilege on group.
|
boolean |
hqlFilterStemsNotWithPrivWhereClause(Subject subject,
HqlQuery hqlQuery,
StringBuilder hql,
String stemColumn,
Privilege privilege,
boolean considerAllSubject)
for a stem query, check to make sure the subject doesnt have privs
|
Set<Stem> |
postHqlFilterStems(Set<Stem> stems,
Subject subject,
Set<Privilege> privInSet)
after HQL is run, filter stems.
|
void |
privilegeCopy(Stem stem1,
Stem stem2,
Privilege priv)
Copies privileges for subjects that have the specified privilege on stem1 to stem2.
|
void |
privilegeCopy(Subject subj1,
Subject subj2,
Privilege priv)
Copies privileges of type priv on any subject for the given Subject subj1 to the given Subject subj2.
|
void |
revokeAllPrivilegesForSubject(Subject subject)
Revoke all naming privileges that this subject has.
|
void |
revokePrivilege(Stem stem,
Privilege privilege)
Revoke privilege from all subjects on group.
|
void |
revokePrivilege(Stem stem,
Subject subject,
Privilege privilege)
Revoke privilege from subject on group.
|
void |
stop()
clean up resources, session is stopped
|
getDecoratedResolver, getPrivileges, getStemsWhereSubjectDoesHavePrivilege, getStemsWhereSubjectDoesntHavePrivilege, getStemsWhereSubjectHasPrivilege, getSubjectsWithPrivilege, hqlFilterStemsWhereClause, hqlFilterStemsWithPrivWhereClausepublic static final String CACHE_HASPRIV
public CachingNamingResolver(NamingResolver resolver)
resolver - public void flushCache()
NamingResolverflushCache in interface NamingResolverflushCache in class NamingResolverDecoratorNamingResolver.flushCache()public GrouperSession getGrouperSession()
NamingResolvergetGrouperSession in interface NamingResolvergetGrouperSession in class NamingResolverDecoratorNamingResolver.getGrouperSession()public CacheStats getStats(String cache)
cache - public void grantPrivilege(Stem stem, Subject subject, Privilege privilege, String uuid) throws IllegalArgumentException, UnableToPerformException
NamingResolvergrantPrivilege in interface NamingResolvergrantPrivilege in class NamingResolverDecoratoruuid - if known or nullIllegalArgumentException - if any parameter is null.UnableToPerformException - if the privilege could not be granted.NamingResolver.grantPrivilege(Stem, Subject, Privilege, String)public boolean hasPrivilege(Stem stem, Subject subject, Privilege privilege) throws IllegalArgumentException
NamingResolverhasPrivilege in interface NamingResolverhasPrivilege in class NamingResolverDecoratorIllegalArgumentException - if any parameter is null.NamingResolver.hasPrivilege(Stem, Subject, Privilege)public void revokePrivilege(Stem stem, Privilege privilege) throws IllegalArgumentException, UnableToPerformException
NamingResolverrevokePrivilege in interface NamingResolverrevokePrivilege in class NamingResolverDecoratorIllegalArgumentException - if any parameter is null.UnableToPerformException - if the privilege could not be revoked.NamingResolver.revokePrivilege(Stem, Privilege)public void revokePrivilege(Stem stem, Subject subject, Privilege privilege) throws IllegalArgumentException, UnableToPerformException
NamingResolverrevokePrivilege in interface NamingResolverrevokePrivilege in class NamingResolverDecoratorIllegalArgumentException - if any parameter is null.UnableToPerformException - if the privilege could not be revoked.NamingResolver.revokePrivilege(Stem, Subject, Privilege)public void privilegeCopy(Stem stem1, Stem stem2, Privilege priv) throws IllegalArgumentException, UnableToPerformException
NamingResolverprivilegeCopy in interface NamingResolverprivilegeCopy in class NamingResolverDecoratorIllegalArgumentExceptionUnableToPerformExceptionNamingResolver.privilegeCopy(edu.internet2.middleware.grouper.Stem, edu.internet2.middleware.grouper.Stem, edu.internet2.middleware.grouper.privs.Privilege)public void privilegeCopy(Subject subj1, Subject subj2, Privilege priv) throws IllegalArgumentException, UnableToPerformException
NamingResolverprivilegeCopy in interface NamingResolverprivilegeCopy in class NamingResolverDecoratorIllegalArgumentExceptionUnableToPerformExceptionNamingResolver.privilegeCopy(edu.internet2.middleware.subject.Subject, edu.internet2.middleware.subject.Subject, edu.internet2.middleware.grouper.privs.Privilege)public Set<Stem> postHqlFilterStems(Set<Stem> stems, Subject subject, Set<Privilege> privInSet)
NamingResolverpostHqlFilterStems in interface NamingResolverpostHqlFilterStems in class NamingResolverDecoratorsubject - which needs view access to the groupsprivInSet - find a privilege which is in this set
(e.g. for view, send all access privs). There are pre-canned sets in NamingPrivilegeNamingResolver.postHqlFilterStems(java.util.Set, edu.internet2.middleware.subject.Subject, java.util.Set)public void stop()
NamingResolverstop in interface NamingResolverstop in class NamingResolverDecoratorNamingResolver.stop()public void revokeAllPrivilegesForSubject(Subject subject)
NamingResolverrevokeAllPrivilegesForSubject in interface NamingResolverrevokeAllPrivilegesForSubject in class NamingResolverDecoratorNamingResolver.revokeAllPrivilegesForSubject(edu.internet2.middleware.subject.Subject)public boolean hqlFilterStemsNotWithPrivWhereClause(Subject subject, HqlQuery hqlQuery, StringBuilder hql, String stemColumn, Privilege privilege, boolean considerAllSubject)
NamingResolverhqlFilterStemsNotWithPrivWhereClause in interface NamingResolverhqlFilterStemsNotWithPrivWhereClause in class NamingResolverDecoratorsubject - which needs view access to the groupshql - the select and current from partstemColumn - is the name of the group column to join toprivilege - find a privilege which is in this set (e.g. stem or create)considerAllSubject - if true, then consider GrouperAll when seeign if subject has priv, else do notedu.internet2.middleware.grouper.privs.NamingResolver#hqlFilterStemsNotWithPrivWhereClause(edu.internet2.middleware.subject.Subject, edu.internet2.middleware.grouper.hibernate.HqlQuery, java.lang.StringBuilder, java.lang.String, Privilege)Copyright © 2016 Internet2. All rights reserved.