Class WebRoleRefPermission

java.lang.Object
java.security.Permission
jakarta.security.jacc.WebRoleRefPermission
All Implemented Interfaces:
Serializable, Guard

public final class WebRoleRefPermission extends Permission implements Serializable
Class for Jakarta Servlet isUserInRole (String reference) permissions. A WebRoleRefPermission is a named permission and has actions.

The name of an WebRoleRefPermission (also referred to as the target name) identifies a Web resource by the Jakarta Servlet name (in the deployment descriptor corresponding to the component from which the call to isUserInRole (String reference) is being made.

The actions of an WebRoleRefPermission identifies the role reference to which the permission applies. A WebRoleRefPermission is checked to determine if the subject is a member of the role identified by the reference.

Implementations of this class MAY implement newPermissionCollection or inherit its implementation from the super class.

Author:
Ron Monzillo, Gary Ellison
See Also:
  • Constructor Details

    • WebRoleRefPermission

      public WebRoleRefPermission(String name, String actions)
      Creates a new WebRoleRefPermission with the specified name and actions.

      Parameters:
      name - the servlet-name that identifies the application specific web resource in whose context the role references are to be evaluated.

      actions - identifies the role reference to which the permission pertains. The role reference is scoped to the Web resource identified in the name parameter. The value of the role reference must not be null or the empty string.
  • Method Details

    • equals

      public boolean equals(Object o)
      Checks two WebRoleRefPermission objects for equality. WebRoleRefPermission objects are equivalent if they have case equivalent name and actions values.

      Two Permission objects, P1 and P2, are equivalent if and only if P1.implies(P2) AND P2.implies(P1).

      The name and actions comparisons described above are case sensitive.

      Specified by:
      equals in class Permission
      Parameters:
      o - the WebRoleRefPermission object being tested for equality with this WebRoleRefPermission.
      Returns:
      true if the argument WebRoleRefPermission object is equivalent to this WebRoleRefPermission.
    • getActions

      public String getActions()
      Returns a canonical String representation of the actions of this WebRoleRefPermission.
      Specified by:
      getActions in class Permission
      Returns:
      a String containing the canonicalized actions of this WebRoleRefPermission.
    • hashCode

      public int hashCode()
      Returns the hash code value for this WebRoleRefPermission.

      The properties of the returned hash code must be as follows:

      • During the lifetime of a Java application, the hashCode method must return the same integer value, every time it is called on a WebRoleRefPermission object. The value returned by hashCode for a particular WebRoleRefPermission need not remain consistent from one execution of an application to another.
      • If two WebRoleRefPermission objects are equal according to the equals method, then calling the hashCode method on each of the two Permission objects must produce the same integer result (within an application).
      Specified by:
      hashCode in class Permission
      Returns:
      the integer hash code value for this object.
    • implies

      public boolean implies(Permission permission)
      Determines if the argument Permission is "implied by" this WebRoleRefPermission.

      For this to be the case,

      • The argument must be an instanceof WebRoleRefPermission
      • with name equivalent to this WebRoleRefPermission, and
      • with role reference equivalent to this WebRoleRefPermission (as defined in their actions).

      The comparisons described above are case sensitive.

      Specified by:
      implies in class Permission
      Parameters:
      permission - "this" WebRoleRefPermission is checked to see if it implies the argument permission.
      Returns:
      true if the specified permission is implied by this object, false if not.