This commit is contained in:
Chris Hegarty 2013-10-13 22:00:30 +01:00
commit 15bbca2184
5 changed files with 98 additions and 30 deletions

View File

@ -905,28 +905,4 @@ public class IDLNameTranslatorImpl implements IDLNameTranslator {
return contents.toString(); return contents.toString();
} }
public static void main(String[] args) {
Class remoteInterface = java.rmi.Remote.class;
if( args.length > 0 ) {
String className = args[0];
try {
remoteInterface = Class.forName(className);
} catch(Exception e) {
e.printStackTrace();
System.exit(-1);
}
}
System.out.println("Building name translation for " + remoteInterface);
try {
IDLNameTranslator nameTranslator =
IDLNameTranslatorImpl.get(remoteInterface);
System.out.println(nameTranslator);
} catch(IllegalStateException ise) {
ise.printStackTrace();
}
}
} }

View File

@ -43,6 +43,8 @@ import com.sun.corba.se.spi.orbutil.proxy.InvocationHandlerFactory ;
import com.sun.corba.se.spi.orbutil.proxy.DelegateInvocationHandlerImpl ; import com.sun.corba.se.spi.orbutil.proxy.DelegateInvocationHandlerImpl ;
import com.sun.corba.se.spi.orbutil.proxy.CompositeInvocationHandler ; import com.sun.corba.se.spi.orbutil.proxy.CompositeInvocationHandler ;
import com.sun.corba.se.spi.orbutil.proxy.CompositeInvocationHandlerImpl ; import com.sun.corba.se.spi.orbutil.proxy.CompositeInvocationHandlerImpl ;
import java.security.AccessController;
import java.security.PrivilegedAction;
public class InvocationHandlerFactoryImpl implements InvocationHandlerFactory public class InvocationHandlerFactoryImpl implements InvocationHandlerFactory
{ {
@ -114,24 +116,32 @@ public class InvocationHandlerFactoryImpl implements InvocationHandlerFactory
// which extends org.omg.CORBA.Object. This handler delegates all // which extends org.omg.CORBA.Object. This handler delegates all
// calls directly to a DynamicStubImpl, which extends // calls directly to a DynamicStubImpl, which extends
// org.omg.CORBA.portable.ObjectImpl. // org.omg.CORBA.portable.ObjectImpl.
InvocationHandler dynamicStubHandler = final InvocationHandler dynamicStubHandler =
DelegateInvocationHandlerImpl.create( stub ) ; DelegateInvocationHandlerImpl.create( stub ) ;
// Create an invocation handler that handles any remote interface // Create an invocation handler that handles any remote interface
// methods. // methods.
InvocationHandler stubMethodHandler = new StubInvocationHandlerImpl( final InvocationHandler stubMethodHandler = new StubInvocationHandlerImpl(
pm, classData, stub ) ; pm, classData, stub ) ;
// Create a composite handler that handles the DynamicStub interface // Create a composite handler that handles the DynamicStub interface
// as well as the remote interfaces. // as well as the remote interfaces.
final CompositeInvocationHandler handler = final CompositeInvocationHandler handler =
new CustomCompositeInvocationHandlerImpl( stub ) ; new CustomCompositeInvocationHandlerImpl( stub ) ;
AccessController.doPrivileged(new PrivilegedAction<Void>() {
@Override
public Void run() {
handler.addInvocationHandler( DynamicStub.class, handler.addInvocationHandler( DynamicStub.class,
dynamicStubHandler ) ; dynamicStubHandler ) ;
handler.addInvocationHandler( org.omg.CORBA.Object.class, handler.addInvocationHandler( org.omg.CORBA.Object.class,
dynamicStubHandler ) ; dynamicStubHandler ) ;
handler.addInvocationHandler( Object.class, handler.addInvocationHandler( Object.class,
dynamicStubHandler ) ; dynamicStubHandler ) ;
return null;
}
});
// If the method passed to invoke is not from DynamicStub or its superclasses, // If the method passed to invoke is not from DynamicStub or its superclasses,
// it must be from an implemented interface, so we just handle // it must be from an implemented interface, so we just handle

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -55,7 +55,7 @@ import com.sun.corba.se.impl.orbutil.ORBUtility;
/** /**
* @author Harold Carr * @author Harold Carr
*/ */
public class SelectorImpl class SelectorImpl
extends extends
Thread Thread
implements implements

View File

@ -36,6 +36,7 @@ import java.lang.reflect.InvocationHandler ;
import com.sun.corba.se.spi.logging.CORBALogDomains ; import com.sun.corba.se.spi.logging.CORBALogDomains ;
import com.sun.corba.se.impl.logging.ORBUtilSystemException ; import com.sun.corba.se.impl.logging.ORBUtilSystemException ;
import com.sun.corba.se.impl.presentation.rmi.DynamicAccessPermission;
public class CompositeInvocationHandlerImpl implements public class CompositeInvocationHandlerImpl implements
CompositeInvocationHandler CompositeInvocationHandler
@ -46,11 +47,13 @@ public class CompositeInvocationHandlerImpl implements
public void addInvocationHandler( Class interf, public void addInvocationHandler( Class interf,
InvocationHandler handler ) InvocationHandler handler )
{ {
checkAccess();
classToInvocationHandler.put( interf, handler ) ; classToInvocationHandler.put( interf, handler ) ;
} }
public void setDefaultHandler( InvocationHandler handler ) public void setDefaultHandler( InvocationHandler handler )
{ {
checkAccess();
defaultHandler = handler ; defaultHandler = handler ;
} }
@ -78,4 +81,12 @@ public class CompositeInvocationHandlerImpl implements
return handler.invoke( proxy, method, args ) ; return handler.invoke( proxy, method, args ) ;
} }
private static final DynamicAccessPermission perm = new DynamicAccessPermission("access");
private void checkAccess() {
final SecurityManager sm = System.getSecurityManager();
if (sm != null) {
sm.checkPermission(perm);
}
}
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -34,6 +34,9 @@ package sun.rmi.rmic.iiop;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.SerializablePermission;
import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.Vector; import java.util.Vector;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Enumeration; import java.util.Enumeration;
@ -49,6 +52,7 @@ import com.sun.corba.se.impl.util.Utility;
import com.sun.corba.se.impl.util.PackagePrefixChecker; import com.sun.corba.se.impl.util.PackagePrefixChecker;
import sun.rmi.rmic.Main; import sun.rmi.rmic.Main;
/** /**
* An IIOP stub/tie generator for rmic. * An IIOP stub/tie generator for rmic.
* *
@ -78,6 +82,7 @@ public class StubGenerator extends sun.rmi.rmic.iiop.Generator {
protected boolean castArray = false; protected boolean castArray = false;
protected Hashtable transactionalObjects = new Hashtable() ; protected Hashtable transactionalObjects = new Hashtable() ;
protected boolean POATie = false ; protected boolean POATie = false ;
protected boolean emitPermissionCheck = false;
/** /**
* Default constructor for Main to use. * Default constructor for Main to use.
@ -193,6 +198,9 @@ public class StubGenerator extends sun.rmi.rmic.iiop.Generator {
} else if (argv[i].equals("-standardPackage")) { } else if (argv[i].equals("-standardPackage")) {
standardPackage = true; standardPackage = true;
argv[i] = null; argv[i] = null;
} else if (argv[i].equals("-emitPermissionCheck")) {
emitPermissionCheck = true;
argv[i] = null;
} else if (arg.equals("-xstubbase")) { } else if (arg.equals("-xstubbase")) {
argv[i] = null; argv[i] = null;
if (++i < argv.length && argv[i] != null && !argv[i].startsWith("-")) { if (++i < argv.length && argv[i] != null && !argv[i].startsWith("-")) {
@ -390,9 +398,22 @@ public class StubGenerator extends sun.rmi.rmic.iiop.Generator {
writePackageAndImports(p); writePackageAndImports(p);
// generate
// import java.security.AccessController;
// import java.security.PrivilegedAction;
// import java.io.SerializablePermission;
if (emitPermissionCheck) {
p.pln("import java.security.AccessController;");
p.pln("import java.security.PrivilegedAction;");
p.pln("import java.io.SerializablePermission;");
p.pln();
p.pln();
}
// Declare the stub class; implement all remote interfaces. // Declare the stub class; implement all remote interfaces.
p.p("public class " + currentClass); p.p("public class " + currentClass);
p.p(" extends " + getName(stubBaseClass)); p.p(" extends " + getName(stubBaseClass));
p.p(" implements "); p.p(" implements ");
if (remoteInterfaces.length > 0) { if (remoteInterfaces.length > 0) {
@ -422,6 +443,57 @@ public class StubGenerator extends sun.rmi.rmic.iiop.Generator {
writeIds( p, theType, false ); writeIds( p, theType, false );
p.pln(); p.pln();
if (emitPermissionCheck) {
// produce the following generated code for example
// private static Void checkPermission() {
// SecurityManager sm = System.getSecurityManager();
// if (sm != null) {
// sm.checkPermission(new SerializablePermission(
// "enableSubclassImplementation")); // testing
// }
// return null;
// }
//
// private _XXXXX_Stub(Void ignore) {
// }
//
// public _XXXXX_Stub() {
// this(checkPermission());
// }
//
// where XXXXX is the name of the remote interface
p.pln();
p.plnI("private static Void checkPermission() {");
p.plnI("SecurityManager sm = System.getSecurityManager();");
p.pln("if (sm != null) {");
p.pI();
p.plnI("sm.checkPermission(new SerializablePermission(");
p.plnI("\"enableSubclassImplementation\"));");
p.pO();
p.pO();
p.pOln("}");
p.pln("return null;");
p.pO();
p.pOln("}");
p.pln();
p.pO();
p.pI();
p.pln("private " + currentClass + "(Void ignore) { }");
p.pln();
p.plnI("public " + currentClass + "() { ");
p.pln("this(checkPermission());");
p.pOln("}");
p.pln();
}
if (!emitPermissionCheck) {
p.pI();
}
// Write the _ids() method... // Write the _ids() method...
p.plnI("public String[] _ids() { "); p.plnI("public String[] _ids() { ");
@ -815,7 +887,6 @@ public class StubGenerator extends sun.rmi.rmic.iiop.Generator {
CompoundType theType) throws IOException { CompoundType theType) throws IOException {
// Wtite the method declaration and opening brace... // Wtite the method declaration and opening brace...
String methodName = method.getName(); String methodName = method.getName();
String methodIDLName = method.getIDLName(); String methodIDLName = method.getIDLName();