oliverklee / insecurity
Web application that consists of a plethora of security vulnerabilities held together by some functionality
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 5
Open Issues: 21
Type:project
Requires
- php: >= 7.2
- ext-json: *
- ext-mysqli: *
Requires (Dev)
- phpunit/phpunit: ^8.5.4
- squizlabs/php_codesniffer: ^3.5.5
This package is auto-updated.
Last update: 2024-12-29 05:44:18 UTC
README
What is this all about?
This project is a web application that consists of a plethora of security vulnerabilities held together by some functionality.
This project has been created as an educational resource for workshops on PHP web security. You could use in several ways:
- show the attendees the vulnerabilities and how to fix them
- have the attendees search for vulnerabilities
- have the attendees fix the vulnerabilities
Warning
Never, ever put this project on any web server that is accessible from the internet. Your server will get hacked.
How to use this project for learning
For learning as much as possible (e.g., at a workshop on web application security), I propose you do the exercises in the following order:
-
Install the application and try to find as many vulnerabilities as possible without reading the code and without using any automatic vulnerability scanning tools. Just use the application front end (without logging in, then with the
user
login and with theadmin
login). Use browser plugins that help you manipulate the requests and read the web site source. -
Try to find more vulnerabilities by reading the code.
-
Try to find more vulnerabilities by using automated vulnerability scanners.
-
Compare the list of vulnerabilities you have found in the previous two steps with the list available in the
solutions
branch. -
Fix the vulnerabilities.
Installation
- Install Vagrant and run
vagrant up
. vagrant ssh
cd /var/www/
composer install
- Log out from the virtual box.
- You now can access your insecure site at http://192.168.33.10/.
- You can log in as either
admin@example.com / 12345678
or asuser@example.com / asdfqwer
.
Resetting the database
The database and its contents are automatically created when you run
vagrant up
.
If you ever need to rebuild the database from scratch, follow this list of steps:
vagrant ssh
sh /var/www/db/setup-database.sh
- Log out from the virtual box.
List of vulnerabilities
There is a list of vulnerabilities in the file
Vulnerabilities.md
in the branch solutions
(to keep
you from seeing the solutions by accident before you have had the chance to
find the vulnerabilities yourself).
About me (Oliver Klee)
I am a former member of the TYPO3 Security Team and the maintainer of the PHPUnit TYPO3 extension, which is available in the TYPO3 extension repository (TER).
You can book me for workshops at your company.
I also frequently give workshops at the TYPO3 Developer Days.
Contributing
Contributions in the form of bug fixes, more vulnerabilities or clean-up in the form of pull requests is always more than welcome.
Please do not report any security vulnerabilities, and please do not submit pull requests with security fixes - you're missing the point.
License
The application is licensed under the Gnu Public License (GPL) V3.
The included Twitter Bootstrap and jQuery are licensed under the MIT License (MIT).