All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.ocap.system.SystemModuleRegistrar.html Maven / Gradle / Ivy

There is a newer version: 1.3.1
Show newest version






SystemModuleRegistrar














org.ocap.system
Class SystemModuleRegistrar

java.lang.Object
  extended by org.ocap.system.SystemModuleRegistrar

public class SystemModuleRegistrar
extends java.lang.Object

This class is used by an OCAP-J application to access a system module.

Private Host Application
An OCAP-J application MAY register a SystemModuleHandler to act as a Private Host Application. If the SystemModuleHandler is registered successfully, the current Private Host Application that has a matching Private Host Application ID is terminated.

Man Machine Interface (MMI) Resource and Application Information Resource
An OCAP-J application MAY register a SystemModuleHandler to access the Host?s MMI and Application Information resources. If the SystemModuleHandler is registered successfully, the Host's MMI Resource and Application Information Resource MAY not terminate, but the implementation SHALL pass all APDUs to the registered Handler, and the resident MMI dialog SHALL be hidden.

See also Section 20 Baseline Functionality for details.

Since:
1.0

Constructor Summary
protected SystemModuleRegistrar()
          A constructor of this class.
 
Method Summary
static SystemModuleRegistrar getInstance()
          This method returns a sole instance of the SystemModuleRegistrar class.
 void registerMMIHandler(SystemModuleHandler handler)
           This method registers a SystemModuleHandler instance for accessing MMI and Application Information Resource.
 void registerSASHandler(SystemModuleHandler handler, byte[] privateHostAppID)
           This method registers the specified SystemModuleHandler instance for the specified privateHostAppID.
 void unregisterMMIHandler()
           This method unregisters the SystemModuleHandler and SystemModule instance of the registered application accessing MMI and Application Information Resource and revives the resident MMI and Application Information Resource.
 void unregisterSASHandler(byte[] privateHostAppID)
           This method unregisters the SystemModuleHandler and the SystemModule instance corresponding to the specified privateHostAppID, and revives an original resident Private Host Application.
 void unregisterSASHandler(SystemModuleHandler handler)
           This method unregisters the specified SystemModuleHandler and the corresponding SystemModule instance, and revives an original resident Private Host Application.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

SystemModuleRegistrar

protected SystemModuleRegistrar()
A constructor of this class. An application must use the getInstance() method to create an instance.

Method Detail

getInstance

public static SystemModuleRegistrar getInstance()
This method returns a sole instance of the SystemModuleRegistrar class. The SystemModuleRegistrar instance is either a singleton for each OCAP application or a singleton for an entire OCAP implementation.

Returns:
a singleton SystemModuleRegistrar instance.
Throws:
java.lang.SecurityException - if the caller does not have MonitorAppPermission("podApplication").

registerSASHandler

public void registerSASHandler(SystemModuleHandler handler,
                               byte[] privateHostAppID)

This method registers the specified SystemModuleHandler instance for the specified privateHostAppID. The Private Host Application is a logical entity defined in the CableCARD Interface 2.0 Specification.

If there is a current Private Host Application that has a matching Private Host Application ID as the privateHostAppID parameter, it shall be unregistered first, i.e., corresponding SystemModule and SystemModuleHandler shall be unregistered. The SystemModuleHandler.notifyUnregister() method of the SystemModuleHandler to be unregistered shall be called to notify its unregistration and give a chance to do a termination procedure. Note that the OCAP implementation shall call the notifyUnregister() method in a new thread to avoid blocking.

After the SystemModuleHandler.notifyUnregister() method returns, the OCAP implementation selects an appropriate session number for sending and receiving APDU. Then the OCAP implementation shall send the sas_connect_rqst APDU with the session automatically. After establishing the SAS connection, the OCAP implementation shall call the SystemModuleHandler.ready() method with a new SystemModule instance.

After ready() method is called, all APDUs shall be handled by the registered OCAP-J application instead of the OCAP implementation.

If a native resident Private Host Application is implemented on the Host, it shall has Java interface and be registered in a same manner as the OCAP-J application. Only when no SystemModuleHandler that has a matching Private Host Application ID is registered by the Monitor Application, the OCAP implementation shall register such a native resident Private Host Application.

Parameters:
handler - a SystemModuleHandler instance to receive an APDU from the CableCARD device. If the handler has already been registered to the SystemModuleRegistrar, the method does nothing and throws IllegalArgumentException. Multiple call of this method with different SystemModuleHandler instance registers all of them.
privateHostAppID - a Private Host Application ID for the specified handler. This value is defined as an unsigned 64-bit value in the OpenCable CableCARD Interface specification. The specified byte array shall be big endian. This value is specified as the private_host_application_id field in the sas_connect_rqst APDU. If a SystemModuleHandler instance that has a matching privateHostAppID has already been registered, it shall be unregistered even if it is registered by another OCAP-J application.
Throws:
java.lang.SecurityException - if the caller does not have MonitorAppPermission("podApplication").
java.lang.IllegalStateException - if the CableCARD device is not ready.
java.lang.IllegalArgumentException - if the specified handler already exists, or the specified parameter is out of range.

unregisterSASHandler

public void unregisterSASHandler(SystemModuleHandler handler)

This method unregisters the specified SystemModuleHandler and the corresponding SystemModule instance, and revives an original resident Private Host Application.

In this method call, the SystemModuleHandler.notifyUnregister() method of the specified SystemModuleHandler shall be called to notify its unregistration and give a chance to do a termination procedure. The SystemModuleHandler and the corresponding SystemModule shall be removed from the SystemModuleRegistrar after returning of the notifyUnregister() method. Note that the OCAP implementation shall call the notifyUnregister() method in a new thread to avoid blocking.

The OCAP implementation shall re-register a native resident Private Host Application automatically (i.e., revive it), when no SystemModuleHandler that has a matching Private Host Application ID is registered.

Parameters:
handler - a SystemModuleHandler instance (the Private Host Application) to be unregistered. If the specified handler has not been registered to the SystemModuleRegistrar, the method call does nothing and throws IllegalArgumentException.
Throws:
java.lang.SecurityException - if the caller does not have MonitorAppPermission("podApplication")
java.lang.IllegalArgumentException - if the specified handler has not been registered.

unregisterSASHandler

public void unregisterSASHandler(byte[] privateHostAppID)

This method unregisters the SystemModuleHandler and the SystemModule instance corresponding to the specified privateHostAppID, and revives an original resident Private Host Application.

In this method call, the SystemModuleHandler.notifyUnregister() method corresponding to the specified privateHostAppID shall be called to notify its unregistration and give a chance to do a termination procedure. The SystemModuleHandler and the corresponding SystemModule shall be removed from the SystemModuleRegistrar after returning of the notifyUnregister() method. Note that the OCAP implementation shall call the notifyUnregister() method in a new thread to avoid blocking.

The OCAP implementation shall re-register a native resident Private Host Application automatically (i.e., revive it), when no SystemModuleHandler that has a matching Private Host Application ID is registered.

Parameters:
privateHostAppID - a Private Host Application ID of the Private Host Application (i.e., SystemModuleHandler) to be unregistered. This value is defined as an unsigned 64-bit value in the OpenCable Host-POD Interface specification. The specified byte array shall be a big endian. If the specified privateHostAppID has not been registered to the SystemModuleRegistrar, this method does nothing and throws IllegalArgumentException.
Throws:
java.lang.SecurityException - if the caller does not have MonitorAppPermission("podApplication").
java.lang.IllegalArgumentException - if the specified privateHostAppID has not been registered.

registerMMIHandler

public void registerMMIHandler(SystemModuleHandler handler)

This method registers a SystemModuleHandler instance for accessing MMI and Application Information Resource. The OCAP implementation shall call the SystemModuleHandler.ready(org.ocap.system.SystemModule) method with a new SystemModule instance to send an APDU to the CableCARD device.

The resident MMI and Application Information Resources don't terminate but shall pass APDU to the SystemModuleHandler. The OCAP-J application can send and receive APDUs via the SystemModule.sendAPDU(int, byte[]) and the SystemModuleHandler.receiveAPDU(int, int, byte[]) method instead of the resident Resources. The sessions established by the resident MMI and Application Information Resource is used to send and receive the APDU. See also the description of the SystemModule and the SystemModuleHandler.

After successful registration, the resident MMI Resource shall not represent the MMI dialog on the screen. The Host shall close all resident MMI dialog and finalize all transaction related to the MMI dialog. The Host shall send the close_mmi_cnf APDU to the CableCARD device to notify MMI dialog closing. If the unregisterMMIHandler() is called or the OCAP-J application that called this method changes its state to Destroyed, the resident MMI Resource can represent the MMI dialog again.

Parameters:
handler - a SystemModuleHandler instance to receive an APDU from CableCARD device. Only one SystemModuleHandler can be registered. If the second SystemModuleHandler is to be registered, this method throws IllegalArgumentException.
Throws:
java.lang.SecurityException - if the caller does not have MonitorAppPermission("podApplication").
java.lang.IllegalStateException - if the CableCARD device is not ready.
java.lang.IllegalArgumentException - if the second SystemModuleHandler is to be registered.

unregisterMMIHandler

public void unregisterMMIHandler()

This method unregisters the SystemModuleHandler and SystemModule instance of the registered application accessing MMI and Application Information Resource and revives the resident MMI and Application Information Resource.

In this method call, the SystemModuleHandler.notifyUnregister() method of the SystemModuleHandler registered by the registerMMIHandler() method shall be called to notify its unregistration and give a chance to do a termination procedure. At least, all MMI dialog shall be closed and all of the transaction related to the MMI and Application Information Resource shall be terminated. The OCAP-J application shall send the close_mmi_cnf APDU to the CableCARD device to notify MMI dialog closing. The SystemModuleHandler and the corresponding SystemModule shall be removed from the SystemModuleRegistrar after returning of the notifyUnregister() method. I.e., after returning of the notifyUnregister() method, no APDU can be sent. Note that the OCAP implementation shall call the notifyUnregister() method in a new thread to avoid blocking.

After this method is called, the resident MMI and Application Information Resource handles all APDUs and the resident MMI can represent the MMI dialog again.

Throws:
java.lang.SecurityException - if the caller does not have MonitorAppPermission("podApplication")






© 2015 - 2024 Weber Informatics LLC | Privacy Policy