| /* |
| * Copyright (c) 2002, 2016, 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 jdk.internal.misc; |
| |
| import java.io.ObjectInputStream; |
| |
| /** A repository of "shared secrets", which are a mechanism for |
| calling implementation-private methods in another package without |
| using reflection. A package-private class implements a public |
| interface and provides the ability to call package-private methods |
| within that package; the object implementing that interface is |
| provided through a third package to which access is restricted. |
| This framework avoids the primary disadvantage of using reflection |
| for this purpose, namely the loss of compile-time checking. */ |
| |
| public class SharedSecrets { |
| private static final Unsafe unsafe = Unsafe.getUnsafe(); |
| // BEGIN Android-removed: Pruned unused access interfaces. |
| /* |
| private static JavaUtilJarAccess javaUtilJarAccess; |
| private static JavaLangAccess javaLangAccess; |
| private static JavaLangRefAccess javaLangRefAccess; |
| private static JavaIOAccess javaIOAccess; |
| private static JavaNetAccess javaNetAccess; |
| private static JavaNetHttpCookieAccess javaNetHttpCookieAccess; |
| private static JavaNioAccess javaNioAccess; |
| */ |
| // END Android-removed: Pruned unused access interfaces. |
| private static JavaIOFileDescriptorAccess javaIOFileDescriptorAccess; |
| // BEGIN Android-removed: Pruned unused access interfaces. |
| /* |
| private static JavaSecurityProtectionDomainAccess javaSecurityProtectionDomainAccess; |
| private static JavaSecurityAccess javaSecurityAccess; |
| private static JavaUtilZipFileAccess javaUtilZipFileAccess; |
| private static JavaAWTAccess javaAWTAccess; |
| private static JavaOISAccess javaOISAccess; |
| private static JavaObjectInputStreamReadString javaObjectInputStreamReadString; |
| */ |
| // END Android-removed: Pruned unused access interfaces. |
| private static JavaObjectInputStreamAccess javaObjectInputStreamAccess; |
| // BEGIN Android-removed: Pruned unused access interfaces. |
| /* |
| private static JavaSecuritySignatureAccess javaSecuritySignatureAccess; |
| |
| public static JavaUtilJarAccess javaUtilJarAccess() { |
| if (javaUtilJarAccess == null) { |
| // Ensure JarFile is initialized; we know that that class |
| // provides the shared secret |
| unsafe.ensureClassInitialized(JarFile.class); |
| } |
| return javaUtilJarAccess; |
| } |
| |
| public static void setJavaUtilJarAccess(JavaUtilJarAccess access) { |
| javaUtilJarAccess = access; |
| } |
| |
| public static void setJavaLangAccess(JavaLangAccess jla) { |
| javaLangAccess = jla; |
| } |
| |
| public static JavaLangAccess getJavaLangAccess() { |
| return javaLangAccess; |
| } |
| |
| public static void setJavaLangRefAccess(JavaLangRefAccess jlra) { |
| javaLangRefAccess = jlra; |
| } |
| |
| public static JavaLangRefAccess getJavaLangRefAccess() { |
| return javaLangRefAccess; |
| } |
| |
| public static void setJavaNetAccess(JavaNetAccess jna) { |
| javaNetAccess = jna; |
| } |
| |
| public static JavaNetAccess getJavaNetAccess() { |
| return javaNetAccess; |
| } |
| |
| public static void setJavaNetHttpCookieAccess(JavaNetHttpCookieAccess a) { |
| javaNetHttpCookieAccess = a; |
| } |
| |
| public static JavaNetHttpCookieAccess getJavaNetHttpCookieAccess() { |
| if (javaNetHttpCookieAccess == null) |
| unsafe.ensureClassInitialized(java.net.HttpCookie.class); |
| return javaNetHttpCookieAccess; |
| } |
| |
| public static void setJavaNioAccess(JavaNioAccess jna) { |
| javaNioAccess = jna; |
| } |
| |
| public static JavaNioAccess getJavaNioAccess() { |
| if (javaNioAccess == null) { |
| // Ensure java.nio.ByteOrder is initialized; we know that |
| // this class initializes java.nio.Bits that provides the |
| // shared secret. |
| unsafe.ensureClassInitialized(java.nio.ByteOrder.class); |
| } |
| return javaNioAccess; |
| } |
| |
| public static void setJavaIOAccess(JavaIOAccess jia) { |
| javaIOAccess = jia; |
| } |
| |
| public static JavaIOAccess getJavaIOAccess() { |
| if (javaIOAccess == null) { |
| unsafe.ensureClassInitialized(Console.class); |
| } |
| return javaIOAccess; |
| } |
| */ |
| // END Android-removed: Pruned unused access interfaces. |
| |
| public static void setJavaIOFileDescriptorAccess(JavaIOFileDescriptorAccess jiofda) { |
| javaIOFileDescriptorAccess = jiofda; |
| } |
| |
| public static JavaIOFileDescriptorAccess getJavaIOFileDescriptorAccess() { |
| // Android-changed: ensureClassInitialized isn't supported in Android. Use Class.forName. |
| // if (javaIOFileDescriptorAccess == null) |
| // unsafe.ensureClassInitialized(FileDescriptor.class); |
| if (javaIOFileDescriptorAccess == null) { |
| try { |
| Class.forName("java.io.FileDescriptor"); |
| } catch (ClassNotFoundException e) { |
| // Throw if FileDescriptor class is not found. Something wrong in runtime / libcore. |
| throw new RuntimeException(e); |
| } |
| } |
| return javaIOFileDescriptorAccess; |
| } |
| |
| // BEGIN Android-removed: Pruned unused access interfaces. |
| /* |
| public static void setJavaOISAccess(JavaOISAccess access) { |
| javaOISAccess = access; |
| } |
| |
| public static JavaOISAccess getJavaOISAccess() { |
| if (javaOISAccess == null) |
| unsafe.ensureClassInitialized(ObjectInputStream.class); |
| |
| return javaOISAccess; |
| } |
| |
| |
| public static void setJavaSecurityProtectionDomainAccess |
| (JavaSecurityProtectionDomainAccess jspda) { |
| javaSecurityProtectionDomainAccess = jspda; |
| } |
| |
| public static JavaSecurityProtectionDomainAccess |
| getJavaSecurityProtectionDomainAccess() { |
| if (javaSecurityProtectionDomainAccess == null) |
| unsafe.ensureClassInitialized(ProtectionDomain.class); |
| return javaSecurityProtectionDomainAccess; |
| } |
| |
| public static void setJavaSecurityAccess(JavaSecurityAccess jsa) { |
| javaSecurityAccess = jsa; |
| } |
| |
| public static JavaSecurityAccess getJavaSecurityAccess() { |
| if (javaSecurityAccess == null) { |
| unsafe.ensureClassInitialized(AccessController.class); |
| } |
| return javaSecurityAccess; |
| } |
| |
| public static JavaUtilZipFileAccess getJavaUtilZipFileAccess() { |
| if (javaUtilZipFileAccess == null) |
| unsafe.ensureClassInitialized(java.util.zip.ZipFile.class); |
| return javaUtilZipFileAccess; |
| } |
| |
| public static void setJavaUtilZipFileAccess(JavaUtilZipFileAccess access) { |
| javaUtilZipFileAccess = access; |
| } |
| |
| public static void setJavaAWTAccess(JavaAWTAccess jaa) { |
| javaAWTAccess = jaa; |
| } |
| |
| public static JavaAWTAccess getJavaAWTAccess() { |
| // this may return null in which case calling code needs to |
| // provision for. |
| if (javaAWTAccess == null) { |
| return null; |
| } |
| return javaAWTAccess; |
| } |
| |
| public static JavaObjectInputStreamReadString getJavaObjectInputStreamReadString() { |
| if (javaObjectInputStreamReadString == null) { |
| unsafe.ensureClassInitialized(ObjectInputStream.class); |
| } |
| return javaObjectInputStreamReadString; |
| } |
| |
| public static void setJavaObjectInputStreamReadString(JavaObjectInputStreamReadString access) { |
| javaObjectInputStreamReadString = access; |
| } |
| */ |
| // END Android-removed: Pruned unused access interfaces. |
| |
| public static JavaObjectInputStreamAccess getJavaObjectInputStreamAccess() { |
| if (javaObjectInputStreamAccess == null) { |
| unsafe.ensureClassInitialized(ObjectInputStream.class); |
| } |
| return javaObjectInputStreamAccess; |
| } |
| |
| public static void setJavaObjectInputStreamAccess(JavaObjectInputStreamAccess access) { |
| javaObjectInputStreamAccess = access; |
| } |
| |
| // BEGIN Android-removed: Pruned unused access interfaces. |
| /* |
| public static void setJavaSecuritySignatureAccess(JavaSecuritySignatureAccess jssa) { |
| javaSecuritySignatureAccess = jssa; |
| } |
| |
| public static JavaSecuritySignatureAccess getJavaSecuritySignatureAccess() { |
| if (javaSecuritySignatureAccess == null) { |
| unsafe.ensureClassInitialized(Signature.class); |
| } |
| return javaSecuritySignatureAccess; |
| } |
| */ |
| // END Android-removed: Pruned unused access interfaces. |
| } |