public interface RemoteMethodControl
Constraints for a remote call come from two sources:
 A remote call will be performed only if the combined
 requirements (from both sources) can be satisfied. If the combined requirements cannot be
 satisfied, a ConnectIOException will be thrown by the remote call, typically
 containing (but not required to contain) a nested UnsupportedConstraintException.
 In addition to the requirements, both client and server preferences will be satisfied, to the
 extent possible. 
 Note that constraints imposed by the communication mechanism must be
 factored into the requirements. For example, if the only explicit requirement is
 Delegation.YES, but the communication mechanism always requires client
 authentication, then effectively a ClientAuthentication.YES requirement exists, and
 so the Delegation.YES requirement must also be satisfied. 
The constraint mechanisms are designed such that client constraints do not weaken server constraints, and vice versa. However, it is certainly possible to specify conflicting constraints. Preferences that conflict with requirements are ignored, and if preferences conflict with each other it is arbitrary as to which (if any) are satisfied, but if there are conflicting requirements the remote call will not be made.
| Modifier and Type | Method and Description | 
|---|---|
MethodConstraints | 
getConstraints()
Returns the client constraints placed on this proxy. 
 | 
RemoteMethodControl | 
setConstraints(MethodConstraints constraints)
Returns a new copy of this proxy with the client constraints set to the specified
 constraints. 
 | 
RemoteMethodControl setConstraints(MethodConstraints constraints)
getConstraints method of
 the copy returns the identical constraints instance. The original proxy is not modified. A
 null value is interpreted as mapping all methods to empty constraints (one that
 has no requirements and no preferences). For any given remote call, the specific client
 requirements and preferences to be satisfied are given by the return value of invoking the
 getConstraints method of the specified MethodConstraints instance with a Method object representing the
 remote method.  Client constraints placed on a proxy are included in the serialized state
 of the proxy. This allows third-party services to be transparent to the client's needs. For
 example, if remote object s1 obtains a proxy for remote object s2,
 and passes that proxy to remote object s3, expecting s3 to invoke a
 remote method on s2, then s1 can control that call by placing its
 constraints directly on the proxy before passing it to s3. If s3
 does not wish to be transparent in this way, then it should explicitly replace the client
 constraints on received proxies with whatever constraints are appropriate to implement its
 own policy.
constraints - client constraints, or nullgetConstraints()MethodConstraints getConstraints()
null, which is interpreted as mapping all methods to empty constraints (one that
 has no requirements and no preferences).nullsetConstraints(net.jini.core.constraint.MethodConstraints)Copyright © GigaSpaces.