You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@camel.apache.org by lb...@apache.org on 2019/01/25 08:31:54 UTC

[camel-k] branch master updated: runtime: simplify loader development

This is an automated email from the ASF dual-hosted git repository.

lburgazzoli pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/camel-k.git


The following commit(s) were added to refs/heads/master by this push:
     new 3290846  runtime: simplify loader development
3290846 is described below

commit 32908460b4fd51a0b77779664c12575e32f0991a
Author: lburgazzoli <lb...@gmail.com>
AuthorDate: Fri Jan 25 00:48:11 2019 +0100

    runtime: simplify loader development
---
 .../src/main/java/org/apache/camel/k/Language.java | 105 ---------------------
 .../main/java/org/apache/camel/k/RoutesLoader.java |   2 +-
 .../src/main/java/org/apache/camel/k/Source.java   |  18 ++--
 .../org/apache/camel/k/support/RuntimeSupport.java |   2 +-
 .../camel/k/groovy/GroovyRoutesLoader.groovy       |   8 +-
 .../apache/camel/k/jvm/loader/JavaClassLoader.java |  21 ++++-
 .../camel/k/jvm/loader/JavaScriptLoader.java       |  23 ++++-
 .../camel/k/jvm/loader/JavaSourceLoader.java       |  21 ++++-
 .../org/apache/camel/k/jvm/loader/XmlLoader.java   |  21 ++++-
 .../apache/camel/k/loader/{java-class => class}    |   0
 .../apache/camel/k/loader/{java-source => java}    |   0
 .../apache/camel/k/kotlin/KotlinRoutesLoader.kt    |   5 +-
 .../org/apache/camel/k/loader/{kotlin => kts}      |   0
 .../org/apache/camel/k/yaml/YamlFlowLoader.java    |   5 +-
 .../org/apache/camel/k/loader/{yaml-flow => flow}  |   0
 15 files changed, 94 insertions(+), 137 deletions(-)

diff --git a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Language.java b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Language.java
deleted file mode 100644
index 5fb0194..0000000
--- a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Language.java
+++ /dev/null
@@ -1,105 +0,0 @@
-/**
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements.  See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License.  You may obtain a copy of the License at
- *
- *      http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-package org.apache.camel.k;
-
-import java.util.Arrays;
-import java.util.Collections;
-import java.util.List;
-
-import org.apache.camel.util.ObjectHelper;
-import org.apache.commons.lang3.StringUtils;
-
-public enum Language {
-    Unknown(
-        "unknown",
-        Collections.emptyList(),
-        Collections.emptyList()),
-    JavaClass(
-        "java-class",
-        Collections.singletonList("class"),
-        Collections.singletonList("class")),
-    JavaSource(
-        "java-source",
-        Collections.singletonList("java"),
-        Collections.singletonList("java")),
-    JavaScript(
-        "js",
-        Arrays.asList("js", "javascript"),
-        Collections.singletonList("js")),
-    Groovy(
-        "groovy",
-        Collections.singletonList("groovy"),
-        Collections.singletonList("groovy")),
-    Xml(
-        "xml",
-        Collections.singletonList("xml"),
-        Collections.singletonList("xml")),
-    YamlFlow(
-        "yaml-flow",
-        Arrays.asList("yaml-flow", "flow"),
-        Collections.singletonList("flow")),
-    Kotlin(
-        "kotlin",
-        Arrays.asList("kotlin", "kts"),
-        Collections.singletonList("kts"));
-
-    private final String id;
-    private final List<String> names;
-    private final List<String> extensions;
-
-    Language(String id, List<String> names, List<String> extensions) {
-        this.id = ObjectHelper.notNull(id, "id");
-        this.names = names;
-        this.extensions = extensions;
-    }
-
-    public String getId() {
-        return id;
-    }
-
-    public List<String> getNames() {
-        return names;
-    }
-
-    public List<String> getExtensions() {
-        return extensions;
-    }
-
-    public static Language fromLanguageName(String name) {
-        for (Language language: values()) {
-            if (language.getNames().contains(name)) {
-                return language;
-            }
-        }
-
-        return Unknown;
-    }
-
-    public static Language fromLocation(String resource) {
-        for (Language language: values()) {
-            String path = StringUtils.substringAfter(resource, ":");
-
-            for (String ext : language.getExtensions()) {
-                if (path.endsWith("." + ext)) {
-                    return language;
-                }
-            }
-        }
-
-        return Unknown;
-    }
-}
diff --git a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/RoutesLoader.java b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/RoutesLoader.java
index 3026b92..fe78a54 100644
--- a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/RoutesLoader.java
+++ b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/RoutesLoader.java
@@ -26,7 +26,7 @@ public interface RoutesLoader {
      *
      * @return the supported languages.
      */
-    List<Language> getSupportedLanguages();
+    List<String> getSupportedLanguages();
 
     /**
      * Creates a camel {@link RouteBuilder} from the given resource.
diff --git a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Source.java b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Source.java
index 12b2d1b..b777109 100644
--- a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Source.java
+++ b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/Source.java
@@ -24,10 +24,10 @@ import org.apache.commons.lang3.StringUtils;
 
 public class Source {
     private final String location;
-    private final Language language;
+    private final String language;
     private final boolean compressed;
 
-    private Source(String location, Language language, boolean compression) {
+    private Source(String location, String language, boolean compression) {
         this.location = location;
         this.language = language;
         this.compressed = compression;
@@ -37,7 +37,7 @@ public class Source {
         return location;
     }
 
-    public Language getLanguage() {
+    public String getLanguage() {
         return language;
     }
 
@@ -68,9 +68,15 @@ public class Source {
         final String languageName = (String) params.get("language");
         final boolean compression = Boolean.valueOf((String) params.get("compression"));
 
-        Language language = ObjectHelper.isNotEmpty(languageName)
-            ? Language.fromLanguageName(languageName)
-            : Language.fromLocation(location);
+        String language = languageName;
+        if (ObjectHelper.isEmpty(language)) {
+            language = StringUtils.substringAfterLast(location, ":");
+            language = StringUtils.substringAfterLast(language, ".");
+        }
+        if (ObjectHelper.isEmpty(language)) {
+            throw new IllegalArgumentException("Unknown language " + language);
+        }
+
 
         return new Source(location, language, compression);
     }
diff --git a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/support/RuntimeSupport.java b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/support/RuntimeSupport.java
index 59c6bf6..ec8d47e 100644
--- a/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/support/RuntimeSupport.java
+++ b/runtime/camel-k-runtime-core/src/main/java/org/apache/camel/k/support/RuntimeSupport.java
@@ -126,7 +126,7 @@ public final class RuntimeSupport {
 
         try {
             finder = context.getFactoryFinder(Constants.ROUTES_LOADER_RESOURCE_PATH);
-            loader = (RoutesLoader)finder.newInstance(source.getLanguage().getId());
+            loader = (RoutesLoader)finder.newInstance(source.getLanguage());
         } catch (NoFactoryAvailableException e) {
             throw new IllegalArgumentException("Unable to find loader for: " + source, e);
         }
diff --git a/runtime/camel-k-runtime-groovy/src/main/groovy/org/apache/camel/k/groovy/GroovyRoutesLoader.groovy b/runtime/camel-k-runtime-groovy/src/main/groovy/org/apache/camel/k/groovy/GroovyRoutesLoader.groovy
index 8493c48..7bf787f 100644
--- a/runtime/camel-k-runtime-groovy/src/main/groovy/org/apache/camel/k/groovy/GroovyRoutesLoader.groovy
+++ b/runtime/camel-k-runtime-groovy/src/main/groovy/org/apache/camel/k/groovy/GroovyRoutesLoader.groovy
@@ -16,20 +16,18 @@
  */
 package org.apache.camel.k.groovy
 
-
 import org.apache.camel.builder.RouteBuilder
-import org.apache.camel.k.Language
 import org.apache.camel.k.RoutesLoader
 import org.apache.camel.k.RuntimeRegistry
 import org.apache.camel.k.Source
-import org.apache.camel.k.support.URIResolver
 import org.apache.camel.k.groovy.dsl.IntegrationConfiguration
+import org.apache.camel.k.support.URIResolver
 import org.codehaus.groovy.control.CompilerConfiguration
 
 class GroovyRoutesLoader implements RoutesLoader {
     @Override
-    List<Language> getSupportedLanguages() {
-        return Collections.singletonList(Language.Groovy)
+    List<String> getSupportedLanguages() {
+        return Collections.singletonList("groovy")
     }
 
     @Override
diff --git a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaClassLoader.java b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaClassLoader.java
index bf73a82..c13f2d1 100644
--- a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaClassLoader.java
+++ b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaClassLoader.java
@@ -1,3 +1,19 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
 package org.apache.camel.k.jvm.loader;
 
 import java.util.Collections;
@@ -5,7 +21,6 @@ import java.util.List;
 
 import org.apache.camel.builder.RouteBuilder;
 import org.apache.camel.k.Constants;
-import org.apache.camel.k.Language;
 import org.apache.camel.k.RoutesLoader;
 import org.apache.camel.k.RuntimeRegistry;
 import org.apache.camel.k.Source;
@@ -13,8 +28,8 @@ import org.apache.commons.lang3.StringUtils;
 
 public class JavaClassLoader implements RoutesLoader {
     @Override
-    public List<Language> getSupportedLanguages() {
-        return Collections.singletonList(Language.JavaClass);
+    public List<String> getSupportedLanguages() {
+        return Collections.singletonList("class");
     }
 
     @Override
diff --git a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaScriptLoader.java b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaScriptLoader.java
index ca05c10..c251f44 100644
--- a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaScriptLoader.java
+++ b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaScriptLoader.java
@@ -1,3 +1,19 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
 package org.apache.camel.k.jvm.loader;
 
 import java.io.InputStream;
@@ -13,20 +29,19 @@ import javax.script.SimpleBindings;
 
 import org.apache.camel.CamelContext;
 import org.apache.camel.builder.RouteBuilder;
-import org.apache.camel.k.Language;
 import org.apache.camel.k.RoutesLoader;
 import org.apache.camel.k.RuntimeRegistry;
 import org.apache.camel.k.Source;
-import org.apache.camel.k.support.URIResolver;
 import org.apache.camel.k.jvm.dsl.Components;
+import org.apache.camel.k.support.URIResolver;
 import org.apache.camel.model.RouteDefinition;
 import org.apache.camel.model.rest.RestConfigurationDefinition;
 import org.apache.camel.model.rest.RestDefinition;
 
 public class JavaScriptLoader implements RoutesLoader {
     @Override
-    public List<Language> getSupportedLanguages() {
-        return Collections.singletonList(Language.JavaScript);
+    public List<String> getSupportedLanguages() {
+        return Collections.singletonList("js");
     }
 
     @Override
diff --git a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaSourceLoader.java b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaSourceLoader.java
index bdcb6e3..757c16b 100644
--- a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaSourceLoader.java
+++ b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/JavaSourceLoader.java
@@ -1,3 +1,19 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
 package org.apache.camel.k.jvm.loader;
 
 import java.io.InputStream;
@@ -6,7 +22,6 @@ import java.util.Collections;
 import java.util.List;
 
 import org.apache.camel.builder.RouteBuilder;
-import org.apache.camel.k.Language;
 import org.apache.camel.k.RoutesLoader;
 import org.apache.camel.k.RuntimeRegistry;
 import org.apache.camel.k.Source;
@@ -17,8 +32,8 @@ import org.joor.Reflect;
 
 public class JavaSourceLoader implements RoutesLoader {
     @Override
-    public List<Language> getSupportedLanguages() {
-        return Collections.singletonList(Language.JavaSource);
+    public List<String> getSupportedLanguages() {
+        return Collections.singletonList("java");
     }
 
     @Override
diff --git a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/XmlLoader.java b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/XmlLoader.java
index b16fc62..cd6e9ad 100644
--- a/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/XmlLoader.java
+++ b/runtime/camel-k-runtime-jvm/src/main/java/org/apache/camel/k/jvm/loader/XmlLoader.java
@@ -1,3 +1,19 @@
+/**
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License.  You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
 package org.apache.camel.k.jvm.loader;
 
 import java.io.InputStream;
@@ -6,7 +22,6 @@ import java.util.List;
 import javax.xml.bind.UnmarshalException;
 
 import org.apache.camel.builder.RouteBuilder;
-import org.apache.camel.k.Language;
 import org.apache.camel.k.RoutesLoader;
 import org.apache.camel.k.RuntimeRegistry;
 import org.apache.camel.k.Source;
@@ -20,8 +35,8 @@ public class XmlLoader implements RoutesLoader {
     private static final Logger LOGGER = LoggerFactory.getLogger(XmlLoader.class);
 
     @Override
-    public List<Language> getSupportedLanguages() {
-        return Collections.singletonList(Language.Xml);
+    public List<String> getSupportedLanguages() {
+        return Collections.singletonList("xml");
     }
 
     @Override
diff --git a/runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/java-class b/runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/class
similarity index 100%
rename from runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/java-class
rename to runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/class
diff --git a/runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/java-source b/runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/java
similarity index 100%
rename from runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/java-source
rename to runtime/camel-k-runtime-jvm/src/main/resources/META-INF/services/org/apache/camel/k/loader/java
diff --git a/runtime/camel-k-runtime-kotlin/src/main/kotlin/org/apache/camel/k/kotlin/KotlinRoutesLoader.kt b/runtime/camel-k-runtime-kotlin/src/main/kotlin/org/apache/camel/k/kotlin/KotlinRoutesLoader.kt
index 55604ad..8d5f0e9 100644
--- a/runtime/camel-k-runtime-kotlin/src/main/kotlin/org/apache/camel/k/kotlin/KotlinRoutesLoader.kt
+++ b/runtime/camel-k-runtime-kotlin/src/main/kotlin/org/apache/camel/k/kotlin/KotlinRoutesLoader.kt
@@ -17,7 +17,6 @@
 package org.apache.camel.k.kotlin
 
 import org.apache.camel.builder.RouteBuilder
-import org.apache.camel.k.Language
 import org.apache.camel.k.RoutesLoader
 import org.apache.camel.k.RuntimeRegistry
 import org.apache.camel.k.Source
@@ -41,8 +40,8 @@ class KotlinRoutesLoader : RoutesLoader {
         val LOGGER : Logger = LoggerFactory.getLogger(KotlinRoutesLoader::class.java)
     }
 
-    override fun getSupportedLanguages(): List<Language> {
-        return listOf(Language.Kotlin)
+    override fun getSupportedLanguages(): List<String> {
+        return listOf("kts")
     }
 
     @Throws(Exception::class)
diff --git a/runtime/camel-k-runtime-kotlin/src/main/resources/META-INF/services/org/apache/camel/k/loader/kotlin b/runtime/camel-k-runtime-kotlin/src/main/resources/META-INF/services/org/apache/camel/k/loader/kts
similarity index 100%
rename from runtime/camel-k-runtime-kotlin/src/main/resources/META-INF/services/org/apache/camel/k/loader/kotlin
rename to runtime/camel-k-runtime-kotlin/src/main/resources/META-INF/services/org/apache/camel/k/loader/kts
diff --git a/runtime/camel-k-runtime-yaml/src/main/java/org/apache/camel/k/yaml/YamlFlowLoader.java b/runtime/camel-k-runtime-yaml/src/main/java/org/apache/camel/k/yaml/YamlFlowLoader.java
index d5b5a37..8b6b784 100644
--- a/runtime/camel-k-runtime-yaml/src/main/java/org/apache/camel/k/yaml/YamlFlowLoader.java
+++ b/runtime/camel-k-runtime-yaml/src/main/java/org/apache/camel/k/yaml/YamlFlowLoader.java
@@ -27,7 +27,6 @@ import com.fasterxml.jackson.databind.jsontype.NamedType;
 import com.fasterxml.jackson.dataformat.yaml.YAMLFactory;
 import com.fasterxml.jackson.dataformat.yaml.YAMLGenerator;
 import org.apache.camel.builder.RouteBuilder;
-import org.apache.camel.k.Language;
 import org.apache.camel.k.RoutesLoader;
 import org.apache.camel.k.RuntimeRegistry;
 import org.apache.camel.k.Source;
@@ -56,8 +55,8 @@ public class YamlFlowLoader implements RoutesLoader {
     }
 
     @Override
-    public List<Language> getSupportedLanguages() {
-        return Collections.singletonList(Language.YamlFlow);
+    public List<String> getSupportedLanguages() {
+        return Collections.singletonList("flow");
     }
 
     @SuppressWarnings("uncheked")
diff --git a/runtime/camel-k-runtime-yaml/src/main/resources/META-INF/services/org/apache/camel/k/loader/yaml-flow b/runtime/camel-k-runtime-yaml/src/main/resources/META-INF/services/org/apache/camel/k/loader/flow
similarity index 100%
rename from runtime/camel-k-runtime-yaml/src/main/resources/META-INF/services/org/apache/camel/k/loader/yaml-flow
rename to runtime/camel-k-runtime-yaml/src/main/resources/META-INF/services/org/apache/camel/k/loader/flow