-
Notifications
You must be signed in to change notification settings - Fork 104
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
cba695c
commit 6689481
Showing
10 changed files
with
46 additions
and
14 deletions.
There are no files selected for viewing
60 changes: 46 additions & 14 deletions
60
07_access_control/Unprotected_admin_functionality/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,31 +1,63 @@ | ||
# Lab: Unprotected admin functionality | ||
# Write-up: Unprotected admin functionality @ PortSwigger Academy | ||
|
||
data:image/s3,"s3://crabby-images/f30b2/f30b298ef69320f6f75eec8d31ab865da8fca63b" alt="logo" | ||
|
||
This write-up for the lab *Unprotected admin functionality* is part of my walkthrough series for [PortSwigger's Web Security Academy](https://portswigger.net/web-security). | ||
|
||
**Learning path**: Server-side topics → Access control vulnerabilities | ||
|
||
Lab-Link: <https://portswigger.net/web-security/access-control/lab-unprotected-admin-functionality> | ||
Difficulty: APPRENTICE | ||
Python script: [script.py](script.py) | ||
|
||
## Known information | ||
## Lab description | ||
|
||
- Lab has unprotected admin panel | ||
- Goals: | ||
- Delete user `carlos` | ||
data:image/s3,"s3://crabby-images/2e769/2e769d04d356eb48856b9784ae2c4d70a669be4d" alt="Lab description" | ||
|
||
## Steps | ||
|
||
### Analysis | ||
The first step is to get an overview of the web application which is a shop website. | ||
|
||
One of the first things to do during website enumeration is to check for the existence of a robots.txt file. It is a file that requests search engine crawlers to either include or exclude certain parts of the site from their index. Sometimes, interesting locations are revealed that way. | ||
|
||
It is up to the crawler whether they obey these wishes or ignore them. As the file is plain text, the same applies to any human reading it. | ||
|
||
There are a ton of ways to detect the existence and content of this file. | ||
|
||
--- | ||
|
||
### Manual browsing | ||
|
||
I can just attempt to load the file in the browser to see if it exists and its content: | ||
|
||
data:image/s3,"s3://crabby-images/e5b45/e5b45f241d14deac0fd21339b0fba9c518a1e416" alt="" | ||
|
||
This can be done from the command line as quickly, for example with curl: | ||
|
||
data:image/s3,"s3://crabby-images/353ad/353ad9aa8f6ad2e31bf0bd6f0452d55b47103de4" alt="" | ||
|
||
--- | ||
|
||
### Using tools | ||
|
||
In any reasonable wordlist file, the `robots.txt` file is included as well. Regardless of the workflow used, any attacker will see this file in an instant like in this example using [gobuster](https://github.com/OJ/gobuster) together with a wordlist from [SecLists](https://github.com/danielmiessler/SecLists): | ||
|
||
data:image/s3,"s3://crabby-images/8fc3a/8fc3a69e685c68407bfef34f9f663f3addce8a3e" alt="" | ||
|
||
A lot of tools do it automatically. [Nikto](https://github.com/sullo/nikto), for example, is even kind enough to check whether the files or directories mentioned in the `robots.txt` file exist and reports the result directly in its output: | ||
|
||
The first step is as usual to get an overview of the web application, which is again the shop website. One of the first things to do during website enumeration is checking for robots.txt. A lot of tools do it automatically, for example Burp or nikto. | ||
data:image/s3,"s3://crabby-images/228f6/228f629752a97c9d4bc08582789549a286e46852" alt="" | ||
|
||
data:image/s3,"s3://crabby-images/2063f/2063f41233d4a9d68d4e143cfba2a183e6121815" alt="Burp_robots_txt" | ||
--- | ||
|
||
With `curl https://acc51fe31f729b7cc0845d600054005a.web-security-academy.net/robots.txt` it can be done quickly from the command line as well. | ||
### Doing the harm | ||
|
||
In any wordlist file the robots.txt is included as well, so regardless of the workflow used, any attacker will see this file in an instant (and I just noticed Ubuntu 20.04 has an ancient version of gobuster): | ||
This file must not be used to 'protect' any files or directories. A 'disallow' is just a friendly request that spiders do not index these things. Whether to obey this request is up to the spider. Google & Co will, others less so. And anybody checking the file knows what is disallowed. | ||
|
||
data:image/s3,"s3://crabby-images/8fc3a/8fc3a69e685c68407bfef34f9f663f3addce8a3e" alt="gobuster" | ||
Solving the lab is as easy as visiting `https://0a8f00f704cb9ca9c08906980091002a.web-security-academy.net/administrator-panel` and clicking on `Delete` for user `carlos`: | ||
|
||
It is common knowledge that this file must not be used to 'protect' any files or directories. A 'disallow' is just a friendly request that spiders do not index these things. Whether to obey this request is up to the spider. Google & Co will, others less so. And anybody checking the file knows what is disallowed. | ||
data:image/s3,"s3://crabby-images/82f66/82f66c5e8af7b1072b9c5c885cff9987b228741e" alt="" | ||
|
||
Thus solving the lab is as easy as visiting `https://acc51fe31f729b7cc0845d600054005a.web-security-academy.net/administrator-panel` and clicking on `Delete` for user `carlos`: | ||
At the same time, the lab updates to | ||
|
||
data:image/s3,"s3://crabby-images/ec6f5/ec6f5e4b834a7be9c60e7b4a1ff2d414ec0a3041" alt="success" | ||
data:image/s3,"s3://crabby-images/ec6f5/ec6f5e4b834a7be9c60e7b4a1ff2d414ec0a3041" alt="Lab solved" |
Binary file removed
BIN
-41.5 KB
07_access_control/Unprotected_admin_functionality/img/Burp_robots_txt.png
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
+0 Bytes
(100%)
07_access_control/Unprotected_admin_functionality/img/gobuster.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+3.45 KB
07_access_control/Unprotected_admin_functionality/img/lab_description.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
+8.35 KB
(160%)
07_access_control/Unprotected_admin_functionality/img/success.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.