CAMEL-18425: camel-cli - Make regular Camel applications work with Camel CLI
diff --git a/components-starter/camel-cli-connector-starter/src/main/java/org/apache/camel/springboot/cli/connector/CliConnectorAutoConfiguration.java b/components-starter/camel-cli-connector-starter/src/main/java/org/apache/camel/springboot/cli/connector/CliConnectorAutoConfiguration.java
index 8d95654..e11d4a3 100644
--- a/components-starter/camel-cli-connector-starter/src/main/java/org/apache/camel/springboot/cli/connector/CliConnectorAutoConfiguration.java
+++ b/components-starter/camel-cli-connector-starter/src/main/java/org/apache/camel/springboot/cli/connector/CliConnectorAutoConfiguration.java
@@ -16,6 +16,7 @@
*/
package org.apache.camel.springboot.cli.connector;
+import org.apache.camel.CamelContext;
import org.apache.camel.cli.connector.DefaultCliConnectorFactory;
import org.apache.camel.spi.CliConnectorFactory;
import org.springframework.boot.SpringBootVersion;
@@ -27,6 +28,11 @@
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
+import java.io.InputStream;
+import java.net.URL;
+import java.util.Enumeration;
+import java.util.jar.Manifest;
+
@Configuration(proxyBeanMethods = false)
@ConditionalOnProperty(name = "camel.cli.enabled", matchIfMissing = true)
@ConditionalOnBean(type = "org.apache.camel.spring.boot.CamelAutoConfiguration")
@@ -36,11 +42,30 @@
@Bean
@ConditionalOnMissingBean(CliConnectorFactory.class)
- public CliConnectorFactory cliConnectorFactory(CliConnectorConfiguration config) {
+ public CliConnectorFactory cliConnectorFactory(CamelContext camelContext, CliConnectorConfiguration config) {
CliConnectorFactory answer = new DefaultCliConnectorFactory();
answer.setEnabled(config.getEnabled());
answer.setRuntime("Spring Boot");
answer.setRuntimeVersion(SpringBootVersion.getVersion());
+
+ // if packaged as fat-jar then we need to know what was the main class that started this integration
+ try {
+ Enumeration<URL> en = this.getClass().getClassLoader().getResources("META-INF/MANIFEST.MF");
+ while (en.hasMoreElements()) {
+ URL u = en.nextElement();
+ try (InputStream is = u.openStream()) {
+ Manifest manifest = new Manifest(is);
+ String sc = manifest.getMainAttributes().getValue("Start-Class");
+ if (sc != null) {
+ answer.setRuntimeStartClass(sc);
+ break;
+ }
+ }
+ }
+ } catch (Exception e) {
+ // ignore
+ }
+
return answer;
}