PortSwigger's "Inconsistent security controls" Walkthrough
This is a writeup for the “inconsistent security controls” lab from PortSwigger Academy. For this walkthrough, you’ll need a Portswigger Academy account.
Log in to your Academy account and then view the lab at https://portswigger.net/web-security/logic-flaws/examples/lab-logic-flaws-inconsistent-security-controls
. This is accessible from the “all labs” view or from the Business Logic Flaws page.
Challenge Information
data:image/s3,"s3://crabby-images/3f6c1/3f6c14e4a652f61bb882ad2d8d5ff55beae91759" alt=""
Click the “Access the Lab” button and you will be taken to a temporary website that is created for your account. This will be in format https://<random string here>.web-security-academy.net/
.
Our goal for this lab is to find the admin interface and delete Carlos’ account.
If we open up the website and guess that the admin interface is at /admin
, we see this message:
data:image/s3,"s3://crabby-images/7400c/7400c87cbeecfbfffee7a46d762aefcebcdc736d" alt=""
We aren’t given a set of credentials for this lab, so we’ll need to register a new account:
data:image/s3,"s3://crabby-images/c6b15/c6b1559ba5119133928cd491ed2e8b98a6b0cd97" alt=""
We could try a @dontwannacry.com
account here, but we can’t login with it. That’s because there’s a confirmation email.
We have an assigned email client where we can receive these emails (follow the Email Client
link in the Academy header):
data:image/s3,"s3://crabby-images/f57a9/f57a91718f2095b42d582f04de7b9f799b93ab68" alt=""
If we want to receive an email, we’ll have to do so with our assigned email address:
data:image/s3,"s3://crabby-images/fdfda/fdfda3a1834d66a102d7ba41d77b90c0a9616736" alt=""
Lab Solution
After registering, login with the credentials you provided (admin
/peter
in this case). Having a username of admin
does not help us, but once we login, we’re able to change our email:
data:image/s3,"s3://crabby-images/707b0/707b020c2aec5f92032aee55816911d051cb38fa" alt=""
Change it to <username>@dontwannacry.com
, and you should see an admin link appear:
data:image/s3,"s3://crabby-images/10f2f/10f2fe1377957623caad546b0c431549090a16c3" alt=""
Click this to go to the admin portal at /admin
:
data:image/s3,"s3://crabby-images/84e6a/84e6a005d0ed06493683a50585605d332f85617b" alt=""
Then delete the user to complete the lab!
data:image/s3,"s3://crabby-images/47e09/47e096b075e3cfff1ffc542ca0279de40c7a525b" alt=""
The reason this lab was called “inconsistent security controls” is because there’s a confirmation required for changing the email at registration, but not later on. This effectively makes the first confirmation requirement pointless.