|
GigaSpaces XAP 8.0 API | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.sun.jini.discovery.Discovery
public abstract class Discovery
Class providing methods for participating in versions 1 and 2 of the discovery protocol.
Logging
This implementation uses the Logger
s named
com.sun.jini.discovery.DiscoveryV1
and
com.sun.jini.discovery.DiscoveryV2
to log information at the
following logging levels:
Level | Description |
---|---|
FINEST
| Encoding and decoding of discovery protocol version 1 multicast requests, multicast announcements, and unicast responses |
Level | Description |
---|---|
WARNING
| Truncation of unicast request format ID list due to length; discovery format providers that are unusable or have conflicting discovery format IDs |
HANDLED
| Constraint check failures encountered during the unicast discovery handshake when determining a suitable discovery format to use |
FINEST
| Encoding and decoding of discovery protocol version 2 multicast
requests, multicast announcements, and unicast responses; also,
access of Discovery instances implementing protocol
version 2
|
Field Summary | |
---|---|
static int |
PROTOCOL_VERSION_1
The version number for discovery protocol version 1. |
static int |
PROTOCOL_VERSION_2
The version number for discovery protocol version 2. |
Constructor Summary | |
---|---|
Discovery()
|
Method Summary | |
---|---|
abstract MulticastAnnouncement |
decodeMulticastAnnouncement(DatagramPacket packet,
InvocationConstraints constraints)
Decodes the multicast announcement data contained in the given datagram in a manner that satisfies the specified constraints, returning a MulticastAnnouncement instance that contains the decoded data. |
MulticastAnnouncement |
decodeMulticastAnnouncement(DatagramPacket packet,
InvocationConstraints constraints,
boolean delayConstraintCheck)
Decodes the multicast announcement data contained in the given datagram in a manner that satisfies the specified constraints, returning a MulticastAnnouncement instance that contains the decoded data, with
constraint checking optionally delayed. |
abstract MulticastRequest |
decodeMulticastRequest(DatagramPacket packet,
InvocationConstraints constraints,
ClientSubjectChecker checker)
Decodes the multicast request data contained in the given datagram in a manner that satisfies the specified constraints and client subject checker (if any), returning a MulticastRequest instance that
contains the decoded data. |
MulticastRequest |
decodeMulticastRequest(DatagramPacket packet,
InvocationConstraints constraints,
ClientSubjectChecker checker,
boolean delayConstraintCheck)
Decodes the multicast request data contained in the given datagram in a manner that satisfies the specified constraints and client subject checker (if any), returning a MulticastRequest instance that
contains the decoded data, with constraint checking optionally
delayed. |
abstract UnicastResponse |
doUnicastDiscovery(Socket socket,
InvocationConstraints constraints,
ClassLoader defaultLoader,
ClassLoader verifierLoader,
Collection context)
Performs the client side of unicast discovery, obtaining the returned response data over the provided socket using the given default and codebase verifier class loaders and collection of object stream context objects in a manner that satisfies the specified constraints. |
abstract EncodeIterator |
encodeMulticastAnnouncement(MulticastAnnouncement announcement,
int maxPacketSize,
InvocationConstraints constraints)
Returns an iterator which can be used to encode the given multicast announcement data into sets of DatagramPacket s, each bounded in
length by the specified maximum packet size, in a manner that satisfies
the given constraints. |
abstract EncodeIterator |
encodeMulticastRequest(MulticastRequest request,
int maxPacketSize,
InvocationConstraints constraints)
Returns an iterator which can be used to encode the given multicast request data into sets of DatagramPacket s, each bounded in
length by the specified maximum packet size, in a manner that satisfies
the given constraints. |
static Discovery |
getProtocol1()
Returns an instance implementing protocol version 1. |
static Discovery |
getProtocol2(ClassLoader loader)
Returns an instance implementing protocol version 2 which uses providers loaded from the given class loader, or the current context class loader if the given loader is null . |
static Discovery |
getProtocol2(MulticastRequestEncoder[] mre,
MulticastRequestDecoder[] mrd,
MulticastAnnouncementEncoder[] mae,
MulticastAnnouncementDecoder[] mad,
UnicastDiscoveryClient[] udc,
UnicastDiscoveryServer[] uds)
Returns an instance implementing protocol version 2 which uses the given providers. |
abstract void |
handleUnicastDiscovery(UnicastResponse response,
Socket socket,
InvocationConstraints constraints,
ClientSubjectChecker checker,
Collection context)
Handles the server side of unicast discovery, transmitting the given response data over the provided socket using the given collection of object stream context objects in a manner that satisfies the specified constraints and client subject checker (if any). |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final int PROTOCOL_VERSION_1
public static final int PROTOCOL_VERSION_2
Constructor Detail |
---|
public Discovery()
Method Detail |
---|
public static Discovery getProtocol1()
public static Discovery getProtocol2(ClassLoader loader)
null
. Available providers are
determined by interpreting any resources of the indicated class loader
named
"META-INF/services/com.sun.jini.discovery.DiscoveryFormatProvider"
as files containing names of provider classes, with one name per line.
loader
- class loader from which to load providers, or
null
to indicate the current context class loader
public static Discovery getProtocol2(MulticastRequestEncoder[] mre, MulticastRequestDecoder[] mrd, MulticastAnnouncementEncoder[] mae, MulticastAnnouncementDecoder[] mad, UnicastDiscoveryClient[] udc, UnicastDiscoveryServer[] uds)
null
array
values are equivalent to empty arrays.
mre
- providers for encoding multicast requestsmrd
- providers for decoding multicast requestsmae
- providers for encoding multicast announcementsmad
- providers for decoding multicast announcementsudc
- providers for performing the client side of unicast discoveryuds
- providers for performing the server side of unicast discovery
public abstract EncodeIterator encodeMulticastRequest(MulticastRequest request, int maxPacketSize, InvocationConstraints constraints)
DatagramPacket
s, each bounded in
length by the specified maximum packet size, in a manner that satisfies
the given constraints. null
constraints are considered
equivalent to empty constraints. The destination of each
DatagramPacket
produced by the returned iterator is set to
the address returned by
Constants.getRequestAddress()
, with the value
of Constants.discoveryPort
used as the
destination port.
request
- the request data to encodemaxPacketSize
- the maximum size of packets to produceconstraints
- the constraints to apply when encoding the data, or
null
NullPointerException
- if request
is
null
public abstract MulticastRequest decodeMulticastRequest(DatagramPacket packet, InvocationConstraints constraints, ClientSubjectChecker checker) throws IOException
MulticastRequest
instance that
contains the decoded data. null
constraints are considered
equivalent to empty constraints. All the specified constraints are
checked before this method returns.
packet
- the packet to decodeconstraints
- the constraints to apply when decoding the packet, or
null
checker
- the object to use to check the client subject, or
null
IOException
- if an error occurs in interpreting the data
UnsupportedConstraintException
- if unable to satisfy the
specified constraints
SecurityException
- if the given constraints cannot be satisfied
due to insufficient caller permissions, or if the client subject check
fails
NullPointerException
- if packet
is null
public MulticastRequest decodeMulticastRequest(DatagramPacket packet, InvocationConstraints constraints, ClientSubjectChecker checker, boolean delayConstraintCheck) throws IOException
MulticastRequest
instance that
contains the decoded data, with constraint checking optionally
delayed. null
constraints are considered
equivalent to empty constraints.
The delayConstraintCheck
flag is used to control delayed
constraint checking. Delayed constraint checking is useful for
potentially delaying the expense of complete constraint checking, until
other checks have been made on the returned
MulticastRequest
for preliminary validation.
Implementations may ignore the flag, in which case, the behavior is
equivalent to that of decodeMulticastRequest
.
If delayConstraintCheck
is true
, the method
behaves as follows:
MulticastRequest
's
checkConstraints
method must be invoked to complete checking of all the constraints.
MulticastRequest
can be invoked are always
checked before this method returns.If delayConstraintCheck
is false
, all the
specified constraints are checked before this method returns.
Discovery
implements this method to simply invoke decodeMulticastRequest
, and thus checks all the
specified constraints before returning.
packet
- the packet to decodeconstraints
- the constraints to apply when decoding the packet, or
null
checker
- the object to use to check the client subject, or
null
delayConstraintCheck
- flag to control delayed constraint checking
IOException
- if an error occurs in interpreting the data
SecurityException
- if the given constraints cannot be satisfied
due to insufficient caller permissions, or if the client subject check
fails
NullPointerException
- if packet
is null
public abstract EncodeIterator encodeMulticastAnnouncement(MulticastAnnouncement announcement, int maxPacketSize, InvocationConstraints constraints)
DatagramPacket
s, each bounded in
length by the specified maximum packet size, in a manner that satisfies
the given constraints. null
constraints are considered
equivalent to empty constraints. The destination of each
DatagramPacket
produced by the returned iterator is set to
the address returned by
Constants.getAnnouncementAddress()
, with the
value of Constants.discoveryPort
used as the
destination port.
announcement
- the announcement data to encodemaxPacketSize
- the maximum size of packets to produceconstraints
- the constraints to apply when encoding the data, or
null
NullPointerException
- if announcement
is
null
public abstract MulticastAnnouncement decodeMulticastAnnouncement(DatagramPacket packet, InvocationConstraints constraints) throws IOException
MulticastAnnouncement
instance that contains the decoded data.
null
constraints are considered equivalent to empty
constraints. All the specified constraints are checked before this
method returns.
packet
- the packet to decodeconstraints
- the constraints to apply when decoding the packet, or
null
IOException
- if an error occurs in interpreting the data
UnsupportedConstraintException
- if unable to satisfy the
specified constraints
SecurityException
- if the given constraints cannot be satisfied
due to insufficient caller permissions
NullPointerException
- if packet
is null
public MulticastAnnouncement decodeMulticastAnnouncement(DatagramPacket packet, InvocationConstraints constraints, boolean delayConstraintCheck) throws IOException
MulticastAnnouncement
instance that contains the decoded data, with
constraint checking optionally delayed. null
constraints
are considered equivalent to empty constraints.
The delayConstraintCheck
flag is used to control delayed
constraint checking. Delayed constraint checking is useful for
potentially delaying the expense of complete constraint checking, until
other checks have been made on the returned
MulticastAnnouncement
for preliminary validation.
Implementations may ignore the flag, in which case, the behavior is
equivalent to that of decodeMulticastAnnouncement
.
If delayConstraintCheck
is true
, the method
behaves as follows:
MulticastAnnouncement
's
checkConstraints
method must be invoked to complete checking of all the constraints.
MulticastAnnouncement
can be invoked are always
checked before this method returns. If delayConstraintCheck
is false
,
all the specified constraints are checked before this method returns.
Discovery
implements this method to simply invoke decodeMulticastAnnouncement
, and thus checks
all the specified constraints before returning.
packet
- the packet to decodeconstraints
- the constraints to apply when decoding the packet, or
null
delayConstraintCheck
- flag to control delayed constraint checking
IOException
- if an error occurs in interpreting the data
UnsupportedConstraintException
- if unable to satisfy the
specified constraints
SecurityException
- if the given constraints cannot be satisfied
due to insufficient caller permissions.
NullPointerException
- if packet
is null
public abstract UnicastResponse doUnicastDiscovery(Socket socket, InvocationConstraints constraints, ClassLoader defaultLoader, ClassLoader verifierLoader, Collection context) throws IOException, ClassNotFoundException
null
constraints are considered equivalent to empty
constraints.
socket
- the socket on which to perform unicast discoveryconstraints
- the constraints to apply to unicast discovery, or
null
defaultLoader
- the class loader value (possibly null
)
to be passed as the defaultLoader
argument to
RMIClassLoader
methods when unmarshalling the registrar
proxyverifierLoader
- the class loader value (possibly
null
) to pass to Security.verifyCodebaseIntegrity
, if codebase integrity verification is
used when unmarshalling the registrar proxycontext
- the collection of context information objects (possibly
null
) to use when unmarshalling the registrar proxy
IOException
- if an error occurs in interpreting received data or
in formatting data to send
UnsupportedConstraintException
- if unable to satisfy the
specified constraints
SecurityException
- if the given constraints cannot be satisfied
due to insufficient caller permissions
ClassNotFoundException
- if the class of the discovered registrar
cannot be resolved
NullPointerException
- if socket
is null
public abstract void handleUnicastDiscovery(UnicastResponse response, Socket socket, InvocationConstraints constraints, ClientSubjectChecker checker, Collection context) throws IOException
null
constraints are considered equivalent to empty
constraints.
response
- the unicast response data to transmitsocket
- the socket on which to handle unicast discoveryconstraints
- the constraints to apply to unicast discovery, or
null
checker
- the object to use to check the client subject, or
null
context
- the collection of context information objects to use when
marshalling the registrar proxy
IOException
- if the protocol handshake fails, or if an error
occurs in interpreting received data or in formatting data to send
UnsupportedConstraintException
- if unable to satisfy the
specified constraints
SecurityException
- if the given constraints cannot be satisfied
due to insufficient caller permissions, or if the client subject check
fails
NullPointerException
- if response
,
socket
, or context
is null
|
GigaSpaces XAP 8.0 API | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |