You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@activemq.apache.org by "Kevin Earls (JIRA)" <ji...@apache.org> on 2013/06/24 13:50:21 UTC
[jira] [Updated] (AMQ-4596) AMQP: JMSSecurityExceptions are not
propagated back to QPID client on authentication failures
[ https://issues.apache.org/jira/browse/AMQ-4596?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Kevin Earls updated AMQ-4596:
-----------------------------
Attachment: AMQ-4596.patch
Unit test that reproduces the problem.
> AMQP: JMSSecurityExceptions are not propagated back to QPID client on authentication failures
> ---------------------------------------------------------------------------------------------
>
> Key: AMQ-4596
> URL: https://issues.apache.org/jira/browse/AMQ-4596
> Project: ActiveMQ
> Issue Type: Bug
> Reporter: Kevin Earls
> Attachments: AMQ-4596.patch
>
>
> I created a broker using a config file that contained:
> <simpleAuthenticationPlugin>
> <users>
> <authenticationUser username="system" password="systemPassword" groups="users,admins"/>
> <authenticationUser username="user" password="userPassword" groups="users"/>
> <authenticationUser username="guest" password="guestPassword" groups="guests"/>
> </users>
> </simpleAuthenticationPlugin>
> With a normal client, the following code will throw a JMSSecurityException on the connection.start(), or connection.createProducer(), or I assume on anything you do with connection. The same is true if I call createConnection with an unknown user, or a known user and invalid password
> ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
> Connection connection = factory.createConnection();
> connection.start();
> When I use the QPID client though, I don't get the JMSSecurityException. In the logs I can see the exception being thrown by the broker, but it doesn't get propagated back to the client, even if I add an exception listener. The code below will continue along until it hangs on the session.CreateProducer() call.
> ConnectionFactoryImpl factory = new ConnectionFactoryImpl("localhost", port, "admin", "password");
> Connection connection = factory.createConnection();
> connection.setExceptionListener(new ExceptionListener() {
> @Override
> public void onException(JMSException exception) {
> exception.printStackTrace();
> }
> });
> Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
> QueueImpl queue = new QueueImpl("queue://txqueue");
> MessageProducer p = session.createProducer(queue);
> I will attach a unit test that reproduces this.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira