Mass assignment
General index of the course
- Setting up the environment
- Api Reconnaissance.
- Endpoint Analysis.
- Scanning APIS.
- API Authorization Attacks.
- Exploiting API Authorization.
- Testing for Improper Assets Management.
- Mass Assignment.
- Server side Request Forgery.
- Injection Attacks.
- Evasion and Combining techniques.
- Setting up the labs + Writeups
What is mass asset management?
Basically UserA is said in the frontend to have the ability to post/update an object and we use that request to post/update a different object. We are sending a request that updates or overwrites server-side variables.
Example:
In a login process you are said to be able to send these parameters:
But you send this:
And now, your new created user will have a credit of 10,000 units.
Other other key-values that you could include in the JSON POST body could be:
Key thing is this vulnerability is to identify vectors and entrypoints.
Methodology
Identify endpoints that accept user input in your collection and that have the potential to modify objects. In the crAPI application this was about taking a BFLA to the next level:
- Changing the request "GET /workshop/api/shop/products" (which displays existing products) to a "POST /workshop/api/shop/products", the app responded with a 400 Bad request code, and provided information with suggested fields for a POST request. Basically this post request is a way to submit requests to alter or create store products. So, we can create our own product items.
- Now we can create a product with a value in negative. Adquiring that item will give you credit!
Finding Mass assignment targets
To discover and exploit mass assignment vulnerabilities search for API requests that accept and process client input:
1. Account registration
1 2 |
|
2. Unauthorized access to organizations: If your user's objects belong to an organization with access to sensitive data, attempt to gain access to that organization.
3. Resetting passwords, updating accounts, profiles or organizational objects: Do not limit yourself to the account registration process.
Tools
BurpSuite Intruder + Param Miner Arjun
Using Param Miner extension
1. Spotting sections focused on privileged actions. Some headers like:
1 2 |
|
A nice way to do this is with Burp Extension: Param Miner.
Param Miner can be downloaded from BApp Store in BurpSuite. To run it, right-click on a request (for instance, a request in Repeater and select Extensions>Param Miner>Guess params>Gues JSON parameter).
Now, go to Extender tab> Extensions. And in the box below, select Output, and later "Show in UI":
After a while you will see results from the attack.
With Param Miner you can: fuzz unknown variables.
Arjun
Arjun is a great tool for finding query parameters in URL endpoints.
Advantages: - Supports GET/POST/POST-JSON/POST-XML requests. - It deals with rate-limits and timeouts.
Awesome wiki about arjun usage: https://github.com/s0md3v/Arjun/wiki/Usage.
Last update: 2023-02-09 Created: January 2, 2023 13:20:11