0xma Cyber Security Articles




June 24, 2022

Mass Assignment Vulnerability

In this tutorial, we will see how to perform a mass assignment vulnerability attack. The API on the website takes JSON input. We can change settings like email address, profile, etc. But the API also allows us to change our privilege level.

Let's start by creating an account on the web application API.

Signing up in the web application API using JSON.

Now that we have created an account, we can login and get an access token.

Log in to the web application API to get an access token.

The documentation for the API is in "http://10.129.106.137/docs/". I try to access that page and capture the request in Burp Intercept.

Visiting the documentation page for the API.

Since the documentation page requires us to be authenticated, it is important to add the "Authorization" header with the access token that we got from the API.

Adding the 'Authorization' header to the request.

It is important to add this header to all the subsequent requests that are sent to the API.

Adding the 'Authorization' header to the request.

Adding the 'Authorization' header to the request.

This shows the API's documentation page. From here we can view and change user settings.

API documentation page that allows us to view and change user settings.

Trying to access the user's settings displays this page. It has the following fields: guid, email, profile, last_update, time_created, is_superuser and id.

User settings.

The user section allows us to fetch user data, edit the user's profile, edit the user's password, login and signup.

Options available for the user in the API documentation.

Since the user profile was empty, let's try to add something to it.

Adding a user profile.

We can see that the profile is updated.

Profile update in the API documentation.

Let's see if we can update the email address as well.

Updating the email address in the profile.

The email address has been updated.

Profile update in the API documentation.

The next step is to see if we can update the user's privileges.

Updating the 'is_superuser' setting to elevate the user's privilege.

We can see that the 'is_superuser' setting is set to true. We have successfully been able to elevate our privileges.

Profile update in the API documentation.

If you liked reading this article, you can follow me on Twitter: 0xmaCyberSec.