Merge
This commit is contained in:
commit
5b3e71f3bd
@ -0,0 +1,188 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation. Sun designates this
|
||||||
|
* particular file as subject to the "Classpath" exception as provided
|
||||||
|
* by Sun in the LICENSE file that accompanied this code.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||||
|
* have any questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.sun.jmx.remote.internal;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.rmi.Remote;
|
||||||
|
import java.rmi.RemoteException;
|
||||||
|
import java.rmi.NoSuchObjectException;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.rmi.Remote;
|
||||||
|
import java.rmi.RemoteException;
|
||||||
|
import java.rmi.NoSuchObjectException;
|
||||||
|
|
||||||
|
import java.security.AccessController;
|
||||||
|
import java.security.PrivilegedAction;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A helper class for RMI-IIOP and CORBA APIs.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public final class IIOPHelper {
|
||||||
|
private IIOPHelper() { }
|
||||||
|
|
||||||
|
// loads IIOPProxy implementation class if available
|
||||||
|
private static final String IMPL_CLASS =
|
||||||
|
"com.sun.jmx.remote.protocol.iiop.IIOPProxyImpl";
|
||||||
|
private static final IIOPProxy proxy =
|
||||||
|
AccessController.doPrivileged(new PrivilegedAction<IIOPProxy>() {
|
||||||
|
public IIOPProxy run() {
|
||||||
|
try {
|
||||||
|
Class<?> c = Class.forName(IMPL_CLASS, true, null);
|
||||||
|
return (IIOPProxy)c.newInstance();
|
||||||
|
} catch (ClassNotFoundException cnf) {
|
||||||
|
return null;
|
||||||
|
} catch (InstantiationException e) {
|
||||||
|
throw new AssertionError(e);
|
||||||
|
} catch (IllegalAccessException e) {
|
||||||
|
throw new AssertionError(e);
|
||||||
|
}
|
||||||
|
}});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if RMI-IIOP and CORBA is available.
|
||||||
|
*/
|
||||||
|
public static boolean isAvailable() {
|
||||||
|
return proxy != null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void ensureAvailable() {
|
||||||
|
if (proxy == null)
|
||||||
|
throw new AssertionError("Should not here");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the given object is a Stub.
|
||||||
|
*/
|
||||||
|
public static boolean isStub(Object obj) {
|
||||||
|
return (proxy == null) ? false : proxy.isStub(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Delegate to which the given Stub delegates.
|
||||||
|
*/
|
||||||
|
public static Object getDelegate(Object stub) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.getDelegate(stub);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the Delegate for a given Stub.
|
||||||
|
*/
|
||||||
|
public static void setDelegate(Object stub, Object delegate) {
|
||||||
|
ensureAvailable();
|
||||||
|
proxy.setDelegate(stub, delegate);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the ORB associated with the given stub
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException
|
||||||
|
* if the object does not support the operation that
|
||||||
|
* was invoked
|
||||||
|
*/
|
||||||
|
public static Object getOrb(Object stub) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.getOrb(stub);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Connects the Stub to the given ORB.
|
||||||
|
*/
|
||||||
|
public static void connect(Object stub, Object orb)
|
||||||
|
throws RemoteException
|
||||||
|
{
|
||||||
|
ensureAvailable();
|
||||||
|
proxy.connect(stub, orb);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the given object is an ORB.
|
||||||
|
*/
|
||||||
|
public static boolean isOrb(Object obj) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.isOrb(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates, and returns, a new ORB instance.
|
||||||
|
*/
|
||||||
|
public static Object createOrb(String[] args, Properties props) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.createOrb(args, props);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts a string, produced by the object_to_string method, back
|
||||||
|
* to a CORBA object reference.
|
||||||
|
*/
|
||||||
|
public static Object stringToObject(Object orb, String str) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.stringToObject(orb, str);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts the given CORBA object reference to a string.
|
||||||
|
*/
|
||||||
|
public static String objectToString(Object orb, Object obj) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.objectToString(orb, obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks to ensure that an object of a remote or abstract interface
|
||||||
|
* type can be cast to a desired type.
|
||||||
|
*/
|
||||||
|
public static <T> T narrow(Object narrowFrom, Class<T> narrowTo) {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.narrow(narrowFrom, narrowTo);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes a server object ready to receive remote calls
|
||||||
|
*/
|
||||||
|
public static void exportObject(Remote obj) throws RemoteException {
|
||||||
|
ensureAvailable();
|
||||||
|
proxy.exportObject(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deregisters a server object from the runtime.
|
||||||
|
*/
|
||||||
|
public static void unexportObject(Remote obj) throws NoSuchObjectException {
|
||||||
|
ensureAvailable();
|
||||||
|
proxy.unexportObject(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a stub for the given server object.
|
||||||
|
*/
|
||||||
|
public static Remote toStub(Remote obj) throws NoSuchObjectException {
|
||||||
|
ensureAvailable();
|
||||||
|
return proxy.toStub(obj);
|
||||||
|
}
|
||||||
|
}
|
110
jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPProxy.java
Normal file
110
jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPProxy.java
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation. Sun designates this
|
||||||
|
* particular file as subject to the "Classpath" exception as provided
|
||||||
|
* by Sun in the LICENSE file that accompanied this code.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||||
|
* have any questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.sun.jmx.remote.internal;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.rmi.Remote;
|
||||||
|
import java.rmi.RemoteException;
|
||||||
|
import java.rmi.NoSuchObjectException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An interface to a subset of the RMI-IIOP and CORBA APIs to avoid a
|
||||||
|
* static dependencies on the types defined by these APIs.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public interface IIOPProxy {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the given object is a Stub.
|
||||||
|
*/
|
||||||
|
boolean isStub(Object obj);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Delegate to which the given Stub delegates.
|
||||||
|
*/
|
||||||
|
Object getDelegate(Object stub);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the Delegate for a given Stub.
|
||||||
|
*/
|
||||||
|
void setDelegate(Object stub, Object delegate);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the ORB associated with the given stub
|
||||||
|
*
|
||||||
|
* @throws UnsupportedOperationException
|
||||||
|
* if the object does not support the operation that
|
||||||
|
* was invoked
|
||||||
|
*/
|
||||||
|
Object getOrb(Object stub);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Connects the Stub to the given ORB.
|
||||||
|
*/
|
||||||
|
void connect(Object stub, Object orb) throws RemoteException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns true if the given object is an ORB.
|
||||||
|
*/
|
||||||
|
boolean isOrb(Object obj);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates, and returns, a new ORB instance.
|
||||||
|
*/
|
||||||
|
Object createOrb(String[] args, Properties props);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts a string, produced by the object_to_string method, back
|
||||||
|
* to a CORBA object reference.
|
||||||
|
*/
|
||||||
|
Object stringToObject(Object orb, String str);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts the given CORBA object reference to a string.
|
||||||
|
*/
|
||||||
|
String objectToString(Object orb, Object obj);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks to ensure that an object of a remote or abstract interface
|
||||||
|
* type can be cast to a desired type.
|
||||||
|
*/
|
||||||
|
<T> T narrow(Object narrowFrom, Class<T> narrowTo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Makes a server object ready to receive remote calls
|
||||||
|
*/
|
||||||
|
void exportObject(Remote obj) throws RemoteException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deregisters a server object from the runtime.
|
||||||
|
*/
|
||||||
|
void unexportObject(Remote obj) throws NoSuchObjectException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a stub for the given server object.
|
||||||
|
*/
|
||||||
|
Remote toStub(Remote obj) throws NoSuchObjectException;
|
||||||
|
}
|
@ -0,0 +1,119 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation. Sun designates this
|
||||||
|
* particular file as subject to the "Classpath" exception as provided
|
||||||
|
* by Sun in the LICENSE file that accompanied this code.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
|
||||||
|
* CA 95054 USA or visit www.sun.com if you need additional information or
|
||||||
|
* have any questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.sun.jmx.remote.protocol.iiop;
|
||||||
|
|
||||||
|
import org.omg.CORBA.ORB;
|
||||||
|
import org.omg.CORBA.portable.Delegate;
|
||||||
|
import javax.rmi.PortableRemoteObject;
|
||||||
|
import javax.rmi.CORBA.Stub;
|
||||||
|
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.rmi.Remote;
|
||||||
|
import java.rmi.RemoteException;
|
||||||
|
import java.rmi.NoSuchObjectException;
|
||||||
|
|
||||||
|
import com.sun.jmx.remote.internal.IIOPProxy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An implementatin of IIOPProxy that simply delegates to the appropriate
|
||||||
|
* RMI-IIOP and CORBA APIs.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class IIOPProxyImpl implements IIOPProxy {
|
||||||
|
public IIOPProxyImpl() { }
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isStub(Object obj) {
|
||||||
|
return (obj instanceof Stub);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object getDelegate(Object stub) {
|
||||||
|
return ((Stub)stub)._get_delegate();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setDelegate(Object stub, Object delegate) {
|
||||||
|
((Stub)stub)._set_delegate((Delegate)delegate);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object getOrb(Object stub) {
|
||||||
|
try {
|
||||||
|
return ((Stub)stub)._orb();
|
||||||
|
} catch (org.omg.CORBA.BAD_OPERATION x) {
|
||||||
|
throw new UnsupportedOperationException(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void connect(Object stub, Object orb)
|
||||||
|
throws RemoteException
|
||||||
|
{
|
||||||
|
((Stub)stub).connect((ORB)orb);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isOrb(Object obj) {
|
||||||
|
return (obj instanceof ORB);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object createOrb(String[] args, Properties props) {
|
||||||
|
return ORB.init(args, props);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object stringToObject(Object orb, String str) {
|
||||||
|
return ((ORB)orb).string_to_object(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String objectToString(Object orb, Object obj) {
|
||||||
|
return ((ORB)orb).object_to_string((org.omg.CORBA.Object)obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
public <T> T narrow(Object narrowFrom, Class<T> narrowTo) {
|
||||||
|
return (T)PortableRemoteObject.narrow(narrowFrom, narrowTo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void exportObject(Remote obj) throws RemoteException {
|
||||||
|
PortableRemoteObject.exportObject(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void unexportObject(Remote obj) throws NoSuchObjectException {
|
||||||
|
PortableRemoteObject.unexportObject(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Remote toStub(Remote obj) throws NoSuchObjectException {
|
||||||
|
return PortableRemoteObject.toStub(obj);
|
||||||
|
}
|
||||||
|
}
|
@ -23,7 +23,7 @@
|
|||||||
* have any questions.
|
* have any questions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package com.sun.jmx.remote.internal;
|
package com.sun.jmx.remote.protocol.iiop;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
@ -225,4 +225,72 @@ insert-buffer'd into a Java program."
|
|||||||
(insert "\"")
|
(insert "\"")
|
||||||
(switch-to-buffer buf)))
|
(switch-to-buffer buf)))
|
||||||
|
|
||||||
|
Alternatively, the following class reads a class file and outputs a string
|
||||||
|
that can be used by the stringToBytes method above.
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
public class BytesToString {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws IOException {
|
||||||
|
File f = new File(args[0]);
|
||||||
|
int len = (int)f.length();
|
||||||
|
byte[] classBytes = new byte[len];
|
||||||
|
|
||||||
|
FileInputStream in = new FileInputStream(args[0]);
|
||||||
|
try {
|
||||||
|
int pos = 0;
|
||||||
|
for (;;) {
|
||||||
|
int n = in.read(classBytes, pos, (len-pos));
|
||||||
|
if (n < 0)
|
||||||
|
throw new RuntimeException("class file changed??");
|
||||||
|
pos += n;
|
||||||
|
if (pos >= n)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
in.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
int pos = 0;
|
||||||
|
boolean lastWasOctal = false;
|
||||||
|
for (int i=0; i<len; i++) {
|
||||||
|
int value = classBytes[i];
|
||||||
|
if (value < 0)
|
||||||
|
value += 256;
|
||||||
|
String s = null;
|
||||||
|
if (value == '\\')
|
||||||
|
s = "\\\\";
|
||||||
|
else if (value == '\"')
|
||||||
|
s = "\\\"";
|
||||||
|
else {
|
||||||
|
if ((value >= 32 && value < 127) && ((!lastWasOctal ||
|
||||||
|
(value < '0' || value > '7')))) {
|
||||||
|
s = Character.toString((char)value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (s == null) {
|
||||||
|
s = "\\" + Integer.toString(value, 8);
|
||||||
|
lastWasOctal = true;
|
||||||
|
} else {
|
||||||
|
lastWasOctal = false;
|
||||||
|
}
|
||||||
|
if (pos > 61) {
|
||||||
|
System.out.print("\"");
|
||||||
|
if (i<len)
|
||||||
|
System.out.print("+");
|
||||||
|
System.out.println();
|
||||||
|
pos = 0;
|
||||||
|
}
|
||||||
|
if (pos == 0)
|
||||||
|
System.out.print(" \"");
|
||||||
|
System.out.print(s);
|
||||||
|
pos += s.length();
|
||||||
|
}
|
||||||
|
System.out.println("\"");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
@ -29,8 +29,8 @@ import com.sun.jmx.mbeanserver.Util;
|
|||||||
import com.sun.jmx.remote.internal.ClientCommunicatorAdmin;
|
import com.sun.jmx.remote.internal.ClientCommunicatorAdmin;
|
||||||
import com.sun.jmx.remote.internal.ClientListenerInfo;
|
import com.sun.jmx.remote.internal.ClientListenerInfo;
|
||||||
import com.sun.jmx.remote.internal.ClientNotifForwarder;
|
import com.sun.jmx.remote.internal.ClientNotifForwarder;
|
||||||
import com.sun.jmx.remote.internal.ProxyInputStream;
|
|
||||||
import com.sun.jmx.remote.internal.ProxyRef;
|
import com.sun.jmx.remote.internal.ProxyRef;
|
||||||
|
import com.sun.jmx.remote.internal.IIOPHelper;
|
||||||
import com.sun.jmx.remote.util.ClassLogger;
|
import com.sun.jmx.remote.util.ClassLogger;
|
||||||
import com.sun.jmx.remote.util.EnvHelp;
|
import com.sun.jmx.remote.util.EnvHelp;
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
@ -101,12 +101,8 @@ import javax.management.remote.NotificationResult;
|
|||||||
import javax.management.remote.JMXAddressable;
|
import javax.management.remote.JMXAddressable;
|
||||||
import javax.naming.InitialContext;
|
import javax.naming.InitialContext;
|
||||||
import javax.naming.NamingException;
|
import javax.naming.NamingException;
|
||||||
import javax.rmi.CORBA.Stub;
|
|
||||||
import javax.rmi.PortableRemoteObject;
|
|
||||||
import javax.rmi.ssl.SslRMIClientSocketFactory;
|
import javax.rmi.ssl.SslRMIClientSocketFactory;
|
||||||
import javax.security.auth.Subject;
|
import javax.security.auth.Subject;
|
||||||
import org.omg.CORBA.BAD_OPERATION;
|
|
||||||
import org.omg.CORBA.ORB;
|
|
||||||
import sun.rmi.server.UnicastRef2;
|
import sun.rmi.server.UnicastRef2;
|
||||||
import sun.rmi.transport.LiveRef;
|
import sun.rmi.transport.LiveRef;
|
||||||
|
|
||||||
@ -1693,12 +1689,12 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
static RMIServer connectStub(RMIServer rmiServer,
|
static RMIServer connectStub(RMIServer rmiServer,
|
||||||
Map<String, ?> environment)
|
Map<String, ?> environment)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
if (rmiServer instanceof javax.rmi.CORBA.Stub) {
|
if (IIOPHelper.isStub(rmiServer)) {
|
||||||
javax.rmi.CORBA.Stub stub = (javax.rmi.CORBA.Stub) rmiServer;
|
|
||||||
try {
|
try {
|
||||||
stub._orb();
|
IIOPHelper.getOrb(rmiServer);
|
||||||
} catch (BAD_OPERATION x) {
|
} catch (UnsupportedOperationException x) {
|
||||||
stub.connect(resolveOrb(environment));
|
// BAD_OPERATION
|
||||||
|
IIOPHelper.connect(rmiServer, resolveOrb(environment));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return rmiServer;
|
return rmiServer;
|
||||||
@ -1725,22 +1721,22 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
* does not point to an {@link org.omg.CORBA.ORB ORB}.
|
* does not point to an {@link org.omg.CORBA.ORB ORB}.
|
||||||
* @exception IOException if the ORB initialization failed.
|
* @exception IOException if the ORB initialization failed.
|
||||||
**/
|
**/
|
||||||
static ORB resolveOrb(Map<String, ?> environment)
|
static Object resolveOrb(Map<String, ?> environment)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
if (environment != null) {
|
if (environment != null) {
|
||||||
final Object orb = environment.get(EnvHelp.DEFAULT_ORB);
|
final Object orb = environment.get(EnvHelp.DEFAULT_ORB);
|
||||||
if (orb != null && !(orb instanceof ORB))
|
if (orb != null && !(IIOPHelper.isOrb(orb)))
|
||||||
throw new IllegalArgumentException(EnvHelp.DEFAULT_ORB +
|
throw new IllegalArgumentException(EnvHelp.DEFAULT_ORB +
|
||||||
" must be an instance of org.omg.CORBA.ORB.");
|
" must be an instance of org.omg.CORBA.ORB.");
|
||||||
if (orb != null) return (ORB)orb;
|
if (orb != null) return orb;
|
||||||
}
|
}
|
||||||
final ORB orb =
|
final Object orb =
|
||||||
(RMIConnector.orb==null)?null:RMIConnector.orb.get();
|
(RMIConnector.orb==null)?null:RMIConnector.orb.get();
|
||||||
if (orb != null) return orb;
|
if (orb != null) return orb;
|
||||||
|
|
||||||
final ORB newOrb =
|
final Object newOrb =
|
||||||
ORB.init((String[])null, (Properties)null);
|
IIOPHelper.createOrb((String[])null, (Properties)null);
|
||||||
RMIConnector.orb = new WeakReference<ORB>(newOrb);
|
RMIConnector.orb = new WeakReference<Object>(newOrb);
|
||||||
return newOrb;
|
return newOrb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1878,9 +1874,11 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
return findRMIServerJNDI(path.substring(6,end), environment, isIiop);
|
return findRMIServerJNDI(path.substring(6,end), environment, isIiop);
|
||||||
else if (path.startsWith("/stub/"))
|
else if (path.startsWith("/stub/"))
|
||||||
return findRMIServerJRMP(path.substring(6,end), environment, isIiop);
|
return findRMIServerJRMP(path.substring(6,end), environment, isIiop);
|
||||||
else if (path.startsWith("/ior/"))
|
else if (path.startsWith("/ior/")) {
|
||||||
|
if (!IIOPHelper.isAvailable())
|
||||||
|
throw new IOException("iiop protocol not available");
|
||||||
return findRMIServerIIOP(path.substring(5,end), environment, isIiop);
|
return findRMIServerIIOP(path.substring(5,end), environment, isIiop);
|
||||||
else {
|
} else {
|
||||||
final String msg = "URL path must begin with /jndi/ or /stub/ " +
|
final String msg = "URL path must begin with /jndi/ or /stub/ " +
|
||||||
"or /ior/: " + path;
|
"or /ior/: " + path;
|
||||||
throw new MalformedURLException(msg);
|
throw new MalformedURLException(msg);
|
||||||
@ -1922,8 +1920,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
|
|
||||||
private static RMIServer narrowIIOPServer(Object objref) {
|
private static RMIServer narrowIIOPServer(Object objref) {
|
||||||
try {
|
try {
|
||||||
return (RMIServer)
|
return IIOPHelper.narrow(objref, RMIServer.class);
|
||||||
PortableRemoteObject.narrow(objref, RMIServer.class);
|
|
||||||
} catch (ClassCastException e) {
|
} catch (ClassCastException e) {
|
||||||
if (logger.traceOn())
|
if (logger.traceOn())
|
||||||
logger.trace("narrowIIOPServer","Failed to narrow objref=" +
|
logger.trace("narrowIIOPServer","Failed to narrow objref=" +
|
||||||
@ -1935,10 +1932,9 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
|
|
||||||
private RMIServer findRMIServerIIOP(String ior, Map<String, ?> env, boolean isIiop) {
|
private RMIServer findRMIServerIIOP(String ior, Map<String, ?> env, boolean isIiop) {
|
||||||
// could forbid "rmi:" URL here -- but do we need to?
|
// could forbid "rmi:" URL here -- but do we need to?
|
||||||
final ORB orb = (ORB)
|
final Object orb = env.get(EnvHelp.DEFAULT_ORB);
|
||||||
env.get(EnvHelp.DEFAULT_ORB);
|
final Object stub = IIOPHelper.stringToObject(orb, ior);
|
||||||
final Object stub = orb.string_to_object(ior);
|
return IIOPHelper.narrow(stub, RMIServer.class);
|
||||||
return (RMIServer) PortableRemoteObject.narrow(stub, RMIServer.class);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private RMIServer findRMIServerJRMP(String base64, Map<String, ?> env, boolean isIiop)
|
private RMIServer findRMIServerJRMP(String base64, Map<String, ?> env, boolean isIiop)
|
||||||
@ -1964,7 +1960,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
} catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
throw new MalformedURLException("Class not found: " + e);
|
throw new MalformedURLException("Class not found: " + e);
|
||||||
}
|
}
|
||||||
return (RMIServer) PortableRemoteObject.narrow(stub, RMIServer.class);
|
return (RMIServer)stub;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final class ObjectInputStreamWithLoader
|
private static final class ObjectInputStreamWithLoader
|
||||||
@ -2205,9 +2201,9 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
again, using reflection.
|
again, using reflection.
|
||||||
|
|
||||||
The strings below encode the following two Java classes,
|
The strings below encode the following two Java classes,
|
||||||
compiled using J2SE 1.4.2 with javac -g:none.
|
compiled using javac -g:none.
|
||||||
|
|
||||||
package com.sun.jmx.remote.internal;
|
package com.sun.jmx.remote.protocol.iiop;
|
||||||
|
|
||||||
import org.omg.stub.javax.management.remote.rmi._RMIConnection_Stub;
|
import org.omg.stub.javax.management.remote.rmi._RMIConnection_Stub;
|
||||||
|
|
||||||
@ -2228,12 +2224,13 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void _releaseReply(InputStream in) {
|
public void _releaseReply(InputStream in) {
|
||||||
PInputStream pis = (PInputStream) in;
|
if (in != null)
|
||||||
super._releaseReply(pis.getProxiedInputStream());
|
in = ((PInputStream)in).getProxiedInputStream();
|
||||||
|
super._releaseReply(in);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
package com.sun.jmx.remote.internal;
|
package com.sun.jmx.remote.protocol.iiop;
|
||||||
|
|
||||||
public class PInputStream extends ProxyInputStream {
|
public class PInputStream extends ProxyInputStream {
|
||||||
public PInputStream(org.omg.CORBA.portable.InputStream in) {
|
public PInputStream(org.omg.CORBA.portable.InputStream in) {
|
||||||
@ -2252,49 +2249,52 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
private static final String iiopConnectionStubClassName =
|
private static final String iiopConnectionStubClassName =
|
||||||
"org.omg.stub.javax.management.remote.rmi._RMIConnection_Stub";
|
"org.omg.stub.javax.management.remote.rmi._RMIConnection_Stub";
|
||||||
private static final String proxyStubClassName =
|
private static final String proxyStubClassName =
|
||||||
"com.sun.jmx.remote.internal.ProxyStub";
|
"com.sun.jmx.remote.protocol.iiop.ProxyStub";
|
||||||
|
private static final String ProxyInputStreamClassName =
|
||||||
|
"com.sun.jmx.remote.protocol.iiop.ProxyInputStream";
|
||||||
private static final String pInputStreamClassName =
|
private static final String pInputStreamClassName =
|
||||||
"com.sun.jmx.remote.internal.PInputStream";
|
"com.sun.jmx.remote.protocol.iiop.PInputStream";
|
||||||
private static final Class<?> proxyStubClass;
|
private static final Class<?> proxyStubClass;
|
||||||
static {
|
static {
|
||||||
final String proxyStubByteCodeString =
|
final String proxyStubByteCodeString =
|
||||||
"\312\376\272\276\0\0\0.\0)\12\0\14\0\26\7\0\27\12\0\14\0\30\12"+
|
"\312\376\272\276\0\0\0\63\0+\12\0\14\0\30\7\0\31\12\0\14\0\32\12"+
|
||||||
"\0\2\0\31\7\0\32\12\0\5\0\33\12\0\5\0\34\12\0\5\0\35\12\0\2\0"+
|
"\0\2\0\33\7\0\34\12\0\5\0\35\12\0\5\0\36\12\0\5\0\37\12\0\2\0 "+
|
||||||
"\36\12\0\14\0\37\7\0\40\7\0!\1\0\6<init>\1\0\3()V\1\0\4Code\1"+
|
"\12\0\14\0!\7\0\"\7\0#\1\0\6<init>\1\0\3()V\1\0\4Code\1\0\7_in"+
|
||||||
"\0\7_invoke\1\0K(Lorg/omg/CORBA/portable/OutputStream;)Lorg/o"+
|
"voke\1\0K(Lorg/omg/CORBA/portable/OutputStream;)Lorg/omg/CORBA"+
|
||||||
"mg/CORBA/portable/InputStream;\1\0\12Exceptions\7\0\"\1\0\15_"+
|
"/portable/InputStream;\1\0\15StackMapTable\7\0\34\1\0\12Except"+
|
||||||
"releaseReply\1\0'(Lorg/omg/CORBA/portable/InputStream;)V\14\0"+
|
"ions\7\0$\1\0\15_releaseReply\1\0'(Lorg/omg/CORBA/portable/Inp"+
|
||||||
"\15\0\16\1\0(com/sun/jmx/remote/internal/PInputStream\14\0\20"+
|
"utStream;)V\14\0\15\0\16\1\0-com/sun/jmx/remote/protocol/iiop/"+
|
||||||
"\0\21\14\0\15\0\25\1\0+org/omg/CORBA/portable/ApplicationExce"+
|
"PInputStream\14\0\20\0\21\14\0\15\0\27\1\0+org/omg/CORBA/porta"+
|
||||||
"ption\14\0#\0$\14\0%\0&\14\0\15\0'\14\0(\0$\14\0\24\0\25\1\0%"+
|
"ble/ApplicationException\14\0%\0&\14\0'\0(\14\0\15\0)\14\0*\0&"+
|
||||||
"com/sun/jmx/remote/internal/ProxyStub\1\0<org/omg/stub/javax/"+
|
"\14\0\26\0\27\1\0*com/sun/jmx/remote/protocol/iiop/ProxyStub\1"+
|
||||||
"management/remote/rmi/_RMIConnection_Stub\1\0)org/omg/CORBA/p"+
|
"\0<org/omg/stub/javax/management/remote/rmi/_RMIConnection_Stu"+
|
||||||
"ortable/RemarshalException\1\0\16getInputStream\1\0&()Lorg/om"+
|
"b\1\0)org/omg/CORBA/portable/RemarshalException\1\0\16getInput"+
|
||||||
"g/CORBA/portable/InputStream;\1\0\5getId\1\0\24()Ljava/lang/S"+
|
"Stream\1\0&()Lorg/omg/CORBA/portable/InputStream;\1\0\5getId\1"+
|
||||||
"tring;\1\09(Ljava/lang/String;Lorg/omg/CORBA/portable/InputSt"+
|
"\0\24()Ljava/lang/String;\1\09(Ljava/lang/String;Lorg/omg/CORB"+
|
||||||
"ream;)V\1\0\25getProxiedInputStream\0!\0\13\0\14\0\0\0\0\0\3\0"+
|
"A/portable/InputStream;)V\1\0\25getProxiedInputStream\0!\0\13\0"+
|
||||||
"\1\0\15\0\16\0\1\0\17\0\0\0\21\0\1\0\1\0\0\0\5*\267\0\1\261\0"+
|
"\14\0\0\0\0\0\3\0\1\0\15\0\16\0\1\0\17\0\0\0\21\0\1\0\1\0\0\0\5"+
|
||||||
"\0\0\0\0\1\0\20\0\21\0\2\0\17\0\0\0;\0\4\0\4\0\0\0'\273\0\2Y*"+
|
"*\267\0\1\261\0\0\0\0\0\1\0\20\0\21\0\2\0\17\0\0\0G\0\4\0\4\0\0"+
|
||||||
"+\267\0\3\267\0\4\260M\273\0\2Y,\266\0\6\267\0\4N\273\0\5Y,\266"+
|
"\0'\273\0\2Y*+\267\0\3\267\0\4\260M\273\0\2Y,\266\0\6\267\0\4N"+
|
||||||
"\0\7-\267\0\10\277\0\1\0\0\0\14\0\15\0\5\0\0\0\22\0\0\0\6\0\2"+
|
"\273\0\5Y,\266\0\7-\267\0\10\277\0\1\0\0\0\14\0\15\0\5\0\1\0\22"+
|
||||||
"\0\5\0\23\0\1\0\24\0\25\0\1\0\17\0\0\0\36\0\2\0\2\0\0\0\22+\306"+
|
"\0\0\0\6\0\1M\7\0\23\0\24\0\0\0\6\0\2\0\5\0\25\0\1\0\26\0\27\0"+
|
||||||
"\0\13+\300\0\2\266\0\11L*+\267\0\12\261\0\0\0\0\0\0";
|
"\1\0\17\0\0\0'\0\2\0\2\0\0\0\22+\306\0\13+\300\0\2\266\0\11L*+"+
|
||||||
|
"\267\0\12\261\0\0\0\1\0\22\0\0\0\3\0\1\14\0\0";
|
||||||
final String pInputStreamByteCodeString =
|
final String pInputStreamByteCodeString =
|
||||||
"\312\376\272\276\0\0\0.\0\36\12\0\7\0\17\11\0\6\0\20\12\0\21\0"+
|
"\312\376\272\276\0\0\0\63\0\36\12\0\7\0\17\11\0\6\0\20\12\0\21"+
|
||||||
"\22\12\0\6\0\23\12\0\24\0\25\7\0\26\7\0\27\1\0\6<init>\1\0'(L"+
|
"\0\22\12\0\6\0\23\12\0\24\0\25\7\0\26\7\0\27\1\0\6<init>\1\0'("+
|
||||||
"org/omg/CORBA/portable/InputStream;)V\1\0\4Code\1\0\10read_an"+
|
"Lorg/omg/CORBA/portable/InputStream;)V\1\0\4Code\1\0\10read_an"+
|
||||||
"y\1\0\25()Lorg/omg/CORBA/Any;\1\0\12read_value\1\0)(Ljava/lan"+
|
"y\1\0\25()Lorg/omg/CORBA/Any;\1\0\12read_value\1\0)(Ljava/lang"+
|
||||||
"g/Class;)Ljava/io/Serializable;\14\0\10\0\11\14\0\30\0\31\7\0"+
|
"/Class;)Ljava/io/Serializable;\14\0\10\0\11\14\0\30\0\31\7\0\32"+
|
||||||
"\32\14\0\13\0\14\14\0\33\0\34\7\0\35\14\0\15\0\16\1\0(com/sun"+
|
"\14\0\13\0\14\14\0\33\0\34\7\0\35\14\0\15\0\16\1\0-com/sun/jmx"+
|
||||||
"/jmx/remote/internal/PInputStream\1\0,com/sun/jmx/remote/inte"+
|
"/remote/protocol/iiop/PInputStream\1\0\61com/sun/jmx/remote/pr"+
|
||||||
"rnal/ProxyInputStream\1\0\2in\1\0$Lorg/omg/CORBA/portable/Inp"+
|
"otocol/iiop/ProxyInputStream\1\0\2in\1\0$Lorg/omg/CORBA/portab"+
|
||||||
"utStream;\1\0\"org/omg/CORBA/portable/InputStream\1\0\6narrow"+
|
"le/InputStream;\1\0\"org/omg/CORBA/portable/InputStream\1\0\6n"+
|
||||||
"\1\0*()Lorg/omg/CORBA_2_3/portable/InputStream;\1\0&org/omg/C"+
|
"arrow\1\0*()Lorg/omg/CORBA_2_3/portable/InputStream;\1\0&org/o"+
|
||||||
"ORBA_2_3/portable/InputStream\0!\0\6\0\7\0\0\0\0\0\3\0\1\0\10"+
|
"mg/CORBA_2_3/portable/InputStream\0!\0\6\0\7\0\0\0\0\0\3\0\1\0"+
|
||||||
"\0\11\0\1\0\12\0\0\0\22\0\2\0\2\0\0\0\6*+\267\0\1\261\0\0\0\0"+
|
"\10\0\11\0\1\0\12\0\0\0\22\0\2\0\2\0\0\0\6*+\267\0\1\261\0\0\0"+
|
||||||
"\0\1\0\13\0\14\0\1\0\12\0\0\0\24\0\1\0\1\0\0\0\10*\264\0\2\266"+
|
"\0\0\1\0\13\0\14\0\1\0\12\0\0\0\24\0\1\0\1\0\0\0\10*\264\0\2\266"+
|
||||||
"\0\3\260\0\0\0\0\0\1\0\15\0\16\0\1\0\12\0\0\0\25\0\2\0\2\0\0\0"+
|
"\0\3\260\0\0\0\0\0\1\0\15\0\16\0\1\0\12\0\0\0\25\0\2\0\2\0\0\0"+
|
||||||
"\11*\266\0\4+\266\0\5\260\0\0\0\0\0\0";
|
"\11*\266\0\4+\266\0\5\260\0\0\0\0\0\0";
|
||||||
final byte[] proxyStubByteCode =
|
final byte[] proxyStubByteCode =
|
||||||
@ -2305,12 +2305,12 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
final byte[][] byteCodes = {proxyStubByteCode, pInputStreamByteCode};
|
final byte[][] byteCodes = {proxyStubByteCode, pInputStreamByteCode};
|
||||||
final String[] otherClassNames = {
|
final String[] otherClassNames = {
|
||||||
iiopConnectionStubClassName,
|
iiopConnectionStubClassName,
|
||||||
ProxyInputStream.class.getName(),
|
ProxyInputStreamClassName,
|
||||||
};
|
};
|
||||||
PrivilegedExceptionAction<Class<?>> action =
|
if (IIOPHelper.isAvailable()) {
|
||||||
|
PrivilegedExceptionAction<Class<?>> action =
|
||||||
new PrivilegedExceptionAction<Class<?>>() {
|
new PrivilegedExceptionAction<Class<?>>() {
|
||||||
public Class<?> run() throws Exception {
|
public Class<?> run() throws Exception {
|
||||||
|
|
||||||
Class thisClass = RMIConnector.class;
|
Class thisClass = RMIConnector.class;
|
||||||
ClassLoader thisLoader = thisClass.getClassLoader();
|
ClassLoader thisLoader = thisClass.getClassLoader();
|
||||||
ProtectionDomain thisProtectionDomain =
|
ProtectionDomain thisProtectionDomain =
|
||||||
@ -2322,24 +2322,27 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
thisLoader,
|
thisLoader,
|
||||||
thisProtectionDomain);
|
thisProtectionDomain);
|
||||||
return cl.loadClass(proxyStubClassName);
|
return cl.loadClass(proxyStubClassName);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
Class<?> stubClass;
|
||||||
|
try {
|
||||||
|
stubClass = AccessController.doPrivileged(action);
|
||||||
|
} catch (Exception e) {
|
||||||
|
logger.error("<clinit>",
|
||||||
|
"Unexpected exception making shadow IIOP stub class: "+e);
|
||||||
|
logger.debug("<clinit>",e);
|
||||||
|
stubClass = null;
|
||||||
}
|
}
|
||||||
};
|
proxyStubClass = stubClass;
|
||||||
Class<?> stubClass;
|
} else {
|
||||||
try {
|
proxyStubClass = null;
|
||||||
stubClass = AccessController.doPrivileged(action);
|
|
||||||
} catch (Exception e) {
|
|
||||||
logger.error("<clinit>",
|
|
||||||
"Unexpected exception making shadow IIOP stub class: "+e);
|
|
||||||
logger.debug("<clinit>",e);
|
|
||||||
stubClass = null;
|
|
||||||
}
|
}
|
||||||
proxyStubClass = stubClass;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static RMIConnection shadowIiopStub(Stub stub)
|
private static RMIConnection shadowIiopStub(Object stub)
|
||||||
throws InstantiationException, IllegalAccessException {
|
throws InstantiationException, IllegalAccessException {
|
||||||
Stub proxyStub = (Stub) proxyStubClass.newInstance();
|
Object proxyStub = proxyStubClass.newInstance();
|
||||||
proxyStub._set_delegate(stub._get_delegate());
|
IIOPHelper.setDelegate(proxyStub, IIOPHelper.getDelegate(stub));
|
||||||
return (RMIConnection) proxyStub;
|
return (RMIConnection) proxyStub;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2353,7 +2356,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
if (c.getClass() == rmiConnectionImplStubClass)
|
if (c.getClass() == rmiConnectionImplStubClass)
|
||||||
return shadowJrmpStub((RemoteObject) c);
|
return shadowJrmpStub((RemoteObject) c);
|
||||||
if (c.getClass().getName().equals(iiopConnectionStubClassName))
|
if (c.getClass().getName().equals(iiopConnectionStubClassName))
|
||||||
return shadowIiopStub((Stub) c);
|
return shadowIiopStub(c);
|
||||||
logger.trace("getConnection",
|
logger.trace("getConnection",
|
||||||
"Did not wrap " + c.getClass() + " to foil " +
|
"Did not wrap " + c.getClass() + " to foil " +
|
||||||
"stack search for classes: class loading semantics " +
|
"stack search for classes: class loading semantics " +
|
||||||
@ -2539,7 +2542,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable
|
|||||||
* A static WeakReference to an {@link org.omg.CORBA.ORB ORB} to
|
* A static WeakReference to an {@link org.omg.CORBA.ORB ORB} to
|
||||||
* connect unconnected stubs.
|
* connect unconnected stubs.
|
||||||
**/
|
**/
|
||||||
private static volatile WeakReference<ORB> orb = null;
|
private static volatile WeakReference<Object> orb = null;
|
||||||
|
|
||||||
// TRACES & DEBUG
|
// TRACES & DEBUG
|
||||||
//---------------
|
//---------------
|
||||||
|
@ -27,6 +27,7 @@ package javax.management.remote.rmi;
|
|||||||
|
|
||||||
|
|
||||||
import com.sun.jmx.remote.security.MBeanServerFileAccessController;
|
import com.sun.jmx.remote.security.MBeanServerFileAccessController;
|
||||||
|
import com.sun.jmx.remote.internal.IIOPHelper;
|
||||||
import com.sun.jmx.remote.util.ClassLogger;
|
import com.sun.jmx.remote.util.ClassLogger;
|
||||||
import com.sun.jmx.remote.util.EnvHelp;
|
import com.sun.jmx.remote.util.EnvHelp;
|
||||||
|
|
||||||
@ -674,7 +675,7 @@ public class RMIConnectorServer extends JMXConnectorServer {
|
|||||||
final int port;
|
final int port;
|
||||||
|
|
||||||
if (address == null) {
|
if (address == null) {
|
||||||
if (rmiServer instanceof javax.rmi.CORBA.Stub)
|
if (IIOPHelper.isStub(rmiServer))
|
||||||
protocol = "iiop";
|
protocol = "iiop";
|
||||||
else
|
else
|
||||||
protocol = "rmi";
|
protocol = "rmi";
|
||||||
@ -712,7 +713,7 @@ public class RMIConnectorServer extends JMXConnectorServer {
|
|||||||
**/
|
**/
|
||||||
static String encodeStub(
|
static String encodeStub(
|
||||||
RMIServer rmiServer, Map<String, ?> env) throws IOException {
|
RMIServer rmiServer, Map<String, ?> env) throws IOException {
|
||||||
if (rmiServer instanceof javax.rmi.CORBA.Stub)
|
if (IIOPHelper.isStub(rmiServer))
|
||||||
return "/ior/" + encodeIIOPStub(rmiServer, env);
|
return "/ior/" + encodeIIOPStub(rmiServer, env);
|
||||||
else
|
else
|
||||||
return "/stub/" + encodeJRMPStub(rmiServer, env);
|
return "/stub/" + encodeJRMPStub(rmiServer, env);
|
||||||
@ -733,10 +734,9 @@ public class RMIConnectorServer extends JMXConnectorServer {
|
|||||||
RMIServer rmiServer, Map<String, ?> env)
|
RMIServer rmiServer, Map<String, ?> env)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
try {
|
try {
|
||||||
javax.rmi.CORBA.Stub stub =
|
Object orb = IIOPHelper.getOrb(rmiServer);
|
||||||
(javax.rmi.CORBA.Stub) rmiServer;
|
return IIOPHelper.objectToString(orb, rmiServer);
|
||||||
return stub._orb().object_to_string(stub);
|
} catch (RuntimeException x) {
|
||||||
} catch (org.omg.CORBA.BAD_OPERATION x) {
|
|
||||||
throw newIOException(x.getMessage(), x);
|
throw newIOException(x.getMessage(), x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,9 +33,10 @@ import java.security.PrivilegedActionException;
|
|||||||
import java.security.PrivilegedExceptionAction;
|
import java.security.PrivilegedExceptionAction;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import javax.rmi.PortableRemoteObject;
|
|
||||||
import javax.security.auth.Subject;
|
import javax.security.auth.Subject;
|
||||||
|
|
||||||
|
import com.sun.jmx.remote.internal.IIOPHelper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>An {@link RMIServerImpl} that is exported through IIOP and that
|
* <p>An {@link RMIServerImpl} that is exported through IIOP and that
|
||||||
* creates client connections as RMI objects exported through IIOP.
|
* creates client connections as RMI objects exported through IIOP.
|
||||||
@ -65,7 +66,7 @@ public class RMIIIOPServerImpl extends RMIServerImpl {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void export() throws IOException {
|
protected void export() throws IOException {
|
||||||
PortableRemoteObject.exportObject(this);
|
IIOPHelper.exportObject(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String getProtocol() {
|
protected String getProtocol() {
|
||||||
@ -83,7 +84,7 @@ public class RMIIIOPServerImpl extends RMIServerImpl {
|
|||||||
public Remote toStub() throws IOException {
|
public Remote toStub() throws IOException {
|
||||||
// javax.rmi.CORBA.Stub stub =
|
// javax.rmi.CORBA.Stub stub =
|
||||||
// (javax.rmi.CORBA.Stub) PortableRemoteObject.toStub(this);
|
// (javax.rmi.CORBA.Stub) PortableRemoteObject.toStub(this);
|
||||||
final Remote stub = PortableRemoteObject.toStub(this);
|
final Remote stub = IIOPHelper.toStub(this);
|
||||||
// java.lang.System.out.println("NON CONNECTED STUB " + stub);
|
// java.lang.System.out.println("NON CONNECTED STUB " + stub);
|
||||||
// org.omg.CORBA.ORB orb =
|
// org.omg.CORBA.ORB orb =
|
||||||
// org.omg.CORBA.ORB.init((String[])null, (Properties)null);
|
// org.omg.CORBA.ORB.init((String[])null, (Properties)null);
|
||||||
@ -117,12 +118,12 @@ public class RMIIIOPServerImpl extends RMIServerImpl {
|
|||||||
RMIConnection client =
|
RMIConnection client =
|
||||||
new RMIConnectionImpl(this, connectionId, getDefaultClassLoader(),
|
new RMIConnectionImpl(this, connectionId, getDefaultClassLoader(),
|
||||||
subject, env);
|
subject, env);
|
||||||
PortableRemoteObject.exportObject(client);
|
IIOPHelper.exportObject(client);
|
||||||
return client;
|
return client;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void closeClient(RMIConnection client) throws IOException {
|
protected void closeClient(RMIConnection client) throws IOException {
|
||||||
PortableRemoteObject.unexportObject(client);
|
IIOPHelper.unexportObject(client);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -134,7 +135,7 @@ public class RMIIIOPServerImpl extends RMIServerImpl {
|
|||||||
* server failed.
|
* server failed.
|
||||||
*/
|
*/
|
||||||
protected void closeServer() throws IOException {
|
protected void closeServer() throws IOException {
|
||||||
PortableRemoteObject.unexportObject(this);
|
IIOPHelper.unexportObject(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
x
Reference in New Issue
Block a user