Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FipsStatus.getMarker method does not work with bootstrap class loader #1904

Open
XueleiFan opened this issue Nov 11, 2024 · 5 comments
Open
Assignees
Labels
question Further information is requested

Comments

@XueleiFan
Copy link

XueleiFan commented Nov 11, 2024

If using bootstrap class loader, the FipsStatus.getMarker() cannot work because it relies on system class loader.

Here is the context:

  1. bootstrap class loader is used to load bc classes.
  2. bc classes and resources are not accessible in system class loader.

In the FipsStatus.getMarker(final Class sourceClass, final String markerName) implementation:

  1. try to get the sourceClass loader, which will return null for bootstrap class loader:
    ClassLoader loader = sourceClass.getClassLoader();
  2. system class loader will be use instead when the "loader" is null
    ClassLoader.getSystemResource(markerName).toString();
  3. As the resource is not available in system class loader, ClassLoader.getSystemResource() does not work as expected.

Is it possible to have an improvement so that this method could work with bootstrap class loader?

    static String getMarker(final Class sourceClass, final String markerName) {
        // wrap with privileged action
        return sourceClass.getResource(markerName);
    }

sourceClass.getResource(markerName) may not work as bc libs may not have a module name.

Thanks!

@dghgit
Copy link
Contributor

dghgit commented Nov 13, 2024

What version of the FIPS provider is this with?
Just to clarify further:

java -Xbootclasspath/a:bc-fips-2.0.0.jar org.bouncycastle.util.DumpInfo

produces:

Version Info: BouncyCastle Security Provider (FIPS edition) v2.0.0
FIPS Ready Status: READY
Module SHA-256 HMAC: 164c8ae41945cb85fdc65666fc4de7301a65d29659ecd455ee5199c7d42d107e

@dimitryc
Copy link

Looks like the issue is specific to java agents with bc-fips-2.0.0.jar appended to the boot class path using Instrumentation.appendToBootstrapClassLoaderSearch

Below are the steps to reproduce this

$ cat TestAgent.java 
import java.io.File;
import java.io.IOException;
import java.lang.instrument.Instrumentation;
import java.util.jar.JarFile;

public class TestAgent {
    public static void premain(String agentArgs, Instrumentation instrumentation) throws IOException {
        File file = new File("/tmp/bc-fips-2.0.0.jar");
        instrumentation.appendToBootstrapClassLoaderSearch(new JarFile(file));
    }
}

$ cat MANIFEST.MF 
Premain-Class: TestAgent

$ javac TestAgent.java
$ jar cfm TestAgent.jar MANIFEST.MF TestAgent.class
$ java -javaagent:TestAgent.jar org.bouncycastle.util.DumpInfo

OpenJDK 64-Bit Server VM warning: Sharing is only supported for boot loader classes because bootstrap classpath has been appended
Exception in thread "main" org.bouncycastle.crypto.fips.FipsSelfTestFailedError: Exception on self test: Cannot invoke "java.net.URL.toString()" because the return value of "java.lang.ClassLoader.getSystemResource(String)" is null: EC
at org.bouncycastle.crypto.fips.SelfTestExecutor.validate(Unknown Source)
at org.bouncycastle.crypto.fips.FipsEC$DsaProvider.createEngine(Unknown Source)
at org.bouncycastle.crypto.fips.FipsEC$DsaProvider.createEngine(Unknown Source)
at org.bouncycastle.crypto.fips.FipsEC.(Unknown Source)
at java.base/java.lang.Class.forName0(Native Method)
at java.base/java.lang.Class.forName(Class.java:375)
at org.bouncycastle.util.DumpInfo.loadClass(Unknown Source)
at org.bouncycastle.util.DumpInfo.runTests(Unknown Source)
at org.bouncycastle.util.DumpInfo.main(Unknown Source)

@dghgit dghgit self-assigned this Nov 29, 2024
@dghgit
Copy link
Contributor

dghgit commented Nov 30, 2024

So I've tried a couple of different things, but the problem seems to remain... I did find this worked though:

java --module-path /tmp/bc-fips-2.0.0.jar -javaagent:TestAgent.jar org.bouncycastle.util.DumpInfo

Is that any help, or does the additional use of --module-path cause problems?

@XueleiFan
Copy link
Author

I run into the issue with BCFIPS 2.0.0. The method is trying to get resource from system class loader, which is not available because BCFIPS was added to bootstrap class loader in the agent and the resource is not passed to system class loader.

@dghgit
Copy link
Contributor

dghgit commented Dec 1, 2024

I hate to say this, but the problem appears to be intractable.

Any call to getResource() returns null under this case, even when the class is something like:
LICENSE.class.getResource("/org/bouncycastle/LICENCSE.class");
doing
String.class.getResource("java.lang.String.class")
actually works as expected though. My guess is there's a step missing when the appendToBootstrapClassLoaderSearch() method is used.

I also think this is a bug, but it's not one of ours. I'd recommend reporting it to Oracle, if it hasn't been already.

@winfriedgerlach winfriedgerlach added the question Further information is requested label Dec 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
question Further information is requested
Projects
None yet
Development

No branches or pull requests

4 participants