Skip to content

Commit

Permalink
Merge branch '8342992-check-sm' into tmp-8342997-getSecurityManager
Browse files Browse the repository at this point in the history
  • Loading branch information
kevinrushforth committed Nov 5, 2024
2 parents 0187864 + 6e905c1 commit ab722a0
Show file tree
Hide file tree
Showing 5 changed files with 81 additions and 12 deletions.
62 changes: 62 additions & 0 deletions modules/javafx.base/src/main/java/com/sun/javafx/SecurityUtil.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
/*
* Copyright (c) 2024, Oracle and/or its affiliates. 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/

package com.sun.javafx;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

/**
* Utility class to check for the presence of a security manager.
*/
public class SecurityUtil {

// Prevent class from being instantiated.
private SecurityUtil() {}

/**
* Check for the presence of a security manager (from an older JDK) and
* throw UnsupportedOperationException if enabled. Use reflection to avoid
* a dependency on an API that is deprecated for removal. This method does
* nothing if the security manager is not enabled or if
* System::getSecurityManager cannot be invoked.
*
* @throws UnsupportedOperationException if the security manager is enabled
*/
public static void checkSecurityManager() {
try {
// Call System.getSecurityManager() using reflection. Throw an
// UnsupportedOperationException if it returns a non-null object.
// If we cannot find or invoke getSecurityManager, ignore the error.
Method meth = System.class.getMethod("getSecurityManager");
Object sm = meth.invoke(null);
if (sm != null) {
throw new UnsupportedOperationException("JavaFX does not support running with the Security Manager");
}
} catch (NoSuchMethodException | IllegalAccessException | InvocationTargetException ex) {
// Ignore the error
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@

package com.sun.javafx.reflect;

import com.sun.javafx.SecurityUtil;
import java.security.AllPermission;
import java.security.AccessController;
import java.security.PermissionCollection;
Expand Down Expand Up @@ -77,6 +78,12 @@ private static Object invoke(Method m, Object obj, Object[] params)
* Create a trampoline class.
*/
public final class MethodUtil extends SecureClassLoader {

static {
// Check for security manager (throws exception if enabled)
SecurityUtil.checkSecurityManager();
}

private static final String MISC_PKG = "com.sun.javafx.reflect.";
private static final String TRAMPOLINE = MISC_PKG + "Trampoline";
private static final Method bounce = getTrampoline();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,16 @@

package com.sun.javafx.reflect;

import com.sun.javafx.SecurityUtil;
import java.lang.reflect.Proxy;

public final class ReflectUtil {

static {
// Check for security manager (throws exception if enabled)
SecurityUtil.checkSecurityManager();
}

private ReflectUtil() {
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
package com.sun.javafx.application;

import com.sun.javafx.PlatformUtil;
import com.sun.javafx.SecurityUtil;
import javafx.application.Application;
import javafx.application.Preloader;
import javafx.application.Preloader.ErrorNotification;
Expand Down Expand Up @@ -57,12 +58,8 @@
public class LauncherImpl {

static {
@SuppressWarnings("removal")
var sm = System.getSecurityManager();
if (sm != null) {
throw new UnsupportedOperationException("JavaFX does not support running with the Security Manager");
}

// Check for security manager (throws exception if enabled)
SecurityUtil.checkSecurityManager();
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
package com.sun.javafx.application;

import com.sun.javafx.PlatformUtil;
import com.sun.javafx.SecurityUtil;
import com.sun.javafx.application.preferences.PlatformPreferences;
import com.sun.javafx.application.preferences.PreferenceMapping;
import com.sun.javafx.css.StyleManager;
Expand Down Expand Up @@ -59,12 +60,8 @@
public class PlatformImpl {

static {
@SuppressWarnings("removal")
var sm = System.getSecurityManager();
if (sm != null) {
throw new UnsupportedOperationException("JavaFX does not support running with the Security Manager");
}

// Check for security manager (throws exception if enabled)
SecurityUtil.checkSecurityManager();
}

private static AtomicBoolean initialized = new AtomicBoolean(false);
Expand Down

0 comments on commit ab722a0

Please sign in to comment.