From 84bc43415ff0aa7c6f6ae557013903db5b799cc2 Mon Sep 17 00:00:00 2001 From: George Gastaldi Date: Tue, 20 Sep 2022 13:18:45 -0300 Subject: [PATCH] Prevent potential NPEs in QuarkusClassLoader - Fixes #28098 --- .../classloading/QuarkusClassLoader.java | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/independent-projects/bootstrap/core/src/main/java/io/quarkus/bootstrap/classloading/QuarkusClassLoader.java b/independent-projects/bootstrap/core/src/main/java/io/quarkus/bootstrap/classloading/QuarkusClassLoader.java index 1badcfe6c8c209..f3a8ba5848f0fc 100644 --- a/independent-projects/bootstrap/core/src/main/java/io/quarkus/bootstrap/classloading/QuarkusClassLoader.java +++ b/independent-projects/bootstrap/core/src/main/java/io/quarkus/bootstrap/classloading/QuarkusClassLoader.java @@ -230,11 +230,14 @@ public Enumeration getResources(String unsanitisedName, boolean parentAlrea } } //TODO: in theory resources could have been added in dev mode - //but I don't thing this really matters for this code path + //but I don't think this really matters for this code path ClassPathElement[] providers = state.loadableResources.get(name); if (providers != null) { for (ClassPathElement element : providers) { ClassPathResource res = element.getResource(name); + if (res == null) { + continue; + } //if the requested name ends with a trailing / we make sure //that the resource is a directory, and return a URL that ends with a / //this matches the behaviour of URLClassLoader @@ -351,7 +354,10 @@ public URL getResource(String unsanitisedName) { if (name.endsWith(".class") && !endsWithTrailingSlash) { ClassPathElement[] providers = state.loadableResources.get(name); if (providers != null) { - return providers[0].getResource(name).getUrl(); + ClassPathResource resource = providers[0].getResource(name); + if (resource != null) { + return resource.getUrl(); + } } } else { for (ClassPathElement i : elements) { @@ -391,7 +397,11 @@ public InputStream getResourceAsStream(String unsanitisedName) { if (name.endsWith(".class")) { ClassPathElement[] providers = state.loadableResources.get(name); if (providers != null) { - return new ByteArrayInputStream(providers[0].getResource(name).getData()); + ClassPathResource resource = providers[0].getResource(name); + if (resource == null) { + return null; + } + return new ByteArrayInputStream(resource.getData()); } } else { for (ClassPathElement i : elements) {