From b8832a673c467f5bb658252119cd3b48b9902c80 Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Tue, 27 Oct 2009 08:55:35 +0000 Subject: [PATCH] 6888179: Separate out dependency on CORBA Reviewed-by: dfuchs --- .../sun/jmx/remote/internal/IIOPHelper.java | 188 ++++++++++++++++++ .../sun/jmx/remote/internal/IIOPProxy.java | 110 ++++++++++ .../remote/protocol/iiop/IIOPProxyImpl.java | 119 +++++++++++ .../iiop}/ProxyInputStream.java | 2 +- .../remote/rmi/NoCallStackClassLoader.java | 68 +++++++ .../management/remote/rmi/RMIConnector.java | 177 +++++++++-------- .../remote/rmi/RMIConnectorServer.java | 12 +- .../remote/rmi/RMIIIOPServerImpl.java | 13 +- 8 files changed, 589 insertions(+), 100 deletions(-) create mode 100644 jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPHelper.java create mode 100644 jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPProxy.java create mode 100644 jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/IIOPProxyImpl.java rename jdk/src/share/classes/com/sun/jmx/remote/{internal => protocol/iiop}/ProxyInputStream.java (99%) diff --git a/jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPHelper.java b/jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPHelper.java new file mode 100644 index 00000000000..c66aa8773e1 --- /dev/null +++ b/jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPHelper.java @@ -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() { + 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 narrow(Object narrowFrom, Class 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); + } +} diff --git a/jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPProxy.java b/jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPProxy.java new file mode 100644 index 00000000000..9c971afc6f3 --- /dev/null +++ b/jdk/src/share/classes/com/sun/jmx/remote/internal/IIOPProxy.java @@ -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 narrow(Object narrowFrom, Class 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; +} diff --git a/jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/IIOPProxyImpl.java b/jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/IIOPProxyImpl.java new file mode 100644 index 00000000000..9d428e5ae23 --- /dev/null +++ b/jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/IIOPProxyImpl.java @@ -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 narrow(Object narrowFrom, Class 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); + } +} diff --git a/jdk/src/share/classes/com/sun/jmx/remote/internal/ProxyInputStream.java b/jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/ProxyInputStream.java similarity index 99% rename from jdk/src/share/classes/com/sun/jmx/remote/internal/ProxyInputStream.java rename to jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/ProxyInputStream.java index b610828065a..205c10fe394 100644 --- a/jdk/src/share/classes/com/sun/jmx/remote/internal/ProxyInputStream.java +++ b/jdk/src/share/classes/com/sun/jmx/remote/protocol/iiop/ProxyInputStream.java @@ -23,7 +23,7 @@ * have any questions. */ -package com.sun.jmx.remote.internal; +package com.sun.jmx.remote.protocol.iiop; import java.io.IOException; import java.io.Serializable; diff --git a/jdk/src/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java b/jdk/src/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java index d3f9c03bdcf..f9aa5acfa30 100644 --- a/jdk/src/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java +++ b/jdk/src/share/classes/javax/management/remote/rmi/NoCallStackClassLoader.java @@ -225,4 +225,72 @@ insert-buffer'd into a Java program." (insert "\"") (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= 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 environment) throws IOException { - if (rmiServer instanceof javax.rmi.CORBA.Stub) { - javax.rmi.CORBA.Stub stub = (javax.rmi.CORBA.Stub) rmiServer; + if (IIOPHelper.isStub(rmiServer)) { try { - stub._orb(); - } catch (BAD_OPERATION x) { - stub.connect(resolveOrb(environment)); + IIOPHelper.getOrb(rmiServer); + } catch (UnsupportedOperationException x) { + // BAD_OPERATION + IIOPHelper.connect(rmiServer, resolveOrb(environment)); } } return rmiServer; @@ -1725,22 +1721,22 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable * does not point to an {@link org.omg.CORBA.ORB ORB}. * @exception IOException if the ORB initialization failed. **/ - static ORB resolveOrb(Map environment) + static Object resolveOrb(Map environment) throws IOException { if (environment != null) { 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 + " 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(); if (orb != null) return orb; - final ORB newOrb = - ORB.init((String[])null, (Properties)null); - RMIConnector.orb = new WeakReference(newOrb); + final Object newOrb = + IIOPHelper.createOrb((String[])null, (Properties)null); + RMIConnector.orb = new WeakReference(newOrb); return newOrb; } @@ -1878,9 +1874,11 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable return findRMIServerJNDI(path.substring(6,end), environment, isIiop); else if (path.startsWith("/stub/")) 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); - else { + } else { final String msg = "URL path must begin with /jndi/ or /stub/ " + "or /ior/: " + path; throw new MalformedURLException(msg); @@ -1922,8 +1920,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable private static RMIServer narrowIIOPServer(Object objref) { try { - return (RMIServer) - PortableRemoteObject.narrow(objref, RMIServer.class); + return IIOPHelper.narrow(objref, RMIServer.class); } catch (ClassCastException e) { if (logger.traceOn()) logger.trace("narrowIIOPServer","Failed to narrow objref=" + @@ -1935,10 +1932,9 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable private RMIServer findRMIServerIIOP(String ior, Map env, boolean isIiop) { // could forbid "rmi:" URL here -- but do we need to? - final ORB orb = (ORB) - env.get(EnvHelp.DEFAULT_ORB); - final Object stub = orb.string_to_object(ior); - return (RMIServer) PortableRemoteObject.narrow(stub, RMIServer.class); + final Object orb = env.get(EnvHelp.DEFAULT_ORB); + final Object stub = IIOPHelper.stringToObject(orb, ior); + return IIOPHelper.narrow(stub, RMIServer.class); } private RMIServer findRMIServerJRMP(String base64, Map env, boolean isIiop) @@ -1964,7 +1960,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable } catch (ClassNotFoundException e) { throw new MalformedURLException("Class not found: " + e); } - return (RMIServer) PortableRemoteObject.narrow(stub, RMIServer.class); + return (RMIServer)stub; } private static final class ObjectInputStreamWithLoader @@ -2205,9 +2201,9 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable again, using reflection. 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; @@ -2228,12 +2224,13 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable } public void _releaseReply(InputStream in) { - PInputStream pis = (PInputStream) in; - super._releaseReply(pis.getProxiedInputStream()); + if (in != null) + 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 PInputStream(org.omg.CORBA.portable.InputStream in) { @@ -2252,49 +2249,52 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable */ 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 = - "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 = - "com.sun.jmx.remote.internal.PInputStream"; + "com.sun.jmx.remote.protocol.iiop.PInputStream"; private static final Class proxyStubClass; static { 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"+ - "\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"+ - "\36\12\0\14\0\37\7\0\40\7\0!\1\0\6\1\0\3()V\1\0\4Code\1"+ - "\0\7_invoke\1\0K(Lorg/omg/CORBA/portable/OutputStream;)Lorg/o"+ - "mg/CORBA/portable/InputStream;\1\0\12Exceptions\7\0\"\1\0\15_"+ - "releaseReply\1\0'(Lorg/omg/CORBA/portable/InputStream;)V\14\0"+ - "\15\0\16\1\0(com/sun/jmx/remote/internal/PInputStream\14\0\20"+ - "\0\21\14\0\15\0\25\1\0+org/omg/CORBA/portable/ApplicationExce"+ - "ption\14\0#\0$\14\0%\0&\14\0\15\0'\14\0(\0$\14\0\24\0\25\1\0%"+ - "com/sun/jmx/remote/internal/ProxyStub\1\0\1\0\3()V\1\0\4Code\1\0\7_in"+ + "voke\1\0K(Lorg/omg/CORBA/portable/OutputStream;)Lorg/omg/CORBA"+ + "/portable/InputStream;\1\0\15StackMapTable\7\0\34\1\0\12Except"+ + "ions\7\0$\1\0\15_releaseReply\1\0'(Lorg/omg/CORBA/portable/Inp"+ + "utStream;)V\14\0\15\0\16\1\0-com/sun/jmx/remote/protocol/iiop/"+ + "PInputStream\14\0\20\0\21\14\0\15\0\27\1\0+org/omg/CORBA/porta"+ + "ble/ApplicationException\14\0%\0&\14\0'\0(\14\0\15\0)\14\0*\0&"+ + "\14\0\26\0\27\1\0*com/sun/jmx/remote/protocol/iiop/ProxyStub\1"+ + "\0\1\0'(L"+ - "org/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"+ - "g/Class;)Ljava/io/Serializable;\14\0\10\0\11\14\0\30\0\31\7\0"+ - "\32\14\0\13\0\14\14\0\33\0\34\7\0\35\14\0\15\0\16\1\0(com/sun"+ - "/jmx/remote/internal/PInputStream\1\0,com/sun/jmx/remote/inte"+ - "rnal/ProxyInputStream\1\0\2in\1\0$Lorg/omg/CORBA/portable/Inp"+ - "utStream;\1\0\"org/omg/CORBA/portable/InputStream\1\0\6narrow"+ - "\1\0*()Lorg/omg/CORBA_2_3/portable/InputStream;\1\0&org/omg/C"+ - "ORBA_2_3/portable/InputStream\0!\0\6\0\7\0\0\0\0\0\3\0\1\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"+ - "\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"+ + "\312\376\272\276\0\0\0\63\0\36\12\0\7\0\17\11\0\6\0\20\12\0\21"+ + "\0\22\12\0\6\0\23\12\0\24\0\25\7\0\26\7\0\27\1\0\6\1\0'("+ + "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/lang"+ + "/Class;)Ljava/io/Serializable;\14\0\10\0\11\14\0\30\0\31\7\0\32"+ + "\14\0\13\0\14\14\0\33\0\34\7\0\35\14\0\15\0\16\1\0-com/sun/jmx"+ + "/remote/protocol/iiop/PInputStream\1\0\61com/sun/jmx/remote/pr"+ + "otocol/iiop/ProxyInputStream\1\0\2in\1\0$Lorg/omg/CORBA/portab"+ + "le/InputStream;\1\0\"org/omg/CORBA/portable/InputStream\1\0\6n"+ + "arrow\1\0*()Lorg/omg/CORBA_2_3/portable/InputStream;\1\0&org/o"+ + "mg/CORBA_2_3/portable/InputStream\0!\0\6\0\7\0\0\0\0\0\3\0\1\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\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"+ "\11*\266\0\4+\266\0\5\260\0\0\0\0\0\0"; final byte[] proxyStubByteCode = @@ -2305,12 +2305,12 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable final byte[][] byteCodes = {proxyStubByteCode, pInputStreamByteCode}; final String[] otherClassNames = { iiopConnectionStubClassName, - ProxyInputStream.class.getName(), + ProxyInputStreamClassName, }; - PrivilegedExceptionAction> action = + if (IIOPHelper.isAvailable()) { + PrivilegedExceptionAction> action = new PrivilegedExceptionAction>() { - public Class run() throws Exception { - + public Class run() throws Exception { Class thisClass = RMIConnector.class; ClassLoader thisLoader = thisClass.getClassLoader(); ProtectionDomain thisProtectionDomain = @@ -2322,24 +2322,27 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable thisLoader, thisProtectionDomain); return cl.loadClass(proxyStubClassName); + } + }; + Class stubClass; + try { + stubClass = AccessController.doPrivileged(action); + } catch (Exception e) { + logger.error("", + "Unexpected exception making shadow IIOP stub class: "+e); + logger.debug("",e); + stubClass = null; } - }; - Class stubClass; - try { - stubClass = AccessController.doPrivileged(action); - } catch (Exception e) { - logger.error("", - "Unexpected exception making shadow IIOP stub class: "+e); - logger.debug("",e); - stubClass = null; + proxyStubClass = stubClass; + } else { + proxyStubClass = null; } - proxyStubClass = stubClass; } - private static RMIConnection shadowIiopStub(Stub stub) + private static RMIConnection shadowIiopStub(Object stub) throws InstantiationException, IllegalAccessException { - Stub proxyStub = (Stub) proxyStubClass.newInstance(); - proxyStub._set_delegate(stub._get_delegate()); + Object proxyStub = proxyStubClass.newInstance(); + IIOPHelper.setDelegate(proxyStub, IIOPHelper.getDelegate(stub)); return (RMIConnection) proxyStub; } @@ -2353,7 +2356,7 @@ public class RMIConnector implements JMXConnector, Serializable, JMXAddressable if (c.getClass() == rmiConnectionImplStubClass) return shadowJrmpStub((RemoteObject) c); if (c.getClass().getName().equals(iiopConnectionStubClassName)) - return shadowIiopStub((Stub) c); + return shadowIiopStub(c); logger.trace("getConnection", "Did not wrap " + c.getClass() + " to foil " + "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 * connect unconnected stubs. **/ - private static volatile WeakReference orb = null; + private static volatile WeakReference orb = null; // TRACES & DEBUG //--------------- diff --git a/jdk/src/share/classes/javax/management/remote/rmi/RMIConnectorServer.java b/jdk/src/share/classes/javax/management/remote/rmi/RMIConnectorServer.java index 9e4efdd183d..057de307dc5 100644 --- a/jdk/src/share/classes/javax/management/remote/rmi/RMIConnectorServer.java +++ b/jdk/src/share/classes/javax/management/remote/rmi/RMIConnectorServer.java @@ -27,6 +27,7 @@ package javax.management.remote.rmi; 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.EnvHelp; @@ -674,7 +675,7 @@ public class RMIConnectorServer extends JMXConnectorServer { final int port; if (address == null) { - if (rmiServer instanceof javax.rmi.CORBA.Stub) + if (IIOPHelper.isStub(rmiServer)) protocol = "iiop"; else protocol = "rmi"; @@ -712,7 +713,7 @@ public class RMIConnectorServer extends JMXConnectorServer { **/ static String encodeStub( RMIServer rmiServer, Map env) throws IOException { - if (rmiServer instanceof javax.rmi.CORBA.Stub) + if (IIOPHelper.isStub(rmiServer)) return "/ior/" + encodeIIOPStub(rmiServer, env); else return "/stub/" + encodeJRMPStub(rmiServer, env); @@ -733,10 +734,9 @@ public class RMIConnectorServer extends JMXConnectorServer { RMIServer rmiServer, Map env) throws IOException { try { - javax.rmi.CORBA.Stub stub = - (javax.rmi.CORBA.Stub) rmiServer; - return stub._orb().object_to_string(stub); - } catch (org.omg.CORBA.BAD_OPERATION x) { + Object orb = IIOPHelper.getOrb(rmiServer); + return IIOPHelper.objectToString(orb, rmiServer); + } catch (RuntimeException x) { throw newIOException(x.getMessage(), x); } } diff --git a/jdk/src/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java b/jdk/src/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java index daaa43fd4d7..f8995954d08 100644 --- a/jdk/src/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java +++ b/jdk/src/share/classes/javax/management/remote/rmi/RMIIIOPServerImpl.java @@ -33,9 +33,10 @@ import java.security.PrivilegedActionException; import java.security.PrivilegedExceptionAction; import java.util.Map; import java.util.Collections; -import javax.rmi.PortableRemoteObject; import javax.security.auth.Subject; +import com.sun.jmx.remote.internal.IIOPHelper; + /** *

An {@link RMIServerImpl} that is exported through IIOP and that * creates client connections as RMI objects exported through IIOP. @@ -65,7 +66,7 @@ public class RMIIIOPServerImpl extends RMIServerImpl { } protected void export() throws IOException { - PortableRemoteObject.exportObject(this); + IIOPHelper.exportObject(this); } protected String getProtocol() { @@ -83,7 +84,7 @@ public class RMIIIOPServerImpl extends RMIServerImpl { public Remote toStub() throws IOException { // javax.rmi.CORBA.Stub stub = // (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); // org.omg.CORBA.ORB orb = // org.omg.CORBA.ORB.init((String[])null, (Properties)null); @@ -117,12 +118,12 @@ public class RMIIIOPServerImpl extends RMIServerImpl { RMIConnection client = new RMIConnectionImpl(this, connectionId, getDefaultClassLoader(), subject, env); - PortableRemoteObject.exportObject(client); + IIOPHelper.exportObject(client); return client; } protected void closeClient(RMIConnection client) throws IOException { - PortableRemoteObject.unexportObject(client); + IIOPHelper.unexportObject(client); } /** @@ -134,7 +135,7 @@ public class RMIIIOPServerImpl extends RMIServerImpl { * server failed. */ protected void closeServer() throws IOException { - PortableRemoteObject.unexportObject(this); + IIOPHelper.unexportObject(this); } @Override