Apache ActiveMQ is a popular message broker that
has several security features to help secure its deployment. User or client authentication
typically a very important security requirement for enterprise applications and
ActiveMQ offers two plugin based authentication mechanisms that need to be
explicitly enabled and sometimes even coded based on your requirements.
ActiveMQ's Simple Authentication Plugin
In this blog post we will discuss ActiveMQ’s simple
authentication plugin and analyze it from security perspective. ActiveMQ’s
simple authentication plugin can be enabled by adding the simpleAuthenticationPlugin
element to the broker configuration with the required user credentials as show
in the image below.
Image shows ActiveMQ's simpleAuthenticationPlugin |
The above configuration has two users, admin and general, assigned to two different groups, admins and general respectively.
Now that we have seen the sample simpleAuthenticationPlugin configuration, following are the important security considerations of using this plugin.
- It stores usernames and passwords in clear in the configuration files. Access to configuration file can therefore reveal user credentials to unauthorized users. For example, a backup administrator may not be the right person to know broker credentials. However, he will be able to view those if simpleAuthenticationPlugin is used in this fashion.
- It does not offer any protection against password bruteforce attacks. That is, there is no provision to enforce account lockout on multiple failed login attempts. This can be devastating if someone is able to bruteforce your admin password and then read all messages passing through the broker and even administer the broker.
Out of the two points discussed above, ActiveMQ tries to address item 1 by providing a capability that can be used to encrypt broker passwords using the password based encryption scheme before storing the passwords inside the configuration files. The password encryption scheme is based off the open source jasypt library’s StandardPBEStringEncryptor class. The image below shows the encrypted passwords for two ActiveMQ users.
ActiveMQ's encrypted passwords Decrypting ActiveMQ Passwords Since the passwords are encrypted and not hashed, it is possible to obtain the correct password if the encryption string is available or if it can be bruteforced. So I wrote a Java Class (code below) to subject the encrypted strings to a bruteforce attack from a wordlist which also contained the correct password. It took 240 seconds for 1,000,000 (1 million) decryption attempts at the rate of 4,166 unique passwords per second on a single thread and a single core. Impressive, isn’t it?
|
Conclusion
To summarize, if you are using ActiveMQ broker for business critical processes, you may want to use the simpleAuthenticationPlugin only for PoC or initial testing as it may not offer the level of security your environment needs. Consider implementing custom JAAS (Java Authentication and Authorization Service) authentication plugin for better security.
We will also have a blog post on writing JAAS based authentication plugin for ActiveMQ in near future. Stay tuned!
To summarize, if you are using ActiveMQ broker for business critical processes, you may want to use the simpleAuthenticationPlugin only for PoC or initial testing as it may not offer the level of security your environment needs. Consider implementing custom JAAS (Java Authentication and Authorization Service) authentication plugin for better security.
We will also have a blog post on writing JAAS based authentication plugin for ActiveMQ in near future. Stay tuned!
1 comment:
I am a Single full time dad on disability getting no help from their moms. It a struggle every day. My boys are 15 and 9 been doing this by myself for 8 years now it’s completely drained all my savings everything . These guys are the present day ROBIN HOOD. Im back on my feet again and my kids can have a better life all thanks to the blank card i acquired from skylink technology. Now i can withdraw up too 3000 per day Contact them as well on Mail: skylinktechnes@yahoo.com or whatsspp/telegram: +1(213)785-1553
Post a Comment