Class GroupPermission
- All Implemented Interfaces:
- java.io.Serializable,- java.security.Guard
public final class GroupPermission extends java.security.Permission implements java.io.Serializable
 Permission to perform an operation on a group in a given wiki. Permission
 actions include: view, edit, delete.
 
The target of a permission is a single group or collection in a given wiki. The syntax for the target is the wiki name, followed by a colon (:) and the name of the group. “All wikis” can be specified using a wildcard (*). Group collections may also be specified using a wildcard. For groups, the wildcard may be a prefix, suffix, or all by itself. Examples of targets include:
*:*
 *:TestPlanners
 *:*Planners
 *:Test*
 mywiki:TestPlanners
 mywiki:*Planners
 mywiki:Test*
 For a given target, certain permissions imply others:
- editimplies- view
- deleteimplies- editand- view
Targets that do not include a wiki prefix never imply others.
 GroupPermission accepts a special target called
 <groupmember> that means “all groups that a user is a
 member of.” When included in a policy file grant block, it
 functions like a wildcard. Thus, this block:
 
  grant signedBy "jspwiki",
    principal org.apache.wiki.auth.authorize.Role "Authenticated" {
      permission org.apache.wiki.auth.permissions.GroupPermission "*:<groupmember>", "edit";
 
 means, “allow Authenticated users to edit any groups they are members of.”
 The wildcard target (*) does not imply <groupmember>; it
 must be granted explicitly.- Since:
- 2.4.17
- See Also:
- Serialized Form
- 
Field SummaryFields Modifier and Type Field Description static GroupPermissionDELETEConvenience constant that denotesGroupPermission( "*:*, "delete" ).static java.lang.StringDELETE_ACTIONAction for deleting a group or collection of groups.protected static intDELETE_MASKstatic GroupPermissionEDITConvenience constant that denotesGroupPermission( "*:*, "edit" ).static java.lang.StringEDIT_ACTIONAction for editing a group or collection of groups.protected static intEDIT_MASKstatic java.lang.StringMEMBER_TOKENSpecial target token that denotes all groups that a Subject's Principals are members of.static GroupPermissionVIEWConvenience constant that denotesGroupPermission( "*:*, "view" ).static java.lang.StringVIEW_ACTIONAction for viewing a group or collection of groups.protected static intVIEW_MASK
- 
Constructor SummaryConstructors Modifier Constructor Description protectedGroupPermission()For serialization purposesGroupPermission(java.lang.String group, java.lang.String actions)Creates a new GroupPermission for a specified group and set of actions.
- 
Method SummaryModifier and Type Method Description protected static intcreateMask(java.lang.String actions)Protected method that creates a binary mask based on the actions specified.booleanequals(java.lang.Object obj)Two PagePermission objects are considered equal if their actions (after normalization), wiki and target are equal.java.lang.StringgetActions()Returns the actions for this permission: “view”, “edit”, or “delete”.java.lang.StringgetGroup()Returns the name of the wiki group represented by this permission.java.lang.StringgetWiki()Returns the name of the wiki containing the group represented by this permission; may return the wildcard string.inthashCode()Returns the hash code for this GroupPermission.protected static intimpliedMask(int mask)Creates an “implied mask” based on the actions originally assigned: for example, delete implies edit; edit implies view.booleanimplies(java.security.Permission permission)GroupPermissions can only imply other GroupPermissions; no other permission types are implied.protected booleanimpliesMember(java.security.Permission permission)Returnstrueif this GroupPermission was created with the token<groupmember>and the current thread’s Subject is a member of the Group indicated by the implied GroupPermission.java.lang.StringtoString()Prints a human-readable representation of this permission.Methods inherited from class java.security.PermissioncheckGuard, getName, newPermissionCollectionMethods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
- 
Field Details- 
MEMBER_TOKENSpecial target token that denotes all groups that a Subject's Principals are members of.- See Also:
- Constant Field Values
 
- 
DELETE_ACTIONAction for deleting a group or collection of groups.- See Also:
- Constant Field Values
 
- 
EDIT_ACTIONAction for editing a group or collection of groups.- See Also:
- Constant Field Values
 
- 
VIEW_ACTIONAction for viewing a group or collection of groups.- See Also:
- Constant Field Values
 
- 
DELETE_MASK- See Also:
- Constant Field Values
 
- 
EDIT_MASK- See Also:
- Constant Field Values
 
- 
VIEW_MASK- See Also:
- Constant Field Values
 
- 
DELETEConvenience constant that denotesGroupPermission( "*:*, "delete" ).
- 
EDITConvenience constant that denotesGroupPermission( "*:*, "edit" ).
- 
VIEWConvenience constant that denotesGroupPermission( "*:*, "view" ).
 
- 
- 
Constructor Details- 
GroupPermissionprotected GroupPermission()For serialization purposes
- 
GroupPermissionCreates a new GroupPermission for a specified group and set of actions. Group should include a prepended wiki name followed by a colon (:). If the wiki name is not supplied or starts with a colon, the group refers to all wikis.- Parameters:
- group- the wiki group
- actions- the allowed actions for this group
 
 
- 
- 
Method Details- 
equalsTwo PagePermission objects are considered equal if their actions (after normalization), wiki and target are equal.- Specified by:
- equalsin class- java.security.Permission
- Parameters:
- obj- the object to compare
- Returns:
- the result of the comparison
- See Also:
- Object.equals(java.lang.Object)
 
- 
getActionsReturns the actions for this permission: “view”, “edit”, or “delete”. The actions will always be sorted in alphabetic order, and will always appear in lower case.- Specified by:
- getActionsin class- java.security.Permission
- Returns:
- the actions
- See Also:
- Permission.getActions()
 
- 
getGroupReturns the name of the wiki group represented by this permission.- Returns:
- the page name
 
- 
getWikiReturns the name of the wiki containing the group represented by this permission; may return the wildcard string.- Returns:
- the wiki
 
- 
hashCodeReturns the hash code for this GroupPermission.- Specified by:
- hashCodein class- java.security.Permission
- Returns:
- the hash code
- See Also:
- Object.hashCode()
 
- 
impliesGroupPermissions can only imply other GroupPermissions; no other permission types are implied. One GroupPermission implies another if its actions if three conditions are met: - The other GroupPermission’s wiki is equal to, or a subset of, that of this permission. This permission’s wiki is considered a superset of the other if it contains a matching prefix plus a wildcard, or a wildcard followed by a matching suffix.
- The other GroupPermission’s target is equal to, or a subset of, the target specified by this permission. This permission’s target is considered a superset of the other if it contains a matching prefix plus a wildcard, or a wildcard followed by a matching suffix.
- All of other GroupPermission’s actions are equal to, or a subset of, those of this permission
 - Specified by:
- impliesin class- java.security.Permission
- Parameters:
- permission- the Permission to examine
- Returns:
- trueif the GroupPermission implies the supplied Permission;- falseotherwise
- See Also:
- Permission.implies(java.security.Permission)
 
- 
toStringPrints a human-readable representation of this permission.- Overrides:
- toStringin class- java.security.Permission
- Returns:
- the string
- See Also:
- Object.toString()
 
- 
impliedMaskCreates an “implied mask” based on the actions originally assigned: for example, delete implies edit; edit implies view.- Parameters:
- mask- binary mask for actions
- Returns:
- binary mask for implied actions
 
- 
createMaskProtected method that creates a binary mask based on the actions specified. This is used byimplies(Permission).- Parameters:
- actions- the actions for this permission, separated by commas
- Returns:
- the binary actions mask
 
- 
impliesMemberReturns trueif this GroupPermission was created with the token<groupmember>and the current thread’s Subject is a member of the Group indicated by the implied GroupPermission. Thus, a GroupPermission with the group<groupmember>implies GroupPermission for group "TestGroup" only if the Subject is a member of TestGroup.We make this determination by obtaining the current Thread’sAccessControlContextand requesting theSubjectDomainCombiner. If the combiner is notnull, then we know that the access check was requested using aSubject; that is, that an upstream caller caused a Subject to be associated with the Thread’s ProtectionDomain by executing aSubject.doAs(Subject, java.security.PrivilegedAction)operation.If a SubjectDomainCombiner exists, determining group membership is simple: just iterate through the Subject’s Principal set and look for all Principals of type GroupPrincipal. If the name of any Principal matches the value of the implied Permission’sgetGroup()value, then the Subject is a member of this group -- and therefore thisimpliesMembercall returnstrue.This may sound complicated, but it really isn’t. Consider the following examples: This object impliesMemberparameterCalling Subject’s Principals Result GroupPermission ("<groupmember>")GroupPermission ("*:TestGroup")WikiPrincipal ("Biff"),
 GroupPrincipal ("TestGroup")trueGroupPermission ("*:TestGroup")GroupPermission ("*:TestGroup")WikiPrincipal ("Biff"),
 GroupPrincipal ("TestGroup")false- this object does not contain<groupmember>GroupPermission ("<groupmember>")GroupPermission ("*:TestGroup")WikiPrincipal ("Biff"),
 GroupPrincipal ("FooGroup")false- Subject does not contain GroupPrincipal matching implied Permission’s group (TestGroup)GroupPermission ("<groupmember>")WikiPermission ("*:createGroups")WikiPrincipal ("Biff"),
 GroupPrincipal ("TestGroup")false- implied permission not of type GroupPermissionGroupPermission ("<groupmember>")GroupPermission ("*:TestGroup")- false-Subject.doAs()not called upstreamNote that JSPWiki’s access control checks are made inside of AuthorizationManager.checkPermission(org.apache.wiki.WikiSession, Permission), which performs aSubject.doAs()call. Thus, this Permission functions exactly the way it should during normal operations.- Parameters:
- permission- the implied permission
- Returns:
- trueif the calling Thread’s Subject contains a GroupPrincipal matching the implied GroupPermission’s group;- falseotherwise
 
 
-