Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Aif4thah/VulnerableLightApp
Vulnerable API for educational purposes
https://github.com/Aif4thah/VulnerableLightApp
api cybersecurity-education cybersecurity-training dotnet educational-project hacking hacking-challenge hacking-competitions owasp-top-10 pentest vulnerabilities vulnerability vulnerable vulnerable-api vulnerable-application vulnerable-applications vulnerable-server vulnerable-web-app vulnerable-web-application web-api
Last synced: 2 months ago
JSON representation
Vulnerable API for educational purposes
- Host: GitHub
- URL: https://github.com/Aif4thah/VulnerableLightApp
- Owner: Aif4thah
- License: gpl-3.0
- Created: 2023-12-19T11:24:00.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-08T06:50:08.000Z (2 months ago)
- Last Synced: 2024-11-08T07:30:55.236Z (2 months ago)
- Topics: api, cybersecurity-education, cybersecurity-training, dotnet, educational-project, hacking, hacking-challenge, hacking-competitions, owasp-top-10, pentest, vulnerabilities, vulnerability, vulnerable, vulnerable-api, vulnerable-application, vulnerable-applications, vulnerable-server, vulnerable-web-app, vulnerable-web-application, web-api
- Language: C#
- Homepage: https://taisen.fr/#Formation
- Size: 17.4 MB
- Stars: 28
- Watchers: 2
- Forks: 32
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-vulnerable-apps - VulnerableLightApp - .NET vulnerable REST API (Uncategorized / Firmware)
README
[![License: GNU GPL v3](https://img.shields.io/badge/License-GPLv3-blue.svg)](https://www.gnu.org/licenses/gpl-3.0)
![GitHub last commit](https://img.shields.io/github/last-commit/Aif4thah/VulnerableLightApp)
[![.NET](https://github.com/Aif4thah/VulnerableLightApp/actions/workflows/dotnet.yml/badge.svg)](https://github.com/Aif4thah/VulnerableLightApp/actions/workflows/dotnet.yml)
[![Docker](https://github.com/Aif4thah/VulnerableLightApp/actions/workflows/docker.yml/badge.svg)](https://github.com/Aif4thah/VulnerableLightApp/actions/workflows/docker.yml)> β οΈ **Disclaimer** : This repository, together with its tools, is provided by Taisen-Solutions on an "as is" basis. Be aware that this application is highly vulnerable, including remote command and code execution. Use it at your own risk. Taisen-Solutions makes no representations or warranties of any kind, express or implied, as to the operation of the information, content, materials, tools, services and/or products included on the repository. Taisen-Solution disclaims, to the full extent permissible by applicable law, all warranties, express or implied, including but not limited to, implied warranties of merchantability and fitness for a particular purpose.
## π± Use Case
![UseCase](./VLAusecase.drawio.png)
## π Vulnerabilities
| MITRE Reference | Description | Difficulty |
|----|---|----|
| CWE-22 | Path Traversal | Medium |
| CWE-78 | OS Command Injection | Easy |
| CWE-79 | Cross-site Scripting | Easy |
| CWE-89 | SQL Injection | Easy |
| CWE-94 | Code Injection| Hard |
| CWE-91 | XML Injection | Hard |
| CWE-98 | Remote File Inclusion | Hard |
| CWE-184 | Incomplete List of Disallowed Inputs | Medium |
| CWE-200 | Exposure of Sensitive Information to an Unauthorized Actor | Medium |
| CWE-213 | Exposure of Sensitive Information Due to Incompatible Policies | Easy |
| CWE-284 | Improper Access Control | Medium |
| CWE-287 | Improper Authentication | Medium |
| CWE-319 | Cleartext Transmission of Sensitive Information | Easy |
| CWE-326 | Inadequate Encryption Strength | Easy |
| CWE-434 | Unrestricted Upload of File with Dangerous Type | Hard |
| CWE-502 | Deserialization of Untrusted Data | Hard |
| CWE-521 | Weak Password Requirements | Easy |
| CWE-532 | Insertion of Sensitive Information into Log File | Easy |
| CWE 639 | Insecure Direct Object Reference | Medium |
| CWE-611 | XML External Entity Reference | Hard |
| CWE-787 | Out-of-bounds Write | Easy |
| CWE-798 | Use of Hard-coded Credentials | Easy |
| CWE-829 | Local File Inclusion | Easy |
| CWE-912 | Backdoor | Hard |
| CWE-918 | Server-Side Request Forgery | Medium |
| CWE-1270 | Generation of Incorrect Security Tokens | Medium |## π Context
VLA is designed as a vulnerable backend application, running in the following environment :
![Context](./Context.png)
## π Hint & Write Up
* Try reading [Dojo-101](https://github.com/Aif4thah/Dojo-101), this project contains all you need to hack this app.
* [Become a sponsor](https://github.com/sponsors/Aif4thah?frequency=recurring&sponsor=Aif4thah) and get access to the **full methodology** and **complete write-up**.## β Prerequisites
Check `.csproj` file to get the current dotnet version and install [.NET SDK](https://dotnet.microsoft.com/en-us/download)
## β¬οΈ Download
```PowerShell
git clone https://github.com/Aif4thah/VulnerableLightApp.git
cd .\VulnerableLightApp\
```## π§π₯ Build and Run
You can use **Dotnet** or **Docker**
### Dotnet
```PowerShell
dotnet run [--url=]
```Alternatively, you can use bin files :
```PowerShell
dotnet build
.\bin\Debug\net8.0\VulnerableWebApplication.exe [--url=]
```### Docker
```bash
docker build -t vulnerablelightapp .
docker run -p 3000:3000 vulnerablelightapp
```### first request
Default : `127.0.0.1:3000`
```sh
curl -k https://127.0.0.1:3000
```## π οΈ Debug
### 401 Unauthorized
Your first request may return a 401 code due to unsuccessful authentication. It's ok, Start Hacking !
### Dotnet Framework
Verify you use the intended .NET Framework
```cmd
where dotnet
dotnet --version
dotnet --list-sdks
```### Dotnet on Linux
Ubuntu / Debian exemple
```bash
wget https://packages.microsoft.com/config/debian/12/packages-microsoft-prod.deb -O packages-microsoft-prod.deb
dpkg -i packages-microsoft-prod.deb
apt update && apt install -y dotnet-sdk-8.0 dotnet-runtime-8.0
```### Certificates
To trust the certificate
```PowerShell
dotnet dev-certs https --trust
```### Dependancies
dependancies have to be dowloaded from [standard sources](https://go.microsoft.com/fwlink/?linkid=848054)
```sh
dotnet nuget add source "https://api.nuget.org/v3/index.json" --name "Microsoft"
```### Misc
* Be aware that VLA runs Linux and MacOS, but is only tested and supported on Windows.
## π CrΓ©dits
* **Special thanks to all the hackers and students who pushed me to improve this work**
* Project maintened by [Michael Vacarella](https://github.com/Aif4thah)