Java 2 Platform, Micro Edition Content Handler API v1.0.1

javax.microedition.content
Class Invocation

java.lang.Object
  extended byjavax.microedition.content.Invocation

public final class Invocation
extends java.lang.Object

An Invocation contains the parameters that are passed from an invoking application to a content handler and the results that are returned to the application. The parameters are the type, URL, action, content handler ID, and responseRequired. The string and data arguments can be set using setArgs and setData methods. All of the parameters are provided to the content handler and are returned with the handlers response, if any. Invocation instances are not thread safe, the application must handle any synchronization necessary.

The values of content handler ID, type, URL, and action are used to identify the content handler when invoked by Registry.invoke. If an Invocation contains an ID then it is used to identify the content handler to be invoked. The other parameters are input to the content handler.

If a type is present, it is used to find handlers that support that type. The application should supply the type if it is known. If the type is not set, then calling the findType will find the type using the URL to the content.

Invocation Status

The status value indicates the next processing step of the invocation by the content handler. The status of an Invocation can be any of the following:

All status transitions occur only during method calls that involve the Invocation instance. The transitions that occur are specified in the methods that make the change visible. For example, when an invoking application creates a new Invocation, the status is INIT. When the application calls Registry.invoke the status changes to WAITING. When the Registry.getResponse method is invoked, the status will be updated to the appropriate OK, CANCELLED, INITIATED, or ERROR status from the content handler.

A content handler calls ContentHandlerServer.getRequest to get the next request. The request always has the ACTIVE status. When the handler is finished acting on the content, the status is set to either OK, CANCELLED, or INITIATED by the ContentHandlerServer.finish method.

If the handler is chaining, then the new Invocation follows the status transitions of invoke as described above. The status of the previous invocation being chained from is set to HOLD by the Registry.invoke method. The status of the previous Invocation is restored to ACTIVE by the Registry.getResponse method that returns the status for the new Invocation.

If the content handler application causes faults because it does not properly dequeue and respond to invocations as described in the ContentHandler class, then the status is set to ERROR in the response queued back to the invoking application.

Access to Content

The implementation of the invocation mechanism may save or cache information about the request, the URL, the content type, or content during the invocation. The information may be utilized when the application accesses the content with the open method. The getURL() method MUST return the original URL unmodified by any implementation specific information.


Field Summary
static int ACTIVE
          This Invocation is a new request and is being handled by the content handler.
static int CANCELLED
          The processing of the Invocation was cancelled by the ContentHandler.
static int ERROR
          The content handler failed to correctly process the Invocation request.
static int HOLD
          This Invocation is on hold until a chained Invocation is completed.
static int INIT
          This Invocation was just constructed and is being initialized.
static int INITIATED
          The processing of the Invocation has been initiated and will continue.
static int OK
          The content handler successfully completed processing the Invocation.
static int WAITING
          This Invocation has been invoked and is waiting to be complete.
 
Constructor Summary
Invocation()
          Creates a new Invocation.
Invocation(java.lang.String url)
          Convenient alternative constructor with a URL.
Invocation(java.lang.String url, java.lang.String type)
          Convenient alternative constructor with URL and type.
Invocation(java.lang.String url, java.lang.String type, java.lang.String ID)
          Convenient alternative constructor with URL, type, and ID.
Invocation(java.lang.String url, java.lang.String type, java.lang.String ID, boolean responseRequired, java.lang.String action)
          Creates a new instance and initializes it from the specified parameters.
 
Method Summary
 java.lang.String findType()
          Finds the type of the content in this Invocation.
 java.lang.String getAction()
          Gets the action to be performed on the content.
 java.lang.String[] getArgs()
          Gets the argument list as an array of Strings.
 byte[] getData()
          Gets the data for the Invocation.
 java.lang.String getID()
          Gets the content handler ID for this Invocation.
 java.lang.String getInvokingAppName()
          Get the user-friendly name of the application that invoked the content handler.
 java.lang.String getInvokingAuthority()
          Gets the authority, if any, used to authenticate the application that invoked this request.
 java.lang.String getInvokingID()
          Gets the ID of the application that invoked the content handler.
 Invocation getPrevious()
          Gets the previous Invocation saved in this Invocation by Registry.invoke or Registry.getResponse.
 boolean getResponseRequired()
          Gets the responseRequired mode for this Invocation.
 int getStatus()
          Gets the status of this Invocation, which can be INIT, WAITING, HOLD, ACTIVE, OK, CANCELLED, INITIATED, or ERROR.
 java.lang.String getType()
          Gets the content type for the Invocation.
 java.lang.String getURL()
          Gets the URL for the invocation.
 javax.microedition.io.Connection open(boolean timeouts)
          Creates and opens a Connection to the content addressed by the URL in getURL.
 void setAction(java.lang.String action)
          Sets the action to be performed on the content.
 void setArgs(java.lang.String[] args)
          Sets the argument list to a new array of Strings.
 void setCredentials(java.lang.String username, char[] password)
          Provide the credentials needed to access the content.
 void setData(byte[] data)
          Sets the data used for the Invocation.
 void setID(java.lang.String ID)
          Sets the ID of the content handler for this Invocation.
 void setResponseRequired(boolean responseRequired)
          Sets the responseRequired mode for this Invocation.
 void setType(java.lang.String type)
          Sets the type for the Invocation.
 void setURL(java.lang.String url)
          Sets the URL for the invocation.
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

INIT

public static final int INIT
This Invocation was just constructed and is being initialized.

See Also:
Constant Field Values

ACTIVE

public static final int ACTIVE
This Invocation is a new request and is being handled by the content handler.

See Also:
Constant Field Values

WAITING

public static final int WAITING
This Invocation has been invoked and is waiting to be complete.

See Also:
Registry.invoke(javax.microedition.content.Invocation, javax.microedition.content.Invocation), Constant Field Values

HOLD

public static final int HOLD
This Invocation is on hold until a chained Invocation is completed.

See Also:
Registry.invoke(javax.microedition.content.Invocation, javax.microedition.content.Invocation), Constant Field Values

OK

public static final int OK
The content handler successfully completed processing the Invocation. Invocations queued with ContentHandlerServer.finish will have this status.

See Also:
Constant Field Values

CANCELLED

public static final int CANCELLED
The processing of the Invocation was cancelled by the ContentHandler. Invocations queued with ContentHandlerServer.finish will have this status.

See Also:
Constant Field Values

ERROR

public static final int ERROR
The content handler failed to correctly process the Invocation request.

See Also:
Constant Field Values

INITIATED

public static final int INITIATED
The processing of the Invocation has been initiated and will continue. This status is only appropriate when the content handler can not provide a response when it is finished.

See Also:
Constant Field Values
Constructor Detail

Invocation

public Invocation()
Creates a new Invocation. The status of the new Invocation object is INIT. The URL, type, ID, action, arguments, and data are set to empty arrays, and initialized to require a response.


Invocation

public Invocation(java.lang.String url,
                  java.lang.String type,
                  java.lang.String ID)
Convenient alternative constructor with URL, type, and ID. The behavior is identical to new Invocation(url, type, ID, true, null).

Parameters:
url - the URL of the content to be dispatched; may be null
type - the content type; may be null
ID - the ID of the content handler; may be null

Invocation

public Invocation(java.lang.String url,
                  java.lang.String type)
Convenient alternative constructor with URL and type. The behavior is identical to new Invocation(url, type, null, true, null).

Parameters:
url - the URL of the content to be dispatched; may be null
type - the content type; may be null

Invocation

public Invocation(java.lang.String url)
Convenient alternative constructor with a URL. The behavior is identical to new Invocation(url, null, null, true, null).

Parameters:
url - the URL of the content to be dispatched; may be null

Invocation

public Invocation(java.lang.String url,
                  java.lang.String type,
                  java.lang.String ID,
                  boolean responseRequired,
                  java.lang.String action)
Creates a new instance and initializes it from the specified parameters. The status of the new Invocation is INIT. None of the values are checked until the Registry.invoke method is called. String arguments or data can be set with setArgs or setData.

Parameters:
url - the URL of the content to be dispatched; may be null
type - the content type; may be null
ID - the ID of the content handler; may be null
responseRequired - true if a response is required; false otherwise
action - the action that the content handler should perform on the content; may be null
Method Detail

setArgs

public void setArgs(java.lang.String[] args)
Sets the argument list to a new array of Strings. The arguments are used by the application to communicate to the content handler and return results from the content handler. The values of the arguments are not checked when they are set. Instead, they are checked during Registry.invoke to check that none of the values are null.

Parameters:
args - the String array; may be null. A null argument is treated the same as a zero-length array
See Also:
getArgs()

getArgs

public java.lang.String[] getArgs()
Gets the argument list as an array of Strings. These values are passed to the content handler and are returned from the content handler. The array is not copied; modifications to array elements will be visible.

Returns:
the arguments array, which MUST NOT be null
See Also:
setArgs(java.lang.String[])

setData

public void setData(byte[] data)
Sets the data used for the Invocation. The data is used by the application to communicate to the content handler and return data from the content handler. The array is not copied until the Invocation is invoked or finished; modifications to array elements will otherwise be visible.

Parameters:
data - the byte data array; may be null. A null is treated the same as a zero-length array
See Also:
getData()

getData

public byte[] getData()
Gets the data for the Invocation. The data is passed to the content handler. The content handler may modify and return the data if it returns a response.

Returns:
the data array, which MUST NOT be null
See Also:
setData(byte[])

getURL

public java.lang.String getURL()
Gets the URL for the invocation. The URL must be equal to the value set with setURL.

Returns:
the URL or null if it has not been set
See Also:
setURL(java.lang.String)

setURL

public void setURL(java.lang.String url)
Sets the URL for the invocation.

Parameters:
url - the URL to be set; may be null
See Also:
getURL()

getType

public java.lang.String getType()
Gets the content type for the Invocation. The type for this Invocation may be set by the application using setType. The findType method can be used by an application to find the type by accessing the content via the URL. When found, findType sets the type returned by getType.

Returns:
the content type or null if it has not been set
See Also:
setType(java.lang.String), findType()

setType

public void setType(java.lang.String type)
Sets the type for the Invocation.

Parameters:
type - the type to be set for the content; may be null
See Also:
getType(), findType()

getAction

public java.lang.String getAction()
Gets the action to be performed on the content.

Returns:
the content action or null if it has not been set
See Also:
setAction(java.lang.String)

setAction

public void setAction(java.lang.String action)
Sets the action to be performed on the content.

Parameters:
action - the action to be performed on the content; may be null
See Also:
getAction()

getResponseRequired

public boolean getResponseRequired()
Gets the responseRequired mode for this Invocation. If true, then the invoking application requires a response to the Invocation.

Returns:
the current value of the responseRequired mode. If true, then a response must be returned to the invoking application.
See Also:
setResponseRequired(boolean)

setResponseRequired

public void setResponseRequired(boolean responseRequired)
Sets the responseRequired mode for this Invocation. If true, then the invoking application requires a response to the Invocation. The value in the request can be changed only if the status is INIT.

Parameters:
responseRequired - true to require a response, false otherwise
Throws:
java.lang.IllegalStateException - is thrown if the status is not INIT
See Also:
getResponseRequired()

getStatus

public int getStatus()
Gets the status of this Invocation, which can be INIT, WAITING, HOLD, ACTIVE, OK, CANCELLED, INITIATED, or ERROR.

Returns:
the status of this Invocation
See Also:
Registry.invoke(javax.microedition.content.Invocation, javax.microedition.content.Invocation), Registry.getResponse(boolean), ContentHandlerServer.getRequest(boolean), ContentHandlerServer.finish(javax.microedition.content.Invocation, int)

getID

public java.lang.String getID()
Gets the content handler ID for this Invocation.

Returns:
the ID of the ContentHandler; may be null
See Also:
Registry.forID(java.lang.String, boolean), setID(java.lang.String)

setID

public void setID(java.lang.String ID)
Sets the ID of the content handler for this Invocation.

Parameters:
ID - of the content handler; may be null
See Also:
getID()

getPrevious

public Invocation getPrevious()
Gets the previous Invocation saved in this Invocation by Registry.invoke or Registry.getResponse. Invocations returned by ContentHandlerServer.getRequest MUST return null.

Returns:
the previous Invocation, if any, saved when this Invocation was invoked or returned as a response; may be null
See Also:
Registry.invoke(javax.microedition.content.Invocation, javax.microedition.content.Invocation), Registry.getResponse(boolean)

getInvokingAuthority

public java.lang.String getInvokingAuthority()
Gets the authority, if any, used to authenticate the application that invoked this request. This value MUST be null unless the device has been able to authenticate this application. If non-null, it is the string identifying the authority. For signed applications, it is the subject of the signing certificate of the class registered as the content handler.

Returns:
the authority used to authenticate this application and if the status is either ACTIVE or HOLD; otherwise it is null, the application has not been authenticated
See Also:
ContentHandler.getAuthority()

getInvokingID

public java.lang.String getInvokingID()
Gets the ID of the application that invoked the content handler. This information is available only if the status is ACTIVE or HOLD. This information has been authenticated only if getInvokingAuthority is non-null.

Returns:
the invoking application's ID if the Invocation status is ACTIVE or HOLD; null otherwise
See Also:
Registry.getID()

getInvokingAppName

public java.lang.String getInvokingAppName()
Get the user-friendly name of the application that invoked the content handler. This information is available only if the status is ACTIVE or HOLD. This information has been authenticated only if getInvokingAuthority is non-null.

Returns:
the application's name if status is ACTIVE or HOLD; null otherwise
See Also:
ContentHandler.getID()

findType

public java.lang.String findType()
                          throws java.io.IOException,
                                 ContentHandlerException,
                                 java.lang.SecurityException
Finds the type of the content in this Invocation. If the getType method return value is non-null, then the type is returned.

If the type is null and the URL is non-null, then the content type will be found by accessing the content through the URL. When found, the type is extracted and parameters or other information that does not intrinsically identify the type of content is ignored. For example, the Content-Type header of HTTP includes type, subtype and parameter of the content in the Invocation. Only the type/subtype string is used to set the type of the content. The type is set as if the setType method was called; subsequent calls to getType and findType will return the type. If an exception is thrown, the getType method will return null.

The calling thread blocks while the type is being determined. If a network access is needed there may be an associated delay.

Returns:
the non-null content type
Throws:
java.io.IOException - if access to the content fails
ContentHandlerException - is thrown with a reason of ContentHandlerException.TYPE_UNKNOWN if the type is null and cannot be found from the content either because the URL is null or the type is not available from the content
java.lang.IllegalArgumentException - if the content is accessed via the URL and the URL is invalid
java.lang.SecurityException - is thrown if access to the content is required and is not permitted
See Also:
setType(java.lang.String), getType()

open

public javax.microedition.io.Connection open(boolean timeouts)
                                      throws java.io.IOException,
                                             java.lang.SecurityException
Creates and opens a Connection to the content addressed by the URL in getURL. This method is similar to Connector.open(getURL(), READ, timeouts) but may deliver the content from a cache. The application should use this method to access the content of the URL so that any type or content information cached by the implementation can be utilized. The content is opened in read only mode. Regardless of whether or not the content is cached, the application or content handler must have permission to access the content via the URL.

Implementations are strongly encouraged to return a sub-interface of Connection that matches the URL scheme requested. For example, when a HTTP URL is accessed, this method SHOULD return an javax.microedition.io.HttpConnection. If a specific Connection interface is not appropriate then a javax.microedition.io.ContentConnection SHOULD be returned. Applications should not assume that the Connection returned is of a particular type. If the return value is not of type expected, the application should not fail and the application should try to use a more basic interface.

Parameters:
timeouts - a flag to indicate that the caller wants timeout exceptions
Returns:
a Connection object
Throws:
ConnectionNotFoundException - is thrown if:
  • the target URL can not be found, or
  • the requested protocol type is not supported
java.lang.NullPointerException - if the URL is null
java.lang.IllegalArgumentException - if a parameter is invalid.
java.io.IOException - if some other kind of I/O error occurs
java.lang.SecurityException - is thrown if access to the protocol handler is prohibited

setCredentials

public void setCredentials(java.lang.String username,
                           char[] password)
Provide the credentials needed to access the content. Use of the credential is protocol specific.

Parameters:
username - the username; may be null
password - the password for the username; may be null

Maintenance Release
September 17, 2009

Submit a comment or suggestion on this specification. This specification is protected under the JSPA version 2.6.
Java is a trademark or registered trademark of Sun Microsystems, Inc. in the US and other countries. Copyright © 2006-2009 Sun Microsystems, Inc. 4150 Network Circle, California, 95054, U.S.A.
All Rights Reserved. Use is subject to license terms.