From 79014b21e7c7e53edf6691e6ce4408f97fabb322 Mon Sep 17 00:00:00 2001 From: "David M. Lloyd" Date: Thu, 29 Aug 2024 08:27:08 -0500 Subject: [PATCH] Only process a path as a JAR if it exists and is a regular file --- .../common/classloader/ClassPathUtils.java | 45 +++++++++++-------- 1 file changed, 27 insertions(+), 18 deletions(-) diff --git a/classloader/src/main/java/io/smallrye/common/classloader/ClassPathUtils.java b/classloader/src/main/java/io/smallrye/common/classloader/ClassPathUtils.java index 2855062..386d6a5 100644 --- a/classloader/src/main/java/io/smallrye/common/classloader/ClassPathUtils.java +++ b/classloader/src/main/java/io/smallrye/common/classloader/ClassPathUtils.java @@ -132,25 +132,34 @@ public static void consumeAsPath(URL url, Consumer consumer) { public static R processAsPath(URL url, Function function) { if (JAR.equals(url.getProtocol())) { final String file = url.getFile(); - final int exclam = file.indexOf("!/"); - try { - URL fileUrl; - String subPath; - if (exclam == -1) { - // assume the first element is a JAR file, not a plain file, since it was a `jar:` URL - fileUrl = new URL(file); - subPath = "/"; - } else { - fileUrl = new URL(file.substring(0, exclam)); - subPath = file.substring(exclam + 1); - } - if (!fileUrl.getProtocol().equals("file")) { - throw new IllegalArgumentException("Sub-URL of JAR URL is expected to have a scheme of `file`"); - } + int exclam = file.indexOf("!/"); + for (;;) { + try { + URL fileUrl; + String subPath; + if (exclam == -1) { + // assume the first element is a JAR file, not a plain file, since it was a `jar:` URL + fileUrl = new URL(file); + subPath = "/"; + } else { + fileUrl = new URL(file.substring(0, exclam)); + subPath = file.substring(exclam + 1); + } + if (!fileUrl.getProtocol().equals("file")) { + throw new IllegalArgumentException("Sub-URL of JAR URL is expected to have a scheme of `file`"); + } - return processAsJarPath(toLocalPath(fileUrl), subPath, function); - } catch (MalformedURLException e) { - throw new RuntimeException("Failed to create a URL for '" + file.substring(0, exclam) + "'", e); + Path proposedPath = toLocalPath(fileUrl); + if (Files.isRegularFile(proposedPath)) { + return processAsJarPath(proposedPath, subPath, function); + } + if (exclam == -1) { + throw new IllegalArgumentException("File not found: " + fileUrl); + } + exclam = file.indexOf("!/", exclam + 1); + } catch (MalformedURLException e) { + throw new RuntimeException("Failed to create a URL for '" + file.substring(0, exclam) + "'", e); + } } }