Skip to content

Commit

Permalink
Remove substitutions for JceSecurity
Browse files Browse the repository at this point in the history
  • Loading branch information
vjovanov committed Mar 1, 2024
1 parent 2334a13 commit f03bcb0
Showing 1 changed file with 35 additions and 19 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,9 @@
import java.security.SecureRandom;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.WeakHashMap;
import java.util.function.BooleanSupplier;
import java.util.function.Predicate;

import org.graalvm.nativeimage.Platform;
Expand All @@ -55,6 +58,7 @@
import com.oracle.svm.core.SubstrateUtil;
import com.oracle.svm.core.annotate.Alias;
import com.oracle.svm.core.annotate.Delete;
import com.oracle.svm.core.annotate.InjectAccessors;
import com.oracle.svm.core.annotate.RecomputeFieldValue;
import com.oracle.svm.core.annotate.Substitute;
import com.oracle.svm.core.annotate.TargetClass;
Expand Down Expand Up @@ -259,13 +263,33 @@ static void initialize(Target_java_security_Provider_Windows provider) {
@SuppressWarnings({"unused"})
final class Target_javax_crypto_ProviderVerifier {

@Substitute
static boolean isTrustedCryptoProvider(Provider provider) {
/*
* This is just used for fast-path checks, so returning false is a safe default. The
* original method accesses the Java home directory.
*/
return false;
@TargetElement(onlyWith = ProviderVerifierJavaHomeFieldPresent.class) //
@Alias @InjectAccessors(ProviderVerifierJavaHomeAccessors.class) //
static String javaHome;

}

class ProviderVerifierJavaHomeFieldPresent implements BooleanSupplier {
@Override
public boolean getAsBoolean() {
Class<?> providerVerifier = Objects.requireNonNull(ReflectionUtil.lookupClass(false, "javax.crypto.ProviderVerifier"));
return ReflectionUtil.lookupField(true, providerVerifier, "javaHome") != null;
}
}

@SuppressWarnings("unused")
class ProviderVerifierJavaHomeAccessors {
private static String javaHome;

private static String getJavaHome() {
if (javaHome == null) {
javaHome = System.getProperty("java.home", "");
}
return javaHome;
}

private static void setJavaHome(String newJavaHome) {
javaHome = newJavaHome;
}
}

Expand Down Expand Up @@ -295,22 +319,14 @@ final class Target_javax_crypto_JceSecurity {
@RecomputeFieldValue(kind = RecomputeFieldValue.Kind.Reset) //
private static Map<Provider, Object> verifyingProviders;

@Alias //
@RecomputeFieldValue(kind = RecomputeFieldValue.Kind.FromAlias) //
private static Map<Class<?>, URL> codeBaseCacheRef = new WeakHashMap<>();

@Alias //
@TargetElement //
private static ReferenceQueue<Object> queue;

@Substitute
static void verifyProvider(URL codeBase, Provider p) {
throw VMError.shouldNotReachHere("javax.crypto.JceSecurity.verifyProviderJar(URL, Provider) is reached at runtime. " +
"This should not happen. The contents of JceSecurity.verificationResults " +
"are computed and cached at image build time.");
}

@Substitute
static URL getCodeBase(final Class<?> clazz) {
throw VMError.unsupportedFeature("Trying to access the code base of " + clazz + ". ");
}

@Substitute
static Exception getVerificationResult(Provider p) {
/* Start code block copied from original method. */
Expand Down

0 comments on commit f03bcb0

Please sign in to comment.