com.sun.jini.norm
Class AdminProxy.ConstrainableAdminProxy
java.lang.Object
com.sun.jini.norm.AbstractProxy
com.sun.jini.norm.AdminProxy
com.sun.jini.norm.AdminProxy.ConstrainableAdminProxy
- All Implemented Interfaces:
- DestroyAdmin, Serializable, JoinAdmin, RemoteMethodControl, ReferentUuid
- Enclosing class:
- AdminProxy
static final class AdminProxy.ConstrainableAdminProxy
- extends AdminProxy
- implements RemoteMethodControl
Defines a subclass that implements RemoteMethodControl.
Methods inherited from class com.sun.jini.norm.AdminProxy |
addLookupAttributes, addLookupGroups, addLookupLocators, create, destroy, getLookupAttributes, getLookupGroups, getLookupLocators, modifyLookupAttributes, removeLookupGroups, removeLookupLocators, setLookupGroups, setLookupLocators |
serialVersionUID
private static final long serialVersionUID
- See Also:
- Constant Field Values
AdminProxy.ConstrainableAdminProxy
AdminProxy.ConstrainableAdminProxy(NormServer server,
Uuid serverUuid)
- Creates an instance of this class.
readObject
private void readObject(ObjectInputStream in)
throws IOException,
ClassNotFoundException
- Require server to implement RemoteMethodControl.
- Throws:
IOException
ClassNotFoundException
setConstraints
public RemoteMethodControl setConstraints(MethodConstraints constraints)
- Description copied from interface:
RemoteMethodControl
- Returns a new copy of this proxy with the client constraints set to the
specified constraints. These constraints completely replace (in the
copy) any client constraints previously placed on this proxy; calling
the
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.
- Specified by:
setConstraints
in interface RemoteMethodControl
- Parameters:
constraints
- client constraints, or null
- Returns:
- a new copy of this proxy with the client constraints set to the
specified constraints
- See Also:
RemoteMethodControl.getConstraints()
getConstraints
public MethodConstraints getConstraints()
- Description copied from interface:
RemoteMethodControl
- Returns the client constraints placed on this proxy. The return
value can be
null
, which is interpreted as mapping all
methods to empty constraints (one that has no requirements and no
preferences).
- Specified by:
getConstraints
in interface RemoteMethodControl
- Returns:
- the client constraints, or
null
- See Also:
RemoteMethodControl.setConstraints(net.jini.core.constraint.MethodConstraints)
getProxyTrustIterator
private ProxyTrustIterator getProxyTrustIterator()
- Returns a proxy trust iterator that yields this object's server.
Copyright 2007-2010, multiple authors.
Licensed under the Apache License, Version 2.0, see the NOTICE file for attributions.