Challenge 7 – Ratings
Rate them high.Rate them good.
Last updated
Rate them high.Rate them good.
Last updated
Ratings systems are one of the main features of social web apps these days. Sometimes it is a simple like/love button or it can be a full-fledged five-star rating system. A user is supposed to rate an object only once.
Let us visualize the happy path with the help of a sequence diagram:
That is just the happy path for one user rating the post. Let us reimagine the same scenario but with the same user acting at the same time from two browsers.
There is only one condition to be met for a user to rate a show - they shouldn’t have rated the show before. If they have already rated the show, the app will remove the existing rating from the database.
Let us see if the application is performing those checks:
Go to the Admin page
Click on reset database button
Go back to the Admin page
Click on Create default users button
Navigate to the login page
Click on the first user button. This will load the user data for user Tom
Click on the Sign in button
Navigate to rate the program page
Click on the Love button
Note the message on the top that says You have 1 rating(s)
Click on the Love button again
Note the message on the top that says You have 0 rating(s)
We need to find a way to rate the program twice. How can we do that? What if we submit two rating requests in parallel?
Let us slow down TimeGap Theory:
On your browser, navigate to the Settings page
Change the time delay to 5 seconds
Click on the Save button
Now, TimeGap Theory will wait 5 seconds before every database write operation.
Preparation phase
Navigate to the Admin page
Click on the reset database button
Click on the create default users button
Open two browsers side by side (Use private/incognito window if you do not have two browsers)
On both the browsers:
Navigate to the login page
Click on the first user button on top. This will fill the user data for user Tom
Submit the form to log in as Tom
Navigate to the rate the program page
Alright, the preparation is done. Here comes the exploitation phase.
Exploitation phase
Click on the Love button on the first browser
Go to the second browser as soon as you can
Click on the Love button on the second browser
That’s it. Let us see the result:
Post-exploitation phase
Let us wait for both the browsers to complete the request
Note the message on the top that says You have 2 rating(s)
If you check your scores, you will see that you have got 100 points for solving the rate the program challenge
Don't forget to change the delay to 0 on the Settings page.
Automation time
As always, we need a way to automate this.
Pro-tip - you can skip this in real life if the webmaster is your friend and is ready to slow down the server for you.
First, we need a valid fetch request:
Open your browser ( Chrome or Firefox)
Navigate to TimeGap Theory > Webapp > Login
Click on the first user button. This will load the user data for Tom
Click on the Sign in button
Navigate to the rate the program page
Open up dev tools by pressing F12 on the browser
On Windows, you can use Ctrl + Shift + I
On Mac, you can use Cmd + Shift + I
Click on the Love button
On the browser dev tools, click on the Network tab
Right click on the rate-the-program.php request
Click on Copy > Copy as fetch
Paste that on the Console tab of the browser dev tools. You will get something like the following:
Based on how playful your browser is, you may see a slightly long fetch request. Feel free to trim it down to the bare minimum version shown above.
Now we have a request.
And we need two requests.
It can be done by copy-pasting the fetch request without pressing the Enter key. However, it is a good practice to separate each request with a comma. Let us do that
Before running this new command, we need to clear the slate. It involves three simple steps:
Ensure that there is no delay
Go to TimeGap Theory > Settings
Ensure that the delay is set to 0
Reset database and create users
Go to TimeGap Theory > Admin
Click on Reset database button
Go back to TimeGap Theory > Admin
Click on Create default users button
Clear the current score
Go to TimeGap Theory > Score
Click on the Clear button
Alright, our slate is clear. Let us execute the attack now:
Navigate to the Sign In page
Click on the first user button on top. This will fill the user data for user Tom
Click on the Sign In button
Enter the combined fetch request on the Console tab of browser dev tools
Press the Enter key
Refresh the page
You will see that our attack attempt is unsuccessful.
Three things went wrong in here:
TimeGap theory now has a CSRF prevention token in the request. This needs to be valid in order for the requests to be successful.
This page of TimeGap Theory is authenticated. We need to supply the cookie as well in order for this request to be successful
Since an authenticated session is involved, webapp is treating the executing requests one by one when it is from the same session
We need to solve all three problems.
Open your browser and navigate to the Rate the program page
Open browser dev tools
Open the Network tab
Click on the Love button several times
On the dev tools, click on each request to rate-the-program page
See if we can find the nature of the anti-CSRF token
Note that the anti-CSRF token is same across all the requests
Fetch request does not support sending cookies. We need an alternate solution. cURL supports sending cookies. We will use that.
This can be solved by creating two sessions for the same user. How can we do that? We will just sign into the same account from two different browsers. Each session will be having their own anti-CSRF token as well.
First, we need two valid cURL requests.
Let us obtain the first one:
Open your browser ( Chrome or Firefox)
Navigate to TimeGap Theory > Webapp > Login
Click on the first user button. This will load the user data for Tom
Click on the Sign-in button
Navigate to the rate the program page
Open up dev tools by pressing F12 on the browser
On Windows, you can use Ctrl + Shift + I
On Mac, you can use Cmd + Shift + I
Click on the Love button.
On the browser dev tools, click on the Network tab
Right-click on the enter-coupon.php request.
Click on Copy > Copy as cURL
For getting the second one:
Open another browser ( Chrome or Firefox)
Navigate to TimeGap Theory > Webapp > Login
Click on the first user button. This will load the user data for Tom
Click on the Sign-in button
Navigate to the rate the program page
Open up dev tools by pressing F12 on the browser
On Windows, you can use Ctrl + Shift + I
On Mac, you can use Cmd + Shift + I
Click on the Love button.
On the browser dev tools, click on the Network tab
Right click on the enter-coupon.php request.
Click on Copy > Copy as cURL
Now that we have both the requests. Let us run them in parallel:
Open your command prompt/Terminal window
If you are on Windows
Type start /b
Put a space
Enter the first cURL request
Put a space
Enter the ampersand symbol (&)
Put a space again
If you are on Windows
Type start /b
Put a space
Enter the second cURL request
If you are on Windows
Remove the following parameter from both the requests --compress. Some versions of cURL do not support this feature.
Now, press the Enter/Return key.
Let us see if we are successful or not:
Go back to any of your browser window
Refresh the rate the program page
Note the message on the top that says You have 2 rating(s)
Check if you got points for completing the rate the program challenge
What would be the business impact of such an attack? Depending on how the app is designed, there are several possibilities:
Users will be able to bombard the system with infinite number of fake ratings/reviews
If this is an online election system, voters would be able to make multiple votes
Let us review what we did:
The rate the program feature limits the number of times one can rate the program
You analyzed this behavior by trying to rate the program multiple times
First, you slowed down the system and bypassed the business logic
Then you tried bypassing the business logic by using browser dev tools
You learned the difficulties involved in exploiting TOCTOU vulnerabilities when there is an authenticated session
Now you know how TOC/TOU security issues in the real world