public final class WebResourcePermission extends Permission implements Serializable
Class for Servlet web resource permissions. A WebResourcePermission
is a named permission and has actions.
The name of a WebResourcePermission
(also referred to as the target name) identifies the Web resources to
which the permission pertains.
Implementations of this class MAY implement newPermissionCollection
or inherit its implementation from the
super class.
Permission
,
Serialized FormConstructor and Description |
---|
WebResourcePermission(HttpServletRequest request)
Creates a new WebResourcePermission from the HttpServletRequest object.
|
WebResourcePermission(String name,
String actions)
Creates a new WebResourcePermission with the specified name and actions.
|
WebResourcePermission(String urlPatternSpec,
String[] httpMethods)
Creates a new WebResourcePermission with name corresponding to the URLPatternSpec, and actions composed from the
array of HTTP methods.
|
Modifier and Type | Method and Description |
---|---|
boolean |
equals(Object p)
Checks two WebResourcePermission objects for equality.
|
String |
getActions()
Returns a canonical String representation of the actions of this WebResourcePermission.
|
int |
hashCode()
Returns the hash code value for this WebResourcePermission.
|
boolean |
implies(Permission permission)
Determines if the argument Permission is "implied by" this WebResourcePermission.
|
checkGuard, getName, newPermissionCollection, toString
public WebResourcePermission(HttpServletRequest request)
Creates a new WebResourcePermission from the HttpServletRequest object.
request
- - the HttpServletRequest
object corresponding to the Servlet operation to which the permission
pertains. The permission name is the substring of the requestURI (HttpServletRequest.getRequestURI()
) that begins after the contextPath (HttpServletRequest.getContextPath()
). When the substring operation yields the string “/”, the
permission is constructed with the empty string as its name. The permission’s actions field is obtained
from HttpServletRequest.getMethod()
. The constructor must transform all colon characters
occurring in the name to escaped encoding as defined in RFC 2396.public WebResourcePermission(String name, String actions)
Creates a new WebResourcePermission with the specified name and actions.
The name contains a URLPatternSpec that identifies the web resources to which the permissions applies. The syntax of a URLPatternSpec is as follows:
URLPatternList ::= URLPattern | URLPatternList colon URLPattern URLPatternSpec ::= null | URLPattern | URLPattern colon URLPatternList
A null URLPatternSpec is translated to the default URLPattern, "/", by the permission constructor. The empty string is an exact URLPattern, and may occur anywhere in a URLPatternSpec that an exact URLPattern may occur. The first URLPattern in a URLPatternSpec may be any of the pattern types, exact, path-prefix, extension, or default as defined in the Java Servlet Specification). When a URLPatternSpec includes a URLPatternList, the patterns of the URLPatternList identify the resources to which the permission does NOT apply and depend on the pattern type and value of the first pattern as follows:
The actions parameter contains a comma separated list of HTTP methods. The syntax of the actions parameter is defined as follows:
ExtensionMethod ::= any token as defined by RFC 2616 (that is, 1*[any CHAR except CTLs or separators]) HTTPMethod ::= "GET" | "POST" | "PUT" | "DELETE" | "HEAD" | "OPTIONS" | "TRACE | ExtensionMethod" HTTPMethodList ::= HTTPMethod | HTTPMethodList comma HTTPMethod HTTPMethodExceptionList ::= exclaimationPoint HTTPMethodList HTTPMethodSpec ::= null | HTTPMethodExceptionList | HTTPMethodList
If duplicates occur in the HTTPMethodSpec they must be eliminated by the permission constructor.
A null or empty string HTTPMethodSpec indicates that the permission applies to all HTTP methods at the resources identified by the URL pattern.
If the HTTPMethodSpec contains an HTTPMethodExceptionList (i.e., it begins with an exclamation- Point), the permission pertains to all methods except those occurring in the exception list.
name
- - the URLPatternSpec that identifies the application specific web resources to which the permission
pertains. All URLPatterns in the URLPatternSpec are relative to the context path of the deployed web
application module, and the same URLPattern must not occur more than once in a URLPatternSpec. A null
URLPatternSpec is translated to the default URLPattern, “/”, by the permission constructor. All colons
occurring within the URLPattern elements of the URLPatternSpec must be represented in escaped encoding
as defined in RFC 2396.actions
- - identifies the HTTP methods to which the permission pertains. If the value passed through this
parameter is null or the empty string, then the permission is constructed with actions corresponding to
all the possible HTTP methods.public WebResourcePermission(String urlPatternSpec, String[] httpMethods)
Creates a new WebResourcePermission with name corresponding to the URLPatternSpec, and actions composed from the array of HTTP methods.
urlPatternSpec
- - the URLPatternSpec that identifies the application specific web resources to which the permission
pertains. All URLPatterns in the URLPatternSpec are relative to the context path of the deployed web
application module, and the same URLPattern must not occur more than once in a URLPatternSpec. A null
URLPatternSpec is translated to the default URLPattern, “/”, by the permission constructor. All colons
occurring within the URLPattern elements of the URLPatternSpec must be represented in escaped encoding
as defined in RFC 2396.httpMethods
- - an array of strings each element of which contains the value of an HTTP method. If the value passed
through this parameter is null or is an array with no elements, then the permission is constructed with
actions corresponding to all the possible HTTP methods.public boolean equals(Object p)
Checks two WebResourcePermission objects for equality. WebResourcePermission objects are equivalent if their URLPatternSpec and (canonicalized) actions values are equivalent. The URLPatternSpec of a refer- ence permission is equivalent to that of an argument permission if their first patterns are equivalent, and the patterns of the URLPatternList of the reference permission collectively match exactly the same set of pat- terns as are matched by the patterns of the URLPatternList of the argument permission.
Two Permission objects, P1 and P2, are equivalent if and only if P1.implies(P2) && P2.implies(P1).
equals
in class Permission
p
- - the WebResourcePermission object being tested for equality with this WebResourcePermission.public String getActions()
Returns a canonical String representation of the actions of this WebResourcePermission. WebResourcePermission actions are canonicalized by sorting the HTTP methods into ascending lexical order. There may be no duplicate HTTP methods in the canonical form, and the canonical form of the set of all HTTP methods is the value null.
getActions
in class Permission
public int hashCode()
Returns the hash code value for this WebResourcePermission. The properties of the returned hash code must be as follows:
hashCode
in class Permission
public boolean implies(Permission permission)
Determines if the argument Permission is "implied by" this WebResourcePermission. For this to be the case, all of the following must be true:
URLPattern matching is performed using the Servlet matching rules where two URL patterns match if they are related as follows:
All of the comparisons described above are case sensitive.
implies
in class Permission
permission
- - “this” WebResourcePermission is checked to see if it implies the argument permission.Copyright © 2019 JBoss by Red Hat. All rights reserved.