|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.apache.pluto.internal.impl.PortletContextImpl
public class PortletContextImpl
Pluto's Portlet Context Implementation. This class implements the
InternalPortletContext
which provides container specific
information needed for processing.
Constructor Summary | |
---|---|
PortletContextImpl(String portletApplicationId,
javax.servlet.ServletContext servletContext,
PortletAppDD portletAppDD)
Constructs an instance. |
Method Summary | |
---|---|
String |
getApplicationId()
Retrieve the unique identifier for the portlet context. |
String |
getApplicationName()
|
Map<String,String[]> |
getApplicationRuntimeOptions()
|
Object |
getAttribute(String name)
Returns the portlet container attribute with the given name, or null if there is no attribute by that name. |
Enumeration |
getAttributeNames()
Returns an Enumeration containing the attribute names
available within this portlet context, or an empty
Enumeration if no attributes are available. |
Map<String,String[]> |
getContainerRuntimeOptions()
Returns the container container runtime options and values supported by this portlet container. |
ClassLoader |
getContextClassLoader()
ClassLoader associated with this context. |
String |
getInitParameter(String name)
Returns a String containing the value of the named context-wide initialization parameter, or null if the parameter does not exist. |
Enumeration |
getInitParameterNames()
Returns the names of the context initialization parameters as an Enumeration of String objects, or an empty Enumeration if the context
has no initialization parameters. |
int |
getMajorVersion()
Returns the major version of the Portlet API that this portlet container supports. |
String |
getMimeType(String file)
Returns the MIME type of the specified file, or null if
the MIME type is not known. |
int |
getMinorVersion()
Returns the minor version of the Portlet API that this portlet container supports. |
PortletRequestDispatcher |
getNamedDispatcher(String name)
Returns a PortletRequestDispatcher object that acts
as a wrapper for the named servlet. |
PortletAppDD |
getPortletApplicationDefinition()
|
String |
getPortletContextName()
Returns the name of this portlet application correponding to this PortletContext as specified in the web.xml deployment descriptor for this web application by the
display-name element. |
Map<String,String[]> |
getPortletRuntimeOptions()
|
String |
getRealPath(String path)
Returns a String containing the real path
for a given virtual path. |
PortletRequestDispatcher |
getRequestDispatcher(String path)
Returns a PortletRequestDispatcher object that acts
as a wrapper for the resource located at the given path. |
URL |
getResource(String path)
Returns a URL to the resource that is mapped to a specified path. |
InputStream |
getResourceAsStream(String path)
Returns the resource located at the given path as an InputStream object. |
Set |
getResourcePaths(String path)
Returns a directory-like listing of all the paths to resources within the web application longest sub-path of which matches the supplied path argument. |
String |
getServerInfo()
Retrieve the PortletContainer's server info. |
javax.servlet.ServletContext |
getServletContext()
|
void |
log(String msg)
Writes the specified message to a portlet log file, usually an event log. |
void |
log(String message,
Throwable throwable)
Writes an explanatory message and a stack trace for a given Throwable exception to the portlet log file. |
void |
removeAttribute(String name)
Removes the attribute with the given name from the portlet context. |
void |
setAttribute(String name,
Object object)
Binds an object to a given attribute name in this portlet context. |
void |
setContextClassLoader(ClassLoader contextClassLoader)
ClassLoader associated with this context. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public PortletContextImpl(String portletApplicationId, javax.servlet.ServletContext servletContext, PortletAppDD portletAppDD)
servletContext
- the servlet context in which we are contained.portletAppDD
- the portlet application descriptor.Method Detail |
---|
public String getApplicationId()
InternalPortletContext
getApplicationId
in interface InternalPortletContext
public String getApplicationName()
public ClassLoader getContextClassLoader()
public void setContextClassLoader(ClassLoader contextClassLoader)
contextClassLoader
- public String getServerInfo()
getServerInfo
in interface PortletContext
Environment.getServerInfo()
public PortletRequestDispatcher getRequestDispatcher(String path)
PortletContext
PortletRequestDispatcher
object that acts
as a wrapper for the resource located at the given path.
A PortletRequestDispatcher
object can be used include the
resource in a response. The resource can be dynamic or static.
The pathname must begin with a slash ( /
) and is interpreted as relative
to the current context root.
This method returns null
if the PortletContext
cannot return a PortletRequestDispatcher
for any reason.
getRequestDispatcher
in interface PortletContext
path
- a String
specifying the pathname
to the resource
PortletRequestDispatcher
object
that acts as a wrapper for the resource
at the specified path.PortletRequestDispatcher
public PortletRequestDispatcher getNamedDispatcher(String name)
PortletContext
PortletRequestDispatcher
object that acts
as a wrapper for the named servlet.
Servlets (and also JSP pages) may be given names via server administration or via a web application deployment descriptor.
This method returns null
if the
PortletContext
cannot return a
PortletRequestDispatcher
for any reason.
getNamedDispatcher
in interface PortletContext
name
- a String
specifying the name
of a servlet to be wrapped
PortletRequestDispatcher
object
that acts as a wrapper for the named servletPortletRequestDispatcher
public InputStream getResourceAsStream(String path)
PortletContext
In order to access protected resources the path has to be prefixed with
/WEB-INF/
(for example /WEB-INF/myportlet/myportlet.jsp
).
Otherwise, the direct path is used
(for example /myportlet/myportlet.jsp
).
getResourceAsStream
in interface PortletContext
path
- the path to the resource
public int getMajorVersion()
PortletContext
getMajorVersion
in interface PortletContext
PortletContext.getMinorVersion()
public int getMinorVersion()
PortletContext
getMinorVersion
in interface PortletContext
PortletContext.getMajorVersion()
public String getMimeType(String file)
PortletContext
null
if
the MIME type is not known. The MIME type is determined
by the configuration of the portlet container and may be specified
in a web application deployment descriptor. Common MIME
types are text/html
and image/gif
.
getMimeType
in interface PortletContext
file
- a String
specifying the name
of a file
String
specifying the MIME type of the filepublic String getRealPath(String path)
PortletContext
String
containing the real path
for a given virtual path. For example, the path /index.html
returns the absolute file path of the portlet container file system.
The real path returned will be in a form
appropriate to the computer and operating system on
which the portlet container is running, including the
proper path separators. This method returns null
if the portlet container cannot translate the virtual path
to a real path for any reason (such as when the content is
being made available from a .war
archive).
getRealPath
in interface PortletContext
path
- a String
specifying a virtual path
String
specifying the real path,
or null if the transformation cannot be performed.public Set getResourcePaths(String path)
PortletContext
/
). The returned paths are all
relative to the root of the web application and have a leading slash.
For example, for a web application
containing
/welcome.html
/catalog/index.html
/catalog/products.html
/catalog/offers/books.html
/catalog/offers/music.html
/customer/login.jsp
/WEB-INF/web.xml
/WEB-INF/classes/com.acme.OrderPortlet.class,
getResourcePaths("/")
returns
{"/welcome.html", "/catalog/", "/customer/", "/WEB-INF/"}
getResourcePaths("/catalog/")
returns
{"/catalog/index.html", "/catalog/products.html", "/catalog/offers/"}
.
getResourcePaths
in interface PortletContext
path
- the partial path used to match the resources, which must start with a slash
null
if there
are no resources in the web application of which the path
begins with the supplied path.public URL getResource(String path) throws MalformedURLException
PortletContext
/
) and is interpreted
as relative to the current context root.
This method allows the portlet container to make a resource
available to portlets from any source. Resources
can be located on a local or remote
file system, in a database, or in a .war
file.
The portlet container must implement the URL handlers
and URLConnection
objects that are necessary
to access the resource.
This method returns null
if no resource is mapped to the pathname.
Some containers may allow writing to the URL returned by this method using the methods of the URL class.
The resource content is returned directly, so be aware that
requesting a .jsp
page returns the JSP source code.
Use a RequestDispatcher
instead to include results of
an execution.
This method has a different purpose than
java.lang.Class.getResource
,
which looks up resources based on a class loader. This
method does not use class loaders.
getResource
in interface PortletContext
path
- a String
specifying
the path to the resource
null
if there is no resource
at that path
MalformedURLException
- if the pathname is not given in
the correct formpublic Object getAttribute(String name)
PortletContext
getAttributeNames
.
The attribute is returned as a java.lang.Object
or some subclass.
Attribute names should follow the same convention as package
names. The Java Portlet API specification reserves names
matching java.*
, javax.*
,
and sun.*
.
getAttribute
in interface PortletContext
name
- a String
specifying the name
of the attribute
Object
containing the value
of the attribute, or null
if no attribute exists matching the given
namePortletContext.getAttributeNames()
public Enumeration getAttributeNames()
PortletContext
Enumeration
containing the attribute names
available within this portlet context, or an empty
Enumeration
if no attributes are available. Use the
PortletContext.getAttribute(java.lang.String)
method with an attribute name
to get the value of an attribute.
getAttributeNames
in interface PortletContext
Enumeration
of attribute namesPortletContext.getAttribute(java.lang.String)
public String getInitParameter(String name)
PortletContext
null
if the parameter does not exist.
This method provides configuration information which may be useful for
an entire "portlet application".
getInitParameter
in interface PortletContext
name
- a String
containing the name of the
requested parameter
String
containing the value
of the initialization parameter, or
null
if the parameter does not exist.PortletContext.getInitParameterNames()
public Enumeration getInitParameterNames()
PortletContext
Enumeration
of String objects, or an empty Enumeration if the context
has no initialization parameters.
getInitParameterNames
in interface PortletContext
Enumeration
of String
objects containing the names of the context
initialization parametersPortletContext.getInitParameter(java.lang.String)
public void log(String msg)
PortletContext
This method mapps to the ServletContext.log
method.
The portlet container may in addition log this message in a
portlet container specific log file.
log
in interface PortletContext
msg
- a String
specifying the
message to be written to the log filepublic void log(String message, Throwable throwable)
PortletContext
This method is mapped to the ServletContext.log
method.
The portlet container may in addition log this message in a
portlet container specific log file.
log
in interface PortletContext
message
- a String
that
describes the error or exceptionthrowable
- the Throwable
error
or exceptionpublic void removeAttribute(String name)
PortletContext
PortletContext.getAttribute(java.lang.String)
to retrieve the attribute's value
will return null
.
removeAttribute
in interface PortletContext
name
- a String
specifying the name
of the attribute to be removedpublic void setAttribute(String name, Object object)
PortletContext
If a null value is passed, the effect is the same as calling
removeAttribute()
.
Attribute names should follow the same convention as package
names. The Java Portlet API specification reserves names
matching java.*
, javax.*
, and
sun.*
.
setAttribute
in interface PortletContext
name
- a String
specifying the name
of the attributeobject
- an Object
representing the
attribute to be boundpublic String getPortletContextName()
PortletContext
web.xml
deployment descriptor for this web application by the
display-name
element.
getPortletContextName
in interface PortletContext
public javax.servlet.ServletContext getServletContext()
getServletContext
in interface InternalPortletContext
public PortletAppDD getPortletApplicationDefinition()
getPortletApplicationDefinition
in interface InternalPortletContext
public Map<String,String[]> getApplicationRuntimeOptions()
public Map<String,String[]> getPortletRuntimeOptions()
public Map<String,String[]> getContainerRuntimeOptions()
PortletContext
The portlet can set container runtime
options in the portlet.xml
via the
container-runtime-option
element with a name and a
value on the application and portlet level.
If a container runtime option is set on the portlet application
level and on the portlet level with the same name the setting
on the portlet level takes precedence and overwrites the one
set on the portal application level.
The map returned from this method will provide the subset the
portlet container supports of the options the portlet has specified
in the portlet.xml
.
The map will contain name of the runtime option as key of type String
and the runtime options as values of type String array (String[]
).
getContainerRuntimeOptions
in interface PortletContext
Map
containing portlet
container runtime options names as keys and the
container runtime values as map values, or an empty Map
if no portlet container runtime options are set
in the portlet.xml
or supported by this portlet container.
The keys in the map are of type String. The values in the map are of type
String array (String[]
).
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |