From 722cbc5d1f656c48eb889ce22fa60e8da49991c3 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 10:50:28 +0200 Subject: [PATCH 01/64] initial commit Signed-off-by: Iliyan Velichkov --- components/api/api-http/pom.xml | 15 +++++--- components/api/api-mail/pom.xml | 5 --- components/api/api-messaging/pom.xml | 6 ---- components/api/api-net/pom.xml | 7 ---- components/engine/engine-websockets/pom.xml | 6 ---- components/ide/ide-console/pom.xml | 7 ---- modules/commons/commons-config/pom.xml | 1 + modules/commons/commons-helpers/pom.xml | 1 + modules/commons/commons-process/pom.xml | 1 + modules/commons/commons-timeout/pom.xml | 1 + modules/commons/commons-xml2json/pom.xml | 1 + modules/database/database-h2/pom.xml | 1 + .../database/database-mongodb-jdbc/pom.xml | 1 + modules/database/database-sql-h2/pom.xml | 1 + modules/database/database-sql-hana/pom.xml | 1 + modules/database/database-sql-mongodb/pom.xml | 1 + modules/database/database-sql-mysql/pom.xml | 1 + .../database/database-sql-postgres/pom.xml | 1 + .../database/database-sql-snowflake/pom.xml | 1 + modules/database/database-sql-sybase/pom.xml | 1 + modules/database/database-sql/pom.xml | 1 + modules/mail/mail-env-config/pom.xml | 1 + modules/odata/odata-core-test/pom.xml | 1 + modules/odata/odata-core/pom.xml | 1 + modules/odata/odata-samples-northwind/pom.xml | 1 + .../repository/repository-api-test/pom.xml | 1 + modules/repository/repository-api/pom.xml | 1 + modules/repository/repository-cache/pom.xml | 1 + modules/repository/repository-local/pom.xml | 1 + modules/repository/repository-master/pom.xml | 1 + modules/repository/repository-search/pom.xml | 1 + modules/repository/repository-zip/pom.xml | 1 + pom.xml | 36 +++++++------------ 33 files changed, 49 insertions(+), 59 deletions(-) diff --git a/components/api/api-http/pom.xml b/components/api/api-http/pom.xml index a9f808f88b7..b41be8b0e06 100644 --- a/components/api/api-http/pom.xml +++ b/components/api/api-http/pom.xml @@ -1,4 +1,6 @@ - + 4.0.0 @@ -24,7 +26,7 @@ org.eclipse.dirigible dirigible-commons-helpers - + org.eclipse.dirigible @@ -34,7 +36,7 @@ org.eclipse.dirigible dirigible-components-engine-javascript - + org.eclipse.dirigible @@ -44,13 +46,13 @@ org.eclipse.dirigible dirigible-components-api-io - + org.eclipse.dirigible dirigible-components-api-test - + commons-net @@ -60,14 +62,17 @@ org.apache.httpcomponents httpasyncclient + ${httpasyncclient.version} org.apache.httpcomponents httpclient + ${httpcore.version} org.apache.httpcomponents httpmime + ${httpcore.version} commons-fileupload diff --git a/components/api/api-mail/pom.xml b/components/api/api-mail/pom.xml index f39e5975641..518afc6b364 100644 --- a/components/api/api-mail/pom.xml +++ b/components/api/api-mail/pom.xml @@ -29,11 +29,6 @@ org.eclipse.dirigible dirigible-commons-config - - - com.sun.mail - jakarta.mail - diff --git a/components/api/api-messaging/pom.xml b/components/api/api-messaging/pom.xml index 1c05bf66a5a..d7895df741f 100644 --- a/components/api/api-messaging/pom.xml +++ b/components/api/api-messaging/pom.xml @@ -38,12 +38,6 @@ - - javax.websocket - javax.websocket-api - provided - - junit junit diff --git a/components/api/api-net/pom.xml b/components/api/api-net/pom.xml index 6bb8ddf99dd..0f3d80570a9 100644 --- a/components/api/api-net/pom.xml +++ b/components/api/api-net/pom.xml @@ -31,13 +31,6 @@ dirigible-components-engine-javascript - - - javax.websocket - javax.websocket-api - provided - - diff --git a/components/engine/engine-websockets/pom.xml b/components/engine/engine-websockets/pom.xml index 013c0e212dd..fef348b0469 100644 --- a/components/engine/engine-websockets/pom.xml +++ b/components/engine/engine-websockets/pom.xml @@ -41,12 +41,6 @@ dirigible-components-api-net - - - javax.websocket - javax.websocket-api - - diff --git a/components/ide/ide-console/pom.xml b/components/ide/ide-console/pom.xml index 15e64a37d52..3bd53ff9b68 100644 --- a/components/ide/ide-console/pom.xml +++ b/components/ide/ide-console/pom.xml @@ -28,13 +28,6 @@ test - - - javax.websocket - javax.websocket-api - provided - - diff --git a/modules/commons/commons-config/pom.xml b/modules/commons/commons-config/pom.xml index 898cc78f5a8..69c78d698d4 100644 --- a/modules/commons/commons-config/pom.xml +++ b/modules/commons/commons-config/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/commons/commons-helpers/pom.xml b/modules/commons/commons-helpers/pom.xml index c5ef2f0a91f..d117120319f 100644 --- a/modules/commons/commons-helpers/pom.xml +++ b/modules/commons/commons-helpers/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/commons/commons-process/pom.xml b/modules/commons/commons-process/pom.xml index 6894fc19618..9e0598a79a5 100644 --- a/modules/commons/commons-process/pom.xml +++ b/modules/commons/commons-process/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/commons/commons-timeout/pom.xml b/modules/commons/commons-timeout/pom.xml index 2eaaa3bbc85..a524869e842 100644 --- a/modules/commons/commons-timeout/pom.xml +++ b/modules/commons/commons-timeout/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/commons/commons-xml2json/pom.xml b/modules/commons/commons-xml2json/pom.xml index 75e3534ee73..70939880643 100644 --- a/modules/commons/commons-xml2json/pom.xml +++ b/modules/commons/commons-xml2json/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-h2/pom.xml b/modules/database/database-h2/pom.xml index e84d27287e4..0afc075eaaf 100644 --- a/modules/database/database-h2/pom.xml +++ b/modules/database/database-h2/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-mongodb-jdbc/pom.xml b/modules/database/database-mongodb-jdbc/pom.xml index 5942f20d551..ae713be81be 100644 --- a/modules/database/database-mongodb-jdbc/pom.xml +++ b/modules/database/database-mongodb-jdbc/pom.xml @@ -28,6 +28,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-h2/pom.xml b/modules/database/database-sql-h2/pom.xml index 2b5895357d1..0ce958ff4ff 100644 --- a/modules/database/database-sql-h2/pom.xml +++ b/modules/database/database-sql-h2/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-hana/pom.xml b/modules/database/database-sql-hana/pom.xml index afff8c86dec..aba44aeeb5b 100644 --- a/modules/database/database-sql-hana/pom.xml +++ b/modules/database/database-sql-hana/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-mongodb/pom.xml b/modules/database/database-sql-mongodb/pom.xml index a7288dbcbe4..0527d4130dd 100644 --- a/modules/database/database-sql-mongodb/pom.xml +++ b/modules/database/database-sql-mongodb/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-mysql/pom.xml b/modules/database/database-sql-mysql/pom.xml index 4069b4c6d05..2a18e874148 100644 --- a/modules/database/database-sql-mysql/pom.xml +++ b/modules/database/database-sql-mysql/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-postgres/pom.xml b/modules/database/database-sql-postgres/pom.xml index 87d46222d91..e16f983a642 100644 --- a/modules/database/database-sql-postgres/pom.xml +++ b/modules/database/database-sql-postgres/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-snowflake/pom.xml b/modules/database/database-sql-snowflake/pom.xml index 719fac45b56..38a7f922f6a 100644 --- a/modules/database/database-sql-snowflake/pom.xml +++ b/modules/database/database-sql-snowflake/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql-sybase/pom.xml b/modules/database/database-sql-sybase/pom.xml index 4440934fa2f..870244a4a70 100644 --- a/modules/database/database-sql-sybase/pom.xml +++ b/modules/database/database-sql-sybase/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/database/database-sql/pom.xml b/modules/database/database-sql/pom.xml index 75f5deb4669..349ca0c907c 100644 --- a/modules/database/database-sql/pom.xml +++ b/modules/database/database-sql/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/mail/mail-env-config/pom.xml b/modules/mail/mail-env-config/pom.xml index c4326385236..509c970cc92 100644 --- a/modules/mail/mail-env-config/pom.xml +++ b/modules/mail/mail-env-config/pom.xml @@ -23,6 +23,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index fb45d238d55..2ca2e020eed 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -22,6 +22,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${custom.java.build.version} ${custom.java.build.version} true diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index 63dc769120d..1fac2a4ab17 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -22,6 +22,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${custom.java.build.version} ${custom.java.build.version} true diff --git a/modules/odata/odata-samples-northwind/pom.xml b/modules/odata/odata-samples-northwind/pom.xml index 66be4cb4e8d..236db90b8d7 100644 --- a/modules/odata/odata-samples-northwind/pom.xml +++ b/modules/odata/odata-samples-northwind/pom.xml @@ -22,6 +22,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${custom.java.build.version} ${custom.java.build.version} true diff --git a/modules/repository/repository-api-test/pom.xml b/modules/repository/repository-api-test/pom.xml index dcfe3d63b92..5e5e40f375c 100644 --- a/modules/repository/repository-api-test/pom.xml +++ b/modules/repository/repository-api-test/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/repository/repository-api/pom.xml b/modules/repository/repository-api/pom.xml index a285ab46e81..2055f094aab 100644 --- a/modules/repository/repository-api/pom.xml +++ b/modules/repository/repository-api/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/repository/repository-cache/pom.xml b/modules/repository/repository-cache/pom.xml index 0a04abc646a..87f8cb56c43 100644 --- a/modules/repository/repository-cache/pom.xml +++ b/modules/repository/repository-cache/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/repository/repository-local/pom.xml b/modules/repository/repository-local/pom.xml index f84909c4480..1dfcf75dfe2 100644 --- a/modules/repository/repository-local/pom.xml +++ b/modules/repository/repository-local/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/repository/repository-master/pom.xml b/modules/repository/repository-master/pom.xml index b85e49cef56..80bc8cc3263 100644 --- a/modules/repository/repository-master/pom.xml +++ b/modules/repository/repository-master/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/repository/repository-search/pom.xml b/modules/repository/repository-search/pom.xml index ddff32a0e19..9eec7d818d0 100644 --- a/modules/repository/repository-search/pom.xml +++ b/modules/repository/repository-search/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/modules/repository/repository-zip/pom.xml b/modules/repository/repository-zip/pom.xml index b02b886b01e..541909b3fb6 100644 --- a/modules/repository/repository-zip/pom.xml +++ b/modules/repository/repository-zip/pom.xml @@ -21,6 +21,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true diff --git a/pom.xml b/pom.xml index 1e0bced62cd..77362e5a0c5 100644 --- a/pom.xml +++ b/pom.xml @@ -127,6 +127,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true @@ -252,6 +253,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true @@ -275,6 +277,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true @@ -341,6 +344,7 @@ maven-compiler-plugin ${maven.compiler.plugin.version} + true ${maven.compiler.source} ${maven.compiler.target} true @@ -461,12 +465,6 @@ - - javax.servlet - javax.servlet-api - provided - - org.slf4j slf4j-api @@ -509,10 +507,6 @@ - - javax.xml.bind - jaxb-api - com.sun.xml.bind jaxb-core @@ -554,16 +548,18 @@ mockito-core test - - org.mockito - mockito-inline - test - + + org.springframework.boot + spring-boot-dependencies + ${spring.boot.version} + pom + import + org.eclipse.dirigible dirigible-application @@ -575,13 +571,7 @@ 5.10.1 test - - org.springframework.boot - spring-boot-dependencies - ${spring.boot.version} - pom - import - + org.seleniumhq.selenium selenium-java @@ -656,7 +646,7 @@ 2.2.3 2.11.0 - 2.7.18 + 3.1.6 23.0.3 0.9.5.5 From 888c2ded0ac682876da27388237c4931bb055903 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 11:46:22 +0200 Subject: [PATCH 02/64] add httpclient versions Signed-off-by: Iliyan Velichkov --- components/api/api-http/pom.xml | 6 +++--- components/engine/engine-openapi/pom.xml | 10 ---------- modules/database/database-persistence/pom.xml | 5 ----- 3 files changed, 3 insertions(+), 18 deletions(-) diff --git a/components/api/api-http/pom.xml b/components/api/api-http/pom.xml index b41be8b0e06..5005ca6eaf8 100644 --- a/components/api/api-http/pom.xml +++ b/components/api/api-http/pom.xml @@ -62,17 +62,17 @@ org.apache.httpcomponents httpasyncclient - ${httpasyncclient.version} + 4.1.5 org.apache.httpcomponents httpclient - ${httpcore.version} + 4.5.14 org.apache.httpcomponents httpmime - ${httpcore.version} + 4.5.14 commons-fileupload diff --git a/components/engine/engine-openapi/pom.xml b/components/engine/engine-openapi/pom.xml index 06d78cfbd4f..9a37a20c0b7 100644 --- a/components/engine/engine-openapi/pom.xml +++ b/components/engine/engine-openapi/pom.xml @@ -45,10 +45,6 @@ org.springframework.boot spring-boot-starter-validation - - jakarta.validation - jakarta.validation-api - org.apache.logging.log4j log4j-to-slf4j @@ -59,12 +55,6 @@ org.springdoc springdoc-openapi-ui ${org.springdoc.openapi.ui.version} - - - jakarta.validation - jakarta.validation-api - - diff --git a/modules/database/database-persistence/pom.xml b/modules/database/database-persistence/pom.xml index d115d9cec2e..4dc6e1f9e7a 100644 --- a/modules/database/database-persistence/pom.xml +++ b/modules/database/database-persistence/pom.xml @@ -29,11 +29,6 @@ org.eclipse.dirigible dirigible-database-sql - - org.eclipse.persistence - jakarta.persistence - ${persistence.api.version} - From 0067c4a634d386d077b83cb5e7e0e52b51c742be Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 12:18:17 +0200 Subject: [PATCH 03/64] use jakarta packages Signed-off-by: Iliyan Velichkov --- .../components/api/cms/CmisFacade.java | 2 +- .../api/core/DestinationsFacade.java | 4 +-- .../components/api/db/DatabaseFacade.java | 6 ++-- .../api/http/HttpRequestFacade.java | 4 +-- .../api/http/HttpResponseFacade.java | 4 +-- .../api/http/HttpSessionFacade.java | 4 +-- .../components/api/http/HttpUploadFacade.java | 2 +- .../api/http/client/HttpClientProxyUtils.java | 12 +++---- .../componenets/api/http/HttpSuiteTest.java | 6 ++-- components/api/api-mail/pom.xml | 15 ++++++--- .../components/api/mail/MailClient.java | 32 ++++++++----------- .../api/messaging/MessagingFacade.java | 2 +- .../api/messaging/MessagingFacadeTest.java | 2 +- .../api/websockets/WebsocketClient.java | 12 +++---- .../api/websockets/WebsocketsFacade.java | 2 +- .../components/api/security/UserFacade.java | 4 +-- .../components/base/artefact/Artefact.java | 12 +++---- .../components/base/artefact/Auditable.java | 10 +++--- .../ArrayOfStringsToCsvConverter.java | 2 +- .../ListOfStringsToCsvConverter.java | 2 +- .../SetOfStringsToCsvConverter.java | 2 +- .../EncryptionBeanPostProcessor.java | 7 ++-- .../base/endpoint/HttpContextFilter.java | 16 +++++----- .../base/home/HomeRedirectEndpoint.java | 8 ++--- .../base/http/access/UserAccessVerifier.java | 2 +- .../base/http/access/UserRequestVerifier.java | 2 +- .../http/access/UserResponseVerifier.java | 2 +- .../database/DataSourceSystemConfig.java | 2 +- .../extensions/domain/Extension.java | 12 +++---- .../extensions/domain/ExtensionPoint.java | 14 ++++---- .../endpoint/ExtensionPointEndpointTest.java | 2 +- .../ExtensionPointRepositoryTest.java | 2 +- .../repository/ExtensionRepositoryTest.java | 2 +- .../ExtensionPointsSynchronizerTest.java | 2 +- .../healthcheck/filter/HealthCheckFilter.java | 16 +++++----- .../initializers/definition/Definition.java | 18 +++++------ .../scheduler/SystemScheduler.java | 2 +- .../definition/DefinitionRepositoryTest.java | 2 +- .../endpoint/DataAnonymizeEndpoint.java | 2 +- .../components/data/csvim/domain/Csv.java | 12 +++---- .../components/data/csvim/domain/CsvFile.java | 18 +++++------ .../components/data/csvim/domain/Csvim.java | 2 +- .../format/ResultSetJsonWriter.java | 2 +- .../data/sources/domain/DataSource.java | 18 +++++------ .../sources/domain/DataSourceProperty.java | 18 +++++------ .../sources/endpoint/DataSourceEndpoint.java | 2 +- .../endpoint/DataSourceEndpointTest.java | 2 +- .../repository/DataSourceRepositoryTest.java | 2 +- .../DataSourcesSynchronizerTest.java | 2 +- .../components/data/store/domain/Entity.java | 12 +++---- .../data/structures/domain/Schema.java | 16 +++++----- .../data/structures/domain/Table.java | 22 ++++++------- .../data/structures/domain/TableColumn.java | 16 +++++----- .../structures/domain/TableConstraint.java | 16 +++++----- .../domain/TableConstraintCheck.java | 16 +++++----- .../domain/TableConstraintForeignKey.java | 16 +++++----- .../domain/TableConstraintPrimaryKey.java | 10 +++--- .../domain/TableConstraintUnique.java | 10 +++--- .../structures/domain/TableConstraints.java | 20 ++++++------ .../data/structures/domain/TableIndex.java | 22 ++++++------- .../data/structures/domain/View.java | 16 +++++----- .../repository/TableRepositoryTest.java | 2 +- .../repository/ViewRepositoryTest.java | 2 +- .../synchronizer/TablesSynchronizerTest.java | 2 +- .../engine/bpm/flowable/domain/Bpmn.java | 14 ++++---- .../components/engine/camel/domain/Camel.java | 2 +- .../components/engine/ftp/domain/FtpUser.java | 16 +++++----- .../ftp/repository/FtpRepositoryTest.java | 2 +- .../dirigible/components/jobs/domain/Job.java | 18 +++++------ .../components/jobs/domain/JobEmail.java | 12 +++---- .../components/jobs/domain/JobLog.java | 12 +++---- .../components/jobs/domain/JobParameter.java | 18 +++++------ .../jobs/email/JobEmailProcessor.java | 4 +-- .../components/jobs/endpoint/JobEndpoint.java | 2 +- .../jobs/endpoint/JobEndpointTest.java | 2 +- .../repository/JobEmailRepositoryTest.java | 2 +- .../jobs/repository/JobLogRepositoryTest.java | 2 +- .../jobs/repository/JobRepositoryTest.java | 2 +- .../synchronizer/JobSynchronizerTest.java | 2 +- .../ActiveMQConnectionArtifactsFactory.java | 8 ++--- ...eActiveMQResourcesApplicationListener.java | 6 ++-- .../config/LoggingExceptionListener.java | 4 +-- .../listeners/config/MessagingConfig.java | 6 ++-- .../components/listeners/domain/Listener.java | 2 +- .../domain/ListenerKindConverter.java | 2 +- .../service/AsynchronousMessageListener.java | 8 ++--- .../service/ConnectionArtifacts.java | 8 ++--- .../service/ListenerExceptionHandler.java | 4 +-- .../listeners/service/ListenerManager.java | 10 +++--- .../listeners/service/MessageConsumer.java | 10 +++--- .../listeners/service/MessageProducer.java | 10 +++--- ...ctiveMQConnectionArtifactsFactoryTest.java | 8 ++--- ...iveMQResourcesApplicationListenerTest.java | 6 ++-- .../config/LoggingExceptionListenerTest.java | 2 +- .../repository/ListenerRepositoryTest.java | 2 +- .../service/ConnectionArtifactsTest.java | 8 ++--- .../service/ListenerExceptionHandlerTest.java | 2 +- .../service/ListenerManagerTest.java | 14 ++++---- .../service/MessageConsumerTest.java | 12 +++---- .../service/MessageListenerTest.java | 6 ++-- .../service/MessageProducerTest.java | 10 +++--- .../components/odata/domain/OData.java | 16 +++++----- .../odata/domain/ODataContainer.java | 12 +++---- .../components/odata/domain/ODataHandler.java | 12 +++---- .../components/odata/domain/ODataMapping.java | 12 +++---- .../components/odata/domain/ODataSchema.java | 12 +++---- .../components/openapi/domain/OpenAPI.java | 2 +- .../repository/OpenAPIRepositoryTest.java | 2 +- .../synchronizer/OpenAPISynchronizerTest.java | 2 +- .../components/security/domain/Access.java | 12 +++---- .../components/security/domain/Role.java | 2 +- .../security/filter/SecurityFilter.java | 16 +++++----- .../repository/AccessRepositoryTest.java | 2 +- .../repository/RoleRepositoryTest.java | 2 +- .../synchronizer/AccessSynchronizerTest.java | 2 +- .../SecurityRoleSynchronizerTest.java | 2 +- .../components/engine/web/domain/Expose.java | 18 +++++------ .../engine/web/service/WebService.java | 2 +- .../web/repository/ExposeRepositoryTest.java | 2 +- .../synchronizer/ExposesSynchronizerTest.java | 2 +- .../websockets/domain/Websocket.java | 2 +- .../repository/WebsocketRepositoryTest.java | 2 +- .../engine/wiki/domain/Confluence.java | 14 ++++---- .../engine/wiki/domain/Markdown.java | 14 ++++---- .../ide/git/endpoint/GitEndpoint.java | 23 +++---------- .../ide/logs/endpoint/LoggersEndpoint.java | 2 +- .../ide/problems/domain/Problem.java | 14 ++++---- .../endpoint/ProblemsEndpointTest.java | 2 +- .../template/endpoint/GenerationEndpoint.java | 2 +- .../TerminalWebsocketClientEndpoint.java | 16 +++++----- .../org.apache.camel.AggregationStrategy | 4 +-- .../snippets/org.apache.camel.Processor | 4 +-- .../workspace/endpoint/WorkspaceEndpoint.java | 2 +- .../endpoint/WorkspaceFindEndpoint.java | 2 +- .../endpoint/WorkspaceSearchEndpoint.java | 2 +- .../endpoint/WorkspacesEndpoint.java | 2 +- .../commons/utils/xml2json/Xml2Json.java | 13 ++------ .../mongodb/jdbc/MongoDBDataSource.java | 2 -- .../persistence/PersistenceManager.java | 2 +- .../parser/PersistenceAnnotationsParser.java | 16 +++++----- .../AbstractPersistenceProcessor.java | 2 +- .../entity/PersistenceInsertProcessor.java | 2 +- .../processors/identity/Identity.java | 6 ++-- .../persistence/test/AllDataTypes.java | 6 ++-- .../database/persistence/test/Customer.java | 6 ++-- .../database/persistence/test/Inquiry.java | 10 +++--- .../database/persistence/test/MultiOrder.java | 2 +- .../database/persistence/test/Offer.java | 10 +++--- .../database/persistence/test/Order.java | 8 ++--- .../database/persistence/test/Process.java | 12 +++---- .../database/persistence/test/Task.java | 6 ++-- modules/database/pom.xml | 14 ++++++-- .../generic/RepositoryGenericBigTextTest.java | 2 +- .../RepositoryGenericFileRenameTest.java | 2 +- 154 files changed, 567 insertions(+), 581 deletions(-) diff --git a/components/api/api-cms/src/main/java/org/eclipse/dirigible/components/api/cms/CmisFacade.java b/components/api/api-cms/src/main/java/org/eclipse/dirigible/components/api/cms/CmisFacade.java index 5a6161b0a12..7e59228d994 100644 --- a/components/api/api-cms/src/main/java/org/eclipse/dirigible/components/api/cms/CmisFacade.java +++ b/components/api/api-cms/src/main/java/org/eclipse/dirigible/components/api/cms/CmisFacade.java @@ -13,7 +13,7 @@ import java.util.HashSet; import java.util.Set; -import javax.servlet.ServletException; +import jakarta.servlet.ServletException; import org.eclipse.dirigible.commons.config.Configuration; import org.eclipse.dirigible.components.api.http.HttpRequestFacade; diff --git a/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java b/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java index afd33ad765b..50211c034e9 100644 --- a/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java +++ b/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java @@ -20,8 +20,8 @@ import java.util.Map; import java.util.Properties; -import javax.naming.InitialContext; -import javax.naming.NamingException; +import jakarta.naming.InitialContext; +import jakarta.naming.NamingException; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.commons.config.Configuration; diff --git a/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java b/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java index a7fd5ae5673..0b28b30f63c 100644 --- a/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java +++ b/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java @@ -475,7 +475,7 @@ private static void setParameters(String parameters, PreparedStatement preparedS .getAsString())); } catch (NumberFormatException e) { // assume date string in ISO format e.g. 2018-05-22T21:00:00.000Z - value = new Date(javax.xml.bind.DatatypeConverter.parseDateTime(valueElement.getAsJsonPrimitive() + value = new Date(jakarta.xml.bind.DatatypeConverter.parseDateTime(valueElement.getAsJsonPrimitive() .getAsString()) .getTime() .getTime()); @@ -498,7 +498,7 @@ private static void setParameters(String parameters, PreparedStatement preparedS .getAsString())); } catch (NumberFormatException e) { // assume XSDTime - value = new Time(javax.xml.bind.DatatypeConverter.parseTime(valueElement.getAsJsonPrimitive() + value = new Time(jakarta.xml.bind.DatatypeConverter.parseTime(valueElement.getAsJsonPrimitive() .getAsString()) .getTime() .getTime()); @@ -521,7 +521,7 @@ private static void setParameters(String parameters, PreparedStatement preparedS .getAsString())); } catch (NumberFormatException e) { // assume date string in ISO format e.g. 2018-05-22T21:00:00.000Z - value = new Timestamp(javax.xml.bind.DatatypeConverter.parseDateTime(valueElement.getAsJsonPrimitive() + value = new Timestamp(jakarta.xml.bind.DatatypeConverter.parseDateTime(valueElement.getAsJsonPrimitive() .getAsString()) .getTime() .getTime()); diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpRequestFacade.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpRequestFacade.java index 527f190b6f0..48b27516bc4 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpRequestFacade.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpRequestFacade.java @@ -15,8 +15,8 @@ import java.util.Collections; import java.util.List; -import javax.servlet.ServletInputStream; -import javax.servlet.http.HttpServletRequest; +import jakarta.servlet.ServletInputStream; +import jakarta.servlet.http.HttpServletRequest; import org.apache.commons.io.IOUtils; import org.eclipse.dirigible.commons.api.context.InvalidStateException; diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpResponseFacade.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpResponseFacade.java index 8138d3415b3..692e309cea5 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpResponseFacade.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpResponseFacade.java @@ -14,8 +14,8 @@ import java.io.OutputStream; import java.util.Locale; -import javax.servlet.http.Cookie; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.http.Cookie; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.commons.api.context.ContextException; import org.eclipse.dirigible.commons.api.context.InvalidStateException; diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpSessionFacade.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpSessionFacade.java index 450c858b5fd..e585a245851 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpSessionFacade.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpSessionFacade.java @@ -12,8 +12,8 @@ import java.util.Collections; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpSession; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpSession; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.components.base.context.ThreadContextFacade; diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java index 57c353400af..93845af31a2 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java @@ -14,7 +14,7 @@ import java.util.Iterator; import java.util.List; -import javax.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletRequest; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileUploadException; diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java index 62d126afbaa..92d63797fcf 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java @@ -16,12 +16,12 @@ import java.security.SecureRandom; import java.security.cert.X509Certificate; -import javax.net.ssl.HostnameVerifier; -import javax.net.ssl.HttpsURLConnection; -import javax.net.ssl.SSLContext; -import javax.net.ssl.SSLSession; -import javax.net.ssl.TrustManager; -import javax.net.ssl.X509TrustManager; +import jakarta.net.ssl.HostnameVerifier; +import jakarta.net.ssl.HttpsURLConnection; +import jakarta.net.ssl.SSLContext; +import jakarta.net.ssl.SSLSession; +import jakarta.net.ssl.TrustManager; +import jakarta.net.ssl.X509TrustManager; import org.apache.commons.lang3.StringUtils; import org.apache.http.HttpException; diff --git a/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java b/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java index f3abe98fcda..9096003db25 100644 --- a/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java +++ b/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java @@ -14,9 +14,9 @@ import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; -import javax.servlet.Filter; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.Filter; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.components.engine.javascript.service.JavascriptService; import org.junit.jupiter.api.BeforeEach; diff --git a/components/api/api-mail/pom.xml b/components/api/api-mail/pom.xml index 518afc6b364..0401bf8f360 100644 --- a/components/api/api-mail/pom.xml +++ b/components/api/api-mail/pom.xml @@ -1,4 +1,6 @@ - + 4.0.0 @@ -13,6 +15,11 @@ jar + + org.springframework.boot + spring-boot-starter-mail + + org.eclipse.dirigible @@ -24,18 +31,18 @@ org.eclipse.dirigible dirigible-commons-helpers - + org.eclipse.dirigible dirigible-commons-config - + org.eclipse.dirigible dirigible-components-api-test - + diff --git a/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java b/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java index abcc401d21f..e57e28e5711 100644 --- a/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java +++ b/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java @@ -10,21 +10,22 @@ */ package org.eclipse.dirigible.components.api.mail; -import com.google.gson.Gson; -import com.sun.mail.smtp.SMTPSSLTransport; -import com.sun.mail.smtp.SMTPTransport; - -import javax.activation.DataHandler; -import javax.mail.*; -import javax.mail.internet.*; -import javax.mail.util.ByteArrayDataSource; import java.io.IOException; import java.net.InetSocketAddress; +import java.net.PasswordAuthentication; import java.net.Socket; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Properties; +import org.springframework.messaging.MessagingException; +import com.google.gson.Gson; +import com.sun.mail.smtp.SMTPSSLTransport; +import com.sun.mail.smtp.SMTPTransport; +import jakarta.activation.DataHandler; +import jakarta.mail.*; +import jakarta.mail.internet.*; +import jakarta.mail.util.ByteArrayDataSource; /** * The Class MailClient. @@ -76,16 +77,11 @@ public Map send(String from, String[] to, String[] cc, String[] bcc, String subj String transportProperty = properties.getProperty("mail.transport.protocol") .toLowerCase(); - switch (transportProperty) { - case SMTP_TRANSPORT: - transport = (SMTPTransport) session.getTransport(); - break; - case SMTPS_TRANSPORT: - transport = (SMTPSSLTransport) session.getTransport(); - break; - default: - throw new IllegalStateException("Unexpected transport property: " + transportProperty); - } + transport = switch (transportProperty) { + case SMTP_TRANSPORT -> (SMTPTransport) session.getTransport(); + case SMTPS_TRANSPORT -> (SMTPSSLTransport) session.getTransport(); + default -> throw new IllegalStateException("Unexpected transport property: " + transportProperty); + }; try { String proxyType = this.properties.getProperty("ProxyType"); diff --git a/components/api/api-messaging/src/main/java/org/eclipse/dirigible/components/api/messaging/MessagingFacade.java b/components/api/api-messaging/src/main/java/org/eclipse/dirigible/components/api/messaging/MessagingFacade.java index 8064c931de2..33f0ae8c5cd 100644 --- a/components/api/api-messaging/src/main/java/org/eclipse/dirigible/components/api/messaging/MessagingFacade.java +++ b/components/api/api-messaging/src/main/java/org/eclipse/dirigible/components/api/messaging/MessagingFacade.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.api.messaging; -import javax.jms.JMSException; +import jakarta.jms.JMSException; import org.eclipse.dirigible.components.listeners.service.MessageConsumer; import org.eclipse.dirigible.components.listeners.service.MessageProducer; import org.springframework.beans.factory.annotation.Autowired; diff --git a/components/api/api-messaging/src/test/java/org/eclipse/dirigible/components/api/messaging/MessagingFacadeTest.java b/components/api/api-messaging/src/test/java/org/eclipse/dirigible/components/api/messaging/MessagingFacadeTest.java index 8c43ff95a5a..fc7256feae8 100644 --- a/components/api/api-messaging/src/test/java/org/eclipse/dirigible/components/api/messaging/MessagingFacadeTest.java +++ b/components/api/api-messaging/src/test/java/org/eclipse/dirigible/components/api/messaging/MessagingFacadeTest.java @@ -15,7 +15,7 @@ import static org.mockito.Mockito.doThrow; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; -import javax.jms.JMSException; +import jakarta.jms.JMSException; import org.eclipse.dirigible.components.listeners.service.MessageConsumer; import org.eclipse.dirigible.components.listeners.service.MessageProducer; import org.eclipse.dirigible.components.listeners.service.TimeoutException; diff --git a/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketClient.java b/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketClient.java index 528042786fe..427bcea0c35 100644 --- a/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketClient.java +++ b/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketClient.java @@ -16,12 +16,12 @@ import java.util.Map; import java.util.concurrent.ExecutionException; -import javax.websocket.ClientEndpoint; -import javax.websocket.OnClose; -import javax.websocket.OnError; -import javax.websocket.OnMessage; -import javax.websocket.OnOpen; -import javax.websocket.Session; +import jakarta.websocket.ClientEndpoint; +import jakarta.websocket.OnClose; +import jakarta.websocket.OnError; +import jakarta.websocket.OnMessage; +import jakarta.websocket.OnOpen; +import jakarta.websocket.Session; import org.eclipse.dirigible.components.engine.javascript.service.JavascriptService; import org.eclipse.dirigible.repository.api.RepositoryPath; diff --git a/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketsFacade.java b/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketsFacade.java index a72d5d9a787..e96439c9204 100644 --- a/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketsFacade.java +++ b/components/api/api-net/src/main/java/org/eclipse/dirigible/components/api/websockets/WebsocketsFacade.java @@ -17,7 +17,7 @@ import java.util.Optional; import java.util.concurrent.ExecutionException; -import javax.websocket.DeploymentException; +import jakarta.websocket.DeploymentException; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.components.engine.javascript.service.JavascriptService; diff --git a/components/api/api-security/src/main/java/org/eclipse/dirigible/components/api/security/UserFacade.java b/components/api/api-security/src/main/java/org/eclipse/dirigible/components/api/security/UserFacade.java index 4fb70409a0c..240af99bf1d 100644 --- a/components/api/api-security/src/main/java/org/eclipse/dirigible/components/api/security/UserFacade.java +++ b/components/api/api-security/src/main/java/org/eclipse/dirigible/components/api/security/UserFacade.java @@ -15,8 +15,8 @@ import java.util.List; import java.util.Locale; -import javax.servlet.http.HttpServletRequest; -import javax.websocket.Session; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.websocket.Session; import org.eclipse.dirigible.commons.config.Configuration; import org.eclipse.dirigible.components.api.http.HttpRequestFacade; diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Artefact.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Artefact.java index a54e8bd4701..c17c5218199 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Artefact.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Artefact.java @@ -14,12 +14,12 @@ import java.util.HashSet; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.Lob; -import javax.persistence.MappedSuperclass; +import jakarta.persistence.Column; +import jakarta.persistence.Convert; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.Lob; +import jakarta.persistence.MappedSuperclass; import org.eclipse.dirigible.components.base.converters.SetOfStringsToCsvConverter; import org.springframework.lang.Nullable; diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Auditable.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Auditable.java index a797c47808c..b34428c14fb 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Auditable.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/artefact/Auditable.java @@ -18,13 +18,13 @@ import com.google.gson.annotations.Expose; -import javax.persistence.Column; -import javax.persistence.EntityListeners; -import javax.persistence.MappedSuperclass; -import javax.persistence.Temporal; +import jakarta.persistence.Column; +import jakarta.persistence.EntityListeners; +import jakarta.persistence.MappedSuperclass; +import jakarta.persistence.Temporal; import java.util.Date; -import static javax.persistence.TemporalType.TIMESTAMP; +import static jakarta.persistence.TemporalType.TIMESTAMP; /** * The Class Auditable. diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ArrayOfStringsToCsvConverter.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ArrayOfStringsToCsvConverter.java index d730456e9e3..4dcc5be0e0a 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ArrayOfStringsToCsvConverter.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ArrayOfStringsToCsvConverter.java @@ -13,7 +13,7 @@ import java.util.Arrays; import java.util.stream.Collectors; -import javax.persistence.AttributeConverter; +import jakarta.persistence.AttributeConverter; /** * The Class ArrayOfStringsToCsvConverter. diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ListOfStringsToCsvConverter.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ListOfStringsToCsvConverter.java index 0145aaba363..ed714e89aa5 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ListOfStringsToCsvConverter.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/ListOfStringsToCsvConverter.java @@ -14,7 +14,7 @@ import java.util.List; import java.util.stream.Collectors; -import javax.persistence.AttributeConverter; +import jakarta.persistence.AttributeConverter; /** * The Class ListOfStringsToCsvConverter. diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/SetOfStringsToCsvConverter.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/SetOfStringsToCsvConverter.java index 41fe3366f75..7c30c93b28f 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/SetOfStringsToCsvConverter.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/converters/SetOfStringsToCsvConverter.java @@ -14,7 +14,7 @@ import java.util.Set; import java.util.stream.Collectors; -import javax.persistence.AttributeConverter; +import jakarta.persistence.AttributeConverter; /** * The Class SetOfStringsToCsvConverter. diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java index 4bc4bbe27bc..42718448414 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java @@ -10,18 +10,17 @@ */ package org.eclipse.dirigible.components.base.encryption; -import javax.persistence.EntityManagerFactory; - +import org.hibernate.engine.spi.SessionFactoryImplementor; import org.hibernate.event.service.spi.EventListenerRegistry; import org.hibernate.event.spi.EventType; import org.hibernate.internal.SessionFactoryImpl; -import org.hibernate.jpa.HibernateEntityManagerFactory; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.BeansException; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.config.BeanPostProcessor; import org.springframework.stereotype.Component; +import jakarta.persistence.EntityManagerFactory; /** * https://github.com/galovics/hibernate-encryption-listener @@ -60,7 +59,7 @@ public Object postProcessBeforeInitialization(Object bean, String beanName) thro @Override public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException { if (bean instanceof EntityManagerFactory) { - HibernateEntityManagerFactory hibernateEntityManagerFactory = (HibernateEntityManagerFactory) bean; + SessionFactoryImplementor hibernateEntityManagerFactory = (SessionFactoryImplementor) bean; SessionFactoryImpl sessionFactoryImpl = (SessionFactoryImpl) hibernateEntityManagerFactory.getSessionFactory(); EventListenerRegistry registry = sessionFactoryImpl.getServiceRegistry() .getService(EventListenerRegistry.class); diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java index 29c5d1afa46..9c1b8935ea8 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java @@ -12,14 +12,14 @@ import java.io.IOException; -import javax.servlet.Filter; -import javax.servlet.FilterChain; -import javax.servlet.FilterConfig; -import javax.servlet.ServletException; -import javax.servlet.ServletRequest; -import javax.servlet.ServletResponse; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.Filter; +import jakarta.servlet.FilterChain; +import jakarta.servlet.FilterConfig; +import jakarta.servlet.ServletException; +import jakarta.servlet.ServletRequest; +import jakarta.servlet.ServletResponse; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.components.base.context.ContextException; import org.eclipse.dirigible.components.base.context.ThreadContextFacade; diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/home/HomeRedirectEndpoint.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/home/HomeRedirectEndpoint.java index 0dcc76dbd99..42398981f6c 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/home/HomeRedirectEndpoint.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/home/HomeRedirectEndpoint.java @@ -12,10 +12,10 @@ import java.io.IOException; -import javax.servlet.ServletException; -import javax.servlet.annotation.WebServlet; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.ServletException; +import jakarta.servlet.annotation.WebServlet; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.commons.config.Configuration; import org.springframework.web.bind.annotation.RequestMapping; diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserAccessVerifier.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserAccessVerifier.java index 6ce3193760c..ef6646c2079 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserAccessVerifier.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserAccessVerifier.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.base.http.access; -import javax.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletRequest; /** * The Interface UserAccessVerifier. diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserRequestVerifier.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserRequestVerifier.java index 5472cbaa9fd..a1f734fe768 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserRequestVerifier.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserRequestVerifier.java @@ -12,7 +12,7 @@ import java.util.ServiceLoader; -import javax.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletRequest; import org.eclipse.dirigible.commons.config.Configuration; import org.eclipse.dirigible.components.base.context.ContextException; diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserResponseVerifier.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserResponseVerifier.java index 317cea16c7d..99211129d25 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserResponseVerifier.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/UserResponseVerifier.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.base.http.access; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.components.base.context.ContextException; import org.eclipse.dirigible.components.base.context.ThreadContextFacade; diff --git a/components/core/core-database/src/main/java/org/eclipse/dirigible/components/database/DataSourceSystemConfig.java b/components/core/core-database/src/main/java/org/eclipse/dirigible/components/database/DataSourceSystemConfig.java index 4294185bd62..5487a7bc51c 100644 --- a/components/core/core-database/src/main/java/org/eclipse/dirigible/components/database/DataSourceSystemConfig.java +++ b/components/core/core-database/src/main/java/org/eclipse/dirigible/components/database/DataSourceSystemConfig.java @@ -12,7 +12,7 @@ import java.util.Properties; -import javax.persistence.EntityManagerFactory; +import jakarta.persistence.EntityManagerFactory; import javax.sql.DataSource; import org.hibernate.SessionFactory; diff --git a/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/Extension.java b/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/Extension.java index 675af9db0cb..a71f3303d27 100644 --- a/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/Extension.java +++ b/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/Extension.java @@ -10,12 +10,12 @@ */ package org.eclipse.dirigible.components.extensions.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/ExtensionPoint.java b/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/ExtensionPoint.java index cd117603239..82959bcc0f1 100644 --- a/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/ExtensionPoint.java +++ b/components/core/core-extensions/src/main/java/org/eclipse/dirigible/components/extensions/domain/ExtensionPoint.java @@ -13,13 +13,13 @@ import java.util.HashSet; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.Transient; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.Transient; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/endpoint/ExtensionPointEndpointTest.java b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/endpoint/ExtensionPointEndpointTest.java index 7dd79e7d934..c28b74f15a3 100644 --- a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/endpoint/ExtensionPointEndpointTest.java +++ b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/endpoint/ExtensionPointEndpointTest.java @@ -16,7 +16,7 @@ import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.extensions.domain.ExtensionPoint; diff --git a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionPointRepositoryTest.java b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionPointRepositoryTest.java index 5d4c2366e24..aa5e1865c33 100644 --- a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionPointRepositoryTest.java +++ b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionPointRepositoryTest.java @@ -15,7 +15,7 @@ import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.extensions.domain.ExtensionPoint; import org.junit.jupiter.api.AfterEach; diff --git a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionRepositoryTest.java b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionRepositoryTest.java index e39115ce4f7..97a7303baca 100644 --- a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionRepositoryTest.java +++ b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/repository/ExtensionRepositoryTest.java @@ -15,7 +15,7 @@ import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.extensions.domain.Extension; import org.junit.jupiter.api.AfterEach; diff --git a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/synchronizer/ExtensionPointsSynchronizerTest.java b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/synchronizer/ExtensionPointsSynchronizerTest.java index 71aaf51fabc..3dcee4c7c12 100644 --- a/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/synchronizer/ExtensionPointsSynchronizerTest.java +++ b/components/core/core-extensions/src/test/java/org/eclipse/dirigible/components/extensions/synchronizer/ExtensionPointsSynchronizerTest.java @@ -18,7 +18,7 @@ import java.text.ParseException; import java.util.List; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.extensions.domain.ExtensionPoint; import org.eclipse.dirigible.components.extensions.repository.ExtensionPointRepository; diff --git a/components/core/core-healthcheck/src/main/java/org/eclipse/dirigible/components/base/healthcheck/filter/HealthCheckFilter.java b/components/core/core-healthcheck/src/main/java/org/eclipse/dirigible/components/base/healthcheck/filter/HealthCheckFilter.java index c3ccdb1f971..57a40062396 100644 --- a/components/core/core-healthcheck/src/main/java/org/eclipse/dirigible/components/base/healthcheck/filter/HealthCheckFilter.java +++ b/components/core/core-healthcheck/src/main/java/org/eclipse/dirigible/components/base/healthcheck/filter/HealthCheckFilter.java @@ -12,14 +12,14 @@ import java.io.IOException; -import javax.servlet.Filter; -import javax.servlet.FilterChain; -import javax.servlet.FilterConfig; -import javax.servlet.ServletException; -import javax.servlet.ServletRequest; -import javax.servlet.ServletResponse; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.Filter; +import jakarta.servlet.FilterChain; +import jakarta.servlet.FilterConfig; +import jakarta.servlet.ServletException; +import jakarta.servlet.ServletRequest; +import jakarta.servlet.ServletResponse; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.components.base.healthcheck.status.HealthCheckStatus; import org.springframework.stereotype.Component; diff --git a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/definition/Definition.java b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/definition/Definition.java index 52f255fd9d7..25254d3e0c8 100644 --- a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/definition/Definition.java +++ b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/definition/Definition.java @@ -14,15 +14,15 @@ import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.xml.bind.DatatypeConverter; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.xml.bind.DatatypeConverter; import org.eclipse.dirigible.components.base.artefact.Auditable; import org.springframework.data.annotation.Transient; diff --git a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/scheduler/SystemScheduler.java b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/scheduler/SystemScheduler.java index 57194d3e2ce..e4e6a8693b9 100644 --- a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/scheduler/SystemScheduler.java +++ b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/scheduler/SystemScheduler.java @@ -17,7 +17,7 @@ import java.io.IOException; import java.util.Properties; -import javax.annotation.PostConstruct; +import jakarta.annotation.PostConstruct; import org.eclipse.dirigible.components.initializers.synchronizer.SynchronizationJob; import org.quartz.JobDetail; diff --git a/components/core/core-initializers/src/test/java/org/eclipse/dirigible/components/initializers/definition/DefinitionRepositoryTest.java b/components/core/core-initializers/src/test/java/org/eclipse/dirigible/components/initializers/definition/DefinitionRepositoryTest.java index 3f930ab658a..022fa11d367 100644 --- a/components/core/core-initializers/src/test/java/org/eclipse/dirigible/components/initializers/definition/DefinitionRepositoryTest.java +++ b/components/core/core-initializers/src/test/java/org/eclipse/dirigible/components/initializers/definition/DefinitionRepositoryTest.java @@ -15,7 +15,7 @@ import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; diff --git a/components/data/data-anonymize/src/main/java/org/eclipse/dirigible/components/data/anonymize/endpoint/DataAnonymizeEndpoint.java b/components/data/data-anonymize/src/main/java/org/eclipse/dirigible/components/data/anonymize/endpoint/DataAnonymizeEndpoint.java index 97332c56b3d..71bfc80167b 100644 --- a/components/data/data-anonymize/src/main/java/org/eclipse/dirigible/components/data/anonymize/endpoint/DataAnonymizeEndpoint.java +++ b/components/data/data-anonymize/src/main/java/org/eclipse/dirigible/components/data/anonymize/endpoint/DataAnonymizeEndpoint.java @@ -14,7 +14,7 @@ import java.sql.SQLException; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.data.anonymize.domain.DataAnonymizeParameters; diff --git a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csv.java b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csv.java index b514ed62bee..d2922ca0be4 100644 --- a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csv.java +++ b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csv.java @@ -14,12 +14,12 @@ import java.util.Objects; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/CsvFile.java b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/CsvFile.java index 78f3df14f9e..14e5ae36f18 100644 --- a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/CsvFile.java +++ b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/CsvFile.java @@ -12,15 +12,15 @@ import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.hibernate.annotations.OnDelete; diff --git a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java index 9dc9be0b0f6..e20596dc300 100644 --- a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java +++ b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java @@ -16,7 +16,7 @@ import org.hibernate.annotations.LazyCollectionOption; import javax.annotation.Nullable; -import javax.persistence.*; +import jakarta.persistence.*; import java.util.ArrayList; import java.util.List; diff --git a/components/data/data-management/src/main/java/org/eclipse/dirigible/components/data/management/format/ResultSetJsonWriter.java b/components/data/data-management/src/main/java/org/eclipse/dirigible/components/data/management/format/ResultSetJsonWriter.java index 58a012b8e52..09d87ca9c02 100644 --- a/components/data/data-management/src/main/java/org/eclipse/dirigible/components/data/management/format/ResultSetJsonWriter.java +++ b/components/data/data-management/src/main/java/org/eclipse/dirigible/components/data/management/format/ResultSetJsonWriter.java @@ -17,7 +17,7 @@ import java.sql.ResultSetMetaData; import java.sql.SQLException; -import javax.annotation.PostConstruct; +import jakarta.annotation.PostConstruct; import org.apache.commons.lang3.ClassUtils; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; diff --git a/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSource.java b/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSource.java index 23ca6c6fcbf..563e26938a5 100644 --- a/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSource.java +++ b/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSource.java @@ -16,15 +16,15 @@ import java.util.stream.Collector; import java.util.stream.Collectors; -import javax.persistence.CascadeType; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.OneToMany; -import javax.persistence.Table; +import jakarta.persistence.CascadeType; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.OneToMany; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.eclipse.dirigible.components.base.encryption.Encrypted; diff --git a/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSourceProperty.java b/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSourceProperty.java index 49c38fad5cd..3c509a7f660 100644 --- a/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSourceProperty.java +++ b/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/domain/DataSourceProperty.java @@ -10,15 +10,15 @@ */ package org.eclipse.dirigible.components.data.sources.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; +import jakarta.persistence.Table; import org.hibernate.annotations.OnDelete; import org.hibernate.annotations.OnDeleteAction; diff --git a/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpoint.java b/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpoint.java index aeafb2f524d..87895036653 100644 --- a/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpoint.java +++ b/components/data/data-sources/src/main/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpoint.java @@ -15,7 +15,7 @@ import java.util.List; import java.util.StringTokenizer; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.data.sources.domain.DataSource; diff --git a/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpointTest.java b/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpointTest.java index 33887e8e7f5..c0d8fde729f 100644 --- a/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpointTest.java +++ b/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/endpoint/DataSourceEndpointTest.java @@ -16,7 +16,7 @@ import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.data.sources.domain.DataSource; diff --git a/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/repository/DataSourceRepositoryTest.java b/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/repository/DataSourceRepositoryTest.java index 3d91c5d2a92..da21fb9e48e 100644 --- a/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/repository/DataSourceRepositoryTest.java +++ b/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/repository/DataSourceRepositoryTest.java @@ -15,7 +15,7 @@ import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.data.sources.domain.DataSource; import org.junit.jupiter.api.AfterEach; diff --git a/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/synchronizer/DataSourcesSynchronizerTest.java b/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/synchronizer/DataSourcesSynchronizerTest.java index 1c77635870b..cfb24e0d101 100644 --- a/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/synchronizer/DataSourcesSynchronizerTest.java +++ b/components/data/data-sources/src/test/java/org/eclipse/dirigible/components/data/sources/synchronizer/DataSourcesSynchronizerTest.java @@ -18,7 +18,7 @@ import java.text.ParseException; import java.util.List; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.data.sources.domain.DataSource; import org.eclipse.dirigible.components.data.sources.repository.DataSourceRepository; diff --git a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java index dffe5065c14..8158e7fab4b 100644 --- a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java +++ b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java @@ -10,12 +10,12 @@ */ package org.eclipse.dirigible.components.data.store.domain; -import javax.persistence.Column; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.Transient; +import jakarta.persistence.Column; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.Transient; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java index fad83f97d0f..f2ed1149cf1 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java @@ -14,14 +14,14 @@ import java.util.List; import java.util.Set; -import javax.persistence.CascadeType; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.OneToMany; +import jakarta.persistence.CascadeType; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.OneToMany; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.hibernate.annotations.LazyCollection; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java index 6cdd8c485b3..42883eb62cf 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java @@ -15,17 +15,17 @@ import java.util.Set; import javax.annotation.Nullable; -import javax.persistence.CascadeType; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; -import javax.persistence.OneToMany; -import javax.persistence.OneToOne; +import jakarta.persistence.CascadeType; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; +import jakarta.persistence.OneToMany; +import jakarta.persistence.OneToOne; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.hibernate.annotations.LazyCollection; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java index 5627b56a0e0..1d0b7d2d346 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java @@ -10,14 +10,14 @@ */ package org.eclipse.dirigible.components.data.structures.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; import org.hibernate.annotations.OnDelete; import org.hibernate.annotations.OnDeleteAction; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java index c64d10b0dc4..7870b36faa9 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java @@ -13,14 +13,14 @@ import java.util.Arrays; import javax.annotation.Nullable; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.ElementCollection; -import javax.persistence.FetchType; -import javax.persistence.JoinColumn; -import javax.persistence.MappedSuperclass; -import javax.persistence.OneToOne; -import javax.persistence.OrderColumn; +import jakarta.persistence.Column; +import jakarta.persistence.Convert; +import jakarta.persistence.ElementCollection; +import jakarta.persistence.FetchType; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.MappedSuperclass; +import jakarta.persistence.OneToOne; +import jakarta.persistence.OrderColumn; import org.eclipse.dirigible.components.base.converters.ArrayOfStringsToCsvConverter; import org.hibernate.annotations.OnDelete; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java index a9e637a285d..fa7538c2215 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java @@ -11,14 +11,14 @@ package org.eclipse.dirigible.components.data.structures.domain; import javax.annotation.Nullable; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; import org.hibernate.annotations.OnDelete; import org.hibernate.annotations.OnDeleteAction; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java index f185f3e7f60..2ef280c04dc 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java @@ -11,14 +11,14 @@ package org.eclipse.dirigible.components.data.structures.domain; import javax.annotation.Nullable; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.ElementCollection; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.OrderColumn; +import jakarta.persistence.Column; +import jakarta.persistence.Convert; +import jakarta.persistence.ElementCollection; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.OrderColumn; import org.eclipse.dirigible.components.base.converters.ArrayOfStringsToCsvConverter; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java index 3bbec9167c6..dfe262aee8a 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java @@ -10,11 +10,11 @@ */ package org.eclipse.dirigible.components.data.structures.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; /** * The Class TableConstraintPrimaryKey. diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java index f3a2668c46d..f55e1985711 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java @@ -11,11 +11,11 @@ package org.eclipse.dirigible.components.data.structures.domain; import javax.annotation.Nullable; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; import com.google.gson.annotations.Expose; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java index 50125a2930d..aa0ded28064 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java @@ -15,16 +15,16 @@ import java.util.Objects; import javax.annotation.Nullable; -import javax.persistence.CascadeType; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.OneToMany; -import javax.persistence.OneToOne; +import jakarta.persistence.CascadeType; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.OneToMany; +import jakarta.persistence.OneToOne; import org.hibernate.annotations.LazyCollection; import org.hibernate.annotations.LazyCollectionOption; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java index 29c33eb3acb..136545aa792 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java @@ -14,17 +14,17 @@ import java.util.HashSet; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.ElementCollection; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; -import javax.persistence.OrderColumn; +import jakarta.persistence.Column; +import jakarta.persistence.Convert; +import jakarta.persistence.ElementCollection; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; +import jakarta.persistence.OrderColumn; import org.eclipse.dirigible.components.base.converters.ArrayOfStringsToCsvConverter; import org.hibernate.annotations.OnDelete; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java index a036574083d..9bd775e6bf3 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java @@ -12,14 +12,14 @@ import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.hibernate.annotations.OnDelete; diff --git a/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/TableRepositoryTest.java b/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/TableRepositoryTest.java index 39de23f80d2..b495b126441 100644 --- a/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/TableRepositoryTest.java +++ b/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/TableRepositoryTest.java @@ -16,7 +16,7 @@ import java.util.Optional; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.data.structures.domain.Table; import org.junit.jupiter.api.AfterEach; diff --git a/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/ViewRepositoryTest.java b/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/ViewRepositoryTest.java index 33a4c3fbd90..c460307beba 100644 --- a/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/ViewRepositoryTest.java +++ b/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/repository/ViewRepositoryTest.java @@ -16,7 +16,7 @@ import java.util.Optional; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.data.structures.domain.View; import org.junit.jupiter.api.AfterEach; diff --git a/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/synchronizer/TablesSynchronizerTest.java b/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/synchronizer/TablesSynchronizerTest.java index 986babe6afc..362cf61f6ba 100644 --- a/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/synchronizer/TablesSynchronizerTest.java +++ b/components/data/data-structures/src/test/java/org/eclipse/dirigible/components/data/structures/synchronizer/TablesSynchronizerTest.java @@ -19,7 +19,7 @@ import java.util.List; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.data.structures.domain.Table; import org.eclipse.dirigible.components.data.structures.repository.TableColumnRepository; diff --git a/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/domain/Bpmn.java b/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/domain/Bpmn.java index 09546607279..49c41a8e38e 100644 --- a/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/domain/Bpmn.java +++ b/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/domain/Bpmn.java @@ -10,13 +10,13 @@ */ package org.eclipse.dirigible.components.engine.bpm.flowable.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.Transient; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.Transient; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/domain/Camel.java b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/domain/Camel.java index 78a10ba9dbc..2db8e3b3662 100644 --- a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/domain/Camel.java +++ b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/domain/Camel.java @@ -13,7 +13,7 @@ import com.google.gson.annotations.Expose; import org.eclipse.dirigible.components.base.artefact.Artefact; -import javax.persistence.*; +import jakarta.persistence.*; @Entity @Table(name = "DIRIGIBLE_CAMEL") diff --git a/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java b/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java index 48c14e4e6d5..cd29bf80b1d 100644 --- a/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java +++ b/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java @@ -17,14 +17,14 @@ import java.util.stream.Collectors; import javax.annotation.Nullable; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.Transient; +import jakarta.persistence.Column; +import jakarta.persistence.Convert; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.Transient; import org.apache.ftpserver.ftplet.Authority; import org.apache.ftpserver.ftplet.AuthorizationRequest; diff --git a/components/engine/engine-ftp/src/test/java/org/eclipse/dirigible/components/engine/ftp/repository/FtpRepositoryTest.java b/components/engine/engine-ftp/src/test/java/org/eclipse/dirigible/components/engine/ftp/repository/FtpRepositoryTest.java index 354ee12b45c..46dfd8ff69b 100644 --- a/components/engine/engine-ftp/src/test/java/org/eclipse/dirigible/components/engine/ftp/repository/FtpRepositoryTest.java +++ b/components/engine/engine-ftp/src/test/java/org/eclipse/dirigible/components/engine/ftp/repository/FtpRepositoryTest.java @@ -17,7 +17,7 @@ import java.util.Optional; import java.util.stream.Collectors; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.apache.ftpserver.ftplet.Authority; import org.eclipse.dirigible.components.engine.ftp.domain.FtpUser; diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/Job.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/Job.java index 1845055f4cd..a465918538b 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/Job.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/Job.java @@ -15,15 +15,15 @@ import java.util.List; import java.util.Set; -import javax.persistence.CascadeType; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.OneToMany; -import javax.persistence.Table; +import jakarta.persistence.CascadeType; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.OneToMany; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.hibernate.annotations.LazyCollection; diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobEmail.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobEmail.java index 6fefac479dd..2c774bb19df 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobEmail.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobEmail.java @@ -12,12 +12,12 @@ import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobLog.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobLog.java index b856d978e04..797577f86c0 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobLog.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobLog.java @@ -13,12 +13,12 @@ import java.sql.Timestamp; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobParameter.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobParameter.java index 7dd6ff47fe4..e8c58511228 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobParameter.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/domain/JobParameter.java @@ -10,15 +10,15 @@ */ package org.eclipse.dirigible.components.jobs.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.ManyToOne; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.FetchType; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.JoinColumn; +import jakarta.persistence.ManyToOne; +import jakarta.persistence.Table; import org.hibernate.annotations.OnDelete; import org.hibernate.annotations.OnDeleteAction; diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java index e055014cd97..7ec14c126df 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java @@ -16,9 +16,6 @@ import java.util.HashMap; import java.util.List; import java.util.Map; - -import javax.mail.MessagingException; - import org.apache.commons.validator.routines.EmailValidator; import org.eclipse.dirigible.commons.api.helpers.ContentTypeHelper; import org.eclipse.dirigible.commons.config.Configuration; @@ -32,6 +29,7 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.messaging.MessagingException; import org.springframework.stereotype.Component; /** diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpoint.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpoint.java index ecf1bcb9168..a8fc8ba5f33 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpoint.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpoint.java @@ -14,7 +14,7 @@ import java.util.List; import java.util.Map; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.eclipse.dirigible.commons.api.helpers.NameValuePair; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; diff --git a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpointTest.java b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpointTest.java index f8283f388f0..33a19c0356a 100644 --- a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpointTest.java +++ b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/endpoint/JobEndpointTest.java @@ -21,7 +21,7 @@ import java.util.List; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.jobs.domain.Job; diff --git a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobEmailRepositoryTest.java b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobEmailRepositoryTest.java index d59d477e245..6a0a6cafad2 100644 --- a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobEmailRepositoryTest.java +++ b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobEmailRepositoryTest.java @@ -16,7 +16,7 @@ import java.util.Optional; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.jobs.domain.JobEmail; import org.junit.jupiter.api.AfterEach; diff --git a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobLogRepositoryTest.java b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobLogRepositoryTest.java index bb758607e28..4fb9c478648 100644 --- a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobLogRepositoryTest.java +++ b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobLogRepositoryTest.java @@ -17,7 +17,7 @@ import java.util.Optional; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.jobs.domain.JobLog; import org.junit.jupiter.api.AfterEach; diff --git a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobRepositoryTest.java b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobRepositoryTest.java index ee38f275476..b4fe612f1bc 100644 --- a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobRepositoryTest.java +++ b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/repository/JobRepositoryTest.java @@ -18,7 +18,7 @@ import java.util.Optional; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.jobs.domain.Job; import org.eclipse.dirigible.components.jobs.domain.JobParameter; diff --git a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/synchronizer/JobSynchronizerTest.java b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/synchronizer/JobSynchronizerTest.java index c7503baddb8..445f24121dd 100644 --- a/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/synchronizer/JobSynchronizerTest.java +++ b/components/engine/engine-jobs/src/test/java/org/eclipse/dirigible/components/jobs/synchronizer/JobSynchronizerTest.java @@ -20,7 +20,7 @@ import java.util.List; import java.util.Set; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.jobs.domain.Job; import org.eclipse.dirigible.components.jobs.domain.JobParameter; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java index 9be707b3295..537520cf118 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java @@ -10,10 +10,10 @@ */ package org.eclipse.dirigible.components.listeners.config; -import javax.jms.Connection; -import javax.jms.ExceptionListener; -import javax.jms.JMSException; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.ExceptionListener; +import jakarta.jms.JMSException; +import jakarta.jms.Session; import org.apache.activemq.ActiveMQConnectionFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java index 54809d1efc6..4152c906165 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java @@ -10,9 +10,9 @@ */ package org.eclipse.dirigible.components.listeners.config; -import javax.jms.Connection; -import javax.jms.JMSException; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.Session; import org.apache.activemq.broker.BrokerService; import org.eclipse.dirigible.components.listeners.service.ListenersManager; import org.slf4j.Logger; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListener.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListener.java index 15c8a2aa1d1..ccf9c4a0caf 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListener.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListener.java @@ -10,8 +10,8 @@ */ package org.eclipse.dirigible.components.listeners.config; -import javax.jms.ExceptionListener; -import javax.jms.JMSException; +import jakarta.jms.ExceptionListener; +import jakarta.jms.JMSException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java index 6b57d0c276c..2338d7c9735 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java @@ -11,9 +11,9 @@ package org.eclipse.dirigible.components.listeners.config; import java.io.File; -import javax.jms.Connection; -import javax.jms.JMSException; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.Session; import javax.sql.DataSource; import org.apache.activemq.ActiveMQConnectionFactory; import org.apache.activemq.broker.BrokerService; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/Listener.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/Listener.java index 44fb2196b73..e0185870829 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/Listener.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/Listener.java @@ -14,7 +14,7 @@ import com.google.gson.annotations.Expose; -import javax.persistence.*; +import jakarta.persistence.*; /** * The Class Listener. diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/ListenerKindConverter.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/ListenerKindConverter.java index 7c93fbf431b..33e9c2e603c 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/ListenerKindConverter.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/domain/ListenerKindConverter.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.listeners.domain; -import javax.persistence.AttributeConverter; +import jakarta.persistence.AttributeConverter; /** * The Class ListenerKindConverter. diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/AsynchronousMessageListener.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/AsynchronousMessageListener.java index 11565ae1413..9d3f2ce931b 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/AsynchronousMessageListener.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/AsynchronousMessageListener.java @@ -10,10 +10,10 @@ */ package org.eclipse.dirigible.components.listeners.service; -import javax.jms.JMSException; -import javax.jms.Message; -import javax.jms.MessageListener; -import javax.jms.TextMessage; +import jakarta.jms.JMSException; +import jakarta.jms.Message; +import jakarta.jms.MessageListener; +import jakarta.jms.TextMessage; import org.eclipse.dirigible.components.listeners.domain.Listener; import org.eclipse.dirigible.graalium.core.DirigibleJavascriptCodeRunner; import org.eclipse.dirigible.graalium.core.javascript.modules.Module; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java index 5f4c42066be..4d261baadf1 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java @@ -10,10 +10,10 @@ */ package org.eclipse.dirigible.components.listeners.service; -import javax.jms.Connection; -import javax.jms.JMSException; -import javax.jms.MessageConsumer; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.MessageConsumer; +import jakarta.jms.Session; import org.slf4j.Logger; import org.slf4j.LoggerFactory; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandler.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandler.java index 264da6e7083..8aa53f772f6 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandler.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandler.java @@ -10,8 +10,8 @@ */ package org.eclipse.dirigible.components.listeners.service; -import javax.jms.ExceptionListener; -import javax.jms.JMSException; +import jakarta.jms.ExceptionListener; +import jakarta.jms.JMSException; import org.eclipse.dirigible.graalium.core.DirigibleJavascriptCodeRunner; import org.eclipse.dirigible.graalium.core.javascript.modules.Module; import org.slf4j.Logger; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerManager.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerManager.java index b2dd54607a0..76ddd75e0d5 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerManager.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ListenerManager.java @@ -10,11 +10,11 @@ */ package org.eclipse.dirigible.components.listeners.service; -import javax.jms.Connection; -import javax.jms.Destination; -import javax.jms.JMSException; -import javax.jms.MessageConsumer; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.Destination; +import jakarta.jms.JMSException; +import jakarta.jms.MessageConsumer; +import jakarta.jms.Session; import org.eclipse.dirigible.components.listeners.config.ActiveMQConnectionArtifactsFactory; import org.eclipse.dirigible.components.listeners.domain.Listener; import org.eclipse.dirigible.components.listeners.domain.ListenerKind; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java index 4716c15fdd7..6450400b9b8 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java @@ -10,11 +10,11 @@ */ package org.eclipse.dirigible.components.listeners.service; -import javax.jms.Destination; -import javax.jms.JMSException; -import javax.jms.Message; -import javax.jms.Session; -import javax.jms.TextMessage; +import jakarta.jms.Destination; +import jakarta.jms.JMSException; +import jakarta.jms.Message; +import jakarta.jms.Session; +import jakarta.jms.TextMessage; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java index a8a71f80902..92edda531e2 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java @@ -10,11 +10,11 @@ */ package org.eclipse.dirigible.components.listeners.service; -import javax.jms.DeliveryMode; -import javax.jms.Destination; -import javax.jms.JMSException; -import javax.jms.Session; -import javax.jms.TextMessage; +import jakarta.jms.DeliveryMode; +import jakarta.jms.Destination; +import jakarta.jms.JMSException; +import jakarta.jms.Session; +import jakarta.jms.TextMessage; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactoryTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactoryTest.java index 5a361863eea..80f7121af89 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactoryTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactoryTest.java @@ -14,10 +14,10 @@ import static org.junit.Assert.assertThrows; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; -import javax.jms.Connection; -import javax.jms.ExceptionListener; -import javax.jms.JMSException; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.ExceptionListener; +import jakarta.jms.JMSException; +import jakarta.jms.Session; import org.apache.activemq.ActiveMQConnectionFactory; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListenerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListenerTest.java index adf181568e3..015de312b84 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListenerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListenerTest.java @@ -12,9 +12,9 @@ import static org.mockito.Mockito.doThrow; import static org.mockito.Mockito.verifyNoInteractions; -import javax.jms.Connection; -import javax.jms.JMSException; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.Session; import org.apache.activemq.broker.BrokerService; import org.eclipse.dirigible.components.listeners.service.ListenersManager; import org.junit.jupiter.api.Test; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListenerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListenerTest.java index 6f6cc71930b..229a0d683a7 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListenerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/config/LoggingExceptionListenerTest.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.listeners.config; -import javax.jms.JMSException; +import jakarta.jms.JMSException; import org.eclipse.dirigible.components.listeners.util.LogsAsserter; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/repository/ListenerRepositoryTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/repository/ListenerRepositoryTest.java index c826724b8cf..4405aaf39be 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/repository/ListenerRepositoryTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/repository/ListenerRepositoryTest.java @@ -14,7 +14,7 @@ import static org.junit.jupiter.api.Assertions.assertNotNull; import java.util.List; import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.listeners.domain.Listener; import org.eclipse.dirigible.components.listeners.domain.ListenerKind; import org.junit.jupiter.api.AfterEach; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifactsTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifactsTest.java index ff2c0cd935e..035e7b2e00b 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifactsTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifactsTest.java @@ -11,10 +11,10 @@ package org.eclipse.dirigible.components.listeners.service; import static org.mockito.Mockito.doThrow; -import javax.jms.Connection; -import javax.jms.JMSException; -import javax.jms.MessageConsumer; -import javax.jms.Session; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.MessageConsumer; +import jakarta.jms.Session; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.mockito.InOrder; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandlerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandlerTest.java index 8c3e9803862..b7af74adadb 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandlerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerExceptionHandlerTest.java @@ -13,7 +13,7 @@ import static org.mockito.Mockito.doReturn; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; -import javax.jms.JMSException; +import jakarta.jms.JMSException; import org.eclipse.dirigible.components.listeners.util.LogsAsserter; import org.eclipse.dirigible.graalium.core.DirigibleJavascriptCodeRunner; import org.eclipse.dirigible.graalium.core.javascript.modules.Module; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerManagerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerManagerTest.java index 395262effaf..baa77601279 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerManagerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/ListenerManagerTest.java @@ -15,13 +15,13 @@ import static org.mockito.ArgumentMatchers.any; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; -import javax.jms.Connection; -import javax.jms.ExceptionListener; -import javax.jms.JMSException; -import javax.jms.MessageConsumer; -import javax.jms.Queue; -import javax.jms.Session; -import javax.jms.Topic; +import jakarta.jms.Connection; +import jakarta.jms.ExceptionListener; +import jakarta.jms.JMSException; +import jakarta.jms.MessageConsumer; +import jakarta.jms.Queue; +import jakarta.jms.Session; +import jakarta.jms.Topic; import org.eclipse.dirigible.components.listeners.config.ActiveMQConnectionArtifactsFactory; import org.eclipse.dirigible.components.listeners.domain.Listener; import org.eclipse.dirigible.components.listeners.domain.ListenerKind; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java index ff50f32977e..ac609ef60e8 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java @@ -13,12 +13,12 @@ import static org.assertj.core.api.Assertions.assertThat; import static org.junit.Assert.assertThrows; import static org.mockito.Mockito.when; -import javax.jms.BytesMessage; -import javax.jms.JMSException; -import javax.jms.Queue; -import javax.jms.Session; -import javax.jms.TextMessage; -import javax.jms.Topic; +import jakarta.jms.BytesMessage; +import jakarta.jms.JMSException; +import jakarta.jms.Queue; +import jakarta.jms.Session; +import jakarta.jms.TextMessage; +import jakarta.jms.Topic; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.mockito.InjectMocks; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageListenerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageListenerTest.java index a60a7502e37..37cb3eda552 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageListenerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageListenerTest.java @@ -15,9 +15,9 @@ import static org.mockito.Mockito.spy; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; -import javax.jms.BytesMessage; -import javax.jms.JMSException; -import javax.jms.TextMessage; +import jakarta.jms.BytesMessage; +import jakarta.jms.JMSException; +import jakarta.jms.TextMessage; import org.eclipse.dirigible.components.listeners.domain.Listener; import org.eclipse.dirigible.graalium.core.DirigibleJavascriptCodeRunner; import org.eclipse.dirigible.graalium.core.javascript.modules.Module; diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java index 6d3ac64ed56..dafc349e139 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java @@ -12,11 +12,11 @@ import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; -import javax.jms.JMSException; -import javax.jms.Queue; -import javax.jms.Session; -import javax.jms.TextMessage; -import javax.jms.Topic; +import jakarta.jms.JMSException; +import jakarta.jms.Queue; +import jakarta.jms.Session; +import jakarta.jms.TextMessage; +import jakarta.jms.Topic; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.mockito.InjectMocks; diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/OData.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/OData.java index 9ad3cdd046a..5ab510609cd 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/OData.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/OData.java @@ -14,14 +14,14 @@ import java.util.List; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Lob; -import javax.persistence.Table; -import javax.persistence.Transient; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Lob; +import jakarta.persistence.Table; +import jakarta.persistence.Transient; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataContainer.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataContainer.java index 1fe00691d5f..7067565ae9e 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataContainer.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataContainer.java @@ -13,12 +13,12 @@ import java.util.Arrays; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataHandler.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataHandler.java index 622a30a8104..befd3840fa1 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataHandler.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataHandler.java @@ -12,12 +12,12 @@ import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataMapping.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataMapping.java index 532672103bb..aff0a6e0ebd 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataMapping.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataMapping.java @@ -13,12 +13,12 @@ import java.util.Arrays; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataSchema.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataSchema.java index f00e1362c31..d81a5c95701 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataSchema.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/domain/ODataSchema.java @@ -13,12 +13,12 @@ import java.util.Arrays; import java.util.Set; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-openapi/src/main/java/org/eclipse/dirigible/components/openapi/domain/OpenAPI.java b/components/engine/engine-openapi/src/main/java/org/eclipse/dirigible/components/openapi/domain/OpenAPI.java index 637c5e41f45..bb7da323674 100644 --- a/components/engine/engine-openapi/src/main/java/org/eclipse/dirigible/components/openapi/domain/OpenAPI.java +++ b/components/engine/engine-openapi/src/main/java/org/eclipse/dirigible/components/openapi/domain/OpenAPI.java @@ -12,7 +12,7 @@ import org.eclipse.dirigible.components.base.artefact.Artefact; -import javax.persistence.*; +import jakarta.persistence.*; /** * The Class OpenAPI. diff --git a/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/repository/OpenAPIRepositoryTest.java b/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/repository/OpenAPIRepositoryTest.java index 50434bbffab..dbaa17f5ba5 100644 --- a/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/repository/OpenAPIRepositoryTest.java +++ b/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/repository/OpenAPIRepositoryTest.java @@ -22,7 +22,7 @@ import org.springframework.context.annotation.ComponentScan; import org.springframework.transaction.annotation.Transactional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import java.util.Optional; import static org.junit.jupiter.api.Assertions.*; diff --git a/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/synchronizer/OpenAPISynchronizerTest.java b/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/synchronizer/OpenAPISynchronizerTest.java index f0658503d14..eefe8034dbb 100644 --- a/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/synchronizer/OpenAPISynchronizerTest.java +++ b/components/engine/engine-openapi/src/test/java/org/eclipse/dirigible/components/openapi/synchronizer/OpenAPISynchronizerTest.java @@ -19,7 +19,7 @@ import java.text.ParseException; import java.util.List; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.openapi.domain.OpenAPI; import org.eclipse.dirigible.components.openapi.repository.OpenAPIRepository; diff --git a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Access.java b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Access.java index 1fdacf276c0..4e0223b7e70 100644 --- a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Access.java +++ b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Access.java @@ -10,12 +10,12 @@ */ package org.eclipse.dirigible.components.security.domain; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Role.java b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Role.java index 17293a40695..84401c92f03 100644 --- a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Role.java +++ b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/domain/Role.java @@ -12,7 +12,7 @@ import org.eclipse.dirigible.components.base.artefact.Artefact; -import javax.persistence.*; +import jakarta.persistence.*; /** * The Class SecurityRole. diff --git a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java index 3f74ef56af3..cf241445e5f 100644 --- a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java +++ b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java @@ -16,14 +16,14 @@ import java.util.List; import java.util.Set; -import javax.servlet.Filter; -import javax.servlet.FilterChain; -import javax.servlet.FilterConfig; -import javax.servlet.ServletException; -import javax.servlet.ServletRequest; -import javax.servlet.ServletResponse; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; +import jakarta.servlet.Filter; +import jakarta.servlet.FilterChain; +import jakarta.servlet.FilterConfig; +import jakarta.servlet.ServletException; +import jakarta.servlet.ServletRequest; +import jakarta.servlet.ServletResponse; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; import org.eclipse.dirigible.commons.config.Configuration; import org.eclipse.dirigible.components.base.http.access.UserRequestVerifier; diff --git a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/AccessRepositoryTest.java b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/AccessRepositoryTest.java index 15415517cf7..0bf82d3e76c 100644 --- a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/AccessRepositoryTest.java +++ b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/AccessRepositoryTest.java @@ -24,7 +24,7 @@ import org.springframework.context.annotation.ComponentScan; import org.springframework.transaction.annotation.Transactional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import java.util.Optional; import static org.junit.jupiter.api.Assertions.*; diff --git a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/RoleRepositoryTest.java b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/RoleRepositoryTest.java index 11a2aa8b504..e4c026112ba 100644 --- a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/RoleRepositoryTest.java +++ b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/repository/RoleRepositoryTest.java @@ -24,7 +24,7 @@ import org.springframework.context.annotation.ComponentScan; import org.springframework.transaction.annotation.Transactional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import java.util.Optional; import static org.junit.jupiter.api.Assertions.*; diff --git a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/AccessSynchronizerTest.java b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/AccessSynchronizerTest.java index 4ac05395fe5..5d04a9d51ab 100644 --- a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/AccessSynchronizerTest.java +++ b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/AccessSynchronizerTest.java @@ -24,7 +24,7 @@ import org.springframework.context.annotation.ComponentScan; import org.springframework.transaction.annotation.Transactional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import java.io.IOException; import java.nio.file.Path; import java.text.ParseException; diff --git a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/SecurityRoleSynchronizerTest.java b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/SecurityRoleSynchronizerTest.java index 7647a83a9a2..7bf67864dab 100644 --- a/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/SecurityRoleSynchronizerTest.java +++ b/components/engine/engine-security/src/test/java/org/eclipse/dirigible/components/security/synchronizer/SecurityRoleSynchronizerTest.java @@ -25,7 +25,7 @@ import org.springframework.context.annotation.ComponentScan; import org.springframework.transaction.annotation.Transactional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import java.io.IOException; import java.nio.file.Path; import java.text.ParseException; diff --git a/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java b/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java index 5b71de8c9b8..2da3e25b461 100644 --- a/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java +++ b/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java @@ -13,15 +13,15 @@ import java.util.Arrays; import javax.annotation.Nullable; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.ElementCollection; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.OrderColumn; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Convert; +import jakarta.persistence.ElementCollection; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.OrderColumn; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; import org.eclipse.dirigible.components.base.converters.ArrayOfStringsToCsvConverter; diff --git a/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/service/WebService.java b/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/service/WebService.java index 02ae0744aa8..77c1b14b1b5 100644 --- a/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/service/WebService.java +++ b/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/service/WebService.java @@ -12,7 +12,7 @@ import java.nio.charset.StandardCharsets; -import javax.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletRequest; import org.eclipse.dirigible.commons.api.helpers.ContentTypeHelper; import org.eclipse.dirigible.commons.config.Configuration; diff --git a/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/repository/ExposeRepositoryTest.java b/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/repository/ExposeRepositoryTest.java index 89d1a771036..6d189a883ea 100644 --- a/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/repository/ExposeRepositoryTest.java +++ b/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/repository/ExposeRepositoryTest.java @@ -15,7 +15,7 @@ import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.engine.web.domain.Expose; import org.eclipse.dirigible.components.initializers.definition.DefinitionRepository; diff --git a/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/synchronizer/ExposesSynchronizerTest.java b/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/synchronizer/ExposesSynchronizerTest.java index 63bc912bba7..996e66b74fa 100644 --- a/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/synchronizer/ExposesSynchronizerTest.java +++ b/components/engine/engine-web/src/test/java/org/eclipse/dirigible/components/engine/web/synchronizer/ExposesSynchronizerTest.java @@ -22,7 +22,7 @@ import java.text.ParseException; import java.util.List; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.engine.web.domain.Expose; import org.eclipse.dirigible.components.engine.web.exposure.ExposeManager; diff --git a/components/engine/engine-websockets/src/main/java/org/eclipse/dirigible/components/websockets/domain/Websocket.java b/components/engine/engine-websockets/src/main/java/org/eclipse/dirigible/components/websockets/domain/Websocket.java index 2307f10452c..732d28f0e34 100644 --- a/components/engine/engine-websockets/src/main/java/org/eclipse/dirigible/components/websockets/domain/Websocket.java +++ b/components/engine/engine-websockets/src/main/java/org/eclipse/dirigible/components/websockets/domain/Websocket.java @@ -14,7 +14,7 @@ import com.google.gson.annotations.Expose; -import javax.persistence.*; +import jakarta.persistence.*; /** * The Class Websocket. diff --git a/components/engine/engine-websockets/src/test/java/org/eclipse/dirigible/components/websockets/repository/WebsocketRepositoryTest.java b/components/engine/engine-websockets/src/test/java/org/eclipse/dirigible/components/websockets/repository/WebsocketRepositoryTest.java index 52c5f4e354f..f907fa5ce5f 100644 --- a/components/engine/engine-websockets/src/test/java/org/eclipse/dirigible/components/websockets/repository/WebsocketRepositoryTest.java +++ b/components/engine/engine-websockets/src/test/java/org/eclipse/dirigible/components/websockets/repository/WebsocketRepositoryTest.java @@ -16,7 +16,7 @@ import java.util.List; import java.util.Optional; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.websockets.domain.Websocket; import org.eclipse.dirigible.components.websockets.repository.WebsocketRepository; diff --git a/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Confluence.java b/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Confluence.java index 7be38cba652..c63bb7ded1f 100644 --- a/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Confluence.java +++ b/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Confluence.java @@ -12,13 +12,13 @@ import java.util.Arrays; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Lob; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Lob; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Markdown.java b/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Markdown.java index c192f1fcd16..08b515e41e7 100644 --- a/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Markdown.java +++ b/components/engine/engine-wiki/src/main/java/org/eclipse/dirigible/components/engine/wiki/domain/Markdown.java @@ -12,13 +12,13 @@ import java.util.Arrays; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Lob; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Lob; +import jakarta.persistence.Table; import org.eclipse.dirigible.components.base.artefact.Artefact; diff --git a/components/ide/ide-git/src/main/java/org/eclipse/dirigible/components/ide/git/endpoint/GitEndpoint.java b/components/ide/ide-git/src/main/java/org/eclipse/dirigible/components/ide/git/endpoint/GitEndpoint.java index fbb141a476d..296365a078c 100644 --- a/components/ide/ide-git/src/main/java/org/eclipse/dirigible/components/ide/git/endpoint/GitEndpoint.java +++ b/components/ide/ide-git/src/main/java/org/eclipse/dirigible/components/ide/git/endpoint/GitEndpoint.java @@ -11,13 +11,9 @@ package org.eclipse.dirigible.components.ide.git.endpoint; import static java.text.MessageFormat.format; - import java.net.URISyntaxException; import java.util.Arrays; import java.util.List; - -import javax.validation.Valid; - import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.components.api.security.UserFacade; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; @@ -42,8 +38,6 @@ import org.eclipse.jgit.api.errors.InvalidRefNameException; import org.eclipse.jgit.api.errors.RefAlreadyExistsException; import org.eclipse.jgit.api.errors.RefNotFoundException; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; @@ -57,8 +51,8 @@ import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.server.ResponseStatusException; - import com.google.gson.JsonObject; +import jakarta.validation.Valid; /** * Front facing REST service serving the Git commands. @@ -67,12 +61,8 @@ @RequestMapping(BaseEndpoint.PREFIX_ENDPOINT_IDE + "git/{workspace}") public class GitEndpoint { - - /** The Constant logger. */ - private static final Logger logger = LoggerFactory.getLogger(GitEndpoint.class); - /** The git service. */ - private GitService gitService; + private final GitService gitService; /** * Instantiates a new git endpoint. @@ -581,9 +571,8 @@ public ResponseEntity getOriginUrl(@PathVariable("workspace") String workspac ProjectOriginUrls originUrls = gitService.getOriginUrls(workspace, project); if (originUrls != null) { return ResponseEntity.ok(originUrls); - } else { - throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Not a git project"); } + throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Not a git project"); } /** @@ -651,9 +640,8 @@ public ResponseEntity getFileDiff(@PathVariable("workspace") String workspace GitDiffModel diff = gitService.getFileDiff(workspace, repositoryName, path); if (diff != null) { return ResponseEntity.ok(GsonHelper.toJson(diff)); - } else { - throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Not a git project"); } + throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Not a git project"); } /** @@ -671,9 +659,8 @@ public ResponseEntity getHistory(@PathVariable("workspace") String workspace, List history = gitService.getHistory(workspace, project, path); if (history != null) { return ResponseEntity.ok(GsonHelper.toJson(history)); - } else { - throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Not a git project"); } + throw new ResponseStatusException(HttpStatus.BAD_REQUEST, "Not a git project"); } /** diff --git a/components/ide/ide-logs/src/main/java/org/eclipse/dirigible/components/ide/logs/endpoint/LoggersEndpoint.java b/components/ide/ide-logs/src/main/java/org/eclipse/dirigible/components/ide/logs/endpoint/LoggersEndpoint.java index b4e5edfb296..aafdb26abd3 100644 --- a/components/ide/ide-logs/src/main/java/org/eclipse/dirigible/components/ide/logs/endpoint/LoggersEndpoint.java +++ b/components/ide/ide-logs/src/main/java/org/eclipse/dirigible/components/ide/logs/endpoint/LoggersEndpoint.java @@ -13,7 +13,7 @@ import java.io.IOException; import java.net.URISyntaxException; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.ide.logs.service.LogsService; diff --git a/components/ide/ide-problems/src/main/java/org/eclipse/dirigible/components/ide/problems/domain/Problem.java b/components/ide/ide-problems/src/main/java/org/eclipse/dirigible/components/ide/problems/domain/Problem.java index 85dc7279714..58c6ccb791c 100644 --- a/components/ide/ide-problems/src/main/java/org/eclipse/dirigible/components/ide/problems/domain/Problem.java +++ b/components/ide/ide-problems/src/main/java/org/eclipse/dirigible/components/ide/problems/domain/Problem.java @@ -12,13 +12,13 @@ import java.sql.Timestamp; -import javax.persistence.Column; -import javax.persistence.Entity; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.UniqueConstraint; +import jakarta.persistence.Column; +import jakarta.persistence.Entity; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.UniqueConstraint; import org.eclipse.dirigible.components.api.security.UserFacade; diff --git a/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java b/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java index 0a5495035b0..b315f349719 100644 --- a/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java +++ b/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java @@ -15,7 +15,7 @@ import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; -import javax.persistence.EntityManager; +import jakarta.persistence.EntityManager; import org.eclipse.dirigible.components.ide.problems.domain.Problem; import org.eclipse.dirigible.components.ide.problems.repository.ProblemRepository; diff --git a/components/ide/ide-template/src/main/java/org/eclipse/dirigible/components/ide/template/endpoint/GenerationEndpoint.java b/components/ide/ide-template/src/main/java/org/eclipse/dirigible/components/ide/template/endpoint/GenerationEndpoint.java index 42ceab9ce58..0eca16e1bbe 100644 --- a/components/ide/ide-template/src/main/java/org/eclipse/dirigible/components/ide/template/endpoint/GenerationEndpoint.java +++ b/components/ide/ide-template/src/main/java/org/eclipse/dirigible/components/ide/template/endpoint/GenerationEndpoint.java @@ -17,7 +17,7 @@ import java.net.URISyntaxException; import java.util.List; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.ide.template.domain.GenerationTemplateParameters; diff --git a/components/ide/ide-terminal/src/main/java/org/eclipse/dirigible/components/terminal/client/TerminalWebsocketClientEndpoint.java b/components/ide/ide-terminal/src/main/java/org/eclipse/dirigible/components/terminal/client/TerminalWebsocketClientEndpoint.java index 3df4207e18d..dbd3ac6be2b 100644 --- a/components/ide/ide-terminal/src/main/java/org/eclipse/dirigible/components/terminal/client/TerminalWebsocketClientEndpoint.java +++ b/components/ide/ide-terminal/src/main/java/org/eclipse/dirigible/components/terminal/client/TerminalWebsocketClientEndpoint.java @@ -14,14 +14,14 @@ import java.net.URI; import java.nio.ByteBuffer; -import javax.websocket.ClientEndpoint; -import javax.websocket.CloseReason; -import javax.websocket.ContainerProvider; -import javax.websocket.OnClose; -import javax.websocket.OnMessage; -import javax.websocket.OnOpen; -import javax.websocket.Session; -import javax.websocket.WebSocketContainer; +import jakarta.websocket.ClientEndpoint; +import jakarta.websocket.CloseReason; +import jakarta.websocket.ContainerProvider; +import jakarta.websocket.OnClose; +import jakarta.websocket.OnMessage; +import jakarta.websocket.OnOpen; +import jakarta.websocket.Session; +import jakarta.websocket.WebSocketContainer; import org.slf4j.Logger; import org.slf4j.LoggerFactory; diff --git a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.AggregationStrategy b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.AggregationStrategy index 4dcc88293c4..2c9df26ccc7 100644 --- a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.AggregationStrategy +++ b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.AggregationStrategy @@ -1,8 +1,8 @@ import org.apache.camel.AggregationStrategy; import org.apache.camel.Exchange; -import javax.inject.Named; -import javax.inject.Singleton; +import jakarta.inject.Named; +import jakarta.inject.Singleton; @Singleton @Named("NAME") diff --git a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.Processor b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.Processor index 6b813234e1f..3efb7c4f391 100644 --- a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.Processor +++ b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/snippets/org.apache.camel.Processor @@ -1,8 +1,8 @@ import org.apache.camel.Exchange; import org.apache.camel.Processor; -import javax.inject.Named; -import javax.inject.Singleton; +import jakarta.inject.Named; +import jakarta.inject.Singleton; @Singleton @Named("NAME") diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java index 27730be374c..8854586b9a1 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java @@ -18,7 +18,7 @@ import java.util.ArrayList; import java.util.InputMismatchException; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.apache.commons.codec.DecoderException; import org.eclipse.dirigible.components.api.utils.UrlFacade; diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceFindEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceFindEndpoint.java index c05b112d899..987c0efc602 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceFindEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceFindEndpoint.java @@ -14,7 +14,7 @@ import java.net.URISyntaxException; import java.util.List; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.apache.commons.codec.DecoderException; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceSearchEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceSearchEndpoint.java index 945a2818830..317207ca3dc 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceSearchEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceSearchEndpoint.java @@ -14,7 +14,7 @@ import java.net.URISyntaxException; import java.util.List; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.apache.commons.codec.DecoderException; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java index 2da63bb9ec2..c87743d7d76 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java @@ -20,7 +20,7 @@ import java.util.List; import javax.annotation.Nullable; -import javax.validation.Valid; +import jakarta.validation.Valid; import org.apache.commons.codec.binary.Base64; import org.eclipse.dirigible.components.engine.typescript.TypeScriptService; diff --git a/modules/commons/commons-xml2json/src/main/java/org/eclipse/dirigible/commons/utils/xml2json/Xml2Json.java b/modules/commons/commons-xml2json/src/main/java/org/eclipse/dirigible/commons/utils/xml2json/Xml2Json.java index 64b93fafa76..58a21d7e3e7 100644 --- a/modules/commons/commons-xml2json/src/main/java/org/eclipse/dirigible/commons/utils/xml2json/Xml2Json.java +++ b/modules/commons/commons-xml2json/src/main/java/org/eclipse/dirigible/commons/utils/xml2json/Xml2Json.java @@ -21,7 +21,6 @@ import java.util.List; import java.util.Map; import java.util.Map.Entry; - import javax.xml.XMLConstants; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; @@ -33,7 +32,6 @@ import javax.xml.transform.TransformerFactoryConfigurationError; import javax.xml.transform.dom.DOMSource; import javax.xml.transform.stream.StreamResult; - import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.w3c.dom.Document; @@ -42,7 +40,6 @@ import org.w3c.dom.NodeList; import org.xml.sax.InputSource; import org.xml.sax.SAXException; - import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.JsonArray; @@ -119,9 +116,7 @@ public static String toJson(String xml) throws ParserConfigurationException, SAX Gson gson = new GsonBuilder().setPrettyPrinting() .disableHtmlEscaping() .create(); - String json = gson.toJson(rootJson); - - return json; + return gson.toJson(rootJson); } /** @@ -319,8 +314,7 @@ private static void reorganizePrimitiveToArray(Node parentNode, JsonObject upper */ private static void reorganizeAddAttributes(Node childNode, Iterator attrs) { JsonElement reorganizedJson = REORGANIZED.get(childNode.hashCode() + EMPTY); - if (reorganizedJson instanceof JsonObject) { - JsonObject objectJson = (JsonObject) reorganizedJson; + if (reorganizedJson instanceof JsonObject objectJson) { while (attrs.hasNext()) { Entry entry = (Entry) attrs.next(); objectJson.addProperty(entry.getKey() @@ -494,8 +488,7 @@ private static void serializeArrayAsXml(StringBuffer buff, Object key, Object va .append(GT); } else if (elementJson instanceof JsonArray) { serializeArrayAsXml(buff, key, elementJson); - } else if (elementJson instanceof JsonPrimitive) { - JsonPrimitive elementPrimitive = (JsonPrimitive) elementJson; + } else if (elementJson instanceof JsonPrimitive elementPrimitive) { if (ATTR_TEXT.equals(key)) { buff.append(elementPrimitive.toString() .replace(EQ, EMPTY)); diff --git a/modules/database/database-mongodb-jdbc/src/main/java/org/eclipse/dirigible/mongodb/jdbc/MongoDBDataSource.java b/modules/database/database-mongodb-jdbc/src/main/java/org/eclipse/dirigible/mongodb/jdbc/MongoDBDataSource.java index 5ec87fbba18..e66632db4f9 100644 --- a/modules/database/database-mongodb-jdbc/src/main/java/org/eclipse/dirigible/mongodb/jdbc/MongoDBDataSource.java +++ b/modules/database/database-mongodb-jdbc/src/main/java/org/eclipse/dirigible/mongodb/jdbc/MongoDBDataSource.java @@ -16,9 +16,7 @@ import java.sql.SQLException; import java.sql.SQLFeatureNotSupportedException; import java.util.logging.Logger; - import javax.sql.DataSource; - import org.slf4j.LoggerFactory; /** diff --git a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/PersistenceManager.java b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/PersistenceManager.java index 278fc60bdf6..e8ac263eb7c 100644 --- a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/PersistenceManager.java +++ b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/PersistenceManager.java @@ -20,7 +20,7 @@ import java.util.List; import java.util.Locale; -import javax.persistence.GenerationType; +import jakarta.persistence.GenerationType; import org.eclipse.dirigible.database.persistence.model.PersistenceTableColumnModel; import org.eclipse.dirigible.database.persistence.model.PersistenceTableModel; diff --git a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/parser/PersistenceAnnotationsParser.java b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/parser/PersistenceAnnotationsParser.java index 1f154320e55..1ac77c173e3 100644 --- a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/parser/PersistenceAnnotationsParser.java +++ b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/parser/PersistenceAnnotationsParser.java @@ -22,14 +22,14 @@ import java.util.List; import java.util.Map; -import javax.persistence.Column; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; -import javax.persistence.Transient; +import jakarta.persistence.Column; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; +import jakarta.persistence.Transient; import org.eclipse.dirigible.database.persistence.PersistenceException; import org.eclipse.dirigible.database.persistence.model.PersistenceTableColumnModel; diff --git a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/AbstractPersistenceProcessor.java b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/AbstractPersistenceProcessor.java index eb123588615..94bc8c470bc 100644 --- a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/AbstractPersistenceProcessor.java +++ b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/AbstractPersistenceProcessor.java @@ -29,7 +29,7 @@ import java.util.List; import java.util.Optional; -import javax.persistence.EnumType; +import jakarta.persistence.EnumType; import org.apache.commons.io.IOUtils; import org.eclipse.dirigible.database.persistence.IEntityManagerInterceptor; diff --git a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/entity/PersistenceInsertProcessor.java b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/entity/PersistenceInsertProcessor.java index 713e6033644..8689762dee5 100644 --- a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/entity/PersistenceInsertProcessor.java +++ b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/entity/PersistenceInsertProcessor.java @@ -19,7 +19,7 @@ import java.sql.SQLException; import java.sql.Statement; -import javax.persistence.GenerationType; +import jakarta.persistence.GenerationType; import org.eclipse.dirigible.database.persistence.IEntityManagerInterceptor; import org.eclipse.dirigible.database.persistence.PersistenceException; diff --git a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/identity/Identity.java b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/identity/Identity.java index 604d7e174bf..5da50a82a70 100644 --- a/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/identity/Identity.java +++ b/modules/database/database-persistence/src/main/java/org/eclipse/dirigible/database/persistence/processors/identity/Identity.java @@ -10,9 +10,9 @@ */ package org.eclipse.dirigible.database.persistence.processors.identity; -import javax.persistence.Column; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Identity transport object. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/AllDataTypes.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/AllDataTypes.java index 88a1c66ad82..5c6e0254782 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/AllDataTypes.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/AllDataTypes.java @@ -16,9 +16,9 @@ import java.sql.Time; import java.sql.Timestamp; -import javax.persistence.Column; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class All Data Types. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Customer.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Customer.java index dd3e63d60e1..8c41c8059dd 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Customer.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Customer.java @@ -10,9 +10,9 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class Customer. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Inquiry.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Inquiry.java index 0f064df22be..0f05184a87e 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Inquiry.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Inquiry.java @@ -10,11 +10,11 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class Inquiry. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/MultiOrder.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/MultiOrder.java index 1938f36f4a0..7ff627ccada 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/MultiOrder.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/MultiOrder.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; +import jakarta.persistence.Column; /** * The Class MultiOrder. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Offer.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Offer.java index 0ac72edea11..f7f3a69180a 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Offer.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Offer.java @@ -10,11 +10,11 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.GenerationType; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class Offer. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Order.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Order.java index ff62f95ffd3..1077054eb48 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Order.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Order.java @@ -10,10 +10,10 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; -import javax.persistence.GeneratedValue; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class Order. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Process.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Process.java index 35e787dfb46..5e870040cda 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Process.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Process.java @@ -10,12 +10,12 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; -import javax.persistence.EnumType; -import javax.persistence.Enumerated; -import javax.persistence.GeneratedValue; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.EnumType; +import jakarta.persistence.Enumerated; +import jakarta.persistence.GeneratedValue; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class Process. diff --git a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Task.java b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Task.java index c5fad38513e..c87d448a476 100644 --- a/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Task.java +++ b/modules/database/database-persistence/src/test/java/org/eclipse/dirigible/database/persistence/test/Task.java @@ -10,9 +10,9 @@ */ package org.eclipse.dirigible.database.persistence.test; -import javax.persistence.Column; -import javax.persistence.Id; -import javax.persistence.Table; +import jakarta.persistence.Column; +import jakarta.persistence.Id; +import jakarta.persistence.Table; /** * The Class Task. diff --git a/modules/database/pom.xml b/modules/database/pom.xml index ad19d4b8faa..6cb385a65fd 100644 --- a/modules/database/pom.xml +++ b/modules/database/pom.xml @@ -1,7 +1,8 @@ - 4.0.0 - + org.eclipse.dirigible dirigible-modules-parent @@ -11,7 +12,7 @@ Database - Parent dirigible-database-parent - pom + pom database-persistence @@ -31,4 +32,11 @@ ../../licensing-header.txt + + + org.springframework.boot + spring-boot-starter-data-jpa + + + \ No newline at end of file diff --git a/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericBigTextTest.java b/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericBigTextTest.java index 0850020f181..e3d080de68e 100644 --- a/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericBigTextTest.java +++ b/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericBigTextTest.java @@ -19,7 +19,7 @@ import java.util.Arrays; import java.util.Random; -import javax.xml.bind.DatatypeConverter; +import jakarta.xml.bind.DatatypeConverter; import org.eclipse.dirigible.repository.api.IRepository; import org.eclipse.dirigible.repository.api.IResource; diff --git a/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericFileRenameTest.java b/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericFileRenameTest.java index b918ef020bf..61b249b9e48 100644 --- a/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericFileRenameTest.java +++ b/modules/repository/repository-api-test/src/main/java/org/eclipse/dirigible/repository/generic/RepositoryGenericFileRenameTest.java @@ -18,7 +18,7 @@ import java.util.Random; -import javax.xml.bind.DatatypeConverter; +import jakarta.xml.bind.DatatypeConverter; import org.eclipse.dirigible.repository.api.ICollection; import org.eclipse.dirigible.repository.api.IRepository; From 060436ca608e1ae91d401ff1b3383ef285e78d01 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 12:40:43 +0200 Subject: [PATCH 04/64] adapt spring security Signed-off-by: Iliyan Velichkov --- .../access/HttpSecurityURIConfigurator.java | 128 +++++++++--------- .../basic/BasicAuthSecurityConfiguration.java | 38 ++---- .../KeycloakSecurityConfiguration.java | 65 +++------ .../oauth2/OAuth2SecurityConfiguration.java | 78 ++--------- 4 files changed, 101 insertions(+), 208 deletions(-) diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java index cf55c2f1d91..c86ecba84a1 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java @@ -24,80 +24,80 @@ public class HttpSecurityURIConfigurator { * @throws Exception the exception */ public static void configure(HttpSecurity http) throws Exception { - http.authorizeRequests() - .antMatchers("/") - .permitAll() - .antMatchers("/home") - .permitAll() - .antMatchers("/logout") - .permitAll() - .antMatchers("/index-busy.html") - .permitAll() + http.authorizeHttpRequests((authz) -> // + authz.requestMatchers("/") + .permitAll() + .requestMatchers("/home") + .permitAll() + .requestMatchers("/logout") + .permitAll() + .requestMatchers("/index-busy.html") + .permitAll() - .antMatchers("/stomp") - .permitAll() + .requestMatchers("/stomp") + .permitAll() - .antMatchers("/error/**") - .permitAll() - .antMatchers("/error.html") - .permitAll() + .requestMatchers("/error/**") + .permitAll() + .requestMatchers("/error.html") + .permitAll() - // Public - .antMatchers("/favicon.ico") - .permitAll() - .antMatchers("/public/**") - .permitAll() - .antMatchers("/webjars/**") - .permitAll() + // Public + .requestMatchers("/favicon.ico") + .permitAll() + .requestMatchers("/public/**") + .permitAll() + .requestMatchers("/webjars/**") + .permitAll() - .antMatchers("/services/core/theme/**") - .permitAll() - .antMatchers("/services/core/version/**") - .permitAll() - .antMatchers("/services/core/healthcheck/**") - .permitAll() - .antMatchers("/services/web/resources/**") - .permitAll() - .antMatchers("/services/web/resources-core/**") - .permitAll() - .antMatchers("/services/js/resources-core/**") - .permitAll() - .antMatchers("/services/integrations/**") - .permitAll() + .requestMatchers("/services/core/theme/**") + .permitAll() + .requestMatchers("/services/core/version/**") + .permitAll() + .requestMatchers("/services/core/healthcheck/**") + .permitAll() + .requestMatchers("/services/web/resources/**") + .permitAll() + .requestMatchers("/services/web/resources-core/**") + .permitAll() + .requestMatchers("/services/js/resources-core/**") + .permitAll() + .requestMatchers("/services/integrations/**") + .permitAll() - .antMatchers("/actuator/**") - .permitAll() + .requestMatchers("/actuator/**") + .permitAll() - // Authenticated - .antMatchers("/services/**") - .authenticated() - .antMatchers("/websockets/**") - .authenticated() - .antMatchers("/odata/**") - .authenticated() + // Authenticated + .requestMatchers("/services/**") + .authenticated() + .requestMatchers("/websockets/**") + .authenticated() + .requestMatchers("/odata/**") + .authenticated() - // Swagger UI - .antMatchers("/swagger-ui/**") - .authenticated() - .antMatchers("/v3/api-docs/swagger-config") - .authenticated() - .antMatchers("/v3/api-docs/**") - .authenticated() + // Swagger UI + .requestMatchers("/swagger-ui/**") + .authenticated() + .requestMatchers("/v3/api-docs/swagger-config") + .authenticated() + .requestMatchers("/v3/api-docs/**") + .authenticated() - // "Developer" role required - .antMatchers("/services/ide/**") - .hasRole("Developer") - .antMatchers("/websockets/ide/**") - .hasRole("Developer") + // "Developer" role required + .requestMatchers("/services/ide/**") + .hasRole("Developer") + .requestMatchers("/websockets/ide/**") + .hasRole("Developer") - // "Operator" role required - // .antMatchers("/services/ops/**").hasRole("Operator") - // .antMatchers("/services/transport/**").hasRole("Operator") - // .antMatchers("/websockets/ops/**").hasRole("Operator") + // "Operator" role required + // .requestMatchers("/services/ops/**").hasRole("Operator") + // .requestMatchers("/services/transport/**").hasRole("Operator") + // .requestMatchers("/websockets/ops/**").hasRole("Operator") - // Deny all other requests - .anyRequest() - .denyAll(); + // Deny all other requests + .anyRequest() + .denyAll()); } } diff --git a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java index 80d1f793437..e9474925a90 100644 --- a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java +++ b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java @@ -12,12 +12,12 @@ import java.nio.charset.StandardCharsets; import java.util.Arrays; - import org.apache.commons.codec.binary.Base64; import org.eclipse.dirigible.components.base.http.access.HttpSecurityURIConfigurator; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; +import org.springframework.security.config.Customizer; import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.core.userdetails.User; import org.springframework.security.core.userdetails.UserDetails; @@ -32,31 +32,13 @@ public class BasicAuthSecurityConfiguration { @Bean - public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { - http.cors() - .and() - .csrf() - .disable() - .httpBasic() - .and() - // .authorizeRequests() - // .antMatchers("/login/**").permitAll() - // .antMatchers("/error/**").permitAll() - // .antMatchers("/error.html").permitAll() - // .antMatchers("/index-busy.html").permitAll() - // .antMatchers("/stomp").permitAll() - // .antMatchers("/actuator/**").permitAll() - // .antMatchers("/*").fullyAuthenticated() - // .anyRequest().authenticated() - // .and() - .formLogin() - .and() - .logout() - .deleteCookies("JSESSIONID") - .and() - .headers() - .frameOptions() - .disable(); + SecurityFilterChain filterChain(HttpSecurity http) throws Exception { + http.cors(Customizer.withDefaults()) + .csrf((csrf) -> csrf.disable()) + .httpBasic(Customizer.withDefaults()) + .formLogin(Customizer.withDefaults()) + .logout(logout -> logout.deleteCookies("JSESSIONID")) + .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.disable())); HttpSecurityURIConfigurator.configure(http); @@ -64,7 +46,7 @@ public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { } @Bean - public InMemoryUserDetailsManager userDetailsService() { + InMemoryUserDetailsManager userDetailsService() { String username = org.eclipse.dirigible.commons.config.Configuration.get("DIRIGIBLE_BASIC_USERNAME", "YWRtaW4="); // admin String password = org.eclipse.dirigible.commons.config.Configuration.get("DIRIGIBLE_BASIC_PASSWORD", "YWRtaW4="); // admin UserDetails user = User.withUsername(new String(new Base64().decode(username.getBytes()), StandardCharsets.UTF_8).trim()) @@ -75,7 +57,7 @@ public InMemoryUserDetailsManager userDetailsService() { } @Bean - public CorsConfigurationSource corsConfigurationSource() { + CorsConfigurationSource corsConfigurationSource() { CorsConfiguration configuration = new CorsConfiguration(); configuration.setAllowedOriginPatterns(Arrays.asList("*")); configuration.setAllowCredentials(true); diff --git a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java index 8f5c58fc5bd..3d5106f0198 100644 --- a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java +++ b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java @@ -16,8 +16,10 @@ import org.keycloak.adapters.springsecurity.config.KeycloakWebSecurityConfigurerAdapter; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; +import org.springframework.security.config.Customizer; import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; import org.springframework.security.config.annotation.web.builders.HttpSecurity; +import org.springframework.security.config.annotation.web.builders.WebSecurity; import org.springframework.security.core.authority.mapping.SimpleAuthorityMapper; import org.springframework.security.core.session.SessionRegistryImpl; import org.springframework.security.web.authentication.session.RegisterSessionAuthenticationStrategy; @@ -25,7 +27,7 @@ @KeycloakConfiguration @ConditionalOnProperty(name = "keycloak.enabled", havingValue = "true") -public class KeycloakSecurityConfiguration extends KeycloakWebSecurityConfigurerAdapter { +class KeycloakSecurityConfiguration extends KeycloakWebSecurityConfigurerAdapter { @Autowired public void configureGlobal(AuthenticationManagerBuilder auth) { @@ -42,54 +44,25 @@ protected SessionAuthenticationStrategy sessionAuthenticationStrategy() { @Override protected void configure(HttpSecurity http) throws Exception { super.configure(http); - http.csrf() - .disable(); - http.headers() - .frameOptions() - .sameOrigin(); + + http.cors(Customizer.withDefaults()) + .csrf((csrf) -> csrf.disable()) + .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.sameOrigin())); + HttpSecurityURIConfigurator.configure(http); + } + + @Override + public void init(WebSecurity builder) throws Exception { + // TODO Auto-generated method stub - // http - // .authorizeRequests() - // .antMatchers("/").permitAll() - // .antMatchers("/home").permitAll() - // .antMatchers("/logout").permitAll() - // .antMatchers("/index-busy.html").permitAll() - // - // .antMatchers("/stomp").permitAll() - // - // .antMatchers("/error/**").permitAll() - // .antMatchers("/error.html").permitAll() - // - // // Public - // .antMatchers("/favicon.ico").permitAll() - // .antMatchers("/public/**").permitAll() - // .antMatchers("/webjars/**").permitAll() - // - // .antMatchers("/services/core/theme/**").permitAll() - // .antMatchers("/services/core/version/**").permitAll() - // .antMatchers("/services/core/healthcheck/**").permitAll() - // .antMatchers("/services/web/resources/**").permitAll() - // .antMatchers("/services/web/resources-core/**").permitAll() - // .antMatchers("/services/js/resources-core/**").permitAll() - // - // .antMatchers("/actuator/**").permitAll() - // - // // Authenticated - // .antMatchers("/services/**").authenticated() - // .antMatchers("/websockets/**").authenticated() - // .antMatchers("/odata/**").authenticated() - // - // // "Developer" role required - // .antMatchers("/services/ide/**").hasRole("Developer") - // .antMatchers("/websockets/ide/**").hasRole("Developer") + } - // "Operator" role required - // .antMatchers("/services/ops/**").hasRole("Operator") - // .antMatchers("/services/transport/**").hasRole("Operator") - // .antMatchers("/websockets/ops/**").hasRole("Operator") + @Override + public void configure(WebSecurity builder) throws Exception { + builder.c + // TODO Auto-generated method stub - // Deny all other requests - // .anyRequest().denyAll(); } + } diff --git a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java index 79f7180b7cb..f28bdb71b23 100644 --- a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java +++ b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java @@ -10,94 +10,32 @@ */ package org.eclipse.dirigible.components.security.oauth2; -import java.nio.charset.StandardCharsets; -import java.util.Arrays; - import org.eclipse.dirigible.components.base.http.access.HttpSecurityURIConfigurator; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; +import org.springframework.security.config.Customizer; import org.springframework.security.config.annotation.web.builders.HttpSecurity; -import org.springframework.security.core.userdetails.User; -import org.springframework.security.core.userdetails.UserDetails; -import org.springframework.security.provisioning.InMemoryUserDetailsManager; import org.springframework.security.web.SecurityFilterChain; -import org.springframework.web.cors.CorsConfiguration; -import org.springframework.web.cors.CorsConfigurationSource; -import org.springframework.web.cors.UrlBasedCorsConfigurationSource; @Configuration @ConditionalOnProperty(name = "oauth2.enabled", havingValue = "true") -public class OAuth2SecurityConfiguration { +class OAuth2SecurityConfiguration { @Bean - public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { - // http.authorizeRequests() - // .anyRequest().authenticated() - // .and() - // .oauth2Login(); + SecurityFilterChain filterChain(HttpSecurity http) throws Exception { + + http.cors(Customizer.withDefaults()) + .csrf((csrf) -> csrf.disable()) + .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.disable())) + .oauth2Login(Customizer.withDefaults()); - http.cors() - .and() - .csrf() - .disable() - .oauth2Login() - .and() - // .authorizeRequests() - // .antMatchers("/login/**").permitAll() - // .antMatchers("/error/**").permitAll() - // .antMatchers("/error.html").permitAll() - // .antMatchers("/index-busy.html").permitAll() - // .antMatchers("/stomp").permitAll() - // .antMatchers("/actuator/**").permitAll() - // .antMatchers("/*").fullyAuthenticated() - // .anyRequest().authenticated() - // .and() - // .formLogin() - // .and() - // .logout().deleteCookies("JSESSIONID") - // .and() - .headers() - .frameOptions() - .disable(); HttpSecurityURIConfigurator.configure(http); return http.build(); } - // @Bean - // public InMemoryUserDetailsManager userDetailsService() { - // String username = - // org.eclipse.dirigible.commons.config.Configuration.get("DIRIGIBLE_BASIC_USERNAME", "YWRtaW4="); - // // admin - // String password = - // org.eclipse.dirigible.commons.config.Configuration.get("DIRIGIBLE_BASIC_PASSWORD", "YWRtaW4="); - // // admin - // UserDetails user = User - // .withUsername(new String(new Base64().decode(username.getBytes()), - // StandardCharsets.UTF_8).trim()) - // .password("{noop}" + new String(new Base64().decode(password.getBytes()), - // StandardCharsets.UTF_8).trim()) - // .roles("DEVELOPER", "OPERATOR") - // .build(); - // return new InMemoryUserDetailsManager(user); - // } - - // @Bean - // public CorsConfigurationSource corsConfigurationSource() { - // CorsConfiguration configuration = new CorsConfiguration(); - // configuration.setAllowedOriginPatterns(Arrays.asList("*")); - // configuration.setAllowCredentials(true); - // configuration.setAllowedHeaders(Arrays.asList("Access-Control-Allow-Headers","Access-Control-Allow-Origin","Access-Control-Request-Method", - // "Access-Control-Request-Headers", "Origin", "Cache-Control", "Content-Type", "Authorization")); - // configuration.setExposedHeaders(Arrays.asList("Access-Control-Allow-Headers","Access-Control-Allow-Origin","Access-Control-Request-Method", - // "Access-Control-Request-Headers", "Origin", "Cache-Control", "Content-Type", "Authorization")); - // configuration.setAllowedMethods(Arrays.asList("HEAD", "DELETE", "GET", "POST", "PATCH", "PUT")); - // UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(); - // source.registerCorsConfiguration("/**", configuration); - // return source; - // } } From 97e484415b4489f0b8c1e0142577de2dff138990 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 12:44:50 +0200 Subject: [PATCH 05/64] fix mail client Signed-off-by: Iliyan Velichkov --- .../dirigible/components/api/mail/MailClient.java | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java b/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java index e57e28e5711..ec448551744 100644 --- a/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java +++ b/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java @@ -12,19 +12,25 @@ import java.io.IOException; import java.net.InetSocketAddress; -import java.net.PasswordAuthentication; import java.net.Socket; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Properties; -import org.springframework.messaging.MessagingException; import com.google.gson.Gson; import com.sun.mail.smtp.SMTPSSLTransport; import com.sun.mail.smtp.SMTPTransport; import jakarta.activation.DataHandler; -import jakarta.mail.*; -import jakarta.mail.internet.*; +import jakarta.mail.Authenticator; +import jakarta.mail.Message; +import jakarta.mail.MessagingException; +import jakarta.mail.PasswordAuthentication; +import jakarta.mail.Session; +import jakarta.mail.internet.ContentType; +import jakarta.mail.internet.InternetAddress; +import jakarta.mail.internet.MimeBodyPart; +import jakarta.mail.internet.MimeMessage; +import jakarta.mail.internet.MimeMultipart; import jakarta.mail.util.ByteArrayDataSource; /** @@ -124,6 +130,7 @@ private Session getSession(Properties properties) { String user = properties.getProperty(MAIL_USER); String password = properties.getProperty(MAIL_PASSWORD); Authenticator authenticator = new Authenticator() { + @Override protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication(user, password); } From 95cbc2a212720f66919766b8241e30a11d847eb5 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 12:45:53 +0200 Subject: [PATCH 06/64] disable odata module for now Signed-off-by: Iliyan Velichkov --- modules/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/pom.xml b/modules/pom.xml index a045f69f7a2..f6f37bd657d 100644 --- a/modules/pom.xml +++ b/modules/pom.xml @@ -20,7 +20,7 @@ database engines mail - odata + repository From b3e37d6ce2a3afe4d6c82bbe6d65472bd1c7a058 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 14:09:49 +0200 Subject: [PATCH 07/64] more adaptations Signed-off-by: Iliyan Velichkov --- components/api/api-http/pom.xml | 7 +- .../components/api/http/HttpUploadFacade.java | 25 ++--- .../api/http/client/HttpClientProxyUtils.java | 26 ++--- .../components/data/store/DataStore.java | 2 +- .../components/data/store/domain/Entity.java | 2 +- .../data/structures/domain/Schema.java | 2 +- .../data/structures/domain/Table.java | 2 +- .../data/structures/domain/TableColumn.java | 2 +- .../domain/TableConstraintCheck.java | 2 +- .../domain/TableConstraintForeignKey.java | 2 +- .../domain/TableConstraintPrimaryKey.java | 2 +- .../domain/TableConstraintUnique.java | 2 +- .../structures/domain/TableConstraints.java | 2 +- .../data/structures/domain/TableIndex.java | 2 +- .../data/structures/domain/View.java | 2 +- .../KeycloakSecurityConfiguration.java | 98 ++++++++----------- 16 files changed, 76 insertions(+), 104 deletions(-) diff --git a/components/api/api-http/pom.xml b/components/api/api-http/pom.xml index 5005ca6eaf8..a953f9a615d 100644 --- a/components/api/api-http/pom.xml +++ b/components/api/api-http/pom.xml @@ -75,11 +75,12 @@ 4.5.14 - commons-fileupload - commons-fileupload - 1.5 + org.apache.commons + commons-fileupload2-jakarta + 2.0.0-M1 + diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java index 93845af31a2..f3c097c8f46 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/HttpUploadFacade.java @@ -13,17 +13,13 @@ import java.util.ArrayList; import java.util.Iterator; import java.util.List; - -import jakarta.servlet.http.HttpServletRequest; - -import org.apache.commons.fileupload.FileItem; -import org.apache.commons.fileupload.FileUploadException; -import org.apache.commons.fileupload.disk.DiskFileItemFactory; -import org.apache.commons.fileupload.servlet.ServletFileUpload; +import org.apache.commons.fileupload2.core.DiskFileItemFactory; +import org.apache.commons.fileupload2.core.FileItem; +import org.apache.commons.fileupload2.core.FileUploadException; +import org.apache.commons.fileupload2.jakarta.JakartaServletFileUpload; import org.eclipse.dirigible.commons.api.context.InvalidStateException; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; +import jakarta.servlet.http.HttpServletRequest; /** * Java facade for working uploading files. @@ -34,8 +30,6 @@ public class HttpUploadFacade { /** The Constant NO_VALID_REQUEST. */ private static final String NO_VALID_REQUEST = "Trying to use HTTP Upload Facade without a valid Request"; - /** The Constant logger. */ - private static final Logger logger = LoggerFactory.getLogger(HttpUploadFacade.class); /** * Checks if the request contains multipart content. @@ -49,7 +43,7 @@ public static final boolean isMultipartContent() { return false; } - return ServletFileUpload.isMultipartContent(request); + return JakartaServletFileUpload.isMultipartContent(request); } /** @@ -60,13 +54,14 @@ public static final boolean isMultipartContent() { * @throws FileUploadException if there is a problem parsing the request */ public static final List parseRequest() throws FileUploadException { - ServletFileUpload servletFileUpload = new ServletFileUpload(new DiskFileItemFactory()); + DiskFileItemFactory diskFileItemFactory = DiskFileItemFactory.builder() + .get(); + JakartaServletFileUpload JakartaServletFileUpload = new JakartaServletFileUpload(diskFileItemFactory); HttpServletRequest request = HttpRequestFacade.getRequest(); if (request == null) { throw new InvalidStateException(NO_VALID_REQUEST); } - List fileItems = servletFileUpload.parseRequest(request); - return fileItems; + return JakartaServletFileUpload.parseRequest(request); } /** diff --git a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java index 92d63797fcf..b17e043c238 100644 --- a/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java +++ b/components/api/api-http/src/main/java/org/eclipse/dirigible/components/api/http/client/HttpClientProxyUtils.java @@ -15,14 +15,11 @@ import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.cert.X509Certificate; - -import jakarta.net.ssl.HostnameVerifier; -import jakarta.net.ssl.HttpsURLConnection; -import jakarta.net.ssl.SSLContext; -import jakarta.net.ssl.SSLSession; -import jakarta.net.ssl.TrustManager; -import jakarta.net.ssl.X509TrustManager; - +import javax.net.ssl.HostnameVerifier; +import javax.net.ssl.HttpsURLConnection; +import javax.net.ssl.SSLContext; +import javax.net.ssl.TrustManager; +import javax.net.ssl.X509TrustManager; import org.apache.commons.lang3.StringUtils; import org.apache.http.HttpException; import org.apache.http.HttpHost; @@ -175,18 +172,11 @@ private static void setTrustAllSSL() throws IOException { try { HttpsURLConnection.setDefaultSSLSocketFactory(createTrustAllSSLContext().getSocketFactory()); // Create all-trusting host name verifier - HostnameVerifier allHostsValid = new HostnameVerifier() { - @Override - public boolean verify(String hostname, SSLSession session) { - return true; - } - }; + HostnameVerifier allHostsValid = (hostname, session) -> true; // Install the all-trusting host verifier HttpsURLConnection.setDefaultHostnameVerifier(allHostsValid); - } catch (KeyManagementException e) { - throw new IOException(e); - } catch (NoSuchAlgorithmException e) { + } catch (KeyManagementException | NoSuchAlgorithmException e) { throw new IOException(e); } } @@ -202,7 +192,7 @@ private static SSLContext createTrustAllSSLContext() throws NoSuchAlgorithmExcep SSLContext sslContext = SSLContext.getInstance("SSL"); // Create a trust manager that does not validate certificate chains - TrustManager[] trustAllCerts = new TrustManager[] {new X509TrustManager() { + TrustManager[] trustAllCerts = {new X509TrustManager() { @Override public java.security.cert.X509Certificate[] getAcceptedIssuers() { return null; diff --git a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java index e0d8279bcc1..ca11bd3db48 100644 --- a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java +++ b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java @@ -21,7 +21,7 @@ import org.apache.commons.io.IOUtils; import org.eclipse.dirigible.components.base.helpers.JsonHelper; import org.eclipse.dirigible.components.data.sources.manager.DataSourcesManager; -import org.hibernate.Criteria; +import org.hibernate.Criteria; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; diff --git a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java index 8158e7fab4b..5f8182b8f5f 100644 --- a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java +++ b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/domain/Entity.java @@ -22,7 +22,7 @@ /** * The Class Entity. */ -@javax.persistence.Entity +@jakarta.persistence.Entity @Table(name = "DIRIGIBLE_ENTITIES") public class Entity extends Artefact { diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java index f2ed1149cf1..6c371c55ed6 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Schema.java @@ -33,7 +33,7 @@ * The Class Schema. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_SCHEMAS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_SCHEMAS") public class Schema extends Artefact { /** The Constant ARTEFACT_TYPE. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java index 42883eb62cf..c8b4eb63c57 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java @@ -40,7 +40,7 @@ * The Class Table. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLES") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLES") public class Table extends Artefact { /** The Constant ARTEFACT_TYPE. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java index 1d0b7d2d346..3c225317c2d 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableColumn.java @@ -29,7 +29,7 @@ * The Class TableColumn. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_COLUMNS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_COLUMNS") public class TableColumn { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java index fa7538c2215..907cd71f617 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java @@ -30,7 +30,7 @@ * The Class TableConstraintCheck. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_CHECKS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_CHECKS") public class TableConstraintCheck extends TableConstraint { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java index 2ef280c04dc..a5b4b465e6f 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java @@ -28,7 +28,7 @@ * The Class TableConstraintForeignKey. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_FOREIGNKEYS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_FOREIGNKEYS") public class TableConstraintForeignKey extends TableConstraint { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java index dfe262aee8a..adfb93e4b11 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintPrimaryKey.java @@ -20,7 +20,7 @@ * The Class TableConstraintPrimaryKey. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_PRIMARYKEYS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_PRIMARYKEYS") public class TableConstraintPrimaryKey extends TableConstraint { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java index f55e1985711..42c8317da57 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java @@ -23,7 +23,7 @@ * The Class TableConstraintUnique. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_UNIQUES") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_UNIQUES") public class TableConstraintUnique extends TableConstraint { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java index aa0ded28064..124c7a5b508 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java @@ -38,7 +38,7 @@ * The Class TableConstraints. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_CONSTRAINTS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_CONSTRAINTS") public class TableConstraints { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java index 136545aa792..75d374fab92 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableIndex.java @@ -38,7 +38,7 @@ * The Class TableIndex. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_INDEXES") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_TABLE_INDEXES") public class TableIndex { /** The id. */ diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java index 9bd775e6bf3..bec3fd2f59f 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/View.java @@ -32,7 +32,7 @@ * The Class View. */ @Entity -@javax.persistence.Table(name = "DIRIGIBLE_DATA_VIEWS") +@jakarta.persistence.Table(name = "DIRIGIBLE_DATA_VIEWS") public class View extends Artefact { /** The Constant ARTEFACT_TYPE. */ diff --git a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java index 3d5106f0198..f6fc8b303ee 100644 --- a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java +++ b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java @@ -10,59 +10,45 @@ */ package org.eclipse.dirigible.components.security.keycloak; -import org.eclipse.dirigible.components.base.http.access.HttpSecurityURIConfigurator; -import org.keycloak.adapters.springsecurity.KeycloakConfiguration; -import org.keycloak.adapters.springsecurity.authentication.KeycloakAuthenticationProvider; -import org.keycloak.adapters.springsecurity.config.KeycloakWebSecurityConfigurerAdapter; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; -import org.springframework.security.config.Customizer; -import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; -import org.springframework.security.config.annotation.web.builders.HttpSecurity; -import org.springframework.security.config.annotation.web.builders.WebSecurity; -import org.springframework.security.core.authority.mapping.SimpleAuthorityMapper; -import org.springframework.security.core.session.SessionRegistryImpl; -import org.springframework.security.web.authentication.session.RegisterSessionAuthenticationStrategy; -import org.springframework.security.web.authentication.session.SessionAuthenticationStrategy; - -@KeycloakConfiguration -@ConditionalOnProperty(name = "keycloak.enabled", havingValue = "true") -class KeycloakSecurityConfiguration extends KeycloakWebSecurityConfigurerAdapter { - - @Autowired - public void configureGlobal(AuthenticationManagerBuilder auth) { - KeycloakAuthenticationProvider keycloakAuthenticationProvider = keycloakAuthenticationProvider(); - keycloakAuthenticationProvider.setGrantedAuthoritiesMapper(new SimpleAuthorityMapper()); // prefix = "ROLE_ - auth.authenticationProvider(keycloakAuthenticationProvider); - } - - @Override - protected SessionAuthenticationStrategy sessionAuthenticationStrategy() { - return new RegisterSessionAuthenticationStrategy(new SessionRegistryImpl()); - } - - @Override - protected void configure(HttpSecurity http) throws Exception { - super.configure(http); - - http.cors(Customizer.withDefaults()) - .csrf((csrf) -> csrf.disable()) - .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.sameOrigin())); - - HttpSecurityURIConfigurator.configure(http); - } - - @Override - public void init(WebSecurity builder) throws Exception { - // TODO Auto-generated method stub - - } - - @Override - public void configure(WebSecurity builder) throws Exception { - builder.c - // TODO Auto-generated method stub - - } - -} +// TODO to be adapted +// +// @KeycloakConfiguration +// @ConditionalOnProperty(name = "keycloak.enabled", havingValue = "true") +// class KeycloakSecurityConfiguration extends KeycloakWebSecurityConfigurerAdapter { +// +// @Autowired +// public void configureGlobal(AuthenticationManagerBuilder auth) { +// KeycloakAuthenticationProvider keycloakAuthenticationProvider = keycloakAuthenticationProvider(); +// keycloakAuthenticationProvider.setGrantedAuthoritiesMapper(new SimpleAuthorityMapper()); // +// prefix = "ROLE_ +// auth.authenticationProvider(keycloakAuthenticationProvider); +// } +// +// @Override +// protected SessionAuthenticationStrategy sessionAuthenticationStrategy() { +// return new RegisterSessionAuthenticationStrategy(new SessionRegistryImpl()); +// } +// +// @Override +// protected void configure(HttpSecurity http) throws Exception { +// super.configure(http); +// +// http.cors(Customizer.withDefaults()) +// .csrf((csrf) -> csrf.disable()) +// .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.sameOrigin())); +// +// HttpSecurityURIConfigurator.configure(http); +// } +// +// @Override +// public void init(WebSecurity builder) throws Exception { +// // TODO Auto-generated method stub +// +// } +// +// @Override +// public void configure(WebSecurity builder) throws Exception { +// // TODO Auto-generated method stub +// } +// +// } From e8a2737d972ae99acd44b728882ea264409ffcc2 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 14:41:31 +0200 Subject: [PATCH 08/64] disable odata Signed-off-by: Iliyan Velichkov --- components/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/pom.xml b/components/pom.xml index 6180257bf0b..b818a3396cc 100644 --- a/components/pom.xml +++ b/components/pom.xml @@ -64,7 +64,7 @@ engine/engine-websockets engine/engine-security engine/engine-listeners - engine/engine-odata + engine/engine-camel engine/engine-ftp engine/engine-sftp From 9a0c6b47a510905dde32758735a63635bd6b05e7 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 15:22:37 +0200 Subject: [PATCH 09/64] more adaptations Signed-off-by: Iliyan Velichkov --- .../api/core/DestinationsFacade.java | 10 +- .../components/api/db/DataStoreFacade.java | 7 +- .../components/api/db/DatabaseFacade.java | 18 +- .../components/data/store/DataStore.java | 66 ++----- .../ftp/config/IntegrationConfiguration.java | 21 ++- .../jobs/email/JobEmailProcessor.java | 2 +- components/engine/engine-listeners/pom.xml | 165 ++++++++++++------ .../ActiveMQConnectionArtifactsFactory.java | 6 +- ...eActiveMQResourcesApplicationListener.java | 6 +- .../listeners/config/MessagingConfig.java | 6 +- .../listeners/service/MessageConsumer.java | 15 +- .../listeners/service/MessageProducer.java | 15 +- .../service/MessageConsumerTest.java | 2 +- .../service/MessageProducerTest.java | 2 +- .../designer/components/components.json | 10 +- 15 files changed, 179 insertions(+), 172 deletions(-) diff --git a/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java b/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java index 50211c034e9..14c64bcf694 100644 --- a/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java +++ b/components/api/api-core/src/main/java/org/eclipse/dirigible/components/api/core/DestinationsFacade.java @@ -16,13 +16,10 @@ import java.io.IOException; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; -import java.util.Date; import java.util.Map; import java.util.Properties; - -import jakarta.naming.InitialContext; -import jakarta.naming.NamingException; - +import javax.naming.InitialContext; +import javax.naming.NamingException; import org.eclipse.dirigible.commons.api.helpers.GsonHelper; import org.eclipse.dirigible.commons.config.Configuration; import org.eclipse.dirigible.repository.api.IRepository; @@ -102,7 +99,8 @@ public static String get(String name) throws NoSuchMethodException, SecurityExce } else { throw new IllegalArgumentException(String.format("Destination: %s does not exist", fullName)); } - } else if (DIRIGIBLE_DESTINATIONS_PROVIDER_MANAGED.equals(destinationProvider)) { + } + if (DIRIGIBLE_DESTINATIONS_PROVIDER_MANAGED.equals(destinationProvider)) { Map destinationProperties = initializeFromDestination(name); return GsonHelper.toJson(destinationProperties); } else { diff --git a/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DataStoreFacade.java b/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DataStoreFacade.java index 1dc82b44791..fcbf840fc77 100644 --- a/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DataStoreFacade.java +++ b/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DataStoreFacade.java @@ -15,8 +15,6 @@ import java.util.Map; import org.eclipse.dirigible.components.base.helpers.JsonHelper; import org.eclipse.dirigible.components.data.store.DataStore; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import org.springframework.beans.factory.InitializingBean; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; @@ -27,14 +25,11 @@ @Component public class DataStoreFacade implements InitializingBean { - /** The Constant logger. */ - private static final Logger logger = LoggerFactory.getLogger(DataStoreFacade.class); - /** The data sore facade. */ private static DataStoreFacade INSTANCE; /** The data store. */ - private DataStore dataStore; + private final DataStore dataStore; /** * Instantiates a new data store facade. diff --git a/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java b/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java index 0b28b30f63c..df5b095ed20 100644 --- a/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java +++ b/components/api/api-database/src/main/java/org/eclipse/dirigible/components/api/db/DatabaseFacade.java @@ -476,9 +476,9 @@ private static void setParameters(String parameters, PreparedStatement preparedS } catch (NumberFormatException e) { // assume date string in ISO format e.g. 2018-05-22T21:00:00.000Z value = new Date(jakarta.xml.bind.DatatypeConverter.parseDateTime(valueElement.getAsJsonPrimitive() - .getAsString()) - .getTime() - .getTime()); + .getAsString()) + .getTime() + .getTime()); } preparedStatement.setDate(i++, value); } else { @@ -499,9 +499,9 @@ private static void setParameters(String parameters, PreparedStatement preparedS } catch (NumberFormatException e) { // assume XSDTime value = new Time(jakarta.xml.bind.DatatypeConverter.parseTime(valueElement.getAsJsonPrimitive() - .getAsString()) - .getTime() - .getTime()); + .getAsString()) + .getTime() + .getTime()); } preparedStatement.setTime(i++, value); } else { @@ -522,9 +522,9 @@ private static void setParameters(String parameters, PreparedStatement preparedS } catch (NumberFormatException e) { // assume date string in ISO format e.g. 2018-05-22T21:00:00.000Z value = new Timestamp(jakarta.xml.bind.DatatypeConverter.parseDateTime(valueElement.getAsJsonPrimitive() - .getAsString()) - .getTime() - .getTime()); + .getAsString()) + .getTime() + .getTime()); } preparedStatement.setTimestamp(i++, value); } else { diff --git a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java index ca11bd3db48..0b03e6849e4 100644 --- a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java +++ b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java @@ -17,11 +17,11 @@ import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.Set; import javax.sql.DataSource; import org.apache.commons.io.IOUtils; import org.eclipse.dirigible.components.base.helpers.JsonHelper; import org.eclipse.dirigible.components.data.sources.manager.DataSourcesManager; -import org.hibernate.Criteria; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; @@ -29,9 +29,11 @@ import org.hibernate.boot.registry.StandardServiceRegistryBuilder; import org.hibernate.cfg.Configuration; import org.hibernate.cfg.Environment; -import org.hibernate.criterion.Restrictions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; +import com.google.common.base.Objects; +import jakarta.persistence.EntityManager; +import jakarta.persistence.metamodel.EntityType; /** * The Class ObjectStore. @@ -273,56 +275,18 @@ public boolean contains(String type, String json, DataSource datasource) { * @return the list */ public List list(String type) { - return list(type, getDataSource()); - } - - /** - * List. - * - * @param type the type - * @param datasource the datasource - * @return the list - */ - public List list(String type, DataSource datasource) { - try (Session session = sessionFactory.openSession()) { - return session.createCriteria(type) - .list(); - } - } - - /** - * Criteria. - * - * @param type the type - * @param restrictions the restrictions - * @param aliases the aliases - * @return the list - */ - public List criteria(String type, Map restrictions, Map aliases) { - return criteria(type, restrictions, aliases, getDataSource()); - } - - /** - * Criteria. - * - * @param type the type - * @param restrictions the restrictions - * @param aliases the aliases - * @param datasource the datasource - * @return the list - */ - public List criteria(String type, Map restrictions, Map aliases, DataSource datasource) { try (Session session = sessionFactory.openSession()) { - Criteria criteria = session.createCriteria(type); - if (aliases != null) { - aliases.entrySet() - .forEach(e -> criteria.createAlias(e.getKey(), e.getValue())); + Set> entities = sessionFactory.getMetamodel() + .getEntities(); + EntityType entityType = entities.stream() + .filter(et -> Objects.equal(et.getName(), type)) + .findFirst() + .orElseThrow(() -> new IllegalArgumentException("There is not entity of type " + type)); + try (EntityManager entityManager = session.getEntityManagerFactory() + .createEntityManager()) { + jakarta.persistence.Query query = entityManager.createQuery("from " + entityType.getName() + " c"); + return query.getResultList(); } - if (restrictions != null) { - restrictions.entrySet() - .forEach(e -> criteria.add(Restrictions.like(e.getKey(), e.getValue()))); - } - return criteria.list(); } } @@ -364,3 +328,5 @@ public List query(String query, DataSource datasource) { // } } + + diff --git a/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/config/IntegrationConfiguration.java b/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/config/IntegrationConfiguration.java index 89db46514fb..2ed9e168003 100644 --- a/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/config/IntegrationConfiguration.java +++ b/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/config/IntegrationConfiguration.java @@ -14,13 +14,12 @@ import org.slf4j.LoggerFactory; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; +import org.springframework.integration.core.GenericHandler; import org.springframework.integration.dsl.IntegrationFlow; -import org.springframework.integration.dsl.IntegrationFlows; import org.springframework.integration.dsl.MessageChannels; import org.springframework.integration.event.inbound.ApplicationEventListeningMessageProducer; import org.springframework.integration.ftp.server.ApacheMinaFtpEvent; import org.springframework.integration.ftp.server.ApacheMinaFtplet; -import org.springframework.integration.handler.GenericHandler; import org.springframework.messaging.MessageChannel; /** @@ -50,7 +49,7 @@ ApacheMinaFtplet apacheMinaFtplet() { @Bean MessageChannel eventsChannel() { return MessageChannels.direct() - .get(); + .getObject(); } /** @@ -60,14 +59,14 @@ MessageChannel eventsChannel() { */ @Bean IntegrationFlow integrationFlow() { - return IntegrationFlows.from(this.eventsChannel()) - .handle((GenericHandler) (apacheMinaFtpEvent, messageHeaders) -> { - logger.info("new event: " + apacheMinaFtpEvent.getClass() - .getName() - + ':' + apacheMinaFtpEvent.getSession()); - return null; - }) - .get(); + return IntegrationFlow.from(this.eventsChannel()) + .handle((GenericHandler) (apacheMinaFtpEvent, messageHeaders) -> { + logger.info("new event: " + apacheMinaFtpEvent.getClass() + .getName() + + ':' + apacheMinaFtpEvent.getSession()); + return null; + }) + .get(); } /** diff --git a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java index 7ec14c126df..5cc1113ee8b 100644 --- a/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java +++ b/components/engine/engine-jobs/src/main/java/org/eclipse/dirigible/components/jobs/email/JobEmailProcessor.java @@ -29,8 +29,8 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.messaging.MessagingException; import org.springframework.stereotype.Component; +import jakarta.mail.MessagingException; /** * The Class JobEmailProcessor. diff --git a/components/engine/engine-listeners/pom.xml b/components/engine/engine-listeners/pom.xml index 3785e73cfac..4d50e54cac7 100644 --- a/components/engine/engine-listeners/pom.xml +++ b/components/engine/engine-listeners/pom.xml @@ -1,77 +1,132 @@ - - - - dirigible-components-parent - org.eclipse.dirigible - 10.0.0-SNAPSHOT - ../../pom.xml - - - Components - Engine - Listeners - dirigible-components-engine-listeners - 4.0.0 - + - - - org.eclipse.dirigible - dirigible-components-core-base - - - org.eclipse.dirigible - dirigible-components-core-database - - - org.eclipse.dirigible - dirigible-components-core-repository - - - + + dirigible-components-parent + org.eclipse.dirigible + 10.0.0-SNAPSHOT + ../../pom.xml + + + Components - Engine - Listeners + dirigible-components-engine-listeners + 4.0.0 + + + org.apache.activemq + activemq-broker + + + org.apache.activemq + activemq-client + + + + + org.apache.activemq + activemq-client-jakarta + + + org.apache.activemq + activemq-client + + + + + + org.eclipse.dirigible + dirigible-components-core-base + + + org.eclipse.dirigible + dirigible-components-core-database + + + org.eclipse.dirigible + dirigible-components-core-repository + + + org.eclipse.dirigible dirigible-components-engine-javascript - - - - org.apache.geronimo.specs - geronimo-j2ee-management_1.1_spec - 1.0.1 + + + + org.apache.geronimo.specs + geronimo-j2ee-management_1.1_spec + 1.0.1 - - org.apache.activemq - activemq-broker + + org.apache.activemq + activemq-broker - org.apache.activemq - activemq-client + org.apache.activemq + activemq-client - org.apache.activemq - activemq-jdbc-store + org.apache.activemq + activemq-jdbc-store - org.apache.activemq - activemq-kahadb-store + org.apache.activemq + activemq-kahadb-store - org.apache.activemq - activemq-openwire-legacy + org.apache.activemq + activemq-openwire-legacy - org.fusesource.hawtbuf - hawtbuf - 1.11 + org.fusesource.hawtbuf + hawtbuf + 1.11 org.junit.vintage junit-vintage-engine - + + + + + + org.apache.activemq + activemq-broker + ${activemq.version} + + + org.apache.activemq + activemq-client + ${activemq.version} + + + org.apache.activemq + activemq-client-jakarta + ${activemq.version} + + + org.apache.activemq + activemq-jdbc-store + ${activemq.version} + + + org.apache.activemq + activemq-kahadb-store + ${activemq.version} + + + org.apache.activemq + activemq-openwire-legacy + ${activemq.version} + + + - - ../../../licensing-header.txt - ../../../ - - + + ../../../licensing-header.txt + ../../../ + + \ No newline at end of file diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java index 537520cf118..c66f220004a 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/ActiveMQConnectionArtifactsFactory.java @@ -10,13 +10,13 @@ */ package org.eclipse.dirigible.components.listeners.config; +import org.apache.activemq.ActiveMQConnectionFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; import jakarta.jms.Connection; import jakarta.jms.ExceptionListener; import jakarta.jms.JMSException; import jakarta.jms.Session; -import org.apache.activemq.ActiveMQConnectionFactory; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.stereotype.Component; /** * A factory for creating ActiveMQConnectionArtifacts objects. diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java index 4152c906165..13bb75b451c 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/CloseActiveMQResourcesApplicationListener.java @@ -10,9 +10,6 @@ */ package org.eclipse.dirigible.components.listeners.config; -import jakarta.jms.Connection; -import jakarta.jms.JMSException; -import jakarta.jms.Session; import org.apache.activemq.broker.BrokerService; import org.eclipse.dirigible.components.listeners.service.ListenersManager; import org.slf4j.Logger; @@ -24,6 +21,9 @@ import org.springframework.context.event.ContextClosedEvent; import org.springframework.context.event.ContextStoppedEvent; import org.springframework.stereotype.Component; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.Session; /** * The listener interface for receiving closeActiveMQResourcesApplication events. The class that is diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java index 2338d7c9735..b65a63b5178 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java @@ -11,9 +11,6 @@ package org.eclipse.dirigible.components.listeners.config; import java.io.File; -import jakarta.jms.Connection; -import jakarta.jms.JMSException; -import jakarta.jms.Session; import javax.sql.DataSource; import org.apache.activemq.ActiveMQConnectionFactory; import org.apache.activemq.broker.BrokerService; @@ -26,6 +23,9 @@ import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.DependsOn; +import jakarta.jms.Connection; +import jakarta.jms.JMSException; +import jakarta.jms.Session; /** * The Class MessagingConfig. diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java index 6450400b9b8..a0d80bf4a8c 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageConsumer.java @@ -10,16 +10,16 @@ */ package org.eclipse.dirigible.components.listeners.service; -import jakarta.jms.Destination; -import jakarta.jms.JMSException; -import jakarta.jms.Message; -import jakarta.jms.Session; -import jakarta.jms.TextMessage; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; +import jakarta.jms.Destination; +import jakarta.jms.JMSException; +import jakarta.jms.Message; +import jakarta.jms.Session; +import jakarta.jms.TextMessage; /** * The Class MessageConsumer. @@ -79,8 +79,7 @@ public String receiveMessageFromTopic(String topic, long timeout) throws JMSExce * @throws TimeoutException the timeout exception */ private String receiveMessage(long timeout, Destination destination) throws JMSException, TimeoutException { - javax.jms.MessageConsumer consumer = session.createConsumer(destination); - try { + try (jakarta.jms.MessageConsumer consumer = session.createConsumer(destination)) { Message message = consumer.receive(timeout); LOGGER.debug("Received message [{}] by synchronous consumer.", message); @@ -91,8 +90,6 @@ private String receiveMessage(long timeout, Destination destination) throws JMSE return textMessage.getText(); } throw new IllegalStateException("Received an unsupported message " + message); - } finally { - consumer.close(); } } diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java index 92edda531e2..1ce505a4468 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/MessageProducer.java @@ -10,16 +10,16 @@ */ package org.eclipse.dirigible.components.listeners.service; -import jakarta.jms.DeliveryMode; -import jakarta.jms.Destination; -import jakarta.jms.JMSException; -import jakarta.jms.Session; -import jakarta.jms.TextMessage; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.stereotype.Component; +import jakarta.jms.DeliveryMode; +import jakarta.jms.Destination; +import jakarta.jms.JMSException; +import jakarta.jms.Session; +import jakarta.jms.TextMessage; /** * The Class MessageProducer. @@ -75,16 +75,13 @@ public void sendMessageToQueue(String queue, String message) throws JMSException * @throws JMSException the JMS exception */ private void sendMessage(String message, Destination destination) throws JMSException { - javax.jms.MessageProducer producer = session.createProducer(destination); - try { + try (jakarta.jms.MessageProducer producer = session.createProducer(destination)) { producer.setDeliveryMode(DeliveryMode.PERSISTENT); TextMessage textMessage = session.createTextMessage(message); producer.send(textMessage); LOGGER.trace("Message sent in [{}]", destination); - } finally { - producer.close(); } } diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java index ac609ef60e8..4c0c802f906 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageConsumerTest.java @@ -54,7 +54,7 @@ class MessageConsumerTest { /** The jsm consumer. */ @Mock - private javax.jms.MessageConsumer jsmConsumer; + private jakarta.jms.MessageConsumer jsmConsumer; /** The queue. */ @Mock diff --git a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java index dafc349e139..330a98f5b32 100644 --- a/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java +++ b/components/engine/engine-listeners/src/test/java/org/eclipse/dirigible/components/listeners/service/MessageProducerTest.java @@ -49,7 +49,7 @@ class MessageProducerTest { /** The jsm producer. */ @Mock - private javax.jms.MessageProducer jsmProducer; + private jakarta.jms.MessageProducer jsmProducer; /** The queue. */ @Mock diff --git a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json index 4accdea7c41..fec4b5376fa 100644 --- a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json +++ b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json @@ -1,7 +1,7 @@ [ -{"component":{"kind":"component","name":"activemq","title":"ActiveMQ","description":"Send messages to (or consume from) Apache ActiveMQ. This component extends the Camel JMS component.","deprecated":false,"firstVersion":"1.0.0","label":"messaging","javaType":"org.apache.camel.component.activemq.ActiveMQComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-activemq","version":"3.20.3","scheme":"activemq","extendsScheme":"jms","syntax":"activemq:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJmsDestination":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION"},"CamelJmsDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the queue or topic to use as destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION_NAME"},"JMSXGroupID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS group ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_X_GROUP_ID"},"JMSMessageID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS unique message ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_MESSAGE_ID"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID"},"JMSCorrelationIDAsBytes":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID as bytes.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID_AS_BYTES"},"JMSDeliveryMode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS delivery mode.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DELIVERY_MODE"},"JMSDestination":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DESTINATION"},"JMSExpiration":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS expiration.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_EXPIRATION"},"JMSPriority":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS priority (with 0 as the lowest priority and 9 as the highest).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_PRIORITY"},"JMSRedelivered":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Is the JMS message redelivered.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REDELIVERED"},"JMSTimestamp":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS timestamp.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TIMESTAMP"},"JMSReplyTo":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS reply-to destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REPLY_TO"},"JMSType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TYPE"},"JMSXUserID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The XUser id.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_XUSER_ID"},"CamelJmsMessageType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text","Blob"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The message type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_MESSAGE_TYPE"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"20_000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_REQUEST_TIMEOUT"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic","temp-queue","temp-topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of the queue or topic to use as destination"},"clientId":{"kind":"parameter","displayName":"Client Id","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"","required":false,"type":"object","javaType":"javax.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"jmsMessageType":{"kind":"parameter","displayName":"Jms Message Type","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to force the use of a specific javax.jms.Message implementation for sending JMS messages. Possible values are: Bytes, Map, Object, Stream, Text. By default, Camel would determine which JMS message type to use from the In body type. This option allows you to specify it."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"acknowledgementModeName":{"kind":"parameter","displayName":"Acknowledgement Mode Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"artemisConsumerPriority":{"kind":"parameter","displayName":"Artemis Consumer Priority","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Consumer priorities allow you to ensure that high priority consumers receive messages while they are active. Normally, active consumers connected to a queue receive messages from it in a round-robin fashion. When consumer priorities are in use, messages are delivered round-robin if multiple active consumers exist with the same high priority. Messages will only going to lower priority consumers when the high priority consumers do not have credit available to consume the message, or those high priority consumers have declined to accept the message (for instance because it does not meet the criteria of any selectors associated with the consumer)."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer container should auto-startup."},"cacheLevel":{"kind":"parameter","displayName":"Cache Level","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by ID for the underlying JMS resources. See cacheLevelName option for more details."},"cacheLevelName":{"kind":"parameter","displayName":"Cache Level Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"CACHE_AUTO","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the underlying JMS resources. Possible values are: CACHE_AUTO, CACHE_CONNECTION, CACHE_CONSUMER, CACHE_NONE, and CACHE_SESSION. The default setting is CACHE_AUTO. See the Spring documentation and Transactions Cache Levels for more information."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"maxConcurrentConsumers":{"kind":"parameter","displayName":"Max Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToMaxConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use persistent delivery by default for replies."},"selector":{"kind":"parameter","displayName":"Selector","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS selector to use"},"subscriptionDurable":{"kind":"parameter","displayName":"Subscription Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription durable. The durable subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a durable subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well."},"subscriptionName":{"kind":"parameter","displayName":"Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set the name of a subscription to create. To be applied in case of a topic (pub-sub domain) with a shared or durable subscription. The subscription name needs to be unique within this client's JMS client id. Default is the class name of the specified message listener. Note: Only 1 concurrent consumer (which is the default of this message listener container) is allowed for each subscription, except for a shared subscription (which requires JMS 2.0)."},"subscriptionShared":{"kind":"parameter","displayName":"Subscription Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription shared. The shared subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a shared subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Note that shared subscriptions may also be durable, so this flag can (and often will) be combined with subscriptionDurable as well. Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well. Requires a JMS 2.0 compatible message broker."},"acceptMessagesWhileStopping":{"kind":"parameter","displayName":"Accept Messages While Stopping","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer accept messages while it is stopping. You may consider enabling this option, if you start and stop JMS routes at runtime, while there are still messages enqueued on the queue. If this option is false, and you stop the JMS route, then messages may be rejected, and the JMS broker would have to attempt redeliveries, which yet again may be rejected, and eventually the message may be moved at a dead letter queue on the JMS broker. To avoid this its recommended to enable this option."},"allowReplyManagerQuickStop":{"kind":"parameter","displayName":"Allow Reply Manager Quick Stop","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the DefaultMessageListenerContainer used in the reply managers for request-reply messaging allow the DefaultMessageListenerContainer.runningAllowed flag to quick stop in case JmsConfiguration#isAcceptMessagesWhileStopping is enabled, and org.apache.camel.CamelContext is currently being stopped. This quick stop ability is enabled by default in the regular JMS consumers but to enable for reply managers you must enable this flag."},"consumerType":{"kind":"parameter","displayName":"Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type to use, which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"defaultTaskExecutorType":{"kind":"parameter","displayName":"Default Task Executor Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.DefaultTaskExecutorType","enum":["ThreadPool","SimpleAsync"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies what default TaskExecutor type to use in the DefaultMessageListenerContainer, for both consumer endpoints and the ReplyTo consumer of producer endpoints. Possible values: SimpleAsync (uses Spring's SimpleAsyncTaskExecutor) or ThreadPool (uses Spring's ThreadPoolTaskExecutor with optimal values - cached threadpool-like). If not set, it defaults to the previous behaviour, which uses a cached thread pool for consumer endpoints and SimpleAsync for reply consumers. The use of ThreadPool is recommended to reduce thread trash in elastic configurations with dynamically increasing and decreasing concurrent consumers."},"destinationOptions":{"kind":"parameter","displayName":"Destination Options","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"java.util.Map","prefix":"destination.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"Destination Options are a way to provide extended configuration options to a JMS consumer without having to extend the JMS API. The options are encoded using URL query syntax in the destination name that the consumer is created on. See more details at https://activemq.apache.org/destination-options."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"exposeListenerSession":{"kind":"parameter","displayName":"Expose Listener Session","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the listener session should be exposed when consuming messages."},"replyToConsumerType":{"kind":"parameter","displayName":"Reply To Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type of the reply consumer (when doing request/reply), which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"taskExecutor":{"kind":"parameter","displayName":"Task Executor","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.springframework.core.task.TaskExecutor","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to specify a custom task executor for consuming messages."},"deliveryDelay":{"kind":"parameter","displayName":"Delivery Delay","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets delivery delay to use for send calls for JMS. This option requires JMS 2.0 compliant broker."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the delivery mode to be used. Possible values are those defined by javax.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether persistent delivery is used by default."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"formatDateHeadersToIso8601":{"kind":"parameter","displayName":"Format Date Headers To Iso8601","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether JMS date properties should be formatted according to the ISO 8601 standard."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when using request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOnTimeoutMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To On Timeout Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers for continue routing when timeout occurred when using request/reply over JMS."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ReplyToType","enum":["Temporary","Shared","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary, Shared, or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Shared is used by default. This option allows you to use exclusive queues instead of shared ones. See Camel JMS documentation for more details, and especially the notes about the implications if running in a clustered environment, and the fact that Shared reply queues has lower performance than its alternatives Temporary and Exclusive."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowAdditionalHeaders":{"kind":"parameter","displayName":"Allow Additional Headers","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"This option is used to allow additional headers which may have values that are invalid according to JMS specification. For example some message systems such as WMQ do this with header names using prefix JMS_IBM_MQMD_ containing values with byte array or other invalid types. You can specify multiple header names separated by comma, and use as suffix for wildcard matching."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"alwaysCopyMessage":{"kind":"parameter","displayName":"Always Copy Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will always make a JMS message copy of the message when it is passed to the producer for sending. Copying the message is needed in some situations, such as when a replyToDestinationSelectorName is set (incidentally, Camel will set the alwaysCopyMessage option to true, if a replyToDestinationSelectorName is set)"},"correlationProperty":{"kind":"parameter","displayName":"Correlation Property","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using InOut exchange pattern use this JMS property instead of JMSCorrelationID JMS property to correlate messages. If set messages will be correlated solely on the value of this property JMSCorrelationID property will be ignored and not set by Camel."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"forceSendOriginalMessage":{"kind":"parameter","displayName":"Force Send Original Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using mapJmsMessage=false Camel will create a new JMS message to send to a new JMS destination if you touch the headers (get or set) during the route. Set this option to true to force Camel to send the original JMS message that was received."},"includeSentJMSMessageID":{"kind":"parameter","displayName":"Include Sent JMSMessage ID","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Only applicable when sending to JMS destination using InOnly (eg fire and forget). Enabling this option will enrich the Camel Exchange with the actual JMSMessageID that was used by the JMS client when the message was sent to the JMS destination."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"replyToCacheLevelName":{"kind":"parameter","displayName":"Reply To Cache Level Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the reply consumer when doing request/reply over JMS. This option only applies when using fixed reply queues (not temporary). Camel will by default use: CACHE_CONSUMER for exclusive or shared w/ replyToSelectorName. And CACHE_SESSION for shared without replyToSelectorName. Some JMS brokers such as IBM WebSphere may require to set the replyToCacheLevelName=CACHE_NONE to work. Note: If using temporary queues then CACHE_NONE is not allowed, and you must use a higher value such as CACHE_CONSUMER or CACHE_SESSION."},"replyToDestinationSelectorName":{"kind":"parameter","displayName":"Reply To Destination Selector Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS Selector using the fixed name to be used so you can filter out your own replies from the others when using a shared queue (that is, if you are not using a temporary reply queue)."},"streamMessageTypeEnabled":{"kind":"parameter","displayName":"Stream Message Type Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether StreamMessage type is enabled or not. Message payloads of streaming kind such as files, InputStream, etc will either by sent as BytesMessage or StreamMessage. This option controls which kind will be used. By default BytesMessage is used which enforces the entire message payload to be read into memory. By enabling this option the message payload is read into memory in chunks and each chunk is then written to the StreamMessage until no more data."},"allowSerializedHeaders":{"kind":"parameter","displayName":"Allow Serialized Headers","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Controls whether or not to include serialized headers. Applies only when transferExchange is true. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level."},"artemisStreamingEnabled":{"kind":"parameter","displayName":"Artemis Streaming Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether optimizing for Apache Artemis streaming mode. This can reduce memory overhead when using Artemis with JMS StreamMessage types. This option must only be enabled if Apache Artemis is being used."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to startup the JmsConsumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to stop the JmsConsumer message listener asynchronously, when stopping a route."},"destinationResolver":{"kind":"parameter","displayName":"Destination Resolver","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.destination.DestinationResolver","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"A pluggable org.springframework.jms.support.destination.DestinationResolver that allows you to use your own resolver (for example, to lookup the real destination in a JNDI registry)."},"errorHandler":{"kind":"parameter","displayName":"Error Handler","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.util.ErrorHandler","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies a org.springframework.util.ErrorHandler to be invoked in case of any uncaught exceptions thrown while processing a Message. By default these exceptions will be logged at the WARN level, if no errorHandler has been configured. You can configure logging level and whether stack traces should be logged using errorHandlerLoggingLevel and errorHandlerLogStackTrace options. This makes it much easier to configure, than having to code a custom errorHandler."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"javax.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"idleConsumerLimit":{"kind":"parameter","displayName":"Idle Consumer Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specify the limit for the number of consumers that are allowed to be idle at any given time."},"idleTaskExecutionLimit":{"kind":"parameter","displayName":"Idle Task Execution Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the limit for idle executions of a receive task, not having received any message within its execution. If this limit is reached, the task will shut down and leave receiving to other executing tasks (in the case of dynamic scheduling; see the maxConcurrentConsumers setting). There is additional doc available from Spring."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsKeyFormatStrategy","enum":["default","passthrough"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as javax.jms.TextMessage to a String etc."},"maxMessagesPerTask":{"kind":"parameter","displayName":"Max Messages Per Task","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The number of messages per task. -1 is unlimited. If you use a range for concurrent consumers (eg min max), then this option can be used to set a value to eg 100 to control how fast the consumers will shrink when less work is required."},"messageConverter":{"kind":"parameter","displayName":"Message Converter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.converter.MessageConverter","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use a custom Spring org.springframework.jms.support.converter.MessageConverter so you can be in control how to map to/from a javax.jms.Message."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of javax.jms.Message objects when Camel is sending a JMS message."},"messageIdEnabled":{"kind":"parameter","displayName":"Message Id Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending, specifies whether message IDs should be added. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the message ID set to null; if the provider ignores the hint, the message ID must be set to its normal unique value."},"messageListenerContainerFactory":{"kind":"parameter","displayName":"Message Listener Container Factory","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageListenerContainerFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Registry ID of the MessageListenerContainerFactory used to determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use to consume messages. Setting this will automatically set consumerType to Custom."},"messageTimestampEnabled":{"kind":"parameter","displayName":"Message Timestamp Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether timestamps should be enabled by default on sending messages. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the timestamp set to zero; if the provider ignores the hint the timestamp must be set to its normal value."},"pubSubNoLocal":{"kind":"parameter","displayName":"Pub Sub No Local","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to inhibit the delivery of messages published by its own connection."},"receiveTimeout":{"kind":"parameter","displayName":"Receive Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for receiving messages (in milliseconds)."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"requestTimeoutCheckerInterval":{"kind":"parameter","displayName":"Request Timeout Checker Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Configures how often Camel should check for timed out Exchanges when doing request/reply over JMS. By default Camel checks once per second. But if you must react faster when a timeout occurs, then you can lower this interval, to check more frequently. The timeout is determined by the option requestTimeout."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a javax.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transferExchange":{"kind":"parameter","displayName":"Transfer Exchange","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"You can transfer the exchange over the wire instead of just the body and headers. The following fields are transferred: In body, Out body, Fault body, In headers, Out headers, Fault headers, exchange properties, exchange exception. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level. You must enable this option on both the producer and consumer side, so Camel knows the payloads is an Exchange and not a regular payload. Use this with caution as the data is using Java Object serialization and requires the receiver to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumers having to use compatible Camel versions!"},"useMessageIDAsCorrelationID":{"kind":"parameter","displayName":"Use Message IDAs Correlation ID","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether JMSMessageID should always be used as JMSCorrelationID for InOut messages."},"waitForProvisionCorrelationToBeUpdatedCounter":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Counter","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":50,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Number of times to wait for provisional correlation id to be updated to the actual correlation id when doing request/reply over JMS and when the option useMessageIDAsCorrelationID is enabled."},"waitForProvisionCorrelationToBeUpdatedThreadSleepingTime":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Thread Sleeping Time","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"100","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Interval in millis to sleep each time while waiting for provisional correlation id to be updated."},"errorHandlerLoggingLevel":{"kind":"parameter","displayName":"Error Handler Logging Level","group":"logging","label":"consumer,logging","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to configure the default errorHandler logging level for logging uncaught exceptions."},"errorHandlerLogStackTrace":{"kind":"parameter","displayName":"Error Handler Log Stack Trace","group":"logging","label":"consumer,logging","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to control whether stacktraces should be logged or not, by the default errorHandler."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Password to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Username to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use transacted mode"},"transactedInOut":{"kind":"parameter","displayName":"Transacted In Out","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether InOut operations (request reply) default to using transacted mode If this flag is set to true, then Spring JmsTemplate will have sessionTransacted set to true, and the acknowledgeMode as transacted on the JmsTemplate used for InOut operations. Note from Spring JMS: that within a JTA transaction, the parameters passed to createQueue, createTopic methods are not taken into account. Depending on the Java EE transaction context, the container makes its own decisions on these values. Analogously, these parameters are not taken into account within a locally managed transaction either, since Spring JMS operates on an existing JMS Session in this case. Setting this flag to true will use a short local JMS transaction when running outside of a managed transaction, and a synchronized local JMS transaction in case of a managed transaction (other than an XA transaction) being present. This has the effect of a local JMS transaction being managed alongside the main transaction (which might be a native JDBC transaction), with the JMS transaction committing right after the main transaction."},"lazyCreateTransactionManager":{"kind":"parameter","displayName":"Lazy Create Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will create a JmsTransactionManager, if there is no transactionManager injected when option transacted=true."},"transactionManager":{"kind":"parameter","displayName":"Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"object","javaType":"org.springframework.transaction.PlatformTransactionManager","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The Spring transaction manager to use."},"transactionName":{"kind":"parameter","displayName":"Transaction Name","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The name of the transaction to use."},"transactionTimeout":{"kind":"parameter","displayName":"Transaction Timeout","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout value of the transaction (in seconds), if using transacted mode."}}} +{"component":{"kind":"component","name":"activemq","title":"ActiveMQ","description":"Send messages to (or consume from) Apache ActiveMQ. This component extends the Camel JMS component.","deprecated":false,"firstVersion":"1.0.0","label":"messaging","javaType":"org.apache.camel.component.activemq.ActiveMQComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-activemq","version":"3.20.3","scheme":"activemq","extendsScheme":"jms","syntax":"activemq:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJmsDestination":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION"},"CamelJmsDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the queue or topic to use as destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION_NAME"},"JMSXGroupID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS group ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_X_GROUP_ID"},"JMSMessageID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS unique message ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_MESSAGE_ID"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID"},"JMSCorrelationIDAsBytes":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID as bytes.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID_AS_BYTES"},"JMSDeliveryMode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS delivery mode.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DELIVERY_MODE"},"JMSDestination":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DESTINATION"},"JMSExpiration":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS expiration.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_EXPIRATION"},"JMSPriority":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS priority (with 0 as the lowest priority and 9 as the highest).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_PRIORITY"},"JMSRedelivered":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Is the JMS message redelivered.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REDELIVERED"},"JMSTimestamp":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS timestamp.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TIMESTAMP"},"JMSReplyTo":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS reply-to destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REPLY_TO"},"JMSType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TYPE"},"JMSXUserID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The XUser id.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_XUSER_ID"},"CamelJmsMessageType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text","Blob"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The message type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_MESSAGE_TYPE"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"20_000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_REQUEST_TIMEOUT"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic","temp-queue","temp-topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of the queue or topic to use as destination"},"clientId":{"kind":"parameter","displayName":"Client Id","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"","required":false,"type":"object","javaType":"jakarta.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"jmsMessageType":{"kind":"parameter","displayName":"Jms Message Type","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to force the use of a specific jakarta.jms.Message implementation for sending JMS messages. Possible values are: Bytes, Map, Object, Stream, Text. By default, Camel would determine which JMS message type to use from the In body type. This option allows you to specify it."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"acknowledgementModeName":{"kind":"parameter","displayName":"Acknowledgement Mode Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"artemisConsumerPriority":{"kind":"parameter","displayName":"Artemis Consumer Priority","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Consumer priorities allow you to ensure that high priority consumers receive messages while they are active. Normally, active consumers connected to a queue receive messages from it in a round-robin fashion. When consumer priorities are in use, messages are delivered round-robin if multiple active consumers exist with the same high priority. Messages will only going to lower priority consumers when the high priority consumers do not have credit available to consume the message, or those high priority consumers have declined to accept the message (for instance because it does not meet the criteria of any selectors associated with the consumer)."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer container should auto-startup."},"cacheLevel":{"kind":"parameter","displayName":"Cache Level","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by ID for the underlying JMS resources. See cacheLevelName option for more details."},"cacheLevelName":{"kind":"parameter","displayName":"Cache Level Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"CACHE_AUTO","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the underlying JMS resources. Possible values are: CACHE_AUTO, CACHE_CONNECTION, CACHE_CONSUMER, CACHE_NONE, and CACHE_SESSION. The default setting is CACHE_AUTO. See the Spring documentation and Transactions Cache Levels for more information."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"maxConcurrentConsumers":{"kind":"parameter","displayName":"Max Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToMaxConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use persistent delivery by default for replies."},"selector":{"kind":"parameter","displayName":"Selector","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS selector to use"},"subscriptionDurable":{"kind":"parameter","displayName":"Subscription Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription durable. The durable subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a durable subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well."},"subscriptionName":{"kind":"parameter","displayName":"Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set the name of a subscription to create. To be applied in case of a topic (pub-sub domain) with a shared or durable subscription. The subscription name needs to be unique within this client's JMS client id. Default is the class name of the specified message listener. Note: Only 1 concurrent consumer (which is the default of this message listener container) is allowed for each subscription, except for a shared subscription (which requires JMS 2.0)."},"subscriptionShared":{"kind":"parameter","displayName":"Subscription Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription shared. The shared subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a shared subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Note that shared subscriptions may also be durable, so this flag can (and often will) be combined with subscriptionDurable as well. Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well. Requires a JMS 2.0 compatible message broker."},"acceptMessagesWhileStopping":{"kind":"parameter","displayName":"Accept Messages While Stopping","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer accept messages while it is stopping. You may consider enabling this option, if you start and stop JMS routes at runtime, while there are still messages enqueued on the queue. If this option is false, and you stop the JMS route, then messages may be rejected, and the JMS broker would have to attempt redeliveries, which yet again may be rejected, and eventually the message may be moved at a dead letter queue on the JMS broker. To avoid this its recommended to enable this option."},"allowReplyManagerQuickStop":{"kind":"parameter","displayName":"Allow Reply Manager Quick Stop","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the DefaultMessageListenerContainer used in the reply managers for request-reply messaging allow the DefaultMessageListenerContainer.runningAllowed flag to quick stop in case JmsConfiguration#isAcceptMessagesWhileStopping is enabled, and org.apache.camel.CamelContext is currently being stopped. This quick stop ability is enabled by default in the regular JMS consumers but to enable for reply managers you must enable this flag."},"consumerType":{"kind":"parameter","displayName":"Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type to use, which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"defaultTaskExecutorType":{"kind":"parameter","displayName":"Default Task Executor Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.DefaultTaskExecutorType","enum":["ThreadPool","SimpleAsync"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies what default TaskExecutor type to use in the DefaultMessageListenerContainer, for both consumer endpoints and the ReplyTo consumer of producer endpoints. Possible values: SimpleAsync (uses Spring's SimpleAsyncTaskExecutor) or ThreadPool (uses Spring's ThreadPoolTaskExecutor with optimal values - cached threadpool-like). If not set, it defaults to the previous behaviour, which uses a cached thread pool for consumer endpoints and SimpleAsync for reply consumers. The use of ThreadPool is recommended to reduce thread trash in elastic configurations with dynamically increasing and decreasing concurrent consumers."},"destinationOptions":{"kind":"parameter","displayName":"Destination Options","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"java.util.Map","prefix":"destination.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"Destination Options are a way to provide extended configuration options to a JMS consumer without having to extend the JMS API. The options are encoded using URL query syntax in the destination name that the consumer is created on. See more details at https://activemq.apache.org/destination-options."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"exposeListenerSession":{"kind":"parameter","displayName":"Expose Listener Session","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the listener session should be exposed when consuming messages."},"replyToConsumerType":{"kind":"parameter","displayName":"Reply To Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type of the reply consumer (when doing request/reply), which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"taskExecutor":{"kind":"parameter","displayName":"Task Executor","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.springframework.core.task.TaskExecutor","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to specify a custom task executor for consuming messages."},"deliveryDelay":{"kind":"parameter","displayName":"Delivery Delay","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets delivery delay to use for send calls for JMS. This option requires JMS 2.0 compliant broker."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the delivery mode to be used. Possible values are those defined by jakarta.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether persistent delivery is used by default."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"formatDateHeadersToIso8601":{"kind":"parameter","displayName":"Format Date Headers To Iso8601","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether JMS date properties should be formatted according to the ISO 8601 standard."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when using request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOnTimeoutMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To On Timeout Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers for continue routing when timeout occurred when using request/reply over JMS."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ReplyToType","enum":["Temporary","Shared","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary, Shared, or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Shared is used by default. This option allows you to use exclusive queues instead of shared ones. See Camel JMS documentation for more details, and especially the notes about the implications if running in a clustered environment, and the fact that Shared reply queues has lower performance than its alternatives Temporary and Exclusive."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowAdditionalHeaders":{"kind":"parameter","displayName":"Allow Additional Headers","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"This option is used to allow additional headers which may have values that are invalid according to JMS specification. For example some message systems such as WMQ do this with header names using prefix JMS_IBM_MQMD_ containing values with byte array or other invalid types. You can specify multiple header names separated by comma, and use as suffix for wildcard matching."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"alwaysCopyMessage":{"kind":"parameter","displayName":"Always Copy Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will always make a JMS message copy of the message when it is passed to the producer for sending. Copying the message is needed in some situations, such as when a replyToDestinationSelectorName is set (incidentally, Camel will set the alwaysCopyMessage option to true, if a replyToDestinationSelectorName is set)"},"correlationProperty":{"kind":"parameter","displayName":"Correlation Property","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using InOut exchange pattern use this JMS property instead of JMSCorrelationID JMS property to correlate messages. If set messages will be correlated solely on the value of this property JMSCorrelationID property will be ignored and not set by Camel."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"forceSendOriginalMessage":{"kind":"parameter","displayName":"Force Send Original Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using mapJmsMessage=false Camel will create a new JMS message to send to a new JMS destination if you touch the headers (get or set) during the route. Set this option to true to force Camel to send the original JMS message that was received."},"includeSentJMSMessageID":{"kind":"parameter","displayName":"Include Sent JMSMessage ID","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Only applicable when sending to JMS destination using InOnly (eg fire and forget). Enabling this option will enrich the Camel Exchange with the actual JMSMessageID that was used by the JMS client when the message was sent to the JMS destination."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"replyToCacheLevelName":{"kind":"parameter","displayName":"Reply To Cache Level Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the reply consumer when doing request/reply over JMS. This option only applies when using fixed reply queues (not temporary). Camel will by default use: CACHE_CONSUMER for exclusive or shared w/ replyToSelectorName. And CACHE_SESSION for shared without replyToSelectorName. Some JMS brokers such as IBM WebSphere may require to set the replyToCacheLevelName=CACHE_NONE to work. Note: If using temporary queues then CACHE_NONE is not allowed, and you must use a higher value such as CACHE_CONSUMER or CACHE_SESSION."},"replyToDestinationSelectorName":{"kind":"parameter","displayName":"Reply To Destination Selector Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS Selector using the fixed name to be used so you can filter out your own replies from the others when using a shared queue (that is, if you are not using a temporary reply queue)."},"streamMessageTypeEnabled":{"kind":"parameter","displayName":"Stream Message Type Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether StreamMessage type is enabled or not. Message payloads of streaming kind such as files, InputStream, etc will either by sent as BytesMessage or StreamMessage. This option controls which kind will be used. By default BytesMessage is used which enforces the entire message payload to be read into memory. By enabling this option the message payload is read into memory in chunks and each chunk is then written to the StreamMessage until no more data."},"allowSerializedHeaders":{"kind":"parameter","displayName":"Allow Serialized Headers","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Controls whether or not to include serialized headers. Applies only when transferExchange is true. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level."},"artemisStreamingEnabled":{"kind":"parameter","displayName":"Artemis Streaming Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether optimizing for Apache Artemis streaming mode. This can reduce memory overhead when using Artemis with JMS StreamMessage types. This option must only be enabled if Apache Artemis is being used."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to startup the JmsConsumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to stop the JmsConsumer message listener asynchronously, when stopping a route."},"destinationResolver":{"kind":"parameter","displayName":"Destination Resolver","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.destination.DestinationResolver","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"A pluggable org.springframework.jms.support.destination.DestinationResolver that allows you to use your own resolver (for example, to lookup the real destination in a JNDI registry)."},"errorHandler":{"kind":"parameter","displayName":"Error Handler","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.util.ErrorHandler","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies a org.springframework.util.ErrorHandler to be invoked in case of any uncaught exceptions thrown while processing a Message. By default these exceptions will be logged at the WARN level, if no errorHandler has been configured. You can configure logging level and whether stack traces should be logged using errorHandlerLoggingLevel and errorHandlerLogStackTrace options. This makes it much easier to configure, than having to code a custom errorHandler."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"jakarta.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"idleConsumerLimit":{"kind":"parameter","displayName":"Idle Consumer Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specify the limit for the number of consumers that are allowed to be idle at any given time."},"idleTaskExecutionLimit":{"kind":"parameter","displayName":"Idle Task Execution Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the limit for idle executions of a receive task, not having received any message within its execution. If this limit is reached, the task will shut down and leave receiving to other executing tasks (in the case of dynamic scheduling; see the maxConcurrentConsumers setting). There is additional doc available from Spring."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsKeyFormatStrategy","enum":["default","passthrough"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as jakarta.jms.TextMessage to a String etc."},"maxMessagesPerTask":{"kind":"parameter","displayName":"Max Messages Per Task","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The number of messages per task. -1 is unlimited. If you use a range for concurrent consumers (eg min max), then this option can be used to set a value to eg 100 to control how fast the consumers will shrink when less work is required."},"messageConverter":{"kind":"parameter","displayName":"Message Converter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.converter.MessageConverter","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use a custom Spring org.springframework.jms.support.converter.MessageConverter so you can be in control how to map to/from a jakarta.jms.Message."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of jakarta.jms.Message objects when Camel is sending a JMS message."},"messageIdEnabled":{"kind":"parameter","displayName":"Message Id Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending, specifies whether message IDs should be added. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the message ID set to null; if the provider ignores the hint, the message ID must be set to its normal unique value."},"messageListenerContainerFactory":{"kind":"parameter","displayName":"Message Listener Container Factory","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageListenerContainerFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Registry ID of the MessageListenerContainerFactory used to determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use to consume messages. Setting this will automatically set consumerType to Custom."},"messageTimestampEnabled":{"kind":"parameter","displayName":"Message Timestamp Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether timestamps should be enabled by default on sending messages. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the timestamp set to zero; if the provider ignores the hint the timestamp must be set to its normal value."},"pubSubNoLocal":{"kind":"parameter","displayName":"Pub Sub No Local","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to inhibit the delivery of messages published by its own connection."},"receiveTimeout":{"kind":"parameter","displayName":"Receive Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for receiving messages (in milliseconds)."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"requestTimeoutCheckerInterval":{"kind":"parameter","displayName":"Request Timeout Checker Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Configures how often Camel should check for timed out Exchanges when doing request/reply over JMS. By default Camel checks once per second. But if you must react faster when a timeout occurs, then you can lower this interval, to check more frequently. The timeout is determined by the option requestTimeout."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a jakarta.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transferExchange":{"kind":"parameter","displayName":"Transfer Exchange","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"You can transfer the exchange over the wire instead of just the body and headers. The following fields are transferred: In body, Out body, Fault body, In headers, Out headers, Fault headers, exchange properties, exchange exception. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level. You must enable this option on both the producer and consumer side, so Camel knows the payloads is an Exchange and not a regular payload. Use this with caution as the data is using Java Object serialization and requires the receiver to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumers having to use compatible Camel versions!"},"useMessageIDAsCorrelationID":{"kind":"parameter","displayName":"Use Message IDAs Correlation ID","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether JMSMessageID should always be used as JMSCorrelationID for InOut messages."},"waitForProvisionCorrelationToBeUpdatedCounter":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Counter","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":50,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Number of times to wait for provisional correlation id to be updated to the actual correlation id when doing request/reply over JMS and when the option useMessageIDAsCorrelationID is enabled."},"waitForProvisionCorrelationToBeUpdatedThreadSleepingTime":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Thread Sleeping Time","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"100","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Interval in millis to sleep each time while waiting for provisional correlation id to be updated."},"errorHandlerLoggingLevel":{"kind":"parameter","displayName":"Error Handler Logging Level","group":"logging","label":"consumer,logging","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to configure the default errorHandler logging level for logging uncaught exceptions."},"errorHandlerLogStackTrace":{"kind":"parameter","displayName":"Error Handler Log Stack Trace","group":"logging","label":"consumer,logging","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to control whether stacktraces should be logged or not, by the default errorHandler."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Password to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Username to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use transacted mode"},"transactedInOut":{"kind":"parameter","displayName":"Transacted In Out","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether InOut operations (request reply) default to using transacted mode If this flag is set to true, then Spring JmsTemplate will have sessionTransacted set to true, and the acknowledgeMode as transacted on the JmsTemplate used for InOut operations. Note from Spring JMS: that within a JTA transaction, the parameters passed to createQueue, createTopic methods are not taken into account. Depending on the Java EE transaction context, the container makes its own decisions on these values. Analogously, these parameters are not taken into account within a locally managed transaction either, since Spring JMS operates on an existing JMS Session in this case. Setting this flag to true will use a short local JMS transaction when running outside of a managed transaction, and a synchronized local JMS transaction in case of a managed transaction (other than an XA transaction) being present. This has the effect of a local JMS transaction being managed alongside the main transaction (which might be a native JDBC transaction), with the JMS transaction committing right after the main transaction."},"lazyCreateTransactionManager":{"kind":"parameter","displayName":"Lazy Create Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will create a JmsTransactionManager, if there is no transactionManager injected when option transacted=true."},"transactionManager":{"kind":"parameter","displayName":"Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"object","javaType":"org.springframework.transaction.PlatformTransactionManager","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The Spring transaction manager to use."},"transactionName":{"kind":"parameter","displayName":"Transaction Name","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The name of the transaction to use."},"transactionTimeout":{"kind":"parameter","displayName":"Transaction Timeout","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout value of the transaction (in seconds), if using transacted mode."}}} , -{"component":{"kind":"component","name":"amqp","title":"AMQP","description":"Messaging with AMQP protocol using Apache QPid Client.","deprecated":false,"firstVersion":"1.2.0","label":"messaging","javaType":"org.apache.camel.component.amqp.AMQPComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-amqp","version":"3.20.3","scheme":"amqp","extendsScheme":"jms","syntax":"amqp:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJmsDestination":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION"},"CamelJmsDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the queue or topic to use as destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION_NAME"},"JMSXGroupID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS group ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_X_GROUP_ID"},"JMSMessageID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS unique message ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_MESSAGE_ID"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID"},"JMSCorrelationIDAsBytes":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID as bytes.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID_AS_BYTES"},"JMSDeliveryMode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS delivery mode.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DELIVERY_MODE"},"JMSDestination":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DESTINATION"},"JMSExpiration":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS expiration.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_EXPIRATION"},"JMSPriority":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS priority (with 0 as the lowest priority and 9 as the highest).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_PRIORITY"},"JMSRedelivered":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Is the JMS message redelivered.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REDELIVERED"},"JMSTimestamp":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS timestamp.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TIMESTAMP"},"JMSReplyTo":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS reply-to destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REPLY_TO"},"JMSType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TYPE"},"JMSXUserID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The XUser id.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_XUSER_ID"},"CamelJmsMessageType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text","Blob"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The message type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_MESSAGE_TYPE"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"20_000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_REQUEST_TIMEOUT"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic","temp-queue","temp-topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of the queue or topic to use as destination"},"clientId":{"kind":"parameter","displayName":"Client Id","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"","required":false,"type":"object","javaType":"javax.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"jmsMessageType":{"kind":"parameter","displayName":"Jms Message Type","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to force the use of a specific javax.jms.Message implementation for sending JMS messages. Possible values are: Bytes, Map, Object, Stream, Text. By default, Camel would determine which JMS message type to use from the In body type. This option allows you to specify it."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"acknowledgementModeName":{"kind":"parameter","displayName":"Acknowledgement Mode Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"artemisConsumerPriority":{"kind":"parameter","displayName":"Artemis Consumer Priority","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Consumer priorities allow you to ensure that high priority consumers receive messages while they are active. Normally, active consumers connected to a queue receive messages from it in a round-robin fashion. When consumer priorities are in use, messages are delivered round-robin if multiple active consumers exist with the same high priority. Messages will only going to lower priority consumers when the high priority consumers do not have credit available to consume the message, or those high priority consumers have declined to accept the message (for instance because it does not meet the criteria of any selectors associated with the consumer)."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer container should auto-startup."},"cacheLevel":{"kind":"parameter","displayName":"Cache Level","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by ID for the underlying JMS resources. See cacheLevelName option for more details."},"cacheLevelName":{"kind":"parameter","displayName":"Cache Level Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"CACHE_AUTO","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the underlying JMS resources. Possible values are: CACHE_AUTO, CACHE_CONNECTION, CACHE_CONSUMER, CACHE_NONE, and CACHE_SESSION. The default setting is CACHE_AUTO. See the Spring documentation and Transactions Cache Levels for more information."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"maxConcurrentConsumers":{"kind":"parameter","displayName":"Max Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToMaxConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use persistent delivery by default for replies."},"selector":{"kind":"parameter","displayName":"Selector","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS selector to use"},"subscriptionDurable":{"kind":"parameter","displayName":"Subscription Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription durable. The durable subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a durable subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well."},"subscriptionName":{"kind":"parameter","displayName":"Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set the name of a subscription to create. To be applied in case of a topic (pub-sub domain) with a shared or durable subscription. The subscription name needs to be unique within this client's JMS client id. Default is the class name of the specified message listener. Note: Only 1 concurrent consumer (which is the default of this message listener container) is allowed for each subscription, except for a shared subscription (which requires JMS 2.0)."},"subscriptionShared":{"kind":"parameter","displayName":"Subscription Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription shared. The shared subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a shared subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Note that shared subscriptions may also be durable, so this flag can (and often will) be combined with subscriptionDurable as well. Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well. Requires a JMS 2.0 compatible message broker."},"acceptMessagesWhileStopping":{"kind":"parameter","displayName":"Accept Messages While Stopping","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer accept messages while it is stopping. You may consider enabling this option, if you start and stop JMS routes at runtime, while there are still messages enqueued on the queue. If this option is false, and you stop the JMS route, then messages may be rejected, and the JMS broker would have to attempt redeliveries, which yet again may be rejected, and eventually the message may be moved at a dead letter queue on the JMS broker. To avoid this its recommended to enable this option."},"allowReplyManagerQuickStop":{"kind":"parameter","displayName":"Allow Reply Manager Quick Stop","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the DefaultMessageListenerContainer used in the reply managers for request-reply messaging allow the DefaultMessageListenerContainer.runningAllowed flag to quick stop in case JmsConfiguration#isAcceptMessagesWhileStopping is enabled, and org.apache.camel.CamelContext is currently being stopped. This quick stop ability is enabled by default in the regular JMS consumers but to enable for reply managers you must enable this flag."},"consumerType":{"kind":"parameter","displayName":"Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type to use, which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"defaultTaskExecutorType":{"kind":"parameter","displayName":"Default Task Executor Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.DefaultTaskExecutorType","enum":["ThreadPool","SimpleAsync"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies what default TaskExecutor type to use in the DefaultMessageListenerContainer, for both consumer endpoints and the ReplyTo consumer of producer endpoints. Possible values: SimpleAsync (uses Spring's SimpleAsyncTaskExecutor) or ThreadPool (uses Spring's ThreadPoolTaskExecutor with optimal values - cached threadpool-like). If not set, it defaults to the previous behaviour, which uses a cached thread pool for consumer endpoints and SimpleAsync for reply consumers. The use of ThreadPool is recommended to reduce thread trash in elastic configurations with dynamically increasing and decreasing concurrent consumers."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"exposeListenerSession":{"kind":"parameter","displayName":"Expose Listener Session","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the listener session should be exposed when consuming messages."},"replyToConsumerType":{"kind":"parameter","displayName":"Reply To Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type of the reply consumer (when doing request/reply), which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"taskExecutor":{"kind":"parameter","displayName":"Task Executor","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.springframework.core.task.TaskExecutor","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to specify a custom task executor for consuming messages."},"deliveryDelay":{"kind":"parameter","displayName":"Delivery Delay","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets delivery delay to use for send calls for JMS. This option requires JMS 2.0 compliant broker."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the delivery mode to be used. Possible values are those defined by javax.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether persistent delivery is used by default."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"formatDateHeadersToIso8601":{"kind":"parameter","displayName":"Format Date Headers To Iso8601","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether JMS date properties should be formatted according to the ISO 8601 standard."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when using request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOnTimeoutMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To On Timeout Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers for continue routing when timeout occurred when using request/reply over JMS."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ReplyToType","enum":["Temporary","Shared","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary, Shared, or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Shared is used by default. This option allows you to use exclusive queues instead of shared ones. See Camel JMS documentation for more details, and especially the notes about the implications if running in a clustered environment, and the fact that Shared reply queues has lower performance than its alternatives Temporary and Exclusive."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowAdditionalHeaders":{"kind":"parameter","displayName":"Allow Additional Headers","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"This option is used to allow additional headers which may have values that are invalid according to JMS specification. For example some message systems such as WMQ do this with header names using prefix JMS_IBM_MQMD_ containing values with byte array or other invalid types. You can specify multiple header names separated by comma, and use as suffix for wildcard matching."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"alwaysCopyMessage":{"kind":"parameter","displayName":"Always Copy Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will always make a JMS message copy of the message when it is passed to the producer for sending. Copying the message is needed in some situations, such as when a replyToDestinationSelectorName is set (incidentally, Camel will set the alwaysCopyMessage option to true, if a replyToDestinationSelectorName is set)"},"correlationProperty":{"kind":"parameter","displayName":"Correlation Property","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using InOut exchange pattern use this JMS property instead of JMSCorrelationID JMS property to correlate messages. If set messages will be correlated solely on the value of this property JMSCorrelationID property will be ignored and not set by Camel."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"forceSendOriginalMessage":{"kind":"parameter","displayName":"Force Send Original Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using mapJmsMessage=false Camel will create a new JMS message to send to a new JMS destination if you touch the headers (get or set) during the route. Set this option to true to force Camel to send the original JMS message that was received."},"includeSentJMSMessageID":{"kind":"parameter","displayName":"Include Sent JMSMessage ID","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Only applicable when sending to JMS destination using InOnly (eg fire and forget). Enabling this option will enrich the Camel Exchange with the actual JMSMessageID that was used by the JMS client when the message was sent to the JMS destination."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"replyToCacheLevelName":{"kind":"parameter","displayName":"Reply To Cache Level Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the reply consumer when doing request/reply over JMS. This option only applies when using fixed reply queues (not temporary). Camel will by default use: CACHE_CONSUMER for exclusive or shared w/ replyToSelectorName. And CACHE_SESSION for shared without replyToSelectorName. Some JMS brokers such as IBM WebSphere may require to set the replyToCacheLevelName=CACHE_NONE to work. Note: If using temporary queues then CACHE_NONE is not allowed, and you must use a higher value such as CACHE_CONSUMER or CACHE_SESSION."},"replyToDestinationSelectorName":{"kind":"parameter","displayName":"Reply To Destination Selector Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS Selector using the fixed name to be used so you can filter out your own replies from the others when using a shared queue (that is, if you are not using a temporary reply queue)."},"streamMessageTypeEnabled":{"kind":"parameter","displayName":"Stream Message Type Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether StreamMessage type is enabled or not. Message payloads of streaming kind such as files, InputStream, etc will either by sent as BytesMessage or StreamMessage. This option controls which kind will be used. By default BytesMessage is used which enforces the entire message payload to be read into memory. By enabling this option the message payload is read into memory in chunks and each chunk is then written to the StreamMessage until no more data."},"allowSerializedHeaders":{"kind":"parameter","displayName":"Allow Serialized Headers","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Controls whether or not to include serialized headers. Applies only when transferExchange is true. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level."},"artemisStreamingEnabled":{"kind":"parameter","displayName":"Artemis Streaming Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether optimizing for Apache Artemis streaming mode. This can reduce memory overhead when using Artemis with JMS StreamMessage types. This option must only be enabled if Apache Artemis is being used."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to startup the JmsConsumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to stop the JmsConsumer message listener asynchronously, when stopping a route."},"destinationResolver":{"kind":"parameter","displayName":"Destination Resolver","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.destination.DestinationResolver","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"A pluggable org.springframework.jms.support.destination.DestinationResolver that allows you to use your own resolver (for example, to lookup the real destination in a JNDI registry)."},"errorHandler":{"kind":"parameter","displayName":"Error Handler","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.util.ErrorHandler","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies a org.springframework.util.ErrorHandler to be invoked in case of any uncaught exceptions thrown while processing a Message. By default these exceptions will be logged at the WARN level, if no errorHandler has been configured. You can configure logging level and whether stack traces should be logged using errorHandlerLoggingLevel and errorHandlerLogStackTrace options. This makes it much easier to configure, than having to code a custom errorHandler."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"javax.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"idleConsumerLimit":{"kind":"parameter","displayName":"Idle Consumer Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specify the limit for the number of consumers that are allowed to be idle at any given time."},"idleTaskExecutionLimit":{"kind":"parameter","displayName":"Idle Task Execution Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the limit for idle executions of a receive task, not having received any message within its execution. If this limit is reached, the task will shut down and leave receiving to other executing tasks (in the case of dynamic scheduling; see the maxConcurrentConsumers setting). There is additional doc available from Spring."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsKeyFormatStrategy","enum":["default","passthrough"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as javax.jms.TextMessage to a String etc."},"maxMessagesPerTask":{"kind":"parameter","displayName":"Max Messages Per Task","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The number of messages per task. -1 is unlimited. If you use a range for concurrent consumers (eg min max), then this option can be used to set a value to eg 100 to control how fast the consumers will shrink when less work is required."},"messageConverter":{"kind":"parameter","displayName":"Message Converter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.converter.MessageConverter","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use a custom Spring org.springframework.jms.support.converter.MessageConverter so you can be in control how to map to/from a javax.jms.Message."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of javax.jms.Message objects when Camel is sending a JMS message."},"messageIdEnabled":{"kind":"parameter","displayName":"Message Id Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending, specifies whether message IDs should be added. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the message ID set to null; if the provider ignores the hint, the message ID must be set to its normal unique value."},"messageListenerContainerFactory":{"kind":"parameter","displayName":"Message Listener Container Factory","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageListenerContainerFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Registry ID of the MessageListenerContainerFactory used to determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use to consume messages. Setting this will automatically set consumerType to Custom."},"messageTimestampEnabled":{"kind":"parameter","displayName":"Message Timestamp Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether timestamps should be enabled by default on sending messages. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the timestamp set to zero; if the provider ignores the hint the timestamp must be set to its normal value."},"pubSubNoLocal":{"kind":"parameter","displayName":"Pub Sub No Local","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to inhibit the delivery of messages published by its own connection."},"receiveTimeout":{"kind":"parameter","displayName":"Receive Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for receiving messages (in milliseconds)."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"requestTimeoutCheckerInterval":{"kind":"parameter","displayName":"Request Timeout Checker Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Configures how often Camel should check for timed out Exchanges when doing request/reply over JMS. By default Camel checks once per second. But if you must react faster when a timeout occurs, then you can lower this interval, to check more frequently. The timeout is determined by the option requestTimeout."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a javax.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transferExchange":{"kind":"parameter","displayName":"Transfer Exchange","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"You can transfer the exchange over the wire instead of just the body and headers. The following fields are transferred: In body, Out body, Fault body, In headers, Out headers, Fault headers, exchange properties, exchange exception. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level. You must enable this option on both the producer and consumer side, so Camel knows the payloads is an Exchange and not a regular payload. Use this with caution as the data is using Java Object serialization and requires the receiver to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumers having to use compatible Camel versions!"},"useMessageIDAsCorrelationID":{"kind":"parameter","displayName":"Use Message IDAs Correlation ID","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether JMSMessageID should always be used as JMSCorrelationID for InOut messages."},"waitForProvisionCorrelationToBeUpdatedCounter":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Counter","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":50,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Number of times to wait for provisional correlation id to be updated to the actual correlation id when doing request/reply over JMS and when the option useMessageIDAsCorrelationID is enabled."},"waitForProvisionCorrelationToBeUpdatedThreadSleepingTime":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Thread Sleeping Time","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"100","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Interval in millis to sleep each time while waiting for provisional correlation id to be updated."},"errorHandlerLoggingLevel":{"kind":"parameter","displayName":"Error Handler Logging Level","group":"logging","label":"consumer,logging","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to configure the default errorHandler logging level for logging uncaught exceptions."},"errorHandlerLogStackTrace":{"kind":"parameter","displayName":"Error Handler Log Stack Trace","group":"logging","label":"consumer,logging","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to control whether stacktraces should be logged or not, by the default errorHandler."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Password to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Username to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use transacted mode"},"transactedInOut":{"kind":"parameter","displayName":"Transacted In Out","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether InOut operations (request reply) default to using transacted mode If this flag is set to true, then Spring JmsTemplate will have sessionTransacted set to true, and the acknowledgeMode as transacted on the JmsTemplate used for InOut operations. Note from Spring JMS: that within a JTA transaction, the parameters passed to createQueue, createTopic methods are not taken into account. Depending on the Java EE transaction context, the container makes its own decisions on these values. Analogously, these parameters are not taken into account within a locally managed transaction either, since Spring JMS operates on an existing JMS Session in this case. Setting this flag to true will use a short local JMS transaction when running outside of a managed transaction, and a synchronized local JMS transaction in case of a managed transaction (other than an XA transaction) being present. This has the effect of a local JMS transaction being managed alongside the main transaction (which might be a native JDBC transaction), with the JMS transaction committing right after the main transaction."},"lazyCreateTransactionManager":{"kind":"parameter","displayName":"Lazy Create Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will create a JmsTransactionManager, if there is no transactionManager injected when option transacted=true."},"transactionManager":{"kind":"parameter","displayName":"Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"object","javaType":"org.springframework.transaction.PlatformTransactionManager","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The Spring transaction manager to use."},"transactionName":{"kind":"parameter","displayName":"Transaction Name","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The name of the transaction to use."},"transactionTimeout":{"kind":"parameter","displayName":"Transaction Timeout","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout value of the transaction (in seconds), if using transacted mode."}}} +{"component":{"kind":"component","name":"amqp","title":"AMQP","description":"Messaging with AMQP protocol using Apache QPid Client.","deprecated":false,"firstVersion":"1.2.0","label":"messaging","javaType":"org.apache.camel.component.amqp.AMQPComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-amqp","version":"3.20.3","scheme":"amqp","extendsScheme":"jms","syntax":"amqp:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJmsDestination":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION"},"CamelJmsDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the queue or topic to use as destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION_NAME"},"JMSXGroupID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS group ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_X_GROUP_ID"},"JMSMessageID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS unique message ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_MESSAGE_ID"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID"},"JMSCorrelationIDAsBytes":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID as bytes.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID_AS_BYTES"},"JMSDeliveryMode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS delivery mode.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DELIVERY_MODE"},"JMSDestination":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DESTINATION"},"JMSExpiration":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS expiration.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_EXPIRATION"},"JMSPriority":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS priority (with 0 as the lowest priority and 9 as the highest).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_PRIORITY"},"JMSRedelivered":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Is the JMS message redelivered.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REDELIVERED"},"JMSTimestamp":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS timestamp.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TIMESTAMP"},"JMSReplyTo":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS reply-to destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REPLY_TO"},"JMSType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TYPE"},"JMSXUserID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The XUser id.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_XUSER_ID"},"CamelJmsMessageType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text","Blob"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The message type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_MESSAGE_TYPE"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"20_000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_REQUEST_TIMEOUT"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic","temp-queue","temp-topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of the queue or topic to use as destination"},"clientId":{"kind":"parameter","displayName":"Client Id","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"","required":false,"type":"object","javaType":"jakarta.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"jmsMessageType":{"kind":"parameter","displayName":"Jms Message Type","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to force the use of a specific jakarta.jms.Message implementation for sending JMS messages. Possible values are: Bytes, Map, Object, Stream, Text. By default, Camel would determine which JMS message type to use from the In body type. This option allows you to specify it."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"acknowledgementModeName":{"kind":"parameter","displayName":"Acknowledgement Mode Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"artemisConsumerPriority":{"kind":"parameter","displayName":"Artemis Consumer Priority","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Consumer priorities allow you to ensure that high priority consumers receive messages while they are active. Normally, active consumers connected to a queue receive messages from it in a round-robin fashion. When consumer priorities are in use, messages are delivered round-robin if multiple active consumers exist with the same high priority. Messages will only going to lower priority consumers when the high priority consumers do not have credit available to consume the message, or those high priority consumers have declined to accept the message (for instance because it does not meet the criteria of any selectors associated with the consumer)."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer container should auto-startup."},"cacheLevel":{"kind":"parameter","displayName":"Cache Level","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by ID for the underlying JMS resources. See cacheLevelName option for more details."},"cacheLevelName":{"kind":"parameter","displayName":"Cache Level Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"CACHE_AUTO","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the underlying JMS resources. Possible values are: CACHE_AUTO, CACHE_CONNECTION, CACHE_CONSUMER, CACHE_NONE, and CACHE_SESSION. The default setting is CACHE_AUTO. See the Spring documentation and Transactions Cache Levels for more information."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"maxConcurrentConsumers":{"kind":"parameter","displayName":"Max Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToMaxConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use persistent delivery by default for replies."},"selector":{"kind":"parameter","displayName":"Selector","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS selector to use"},"subscriptionDurable":{"kind":"parameter","displayName":"Subscription Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription durable. The durable subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a durable subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well."},"subscriptionName":{"kind":"parameter","displayName":"Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set the name of a subscription to create. To be applied in case of a topic (pub-sub domain) with a shared or durable subscription. The subscription name needs to be unique within this client's JMS client id. Default is the class name of the specified message listener. Note: Only 1 concurrent consumer (which is the default of this message listener container) is allowed for each subscription, except for a shared subscription (which requires JMS 2.0)."},"subscriptionShared":{"kind":"parameter","displayName":"Subscription Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription shared. The shared subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a shared subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Note that shared subscriptions may also be durable, so this flag can (and often will) be combined with subscriptionDurable as well. Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well. Requires a JMS 2.0 compatible message broker."},"acceptMessagesWhileStopping":{"kind":"parameter","displayName":"Accept Messages While Stopping","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer accept messages while it is stopping. You may consider enabling this option, if you start and stop JMS routes at runtime, while there are still messages enqueued on the queue. If this option is false, and you stop the JMS route, then messages may be rejected, and the JMS broker would have to attempt redeliveries, which yet again may be rejected, and eventually the message may be moved at a dead letter queue on the JMS broker. To avoid this its recommended to enable this option."},"allowReplyManagerQuickStop":{"kind":"parameter","displayName":"Allow Reply Manager Quick Stop","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the DefaultMessageListenerContainer used in the reply managers for request-reply messaging allow the DefaultMessageListenerContainer.runningAllowed flag to quick stop in case JmsConfiguration#isAcceptMessagesWhileStopping is enabled, and org.apache.camel.CamelContext is currently being stopped. This quick stop ability is enabled by default in the regular JMS consumers but to enable for reply managers you must enable this flag."},"consumerType":{"kind":"parameter","displayName":"Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type to use, which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"defaultTaskExecutorType":{"kind":"parameter","displayName":"Default Task Executor Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.DefaultTaskExecutorType","enum":["ThreadPool","SimpleAsync"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies what default TaskExecutor type to use in the DefaultMessageListenerContainer, for both consumer endpoints and the ReplyTo consumer of producer endpoints. Possible values: SimpleAsync (uses Spring's SimpleAsyncTaskExecutor) or ThreadPool (uses Spring's ThreadPoolTaskExecutor with optimal values - cached threadpool-like). If not set, it defaults to the previous behaviour, which uses a cached thread pool for consumer endpoints and SimpleAsync for reply consumers. The use of ThreadPool is recommended to reduce thread trash in elastic configurations with dynamically increasing and decreasing concurrent consumers."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"exposeListenerSession":{"kind":"parameter","displayName":"Expose Listener Session","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the listener session should be exposed when consuming messages."},"replyToConsumerType":{"kind":"parameter","displayName":"Reply To Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type of the reply consumer (when doing request/reply), which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"taskExecutor":{"kind":"parameter","displayName":"Task Executor","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.springframework.core.task.TaskExecutor","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to specify a custom task executor for consuming messages."},"deliveryDelay":{"kind":"parameter","displayName":"Delivery Delay","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets delivery delay to use for send calls for JMS. This option requires JMS 2.0 compliant broker."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the delivery mode to be used. Possible values are those defined by jakarta.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether persistent delivery is used by default."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"formatDateHeadersToIso8601":{"kind":"parameter","displayName":"Format Date Headers To Iso8601","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether JMS date properties should be formatted according to the ISO 8601 standard."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when using request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOnTimeoutMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To On Timeout Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers for continue routing when timeout occurred when using request/reply over JMS."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ReplyToType","enum":["Temporary","Shared","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary, Shared, or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Shared is used by default. This option allows you to use exclusive queues instead of shared ones. See Camel JMS documentation for more details, and especially the notes about the implications if running in a clustered environment, and the fact that Shared reply queues has lower performance than its alternatives Temporary and Exclusive."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowAdditionalHeaders":{"kind":"parameter","displayName":"Allow Additional Headers","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"This option is used to allow additional headers which may have values that are invalid according to JMS specification. For example some message systems such as WMQ do this with header names using prefix JMS_IBM_MQMD_ containing values with byte array or other invalid types. You can specify multiple header names separated by comma, and use as suffix for wildcard matching."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"alwaysCopyMessage":{"kind":"parameter","displayName":"Always Copy Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will always make a JMS message copy of the message when it is passed to the producer for sending. Copying the message is needed in some situations, such as when a replyToDestinationSelectorName is set (incidentally, Camel will set the alwaysCopyMessage option to true, if a replyToDestinationSelectorName is set)"},"correlationProperty":{"kind":"parameter","displayName":"Correlation Property","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using InOut exchange pattern use this JMS property instead of JMSCorrelationID JMS property to correlate messages. If set messages will be correlated solely on the value of this property JMSCorrelationID property will be ignored and not set by Camel."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"forceSendOriginalMessage":{"kind":"parameter","displayName":"Force Send Original Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using mapJmsMessage=false Camel will create a new JMS message to send to a new JMS destination if you touch the headers (get or set) during the route. Set this option to true to force Camel to send the original JMS message that was received."},"includeSentJMSMessageID":{"kind":"parameter","displayName":"Include Sent JMSMessage ID","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Only applicable when sending to JMS destination using InOnly (eg fire and forget). Enabling this option will enrich the Camel Exchange with the actual JMSMessageID that was used by the JMS client when the message was sent to the JMS destination."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"replyToCacheLevelName":{"kind":"parameter","displayName":"Reply To Cache Level Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the reply consumer when doing request/reply over JMS. This option only applies when using fixed reply queues (not temporary). Camel will by default use: CACHE_CONSUMER for exclusive or shared w/ replyToSelectorName. And CACHE_SESSION for shared without replyToSelectorName. Some JMS brokers such as IBM WebSphere may require to set the replyToCacheLevelName=CACHE_NONE to work. Note: If using temporary queues then CACHE_NONE is not allowed, and you must use a higher value such as CACHE_CONSUMER or CACHE_SESSION."},"replyToDestinationSelectorName":{"kind":"parameter","displayName":"Reply To Destination Selector Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS Selector using the fixed name to be used so you can filter out your own replies from the others when using a shared queue (that is, if you are not using a temporary reply queue)."},"streamMessageTypeEnabled":{"kind":"parameter","displayName":"Stream Message Type Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether StreamMessage type is enabled or not. Message payloads of streaming kind such as files, InputStream, etc will either by sent as BytesMessage or StreamMessage. This option controls which kind will be used. By default BytesMessage is used which enforces the entire message payload to be read into memory. By enabling this option the message payload is read into memory in chunks and each chunk is then written to the StreamMessage until no more data."},"allowSerializedHeaders":{"kind":"parameter","displayName":"Allow Serialized Headers","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Controls whether or not to include serialized headers. Applies only when transferExchange is true. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level."},"artemisStreamingEnabled":{"kind":"parameter","displayName":"Artemis Streaming Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether optimizing for Apache Artemis streaming mode. This can reduce memory overhead when using Artemis with JMS StreamMessage types. This option must only be enabled if Apache Artemis is being used."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to startup the JmsConsumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to stop the JmsConsumer message listener asynchronously, when stopping a route."},"destinationResolver":{"kind":"parameter","displayName":"Destination Resolver","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.destination.DestinationResolver","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"A pluggable org.springframework.jms.support.destination.DestinationResolver that allows you to use your own resolver (for example, to lookup the real destination in a JNDI registry)."},"errorHandler":{"kind":"parameter","displayName":"Error Handler","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.util.ErrorHandler","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies a org.springframework.util.ErrorHandler to be invoked in case of any uncaught exceptions thrown while processing a Message. By default these exceptions will be logged at the WARN level, if no errorHandler has been configured. You can configure logging level and whether stack traces should be logged using errorHandlerLoggingLevel and errorHandlerLogStackTrace options. This makes it much easier to configure, than having to code a custom errorHandler."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"jakarta.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"idleConsumerLimit":{"kind":"parameter","displayName":"Idle Consumer Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specify the limit for the number of consumers that are allowed to be idle at any given time."},"idleTaskExecutionLimit":{"kind":"parameter","displayName":"Idle Task Execution Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the limit for idle executions of a receive task, not having received any message within its execution. If this limit is reached, the task will shut down and leave receiving to other executing tasks (in the case of dynamic scheduling; see the maxConcurrentConsumers setting). There is additional doc available from Spring."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsKeyFormatStrategy","enum":["default","passthrough"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as jakarta.jms.TextMessage to a String etc."},"maxMessagesPerTask":{"kind":"parameter","displayName":"Max Messages Per Task","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The number of messages per task. -1 is unlimited. If you use a range for concurrent consumers (eg min max), then this option can be used to set a value to eg 100 to control how fast the consumers will shrink when less work is required."},"messageConverter":{"kind":"parameter","displayName":"Message Converter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.converter.MessageConverter","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use a custom Spring org.springframework.jms.support.converter.MessageConverter so you can be in control how to map to/from a jakarta.jms.Message."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of jakarta.jms.Message objects when Camel is sending a JMS message."},"messageIdEnabled":{"kind":"parameter","displayName":"Message Id Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending, specifies whether message IDs should be added. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the message ID set to null; if the provider ignores the hint, the message ID must be set to its normal unique value."},"messageListenerContainerFactory":{"kind":"parameter","displayName":"Message Listener Container Factory","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageListenerContainerFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Registry ID of the MessageListenerContainerFactory used to determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use to consume messages. Setting this will automatically set consumerType to Custom."},"messageTimestampEnabled":{"kind":"parameter","displayName":"Message Timestamp Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether timestamps should be enabled by default on sending messages. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the timestamp set to zero; if the provider ignores the hint the timestamp must be set to its normal value."},"pubSubNoLocal":{"kind":"parameter","displayName":"Pub Sub No Local","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to inhibit the delivery of messages published by its own connection."},"receiveTimeout":{"kind":"parameter","displayName":"Receive Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for receiving messages (in milliseconds)."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"requestTimeoutCheckerInterval":{"kind":"parameter","displayName":"Request Timeout Checker Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Configures how often Camel should check for timed out Exchanges when doing request/reply over JMS. By default Camel checks once per second. But if you must react faster when a timeout occurs, then you can lower this interval, to check more frequently. The timeout is determined by the option requestTimeout."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a jakarta.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transferExchange":{"kind":"parameter","displayName":"Transfer Exchange","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"You can transfer the exchange over the wire instead of just the body and headers. The following fields are transferred: In body, Out body, Fault body, In headers, Out headers, Fault headers, exchange properties, exchange exception. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level. You must enable this option on both the producer and consumer side, so Camel knows the payloads is an Exchange and not a regular payload. Use this with caution as the data is using Java Object serialization and requires the receiver to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumers having to use compatible Camel versions!"},"useMessageIDAsCorrelationID":{"kind":"parameter","displayName":"Use Message IDAs Correlation ID","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether JMSMessageID should always be used as JMSCorrelationID for InOut messages."},"waitForProvisionCorrelationToBeUpdatedCounter":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Counter","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":50,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Number of times to wait for provisional correlation id to be updated to the actual correlation id when doing request/reply over JMS and when the option useMessageIDAsCorrelationID is enabled."},"waitForProvisionCorrelationToBeUpdatedThreadSleepingTime":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Thread Sleeping Time","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"100","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Interval in millis to sleep each time while waiting for provisional correlation id to be updated."},"errorHandlerLoggingLevel":{"kind":"parameter","displayName":"Error Handler Logging Level","group":"logging","label":"consumer,logging","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to configure the default errorHandler logging level for logging uncaught exceptions."},"errorHandlerLogStackTrace":{"kind":"parameter","displayName":"Error Handler Log Stack Trace","group":"logging","label":"consumer,logging","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to control whether stacktraces should be logged or not, by the default errorHandler."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Password to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Username to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use transacted mode"},"transactedInOut":{"kind":"parameter","displayName":"Transacted In Out","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether InOut operations (request reply) default to using transacted mode If this flag is set to true, then Spring JmsTemplate will have sessionTransacted set to true, and the acknowledgeMode as transacted on the JmsTemplate used for InOut operations. Note from Spring JMS: that within a JTA transaction, the parameters passed to createQueue, createTopic methods are not taken into account. Depending on the Java EE transaction context, the container makes its own decisions on these values. Analogously, these parameters are not taken into account within a locally managed transaction either, since Spring JMS operates on an existing JMS Session in this case. Setting this flag to true will use a short local JMS transaction when running outside of a managed transaction, and a synchronized local JMS transaction in case of a managed transaction (other than an XA transaction) being present. This has the effect of a local JMS transaction being managed alongside the main transaction (which might be a native JDBC transaction), with the JMS transaction committing right after the main transaction."},"lazyCreateTransactionManager":{"kind":"parameter","displayName":"Lazy Create Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will create a JmsTransactionManager, if there is no transactionManager injected when option transacted=true."},"transactionManager":{"kind":"parameter","displayName":"Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"object","javaType":"org.springframework.transaction.PlatformTransactionManager","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The Spring transaction manager to use."},"transactionName":{"kind":"parameter","displayName":"Transaction Name","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The name of the transaction to use."},"transactionTimeout":{"kind":"parameter","displayName":"Transaction Timeout","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout value of the transaction (in seconds), if using transacted mode."}}} , {"component":{"kind":"component","name":"arangodb","title":"ArangoDb","description":"Perform operations on ArangoDb when used as a Document Database, or as a Graph Database","deprecated":false,"firstVersion":"3.5.0","label":"database,nosql","javaType":"org.apache.camel.component.arangodb.ArangoDbComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-arangodb","version":"3.20.3","scheme":"arangodb","extendsScheme":"","syntax":"arangodb:database","async":false,"api":false,"consumerOnly":false,"producerOnly":true,"lenientProperties":false},"headers":{"CamelArangoDbMultiUpdate":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.lang.Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"Indicates if there are multiple documents to update. If set to true, the body of the message must be a Collection of documents to update.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#MULTI_UPDATE"},"CamelArangoDbMultiInsert":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.lang.Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"Indicates if there are multiple documents to insert. If set to true, the body of the message must be a Collection of documents to insert.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#MULTI_INSERT"},"CamelArangoDbMultiDelete":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.lang.Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"Indicates if there are multiple documents to delete. If set to true, the body of the message must be a Collection of key of documents to delete.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#MULTI_DELETE"},"key":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The Arango key to use for the operation.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#ARANGO_KEY"},"ResultClassType":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.lang.Class","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"BaseDocument.class or BaseEdgeDocument.class","description":"The type of the result of the operation.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#RESULT_CLASS_TYPE"},"CamelArangoDbAqlQuery":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The AQL query to execute.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#AQL_QUERY"},"CamelArangoDbAqlParameters":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"java.util.Map","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The key/value pairs defining the variables to bind the query to.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#AQL_QUERY_BIND_PARAMETERS"},"CamelArangoDbAqlOptions":{"kind":"header","displayName":"","group":"advanced","label":"advanced","required":false,"javaType":"com.arangodb.model.AqlQueryOptions","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The additional options that will be passed to the query API.","constantName":"org.apache.camel.component.arangodb.ArangoDbConstants#AQL_QUERY_OPTIONS"}},"properties":{"database":{"kind":"path","displayName":"Database","group":"producer","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"database name"},"documentCollection":{"kind":"parameter","displayName":"Document Collection","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"Collection name, when using ArangoDb as a Document Database. Set the documentCollection name when using the CRUD operation on the document database collections (SAVE_DOCUMENT , FIND_DOCUMENT_BY_KEY, UPDATE_DOCUMENT, DELETE_DOCUMENT)."},"edgeCollection":{"kind":"parameter","displayName":"Edge Collection","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"Collection name of vertices, when using ArangoDb as a Graph Database. Set the edgeCollection name to perform CRUD operation on edges using these operations : SAVE_VERTEX, FIND_VERTEX_BY_KEY, UPDATE_VERTEX, DELETE_VERTEX. The graph attribute is mandatory."},"graph":{"kind":"parameter","displayName":"Graph","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"Graph name, when using ArangoDb as a Graph Database. Combine this attribute with one of the two attributes vertexCollection and edgeCollection."},"host":{"kind":"parameter","displayName":"Host","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"ArangoDB host. If host and port are default, this field is Optional."},"operation":{"kind":"parameter","displayName":"Operation","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.arangodb.ArangoDbOperation","enum":["SAVE_DOCUMENT","FIND_DOCUMENT_BY_KEY","UPDATE_DOCUMENT","DELETE_DOCUMENT","AQL_QUERY","SAVE_VERTEX","FIND_VERTEX_BY_KEY","UPDATE_VERTEX","DELETE_VERTEX","SAVE_EDGE","FIND_EDGE_BY_KEY","UPDATE_EDGE","DELETE_EDGE"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"Operations to perform on ArangoDb. For the operation AQL_QUERY, no need to specify a collection or graph."},"port":{"kind":"parameter","displayName":"Port","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"ArangoDB exposed port. If host and port are default, this field is Optional."},"vertexCollection":{"kind":"parameter","displayName":"Vertex Collection","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"Collection name of vertices, when using ArangoDb as a Graph Database. Set the vertexCollection name to perform CRUD operation on vertices using these operations : SAVE_EDGE, FIND_EDGE_BY_KEY, UPDATE_EDGE, DELETE_EDGE. The graph attribute is mandatory."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"ArangoDB password. If user and password are default, this field is Optional."},"user":{"kind":"parameter","displayName":"User","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.arangodb.ArangoDbConfiguration","configurationField":"configuration","description":"ArangoDB user. If user and password are default, this field is Optional."}}} , @@ -343,7 +343,7 @@ , {"component":{"kind":"component","name":"jira","title":"Jira","description":"Interact with JIRA issue tracker.","deprecated":false,"firstVersion":"3.0","label":"api,reporting","javaType":"org.apache.camel.component.jira.JiraComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jira","version":"3.20.3","scheme":"jira","extendsScheme":"","syntax":"jira:type","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"IssueAssignee":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The assignee's name of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_ASSIGNEE"},"IssueComponents":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The comma separated list of the issue's components","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_COMPONENTS"},"IssueChanged":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the updated field (i.e Status)","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_CHANGED"},"IssueKey":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The id of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_KEY"},"IssuePriorityId":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"Long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The priority's id of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_PRIORITY_ID"},"IssuePriorityName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The priority's name of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_PRIORITY_NAME"},"ProjectKey":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The project's id of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_PROJECT_KEY"},"IssueSummary":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The summary of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_SUMMARY"},"IssueTransitionId":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"Integer","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The transition id","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_TRANSITION_ID"},"IssueTypeId":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"Long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type's id of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_TYPE_ID"},"IssueTypeName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type's name of the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_TYPE_NAME"},"IssueWatchedIssues":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The list of all issue keys that are watched in the time of update","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_WATCHED_ISSUES"},"IssueWatchersAdd":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The comma separated list of watchers to add to the issue","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_WATCHERS_ADD"},"IssueWatchersRemove":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The watchers of the issue to remove","constantName":"org.apache.camel.component.jira.JiraConstants#ISSUE_WATCHERS_REMOVE"},"ParentIssueKey":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The id of the parent issue","constantName":"org.apache.camel.component.jira.JiraConstants#PARENT_ISSUE_KEY"},"ChildIssueKey":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The id of the child issue","constantName":"org.apache.camel.component.jira.JiraConstants#CHILD_ISSUE_KEY"},"linkType":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type of link","constantName":"org.apache.camel.component.jira.JiraConstants#LINK_TYPE"},"minutesSpent":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"-1","description":"The minutes spent","constantName":"org.apache.camel.component.jira.JiraConstants#MINUTES_SPENT"}},"properties":{"type":{"kind":"path","displayName":"Type","group":"common","label":"","required":true,"type":"object","javaType":"org.apache.camel.component.jira.JiraType","enum":["ADDCOMMENT","ADDISSUE","ATTACH","DELETEISSUE","NEWISSUES","NEWCOMMENTS","WATCHUPDATES","UPDATEISSUE","TRANSITIONISSUE","WATCHERS","ADDISSUELINK","ADDWORKLOG","FETCHISSUE","FETCHCOMMENTS"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Operation to perform. Consumers: NewIssues, NewComments. Producers: AddIssue, AttachFile, DeleteIssue, TransitionIssue, UpdateIssue, Watchers. See this class javadoc description for more information."},"delay":{"kind":"parameter","displayName":"Delay","group":"common","label":"","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"defaultValue":"6000","configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"Time in milliseconds to elapse for the next poll."},"jiraUrl":{"kind":"parameter","displayName":"Jira Url","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"The Jira server url, example: http://my_jira.com:8081"},"jql":{"kind":"parameter","displayName":"Jql","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"JQL is the query language from JIRA which allows you to retrieve the data you want. For example jql=project=MyProject Where MyProject is the product key in Jira. It is important to use the RAW() and set the JQL inside it to prevent camel parsing it, example: RAW(project in (MYP, COM) AND resolution = Unresolved)"},"maxResults":{"kind":"parameter","displayName":"Max Results","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"defaultValue":"50","description":"Max number of issues to search for"},"sendOnlyUpdatedField":{"kind":"parameter","displayName":"Send Only Updated Field","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Indicator for sending only changed fields in exchange body or issue object. By default consumer sends only changed fields."},"watchedFields":{"kind":"parameter","displayName":"Watched Fields","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Status,Priority","description":"Comma separated list of fields to watch for changes. Status,Priority are the defaults."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"accessToken":{"kind":"parameter","displayName":"Access Token","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"(OAuth or Personal Access Token authentication) The access token generated by the Jira server."},"consumerKey":{"kind":"parameter","displayName":"Consumer Key","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"(OAuth only) The consumer key from Jira settings."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"(Basic authentication only) The password or the API Token to authenticate to the Jira server. Use only if username basic authentication is used."},"privateKey":{"kind":"parameter","displayName":"Private Key","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"(OAuth only) The private key generated by the client to encrypt the conversation to the server."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"(Basic authentication only) The username to authenticate to the Jira server. Use only if OAuth is not enabled on the Jira server. Do not set the username and OAuth token parameter, if they are both set, the username basic authentication takes precedence."},"verificationCode":{"kind":"parameter","displayName":"Verification Code","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jira.JiraConfiguration","configurationField":"configuration","description":"(OAuth only) The verification code from Jira generated in the first step of the authorization proccess."}}} , -{"component":{"kind":"component","name":"jms","title":"JMS","description":"Sent and receive messages to/from a JMS Queue or Topic.","deprecated":false,"deprecationNote":"","firstVersion":"1.0.0","label":"messaging","javaType":"org.apache.camel.component.jms.JmsComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jms","version":"3.20.3","scheme":"jms","extendsScheme":"","syntax":"jms:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJmsDestination":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION"},"CamelJmsDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the queue or topic to use as destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION_NAME"},"JMSXGroupID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS group ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_X_GROUP_ID"},"JMSMessageID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS unique message ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_MESSAGE_ID"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID"},"JMSCorrelationIDAsBytes":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID as bytes.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID_AS_BYTES"},"JMSDeliveryMode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS delivery mode.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DELIVERY_MODE"},"JMSDestination":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DESTINATION"},"JMSExpiration":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS expiration.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_EXPIRATION"},"JMSPriority":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS priority (with 0 as the lowest priority and 9 as the highest).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_PRIORITY"},"JMSRedelivered":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Is the JMS message redelivered.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REDELIVERED"},"JMSTimestamp":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS timestamp.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TIMESTAMP"},"JMSReplyTo":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"javax.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS reply-to destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REPLY_TO"},"JMSType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TYPE"},"JMSXUserID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The XUser id.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_XUSER_ID"},"CamelJmsMessageType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text","Blob"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The message type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_MESSAGE_TYPE"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"20_000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_REQUEST_TIMEOUT"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic","temp-queue","temp-topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of the queue or topic to use as destination"},"clientId":{"kind":"parameter","displayName":"Client Id","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"","required":false,"type":"object","javaType":"javax.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"jmsMessageType":{"kind":"parameter","displayName":"Jms Message Type","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to force the use of a specific javax.jms.Message implementation for sending JMS messages. Possible values are: Bytes, Map, Object, Stream, Text. By default, Camel would determine which JMS message type to use from the In body type. This option allows you to specify it."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"acknowledgementModeName":{"kind":"parameter","displayName":"Acknowledgement Mode Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"artemisConsumerPriority":{"kind":"parameter","displayName":"Artemis Consumer Priority","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Consumer priorities allow you to ensure that high priority consumers receive messages while they are active. Normally, active consumers connected to a queue receive messages from it in a round-robin fashion. When consumer priorities are in use, messages are delivered round-robin if multiple active consumers exist with the same high priority. Messages will only going to lower priority consumers when the high priority consumers do not have credit available to consume the message, or those high priority consumers have declined to accept the message (for instance because it does not meet the criteria of any selectors associated with the consumer)."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer container should auto-startup."},"cacheLevel":{"kind":"parameter","displayName":"Cache Level","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by ID for the underlying JMS resources. See cacheLevelName option for more details."},"cacheLevelName":{"kind":"parameter","displayName":"Cache Level Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"CACHE_AUTO","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the underlying JMS resources. Possible values are: CACHE_AUTO, CACHE_CONNECTION, CACHE_CONSUMER, CACHE_NONE, and CACHE_SESSION. The default setting is CACHE_AUTO. See the Spring documentation and Transactions Cache Levels for more information."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"maxConcurrentConsumers":{"kind":"parameter","displayName":"Max Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToMaxConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use persistent delivery by default for replies."},"selector":{"kind":"parameter","displayName":"Selector","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS selector to use"},"subscriptionDurable":{"kind":"parameter","displayName":"Subscription Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription durable. The durable subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a durable subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well."},"subscriptionName":{"kind":"parameter","displayName":"Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set the name of a subscription to create. To be applied in case of a topic (pub-sub domain) with a shared or durable subscription. The subscription name needs to be unique within this client's JMS client id. Default is the class name of the specified message listener. Note: Only 1 concurrent consumer (which is the default of this message listener container) is allowed for each subscription, except for a shared subscription (which requires JMS 2.0)."},"subscriptionShared":{"kind":"parameter","displayName":"Subscription Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription shared. The shared subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a shared subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Note that shared subscriptions may also be durable, so this flag can (and often will) be combined with subscriptionDurable as well. Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well. Requires a JMS 2.0 compatible message broker."},"acceptMessagesWhileStopping":{"kind":"parameter","displayName":"Accept Messages While Stopping","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer accept messages while it is stopping. You may consider enabling this option, if you start and stop JMS routes at runtime, while there are still messages enqueued on the queue. If this option is false, and you stop the JMS route, then messages may be rejected, and the JMS broker would have to attempt redeliveries, which yet again may be rejected, and eventually the message may be moved at a dead letter queue on the JMS broker. To avoid this its recommended to enable this option."},"allowReplyManagerQuickStop":{"kind":"parameter","displayName":"Allow Reply Manager Quick Stop","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the DefaultMessageListenerContainer used in the reply managers for request-reply messaging allow the DefaultMessageListenerContainer.runningAllowed flag to quick stop in case JmsConfiguration#isAcceptMessagesWhileStopping is enabled, and org.apache.camel.CamelContext is currently being stopped. This quick stop ability is enabled by default in the regular JMS consumers but to enable for reply managers you must enable this flag."},"consumerType":{"kind":"parameter","displayName":"Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type to use, which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"defaultTaskExecutorType":{"kind":"parameter","displayName":"Default Task Executor Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.DefaultTaskExecutorType","enum":["ThreadPool","SimpleAsync"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies what default TaskExecutor type to use in the DefaultMessageListenerContainer, for both consumer endpoints and the ReplyTo consumer of producer endpoints. Possible values: SimpleAsync (uses Spring's SimpleAsyncTaskExecutor) or ThreadPool (uses Spring's ThreadPoolTaskExecutor with optimal values - cached threadpool-like). If not set, it defaults to the previous behaviour, which uses a cached thread pool for consumer endpoints and SimpleAsync for reply consumers. The use of ThreadPool is recommended to reduce thread trash in elastic configurations with dynamically increasing and decreasing concurrent consumers."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"exposeListenerSession":{"kind":"parameter","displayName":"Expose Listener Session","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the listener session should be exposed when consuming messages."},"replyToConsumerType":{"kind":"parameter","displayName":"Reply To Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type of the reply consumer (when doing request/reply), which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"taskExecutor":{"kind":"parameter","displayName":"Task Executor","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.springframework.core.task.TaskExecutor","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to specify a custom task executor for consuming messages."},"deliveryDelay":{"kind":"parameter","displayName":"Delivery Delay","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets delivery delay to use for send calls for JMS. This option requires JMS 2.0 compliant broker."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the delivery mode to be used. Possible values are those defined by javax.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether persistent delivery is used by default."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"formatDateHeadersToIso8601":{"kind":"parameter","displayName":"Format Date Headers To Iso8601","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether JMS date properties should be formatted according to the ISO 8601 standard."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when using request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOnTimeoutMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To On Timeout Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers for continue routing when timeout occurred when using request/reply over JMS."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ReplyToType","enum":["Temporary","Shared","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary, Shared, or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Shared is used by default. This option allows you to use exclusive queues instead of shared ones. See Camel JMS documentation for more details, and especially the notes about the implications if running in a clustered environment, and the fact that Shared reply queues has lower performance than its alternatives Temporary and Exclusive."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowAdditionalHeaders":{"kind":"parameter","displayName":"Allow Additional Headers","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"This option is used to allow additional headers which may have values that are invalid according to JMS specification. For example some message systems such as WMQ do this with header names using prefix JMS_IBM_MQMD_ containing values with byte array or other invalid types. You can specify multiple header names separated by comma, and use as suffix for wildcard matching."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"alwaysCopyMessage":{"kind":"parameter","displayName":"Always Copy Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will always make a JMS message copy of the message when it is passed to the producer for sending. Copying the message is needed in some situations, such as when a replyToDestinationSelectorName is set (incidentally, Camel will set the alwaysCopyMessage option to true, if a replyToDestinationSelectorName is set)"},"correlationProperty":{"kind":"parameter","displayName":"Correlation Property","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using InOut exchange pattern use this JMS property instead of JMSCorrelationID JMS property to correlate messages. If set messages will be correlated solely on the value of this property JMSCorrelationID property will be ignored and not set by Camel."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"forceSendOriginalMessage":{"kind":"parameter","displayName":"Force Send Original Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using mapJmsMessage=false Camel will create a new JMS message to send to a new JMS destination if you touch the headers (get or set) during the route. Set this option to true to force Camel to send the original JMS message that was received."},"includeSentJMSMessageID":{"kind":"parameter","displayName":"Include Sent JMSMessage ID","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Only applicable when sending to JMS destination using InOnly (eg fire and forget). Enabling this option will enrich the Camel Exchange with the actual JMSMessageID that was used by the JMS client when the message was sent to the JMS destination."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"replyToCacheLevelName":{"kind":"parameter","displayName":"Reply To Cache Level Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the reply consumer when doing request/reply over JMS. This option only applies when using fixed reply queues (not temporary). Camel will by default use: CACHE_CONSUMER for exclusive or shared w/ replyToSelectorName. And CACHE_SESSION for shared without replyToSelectorName. Some JMS brokers such as IBM WebSphere may require to set the replyToCacheLevelName=CACHE_NONE to work. Note: If using temporary queues then CACHE_NONE is not allowed, and you must use a higher value such as CACHE_CONSUMER or CACHE_SESSION."},"replyToDestinationSelectorName":{"kind":"parameter","displayName":"Reply To Destination Selector Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS Selector using the fixed name to be used so you can filter out your own replies from the others when using a shared queue (that is, if you are not using a temporary reply queue)."},"streamMessageTypeEnabled":{"kind":"parameter","displayName":"Stream Message Type Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether StreamMessage type is enabled or not. Message payloads of streaming kind such as files, InputStream, etc will either by sent as BytesMessage or StreamMessage. This option controls which kind will be used. By default BytesMessage is used which enforces the entire message payload to be read into memory. By enabling this option the message payload is read into memory in chunks and each chunk is then written to the StreamMessage until no more data."},"allowSerializedHeaders":{"kind":"parameter","displayName":"Allow Serialized Headers","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Controls whether or not to include serialized headers. Applies only when transferExchange is true. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level."},"artemisStreamingEnabled":{"kind":"parameter","displayName":"Artemis Streaming Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether optimizing for Apache Artemis streaming mode. This can reduce memory overhead when using Artemis with JMS StreamMessage types. This option must only be enabled if Apache Artemis is being used."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to startup the JmsConsumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to stop the JmsConsumer message listener asynchronously, when stopping a route."},"destinationResolver":{"kind":"parameter","displayName":"Destination Resolver","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.destination.DestinationResolver","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"A pluggable org.springframework.jms.support.destination.DestinationResolver that allows you to use your own resolver (for example, to lookup the real destination in a JNDI registry)."},"errorHandler":{"kind":"parameter","displayName":"Error Handler","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.util.ErrorHandler","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies a org.springframework.util.ErrorHandler to be invoked in case of any uncaught exceptions thrown while processing a Message. By default these exceptions will be logged at the WARN level, if no errorHandler has been configured. You can configure logging level and whether stack traces should be logged using errorHandlerLoggingLevel and errorHandlerLogStackTrace options. This makes it much easier to configure, than having to code a custom errorHandler."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"javax.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"idleConsumerLimit":{"kind":"parameter","displayName":"Idle Consumer Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specify the limit for the number of consumers that are allowed to be idle at any given time."},"idleTaskExecutionLimit":{"kind":"parameter","displayName":"Idle Task Execution Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the limit for idle executions of a receive task, not having received any message within its execution. If this limit is reached, the task will shut down and leave receiving to other executing tasks (in the case of dynamic scheduling; see the maxConcurrentConsumers setting). There is additional doc available from Spring."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsKeyFormatStrategy","enum":["default","passthrough"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as javax.jms.TextMessage to a String etc."},"maxMessagesPerTask":{"kind":"parameter","displayName":"Max Messages Per Task","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The number of messages per task. -1 is unlimited. If you use a range for concurrent consumers (eg min max), then this option can be used to set a value to eg 100 to control how fast the consumers will shrink when less work is required."},"messageConverter":{"kind":"parameter","displayName":"Message Converter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.converter.MessageConverter","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use a custom Spring org.springframework.jms.support.converter.MessageConverter so you can be in control how to map to/from a javax.jms.Message."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of javax.jms.Message objects when Camel is sending a JMS message."},"messageIdEnabled":{"kind":"parameter","displayName":"Message Id Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending, specifies whether message IDs should be added. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the message ID set to null; if the provider ignores the hint, the message ID must be set to its normal unique value."},"messageListenerContainerFactory":{"kind":"parameter","displayName":"Message Listener Container Factory","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageListenerContainerFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Registry ID of the MessageListenerContainerFactory used to determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use to consume messages. Setting this will automatically set consumerType to Custom."},"messageTimestampEnabled":{"kind":"parameter","displayName":"Message Timestamp Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether timestamps should be enabled by default on sending messages. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the timestamp set to zero; if the provider ignores the hint the timestamp must be set to its normal value."},"pubSubNoLocal":{"kind":"parameter","displayName":"Pub Sub No Local","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to inhibit the delivery of messages published by its own connection."},"receiveTimeout":{"kind":"parameter","displayName":"Receive Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for receiving messages (in milliseconds)."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"requestTimeoutCheckerInterval":{"kind":"parameter","displayName":"Request Timeout Checker Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Configures how often Camel should check for timed out Exchanges when doing request/reply over JMS. By default Camel checks once per second. But if you must react faster when a timeout occurs, then you can lower this interval, to check more frequently. The timeout is determined by the option requestTimeout."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a javax.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transferExchange":{"kind":"parameter","displayName":"Transfer Exchange","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"You can transfer the exchange over the wire instead of just the body and headers. The following fields are transferred: In body, Out body, Fault body, In headers, Out headers, Fault headers, exchange properties, exchange exception. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level. You must enable this option on both the producer and consumer side, so Camel knows the payloads is an Exchange and not a regular payload. Use this with caution as the data is using Java Object serialization and requires the receiver to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumers having to use compatible Camel versions!"},"useMessageIDAsCorrelationID":{"kind":"parameter","displayName":"Use Message IDAs Correlation ID","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether JMSMessageID should always be used as JMSCorrelationID for InOut messages."},"waitForProvisionCorrelationToBeUpdatedCounter":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Counter","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":50,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Number of times to wait for provisional correlation id to be updated to the actual correlation id when doing request/reply over JMS and when the option useMessageIDAsCorrelationID is enabled."},"waitForProvisionCorrelationToBeUpdatedThreadSleepingTime":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Thread Sleeping Time","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"100","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Interval in millis to sleep each time while waiting for provisional correlation id to be updated."},"errorHandlerLoggingLevel":{"kind":"parameter","displayName":"Error Handler Logging Level","group":"logging","label":"consumer,logging","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to configure the default errorHandler logging level for logging uncaught exceptions."},"errorHandlerLogStackTrace":{"kind":"parameter","displayName":"Error Handler Log Stack Trace","group":"logging","label":"consumer,logging","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to control whether stacktraces should be logged or not, by the default errorHandler."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Password to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Username to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use transacted mode"},"transactedInOut":{"kind":"parameter","displayName":"Transacted In Out","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether InOut operations (request reply) default to using transacted mode If this flag is set to true, then Spring JmsTemplate will have sessionTransacted set to true, and the acknowledgeMode as transacted on the JmsTemplate used for InOut operations. Note from Spring JMS: that within a JTA transaction, the parameters passed to createQueue, createTopic methods are not taken into account. Depending on the Java EE transaction context, the container makes its own decisions on these values. Analogously, these parameters are not taken into account within a locally managed transaction either, since Spring JMS operates on an existing JMS Session in this case. Setting this flag to true will use a short local JMS transaction when running outside of a managed transaction, and a synchronized local JMS transaction in case of a managed transaction (other than an XA transaction) being present. This has the effect of a local JMS transaction being managed alongside the main transaction (which might be a native JDBC transaction), with the JMS transaction committing right after the main transaction."},"lazyCreateTransactionManager":{"kind":"parameter","displayName":"Lazy Create Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will create a JmsTransactionManager, if there is no transactionManager injected when option transacted=true."},"transactionManager":{"kind":"parameter","displayName":"Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"object","javaType":"org.springframework.transaction.PlatformTransactionManager","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The Spring transaction manager to use."},"transactionName":{"kind":"parameter","displayName":"Transaction Name","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The name of the transaction to use."},"transactionTimeout":{"kind":"parameter","displayName":"Transaction Timeout","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout value of the transaction (in seconds), if using transacted mode."}}} +{"component":{"kind":"component","name":"jms","title":"JMS","description":"Sent and receive messages to/from a JMS Queue or Topic.","deprecated":false,"deprecationNote":"","firstVersion":"1.0.0","label":"messaging","javaType":"org.apache.camel.component.jms.JmsComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jms","version":"3.20.3","scheme":"jms","extendsScheme":"","syntax":"jms:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJmsDestination":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION"},"CamelJmsDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the queue or topic to use as destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_DESTINATION_NAME"},"JMSXGroupID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS group ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_X_GROUP_ID"},"JMSMessageID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS unique message ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_MESSAGE_ID"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID"},"JMSCorrelationIDAsBytes":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS correlation ID as bytes.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_CORRELATION_ID_AS_BYTES"},"JMSDeliveryMode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS delivery mode.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DELIVERY_MODE"},"JMSDestination":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_DESTINATION"},"JMSExpiration":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS expiration.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_EXPIRATION"},"JMSPriority":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS priority (with 0 as the lowest priority and 9 as the highest).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_PRIORITY"},"JMSRedelivered":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Is the JMS message redelivered.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REDELIVERED"},"JMSTimestamp":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS timestamp.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TIMESTAMP"},"JMSReplyTo":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"jakarta.jms.Destination","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS reply-to destination.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_REPLY_TO"},"JMSType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The JMS type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_TYPE"},"JMSXUserID":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The XUser id.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_HEADER_XUSER_ID"},"CamelJmsMessageType":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text","Blob"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The message type.","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_MESSAGE_TYPE"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"20_000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.jms.JmsConstants#JMS_REQUEST_TIMEOUT"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic","temp-queue","temp-topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of the queue or topic to use as destination"},"clientId":{"kind":"parameter","displayName":"Client Id","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"","required":false,"type":"object","javaType":"jakarta.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"jmsMessageType":{"kind":"parameter","displayName":"Jms Message Type","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsMessageType","enum":["Bytes","Map","Object","Stream","Text"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to force the use of a specific jakarta.jms.Message implementation for sending JMS messages. Possible values are: Bytes, Map, Object, Stream, Text. By default, Camel would determine which JMS message type to use from the In body type. This option allows you to specify it."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"acknowledgementModeName":{"kind":"parameter","displayName":"Acknowledgement Mode Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"artemisConsumerPriority":{"kind":"parameter","displayName":"Artemis Consumer Priority","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Consumer priorities allow you to ensure that high priority consumers receive messages while they are active. Normally, active consumers connected to a queue receive messages from it in a round-robin fashion. When consumer priorities are in use, messages are delivered round-robin if multiple active consumers exist with the same high priority. Messages will only going to lower priority consumers when the high priority consumers do not have credit available to consume the message, or those high priority consumers have declined to accept the message (for instance because it does not meet the criteria of any selectors associated with the consumer)."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer container should auto-startup."},"cacheLevel":{"kind":"parameter","displayName":"Cache Level","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by ID for the underlying JMS resources. See cacheLevelName option for more details."},"cacheLevelName":{"kind":"parameter","displayName":"Cache Level Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"CACHE_AUTO","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the underlying JMS resources. Possible values are: CACHE_AUTO, CACHE_CONNECTION, CACHE_CONSUMER, CACHE_NONE, and CACHE_SESSION. The default setting is CACHE_AUTO. See the Spring documentation and Transactions Cache Levels for more information."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"maxConcurrentConsumers":{"kind":"parameter","displayName":"Max Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToMaxConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use persistent delivery by default for replies."},"selector":{"kind":"parameter","displayName":"Selector","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS selector to use"},"subscriptionDurable":{"kind":"parameter","displayName":"Subscription Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription durable. The durable subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a durable subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well."},"subscriptionName":{"kind":"parameter","displayName":"Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set the name of a subscription to create. To be applied in case of a topic (pub-sub domain) with a shared or durable subscription. The subscription name needs to be unique within this client's JMS client id. Default is the class name of the specified message listener. Note: Only 1 concurrent consumer (which is the default of this message listener container) is allowed for each subscription, except for a shared subscription (which requires JMS 2.0)."},"subscriptionShared":{"kind":"parameter","displayName":"Subscription Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set whether to make the subscription shared. The shared subscription name to be used can be specified through the subscriptionName property. Default is false. Set this to true to register a shared subscription, typically in combination with a subscriptionName value (unless your message listener class name is good enough as subscription name). Note that shared subscriptions may also be durable, so this flag can (and often will) be combined with subscriptionDurable as well. Only makes sense when listening to a topic (pub-sub domain), therefore this method switches the pubSubDomain flag as well. Requires a JMS 2.0 compatible message broker."},"acceptMessagesWhileStopping":{"kind":"parameter","displayName":"Accept Messages While Stopping","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the consumer accept messages while it is stopping. You may consider enabling this option, if you start and stop JMS routes at runtime, while there are still messages enqueued on the queue. If this option is false, and you stop the JMS route, then messages may be rejected, and the JMS broker would have to attempt redeliveries, which yet again may be rejected, and eventually the message may be moved at a dead letter queue on the JMS broker. To avoid this its recommended to enable this option."},"allowReplyManagerQuickStop":{"kind":"parameter","displayName":"Allow Reply Manager Quick Stop","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether the DefaultMessageListenerContainer used in the reply managers for request-reply messaging allow the DefaultMessageListenerContainer.runningAllowed flag to quick stop in case JmsConfiguration#isAcceptMessagesWhileStopping is enabled, and org.apache.camel.CamelContext is currently being stopped. This quick stop ability is enabled by default in the regular JMS consumers but to enable for reply managers you must enable this flag."},"consumerType":{"kind":"parameter","displayName":"Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type to use, which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"defaultTaskExecutorType":{"kind":"parameter","displayName":"Default Task Executor Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.DefaultTaskExecutorType","enum":["ThreadPool","SimpleAsync"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies what default TaskExecutor type to use in the DefaultMessageListenerContainer, for both consumer endpoints and the ReplyTo consumer of producer endpoints. Possible values: SimpleAsync (uses Spring's SimpleAsyncTaskExecutor) or ThreadPool (uses Spring's ThreadPoolTaskExecutor with optimal values - cached threadpool-like). If not set, it defaults to the previous behaviour, which uses a cached thread pool for consumer endpoints and SimpleAsync for reply consumers. The use of ThreadPool is recommended to reduce thread trash in elastic configurations with dynamically increasing and decreasing concurrent consumers."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"exposeListenerSession":{"kind":"parameter","displayName":"Expose Listener Session","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether the listener session should be exposed when consuming messages."},"replyToConsumerType":{"kind":"parameter","displayName":"Reply To Consumer Type","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ConsumerType","enum":["Simple","Default","Custom"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Default","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The consumer type of the reply consumer (when doing request/reply), which can be one of: Simple, Default, or Custom. The consumer type determines which Spring JMS listener to use. Default will use org.springframework.jms.listener.DefaultMessageListenerContainer, Simple will use org.springframework.jms.listener.SimpleMessageListenerContainer. When Custom is specified, the MessageListenerContainerFactory defined by the messageListenerContainerFactory option will determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"taskExecutor":{"kind":"parameter","displayName":"Task Executor","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.springframework.core.task.TaskExecutor","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows you to specify a custom task executor for consuming messages."},"deliveryDelay":{"kind":"parameter","displayName":"Delivery Delay","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets delivery delay to use for send calls for JMS. This option requires JMS 2.0 compliant broker."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the delivery mode to be used. Possible values are those defined by jakarta.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether persistent delivery is used by default."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"formatDateHeadersToIso8601":{"kind":"parameter","displayName":"Format Date Headers To Iso8601","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether JMS date properties should be formatted according to the ISO 8601 standard."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers when using request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOnTimeoutMaxConcurrentConsumers":{"kind":"parameter","displayName":"Reply To On Timeout Max Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the maximum number of concurrent consumers for continue routing when timeout occurred when using request/reply over JMS."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.jms.ReplyToType","enum":["Temporary","Shared","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary, Shared, or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Shared is used by default. This option allows you to use exclusive queues instead of shared ones. See Camel JMS documentation for more details, and especially the notes about the implications if running in a clustered environment, and the fact that Shared reply queues has lower performance than its alternatives Temporary and Exclusive."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowAdditionalHeaders":{"kind":"parameter","displayName":"Allow Additional Headers","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"This option is used to allow additional headers which may have values that are invalid according to JMS specification. For example some message systems such as WMQ do this with header names using prefix JMS_IBM_MQMD_ containing values with byte array or other invalid types. You can specify multiple header names separated by comma, and use as suffix for wildcard matching."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"alwaysCopyMessage":{"kind":"parameter","displayName":"Always Copy Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will always make a JMS message copy of the message when it is passed to the producer for sending. Copying the message is needed in some situations, such as when a replyToDestinationSelectorName is set (incidentally, Camel will set the alwaysCopyMessage option to true, if a replyToDestinationSelectorName is set)"},"correlationProperty":{"kind":"parameter","displayName":"Correlation Property","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using InOut exchange pattern use this JMS property instead of JMSCorrelationID JMS property to correlate messages. If set messages will be correlated solely on the value of this property JMSCorrelationID property will be ignored and not set by Camel."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"forceSendOriginalMessage":{"kind":"parameter","displayName":"Force Send Original Message","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When using mapJmsMessage=false Camel will create a new JMS message to send to a new JMS destination if you touch the headers (get or set) during the route. Set this option to true to force Camel to send the original JMS message that was received."},"includeSentJMSMessageID":{"kind":"parameter","displayName":"Include Sent JMSMessage ID","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Only applicable when sending to JMS destination using InOnly (eg fire and forget). Enabling this option will enrich the Camel Exchange with the actual JMSMessageID that was used by the JMS client when the message was sent to the JMS destination."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"replyToCacheLevelName":{"kind":"parameter","displayName":"Reply To Cache Level Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","enum":["CACHE_AUTO","CACHE_CONNECTION","CACHE_CONSUMER","CACHE_NONE","CACHE_SESSION"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the cache level by name for the reply consumer when doing request/reply over JMS. This option only applies when using fixed reply queues (not temporary). Camel will by default use: CACHE_CONSUMER for exclusive or shared w/ replyToSelectorName. And CACHE_SESSION for shared without replyToSelectorName. Some JMS brokers such as IBM WebSphere may require to set the replyToCacheLevelName=CACHE_NONE to work. Note: If using temporary queues then CACHE_NONE is not allowed, and you must use a higher value such as CACHE_CONSUMER or CACHE_SESSION."},"replyToDestinationSelectorName":{"kind":"parameter","displayName":"Reply To Destination Selector Name","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets the JMS Selector using the fixed name to be used so you can filter out your own replies from the others when using a shared queue (that is, if you are not using a temporary reply queue)."},"streamMessageTypeEnabled":{"kind":"parameter","displayName":"Stream Message Type Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether StreamMessage type is enabled or not. Message payloads of streaming kind such as files, InputStream, etc will either by sent as BytesMessage or StreamMessage. This option controls which kind will be used. By default BytesMessage is used which enforces the entire message payload to be read into memory. By enabling this option the message payload is read into memory in chunks and each chunk is then written to the StreamMessage until no more data."},"allowSerializedHeaders":{"kind":"parameter","displayName":"Allow Serialized Headers","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Controls whether or not to include serialized headers. Applies only when transferExchange is true. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level."},"artemisStreamingEnabled":{"kind":"parameter","displayName":"Artemis Streaming Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether optimizing for Apache Artemis streaming mode. This can reduce memory overhead when using Artemis with JMS StreamMessage types. This option must only be enabled if Apache Artemis is being used."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to startup the JmsConsumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to stop the JmsConsumer message listener asynchronously, when stopping a route."},"destinationResolver":{"kind":"parameter","displayName":"Destination Resolver","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.destination.DestinationResolver","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"A pluggable org.springframework.jms.support.destination.DestinationResolver that allows you to use your own resolver (for example, to lookup the real destination in a JNDI registry)."},"errorHandler":{"kind":"parameter","displayName":"Error Handler","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.util.ErrorHandler","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies a org.springframework.util.ErrorHandler to be invoked in case of any uncaught exceptions thrown while processing a Message. By default these exceptions will be logged at the WARN level, if no errorHandler has been configured. You can configure logging level and whether stack traces should be logged using errorHandlerLoggingLevel and errorHandlerLogStackTrace options. This makes it much easier to configure, than having to code a custom errorHandler."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"jakarta.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"idleConsumerLimit":{"kind":"parameter","displayName":"Idle Consumer Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specify the limit for the number of consumers that are allowed to be idle at any given time."},"idleTaskExecutionLimit":{"kind":"parameter","displayName":"Idle Task Execution Limit","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the limit for idle executions of a receive task, not having received any message within its execution. If this limit is reached, the task will shut down and leave receiving to other executing tasks (in the case of dynamic scheduling; see the maxConcurrentConsumers setting). There is additional doc available from Spring."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.JmsKeyFormatStrategy","enum":["default","passthrough"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as jakarta.jms.TextMessage to a String etc."},"maxMessagesPerTask":{"kind":"parameter","displayName":"Max Messages Per Task","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The number of messages per task. -1 is unlimited. If you use a range for concurrent consumers (eg min max), then this option can be used to set a value to eg 100 to control how fast the consumers will shrink when less work is required."},"messageConverter":{"kind":"parameter","displayName":"Message Converter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.springframework.jms.support.converter.MessageConverter","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use a custom Spring org.springframework.jms.support.converter.MessageConverter so you can be in control how to map to/from a jakarta.jms.Message."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of jakarta.jms.Message objects when Camel is sending a JMS message."},"messageIdEnabled":{"kind":"parameter","displayName":"Message Id Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"When sending, specifies whether message IDs should be added. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the message ID set to null; if the provider ignores the hint, the message ID must be set to its normal unique value."},"messageListenerContainerFactory":{"kind":"parameter","displayName":"Message Listener Container Factory","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jms.MessageListenerContainerFactory","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Registry ID of the MessageListenerContainerFactory used to determine what org.springframework.jms.listener.AbstractMessageListenerContainer to use to consume messages. Setting this will automatically set consumerType to Custom."},"messageTimestampEnabled":{"kind":"parameter","displayName":"Message Timestamp Enabled","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether timestamps should be enabled by default on sending messages. This is just an hint to the JMS broker. If the JMS provider accepts this hint, these messages must have the timestamp set to zero; if the provider ignores the hint the timestamp must be set to its normal value."},"pubSubNoLocal":{"kind":"parameter","displayName":"Pub Sub No Local","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to inhibit the delivery of messages published by its own connection."},"receiveTimeout":{"kind":"parameter","displayName":"Receive Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout for receiving messages (in milliseconds)."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"requestTimeoutCheckerInterval":{"kind":"parameter","displayName":"Request Timeout Checker Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Configures how often Camel should check for timed out Exchanges when doing request/reply over JMS. By default Camel checks once per second. But if you must react faster when a timeout occurs, then you can lower this interval, to check more frequently. The timeout is determined by the option requestTimeout."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a jakarta.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transferExchange":{"kind":"parameter","displayName":"Transfer Exchange","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"You can transfer the exchange over the wire instead of just the body and headers. The following fields are transferred: In body, Out body, Fault body, In headers, Out headers, Fault headers, exchange properties, exchange exception. This requires that the objects are serializable. Camel will exclude any non-serializable objects and log it at WARN level. You must enable this option on both the producer and consumer side, so Camel knows the payloads is an Exchange and not a regular payload. Use this with caution as the data is using Java Object serialization and requires the receiver to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumers having to use compatible Camel versions!"},"useMessageIDAsCorrelationID":{"kind":"parameter","displayName":"Use Message IDAs Correlation ID","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether JMSMessageID should always be used as JMSCorrelationID for InOut messages."},"waitForProvisionCorrelationToBeUpdatedCounter":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Counter","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":50,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Number of times to wait for provisional correlation id to be updated to the actual correlation id when doing request/reply over JMS and when the option useMessageIDAsCorrelationID is enabled."},"waitForProvisionCorrelationToBeUpdatedThreadSleepingTime":{"kind":"parameter","displayName":"Wait For Provision Correlation To Be Updated Thread Sleeping Time","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"100","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Interval in millis to sleep each time while waiting for provisional correlation id to be updated."},"errorHandlerLoggingLevel":{"kind":"parameter","displayName":"Error Handler Logging Level","group":"logging","label":"consumer,logging","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to configure the default errorHandler logging level for logging uncaught exceptions."},"errorHandlerLogStackTrace":{"kind":"parameter","displayName":"Error Handler Log Stack Trace","group":"logging","label":"consumer,logging","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Allows to control whether stacktraces should be logged or not, by the default errorHandler."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Password to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Username to use with the ConnectionFactory. You can also configure username/password directly on the ConnectionFactory."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether to use transacted mode"},"transactedInOut":{"kind":"parameter","displayName":"Transacted In Out","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"Specifies whether InOut operations (request reply) default to using transacted mode If this flag is set to true, then Spring JmsTemplate will have sessionTransacted set to true, and the acknowledgeMode as transacted on the JmsTemplate used for InOut operations. Note from Spring JMS: that within a JTA transaction, the parameters passed to createQueue, createTopic methods are not taken into account. Depending on the Java EE transaction context, the container makes its own decisions on these values. Analogously, these parameters are not taken into account within a locally managed transaction either, since Spring JMS operates on an existing JMS Session in this case. Setting this flag to true will use a short local JMS transaction when running outside of a managed transaction, and a synchronized local JMS transaction in case of a managed transaction (other than an XA transaction) being present. This has the effect of a local JMS transaction being managed alongside the main transaction (which might be a native JDBC transaction), with the JMS transaction committing right after the main transaction."},"lazyCreateTransactionManager":{"kind":"parameter","displayName":"Lazy Create Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"If true, Camel will create a JmsTransactionManager, if there is no transactionManager injected when option transacted=true."},"transactionManager":{"kind":"parameter","displayName":"Transaction Manager","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"object","javaType":"org.springframework.transaction.PlatformTransactionManager","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The Spring transaction manager to use."},"transactionName":{"kind":"parameter","displayName":"Transaction Name","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The name of the transaction to use."},"transactionTimeout":{"kind":"parameter","displayName":"Transaction Timeout","group":"transaction (advanced)","label":"transaction,advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"configurationClass":"org.apache.camel.component.jms.JmsConfiguration","configurationField":"configuration","description":"The timeout value of the transaction (in seconds), if using transacted mode."}}} , {"component":{"kind":"component","name":"jmx","title":"JMX","description":"Receive JMX notifications.","deprecated":false,"firstVersion":"2.6.0","label":"monitoring","javaType":"org.apache.camel.component.jmx.JMXComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jmx","version":"3.20.3","scheme":"jmx","extendsScheme":"","syntax":"jmx:serverURL","async":false,"api":false,"consumerOnly":true,"producerOnly":false,"lenientProperties":false},"headers":{"jmx.handback":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"Object","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The handback.","constantName":"org.apache.camel.component.jmx.JMXConstants#JMX_HANDBACK"}},"properties":{"serverURL":{"kind":"path","displayName":"Server URL","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Server url comes from the remaining endpoint. Use platform to connect to local JVM."},"format":{"kind":"parameter","displayName":"Format","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["xml","raw"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"xml","description":"Format for the message body. Either xml or raw. If xml, the notification is serialized to xml. If raw, then the raw java object is set as the body."},"granularityPeriod":{"kind":"parameter","displayName":"Granularity Period","group":"consumer","label":"","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"10000","description":"The frequency to poll the bean to check the monitor (monitor types only)."},"monitorType":{"kind":"parameter","displayName":"Monitor Type","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["counter","gauge","string"],"deprecated":false,"autowired":false,"secret":false,"description":"The type of monitor to create. One of string, gauge, counter (monitor types only)."},"objectDomain":{"kind":"parameter","displayName":"Object Domain","group":"consumer","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The domain for the mbean you're connecting to"},"objectName":{"kind":"parameter","displayName":"Object Name","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The name key for the mbean you're connecting to. This value is mutually exclusive with the object properties that get passed."},"observedAttribute":{"kind":"parameter","displayName":"Observed Attribute","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The attribute to observe for the monitor bean or consumer."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"executorService":{"kind":"parameter","displayName":"Executor Service","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"java.util.concurrent.ExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom shared thread pool for the consumers. By default each consume has their own thread-pool to process and route notifications."},"handback":{"kind":"parameter","displayName":"Handback","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"java.lang.Object","deprecated":false,"autowired":false,"secret":false,"description":"Value to handback to the listener when a notification is received. This value will be put in the message header with the key JMXConstants#JMX_HANDBACK."},"notificationFilter":{"kind":"parameter","displayName":"Notification Filter","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"javax.management.NotificationFilter","deprecated":false,"autowired":false,"secret":false,"description":"Reference to a bean that implements the NotificationFilter."},"objectProperties":{"kind":"parameter","displayName":"Object Properties","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"java.util.Map","prefix":"key.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"Properties for the object name. These values will be used if the objectName param is not set"},"reconnectDelay":{"kind":"parameter","displayName":"Reconnect Delay","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":10,"description":"The number of seconds to wait before attempting to retry establishment of the initial connection or attempt to reconnect a lost connection"},"reconnectOnConnectionFailure":{"kind":"parameter","displayName":"Reconnect On Connection Failure","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true the consumer will attempt to reconnect to the JMX server when any connection failure occurs. The consumer will attempt to re-establish the JMX connection every 'x' seconds until the connection is made-- where 'x' is the configured reconnectionDelay"},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If true the consumer will throw an exception if unable to establish the JMX connection upon startup. If false, the consumer will attempt to establish the JMX connection every 'x' seconds until the connection is made -- where 'x' is the configured reconnectionDelay"},"initThreshold":{"kind":"parameter","displayName":"Init Threshold","group":"counter","label":"counter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"Initial threshold for the monitor. The value must exceed this before notifications are fired (counter monitor only)."},"modulus":{"kind":"parameter","displayName":"Modulus","group":"counter","label":"counter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The value at which the counter is reset to zero (counter monitor only)."},"offset":{"kind":"parameter","displayName":"Offset","group":"counter","label":"counter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The amount to increment the threshold after it's been exceeded (counter monitor only)."},"differenceMode":{"kind":"parameter","displayName":"Difference Mode","group":"gauge","label":"counter,gauge","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, then the value reported in the notification is the difference from the threshold as opposed to the value itself (counter and gauge monitor only)."},"notifyHigh":{"kind":"parameter","displayName":"Notify High","group":"gauge","label":"gauge","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, the gauge will fire a notification when the high threshold is exceeded (gauge monitor only)."},"notifyLow":{"kind":"parameter","displayName":"Notify Low","group":"gauge","label":"gauge","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, the gauge will fire a notification when the low threshold is exceeded (gauge monitor only)."},"thresholdHigh":{"kind":"parameter","displayName":"Threshold High","group":"gauge","label":"gauge","required":false,"type":"number","javaType":"java.lang.Double","deprecated":false,"autowired":false,"secret":false,"description":"Value for the gauge's high threshold (gauge monitor only)."},"thresholdLow":{"kind":"parameter","displayName":"Threshold Low","group":"gauge","label":"gauge","required":false,"type":"number","javaType":"java.lang.Double","deprecated":false,"autowired":false,"secret":false,"description":"Value for the gauge's low threshold (gauge monitor only)."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"description":"Credentials for making a remote connection"},"user":{"kind":"parameter","displayName":"User","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"description":"Credentials for making a remote connection"},"notifyDiffer":{"kind":"parameter","displayName":"Notify Differ","group":"string","label":"consumer,string","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, will fire a notification when the string attribute differs from the string to compare (string monitor or consumer). By default the consumer will notify match if observed attribute and string to compare has been configured."},"notifyMatch":{"kind":"parameter","displayName":"Notify Match","group":"string","label":"consumer,string","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, will fire a notification when the string attribute matches the string to compare (string monitor or consumer). By default the consumer will notify match if observed attribute and string to compare has been configured."},"stringToCompare":{"kind":"parameter","displayName":"String To Compare","group":"string","label":"consumer,string","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Value for attribute to compare (string monitor or consumer). By default the consumer will notify match if observed attribute and string to compare has been configured."}}} , @@ -551,9 +551,9 @@ , {"component":{"kind":"component","name":"sftp","title":"SFTP","description":"Upload and download files to/from SFTP servers.","deprecated":false,"deprecationNote":"","firstVersion":"1.1.0","label":"file","javaType":"org.apache.camel.component.file.remote.SftpComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-ftp","version":"3.20.3","scheme":"sftp","extendsScheme":"file","syntax":"sftp:host:port/directoryName","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelFileLength":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"A long value containing the file size.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_LENGTH"},"CamelFileLastModified":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"A Long value containing the last modified timestamp of the file.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_LAST_MODIFIED"},"CamelFileName":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Specifies the output file name (relative to the endpoint directory) to be used for the output message when sending to the endpoint. If this is not present and no expression either, then a generated message ID is used as the filename instead.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_NAME"},"CamelFileNameOnly":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Only the file name (the name with no leading paths).","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_NAME_ONLY"},"CamelFileParent":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The parent path.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_PARENT"},"CamelRemoteFileInputStream":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.io.InputStream","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The remote file input stream.","constantName":"org.apache.camel.component.file.remote.FtpConstants#REMOTE_FILE_INPUT_STREAM"},"CamelFileLocalWorkPath":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Path to the local work file, if local work directory is used.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_LOCAL_WORK_PATH"},"CamelFtpReplyCode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The FTP client reply code","constantName":"org.apache.camel.component.file.remote.FtpConstants#FTP_REPLY_CODE"},"CamelFtpReplyString":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The FTP client reply string","constantName":"org.apache.camel.component.file.remote.FtpConstants#FTP_REPLY_STRING"},"CamelFileHost":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The remote hostname.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_HOST"}},"properties":{"host":{"kind":"path","displayName":"Host","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Hostname of the FTP server"},"port":{"kind":"path","displayName":"Port","group":"common","label":"","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Port of the FTP server"},"directoryName":{"kind":"path","displayName":"Directory Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"The starting directory"},"binary":{"kind":"parameter","displayName":"Binary","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false)."},"charset":{"kind":"parameter","displayName":"Charset","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"This option is used to specify the encoding of the file. You can use this on the consumer, to specify the encodings of the files, which allow Camel to know the charset it should load the file content in case the file content is being accessed. Likewise when writing a file, you can use this option to specify which charset to write the file as well. Do mind that when writing the file Camel may have to read the message content into memory to be able to convert the data into the configured charset, so do not use this if you have big messages."},"disconnect":{"kind":"parameter","displayName":"Disconnect","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not to disconnect from remote FTP server right after use. Disconnect will only disconnect the current connection to the FTP server. If you have a consumer which you want to stop, then you need to stop the consumer/route instead."},"doneFileName":{"kind":"parameter","displayName":"Done File Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Producer: If provided, then Camel will write a 2nd done file when the original file has been written. The done file will be empty. This option configures what file name to use. Either you can specify a fixed name. Or you can use dynamic placeholders. The done file will always be written in the same folder as the original file. Consumer: If provided, Camel will only consume files if a done file exists. This option configures what file name to use. Either you can specify a fixed name. Or you can use dynamic placeholders.The done file is always expected in the same folder as the original file. Only ${file.name} and ${file.name.next} is supported as dynamic placeholders."},"fileName":{"kind":"parameter","displayName":"File Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Use Expression such as File Language to dynamically set the filename. For consumers, it's used as a filename filter. For producers, it's used to evaluate the filename to write. If an expression is set, it take precedence over the CamelFileName header. (Note: The header itself can also be an Expression). The expression options support both String and Expression types. If the expression is a String type, it is always evaluated using the File Language. If the expression is an Expression type, the specified Expression type is used - this allows you, for instance, to use OGNL expressions. For the consumer, you can use it to filter filenames, so you can for instance consume today's file using the File Language syntax: mydata-${date:now:yyyyMMdd}.txt. The producers support the CamelOverruleFileName header which takes precedence over any existing CamelFileName header; the CamelOverruleFileName is a header that is used only once, and makes it easier as this avoids to temporary store CamelFileName and have to restore it afterwards."},"jschLoggingLevel":{"kind":"parameter","displayName":"Jsch Logging Level","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"The logging level to use for JSCH activity logging. As JSCH is verbose at by default at INFO level the threshold is WARN by default."},"passiveMode":{"kind":"parameter","displayName":"Passive Mode","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets passive mode connections. Default is active mode connections."},"separator":{"kind":"parameter","displayName":"Separator","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.file.remote.RemoteFileConfiguration.PathSeparator","enum":["UNIX","Windows","Auto"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"UNIX","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the path separator to be used. UNIX = Uses unix style path separator Windows = Uses windows style path separator Auto = (is default) Use existing path separator in file name"},"fastExistsCheck":{"kind":"parameter","displayName":"Fast Exists Check","group":"common (advanced)","label":"common,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If set this option to be true, camel-ftp will use the list file directly to check if the file exists. Since some FTP server may not support to list the file directly, if the option is false, camel-ftp will use the old way to list the directory and check if the file exists. This option also influences readLock=changed to control whether it performs a fast check to update file information or not. This can be used to speed up the process if the FTP server has a lot of files."},"delete":{"kind":"parameter","displayName":"Delete","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, the file will be deleted after it is processed successfully."},"moveFailed":{"kind":"parameter","displayName":"Move Failed","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the move failure expression based on Simple language. For example, to move files into a .error subdirectory use: .error. Note: When moving the files to the fail location Camel will handle the error and will not pick up the file again."},"noop":{"kind":"parameter","displayName":"Noop","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, the file is not moved or deleted in any way. This option is good for readonly data, or for ETL type requirements. If noop=true, Camel will set idempotent=true as well, to avoid consuming the same files over and over again."},"preMove":{"kind":"parameter","displayName":"Pre Move","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Expression (such as File Language) used to dynamically set the filename when moving it before processing. For example to move in-progress files into the order directory set this value to order."},"preSort":{"kind":"parameter","displayName":"Pre Sort","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"When pre-sort is enabled then the consumer will sort the file and directory names during polling, that was retrieved from the file system. You may want to do this in case you need to operate on the files in a sorted order. The pre-sort is executed before the consumer starts to filter, and accept files to process by Camel. This option is default=false meaning disabled."},"recursive":{"kind":"parameter","displayName":"Recursive","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If a directory, will look for files in all the sub-directories as well."},"sendEmptyMessageWhenIdle":{"kind":"parameter","displayName":"Send Empty Message When Idle","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the polling consumer did not poll any files, you can enable this option to send an empty message (no body) instead."},"streamDownload":{"kind":"parameter","displayName":"Stream Download","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the download method to use when not using a local working directory. If set to true, the remote files are streamed to the route as they are read. When set to false, the remote files are loaded into memory before being sent into the route. If enabling this option then you must set stepwise=false as both cannot be enabled at the same time."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"download":{"kind":"parameter","displayName":"Download","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the FTP consumer should download the file. If this option is set to false, then the message body will be null, but the consumer will still trigger a Camel Exchange that has details about the file such as file name, file size, etc. It's just that the file will not be downloaded."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"ignoreFileNotFoundOrPermissionError":{"kind":"parameter","displayName":"Ignore File Not Found Or Permission Error","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to ignore when (trying to list files in directories or when downloading a file), which does not exist or due to permission error. By default when a directory or file does not exists or insufficient permission, then an exception is thrown. Setting this option to true allows to ignore that instead."},"inProgressRepository":{"kind":"parameter","displayName":"In Progress Repository","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.IdempotentRepository","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable in-progress repository org.apache.camel.spi.IdempotentRepository. The in-progress repository is used to account the current in progress files being consumed. By default a memory based repository is used."},"localWorkDirectory":{"kind":"parameter","displayName":"Local Work Directory","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"When consuming, a local work directory can be used to store the remote file content directly in local files, to avoid loading the content into memory. This is beneficial, if you consume a very big remote file and thus can conserve memory."},"onCompletionExceptionHandler":{"kind":"parameter","displayName":"On Completion Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom org.apache.camel.spi.ExceptionHandler to handle any thrown exceptions that happens during the file on completion process where the consumer does either a commit or rollback. The default implementation will log any exception at WARN level and ignore."},"pollStrategy":{"kind":"parameter","displayName":"Poll Strategy","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.PollingConsumerPollStrategy","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable org.apache.camel.PollingConsumerPollingStrategy allowing you to provide your custom implementation to control error handling usually occurred during the poll operation before an Exchange have been created and being routed in Camel."},"processStrategy":{"kind":"parameter","displayName":"Process Strategy","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileProcessStrategy","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable org.apache.camel.component.file.GenericFileProcessStrategy allowing you to implement your own readLock option or similar. Can also be used when special conditions must be met before a file can be consumed, such as a special ready file exists. If this option is set then the readLock option does not apply."},"useList":{"kind":"parameter","displayName":"Use List","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to allow using LIST command when downloading a file. Default is true. In some use cases you may want to download a specific file and are not allowed to use the LIST command, and therefore you can set this option to false. Notice when using this option, then the specific file to download does not include meta-data information such as file size, timestamp, permissions etc, because those information is only possible to retrieve when LIST command is in use."},"fileExist":{"kind":"parameter","displayName":"File Exist","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileExist","enum":["Override","Append","Fail","Ignore","Move","TryRename"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Override","description":"What to do if a file already exists with the same name. Override, which is the default, replaces the existing file. - Append - adds content to the existing file. - Fail - throws a GenericFileOperationException, indicating that there is already an existing file. - Ignore - silently ignores the problem and does not override the existing file, but assumes everything is okay. - Move - option requires to use the moveExisting option to be configured as well. The option eagerDeleteTargetFile can be used to control what to do if an moving the file, and there exists already an existing file, otherwise causing the move operation to fail. The Move option will move any existing files, before writing the target file. - TryRename is only applicable if tempFileName option is in use. This allows to try renaming the file from the temporary name to the actual name, without doing any exists check. This check may be faster on some file systems and especially FTP servers."},"flatten":{"kind":"parameter","displayName":"Flatten","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Flatten is used to flatten the file name path to strip any leading paths, so it's just the file name. This allows you to consume recursively into sub-directories, but when you eg write the files to another directory they will be written in a single directory. Setting this to true on the producer enforces that any file name in CamelFileName header will be stripped for any leading paths."},"jailStartingDirectory":{"kind":"parameter","displayName":"Jail Starting Directory","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Used for jailing (restricting) writing files to the starting directory (and sub) only. This is enabled by default to not allow Camel to write files to outside directories (to be more secured out of the box). You can turn this off to allow writing files to directories outside the starting directory, such as parent or root folders."},"moveExisting":{"kind":"parameter","displayName":"Move Existing","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Expression (such as File Language) used to compute file name to use when fileExist=Move is configured. To move files into a backup subdirectory just enter backup. This option only supports the following File Language tokens: file:name, file:name.ext, file:name.noext, file:onlyname, file:onlyname.noext, file:ext, and file:parent. Notice the file:parent is not supported by the FTP component, as the FTP component can only move any existing files to a relative directory based on current dir as base."},"tempFileName":{"kind":"parameter","displayName":"Temp File Name","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The same as tempPrefix option but offering a more fine grained control on the naming of the temporary filename as it uses the File Language. The location for tempFilename is relative to the final file location in the option 'fileName', not the target directory in the base uri. For example if option fileName includes a directory prefix: dir/finalFilename then tempFileName is relative to that subdirectory dir."},"tempPrefix":{"kind":"parameter","displayName":"Temp Prefix","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"This option is used to write the file using a temporary name and then, after the write is complete, rename it to the real name. Can be used to identify files being written and also avoid consumers (not using exclusive read locks) reading in progress files. Is often used by FTP when uploading big files."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Used to specify if a null body is allowed during file writing. If set to true then an empty file will be created, when set to false, and attempting to send a null body to the file component, a GenericFileWriteException of 'Cannot write null body to file.' will be thrown. If the fileExist option is set to 'Override', then the file will be truncated, and if set to append the file will remain unchanged."},"chmod":{"kind":"parameter","displayName":"Chmod","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Allows you to set chmod on the stored file. For example chmod=640."},"chmodDirectory":{"kind":"parameter","displayName":"Chmod Directory","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Allows you to set chmod during path creation. For example chmod=640."},"disconnectOnBatchComplete":{"kind":"parameter","displayName":"Disconnect On Batch Complete","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not to disconnect from remote FTP server right after a Batch upload is complete. disconnectOnBatchComplete will only disconnect the current connection to the FTP server."},"eagerDeleteTargetFile":{"kind":"parameter","displayName":"Eager Delete Target File","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether or not to eagerly delete any existing target file. This option only applies when you use fileExists=Override and the tempFileName option as well. You can use this to disable (set it to false) deleting the target file before the temp file is written. For example you may write big files and want the target file to exists during the temp file is being written. This ensure the target file is only deleted until the very last moment, just before the temp file is being renamed to the target filename. This option is also used to control whether to delete any existing files when fileExist=Move is enabled, and an existing file exists. If this option copyAndDeleteOnRenameFails false, then an exception will be thrown if an existing file existed, if its true, then the existing file is deleted before the move operation."},"keepLastModified":{"kind":"parameter","displayName":"Keep Last Modified","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Will keep the last modified timestamp from the source file (if any). Will use the FileConstants.FILE_LAST_MODIFIED header to located the timestamp. This header can contain either a java.util.Date or long with the timestamp. If the timestamp exists and the option is enabled it will set this timestamp on the written file. Note: This option only applies to the file producer. You cannot use this option with any of the ftp producers."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"moveExistingFileStrategy":{"kind":"parameter","displayName":"Move Existing File Strategy","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.file.strategy.FileMoveExistingStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Strategy (Custom Strategy) used to move file with special naming token to use when fileExist=Move is configured. By default, there is an implementation used if no custom strategy is provided"},"sendNoop":{"kind":"parameter","displayName":"Send Noop","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to send a noop command as a pre-write check before uploading files to the FTP server. This is enabled by default as a validation of the connection is still valid, which allows to silently re-connect to be able to upload the file. However if this causes problems, you can turn this option off."},"autoCreate":{"kind":"parameter","displayName":"Auto Create","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Automatically create missing directories in the file's pathname. For the file consumer, that means creating the starting directory. For the file producer, it means the directory the files should be written to."},"bindAddress":{"kind":"parameter","displayName":"Bind Address","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Specifies the address of the local interface against which the connection should bind."},"bulkRequests":{"kind":"parameter","displayName":"Bulk Requests","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Specifies how many requests may be outstanding at any one time. Increasing this value may slightly improve file transfer speed but will increase memory usage."},"compression":{"kind":"parameter","displayName":"Compression","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"To use compression. Specify a level from 1 to 10. Important: You must manually add the needed JSCH zlib JAR to the classpath for compression support."},"connectTimeout":{"kind":"parameter","displayName":"Connect Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":"10000","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the connect timeout for waiting for a connection to be established Used by both FTPClient and JSCH"},"existDirCheckUsingLs":{"kind":"parameter","displayName":"Exist Dir Check Using Ls","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to check for existing directory using LS command or CD. By default LS is used which is safer as otherwise Camel needs to change the directory back after checking. However LS has been reported to cause a problem on windows system in some situations and therefore you can disable this option to use CD."},"maximumReconnectAttempts":{"kind":"parameter","displayName":"Maximum Reconnect Attempts","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"Specifies the maximum reconnect attempts Camel performs when it tries to connect to the remote FTP server. Use 0 to disable this behavior."},"proxy":{"kind":"parameter","displayName":"Proxy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"com.jcraft.jsch.Proxy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom configured com.jcraft.jsch.Proxy. This proxy is used to consume/send messages from the target SFTP host."},"reconnectDelay":{"kind":"parameter","displayName":"Reconnect Delay","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","description":"Delay in millis Camel will wait before performing a reconnect attempt."},"serverAliveCountMax":{"kind":"parameter","displayName":"Server Alive Count Max","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the number of keep-alive messages which may be sent without receiving any messages back from the server. If this threshold is reached while keep-alive messages are being sent, the connection will be disconnected. The default value is one."},"serverAliveInterval":{"kind":"parameter","displayName":"Server Alive Interval","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the interval (millis) to send a keep-alive message. If zero is specified, any keep-alive message must not be sent. The default interval is zero."},"soTimeout":{"kind":"parameter","displayName":"So Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":"300000","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the so timeout FTP and FTPS Is the SocketOptions.SO_TIMEOUT value in millis. Recommended option is to set this to 300000 so as not have a hanged connection. On SFTP this option is set as timeout on the JSCH Session instance."},"stepwise":{"kind":"parameter","displayName":"Stepwise","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets whether we should stepwise change directories while traversing file structures when downloading files, or as well when uploading a file to a directory. You can disable this if you for example are in a situation where you cannot change directory on the FTP server due security reasons. Stepwise cannot be used together with streamDownload."},"throwExceptionOnConnectFailed":{"kind":"parameter","displayName":"Throw Exception On Connect Failed","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Should an exception be thrown if connection failed (exhausted)By default exception is not thrown and a WARN is logged. You can use this to enable exception being thrown and handle the thrown exception from the org.apache.camel.spi.PollingConsumerPollStrategy rollback method."},"timeout":{"kind":"parameter","displayName":"Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":"30000","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the data timeout for waiting for reply Used only by FTPClient"},"antExclude":{"kind":"parameter","displayName":"Ant Exclude","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Ant style filter exclusion. If both antInclude and antExclude are used, antExclude takes precedence over antInclude. Multiple exclusions may be specified in comma-delimited format."},"antFilterCaseSensitive":{"kind":"parameter","displayName":"Ant Filter Case Sensitive","group":"filter","label":"consumer,filter","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Sets case sensitive flag on ant filter."},"antInclude":{"kind":"parameter","displayName":"Ant Include","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Ant style filter inclusion. Multiple inclusions may be specified in comma-delimited format."},"eagerMaxMessagesPerPoll":{"kind":"parameter","displayName":"Eager Max Messages Per Poll","group":"filter","label":"consumer,filter","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Allows for controlling whether the limit from maxMessagesPerPoll is eager or not. If eager then the limit is during the scanning of files. Where as false would scan all files, and then perform sorting. Setting this option to false allows for sorting all files first, and then limit the poll. Mind that this requires a higher memory usage as all file details are in memory to perform the sorting."},"exclude":{"kind":"parameter","displayName":"Exclude","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to exclude files, if filename matches the regex pattern (matching is case in-sensitive). Notice if you use symbols such as plus sign and others you would need to configure this using the RAW() syntax if configuring this as an endpoint uri. See more details at configuring endpoint uris"},"excludeExt":{"kind":"parameter","displayName":"Exclude Ext","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to exclude files matching file extension name (case insensitive). For example to exclude bak files, then use excludeExt=bak. Multiple extensions can be separated by comma, for example to exclude bak and dat files, use excludeExt=bak,dat. Note that the file extension includes all parts, for example having a file named mydata.tar.gz will have extension as tar.gz. For more flexibility then use the include/exclude options."},"filter":{"kind":"parameter","displayName":"Filter","group":"filter","label":"consumer,filter","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileFilter","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable filter as a org.apache.camel.component.file.GenericFileFilter class. Will skip files if filter returns false in its accept() method."},"filterDirectory":{"kind":"parameter","displayName":"Filter Directory","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Filters the directory based on Simple language. For example to filter on current date, you can use a simple date pattern such as ${date:now:yyyMMdd}"},"filterFile":{"kind":"parameter","displayName":"Filter File","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Filters the file based on Simple language. For example to filter on file size, you can use ${file:size} 5000"},"idempotent":{"kind":"parameter","displayName":"Idempotent","group":"filter","label":"consumer,filter","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","description":"Option to use the Idempotent Consumer EIP pattern to let Camel skip already processed files. Will by default use a memory based LRUCache that holds 1000 entries. If noop=true then idempotent will be enabled as well to avoid consuming the same files over and over again."},"idempotentKey":{"kind":"parameter","displayName":"Idempotent Key","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom idempotent key. By default the absolute path of the file is used. You can use the File Language, for example to use the file name and file size, you can do: idempotentKey=${file:name}-${file:size}"},"idempotentRepository":{"kind":"parameter","displayName":"Idempotent Repository","group":"filter","label":"consumer,filter","required":false,"type":"object","javaType":"org.apache.camel.spi.IdempotentRepository","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable repository org.apache.camel.spi.IdempotentRepository which by default use MemoryIdempotentRepository if none is specified and idempotent is true."},"include":{"kind":"parameter","displayName":"Include","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to include files, if filename matches the regex pattern (matching is case in-sensitive). Notice if you use symbols such as plus sign and others you would need to configure this using the RAW() syntax if configuring this as an endpoint uri. See more details at configuring endpoint uris"},"includeExt":{"kind":"parameter","displayName":"Include Ext","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to include files matching file extension name (case insensitive). For example to include txt files, then use includeExt=txt. Multiple extensions can be separated by comma, for example to include txt and xml files, use includeExt=txt,xml. Note that the file extension includes all parts, for example having a file named mydata.tar.gz will have extension as tar.gz. For more flexibility then use the include/exclude options."},"maxDepth":{"kind":"parameter","displayName":"Max Depth","group":"filter","label":"consumer,filter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":2147483647,"description":"The maximum depth to traverse when recursively processing a directory."},"maxMessagesPerPoll":{"kind":"parameter","displayName":"Max Messages Per Poll","group":"filter","label":"consumer,filter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"To define a maximum messages to gather per poll. By default no maximum is set. Can be used to set a limit of e.g. 1000 to avoid when starting up the server that there are thousands of files. Set a value of 0 or negative to disabled it. Notice: If this option is in use then the File and FTP components will limit before any sorting. For example if you have 100000 files and use maxMessagesPerPoll=500, then only the first 500 files will be picked up, and then sorted. You can use the eagerMaxMessagesPerPoll option and set this to false to allow to scan all files first and then sort afterwards."},"minDepth":{"kind":"parameter","displayName":"Min Depth","group":"filter","label":"consumer,filter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The minimum depth to start processing when recursively processing a directory. Using minDepth=1 means the base directory. Using minDepth=2 means the first sub directory."},"move":{"kind":"parameter","displayName":"Move","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Expression (such as Simple Language) used to dynamically set the filename when moving it after processing. To move files into a .done subdirectory just enter .done."},"exclusiveReadLockStrategy":{"kind":"parameter","displayName":"Exclusive Read Lock Strategy","group":"lock","label":"consumer,lock","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileExclusiveReadLockStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable read-lock as a org.apache.camel.component.file.GenericFileExclusiveReadLockStrategy implementation."},"readLock":{"kind":"parameter","displayName":"Read Lock","group":"lock","label":"consumer,lock","required":false,"type":"string","javaType":"java.lang.String","enum":["none","markerFile","fileLock","rename","changed","idempotent","idempotent-changed","idempotent-rename"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"none","description":"Used by consumer, to only poll the files if it has exclusive read-lock on the file (i.e. the file is not in-progress or being written). Camel will wait until the file lock is granted. This option provides the build in strategies: - none - No read lock is in use - markerFile - Camel creates a marker file (fileName.camelLock) and then holds a lock on it. This option is not available for the FTP component - changed - Changed is using file length/modification timestamp to detect whether the file is currently being copied or not. Will at least use 1 sec to determine this, so this option cannot consume files as fast as the others, but can be more reliable as the JDK IO API cannot always determine whether a file is currently being used by another process. The option readLockCheckInterval can be used to set the check frequency. - fileLock - is for using java.nio.channels.FileLock. This option is not avail for Windows OS and the FTP component. This approach should be avoided when accessing a remote file system via a mount/share unless that file system supports distributed file locks. - rename - rename is for using a try to rename the file as a test if we can get exclusive read-lock. - idempotent - (only for file component) idempotent is for using a idempotentRepository as the read-lock. This allows to use read locks that supports clustering if the idempotent repository implementation supports that. - idempotent-changed - (only for file component) idempotent-changed is for using a idempotentRepository and changed as the combined read-lock. This allows to use read locks that supports clustering if the idempotent repository implementation supports that. - idempotent-rename - (only for file component) idempotent-rename is for using a idempotentRepository and rename as the combined read-lock. This allows to use read locks that supports clustering if the idempotent repository implementation supports that.Notice: The various read locks is not all suited to work in clustered mode, where concurrent consumers on different nodes is competing for the same files on a shared file system. The markerFile using a close to atomic operation to create the empty marker file, but its not guaranteed to work in a cluster. The fileLock may work better but then the file system need to support distributed file locks, and so on. Using the idempotent read lock can support clustering if the idempotent repository supports clustering, such as Hazelcast Component or Infinispan."},"readLockCheckInterval":{"kind":"parameter","displayName":"Read Lock Check Interval","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1000,"description":"Interval in millis for the read-lock, if supported by the read lock. This interval is used for sleeping between attempts to acquire the read lock. For example when using the changed read lock, you can set a higher interval period to cater for slow writes. The default of 1 sec. may be too fast if the producer is very slow writing the file. Notice: For FTP the default readLockCheckInterval is 5000. The readLockTimeout value must be higher than readLockCheckInterval, but a rule of thumb is to have a timeout that is at least 2 or more times higher than the readLockCheckInterval. This is needed to ensure that amble time is allowed for the read lock process to try to grab the lock before the timeout was hit."},"readLockDeleteOrphanLockFiles":{"kind":"parameter","displayName":"Read Lock Delete Orphan Lock Files","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether or not read lock with marker files should upon startup delete any orphan read lock files, which may have been left on the file system, if Camel was not properly shutdown (such as a JVM crash). If turning this option to false then any orphaned lock file will cause Camel to not attempt to pickup that file, this could also be due another node is concurrently reading files from the same shared directory."},"readLockIdempotentReleaseAsync":{"kind":"parameter","displayName":"Read Lock Idempotent Release Async","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the delayed release task should be synchronous or asynchronous. See more details at the readLockIdempotentReleaseDelay option."},"readLockIdempotentReleaseAsyncPoolSize":{"kind":"parameter","displayName":"Read Lock Idempotent Release Async Pool Size","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of threads in the scheduled thread pool when using asynchronous release tasks. Using a default of 1 core threads should be sufficient in almost all use-cases, only set this to a higher value if either updating the idempotent repository is slow, or there are a lot of files to process. This option is not in-use if you use a shared thread pool by configuring the readLockIdempotentReleaseExecutorService option. See more details at the readLockIdempotentReleaseDelay option."},"readLockIdempotentReleaseDelay":{"kind":"parameter","displayName":"Read Lock Idempotent Release Delay","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"Whether to delay the release task for a period of millis. This can be used to delay the release tasks to expand the window when a file is regarded as read-locked, in an active/active cluster scenario with a shared idempotent repository, to ensure other nodes cannot potentially scan and acquire the same file, due to race-conditions. By expanding the time-window of the release tasks helps prevents these situations. Note delaying is only needed if you have configured readLockRemoveOnCommit to true."},"readLockIdempotentReleaseExecutorService":{"kind":"parameter","displayName":"Read Lock Idempotent Release Executor Service","group":"lock","label":"consumer,lock","required":false,"type":"object","javaType":"java.util.concurrent.ScheduledExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom and shared thread pool for asynchronous release tasks. See more details at the readLockIdempotentReleaseDelay option."},"readLockLoggingLevel":{"kind":"parameter","displayName":"Read Lock Logging Level","group":"lock","label":"consumer,lock","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"DEBUG","description":"Logging level used when a read lock could not be acquired. By default a DEBUG is logged. You can change this level, for example to OFF to not have any logging. This option is only applicable for readLock of types: changed, fileLock, idempotent, idempotent-changed, idempotent-rename, rename."},"readLockMarkerFile":{"kind":"parameter","displayName":"Read Lock Marker File","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to use marker file with the changed, rename, or exclusive read lock types. By default a marker file is used as well to guard against other processes picking up the same files. This behavior can be turned off by setting this option to false. For example if you do not want to write marker files to the file systems by the Camel application."},"readLockMinAge":{"kind":"parameter","displayName":"Read Lock Min Age","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":0,"description":"This option is applied only for readLock=changed. It allows to specify a minimum age the file must be before attempting to acquire the read lock. For example use readLockMinAge=300s to require the file is at last 5 minutes old. This can speedup the changed read lock as it will only attempt to acquire files which are at least that given age."},"readLockMinLength":{"kind":"parameter","displayName":"Read Lock Min Length","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"This option is applied only for readLock=changed. It allows you to configure a minimum file length. By default Camel expects the file to contain data, and thus the default value is 1. You can set this option to zero, to allow consuming zero-length files."},"readLockRemoveOnCommit":{"kind":"parameter","displayName":"Read Lock Remove On Commit","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"This option is applied only for readLock=idempotent. It allows to specify whether to remove the file name entry from the idempotent repository when processing the file is succeeded and a commit happens. By default the file is not removed which ensures that any race-condition do not occur so another active node may attempt to grab the file. Instead the idempotent repository may support eviction strategies that you can configure to evict the file name entry after X minutes - this ensures no problems with race conditions. See more details at the readLockIdempotentReleaseDelay option."},"readLockRemoveOnRollback":{"kind":"parameter","displayName":"Read Lock Remove On Rollback","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"This option is applied only for readLock=idempotent. It allows to specify whether to remove the file name entry from the idempotent repository when processing the file failed and a rollback happens. If this option is false, then the file name entry is confirmed (as if the file did a commit)."},"readLockTimeout":{"kind":"parameter","displayName":"Read Lock Timeout","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":10000,"description":"Optional timeout in millis for the read-lock, if supported by the read-lock. If the read-lock could not be granted and the timeout triggered, then Camel will skip the file. At next poll Camel, will try the file again, and this time maybe the read-lock could be granted. Use a value of 0 or lower to indicate forever. Currently fileLock, changed and rename support the timeout. Notice: For FTP the default readLockTimeout value is 20000 instead of 10000. The readLockTimeout value must be higher than readLockCheckInterval, but a rule of thumb is to have a timeout that is at least 2 or more times higher than the readLockCheckInterval. This is needed to ensure that amble time is allowed for the read lock process to try to grab the lock before the timeout was hit."},"backoffErrorThreshold":{"kind":"parameter","displayName":"Backoff Error Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent error polls (failed due some error) that should happen before the backoffMultipler should kick-in."},"backoffIdleThreshold":{"kind":"parameter","displayName":"Backoff Idle Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent idle polls that should happen before the backoffMultipler should kick-in."},"backoffMultiplier":{"kind":"parameter","displayName":"Backoff Multiplier","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"To let the scheduled polling consumer backoff if there has been a number of subsequent idles/errors in a row. The multiplier is then the number of polls that will be skipped before the next actual attempt is happening again. When this option is in use then backoffIdleThreshold and/or backoffErrorThreshold must also be configured."},"delay":{"kind":"parameter","displayName":"Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":500,"description":"Milliseconds before the next poll."},"greedy":{"kind":"parameter","displayName":"Greedy","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If greedy is enabled, then the ScheduledPollConsumer will run immediately again, if the previous run polled 1 or more messages."},"initialDelay":{"kind":"parameter","displayName":"Initial Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1000,"description":"Milliseconds before the first poll starts."},"repeatCount":{"kind":"parameter","displayName":"Repeat Count","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":0,"description":"Specifies a maximum limit of number of fires. So if you set it to 1, the scheduler will only fire once. If you set it to 5, it will only fire five times. A value of zero or negative means fire forever."},"runLoggingLevel":{"kind":"parameter","displayName":"Run Logging Level","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"TRACE","description":"The consumer logs a start/complete log line when it polls. This option allows you to configure the logging level for that."},"scheduledExecutorService":{"kind":"parameter","displayName":"Scheduled Executor Service","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.ScheduledExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"Allows for configuring a custom/shared thread pool to use for the consumer. By default each consumer has its own single threaded thread pool."},"scheduler":{"kind":"parameter","displayName":"Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.lang.Object","deprecated":false,"autowired":false,"secret":false,"defaultValue":"none","description":"To use a cron scheduler from either camel-spring or camel-quartz component. Use value spring or quartz for built in scheduler"},"schedulerProperties":{"kind":"parameter","displayName":"Scheduler Properties","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.Map","prefix":"scheduler.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"To configure additional properties when using a custom scheduler or any of the Quartz, Spring based scheduler."},"startScheduler":{"kind":"parameter","displayName":"Start Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether the scheduler should be auto started."},"timeUnit":{"kind":"parameter","displayName":"Time Unit","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.TimeUnit","enum":["NANOSECONDS","MICROSECONDS","MILLISECONDS","SECONDS","MINUTES","HOURS","DAYS"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"MILLISECONDS","description":"Time unit for initialDelay and delay options."},"useFixedDelay":{"kind":"parameter","displayName":"Use Fixed Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Controls if fixed delay or fixed rate is used. See ScheduledExecutorService in JDK for details."},"ciphers":{"kind":"parameter","displayName":"Ciphers","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of ciphers that will be used in order of preference. Possible cipher names are defined by JCraft JSCH. Some examples include: aes128-ctr,aes128-cbc,3des-ctr,3des-cbc,blowfish-cbc,aes192-cbc,aes256-cbc. If not specified the default list from JSCH will be used."},"keyExchangeProtocols":{"kind":"parameter","displayName":"Key Exchange Protocols","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of key exchange protocols that will be used in order of preference. Possible cipher names are defined by JCraft JSCH. Some examples include: diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1,diffie-hellman-group14-sha1, diffie-hellman-group-exchange-sha256,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521. If not specified the default list from JSCH will be used."},"keyPair":{"kind":"parameter","displayName":"Key Pair","group":"security","label":"security","required":false,"type":"object","javaType":"java.security.KeyPair","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets a key pair of the public and private key so to that the SFTP endpoint can do public/private key verification."},"knownHosts":{"kind":"parameter","displayName":"Known Hosts","group":"security","label":"security","required":false,"type":"string","javaType":"byte[]","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the known_hosts from the byte array, so that the SFTP endpoint can do host key verification."},"knownHostsFile":{"kind":"parameter","displayName":"Known Hosts File","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the known_hosts file, so that the SFTP endpoint can do host key verification."},"knownHostsUri":{"kind":"parameter","displayName":"Known Hosts Uri","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the known_hosts file (loaded from classpath by default), so that the SFTP endpoint can do host key verification."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Password to use for login"},"preferredAuthentications":{"kind":"parameter","displayName":"Preferred Authentications","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the preferred authentications which SFTP endpoint will used. Some example include:password,publickey. If not specified the default list from JSCH will be used."},"privateKey":{"kind":"parameter","displayName":"Private Key","group":"security","label":"security","required":false,"type":"string","javaType":"byte[]","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key as byte so that the SFTP endpoint can do private key verification."},"privateKeyFile":{"kind":"parameter","displayName":"Private Key File","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key file so that the SFTP endpoint can do private key verification."},"privateKeyPassphrase":{"kind":"parameter","displayName":"Private Key Passphrase","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key file passphrase so that the SFTP endpoint can do private key verification."},"privateKeyUri":{"kind":"parameter","displayName":"Private Key Uri","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key file (loaded from classpath by default) so that the SFTP endpoint can do private key verification."},"publicKeyAcceptedAlgorithms":{"kind":"parameter","displayName":"Public Key Accepted Algorithms","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of public key accepted algorithms. Some examples include: ssh-dss,ssh-rsa,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521. If not specified the default list from JSCH will be used."},"serverHostKeys":{"kind":"parameter","displayName":"Server Host Keys","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of algorithms supported for the server host key. Some examples include: ssh-dss,ssh-rsa,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521. If not specified the default list from JSCH will be used."},"strictHostKeyChecking":{"kind":"parameter","displayName":"Strict Host Key Checking","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","enum":["no","yes"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"no","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets whether to use strict host key checking."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Username to use for login"},"useUserKnownHostsFile":{"kind":"parameter","displayName":"Use User Known Hosts File","group":"security","label":"security","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"If knownHostFile has not been explicit configured then use the host file from System.getProperty(user.home)/.ssh/known_hosts"},"shuffle":{"kind":"parameter","displayName":"Shuffle","group":"sort","label":"consumer,sort","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"To shuffle the list of files (sort in random order)"},"sortBy":{"kind":"parameter","displayName":"Sort By","group":"sort","label":"consumer,sort","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Built-in sort by using the File Language. Supports nested sorts, so you can have a sort by file name and as a 2nd group sort by modified date."},"sorter":{"kind":"parameter","displayName":"Sorter","group":"sort","label":"consumer,sort","required":false,"type":"object","javaType":"java.util.Comparator>","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable sorter as a java.util.Comparator class."}}} , -{"component":{"kind":"component","name":"sjms","title":"Simple JMS","description":"Send and receive messages to/from a JMS Queue or Topic using plain JMS 1.x API.","deprecated":false,"firstVersion":"2.11.0","label":"messaging","javaType":"org.apache.camel.component.sjms.SjmsComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-sjms","version":"3.20.3","scheme":"sjms","extendsScheme":"","syntax":"sjms:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJMSDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_DESTINATION_NAME"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REQUEST_TIMEOUT"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The correlation ID.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_CORRELATION_ID"},"JMSReplyTo":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REPLY_TO"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name."},"acknowledgementMode":{"kind":"parameter","displayName":"Acknowledgement Mode","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.SessionAcknowledgementType","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"common","required":false,"type":"object","javaType":"javax.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether the consumer container should auto-startup."},"clientId":{"kind":"parameter","displayName":"Client Id","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether to use persistent delivery by default for replies."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"messageSelector":{"kind":"parameter","displayName":"Message Selector","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS Message selector syntax."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"description":"Specifies the delivery mode to be used. Possible values are those defined by javax.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether persistent delivery is used by default."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.ReplyToType","enum":["Temporary","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Exclusive is used."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to startup the consumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to stop the consumer message listener asynchronously, when stopping a route."},"destinationCreationStrategy":{"kind":"parameter","displayName":"Destination Creation Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.DestinationCreationStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom DestinationCreationStrategy."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"javax.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.JmsKeyFormatStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as javax.jms.TextMessage to a String etc. See section about how mapping works below for more details."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of javax.jms.Message objects when Camel is sending a JMS message."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a javax.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to use transacted mode"}}} +{"component":{"kind":"component","name":"sjms","title":"Simple JMS","description":"Send and receive messages to/from a JMS Queue or Topic using plain JMS 1.x API.","deprecated":false,"firstVersion":"2.11.0","label":"messaging","javaType":"org.apache.camel.component.sjms.SjmsComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-sjms","version":"3.20.3","scheme":"sjms","extendsScheme":"","syntax":"sjms:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJMSDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_DESTINATION_NAME"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REQUEST_TIMEOUT"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The correlation ID.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_CORRELATION_ID"},"JMSReplyTo":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REPLY_TO"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name."},"acknowledgementMode":{"kind":"parameter","displayName":"Acknowledgement Mode","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.SessionAcknowledgementType","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"common","required":false,"type":"object","javaType":"jakarta.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether the consumer container should auto-startup."},"clientId":{"kind":"parameter","displayName":"Client Id","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether to use persistent delivery by default for replies."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"messageSelector":{"kind":"parameter","displayName":"Message Selector","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS Message selector syntax."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"description":"Specifies the delivery mode to be used. Possible values are those defined by jakarta.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether persistent delivery is used by default."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.ReplyToType","enum":["Temporary","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Exclusive is used."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to startup the consumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to stop the consumer message listener asynchronously, when stopping a route."},"destinationCreationStrategy":{"kind":"parameter","displayName":"Destination Creation Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.DestinationCreationStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom DestinationCreationStrategy."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"jakarta.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.JmsKeyFormatStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as jakarta.jms.TextMessage to a String etc. See section about how mapping works below for more details."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of jakarta.jms.Message objects when Camel is sending a JMS message."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a jakarta.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to use transacted mode"}}} , -{"component":{"kind":"component","name":"sjms2","title":"Simple JMS2","description":"Send and receive messages to/from a JMS Queue or Topic using plain JMS 2.x API.","deprecated":false,"firstVersion":"2.19.0","label":"messaging","javaType":"org.apache.camel.component.sjms2.Sjms2Component","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-sjms2","version":"3.20.3","scheme":"sjms2","extendsScheme":"sjms","syntax":"sjms2:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJMSDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_DESTINATION_NAME"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REQUEST_TIMEOUT"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The correlation ID.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_CORRELATION_ID"},"JMSReplyTo":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REPLY_TO"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name."},"acknowledgementMode":{"kind":"parameter","displayName":"Acknowledgement Mode","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.SessionAcknowledgementType","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"common","required":false,"type":"object","javaType":"javax.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether the consumer container should auto-startup."},"clientId":{"kind":"parameter","displayName":"Client Id","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"durable":{"kind":"parameter","displayName":"Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets the topic to be durable"},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether to use persistent delivery by default for replies."},"shared":{"kind":"parameter","displayName":"Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets the topic to be shared"},"subscriptionId":{"kind":"parameter","displayName":"Subscription Id","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the topic subscription id, required for durable or shared topics."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"messageSelector":{"kind":"parameter","displayName":"Message Selector","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS Message selector syntax."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"description":"Specifies the delivery mode to be used. Possible values are those defined by javax.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether persistent delivery is used by default."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.ReplyToType","enum":["Temporary","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Exclusive is used."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to startup the consumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to stop the consumer message listener asynchronously, when stopping a route."},"destinationCreationStrategy":{"kind":"parameter","displayName":"Destination Creation Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.DestinationCreationStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom DestinationCreationStrategy."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"javax.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.JmsKeyFormatStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as javax.jms.TextMessage to a String etc. See section about how mapping works below for more details."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of javax.jms.Message objects when Camel is sending a JMS message."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a javax.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to use transacted mode"}}} +{"component":{"kind":"component","name":"sjms2","title":"Simple JMS2","description":"Send and receive messages to/from a JMS Queue or Topic using plain JMS 2.x API.","deprecated":false,"firstVersion":"2.19.0","label":"messaging","javaType":"org.apache.camel.component.sjms2.Sjms2Component","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-sjms2","version":"3.20.3","scheme":"sjms2","extendsScheme":"sjms","syntax":"sjms2:destinationType:destinationName","async":true,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelJMSDestinationName":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_DESTINATION_NAME"},"CamelJmsRequestTimeout":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds).","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REQUEST_TIMEOUT"},"JMSCorrelationID":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The correlation ID.","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_CORRELATION_ID"},"JMSReplyTo":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)","constantName":"org.apache.camel.component.sjms.SjmsConstants#JMS_REPLY_TO"}},"properties":{"destinationType":{"kind":"path","displayName":"Destination Type","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["queue","topic"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"queue","description":"The kind of destination to use"},"destinationName":{"kind":"path","displayName":"Destination Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"DestinationName is a JMS queue or topic name. By default, the destinationName is interpreted as a queue name."},"acknowledgementMode":{"kind":"parameter","displayName":"Acknowledgement Mode","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.SessionAcknowledgementType","enum":["SESSION_TRANSACTED","CLIENT_ACKNOWLEDGE","AUTO_ACKNOWLEDGE","DUPS_OK_ACKNOWLEDGE"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"AUTO_ACKNOWLEDGE","description":"The JMS acknowledgement name, which is one of: SESSION_TRANSACTED, CLIENT_ACKNOWLEDGE, AUTO_ACKNOWLEDGE, DUPS_OK_ACKNOWLEDGE"},"connectionFactory":{"kind":"parameter","displayName":"Connection Factory","group":"common","label":"common","required":false,"type":"object","javaType":"jakarta.jms.ConnectionFactory","deprecated":false,"autowired":false,"secret":false,"description":"The connection factory to be use. A connection factory must be configured either on the component or endpoint."},"disableReplyTo":{"kind":"parameter","displayName":"Disable Reply To","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether Camel ignores the JMSReplyTo header in messages. If true, Camel does not send a reply back to the destination specified in the JMSReplyTo header. You can use this option if you want Camel to consume from a route and you do not want Camel to automatically send back a reply message because another component in your code handles the reply message. You can also use this option if you want to use Camel as a proxy between different message brokers and you want to route message from one system to another."},"replyTo":{"kind":"parameter","displayName":"Reply To","group":"common","label":"common","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination (overrides any incoming value of Message.getJMSReplyTo() in consumer)."},"testConnectionOnStartup":{"kind":"parameter","displayName":"Test Connection On Startup","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to test the connection on startup. This ensures that when Camel starts that all the JMS consumers have a valid connection to the JMS broker. If a connection cannot be granted then Camel throws an exception on startup. This ensures that Camel is not started with failed connections. The JMS producers is tested as well."},"asyncConsumer":{"kind":"parameter","displayName":"Async Consumer","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the JmsConsumer processes the Exchange asynchronously. If enabled then the JmsConsumer may pickup the next message from the JMS queue, while the previous message is being processed asynchronously (by the Asynchronous Routing Engine). This means that messages may be processed not 100% strictly in order. If disabled (as default) then the Exchange is fully processed before the JmsConsumer will pickup the next message from the JMS queue. Note if transacted has been enabled, then asyncConsumer=true does not run asynchronously, as transaction must be executed synchronously (Camel 3.0 may support async transactions)."},"autoStartup":{"kind":"parameter","displayName":"Auto Startup","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether the consumer container should auto-startup."},"clientId":{"kind":"parameter","displayName":"Client Id","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS client ID to use. Note that this value, if specified, must be unique and can only be used by a single JMS connection instance. It is typically only required for durable topic subscriptions. If using Apache ActiveMQ you may prefer to use Virtual Topics instead."},"concurrentConsumers":{"kind":"parameter","displayName":"Concurrent Consumers","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when consuming from JMS (not for request/reply over JMS). See also the maxMessagesPerTask option to control dynamic scaling up/down of threads. When doing request/reply over JMS then the option replyToConcurrentConsumers is used to control number of concurrent consumers on the reply message listener."},"durable":{"kind":"parameter","displayName":"Durable","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets the topic to be durable"},"durableSubscriptionName":{"kind":"parameter","displayName":"Durable Subscription Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The durable subscriber name for specifying durable topic subscriptions. The clientId option must be configured as well."},"replyToDeliveryPersistent":{"kind":"parameter","displayName":"Reply To Delivery Persistent","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether to use persistent delivery by default for replies."},"shared":{"kind":"parameter","displayName":"Shared","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets the topic to be shared"},"subscriptionId":{"kind":"parameter","displayName":"Subscription Id","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the topic subscription id, required for durable or shared topics."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerLoadingOfProperties":{"kind":"parameter","displayName":"Eager Loading Of Properties","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Enables eager loading of JMS properties and payload as soon as a message is loaded which generally is inefficient as the JMS properties may not be required but sometimes can catch early any issues with the underlying JMS provider and the use of JMS properties. See also the option eagerPoisonBody."},"eagerPoisonBody":{"kind":"parameter","displayName":"Eager Poison Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"Poison JMS message due to ${exception.message}","description":"If eagerLoadingOfProperties is enabled and the JMS message payload (JMS body or JMS properties) is poison (cannot be read/mapped), then set this text as the message body instead so the message can be processed (the cause of the poison are already stored as exception on the Exchange). This can be turned off by setting eagerPoisonBody=false. See also the option eagerLoadingOfProperties."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"messageSelector":{"kind":"parameter","displayName":"Message Selector","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the JMS Message selector syntax."},"replyToSameDestinationAllowed":{"kind":"parameter","displayName":"Reply To Same Destination Allowed","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether a JMS consumer is allowed to send a reply message to the same destination that the consumer is using to consume from. This prevents an endless loop by consuming and sending back the same message to itself."},"deliveryMode":{"kind":"parameter","displayName":"Delivery Mode","group":"producer","label":"producer","required":false,"type":"integer","javaType":"java.lang.Integer","enum":["1","2"],"deprecated":false,"autowired":false,"secret":false,"description":"Specifies the delivery mode to be used. Possible values are those defined by jakarta.jms.DeliveryMode. NON_PERSISTENT = 1 and PERSISTENT = 2."},"deliveryPersistent":{"kind":"parameter","displayName":"Delivery Persistent","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether persistent delivery is used by default."},"priority":{"kind":"parameter","displayName":"Priority","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","enum":["1","2","3","4","5","6","7","8","9"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":4,"description":"Values greater than 1 specify the message priority when sending (where 1 is the lowest priority and 9 is the highest). The explicitQosEnabled option must also be enabled in order for this option to have any effect."},"replyToConcurrentConsumers":{"kind":"parameter","displayName":"Reply To Concurrent Consumers","group":"producer","label":"producer","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"Specifies the default number of concurrent consumers when doing request/reply over JMS. See also the maxMessagesPerTask option to control dynamic scaling up/down of threads."},"replyToOverride":{"kind":"parameter","displayName":"Reply To Override","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Provides an explicit ReplyTo destination in the JMS message, which overrides the setting of replyTo. It is useful if you want to forward the message to a remote Queue and receive the reply message from the ReplyTo destination."},"replyToType":{"kind":"parameter","displayName":"Reply To Type","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.ReplyToType","enum":["Temporary","Exclusive"],"deprecated":false,"autowired":false,"secret":false,"description":"Allows for explicitly specifying which kind of strategy to use for replyTo queues when doing request/reply over JMS. Possible values are: Temporary or Exclusive. By default Camel will use temporary queues. However if replyTo has been configured, then Exclusive is used."},"requestTimeout":{"kind":"parameter","displayName":"Request Timeout","group":"producer","label":"producer","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"20000","description":"The timeout for waiting for a reply when using the InOut Exchange Pattern (in milliseconds). The default is 20 seconds. You can include the header CamelJmsRequestTimeout to override this endpoint configured timeout value, and thus have per message individual timeout values. See also the requestTimeoutCheckerInterval option."},"timeToLive":{"kind":"parameter","displayName":"Time To Live","group":"producer","label":"producer","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":-1,"description":"When sending messages, specifies the time-to-live of the message (in milliseconds)."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to allow sending messages with no body. If this option is false and the message body is null, then an JMSException is thrown."},"disableTimeToLive":{"kind":"parameter","displayName":"Disable Time To Live","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Use this option to force disabling time to live. For example when you do request/reply over JMS, then Camel will by default use the requestTimeout value as time to live on the message being sent. The problem is that the sender and receiver systems have to have their clocks synchronized, so they are in sync. This is not always so easy to archive. So you can use disableTimeToLive=true to not set a time to live value on the sent message. Then the message will not expire on the receiver system. See below in section About time to live for more details."},"explicitQosEnabled":{"kind":"parameter","displayName":"Explicit Qos Enabled","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","description":"Set if the deliveryMode, priority or timeToLive qualities of service should be used when sending messages. This option is based on Spring's JmsTemplate. The deliveryMode, priority and timeToLive options are applied to the current endpoint. This contrasts with the preserveMessageQos option, which operates at message granularity, reading QoS properties exclusively from the Camel In message headers."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"preserveMessageQos":{"kind":"parameter","displayName":"Preserve Message Qos","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Set to true, if you want to send message using the QoS settings specified on the message, instead of the QoS settings on the JMS endpoint. The following three headers are considered JMSPriority, JMSDeliveryMode, and JMSExpiration. You can provide all or only some of them. If not provided, Camel will fall back to use the values from the endpoint instead. So, when using this option, the headers override the values from the endpoint. The explicitQosEnabled option, by contrast, will only use options set on the endpoint, and not values from the message header."},"asyncStartListener":{"kind":"parameter","displayName":"Async Start Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to startup the consumer message listener asynchronously, when starting a route. For example if a JmsConsumer cannot get a connection to a remote JMS broker, then it may block while retrying and/or failover. This will cause Camel to block while starting routes. By setting this option to true, you will let routes startup, while the JmsConsumer connects to the JMS broker using a dedicated thread in asynchronous mode. If this option is used, then beware that if the connection could not be established, then an exception is logged at WARN level, and the consumer will not be able to receive messages; You can then restart the route to retry."},"asyncStopListener":{"kind":"parameter","displayName":"Async Stop Listener","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to stop the consumer message listener asynchronously, when stopping a route."},"destinationCreationStrategy":{"kind":"parameter","displayName":"Destination Creation Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.DestinationCreationStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom DestinationCreationStrategy."},"exceptionListener":{"kind":"parameter","displayName":"Exception Listener","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"jakarta.jms.ExceptionListener","deprecated":false,"autowired":false,"secret":false,"description":"Specifies the JMS Exception Listener that is to be notified of any underlying JMS exceptions."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"includeAllJMSXProperties":{"kind":"parameter","displayName":"Include All JMSXProperties","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to include all JMSXxxx properties when mapping from JMS to Camel Message. Setting this to true will include properties such as JMSXAppID, and JMSXUserID etc. Note: If you are using a custom headerFilterStrategy then this option does not apply."},"jmsKeyFormatStrategy":{"kind":"parameter","displayName":"Jms Key Format Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.JmsKeyFormatStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable strategy for encoding and decoding JMS keys so they can be compliant with the JMS specification. Camel provides two implementations out of the box: default and passthrough. The default strategy will safely marshal dots and hyphens (. and -). The passthrough strategy leaves the key as is. Can be used for JMS brokers which do not care whether JMS header keys contain illegal characters. You can provide your own implementation of the org.apache.camel.component.jms.JmsKeyFormatStrategy and refer to it using the # notation."},"mapJmsMessage":{"kind":"parameter","displayName":"Map Jms Message","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Specifies whether Camel should auto map the received JMS message to a suited payload type, such as jakarta.jms.TextMessage to a String etc. See section about how mapping works below for more details."},"messageCreatedStrategy":{"kind":"parameter","displayName":"Message Created Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.sjms.jms.MessageCreatedStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use the given MessageCreatedStrategy which are invoked when Camel creates new instances of jakarta.jms.Message objects when Camel is sending a JMS message."},"recoveryInterval":{"kind":"parameter","displayName":"Recovery Interval","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"5000","description":"Specifies the interval between recovery attempts, i.e. when a connection is being refreshed, in milliseconds. The default is 5000 ms, that is, 5 seconds."},"synchronous":{"kind":"parameter","displayName":"Synchronous","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets whether synchronous processing should be strictly used"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and you are using Request Reply messaging (InOut) and an Exchange failed on the consumer side, then the caused Exception will be send back in response as a jakarta.jms.ObjectMessage. If the client is Camel, the returned Exception is rethrown. This allows you to use Camel JMS as a bridge in your routing - for example, using persistent queues to enable robust routing. Notice that if you also have transferExchange enabled, this option takes precedence. The caught exception is required to be serializable. The original Exception on the consumer side can be wrapped in an outer exception such as org.apache.camel.RuntimeCamelException when returned to the producer. Use this with caution as the data is using Java Object serialization and requires the received to be able to deserialize the data at Class level, which forces a strong coupling between the producers and consumer!"},"transacted":{"kind":"parameter","displayName":"Transacted","group":"transaction","label":"transaction","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to use transacted mode"}}} , {"component":{"kind":"component","name":"slack","title":"Slack","description":"Send and receive messages to/from Slack.","deprecated":false,"firstVersion":"2.16.0","label":"social","javaType":"org.apache.camel.component.slack.SlackComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-slack","version":"3.20.3","scheme":"slack","extendsScheme":"","syntax":"slack:channel","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"properties":{"channel":{"kind":"path","displayName":"Channel","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The channel name (syntax #name) or slack user (syntax userName) to send a message directly to an user."},"token":{"kind":"parameter","displayName":"Token","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"description":"The token to access Slack. This app needs to have channels:history, groups:history, im:history, mpim:history, channels:read, groups:read, im:read and mpim:read permissions. The User OAuth Token is the kind of token needed."},"conversationType":{"kind":"parameter","displayName":"Conversation Type","group":"consumer","label":"consumer","required":false,"type":"object","javaType":"com.slack.api.model.ConversationType","enum":["PUBLIC_CHANNEL","PRIVATE_CHANNEL","MPIM","IM"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"PUBLIC_CHANNEL","description":"Type of conversation"},"maxResults":{"kind":"parameter","displayName":"Max Results","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"10","description":"The Max Result for the poll"},"naturalOrder":{"kind":"parameter","displayName":"Natural Order","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Create exchanges in natural order (oldest to newest) or not"},"sendEmptyMessageWhenIdle":{"kind":"parameter","displayName":"Send Empty Message When Idle","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the polling consumer did not poll any files, you can enable this option to send an empty message (no body) instead."},"serverUrl":{"kind":"parameter","displayName":"Server Url","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"https://slack.com","description":"The Server URL of the Slack instance"},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"pollStrategy":{"kind":"parameter","displayName":"Poll Strategy","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.PollingConsumerPollStrategy","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable org.apache.camel.PollingConsumerPollingStrategy allowing you to provide your custom implementation to control error handling usually occurred during the poll operation before an Exchange have been created and being routed in Camel."},"iconEmoji":{"kind":"parameter","displayName":"Icon Emoji","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":true,"autowired":false,"secret":false,"description":"Use a Slack emoji as an avatar"},"iconUrl":{"kind":"parameter","displayName":"Icon Url","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":true,"autowired":false,"secret":false,"description":"The avatar that the component will use when sending message to a channel or user."},"username":{"kind":"parameter","displayName":"Username","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":true,"autowired":false,"secret":true,"description":"This is the username that the bot will have when sending messages to a channel or user."},"webhookUrl":{"kind":"parameter","displayName":"Webhook Url","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The incoming webhook URL"},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"backoffErrorThreshold":{"kind":"parameter","displayName":"Backoff Error Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent error polls (failed due some error) that should happen before the backoffMultipler should kick-in."},"backoffIdleThreshold":{"kind":"parameter","displayName":"Backoff Idle Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent idle polls that should happen before the backoffMultipler should kick-in."},"backoffMultiplier":{"kind":"parameter","displayName":"Backoff Multiplier","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"To let the scheduled polling consumer backoff if there has been a number of subsequent idles/errors in a row. The multiplier is then the number of polls that will be skipped before the next actual attempt is happening again. When this option is in use then backoffIdleThreshold and/or backoffErrorThreshold must also be configured."},"delay":{"kind":"parameter","displayName":"Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":500,"description":"Milliseconds before the next poll."},"greedy":{"kind":"parameter","displayName":"Greedy","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If greedy is enabled, then the ScheduledPollConsumer will run immediately again, if the previous run polled 1 or more messages."},"initialDelay":{"kind":"parameter","displayName":"Initial Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1000,"description":"Milliseconds before the first poll starts."},"repeatCount":{"kind":"parameter","displayName":"Repeat Count","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":0,"description":"Specifies a maximum limit of number of fires. So if you set it to 1, the scheduler will only fire once. If you set it to 5, it will only fire five times. A value of zero or negative means fire forever."},"runLoggingLevel":{"kind":"parameter","displayName":"Run Logging Level","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"TRACE","description":"The consumer logs a start/complete log line when it polls. This option allows you to configure the logging level for that."},"scheduledExecutorService":{"kind":"parameter","displayName":"Scheduled Executor Service","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.ScheduledExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"Allows for configuring a custom/shared thread pool to use for the consumer. By default each consumer has its own single threaded thread pool."},"scheduler":{"kind":"parameter","displayName":"Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.lang.Object","deprecated":false,"autowired":false,"secret":false,"defaultValue":"none","description":"To use a cron scheduler from either camel-spring or camel-quartz component. Use value spring or quartz for built in scheduler"},"schedulerProperties":{"kind":"parameter","displayName":"Scheduler Properties","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.Map","prefix":"scheduler.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"To configure additional properties when using a custom scheduler or any of the Quartz, Spring based scheduler."},"startScheduler":{"kind":"parameter","displayName":"Start Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether the scheduler should be auto started."},"timeUnit":{"kind":"parameter","displayName":"Time Unit","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.TimeUnit","enum":["NANOSECONDS","MICROSECONDS","MILLISECONDS","SECONDS","MINUTES","HOURS","DAYS"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"MILLISECONDS","description":"Time unit for initialDelay and delay options."},"useFixedDelay":{"kind":"parameter","displayName":"Use Fixed Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Controls if fixed delay or fixed rate is used. See ScheduledExecutorService in JDK for details."}}} , From b70e84cb57d6605608a3a40e8d0a25bffe7fd651 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 15:24:57 +0200 Subject: [PATCH 10/64] use newer interface Signed-off-by: Iliyan Velichkov --- .../service/ConnectionArtifacts.java | 39 +++++++------------ 1 file changed, 14 insertions(+), 25 deletions(-) diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java index 4d261baadf1..34783886611 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/service/ConnectionArtifacts.java @@ -10,12 +10,11 @@ */ package org.eclipse.dirigible.components.listeners.service; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; import jakarta.jms.Connection; -import jakarta.jms.JMSException; import jakarta.jms.MessageConsumer; import jakarta.jms.Session; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; /** * The Class ConnectionArtifacts. @@ -51,32 +50,22 @@ public ConnectionArtifacts(Connection connection, Session session, MessageConsum * Close all. */ public void closeAll() { - closeMessageConsumer(); - closeSession(); - closeConnection(); - } - - private void closeMessageConsumer() { - try { - messageConsumer.close(); - } catch (RuntimeException | JMSException ex) { - LOGGER.warn("Failed to close message consumer", ex); - } + close(messageConsumer); + close(session); + close(connection); } - private void closeConnection() { + /** + * Close. + * + * @param closeable the closeable + */ + private void close(AutoCloseable closeable) { try { - connection.close(); - } catch (RuntimeException | JMSException ex) { - LOGGER.warn("Failed to close conneciton", ex); + closeable.close(); + } catch (Exception ex) { + LOGGER.warn("Failed to close {}", closeable, ex); } - } - private void closeSession() { - try { - session.close(); - } catch (RuntimeException | JMSException ex) { - LOGGER.warn("Failed to close session", ex); - } } } From 8222340db36eee5c67754c6c54ce1232549636e7 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 15:31:37 +0200 Subject: [PATCH 11/64] minor fixes Signed-off-by: Iliyan Velichkov --- .../java/org/eclipse/dirigible/DirigibleApplication.java | 6 +++--- .../components/listeners/config/MessagingConfig.java | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java b/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java index 5fe4c9a4c7d..bea1b5f4c26 100644 --- a/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java +++ b/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java @@ -37,17 +37,17 @@ public static void main(String[] args) { } @Bean - public RestTemplate restTemplate(RestTemplateBuilder builder) { + RestTemplate restTemplate(RestTemplateBuilder builder) { return builder.build(); } @EventListener - public void onStartup(ApplicationReadyEvent event) { + void onStartup(@SuppressWarnings("unused") ApplicationReadyEvent event) { LOGGER.info("------------------------ Dirigible started ------------------------"); } @EventListener - public void onShutdown(ContextClosedEvent event) { + void onShutdown(@SuppressWarnings("unused") ContextClosedEvent event) { LOGGER.info("------------------------ Dirigible stopped ------------------------"); } } diff --git a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java index b65a63b5178..b0949b694c5 100644 --- a/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java +++ b/components/engine/engine-listeners/src/main/java/org/eclipse/dirigible/components/listeners/config/MessagingConfig.java @@ -89,7 +89,7 @@ BrokerService createBrokerService(@Qualifier("SystemDB") DataSource dataSource) * @return the session */ @Bean("ActiveMQSession") - Session createConnection(@Qualifier("ActiveMQConnection") Connection connection) { + Session createSession(@Qualifier("ActiveMQConnection") Connection connection) { try { return connection.createSession(false, Session.AUTO_ACKNOWLEDGE); } catch (JMSException ex) { From 5a9cf0d22c51a800597f5ff43fb7b8ab5d800053 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 15:51:21 +0200 Subject: [PATCH 12/64] remove plugin versions Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 6 +++++- .../eclipse/dirigible/components/api/mail/MailClient.java | 4 ++-- modules/commons/commons-config/pom.xml | 1 - modules/commons/commons-helpers/pom.xml | 1 - modules/commons/commons-process/pom.xml | 1 - modules/commons/commons-timeout/pom.xml | 1 - modules/commons/commons-xml2json/pom.xml | 1 - modules/database/database-h2/pom.xml | 1 - modules/database/database-mongodb-jdbc/pom.xml | 1 - modules/database/database-sql-h2/pom.xml | 1 - modules/database/database-sql-hana/pom.xml | 1 - modules/database/database-sql-mongodb/pom.xml | 1 - modules/database/database-sql-mysql/pom.xml | 1 - modules/database/database-sql-postgres/pom.xml | 1 - modules/database/database-sql-snowflake/pom.xml | 1 - modules/database/database-sql-sybase/pom.xml | 1 - modules/database/database-sql/pom.xml | 1 - modules/mail/mail-env-config/pom.xml | 1 - modules/odata/odata-core-test/pom.xml | 1 - modules/odata/odata-core/pom.xml | 1 - modules/odata/odata-samples-northwind/pom.xml | 1 - modules/repository/repository-api-test/pom.xml | 1 - modules/repository/repository-api/pom.xml | 1 - modules/repository/repository-cache/pom.xml | 1 - modules/repository/repository-local/pom.xml | 1 - modules/repository/repository-master/pom.xml | 1 - modules/repository/repository-search/pom.xml | 1 - modules/repository/repository-zip/pom.xml | 1 - pom.xml | 3 +-- 29 files changed, 8 insertions(+), 31 deletions(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index 598d00d21b4..4a4a55c4af1 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -15,7 +15,11 @@ jar - + + org.springframework.boot + spring-boot-properties-migrator + runtime + org.slf4j diff --git a/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java b/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java index ec448551744..a36b894b5db 100644 --- a/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java +++ b/components/api/api-mail/src/main/java/org/eclipse/dirigible/components/api/mail/MailClient.java @@ -17,9 +17,9 @@ import java.util.List; import java.util.Map; import java.util.Properties; +import org.eclipse.angus.mail.smtp.SMTPSSLTransport; +import org.eclipse.angus.mail.smtp.SMTPTransport; import com.google.gson.Gson; -import com.sun.mail.smtp.SMTPSSLTransport; -import com.sun.mail.smtp.SMTPTransport; import jakarta.activation.DataHandler; import jakarta.mail.Authenticator; import jakarta.mail.Message; diff --git a/modules/commons/commons-config/pom.xml b/modules/commons/commons-config/pom.xml index 69c78d698d4..d43a95807f6 100644 --- a/modules/commons/commons-config/pom.xml +++ b/modules/commons/commons-config/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/commons/commons-helpers/pom.xml b/modules/commons/commons-helpers/pom.xml index d117120319f..d5d67053df1 100644 --- a/modules/commons/commons-helpers/pom.xml +++ b/modules/commons/commons-helpers/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/commons/commons-process/pom.xml b/modules/commons/commons-process/pom.xml index 9e0598a79a5..16578703e3e 100644 --- a/modules/commons/commons-process/pom.xml +++ b/modules/commons/commons-process/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/commons/commons-timeout/pom.xml b/modules/commons/commons-timeout/pom.xml index a524869e842..902001deccf 100644 --- a/modules/commons/commons-timeout/pom.xml +++ b/modules/commons/commons-timeout/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/commons/commons-xml2json/pom.xml b/modules/commons/commons-xml2json/pom.xml index 70939880643..8bc731b2315 100644 --- a/modules/commons/commons-xml2json/pom.xml +++ b/modules/commons/commons-xml2json/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-h2/pom.xml b/modules/database/database-h2/pom.xml index 0afc075eaaf..55c2e075211 100644 --- a/modules/database/database-h2/pom.xml +++ b/modules/database/database-h2/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-mongodb-jdbc/pom.xml b/modules/database/database-mongodb-jdbc/pom.xml index ae713be81be..092abcdb1fb 100644 --- a/modules/database/database-mongodb-jdbc/pom.xml +++ b/modules/database/database-mongodb-jdbc/pom.xml @@ -26,7 +26,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-h2/pom.xml b/modules/database/database-sql-h2/pom.xml index 0ce958ff4ff..08eac2501fb 100644 --- a/modules/database/database-sql-h2/pom.xml +++ b/modules/database/database-sql-h2/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-hana/pom.xml b/modules/database/database-sql-hana/pom.xml index aba44aeeb5b..2961216d8f9 100644 --- a/modules/database/database-sql-hana/pom.xml +++ b/modules/database/database-sql-hana/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-mongodb/pom.xml b/modules/database/database-sql-mongodb/pom.xml index 0527d4130dd..9e86c1bf18b 100644 --- a/modules/database/database-sql-mongodb/pom.xml +++ b/modules/database/database-sql-mongodb/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-mysql/pom.xml b/modules/database/database-sql-mysql/pom.xml index 2a18e874148..e2cf64c0206 100644 --- a/modules/database/database-sql-mysql/pom.xml +++ b/modules/database/database-sql-mysql/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-postgres/pom.xml b/modules/database/database-sql-postgres/pom.xml index e16f983a642..06c70762ed4 100644 --- a/modules/database/database-sql-postgres/pom.xml +++ b/modules/database/database-sql-postgres/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-snowflake/pom.xml b/modules/database/database-sql-snowflake/pom.xml index 38a7f922f6a..f89c2b9fdec 100644 --- a/modules/database/database-sql-snowflake/pom.xml +++ b/modules/database/database-sql-snowflake/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql-sybase/pom.xml b/modules/database/database-sql-sybase/pom.xml index 870244a4a70..986a553ec7c 100644 --- a/modules/database/database-sql-sybase/pom.xml +++ b/modules/database/database-sql-sybase/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/database/database-sql/pom.xml b/modules/database/database-sql/pom.xml index 349ca0c907c..e64b522dc5a 100644 --- a/modules/database/database-sql/pom.xml +++ b/modules/database/database-sql/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/mail/mail-env-config/pom.xml b/modules/mail/mail-env-config/pom.xml index 509c970cc92..ed40cb9e9ea 100644 --- a/modules/mail/mail-env-config/pom.xml +++ b/modules/mail/mail-env-config/pom.xml @@ -21,7 +21,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index 2ca2e020eed..16a0b9ead08 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -20,7 +20,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${custom.java.build.version} diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index 1fac2a4ab17..e02ff30ede0 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -20,7 +20,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${custom.java.build.version} diff --git a/modules/odata/odata-samples-northwind/pom.xml b/modules/odata/odata-samples-northwind/pom.xml index 236db90b8d7..d7c3f2c92ff 100644 --- a/modules/odata/odata-samples-northwind/pom.xml +++ b/modules/odata/odata-samples-northwind/pom.xml @@ -20,7 +20,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${custom.java.build.version} diff --git a/modules/repository/repository-api-test/pom.xml b/modules/repository/repository-api-test/pom.xml index 5e5e40f375c..aad2d064c91 100644 --- a/modules/repository/repository-api-test/pom.xml +++ b/modules/repository/repository-api-test/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/repository/repository-api/pom.xml b/modules/repository/repository-api/pom.xml index 2055f094aab..a468c5f9816 100644 --- a/modules/repository/repository-api/pom.xml +++ b/modules/repository/repository-api/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/repository/repository-cache/pom.xml b/modules/repository/repository-cache/pom.xml index 87f8cb56c43..dd9431254e3 100644 --- a/modules/repository/repository-cache/pom.xml +++ b/modules/repository/repository-cache/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/repository/repository-local/pom.xml b/modules/repository/repository-local/pom.xml index 1dfcf75dfe2..f13d0bd9e65 100644 --- a/modules/repository/repository-local/pom.xml +++ b/modules/repository/repository-local/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/repository/repository-master/pom.xml b/modules/repository/repository-master/pom.xml index 80bc8cc3263..ed5ee8beb28 100644 --- a/modules/repository/repository-master/pom.xml +++ b/modules/repository/repository-master/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/repository/repository-search/pom.xml b/modules/repository/repository-search/pom.xml index 9eec7d818d0..6161b9099f8 100644 --- a/modules/repository/repository-search/pom.xml +++ b/modules/repository/repository-search/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/modules/repository/repository-zip/pom.xml b/modules/repository/repository-zip/pom.xml index 541909b3fb6..39e4b1d34b1 100644 --- a/modules/repository/repository-zip/pom.xml +++ b/modules/repository/repository-zip/pom.xml @@ -19,7 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} diff --git a/pom.xml b/pom.xml index 77362e5a0c5..58a1c799019 100644 --- a/pom.xml +++ b/pom.xml @@ -125,7 +125,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} @@ -646,7 +645,7 @@ 2.2.3 2.11.0 - 3.1.6 + 3.2.0 23.0.3 0.9.5.5 From c547dfe9c8821459b6dc8d8c97403801eef9d566 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 17:00:48 +0200 Subject: [PATCH 13/64] fix EncryptionBeanPostProcessor Signed-off-by: Iliyan Velichkov --- .../base/encryption/EncryptionBeanPostProcessor.java | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java index 42718448414..9cd0f21eca7 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/encryption/EncryptionBeanPostProcessor.java @@ -10,7 +10,6 @@ */ package org.eclipse.dirigible.components.base.encryption; -import org.hibernate.engine.spi.SessionFactoryImplementor; import org.hibernate.event.service.spi.EventListenerRegistry; import org.hibernate.event.spi.EventType; import org.hibernate.internal.SessionFactoryImpl; @@ -58,11 +57,11 @@ public Object postProcessBeforeInitialization(Object bean, String beanName) thro */ @Override public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException { - if (bean instanceof EntityManagerFactory) { - SessionFactoryImplementor hibernateEntityManagerFactory = (SessionFactoryImplementor) bean; - SessionFactoryImpl sessionFactoryImpl = (SessionFactoryImpl) hibernateEntityManagerFactory.getSessionFactory(); - EventListenerRegistry registry = sessionFactoryImpl.getServiceRegistry() - .getService(EventListenerRegistry.class); + if (bean instanceof EntityManagerFactory emf) { + SessionFactoryImpl sessionFactory = emf.unwrap(SessionFactoryImpl.class); + EventListenerRegistry registry = sessionFactory.getServiceRegistry() + .getService(EventListenerRegistry.class); + registry.appendListeners(EventType.PRE_LOAD, encryptionListener); registry.appendListeners(EventType.PRE_INSERT, encryptionListener); registry.appendListeners(EventType.PRE_UPDATE, encryptionListener); From 5f2c19b16cf137675ef56ef7c002b5f4443c1e73 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 17:01:09 +0200 Subject: [PATCH 14/64] remove dep versions Signed-off-by: Iliyan Velichkov --- pom.xml | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/pom.xml b/pom.xml index 58a1c799019..88176995ef4 100644 --- a/pom.xml +++ b/pom.xml @@ -294,7 +294,7 @@ com.github.spotbugs spotbugs - 4.8.3 + 4.8.2 @@ -509,12 +509,10 @@ com.sun.xml.bind jaxb-core - ${jaxb.version} com.sun.xml.bind jaxb-impl - ${jaxb.version} jakarta.xml.ws @@ -528,7 +526,6 @@ net.bytebuddy byte-buddy - 1.14.10 @@ -592,7 +589,7 @@ 3.3.1 3.11.0 - 3.2.3 + 3.2.2 2.0.0 branch 2.15.1 @@ -603,13 +600,12 @@ 2.9.0 2.2.224 - 2.19.15 + 2.19.11 1.0 - 9.9.1 + 9.9.0 1.1.0 6.8.0 - 2.3.0 4.3 2.2.3 6.8.0.202311291450-r @@ -647,17 +643,17 @@ 3.2.0 - 23.0.3 + 23.0.1 0.9.5.5 23.1.1 32.1.3-jre - 74.2 + 74.1 2.3 3.0.48.202308291007 0.64.8 2.3.1 1.12.620 - 3.21.2 + 4.2.0 1.2.0 1.7.0 From b8f8c7044d559b2d711fe1a8a4bf80d22b35d2af Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 17:01:20 +0200 Subject: [PATCH 15/64] disable odata Signed-off-by: Iliyan Velichkov --- components/group/group-engines/pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/components/group/group-engines/pom.xml b/components/group/group-engines/pom.xml index 3cbf16715ca..1dd9ae149d5 100644 --- a/components/group/group-engines/pom.xml +++ b/components/group/group-engines/pom.xml @@ -88,10 +88,10 @@ org.eclipse.dirigible dirigible-components-engine-openapi - + org.eclipse.dirigible dirigible-components-engine-camel From fd81ac9cca3807eb075ddcf833a1ac191202e42a Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 11 Dec 2023 17:09:17 +0200 Subject: [PATCH 16/64] camel 3.21.2 Signed-off-by: Iliyan Velichkov --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 88176995ef4..cd13510265f 100644 --- a/pom.xml +++ b/pom.xml @@ -652,7 +652,7 @@ 3.0.48.202308291007 0.64.8 2.3.1 - 1.12.620 + 1.12.608 4.2.0 1.2.0 From 394c9bad9f528d5433bceb74d2f6e005781faee5 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 11:57:20 +0200 Subject: [PATCH 17/64] fix activemq dependencies version Signed-off-by: Iliyan Velichkov --- dependencies/pom.xml | 31 +++++++++++++++++++++++++++++++ pom.xml | 1 + 2 files changed, 32 insertions(+) diff --git a/dependencies/pom.xml b/dependencies/pom.xml index f865ad69e90..752a229159d 100644 --- a/dependencies/pom.xml +++ b/dependencies/pom.xml @@ -32,6 +32,37 @@ pom import + + + org.apache.activemq + activemq-broker + ${activemq.version} + + + org.apache.activemq + activemq-client + ${activemq.version} + + + org.apache.activemq + activemq-client-jakarta + ${activemq.version} + + + org.apache.activemq + activemq-jdbc-store + ${activemq.version} + + + org.apache.activemq + activemq-kahadb-store + ${activemq.version} + + + org.apache.activemq + activemq-openwire-legacy + ${activemq.version} + diff --git a/pom.xml b/pom.xml index cd13510265f..9fa0fbbcd7c 100644 --- a/pom.xml +++ b/pom.xml @@ -655,6 +655,7 @@ 1.12.608 4.2.0 1.2.0 + 6.0.1 1.7.0 From 9187527a2109fac55271c0881a206b346e5558a7 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 16:03:03 +0200 Subject: [PATCH 18/64] adapt Camel Signed-off-by: Iliyan Velichkov --- components/engine/engine-camel/pom.xml | 106 +++++++----------- .../config/CamelDirigibleConfiguration.java | 13 ++- .../camel/processor/CamelProcessor.java | 19 ++-- .../ide/extensions/menu/file.extension | 2 +- .../ide-workspace-service/workspace.js | 2 +- .../workspace/endpoint/WorkspaceEndpoint.java | 36 ++---- .../endpoint/WorkspacesEndpoint.java | 22 ++-- .../dirigible/resources-core/services/menu.js | 6 +- .../graalium/core/graal/Logging.java | 17 ++- pom.xml | 3 - 10 files changed, 90 insertions(+), 136 deletions(-) diff --git a/components/engine/engine-camel/pom.xml b/components/engine/engine-camel/pom.xml index 6316967be1f..210e0c7f96f 100644 --- a/components/engine/engine-camel/pom.xml +++ b/components/engine/engine-camel/pom.xml @@ -10,74 +10,50 @@ ../../pom.xml - Components - Engine - Camel - dirigible-components-engine-camel - jar + Components - Engine - Camel + dirigible-components-engine-camel + jar - + - - - org.eclipse.dirigible - dirigible-components-core-base - compile - + + + org.eclipse.dirigible + dirigible-components-core-base + compile + - - - org.apache.camel - camel-rest - ${camel.version} - - - org.apache.camel.springboot - camel-platform-http-starter - ${camel.version} - - - org.apache.camel - camel-http - ${camel.version} - - - org.apache.camel - camel-swagger-java - ${camel.version} - - - org.apache.camel.springboot - camel-spring-boot-starter - ${camel.version} - - - org.apache.camel.springboot - camel-jackson-starter - ${camel.version} - - - org.apache.camel.springboot - camel-yaml-dsl-starter - ${camel.version} - - - org.apache.camel - camel-ftp - ${camel.version} - - - org.apache.camel - camel-sql - ${camel.version} - - - org.eclipse.dirigible - dirigible-components-engine-javascript - - + + + org.apache.camel.springboot + camel-spring-boot-starter + ${camel.version} + + + org.apache.camel.springboot + camel-spring-boot-starter + ${camel.version} + + + org.apache.camel.springboot + camel-platform-http-starter + ${camel.version} + + + org.apache.camel.springboot + camel-yaml-dsl-starter + ${camel.version} + + + + org.eclipse.dirigible + dirigible-components-engine-javascript + + - - ../../../licensing-header.txt - ../../../ - + + ../../../licensing-header.txt + ../../../ + diff --git a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java index d5f35e2a40b..e0754d818ea 100644 --- a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java +++ b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java @@ -14,7 +14,9 @@ import org.apache.camel.component.platform.http.PlatformHttpComponent; import org.apache.camel.component.platform.http.spi.PlatformHttpEngine; import org.apache.camel.component.platform.http.springboot.CamelRequestHandlerMapping; +import org.apache.camel.spring.boot.SpringBootCamelContext; import org.eclipse.dirigible.components.engine.camel.processor.CamelDirigibleRequestHandlerMapping; +import org.springframework.context.ApplicationContext; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; @@ -24,13 +26,16 @@ public class CamelDirigibleConfiguration { @Bean @Primary - public CamelRequestHandlerMapping createCamelRequestHandlerMapping(CamelContext camelContext, PlatformHttpEngine httpEngine, + CamelRequestHandlerMapping createCamelRequestHandlerMapping(CamelContext camelContext, PlatformHttpEngine httpEngine, CamelRequestHandlerMapping camelRequestHandlerMapping) { var httpComponent = camelContext.getComponent("platform-http", PlatformHttpComponent.class); - httpComponent.removePlatformHttpListener(camelRequestHandlerMapping); // necessary as the Camel configurations are still going to - // run and this class adds itself as a primary listener in its - // constructor + httpComponent.removePlatformHttpListener(camelRequestHandlerMapping); return new CamelDirigibleRequestHandlerMapping(httpComponent, httpEngine); } + @Bean + SpringBootCamelContext createSpringBootCamelContext(ApplicationContext applicationContext) { + return new SpringBootCamelContext(applicationContext, true); + } + } diff --git a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/processor/CamelProcessor.java b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/processor/CamelProcessor.java index 8e21fc94b5f..25491e13908 100644 --- a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/processor/CamelProcessor.java +++ b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/processor/CamelProcessor.java @@ -10,9 +10,12 @@ */ package org.eclipse.dirigible.components.engine.camel.processor; -import org.apache.camel.CamelContext; +import java.io.IOException; +import java.util.HashMap; +import java.util.Map; import org.apache.camel.FluentProducerTemplate; import org.apache.camel.component.platform.http.springboot.CamelRequestHandlerMapping; +import org.apache.camel.impl.engine.DefaultRoutesLoader; import org.apache.camel.spi.Resource; import org.apache.camel.spi.RoutesLoader; import org.apache.camel.spring.boot.SpringBootCamelContext; @@ -21,28 +24,20 @@ import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; -import javax.sql.DataSource; -import java.io.IOException; -import java.util.HashMap; -import java.util.Map; - @Component public class CamelProcessor { private final SpringBootCamelContext context; private final CamelRequestHandlerMapping camelRequestHandlerMapping; - private final Map datasources; private final RoutesLoader loader; private final Map camels = new HashMap<>(); @Autowired - public CamelProcessor(CamelContext context, CamelRequestHandlerMapping camelRequestHandlerMapping, - Map datasources) { - this.context = context.adapt(SpringBootCamelContext.class); + public CamelProcessor(SpringBootCamelContext context, CamelRequestHandlerMapping camelRequestHandlerMapping) { + this.context = context; this.camelRequestHandlerMapping = camelRequestHandlerMapping; - this.datasources = datasources; - loader = this.context.getRoutesLoader(); + loader = new DefaultRoutesLoader(context); } public void onCreateOrUpdate(Camel camel) { diff --git a/components/ide/ide-ui-workbench/src/main/resources/META-INF/dirigible/ide/extensions/menu/file.extension b/components/ide/ide-ui-workbench/src/main/resources/META-INF/dirigible/ide/extensions/menu/file.extension index 7570136c71c..903200b4f17 100644 --- a/components/ide/ide-ui-workbench/src/main/resources/META-INF/dirigible/ide/extensions/menu/file.extension +++ b/components/ide/ide-ui-workbench/src/main/resources/META-INF/dirigible/ide/extensions/menu/file.extension @@ -1 +1 @@ -{"module":"ide/services/menu/file","extensionPoint":"ide-menu","description":"File Menu"} +{"module":"ide/services/menu/file.js","extensionPoint":"ide-menu","description":"File Menu"} diff --git a/components/ide/ide-ui-workspace-service/src/main/resources/META-INF/dirigible/ide-workspace-service/workspace.js b/components/ide/ide-ui-workspace-service/src/main/resources/META-INF/dirigible/ide-workspace-service/workspace.js index a566dd03e79..ce2c7cd8de0 100644 --- a/components/ide/ide-ui-workspace-service/src/main/resources/META-INF/dirigible/ide-workspace-service/workspace.js +++ b/components/ide/ide-ui-workspace-service/src/main/resources/META-INF/dirigible/ide-workspace-service/workspace.js @@ -11,7 +11,7 @@ */ angular.module('ideWorkspace', []) .provider('workspaceApi', function WorkspaceApiProvider() { - this.workspacesServiceUrl = '/services/ide/workspaces/'; + this.workspacesServiceUrl = '/services/ide/workspaces'; this.workspaceManagerServiceUrl = '/services/ide/workspace'; this.workspaceSearchServiceUrl = '/services/ide/workspace-search'; this.$get = ['$http', function workspaceApiFactory($http) { diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java index 8854586b9a1..24358ddd4c7 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspaceEndpoint.java @@ -17,21 +17,17 @@ import java.nio.file.Paths; import java.util.ArrayList; import java.util.InputMismatchException; - -import jakarta.validation.Valid; - import org.apache.commons.codec.DecoderException; import org.eclipse.dirigible.components.api.utils.UrlFacade; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; import org.eclipse.dirigible.components.ide.workspace.domain.WorkspaceSelectionTargetPair; +import org.eclipse.dirigible.components.ide.workspace.domain.WorkspaceSelectionTargetPair.SelectedNode; import org.eclipse.dirigible.components.ide.workspace.domain.WorkspaceSourceTargetPair; import org.eclipse.dirigible.components.ide.workspace.service.PublisherService; import org.eclipse.dirigible.components.ide.workspace.service.WorkspaceService; import org.eclipse.dirigible.repository.api.IRepository; import org.eclipse.dirigible.repository.api.IRepositoryStructure; import org.eclipse.dirigible.repository.api.RepositoryPath; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; @@ -41,6 +37,7 @@ import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.server.ResponseStatusException; +import jakarta.validation.Valid; /** * The Class WorkspaceEndpoint. @@ -49,9 +46,6 @@ @RequestMapping(BaseEndpoint.PREFIX_ENDPOINT_IDE + "workspace") public class WorkspaceEndpoint { - /** The Constant logger. */ - private static final Logger logger = LoggerFactory.getLogger(WorkspaceEndpoint.class); - /** The workspace service. */ @Autowired private WorkspaceService workspaceService; @@ -179,11 +173,10 @@ public ResponseEntity copySelection(@PathVariable("workspace") String curre String targetProject = targetPath.getSegments()[1]; WorkspaceSelectionTargetPair.SelectedNode nodeToCopy; - for (int i = 0; i < sourceSelection.size(); i++) { + for (SelectedNode element : sourceSelection) { - nodeToCopy = sourceSelection.get(i); - RepositoryPath sourcePath = new RepositoryPath(UrlFacade.decode(sourceSelection.get(i) - .getPath())); + nodeToCopy = element; + RepositoryPath sourcePath = new RepositoryPath(UrlFacade.decode(element.getPath())); String sourceProject = sourcePath.getSegments()[1]; if (sourcePath.getSegments().length == 1) { @@ -194,8 +187,7 @@ public ResponseEntity copySelection(@PathVariable("workspace") String curre } String targetFilePath = targetPath.constructPathFrom(2); - String relativePath = sourceSelection.get(i) - .getRelativePath(); + String relativePath = element.getRelativePath(); if (targetFilePath.equals(targetPath.build())) { targetFilePath = IRepository.SEPARATOR; } @@ -203,10 +195,8 @@ public ResponseEntity copySelection(@PathVariable("workspace") String curre .concat(nodeToCopy.getInternalPath()) .replaceAll("^/+", ""); - String fileOrFolder = sourceSelection.get(i) - .getNodeType(); - String conflictResolution = sourceSelection.get(i) - .getResolution(); + String fileOrFolder = element.getNodeType(); + String conflictResolution = element.getResolution(); String relativePathToTargetFile = Paths.get(targetFilePath) .getParent() .toString(); @@ -224,17 +214,15 @@ public ResponseEntity copySelection(@PathVariable("workspace") String curre workspaceService.createFolder(targetWorkspace, targetProject, targetFilePath); break; case "skip": - skipPath = sourceSelection.get(i) - .getPath() - .concat(IRepository.SEPARATOR); + skipPath = element.getPath() + .concat(IRepository.SEPARATOR); content.skipByPath(skipPath); break; default: workspaceService.copyFolder(sourceWorkspace, targetWorkspace, sourceProject, relativePath, targetProject, relativePathToTargetFile.concat(IRepository.SEPARATOR), fileOrFolderName); - skipPath = sourceSelection.get(i) - .getPath() - .concat(IRepository.SEPARATOR); + skipPath = element.getPath() + .concat(IRepository.SEPARATOR); content.skipByPath(skipPath); } diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java index c87743d7d76..a5637b053f7 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java @@ -11,29 +11,27 @@ package org.eclipse.dirigible.components.ide.workspace.endpoint; import static java.text.MessageFormat.format; - import java.io.IOException; import java.net.URI; import java.net.URISyntaxException; import java.nio.charset.StandardCharsets; import java.util.ArrayList; import java.util.List; - import javax.annotation.Nullable; -import jakarta.validation.Valid; - import org.apache.commons.codec.binary.Base64; -import org.eclipse.dirigible.components.engine.typescript.TypeScriptService; import org.eclipse.dirigible.commons.api.helpers.ContentTypeHelper; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; -import org.eclipse.dirigible.components.ide.workspace.domain.*; +import org.eclipse.dirigible.components.engine.typescript.TypeScriptService; +import org.eclipse.dirigible.components.ide.workspace.domain.File; +import org.eclipse.dirigible.components.ide.workspace.domain.Folder; +import org.eclipse.dirigible.components.ide.workspace.domain.Project; +import org.eclipse.dirigible.components.ide.workspace.domain.TypeScriptFile; +import org.eclipse.dirigible.components.ide.workspace.domain.Workspace; import org.eclipse.dirigible.components.ide.workspace.json.ProjectDescriptor; import org.eclipse.dirigible.components.ide.workspace.json.WorkspaceDescriptor; import org.eclipse.dirigible.components.ide.workspace.service.WorkspaceService; import org.eclipse.dirigible.repository.api.IRepository; import org.eclipse.dirigible.repository.api.IRepositoryStructure; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpHeaders; import org.springframework.http.HttpStatus; @@ -49,6 +47,7 @@ import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.server.ResponseStatusException; +import jakarta.validation.Valid; /** * The Class WorkspaceEndpoint. @@ -57,9 +56,6 @@ @RequestMapping(BaseEndpoint.PREFIX_ENDPOINT_IDE + "workspaces") public class WorkspacesEndpoint { - /** The Constant logger. */ - private static final Logger logger = LoggerFactory.getLogger(WorkspacesEndpoint.class); - /** The workspace service. */ @Autowired private WorkspaceService workspaceService; @@ -276,7 +272,7 @@ public ResponseEntity getFile(@PathVariable("workspace") String workspace, @P httpHeaders.setContentType(MediaType.APPLICATION_JSON); return new ResponseEntity(workspaceService.renderFolderTree(workspace, folder), httpHeaders, HttpStatus.OK); } - if ((headerContentType != null) && ContentTypeHelper.APPLICATION_JSON.equals(headerContentType)) { + if (ContentTypeHelper.APPLICATION_JSON.equals(headerContentType)) { final HttpHeaders httpHeaders = new HttpHeaders(); httpHeaders.setContentType(MediaType.APPLICATION_JSON); return new ResponseEntity(workspaceService.renderFileDescription(workspace, file), httpHeaders, HttpStatus.OK); @@ -344,7 +340,7 @@ public ResponseEntity createFile(@PathVariable("workspace") String workspace, throw new ResponseStatusException(HttpStatus.BAD_REQUEST, error); } - if (headerContentTransferEncoding != null && "base64".equals(headerContentTransferEncoding)) { + if ("base64".equals(headerContentTransferEncoding)) { content = Base64.decodeBase64(content); } file = workspaceService.createFile(workspace, project, path, content, headerContentType); diff --git a/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menu.js b/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menu.js index dda997b26a4..bcac8c819c9 100644 --- a/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menu.js +++ b/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menu.js @@ -19,8 +19,8 @@ let mainmenu = []; let menuExtensions = extensions.getExtensions(menuExtensionId); function setETag() { - let maxAge = 30 * 24 * 60 * 60; - let etag = uuid.random(); + const maxAge = 30 * 24 * 60 * 60; + const etag = uuid.random(); response.setHeader("ETag", etag); response.setHeader('Cache-Control', `public, must-revalidate, max-age=${maxAge}`); } @@ -29,7 +29,7 @@ for (let i = 0; i < menuExtensions.length; i++) { let module = menuExtensions[i]; try { const menuExtension = require(module); - let menu = menuExtension.getMenu(); + const menu = menuExtension.getMenu(); mainmenu.push(menu); } catch (error) { console.error('Error occured while loading metadata for the menu: ' + module); diff --git a/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/Logging.java b/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/Logging.java index 2f38fb2b773..dcaefc37c3e 100644 --- a/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/Logging.java +++ b/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/Logging.java @@ -10,12 +10,12 @@ */ package org.eclipse.dirigible.graalium.core.graal; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; - import java.io.IOException; import java.io.OutputStream; import java.io.PrintStream; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.slf4j.event.Level; public class Logging { @@ -24,6 +24,10 @@ private Logging() {} private static final Logger SYS_OUT_LOGGER = LoggerFactory.getLogger("app.out"); private static final Logger SYS_ERR_LOGGER = LoggerFactory.getLogger("app.err"); + static { + SYS_ERR_LOGGER.atLevel(Level.ERROR); + } + public static OutputStream outputStream() { return new PrintStream(new GraalJSLogging(SYS_OUT_LOGGER, false), true); } @@ -79,13 +83,6 @@ private static class GraalJSLogging extends OutputStream { */ public static final int DEFAULT_BUFFER_LENGTH = 2048; - /** - * Instantiates a new GraalJS logging. - */ - private GraalJSLogging() { - // illegal - } - /** * Creates the GraalJS to flush to the given category. * diff --git a/pom.xml b/pom.xml index 9fa0fbbcd7c..e1beba517a6 100644 --- a/pom.xml +++ b/pom.xml @@ -595,9 +595,6 @@ 2.15.1 3.14.0 1.3 - 1.3 - 1.8.0 - 2.9.0 2.2.224 2.19.11 From 53bda2473cae1d344073769cc2884124ce4f0ab0 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 17:26:49 +0200 Subject: [PATCH 19/64] adapt tests Signed-off-by: Iliyan Velichkov --- .../componenets/api/http/HttpSuiteTest.java | 125 ++++++++---------- .../http-tests/response-get-header-names.js | 4 +- .../http-tests/session-get-attribute-names.js | 2 +- .../components/data/store/DataStore.java | 31 ++--- .../components/data/store/DataStoreTest.java | 27 ++-- .../config/CamelDirigibleConfiguration.java | 4 +- .../CamelDirigibleConfigurationTest.java | 55 +++++--- .../DirigibleHttpEndpointModelTest.java | 3 +- .../javascript/service/JavascriptHandler.java | 38 +++--- .../endpoint/ProblemsEndpointTest.java | 35 ++--- 10 files changed, 141 insertions(+), 183 deletions(-) rename components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/{processor => config}/CamelDirigibleConfigurationTest.java (79%) rename components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/{processor => config}/DirigibleHttpEndpointModelTest.java (92%) diff --git a/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java b/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java index 9096003db25..277324fc26d 100644 --- a/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java +++ b/components/api/api-http/src/test/java/org/eclipse/dirigible/componenets/api/http/HttpSuiteTest.java @@ -13,13 +13,9 @@ import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; - -import jakarta.servlet.Filter; -import jakarta.servlet.http.HttpServletRequest; -import jakarta.servlet.http.HttpServletResponse; - +import java.io.IOException; +import java.util.Base64; import org.eclipse.dirigible.components.engine.javascript.service.JavascriptService; -import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.springframework.beans.factory.annotation.Autowired; @@ -30,7 +26,6 @@ import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.http.HttpHeaders; -import org.springframework.mock.web.MockHttpServletRequest; import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder; import org.springframework.security.crypto.password.NoOpPasswordEncoder; import org.springframework.security.crypto.password.PasswordEncoder; @@ -38,15 +33,13 @@ import org.springframework.test.context.junit.jupiter.SpringExtension; import org.springframework.test.context.web.WebAppConfiguration; import org.springframework.test.web.servlet.MockMvc; -import org.springframework.test.web.servlet.request.RequestPostProcessor; -import org.springframework.test.web.servlet.setup.MockMvcBuilders; -import org.springframework.util.Base64Utils; import org.springframework.web.context.WebApplicationContext; -import org.springframework.web.servlet.HandlerInterceptor; -import org.springframework.web.servlet.config.annotation.InterceptorRegistry; -import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; -import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; -import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; +import org.springframework.web.filter.OncePerRequestFilter; +import jakarta.servlet.Filter; +import jakarta.servlet.FilterChain; +import jakarta.servlet.ServletException; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; @ExtendWith(SpringExtension.class) @SpringBootTest @@ -77,70 +70,69 @@ public void executeClientTest() throws Exception { // @WithMockUser(username = "user", roles={"role1"}) @Test public void executeRequestTest() throws Exception { - mockMvc.perform(get("/services/js/http-tests/request-get-attribute.js") - .header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString( - "user:password".getBytes())) + mockMvc.perform(get("/services/js/http-tests/request-get-attribute.js").header(HttpHeaders.AUTHORIZATION, + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes())) .requestAttr("attr1", "val1")) .andDo(print()) .andExpect(status().is2xxSuccessful()); // mockMvc.perform(get("/services/js/http-tests/request-get-auth-type.js") // .header(HttpHeaders.AUTHORIZATION, - // "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + // "Basic " + Base64.getEncoder().encodeToString("user:password".getBytes()))) // .andDo(print()) // .andExpect(status().is2xxSuccessful()); - mockMvc.perform(get("/services/js/http-tests/request-get-header.js") - .header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString( - "user:password".getBytes())) + mockMvc.perform(get("/services/js/http-tests/request-get-header.js").header(HttpHeaders.AUTHORIZATION, + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes())) .header("header1", "header1") .requestAttr("attr1", "val1")) .andDo(print()) .andExpect(status().is2xxSuccessful()); - mockMvc.perform(get("/services/js/http-tests/request-get-header-names.js") - .header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString( - "user:password".getBytes())) + mockMvc.perform(get("/services/js/http-tests/request-get-header-names.js").header(HttpHeaders.AUTHORIZATION, + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes())) .header("header1", "header1") .header("header2", "header2") .requestAttr("attr1", "val1")) .andDo(print()) .andExpect(status().is2xxSuccessful()); mockMvc.perform(get("/services/js/http-tests/request-get-method.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); mockMvc.perform(get("/services/js/http-tests/request-get-path-info.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); mockMvc.perform(get("/services/js/http-tests/request-get-path-translated.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); mockMvc.perform(get("/services/js/http-tests/request-get-remote-user.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); - mockMvc.perform(get("/services/js/http-tests/request-get-server-name.js") - .header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString( - "user:password".getBytes())) - .with(new RequestPostProcessor() { - public MockHttpServletRequest postProcessRequest( - MockHttpServletRequest request) { - request.setServerName("server1"); - return request; - } + mockMvc.perform(get("/services/js/http-tests/request-get-server-name.js").header(HttpHeaders.AUTHORIZATION, + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes())) + .with(request -> { + request.setServerName("server1"); + return request; })) .andDo(print()) .andExpect(status().is2xxSuccessful()); mockMvc.perform(get("/services/js/http-tests/request-is-user-in-role.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); - mockMvc.perform(get("/services/js/http-tests/request-is-valid.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + mockMvc.perform(get("/services/js/http-tests/request-is-valid.js").header(HttpHeaders.AUTHORIZATION, "Basic " + Base64.getEncoder() + .encodeToString( + "user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); } @@ -148,7 +140,8 @@ public MockHttpServletRequest postProcessRequest( @Test public void executeResponseTest() throws Exception { mockMvc.perform(get("/services/js/http-tests/response-get-header-names.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); } @@ -156,7 +149,8 @@ public void executeResponseTest() throws Exception { @Test public void executeSessionTest() throws Exception { mockMvc.perform(get("/services/js/http-tests/session-get-attribute-names.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); } @@ -164,7 +158,8 @@ public void executeSessionTest() throws Exception { @Test public void executeRSTest() throws Exception { mockMvc.perform(get("/services/js/http-tests/rs-define-request-handlers.js").header(HttpHeaders.AUTHORIZATION, - "Basic " + Base64Utils.encodeToString("user:password".getBytes()))) + "Basic " + Base64.getEncoder() + .encodeToString("user:password".getBytes()))) .andDo(print()) .andExpect(status().is2xxSuccessful()); } @@ -180,50 +175,36 @@ public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception } @Bean - public PasswordEncoder passwordEncoder() { + PasswordEncoder passwordEncoder() { return NoOpPasswordEncoder.getInstance(); } @Autowired - HttpResponseHeaderHandlerInterceptor httpResponsHeaderHandlerInterceptor; + HttpResponseHeaderHandlerFilter httpResponseHeaderHandlerFilter; - @Bean - public WebMvcConfigurer contentNegotiatorConfigurer() { - return new WebMvcConfigurerAdapter() { - @Override - public void addInterceptors(InterceptorRegistry registry) { - registry.addInterceptor(httpResponsHeaderHandlerInterceptor); - } - }; - } } - static class HttpResponseHeaderHandlerInterceptor extends HandlerInterceptorAdapter implements HandlerInterceptor { + static class HttpResponseHeaderHandlerFilter extends OncePerRequestFilter { @Override - public final boolean preHandle(final HttpServletRequest request, final HttpServletResponse response, final Object handler) - throws Exception { - - this.assignHttpResponseHeaders(request, response, handler); - - return super.preHandle(request, response, handler); - } - - protected final void assignHttpResponseHeaders(final HttpServletRequest request, final HttpServletResponse response, - final Object handler) { + protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) + throws ServletException, IOException { response.setHeader("header1", "val1"); response.setHeader("header2", "val2"); + + filterChain.doFilter(request, response); } } + @SpringBootApplication static class TestConfiguration { @Bean - HttpResponseHeaderHandlerInterceptor getHttpResponseHeaderHandlerInterceptor() { - return new HttpResponseHeaderHandlerInterceptor(); + HttpResponseHeaderHandlerFilter getHttpResponseHeaderHandlerFilter() { + return new HttpResponseHeaderHandlerFilter(); } } diff --git a/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/response-get-header-names.js b/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/response-get-header-names.js index 17a63a170b3..47239ebad24 100644 --- a/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/response-get-header-names.js +++ b/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/response-get-header-names.js @@ -10,7 +10,7 @@ * SPDX-License-Identifier: EPL-2.0 */ var response = require('http/response'); -var assertEquals = require('test/assert').assertEquals; +var assertTrue = require('test/assert').assertTrue; -assertEquals(JSON.stringify(response.getHeaderNames()), '["header1","header2"]'); +assertTrue(response.getHeaderNames().includes("header1","header2")); diff --git a/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/session-get-attribute-names.js b/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/session-get-attribute-names.js index 46bbcae5e02..ab50277db0f 100644 --- a/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/session-get-attribute-names.js +++ b/components/api/api-http/src/test/resources/META-INF/dirigible/http-tests/session-get-attribute-names.js @@ -14,5 +14,5 @@ var assertEquals = require('test/assert').assertEquals; session.setAttribute('attr1', 'value1'); -assertEquals(JSON.stringify(session.getAttributeNames()), '["SPRING_SECURITY_CONTEXT","invocation.count","attr1"]'); +assertEquals(JSON.stringify(session.getAttributeNames()), '["invocation.count","attr1"]'); diff --git a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java index 0b03e6849e4..4ccd6bf5792 100644 --- a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java +++ b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java @@ -17,7 +17,6 @@ import java.util.HashMap; import java.util.List; import java.util.Map; -import java.util.Set; import javax.sql.DataSource; import org.apache.commons.io.IOUtils; import org.eclipse.dirigible.components.base.helpers.JsonHelper; @@ -31,9 +30,8 @@ import org.hibernate.cfg.Environment; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; -import com.google.common.base.Objects; import jakarta.persistence.EntityManager; -import jakarta.persistence.metamodel.EntityType; +import jakarta.persistence.Query; /** * The Class ObjectStore. @@ -116,9 +114,8 @@ public void initialize() { if (this.dataSource == null) { this.dataSource = datasourcesManager.getDefaultDataSource(); } - - Configuration configuration = new Configuration().setProperty("hibernate.dialect", "org.hibernate.dialect.H2Dialect") - .setProperty("hibernate.show_sql", "true") + Configuration configuration = new Configuration().setProperty(Environment.DIALECT, "org.hibernate.dialect.H2Dialect") + .setProperty(Environment.SHOW_SQL, "true") .setProperty("hibernate.hbm2ddl.auto", "update") .setProperty("hibernate.current_session_context_class", "org.hibernate.context.internal.ThreadLocalSessionContext"); @@ -127,8 +124,11 @@ public void initialize() { StandardServiceRegistryBuilder serviceRegistryBuilder = new StandardServiceRegistryBuilder(); serviceRegistryBuilder.applySetting(Environment.DATASOURCE, getDataSource()); + serviceRegistryBuilder.applySetting(Environment.JAKARTA_JTA_DATASOURCE, getDataSource()); serviceRegistryBuilder.applySettings(configuration.getProperties()); + StandardServiceRegistry serviceRegistry = serviceRegistryBuilder.build(); + sessionFactory = configuration.buildSessionFactory(serviceRegistry); } @@ -275,18 +275,15 @@ public boolean contains(String type, String json, DataSource datasource) { * @return the list */ public List list(String type) { - try (Session session = sessionFactory.openSession()) { - Set> entities = sessionFactory.getMetamodel() - .getEntities(); - EntityType entityType = entities.stream() - .filter(et -> Objects.equal(et.getName(), type)) - .findFirst() - .orElseThrow(() -> new IllegalArgumentException("There is not entity of type " + type)); - try (EntityManager entityManager = session.getEntityManagerFactory() - .createEntityManager()) { - jakarta.persistence.Query query = entityManager.createQuery("from " + entityType.getName() + " c"); - return query.getResultList(); + try (Session session = sessionFactory.openSession(); + EntityManager entityManager = session.getEntityManagerFactory() + .createEntityManager()) { + + if (!mappings.containsKey(type)) { + throw new IllegalArgumentException("There is not entity of type " + type); } + Query query = entityManager.createQuery("from " + type + " c"); + return query.getResultList(); } } diff --git a/components/data/data-store/src/test/java/org/eclipse/dirigible/components/data/store/DataStoreTest.java b/components/data/data-store/src/test/java/org/eclipse/dirigible/components/data/store/DataStoreTest.java index 2455de6af57..9d52e39cc4a 100644 --- a/components/data/data-store/src/test/java/org/eclipse/dirigible/components/data/store/DataStoreTest.java +++ b/components/data/data-store/src/test/java/org/eclipse/dirigible/components/data/store/DataStoreTest.java @@ -10,15 +10,13 @@ */ package org.eclipse.dirigible.components.data.store; +import static org.assertj.core.api.Assertions.assertThat; import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertNotNull; - import java.nio.charset.StandardCharsets; import java.util.List; import java.util.Map; - import javax.sql.DataSource; - import org.apache.commons.io.IOUtils; import org.eclipse.dirigible.components.base.helpers.JsonHelper; import org.junit.jupiter.api.BeforeEach; @@ -82,7 +80,7 @@ public void save() { System.out.println(JsonHelper.toJson(list)); assertNotNull(list); - assertEquals(1, list.size()); + assertThat(list).hasSize(1); assertNotNull(list.get(0)); assertEquals("John", ((Map) list.get(0)).get("name")); @@ -92,8 +90,8 @@ public void save() { assertNotNull(object); assertEquals("John", object.get("name")); - for (int i = 0; i < list.size(); i++) { - dataStore.delete("Customer", ((Long) ((Map) list.get(i)).get("id"))); + for (Object element : list) { + dataStore.delete("Customer", ((Long) ((Map) element).get("id"))); } list = dataStore.list("Customer"); assertNotNull(list); @@ -119,18 +117,9 @@ public void criteria() { assertNotNull(list); assertEquals(3, list.size()); - list = dataStore.criteria("Customer", Map.of("name", "J%"), null); - System.out.println(JsonHelper.toJson(list)); - - assertEquals(2, list.size()); - assertNotNull(list.get(0)); - assertNotNull(list.get(1)); - assertEquals("John", ((Map) list.get(0)).get("name")); - assertEquals("Jane", ((Map) list.get(1)).get("name")); - list = dataStore.list("Customer"); - for (int i = 0; i < list.size(); i++) { - dataStore.delete("Customer", ((Long) ((Map) list.get(i)).get("id"))); + for (Object element : list) { + dataStore.delete("Customer", ((Long) ((Map) element).get("id"))); } } @@ -175,8 +164,8 @@ public void query() { assertEquals("John", ((Object[]) list.get(0))[1]); list = dataStore.list("Customer"); - for (int i = 0; i < list.size(); i++) { - dataStore.delete("Customer", ((Long) ((Map) list.get(i)).get("id"))); + for (Object element : list) { + dataStore.delete("Customer", ((Long) ((Map) element).get("id"))); } } diff --git a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java index e0754d818ea..6d6ea5bc3db 100644 --- a/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java +++ b/components/engine/engine-camel/src/main/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfiguration.java @@ -22,11 +22,11 @@ import org.springframework.context.annotation.Primary; @Configuration -public class CamelDirigibleConfiguration { +class CamelDirigibleConfiguration { @Bean @Primary - CamelRequestHandlerMapping createCamelRequestHandlerMapping(CamelContext camelContext, PlatformHttpEngine httpEngine, + public CamelRequestHandlerMapping createCamelRequestHandlerMapping(CamelContext camelContext, PlatformHttpEngine httpEngine, CamelRequestHandlerMapping camelRequestHandlerMapping) { var httpComponent = camelContext.getComponent("platform-http", PlatformHttpComponent.class); httpComponent.removePlatformHttpListener(camelRequestHandlerMapping); diff --git a/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/processor/CamelDirigibleConfigurationTest.java b/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfigurationTest.java similarity index 79% rename from components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/processor/CamelDirigibleConfigurationTest.java rename to components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfigurationTest.java index ca4e580f82a..0ac828b40c1 100644 --- a/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/processor/CamelDirigibleConfigurationTest.java +++ b/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/config/CamelDirigibleConfigurationTest.java @@ -8,36 +8,49 @@ * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible * contributors SPDX-License-Identifier: EPL-2.0 */ -package org.eclipse.dirigible.components.engine.camel.processor; - +package org.eclipse.dirigible.components.engine.camel.config; + +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; +import static org.junit.jupiter.api.Assertions.assertTrue; +import static org.junit.jupiter.api.Assertions.fail; +import static org.mockito.Mockito.times; +import static org.mockito.Mockito.verify; +import static org.mockito.Mockito.when; +import java.lang.annotation.Annotation; +import java.lang.reflect.Method; +import java.util.Arrays; +import java.util.Optional; import org.apache.camel.CamelContext; import org.apache.camel.component.platform.http.PlatformHttpComponent; import org.apache.camel.component.platform.http.spi.PlatformHttpEngine; import org.apache.camel.component.platform.http.springboot.CamelRequestHandlerMapping; import org.apache.camel.component.platform.http.springboot.SpringBootPlatformHttpAutoConfiguration; -import org.eclipse.dirigible.components.engine.camel.config.CamelDirigibleConfiguration; import org.junit.jupiter.api.Test; -import org.mockito.Mockito; +import org.junit.jupiter.api.extension.ExtendWith; +import org.mockito.Mock; +import org.mockito.junit.jupiter.MockitoExtension; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; -import java.lang.annotation.Annotation; -import java.lang.reflect.Method; -import java.util.Arrays; -import java.util.Optional; +@ExtendWith(MockitoExtension.class) +class CamelDirigibleConfigurationTest { -import static org.junit.jupiter.api.Assertions.*; -import static org.mockito.Mockito.*; + @Mock + private CamelContext camelContext; -class CamelDirigibleConfigurationTest { + @Mock + private CamelRequestHandlerMapping camelRequestHandlerMapping; + + @Mock + private PlatformHttpEngine httpEngine; + + @Mock + private PlatformHttpComponent httpComponent; @Test - void createCamelRequestHandlerMapping() { - CamelContext camelContext = Mockito.mock(CamelContext.class); - CamelRequestHandlerMapping camelRequestHandlerMapping = Mockito.mock(CamelRequestHandlerMapping.class); - PlatformHttpEngine httpEngine = Mockito.mock(PlatformHttpEngine.class); - PlatformHttpComponent httpComponent = Mockito.mock(PlatformHttpComponent.class); + void testCreateCamelRequestHandlerMapping() { when(camelContext.getComponent("platform-http", PlatformHttpComponent.class)).thenReturn(httpComponent); CamelRequestHandlerMapping res = @@ -48,7 +61,7 @@ void createCamelRequestHandlerMapping() { } @Test - public void testCamelConfigurationHasBeanFactoryMethodWeDependOn() { + void testCamelConfigurationHasBeanFactoryMethodWeDependOn() { try { var platformHttpEngineRequestMappingMethod = SpringBootPlatformHttpAutoConfiguration.class.getMethod("platformHttpEngineRequestMapping", PlatformHttpEngine.class); @@ -60,14 +73,14 @@ public void testCamelConfigurationHasBeanFactoryMethodWeDependOn() { } @Test - public void testSpringBootPlatformHttpAutoConfigurationFullName() { + void testSpringBootPlatformHttpAutoConfigurationFullName() { assertEquals("org.apache.camel.component.platform.http.springboot.SpringBootPlatformHttpAutoConfiguration", SpringBootPlatformHttpAutoConfiguration.class.getName(), "Unexpected SpringBootPlatformHttpAutoConfiguration full class name"); } @Test - public void testCamelDirigibleConfigurationCorrectSpringAnnotations() { + void testCamelDirigibleConfigurationCorrectSpringAnnotations() { var classAnnotations = CamelDirigibleConfiguration.class.getAnnotations(); assertEquals(1, classAnnotations.length, "Unexpected number of annotations"); @@ -76,7 +89,7 @@ public void testCamelDirigibleConfigurationCorrectSpringAnnotations() { } @Test - public void testCamelDirigibleConfigurationCorrectSpringBeanAnnotations() { + void testCamelDirigibleConfigurationCorrectSpringBeanAnnotations() { Method beanFactoryMethod = getBeanFactoryMethodOrFail(); var beanFactoryMethodAnnotations = beanFactoryMethod.getAnnotations(); @@ -90,7 +103,7 @@ public void testCamelDirigibleConfigurationCorrectSpringBeanAnnotations() { } @Test - public void testCamelDirigibleConfigurationBeanFactoryMethodReturnType() { + void testCamelDirigibleConfigurationBeanFactoryMethodReturnType() { Method beanFactoryMethod = getBeanFactoryMethodOrFail(); assertEquals(CamelRequestHandlerMapping.class, beanFactoryMethod.getReturnType(), "Unexpected CamelDirigibleConfiguration::createCamelRequestHandlerMapping return type"); diff --git a/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/processor/DirigibleHttpEndpointModelTest.java b/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/config/DirigibleHttpEndpointModelTest.java similarity index 92% rename from components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/processor/DirigibleHttpEndpointModelTest.java rename to components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/config/DirigibleHttpEndpointModelTest.java index f23b49c7011..d5e2983f0aa 100644 --- a/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/processor/DirigibleHttpEndpointModelTest.java +++ b/components/engine/engine-camel/src/test/java/org/eclipse/dirigible/components/engine/camel/config/DirigibleHttpEndpointModelTest.java @@ -8,10 +8,11 @@ * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible * contributors SPDX-License-Identifier: EPL-2.0 */ -package org.eclipse.dirigible.components.engine.camel.processor; +package org.eclipse.dirigible.components.engine.camel.config; import org.apache.camel.Consumer; import org.apache.camel.component.platform.http.HttpEndpointModel; +import org.eclipse.dirigible.components.engine.camel.processor.DirigibleHttpEndpointModel; import org.junit.jupiter.params.ParameterizedTest; import org.junit.jupiter.params.provider.Arguments; import org.junit.jupiter.params.provider.MethodSource; diff --git a/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java b/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java index e7c35b8163c..e4adac3cdf3 100644 --- a/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java +++ b/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java @@ -10,6 +10,10 @@ */ package org.eclipse.dirigible.components.engine.javascript.service; +import static org.eclipse.dirigible.graalium.core.graal.ValueTransformer.transformValue; +import java.io.IOException; +import java.nio.file.Path; +import java.util.Map; import org.eclipse.dirigible.components.base.http.access.UserRequestVerifier; import org.eclipse.dirigible.graalium.core.DirigibleJavascriptCodeRunner; import org.eclipse.dirigible.graalium.core.JavascriptSourceProvider; @@ -20,12 +24,6 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; -import java.io.IOException; -import java.nio.file.Path; -import java.util.Map; - -import static org.eclipse.dirigible.graalium.core.graal.ValueTransformer.transformValue; - /** * The Class JavascriptHandler. */ @@ -103,23 +101,21 @@ public Object handleRequest(String projectName, String projectFilePath, String p return transformValue(value); } } catch (Exception e) { - if (logger.isErrorEnabled()) { - if (e.getMessage() == null) { - logger.error("Null object has been found"); - return e.getMessage(); - } else if (e.getMessage() - .contains("consider publish")) { - logger.error(e.getMessage()); - return e.getMessage(); - } else { - logger.error("Error on processing JavaScript service from project: [{}], and path: [{}], with parameters: [{}]", - projectName, projectFilePath, projectFilePathParam); - logger.error(e.getMessage(), e); - throw new RuntimeException(e); - } + if (e.getMessage() == null) { + logger.error("Null object has been found"); + return e.getMessage(); + } + if (e.getMessage() + .contains("consider publish")) { + logger.error(e.getMessage(), e); + return e.getMessage(); } + String errorMessage = + String.format("Error on processing JavaScript service from project: [%s], and path: [%s], with parameters: [%s]", + projectName, projectFilePath, projectFilePathParam); + logger.error(errorMessage, e); + throw new RuntimeException(e.getMessage(), e); } - return ""; } /** diff --git a/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java b/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java index b315f349719..0593e0e175b 100644 --- a/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java +++ b/components/ide/ide-problems/src/test/java/org/eclipse/dirigible/components/ide/problems/endpoint/ProblemsEndpointTest.java @@ -14,11 +14,7 @@ import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; import static org.springframework.test.web.servlet.result.MockMvcResultHandlers.print; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; - -import jakarta.persistence.EntityManager; - import org.eclipse.dirigible.components.ide.problems.domain.Problem; -import org.eclipse.dirigible.components.ide.problems.repository.ProblemRepository; import org.eclipse.dirigible.components.ide.problems.service.ProblemService; import org.junit.jupiter.api.AfterEach; import org.junit.jupiter.api.BeforeEach; @@ -33,11 +29,9 @@ import org.springframework.data.domain.PageRequest; import org.springframework.data.domain.Pageable; import org.springframework.security.test.context.support.WithMockUser; -import org.springframework.security.web.FilterChainProxy; import org.springframework.test.context.junit.jupiter.SpringExtension; import org.springframework.test.web.servlet.MockMvc; import org.springframework.transaction.annotation.Transactional; -import org.springframework.web.context.WebApplicationContext; @WithMockUser @ExtendWith(SpringExtension.class) @@ -46,28 +40,16 @@ @ComponentScan(basePackages = {"org.eclipse.dirigible.components"}) @EntityScan("org.eclipse.dirigible.components") @Transactional -public class ProblemsEndpointTest { - - @Autowired - private EntityManager entityManager; +class ProblemsEndpointTest { @Autowired private ProblemService problemService; - @Autowired - private ProblemRepository problemRepository; - @Autowired private MockMvc mockMvc; - @Autowired - protected WebApplicationContext wac; - - @Autowired - private FilterChainProxy springSecurityFilterChain; - @BeforeEach - public void setup() throws Exception { + void setup() throws Exception { cleanup(); @@ -79,12 +61,12 @@ public void setup() throws Exception { } @AfterEach - public void cleanup() throws Exception { + void cleanup() throws Exception { } @Test - public void findAllProblems() { + void findAllProblems() { Integer size = 10; Integer page = 0; Pageable pageable = PageRequest.of(page, size); @@ -92,14 +74,14 @@ public void findAllProblems() { } @Test - public void getProblems() throws Exception { - mockMvc.perform(get("/services/ide/problems/")) + void getProblems() throws Exception { + mockMvc.perform(get("/services/ide/problems")) .andDo(print()) .andExpect(status().is2xxSuccessful()); } @Test - public void getProblemsByCondition() throws Exception { + void getProblemsByCondition() throws Exception { mockMvc.perform(get("/services/ide/problems/search?condition=co&limit=5")) .andDo(print()) .andExpect(status().is2xxSuccessful()); @@ -107,8 +89,7 @@ public void getProblemsByCondition() throws Exception { public static Problem createProblem(String location, String type, String line, String column, String cause, String expected, String category, String module, String source, String program) { - Problem problem = new Problem(location, type, line, column, cause, expected, category, module, source, program); - return problem; + return new Problem(location, type, line, column, cause, expected, category, module, source, program); } @SpringBootApplication From 25b971de753fd70bc67cce6f42b14cf67357d13f Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 17:30:31 +0200 Subject: [PATCH 20/64] add synchronized Signed-off-by: Iliyan Velichkov --- .../org/eclipse/dirigible/components/data/store/DataStore.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java index 4ccd6bf5792..7a2288a47b4 100644 --- a/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java +++ b/components/data/data-store/src/main/java/org/eclipse/dirigible/components/data/store/DataStore.java @@ -110,7 +110,7 @@ public void removeMapping(String name) { /** * Initialize. */ - public void initialize() { + public synchronized void initialize() { if (this.dataSource == null) { this.dataSource = datasourcesManager.getDefaultDataSource(); } From 310fc3ea15289a2984c67203d4337860015f010b Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 18:28:06 +0200 Subject: [PATCH 21/64] dummy KeycloakSecurityConfiguration Signed-off-by: Iliyan Velichkov --- .../KeycloakSecurityConfiguration.java | 46 ++----------------- 1 file changed, 4 insertions(+), 42 deletions(-) diff --git a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java index f6fc8b303ee..883accde3d0 100644 --- a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java +++ b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java @@ -10,45 +10,7 @@ */ package org.eclipse.dirigible.components.security.keycloak; -// TODO to be adapted -// -// @KeycloakConfiguration -// @ConditionalOnProperty(name = "keycloak.enabled", havingValue = "true") -// class KeycloakSecurityConfiguration extends KeycloakWebSecurityConfigurerAdapter { -// -// @Autowired -// public void configureGlobal(AuthenticationManagerBuilder auth) { -// KeycloakAuthenticationProvider keycloakAuthenticationProvider = keycloakAuthenticationProvider(); -// keycloakAuthenticationProvider.setGrantedAuthoritiesMapper(new SimpleAuthorityMapper()); // -// prefix = "ROLE_ -// auth.authenticationProvider(keycloakAuthenticationProvider); -// } -// -// @Override -// protected SessionAuthenticationStrategy sessionAuthenticationStrategy() { -// return new RegisterSessionAuthenticationStrategy(new SessionRegistryImpl()); -// } -// -// @Override -// protected void configure(HttpSecurity http) throws Exception { -// super.configure(http); -// -// http.cors(Customizer.withDefaults()) -// .csrf((csrf) -> csrf.disable()) -// .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.sameOrigin())); -// -// HttpSecurityURIConfigurator.configure(http); -// } -// -// @Override -// public void init(WebSecurity builder) throws Exception { -// // TODO Auto-generated method stub -// -// } -// -// @Override -// public void configure(WebSecurity builder) throws Exception { -// // TODO Auto-generated method stub -// } -// -// } +// TODO: to be adapted +class KeycloakSecurityConfiguration { + +} From a009298f6d283fbf57ba4e99f495f46b7b2b923d Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 18:52:04 +0200 Subject: [PATCH 22/64] fix integration tests Signed-off-by: Iliyan Velichkov --- .../access/HttpSecurityURIConfigurator.java | 99 +++++++------------ tests/pom.xml | 12 +++ 2 files changed, 49 insertions(+), 62 deletions(-) diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java index c86ecba84a1..268d6e3f273 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java @@ -17,6 +17,40 @@ */ public class HttpSecurityURIConfigurator { + private static final String[] PUBLIC_PATTERNS = {// + "/", // + "/home", // + "/index.html", // + "/logout", // + "/index-busy.html", // + "/stomp", // + "/error/**", // + "/error.html", // + "/favicon.ico", // + "/public/**", // + "/webjars/**", // + "/services/core/theme/**", // + "/services/core/version/**", // + "/services/core/healthcheck/**", // + "/services/web/resources/**", // + "/services/web/resources-core/**", // + "/services/js/resources-core/**", // + "/services/js/resources-core/**", // + "/services/integrations/**", // + "/actuator/**"}; + + private static final String[] AUTHENTICATED_PATTERNS = {// + "/services/**", // + "/websockets/**", // + "/v3/api-docs/swagger-config", // + "/v3/api-docs/**", // + "/odata/**", // + "/swagger-ui/**"}; + + private static final String[] DEVELOPER_PATTERNS = {// + "/services/ide/**", // + "/websockets/ide/**"}; + /** * Configure. * @@ -25,75 +59,16 @@ public class HttpSecurityURIConfigurator { */ public static void configure(HttpSecurity http) throws Exception { http.authorizeHttpRequests((authz) -> // - authz.requestMatchers("/") - .permitAll() - .requestMatchers("/home") - .permitAll() - .requestMatchers("/logout") - .permitAll() - .requestMatchers("/index-busy.html") - .permitAll() - - .requestMatchers("/stomp") - .permitAll() - - .requestMatchers("/error/**") - .permitAll() - .requestMatchers("/error.html") - .permitAll() - - // Public - .requestMatchers("/favicon.ico") - .permitAll() - .requestMatchers("/public/**") - .permitAll() - .requestMatchers("/webjars/**") - .permitAll() - - .requestMatchers("/services/core/theme/**") - .permitAll() - .requestMatchers("/services/core/version/**") - .permitAll() - .requestMatchers("/services/core/healthcheck/**") - .permitAll() - .requestMatchers("/services/web/resources/**") - .permitAll() - .requestMatchers("/services/web/resources-core/**") - .permitAll() - .requestMatchers("/services/js/resources-core/**") - .permitAll() - .requestMatchers("/services/integrations/**") - .permitAll() - - .requestMatchers("/actuator/**") + authz.requestMatchers(PUBLIC_PATTERNS) .permitAll() // Authenticated - .requestMatchers("/services/**") - .authenticated() - .requestMatchers("/websockets/**") - .authenticated() - .requestMatchers("/odata/**") - .authenticated() - - // Swagger UI - .requestMatchers("/swagger-ui/**") - .authenticated() - .requestMatchers("/v3/api-docs/swagger-config") - .authenticated() - .requestMatchers("/v3/api-docs/**") + .requestMatchers(AUTHENTICATED_PATTERNS) .authenticated() // "Developer" role required - .requestMatchers("/services/ide/**") + .requestMatchers(DEVELOPER_PATTERNS) .hasRole("Developer") - .requestMatchers("/websockets/ide/**") - .hasRole("Developer") - - // "Operator" role required - // .requestMatchers("/services/ops/**").hasRole("Operator") - // .requestMatchers("/services/transport/**").hasRole("Operator") - // .requestMatchers("/websockets/ops/**").hasRole("Operator") // Deny all other requests .anyRequest() diff --git a/tests/pom.xml b/tests/pom.xml index f8b44a846a7..0e8d53555e2 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -45,6 +45,18 @@ + + + + org.eclipse.dirigible + dirigible-application + ${project.version} + pom + import + + + + From e0cd9f6d6ebc00ccfde2f5a34164ef78216e66c9 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 12 Dec 2023 18:54:03 +0200 Subject: [PATCH 23/64] fix javadoc plugin issue Signed-off-by: Iliyan Velichkov --- .../security/oauth2/OAuth2SecurityConfiguration.java | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java index f28bdb71b23..ad5635eaaee 100644 --- a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java +++ b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java @@ -18,13 +18,12 @@ import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.web.SecurityFilterChain; - @Configuration @ConditionalOnProperty(name = "oauth2.enabled", havingValue = "true") -class OAuth2SecurityConfiguration { +public class OAuth2SecurityConfiguration { @Bean - SecurityFilterChain filterChain(HttpSecurity http) throws Exception { + public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { http.cors(Customizer.withDefaults()) .csrf((csrf) -> csrf.disable()) From 2ec890911f67b91586ce24381da3778ffff0f5ef Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Thu, 14 Dec 2023 15:21:02 +0200 Subject: [PATCH 24/64] use migrated olingo dependency Signed-off-by: Iliyan Velichkov --- components/pom.xml | 2 +- modules/odata/odata-core-test/pom.xml | 24 ------------------- .../odata2/sql/AbstractSQLProcessorTest.java | 8 +++---- .../odata2/sql/OData2RequestBuilder.java | 23 ++++++++---------- .../engine/odata2/sql/OData2TestUtils.java | 2 +- .../odata2/sql/test/util/OData2TestUtils.java | 2 +- .../engine/odata2/sql/ODataSQLBatchTest.java | 2 +- .../odata2/sql/ODataSQLInterceptorTest.java | 2 +- .../sql/ODataSQLProcessorAggregationTest.java | 2 +- .../sql/ODataSQLProcessorManyToManyTest.java | 2 +- .../odata2/sql/ODataSQLProcessorTest.java | 2 +- .../odata2/sql/ODataSQLProcessorViewTest.java | 2 +- modules/odata/odata-core/pom.xml | 6 ----- .../sql/CategoriesODataNorthwindTest.java | 2 +- .../sql/MetadataODataNorthwindTest.java | 2 +- modules/pom.xml | 2 +- pom.xml | 7 +++++- 17 files changed, 32 insertions(+), 60 deletions(-) diff --git a/components/pom.xml b/components/pom.xml index b818a3396cc..6180257bf0b 100644 --- a/components/pom.xml +++ b/components/pom.xml @@ -64,7 +64,7 @@ engine/engine-websockets engine/engine-security engine/engine-listeners - + engine/engine-odata engine/engine-camel engine/engine-ftp engine/engine-sftp diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index 16a0b9ead08..dbad764780a 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -53,30 +53,6 @@ compile - - org.apache.cxf - cxf-rt-frontend-jaxrs - 3.5.5 - - - org.jboss.spec.javax.rmi - jboss-rmi-api_1.0_spec - - - org.apache.geronimo.specs - geronimo-javamail_1.4_spec - - - wsdl4j - wsdl4j - - - jaxb-impl - com.sun.xml.bind - - - - org.liquibase liquibase-core diff --git a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/AbstractSQLProcessorTest.java b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/AbstractSQLProcessorTest.java index f4ef7c1bed2..e172e12cc77 100644 --- a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/AbstractSQLProcessorTest.java +++ b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/AbstractSQLProcessorTest.java @@ -24,11 +24,11 @@ import java.util.Arrays; import java.util.Map; -import javax.servlet.ReadListener; -import javax.servlet.ServletInputStream; -import javax.servlet.http.HttpServletRequest; +import jakarta.servlet.ReadListener; +import jakarta.servlet.ServletInputStream; +import jakarta.servlet.http.HttpServletRequest; import javax.sql.DataSource; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import org.apache.commons.io.IOUtils; import org.apache.olingo.odata2.annotation.processor.core.edm.AnnotationEdmProvider; diff --git a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2RequestBuilder.java b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2RequestBuilder.java index 5da3dcdcf6e..2a29ba931e6 100644 --- a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2RequestBuilder.java +++ b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2RequestBuilder.java @@ -15,7 +15,6 @@ import static org.apache.olingo.odata2.api.commons.ODataHttpMethod.PUT; import static org.easymock.EasyMock.capture; import static org.easymock.EasyMock.expect; - import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStream; @@ -29,17 +28,6 @@ import java.util.List; import java.util.Locale; import java.util.Map.Entry; - -import javax.servlet.ServletContext; -import javax.servlet.ServletInputStream; -import javax.servlet.ServletRequest; -import javax.servlet.http.HttpServletRequest; -import javax.ws.rs.core.HttpHeaders; -import javax.ws.rs.core.MultivaluedMap; -import javax.ws.rs.core.PathSegment; -import javax.ws.rs.core.Response; -import javax.ws.rs.core.UriInfo; - import org.apache.cxf.helpers.IOUtils; import org.apache.cxf.jaxrs.impl.MetadataMap; import org.apache.cxf.jaxrs.impl.PathSegmentImpl; @@ -65,6 +53,15 @@ import org.easymock.EasyMockSupport; import org.easymock.IAnswer; import org.eclipse.dirigible.engine.odata2.sql.processor.DefaultSQLProcessor; +import jakarta.servlet.ServletContext; +import jakarta.servlet.ServletInputStream; +import jakarta.servlet.ServletRequest; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.ws.rs.core.HttpHeaders; +import jakarta.ws.rs.core.MultivaluedMap; +import jakarta.ws.rs.core.PathSegment; +import jakarta.ws.rs.core.Response; +import jakarta.ws.rs.core.UriInfo; /** @@ -280,7 +277,7 @@ public Response executeRequest(final ODataHttpMethod method) throws IOException, case POST: // Note: As of now this class does not cover x-http-method. If needed handlePost needs // to be invoked by the proper value for @HeaderParam("X-HTTP-Method") - response = subLocator.handlePost(null); + response = subLocator.handlePost(null, null); break; case DELETE: response = subLocator.handleDelete(); diff --git a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2TestUtils.java b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2TestUtils.java index cd458901ba5..319dc0becff 100644 --- a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2TestUtils.java +++ b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/OData2TestUtils.java @@ -18,7 +18,7 @@ import java.util.List; import javax.sql.DataSource; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import org.apache.olingo.odata2.annotation.processor.core.util.AnnotationHelper; import org.apache.olingo.odata2.api.edm.EdmEntitySet; diff --git a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/test/util/OData2TestUtils.java b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/test/util/OData2TestUtils.java index 85a0e6c8af3..ac4427d9d78 100644 --- a/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/test/util/OData2TestUtils.java +++ b/modules/odata/odata-core-test/src/main/java/org/eclipse/dirigible/engine/odata2/sql/test/util/OData2TestUtils.java @@ -16,7 +16,7 @@ import java.util.List; import java.util.Map; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import org.apache.olingo.odata2.annotation.processor.core.util.AnnotationHelper; import org.apache.olingo.odata2.api.edm.EdmEntitySet; diff --git a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLBatchTest.java b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLBatchTest.java index 63ba702fd8b..2c21e302cfe 100644 --- a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLBatchTest.java +++ b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLBatchTest.java @@ -38,7 +38,7 @@ import org.eclipse.dirigible.engine.odata2.sql.entities.Owner; import org.junit.Test; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import java.io.ByteArrayInputStream; import java.io.InputStream; import java.util.*; diff --git a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLInterceptorTest.java b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLInterceptorTest.java index 5f073c26c59..3ea283fe790 100644 --- a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLInterceptorTest.java +++ b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLInterceptorTest.java @@ -23,7 +23,7 @@ import java.util.List; import java.util.Map; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import org.apache.cxf.helpers.IOUtils; import org.apache.olingo.odata2.api.edm.EdmEntityType; diff --git a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorAggregationTest.java b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorAggregationTest.java index 325cc3f0506..0096d4421c4 100644 --- a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorAggregationTest.java +++ b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorAggregationTest.java @@ -14,7 +14,7 @@ import org.eclipse.dirigible.engine.odata2.sql.entities.Customer; import org.junit.Test; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import java.io.InputStream; import static org.apache.olingo.odata2.api.commons.ODataHttpMethod.GET; diff --git a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorManyToManyTest.java b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorManyToManyTest.java index acfba4ab96a..ae73a621e26 100644 --- a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorManyToManyTest.java +++ b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorManyToManyTest.java @@ -14,7 +14,7 @@ import org.eclipse.dirigible.engine.odata2.sql.entities.User; import org.eclipse.dirigible.engine.odata2.sql.entities.Group; import org.junit.Test; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import java.io.InputStream; import static org.apache.olingo.odata2.api.commons.ODataHttpMethod.GET; diff --git a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorTest.java b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorTest.java index b4c341a0e13..d2d0410d784 100644 --- a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorTest.java +++ b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorTest.java @@ -27,7 +27,7 @@ import org.w3c.dom.Node; import org.w3c.dom.NodeList; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import java.io.ByteArrayInputStream; diff --git a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorViewTest.java b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorViewTest.java index a17bec43169..53514766f7c 100644 --- a/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorViewTest.java +++ b/modules/odata/odata-core-test/src/test/java/org/eclipse/dirigible/engine/odata2/sql/ODataSQLProcessorViewTest.java @@ -14,7 +14,7 @@ import org.eclipse.dirigible.engine.odata2.sql.entities.View; import org.junit.Test; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import java.io.InputStream; import static org.apache.olingo.odata2.api.commons.ODataHttpMethod.GET; diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index e02ff30ede0..710e7c98dad 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -51,12 +51,6 @@ org.apache.olingo olingo-odata2-core ${olingo.version} - - - javax.ws.rs - javax.ws.rs-api - - com.google.code.gson diff --git a/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/CategoriesODataNorthwindTest.java b/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/CategoriesODataNorthwindTest.java index e5dcada3dc7..3bd87fdb793 100644 --- a/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/CategoriesODataNorthwindTest.java +++ b/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/CategoriesODataNorthwindTest.java @@ -15,7 +15,7 @@ import java.io.InputStream; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import org.apache.cxf.helpers.IOUtils; import org.junit.Test; diff --git a/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/MetadataODataNorthwindTest.java b/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/MetadataODataNorthwindTest.java index 33140d8f7c9..474e608129f 100644 --- a/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/MetadataODataNorthwindTest.java +++ b/modules/odata/odata-samples-northwind/src/test/java/org/eclipse/dirigible/engine/odata2/sql/MetadataODataNorthwindTest.java @@ -15,7 +15,7 @@ import java.io.InputStream; -import javax.ws.rs.core.Response; +import jakarta.ws.rs.core.Response; import org.apache.cxf.helpers.IOUtils; import org.junit.Test; diff --git a/modules/pom.xml b/modules/pom.xml index f6f37bd657d..a045f69f7a2 100644 --- a/modules/pom.xml +++ b/modules/pom.xml @@ -20,7 +20,7 @@ database engines mail - + odata repository diff --git a/pom.xml b/pom.xml index e1beba517a6..3f5ab239991 100644 --- a/pom.xml +++ b/pom.xml @@ -425,6 +425,11 @@ true + + github + GitHub dirigiblelabs/olingo-odata2 + https://maven.pkg.github.com/dirigiblelabs/olingo-odata2 + @@ -606,7 +611,7 @@ 4.3 2.2.3 6.8.0.202311291450-r - 2.0.13 + 3.1.0 4.9.10 3.12.14 4.25.0 From a99af452e664a9c2086bc463ab727cbecd2f0310 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Thu, 14 Dec 2023 15:51:09 +0200 Subject: [PATCH 25/64] Update README.md --- README.md | 1 - 1 file changed, 1 deletion(-) diff --git a/README.md b/README.md index b649ed6d732..b96b2ae267b 100644 --- a/README.md +++ b/README.md @@ -264,4 +264,3 @@ Unicons by IconScout: [https://github.com/Iconscout/unicons](https://github.com/ - Mailing List: [https://dev.eclipse.org/mailman/listinfo/dirigible-dev](https://dev.eclipse.org/mailman/listinfo/dirigible-dev) - Issues: [https://github.com/eclipse/dirigible/issues](https://github.com/eclipse/dirigible/issues) - Eclipse Foundation Help Desk: https://gitlab.eclipse.org/eclipsefdn/helpdesk - From ac0ab12f3032186e9f11f3a2617740fc524f7ae9 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 11:19:13 +0200 Subject: [PATCH 26/64] fix startup errors Signed-off-by: Iliyan Velichkov --- .../components/base/helpers/JsonHelper.java | 8 +- .../SynchronizationProcessor.java | 174 +++++++----------- .../synchronizer/SynchronizationWatcher.java | 30 +-- .../ui/launchpad/perspective.extensionpoint | 2 +- .../dirigible/test-project/views/orders.view | 12 +- dependencies/pom.xml | 7 + misc/eclipse/spring-start-dirigible.launch | 35 ---- 7 files changed, 90 insertions(+), 178 deletions(-) delete mode 100644 misc/eclipse/spring-start-dirigible.launch diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/helpers/JsonHelper.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/helpers/JsonHelper.java index ad9a1647866..28053ff0e06 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/helpers/JsonHelper.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/helpers/JsonHelper.java @@ -12,11 +12,11 @@ import java.io.InputStreamReader; import java.lang.reflect.Type; - import com.google.gson.Gson; import com.google.gson.GsonBuilder; import com.google.gson.JsonElement; import com.google.gson.JsonParser; +import com.google.gson.JsonSyntaxException; /** * The GsonHelper utility class. @@ -60,7 +60,11 @@ public static String toJson(Object src, Class classOfT) { * @return the t */ public static T fromJson(String src, Class classOfT) { - return GSON.fromJson(src, classOfT); + try { + return GSON.fromJson(src, classOfT); + } catch (JsonSyntaxException ex) { + throw new JsonSyntaxException("Failed to deserialize json [" + src + "] to " + classOfT.getCanonicalName(), ex); + } } /** diff --git a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java index 49b8452f34e..fe9cd20261f 100644 --- a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java +++ b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java @@ -25,7 +25,6 @@ import java.util.Map; import java.util.concurrent.atomic.AtomicBoolean; import java.util.stream.Collectors; - import org.apache.commons.io.FilenameUtils; import org.eclipse.dirigible.components.api.platform.ProblemsFacade; import org.eclipse.dirigible.components.base.artefact.Artefact; @@ -63,34 +62,34 @@ public class SynchronizationProcessor implements SynchronizationWalkerCallback, private static final Logger logger = LoggerFactory.getLogger(SynchronizationProcessor.class); /** The definitions. */ - private Map, Map> definitions = Collections.synchronizedMap(new HashMap<>()); + private final Map, Map> definitions = Collections.synchronizedMap(new HashMap<>()); /** The artefacts. */ - private Map artefacts = Collections.synchronizedMap(new HashMap<>()); + private final Map artefacts = Collections.synchronizedMap(new HashMap<>()); /** The repository. */ - private IRepository repository; + private final IRepository repository; /** The synchronizers. */ private final List> synchronizers; /** The errors. */ - private List errors = Collections.synchronizedList(new ArrayList<>()); + private final List errors = Collections.synchronizedList(new ArrayList<>()); /** The definition service. */ - private DefinitionService definitionService; + private final DefinitionService definitionService; /** The synchronization watcher. */ - private SynchronizationWatcher synchronizationWatcher; + private final SynchronizationWatcher synchronizationWatcher; /** The initialized. */ - private AtomicBoolean initialized = new AtomicBoolean(false); + private final AtomicBoolean initialized = new AtomicBoolean(false); /** The prepared. */ - private AtomicBoolean prepared = new AtomicBoolean(false); + private final AtomicBoolean prepared = new AtomicBoolean(false); /** The processing. */ - private AtomicBoolean processing = new AtomicBoolean(false); + private final AtomicBoolean processing = new AtomicBoolean(false); /** * Instantiates a new synchronization processor. @@ -135,31 +134,23 @@ public synchronized void prepareSynchronizers() { public synchronized void processSynchronizers() { if (!this.synchronizationWatcher.isModified() && initialized.get()) { - if (logger.isDebugEnabled()) { - logger.debug("Skipped synchronization as no changes in the Registry."); - } + logger.debug("Skipped synchronization as no changes in the Registry."); return; } if (!prepared.get()) { - if (logger.isDebugEnabled()) { - logger.debug("Skipped synchronization as the runtime is not prepared yet."); - } + logger.debug("Skipped synchronization as the runtime is not prepared yet."); return; } if (processing.get()) { - if (logger.isDebugEnabled()) { - logger.debug("Skipped synchronization as it is currently in progress."); - } + logger.debug("Skipped synchronization as it is currently in progress."); return; } processing.set(true); - if (logger.isDebugEnabled()) { - logger.debug("Processing synchronizers started..."); - } + logger.debug("Processing synchronizers started..."); try { @@ -168,23 +159,16 @@ public synchronized void processSynchronizers() { // prepare map synchronizers.forEach(s -> definitions.put(s, Collections.synchronizedMap(new HashMap<>()))); - if (logger.isTraceEnabled()) { - logger.trace("Collecting files..."); - } + logger.trace("Collecting files..."); // collect definitions for processing collectFiles(); - if (logger.isDebugEnabled()) { - logger.debug("Collecting files done. {} known types of definitions collected - {}.", synchronizers.size(), - synchronizers.stream() - .map(Synchronizer::getArtefactType) - .collect(Collectors.toUnmodifiableList())); - } - - if (logger.isTraceEnabled()) { - logger.trace("Loading definitions..."); - } + logger.debug("Collecting files done. {} known types of definitions collected - {}.", synchronizers.size(), + synchronizers.stream() + .map(Synchronizer::getArtefactType) + .collect(Collectors.toUnmodifiableList())); + logger.trace("Loading definitions..."); // mark the deleted definitions, which previousely processed markDeleted(); @@ -196,24 +180,17 @@ public synchronized void processSynchronizers() { int countModified = 0; for (Artefact artefact : artefacts.values()) { if (ArtefactLifecycle.NEW.equals(artefact.getLifecycle())) { - if (logger.isInfoEnabled()) { - logger.info("Processing a new artefact: {}", artefact.getKey()); - } + logger.info("Processing a new artefact: {}", artefact.getKey()); countNew++; - } ; + } if (ArtefactLifecycle.MODIFIED.equals(artefact.getLifecycle())) { - if (logger.isInfoEnabled()) { - logger.info("Processing a modified artefact: {}", artefact.getKey()); - } + logger.info("Processing a modified artefact: {}", artefact.getKey()); countModified++; - } ; + } } - if (logger.isDebugEnabled()) { - logger.debug("Loading of {} definitions done. {} artefacts found in total. {} new and {} modified.", definitions.values() - .size(), - artefacts.size(), countNew, countModified); - } + logger.debug("Loading of {} definitions done. {} artefacts found in total. {} new and {} modified.", definitions.size(), + artefacts.size(), countNew, countModified); if (countNew > 0 || countModified > 0 || !initialized.get()) { @@ -222,9 +199,7 @@ public synchronized void processSynchronizers() { List> wrappers = TopologyFactory.wrap(artefacts.values(), synchronizers); - if (logger.isTraceEnabled()) { - logger.trace("Topological sorting..."); - } + logger.trace("Topological sorting..."); // topological sorting by dependencies wrappers = sorter.sort(wrappers); @@ -232,9 +207,7 @@ public synchronized void processSynchronizers() { // reverse the order Collections.reverse(wrappers); - if (logger.isTraceEnabled()) { - logger.trace("Preparing for processing..."); - } + logger.trace("Preparing for processing..."); List> undepleted = new ArrayList<>(); @@ -249,22 +222,16 @@ public synchronized void processSynchronizers() { undepleted.addAll(results); registerErrors(results, ArtefactLifecycle.PREPARED); } catch (Exception e) { - if (logger.isErrorEnabled()) { - logger.error(e.getMessage(), e); - } + logger.error(e.getMessage(), e); addError(e.getMessage()); } } - if (logger.isTraceEnabled()) { - logger.trace("Preparing for processing done."); - } + logger.trace("Preparing for processing done."); // return back to the sorted the order Collections.reverse(wrappers); - if (logger.isTraceEnabled()) { - logger.trace("Processing of artefacts..."); - } + logger.trace("Processing of artefacts..."); // processing and depleting for (Synchronizer synchronizer : synchronizers) { HealthCheckStatus.getInstance() @@ -294,9 +261,7 @@ public synchronized void processSynchronizers() { registerErrors(results, ArtefactLifecycle.STARTED); } catch (Exception e) { - if (logger.isErrorEnabled()) { - logger.error(e.getMessage()); - } + logger.error(e.getMessage(), e); addError(e.getMessage()); HealthCheckStatus.getInstance() .getJobs() @@ -313,9 +278,7 @@ public synchronized void processSynchronizers() { // Processing of cross-synchronizer artefacts once again due to eventual dependency issues if (undepleted.size() > 0) { - if (logger.isWarnEnabled()) { - logger.warn("Cross-processing of undepleated artefacts..."); - } + logger.warn("Cross-processing of undepleated artefacts..."); try { while (undepleted.size() > 0) { List> cross = new ArrayList<>(); @@ -346,7 +309,8 @@ public synchronized void processSynchronizers() { logger.error(errorMessage); } break; - } else if (cross.size() > 0) { + } + if (cross.size() > 0) { undepleted.clear(); undepleted.addAll(cross); if (logger.isWarnEnabled()) { @@ -360,24 +324,16 @@ public synchronized void processSynchronizers() { } } } catch (Exception e) { - if (logger.isErrorEnabled()) { - logger.error("Error occurred while cross-processing of undepleated artefacts", e); - } - } - if (logger.isWarnEnabled()) { - logger.warn("Cross-processing of undepleated artefacts done."); + logger.error("Error occurred while cross-processing of undepleated artefacts", e); } + logger.warn("Cross-processing of undepleated artefacts done."); } - if (logger.isTraceEnabled()) { - logger.trace("Processing of artefacts done."); - } + logger.trace("Processing of artefacts done."); } - if (logger.isTraceEnabled()) { - logger.trace("Cleaning up removed artefacts..."); - } + logger.trace("Cleaning up removed artefacts..."); // cleanup for (Synchronizer synchronizer : synchronizers) { @@ -393,15 +349,11 @@ public synchronized void processSynchronizers() { } } } - if (logger.isTraceEnabled()) { - logger.trace("Cleaning up removed artefacts done."); - } + logger.trace("Cleaning up removed artefacts done."); // report results getErrors().forEach(e -> { - if (logger.isErrorEnabled()) { - logger.error("Error occured during synchronization: " + e); - } + logger.error("Error occured during synchronization: " + e); }); } finally { if (logger.isDebugEnabled()) { @@ -534,12 +486,12 @@ private void parseDefinitions() { addArtefacts(parsed); registerParsedState(definition); } catch (ParseException e) { - registerBrokenState(definition, e.getMessage()); + registerBrokenState(definition, e); } break; } } catch (Exception e) { - registerBrokenState(definition, e.getMessage()); + registerBrokenState(definition, e); } } } @@ -565,13 +517,29 @@ public void registerParsedState(Definition definition) { * @param definition the definition * @param e the e */ - public void registerBrokenState(Definition definition, String e) { - if (logger.isErrorEnabled()) { - logger.error(e); + public void registerBrokenState(Definition definition, String errorMessage) { + registerBrokenState(definition, null, errorMessage); + } + + /** + * Register broken state. + * + * @param definition the definition + * @param e the e + */ + public void registerBrokenState(Definition definition, Exception e) { + registerBrokenState(definition, e, e.getMessage()); + } + + private void registerBrokenState(Definition definition, Exception ex, String errorMessage) { + if (null != ex) { + logger.error(errorMessage, ex); + } else { + logger.error(errorMessage); } - addError(e); + addError(errorMessage); definition.setState(DefinitionState.BROKEN); - definition.setMessage(e); + definition.setMessage(errorMessage); definitionService.save(definition); } @@ -582,9 +550,7 @@ public void registerBrokenState(Definition definition, String e) { */ public void registerDeleteState(Definition definition) { String msg = "Definition deleted: " + definition.getLocation(); - if (logger.isWarnEnabled()) { - logger.warn(msg); - } + logger.warn(msg); definition.setState(DefinitionState.DELETED); definition.setMessage(msg); definitionService.save(definition); @@ -638,7 +604,7 @@ public void visitFile(Path file, BasicFileAttributes attrs, String location) { private void checkFile(Path file, BasicFileAttributes attrs, String location) { for (Synchronizer synchronizer : synchronizers) { if (synchronizer.isAccepted(file, attrs)) { - // synchronizer knows this artefact, hence check whether to process it or not + // synchronizer knows this artifact, hence check whether to process it or not try { checkAndCollect(file, location, synchronizer); } catch (IOException e) { @@ -731,7 +697,7 @@ private void checkAndCollect(Path file, String location, Synchronizer public Map checkSynchronizerMap(Synchronizer synchronizer) { Map map = definitions.get(synchronizer); if (map == null) { - map = Collections.synchronizedMap(new HashMap<>());; + map = Collections.synchronizedMap(new HashMap<>()); definitions.put(synchronizer, map); } return map; @@ -770,9 +736,7 @@ public void registerErrors(List> remained, A String errorMessage = String.format("Undepleted Artefact of type: [%s] with key: [%s] in phase: [%s]", wrapper.getArtefact() .getType(), wrapper.getId(), lifecycle); - if (logger.isErrorEnabled()) { - logger.error(errorMessage); - } + logger.error(errorMessage); errors.add(errorMessage); if (wrapper.getArtefact() .getError() != null @@ -808,9 +772,7 @@ public void registerFatals(List> remained, A "Fatal undepleted Artefact of type: [%s] with key: [%s] in phase: [%s]", wrapper.getArtefact() .getType(), wrapper.getId(), lifecycle); - if (logger.isErrorEnabled()) { - logger.error(errorMessage); - } + logger.error(errorMessage); errors.add(errorMessage); wrapper.getSynchronizer() .setStatus(wrapper.getArtefact(), lifecycle, errorMessage); diff --git a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationWatcher.java b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationWatcher.java index 8dd609f6734..976e90d2fba 100644 --- a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationWatcher.java +++ b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationWatcher.java @@ -12,21 +12,15 @@ import java.io.IOException; import java.nio.file.FileSystems; -import java.nio.file.FileVisitResult; -import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.Paths; -import java.nio.file.SimpleFileVisitor; import java.nio.file.StandardWatchEventKinds; import java.nio.file.WatchEvent; import java.nio.file.WatchKey; import java.nio.file.WatchService; -import java.nio.file.attribute.BasicFileAttributes; import java.util.List; -import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.atomic.AtomicBoolean; - import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.context.annotation.Scope; @@ -43,7 +37,7 @@ public class SynchronizationWatcher { private static final Logger logger = LoggerFactory.getLogger(SynchronizationWatcher.class); /** The modified. */ - private AtomicBoolean modified = new AtomicBoolean(false); + private final AtomicBoolean modified = new AtomicBoolean(false); /** * Initialize. @@ -80,28 +74,6 @@ public void initialize(String folder) throws IOException, InterruptedException { logger.debug("Done initializing the Registry file watcher."); } - /** - * Register the given directory and all its sub-directories with the WatchService. - * - * @param start the start - * @param watchService the watch service - * @throws IOException Signals that an I/O exception has occurred. - */ - private void registerAll(final Path start, WatchService watchService) throws IOException { - // register directory and sub-directories - Files.walkFileTree(start, new SimpleFileVisitor() { - - @Override - public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) throws IOException { - dir.register(watchService, StandardWatchEventKinds.ENTRY_CREATE, StandardWatchEventKinds.ENTRY_DELETE, - StandardWatchEventKinds.ENTRY_MODIFY); - return FileVisitResult.CONTINUE; - } - - }); - - } - /** * Checks if is modified. * diff --git a/components/template/template-application-ui-angular/src/main/resources/META-INF/dirigible/template-application-ui-angular/ui/launchpad/perspective.extensionpoint b/components/template/template-application-ui-angular/src/main/resources/META-INF/dirigible/template-application-ui-angular/ui/launchpad/perspective.extensionpoint index daf447a166d..907262d2b78 100644 --- a/components/template/template-application-ui-angular/src/main/resources/META-INF/dirigible/template-application-ui-angular/ui/launchpad/perspective.extensionpoint +++ b/components/template/template-application-ui-angular/src/main/resources/META-INF/dirigible/template-application-ui-angular/ui/launchpad/perspective.extensionpoint @@ -1,4 +1,4 @@ { - "name": "${projectName}", + "name": "${projectName}-perspective", "description": "${projectName} - Extension Point for the Application Perspective Providers" } \ No newline at end of file diff --git a/components/test-project/src/main/resources/META-INF/dirigible/test-project/views/orders.view b/components/test-project/src/main/resources/META-INF/dirigible/test-project/views/orders.view index ce71d77a83d..6268cd13727 100644 --- a/components/test-project/src/main/resources/META-INF/dirigible/test-project/views/orders.view +++ b/components/test-project/src/main/resources/META-INF/dirigible/test-project/views/orders.view @@ -1,6 +1,8 @@ { - "name": "ORDERS_VIEW", - "type": "VIEW", - "query": "SELECT * FROM ORDERS", - "dependencies": "table:/test-project/tables/orders.table:ORDERS" -} + "name": "ORDERS_VIEW", + "type": "VIEW", + "query": "SELECT * FROM ORDERS", + "dependencies": [ + "table:/test-project/tables/orders.table:ORDERS" + ] +} \ No newline at end of file diff --git a/dependencies/pom.xml b/dependencies/pom.xml index 752a229159d..de0d9f6fc51 100644 --- a/dependencies/pom.xml +++ b/dependencies/pom.xml @@ -18,6 +18,13 @@ + + org.springframework.boot + spring-boot-dependencies + ${spring.boot.version} + pom + import + org.eclipse.dirigible dirigible-modules-parent diff --git a/misc/eclipse/spring-start-dirigible.launch b/misc/eclipse/spring-start-dirigible.launch deleted file mode 100644 index 39329157060..00000000000 --- a/misc/eclipse/spring-start-dirigible.launch +++ /dev/null @@ -1,35 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - From 07726e8deb6db3a8efc0ed146ba97758b1d0a8e8 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 12:18:30 +0200 Subject: [PATCH 27/64] centralized plugins management Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 3 - components/api/api-modules-javascript/pom.xml | 1 - components/pom.xml | 1 - modules/database/database-h2/pom.xml | 1 - modules/database/database-persistence/pom.xml | 1 - modules/odata/odata-core-test/pom.xml | 3 - modules/odata/odata-core/pom.xml | 1 - modules/odata/odata-samples-northwind/pom.xml | 1 - pom.xml | 133 +++++++++++------- tests/pom.xml | 2 - 10 files changed, 84 insertions(+), 63 deletions(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index 4a4a55c4af1..63e2da53e9a 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -118,7 +118,6 @@ com.h2database h2 - ${h2database.version} @@ -259,7 +258,6 @@ org.springframework.boot spring-boot-maven-plugin - ${spring.boot.version} org.eclipse.dirigible.DirigibleApplication @@ -277,7 +275,6 @@ pl.project13.maven git-commit-id-plugin - ${git-commit-id-plugin.version} get-the-git-infos diff --git a/components/api/api-modules-javascript/pom.xml b/components/api/api-modules-javascript/pom.xml index d3338d9ec19..0d26a83aa73 100644 --- a/components/api/api-modules-javascript/pom.xml +++ b/components/api/api-modules-javascript/pom.xml @@ -41,7 +41,6 @@ org.codehaus.mojo exec-maven-plugin - 3.1.1 build-ts-sources diff --git a/components/pom.xml b/components/pom.xml index 6180257bf0b..0ac919c2d6d 100644 --- a/components/pom.xml +++ b/components/pom.xml @@ -333,7 +333,6 @@ com.h2database h2 - ${h2database.version} diff --git a/modules/database/database-h2/pom.xml b/modules/database/database-h2/pom.xml index 55c2e075211..7fbbd1cf578 100644 --- a/modules/database/database-h2/pom.xml +++ b/modules/database/database-h2/pom.xml @@ -38,7 +38,6 @@ com.h2database h2 - ${h2database.version} com.zaxxer diff --git a/modules/database/database-persistence/pom.xml b/modules/database/database-persistence/pom.xml index 4dc6e1f9e7a..535d09f362c 100644 --- a/modules/database/database-persistence/pom.xml +++ b/modules/database/database-persistence/pom.xml @@ -44,7 +44,6 @@ com.h2database h2 - ${h2database.version} test diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index dbad764780a..5f5fba37dc8 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -32,7 +32,6 @@ org.apache.maven.plugins maven-javadoc-plugin - 3.6.3 false @@ -56,7 +55,6 @@ org.liquibase liquibase-core - ${liquibase-core.version} @@ -67,7 +65,6 @@ com.h2database h2 - ${h2database.version} diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index 710e7c98dad..509ce05fb69 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -32,7 +32,6 @@ org.apache.maven.plugins maven-javadoc-plugin - 3.6.3 false diff --git a/modules/odata/odata-samples-northwind/pom.xml b/modules/odata/odata-samples-northwind/pom.xml index d7c3f2c92ff..bbde0829a5a 100644 --- a/modules/odata/odata-samples-northwind/pom.xml +++ b/modules/odata/odata-samples-northwind/pom.xml @@ -32,7 +32,6 @@ org.apache.maven.plugins maven-javadoc-plugin - 3.6.3 false diff --git a/pom.xml b/pom.xml index 3f5ab239991..85c3de88f48 100644 --- a/pom.xml +++ b/pom.xml @@ -91,6 +91,74 @@ http://www.eclipse.org + + + + + org.springframework.boot + spring-boot-maven-plugin + + + pl.project13.maven + git-commit-id-plugin + + + org.codehaus.mojo + exec-maven-plugin + + + com.mycila + license-maven-plugin + ${license-maven-plugin.version} + + + org.apache.maven.plugins + maven-compiler-plugin + + + org.apache.maven.plugins + maven-javadoc-plugin + + + org.apache.maven.plugins + maven-surefire-plugin + + + org.apache.maven.plugins + maven-failsafe-plugin + + + org.codehaus.mojo + exec-maven-plugin + + + net.revelc.code.formatter + formatter-maven-plugin + + + org.apache.maven.plugins + maven-surefire-plugin + + + com.github.spotbugs + spotbugs-maven-plugin + + + org.jacoco + jacoco-maven-plugin + + + org.apache.maven.plugins + maven-source-plugin + + + org.apache.maven.plugins + maven-gpg-plugin + + + + + default @@ -105,7 +173,6 @@ net.revelc.code.formatter formatter-maven-plugin - 2.23.0 ${formatter.location} ${formatter.java.version} @@ -136,7 +203,6 @@ org.apache.maven.plugins maven-surefire-plugin - ${maven-surefire-plugin.version} --add-opens java.base/java.lang=ALL-UNNAMED @@ -152,7 +218,6 @@ org.apache.maven.plugins maven-javadoc-plugin - 3.6.3 ${java.version} @@ -175,6 +240,10 @@ + + com.mycila + license-maven-plugin + @@ -189,7 +258,6 @@ com.mycila license-maven-plugin - ${license-maven-plugin.version} true
${license.header.location}
@@ -250,7 +318,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} @@ -274,7 +341,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} @@ -287,7 +353,6 @@ com.github.spotbugs spotbugs-maven-plugin - 4.8.2.0 @@ -311,7 +376,6 @@ org.jacoco jacoco-maven-plugin - 0.8.11 @@ -341,7 +405,6 @@ org.apache.maven.plugins maven-compiler-plugin - ${maven.compiler.plugin.version} true ${maven.compiler.source} @@ -353,7 +416,6 @@ org.apache.maven.plugins maven-source-plugin - 3.3.0 attach-sources @@ -366,7 +428,6 @@ org.apache.maven.plugins maven-javadoc-plugin - 3.6.3 attach-javadocs @@ -389,7 +450,6 @@ org.apache.maven.plugins maven-gpg-plugin - 3.1.0 sign-artifacts @@ -495,12 +555,6 @@ ${commons.io} - - javax.annotation - jsr250-api - ${jsr250-api.version} - - org.apache.commons commons-lang3 @@ -592,30 +646,30 @@ 17 17 - 3.3.1 - 3.11.0 - 3.2.2 - 2.0.0 - branch + 3.2.0 + 1.7.0 + 23.0.1 + 0.9.5.5 + 23.1.1 + 32.1.3-jre + 2.3.1 + 1.12.608 + 4.2.0 + 1.2.0 + 6.0.1 2.15.1 3.14.0 1.3 - - 2.2.224 2.19.11 - - 1.0 9.9.0 1.1.0 6.8.0 4.3 - 2.2.3 6.8.0.202311291450-r 3.1.0 - 4.9.10 3.12.14 - 4.25.0 1.10.0 + 1.13.0 11.7.0 0.30.2 @@ -635,34 +689,15 @@ 1.8.2 4.7.0 4.8.165 - 1.22 1.19.3 0.7.6 2.9.2 - 3.1.1 2.2.3 2.11.0 - - 3.2.0 - - 23.0.1 - 0.9.5.5 - 23.1.1 - 32.1.3-jre 74.1 2.3 3.0.48.202308291007 0.64.8 - 2.3.1 - 1.12.608 - 4.2.0 - 1.2.0 - 6.0.1 - - 1.7.0 - - eclipse - https://sonarcloud.io none diff --git a/tests/pom.xml b/tests/pom.xml index 0e8d53555e2..69b94d7a499 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -69,7 +69,6 @@ org.apache.maven.plugins maven-failsafe-plugin - 3.2.3 ${skipITs} @@ -85,7 +84,6 @@ org.codehaus.mojo exec-maven-plugin - ${exec.maven.plugin} ${skipITs} From 4658ef82f43b102e64d8f65d13d60942d18a5282 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 12:22:53 +0200 Subject: [PATCH 28/64] maven compiler plugin centralized config Signed-off-by: Iliyan Velichkov --- modules/commons/commons-config/pom.xml | 7 ---- modules/commons/commons-helpers/pom.xml | 7 ---- modules/commons/commons-process/pom.xml | 7 ---- modules/commons/commons-timeout/pom.xml | 7 ---- modules/commons/commons-xml2json/pom.xml | 7 ---- modules/database/database-h2/pom.xml | 7 ---- .../database/database-mongodb-jdbc/pom.xml | 7 ---- modules/database/database-sql-h2/pom.xml | 7 ---- modules/database/database-sql-hana/pom.xml | 7 ---- modules/database/database-sql-mongodb/pom.xml | 7 ---- modules/database/database-sql-mysql/pom.xml | 7 ---- .../database/database-sql-postgres/pom.xml | 7 ---- .../database/database-sql-snowflake/pom.xml | 7 ---- modules/database/database-sql-sybase/pom.xml | 7 ---- modules/database/database-sql/pom.xml | 7 ---- modules/mail/mail-env-config/pom.xml | 7 ---- modules/odata/odata-core-test/pom.xml | 7 ---- modules/odata/odata-core/pom.xml | 7 ---- modules/odata/odata-samples-northwind/pom.xml | 7 ---- .../repository/repository-api-test/pom.xml | 7 ---- modules/repository/repository-api/pom.xml | 7 ---- modules/repository/repository-cache/pom.xml | 7 ---- modules/repository/repository-local/pom.xml | 7 ---- modules/repository/repository-master/pom.xml | 7 ---- modules/repository/repository-search/pom.xml | 7 ---- modules/repository/repository-zip/pom.xml | 7 ---- pom.xml | 36 ++++--------------- 27 files changed, 7 insertions(+), 211 deletions(-) diff --git a/modules/commons/commons-config/pom.xml b/modules/commons/commons-config/pom.xml index d43a95807f6..8350057b64d 100644 --- a/modules/commons/commons-config/pom.xml +++ b/modules/commons/commons-config/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/commons/commons-helpers/pom.xml b/modules/commons/commons-helpers/pom.xml index d5d67053df1..112377fad92 100644 --- a/modules/commons/commons-helpers/pom.xml +++ b/modules/commons/commons-helpers/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/commons/commons-process/pom.xml b/modules/commons/commons-process/pom.xml index 16578703e3e..4e336d2e679 100644 --- a/modules/commons/commons-process/pom.xml +++ b/modules/commons/commons-process/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/commons/commons-timeout/pom.xml b/modules/commons/commons-timeout/pom.xml index 902001deccf..06eaa1b3202 100644 --- a/modules/commons/commons-timeout/pom.xml +++ b/modules/commons/commons-timeout/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/commons/commons-xml2json/pom.xml b/modules/commons/commons-xml2json/pom.xml index 8bc731b2315..1332a3b647f 100644 --- a/modules/commons/commons-xml2json/pom.xml +++ b/modules/commons/commons-xml2json/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-h2/pom.xml b/modules/database/database-h2/pom.xml index 7fbbd1cf578..1641fdf9608 100644 --- a/modules/database/database-h2/pom.xml +++ b/modules/database/database-h2/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-mongodb-jdbc/pom.xml b/modules/database/database-mongodb-jdbc/pom.xml index 092abcdb1fb..ae415b192ea 100644 --- a/modules/database/database-mongodb-jdbc/pom.xml +++ b/modules/database/database-mongodb-jdbc/pom.xml @@ -26,13 +26,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-h2/pom.xml b/modules/database/database-sql-h2/pom.xml index 08eac2501fb..e909eb56297 100644 --- a/modules/database/database-sql-h2/pom.xml +++ b/modules/database/database-sql-h2/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-hana/pom.xml b/modules/database/database-sql-hana/pom.xml index 2961216d8f9..9314cb264a3 100644 --- a/modules/database/database-sql-hana/pom.xml +++ b/modules/database/database-sql-hana/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-mongodb/pom.xml b/modules/database/database-sql-mongodb/pom.xml index 9e86c1bf18b..80f1ab86eb8 100644 --- a/modules/database/database-sql-mongodb/pom.xml +++ b/modules/database/database-sql-mongodb/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-mysql/pom.xml b/modules/database/database-sql-mysql/pom.xml index e2cf64c0206..9bf7bde000f 100644 --- a/modules/database/database-sql-mysql/pom.xml +++ b/modules/database/database-sql-mysql/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-postgres/pom.xml b/modules/database/database-sql-postgres/pom.xml index 06c70762ed4..56a6524bb5c 100644 --- a/modules/database/database-sql-postgres/pom.xml +++ b/modules/database/database-sql-postgres/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-snowflake/pom.xml b/modules/database/database-sql-snowflake/pom.xml index f89c2b9fdec..769f5ca1fa1 100644 --- a/modules/database/database-sql-snowflake/pom.xml +++ b/modules/database/database-sql-snowflake/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql-sybase/pom.xml b/modules/database/database-sql-sybase/pom.xml index 986a553ec7c..3eb0111136c 100644 --- a/modules/database/database-sql-sybase/pom.xml +++ b/modules/database/database-sql-sybase/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/database/database-sql/pom.xml b/modules/database/database-sql/pom.xml index e64b522dc5a..866a12279ad 100644 --- a/modules/database/database-sql/pom.xml +++ b/modules/database/database-sql/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/mail/mail-env-config/pom.xml b/modules/mail/mail-env-config/pom.xml index ed40cb9e9ea..b5e807e2ba4 100644 --- a/modules/mail/mail-env-config/pom.xml +++ b/modules/mail/mail-env-config/pom.xml @@ -21,13 +21,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index 5f5fba37dc8..76c0f4c1fc0 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -20,13 +20,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${custom.java.build.version} - ${custom.java.build.version} - true - lines,vars,source - diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index 509ce05fb69..9f8f8404cd9 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -20,13 +20,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${custom.java.build.version} - ${custom.java.build.version} - true - lines,vars,source - diff --git a/modules/odata/odata-samples-northwind/pom.xml b/modules/odata/odata-samples-northwind/pom.xml index bbde0829a5a..bf319c14c83 100644 --- a/modules/odata/odata-samples-northwind/pom.xml +++ b/modules/odata/odata-samples-northwind/pom.xml @@ -20,13 +20,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${custom.java.build.version} - ${custom.java.build.version} - true - lines,vars,source - diff --git a/modules/repository/repository-api-test/pom.xml b/modules/repository/repository-api-test/pom.xml index aad2d064c91..c96b7597680 100644 --- a/modules/repository/repository-api-test/pom.xml +++ b/modules/repository/repository-api-test/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/repository/repository-api/pom.xml b/modules/repository/repository-api/pom.xml index a468c5f9816..fa5137aac36 100644 --- a/modules/repository/repository-api/pom.xml +++ b/modules/repository/repository-api/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/repository/repository-cache/pom.xml b/modules/repository/repository-cache/pom.xml index dd9431254e3..8b5d5295d66 100644 --- a/modules/repository/repository-cache/pom.xml +++ b/modules/repository/repository-cache/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/repository/repository-local/pom.xml b/modules/repository/repository-local/pom.xml index f13d0bd9e65..09d7bdfd535 100644 --- a/modules/repository/repository-local/pom.xml +++ b/modules/repository/repository-local/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/repository/repository-master/pom.xml b/modules/repository/repository-master/pom.xml index ed5ee8beb28..779bc2e327b 100644 --- a/modules/repository/repository-master/pom.xml +++ b/modules/repository/repository-master/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/repository/repository-search/pom.xml b/modules/repository/repository-search/pom.xml index 6161b9099f8..a38ffb1d720 100644 --- a/modules/repository/repository-search/pom.xml +++ b/modules/repository/repository-search/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/modules/repository/repository-zip/pom.xml b/modules/repository/repository-zip/pom.xml index 39e4b1d34b1..d99eedd097e 100644 --- a/modules/repository/repository-zip/pom.xml +++ b/modules/repository/repository-zip/pom.xml @@ -19,13 +19,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - diff --git a/pom.xml b/pom.xml index 85c3de88f48..6fa69dc024c 100644 --- a/pom.xml +++ b/pom.xml @@ -114,6 +114,13 @@ org.apache.maven.plugins maven-compiler-plugin + + true + ${maven.compiler.source} + ${maven.compiler.target} + true + lines,vars,source + org.apache.maven.plugins @@ -192,13 +199,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - org.apache.maven.plugins @@ -318,13 +318,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - @@ -337,17 +330,9 @@ - org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - @@ -405,13 +390,6 @@ org.apache.maven.plugins maven-compiler-plugin - - true - ${maven.compiler.source} - ${maven.compiler.target} - true - lines,vars,source - org.apache.maven.plugins From 189a173a5d22bd438f013eab15dca7e8b6113011 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 12:25:57 +0200 Subject: [PATCH 29/64] maven-compiler-plugin in parent Signed-off-by: Iliyan Velichkov --- modules/commons/commons-config/pom.xml | 6 ----- modules/commons/commons-helpers/pom.xml | 6 ----- modules/commons/commons-process/pom.xml | 6 ----- modules/commons/commons-timeout/pom.xml | 6 ----- modules/commons/commons-xml2json/pom.xml | 6 ----- modules/database/database-h2/pom.xml | 6 ----- .../database/database-mongodb-jdbc/pom.xml | 6 ----- modules/database/database-sql-h2/pom.xml | 6 ----- modules/database/database-sql-hana/pom.xml | 6 ----- modules/database/database-sql-mongodb/pom.xml | 6 ----- modules/database/database-sql-mysql/pom.xml | 6 ----- .../database/database-sql-postgres/pom.xml | 6 ----- .../database/database-sql-snowflake/pom.xml | 6 ----- modules/database/database-sql-sybase/pom.xml | 6 ----- modules/database/database-sql/pom.xml | 6 ----- modules/mail/mail-env-config/pom.xml | 6 ----- modules/odata/odata-core-test/pom.xml | 5 ---- modules/odata/odata-core/pom.xml | 5 ---- modules/odata/odata-samples-northwind/pom.xml | 5 ---- .../repository/repository-api-test/pom.xml | 6 ----- modules/repository/repository-api/pom.xml | 6 ----- modules/repository/repository-cache/pom.xml | 6 ----- modules/repository/repository-local/pom.xml | 6 ----- modules/repository/repository-master/pom.xml | 6 ----- modules/repository/repository-search/pom.xml | 6 ----- modules/repository/repository-zip/pom.xml | 6 ----- pom.xml | 23 +++++-------------- 27 files changed, 6 insertions(+), 170 deletions(-) diff --git a/modules/commons/commons-config/pom.xml b/modules/commons/commons-config/pom.xml index 8350057b64d..89fe9ee3d0b 100644 --- a/modules/commons/commons-config/pom.xml +++ b/modules/commons/commons-config/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/commons/commons-helpers/pom.xml b/modules/commons/commons-helpers/pom.xml index 112377fad92..e35ffe94829 100644 --- a/modules/commons/commons-helpers/pom.xml +++ b/modules/commons/commons-helpers/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/commons/commons-process/pom.xml b/modules/commons/commons-process/pom.xml index 4e336d2e679..b4250a1998b 100644 --- a/modules/commons/commons-process/pom.xml +++ b/modules/commons/commons-process/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/commons/commons-timeout/pom.xml b/modules/commons/commons-timeout/pom.xml index 06eaa1b3202..4312353d93a 100644 --- a/modules/commons/commons-timeout/pom.xml +++ b/modules/commons/commons-timeout/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/commons/commons-xml2json/pom.xml b/modules/commons/commons-xml2json/pom.xml index 1332a3b647f..7c0a13c7193 100644 --- a/modules/commons/commons-xml2json/pom.xml +++ b/modules/commons/commons-xml2json/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-h2/pom.xml b/modules/database/database-h2/pom.xml index 1641fdf9608..7f493e4020d 100644 --- a/modules/database/database-h2/pom.xml +++ b/modules/database/database-h2/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-mongodb-jdbc/pom.xml b/modules/database/database-mongodb-jdbc/pom.xml index ae415b192ea..4b5056f31d3 100644 --- a/modules/database/database-mongodb-jdbc/pom.xml +++ b/modules/database/database-mongodb-jdbc/pom.xml @@ -22,12 +22,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-h2/pom.xml b/modules/database/database-sql-h2/pom.xml index e909eb56297..6b7fea84597 100644 --- a/modules/database/database-sql-h2/pom.xml +++ b/modules/database/database-sql-h2/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-hana/pom.xml b/modules/database/database-sql-hana/pom.xml index 9314cb264a3..18c52ac257f 100644 --- a/modules/database/database-sql-hana/pom.xml +++ b/modules/database/database-sql-hana/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-mongodb/pom.xml b/modules/database/database-sql-mongodb/pom.xml index 80f1ab86eb8..3ebda5ab71d 100644 --- a/modules/database/database-sql-mongodb/pom.xml +++ b/modules/database/database-sql-mongodb/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-mysql/pom.xml b/modules/database/database-sql-mysql/pom.xml index 9bf7bde000f..32457f78fc6 100644 --- a/modules/database/database-sql-mysql/pom.xml +++ b/modules/database/database-sql-mysql/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-postgres/pom.xml b/modules/database/database-sql-postgres/pom.xml index 56a6524bb5c..fa14a863307 100644 --- a/modules/database/database-sql-postgres/pom.xml +++ b/modules/database/database-sql-postgres/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-snowflake/pom.xml b/modules/database/database-sql-snowflake/pom.xml index 769f5ca1fa1..2be9b27673d 100644 --- a/modules/database/database-sql-snowflake/pom.xml +++ b/modules/database/database-sql-snowflake/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql-sybase/pom.xml b/modules/database/database-sql-sybase/pom.xml index 3eb0111136c..6aeb331a391 100644 --- a/modules/database/database-sql-sybase/pom.xml +++ b/modules/database/database-sql-sybase/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/database/database-sql/pom.xml b/modules/database/database-sql/pom.xml index 866a12279ad..d260745ec48 100644 --- a/modules/database/database-sql/pom.xml +++ b/modules/database/database-sql/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/mail/mail-env-config/pom.xml b/modules/mail/mail-env-config/pom.xml index b5e807e2ba4..52891245fee 100644 --- a/modules/mail/mail-env-config/pom.xml +++ b/modules/mail/mail-env-config/pom.xml @@ -17,12 +17,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index 76c0f4c1fc0..77431893e59 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -16,11 +16,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - org.apache.maven.plugins diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index 9f8f8404cd9..b65d04b6368 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -16,11 +16,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - org.apache.maven.plugins diff --git a/modules/odata/odata-samples-northwind/pom.xml b/modules/odata/odata-samples-northwind/pom.xml index bf319c14c83..93ea12129de 100644 --- a/modules/odata/odata-samples-northwind/pom.xml +++ b/modules/odata/odata-samples-northwind/pom.xml @@ -16,11 +16,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - org.apache.maven.plugins diff --git a/modules/repository/repository-api-test/pom.xml b/modules/repository/repository-api-test/pom.xml index c96b7597680..b70fdba31aa 100644 --- a/modules/repository/repository-api-test/pom.xml +++ b/modules/repository/repository-api-test/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/repository/repository-api/pom.xml b/modules/repository/repository-api/pom.xml index fa5137aac36..850003bfce1 100644 --- a/modules/repository/repository-api/pom.xml +++ b/modules/repository/repository-api/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/repository/repository-cache/pom.xml b/modules/repository/repository-cache/pom.xml index 8b5d5295d66..2fae70e269d 100644 --- a/modules/repository/repository-cache/pom.xml +++ b/modules/repository/repository-cache/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/repository/repository-local/pom.xml b/modules/repository/repository-local/pom.xml index 09d7bdfd535..8bbff606ca2 100644 --- a/modules/repository/repository-local/pom.xml +++ b/modules/repository/repository-local/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/repository/repository-master/pom.xml b/modules/repository/repository-master/pom.xml index 779bc2e327b..52e447a50c2 100644 --- a/modules/repository/repository-master/pom.xml +++ b/modules/repository/repository-master/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/repository/repository-search/pom.xml b/modules/repository/repository-search/pom.xml index a38ffb1d720..7dc4fb58859 100644 --- a/modules/repository/repository-search/pom.xml +++ b/modules/repository/repository-search/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/modules/repository/repository-zip/pom.xml b/modules/repository/repository-zip/pom.xml index d99eedd097e..f32963866d0 100644 --- a/modules/repository/repository-zip/pom.xml +++ b/modules/repository/repository-zip/pom.xml @@ -15,12 +15,6 @@ ${project.artifactId} - - - org.apache.maven.plugins - maven-compiler-plugin - - diff --git a/pom.xml b/pom.xml index 6fa69dc024c..7cb1e556214 100644 --- a/pom.xml +++ b/pom.xml @@ -92,6 +92,12 @@ + + + org.apache.maven.plugins + maven-compiler-plugin + + @@ -196,10 +202,6 @@ - - org.apache.maven.plugins - maven-compiler-plugin - org.apache.maven.plugins maven-surefire-plugin @@ -315,10 +317,6 @@ - - org.apache.maven.plugins - maven-compiler-plugin - @@ -330,11 +328,6 @@ - - org.apache.maven.plugins - maven-compiler-plugin - - com.github.spotbugs spotbugs-maven-plugin @@ -387,10 +380,6 @@ - - org.apache.maven.plugins - maven-compiler-plugin - org.apache.maven.plugins maven-source-plugin From 159535aa4cdcb43747dc99cce463f5926729e2be Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 12:31:33 +0200 Subject: [PATCH 30/64] centralized formatter-maven-plugin Signed-off-by: Iliyan Velichkov --- pom.xml | 46 +++++++++++++++++++--------------------------- 1 file changed, 19 insertions(+), 27 deletions(-) diff --git a/pom.xml b/pom.xml index 7cb1e556214..a2ea9c879bb 100644 --- a/pom.xml +++ b/pom.xml @@ -97,6 +97,10 @@ org.apache.maven.plugins maven-compiler-plugin + + net.revelc.code.formatter + formatter-maven-plugin + @@ -140,17 +144,24 @@ org.apache.maven.plugins maven-failsafe-plugin - - org.codehaus.mojo - exec-maven-plugin - net.revelc.code.formatter formatter-maven-plugin - - - org.apache.maven.plugins - maven-surefire-plugin + + ${formatter.location} + ${formatter.java.version} + ${formatter.java.version} + ${formatter.java.version} + + + + format-java-code + process-sources + + format + + + com.github.spotbugs @@ -183,25 +194,6 @@ - - net.revelc.code.formatter - formatter-maven-plugin - - ${formatter.location} - ${formatter.java.version} - ${formatter.java.version} - ${formatter.java.version} - - - - format-java-code - process-sources - - format - - - - org.apache.maven.plugins maven-surefire-plugin From c9dac537522d34d87b55c56edc835b8b0c69236a Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 12:41:51 +0200 Subject: [PATCH 31/64] set fixed plugins version Signed-off-by: Iliyan Velichkov --- pom.xml | 195 +++++++++++++++++++++++++++++++------------------------- 1 file changed, 109 insertions(+), 86 deletions(-) diff --git a/pom.xml b/pom.xml index a2ea9c879bb..450858b8b74 100644 --- a/pom.xml +++ b/pom.xml @@ -91,6 +91,103 @@ http://www.eclipse.org + + Eclipse Dirigible + + UTF-8 + UTF-8 + + 17 + 17 + 17 + + 3.11.0 + 3.6.2 + 3.1.2 + 3.1.2 + 3.1.0 + 0.8.11 + 4.8.2.0 + 2.23.0 + 3.1.1 + 4.9.10 + 4.3 + + 3.2.0 + 1.7.0 + 23.0.1 + 0.9.5.5 + 23.1.1 + 32.1.3-jre + 2.3.1 + 1.12.608 + 4.2.0 + 1.2.0 + 6.0.1 + 2.15.1 + 3.14.0 + 1.3 + 2.19.11 + 9.9.0 + 1.1.0 + 6.8.0 + 6.8.0.202311291450-r + 3.1.0 + 3.12.14 + 1.10.0 + + 1.13.0 + 11.7.0 + 0.30.2 + 1.8.2 + 1.6.5 + 5.1.0 + 0.40.0 + 2.3.6 + 3.3.12 + 3.6.0 + 1.0.8r1250 + 5.3.2 + 0.50 + 0.55 + 4.6.7 + 2.6.1 + 1.8.2 + 4.7.0 + 4.8.165 + 1.19.3 + 0.7.6 + 2.9.2 + 2.2.3 + 2.11.0 + 74.1 + 2.3 + 3.0.48.202308291007 + 0.64.8 + + none + + + https://github.com/dirigiblelabs/${content.repository.name} + + scm:git:https://github.com/dirigiblelabs/${content.repository.name}.git + + scm:git:https://github.com/dirigiblelabs/${content.repository.name} + master + + github + target + target/${content.project.name} + + ${basedir}/src/main/resources/META-INF/dirigible/${content.project.name} + + licensing-header.txt + + ./ + ${parent.pom.folder}/dirigible-formatter.xml + ${java.version} + + @@ -107,14 +204,17 @@ org.springframework.boot spring-boot-maven-plugin + ${spring.boot.version} pl.project13.maven git-commit-id-plugin + ${git-commit-id-plugin.version} org.codehaus.mojo exec-maven-plugin + ${exec-maven-plugin.version} com.mycila @@ -124,6 +224,7 @@ org.apache.maven.plugins maven-compiler-plugin + ${maven-compiler-plugin.version} true ${maven.compiler.source} @@ -135,18 +236,22 @@ org.apache.maven.plugins maven-javadoc-plugin + ${maven-javadoc-plugin.version} org.apache.maven.plugins maven-surefire-plugin + ${maven-surefire-plugin.version} org.apache.maven.plugins maven-failsafe-plugin + ${maven-failsafe-plugin.version} net.revelc.code.formatter formatter-maven-plugin + ${formatter-maven-plugin.version} ${formatter.location} ${formatter.java.version} @@ -166,18 +271,22 @@ com.github.spotbugs spotbugs-maven-plugin + ${spotbugs-maven-plugin.version} org.jacoco jacoco-maven-plugin + ${jacoco-maven-plugin.version} org.apache.maven.plugins maven-source-plugin + ${maven-source-plugin.version} org.apache.maven.plugins maven-gpg-plugin + ${maven-gpg-plugin.version} @@ -595,90 +704,4 @@ - - Eclipse Dirigible - - UTF-8 - UTF-8 - - 17 - 17 - 17 - - 3.2.0 - 1.7.0 - 23.0.1 - 0.9.5.5 - 23.1.1 - 32.1.3-jre - 2.3.1 - 1.12.608 - 4.2.0 - 1.2.0 - 6.0.1 - 2.15.1 - 3.14.0 - 1.3 - 2.19.11 - 9.9.0 - 1.1.0 - 6.8.0 - 4.3 - 6.8.0.202311291450-r - 3.1.0 - 3.12.14 - 1.10.0 - - 1.13.0 - 11.7.0 - 0.30.2 - 1.8.2 - 1.6.5 - 5.1.0 - 0.40.0 - 2.3.6 - 3.3.12 - 3.6.0 - 1.0.8r1250 - 5.3.2 - 0.50 - 0.55 - 4.6.7 - 2.6.1 - 1.8.2 - 4.7.0 - 4.8.165 - 1.19.3 - 0.7.6 - 2.9.2 - 2.2.3 - 2.11.0 - 74.1 - 2.3 - 3.0.48.202308291007 - 0.64.8 - - none - - - https://github.com/dirigiblelabs/${content.repository.name} - - scm:git:https://github.com/dirigiblelabs/${content.repository.name}.git - - scm:git:https://github.com/dirigiblelabs/${content.repository.name} - master - - github - target - target/${content.project.name} - - ${basedir}/src/main/resources/META-INF/dirigible/${content.project.name} - - licensing-header.txt - - ./ - ${parent.pom.folder}/dirigible-formatter.xml - ${java.version} - - From 43d257fdcf3f4f823b64df079aa2d5740fc8fd17 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Fri, 15 Dec 2023 13:28:11 +0200 Subject: [PATCH 32/64] improve logging Signed-off-by: Iliyan Velichkov --- .../application/src/main/resources/logback.xml | 4 ++-- .../synchronizer/SynchronizationProcessor.java | 2 +- .../javascript/service/JavascriptHandler.java | 18 +++++++++--------- .../api/utils/moduleInfoCache.js | 2 +- 4 files changed, 13 insertions(+), 13 deletions(-) diff --git a/build/application/src/main/resources/logback.xml b/build/application/src/main/resources/logback.xml index d6f81ae6ceb..c34cf75f6ec 100644 --- a/build/application/src/main/resources/logback.xml +++ b/build/application/src/main/resources/logback.xml @@ -57,7 +57,7 @@ - + @@ -69,6 +69,6 @@ - + \ No newline at end of file diff --git a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java index fe9cd20261f..104a914d065 100644 --- a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java +++ b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java @@ -353,7 +353,7 @@ public synchronized void processSynchronizers() { // report results getErrors().forEach(e -> { - logger.error("Error occured during synchronization: " + e); + logger.error("Error occured during synchronization: ", e); }); } finally { if (logger.isDebugEnabled()) { diff --git a/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java b/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java index e4adac3cdf3..79844e3cc57 100644 --- a/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java +++ b/components/engine/engine-javascript/src/main/java/org/eclipse/dirigible/components/engine/javascript/service/JavascriptHandler.java @@ -100,21 +100,21 @@ public Object handleRequest(String projectName, String projectFilePath, String p value); return transformValue(value); } - } catch (Exception e) { - if (e.getMessage() == null) { + } catch (Throwable ex) { + if (ex.getMessage() == null) { logger.error("Null object has been found"); - return e.getMessage(); + return ex.getMessage(); } - if (e.getMessage() - .contains("consider publish")) { - logger.error(e.getMessage(), e); - return e.getMessage(); + if (ex.getMessage() + .contains("consider publish")) { + logger.error(ex.getMessage(), ex); + return ex.getMessage(); } String errorMessage = String.format("Error on processing JavaScript service from project: [%s], and path: [%s], with parameters: [%s]", projectName, projectFilePath, projectFilePathParam); - logger.error(errorMessage, e); - throw new RuntimeException(e.getMessage(), e); + logger.error(errorMessage, ex); + throw new RuntimeException(ex.getMessage(), ex); } } diff --git a/components/ide/ide-ui-monaco-extensions/src/main/resources/META-INF/dirigible/ide-monaco-extensions/api/utils/moduleInfoCache.js b/components/ide/ide-ui-monaco-extensions/src/main/resources/META-INF/dirigible/ide-monaco-extensions/api/utils/moduleInfoCache.js index 75a4d14d417..a9319e821c6 100644 --- a/components/ide/ide-ui-monaco-extensions/src/main/resources/META-INF/dirigible/ide-monaco-extensions/api/utils/moduleInfoCache.js +++ b/components/ide/ide-ui-monaco-extensions/src/main/resources/META-INF/dirigible/ide-monaco-extensions/api/utils/moduleInfoCache.js @@ -43,7 +43,7 @@ exports.get = function (moduleName) { saveModuleInfo(moduleInfo); } } catch (e) { - console.error(`Error occured ${e}`); + console.error(`Error occured: [${e}]`); } return moduleInfo; }; From 7afb67f3caec3d65f2431d539acf0dac5f9b2462 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Sun, 17 Dec 2023 17:17:39 +0200 Subject: [PATCH 33/64] use olingo from the codbex fork repo https://github.com/codbex/olingo-odata2 Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 2 +- modules/odata/odata-core-test/pom.xml | 8 ++++---- modules/odata/odata-core/pom.xml | 2 +- pom.xml | 2 +- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index 63e2da53e9a..94bcd09a177 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -129,7 +129,7 @@ - org.apache.olingo + com.codbex.olingo olingo-odata2-lib ${olingo.version} pom diff --git a/modules/odata/odata-core-test/pom.xml b/modules/odata/odata-core-test/pom.xml index 77431893e59..5040a416cd6 100644 --- a/modules/odata/odata-core-test/pom.xml +++ b/modules/odata/odata-core-test/pom.xml @@ -61,22 +61,22 @@ - org.apache.olingo + com.codbex.olingo olingo-odata2-annotation-processor-core ${olingo.version} - org.apache.olingo + com.codbex.olingo olingo-odata2-api ${olingo.version} - org.apache.olingo + com.codbex.olingo olingo-odata2-api-annotation ${olingo.version} - org.apache.olingo + com.codbex.olingo olingo-odata2-annotation-processor-api ${olingo.version} diff --git a/modules/odata/odata-core/pom.xml b/modules/odata/odata-core/pom.xml index b65d04b6368..7122e57530c 100644 --- a/modules/odata/odata-core/pom.xml +++ b/modules/odata/odata-core/pom.xml @@ -35,7 +35,7 @@ - org.apache.olingo + com.codbex.olingo olingo-odata2-core ${olingo.version} diff --git a/pom.xml b/pom.xml index 450858b8b74..d2ce22730a8 100644 --- a/pom.xml +++ b/pom.xml @@ -132,7 +132,7 @@ 1.1.0 6.8.0 6.8.0.202311291450-r - 3.1.0 + 3.1.3 3.12.14 1.10.0 From 799bb97bbbb3ba8a8e588d94e45eb20e270676cd Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Sun, 17 Dec 2023 17:43:37 +0200 Subject: [PATCH 34/64] fix javadoc error Signed-off-by: Iliyan Velichkov --- .../initializers/synchronizer/SynchronizationProcessor.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java index 104a914d065..d42e52021db 100644 --- a/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java +++ b/components/core/core-initializers/src/main/java/org/eclipse/dirigible/components/initializers/synchronizer/SynchronizationProcessor.java @@ -515,7 +515,7 @@ public void registerParsedState(Definition definition) { * Register broken state. * * @param definition the definition - * @param e the e + * @param errorMessage the error message */ public void registerBrokenState(Definition definition, String errorMessage) { registerBrokenState(definition, null, errorMessage); From 1f686ac01ffc9448a1a4cbba4def91d91cfdfffa Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Sun, 17 Dec 2023 18:02:08 +0200 Subject: [PATCH 35/64] integration tests on ubuntu as well --- .github/workflows/pull-request.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index dcb90ec55a3..9abf855b71d 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -47,7 +47,7 @@ jobs: continue-on-error: true strategy: matrix: - os: [windows] + os: [ubuntu, windows] steps: - name: Setup Chrome uses: browser-actions/setup-chrome@v1.3.0 From 998a98862f9227f0d068a9a11fef621df010bbd0 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Sun, 17 Dec 2023 18:08:57 +0200 Subject: [PATCH 36/64] Update pull-request.yml --- .github/workflows/pull-request.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index 9abf855b71d..dcb90ec55a3 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -47,7 +47,7 @@ jobs: continue-on-error: true strategy: matrix: - os: [ubuntu, windows] + os: [windows] steps: - name: Setup Chrome uses: browser-actions/setup-chrome@v1.3.0 From a094956e37917ea801f0612a30d65715436539fd Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 18 Dec 2023 09:16:32 +0200 Subject: [PATCH 37/64] remove provided scopes Signed-off-by: Iliyan Velichkov --- pom.xml | 3 --- 1 file changed, 3 deletions(-) diff --git a/pom.xml b/pom.xml index d2ce22730a8..a20ee93f648 100644 --- a/pom.xml +++ b/pom.xml @@ -600,17 +600,14 @@ org.slf4j slf4j-api - provided ch.qos.logback logback-core - provided ch.qos.logback logback-classic - provided From cec41dbf030f6594e60e48333eb672f8e76502f3 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 18 Dec 2023 15:56:10 +0200 Subject: [PATCH 38/64] add keycloak conifugations Signed-off-by: Iliyan Velichkov --- .gitignore | 4 +- build/application/pom.xml | 5 -- .../resources/application-keycloak.properties | 11 +++ .../resources/application-oauth.properties | 4 + .../src/main/resources/application.properties | 16 +--- .../dirigible/templates/dirigible.yaml | 16 ++-- .../basic/BasicAuthSecurityConfiguration.java | 4 +- components/security/security-keycloak/pom.xml | 83 ++++++++++--------- .../keycloak/KeycloakConfiguration.java | 26 ------ .../KeycloakSecurityConfiguration.java | 31 ++++++- .../oauth2/OAuth2SecurityConfiguration.java | 10 +-- .../spring-start-dirigibile-keycloak.launch | 40 +++++++++ .../spring-start-dirigibile-oauth.launch | 39 +++++++++ misc/eclipse/spring-start-dirigibile.launch | 35 ++++++++ .../commons/config/Configuration.java | 24 +++--- pom.xml | 1 - .../dirigible/modules-tests/build-source.sh | 2 + 17 files changed, 235 insertions(+), 116 deletions(-) create mode 100644 build/application/src/main/resources/application-keycloak.properties create mode 100644 build/application/src/main/resources/application-oauth.properties delete mode 100644 components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakConfiguration.java create mode 100644 misc/eclipse/spring-start-dirigibile-keycloak.launch create mode 100644 misc/eclipse/spring-start-dirigibile-oauth.launch create mode 100644 misc/eclipse/spring-start-dirigibile.launch diff --git a/.gitignore b/.gitignore index 73177dda138..034fa517ac8 100644 --- a/.gitignore +++ b/.gitignore @@ -8,7 +8,9 @@ bin/ .history .vscode node_modules -build/ +**/build +build/application/dirigible +!/build # files .DS_Store diff --git a/build/application/pom.xml b/build/application/pom.xml index 94bcd09a177..a2dfc5e9b89 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -15,11 +15,6 @@ jar - - org.springframework.boot - spring-boot-properties-migrator - runtime - org.slf4j diff --git a/build/application/src/main/resources/application-keycloak.properties b/build/application/src/main/resources/application-keycloak.properties new file mode 100644 index 00000000000..1b6306203b7 --- /dev/null +++ b/build/application/src/main/resources/application-keycloak.properties @@ -0,0 +1,11 @@ +basic.enabled=false + +# example https://keycloak.apps.dirigible.io/auth/realms/dirigible +spring.security.oauth2.client.provider.keycloak.issuer-uri=${DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL} + +spring.security.oauth2.client.registration.keycloak.provider=keycloak +spring.security.oauth2.client.registration.keycloak.client-id=${DIRIGIBLE_KEYCLOAK_CLIENT_ID} +spring.security.oauth2.client.registration.keycloak.scope=openid,profile,roles,microprofile-jwt,email,phone,web-origins,address,offline_access +spring.security.oauth2.client.registration.keycloak.authorization-grant-type=authorization_code + +spring.security.oauth2.client.provider.keycloak.user-name-attribute=preferred_username diff --git a/build/application/src/main/resources/application-oauth.properties b/build/application/src/main/resources/application-oauth.properties new file mode 100644 index 00000000000..ddc4b76fe0c --- /dev/null +++ b/build/application/src/main/resources/application-oauth.properties @@ -0,0 +1,4 @@ +basic.enabled=false + +spring.security.oauth2.client.registration.github.clientId=${GITHUB_CLIENT_ID} +spring.security.oauth2.client.registration.github.clientSecret=${GITHUB_CLIENT_SECRET} diff --git a/build/application/src/main/resources/application.properties b/build/application/src/main/resources/application.properties index 56271dbc08f..cae4d72735b 100644 --- a/build/application/src/main/resources/application.properties +++ b/build/application/src/main/resources/application.properties @@ -12,24 +12,10 @@ spring.mvc.async.request-timeout=3600000 basic.enabled=${DIRIGIBLE_BASIC_ENABLED:true} -keycloak.enabled=${DIRIGIBLE_KEYCLOAK_ENABLED:false} -keycloak.realm=${DIRIGIBLE_KEYCLOAK_REALM:null} -keycloak.auth-server-url=${DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL:null} -keycloak.ssl-required=${DIRIGIBLE_KEYCLOAK_SSL_REQUIRED:external} -keycloak.resource=${DIRIGIBLE_KEYCLOAK_CLIENT_ID:null} -keycloak.public-client=true -keycloak.principal-attribute=preferred_username -keycloak.confidential-port=${DIRIGIBLE_KEYCLOAK_CONFIDENTIAL_PORT:443} -keycloak.use-resource-role-mappings=true - -oauth2.enabled=${DIRIGIBLE_OAUTH2_ENABLED:false} -spring.security.oauth2.client.registration.github.clientId=${GITHUB_CLIENT_ID} -spring.security.oauth2.client.registration.github.clientSecret=${GITHUB_CLIENT_SECRET} - terminal.enabled=${DIRIGIBLE_TERMINAL_ENABLED:false} management.metrics.mongo.command.enabled=false management.metrics.mongo.connectionpool.enabled=false spring.devtools.restart.poll-interval=6s -spring.devtools.restart.quiet-period=5s \ No newline at end of file +spring.devtools.restart.quiet-period=5s diff --git a/build/helm-charts/dirigible/templates/dirigible.yaml b/build/helm-charts/dirigible/templates/dirigible.yaml index 7f158dd4371..1cedd935d1e 100644 --- a/build/helm-charts/dirigible/templates/dirigible.yaml +++ b/build/helm-charts/dirigible/templates/dirigible.yaml @@ -155,27 +155,21 @@ spec: value: "true" {{- end }} {{- if .Values.keycloak.enabled }} - - name: DIRIGIBLE_KEYCLOAK_ENABLED - value: "true" + - name: spring_profiles_active + value: "keycloak" - name: DIRIGIBLE_BASIC_ENABLED value: "false" - - name: DIRIGIBLE_KEYCLOAK_CONFIDENTIAL_PORT - value: "443" - - name: DIRIGIBLE_KEYCLOAK_SSL_REQUIRED - value: "none" - - name: DIRIGIBLE_KEYCLOAK_REALM - value: {{ required "Missing Keycloak realm" .Values.keycloak.realm }} - name: DIRIGIBLE_KEYCLOAK_CLIENT_ID value: {{ required "Missing Keycloak client id" .Values.keycloak.clientId }} {{- if .Values.ingress.enabled }} - name: DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL - value: http{{ if $.Values.ingress.tls }}s{{ end }}://{{ required "Missing Keycloak name" .Values.keycloak.name }}.{{ required "Missing ingress host" .Values.ingress.host }}/auth/ + value: http{{ if $.Values.ingress.tls }}s{{ end }}://{{ required "Missing Keycloak name" .Values.keycloak.name }}.{{ required "Missing ingress host" .Values.ingress.host }}/auth/realms/{{ required "Missing Keycloak realm" .Values.keycloak.realm }} {{- else if .Values.istio.enabled }} - name: DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL - value: http{{ if $.Values.ingress.tls }}s{{ end }}://{{ required "Missing Keycloak name" .Values.keycloak.name }}.{{ required "Missing ingress host" .Values.ingress.host }}/auth/ + value: http{{ if $.Values.ingress.tls }}s{{ end }}://{{ required "Missing Keycloak name" .Values.keycloak.name }}.{{ required "Missing ingress host" .Values.ingress.host }}/auth/realms/{{ required "Missing Keycloak realm" .Values.keycloak.realm }} {{- else }} - name: DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL - value: https://{{ required "Missing Keycloak name" .Values.keycloak.name }}/auth/ + value: https://{{ required "Missing Keycloak name" .Values.keycloak.name }}/auth/realms/{{ required "Missing Keycloak realm" .Values.keycloak.realm }} {{- end }} {{- end }} securityContext: diff --git a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java index e9474925a90..985549f2aba 100644 --- a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java +++ b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java @@ -29,12 +29,12 @@ @Configuration @ConditionalOnProperty(name = "basic.enabled", havingValue = "true") -public class BasicAuthSecurityConfiguration { +class BasicAuthSecurityConfiguration { @Bean SecurityFilterChain filterChain(HttpSecurity http) throws Exception { http.cors(Customizer.withDefaults()) - .csrf((csrf) -> csrf.disable()) + .csrf(csrf -> csrf.disable()) .httpBasic(Customizer.withDefaults()) .formLogin(Customizer.withDefaults()) .logout(logout -> logout.deleteCookies("JSESSIONID")) diff --git a/components/security/security-keycloak/pom.xml b/components/security/security-keycloak/pom.xml index 5547a90ea62..b39d8e17239 100644 --- a/components/security/security-keycloak/pom.xml +++ b/components/security/security-keycloak/pom.xml @@ -1,42 +1,51 @@ - - 4.0.0 - - - dirigible-components-parent - org.eclipse.dirigible - 10.0.0-SNAPSHOT - ../../pom.xml - - - Components - Security - Keycloak - dirigible-components-security-keycloak - jar - - - - org.eclipse.dirigible - dirigible-components-core-base - - - - org.springframework.boot - spring-boot-starter-security - - - org.keycloak - keycloak-spring-boot-starter - ${keycloak.keycloak-spring-boot-starter} - - - - - - ../../../licensing-header.txt + xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" + xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> + + 4.0.0 + + + dirigible-components-parent + org.eclipse.dirigible + 10.0.0-SNAPSHOT + ../../pom.xml + + + Components - Security - Keycloak + dirigible-components-security-keycloak + jar + + + + + org.keycloak.bom + keycloak-adapter-bom + 23.0.3 + pom + import + + + + + + + org.eclipse.dirigible + dirigible-components-core-base + + + org.springframework.boot + spring-boot-starter-oauth2-client + + + org.springframework.boot + spring-boot-starter-security + + + + + ../../../licensing-header.txt ../../../ - + \ No newline at end of file diff --git a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakConfiguration.java b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakConfiguration.java deleted file mode 100644 index 89f5b7b5daa..00000000000 --- a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakConfiguration.java +++ /dev/null @@ -1,26 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible.components.security.keycloak; - -import org.keycloak.adapters.springboot.KeycloakSpringBootConfigResolver; -import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; - -@Configuration -@ConditionalOnProperty(name = "keycloak.enabled", havingValue = "true") -public class KeycloakConfiguration { - - @Bean - public KeycloakSpringBootConfigResolver keycloakSpringBootConfigResolver() { - return new KeycloakSpringBootConfigResolver(); - } -} diff --git a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java index 883accde3d0..0b93815c0d7 100644 --- a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java +++ b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java @@ -10,7 +10,36 @@ */ package org.eclipse.dirigible.components.security.keycloak; -// TODO: to be adapted +import org.eclipse.dirigible.components.base.http.access.HttpSecurityURIConfigurator; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.context.annotation.Profile; +import org.springframework.security.config.Customizer; +import org.springframework.security.config.annotation.method.configuration.EnableMethodSecurity; +import org.springframework.security.config.annotation.web.builders.HttpSecurity; +import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; +import org.springframework.security.config.http.SessionCreationPolicy; +import org.springframework.security.web.SecurityFilterChain; + +@Profile("keycloak") +@Configuration +@EnableWebSecurity +@EnableMethodSecurity class KeycloakSecurityConfiguration { + @Bean + SecurityFilterChain configure(HttpSecurity http) throws Exception { + http// + .authorizeHttpRequests(authz -> authz.requestMatchers("/oauth2/**", "/login/**") + .permitAll()) + .csrf(csrf -> csrf.disable()) + .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.sameOrigin())) + .oauth2Client(Customizer.withDefaults()) + .oauth2Login(Customizer.withDefaults()) + .sessionManagement(sessionManagement -> sessionManagement.sessionCreationPolicy(SessionCreationPolicy.ALWAYS)); + + HttpSecurityURIConfigurator.configure(http); + + return http.build(); + } } diff --git a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java index ad5635eaaee..b7f3dbe6dc0 100644 --- a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java +++ b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java @@ -11,22 +11,22 @@ package org.eclipse.dirigible.components.security.oauth2; import org.eclipse.dirigible.components.base.http.access.HttpSecurityURIConfigurator; -import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; +import org.springframework.context.annotation.Profile; import org.springframework.security.config.Customizer; import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.web.SecurityFilterChain; +@Profile("oauth") @Configuration -@ConditionalOnProperty(name = "oauth2.enabled", havingValue = "true") -public class OAuth2SecurityConfiguration { +class OAuth2SecurityConfiguration { @Bean - public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { + SecurityFilterChain filterChain(HttpSecurity http) throws Exception { http.cors(Customizer.withDefaults()) - .csrf((csrf) -> csrf.disable()) + .csrf(csrf -> csrf.disable()) .headers(headers -> headers.frameOptions(frameOpts -> frameOpts.disable())) .oauth2Login(Customizer.withDefaults()); diff --git a/misc/eclipse/spring-start-dirigibile-keycloak.launch b/misc/eclipse/spring-start-dirigibile-keycloak.launch new file mode 100644 index 00000000000..2c15ab02b50 --- /dev/null +++ b/misc/eclipse/spring-start-dirigibile-keycloak.launch @@ -0,0 +1,40 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/misc/eclipse/spring-start-dirigibile-oauth.launch b/misc/eclipse/spring-start-dirigibile-oauth.launch new file mode 100644 index 00000000000..a59460f0d1a --- /dev/null +++ b/misc/eclipse/spring-start-dirigibile-oauth.launch @@ -0,0 +1,39 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/misc/eclipse/spring-start-dirigibile.launch b/misc/eclipse/spring-start-dirigibile.launch new file mode 100644 index 00000000000..39329157060 --- /dev/null +++ b/misc/eclipse/spring-start-dirigibile.launch @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/modules/commons/commons-config/src/main/java/org/eclipse/dirigible/commons/config/Configuration.java b/modules/commons/commons-config/src/main/java/org/eclipse/dirigible/commons/config/Configuration.java index 330ef5abbfc..c3dd301ef68 100644 --- a/modules/commons/commons-config/src/main/java/org/eclipse/dirigible/commons/config/Configuration.java +++ b/modules/commons/commons-config/src/main/java/org/eclipse/dirigible/commons/config/Configuration.java @@ -11,7 +11,6 @@ package org.eclipse.dirigible.commons.config; import static java.text.MessageFormat.format; - import java.io.IOException; import java.io.InputStream; import java.lang.reflect.Field; @@ -21,7 +20,6 @@ import java.util.Map; import java.util.Properties; import java.util.Set; - import org.apache.commons.lang3.reflect.FieldUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -345,7 +343,7 @@ public static boolean isAnonymousUserEnabled() { * @return true, if the OAuth authentication is enabled */ public static boolean isOAuthAuthenticationEnabled() { - return Boolean.parseBoolean(get("DIRIGIBLE_OAUTH_ENABLED", Boolean.FALSE.toString())); + return isActiveSpringProfile("oauth"); } /** @@ -354,7 +352,11 @@ public static boolean isOAuthAuthenticationEnabled() { * @return true, if the Keycloak authentication is enabled */ public static boolean isKeycloakModeEnabled() { - return Boolean.parseBoolean(get("DIRIGIBLE_KEYCLOAK_ENABLED", Boolean.FALSE.toString())); + return isActiveSpringProfile("keycloak"); + } + + private static boolean isActiveSpringProfile(String profile) { + return get("spring.profiles.active", "").contains(profile) || get("spring_profiles_active", "").contains(profile); } /** @@ -440,10 +442,10 @@ public static Map getModuleVariables() { } /** The Constant CONFIGURATION_PARAMETERS. */ - private static final String[] CONFIGURATION_PARAMETERS = new String[] {"DIRIGIBLE_ANONYMOUS_USER_NAME_PROPERTY_NAME", - "DIRIGIBLE_BRANDING_NAME", "DIRIGIBLE_BRANDING_BRAND", "DIRIGIBLE_BRANDING_ICON", "DIRIGIBLE_BRANDING_WELCOME_PAGE_DEFAULT", - "DIRIGIBLE_GIT_ROOT_FOLDER", "DIRIGIBLE_REGISTRY_EXTERNAL_FOLDER", "DIRIGIBLE_REGISTRY_IMPORT_WORKSPACE", - "DIRIGIBLE_REPOSITORY_PROVIDER", "DIRIGIBLE_REPOSITORY_DATABASE_DATASOURCE_NAME", "DIRIGIBLE_REPOSITORY_LOCAL_ROOT_FOLDER", + private static final String[] CONFIGURATION_PARAMETERS = {"DIRIGIBLE_ANONYMOUS_USER_NAME_PROPERTY_NAME", "DIRIGIBLE_BRANDING_NAME", + "DIRIGIBLE_BRANDING_BRAND", "DIRIGIBLE_BRANDING_ICON", "DIRIGIBLE_BRANDING_WELCOME_PAGE_DEFAULT", "DIRIGIBLE_GIT_ROOT_FOLDER", + "DIRIGIBLE_REGISTRY_EXTERNAL_FOLDER", "DIRIGIBLE_REGISTRY_IMPORT_WORKSPACE", "DIRIGIBLE_REPOSITORY_PROVIDER", + "DIRIGIBLE_REPOSITORY_DATABASE_DATASOURCE_NAME", "DIRIGIBLE_REPOSITORY_LOCAL_ROOT_FOLDER", "DIRIGIBLE_REPOSITORY_LOCAL_ROOT_FOLDER_IS_ABSOLUTE", "DIRIGIBLE_MASTER_REPOSITORY_PROVIDER", "DIRIGIBLE_MASTER_REPOSITORY_ROOT_FOLDER", "DIRIGIBLE_MASTER_REPOSITORY_ZIP_LOCATION", "DIRIGIBLE_MASTER_REPOSITORY_JAR_PATH", "DIRIGIBLE_REPOSITORY_SEARCH_ROOT_FOLDER", "DIRIGIBLE_REPOSITORY_SEARCH_ROOT_FOLDER_IS_ABSOLUTE", @@ -488,8 +490,7 @@ public static Map getModuleVariables() { "DIRIGIBLE_EXEC_COMMAND_LOGGING_ENABLED", "DIRIGIBLE_TERMINAL_ENABLED", "DIRIGIBLE_MAIL_CONFIG_PROVIDER", "DIRIGIBLE_MAIL_USERNAME", "DIRIGIBLE_MAIL_PASSWORD", "DIRIGIBLE_MAIL_TRANSPORT_PROTOCOL", "DIRIGIBLE_MAIL_SMTPS_HOST", "DIRIGIBLE_MAIL_SMTPS_PORT", "DIRIGIBLE_MAIL_SMTPS_AUTH", "DIRIGIBLE_MAIL_SMTP_HOST", "DIRIGIBLE_MAIL_SMTP_PORT", - "DIRIGIBLE_MAIL_SMTP_AUTH", "DIRIGIBLE_KEYCLOAK_ENABLED", "DIRIGIBLE_KEYCLOAK_REALM", "DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL", - "DIRIGIBLE_KEYCLOAK_SSL_REQUIRED", "DIRIGIBLE_KEYCLOAK_CLIENT_ID", "DIRIGIBLE_KEYCLOAK_CONFIDENTIAL_PORT", + "DIRIGIBLE_MAIL_SMTP_AUTH", "DIRIGIBLE_KEYCLOAK_AUTH_SERVER_URL", "DIRIGIBLE_KEYCLOAK_CLIENT_ID", "DIRIGIBLE_CSV_DATA_MAX_COMPARE_SIZE", "DIRIGIBLE_CSV_DATA_BATCH_SIZE", "DIRIGIBLE_DESTINATION_CLIENT_ID", "DIRIGIBLE_DESTINATION_CLIENT_SECRET", "DIRIGIBLE_DESTINATION_URL", "DIRIGIBLE_DESTINATION_URI", "DIRIGIBLE_BASIC_ENABLED", "DIRIGIBLE_BASIC_USERNAME", "DIRIGIBLE_BASIC_PASSWORD", "DIRIGIBLE_FTP_USERNAME", "DIRIGIBLE_FTP_PASSWORD", @@ -565,8 +566,7 @@ public static void configureObject(Object o) { for (Field field : FieldUtils.getAllFields(o.getClass())) { Object v = FieldUtils.readField(field, o, true); if (v != null) { - if (v instanceof String) { - String s = (String) v; + if (v instanceof String s) { if (s.startsWith("${") && s.endsWith("}")) { if (s.indexOf("}.{") > 0) { String k = s.substring(2, s.indexOf("}.{")); diff --git a/pom.xml b/pom.xml index a20ee93f648..e7cb7a5de5f 100644 --- a/pom.xml +++ b/pom.xml @@ -115,7 +115,6 @@ 3.2.0 1.7.0 - 23.0.1 0.9.5.5 23.1.1 32.1.3-jre diff --git a/tests/src/test/resources/META-INF/dirigible/modules-tests/build-source.sh b/tests/src/test/resources/META-INF/dirigible/modules-tests/build-source.sh index b17078620e2..d524ab9eb92 100755 --- a/tests/src/test/resources/META-INF/dirigible/modules-tests/build-source.sh +++ b/tests/src/test/resources/META-INF/dirigible/modules-tests/build-source.sh @@ -1,3 +1,5 @@ +set -e + # clean rm -rf ./dist From 9b2a66207ca81dcb00a4e1be89778a017d5e6f8f Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 18 Dec 2023 16:09:59 +0200 Subject: [PATCH 39/64] rebase Signed-off-by: Iliyan Velichkov --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index e7cb7a5de5f..787b567e8b5 100644 --- a/pom.xml +++ b/pom.xml @@ -119,7 +119,7 @@ 23.1.1 32.1.3-jre 2.3.1 - 1.12.608 + 1.12.620 4.2.0 1.2.0 6.0.1 From 4c63065f9266c68bf3d23f7084dfa5a330353ede Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 18 Dec 2023 16:13:34 +0200 Subject: [PATCH 40/64] remove dependencyManagement Signed-off-by: Iliyan Velichkov --- components/security/security-keycloak/pom.xml | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/components/security/security-keycloak/pom.xml b/components/security/security-keycloak/pom.xml index b39d8e17239..eb30beaaebe 100644 --- a/components/security/security-keycloak/pom.xml +++ b/components/security/security-keycloak/pom.xml @@ -16,18 +16,6 @@ dirigible-components-security-keycloak jar - - - - org.keycloak.bom - keycloak-adapter-bom - 23.0.3 - pom - import - - - - org.eclipse.dirigible From b12bef78a10718cf02049736a1cc1164820ff252 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 18 Dec 2023 16:30:08 +0200 Subject: [PATCH 41/64] fix javadoc generation Signed-off-by: Iliyan Velichkov --- .../security/basic/BasicAuthSecurityConfiguration.java | 2 +- .../security/keycloak/KeycloakSecurityConfiguration.java | 2 +- .../components/security/oauth2/OAuth2SecurityConfiguration.java | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java index 985549f2aba..7af63cfd9cc 100644 --- a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java +++ b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java @@ -29,7 +29,7 @@ @Configuration @ConditionalOnProperty(name = "basic.enabled", havingValue = "true") -class BasicAuthSecurityConfiguration { +public class BasicAuthSecurityConfiguration { @Bean SecurityFilterChain filterChain(HttpSecurity http) throws Exception { diff --git a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java index 0b93815c0d7..27581a2849e 100644 --- a/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java +++ b/components/security/security-keycloak/src/main/java/org/eclipse/dirigible/components/security/keycloak/KeycloakSecurityConfiguration.java @@ -25,7 +25,7 @@ @Configuration @EnableWebSecurity @EnableMethodSecurity -class KeycloakSecurityConfiguration { +public class KeycloakSecurityConfiguration { @Bean SecurityFilterChain configure(HttpSecurity http) throws Exception { diff --git a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java index b7f3dbe6dc0..b9881bc366a 100644 --- a/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java +++ b/components/security/security-oauth2/src/main/java/org/eclipse/dirigible/components/security/oauth2/OAuth2SecurityConfiguration.java @@ -20,7 +20,7 @@ @Profile("oauth") @Configuration -class OAuth2SecurityConfiguration { +public class OAuth2SecurityConfiguration { @Bean SecurityFilterChain filterChain(HttpSecurity http) throws Exception { From 7834e6f63560c4d792b5a842a855e11127346e93 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 09:20:55 +0200 Subject: [PATCH 42/64] native images support Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 73 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 72 insertions(+), 1 deletion(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index a2dfc5e9b89..6426e5f259b 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -210,7 +210,7 @@ org.postgresql postgresql - + org.eclipse.dirigible dirigible-database-mongodb-jdbc @@ -250,6 +250,12 @@ + + org.graalvm.buildtools + native-maven-plugin + 0.9.28 + true + org.springframework.boot spring-boot-maven-plugin @@ -291,6 +297,71 @@ + + + native + + + + + org.apache.maven.plugins + maven-jar-plugin + + + + true + + + + + + org.springframework.boot + spring-boot-maven-plugin + + + + paketobuildpacks/builder-jammy-tiny:latest + + true + + + + + + process-aot + + process-aot + + + + + + org.graalvm.buildtools + native-maven-plugin + 0.9.28 + + + ${project.build.outputDirectory} + + true + + 22.3 + + + + add-reachability-metadata + + add-reachability-metadata + + + + + + + + + + ../../licensing-header.txt ../../ From da82f723e84e9bc9161458e59928ccb6f15fd06c Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 14:36:16 +0200 Subject: [PATCH 43/64] fix OData Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 75 +------------------ .../components/odata/config/ODataConfig.java | 8 +- .../factory/DirigibleODataServiceFactory.java | 35 ++++----- .../odata/service/ODataContainerService.java | 40 ++-------- .../odata/service/ODataMetadataService.java | 50 ++----------- .../odata/service/ODataSchemaService.java | 39 ++-------- .../integration/tests/JsonAsserter.java | 18 +++++ .../integration/tests/api/ODataAPIIT.java | 71 ++++++++++++++++++ 8 files changed, 135 insertions(+), 201 deletions(-) create mode 100644 tests/src/test/java/org/eclipse/dirigible/integration/tests/JsonAsserter.java create mode 100644 tests/src/test/java/org/eclipse/dirigible/integration/tests/api/ODataAPIIT.java diff --git a/build/application/pom.xml b/build/application/pom.xml index 6426e5f259b..ba8c7a3cf79 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -15,6 +15,10 @@ jar + + org.eclipse.dirigible + dirigible-components-engine-odata + org.slf4j @@ -250,12 +254,6 @@ - - org.graalvm.buildtools - native-maven-plugin - 0.9.28 - true - org.springframework.boot spring-boot-maven-plugin @@ -297,71 +295,6 @@ - - - native - - - - - org.apache.maven.plugins - maven-jar-plugin - - - - true - - - - - - org.springframework.boot - spring-boot-maven-plugin - - - - paketobuildpacks/builder-jammy-tiny:latest - - true - - - - - - process-aot - - process-aot - - - - - - org.graalvm.buildtools - native-maven-plugin - 0.9.28 - - - ${project.build.outputDirectory} - - true - - 22.3 - - - - add-reachability-metadata - - add-reachability-metadata - - - - - - - - - - ../../licensing-header.txt ../../ diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java index fb85102b432..d72eefcb2a3 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java @@ -22,7 +22,7 @@ */ @Configuration @EnableAutoConfiguration(exclude = LiquibaseAutoConfiguration.class) -public class ODataConfig { +class ODataConfig { /** * Olingo servlet. @@ -30,9 +30,9 @@ public class ODataConfig { * @return the servlet registration bean */ @Bean - public ServletRegistrationBean olingoServlet() { - ServletRegistrationBean bean = new ServletRegistrationBean(new ODataServlet(), "/odata/v2/*"); - bean.addInitParameter("javax.ws.rs.Application", "org.apache.olingo.odata2.core.rest.app.ODataApplication"); + ServletRegistrationBean olingoServlet() { + ServletRegistrationBean bean = new ServletRegistrationBean<>(new ODataServlet(), "/odata/v2/*"); + bean.addInitParameter("jakarta.ws.rs.Application", "org.apache.olingo.odata2.core.rest.app.ODataApplication"); bean.addInitParameter("org.apache.olingo.odata2.service.factory", "org.eclipse.dirigible.components.odata.factory.DirigibleODataServiceFactory"); bean.setLoadOnStartup(1); diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/factory/DirigibleODataServiceFactory.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/factory/DirigibleODataServiceFactory.java index f2ff46c0979..8881a865b97 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/factory/DirigibleODataServiceFactory.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/factory/DirigibleODataServiceFactory.java @@ -11,11 +11,9 @@ package org.eclipse.dirigible.components.odata.factory; import static org.eclipse.dirigible.engine.odata2.sql.processor.DefaultSQLProcessor.DEFAULT_DATA_SOURCE_CONTEXT_KEY; - +import java.io.InputStream; import java.util.ServiceLoader; - import javax.sql.DataSource; - import org.apache.olingo.odata2.api.ODataCallback; import org.apache.olingo.odata2.api.ODataService; import org.apache.olingo.odata2.api.ODataServiceFactory; @@ -36,31 +34,29 @@ import org.eclipse.dirigible.engine.odata2.sql.processor.DefaultSQLProcessor; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; /** * A factory for creating DirigibleODataService objects. */ +@Component public class DirigibleODataServiceFactory extends ODataServiceFactory { /** The Constant logger. */ private static final Logger logger = LoggerFactory.getLogger(DirigibleODataServiceFactory.class); - /** - * Gets the data sources manager. - * - * @return the data sources manager - */ - public DataSourcesManager getDataSourcesManager() { - return DataSourcesManager.get(); + private static DataSourcesManager dataSourcesManager; + private static ODataMetadataService odataMetadataService; + + public DirigibleODataServiceFactory() { + // called by ODataServlet } - /** - * Gets the odata metadata service. - * - * @return the odata metadata service - */ - public ODataMetadataService getODataMetadataService() { - return ODataMetadataService.get(); + @Autowired + public DirigibleODataServiceFactory(DataSourcesManager dataSourcesManager, ODataMetadataService odataMetadataService) { + DirigibleODataServiceFactory.dataSourcesManager = dataSourcesManager; + DirigibleODataServiceFactory.odataMetadataService = odataMetadataService; } /** @@ -84,7 +80,8 @@ public ODataEdmTableMappingProvider getEdmTableMappingProvider() throws ODataExc public ODataService createService(ODataContext ctx) throws ODataException { try { EdmProvider edmProvider = new EdmxProvider(); - ((EdmxProvider) edmProvider).parse(getODataMetadataService().getMetadata(), false); + InputStream metadata = odataMetadataService.getMetadata(); + ((EdmxProvider) edmProvider).parse(metadata, false); setDefaultDataSource(ctx); @@ -143,7 +140,7 @@ public ODataResponse handleError(ODataErrorContext context) throws ODataApplicat */ private void setDefaultDataSource(ODataContext ctx) throws ODataException { DataSource dataSource; - dataSource = getDataSourcesManager().getDefaultDataSource(); + dataSource = dataSourcesManager.getDefaultDataSource(); ctx.setParameter(DEFAULT_DATA_SOURCE_CONTEXT_KEY, dataSource); } diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataContainerService.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataContainerService.java index 326ce522a2e..1483bd75236 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataContainerService.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataContainerService.java @@ -12,12 +12,9 @@ import java.util.List; import java.util.Optional; - import org.eclipse.dirigible.components.base.artefact.ArtefactService; import org.eclipse.dirigible.components.odata.domain.ODataContainer; import org.eclipse.dirigible.components.odata.repository.ODataContainerRepository; -import org.springframework.beans.factory.InitializingBean; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Example; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; @@ -29,34 +26,14 @@ */ @Service @Transactional -public class ODataContainerService implements ArtefactService, InitializingBean { +public class ODataContainerService implements ArtefactService { - /** The instance. */ - private static ODataContainerService INSTANCE; + private final ODataContainerRepository odataContainerRepository; - /** - * After properties set. - * - * @throws Exception the exception - */ - @Override - public void afterPropertiesSet() throws Exception { - INSTANCE = this; + public ODataContainerService(ODataContainerRepository odataContainerRepository) { + this.odataContainerRepository = odataContainerRepository; } - /** - * Gets the. - * - * @return the o data container service - */ - public static ODataContainerService get() { - return INSTANCE; - } - - /** The ODataContainer repository. */ - @Autowired - private ODataContainerRepository odataContainerRepository; - /** * Gets the all. * @@ -89,9 +66,8 @@ public ODataContainer findById(Long id) { Optional odataContainer = odataContainerRepository.findById(id); if (odataContainer.isPresent()) { return odataContainer.get(); - } else { - throw new IllegalArgumentException("OData Container with id does not exist: " + id); } + throw new IllegalArgumentException("OData Container with id does not exist: " + id); } /** @@ -108,9 +84,8 @@ public ODataContainer findByName(String name) { Optional odataContainer = odataContainerRepository.findOne(example); if (odataContainer.isPresent()) { return odataContainer.get(); - } else { - throw new IllegalArgumentException("OData Container with name does not exist: " + name); } + throw new IllegalArgumentException("OData Container with name does not exist: " + name); } /** @@ -125,8 +100,7 @@ public List findByLocation(String location) { ODataContainer filter = new ODataContainer(); filter.setLocation(location); Example example = Example.of(filter); - List list = odataContainerRepository.findAll(example); - return list; + return odataContainerRepository.findAll(example); } /** diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataMetadataService.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataMetadataService.java index 2dfc750961d..27c6563c7ce 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataMetadataService.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataMetadataService.java @@ -13,58 +13,24 @@ import java.io.ByteArrayInputStream; import java.io.InputStream; import java.util.List; - import org.apache.olingo.odata2.api.exception.ODataException; import org.eclipse.dirigible.components.odata.domain.ODataContainer; import org.eclipse.dirigible.components.odata.domain.ODataSchema; -import org.springframework.beans.factory.InitializingBean; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; /** * The Class ODataMetadataService. */ @Service -public class ODataMetadataService implements InitializingBean { - - /** The instance. */ - private static ODataMetadataService INSTANCE; +public class ODataMetadataService { - /** - * After properties set. - * - * @throws Exception the exception - */ - @Override - public void afterPropertiesSet() throws Exception { - INSTANCE = this; - } - - /** - * Gets the. - * - * @return the o data metadata service - */ - public static ODataMetadataService get() { - return INSTANCE; - } - /** - * Gets the o data container service. - * - * @return the o data container service - */ - public ODataContainerService getODataContainerService() { - return ODataContainerService.get(); - } + private final ODataSchemaService odataSchemaService; + private final ODataContainerService odataContainerService; - /** - * Gets the o data schema service. - * - * @return the o data schema service - */ - public ODataSchemaService getODataSchemaService() { - return ODataSchemaService.get(); + ODataMetadataService(ODataSchemaService odataSchemaService, ODataContainerService odataContainerService) { + this.odataSchemaService = odataSchemaService; + this.odataContainerService = odataContainerService; } /** @@ -81,7 +47,7 @@ public InputStream getMetadata() throws ODataException { builder.append( " \n"); - List schemas = getODataSchemaService().getAll(); + List schemas = odataSchemaService.getAll(); for (ODataSchema schema : schemas) { builder.append(new String(schema.getContent())); builder.append("\n"); @@ -94,7 +60,7 @@ public InputStream getMetadata() throws ODataException { builder.append(" \n"); - List containers = getODataContainerService().getAll(); + List containers = odataContainerService.getAll(); for (ODataContainer container : containers) { builder.append(new String(container.getContent())); builder.append("\n"); diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataSchemaService.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataSchemaService.java index 59c079f0915..4c09b0a3731 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataSchemaService.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/service/ODataSchemaService.java @@ -12,12 +12,9 @@ import java.util.List; import java.util.Optional; - import org.eclipse.dirigible.components.base.artefact.ArtefactService; import org.eclipse.dirigible.components.odata.domain.ODataSchema; import org.eclipse.dirigible.components.odata.repository.ODataSchemaRepository; -import org.springframework.beans.factory.InitializingBean; -import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.Example; import org.springframework.data.domain.Page; import org.springframework.data.domain.Pageable; @@ -29,33 +26,14 @@ */ @Service @Transactional -public class ODataSchemaService implements ArtefactService, InitializingBean { - - /** The instance. */ - private static ODataSchemaService INSTANCE; +public class ODataSchemaService implements ArtefactService { - /** - * After properties set. - * - * @throws Exception the exception - */ - @Override - public void afterPropertiesSet() throws Exception { - INSTANCE = this; - } + private final ODataSchemaRepository odataSchemaRepository; - /** - * Gets the. - * - * @return the o data schema service - */ - public static ODataSchemaService get() { - return INSTANCE; + ODataSchemaService(ODataSchemaRepository odataSchemaRepository) { + this.odataSchemaRepository = odataSchemaRepository; } - /** The ODataSchema repository. */ - @Autowired - private ODataSchemaRepository odataSchemaRepository; /** * Gets the all. @@ -89,9 +67,8 @@ public ODataSchema findById(Long id) { Optional odataSchema = odataSchemaRepository.findById(id); if (odataSchema.isPresent()) { return odataSchema.get(); - } else { - throw new IllegalArgumentException("OData Schema with id does not exist: " + id); } + throw new IllegalArgumentException("OData Schema with id does not exist: " + id); } /** @@ -108,9 +85,8 @@ public ODataSchema findByName(String name) { Optional odataSchema = odataSchemaRepository.findOne(example); if (odataSchema.isPresent()) { return odataSchema.get(); - } else { - throw new IllegalArgumentException("OData Schema with name does not exist: " + name); } + throw new IllegalArgumentException("OData Schema with name does not exist: " + name); } /** @@ -125,8 +101,7 @@ public List findByLocation(String location) { ODataSchema filter = new ODataSchema(); filter.setLocation(location); Example example = Example.of(filter); - List list = odataSchemaRepository.findAll(example); - return list; + return odataSchemaRepository.findAll(example); } /** diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/JsonAsserter.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/JsonAsserter.java new file mode 100644 index 00000000000..8bb8a5fbb5d --- /dev/null +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/JsonAsserter.java @@ -0,0 +1,18 @@ +package org.eclipse.dirigible.integration.tests; + +import static org.assertj.core.api.Assertions.assertThat; +import com.fasterxml.jackson.core.JsonProcessingException; +import com.fasterxml.jackson.databind.ObjectMapper; + +public class JsonAsserter { + + public static void assertEquals(String expectedJson, String actualJson) { + ObjectMapper mapper = new ObjectMapper(); + try { + assertThat(mapper.readTree(actualJson)).isEqualTo(mapper.readTree(expectedJson)) + .withFailMessage("Unexpected JSON"); + } catch (JsonProcessingException e) { + throw new IllegalArgumentException("Unexpected JSON", e); + } + } +} diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/ODataAPIIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/ODataAPIIT.java new file mode 100644 index 00000000000..4a999e40ea0 --- /dev/null +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/ODataAPIIT.java @@ -0,0 +1,71 @@ +package org.eclipse.dirigible.integration.tests.api; + +import static org.junit.Assert.assertEquals; +import org.apache.hc.client5.http.auth.AuthScope; +import org.apache.hc.client5.http.auth.UsernamePasswordCredentials; +import org.apache.hc.client5.http.classic.methods.HttpGet; +import org.apache.hc.client5.http.impl.auth.BasicCredentialsProvider; +import org.apache.hc.client5.http.impl.classic.CloseableHttpClient; +import org.apache.hc.client5.http.impl.classic.HttpClientBuilder; +import org.apache.hc.core5.http.ClassicHttpResponse; +import org.apache.hc.core5.http.HttpEntity; +import org.apache.hc.core5.http.HttpHeaders; +import org.apache.hc.core5.http.HttpHost; +import org.apache.hc.core5.http.HttpStatus; +import org.apache.hc.core5.http.io.HttpClientResponseHandler; +import org.apache.hc.core5.http.io.entity.EntityUtils; +import org.eclipse.dirigible.integration.tests.IntegrationTest; +import org.eclipse.dirigible.integration.tests.JsonAsserter; +import org.junit.jupiter.api.Test; +import org.springframework.boot.test.web.server.LocalServerPort; +import org.springframework.http.MediaType; +import org.springframework.security.test.context.support.WithMockUser; + +class ODataAPIIT extends IntegrationTest { + + + private static final String EXPECTED_METADATA = """ + { + "d": { + "EntitySets": [ + "Cars" + ] + } + } + """; + + @LocalServerPort + private int localServerPort; + + @WithMockUser(username = "developer", roles = {"developer"}) + @Test + void testODataMetadata() throws Exception { + String uri = "http://localhost:" + localServerPort + "/odata/v2"; + HttpGet httpGet = new HttpGet(uri); + httpGet.addHeader(HttpHeaders.ACCEPT, MediaType.APPLICATION_JSON.toString()); + + try (CloseableHttpClient httpclient = createClient()) { + HttpClientResponseHandler handler = response -> { + assertEquals(HttpStatus.SC_OK, response.getCode()); + assertEquals(MediaType.APPLICATION_JSON.toString(), response.getHeader(HttpHeaders.CONTENT_TYPE) + .getValue()); + try (HttpEntity entity = response.getEntity()) { + JsonAsserter.assertEquals(EXPECTED_METADATA, EntityUtils.toString(entity)); + } + return response; + }; + httpclient.execute(httpGet, handler); + } + } + + private CloseableHttpClient createClient() { + HttpHost targetHost = new HttpHost("http", "localhost", localServerPort); + BasicCredentialsProvider provider = new BasicCredentialsProvider(); + AuthScope authScope = new AuthScope(targetHost); + provider.setCredentials(authScope, new UsernamePasswordCredentials("admin", "admin".toCharArray())); + + return HttpClientBuilder.create() + .setDefaultCredentialsProvider(provider) + .build(); + } +} From a7266940ebb253ec392f8b0e5c4c2889235b9cb5 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 14:59:12 +0200 Subject: [PATCH 44/64] javax replacements javax.annotation.Nullable javax.xml.soap javax.servlet Signed-off-by: Iliyan Velichkov --- .../dirigible/modules/src/net/soap.ts | 6 ++--- .../resources/META-INF/dirigible/net/soap.js | 8 +++--- .../base/endpoint/HttpContextFilter.java | 8 +++--- .../components/data/csvim/domain/Csvim.java | 2 +- .../data/structures/domain/Table.java | 2 +- .../structures/domain/TableConstraint.java | 2 +- .../domain/TableConstraintCheck.java | 2 +- .../domain/TableConstraintForeignKey.java | 2 +- .../domain/TableConstraintUnique.java | 2 +- .../structures/domain/TableConstraints.java | 2 +- .../delegate/DirigibleCallDelegate.java | 2 +- .../components/engine/ftp/domain/FtpUser.java | 2 +- .../security/filter/SecurityFilter.java | 8 +++--- .../components/engine/web/domain/Expose.java | 2 +- .../designer/components/components.json | 6 ++--- .../endpoint/WorkspacesEndpoint.java | 2 +- modules/commons/commons-process/pom.xml | 27 +++++++++++-------- .../execution/ProcessExecutionOptions.java | 2 +- .../engines/engine-graalium/execution/pom.xml | 9 ++++++- .../graalium/core/graal/ContextCreator.java | 2 +- 20 files changed, 55 insertions(+), 43 deletions(-) diff --git a/components/api/api-modules-javascript/src/main/resources/META-INF/dirigible/modules/src/net/soap.ts b/components/api/api-modules-javascript/src/main/resources/META-INF/dirigible/modules/src/net/soap.ts index d2e6d5edb5a..c2d5298c6b2 100644 --- a/components/api/api-modules-javascript/src/main/resources/META-INF/dirigible/modules/src/net/soap.ts +++ b/components/api/api-modules-javascript/src/main/resources/META-INF/dirigible/modules/src/net/soap.ts @@ -12,9 +12,9 @@ import * as streams from "@dirigible/io/streams"; import * as request from "@dirigible/http/request"; import * as base64 from "@dirigible/utils/base64"; -const MessageFactory = Java.type("javax.xml.soap.MessageFactory"); -const MimeHeadersInternal = Java.type("javax.xml.soap.MimeHeaders"); -const SOAPConnectionFactory = Java.type("javax.xml.soap.SOAPConnectionFactory"); +const MessageFactory = Java.type("jakarta.xml.soap.MessageFactory"); +const MimeHeadersInternal = Java.type("jakarta.xml.soap.MimeHeaders"); +const SOAPConnectionFactory = Java.type("jakarta.xml.soap.SOAPConnectionFactory"); export function createMessage() { const internalFactory = MessageFactory.newInstance(); diff --git a/components/api/api-net/src/main/resources/META-INF/dirigible/net/soap.js b/components/api/api-net/src/main/resources/META-INF/dirigible/net/soap.js index 5bfe8f72c19..631d2c6e4d7 100644 --- a/components/api/api-net/src/main/resources/META-INF/dirigible/net/soap.js +++ b/components/api/api-net/src/main/resources/META-INF/dirigible/net/soap.js @@ -14,13 +14,13 @@ const request = require('http/request'); const base64 = require("utils/base64"); exports.createMessage = function() { - const internalFactory = javax.xml.soap.MessageFactory.newInstance(); + const internalFactory = jakarta.xml.soap.MessageFactory.newInstance(); const internalMessage = internalFactory.createMessage(); return new Message(internalMessage); }; exports.parseMessage = function(mimeHeaders, inputStream) { - const internalFactory = javax.xml.soap.MessageFactory.newInstance(); + const internalFactory = jakarta.xml.soap.MessageFactory.newInstance(); if (inputStream.native) { try { const internalMessage = internalFactory.createMessage(mimeHeaders.native, inputStream.native); @@ -46,7 +46,7 @@ exports.parseRequest = function() { }; exports.createMimeHeaders = function() { - const internalMimeHeaders = javax.xml.soap.MimeHeaders(); + const internalMimeHeaders = jakarta.xml.soap.MimeHeaders(); return new MimeHeaders(internalMimeHeaders); }; @@ -253,7 +253,7 @@ function Element(element) { * Call a given SOAP endpoint with a given request message */ exports.call = function(message, url) { - const soapConnectionFactory = javax.xml.soap.SOAPConnectionFactory.newInstance(); + const soapConnectionFactory = jakarta.xml.soap.SOAPConnectionFactory.newInstance(); const internalConnection = soapConnectionFactory.createConnection(); const internalResponse = internalConnection.call(message.native, url); return new Message(internalResponse); diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java index 9c1b8935ea8..29c62c0076f 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/endpoint/HttpContextFilter.java @@ -40,7 +40,7 @@ public class HttpContextFilter implements Filter { /* * (non-Javadoc) * - * @see javax.servlet.Filter#init(javax.servlet.FilterConfig) + * @see jakarta.servlet.Filter#init(jakarta.servlet.FilterConfig) */ @Override public void init(FilterConfig filterConfig) throws ServletException { @@ -59,8 +59,8 @@ public void init(FilterConfig filterConfig) throws ServletException { /* * (non-Javadoc) * - * @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest, javax.servlet.ServletResponse, - * javax.servlet.FilterChain) + * @see jakarta.servlet.Filter#doFilter(jakarta.servlet.ServletRequest, + * jakarta.servlet.ServletResponse, jakarta.servlet.FilterChain) */ @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { @@ -85,7 +85,7 @@ public void doFilter(ServletRequest request, ServletResponse response, FilterCha /* * (non-Javadoc) * - * @see javax.servlet.Filter#destroy() + * @see jakarta.servlet.Filter#destroy() */ @Override public void destroy() { diff --git a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java index e20596dc300..4f7aa64d881 100644 --- a/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java +++ b/components/data/data-csvim/src/main/java/org/eclipse/dirigible/components/data/csvim/domain/Csvim.java @@ -15,7 +15,7 @@ import org.hibernate.annotations.LazyCollection; import org.hibernate.annotations.LazyCollectionOption; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.*; import java.util.ArrayList; import java.util.List; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java index c8b4eb63c57..8ba70a66e69 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/Table.java @@ -14,7 +14,7 @@ import java.util.List; import java.util.Set; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.CascadeType; import jakarta.persistence.Column; import jakarta.persistence.Entity; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java index 7870b36faa9..7b04e57baa8 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraint.java @@ -12,7 +12,7 @@ import java.util.Arrays; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.Column; import jakarta.persistence.Convert; import jakarta.persistence.ElementCollection; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java index 907cd71f617..f41fc2b3303 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintCheck.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.data.structures.domain; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.Column; import jakarta.persistence.Entity; import jakarta.persistence.FetchType; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java index a5b4b465e6f..23555eb6311 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintForeignKey.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.data.structures.domain; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.Column; import jakarta.persistence.Convert; import jakarta.persistence.ElementCollection; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java index 42c8317da57..0ea99325baa 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraintUnique.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.components.data.structures.domain; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.Column; import jakarta.persistence.Entity; import jakarta.persistence.GeneratedValue; diff --git a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java index 124c7a5b508..bfaa33e71e3 100644 --- a/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java +++ b/components/data/data-structures/src/main/java/org/eclipse/dirigible/components/data/structures/domain/TableConstraints.java @@ -14,7 +14,7 @@ import java.util.List; import java.util.Objects; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.CascadeType; import jakarta.persistence.Column; import jakarta.persistence.Entity; diff --git a/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/delegate/DirigibleCallDelegate.java b/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/delegate/DirigibleCallDelegate.java index 6e3a12a82e0..b674ee64269 100644 --- a/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/delegate/DirigibleCallDelegate.java +++ b/components/engine/engine-bpm-flowable/src/main/java/org/eclipse/dirigible/components/engine/bpm/flowable/delegate/DirigibleCallDelegate.java @@ -22,7 +22,7 @@ import org.graalvm.polyglot.Value; import org.springframework.beans.BeanUtils; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import java.nio.file.Path; import java.util.HashMap; import java.util.Map; diff --git a/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java b/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java index cd29bf80b1d..af87d150fbf 100644 --- a/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java +++ b/components/engine/engine-ftp/src/main/java/org/eclipse/dirigible/components/engine/ftp/domain/FtpUser.java @@ -16,7 +16,7 @@ import java.util.Objects; import java.util.stream.Collectors; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.Column; import jakarta.persistence.Convert; import jakarta.persistence.Entity; diff --git a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java index cf241445e5f..9813c7fa338 100644 --- a/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java +++ b/components/engine/engine-security/src/main/java/org/eclipse/dirigible/components/security/filter/SecurityFilter.java @@ -99,7 +99,7 @@ public SecurityFilter(AccessVerifier securityAccessVerifier) { /* * (non-Javadoc) * - * @see javax.servlet.Filter#init(javax.servlet.FilterConfig) + * @see jakarta.servlet.Filter#init(jakarta.servlet.FilterConfig) */ @Override public void init(FilterConfig filterConfig) { @@ -122,8 +122,8 @@ public void init(FilterConfig filterConfig) { /* * (non-Javadoc) * - * @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest, javax.servlet.ServletResponse, - * javax.servlet.FilterChain) + * @see jakarta.servlet.Filter#doFilter(jakarta.servlet.ServletRequest, + * jakarta.servlet.ServletResponse, jakarta.servlet.FilterChain) */ @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException { @@ -216,7 +216,7 @@ private void forbidden(String uri, String message, HttpServletResponse response) /* * (non-Javadoc) * - * @see javax.servlet.Filter#destroy() + * @see jakarta.servlet.Filter#destroy() */ @Override public void destroy() { diff --git a/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java b/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java index 2da3e25b461..5f4deb0872c 100644 --- a/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java +++ b/components/engine/engine-web/src/main/java/org/eclipse/dirigible/components/engine/web/domain/Expose.java @@ -12,7 +12,7 @@ import java.util.Arrays; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import jakarta.persistence.Column; import jakarta.persistence.Convert; import jakarta.persistence.ElementCollection; diff --git a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json index fec4b5376fa..f8976c4ba9e 100644 --- a/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json +++ b/components/ide/ide-ui-integrations/src/main/resources/META-INF/dirigible/ide-integrations/designer/components/components.json @@ -13,7 +13,7 @@ , {"component":{"kind":"component","name":"atmos","title":"Atmos","description":"Integrate with EMC's ViPR object data services using the Atmos Client.","deprecated":false,"firstVersion":"2.15.0","label":"cloud,file","javaType":"org.apache.camel.component.atmos.AtmosComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-atmos","version":"3.20.3","scheme":"atmos","extendsScheme":"","syntax":"atmos:name/operation","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"DOWNLOADED_FILE":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the remote path downloaded in case of a single file.","constantName":"org.apache.camel.component.atmos.util.AtmosConstants#DOWNLOADED_FILE"},"DOWNLOADED_FILES":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the remote paths downloaded in case of multiple files (one per line).","constantName":"org.apache.camel.component.atmos.util.AtmosConstants#DOWNLOADED_FILES"},"UPLOADED_FILE":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the remote path uploaded in case of a single file.","constantName":"org.apache.camel.component.atmos.util.AtmosConstants#UPLOADED_FILE"},"UPLOADED_FILES":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the remote paths uploaded in case of multiple files (one per line).","constantName":"org.apache.camel.component.atmos.util.AtmosConstants#UPLOADED_FILES"},"DELETED_PATH":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The remote path deleted on Atmos.","constantName":"org.apache.camel.component.atmos.util.AtmosConstants#DELETED_PATH"},"MOVED_PATH":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The moved path.","constantName":"org.apache.camel.component.atmos.util.AtmosConstants#MOVED_PATH"}},"properties":{"name":{"kind":"path","displayName":"Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Atmos name"},"operation":{"kind":"path","displayName":"Operation","group":"common","label":"","required":true,"type":"object","javaType":"org.apache.camel.component.atmos.util.AtmosOperation","enum":["put","del","search","get","move"],"deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Operation to perform"},"localPath":{"kind":"parameter","displayName":"Local Path","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Local path to put files"},"newRemotePath":{"kind":"parameter","displayName":"New Remote Path","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"New path on Atmos when moving files"},"query":{"kind":"parameter","displayName":"Query","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Search query on Atmos"},"remotePath":{"kind":"parameter","displayName":"Remote Path","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Where to put files on Atmos"},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"uri":{"kind":"parameter","displayName":"Uri","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Atomos server uri"},"fullTokenId":{"kind":"parameter","displayName":"Full Token Id","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Atmos client fullTokenId"},"secretKey":{"kind":"parameter","displayName":"Secret Key","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"The secret key to pass to the Atmos client (should be base64 encoded)"},"sslValidation":{"kind":"parameter","displayName":"Ssl Validation","group":"security","label":"security","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.atmos.AtmosConfiguration","configurationField":"configuration","description":"Atmos SSL validation"}}} , -{"component":{"kind":"component","name":"atmosphere-websocket","title":"Atmosphere Websocket","description":"Expose WebSocket endpoints using the Atmosphere framework.","deprecated":false,"deprecationNote":"","firstVersion":"2.14.0","label":"websocket","javaType":"org.apache.camel.component.atmosphere.websocket.WebsocketComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-atmosphere-websocket","version":"3.20.3","scheme":"atmosphere-websocket","extendsScheme":"servlet","syntax":"atmosphere-websocket:servicePath","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"websocket.connectionKey":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The connection key.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#CONNECTION_KEY"},"websocket.connectionKey.list":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.util.List","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The list of connection keys.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#CONNECTION_KEY_LIST"},"websocket.eventType":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type of event received. It can be ONOPEN_EVENT_TYPE, ONERROR_EVENT_TYPE or ONCLOSE_EVENT_TYPE.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#EVENT_TYPE"},"websocket.errorType":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type of error that occurred. It can be MESSAGE_NOT_SENT_ERROR_TYPE.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#ERROR_TYPE"}},"properties":{"servicePath":{"kind":"path","displayName":"Service Path","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of websocket endpoint"},"chunked":{"kind":"parameter","displayName":"Chunked","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is false the Servlet will disable the HTTP streaming and set the content-length header on the response"},"disableStreamCache":{"kind":"parameter","displayName":"Disable Stream Cache","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Determines whether or not the raw input stream from Servlet is cached or not (Camel will read the stream into a in memory/overflow to file, Stream caching) cache. By default Camel will cache the Servlet input stream to support reading it multiple times to ensure it Camel can retrieve all data from the stream. However you can set this option to true when you for example need to access the raw stream, such as streaming it directly to a file or other persistent store. DefaultHttpBinding will copy the request input stream into a stream cache and put it into message body if this option is false to support reading the stream multiple times. If you use Servlet to bridge/proxy an endpoint then consider enabling this option to improve performance, in case you do not need to read the message payload multiple times. The http producer will by default cache the response body stream. If setting this option to true, then the producers will not cache the response body stream but use the response stream as-is as the message body."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"common","label":"common","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"sendToAll":{"kind":"parameter","displayName":"Send To All","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to send to all (broadcast) or send to a single receiver."},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side, and if the caused Exception was send back serialized in the response as a application/x-java-serialized-object content type. On the producer side the exception will be deserialized and thrown as is, instead of the HttpOperationFailedException. The caused exception is required to be serialized. This is by default turned off. If you enable this then be aware that Java will deserialize the incoming data from the request to Java and that can be a potential security risk."},"useStreaming":{"kind":"parameter","displayName":"Use Streaming","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"To enable streaming to send data as multiple text fragments."},"httpBinding":{"kind":"parameter","displayName":"Http Binding","group":"common (advanced)","label":"common,advanced","required":false,"type":"object","javaType":"org.apache.camel.http.common.HttpBinding","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HttpBinding to control the mapping between Camel message and HttpClient."},"async":{"kind":"parameter","displayName":"Async","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Configure the consumer to work in async mode"},"httpMethodRestrict":{"kind":"parameter","displayName":"Http Method Restrict","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Used to only allow consuming if the HttpMethod matches, such as GET/POST/PUT etc. Multiple methods can be specified separated by comma."},"matchOnUriPrefix":{"kind":"parameter","displayName":"Match On Uri Prefix","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not the consumer should try to find a target consumer by matching the URI prefix if no exact match is found."},"muteException":{"kind":"parameter","displayName":"Mute Exception","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side the response's body won't contain the exception's stack trace."},"responseBufferSize":{"kind":"parameter","displayName":"Response Buffer Size","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom buffer size on the javax.servlet.ServletResponse."},"servletName":{"kind":"parameter","displayName":"Servlet Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"CamelServlet","description":"Name of the servlet to use"},"attachmentMultipartBinding":{"kind":"parameter","displayName":"Attachment Multipart Binding","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to automatic bind multipart/form-data as attachments on the Camel Exchange. The options attachmentMultipartBinding=true and disableStreamCache=false cannot work together. Remove disableStreamCache to use AttachmentMultipartBinding. This is turn off by default as this may require servlet specific configuration to enable this when using Servlet's."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerCheckContentAvailable":{"kind":"parameter","displayName":"Eager Check Content Available","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to eager check whether the HTTP requests has content if the content-length header is 0 or not present. This can be turned on in case HTTP clients do not send streamed data."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"fileNameExtWhitelist":{"kind":"parameter","displayName":"File Name Ext Whitelist","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Whitelist of accepted filename extensions for accepting uploaded files. Multiple extensions can be separated by comma, such as txt,xml."},"mapHttpMessageBody":{"kind":"parameter","displayName":"Map Http Message Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Body of the exchange will be mapped to HTTP body. Setting this to false will avoid the HTTP mapping."},"mapHttpMessageFormUrlEncodedBody":{"kind":"parameter","displayName":"Map Http Message Form Url Encoded Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Form Encoded body of the exchange will be mapped to HTTP. Setting this to false will avoid the HTTP Form Encoded body mapping."},"mapHttpMessageHeaders":{"kind":"parameter","displayName":"Map Http Message Headers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Headers of the exchange will be mapped to HTTP headers. Setting this to false will avoid the HTTP Headers mapping."},"optionsEnabled":{"kind":"parameter","displayName":"Options Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP OPTIONS for this Servlet consumer. By default OPTIONS is turned off."},"traceEnabled":{"kind":"parameter","displayName":"Trace Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP TRACE for this Servlet consumer. By default TRACE is turned off."},"bridgeEndpoint":{"kind":"parameter","displayName":"Bridge Endpoint","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the option is true, HttpProducer will ignore the Exchange.HTTP_URI header, and use the endpoint's URI for request. You may also set the option throwExceptionOnFailure to be false to let the HttpProducer send all the fault response back."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."}}} +{"component":{"kind":"component","name":"atmosphere-websocket","title":"Atmosphere Websocket","description":"Expose WebSocket endpoints using the Atmosphere framework.","deprecated":false,"deprecationNote":"","firstVersion":"2.14.0","label":"websocket","javaType":"org.apache.camel.component.atmosphere.websocket.WebsocketComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-atmosphere-websocket","version":"3.20.3","scheme":"atmosphere-websocket","extendsScheme":"servlet","syntax":"atmosphere-websocket:servicePath","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"websocket.connectionKey":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The connection key.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#CONNECTION_KEY"},"websocket.connectionKey.list":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.util.List","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The list of connection keys.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#CONNECTION_KEY_LIST"},"websocket.eventType":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type of event received. It can be ONOPEN_EVENT_TYPE, ONERROR_EVENT_TYPE or ONCLOSE_EVENT_TYPE.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#EVENT_TYPE"},"websocket.errorType":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type of error that occurred. It can be MESSAGE_NOT_SENT_ERROR_TYPE.","constantName":"org.apache.camel.component.atmosphere.websocket.WebsocketConstants#ERROR_TYPE"}},"properties":{"servicePath":{"kind":"path","displayName":"Service Path","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of websocket endpoint"},"chunked":{"kind":"parameter","displayName":"Chunked","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is false the Servlet will disable the HTTP streaming and set the content-length header on the response"},"disableStreamCache":{"kind":"parameter","displayName":"Disable Stream Cache","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Determines whether or not the raw input stream from Servlet is cached or not (Camel will read the stream into a in memory/overflow to file, Stream caching) cache. By default Camel will cache the Servlet input stream to support reading it multiple times to ensure it Camel can retrieve all data from the stream. However you can set this option to true when you for example need to access the raw stream, such as streaming it directly to a file or other persistent store. DefaultHttpBinding will copy the request input stream into a stream cache and put it into message body if this option is false to support reading the stream multiple times. If you use Servlet to bridge/proxy an endpoint then consider enabling this option to improve performance, in case you do not need to read the message payload multiple times. The http producer will by default cache the response body stream. If setting this option to true, then the producers will not cache the response body stream but use the response stream as-is as the message body."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"common","label":"common","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"sendToAll":{"kind":"parameter","displayName":"Send To All","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to send to all (broadcast) or send to a single receiver."},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side, and if the caused Exception was send back serialized in the response as a application/x-java-serialized-object content type. On the producer side the exception will be deserialized and thrown as is, instead of the HttpOperationFailedException. The caused exception is required to be serialized. This is by default turned off. If you enable this then be aware that Java will deserialize the incoming data from the request to Java and that can be a potential security risk."},"useStreaming":{"kind":"parameter","displayName":"Use Streaming","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"To enable streaming to send data as multiple text fragments."},"httpBinding":{"kind":"parameter","displayName":"Http Binding","group":"common (advanced)","label":"common,advanced","required":false,"type":"object","javaType":"org.apache.camel.http.common.HttpBinding","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HttpBinding to control the mapping between Camel message and HttpClient."},"async":{"kind":"parameter","displayName":"Async","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Configure the consumer to work in async mode"},"httpMethodRestrict":{"kind":"parameter","displayName":"Http Method Restrict","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Used to only allow consuming if the HttpMethod matches, such as GET/POST/PUT etc. Multiple methods can be specified separated by comma."},"matchOnUriPrefix":{"kind":"parameter","displayName":"Match On Uri Prefix","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not the consumer should try to find a target consumer by matching the URI prefix if no exact match is found."},"muteException":{"kind":"parameter","displayName":"Mute Exception","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side the response's body won't contain the exception's stack trace."},"responseBufferSize":{"kind":"parameter","displayName":"Response Buffer Size","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom buffer size on the jakarta.servlet.ServletResponse."},"servletName":{"kind":"parameter","displayName":"Servlet Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"CamelServlet","description":"Name of the servlet to use"},"attachmentMultipartBinding":{"kind":"parameter","displayName":"Attachment Multipart Binding","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to automatic bind multipart/form-data as attachments on the Camel Exchange. The options attachmentMultipartBinding=true and disableStreamCache=false cannot work together. Remove disableStreamCache to use AttachmentMultipartBinding. This is turn off by default as this may require servlet specific configuration to enable this when using Servlet's."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerCheckContentAvailable":{"kind":"parameter","displayName":"Eager Check Content Available","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to eager check whether the HTTP requests has content if the content-length header is 0 or not present. This can be turned on in case HTTP clients do not send streamed data."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"fileNameExtWhitelist":{"kind":"parameter","displayName":"File Name Ext Whitelist","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Whitelist of accepted filename extensions for accepting uploaded files. Multiple extensions can be separated by comma, such as txt,xml."},"mapHttpMessageBody":{"kind":"parameter","displayName":"Map Http Message Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Body of the exchange will be mapped to HTTP body. Setting this to false will avoid the HTTP mapping."},"mapHttpMessageFormUrlEncodedBody":{"kind":"parameter","displayName":"Map Http Message Form Url Encoded Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Form Encoded body of the exchange will be mapped to HTTP. Setting this to false will avoid the HTTP Form Encoded body mapping."},"mapHttpMessageHeaders":{"kind":"parameter","displayName":"Map Http Message Headers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Headers of the exchange will be mapped to HTTP headers. Setting this to false will avoid the HTTP Headers mapping."},"optionsEnabled":{"kind":"parameter","displayName":"Options Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP OPTIONS for this Servlet consumer. By default OPTIONS is turned off."},"traceEnabled":{"kind":"parameter","displayName":"Trace Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP TRACE for this Servlet consumer. By default TRACE is turned off."},"bridgeEndpoint":{"kind":"parameter","displayName":"Bridge Endpoint","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the option is true, HttpProducer will ignore the Exchange.HTTP_URI header, and use the endpoint's URI for request. You may also set the option throwExceptionOnFailure to be false to let the HttpProducer send all the fault response back."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."}}} , {"component":{"kind":"component","name":"atom","title":"Atom","description":"Poll Atom RSS feeds.","deprecated":false,"firstVersion":"1.2.0","label":"rss","javaType":"org.apache.camel.component.atom.AtomComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-atom","version":"3.20.3","scheme":"atom","extendsScheme":"","syntax":"atom:feedUri","async":false,"api":false,"consumerOnly":true,"producerOnly":false,"lenientProperties":true},"headers":{"CamelAtomFeed":{"kind":"header","displayName":"","group":"consumer","label":"","required":false,"javaType":"org.apache.abdera.model.Feed","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"When consuming the org.apache.abdera.model.Feed object is set to this header.","constantName":"org.apache.camel.component.atom.AtomConstants#ATOM_FEED"}},"properties":{"feedUri":{"kind":"path","displayName":"Feed Uri","group":"consumer","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The URI to the feed to poll."},"feedHeader":{"kind":"parameter","displayName":"Feed Header","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Sets whether to add the feed object as a header."},"password":{"kind":"parameter","displayName":"Password","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the password to be used for basic authentication when polling from a HTTP feed."},"sendEmptyMessageWhenIdle":{"kind":"parameter","displayName":"Send Empty Message When Idle","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the polling consumer did not poll any files, you can enable this option to send an empty message (no body) instead."},"sortEntries":{"kind":"parameter","displayName":"Sort Entries","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Sets whether to sort entries by published date. Only works when splitEntries = true."},"splitEntries":{"kind":"parameter","displayName":"Split Entries","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Sets whether or not entries should be sent individually or whether the entire feed should be sent as a single message"},"throttleEntries":{"kind":"parameter","displayName":"Throttle Entries","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Sets whether all entries identified in a single feed poll should be delivered immediately. If true, only one entry is processed per delay. Only applicable when splitEntries = true."},"username":{"kind":"parameter","displayName":"Username","group":"consumer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the username to be used for basic authentication when polling from a HTTP feed."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"pollStrategy":{"kind":"parameter","displayName":"Poll Strategy","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.PollingConsumerPollStrategy","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable org.apache.camel.PollingConsumerPollingStrategy allowing you to provide your custom implementation to control error handling usually occurred during the poll operation before an Exchange have been created and being routed in Camel."},"backoffErrorThreshold":{"kind":"parameter","displayName":"Backoff Error Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent error polls (failed due some error) that should happen before the backoffMultipler should kick-in."},"backoffIdleThreshold":{"kind":"parameter","displayName":"Backoff Idle Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent idle polls that should happen before the backoffMultipler should kick-in."},"backoffMultiplier":{"kind":"parameter","displayName":"Backoff Multiplier","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"To let the scheduled polling consumer backoff if there has been a number of subsequent idles/errors in a row. The multiplier is then the number of polls that will be skipped before the next actual attempt is happening again. When this option is in use then backoffIdleThreshold and/or backoffErrorThreshold must also be configured."},"delay":{"kind":"parameter","displayName":"Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":500,"description":"Milliseconds before the next poll."},"greedy":{"kind":"parameter","displayName":"Greedy","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If greedy is enabled, then the ScheduledPollConsumer will run immediately again, if the previous run polled 1 or more messages."},"initialDelay":{"kind":"parameter","displayName":"Initial Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1000,"description":"Milliseconds before the first poll starts."},"repeatCount":{"kind":"parameter","displayName":"Repeat Count","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":0,"description":"Specifies a maximum limit of number of fires. So if you set it to 1, the scheduler will only fire once. If you set it to 5, it will only fire five times. A value of zero or negative means fire forever."},"runLoggingLevel":{"kind":"parameter","displayName":"Run Logging Level","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"TRACE","description":"The consumer logs a start/complete log line when it polls. This option allows you to configure the logging level for that."},"scheduledExecutorService":{"kind":"parameter","displayName":"Scheduled Executor Service","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.ScheduledExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"Allows for configuring a custom/shared thread pool to use for the consumer. By default each consumer has its own single threaded thread pool."},"scheduler":{"kind":"parameter","displayName":"Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.lang.Object","deprecated":false,"autowired":false,"secret":false,"defaultValue":"none","description":"To use a cron scheduler from either camel-spring or camel-quartz component. Use value spring or quartz for built in scheduler"},"schedulerProperties":{"kind":"parameter","displayName":"Scheduler Properties","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.Map","prefix":"scheduler.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"To configure additional properties when using a custom scheduler or any of the Quartz, Spring based scheduler."},"startScheduler":{"kind":"parameter","displayName":"Start Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether the scheduler should be auto started."},"timeUnit":{"kind":"parameter","displayName":"Time Unit","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.TimeUnit","enum":["NANOSECONDS","MICROSECONDS","MILLISECONDS","SECONDS","MINUTES","HOURS","DAYS"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"MILLISECONDS","description":"Time unit for initialDelay and delay options."},"useFixedDelay":{"kind":"parameter","displayName":"Use Fixed Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Controls if fixed delay or fixed rate is used. See ScheduledExecutorService in JDK for details."}}} , @@ -335,7 +335,7 @@ , {"component":{"kind":"component","name":"jdbc","title":"JDBC","description":"Access databases through SQL and JDBC.","deprecated":false,"firstVersion":"1.2.0","label":"database,sql","javaType":"org.apache.camel.component.jdbc.JdbcComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jdbc","version":"3.20.3","scheme":"jdbc","extendsScheme":"","syntax":"jdbc:dataSourceName","async":false,"api":false,"consumerOnly":false,"producerOnly":true,"lenientProperties":false},"headers":{"CamelJdbcUpdateCount":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"If the query is an UPDATE, query the update count is returned in this OUT header.","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_UPDATE_COUNT"},"CamelJdbcRowCount":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"If the query is a SELECT, query the row count is returned in this OUT header.","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_ROW_COUNT"},"CamelJdbcColumnNames":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"Set","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The column names from the ResultSet as a java.util.Set type.","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_COLUMN_NAMES"},"CamelJdbcParameters":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"Map","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"A java.util.Map which has the headers to be used if useHeadersAsParameters has been enabled.","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_PARAMETERS"},"CamelRetrieveGeneratedKeys":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"Set its value to true to retrieve generated keys","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_RETRIEVE_GENERATED_KEYS"},"CamelGeneratedColumns":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"String[] or int[]","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set it to specify the expected generated columns","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_GENERATED_COLUMNS"},"CamelGeneratedKeysRowCount":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The number of rows in the header that contains generated keys.","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_GENERATED_KEYS_ROW_COUNT"},"CamelGeneratedKeysRows":{"kind":"header","displayName":"","group":"producer","label":"producer","required":false,"javaType":"List>","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Rows that contains the generated keys.","constantName":"org.apache.camel.component.jdbc.JdbcConstants#JDBC_GENERATED_KEYS_DATA"}},"properties":{"dataSourceName":{"kind":"path","displayName":"Data Source Name","group":"producer","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Name of DataSource to lookup in the Registry. If the name is dataSource or default, then Camel will attempt to lookup a default DataSource from the registry, meaning if there is a only one instance of DataSource found, then this DataSource will be used."},"allowNamedParameters":{"kind":"parameter","displayName":"Allow Named Parameters","group":"producer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to allow using named parameters in the queries."},"outputClass":{"kind":"parameter","displayName":"Output Class","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Specify the full package and class name to use as conversion when outputType=SelectOne or SelectList."},"outputType":{"kind":"parameter","displayName":"Output Type","group":"producer","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.jdbc.JdbcOutputType","enum":["SelectOne","SelectList","StreamList"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"SelectList","description":"Determines the output the producer should use."},"parameters":{"kind":"parameter","displayName":"Parameters","group":"producer","label":"","required":false,"type":"object","javaType":"java.util.Map","prefix":"statement.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"Optional parameters to the java.sql.Statement. For example to set maxRows, fetchSize etc."},"readSize":{"kind":"parameter","displayName":"Read Size","group":"producer","label":"","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The default maximum number of rows that can be read by a polling query. The default value is 0."},"resetAutoCommit":{"kind":"parameter","displayName":"Reset Auto Commit","group":"producer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Camel will set the autoCommit on the JDBC connection to be false, commit the change after executed the statement and reset the autoCommit flag of the connection at the end, if the resetAutoCommit is true. If the JDBC connection doesn't support to reset the autoCommit flag, you can set the resetAutoCommit flag to be false, and Camel will not try to reset the autoCommit flag. When used with XA transactions you most likely need to set it to false so that the transaction manager is in charge of committing this tx."},"transacted":{"kind":"parameter","displayName":"Transacted","group":"producer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether transactions are in use."},"useGetBytesForBlob":{"kind":"parameter","displayName":"Use Get Bytes For Blob","group":"producer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"To read BLOB columns as bytes instead of string data. This may be needed for certain databases such as Oracle where you must read BLOB columns as bytes."},"useHeadersAsParameters":{"kind":"parameter","displayName":"Use Headers As Parameters","group":"producer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Set this option to true to use the prepareStatementStrategy with named parameters. This allows to define queries with named placeholders, and use headers with the dynamic values for the query placeholders."},"useJDBC4ColumnNameAndLabelSemantics":{"kind":"parameter","displayName":"Use JDBC4 Column Name And Label Semantics","group":"producer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Sets whether to use JDBC 4 or JDBC 3.0 or older semantic when retrieving column name. JDBC 4.0 uses columnLabel to get the column name where as JDBC 3.0 uses both columnName or columnLabel. Unfortunately JDBC drivers behave differently so you can use this option to work out issues around your JDBC driver if you get problem using this component This option is default true."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"beanRowMapper":{"kind":"parameter","displayName":"Bean Row Mapper","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jdbc.BeanRowMapper","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom org.apache.camel.component.jdbc.BeanRowMapper when using outputClass. The default implementation will lower case the row names and skip underscores, and dashes. For example CUST_ID is mapped as custId."},"connectionStrategy":{"kind":"parameter","displayName":"Connection Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jdbc.ConnectionStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom strategy for working with connections. Do not use a custom strategy when using the spring-jdbc component because a special Spring ConnectionStrategy is used by default to support Spring Transactions."},"prepareStatementStrategy":{"kind":"parameter","displayName":"Prepare Statement Strategy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.camel.component.jdbc.JdbcPrepareStatementStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Allows the plugin to use a custom org.apache.camel.component.jdbc.JdbcPrepareStatementStrategy to control preparation of the query and prepared statement."}}} , -{"component":{"kind":"component","name":"jetty","title":"Jetty","description":"Expose HTTP endpoints using Jetty 9.","deprecated":false,"deprecationNote":"","firstVersion":"1.2.0","label":"http","javaType":"org.apache.camel.component.jetty9.JettyHttpComponent9","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jetty","version":"3.20.3","scheme":"jetty","extendsScheme":"http","syntax":"jetty:httpUri","async":true,"api":false,"consumerOnly":true,"producerOnly":false,"lenientProperties":true},"headers":{"CamelServletContextPath":{"kind":"header","displayName":"","group":"consumer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The servlet context path used","constantName":"org.apache.camel.component.jetty.JettyHttpConstants#SERVLET_CONTEXT_PATH"},"CamelHttpPath":{"kind":"header","displayName":"","group":"consumer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Request URI's path, the header will be used to build the request URI with the HTTP_URI.","constantName":"org.apache.camel.component.jetty.JettyHttpConstants#HTTP_PATH"}},"properties":{"httpUri":{"kind":"path","displayName":"Http Uri","group":"common","label":"common","required":true,"type":"string","javaType":"java.net.URI","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The url of the HTTP endpoint to call."},"chunked":{"kind":"parameter","displayName":"Chunked","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is false the Servlet will disable the HTTP streaming and set the content-length header on the response"},"disableStreamCache":{"kind":"parameter","displayName":"Disable Stream Cache","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Determines whether or not the raw input stream from Servlet is cached or not (Camel will read the stream into a in memory/overflow to file, Stream caching) cache. By default Camel will cache the Servlet input stream to support reading it multiple times to ensure it Camel can retrieve all data from the stream. However you can set this option to true when you for example need to access the raw stream, such as streaming it directly to a file or other persistent store. DefaultHttpBinding will copy the request input stream into a stream cache and put it into message body if this option is false to support reading the stream multiple times. If you use Servlet to bridge/proxy an endpoint then consider enabling this option to improve performance, in case you do not need to read the message payload multiple times. The http producer will by default cache the response body stream. If setting this option to true, then the producers will not cache the response body stream but use the response stream as-is as the message body."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"common","label":"common","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"httpBinding":{"kind":"parameter","displayName":"Http Binding","group":"common (advanced)","label":"common,advanced","required":false,"type":"object","javaType":"org.apache.camel.http.common.HttpBinding","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HttpBinding to control the mapping between Camel message and HttpClient."},"async":{"kind":"parameter","displayName":"Async","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Configure the consumer to work in async mode"},"continuationTimeout":{"kind":"parameter","displayName":"Continuation Timeout","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"30000","description":"Allows to set a timeout in millis when using Jetty as consumer (server). By default Jetty uses 30000. You can use a value of = 0 to never expire. If a timeout occurs then the request will be expired and Jetty will return back a http error 503 to the client. This option is only in use when using Jetty with the Asynchronous Routing Engine."},"enableCORS":{"kind":"parameter","displayName":"Enable CORS","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the option is true, Jetty server will setup the CrossOriginFilter which supports the CORS out of box."},"enableJmx":{"kind":"parameter","displayName":"Enable Jmx","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If this option is true, Jetty JMX support will be enabled for this endpoint. See Jetty JMX support for more details."},"enableMultipartFilter":{"kind":"parameter","displayName":"Enable Multipart Filter","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether org.apache.camel.component.jetty.MultiPartFilter is enabled or not. You should set this value to false when bridging endpoints, to ensure multipart requests is proxied/bridged as well."},"httpMethodRestrict":{"kind":"parameter","displayName":"Http Method Restrict","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Used to only allow consuming if the HttpMethod matches, such as GET/POST/PUT etc. Multiple methods can be specified separated by comma."},"matchOnUriPrefix":{"kind":"parameter","displayName":"Match On Uri Prefix","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not the consumer should try to find a target consumer by matching the URI prefix if no exact match is found."},"muteException":{"kind":"parameter","displayName":"Mute Exception","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side the response's body won't contain the exception's stack trace."},"responseBufferSize":{"kind":"parameter","displayName":"Response Buffer Size","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom buffer size on the javax.servlet.ServletResponse."},"sendDateHeader":{"kind":"parameter","displayName":"Send Date Header","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the option is true, jetty server will send the date header to the client which sends the request. NOTE please make sure there is no any other camel-jetty endpoint is share the same port, otherwise this option may not work as expected."},"sendServerVersion":{"kind":"parameter","displayName":"Send Server Version","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If the option is true, jetty will send the server header with the jetty version information to the client which sends the request. NOTE please make sure there is no any other camel-jetty endpoint is share the same port, otherwise this option may not work as expected."},"sessionSupport":{"kind":"parameter","displayName":"Session Support","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable the session manager on the server side of Jetty."},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side, and if the caused Exception was send back serialized in the response as a application/x-java-serialized-object content type. On the producer side the exception will be deserialized and thrown as is, instead of the HttpOperationFailedException. The caused exception is required to be serialized. This is by default turned off. If you enable this then be aware that Java will deserialize the incoming data from the request to Java and that can be a potential security risk."},"useContinuation":{"kind":"parameter","displayName":"Use Continuation","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"description":"Whether or not to use Jetty continuations for the Jetty Server."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerCheckContentAvailable":{"kind":"parameter","displayName":"Eager Check Content Available","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to eager check whether the HTTP requests has content if the content-length header is 0 or not present. This can be turned on in case HTTP clients do not send streamed data."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"filterInitParameters":{"kind":"parameter","displayName":"Filter Init Parameters","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"java.util.Map","prefix":"filter.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"Configuration of the filter init parameters. These parameters will be applied to the filter list before starting the jetty server."},"filters":{"kind":"parameter","displayName":"Filters","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"array","javaType":"java.util.List","deprecated":false,"autowired":false,"secret":false,"description":"Allows using a custom filters which is putted into a list and can be find in the Registry. Multiple values can be separated by comma."},"handlers":{"kind":"parameter","displayName":"Handlers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"array","javaType":"java.util.List","deprecated":false,"autowired":false,"secret":false,"description":"Specifies a comma-delimited set of Handler instances to lookup in your Registry. These handlers are added to the Jetty servlet context (for example, to add security). Important: You can not use different handlers with different Jetty endpoints using the same port number. The handlers is associated to the port number. If you need different handlers, then use different port numbers."},"mapHttpMessageBody":{"kind":"parameter","displayName":"Map Http Message Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Body of the exchange will be mapped to HTTP body. Setting this to false will avoid the HTTP mapping."},"mapHttpMessageFormUrlEncodedBody":{"kind":"parameter","displayName":"Map Http Message Form Url Encoded Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Form Encoded body of the exchange will be mapped to HTTP. Setting this to false will avoid the HTTP Form Encoded body mapping."},"mapHttpMessageHeaders":{"kind":"parameter","displayName":"Map Http Message Headers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Headers of the exchange will be mapped to HTTP headers. Setting this to false will avoid the HTTP Headers mapping."},"multipartFilter":{"kind":"parameter","displayName":"Multipart Filter","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"javax.servlet.Filter","deprecated":false,"autowired":false,"secret":false,"description":"Allows using a custom multipart filter. Note: setting multipartFilterRef forces the value of enableMultipartFilter to true."},"optionsEnabled":{"kind":"parameter","displayName":"Options Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP OPTIONS for this Servlet consumer. By default OPTIONS is turned off."},"traceEnabled":{"kind":"parameter","displayName":"Trace Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP TRACE for this Servlet consumer. By default TRACE is turned off."},"sslContextParameters":{"kind":"parameter","displayName":"Ssl Context Parameters","group":"security","label":"security","required":false,"type":"object","javaType":"org.apache.camel.support.jsse.SSLContextParameters","deprecated":false,"autowired":false,"secret":false,"description":"To configure security using SSLContextParameters"}}} +{"component":{"kind":"component","name":"jetty","title":"Jetty","description":"Expose HTTP endpoints using Jetty 9.","deprecated":false,"deprecationNote":"","firstVersion":"1.2.0","label":"http","javaType":"org.apache.camel.component.jetty9.JettyHttpComponent9","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jetty","version":"3.20.3","scheme":"jetty","extendsScheme":"http","syntax":"jetty:httpUri","async":true,"api":false,"consumerOnly":true,"producerOnly":false,"lenientProperties":true},"headers":{"CamelServletContextPath":{"kind":"header","displayName":"","group":"consumer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The servlet context path used","constantName":"org.apache.camel.component.jetty.JettyHttpConstants#SERVLET_CONTEXT_PATH"},"CamelHttpPath":{"kind":"header","displayName":"","group":"consumer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Request URI's path, the header will be used to build the request URI with the HTTP_URI.","constantName":"org.apache.camel.component.jetty.JettyHttpConstants#HTTP_PATH"}},"properties":{"httpUri":{"kind":"path","displayName":"Http Uri","group":"common","label":"common","required":true,"type":"string","javaType":"java.net.URI","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The url of the HTTP endpoint to call."},"chunked":{"kind":"parameter","displayName":"Chunked","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is false the Servlet will disable the HTTP streaming and set the content-length header on the response"},"disableStreamCache":{"kind":"parameter","displayName":"Disable Stream Cache","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Determines whether or not the raw input stream from Servlet is cached or not (Camel will read the stream into a in memory/overflow to file, Stream caching) cache. By default Camel will cache the Servlet input stream to support reading it multiple times to ensure it Camel can retrieve all data from the stream. However you can set this option to true when you for example need to access the raw stream, such as streaming it directly to a file or other persistent store. DefaultHttpBinding will copy the request input stream into a stream cache and put it into message body if this option is false to support reading the stream multiple times. If you use Servlet to bridge/proxy an endpoint then consider enabling this option to improve performance, in case you do not need to read the message payload multiple times. The http producer will by default cache the response body stream. If setting this option to true, then the producers will not cache the response body stream but use the response stream as-is as the message body."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"common","label":"common","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"httpBinding":{"kind":"parameter","displayName":"Http Binding","group":"common (advanced)","label":"common,advanced","required":false,"type":"object","javaType":"org.apache.camel.http.common.HttpBinding","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HttpBinding to control the mapping between Camel message and HttpClient."},"async":{"kind":"parameter","displayName":"Async","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Configure the consumer to work in async mode"},"continuationTimeout":{"kind":"parameter","displayName":"Continuation Timeout","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"30000","description":"Allows to set a timeout in millis when using Jetty as consumer (server). By default Jetty uses 30000. You can use a value of = 0 to never expire. If a timeout occurs then the request will be expired and Jetty will return back a http error 503 to the client. This option is only in use when using Jetty with the Asynchronous Routing Engine."},"enableCORS":{"kind":"parameter","displayName":"Enable CORS","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the option is true, Jetty server will setup the CrossOriginFilter which supports the CORS out of box."},"enableJmx":{"kind":"parameter","displayName":"Enable Jmx","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If this option is true, Jetty JMX support will be enabled for this endpoint. See Jetty JMX support for more details."},"enableMultipartFilter":{"kind":"parameter","displayName":"Enable Multipart Filter","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether org.apache.camel.component.jetty.MultiPartFilter is enabled or not. You should set this value to false when bridging endpoints, to ensure multipart requests is proxied/bridged as well."},"httpMethodRestrict":{"kind":"parameter","displayName":"Http Method Restrict","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Used to only allow consuming if the HttpMethod matches, such as GET/POST/PUT etc. Multiple methods can be specified separated by comma."},"matchOnUriPrefix":{"kind":"parameter","displayName":"Match On Uri Prefix","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not the consumer should try to find a target consumer by matching the URI prefix if no exact match is found."},"muteException":{"kind":"parameter","displayName":"Mute Exception","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side the response's body won't contain the exception's stack trace."},"responseBufferSize":{"kind":"parameter","displayName":"Response Buffer Size","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom buffer size on the jakarta.servlet.ServletResponse."},"sendDateHeader":{"kind":"parameter","displayName":"Send Date Header","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the option is true, jetty server will send the date header to the client which sends the request. NOTE please make sure there is no any other camel-jetty endpoint is share the same port, otherwise this option may not work as expected."},"sendServerVersion":{"kind":"parameter","displayName":"Send Server Version","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If the option is true, jetty will send the server header with the jetty version information to the client which sends the request. NOTE please make sure there is no any other camel-jetty endpoint is share the same port, otherwise this option may not work as expected."},"sessionSupport":{"kind":"parameter","displayName":"Session Support","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable the session manager on the server side of Jetty."},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side, and if the caused Exception was send back serialized in the response as a application/x-java-serialized-object content type. On the producer side the exception will be deserialized and thrown as is, instead of the HttpOperationFailedException. The caused exception is required to be serialized. This is by default turned off. If you enable this then be aware that Java will deserialize the incoming data from the request to Java and that can be a potential security risk."},"useContinuation":{"kind":"parameter","displayName":"Use Continuation","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"description":"Whether or not to use Jetty continuations for the Jetty Server."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerCheckContentAvailable":{"kind":"parameter","displayName":"Eager Check Content Available","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to eager check whether the HTTP requests has content if the content-length header is 0 or not present. This can be turned on in case HTTP clients do not send streamed data."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"filterInitParameters":{"kind":"parameter","displayName":"Filter Init Parameters","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"java.util.Map","prefix":"filter.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"Configuration of the filter init parameters. These parameters will be applied to the filter list before starting the jetty server."},"filters":{"kind":"parameter","displayName":"Filters","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"array","javaType":"java.util.List","deprecated":false,"autowired":false,"secret":false,"description":"Allows using a custom filters which is putted into a list and can be find in the Registry. Multiple values can be separated by comma."},"handlers":{"kind":"parameter","displayName":"Handlers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"array","javaType":"java.util.List","deprecated":false,"autowired":false,"secret":false,"description":"Specifies a comma-delimited set of Handler instances to lookup in your Registry. These handlers are added to the Jetty servlet context (for example, to add security). Important: You can not use different handlers with different Jetty endpoints using the same port number. The handlers is associated to the port number. If you need different handlers, then use different port numbers."},"mapHttpMessageBody":{"kind":"parameter","displayName":"Map Http Message Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Body of the exchange will be mapped to HTTP body. Setting this to false will avoid the HTTP mapping."},"mapHttpMessageFormUrlEncodedBody":{"kind":"parameter","displayName":"Map Http Message Form Url Encoded Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Form Encoded body of the exchange will be mapped to HTTP. Setting this to false will avoid the HTTP Form Encoded body mapping."},"mapHttpMessageHeaders":{"kind":"parameter","displayName":"Map Http Message Headers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Headers of the exchange will be mapped to HTTP headers. Setting this to false will avoid the HTTP Headers mapping."},"multipartFilter":{"kind":"parameter","displayName":"Multipart Filter","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"jakarta.servlet.Filter","deprecated":false,"autowired":false,"secret":false,"description":"Allows using a custom multipart filter. Note: setting multipartFilterRef forces the value of enableMultipartFilter to true."},"optionsEnabled":{"kind":"parameter","displayName":"Options Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP OPTIONS for this Servlet consumer. By default OPTIONS is turned off."},"traceEnabled":{"kind":"parameter","displayName":"Trace Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP TRACE for this Servlet consumer. By default TRACE is turned off."},"sslContextParameters":{"kind":"parameter","displayName":"Ssl Context Parameters","group":"security","label":"security","required":false,"type":"object","javaType":"org.apache.camel.support.jsse.SSLContextParameters","deprecated":false,"autowired":false,"secret":false,"description":"To configure security using SSLContextParameters"}}} , {"component":{"kind":"component","name":"jgroups","title":"JGroups","description":"Exchange messages with JGroups clusters.","deprecated":false,"firstVersion":"2.13.0","label":"clustering,messaging","javaType":"org.apache.camel.component.jgroups.JGroupsComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-jgroups","version":"3.20.3","scheme":"jgroups","extendsScheme":"","syntax":"jgroups:clusterName","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"JGROUPS_CHANNEL_ADDRESS":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.jgroups.Address","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Address (org.jgroups.Address) of the channel associated with the endpoint.","constantName":"org.apache.camel.component.jgroups.JGroupsConstants#HEADER_JGROUPS_CHANNEL_ADDRESS"},"JGROUPS_DEST":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.jgroups.Address","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Consumer: The org.jgroups.Address instance extracted by org.jgroups.Message.getDest() method of the consumed message. Producer: The custom destination org.jgroups.Address of the message to be sent.","constantName":"org.apache.camel.component.jgroups.JGroupsConstants#HEADER_JGROUPS_DEST"},"JGROUPS_SRC":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.jgroups.Address","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Consumer : The org.jgroups.Address instance extracted by org.jgroups.Message.getSrc() method of the consumed message. Producer: The custom source org.jgroups.Address of the message to be sent.","constantName":"org.apache.camel.component.jgroups.JGroupsConstants#HEADER_JGROUPS_SRC"},"JGROUPS_ORIGINAL_MESSAGE":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"org.jgroups.Message","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The original org.jgroups.Message instance from which the body of the consumed message has been extracted.","constantName":"org.apache.camel.component.jgroups.JGroupsConstants#HEADER_JGROUPS_ORIGINAL_MESSAGE"}},"properties":{"clusterName":{"kind":"path","displayName":"Cluster Name","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The name of the JGroups cluster the component should connect to."},"channelProperties":{"kind":"parameter","displayName":"Channel Properties","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Specifies configuration properties of the JChannel used by the endpoint."},"enableViewMessages":{"kind":"parameter","displayName":"Enable View Messages","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If set to true, the consumer endpoint will receive org.jgroups.View messages as well (not only org.jgroups.Message instances). By default only regular messages are consumed by the endpoint."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."}}} , @@ -547,7 +547,7 @@ , {"component":{"kind":"component","name":"servicenow","title":"ServiceNow","description":"Interact with ServiceNow via its REST API.","deprecated":false,"firstVersion":"2.18.0","label":"api,cloud,management","javaType":"org.apache.camel.component.servicenow.ServiceNowComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-servicenow","version":"3.20.3","scheme":"servicenow","extendsScheme":"","syntax":"servicenow:instanceName","async":false,"api":false,"consumerOnly":false,"producerOnly":true,"lenientProperties":false,"verifiers":"parameters,connectivity"},"headers":{"CamelServiceNowResource":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The resource to access","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#RESOURCE"},"CamelServiceNowAction":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The action to perform","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#ACTION"},"CamelServiceNowActionSubject":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The action subject","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#ACTION_SUBJECT"},"CamelServiceNowModel":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Class","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The data model","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#MODEL"},"CamelServiceNowRequestModel":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Class","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The request data model","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#REQUEST_MODEL"},"CamelServiceNowResponseModel":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Class","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The response data model","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#RESPONSE_MODEL"},"CamelServiceNowContentType":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The content type","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#CONTENT_TYPE"},"CamelServiceNowContentMeta":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Map","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The content meta","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#CONTENT_META"},"CamelServiceNowResponseMeta":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Map","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The response meta","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#RESPONSE_META"},"CamelServiceNowApiVersion":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The REST API version","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#API_VERSION"},"CamelServiceNowResponseType":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Class","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The type of the response","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#RESPONSE_TYPE"},"CamelServiceNowRetrieveTargetRecord":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to retrieve the target record.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#RETRIEVE_TARGET_RECORD"},"CamelServiceNowTable":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The default table","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_TABLE_NAME"},"CamelServiceNowSysId":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys id","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_SYS_ID"},"CamelServiceNowUserSysId":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The user sys id","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_USER_SYS_ID"},"CamelServiceNowUserId":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The user id","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_USER_ID"},"CamelServiceNowCartItemId":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The cart item id","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_CART_ITEM_ID"},"CamelServiceNowFileName":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The file name","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_FILE_NAME"},"CamelServiceNowTableSysId":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The table sys id","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_TABLE_SYS_ID"},"CamelServiceNowEncryptionContext":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The encryption context","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#PARAM_ENCRYPTION_CONTEXT"},"CamelServiceNowCategory":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param category","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_CATEGORY"},"CamelServiceNowType":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param type","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_TYPE"},"CamelServiceNowCatalog":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param catalog","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_CATALOG"},"CamelServiceNowQuery":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param query","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_QUERY"},"CamelServiceNowDisplayValue":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"Return the display value (true), actual value (false), or both (all) for reference fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_DISPLAY_VALUE"},"CamelServiceNowInputDisplayValue":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"True to set raw value of input fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_INPUT_DISPLAY_VALUE"},"CamelServiceNowExcludeReferenceLink":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"True to exclude Table API links for reference fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_EXCLUDE_REFERENCE_LINK"},"CamelServiceNowFields":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_FIELDS"},"CamelServiceNowLimit":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Integer","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param limit","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_LIMIT"},"CamelServiceNowText":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param text","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_TEXT"},"CamelServiceNowOffset":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Integer","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param offset","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_OFFSET"},"CamelServiceNowView":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param view","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_VIEW"},"CamelServiceNowSuppressAutoSysField":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"false","description":"True to suppress auto generation of system fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_SUPPRESS_AUTO_SYS_FIELD"},"CamelServiceNowSuppressPaginationHeader":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this value to true to remove the Link header from the response. The Link header allows you to request additional pages of data when the number of records matching your query exceeds the query limit","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_SUPPRESS_PAGINATION_HEADER"},"CamelServiceNowMinFields":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param min fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_MIN_FIELDS"},"CamelServiceNowMaxFields":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param max fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_MAX_FIELDS"},"CamelServiceNowSumFields":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param sum fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_SUM_FIELDS"},"CamelServiceNowAvgFields":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param avg fields","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_AVG_FIELDS"},"CamelServiceNowCount":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param count","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_COUNT"},"CamelServiceNowGroupBy":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param group by","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_GROUP_BY"},"CamelServiceNowOrderBy":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param order by","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_ORDER_BY"},"CamelServiceNowHaving":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param having","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_HAVING"},"CamelServiceNowUUID":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param UUID","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_UUID"},"CamelServiceNowBreakdown":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param breakdown","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_BREAKDOWN"},"CamelServiceNowIncludeScores":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return all scores for a scorecard. If a value is not specified, this parameter defaults to false and returns only the most recent score value.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_INCLUDE_SCORES"},"CamelServiceNowIncludeScoreNotes":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return all notes associated with the score. The note element contains the note text as well as the author and timestamp when the note was added.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_INCLUDE_SCORE_NOTES"},"CamelServiceNowIncludeAggregates":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to always return all available aggregates for an indicator, including when an aggregate has already been applied. If a value is not specified, this parameter defaults to false and returns no aggregates.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_INCLUDE_AGGREGATES"},"CamelServiceNowIncludeAvailableBreakdowns":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return all available breakdowns for an indicator. If a value is not specified, this parameter defaults to false and returns no breakdowns.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_INCLUDE_AVAILABLE_BREAKDOWNS"},"CamelServiceNowIncludeAvailableAggregates":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return all available aggregates for an indicator when no aggregate has been applied. If a value is not specified, this parameter defaults to false and returns no aggregates.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_INCLUDE_AVAILABLE_AGGREGATES"},"CamelServiceNowFavorites":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return only scorecards that are favorites of the querying user.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_FAVORITES"},"CamelServiceNowKey":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return only scorecards for key indicators.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_KEY"},"CamelServiceNowTarget":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Set this parameter to true to return only scorecards that have a target.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_TARGET"},"CamelServiceNowDisplay":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"true","description":"Set this parameter to true to return only scorecards where the indicator Display field is selected. Set this parameter to all to return scorecards with any Display field value.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_DISPLAY"},"CamelServiceNowPerPage":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Integer","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"defaultValue":"10","description":"Enter the maximum number of scorecards each query can return. By default this value is 10, and the maximum is 100.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_PER_PAGE"},"CamelServiceNowSortBy":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Specify the value to use when sorting results. By default, queries sort records by value.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_SORT_BY"},"CamelServiceNowSortDir":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Specify the sort direction, ascending or descending. By default, queries sort records in descending order. Use sysparm_sortdir=asc to sort in ascending order.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_SORT_DIR"},"CamelServiceNowContains":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param contains.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_CONTAINS"},"CamelServiceNowTags":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param tags.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_TAGS"},"CamelServiceNowPage":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param page.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_PAGE"},"CamelServiceNowElementsFilter":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param elements filter.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_ELEMENTS_FILTER"},"CamelServiceNowBreakdownRelation":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param breakdown relation.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_BREAKDOWN_RELATION"},"CamelServiceNowDataSource":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The sys param data source.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_DATA_SOURCE"},"CamelServiceNowTopLevelOnly":{"kind":"header","displayName":"","group":"producer","label":"","required":false,"javaType":"Boolean","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Gets only those categories whose parent is a catalog.","constantName":"org.apache.camel.component.servicenow.ServiceNowConstants#SYSPARM_TOP_LEVEL_ONLY"}},"properties":{"instanceName":{"kind":"path","displayName":"Instance Name","group":"producer","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The ServiceNow instance name"},"display":{"kind":"parameter","displayName":"Display","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["false","true","all"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"true","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return only scorecards where the indicator Display field is selected. Set this parameter to all to return scorecards with any Display field value. This parameter is true by default."},"displayValue":{"kind":"parameter","displayName":"Display Value","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["false","true","all"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Return the display value (true), actual value (false), or both (all) for reference fields (default: false)"},"excludeReferenceLink":{"kind":"parameter","displayName":"Exclude Reference Link","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"True to exclude Table API links for reference fields (default: false)"},"favorites":{"kind":"parameter","displayName":"Favorites","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return only scorecards that are favorites of the querying user."},"includeAggregates":{"kind":"parameter","displayName":"Include Aggregates","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to always return all available aggregates for an indicator, including when an aggregate has already been applied. If a value is not specified, this parameter defaults to false and returns no aggregates."},"includeAvailableAggregates":{"kind":"parameter","displayName":"Include Available Aggregates","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return all available aggregates for an indicator when no aggregate has been applied. If a value is not specified, this parameter defaults to false and returns no aggregates."},"includeAvailableBreakdowns":{"kind":"parameter","displayName":"Include Available Breakdowns","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return all available breakdowns for an indicator. If a value is not specified, this parameter defaults to false and returns no breakdowns."},"includeScoreNotes":{"kind":"parameter","displayName":"Include Score Notes","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return all notes associated with the score. The note element contains the note text as well as the author and timestamp when the note was added."},"includeScores":{"kind":"parameter","displayName":"Include Scores","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return all scores for a scorecard. If a value is not specified, this parameter defaults to false and returns only the most recent score value."},"inputDisplayValue":{"kind":"parameter","displayName":"Input Display Value","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"True to set raw value of input fields (default: false)"},"key":{"kind":"parameter","displayName":"Key","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return only scorecards for key indicators."},"models":{"kind":"parameter","displayName":"Models","group":"producer","label":"","required":false,"type":"object","javaType":"java.util.Map>","prefix":"model.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Defines both request and response models"},"perPage":{"kind":"parameter","displayName":"Per Page","group":"producer","label":"","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"defaultValue":"10","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Enter the maximum number of scorecards each query can return. By default this value is 10, and the maximum is 100."},"release":{"kind":"parameter","displayName":"Release","group":"producer","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.servicenow.ServiceNowRelease","enum":["FUJI","GENEVA","HELSINKI"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"HELSINKI","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The ServiceNow release to target, default to Helsinki See https://docs.servicenow.com"},"requestModels":{"kind":"parameter","displayName":"Request Models","group":"producer","label":"","required":false,"type":"object","javaType":"java.util.Map>","prefix":"request-model.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Defines the request model"},"resource":{"kind":"parameter","displayName":"Resource","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The default resource, can be overridden by header CamelServiceNowResource"},"responseModels":{"kind":"parameter","displayName":"Response Models","group":"producer","label":"","required":false,"type":"object","javaType":"java.util.Map>","prefix":"response-model.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Defines the response model"},"sortBy":{"kind":"parameter","displayName":"Sort By","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["value","change","changeperc","gap","gapperc","duedate","name","order","default","group","indicator_group","frequency","target","date","trend","bullet","direction"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Specify the value to use when sorting results. By default, queries sort records by value."},"sortDir":{"kind":"parameter","displayName":"Sort Dir","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","enum":["asc","desc"],"deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Specify the sort direction, ascending or descending. By default, queries sort records in descending order. Use sysparm_sortdir=asc to sort in ascending order."},"suppressAutoSysField":{"kind":"parameter","displayName":"Suppress Auto Sys Field","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"True to suppress auto generation of system fields (default: false)"},"suppressPaginationHeader":{"kind":"parameter","displayName":"Suppress Pagination Header","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this value to true to remove the Link header from the response. The Link header allows you to request additional pages of data when the number of records matching your query exceeds the query limit"},"table":{"kind":"parameter","displayName":"Table","group":"producer","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The default table, can be overridden by header CamelServiceNowTable"},"target":{"kind":"parameter","displayName":"Target","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to return only scorecards that have a target."},"topLevelOnly":{"kind":"parameter","displayName":"Top Level Only","group":"producer","label":"","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Gets only those categories whose parent is a catalog."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"apiVersion":{"kind":"parameter","displayName":"Api Version","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The ServiceNow REST API version, default latest"},"dateFormat":{"kind":"parameter","displayName":"Date Format","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"yyyy-MM-dd","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The date format used for Json serialization/deserialization"},"dateTimeFormat":{"kind":"parameter","displayName":"Date Time Format","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"yyyy-MM-dd HH:mm:ss","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The date-time format used for Json serialization/deserialization"},"httpClientPolicy":{"kind":"parameter","displayName":"Http Client Policy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.cxf.transports.http.configuration.HTTPClientPolicy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"To configure http-client"},"mapper":{"kind":"parameter","displayName":"Mapper","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"com.fasterxml.jackson.databind.ObjectMapper","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Sets Jackson's ObjectMapper to use for request/reply"},"proxyAuthorizationPolicy":{"kind":"parameter","displayName":"Proxy Authorization Policy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"org.apache.cxf.configuration.security.ProxyAuthorizationPolicy","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"To configure proxy authentication"},"retrieveTargetRecordOnImport":{"kind":"parameter","displayName":"Retrieve Target Record On Import","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Set this parameter to true to retrieve the target record when using import set api. The import set result is then replaced by the target record"},"timeFormat":{"kind":"parameter","displayName":"Time Format","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"HH:mm:ss","configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The time format used for Json serialization/deserialization"},"proxyHost":{"kind":"parameter","displayName":"Proxy Host","group":"proxy","label":"proxy","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The proxy host name"},"proxyPort":{"kind":"parameter","displayName":"Proxy Port","group":"proxy","label":"proxy","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The proxy port number"},"apiUrl":{"kind":"parameter","displayName":"Api Url","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"The ServiceNow REST API url"},"oauthClientId":{"kind":"parameter","displayName":"Oauth Client Id","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"OAuth2 ClientID"},"oauthClientSecret":{"kind":"parameter","displayName":"Oauth Client Secret","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"OAuth2 ClientSecret"},"oauthTokenUrl":{"kind":"parameter","displayName":"Oauth Token Url","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"OAuth token Url"},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"ServiceNow account password, MUST be provided"},"proxyPassword":{"kind":"parameter","displayName":"Proxy Password","group":"security","label":"proxy,security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Password for proxy authentication"},"proxyUserName":{"kind":"parameter","displayName":"Proxy User Name","group":"security","label":"proxy,security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"Username for proxy authentication"},"sslContextParameters":{"kind":"parameter","displayName":"Ssl Context Parameters","group":"security","label":"security","required":false,"type":"object","javaType":"org.apache.camel.support.jsse.SSLContextParameters","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"To configure security using SSLContextParameters. See http://camel.apache.org/camel-configuration-utilities.html"},"userName":{"kind":"parameter","displayName":"User Name","group":"security","label":"security","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.servicenow.ServiceNowConfiguration","configurationField":"configuration","description":"ServiceNow user account name, MUST be provided"}}} , -{"component":{"kind":"component","name":"servlet","title":"Servlet","description":"Serve HTTP requests by a Servlet.","deprecated":false,"deprecationNote":"","firstVersion":"2.0.0","label":"http","javaType":"org.apache.camel.component.servlet.ServletComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-servlet","version":"3.20.3","scheme":"servlet","extendsScheme":"http","syntax":"servlet:contextPath","async":false,"api":false,"consumerOnly":true,"producerOnly":false,"lenientProperties":false},"properties":{"contextPath":{"kind":"path","displayName":"Context Path","group":"consumer","label":"consumer","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The context-path to use"},"chunked":{"kind":"parameter","displayName":"Chunked","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is false the Servlet will disable the HTTP streaming and set the content-length header on the response"},"disableStreamCache":{"kind":"parameter","displayName":"Disable Stream Cache","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Determines whether or not the raw input stream from Servlet is cached or not (Camel will read the stream into a in memory/overflow to file, Stream caching) cache. By default Camel will cache the Servlet input stream to support reading it multiple times to ensure it Camel can retrieve all data from the stream. However you can set this option to true when you for example need to access the raw stream, such as streaming it directly to a file or other persistent store. DefaultHttpBinding will copy the request input stream into a stream cache and put it into message body if this option is false to support reading the stream multiple times. If you use Servlet to bridge/proxy an endpoint then consider enabling this option to improve performance, in case you do not need to read the message payload multiple times. The http producer will by default cache the response body stream. If setting this option to true, then the producers will not cache the response body stream but use the response stream as-is as the message body."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"common","label":"common","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"httpBinding":{"kind":"parameter","displayName":"Http Binding","group":"common (advanced)","label":"common,advanced","required":false,"type":"object","javaType":"org.apache.camel.http.common.HttpBinding","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HttpBinding to control the mapping between Camel message and HttpClient."},"async":{"kind":"parameter","displayName":"Async","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Configure the consumer to work in async mode"},"httpMethodRestrict":{"kind":"parameter","displayName":"Http Method Restrict","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Used to only allow consuming if the HttpMethod matches, such as GET/POST/PUT etc. Multiple methods can be specified separated by comma."},"matchOnUriPrefix":{"kind":"parameter","displayName":"Match On Uri Prefix","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not the consumer should try to find a target consumer by matching the URI prefix if no exact match is found."},"muteException":{"kind":"parameter","displayName":"Mute Exception","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side the response's body won't contain the exception's stack trace."},"responseBufferSize":{"kind":"parameter","displayName":"Response Buffer Size","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom buffer size on the javax.servlet.ServletResponse."},"servletName":{"kind":"parameter","displayName":"Servlet Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"CamelServlet","description":"Name of the servlet to use"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side, and if the caused Exception was send back serialized in the response as a application/x-java-serialized-object content type. On the producer side the exception will be deserialized and thrown as is, instead of the HttpOperationFailedException. The caused exception is required to be serialized. This is by default turned off. If you enable this then be aware that Java will deserialize the incoming data from the request to Java and that can be a potential security risk."},"attachmentMultipartBinding":{"kind":"parameter","displayName":"Attachment Multipart Binding","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to automatic bind multipart/form-data as attachments on the Camel Exchange. The options attachmentMultipartBinding=true and disableStreamCache=false cannot work together. Remove disableStreamCache to use AttachmentMultipartBinding. This is turn off by default as this may require servlet specific configuration to enable this when using Servlet's."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerCheckContentAvailable":{"kind":"parameter","displayName":"Eager Check Content Available","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to eager check whether the HTTP requests has content if the content-length header is 0 or not present. This can be turned on in case HTTP clients do not send streamed data."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"fileNameExtWhitelist":{"kind":"parameter","displayName":"File Name Ext Whitelist","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Whitelist of accepted filename extensions for accepting uploaded files. Multiple extensions can be separated by comma, such as txt,xml."},"mapHttpMessageBody":{"kind":"parameter","displayName":"Map Http Message Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Body of the exchange will be mapped to HTTP body. Setting this to false will avoid the HTTP mapping."},"mapHttpMessageFormUrlEncodedBody":{"kind":"parameter","displayName":"Map Http Message Form Url Encoded Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Form Encoded body of the exchange will be mapped to HTTP. Setting this to false will avoid the HTTP Form Encoded body mapping."},"mapHttpMessageHeaders":{"kind":"parameter","displayName":"Map Http Message Headers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Headers of the exchange will be mapped to HTTP headers. Setting this to false will avoid the HTTP Headers mapping."},"optionsEnabled":{"kind":"parameter","displayName":"Options Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP OPTIONS for this Servlet consumer. By default OPTIONS is turned off."},"traceEnabled":{"kind":"parameter","displayName":"Trace Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP TRACE for this Servlet consumer. By default TRACE is turned off."}}} +{"component":{"kind":"component","name":"servlet","title":"Servlet","description":"Serve HTTP requests by a Servlet.","deprecated":false,"deprecationNote":"","firstVersion":"2.0.0","label":"http","javaType":"org.apache.camel.component.servlet.ServletComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-servlet","version":"3.20.3","scheme":"servlet","extendsScheme":"http","syntax":"servlet:contextPath","async":false,"api":false,"consumerOnly":true,"producerOnly":false,"lenientProperties":false},"properties":{"contextPath":{"kind":"path","displayName":"Context Path","group":"consumer","label":"consumer","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The context-path to use"},"chunked":{"kind":"parameter","displayName":"Chunked","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is false the Servlet will disable the HTTP streaming and set the content-length header on the response"},"disableStreamCache":{"kind":"parameter","displayName":"Disable Stream Cache","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Determines whether or not the raw input stream from Servlet is cached or not (Camel will read the stream into a in memory/overflow to file, Stream caching) cache. By default Camel will cache the Servlet input stream to support reading it multiple times to ensure it Camel can retrieve all data from the stream. However you can set this option to true when you for example need to access the raw stream, such as streaming it directly to a file or other persistent store. DefaultHttpBinding will copy the request input stream into a stream cache and put it into message body if this option is false to support reading the stream multiple times. If you use Servlet to bridge/proxy an endpoint then consider enabling this option to improve performance, in case you do not need to read the message payload multiple times. The http producer will by default cache the response body stream. If setting this option to true, then the producers will not cache the response body stream but use the response stream as-is as the message body."},"headerFilterStrategy":{"kind":"parameter","displayName":"Header Filter Strategy","group":"common","label":"common","required":false,"type":"object","javaType":"org.apache.camel.spi.HeaderFilterStrategy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HeaderFilterStrategy to filter header to and from Camel message."},"httpBinding":{"kind":"parameter","displayName":"Http Binding","group":"common (advanced)","label":"common,advanced","required":false,"type":"object","javaType":"org.apache.camel.http.common.HttpBinding","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom HttpBinding to control the mapping between Camel message and HttpClient."},"async":{"kind":"parameter","displayName":"Async","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Configure the consumer to work in async mode"},"httpMethodRestrict":{"kind":"parameter","displayName":"Http Method Restrict","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Used to only allow consuming if the HttpMethod matches, such as GET/POST/PUT etc. Multiple methods can be specified separated by comma."},"matchOnUriPrefix":{"kind":"parameter","displayName":"Match On Uri Prefix","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not the consumer should try to find a target consumer by matching the URI prefix if no exact match is found."},"muteException":{"kind":"parameter","displayName":"Mute Exception","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side the response's body won't contain the exception's stack trace."},"responseBufferSize":{"kind":"parameter","displayName":"Response Buffer Size","group":"consumer","label":"consumer","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom buffer size on the jakarta.servlet.ServletResponse."},"servletName":{"kind":"parameter","displayName":"Servlet Name","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"defaultValue":"CamelServlet","description":"Name of the servlet to use"},"transferException":{"kind":"parameter","displayName":"Transfer Exception","group":"consumer","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If enabled and an Exchange failed processing on the consumer side, and if the caused Exception was send back serialized in the response as a application/x-java-serialized-object content type. On the producer side the exception will be deserialized and thrown as is, instead of the HttpOperationFailedException. The caused exception is required to be serialized. This is by default turned off. If you enable this then be aware that Java will deserialize the incoming data from the request to Java and that can be a potential security risk."},"attachmentMultipartBinding":{"kind":"parameter","displayName":"Attachment Multipart Binding","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to automatic bind multipart/form-data as attachments on the Camel Exchange. The options attachmentMultipartBinding=true and disableStreamCache=false cannot work together. Remove disableStreamCache to use AttachmentMultipartBinding. This is turn off by default as this may require servlet specific configuration to enable this when using Servlet's."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"eagerCheckContentAvailable":{"kind":"parameter","displayName":"Eager Check Content Available","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether to eager check whether the HTTP requests has content if the content-length header is 0 or not present. This can be turned on in case HTTP clients do not send streamed data."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"fileNameExtWhitelist":{"kind":"parameter","displayName":"File Name Ext Whitelist","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Whitelist of accepted filename extensions for accepting uploaded files. Multiple extensions can be separated by comma, such as txt,xml."},"mapHttpMessageBody":{"kind":"parameter","displayName":"Map Http Message Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Body of the exchange will be mapped to HTTP body. Setting this to false will avoid the HTTP mapping."},"mapHttpMessageFormUrlEncodedBody":{"kind":"parameter","displayName":"Map Http Message Form Url Encoded Body","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Form Encoded body of the exchange will be mapped to HTTP. Setting this to false will avoid the HTTP Form Encoded body mapping."},"mapHttpMessageHeaders":{"kind":"parameter","displayName":"Map Http Message Headers","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"If this option is true then IN exchange Headers of the exchange will be mapped to HTTP headers. Setting this to false will avoid the HTTP Headers mapping."},"optionsEnabled":{"kind":"parameter","displayName":"Options Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP OPTIONS for this Servlet consumer. By default OPTIONS is turned off."},"traceEnabled":{"kind":"parameter","displayName":"Trace Enabled","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Specifies whether to enable HTTP TRACE for this Servlet consumer. By default TRACE is turned off."}}} , {"component":{"kind":"component","name":"sftp","title":"SFTP","description":"Upload and download files to/from SFTP servers.","deprecated":false,"deprecationNote":"","firstVersion":"1.1.0","label":"file","javaType":"org.apache.camel.component.file.remote.SftpComponent","supportLevel":"Stable","groupId":"org.apache.camel","artifactId":"camel-ftp","version":"3.20.3","scheme":"sftp","extendsScheme":"file","syntax":"sftp:host:port/directoryName","async":false,"api":false,"consumerOnly":false,"producerOnly":false,"lenientProperties":false},"headers":{"CamelFileLength":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"A long value containing the file size.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_LENGTH"},"CamelFileLastModified":{"kind":"header","displayName":"","group":"consumer","label":"consumer","required":false,"javaType":"long","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"A Long value containing the last modified timestamp of the file.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_LAST_MODIFIED"},"CamelFileName":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Specifies the output file name (relative to the endpoint directory) to be used for the output message when sending to the endpoint. If this is not present and no expression either, then a generated message ID is used as the filename instead.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_NAME"},"CamelFileNameOnly":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Only the file name (the name with no leading paths).","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_NAME_ONLY"},"CamelFileParent":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The parent path.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_PARENT"},"CamelRemoteFileInputStream":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"java.io.InputStream","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The remote file input stream.","constantName":"org.apache.camel.component.file.remote.FtpConstants#REMOTE_FILE_INPUT_STREAM"},"CamelFileLocalWorkPath":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"Path to the local work file, if local work directory is used.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_LOCAL_WORK_PATH"},"CamelFtpReplyCode":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"int","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The FTP client reply code","constantName":"org.apache.camel.component.file.remote.FtpConstants#FTP_REPLY_CODE"},"CamelFtpReplyString":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The FTP client reply string","constantName":"org.apache.camel.component.file.remote.FtpConstants#FTP_REPLY_STRING"},"CamelFileHost":{"kind":"header","displayName":"","group":"common","label":"","required":false,"javaType":"String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"description":"The remote hostname.","constantName":"org.apache.camel.component.file.remote.FtpConstants#FILE_HOST"}},"properties":{"host":{"kind":"path","displayName":"Host","group":"common","label":"","required":true,"type":"string","javaType":"java.lang.String","deprecated":false,"deprecationNote":"","autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Hostname of the FTP server"},"port":{"kind":"path","displayName":"Port","group":"common","label":"","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Port of the FTP server"},"directoryName":{"kind":"path","displayName":"Directory Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"The starting directory"},"binary":{"kind":"parameter","displayName":"Binary","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Specifies the file transfer mode, BINARY or ASCII. Default is ASCII (false)."},"charset":{"kind":"parameter","displayName":"Charset","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"This option is used to specify the encoding of the file. You can use this on the consumer, to specify the encodings of the files, which allow Camel to know the charset it should load the file content in case the file content is being accessed. Likewise when writing a file, you can use this option to specify which charset to write the file as well. Do mind that when writing the file Camel may have to read the message content into memory to be able to convert the data into the configured charset, so do not use this if you have big messages."},"disconnect":{"kind":"parameter","displayName":"Disconnect","group":"common","label":"common","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not to disconnect from remote FTP server right after use. Disconnect will only disconnect the current connection to the FTP server. If you have a consumer which you want to stop, then you need to stop the consumer/route instead."},"doneFileName":{"kind":"parameter","displayName":"Done File Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Producer: If provided, then Camel will write a 2nd done file when the original file has been written. The done file will be empty. This option configures what file name to use. Either you can specify a fixed name. Or you can use dynamic placeholders. The done file will always be written in the same folder as the original file. Consumer: If provided, Camel will only consume files if a done file exists. This option configures what file name to use. Either you can specify a fixed name. Or you can use dynamic placeholders.The done file is always expected in the same folder as the original file. Only ${file.name} and ${file.name.next} is supported as dynamic placeholders."},"fileName":{"kind":"parameter","displayName":"File Name","group":"common","label":"","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Use Expression such as File Language to dynamically set the filename. For consumers, it's used as a filename filter. For producers, it's used to evaluate the filename to write. If an expression is set, it take precedence over the CamelFileName header. (Note: The header itself can also be an Expression). The expression options support both String and Expression types. If the expression is a String type, it is always evaluated using the File Language. If the expression is an Expression type, the specified Expression type is used - this allows you, for instance, to use OGNL expressions. For the consumer, you can use it to filter filenames, so you can for instance consume today's file using the File Language syntax: mydata-${date:now:yyyyMMdd}.txt. The producers support the CamelOverruleFileName header which takes precedence over any existing CamelFileName header; the CamelOverruleFileName is a header that is used only once, and makes it easier as this avoids to temporary store CamelFileName and have to restore it afterwards."},"jschLoggingLevel":{"kind":"parameter","displayName":"Jsch Logging Level","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"WARN","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"The logging level to use for JSCH activity logging. As JSCH is verbose at by default at INFO level the threshold is WARN by default."},"passiveMode":{"kind":"parameter","displayName":"Passive Mode","group":"common","label":"","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets passive mode connections. Default is active mode connections."},"separator":{"kind":"parameter","displayName":"Separator","group":"common","label":"","required":false,"type":"object","javaType":"org.apache.camel.component.file.remote.RemoteFileConfiguration.PathSeparator","enum":["UNIX","Windows","Auto"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"UNIX","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the path separator to be used. UNIX = Uses unix style path separator Windows = Uses windows style path separator Auto = (is default) Use existing path separator in file name"},"fastExistsCheck":{"kind":"parameter","displayName":"Fast Exists Check","group":"common (advanced)","label":"common,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If set this option to be true, camel-ftp will use the list file directly to check if the file exists. Since some FTP server may not support to list the file directly, if the option is false, camel-ftp will use the old way to list the directory and check if the file exists. This option also influences readLock=changed to control whether it performs a fast check to update file information or not. This can be used to speed up the process if the FTP server has a lot of files."},"delete":{"kind":"parameter","displayName":"Delete","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, the file will be deleted after it is processed successfully."},"moveFailed":{"kind":"parameter","displayName":"Move Failed","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Sets the move failure expression based on Simple language. For example, to move files into a .error subdirectory use: .error. Note: When moving the files to the fail location Camel will handle the error and will not pick up the file again."},"noop":{"kind":"parameter","displayName":"Noop","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If true, the file is not moved or deleted in any way. This option is good for readonly data, or for ETL type requirements. If noop=true, Camel will set idempotent=true as well, to avoid consuming the same files over and over again."},"preMove":{"kind":"parameter","displayName":"Pre Move","group":"consumer","label":"consumer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Expression (such as File Language) used to dynamically set the filename when moving it before processing. For example to move in-progress files into the order directory set this value to order."},"preSort":{"kind":"parameter","displayName":"Pre Sort","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"When pre-sort is enabled then the consumer will sort the file and directory names during polling, that was retrieved from the file system. You may want to do this in case you need to operate on the files in a sorted order. The pre-sort is executed before the consumer starts to filter, and accept files to process by Camel. This option is default=false meaning disabled."},"recursive":{"kind":"parameter","displayName":"Recursive","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If a directory, will look for files in all the sub-directories as well."},"sendEmptyMessageWhenIdle":{"kind":"parameter","displayName":"Send Empty Message When Idle","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If the polling consumer did not poll any files, you can enable this option to send an empty message (no body) instead."},"streamDownload":{"kind":"parameter","displayName":"Stream Download","group":"consumer","label":"consumer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the download method to use when not using a local working directory. If set to true, the remote files are streamed to the route as they are read. When set to false, the remote files are loaded into memory before being sent into the route. If enabling this option then you must set stepwise=false as both cannot be enabled at the same time."},"bridgeErrorHandler":{"kind":"parameter","displayName":"Bridge Error Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Allows for bridging the consumer to the Camel routing Error Handler, which mean any exceptions occurred while the consumer is trying to pickup incoming messages, or the likes, will now be processed as a message and handled by the routing Error Handler. By default the consumer will use the org.apache.camel.spi.ExceptionHandler to deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"download":{"kind":"parameter","displayName":"Download","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the FTP consumer should download the file. If this option is set to false, then the message body will be null, but the consumer will still trigger a Camel Exchange that has details about the file such as file name, file size, etc. It's just that the file will not be downloaded."},"exceptionHandler":{"kind":"parameter","displayName":"Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","optionalPrefix":"consumer.","deprecated":false,"autowired":false,"secret":false,"description":"To let the consumer use a custom ExceptionHandler. Notice if the option bridgeErrorHandler is enabled then this option is not in use. By default the consumer will deal with exceptions, that will be logged at WARN or ERROR level and ignored."},"exchangePattern":{"kind":"parameter","displayName":"Exchange Pattern","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.ExchangePattern","enum":["InOnly","InOut","InOptionalOut"],"deprecated":false,"autowired":false,"secret":false,"description":"Sets the exchange pattern when the consumer creates an exchange."},"ignoreFileNotFoundOrPermissionError":{"kind":"parameter","displayName":"Ignore File Not Found Or Permission Error","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to ignore when (trying to list files in directories or when downloading a file), which does not exist or due to permission error. By default when a directory or file does not exists or insufficient permission, then an exception is thrown. Setting this option to true allows to ignore that instead."},"inProgressRepository":{"kind":"parameter","displayName":"In Progress Repository","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.IdempotentRepository","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable in-progress repository org.apache.camel.spi.IdempotentRepository. The in-progress repository is used to account the current in progress files being consumed. By default a memory based repository is used."},"localWorkDirectory":{"kind":"parameter","displayName":"Local Work Directory","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"When consuming, a local work directory can be used to store the remote file content directly in local files, to avoid loading the content into memory. This is beneficial, if you consume a very big remote file and thus can conserve memory."},"onCompletionExceptionHandler":{"kind":"parameter","displayName":"On Completion Exception Handler","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.ExceptionHandler","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom org.apache.camel.spi.ExceptionHandler to handle any thrown exceptions that happens during the file on completion process where the consumer does either a commit or rollback. The default implementation will log any exception at WARN level and ignore."},"pollStrategy":{"kind":"parameter","displayName":"Poll Strategy","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.spi.PollingConsumerPollStrategy","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable org.apache.camel.PollingConsumerPollingStrategy allowing you to provide your custom implementation to control error handling usually occurred during the poll operation before an Exchange have been created and being routed in Camel."},"processStrategy":{"kind":"parameter","displayName":"Process Strategy","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileProcessStrategy","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable org.apache.camel.component.file.GenericFileProcessStrategy allowing you to implement your own readLock option or similar. Can also be used when special conditions must be met before a file can be consumed, such as a special ready file exists. If this option is set then the readLock option does not apply."},"useList":{"kind":"parameter","displayName":"Use List","group":"consumer (advanced)","label":"consumer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to allow using LIST command when downloading a file. Default is true. In some use cases you may want to download a specific file and are not allowed to use the LIST command, and therefore you can set this option to false. Notice when using this option, then the specific file to download does not include meta-data information such as file size, timestamp, permissions etc, because those information is only possible to retrieve when LIST command is in use."},"fileExist":{"kind":"parameter","displayName":"File Exist","group":"producer","label":"producer","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileExist","enum":["Override","Append","Fail","Ignore","Move","TryRename"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"Override","description":"What to do if a file already exists with the same name. Override, which is the default, replaces the existing file. - Append - adds content to the existing file. - Fail - throws a GenericFileOperationException, indicating that there is already an existing file. - Ignore - silently ignores the problem and does not override the existing file, but assumes everything is okay. - Move - option requires to use the moveExisting option to be configured as well. The option eagerDeleteTargetFile can be used to control what to do if an moving the file, and there exists already an existing file, otherwise causing the move operation to fail. The Move option will move any existing files, before writing the target file. - TryRename is only applicable if tempFileName option is in use. This allows to try renaming the file from the temporary name to the actual name, without doing any exists check. This check may be faster on some file systems and especially FTP servers."},"flatten":{"kind":"parameter","displayName":"Flatten","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Flatten is used to flatten the file name path to strip any leading paths, so it's just the file name. This allows you to consume recursively into sub-directories, but when you eg write the files to another directory they will be written in a single directory. Setting this to true on the producer enforces that any file name in CamelFileName header will be stripped for any leading paths."},"jailStartingDirectory":{"kind":"parameter","displayName":"Jail Starting Directory","group":"producer","label":"producer","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Used for jailing (restricting) writing files to the starting directory (and sub) only. This is enabled by default to not allow Camel to write files to outside directories (to be more secured out of the box). You can turn this off to allow writing files to directories outside the starting directory, such as parent or root folders."},"moveExisting":{"kind":"parameter","displayName":"Move Existing","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Expression (such as File Language) used to compute file name to use when fileExist=Move is configured. To move files into a backup subdirectory just enter backup. This option only supports the following File Language tokens: file:name, file:name.ext, file:name.noext, file:onlyname, file:onlyname.noext, file:ext, and file:parent. Notice the file:parent is not supported by the FTP component, as the FTP component can only move any existing files to a relative directory based on current dir as base."},"tempFileName":{"kind":"parameter","displayName":"Temp File Name","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"The same as tempPrefix option but offering a more fine grained control on the naming of the temporary filename as it uses the File Language. The location for tempFilename is relative to the final file location in the option 'fileName', not the target directory in the base uri. For example if option fileName includes a directory prefix: dir/finalFilename then tempFileName is relative to that subdirectory dir."},"tempPrefix":{"kind":"parameter","displayName":"Temp Prefix","group":"producer","label":"producer","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"This option is used to write the file using a temporary name and then, after the write is complete, rename it to the real name. Can be used to identify files being written and also avoid consumers (not using exclusive read locks) reading in progress files. Is often used by FTP when uploading big files."},"allowNullBody":{"kind":"parameter","displayName":"Allow Null Body","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Used to specify if a null body is allowed during file writing. If set to true then an empty file will be created, when set to false, and attempting to send a null body to the file component, a GenericFileWriteException of 'Cannot write null body to file.' will be thrown. If the fileExist option is set to 'Override', then the file will be truncated, and if set to append the file will remain unchanged."},"chmod":{"kind":"parameter","displayName":"Chmod","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Allows you to set chmod on the stored file. For example chmod=640."},"chmodDirectory":{"kind":"parameter","displayName":"Chmod Directory","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Allows you to set chmod during path creation. For example chmod=640."},"disconnectOnBatchComplete":{"kind":"parameter","displayName":"Disconnect On Batch Complete","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether or not to disconnect from remote FTP server right after a Batch upload is complete. disconnectOnBatchComplete will only disconnect the current connection to the FTP server."},"eagerDeleteTargetFile":{"kind":"parameter","displayName":"Eager Delete Target File","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether or not to eagerly delete any existing target file. This option only applies when you use fileExists=Override and the tempFileName option as well. You can use this to disable (set it to false) deleting the target file before the temp file is written. For example you may write big files and want the target file to exists during the temp file is being written. This ensure the target file is only deleted until the very last moment, just before the temp file is being renamed to the target filename. This option is also used to control whether to delete any existing files when fileExist=Move is enabled, and an existing file exists. If this option copyAndDeleteOnRenameFails false, then an exception will be thrown if an existing file existed, if its true, then the existing file is deleted before the move operation."},"keepLastModified":{"kind":"parameter","displayName":"Keep Last Modified","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Will keep the last modified timestamp from the source file (if any). Will use the FileConstants.FILE_LAST_MODIFIED header to located the timestamp. This header can contain either a java.util.Date or long with the timestamp. If the timestamp exists and the option is enabled it will set this timestamp on the written file. Note: This option only applies to the file producer. You cannot use this option with any of the ftp producers."},"lazyStartProducer":{"kind":"parameter","displayName":"Lazy Start Producer","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the producer should be started lazy (on the first message). By starting lazy you can use this to allow CamelContext and routes to startup in situations where a producer may otherwise fail during starting and cause the route to fail being started. By deferring this startup to be lazy then the startup failure can be handled during routing messages via Camel's routing error handlers. Beware that when the first message is processed then creating and starting the producer may take a little time and prolong the total processing time of the processing."},"moveExistingFileStrategy":{"kind":"parameter","displayName":"Move Existing File Strategy","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"object","javaType":"org.apache.camel.component.file.strategy.FileMoveExistingStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Strategy (Custom Strategy) used to move file with special naming token to use when fileExist=Move is configured. By default, there is an implementation used if no custom strategy is provided"},"sendNoop":{"kind":"parameter","displayName":"Send Noop","group":"producer (advanced)","label":"producer,advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to send a noop command as a pre-write check before uploading files to the FTP server. This is enabled by default as a validation of the connection is still valid, which allows to silently re-connect to be able to upload the file. However if this causes problems, you can turn this option off."},"autoCreate":{"kind":"parameter","displayName":"Auto Create","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Automatically create missing directories in the file's pathname. For the file consumer, that means creating the starting directory. For the file producer, it means the directory the files should be written to."},"bindAddress":{"kind":"parameter","displayName":"Bind Address","group":"advanced","label":"advanced","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Specifies the address of the local interface against which the connection should bind."},"bulkRequests":{"kind":"parameter","displayName":"Bulk Requests","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"java.lang.Integer","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Specifies how many requests may be outstanding at any one time. Increasing this value may slightly improve file transfer speed but will increase memory usage."},"compression":{"kind":"parameter","displayName":"Compression","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"To use compression. Specify a level from 1 to 10. Important: You must manually add the needed JSCH zlib JAR to the classpath for compression support."},"connectTimeout":{"kind":"parameter","displayName":"Connect Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":"10000","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the connect timeout for waiting for a connection to be established Used by both FTPClient and JSCH"},"existDirCheckUsingLs":{"kind":"parameter","displayName":"Exist Dir Check Using Ls","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Whether to check for existing directory using LS command or CD. By default LS is used which is safer as otherwise Camel needs to change the directory back after checking. However LS has been reported to cause a problem on windows system in some situations and therefore you can disable this option to use CD."},"maximumReconnectAttempts":{"kind":"parameter","displayName":"Maximum Reconnect Attempts","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"Specifies the maximum reconnect attempts Camel performs when it tries to connect to the remote FTP server. Use 0 to disable this behavior."},"proxy":{"kind":"parameter","displayName":"Proxy","group":"advanced","label":"advanced","required":false,"type":"object","javaType":"com.jcraft.jsch.Proxy","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom configured com.jcraft.jsch.Proxy. This proxy is used to consume/send messages from the target SFTP host."},"reconnectDelay":{"kind":"parameter","displayName":"Reconnect Delay","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":"1000","description":"Delay in millis Camel will wait before performing a reconnect attempt."},"serverAliveCountMax":{"kind":"parameter","displayName":"Server Alive Count Max","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the number of keep-alive messages which may be sent without receiving any messages back from the server. If this threshold is reached while keep-alive messages are being sent, the connection will be disconnected. The default value is one."},"serverAliveInterval":{"kind":"parameter","displayName":"Server Alive Interval","group":"advanced","label":"advanced","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the interval (millis) to send a keep-alive message. If zero is specified, any keep-alive message must not be sent. The default interval is zero."},"soTimeout":{"kind":"parameter","displayName":"So Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":"300000","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the so timeout FTP and FTPS Is the SocketOptions.SO_TIMEOUT value in millis. Recommended option is to set this to 300000 so as not have a hanged connection. On SFTP this option is set as timeout on the JSCH Session instance."},"stepwise":{"kind":"parameter","displayName":"Stepwise","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets whether we should stepwise change directories while traversing file structures when downloading files, or as well when uploading a file to a directory. You can disable this if you for example are in a situation where you cannot change directory on the FTP server due security reasons. Stepwise cannot be used together with streamDownload."},"throwExceptionOnConnectFailed":{"kind":"parameter","displayName":"Throw Exception On Connect Failed","group":"advanced","label":"advanced","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Should an exception be thrown if connection failed (exhausted)By default exception is not thrown and a WARN is logged. You can use this to enable exception being thrown and handle the thrown exception from the org.apache.camel.spi.PollingConsumerPollStrategy rollback method."},"timeout":{"kind":"parameter","displayName":"Timeout","group":"advanced","label":"advanced","required":false,"type":"duration","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":"30000","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the data timeout for waiting for reply Used only by FTPClient"},"antExclude":{"kind":"parameter","displayName":"Ant Exclude","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Ant style filter exclusion. If both antInclude and antExclude are used, antExclude takes precedence over antInclude. Multiple exclusions may be specified in comma-delimited format."},"antFilterCaseSensitive":{"kind":"parameter","displayName":"Ant Filter Case Sensitive","group":"filter","label":"consumer,filter","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Sets case sensitive flag on ant filter."},"antInclude":{"kind":"parameter","displayName":"Ant Include","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Ant style filter inclusion. Multiple inclusions may be specified in comma-delimited format."},"eagerMaxMessagesPerPoll":{"kind":"parameter","displayName":"Eager Max Messages Per Poll","group":"filter","label":"consumer,filter","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Allows for controlling whether the limit from maxMessagesPerPoll is eager or not. If eager then the limit is during the scanning of files. Where as false would scan all files, and then perform sorting. Setting this option to false allows for sorting all files first, and then limit the poll. Mind that this requires a higher memory usage as all file details are in memory to perform the sorting."},"exclude":{"kind":"parameter","displayName":"Exclude","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to exclude files, if filename matches the regex pattern (matching is case in-sensitive). Notice if you use symbols such as plus sign and others you would need to configure this using the RAW() syntax if configuring this as an endpoint uri. See more details at configuring endpoint uris"},"excludeExt":{"kind":"parameter","displayName":"Exclude Ext","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to exclude files matching file extension name (case insensitive). For example to exclude bak files, then use excludeExt=bak. Multiple extensions can be separated by comma, for example to exclude bak and dat files, use excludeExt=bak,dat. Note that the file extension includes all parts, for example having a file named mydata.tar.gz will have extension as tar.gz. For more flexibility then use the include/exclude options."},"filter":{"kind":"parameter","displayName":"Filter","group":"filter","label":"consumer,filter","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileFilter","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable filter as a org.apache.camel.component.file.GenericFileFilter class. Will skip files if filter returns false in its accept() method."},"filterDirectory":{"kind":"parameter","displayName":"Filter Directory","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Filters the directory based on Simple language. For example to filter on current date, you can use a simple date pattern such as ${date:now:yyyMMdd}"},"filterFile":{"kind":"parameter","displayName":"Filter File","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Filters the file based on Simple language. For example to filter on file size, you can use ${file:size} 5000"},"idempotent":{"kind":"parameter","displayName":"Idempotent","group":"filter","label":"consumer,filter","required":false,"type":"boolean","javaType":"java.lang.Boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":"false","description":"Option to use the Idempotent Consumer EIP pattern to let Camel skip already processed files. Will by default use a memory based LRUCache that holds 1000 entries. If noop=true then idempotent will be enabled as well to avoid consuming the same files over and over again."},"idempotentKey":{"kind":"parameter","displayName":"Idempotent Key","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom idempotent key. By default the absolute path of the file is used. You can use the File Language, for example to use the file name and file size, you can do: idempotentKey=${file:name}-${file:size}"},"idempotentRepository":{"kind":"parameter","displayName":"Idempotent Repository","group":"filter","label":"consumer,filter","required":false,"type":"object","javaType":"org.apache.camel.spi.IdempotentRepository","deprecated":false,"autowired":false,"secret":false,"description":"A pluggable repository org.apache.camel.spi.IdempotentRepository which by default use MemoryIdempotentRepository if none is specified and idempotent is true."},"include":{"kind":"parameter","displayName":"Include","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to include files, if filename matches the regex pattern (matching is case in-sensitive). Notice if you use symbols such as plus sign and others you would need to configure this using the RAW() syntax if configuring this as an endpoint uri. See more details at configuring endpoint uris"},"includeExt":{"kind":"parameter","displayName":"Include Ext","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Is used to include files matching file extension name (case insensitive). For example to include txt files, then use includeExt=txt. Multiple extensions can be separated by comma, for example to include txt and xml files, use includeExt=txt,xml. Note that the file extension includes all parts, for example having a file named mydata.tar.gz will have extension as tar.gz. For more flexibility then use the include/exclude options."},"maxDepth":{"kind":"parameter","displayName":"Max Depth","group":"filter","label":"consumer,filter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"defaultValue":2147483647,"description":"The maximum depth to traverse when recursively processing a directory."},"maxMessagesPerPoll":{"kind":"parameter","displayName":"Max Messages Per Poll","group":"filter","label":"consumer,filter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"To define a maximum messages to gather per poll. By default no maximum is set. Can be used to set a limit of e.g. 1000 to avoid when starting up the server that there are thousands of files. Set a value of 0 or negative to disabled it. Notice: If this option is in use then the File and FTP components will limit before any sorting. For example if you have 100000 files and use maxMessagesPerPoll=500, then only the first 500 files will be picked up, and then sorted. You can use the eagerMaxMessagesPerPoll option and set this to false to allow to scan all files first and then sort afterwards."},"minDepth":{"kind":"parameter","displayName":"Min Depth","group":"filter","label":"consumer,filter","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The minimum depth to start processing when recursively processing a directory. Using minDepth=1 means the base directory. Using minDepth=2 means the first sub directory."},"move":{"kind":"parameter","displayName":"Move","group":"filter","label":"consumer,filter","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Expression (such as Simple Language) used to dynamically set the filename when moving it after processing. To move files into a .done subdirectory just enter .done."},"exclusiveReadLockStrategy":{"kind":"parameter","displayName":"Exclusive Read Lock Strategy","group":"lock","label":"consumer,lock","required":false,"type":"object","javaType":"org.apache.camel.component.file.GenericFileExclusiveReadLockStrategy","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable read-lock as a org.apache.camel.component.file.GenericFileExclusiveReadLockStrategy implementation."},"readLock":{"kind":"parameter","displayName":"Read Lock","group":"lock","label":"consumer,lock","required":false,"type":"string","javaType":"java.lang.String","enum":["none","markerFile","fileLock","rename","changed","idempotent","idempotent-changed","idempotent-rename"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"none","description":"Used by consumer, to only poll the files if it has exclusive read-lock on the file (i.e. the file is not in-progress or being written). Camel will wait until the file lock is granted. This option provides the build in strategies: - none - No read lock is in use - markerFile - Camel creates a marker file (fileName.camelLock) and then holds a lock on it. This option is not available for the FTP component - changed - Changed is using file length/modification timestamp to detect whether the file is currently being copied or not. Will at least use 1 sec to determine this, so this option cannot consume files as fast as the others, but can be more reliable as the JDK IO API cannot always determine whether a file is currently being used by another process. The option readLockCheckInterval can be used to set the check frequency. - fileLock - is for using java.nio.channels.FileLock. This option is not avail for Windows OS and the FTP component. This approach should be avoided when accessing a remote file system via a mount/share unless that file system supports distributed file locks. - rename - rename is for using a try to rename the file as a test if we can get exclusive read-lock. - idempotent - (only for file component) idempotent is for using a idempotentRepository as the read-lock. This allows to use read locks that supports clustering if the idempotent repository implementation supports that. - idempotent-changed - (only for file component) idempotent-changed is for using a idempotentRepository and changed as the combined read-lock. This allows to use read locks that supports clustering if the idempotent repository implementation supports that. - idempotent-rename - (only for file component) idempotent-rename is for using a idempotentRepository and rename as the combined read-lock. This allows to use read locks that supports clustering if the idempotent repository implementation supports that.Notice: The various read locks is not all suited to work in clustered mode, where concurrent consumers on different nodes is competing for the same files on a shared file system. The markerFile using a close to atomic operation to create the empty marker file, but its not guaranteed to work in a cluster. The fileLock may work better but then the file system need to support distributed file locks, and so on. Using the idempotent read lock can support clustering if the idempotent repository supports clustering, such as Hazelcast Component or Infinispan."},"readLockCheckInterval":{"kind":"parameter","displayName":"Read Lock Check Interval","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1000,"description":"Interval in millis for the read-lock, if supported by the read lock. This interval is used for sleeping between attempts to acquire the read lock. For example when using the changed read lock, you can set a higher interval period to cater for slow writes. The default of 1 sec. may be too fast if the producer is very slow writing the file. Notice: For FTP the default readLockCheckInterval is 5000. The readLockTimeout value must be higher than readLockCheckInterval, but a rule of thumb is to have a timeout that is at least 2 or more times higher than the readLockCheckInterval. This is needed to ensure that amble time is allowed for the read lock process to try to grab the lock before the timeout was hit."},"readLockDeleteOrphanLockFiles":{"kind":"parameter","displayName":"Read Lock Delete Orphan Lock Files","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether or not read lock with marker files should upon startup delete any orphan read lock files, which may have been left on the file system, if Camel was not properly shutdown (such as a JVM crash). If turning this option to false then any orphaned lock file will cause Camel to not attempt to pickup that file, this could also be due another node is concurrently reading files from the same shared directory."},"readLockIdempotentReleaseAsync":{"kind":"parameter","displayName":"Read Lock Idempotent Release Async","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"Whether the delayed release task should be synchronous or asynchronous. See more details at the readLockIdempotentReleaseDelay option."},"readLockIdempotentReleaseAsyncPoolSize":{"kind":"parameter","displayName":"Read Lock Idempotent Release Async Pool Size","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of threads in the scheduled thread pool when using asynchronous release tasks. Using a default of 1 core threads should be sufficient in almost all use-cases, only set this to a higher value if either updating the idempotent repository is slow, or there are a lot of files to process. This option is not in-use if you use a shared thread pool by configuring the readLockIdempotentReleaseExecutorService option. See more details at the readLockIdempotentReleaseDelay option."},"readLockIdempotentReleaseDelay":{"kind":"parameter","displayName":"Read Lock Idempotent Release Delay","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"Whether to delay the release task for a period of millis. This can be used to delay the release tasks to expand the window when a file is regarded as read-locked, in an active/active cluster scenario with a shared idempotent repository, to ensure other nodes cannot potentially scan and acquire the same file, due to race-conditions. By expanding the time-window of the release tasks helps prevents these situations. Note delaying is only needed if you have configured readLockRemoveOnCommit to true."},"readLockIdempotentReleaseExecutorService":{"kind":"parameter","displayName":"Read Lock Idempotent Release Executor Service","group":"lock","label":"consumer,lock","required":false,"type":"object","javaType":"java.util.concurrent.ScheduledExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"To use a custom and shared thread pool for asynchronous release tasks. See more details at the readLockIdempotentReleaseDelay option."},"readLockLoggingLevel":{"kind":"parameter","displayName":"Read Lock Logging Level","group":"lock","label":"consumer,lock","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"DEBUG","description":"Logging level used when a read lock could not be acquired. By default a DEBUG is logged. You can change this level, for example to OFF to not have any logging. This option is only applicable for readLock of types: changed, fileLock, idempotent, idempotent-changed, idempotent-rename, rename."},"readLockMarkerFile":{"kind":"parameter","displayName":"Read Lock Marker File","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether to use marker file with the changed, rename, or exclusive read lock types. By default a marker file is used as well to guard against other processes picking up the same files. This behavior can be turned off by setting this option to false. For example if you do not want to write marker files to the file systems by the Camel application."},"readLockMinAge":{"kind":"parameter","displayName":"Read Lock Min Age","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":0,"description":"This option is applied only for readLock=changed. It allows to specify a minimum age the file must be before attempting to acquire the read lock. For example use readLockMinAge=300s to require the file is at last 5 minutes old. This can speedup the changed read lock as it will only attempt to acquire files which are at least that given age."},"readLockMinLength":{"kind":"parameter","displayName":"Read Lock Min Length","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1,"description":"This option is applied only for readLock=changed. It allows you to configure a minimum file length. By default Camel expects the file to contain data, and thus the default value is 1. You can set this option to zero, to allow consuming zero-length files."},"readLockRemoveOnCommit":{"kind":"parameter","displayName":"Read Lock Remove On Commit","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"This option is applied only for readLock=idempotent. It allows to specify whether to remove the file name entry from the idempotent repository when processing the file is succeeded and a commit happens. By default the file is not removed which ensures that any race-condition do not occur so another active node may attempt to grab the file. Instead the idempotent repository may support eviction strategies that you can configure to evict the file name entry after X minutes - this ensures no problems with race conditions. See more details at the readLockIdempotentReleaseDelay option."},"readLockRemoveOnRollback":{"kind":"parameter","displayName":"Read Lock Remove On Rollback","group":"lock","label":"consumer,lock","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"This option is applied only for readLock=idempotent. It allows to specify whether to remove the file name entry from the idempotent repository when processing the file failed and a rollback happens. If this option is false, then the file name entry is confirmed (as if the file did a commit)."},"readLockTimeout":{"kind":"parameter","displayName":"Read Lock Timeout","group":"lock","label":"consumer,lock","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":10000,"description":"Optional timeout in millis for the read-lock, if supported by the read-lock. If the read-lock could not be granted and the timeout triggered, then Camel will skip the file. At next poll Camel, will try the file again, and this time maybe the read-lock could be granted. Use a value of 0 or lower to indicate forever. Currently fileLock, changed and rename support the timeout. Notice: For FTP the default readLockTimeout value is 20000 instead of 10000. The readLockTimeout value must be higher than readLockCheckInterval, but a rule of thumb is to have a timeout that is at least 2 or more times higher than the readLockCheckInterval. This is needed to ensure that amble time is allowed for the read lock process to try to grab the lock before the timeout was hit."},"backoffErrorThreshold":{"kind":"parameter","displayName":"Backoff Error Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent error polls (failed due some error) that should happen before the backoffMultipler should kick-in."},"backoffIdleThreshold":{"kind":"parameter","displayName":"Backoff Idle Threshold","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"The number of subsequent idle polls that should happen before the backoffMultipler should kick-in."},"backoffMultiplier":{"kind":"parameter","displayName":"Backoff Multiplier","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"int","deprecated":false,"autowired":false,"secret":false,"description":"To let the scheduled polling consumer backoff if there has been a number of subsequent idles/errors in a row. The multiplier is then the number of polls that will be skipped before the next actual attempt is happening again. When this option is in use then backoffIdleThreshold and/or backoffErrorThreshold must also be configured."},"delay":{"kind":"parameter","displayName":"Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":500,"description":"Milliseconds before the next poll."},"greedy":{"kind":"parameter","displayName":"Greedy","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"If greedy is enabled, then the ScheduledPollConsumer will run immediately again, if the previous run polled 1 or more messages."},"initialDelay":{"kind":"parameter","displayName":"Initial Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":1000,"description":"Milliseconds before the first poll starts."},"repeatCount":{"kind":"parameter","displayName":"Repeat Count","group":"scheduler","label":"consumer,scheduler","required":false,"type":"integer","javaType":"long","deprecated":false,"autowired":false,"secret":false,"defaultValue":0,"description":"Specifies a maximum limit of number of fires. So if you set it to 1, the scheduler will only fire once. If you set it to 5, it will only fire five times. A value of zero or negative means fire forever."},"runLoggingLevel":{"kind":"parameter","displayName":"Run Logging Level","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"org.apache.camel.LoggingLevel","enum":["TRACE","DEBUG","INFO","WARN","ERROR","OFF"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"TRACE","description":"The consumer logs a start/complete log line when it polls. This option allows you to configure the logging level for that."},"scheduledExecutorService":{"kind":"parameter","displayName":"Scheduled Executor Service","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.ScheduledExecutorService","deprecated":false,"autowired":false,"secret":false,"description":"Allows for configuring a custom/shared thread pool to use for the consumer. By default each consumer has its own single threaded thread pool."},"scheduler":{"kind":"parameter","displayName":"Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.lang.Object","deprecated":false,"autowired":false,"secret":false,"defaultValue":"none","description":"To use a cron scheduler from either camel-spring or camel-quartz component. Use value spring or quartz for built in scheduler"},"schedulerProperties":{"kind":"parameter","displayName":"Scheduler Properties","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.Map","prefix":"scheduler.","multiValue":true,"deprecated":false,"autowired":false,"secret":false,"description":"To configure additional properties when using a custom scheduler or any of the Quartz, Spring based scheduler."},"startScheduler":{"kind":"parameter","displayName":"Start Scheduler","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Whether the scheduler should be auto started."},"timeUnit":{"kind":"parameter","displayName":"Time Unit","group":"scheduler","label":"consumer,scheduler","required":false,"type":"object","javaType":"java.util.concurrent.TimeUnit","enum":["NANOSECONDS","MICROSECONDS","MILLISECONDS","SECONDS","MINUTES","HOURS","DAYS"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"MILLISECONDS","description":"Time unit for initialDelay and delay options."},"useFixedDelay":{"kind":"parameter","displayName":"Use Fixed Delay","group":"scheduler","label":"consumer,scheduler","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"description":"Controls if fixed delay or fixed rate is used. See ScheduledExecutorService in JDK for details."},"ciphers":{"kind":"parameter","displayName":"Ciphers","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of ciphers that will be used in order of preference. Possible cipher names are defined by JCraft JSCH. Some examples include: aes128-ctr,aes128-cbc,3des-ctr,3des-cbc,blowfish-cbc,aes192-cbc,aes256-cbc. If not specified the default list from JSCH will be used."},"keyExchangeProtocols":{"kind":"parameter","displayName":"Key Exchange Protocols","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of key exchange protocols that will be used in order of preference. Possible cipher names are defined by JCraft JSCH. Some examples include: diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1,diffie-hellman-group14-sha1, diffie-hellman-group-exchange-sha256,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521. If not specified the default list from JSCH will be used."},"keyPair":{"kind":"parameter","displayName":"Key Pair","group":"security","label":"security","required":false,"type":"object","javaType":"java.security.KeyPair","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets a key pair of the public and private key so to that the SFTP endpoint can do public/private key verification."},"knownHosts":{"kind":"parameter","displayName":"Known Hosts","group":"security","label":"security","required":false,"type":"string","javaType":"byte[]","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the known_hosts from the byte array, so that the SFTP endpoint can do host key verification."},"knownHostsFile":{"kind":"parameter","displayName":"Known Hosts File","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the known_hosts file, so that the SFTP endpoint can do host key verification."},"knownHostsUri":{"kind":"parameter","displayName":"Known Hosts Uri","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets the known_hosts file (loaded from classpath by default), so that the SFTP endpoint can do host key verification."},"password":{"kind":"parameter","displayName":"Password","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Password to use for login"},"preferredAuthentications":{"kind":"parameter","displayName":"Preferred Authentications","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the preferred authentications which SFTP endpoint will used. Some example include:password,publickey. If not specified the default list from JSCH will be used."},"privateKey":{"kind":"parameter","displayName":"Private Key","group":"security","label":"security","required":false,"type":"string","javaType":"byte[]","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key as byte so that the SFTP endpoint can do private key verification."},"privateKeyFile":{"kind":"parameter","displayName":"Private Key File","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key file so that the SFTP endpoint can do private key verification."},"privateKeyPassphrase":{"kind":"parameter","displayName":"Private Key Passphrase","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key file passphrase so that the SFTP endpoint can do private key verification."},"privateKeyUri":{"kind":"parameter","displayName":"Private Key Uri","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set the private key file (loaded from classpath by default) so that the SFTP endpoint can do private key verification."},"publicKeyAcceptedAlgorithms":{"kind":"parameter","displayName":"Public Key Accepted Algorithms","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of public key accepted algorithms. Some examples include: ssh-dss,ssh-rsa,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521. If not specified the default list from JSCH will be used."},"serverHostKeys":{"kind":"parameter","displayName":"Server Host Keys","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Set a comma separated list of algorithms supported for the server host key. Some examples include: ssh-dss,ssh-rsa,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521. If not specified the default list from JSCH will be used."},"strictHostKeyChecking":{"kind":"parameter","displayName":"Strict Host Key Checking","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","enum":["no","yes"],"deprecated":false,"autowired":false,"secret":false,"defaultValue":"no","configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Sets whether to use strict host key checking."},"username":{"kind":"parameter","displayName":"Username","group":"security","label":"security","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"Username to use for login"},"useUserKnownHostsFile":{"kind":"parameter","displayName":"Use User Known Hosts File","group":"security","label":"security","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":true,"configurationClass":"org.apache.camel.component.file.remote.SftpConfiguration","configurationField":"configuration","description":"If knownHostFile has not been explicit configured then use the host file from System.getProperty(user.home)/.ssh/known_hosts"},"shuffle":{"kind":"parameter","displayName":"Shuffle","group":"sort","label":"consumer,sort","required":false,"type":"boolean","javaType":"boolean","deprecated":false,"autowired":false,"secret":false,"defaultValue":false,"description":"To shuffle the list of files (sort in random order)"},"sortBy":{"kind":"parameter","displayName":"Sort By","group":"sort","label":"consumer,sort","required":false,"type":"string","javaType":"java.lang.String","deprecated":false,"autowired":false,"secret":false,"description":"Built-in sort by using the File Language. Supports nested sorts, so you can have a sort by file name and as a 2nd group sort by modified date."},"sorter":{"kind":"parameter","displayName":"Sorter","group":"sort","label":"consumer,sort","required":false,"type":"object","javaType":"java.util.Comparator>","deprecated":false,"autowired":false,"secret":false,"description":"Pluggable sorter as a java.util.Comparator class."}}} , diff --git a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java index a5637b053f7..1c6ea4cc105 100644 --- a/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java +++ b/components/ide/ide-workspace/src/main/java/org/eclipse/dirigible/components/ide/workspace/endpoint/WorkspacesEndpoint.java @@ -17,7 +17,7 @@ import java.nio.charset.StandardCharsets; import java.util.ArrayList; import java.util.List; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import org.apache.commons.codec.binary.Base64; import org.eclipse.dirigible.commons.api.helpers.ContentTypeHelper; import org.eclipse.dirigible.components.base.endpoint.BaseEndpoint; diff --git a/modules/commons/commons-process/pom.xml b/modules/commons/commons-process/pom.xml index b4250a1998b..1e31cde9884 100644 --- a/modules/commons/commons-process/pom.xml +++ b/modules/commons/commons-process/pom.xml @@ -1,4 +1,5 @@ - 4.0.0 @@ -11,17 +12,21 @@ Commons - Process dirigible-commons-process - jar - - - ${project.artifactId} - - - - - org.eclipse.dirigible + jar + + + ${project.artifactId} + + + + + jakarta.annotation + jakarta.annotation-api + + + org.eclipse.dirigible dirigible-commons-config - + org.apache.commons commons-exec diff --git a/modules/commons/commons-process/src/main/java/org/eclipse/dirigible/commons/process/execution/ProcessExecutionOptions.java b/modules/commons/commons-process/src/main/java/org/eclipse/dirigible/commons/process/execution/ProcessExecutionOptions.java index 1698ec9c8e4..5b97250e39f 100644 --- a/modules/commons/commons-process/src/main/java/org/eclipse/dirigible/commons/process/execution/ProcessExecutionOptions.java +++ b/modules/commons/commons-process/src/main/java/org/eclipse/dirigible/commons/process/execution/ProcessExecutionOptions.java @@ -10,7 +10,7 @@ */ package org.eclipse.dirigible.commons.process.execution; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; public class ProcessExecutionOptions { private String workingDirectory; diff --git a/modules/engines/engine-graalium/execution/pom.xml b/modules/engines/engine-graalium/execution/pom.xml index 2cf61ad2715..362ff4661d0 100644 --- a/modules/engines/engine-graalium/execution/pom.xml +++ b/modules/engines/engine-graalium/execution/pom.xml @@ -1,5 +1,7 @@ - + 4.0.0 dirigible-engine-graalium @@ -12,6 +14,11 @@ jar + + + jakarta.annotation + jakarta.annotation-api + org.graalvm.polyglot polyglot diff --git a/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/ContextCreator.java b/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/ContextCreator.java index 30b78dc0fa6..94867b0ccb5 100644 --- a/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/ContextCreator.java +++ b/modules/engines/engine-graalium/execution/src/main/java/org/eclipse/dirigible/graalium/core/graal/ContextCreator.java @@ -18,7 +18,7 @@ import org.graalvm.polyglot.io.FileSystem; import org.graalvm.polyglot.io.IOAccess; -import javax.annotation.Nullable; +import jakarta.annotation.Nullable; import java.nio.file.FileSystems; import java.nio.file.Path; import java.util.function.Consumer; From e6cc74faf9d653d461ddc2e94a01048c5a7cb0f9 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 15:01:03 +0200 Subject: [PATCH 45/64] pom cleanup Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 6 ------ 1 file changed, 6 deletions(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index ba8c7a3cf79..74ada47971d 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -132,12 +132,6 @@ olingo-odata2-lib ${olingo.version} pom - - - javax.ws.rs - javax.ws.rs-api - - From 26b9f75c36337547206e9d57f0a6260f2c1e4c0b Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 16:04:39 +0200 Subject: [PATCH 46/64] fix cxf conflict Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 4 - .../src/main/resources/application.properties | 2 + components/engine/engine-odata/pom.xml | 112 ++++++++++-------- .../components/odata/config/ODataConfig.java | 2 +- components/group/group-engines/pom.xml | 21 ++-- modules/pom.xml | 16 +-- 6 files changed, 88 insertions(+), 69 deletions(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index 74ada47971d..b340b0f6331 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -15,10 +15,6 @@ jar - - org.eclipse.dirigible - dirigible-components-engine-odata - org.slf4j diff --git a/build/application/src/main/resources/application.properties b/build/application/src/main/resources/application.properties index cae4d72735b..6cfddf3e49e 100644 --- a/build/application/src/main/resources/application.properties +++ b/build/application/src/main/resources/application.properties @@ -19,3 +19,5 @@ management.metrics.mongo.connectionpool.enabled=false spring.devtools.restart.poll-interval=6s spring.devtools.restart.quiet-period=5s + +cxf.path=/odata/v2 diff --git a/components/engine/engine-odata/pom.xml b/components/engine/engine-odata/pom.xml index 90e4c9c955f..6638143aa98 100644 --- a/components/engine/engine-odata/pom.xml +++ b/components/engine/engine-odata/pom.xml @@ -1,64 +1,80 @@ - - - dirigible-components-parent - org.eclipse.dirigible - 10.0.0-SNAPSHOT - ../../pom.xml - - - Components - Engine - OData - dirigible-components-engine-odata - 4.0.0 - - + + + dirigible-components-parent + org.eclipse.dirigible + 10.0.0-SNAPSHOT + ../../pom.xml + - - - org.eclipse.dirigible - dirigible-components-core-base - - - org.eclipse.dirigible - dirigible-components-core-database - - - org.eclipse.dirigible - dirigible-components-core-repository - - - - - org.eclipse.dirigible - dirigible-components-data-structures - - - org.eclipse.dirigible - dirigible-components-data-sources - - - + Components - Engine - OData + dirigible-components-engine-odata + 4.0.0 + + + + jakarta.servlet + jakarta.servlet-api + + + org.apache.cxf + cxf-rt-frontend-jaxrs + ${cxf.version} + + + org.apache.cxf + cxf-rt-transports-http + ${cxf.version} + + + + + org.eclipse.dirigible + dirigible-components-core-base + + + org.eclipse.dirigible + dirigible-components-core-database + + + org.eclipse.dirigible + dirigible-components-core-repository + + + + + org.eclipse.dirigible + dirigible-components-data-structures + + + org.eclipse.dirigible + dirigible-components-data-sources + + + org.eclipse.dirigible dirigible-components-engine-javascript - + org.eclipse.dirigible dirigible-components-api-security - - + + org.eclipse.dirigible dirigible-odata-core - - - - ../../../licensing-header.txt - ../../../ - + + + + 4.0.3 + ../../../licensing-header.txt + ../../../ + diff --git a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java index d72eefcb2a3..9e40ee7ae71 100644 --- a/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java +++ b/components/engine/engine-odata/src/main/java/org/eclipse/dirigible/components/odata/config/ODataConfig.java @@ -35,7 +35,7 @@ ServletRegistrationBean olingoServlet() { bean.addInitParameter("jakarta.ws.rs.Application", "org.apache.olingo.odata2.core.rest.app.ODataApplication"); bean.addInitParameter("org.apache.olingo.odata2.service.factory", "org.eclipse.dirigible.components.odata.factory.DirigibleODataServiceFactory"); - bean.setLoadOnStartup(1); + bean.setLoadOnStartup(Integer.MAX_VALUE); return bean; } diff --git a/components/group/group-engines/pom.xml b/components/group/group-engines/pom.xml index 1dd9ae149d5..df82b41ecdb 100644 --- a/components/group/group-engines/pom.xml +++ b/components/group/group-engines/pom.xml @@ -1,4 +1,5 @@ - 4.0.0 @@ -11,11 +12,11 @@ Components - Group - Engines dirigible-components-group-engines - pom + pom - - - + + + org.eclipse.dirigible dirigible-components-group-engines-core pom @@ -106,9 +107,13 @@ org.eclipse.dirigible dirigible-components-engine-sftp - - - + + org.eclipse.dirigible + dirigible-components-engine-odata + + + + ../../../licensing-header.txt ../../../ diff --git a/modules/pom.xml b/modules/pom.xml index a045f69f7a2..bf99216009e 100644 --- a/modules/pom.xml +++ b/modules/pom.xml @@ -199,11 +199,6 @@ dirigible-components-engine-openapi ${project.version} - - org.eclipse.dirigible - dirigible-components-engine-odata - ${project.version} - org.eclipse.dirigible dirigible-components-engine-camel @@ -245,6 +240,11 @@ dirigible-components-engine-sftp ${project.version} + + org.eclipse.dirigible + dirigible-components-engine-odata + ${project.version} + org.eclipse.dirigible dirigible-engine-graalium-execution @@ -256,14 +256,14 @@ ${project.version} pom - + org.eclipse.dirigible dirigible-components-api-mail ${project.version} - + org.eclipse.dirigible @@ -275,7 +275,7 @@ dirigible-odata-core ${project.version} - + org.eclipse.dirigible From 036ab8bdc82eca22f8a325961c7c8ffba898a3da Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 27 Nov 2023 09:47:04 +0200 Subject: [PATCH 47/64] Spring Boot Admin Integration --- .github/workflows/build.yml | 2 + .github/workflows/pull-request.yml | 2 + build/application/pom.xml | 10 ++ .../dirigible/DirigibleApplication.java | 2 + .../dirigible/DirigibleConfiguration.java | 33 ++++ .../src/main/resources/application.properties | 7 + .../src/main/resources/dirigible.properties | 4 +- .../base/http/access/DirigibleRole.java | 33 ++++ .../access/HttpSecurityURIConfigurator.java | 6 +- .../resources-core/services/menus/help.js | 9 +- .../basic/BasicAuthSecurityConfiguration.java | 3 +- integration-tests/pom.xml | 151 ++++++++++++++++++ .../integration/tests/api/SecurityIT.java | 85 ++++++++++ .../integration/tests/ui/Dirigible.java | 76 +++++++++ .../tests/ui/framework/Browser.java | 31 ++++ .../tests/ui/framework/BrowserImpl.java | 139 ++++++++++++++++ .../tests/ui/framework/HtmlAttribute.java | 28 ++++ .../tests/ui/framework/HtmlElementType.java | 30 ++++ .../tests/ui/tests/SpringBootAdminIT.java | 36 +++++ 19 files changed, 683 insertions(+), 4 deletions(-) create mode 100644 build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java create mode 100644 components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java create mode 100644 integration-tests/pom.xml create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java create mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 5a2d55a00c2..2f34aa395fc 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -85,6 +85,8 @@ jobs: run: npm i -g typescript - name: Maven Build run: mvn -T 1C clean install -D maven.test.skip=true -D skipTests -D maven.javadoc.skip=true -D license.skip=true -U + - if: runner.os == 'Windows' + run: Set-DisplayResolution -Width 1920 -Height 1080 -Force - name: Integration tests run: mvn -f tests/pom.xml verify -P integration-tests - name: Upload selenide screenshots diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index dcb90ec55a3..d77f00bc5fd 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -83,6 +83,8 @@ jobs: run: npm i -g typescript - name: Maven Build run: mvn -T 1C clean install -D maven.test.skip=true -D skipTests -D maven.javadoc.skip=true -D license.skip=true -U + - if: runner.os == 'Windows' + run: Set-DisplayResolution -Width 1920 -Height 1080 -Force - name: Integration tests run: mvn -f tests/pom.xml verify -P integration-tests - name: Upload selenide screenshots diff --git a/build/application/pom.xml b/build/application/pom.xml index b340b0f6331..3187a80de53 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -228,6 +228,16 @@ runtime true + + de.codecentric + spring-boot-admin-starter-server + ${spring.boot.version} + + + de.codecentric + spring-boot-admin-starter-client + ${spring.boot.version} + diff --git a/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java b/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java index bea1b5f4c26..967be3d6023 100644 --- a/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java +++ b/build/application/src/main/java/org/eclipse/dirigible/DirigibleApplication.java @@ -23,7 +23,9 @@ import org.springframework.data.jpa.repository.config.EnableJpaRepositories; import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.web.client.RestTemplate; +import de.codecentric.boot.admin.server.config.EnableAdminServer; +@EnableAdminServer @EnableJpaAuditing @EnableJpaRepositories @SpringBootApplication diff --git a/build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java b/build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java new file mode 100644 index 00000000000..1d12277e86a --- /dev/null +++ b/build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible; + +import org.springframework.boot.task.TaskExecutorBuilder; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; + +@Configuration +class DirigibleConfiguration { + + @Bean + ThreadPoolTaskExecutor applicationTaskExecutor(TaskExecutorBuilder builder) { + builder.corePoolSize(8); + builder.maxPoolSize(10); + builder.queueCapacity(100); + + ThreadPoolTaskExecutor executor = builder.build(); + executor.initialize(); + + return executor; + } + +} diff --git a/build/application/src/main/resources/application.properties b/build/application/src/main/resources/application.properties index 6cfddf3e49e..720f7befada 100644 --- a/build/application/src/main/resources/application.properties +++ b/build/application/src/main/resources/application.properties @@ -1,5 +1,9 @@ +spring.application.name=Eclipse Dirigible + spring.main.allow-bean-definition-overriding=true + server.error.include-message=always +server.port=8080 spring.servlet.multipart.enabled=true spring.servlet.multipart.file-size-threshold=2KB @@ -21,3 +25,6 @@ spring.devtools.restart.poll-interval=6s spring.devtools.restart.quiet-period=5s cxf.path=/odata/v2 + +management.endpoints.web.exposure.include=mappings,caches,configprops,camelroutes,metrics,threaddump,heapdump,loggers,health,quartz,scheduledtasks,env,beans,conditions,info +management.endpoints.health.show-details=always diff --git a/build/application/src/main/resources/dirigible.properties b/build/application/src/main/resources/dirigible.properties index bdb08d8d7f3..41bcd7aa6f4 100644 --- a/build/application/src/main/resources/dirigible.properties +++ b/build/application/src/main/resources/dirigible.properties @@ -19,4 +19,6 @@ DIRIGIBLE_DATABASE_PROVIDER=local DIRIGIBLE_JAVASCRIPT_HANDLER_CLASS_NAME=org.eclipse.dirigible.graalium.handler.GraaliumJavascriptHandler DIRIGIBLE_GRAALIUM_ENABLE_DEBUG=true DIRIGIBLE_HOME_URL=services/web/ide/ -DIRIGIBLE_DATABASE_NAMES_CASE_SENSITIVE=true \ No newline at end of file +DIRIGIBLE_DATABASE_NAMES_CASE_SENSITIVE=true +DIRIGIBLE_SPRING_ADMIN_USERNAME=admin +DIRIGIBLE_SPRING_ADMIN_PASSWORD=admin \ No newline at end of file diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java new file mode 100644 index 00000000000..aead7c4786c --- /dev/null +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.components.base.http.access; + +public enum DirigibleRole { + + DEVELOPER(RoleNames.DEVELOPER), OPERATOR(RoleNames.OPERATOR); + + private final String roleName; + + DirigibleRole(String roleName) { + this.roleName = roleName; + } + + public String getName() { + return roleName; + } + + @SuppressWarnings("hiding") + public static class RoleNames { + public static final String OPERATOR = "OPERATOR"; + public static final String DEVELOPER = "DEVELOPER"; + + } +} diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java index 268d6e3f273..a1efa6311a2 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java @@ -68,7 +68,11 @@ public static void configure(HttpSecurity http) throws Exception { // "Developer" role required .requestMatchers(DEVELOPER_PATTERNS) - .hasRole("Developer") + .hasRole(DirigibleRole.DEVELOPER.getName()) + + // Spring Boot Admin + .requestMatchers("/spring-admin/**") + .hasRole(DirigibleRole.OPERATOR.getName()) // Deny all other requests .anyRequest() diff --git a/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js b/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js index 7e37ba8a409..5ebc5045076 100644 --- a/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js +++ b/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js @@ -43,6 +43,13 @@ const defaultMenuItems = [ action: "open", order: 5, data: "http://download.dirigible.io/", + divider: false + }, + { + label: "Admin Panel", + action: "open", + order: 6, + data: "/spring-admin", divider: true } ]; @@ -57,7 +64,7 @@ exports.getMenu = function () { { label: "About", action: "openDialogWindow", - order: 6, + order: 7, dialogId: "about", divider: false }] diff --git a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java index 7af63cfd9cc..b9bdd1b2dcd 100644 --- a/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java +++ b/components/security/security-basic/src/main/java/org/eclipse/dirigible/components/security/basic/BasicAuthSecurityConfiguration.java @@ -13,6 +13,7 @@ import java.nio.charset.StandardCharsets; import java.util.Arrays; import org.apache.commons.codec.binary.Base64; +import org.eclipse.dirigible.components.base.http.access.DirigibleRole; import org.eclipse.dirigible.components.base.http.access.HttpSecurityURIConfigurator; import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty; import org.springframework.context.annotation.Bean; @@ -51,7 +52,7 @@ InMemoryUserDetailsManager userDetailsService() { String password = org.eclipse.dirigible.commons.config.Configuration.get("DIRIGIBLE_BASIC_PASSWORD", "YWRtaW4="); // admin UserDetails user = User.withUsername(new String(new Base64().decode(username.getBytes()), StandardCharsets.UTF_8).trim()) .password("{noop}" + new String(new Base64().decode(password.getBytes()), StandardCharsets.UTF_8).trim()) - .roles("DEVELOPER", "OPERATOR") + .roles(DirigibleRole.DEVELOPER.getName(), DirigibleRole.OPERATOR.getName()) .build(); return new InMemoryUserDetailsManager(user); } diff --git a/integration-tests/pom.xml b/integration-tests/pom.xml new file mode 100644 index 00000000000..d61fc788d42 --- /dev/null +++ b/integration-tests/pom.xml @@ -0,0 +1,151 @@ + + 4.0.0 + + + org.eclipse.dirigible + dirigible-parent + 9.0.0-SNAPSHOT + ../pom.xml + + + + ../licensing-header.txt + ../ + true + 7.0.2 + + + Integration Tests + dirigible-integration-tests + jar + + + + org.eclipse.dirigible + dirigible-application + test + + + org.springframework.boot + spring-boot-starter-test + ${spring.boot.version} + test + + + org.springframework.security + spring-security-test + ${spring-security.version} + test + + + com.codeborne + selenide + ${selenide.version} + test + + + org.junit.jupiter + junit-jupiter-params + 5.8.2 + test + + + + + + + org.apache.maven.plugins + maven-surefire-plugin + + true + + + + org.apache.maven.plugins + maven-failsafe-plugin + 3.2.2 + + ${skipITs} + + + + + integration-test + verify + + + + + + org.codehaus.mojo + exec-maven-plugin + ${exec.maven.plugin} + + ${skipITs} + + + + build-ts-test-sources + generate-test-sources + + exec + + + + ${basedir}/src/test/resources/META-INF/dirigible/modules-tests/build-source${script.extension} + + + src/test/resources/META-INF/dirigible/modules-tests + + + + + + + + + + + integration-tests + + false + + + + Windows 11 + + + dos + + + + .bat + + + + Windows + + + Windows + + + + .bat + + + + unix + + + unix + + + + .sh + + + + + \ No newline at end of file diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java new file mode 100644 index 00000000000..a1d8f498935 --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java @@ -0,0 +1,85 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.api; + +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; +import java.util.stream.Stream; +import org.eclipse.dirigible.components.base.http.access.DirigibleRole.RoleNames; +import org.eclipse.dirigible.integration.tests.IntegrationTest; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.Arguments; +import org.junit.jupiter.params.provider.MethodSource; +import org.junit.jupiter.params.provider.ValueSource; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpStatus; +import org.springframework.security.test.context.support.WithMockUser; +import org.springframework.test.web.servlet.MockMvc; + +class SecurityIT extends IntegrationTest { + + @Autowired + private MockMvc mvc; + + @ParameterizedTest + @MethodSource("providePublicEndpointsParams") + void testPublicEndpoint(String path, HttpStatus expectedStatusCode) throws Exception { + mvc.perform(get(path)) + .andExpect(status().is(expectedStatusCode.value())); + } + + private static Stream providePublicEndpointsParams() { + return Stream.of(Arguments.of("/actuator/health", HttpStatus.OK), // + Arguments.of("/error.html", HttpStatus.OK)); + } + + @ParameterizedTest + @ValueSource(strings = {"/spring-admin", "/actuator/heapdump"}) + void testProtectedEndpointWithoutUnauthenticatedRequest(String path) throws Exception { + mvc.perform(get(path)) + .andExpect(status().isUnauthorized()); + } + + @ParameterizedTest + @ValueSource(strings = {"/actuator/heapdump"}) + @WithMockUser(username = "user_without_roles", roles = {"SOME_UNUSED_ROLE"}) + void testProtectedEndpointsWithUnauthorizedUser(String path) throws Exception { + mvc.perform(get(path)) + .andExpect(status().isForbidden()); + } + + @ParameterizedTest + @MethodSource("provideOperatorEndpointsParams") + @WithMockUser(username = "operator", roles = {RoleNames.OPERATOR}) + void testOperatorEndpointIsAccessible(String path, HttpStatus expectedStatusCode) throws Exception { + mvc.perform(get(path)) + .andExpect(status().is(expectedStatusCode.value())); + } + + private static Stream provideOperatorEndpointsParams() { + return Stream.of(Arguments.of("/spring-admin", HttpStatus.OK), // + Arguments.of("/actuator/heapdump", HttpStatus.OK)); + } + + @ParameterizedTest + @MethodSource("provideDeveloperEndpointsParams") + @WithMockUser(username = "developer", roles = {RoleNames.DEVELOPER}) + void testDeveloperEndpointIsAccessible(String path, HttpStatus expectedStatusCode) throws Exception { + mvc.perform(get(path)) + .andExpect(status().is(expectedStatusCode.value())); + } + + private static Stream provideDeveloperEndpointsParams() { + return Stream.of(Arguments.of("/services/ide/123", HttpStatus.NOT_FOUND), + Arguments.of("/websockets/ide/123", HttpStatus.NOT_FOUND)); + } + +} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java new file mode 100644 index 00000000000..36f83ede645 --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.ui; + +import org.eclipse.dirigible.integration.tests.ui.framework.Browser; +import org.eclipse.dirigible.integration.tests.ui.framework.HtmlAttribute; +import org.eclipse.dirigible.integration.tests.ui.framework.HtmlElementType; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import com.codeborne.selenide.SelenideElement; + +public class Dirigible { + + private static final Logger LOGGER = LoggerFactory.getLogger(Dirigible.class); + + private static final String LOGIN_PAGE_TITLE = "Please sign in"; + + private static final String ROOT_PATH = "/"; + + private static final String USERNAME = "admin"; + private static final String PASSWORD = "admin"; + + private static final String USERNAME_FIELD_ID = "username"; + private static final String PASSWORD_FIELD_ID = "password"; + private static final String SUBMIT_TYPE = "submit"; + + private static final String SIGN_IN_BUTTON_TEXT = "Sign in"; + + private static final String HELP_MENU_BUTTON = "Help"; + + private static final String ADMIN_PANEL_OPTION = "Admin Panel"; + + private final Browser browser; + + public Dirigible(Browser browser) { + this.browser = browser; + } + + public void openHomePage() { + browser.openPath(ROOT_PATH); + login(); + } + + private void login() { + SelenideElement title = browser.waitUntilExist(HtmlElementType.TITLE); + String pageTitle = title.getOwnText(); + if (!LOGIN_PAGE_TITLE.equals(pageTitle)) { + LOGGER.info("Skipping login"); + return; + } + LOGGER.info("Logging..."); + browser.enterTextInElementByAttributePattern(HtmlElementType.INPUT, HtmlAttribute.ID, USERNAME_FIELD_ID, USERNAME); + browser.enterTextInElementByAttributePattern(HtmlElementType.INPUT, HtmlAttribute.ID, PASSWORD_FIELD_ID, PASSWORD); + browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.TYPE, SUBMIT_TYPE, SIGN_IN_BUTTON_TEXT); + } + + public void navigateToAdminPanel() { + openHelpMenu(); + browser.clickElementByAttributePatternAndText(HtmlElementType.LI, HtmlAttribute.TITLE, ADMIN_PANEL_OPTION, ADMIN_PANEL_OPTION); + } + + public void openHelpMenu() { + browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.IS_MENU, Boolean.TRUE.toString(), + HELP_MENU_BUTTON); + } + + +} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java new file mode 100644 index 00000000000..67e07525ea4 --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java @@ -0,0 +1,31 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.ui.framework; + +import com.codeborne.selenide.SelenideElement; + +public interface Browser { + + void openPath(String path); + + void enterTextInElementByAttributePattern(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text); + + void clickElementByAttributePatternAndText(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text); + + void assertElementExistsByTypeAndText(HtmlElementType elementType, String text); + + String getPageTitle(); + + SelenideElement waitUntilExist(HtmlElementType elementType); + + void switchToWindow(String windowTitle); + +} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java new file mode 100644 index 00000000000..87583f30fd0 --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java @@ -0,0 +1,139 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.ui.framework; + +import java.util.concurrent.TimeUnit; +import org.openqa.selenium.By; +import com.codeborne.selenide.Condition; +import com.codeborne.selenide.Configuration; +import com.codeborne.selenide.ElementsCollection; +import com.codeborne.selenide.Selectors; +import com.codeborne.selenide.Selenide; +import com.codeborne.selenide.SelenideElement; +import com.codeborne.selenide.WebDriverRunner; + +public class BrowserImpl implements Browser { + + private static final String BROWSER = "chrome"; + private static final long SELENIDE_TIMEOUT_MILLIS = TimeUnit.SECONDS.toMillis(5); + + private static final String PATH_SEPARATOR = "/"; + + static { + Configuration.timeout = SELENIDE_TIMEOUT_MILLIS; + Configuration.browser = BROWSER; + } + + private final int localServerPort; + + public BrowserImpl(int localServerPort) { + this.localServerPort = localServerPort; + } + + @Override + public void openPath(String path) { + String url = createAppUrl(path); + Selenide.open(url); + maximizeBrowser(); + } + + private void maximizeBrowser() { + WebDriverRunner.getWebDriver() + .manage() + .window() + .maximize(); + } + + private String createAppUrl(String path) { + String absolutePath = path.startsWith(PATH_SEPARATOR) ? path : PATH_SEPARATOR + path; + return "http://localhost:" + localServerPort + absolutePath; + } + + @Override + public void enterTextInElementByAttributePattern(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text) { + SelenideElement element = getElementByAttributePattern(elementType, attribute, pattern); + element.click(); + element.setValue(text); + } + + private SelenideElement getElementByAttributePattern(HtmlElementType elementType, HtmlAttribute attribute, + String attributeValuePattern) { + By selector = constructCssSelectorByTypeAndAttribute(elementType, attribute, attributeValuePattern); + return Selenide.$(selector); + } + + @Override + public void clickElementByAttributePatternAndText(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text) { + SelenideElement element = getElementByAttributePatternAndText(elementType, attribute, pattern, text); + + clickElement(element); + } + + private SelenideElement getElementByAttributePatternAndText(HtmlElementType elementType, HtmlAttribute attribute, String pattern, + String text) { + By selector = constructCssSelectorByTypeAndAttribute(elementType, attribute, pattern); + ElementsCollection options = Selenide.$$(selector); + + return options.findBy(Condition.text(text)); + } + + private By constructCssSelectorByTypeAndAttribute(HtmlElementType elementType, HtmlAttribute attribute, String attributePattern) { + String cssSelector = elementType.getType() + "[" + attribute.getAttribute() + "*='" + attributePattern + "']"; + return Selectors.byCssSelector(cssSelector); + } + + private void clickElement(SelenideElement element) { + element.shouldBe(Condition.visible, Condition.enabled) + .scrollIntoView(false) + .click(); + } + + @Override + public void assertElementExistsByTypeAndText(HtmlElementType elementType, String text) { + SelenideElement element = getElementByAttributeAndText(elementType, text); + element.should(Condition.exist); + } + + private SelenideElement getElementByAttributeAndText(HtmlElementType elementType, String text) { + By selector = constructCssSelectorByType(elementType); + ElementsCollection options = Selenide.$$(selector); + + return options.findBy(Condition.text(text)); + } + + private By constructCssSelectorByType(HtmlElementType elementType) { + String cssSelector = elementType.getType(); + return Selectors.byCssSelector(cssSelector); + } + + @Override + public String getPageTitle() { + return Selenide.title(); + } + + @Override + public SelenideElement waitUntilExist(HtmlElementType elementType) { + SelenideElement element = getElementByType(elementType); + return element.should(Condition.exist); + } + + private SelenideElement getElementByType(HtmlElementType elementType) { + By cssSelector = Selectors.byCssSelector(elementType.getType()); + return Selenide.$(cssSelector); + } + + @Override + public void switchToWindow(String windowTitle) { + com.codeborne.selenide.Selenide.switchTo() + .window(windowTitle); + } + +} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java new file mode 100644 index 00000000000..8b3a08df49f --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java @@ -0,0 +1,28 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.ui.framework; + +public enum HtmlAttribute { + ID("id"), // + TYPE("type"), // + IS_MENU("is-menu"), // + TITLE("title"); + + private final String attribute; + + HtmlAttribute(String attribute) { + this.attribute = attribute; + } + + public String getAttribute() { + return attribute; + } +} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java new file mode 100644 index 00000000000..9f49ce12490 --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.ui.framework; + +public enum HtmlElementType { + BUTTON("button"), // + INPUT("input"), // + HEADER5("h5"), // + TITLE("title"), // + LI("li"), // + ANCHOR("a"); + + private final String type; + + HtmlElementType(String type) { + this.type = type; + } + + public String getType() { + return type; + } +} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java new file mode 100644 index 00000000000..a93c665e3d8 --- /dev/null +++ b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java @@ -0,0 +1,36 @@ +/* + * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors + * + * All rights reserved. This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v20.html + * + * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible + * contributors SPDX-License-Identifier: EPL-2.0 + */ +package org.eclipse.dirigible.integration.tests.ui.tests; + +import org.eclipse.dirigible.integration.tests.ui.Dirigible; +import org.eclipse.dirigible.integration.tests.ui.framework.HtmlElementType; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; + +class SpringBootAdminIT extends UserInterfaceIntegrationTest { + + private static final String SPRING_ADMIN_PAGE_TITLE = "Eclipse Dirigible Admin"; + private static final String SPRING_ADMIN_BRAND_TITLE = "Eclipse Dirigible Admin"; + private Dirigible dirigible; + + @BeforeEach + void setUp() { + this.dirigible = new Dirigible(browser); + } + + @Test + void testOpenSpringBootAdminUI() { + dirigible.openHomePage(); + dirigible.navigateToAdminPanel(); + browser.switchToWindow(SPRING_ADMIN_PAGE_TITLE); + browser.assertElementExistsByTypeAndText(HtmlElementType.ANCHOR, SPRING_ADMIN_BRAND_TITLE); + } +} From e79f34624437ebfdb5c4f5310eba5853e6e0eead Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Mon, 27 Nov 2023 10:06:11 +0200 Subject: [PATCH 48/64] adapt to the changes from master integration-tests -> tests Signed-off-by: Iliyan Velichkov --- integration-tests/pom.xml | 151 ------------------ .../integration/tests/ui/Dirigible.java | 76 --------- .../tests/ui/framework/Browser.java | 31 ---- .../tests/ui/framework/BrowserImpl.java | 139 ---------------- .../tests/ui/framework/HtmlAttribute.java | 28 ---- .../tests/ui/framework/HtmlElementType.java | 30 ---- tests/pom.xml | 6 + .../integration/tests/api/SecurityIT.java | 0 .../integration/tests/ui/Dirigible.java | 16 ++ .../tests/ui/framework/Browser.java | 2 + .../tests/ui/framework/BrowserImpl.java | 8 +- .../tests/ui/framework/HtmlAttribute.java | 4 +- .../tests/ui/framework/HtmlElementType.java | 4 +- .../tests/ui/tests/SpringBootAdminIT.java | 0 14 files changed, 37 insertions(+), 458 deletions(-) delete mode 100644 integration-tests/pom.xml delete mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java delete mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java delete mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java delete mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java delete mode 100644 integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java rename {integration-tests => tests}/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java (100%) rename {integration-tests => tests}/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java (100%) diff --git a/integration-tests/pom.xml b/integration-tests/pom.xml deleted file mode 100644 index d61fc788d42..00000000000 --- a/integration-tests/pom.xml +++ /dev/null @@ -1,151 +0,0 @@ - - 4.0.0 - - - org.eclipse.dirigible - dirigible-parent - 9.0.0-SNAPSHOT - ../pom.xml - - - - ../licensing-header.txt - ../ - true - 7.0.2 - - - Integration Tests - dirigible-integration-tests - jar - - - - org.eclipse.dirigible - dirigible-application - test - - - org.springframework.boot - spring-boot-starter-test - ${spring.boot.version} - test - - - org.springframework.security - spring-security-test - ${spring-security.version} - test - - - com.codeborne - selenide - ${selenide.version} - test - - - org.junit.jupiter - junit-jupiter-params - 5.8.2 - test - - - - - - - org.apache.maven.plugins - maven-surefire-plugin - - true - - - - org.apache.maven.plugins - maven-failsafe-plugin - 3.2.2 - - ${skipITs} - - - - - integration-test - verify - - - - - - org.codehaus.mojo - exec-maven-plugin - ${exec.maven.plugin} - - ${skipITs} - - - - build-ts-test-sources - generate-test-sources - - exec - - - - ${basedir}/src/test/resources/META-INF/dirigible/modules-tests/build-source${script.extension} - - - src/test/resources/META-INF/dirigible/modules-tests - - - - - - - - - - - integration-tests - - false - - - - Windows 11 - - - dos - - - - .bat - - - - Windows - - - Windows - - - - .bat - - - - unix - - - unix - - - - .sh - - - - - \ No newline at end of file diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java deleted file mode 100644 index 36f83ede645..00000000000 --- a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java +++ /dev/null @@ -1,76 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible.integration.tests.ui; - -import org.eclipse.dirigible.integration.tests.ui.framework.Browser; -import org.eclipse.dirigible.integration.tests.ui.framework.HtmlAttribute; -import org.eclipse.dirigible.integration.tests.ui.framework.HtmlElementType; -import org.slf4j.Logger; -import org.slf4j.LoggerFactory; -import com.codeborne.selenide.SelenideElement; - -public class Dirigible { - - private static final Logger LOGGER = LoggerFactory.getLogger(Dirigible.class); - - private static final String LOGIN_PAGE_TITLE = "Please sign in"; - - private static final String ROOT_PATH = "/"; - - private static final String USERNAME = "admin"; - private static final String PASSWORD = "admin"; - - private static final String USERNAME_FIELD_ID = "username"; - private static final String PASSWORD_FIELD_ID = "password"; - private static final String SUBMIT_TYPE = "submit"; - - private static final String SIGN_IN_BUTTON_TEXT = "Sign in"; - - private static final String HELP_MENU_BUTTON = "Help"; - - private static final String ADMIN_PANEL_OPTION = "Admin Panel"; - - private final Browser browser; - - public Dirigible(Browser browser) { - this.browser = browser; - } - - public void openHomePage() { - browser.openPath(ROOT_PATH); - login(); - } - - private void login() { - SelenideElement title = browser.waitUntilExist(HtmlElementType.TITLE); - String pageTitle = title.getOwnText(); - if (!LOGIN_PAGE_TITLE.equals(pageTitle)) { - LOGGER.info("Skipping login"); - return; - } - LOGGER.info("Logging..."); - browser.enterTextInElementByAttributePattern(HtmlElementType.INPUT, HtmlAttribute.ID, USERNAME_FIELD_ID, USERNAME); - browser.enterTextInElementByAttributePattern(HtmlElementType.INPUT, HtmlAttribute.ID, PASSWORD_FIELD_ID, PASSWORD); - browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.TYPE, SUBMIT_TYPE, SIGN_IN_BUTTON_TEXT); - } - - public void navigateToAdminPanel() { - openHelpMenu(); - browser.clickElementByAttributePatternAndText(HtmlElementType.LI, HtmlAttribute.TITLE, ADMIN_PANEL_OPTION, ADMIN_PANEL_OPTION); - } - - public void openHelpMenu() { - browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.IS_MENU, Boolean.TRUE.toString(), - HELP_MENU_BUTTON); - } - - -} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java deleted file mode 100644 index 67e07525ea4..00000000000 --- a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java +++ /dev/null @@ -1,31 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible.integration.tests.ui.framework; - -import com.codeborne.selenide.SelenideElement; - -public interface Browser { - - void openPath(String path); - - void enterTextInElementByAttributePattern(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text); - - void clickElementByAttributePatternAndText(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text); - - void assertElementExistsByTypeAndText(HtmlElementType elementType, String text); - - String getPageTitle(); - - SelenideElement waitUntilExist(HtmlElementType elementType); - - void switchToWindow(String windowTitle); - -} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java deleted file mode 100644 index 87583f30fd0..00000000000 --- a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java +++ /dev/null @@ -1,139 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible.integration.tests.ui.framework; - -import java.util.concurrent.TimeUnit; -import org.openqa.selenium.By; -import com.codeborne.selenide.Condition; -import com.codeborne.selenide.Configuration; -import com.codeborne.selenide.ElementsCollection; -import com.codeborne.selenide.Selectors; -import com.codeborne.selenide.Selenide; -import com.codeborne.selenide.SelenideElement; -import com.codeborne.selenide.WebDriverRunner; - -public class BrowserImpl implements Browser { - - private static final String BROWSER = "chrome"; - private static final long SELENIDE_TIMEOUT_MILLIS = TimeUnit.SECONDS.toMillis(5); - - private static final String PATH_SEPARATOR = "/"; - - static { - Configuration.timeout = SELENIDE_TIMEOUT_MILLIS; - Configuration.browser = BROWSER; - } - - private final int localServerPort; - - public BrowserImpl(int localServerPort) { - this.localServerPort = localServerPort; - } - - @Override - public void openPath(String path) { - String url = createAppUrl(path); - Selenide.open(url); - maximizeBrowser(); - } - - private void maximizeBrowser() { - WebDriverRunner.getWebDriver() - .manage() - .window() - .maximize(); - } - - private String createAppUrl(String path) { - String absolutePath = path.startsWith(PATH_SEPARATOR) ? path : PATH_SEPARATOR + path; - return "http://localhost:" + localServerPort + absolutePath; - } - - @Override - public void enterTextInElementByAttributePattern(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text) { - SelenideElement element = getElementByAttributePattern(elementType, attribute, pattern); - element.click(); - element.setValue(text); - } - - private SelenideElement getElementByAttributePattern(HtmlElementType elementType, HtmlAttribute attribute, - String attributeValuePattern) { - By selector = constructCssSelectorByTypeAndAttribute(elementType, attribute, attributeValuePattern); - return Selenide.$(selector); - } - - @Override - public void clickElementByAttributePatternAndText(HtmlElementType elementType, HtmlAttribute attribute, String pattern, String text) { - SelenideElement element = getElementByAttributePatternAndText(elementType, attribute, pattern, text); - - clickElement(element); - } - - private SelenideElement getElementByAttributePatternAndText(HtmlElementType elementType, HtmlAttribute attribute, String pattern, - String text) { - By selector = constructCssSelectorByTypeAndAttribute(elementType, attribute, pattern); - ElementsCollection options = Selenide.$$(selector); - - return options.findBy(Condition.text(text)); - } - - private By constructCssSelectorByTypeAndAttribute(HtmlElementType elementType, HtmlAttribute attribute, String attributePattern) { - String cssSelector = elementType.getType() + "[" + attribute.getAttribute() + "*='" + attributePattern + "']"; - return Selectors.byCssSelector(cssSelector); - } - - private void clickElement(SelenideElement element) { - element.shouldBe(Condition.visible, Condition.enabled) - .scrollIntoView(false) - .click(); - } - - @Override - public void assertElementExistsByTypeAndText(HtmlElementType elementType, String text) { - SelenideElement element = getElementByAttributeAndText(elementType, text); - element.should(Condition.exist); - } - - private SelenideElement getElementByAttributeAndText(HtmlElementType elementType, String text) { - By selector = constructCssSelectorByType(elementType); - ElementsCollection options = Selenide.$$(selector); - - return options.findBy(Condition.text(text)); - } - - private By constructCssSelectorByType(HtmlElementType elementType) { - String cssSelector = elementType.getType(); - return Selectors.byCssSelector(cssSelector); - } - - @Override - public String getPageTitle() { - return Selenide.title(); - } - - @Override - public SelenideElement waitUntilExist(HtmlElementType elementType) { - SelenideElement element = getElementByType(elementType); - return element.should(Condition.exist); - } - - private SelenideElement getElementByType(HtmlElementType elementType) { - By cssSelector = Selectors.byCssSelector(elementType.getType()); - return Selenide.$(cssSelector); - } - - @Override - public void switchToWindow(String windowTitle) { - com.codeborne.selenide.Selenide.switchTo() - .window(windowTitle); - } - -} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java deleted file mode 100644 index 8b3a08df49f..00000000000 --- a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java +++ /dev/null @@ -1,28 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible.integration.tests.ui.framework; - -public enum HtmlAttribute { - ID("id"), // - TYPE("type"), // - IS_MENU("is-menu"), // - TITLE("title"); - - private final String attribute; - - HtmlAttribute(String attribute) { - this.attribute = attribute; - } - - public String getAttribute() { - return attribute; - } -} diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java b/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java deleted file mode 100644 index 9f49ce12490..00000000000 --- a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java +++ /dev/null @@ -1,30 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible.integration.tests.ui.framework; - -public enum HtmlElementType { - BUTTON("button"), // - INPUT("input"), // - HEADER5("h5"), // - TITLE("title"), // - LI("li"), // - ANCHOR("a"); - - private final String type; - - HtmlElementType(String type) { - this.type = type; - } - - public String getType() { - return type; - } -} diff --git a/tests/pom.xml b/tests/pom.xml index 69b94d7a499..6a91cf0760b 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -43,6 +43,12 @@ ${selenide.version} test + + org.junit.jupiter + junit-jupiter-params + 5.8.2 + test + diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java similarity index 100% rename from integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java rename to tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java index 0d14fc8769d..36f83ede645 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java @@ -34,6 +34,10 @@ public class Dirigible { private static final String SIGN_IN_BUTTON_TEXT = "Sign in"; + private static final String HELP_MENU_BUTTON = "Help"; + + private static final String ADMIN_PANEL_OPTION = "Admin Panel"; + private final Browser browser; public Dirigible(Browser browser) { @@ -57,4 +61,16 @@ private void login() { browser.enterTextInElementByAttributePattern(HtmlElementType.INPUT, HtmlAttribute.ID, PASSWORD_FIELD_ID, PASSWORD); browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.TYPE, SUBMIT_TYPE, SIGN_IN_BUTTON_TEXT); } + + public void navigateToAdminPanel() { + openHelpMenu(); + browser.clickElementByAttributePatternAndText(HtmlElementType.LI, HtmlAttribute.TITLE, ADMIN_PANEL_OPTION, ADMIN_PANEL_OPTION); + } + + public void openHelpMenu() { + browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.IS_MENU, Boolean.TRUE.toString(), + HELP_MENU_BUTTON); + } + + } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java index 16c22107e9f..67e07525ea4 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java @@ -26,4 +26,6 @@ public interface Browser { SelenideElement waitUntilExist(HtmlElementType elementType); + void switchToWindow(String windowTitle); + } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java index d1103cc4bbf..4e7d3beb511 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java @@ -88,7 +88,7 @@ private SelenideElement getElementByAttributePatternAndText(HtmlElementType elem } private By constructCssSelectorByTypeAndAttribute(HtmlElementType elementType, HtmlAttribute attribute, String attributePattern) { - String cssSelector = elementType.getType() + "[" + attribute.getAttribute() + "*=" + attributePattern + "]"; + String cssSelector = elementType.getType() + "[" + attribute.getAttribute() + "*='" + attributePattern + "']"; return Selectors.byCssSelector(cssSelector); } @@ -132,4 +132,10 @@ private SelenideElement getElementByType(HtmlElementType elementType) { return Selenide.$(cssSelector); } + @Override + public void switchToWindow(String windowTitle) { + com.codeborne.selenide.Selenide.switchTo() + .window(windowTitle); + } + } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java index 6cc47886cc0..8b3a08df49f 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java @@ -12,7 +12,9 @@ public enum HtmlAttribute { ID("id"), // - TYPE("type"); + TYPE("type"), // + IS_MENU("is-menu"), // + TITLE("title"); private final String attribute; diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java index b4ef2870f76..9f49ce12490 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java @@ -14,7 +14,9 @@ public enum HtmlElementType { BUTTON("button"), // INPUT("input"), // HEADER5("h5"), // - TITLE("title"); + TITLE("title"), // + LI("li"), // + ANCHOR("a"); private final String type; diff --git a/integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java similarity index 100% rename from integration-tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java rename to tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java From e3d7d3941504ff5531620c06886c04cf46719304 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 28 Nov 2023 09:44:39 +0200 Subject: [PATCH 49/64] install Spring Boot Admin using profile Signed-off-by: Iliyan Velichkov --- README.md | 12 ++++++- build/application/pom.xml | 12 +++---- .../dirigible/DirigibleConfiguration.java | 33 ------------------- .../application-spring-boot-admin.properties | 9 +++++ .../resources-core/services/menus/help.js | 9 +---- pom.xml | 3 +- tests/pom.xml | 2 +- 7 files changed, 28 insertions(+), 52 deletions(-) delete mode 100644 build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java create mode 100644 build/application/src/main/resources/application-spring-boot-admin.properties diff --git a/README.md b/README.md index b96b2ae267b..78c75f5d0fa 100644 --- a/README.md +++ b/README.md @@ -36,7 +36,8 @@ The project started as an internal SAP initiative to address the extension and a - [Run](#run) - [Standalone](#standalone) - [Docker](#docker) - - [Code formatting](#code-formatting) + - [Code formatting](#code-formatting) + - [Spring Boot Admin](#spring-boot-admin) - [Additional Information](#additional-information) - [License](#license) - [Contributors](#contributors) @@ -237,6 +238,15 @@ To format the code using Maven execute the following in the root dir of the proj mvn formatter:format +### Spring Boot Admin +If you want to enable [Spring Boot Admin](https://docs.spring-boot-admin.com/current/) for the Dirigible project, you need to build the project with maven profile `spring-boot-admin` and then activate spring profile `spring-boot-admin`. +To do this, you have to execute the following commands: +``` +mvn -T 1C clean install -P spring-boot-admin -D maven.test.skip=true -D skipTests -D maven.javadoc.skip=true -D license.skip=true + +java -jar -Dspring.profiles.active=spring-boot-admin build/application/target/dirigible-application-*-executable.jar +``` + ## Additional Information ### License diff --git a/build/application/pom.xml b/build/application/pom.xml index 3187a80de53..f49bd0aa2c0 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -229,14 +229,10 @@ true - de.codecentric - spring-boot-admin-starter-server - ${spring.boot.version} - - - de.codecentric - spring-boot-admin-starter-client - ${spring.boot.version} + de.codecentric + spring-boot-admin-starter-server + ${spring.admin.version} + provided diff --git a/build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java b/build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java deleted file mode 100644 index 1d12277e86a..00000000000 --- a/build/application/src/main/java/org/eclipse/dirigible/DirigibleConfiguration.java +++ /dev/null @@ -1,33 +0,0 @@ -/* - * Copyright (c) 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible contributors - * - * All rights reserved. This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v2.0 which accompanies this distribution, and is available at - * http://www.eclipse.org/legal/epl-v20.html - * - * SPDX-FileCopyrightText: 2023 SAP SE or an SAP affiliate company and Eclipse Dirigible - * contributors SPDX-License-Identifier: EPL-2.0 - */ -package org.eclipse.dirigible; - -import org.springframework.boot.task.TaskExecutorBuilder; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; - -@Configuration -class DirigibleConfiguration { - - @Bean - ThreadPoolTaskExecutor applicationTaskExecutor(TaskExecutorBuilder builder) { - builder.corePoolSize(8); - builder.maxPoolSize(10); - builder.queueCapacity(100); - - ThreadPoolTaskExecutor executor = builder.build(); - executor.initialize(); - - return executor; - } - -} diff --git a/build/application/src/main/resources/application-spring-boot-admin.properties b/build/application/src/main/resources/application-spring-boot-admin.properties new file mode 100644 index 00000000000..d4f76689673 --- /dev/null +++ b/build/application/src/main/resources/application-spring-boot-admin.properties @@ -0,0 +1,9 @@ +spring.boot.admin.context-path=spring-admin +spring.boot.admin.ui.title=${spring.application.name} Admin +spring.boot.admin.ui.brand=Eclipse Dirigible Admin + +spring.boot.admin.client.url=http://localhost:${server.port}/spring-admin +spring.boot.admin.client.username=${DIRIGIBLE_SPRING_ADMIN_USERNAME:admin} +spring.boot.admin.client.password=${DIRIGIBLE_SPRING_ADMIN_PASSWORD:admin} +spring.boot.admin.client.instance.metadata.user.name=${spring.boot.admin.client.username} +spring.boot.admin.client.instance.metadata.user.password=${spring.boot.admin.client.password} diff --git a/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js b/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js index 5ebc5045076..7e37ba8a409 100644 --- a/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js +++ b/components/resources/resources-core/src/main/resources/META-INF/dirigible/resources-core/services/menus/help.js @@ -43,13 +43,6 @@ const defaultMenuItems = [ action: "open", order: 5, data: "http://download.dirigible.io/", - divider: false - }, - { - label: "Admin Panel", - action: "open", - order: 6, - data: "/spring-admin", divider: true } ]; @@ -64,7 +57,7 @@ exports.getMenu = function () { { label: "About", action: "openDialogWindow", - order: 7, + order: 6, dialogId: "about", divider: false }] diff --git a/pom.xml b/pom.xml index 787b567e8b5..940a78c1455 100644 --- a/pom.xml +++ b/pom.xml @@ -114,6 +114,7 @@ 4.3 3.2.0 + 3.1.8 1.7.0 0.9.5.5 23.1.1 @@ -700,4 +701,4 @@ - + \ No newline at end of file diff --git a/tests/pom.xml b/tests/pom.xml index 6a91cf0760b..dd5f77892e9 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -46,7 +46,7 @@ org.junit.jupiter junit-jupiter-params - 5.8.2 + ${junit.jupiter} test From d80baa97af066287ccfe0a8d5e8638864570c5aa Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 28 Nov 2023 10:25:32 +0200 Subject: [PATCH 50/64] exclude SpringBootAdminIT from the tests by default Signed-off-by: Iliyan Velichkov --- tests/pom.xml | 53 +++++++++++++++++-- .../integration/tests/api/SecurityIT.java | 2 +- 2 files changed, 50 insertions(+), 5 deletions(-) diff --git a/tests/pom.xml b/tests/pom.xml index dd5f77892e9..22706b5394b 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -44,10 +44,9 @@ test - org.junit.jupiter - junit-jupiter-params - ${junit.jupiter} - test + org.junit.jupiter + junit-jupiter-params + test @@ -120,6 +119,52 @@ false + + + + org.apache.maven.plugins + maven-failsafe-plugin + + + **/SpringBootAdminIT.java + + + + + + + + integration-tests-spring-boot-admin + + false + + + + de.codecentric + spring-boot-admin-starter-server + ${spring.admin.version} + test + + + de.codecentric + spring-boot-admin-starter-client + ${spring.admin.version} + test + + + + + + org.apache.maven.plugins + maven-failsafe-plugin + + + **/SpringBootAdminIT.java + + + + + Windows 11 diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java index a1d8f498935..dfffb2b9619 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java @@ -65,7 +65,7 @@ void testOperatorEndpointIsAccessible(String path, HttpStatus expectedStatusCode } private static Stream provideOperatorEndpointsParams() { - return Stream.of(Arguments.of("/spring-admin", HttpStatus.OK), // + return Stream.of(Arguments.of("/spring-admin", HttpStatus.NOT_FOUND), // Arguments.of("/actuator/heapdump", HttpStatus.OK)); } From 29e484c4d4c3fdca8f8eb87c48341f3c8787f718 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 28 Nov 2023 10:44:24 +0200 Subject: [PATCH 51/64] add spring boot job to workflows Signed-off-by: Iliyan Velichkov --- .github/workflows/build.yml | 55 ++++++++++++++++++++++++++++++ .github/workflows/pull-request.yml | 53 ++++++++++++++++++++++++++++ 2 files changed, 108 insertions(+) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 2f34aa395fc..32e03332ce5 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -96,3 +96,58 @@ jobs: retention-days: 1 name: selenide-screenshots path: tests/build/reports/tests + + integration-tests-spring-boot: + runs-on: ${{ matrix.os }}-latest + continue-on-error: true + strategy: + matrix: + os: [windows] + steps: + - name: Setup Chrome + uses: browser-actions/setup-chrome@v1.3.0 + with: + chrome-version: stable + - if: runner.os == 'Linux' + run: chrome --version + - if: runner.os == 'macOS' + run: chromium --version + - if: runner.os == 'Windows' + run: (Get-Item (Get-Command chrome).Source).VersionInfo.ProductVersion + - uses: actions/checkout@v3 + with: + fetch-depth: 0 + - name: Cache local Maven repository + uses: actions/cache@v3 + with: + path: ~/.m2/repository + key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} + restore-keys: ${{ runner.os }}-maven- + - name: Set up JDK Corretto 21 + uses: actions/setup-java@v3 + with: + distribution: 'corretto' + java-version: '21' + architecture: x64 + - name: Install NodeJS + uses: actions/setup-node@v3 + with: + node-version: 18 + - name: Install esbuild + run: npm i -g esbuild + - name: Install TypeScript compiler + run: npm i -g typescript + - name: Maven Build + run: mvn -T 1C clean install -P spring-boot-admin -D maven.test.skip=true -D skipTests -D maven.javadoc.skip=true -D license.skip=true -U + - if: runner.os == 'Windows' + run: Set-DisplayResolution -Width 1920 -Height 1080 -Force + - name: Integration tests + run: mvn -f tests/pom.xml verify -P spring-boot-admin -D spring.profiles.active=spring-boot-admin + - name: Upload selenide screenshots + uses: actions/upload-artifact@v3.1.3 + if: always() + with: + retention-days: 1 + name: selenide-screenshots-spring-boot + path: tests/build/reports/tests + \ No newline at end of file diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index d77f00bc5fd..e2715ee095d 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -94,3 +94,56 @@ jobs: retention-days: 1 name: selenide-screenshots path: tests/build/reports/tests + + integration-tests-spring-boot: + runs-on: ${{ matrix.os }}-latest + continue-on-error: true + strategy: + matrix: + os: [windows] + steps: + - name: Setup Chrome + uses: browser-actions/setup-chrome@v1.3.0 + with: + chrome-version: stable + - if: runner.os == 'Linux' + run: chrome --version + - if: runner.os == 'macOS' + run: chromium --version + - if: runner.os == 'Windows' + run: (Get-Item (Get-Command chrome).Source).VersionInfo.ProductVersion + - uses: actions/checkout@v3 + with: + fetch-depth: 0 + - name: Cache local Maven repository + uses: actions/cache@v3 + with: + path: ~/.m2/repository + key: ${{ runner.os }}-maven-${{ hashFiles('**/pom.xml') }} + restore-keys: ${{ runner.os }}-maven- + - name: Set up JDK Corretto 21 + uses: actions/setup-java@v3 + with: + distribution: 'corretto' + java-version: 21 + - name: Install NodeJS + uses: actions/setup-node@v3 + with: + node-version: 18 + - name: Install esbuild + run: npm i -g esbuild + - name: Install TypeScript compiler + run: npm i -g typescript + - name: Maven Build + run: mvn -T 1C clean install -P spring-boot-admin -D maven.test.skip=true -D skipTests -D maven.javadoc.skip=true -D license.skip=true -U + - if: runner.os == 'Windows' + run: Set-DisplayResolution -Width 1920 -Height 1080 -Force + - name: Integration tests + run: mvn -f tests/pom.xml verify -P spring-boot-admin -D spring.profiles.active=spring-boot-admin + - name: Upload selenide screenshots + uses: actions/upload-artifact@v3.1.3 + if: always() + with: + retention-days: 1 + name: selenide-screenshots-spring-boot + path: tests/build/reports/tests From cdc16eae0c0550e6cc448990e3509ce0eda559b7 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 28 Nov 2023 10:54:25 +0200 Subject: [PATCH 52/64] adapt SpringBootAdminIT Signed-off-by: Iliyan Velichkov --- .../integration/tests/ui/Dirigible.java | 16 ++++------------ .../integration/tests/ui/framework/Browser.java | 2 -- .../tests/ui/framework/BrowserImpl.java | 7 ------- .../tests/ui/framework/HtmlAttribute.java | 4 +--- .../tests/ui/framework/HtmlElementType.java | 1 - .../tests/ui/tests/SpringBootAdminIT.java | 7 +++---- 6 files changed, 8 insertions(+), 29 deletions(-) diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java index 36f83ede645..d8f0b086af0 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/Dirigible.java @@ -24,6 +24,7 @@ public class Dirigible { private static final String LOGIN_PAGE_TITLE = "Please sign in"; private static final String ROOT_PATH = "/"; + private static final String SPRING_BOOT_PATH = "/spring-admin"; private static final String USERNAME = "admin"; private static final String PASSWORD = "admin"; @@ -34,10 +35,6 @@ public class Dirigible { private static final String SIGN_IN_BUTTON_TEXT = "Sign in"; - private static final String HELP_MENU_BUTTON = "Help"; - - private static final String ADMIN_PANEL_OPTION = "Admin Panel"; - private final Browser browser; public Dirigible(Browser browser) { @@ -62,14 +59,9 @@ private void login() { browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.TYPE, SUBMIT_TYPE, SIGN_IN_BUTTON_TEXT); } - public void navigateToAdminPanel() { - openHelpMenu(); - browser.clickElementByAttributePatternAndText(HtmlElementType.LI, HtmlAttribute.TITLE, ADMIN_PANEL_OPTION, ADMIN_PANEL_OPTION); - } - - public void openHelpMenu() { - browser.clickElementByAttributePatternAndText(HtmlElementType.BUTTON, HtmlAttribute.IS_MENU, Boolean.TRUE.toString(), - HELP_MENU_BUTTON); + public void openSpringBootAdmin() { + browser.openPath(SPRING_BOOT_PATH); + login(); } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java index 67e07525ea4..16c22107e9f 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/Browser.java @@ -26,6 +26,4 @@ public interface Browser { SelenideElement waitUntilExist(HtmlElementType elementType); - void switchToWindow(String windowTitle); - } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java index 4e7d3beb511..33b0f3e98a3 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/BrowserImpl.java @@ -131,11 +131,4 @@ private SelenideElement getElementByType(HtmlElementType elementType) { By cssSelector = Selectors.byCssSelector(elementType.getType()); return Selenide.$(cssSelector); } - - @Override - public void switchToWindow(String windowTitle) { - com.codeborne.selenide.Selenide.switchTo() - .window(windowTitle); - } - } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java index 8b3a08df49f..6cc47886cc0 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlAttribute.java @@ -12,9 +12,7 @@ public enum HtmlAttribute { ID("id"), // - TYPE("type"), // - IS_MENU("is-menu"), // - TITLE("title"); + TYPE("type"); private final String attribute; diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java index 9f49ce12490..492d53f152e 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/framework/HtmlElementType.java @@ -15,7 +15,6 @@ public enum HtmlElementType { INPUT("input"), // HEADER5("h5"), // TITLE("title"), // - LI("li"), // ANCHOR("a"); private final String type; diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java index a93c665e3d8..865b3ea25e7 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/SpringBootAdminIT.java @@ -14,10 +14,11 @@ import org.eclipse.dirigible.integration.tests.ui.framework.HtmlElementType; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; +import org.springframework.test.context.ActiveProfiles; +@ActiveProfiles("spring-boot-admin") class SpringBootAdminIT extends UserInterfaceIntegrationTest { - private static final String SPRING_ADMIN_PAGE_TITLE = "Eclipse Dirigible Admin"; private static final String SPRING_ADMIN_BRAND_TITLE = "Eclipse Dirigible Admin"; private Dirigible dirigible; @@ -28,9 +29,7 @@ void setUp() { @Test void testOpenSpringBootAdminUI() { - dirigible.openHomePage(); - dirigible.navigateToAdminPanel(); - browser.switchToWindow(SPRING_ADMIN_PAGE_TITLE); + dirigible.openSpringBootAdmin(); browser.assertElementExistsByTypeAndText(HtmlElementType.ANCHOR, SPRING_ADMIN_BRAND_TITLE); } } From 19f75bb148dc037ed3831013b5b2d0e7f55b785a Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 28 Nov 2023 15:29:33 +0200 Subject: [PATCH 53/64] fix spring boot admin profile Signed-off-by: Iliyan Velichkov --- .github/workflows/build.yml | 2 +- .github/workflows/pull-request.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 32e03332ce5..46211efdbf5 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -142,7 +142,7 @@ jobs: - if: runner.os == 'Windows' run: Set-DisplayResolution -Width 1920 -Height 1080 -Force - name: Integration tests - run: mvn -f tests/pom.xml verify -P spring-boot-admin -D spring.profiles.active=spring-boot-admin + run: mvn -f tests/pom.xml verify -P integration-tests-spring-boot-admin -D spring.profiles.active=spring-boot-admin - name: Upload selenide screenshots uses: actions/upload-artifact@v3.1.3 if: always() diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index e2715ee095d..7132b605dbe 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -139,7 +139,7 @@ jobs: - if: runner.os == 'Windows' run: Set-DisplayResolution -Width 1920 -Height 1080 -Force - name: Integration tests - run: mvn -f tests/pom.xml verify -P spring-boot-admin -D spring.profiles.active=spring-boot-admin + run: mvn -f tests/pom.xml verify -P integration-tests-spring-boot-admin -D spring.profiles.active=spring-boot-admin - name: Upload selenide screenshots uses: actions/upload-artifact@v3.1.3 if: always() From 8c8fdb2ee476da286a360867fed7c85cb88e8370 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 28 Nov 2023 16:04:05 +0200 Subject: [PATCH 54/64] fix spring boot itests Signed-off-by: Iliyan Velichkov --- tests/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/pom.xml b/tests/pom.xml index 22706b5394b..bc5d0349cfe 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -201,4 +201,4 @@ - \ No newline at end of file + From c88f09dcbf5fdf628d2dc211655a73d304c0b89b Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 5 Dec 2023 14:37:29 +0200 Subject: [PATCH 55/64] fix spring admin versions Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/build/application/pom.xml b/build/application/pom.xml index f49bd0aa2c0..da94f44ae47 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -296,4 +296,28 @@ ../../ + + + default + + true + + + + spring-boot-admin + + + de.codecentric + spring-boot-admin-starter-server + ${spring.admin.version} + + + de.codecentric + spring-boot-admin-starter-client + ${spring.admin.version} + + + + + \ No newline at end of file From b6ad3a49b7ec068ea88a3fab711666c9d2353941 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Thu, 7 Dec 2023 10:42:01 +0200 Subject: [PATCH 56/64] fix merge issues Signed-off-by: Iliyan Velichkov --- build/application/pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build/application/pom.xml b/build/application/pom.xml index da94f44ae47..79b4aaff8f4 100644 --- a/build/application/pom.xml +++ b/build/application/pom.xml @@ -320,4 +320,4 @@ - \ No newline at end of file + From 4672b20650c1a3fd797ef1e08dbb10db40855c58 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Thu, 7 Dec 2023 10:45:04 +0200 Subject: [PATCH 57/64] fix more merge issues Signed-off-by: Iliyan Velichkov --- tests/pom.xml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/tests/pom.xml b/tests/pom.xml index bc5d0349cfe..ec0be6e9539 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -74,6 +74,7 @@ org.apache.maven.plugins maven-failsafe-plugin + 3.2.3 ${skipITs} @@ -89,6 +90,7 @@ org.codehaus.mojo exec-maven-plugin + ${exec.maven.plugin} ${skipITs} @@ -201,4 +203,4 @@ - + \ No newline at end of file From f2a861ad2524a255ba926fa3d133352976a2dd0e Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 16:35:07 +0200 Subject: [PATCH 58/64] remove versions Signed-off-by: Iliyan Velichkov --- tests/pom.xml | 2 -- 1 file changed, 2 deletions(-) diff --git a/tests/pom.xml b/tests/pom.xml index ec0be6e9539..22706b5394b 100644 --- a/tests/pom.xml +++ b/tests/pom.xml @@ -74,7 +74,6 @@ org.apache.maven.plugins maven-failsafe-plugin - 3.2.3 ${skipITs} @@ -90,7 +89,6 @@ org.codehaus.mojo exec-maven-plugin - ${exec.maven.plugin} ${skipITs} From 9345a10598e99d47bc401279bce91f5cf209bd6b Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 17:11:10 +0200 Subject: [PATCH 59/64] rename role Signed-off-by: Iliyan Velichkov --- build/application/src/main/resources/application.properties | 2 +- .../dirigible/components/base/http/access/DirigibleRole.java | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/build/application/src/main/resources/application.properties b/build/application/src/main/resources/application.properties index 720f7befada..30dccdecbfe 100644 --- a/build/application/src/main/resources/application.properties +++ b/build/application/src/main/resources/application.properties @@ -26,5 +26,5 @@ spring.devtools.restart.quiet-period=5s cxf.path=/odata/v2 -management.endpoints.web.exposure.include=mappings,caches,configprops,camelroutes,metrics,threaddump,heapdump,loggers,health,quartz,scheduledtasks,env,beans,conditions,info +management.endpoints.web.exposure.include=camelroutes,mappings,caches,configprops,camelroutes,metrics,threaddump,heapdump,loggers,health,quartz,scheduledtasks,env,beans,conditions,info management.endpoints.health.show-details=always diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java index aead7c4786c..2c8ab8398c6 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/DirigibleRole.java @@ -26,8 +26,8 @@ public String getName() { @SuppressWarnings("hiding") public static class RoleNames { - public static final String OPERATOR = "OPERATOR"; - public static final String DEVELOPER = "DEVELOPER"; + public static final String OPERATOR = "Operator"; + public static final String DEVELOPER = "Developer"; } } From 62a3cbb25d5eded2b384257b32f9f9f57d4f9d38 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 17:27:59 +0200 Subject: [PATCH 60/64] protect actuator endpoints Signed-off-by: Iliyan Velichkov --- .../http/access/HttpSecurityURIConfigurator.java | 8 ++++++-- .../integration/tests/api/SecurityIT.java | 14 ++++++++++---- 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java index a1efa6311a2..7bb329c2b7b 100644 --- a/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java +++ b/components/core/core-base/src/main/java/org/eclipse/dirigible/components/base/http/access/HttpSecurityURIConfigurator.java @@ -37,7 +37,7 @@ public class HttpSecurityURIConfigurator { "/services/js/resources-core/**", // "/services/js/resources-core/**", // "/services/integrations/**", // - "/actuator/**"}; + "/actuator/health"}; private static final String[] AUTHENTICATED_PATTERNS = {// "/services/**", // @@ -51,6 +51,10 @@ public class HttpSecurityURIConfigurator { "/services/ide/**", // "/websockets/ide/**"}; + private static final String[] OPERATOR_PATTERNS = {// + "/spring-admin/**", // + "/actuator/**"}; + /** * Configure. * @@ -71,7 +75,7 @@ public static void configure(HttpSecurity http) throws Exception { .hasRole(DirigibleRole.DEVELOPER.getName()) // Spring Boot Admin - .requestMatchers("/spring-admin/**") + .requestMatchers(OPERATOR_PATTERNS) .hasRole(DirigibleRole.OPERATOR.getName()) // Deny all other requests diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java index dfffb2b9619..aff4853881d 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java @@ -13,6 +13,7 @@ import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; import java.util.stream.Stream; +import org.eclipse.dirigible.DirigibleApplication; import org.eclipse.dirigible.components.base.http.access.DirigibleRole.RoleNames; import org.eclipse.dirigible.integration.tests.IntegrationTest; import org.junit.jupiter.params.ParameterizedTest; @@ -20,10 +21,13 @@ import org.junit.jupiter.params.provider.MethodSource; import org.junit.jupiter.params.provider.ValueSource; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.boot.test.context.SpringBootTest.WebEnvironment; import org.springframework.http.HttpStatus; import org.springframework.security.test.context.support.WithMockUser; import org.springframework.test.web.servlet.MockMvc; +@SpringBootTest(webEnvironment = WebEnvironment.MOCK, classes = DirigibleApplication.class) class SecurityIT extends IntegrationTest { @Autowired @@ -37,19 +41,21 @@ void testPublicEndpoint(String path, HttpStatus expectedStatusCode) throws Excep } private static Stream providePublicEndpointsParams() { - return Stream.of(Arguments.of("/actuator/health", HttpStatus.OK), // + return Stream.of(// + Arguments.of("/actuator/health", HttpStatus.OK), // + Arguments.of("/login", HttpStatus.OK), // Arguments.of("/error.html", HttpStatus.OK)); } @ParameterizedTest - @ValueSource(strings = {"/spring-admin", "/actuator/heapdump"}) + @ValueSource(strings = {"/spring-admin", "/actuator/info"}) void testProtectedEndpointWithoutUnauthenticatedRequest(String path) throws Exception { mvc.perform(get(path)) .andExpect(status().isUnauthorized()); } @ParameterizedTest - @ValueSource(strings = {"/actuator/heapdump"}) + @ValueSource(strings = {"/actuator/info"}) @WithMockUser(username = "user_without_roles", roles = {"SOME_UNUSED_ROLE"}) void testProtectedEndpointsWithUnauthorizedUser(String path) throws Exception { mvc.perform(get(path)) @@ -66,7 +72,7 @@ void testOperatorEndpointIsAccessible(String path, HttpStatus expectedStatusCode private static Stream provideOperatorEndpointsParams() { return Stream.of(Arguments.of("/spring-admin", HttpStatus.NOT_FOUND), // - Arguments.of("/actuator/heapdump", HttpStatus.OK)); + Arguments.of("/actuator/info", HttpStatus.OK)); } @ParameterizedTest From fffd052a804d547bdb828855a19bf1b8e0868fd4 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 18:21:25 +0200 Subject: [PATCH 61/64] fix integration tests execution Signed-off-by: Iliyan Velichkov --- .../integration/tests/ui/tests/DirigibleHomepageIT.java | 3 +++ 1 file changed, 3 insertions(+) diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java index de04bf24a93..6eee237dc69 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java @@ -14,7 +14,10 @@ import org.eclipse.dirigible.integration.tests.ui.framework.HtmlElementType; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; +import org.springframework.test.annotation.DirtiesContext; +import org.springframework.test.annotation.DirtiesContext.ClassMode; +@DirtiesContext(classMode = ClassMode.AFTER_CLASS) class DirigibleHomepageIT extends UserInterfaceIntegrationTest { private static final String ECLIPSE_DIRIGIBLE_HEADER = "Eclipse Dirigible"; From e6b582b72bbe657a43cdd8540a9902b61de88629 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 18:41:04 +0200 Subject: [PATCH 62/64] clean context after SecurityIT Signed-off-by: Iliyan Velichkov --- .../eclipse/dirigible/integration/tests/api/SecurityIT.java | 3 +++ 1 file changed, 3 insertions(+) diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java index aff4853881d..11c84469092 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java @@ -25,8 +25,11 @@ import org.springframework.boot.test.context.SpringBootTest.WebEnvironment; import org.springframework.http.HttpStatus; import org.springframework.security.test.context.support.WithMockUser; +import org.springframework.test.annotation.DirtiesContext; +import org.springframework.test.annotation.DirtiesContext.ClassMode; import org.springframework.test.web.servlet.MockMvc; +@DirtiesContext(classMode = ClassMode.AFTER_CLASS) @SpringBootTest(webEnvironment = WebEnvironment.MOCK, classes = DirigibleApplication.class) class SecurityIT extends IntegrationTest { From 9c502a90832778063b7082f891d1558ceec7ea05 Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Tue, 19 Dec 2023 18:47:38 +0200 Subject: [PATCH 63/64] @DirtiesContext on parent level Signed-off-by: Iliyan Velichkov --- .../dirigible/integration/tests/IntegrationTest.java | 6 +++++- .../eclipse/dirigible/integration/tests/api/SecurityIT.java | 3 --- .../tests/api/java/messaging/MessagingFacadeIT.java | 3 --- .../tests/api/javascript/DirigibleJavaScriptIT.java | 3 --- .../integration/tests/ui/tests/DirigibleHomepageIT.java | 3 --- 5 files changed, 5 insertions(+), 13 deletions(-) diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/IntegrationTest.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/IntegrationTest.java index 0ef7f2351eb..282aa48242e 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/IntegrationTest.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/IntegrationTest.java @@ -15,11 +15,15 @@ import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.boot.test.context.SpringBootTest.WebEnvironment; +import org.springframework.test.annotation.DirtiesContext; +import org.springframework.test.annotation.DirtiesContext.ClassMode; import org.springframework.test.context.junit4.SpringRunner; + +@AutoConfigureMockMvc @RunWith(SpringRunner.class) +@DirtiesContext(classMode = ClassMode.AFTER_CLASS) @SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT, classes = DirigibleApplication.class) -@AutoConfigureMockMvc public abstract class IntegrationTest { // base class for integration tests } diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java index 11c84469092..aff4853881d 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/SecurityIT.java @@ -25,11 +25,8 @@ import org.springframework.boot.test.context.SpringBootTest.WebEnvironment; import org.springframework.http.HttpStatus; import org.springframework.security.test.context.support.WithMockUser; -import org.springframework.test.annotation.DirtiesContext; -import org.springframework.test.annotation.DirtiesContext.ClassMode; import org.springframework.test.web.servlet.MockMvc; -@DirtiesContext(classMode = ClassMode.AFTER_CLASS) @SpringBootTest(webEnvironment = WebEnvironment.MOCK, classes = DirigibleApplication.class) class SecurityIT extends IntegrationTest { diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/java/messaging/MessagingFacadeIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/java/messaging/MessagingFacadeIT.java index 21b8e6b6bae..c1b78b4a14e 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/java/messaging/MessagingFacadeIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/java/messaging/MessagingFacadeIT.java @@ -18,11 +18,8 @@ import org.eclipse.dirigible.integration.tests.IntegrationTest; import org.junit.jupiter.api.Nested; import org.junit.jupiter.api.Test; -import org.springframework.test.annotation.DirtiesContext; -import org.springframework.test.annotation.DirtiesContext.ClassMode; import org.testcontainers.shaded.org.awaitility.Awaitility; -@DirtiesContext(classMode = ClassMode.AFTER_CLASS) class MessagingFacadeIT extends IntegrationTest { private static final String TEST_MESSAGE = "Test message"; diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/javascript/DirigibleJavaScriptIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/javascript/DirigibleJavaScriptIT.java index db72377c105..987fd1270f2 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/javascript/DirigibleJavaScriptIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/api/javascript/DirigibleJavaScriptIT.java @@ -18,10 +18,7 @@ import org.junit.jupiter.api.TestFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.mock.mockito.MockBean; -import org.springframework.test.annotation.DirtiesContext; -import org.springframework.test.annotation.DirtiesContext.ClassMode; -@DirtiesContext(classMode = ClassMode.AFTER_CLASS) class DirigibleJavaScriptIT extends IntegrationTest { @Autowired diff --git a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java index 6eee237dc69..de04bf24a93 100644 --- a/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java +++ b/tests/src/test/java/org/eclipse/dirigible/integration/tests/ui/tests/DirigibleHomepageIT.java @@ -14,10 +14,7 @@ import org.eclipse.dirigible.integration.tests.ui.framework.HtmlElementType; import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; -import org.springframework.test.annotation.DirtiesContext; -import org.springframework.test.annotation.DirtiesContext.ClassMode; -@DirtiesContext(classMode = ClassMode.AFTER_CLASS) class DirigibleHomepageIT extends UserInterfaceIntegrationTest { private static final String ECLIPSE_DIRIGIBLE_HEADER = "Eclipse Dirigible"; From 3cbd3420f517a8144d7e1334638a5060944f20be Mon Sep 17 00:00:00 2001 From: Iliyan Velichkov Date: Thu, 21 Dec 2023 18:34:53 +0200 Subject: [PATCH 64/64] fix merge issues Signed-off-by: Iliyan Velichkov --- README.md | 2 +- pom.xml | 7 +------ 2 files changed, 2 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index e0bc26ed66a..d87a18402f4 100644 --- a/README.md +++ b/README.md @@ -36,7 +36,7 @@ The project started as an internal SAP initiative to address the extension and a - [Run](#run) - [Standalone](#standalone) - [Docker](#docker) - - [Native image](#native-image) + - [Native image](#native-image) - [Code formatting](#code-formatting) - [Spring Boot Admin](#spring-boot-admin) - [Additional Information](#additional-information) diff --git a/pom.xml b/pom.xml index 987364c2c60..1213e3068f4 100644 --- a/pom.xml +++ b/pom.xml @@ -701,9 +701,4 @@ - -<<<<<<< HEAD - -======= - ->>>>>>> refs/remotes/origin/master + \ No newline at end of file