diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/CachedContentLoader.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/CachedContentLoader.java index ad2c78948c4..d8ff0935d24 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/CachedContentLoader.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/CachedContentLoader.java @@ -20,7 +20,6 @@ import java.io.ByteArrayInputStream; import java.io.InputStream; -import java.net.URI; import java.nio.file.Path; import java.util.Optional; @@ -48,10 +47,10 @@ public synchronized byte[] readAllBytes() { } } - private final URI uri; + protected final String uri; private URIContentLoader[] fallbackContentLoaders; - protected CachedContentLoader(URI uri, URIContentLoader... fallbackContentLoaders) { + protected CachedContentLoader(String uri, URIContentLoader... fallbackContentLoaders) { this.uri = uri; this.fallbackContentLoaders = fallbackContentLoaders; } @@ -91,10 +90,13 @@ public InputStream getInputStream() { } } - protected abstract byte[] loadURI(URI uri); - - @Override - public URI uri() { - return uri; + protected static String trimScheme(String uri, String scheme) { + String str = uri; + if (str.toLowerCase().startsWith(scheme)) { + str = str.substring(scheme.length()); + } + return str; } + + protected abstract byte[] loadURI(); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoader.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoader.java index 413c199a674..dc940f398ad 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoader.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoader.java @@ -21,11 +21,8 @@ import java.io.IOException; import java.io.InputStream; import java.io.UncheckedIOException; -import java.net.URI; import java.net.URISyntaxException; import java.net.URL; -import java.net.URLDecoder; -import java.nio.charset.Charset; import java.nio.file.Path; import java.util.Optional; @@ -34,24 +31,12 @@ public class ClassPathContentLoader extends CachedContentLoader { private final Optional resource; private final String classpath; - ClassPathContentLoader(URI uri, Optional cl, URIContentLoader... fallbackContentLoaders) { + ClassPathContentLoader(String uri, Optional cl, URIContentLoader... fallbackContentLoaders) { super(uri, fallbackContentLoaders); - this.classpath = getPath(uri); + this.classpath = uriToPath(uri); this.resource = Optional.ofNullable(cl.orElse(Thread.currentThread().getContextClassLoader()).getResource(classpath)); } - static String getPath(URI uri) { - final String classPathPrefix = "classpath:"; - String str = URLDecoder.decode(uri.toString(), Charset.defaultCharset()); - if (str.toLowerCase().startsWith(classPathPrefix)) { - str = str.substring(classPathPrefix.length()); - while (str.startsWith("/")) { - str = str.substring(1); - } - } - return str; - } - public Optional getResource() { return resource; } @@ -74,7 +59,7 @@ private static Path fromURL(URL url) { } @Override - protected byte[] loadURI(URI uri) { + protected byte[] loadURI() { return resource.map(this::loadBytes).orElseThrow(() -> new IllegalArgumentException("cannot find classpath resource " + classpath)); } @@ -86,6 +71,17 @@ private byte[] loadBytes(URL r) { } } + static String uriToPath(String uri) { + return removeSlash(trimScheme(uri, URIContentLoaderType.CLASSPATH.scheme())); + } + + private static String removeSlash(String str) { + while (str.startsWith("/")) { + str = str.substring(1); + } + return str; + } + @Override public URIContentLoaderType type() { return URIContentLoaderType.CLASSPATH; diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/FileContentLoader.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/FileContentLoader.java index 336efe012f0..aabd9b1258b 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/FileContentLoader.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/FileContentLoader.java @@ -25,13 +25,18 @@ import java.nio.file.Path; import java.util.Optional; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + public class FileContentLoader extends CachedContentLoader { private final Path path; - FileContentLoader(URI uri, URIContentLoader... fallbackContentLoaders) { + private static final Logger logger = LoggerFactory.getLogger(FileContentLoader.class); + + FileContentLoader(String uri, URIContentLoader... fallbackContentLoaders) { super(uri, fallbackContentLoaders); - this.path = Path.of(getPath(uri)); + this.path = obtainPath(uri); } @Override @@ -39,13 +44,24 @@ public URIContentLoaderType type() { return URIContentLoaderType.FILE; } + private static Path obtainPath(String uri) { + if (uri.startsWith(URIContentLoaderType.FILE.scheme())) { + try { + return Path.of(URI.create(uri)); + } catch (Exception ex) { + logger.info("URI {} is not valid one according to Java, trying alternative approach", uri, ex); + } + } + return Path.of(uriToPath(uri)); + } + @Override protected Optional internalGetPath() { return Files.exists(path) ? Optional.of(path) : Optional.empty(); } @Override - protected byte[] loadURI(URI uri) { + protected byte[] loadURI() { try { return Files.readAllBytes(path); } catch (IOException io) { @@ -53,7 +69,7 @@ protected byte[] loadURI(URI uri) { } } - static String getPath(URI uri) { - return uri.getPath(); + static String uriToPath(String uri) { + return trimScheme(uri, URIContentLoaderType.FILE.scheme()); } } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/HttpContentLoader.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/HttpContentLoader.java index 195fcdabd41..21b9c178a16 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/HttpContentLoader.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/HttpContentLoader.java @@ -22,6 +22,7 @@ import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URI; +import java.net.URL; import java.util.Base64; import java.util.Collection; import java.util.HashMap; @@ -50,17 +51,19 @@ class HttpContentLoader extends CachedContentLoader { private Optional workflow; private String authRef; + private final URIContentLoaderType type; - HttpContentLoader(URI uri, Optional workflow, String authRef) { + HttpContentLoader(String uri, Optional workflow, String authRef, URIContentLoaderType type) { super(uri); this.workflow = workflow; this.authRef = authRef; + this.type = type; } @Override - protected byte[] loadURI(URI u) { + protected byte[] loadURI() { try { - HttpURLConnection conn = (HttpURLConnection) u.toURL().openConnection(); + HttpURLConnection conn = (HttpURLConnection) new URL(uri).openConnection(); // some http servers required specific accept header (*/* is specified for those we do not care about accept) conn.setRequestProperty("Accept", "application/json,application/yaml,application/yml,application/text,text/*,*/*"); workflow.map(Workflow::getAuth).map(Auth::getAuthDefs).stream().flatMap(Collection::stream) @@ -74,7 +77,7 @@ protected byte[] loadURI(URI u) { } else { try (InputStream is = conn.getErrorStream()) { throw new IllegalArgumentException(String.format( - "Failed to fetch remote file: %s. Status code is %d and response: %n %s", u, code, is == null ? "" : new String(is.readAllBytes()))); + "Failed to fetch remote file: %s. Status code is %d and response: %n %s", uri, code, is == null ? "" : new String(is.readAllBytes()))); } } } catch (IOException io) { @@ -147,6 +150,11 @@ private String encode(String str) { @Override public URIContentLoaderType type() { - return URIContentLoaderType.HTTP; + return type; } + + static String uriToPath(String uri) { + return URI.create(uri).getPath(); + } + } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCache.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCache.java index 85f3581ba80..dee2d22f1d1 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCache.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCache.java @@ -18,9 +18,8 @@ */ package org.kie.kogito.serverless.workflow.io; -import java.net.URI; -import java.util.function.Function; +import java.util.function.Supplier; public interface ResourceCache { - byte[] get(URI uri, Function retrieveCall); + byte[] get(String uri, Supplier retrieveCall); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactory.java index 9352508a6cd..2e49f4fa398 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactory.java @@ -18,12 +18,11 @@ */ package org.kie.kogito.serverless.workflow.io; -import java.net.URI; import java.util.Collections; import java.util.Map; import java.util.WeakHashMap; import java.util.concurrent.atomic.AtomicReference; -import java.util.function.Function; +import java.util.function.Supplier; public class ResourceCacheFactory { private static final AtomicReference cache = new AtomicReference<>(new LocalResourceCache()); @@ -33,11 +32,11 @@ public static ResourceCache getCache() { } private static class LocalResourceCache implements ResourceCache { - private final Map map = Collections.synchronizedMap(new WeakHashMap<>()); + private final Map map = Collections.synchronizedMap(new WeakHashMap<>()); @Override - public byte[] get(URI uri, Function retrieveCall) { - return map.computeIfAbsent(uri, retrieveCall); + public byte[] get(String uri, Supplier retrieveCall) { + return map.computeIfAbsent(uri, u -> retrieveCall.get()); } } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoader.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoader.java index 41b17ab3d0c..121d82450e9 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoader.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoader.java @@ -19,14 +19,11 @@ package org.kie.kogito.serverless.workflow.io; import java.io.InputStream; -import java.net.URI; import java.nio.file.Path; import java.util.Optional; public interface URIContentLoader { - URI uri(); - InputStream getInputStream(); URIContentLoaderType type(); diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderFactory.java index 6e5b806594a..5c3f82c725f 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderFactory.java @@ -22,9 +22,6 @@ import java.io.InputStream; import java.io.UncheckedIOException; import java.net.URI; -import java.net.URISyntaxException; -import java.net.URLEncoder; -import java.nio.charset.Charset; import java.util.Optional; import org.kie.kogito.serverless.workflow.parser.ParserContext; @@ -51,29 +48,11 @@ public static String readString(URIContentLoader loader) { return new String(readAllBytes(loader)); } - public static String getFileName(URI uri) { - URIContentLoaderType type = URIContentLoaderType.from(uri); - String path = uriToPath(type, uri); - return type.lastPart(path); - } - - private static String uriToPath(URIContentLoaderType type, URI uri) { - switch (type) { - case CLASSPATH: - return ClassPathContentLoader.getPath(uri); - case FILE: - return FileContentLoader.getPath(uri); - case HTTP: - default: - return uri.getPath(); - } - } - public static String readString(Builder builder) { return readString(builder.build()); } - public static URIContentLoader buildLoader(URI uri, Workflow workflow, Optional context, String authRef) { + public static URIContentLoader buildLoader(String uri, Workflow workflow, Optional context, String authRef) { Builder builder = new Builder(uri).withWorkflow(workflow).withAuthRef(authRef); context.map(c -> c.getContext().getClassLoader()).ifPresent(builder::withClassloader); getBaseURI(workflow).ifPresent(builder::withBaseURI); @@ -85,25 +64,29 @@ public static byte[] readBytes(String uriStr, Workflow workflow, ParserContext p } public static byte[] readBytes(String uriStr, Workflow workflow, Optional parserContext) { - return readAllBytes(buildLoader(URI.create(uriStr), workflow, parserContext, null)); + return readAllBytes(buildLoader(uriStr, workflow, parserContext, null)); } public static Builder builder(URI uri) { - return new Builder(uri); + return new Builder(uri.toString()); } public static Builder builder(String uri) { - return new Builder(URI.create(URLEncoder.encode(uri, Charset.defaultCharset()))); + return new Builder(uri); } public static class Builder { - private URI uri; + private String uri; private ClassLoader cl; private Workflow workflow; private String authRef; - private URI baseURI; + private String baseURI; private Builder(URI uri) { + this.uri = uri.toString(); + } + + private Builder(String uri) { this.uri = uri; } @@ -122,19 +105,21 @@ public Builder withAuthRef(String authRef) { return this; } - public Builder withBaseURI(URI baseURI) { + public Builder withBaseURI(String baseURI) { this.baseURI = baseURI; return this; } public URIContentLoader build() { - final URI finalURI = baseURI != null ? compoundURI(baseURI, uri) : uri; + final String finalURI = baseURI != null ? compoundURI(baseURI, uri) : uri; switch (URIContentLoaderType.from(finalURI)) { default: case FILE: return new FileContentLoader(finalURI, new ClassPathContentLoader(uri, Optional.ofNullable(cl))); case HTTP: - return new HttpContentLoader(finalURI, Optional.ofNullable(workflow), authRef); + return new HttpContentLoader(finalURI, Optional.ofNullable(workflow), authRef, URIContentLoaderType.HTTP); + case HTTPS: + return new HttpContentLoader(finalURI, Optional.ofNullable(workflow), authRef, URIContentLoaderType.HTTPS); case CLASSPATH: Optional optionalCl = Optional.ofNullable(cl); return finalURI == uri ? new ClassPathContentLoader(finalURI, optionalCl) : new ClassPathContentLoader(finalURI, optionalCl, new ClassPathContentLoader(uri, optionalCl)); @@ -142,24 +127,8 @@ public URIContentLoader build() { } } - public static URI compoundURI(URI baseURI, URI uri) { - if (uri.getScheme() != null) { - return uri; - } - URIContentLoaderType type = URIContentLoaderType.from(baseURI); - String basePath = type.trimLast(uriToPath(type, baseURI)); - String additionalPath = uriToPath(type, uri); - String path; - if (type.isAbsolutePath(additionalPath)) { - path = additionalPath; - } else { - path = type.concat(basePath, additionalPath); - } - try { - return new URI(type.toString().toLowerCase(), baseURI.getAuthority(), path, uri.getQuery(), uri.getFragment()); - } catch (URISyntaxException e) { - throw new IllegalArgumentException(e.getMessage(), e); - } + public static String compoundURI(String baseURI, String uri) { + return URIContentLoaderType.scheme(uri).isPresent() ? uri : URIContentLoaderType.from(baseURI).concat(baseURI, uri); } private URIContentLoaderFactory() { diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderType.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderType.java index 5b9ed8dbc37..515195bdf95 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderType.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderType.java @@ -19,35 +19,44 @@ package org.kie.kogito.serverless.workflow.io; import java.io.File; -import java.net.URI; +import java.util.Optional; +import java.util.function.Function; public enum URIContentLoaderType { - CLASSPATH(), - FILE(File.separatorChar), - HTTP(); + CLASSPATH(ClassPathContentLoader::uriToPath), + FILE(FileContentLoader::uriToPath, File.separatorChar), + HTTP(HttpContentLoader::uriToPath), + HTTPS(HttpContentLoader::uriToPath); private final char[] additionalSeparators; + private final Function getPathFunction; - private URIContentLoaderType(char... additionalSeparators) { + private final String scheme = name().toLowerCase() + ':'; + + private URIContentLoaderType(Function getPathFunction, char... additionalSeparators) { + this.getPathFunction = getPathFunction; this.additionalSeparators = additionalSeparators; } - public static URIContentLoaderType from(URI uri) { - String scheme = uri.getScheme(); - if (scheme == null) { - return FILE; - } - switch (uri.getScheme().toLowerCase()) { - case "file": - return FILE; - case "classpath": - return CLASSPATH; - case "http": - case "https": - return HTTP; - default: - throw new IllegalArgumentException("Unrecognized uri protocol " + uri); - } + public static Optional scheme(String uri) { + int indexOf = uri.indexOf(":"); + return indexOf == -1 ? Optional.empty() : Optional.of(uri.substring(0, indexOf).toLowerCase()); + } + + public static URIContentLoaderType from(String uri) { + return scheme(uri).map(scheme -> { + switch (scheme) { + default: + case "file": + return FILE; + case "classpath": + return CLASSPATH; + case "http": + return HTTP; + case "https": + return HTTPS; + } + }).orElse(FILE); } public boolean isAbsolutePath(String path) { @@ -63,16 +72,19 @@ public boolean isAbsolutePath(String path) { } public String concat(String basePath, String additionalPath) { - char separator = separator(); - if (!basePath.isBlank() && !isAbsolutePath(basePath)) { - basePath = separator + basePath; + if (isAbsolutePath(additionalPath)) { + return keepSchemaIfPresent(basePath, additionalPath); + } + int indexOf = lastIndexOf(basePath); + if (indexOf != -1) { + return keepSchemaIfPresent(basePath, basePath.substring(0, indexOf + 1) + additionalPath); + } else { + return keepSchemaIfPresent(basePath, additionalPath); } - return basePath + separator + additionalPath; } - public String trimLast(String path) { - int indexOf = lastIndexOf(path); - return indexOf != -1 ? path.substring(0, indexOf) : ""; + private String keepSchemaIfPresent(String basePath, String resultPath) { + return basePath.startsWith(scheme) && !resultPath.startsWith(scheme) ? scheme + resultPath : resultPath; } public String lastPart(String path) { @@ -80,6 +92,14 @@ public String lastPart(String path) { return indexOf != -1 ? path.substring(indexOf + 1) : path; } + public String scheme() { + return scheme; + } + + public String uriToPath(String uri) { + return getPathFunction.apply(uri); + } + private int lastIndexOf(String path) { int indexOf = path.lastIndexOf('/'); int i = 0; @@ -89,7 +109,4 @@ private int lastIndexOf(String path) { return indexOf; } - private char separator() { - return additionalSeparators.length > 0 ? additionalSeparators[0] : '/'; - } } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/AbstractWorkflowOperationIdFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/AbstractWorkflowOperationIdFactory.java index 7fefb0f2a8d..5f4278c92d6 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/AbstractWorkflowOperationIdFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/AbstractWorkflowOperationIdFactory.java @@ -20,7 +20,6 @@ import java.io.IOException; import java.io.UncheckedIOException; -import java.net.URI; import java.util.Optional; import org.kie.kogito.jackson.utils.ObjectMapperFactory; @@ -47,13 +46,13 @@ public abstract class AbstractWorkflowOperationIdFactory implements WorkflowOper public WorkflowOperationId from(Workflow workflow, FunctionDefinition function, Optional context) { ActionResource actionResource = ActionResourceFactory.getActionResource(function); Optional convertedUri = convertURI(workflow, context, actionResource.getUri()); - final URI uri; final String fileName; + final String uri; if (convertedUri.isPresent()) { - uri = URI.create(convertedUri.get()); + uri = convertedUri.get(); fileName = actionResource.getUri(); } else { - uri = URI.create(actionResource.getUri()); + uri = actionResource.getUri(); fileName = getFileName(workflow, function, context, uri, actionResource.getOperation(), actionResource.getService()); } if (fileName == null || fileName.isBlank()) { @@ -88,5 +87,5 @@ private JsonNode getUriDefinitions(Workflow workflow, Optional co return definitions; } - protected abstract String getFileName(Workflow workflow, FunctionDefinition function, Optional context, URI uri, String operation, String service); + protected abstract String getFileName(Workflow workflow, FunctionDefinition function, Optional context, String uri, String operation, String service); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdFactory.java index 0348f9df43e..3cbb9bd79de 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdFactory.java @@ -18,11 +18,10 @@ */ package org.kie.kogito.serverless.workflow.operationid; -import java.net.URI; import java.util.Optional; import java.util.Set; -import org.kie.kogito.serverless.workflow.io.URIContentLoaderFactory; +import org.kie.kogito.serverless.workflow.io.URIContentLoaderType; import org.kie.kogito.serverless.workflow.parser.ParserContext; import io.serverlessworkflow.api.Workflow; @@ -33,8 +32,9 @@ public class FileNameWorkflowOperationIdFactory extends AbstractWorkflowOperatio public static final String FILE_PROP_VALUE = "FILE_NAME"; @Override - public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, URI uri, String operation, String service) { - return URIContentLoaderFactory.getFileName(uri); + public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, String uri, String operation, String service) { + URIContentLoaderType type = URIContentLoaderType.from(uri); + return type.lastPart(type.uriToPath(uri)); } @Override diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FunctionWorkflowOperationIdFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FunctionWorkflowOperationIdFactory.java index 90ce8f093c9..b81c3127350 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FunctionWorkflowOperationIdFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/FunctionWorkflowOperationIdFactory.java @@ -18,7 +18,6 @@ */ package org.kie.kogito.serverless.workflow.operationid; -import java.net.URI; import java.util.Optional; import java.util.Set; @@ -31,7 +30,7 @@ public class FunctionWorkflowOperationIdFactory extends AbstractWorkflowOperatio public static final String FUNCTION_PROP_VALUE = "FUNCTION_NAME"; @Override - public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, URI uri, String operation, String service) { + public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, String uri, String operation, String service) { return workflow.getId() + '_' + function.getName(); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/URIWorkflowOperationIdFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/URIWorkflowOperationIdFactory.java index d15a557b63b..e75cdd1a9ef 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/URIWorkflowOperationIdFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/URIWorkflowOperationIdFactory.java @@ -18,11 +18,10 @@ */ package org.kie.kogito.serverless.workflow.operationid; -import java.net.URI; -import java.nio.file.Path; import java.util.Optional; import java.util.Set; +import org.kie.kogito.serverless.workflow.io.URIContentLoaderType; import org.kie.kogito.serverless.workflow.parser.ParserContext; import io.serverlessworkflow.api.Workflow; @@ -33,8 +32,8 @@ public class URIWorkflowOperationIdFactory extends AbstractWorkflowOperationIdFa public static final String URI_PROP_VALUE = "FULL_URI"; @Override - public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, URI uri, String operation, String service) { - return Path.of(uri.getPath()).toString(); + public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, String uri, String operation, String service) { + return URIContentLoaderType.from(uri).uriToPath(uri); } @Override diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/WorkflowOperationId.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/WorkflowOperationId.java index c32be6e22c6..258f60a2bb8 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/WorkflowOperationId.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/operationid/WorkflowOperationId.java @@ -18,16 +18,14 @@ */ package org.kie.kogito.serverless.workflow.operationid; -import java.net.URI; - public class WorkflowOperationId { - private final URI uri; + private final String uri; private final String operation; private final String fileName; private final String packageName; private final String service; - WorkflowOperationId(URI uri, String operation, String service, String fileName, String packageName) { + WorkflowOperationId(String uri, String operation, String service, String fileName, String packageName) { this.uri = uri; this.operation = operation; this.service = service; @@ -35,7 +33,7 @@ public class WorkflowOperationId { this.packageName = packageName; } - public URI getUri() { + public String getUri() { return uri; } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/parser/JsonSchemaReader.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/parser/JsonSchemaReader.java index 5fe1027a851..81e47771caf 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/parser/JsonSchemaReader.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/parser/JsonSchemaReader.java @@ -20,7 +20,6 @@ import java.io.IOException; import java.io.UncheckedIOException; -import java.net.URI; import java.util.HashMap; import java.util.Map; import java.util.Objects; @@ -62,12 +61,12 @@ private static String getId(JsonNode schemaContent, Counter counter) { } } - static JsonNode read(URI baseURI, byte[] content) { + static JsonNode read(String baseURI, byte[] content) { try { ObjectNode node = ObjectMapperFactory.get().readValue(content, ObjectNode.class); JsonNode id = node.get("$id"); if (id != null) { - baseURI = URI.create(id.asText()); + baseURI = id.asText(); } Objects.requireNonNull(baseURI, "BaseURI must not be null"); Map schemas = new HashMap<>(); @@ -88,7 +87,7 @@ private static JsonNode fillDefs(Map schemas) { return node; } - private static void replaceRefsWithDefs(JsonNode node, URI baseURI, Map schemas, Counter counter) { + private static void replaceRefsWithDefs(JsonNode node, String baseURI, Map schemas, Counter counter) { if (node.isArray()) { node.elements().forEachRemaining(n -> replaceRefsWithDefs(n, baseURI, schemas, counter)); } else if (node.isObject()) { @@ -103,7 +102,7 @@ private static void replaceRefsWithDefs(JsonNode node, URI baseURI, Map parseProcess() { private Optional modelValidator(ParserContext parserContext, Optional schema) { return schema.map(s -> new JsonSchemaValidatorSupplier(JsonSchemaReader.read( - getBaseURI(workflow).map(u -> compoundURI(u, URI.create(s.getSchema()))).orElseGet(() -> URI.create(s.getSchema())), + getBaseURI(workflow).map(u -> compoundURI(u, s.getSchema())).orElseGet(() -> s.getSchema()), readBytes(s.getSchema(), workflow, parserContext)), s.isFailOnValidationErrors())); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/utils/ServerlessWorkflowUtils.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/utils/ServerlessWorkflowUtils.java index 9a85a798e86..e21330ef2e1 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/utils/ServerlessWorkflowUtils.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/main/java/org/kie/kogito/serverless/workflow/utils/ServerlessWorkflowUtils.java @@ -22,7 +22,6 @@ import java.io.InputStreamReader; import java.io.Reader; import java.io.Writer; -import java.net.URI; import java.net.URL; import java.nio.file.Files; import java.nio.file.Path; @@ -141,8 +140,8 @@ public static void writeWorkflow(Workflow workflow, Writer writer, WorkflowForma objectMapper.writeValue(writer, workflow); } - public static Optional getBaseURI(Workflow workflow) { - return Optional.ofNullable(getMetadata(workflow).get(BASE_URI)).map(URI::create); + public static Optional getBaseURI(Workflow workflow) { + return Optional.ofNullable(getMetadata(workflow).get(BASE_URI)); } public static Workflow withBaseURI(Workflow workflow, String baseURI) { diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoaderTest.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoaderTest.java index 4c317433b50..5f732566b16 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoaderTest.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ClassPathContentLoaderTest.java @@ -18,7 +18,6 @@ */ package org.kie.kogito.serverless.workflow.io; -import java.net.URI; import java.util.Optional; import org.junit.jupiter.api.Test; @@ -45,7 +44,7 @@ void testPrefixSlashPath() { } void testPath(String prefix) { - ClassPathContentLoader contentLoader = new ClassPathContentLoader(URI.create(prefix + PATH), Optional.empty()); + ClassPathContentLoader contentLoader = new ClassPathContentLoader(prefix + PATH, Optional.empty()); assertThat(contentLoader.classpath()).isEqualTo(PATH); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactoryTest.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactoryTest.java index 76d419bed84..a995d3d4cb4 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactoryTest.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/ResourceCacheFactoryTest.java @@ -18,11 +18,10 @@ */ package org.kie.kogito.serverless.workflow.io; -import java.net.URI; import java.util.Map; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.atomic.AtomicInteger; -import java.util.function.Function; +import java.util.function.Supplier; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; @@ -31,13 +30,13 @@ public class ResourceCacheFactoryTest { - private URI uri; + private String uri; private AtomicInteger counter; @BeforeEach void setup() { - uri = URI.create("http:://www.google.com"); + uri = "http:://www.google.com"; counter = new AtomicInteger(); } @@ -62,11 +61,11 @@ void testCustomResourceCache() { } private static class TestResourceCache implements ResourceCache { - private Map map = new ConcurrentHashMap<>(); + private Map map = new ConcurrentHashMap<>(); @Override - public byte[] get(URI uri, Function retrieveCall) { - return map.computeIfAbsent(uri, retrieveCall); + public byte[] get(String uri, Supplier retrieveCall) { + return map.computeIfAbsent(uri, u -> retrieveCall.get()); } } @@ -77,7 +76,7 @@ private void callIt(int numOfTimes) { } } - private byte[] called(URI uri) { + private byte[] called() { return new byte[] { (byte) counter.incrementAndGet() }; } } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderTest.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderTest.java index e3c2ec36962..551b9c22fbc 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderTest.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/io/URIContentLoaderTest.java @@ -19,7 +19,6 @@ package org.kie.kogito.serverless.workflow.io; import java.io.UncheckedIOException; -import java.net.URI; import java.net.URISyntaxException; import org.junit.jupiter.api.Test; @@ -35,12 +34,12 @@ class URIContentLoaderTest { @Test void testExistingFile() throws URISyntaxException { - assertThat(readString(builder(Thread.currentThread().getContextClassLoader().getResource("pepe.txt").toURI()))).isEqualTo("my name is javierito"); + assertThat(readString(builder(Thread.currentThread().getContextClassLoader().getResource("pepe a pepa.txt").toURI()))).isEqualTo("my name is javierito"); } @Test void testExistingClasspath() { - assertThat(readString(builder("classpath:pepe.txt"))).isEqualTo("my name is javierito"); + assertThat(readString(builder("classpath:pepe a pepa.txt"))).isEqualTo("my name is javierito"); } @Test @@ -52,18 +51,19 @@ void testNotExistingFile() { @Test void testNotExistingClasspath() { Builder builder = builder("classpath:/noPepe.txt"); - assertThatExceptionOfType(UncheckedIOException.class).isThrownBy(() -> readString(builder)); + assertThatExceptionOfType(IllegalArgumentException.class).isThrownBy(() -> readString(builder)); } @Test void testCompoundURI() { - assertThat(compoundURI(URI.create("classpath:pepe.json"), URI.create("pepa.json"))).isEqualTo(URI.create("classpath:/pepa.json")); - assertThat(compoundURI(URI.create("classpath:pepe.json"), URI.create("file:///pepa.json"))).isEqualTo(URI.create("file:///pepa.json")); - assertThat(compoundURI(URI.create("classpath:schema/pepe.json"), URI.create("/pepa.json"))).isEqualTo(URI.create("classpath:/pepa.json")); - assertThat(compoundURI(URI.create("classpath:schema/pepe.json"), URI.create("pepa.json"))).isEqualTo(URI.create("classpath:/schema/pepa.json")); - assertThat(compoundURI(URI.create("pepe.json"), URI.create("pepa.json"))).isEqualTo(URI.create("file:///pepa.json")); - assertThat(compoundURI(URI.create("schema/pepe.json"), URI.create("pepa.json"))).isEqualTo(URI.create("file:///schema/pepa.json")); - assertThat(compoundURI(URI.create("schema/pepe.json"), URI.create("/pepa.json"))).isEqualTo(URI.create("file:///pepa.json")); - assertThat(compoundURI(URI.create("pepe.json"), URI.create("classpath:pepa.json"))).isEqualTo(URI.create("classpath:pepa.json")); + assertThat(compoundURI("classpath:pepe.json", "pepa.json")).isEqualTo("classpath:pepa.json"); + assertThat(compoundURI("classpath:pepe.json", "file:/pepa.json")).isEqualTo("file:/pepa.json"); + assertThat(compoundURI("classpath:schema/pepe.json", "/pepa.json")).isEqualTo("classpath:/pepa.json"); + assertThat(compoundURI("classpath:schema/pepe.json", "pepa.json")).isEqualTo("classpath:schema/pepa.json"); + assertThat(compoundURI("pepe.json", "pepa.json")).isEqualTo("pepa.json"); + assertThat(compoundURI("schema/pepe.json", "pepa.json")).isEqualTo("schema/pepa.json"); + assertThat(compoundURI("schema/pepe.json", "/pepa.json")).isEqualTo("/pepa.json"); + assertThat(compoundURI("pepe.json", "classpath:pepa.json")).isEqualTo("classpath:pepa.json"); } + } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdTest.java b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdTest.java index e9606a5093f..336cb8ae143 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdTest.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/java/org/kie/kogito/serverless/workflow/operationid/FileNameWorkflowOperationIdTest.java @@ -28,7 +28,6 @@ import io.serverlessworkflow.api.functions.FunctionDefinition.Type; import static org.assertj.core.api.Assertions.assertThat; -import static org.assertj.core.api.Assertions.assertThatThrownBy; import static org.mockito.Mockito.mock; class FileNameWorkflowOperationIdTest { @@ -67,12 +66,4 @@ void testOperationIdWithService() { assertThat(id.getUri()).hasToString("http://myserver.com/spec/PePE1.yaml"); assertThat(id.getService()).isEqualTo("service"); } - - @Test - void testEmptyFileName() { - definition.setType(Type.REST); - definition.setOperation("file://wrongUri.yaml#doSomething"); - assertThatThrownBy(() -> factory.from(workflow, definition, Optional.empty())).isInstanceOf(IllegalArgumentException.class) - .hasMessageContaining("Empty file name"); - } } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/resources/pepe.txt b/kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/resources/pepe a pepa.txt similarity index 100% rename from kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/resources/pepe.txt rename to kogito-serverless-workflow/kogito-serverless-workflow-builder/src/test/resources/pepe a pepa.txt diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/operationid/SpecWorkflowOperationIdFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/operationid/SpecWorkflowOperationIdFactory.java index c08125e1705..9c606ecd981 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/operationid/SpecWorkflowOperationIdFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/operationid/SpecWorkflowOperationIdFactory.java @@ -18,7 +18,6 @@ */ package org.kie.kogito.serverless.workflow.operationid; -import java.net.URI; import java.util.Optional; import java.util.Set; @@ -36,8 +35,7 @@ public class SpecWorkflowOperationIdFactory extends AbstractWorkflowOperationIdF private static final Logger logger = LoggerFactory.getLogger(SpecWorkflowOperationIdFactory.class); @Override - public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, URI uri, String operation, String service) { - logger.debug("Testing reproducible"); + public String getFileName(Workflow workflow, FunctionDefinition function, Optional context, String uri, String operation, String service) { return OpenAPIFactory.getOpenAPI(uri, workflow, function, context).getInfo() .getTitle(); } diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/utils/OpenAPIFactory.java b/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/utils/OpenAPIFactory.java index 5d49f07e71f..6f6835d5f4a 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/utils/OpenAPIFactory.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-openapi-common/src/main/java/org/kie/kogito/serverless/workflow/utils/OpenAPIFactory.java @@ -18,7 +18,6 @@ */ package org.kie.kogito.serverless.workflow.utils; -import java.net.URI; import java.util.Optional; import org.kie.kogito.serverless.workflow.parser.ParserContext; @@ -41,7 +40,7 @@ public class OpenAPIFactory { private OpenAPIFactory() { } - public static OpenAPI getOpenAPI(URI uri, Workflow workflow, FunctionDefinition function, Optional context) { + public static OpenAPI getOpenAPI(String uri, Workflow workflow, FunctionDefinition function, Optional context) { SwaggerParseResult result = new OpenAPIParser().readContents(readString(buildLoader(uri, workflow, context, function.getAuthRef())), null, null); OpenAPI openAPI = result.getOpenAPI(); diff --git a/kogito-serverless-workflow/kogito-serverless-workflow-openapi-parser/src/main/java/org/kie/kogito/serverless/workflow/parser/rest/DescriptorRestOperationHandler.java b/kogito-serverless-workflow/kogito-serverless-workflow-openapi-parser/src/main/java/org/kie/kogito/serverless/workflow/parser/rest/DescriptorRestOperationHandler.java index dd46b0b4279..82a63c7cb20 100644 --- a/kogito-serverless-workflow/kogito-serverless-workflow-openapi-parser/src/main/java/org/kie/kogito/serverless/workflow/parser/rest/DescriptorRestOperationHandler.java +++ b/kogito-serverless-workflow/kogito-serverless-workflow-openapi-parser/src/main/java/org/kie/kogito/serverless/workflow/parser/rest/DescriptorRestOperationHandler.java @@ -18,7 +18,6 @@ */ package org.kie.kogito.serverless.workflow.parser.rest; -import java.net.URI; import java.util.ArrayList; import java.util.Collection; import java.util.Optional; @@ -86,7 +85,7 @@ public class DescriptorRestOperationHandler extends OpenAPITypeHandler { private > WorkItemNodeFactory addOpenApiParameters(WorkItemNodeFactory node, Workflow workflow, FunctionDefinition function, ParserContext parserContext, WorkflowOperationId operationId) { - URI uri = operationId.getUri(); + String uri = operationId.getUri(); String serviceName = replaceNonAlphanumeric(operationId.getFileName()); // although OpenAPIParser has built in support to load uri, it messes up when using contextclassloader, so using our retrieval apis to get the content OpenAPI openAPI = OpenAPIFactory.getOpenAPI(uri, workflow, function, Optional.of(parserContext)); diff --git a/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/quarkus/serverless/workflow/rpc/WorkflowRPCCodeGenProvider.java b/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/quarkus/serverless/workflow/rpc/WorkflowRPCCodeGenProvider.java index 8c35dcc7bf7..59afcdc0f1d 100644 --- a/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/quarkus/serverless/workflow/rpc/WorkflowRPCCodeGenProvider.java +++ b/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/quarkus/serverless/workflow/rpc/WorkflowRPCCodeGenProvider.java @@ -72,7 +72,8 @@ public boolean trigger(CodeGenContext context) throws CodeGenException { } ProtocUtils.generateDescriptor(protoFiles, context); return true; - } catch (IOException io) { + } catch (Exception io) { + logger.error("Exception generating RPC code", io); throw new CodeGenException(io); } } diff --git a/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/serverless/workflow/io/QuarkusResourceCache.java b/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/serverless/workflow/io/QuarkusResourceCache.java index 310dedb1d6b..17beb1d815b 100644 --- a/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/serverless/workflow/io/QuarkusResourceCache.java +++ b/quarkus/extensions/kogito-quarkus-serverless-workflow-extension/kogito-quarkus-serverless-workflow-deployment/src/main/java/org/kie/kogito/serverless/workflow/io/QuarkusResourceCache.java @@ -18,8 +18,7 @@ */ package org.kie.kogito.serverless.workflow.io; -import java.net.URI; -import java.util.function.Function; +import java.util.function.Supplier; import io.quarkus.cache.Cache; import io.quarkus.cache.CacheName; @@ -40,7 +39,7 @@ void init() { ResourceCacheFactory.setResourceCache(this::get); } - private byte[] get(URI uri, Function retrieveCall) { - return cache.get(uri, retrieveCall).await().indefinitely(); + private byte[] get(String uri, Supplier retrieveCall) { + return cache.get(uri, u -> retrieveCall.get()).await().indefinitely(); } }