/* * IronJacamar, a Java EE Connector Architecture implementation * Copyright 2016, Red Hat Inc, and individual contributors * as indicated by the @author tags. See the copyright.txt file in the * distribution for a full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the Eclipse Public License 1.0 as * published by the Free Software Foundation. * * This software 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 Eclipse * Public License for more details. * * You should have received a copy of the Eclipse Public License * along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.ironjacamar.web; import java.io.IOException; import java.net.URL; import java.net.URLClassLoader; import java.security.AccessController; import java.security.PrivilegedAction; import com.github.fungal.api.Kernel; import org.eclipse.jetty.webapp.WebAppClassLoader; import org.eclipse.jetty.webapp.WebAppContext; /** * Privileged Blocks * @author <a href="mailto:jesper.pedersen@ironjacamar.org">Jesper Pedersen</a> */ class SecurityActions { /** * Constructor */ private SecurityActions() { } /** * Get the thread context class loader * @return The class loader */ static ClassLoader getThreadContextClassLoader() { return AccessController.doPrivileged(new PrivilegedAction<ClassLoader>() { public ClassLoader run() { return Thread.currentThread().getContextClassLoader(); } }); } /** * Set the thread context class loader * @param cl The class loader */ static void setThreadContextClassLoader(final ClassLoader cl) { AccessController.doPrivileged(new PrivilegedAction<ClassLoader>() { public ClassLoader run() { Thread.currentThread().setContextClassLoader(cl); return null; } }); } /** * Get a system property * @param name The property name * @return The property value */ static String getSystemProperty(final String name) { return AccessController.doPrivileged(new PrivilegedAction<String>() { public String run() { return System.getProperty(name); } }); } /** * Set a system property * @param name The property name * @param value The property value */ static void setSystemProperty(final String name, final String value) { AccessController.doPrivileged(new PrivilegedAction<Boolean>() { public Boolean run() { System.setProperty(name, value); return Boolean.TRUE; } }); } /** * Create an URLClassLoader * @param urls The urls * @param parent The parent class loader * @return The class loader */ static URLClassLoader createURLCLassLoader(final URL[] urls, final ClassLoader parent) { return AccessController.doPrivileged(new PrivilegedAction<URLClassLoader>() { public URLClassLoader run() { return new URLClassLoader(urls, parent); } }); } /** * Create a WARClassLoader * @param kernel The kernel * @param parent The parent class loader * @return The class loader */ static WARClassLoader createWARClassLoader(final Kernel kernel, final ClassLoader parent) { return AccessController.doPrivileged(new PrivilegedAction<WARClassLoader>() { public WARClassLoader run() { return new WARClassLoader(kernel, parent); } }); } /** * Create a WebClassLoader * @param cl The classloader * @param wac The web app context * @return The class loader */ static WebAppClassLoader createWebAppClassLoader(final ClassLoader cl, final WebAppContext wac) { return AccessController.doPrivileged(new PrivilegedAction<WebAppClassLoader>() { public WebAppClassLoader run() { try { return new WebAppClassLoader(cl, wac); } catch (IOException ioe) { return null; } } }); } }