Skip to content

Commit

Permalink
[AMQ-9398] Fix activemq-ra/activemq-rar namespaces for Jakarta EE
Browse files Browse the repository at this point in the history
(cherry picked from commit 799b802)
  • Loading branch information
mattrpav authored and jbonofre committed Nov 29, 2023
1 parent e5387bd commit 01aa140
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 42 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -147,25 +147,19 @@ public void validate() throws InvalidPropertyException {
}

public boolean isValidUseRAManagedTransaction(List<String> errorMessages) {
try {
new Boolean(useRAManagedTransaction);
return true;
} catch (Throwable e) {
//
boolean valid = isValidBooleanString(useRAManagedTransaction);
if(!valid) {
errorMessages.add("useRAManagedTransaction must be set to: true or false.");
}
errorMessages.add("useRAManagedTransaction must be set to: true or false.");
return false;
return valid;
}

public boolean isValidNoLocal(List<String> errorMessages) {
try {
new Boolean(noLocal);
return true;
} catch (Throwable e) {
//
boolean valid = isValidBooleanString(noLocal);
if(!valid) {
errorMessages.add("noLocal must be set to: true or false.");
}
errorMessages.add("noLocal must be set to: true or false.");
return false;
return valid;
}

public boolean isValidMessageSelector(List<String> errorMessages) {
Expand Down Expand Up @@ -217,14 +211,11 @@ public boolean isValidMaxMessagesPerBatch(List<String> errorMessages) {
}

public boolean isValidEnableBatch(List<String> errorMessages) {
try {
new Boolean(enableBatch);
return true;
} catch (Throwable e) {
//
boolean valid = isValidBooleanString(enableBatch);
if(!valid) {
errorMessages.add("enableBatch must be set to: true or false");
}
errorMessages.add("enableBatch must be set to: true or false");
return false;
return valid;
}

public ResourceAdapter getResourceAdapter() {
Expand Down Expand Up @@ -735,4 +726,8 @@ public String getKeyStoreKeyPassword() {
public void setKeyStoreKeyPassword(String keyStoreKeyPassword) {
this.keyStoreKeyPassword = keyStoreKeyPassword;
}

private static boolean isValidBooleanString(String booleanString) {
return ("true".equalsIgnoreCase(booleanString) || ("false".equalsIgnoreCase(booleanString)));
}
}
38 changes: 18 additions & 20 deletions activemq-rar/src/main/rar/META-INF/ra.xml
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,14 @@
limitations under the License.
-->

<connector xmlns="http://java.sun.com/xml/ns/j2ee"
<connector xmlns="https://jakarta.ee/xml/ns/jakartaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/connector_1_5.xsd"
version="1.5">
xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee https://jakarta.ee/xml/ns/jakartaee/connector_2_0.xsd"
version="2.0">
<description>ActiveMQ inbound and outbound JMS ResourceAdapter</description>
<display-name>ActiveMQ JMS Resource Adapter</display-name>
<vendor-name>activemq.org</vendor-name>
<eis-type>JMS 1.1</eis-type>
<eis-type>JMS 3.1</eis-type>
<resourceadapter-version>1.0</resourceadapter-version>
<license>
<description>
Expand Down Expand Up @@ -106,7 +105,7 @@
<config-property-type>java.lang.String</config-property-type>
</config-property>

<!-- NOTE disable the following property if you do not wish to deploy an embedded broker -->
<!-- NOTE disable the following property if you do not wish to deploy an embedded broker -->
<config-property>
<description>
Sets the XML configuration file used to configure the embedded ActiveMQ broker via
Expand All @@ -131,36 +130,36 @@
<outbound-resourceadapter>
<connection-definition>
<managedconnectionfactory-class>org.apache.activemq.ra.ActiveMQManagedConnectionFactory</managedconnectionfactory-class>
<connectionfactory-interface>javax.jms.ConnectionFactory</connectionfactory-interface>
<connectionfactory-interface>jakarta.jms.ConnectionFactory</connectionfactory-interface>
<connectionfactory-impl-class>org.apache.activemq.ra.ActiveMQConnectionFactory</connectionfactory-impl-class>
<connection-interface>javax.jms.Connection</connection-interface>
<connection-interface>jakarta.jms.Connection</connection-interface>
<connection-impl-class>org.apache.activemq.ra.ManagedConnectionProxy</connection-impl-class>
</connection-definition>
<connection-definition>
<managedconnectionfactory-class>org.apache.activemq.ra.ActiveMQManagedConnectionFactory</managedconnectionfactory-class>
<connectionfactory-interface>javax.jms.QueueConnectionFactory</connectionfactory-interface>
<connectionfactory-interface>jakarta.jms.QueueConnectionFactory</connectionfactory-interface>
<connectionfactory-impl-class>org.apache.activemq.ra.ActiveMQConnectionFactory</connectionfactory-impl-class>
<connection-interface>javax.jms.QueueConnection</connection-interface>
<connection-interface>jakarta.jms.QueueConnection</connection-interface>
<connection-impl-class>org.apache.activemq.ra.ManagedConnectionProxy</connection-impl-class>
</connection-definition>
<connection-definition>
<managedconnectionfactory-class>org.apache.activemq.ra.ActiveMQManagedConnectionFactory</managedconnectionfactory-class>
<connectionfactory-interface>javax.jms.TopicConnectionFactory</connectionfactory-interface>
<connectionfactory-interface>jakarta.jms.TopicConnectionFactory</connectionfactory-interface>
<connectionfactory-impl-class>org.apache.activemq.ra.ActiveMQConnectionFactory</connectionfactory-impl-class>
<connection-interface>javax.jms.TopicConnection</connection-interface>
<connection-interface>jakarta.jms.TopicConnection</connection-interface>
<connection-impl-class>org.apache.activemq.ra.ManagedConnectionProxy</connection-impl-class>
</connection-definition>
<transaction-support>XATransaction</transaction-support>
<authentication-mechanism>
<authentication-mechanism-type>BasicPassword</authentication-mechanism-type>
<credential-interface>javax.resource.spi.security.PasswordCredential</credential-interface>
<credential-interface>jakarta.resource.spi.security.PasswordCredential</credential-interface>
</authentication-mechanism>
<reauthentication-support>false</reauthentication-support>
</outbound-resourceadapter>
<inbound-resourceadapter>
<messageadapter>
<messagelistener>
<messagelistener-type>javax.jms.MessageListener</messagelistener-type>
<messagelistener-type>jakarta.jms.MessageListener</messagelistener-type>
<activationspec>
<activationspec-class>org.apache.activemq.ra.ActiveMQActivationSpec</activationspec-class>

Expand All @@ -176,31 +175,31 @@
</messageadapter>
</inbound-resourceadapter>
<adminobject>
<adminobject-interface>javax.jms.Queue</adminobject-interface>
<adminobject-interface>jakarta.jms.Queue</adminobject-interface>
<adminobject-class>org.apache.activemq.command.ActiveMQQueue</adminobject-class>
<config-property>
<config-property-name>PhysicalName</config-property-name>
<config-property-type>java.lang.String</config-property-type>
</config-property>
</adminobject>
<adminobject>
<adminobject-interface>javax.jms.Topic</adminobject-interface>
<adminobject-interface>jakarta.jms.Topic</adminobject-interface>
<adminobject-class>org.apache.activemq.command.ActiveMQTopic</adminobject-class>
<config-property>
<config-property-name>PhysicalName</config-property-name>
<config-property-type>java.lang.String</config-property-type>
</config-property>
</adminobject>
<adminobject>
<adminobject-interface>javax.jms.ConnectionFactory</adminobject-interface>
<adminobject-interface>jakarta.jms.ConnectionFactory</adminobject-interface>
<adminobject-class>org.apache.activemq.ActiveMQConnectionFactory</adminobject-class>
<config-property>
<config-property-name>brokerUrl</config-property-name>
<config-property-type>java.lang.String</config-property-type>
</config-property>
</adminobject>
<adminobject>
<adminobject-interface>javax.jms.ConnectionFactory</adminobject-interface>
<adminobject-interface>jakarta.jms.ConnectionFactory</adminobject-interface>
<adminobject-class>org.apache.activemq.pool.XaPooledConnectionFactory</adminobject-class>
<config-property>
<config-property-name>brokerUrl</config-property-name>
Expand All @@ -212,14 +211,13 @@
</config-property>
</adminobject>
<adminobject>
<adminobject-interface>javax.jms.XAConnectionFactory</adminobject-interface>
<adminobject-interface>jakarta.jms.XAConnectionFactory</adminobject-interface>
<adminobject-class>org.apache.activemq.ActiveMQXAConnectionFactory</adminobject-class>
<config-property>
<config-property-name>brokerURL</config-property-name>
<config-property-type>java.lang.String</config-property-type>
</config-property>
</adminobject>


</resourceadapter>
</connector>
2 changes: 1 addition & 1 deletion activemq-rar/src/main/rar/broker-config.xml
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
xmlns="http://www.springframework.org/schema/beans"
xmlns:amq="http://activemq.apache.org/schema/core"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://activemq.apache.org/schema/core http://activemq.apache.org/schema/core/activemq-core.xsd">

<!-- shutdown hook is disabled as RAR classloader may be gone at shutdown -->
Expand Down

0 comments on commit 01aa140

Please sign in to comment.