How I found my first AEM related bug.
Hello all the amazing hackers and cyber security enthusiasts. My name is Vedant(Also known as Vegeta on Twitterš) and Iām an aspiring bug bounty hunter and a cyber security enthusiast. Today I want to share with you a story about how I found my first AEM related bug :) First of all I want to tell you that Iām still learning about AEM and I found this issue just by applying whatever Iāve learnt so far. So without any further ado, letās get started.
data:image/s3,"s3://crabby-images/c23bd/c23bda2ef278543e4edf5784115e8a5f10a0e227" alt=""
Background:-
So before understanding the actual bug, youāve to learn about few things. First, what is AEM? āAdobe Experience Manager (AEM), is a comprehensive content management solution for building websites, mobile apps and forms. And it makes it easy to manage your marketing content and assets.ā Basically AEM is a CMS just like Wordpress and Drupal.
Moving on next is Querybuilder servlet, āAEM Query Builder is a framework developed by adobe to build queries (JCR XPath underneath) for a query engine (OAK Query Engine) which are simple to compose. A query can be described as simple set of predicates in key value form.ā you can learn more about it here.
And last but not least, Dispatcher. āDispatcher is Adobe Experience Managerās caching and/or load balancing tool. Using AEMās Dispatcher also helps to protect AEM server from attackā you can think of AEM dispatcher like a WAF.
The vulnerability:-
So in July I got lotās of duplicates and informative bugs on Hackerone platform and I was a little frustrated because of that. Whenever I feel demotivated while hunting for bugs I remember this quote, āIf your life just got harder, youāve just leveled upā I decided to learn about some new bug types and after searching for a while I found this awesome talk from Mikhail Egorov where he talked about AEM related bugs. This was completely new for me so I decided to explore more and read all the write-ups I could find about AEM related vulnerabilities. I got a basic idea about some things and decided to apply what I learned so far. So I selected one program to hack on. I already had gathered subdomains and tried to find vulnerabilities in them multiple times but couldnāt find any, but this time it was different.
I checked every subdomain and using wappalyzer I was checking for a subdomain which was using AEM and after a while I came across a subdomain which was built using AEM. Then I started fuzzing for finding querybuilder servlet and by exploiting it an attacker could read internal path. I was fuzzing manually because itās very fun trying to bypass the dispatcher š. I tried the following payload and the site was always responding with a 404 error but I kept trying some payloads to bypass the dispatcher.
data:image/s3,"s3://crabby-images/f5226/f522601f55cba41107829f019b2e1d7afc1f96ed" alt=""
As you can see in above image we can use things like /a.css , /a.png etc to confuse the dispatcher to give us the access to querybuilder servlet. So after trying out similar payloads like this, one worked successfully! The final payload looked something like this,
Payload:-
ā /bin/querybuilder.json.;%0aa.css?path=/etc&p.hits=full&p.limit=-1ā
I could read the contents of directories like /etc, /home, /content etc. You can find such bugs using automation also, there are many nuclei templates for AEM related bugs, you can check them out here. I quickly reported this issue and after 2 days the issue was triaged! and after a week I was awarded with a $$ bounty for it :)
data:image/s3,"s3://crabby-images/11436/11436ca6e8ba2313ae989a34ffbcc0b2a92fa4a1" alt=""
There are a lot more interesting AEM related vulnerabilities out there and AEM is really a vast topic but very fun to explore. I hope you learned something new reading this write-up and if you have any questions about it you can reach out to me here . If you enjoyed reading the write-up please do clap and share it with your friends. Thank you!