Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/WSP-LAB/FUSE
A penetration testing tool for finding file upload bugs (NDSS 2020)
https://github.com/WSP-LAB/FUSE
content-filtering-check file-upload-vulnerability penetration-testing
Last synced: about 2 months ago
JSON representation
A penetration testing tool for finding file upload bugs (NDSS 2020)
- Host: GitHub
- URL: https://github.com/WSP-LAB/FUSE
- Owner: WSP-LAB
- Created: 2020-01-20T05:10:26.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2021-03-30T03:30:25.000Z (almost 4 years ago)
- Last Synced: 2024-08-05T17:44:38.481Z (5 months ago)
- Topics: content-filtering-check, file-upload-vulnerability, penetration-testing
- Language: Python
- Homepage:
- Size: 1.23 MB
- Stars: 250
- Watchers: 13
- Forks: 44
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-hacking-lists - WSP-LAB/FUSE - A penetration testing tool for finding file upload bugs (NDSS 2020) (Python)
README
# FUSE
FUSE is a penetration testing system designed to identify Unrestricted
Executable File Upload (UEFU) vulnerabilities. The details of the testing
strategy is in our
[paper](https://wsp-lab.github.io/papers/lee-fuse-ndss20.pdf),
"FUSE: Finding File Upload Bugs via Penetration Testing", which appeared in
NDSS 2020. To see how to configure and execute FUSE, see the followings.# Setup
## InstallFUSE currently works on Ubuntu 18.04 and Python 2.7.15.
1. Install dependencies
```
# apt-get install rabbitmq-server
# apt-get install python-pip
# apt-get install git
```2. Clone and build FUSE
```
$ git clone https://github.com/WSP-LAB/FUSE
$ cd FUSE && pip install -r requirements.txt
```* If you plan to leverage headless browser verification using selenium, please
install Chrome and Firefox web driver by refering [selenium
document](https://selenium.dev/selenium/docs/api/py/index.html).## Usage
### Configuration* FUSE uses a user-provided [configuration file](configs/default-credential.conf)
that specifies parameters for a target PHP application. The script must be
filled out before testing a target Web application. You can check out
[README](configs/README.md) file and [example configuration files](configs).* Configuration for File Monitor (Optional)
```
$ vim filemonitor.py...
10 MONITOR_PATH='/var/www/html/' <- Web root of the target application
11 MONITOR_PORT=20174 <- Default port of File Monitor
12 EVENT_LIST_LIMITATION=8000 <- Maxium number of elements in EVENT_LIST
...
```### Execution
* FUSE
```
$ python framework.py [Path of configuration file]
```* File Monitor
```
$ python filemonitor.py
```* Result
* When FUSE completes the penetration testing, a [HOST] directory and a [HOST_report.txt] file are created.
* A [HOST] folder stores files that have been attempted to upload.
* A [HOST_report.txt] file contains test results and information related to files that trigger U(E)FU.# CVEs
If you find UFU and UEFU bugs and get CVEs by running FUSE, please send a PR for [README.md](README.md)Application | CVEs
------------| ----
Elgg | CVE-2018-19172
ECCube3 | CVE-2018-18637
CMSMadeSimple | CVE-2018-19419, CVE-2018-18574
CMSimple | CVE-2018-19062
Concrete5 | CVE-2018-19146
GetSimpleCMS | CVE-2018-19420, CVE-2018-19421
Subrion | CVE-2018-19422
OsCommerce2 | CVE-2018-18572, CVE-2018-18964, CVE-2018-18965, CVE-2018-18966
Monstra | CVE-2018-6383, CVE-2018-18694
XE | XEVE-2019-001# Author
This research project has been conducted by [WSP Lab](https://wsp-lab.github.io) at KAIST.* Taekjin Lee
* [Seongil Wi](https://seongil-wi.github.io/)
* [Suyoung Lee](https://leeswimming.com/)
* [Sooel Son](https://sites.google.com/site/ssonkaist/home)# Citing FUSE
To cite our paper:
```
@INPROCEEDINGS{lee:ndss:2020,
author = {Taekjin Lee and Seongil Wi and Suyoung Lee and Sooel Son},
title = {{FUSE}: Finding File Upload Bugs via Penetration Testing},
booktitle = {Proceedings of the Network and Distributed System Security Symposium},
year = 2020
}
```