From 09a1a05b49a5fd9f048d7b9c5fcfd5714d52e243 Mon Sep 17 00:00:00 2001 From: Andy Damevin Date: Mon, 28 Oct 2024 11:21:38 +0100 Subject: [PATCH] Safer lookup and generate static resources for web dep locator (cherry picked from commit 693cdcaa792dec1c3a421e31046880de0bc1f8c6) --- .../main/asciidoc/web-dependency-locator.adoc | 2 +- .../WebDependencyLocatorProcessor.java | 149 ++++++++---------- 2 files changed, 64 insertions(+), 87 deletions(-) diff --git a/docs/src/main/asciidoc/web-dependency-locator.adoc b/docs/src/main/asciidoc/web-dependency-locator.adoc index 4e9b7820eaa1a..6e86ff1743448 100644 --- a/docs/src/main/asciidoc/web-dependency-locator.adoc +++ b/docs/src/main/asciidoc/web-dependency-locator.adoc @@ -113,7 +113,7 @@ This means adding the following to your `index.html` will allow you to import we ===== Automatic imports -You can also automate the imports above. To do this, move your web assets from `src/main/resources/META-INF/resources` to `src/main/web` +You can also automate the imports above. To do this, move your web assets from `src/main/resources/META-INF/resources` to `src/main/resources/web` and now replace the above scripts and imports with `{#bundle /}`: [source,html] diff --git a/extensions/web-dependency-locator/deployment/src/main/java/io/quarkus/webdependency/locator/deployment/WebDependencyLocatorProcessor.java b/extensions/web-dependency-locator/deployment/src/main/java/io/quarkus/webdependency/locator/deployment/WebDependencyLocatorProcessor.java index 5954664dea853..d0a840540fb2d 100644 --- a/extensions/web-dependency-locator/deployment/src/main/java/io/quarkus/webdependency/locator/deployment/WebDependencyLocatorProcessor.java +++ b/extensions/web-dependency-locator/deployment/src/main/java/io/quarkus/webdependency/locator/deployment/WebDependencyLocatorProcessor.java @@ -7,7 +7,6 @@ import java.net.URL; import java.nio.file.Files; import java.nio.file.Path; -import java.nio.file.StandardOpenOption; import java.util.ArrayList; import java.util.HashMap; import java.util.HashSet; @@ -30,10 +29,10 @@ import io.quarkus.deployment.builditem.FeatureBuildItem; import io.quarkus.deployment.builditem.HotDeploymentWatchedFileBuildItem; import io.quarkus.deployment.pkg.builditem.CurateOutcomeBuildItem; -import io.quarkus.deployment.pkg.builditem.OutputTargetBuildItem; import io.quarkus.maven.dependency.ArtifactKey; import io.quarkus.maven.dependency.ResolvedDependency; import io.quarkus.vertx.http.deployment.RouteBuildItem; +import io.quarkus.vertx.http.deployment.spi.GeneratedStaticResourceBuildItem; import io.quarkus.vertx.http.runtime.HttpBuildTimeConfig; import io.quarkus.webdependency.locator.runtime.WebDependencyLocatorRecorder; import io.vertx.core.Handler; @@ -43,96 +42,81 @@ public class WebDependencyLocatorProcessor { private static final Logger log = Logger.getLogger(WebDependencyLocatorProcessor.class.getName()); @BuildStep - public void findRelevantFiles(BuildProducer feature, - BuildProducer hotDeploymentWatchedProducer, - WebDependencyLocatorConfig config, - OutputTargetBuildItem outputTarget) throws IOException { - - Path web = outputTarget.getOutputDirectory().getParent() - .resolve(SRC) - .resolve(MAIN) - .resolve(RESOURCES) - .resolve(config.webRoot); - - if (Files.exists(web)) { - hotDeploymentWatchedProducer.produce(new HotDeploymentWatchedFileBuildItem(config.webRoot + SLASH + STAR + STAR)); - // Find all css and js (under /app) - Path app = web - .resolve(config.appRoot); + public void feature(BuildProducer feature) { + feature.produce(new FeatureBuildItem(Feature.WEB_DEPENDENCY_LOCATOR)); + } - List cssFiles = new ArrayList<>(); - List jsFiles = new ArrayList<>(); + @BuildStep + public void findRelevantFiles(BuildProducer generatedStaticProducer, + BuildProducer hotDeploymentWatchedProducer, + WebDependencyLocatorConfig config) throws IOException { - if (Files.exists(app)) { + QuarkusClassLoader.visitRuntimeResources(config.webRoot, visit -> { + final Path web = visit.getPath(); + if (Files.isDirectory(web)) { hotDeploymentWatchedProducer - .produce(new HotDeploymentWatchedFileBuildItem( - config.webRoot + SLASH + config.appRoot + SLASH + STAR + STAR)); - try (Stream appstream = Files.walk(app)) { - appstream.forEach(path -> { - if (Files.isRegularFile(path) && path.toString().endsWith(DOT_CSS)) { - cssFiles.add(web.relativize(path)); - } else if (Files.isRegularFile(path) && path.toString().endsWith(DOT_JS)) { - jsFiles.add(web.relativize(path)); + .produce(new HotDeploymentWatchedFileBuildItem(config.webRoot + SLASH + STAR + STAR)); + // Find all css and js (under /app) + Path app = web + .resolve(config.appRoot); + + List cssFiles = new ArrayList<>(); + List jsFiles = new ArrayList<>(); + + if (Files.exists(app)) { + hotDeploymentWatchedProducer + .produce(new HotDeploymentWatchedFileBuildItem( + config.webRoot + SLASH + config.appRoot + SLASH + STAR + STAR)); + try (Stream appstream = Files.walk(app)) { + appstream.forEach(path -> { + if (Files.isRegularFile(path) && path.toString().endsWith(DOT_CSS)) { + cssFiles.add(web.relativize(path)); + } else if (Files.isRegularFile(path) && path.toString().endsWith(DOT_JS)) { + jsFiles.add(web.relativize(path)); + } + }); + } catch (IOException e) { + throw new RuntimeException(e); + } + } + + try (Stream webstream = Files.walk(web)) { + + webstream.forEach(path -> { + if (Files.isRegularFile(path)) { + String endpoint = SLASH + web.relativize(path); + try { + if (path.toString().endsWith(DOT_HTML)) { + generatedStaticProducer.produce(new GeneratedStaticResourceBuildItem(endpoint, + processHtml(path, cssFiles, jsFiles))); + } else { + generatedStaticProducer.produce(new GeneratedStaticResourceBuildItem(endpoint, path)); + } + } catch (IOException e) { + throw new UncheckedIOException(e); + } } }); + } catch (IOException e) { + throw new UncheckedIOException(e); } } + }); - try (Stream webstream = Files.walk(web)) { - - final Path resourcesDirectory = outputTarget.getOutputDirectory() - .resolve(CLASSES) - .resolve(META_INF) - .resolve(RESOURCES); - Files.createDirectories(resourcesDirectory); - - webstream.forEach(path -> { - if (Files.isRegularFile(path)) { - try { - copyResource(resourcesDirectory, web, path, cssFiles, jsFiles, path.toString().endsWith(DOT_HTML)); - } catch (IOException e) { - throw new UncheckedIOException(e); - } - } else if (Files.isRegularFile(path)) { - - } - }); - } catch (IOException e) { - throw new UncheckedIOException(e); - } - } - feature.produce(new FeatureBuildItem(Feature.WEB_DEPENDENCY_LOCATOR)); } - private void copyResource(Path resourcesDirectory, Path webRoot, Path path, List cssFiles, List jsFiles, - boolean filter) + private byte[] processHtml( + Path path, List cssFiles, List jsFiles) throws IOException { - try { + StringJoiner modifiedContent = new StringJoiner(System.lineSeparator()); - Path relativizePath = webRoot.relativize(path); + Files.lines(path).forEach(line -> { + String modifiedLine = processLine(line, cssFiles, jsFiles); + modifiedContent.add(modifiedLine); + }); - byte[] toBeCopied; - if (filter) { - StringJoiner modifiedContent = new StringJoiner(System.lineSeparator()); - - Files.lines(path).forEach(line -> { - String modifiedLine = processLine(line, cssFiles, jsFiles); - modifiedContent.add(modifiedLine); - }); - - String result = modifiedContent.toString(); - toBeCopied = result.getBytes(); - } else { - toBeCopied = Files.readAllBytes(path); - } - - final Path resourceFile = resourcesDirectory.resolve(relativizePath); - Files.createDirectories(resourceFile.getParent()); - Files.write(resourceFile, toBeCopied, StandardOpenOption.CREATE, StandardOpenOption.TRUNCATE_EXISTING); - - } catch (IOException e) { - throw new UncheckedIOException(e); - } + String result = modifiedContent.toString(); + return result.getBytes(); } private static String processLine(String line, List cssFiles, List jsFiles) { @@ -310,13 +294,6 @@ static class LibInfo { private static final String TAB = "\t"; private static final String TAB2 = TAB + TAB; - private static final String CLASSES = "classes"; - private static final String META_INF = "META-INF"; - private static final String RESOURCES = "resources"; - - private static final String SRC = "src"; - private static final String MAIN = "main"; - private static final String SLASH = "/"; private static final String STAR = "*";