OWASP Juice Shop CTF
data:image/s3,"s3://crabby-images/1d4d4/1d4d43b82a4c096d3268982263ac92324277ca86" alt="Twitter Follow"
data:image/s3,"s3://crabby-images/626c3/626c37aadb3fa4dc15130b793c82f6107e64fd39" alt="npm"
The NPM package juice-shop-ctf-cli
published from this repository lets you create a list of INSERT
statements for
the CTFd database that will populate the platform for a Capture the Flag event using
OWASP Juice Shop.
data:image/s3,"s3://crabby-images/d7c73/d7c73b892609a5236b49cd173841166784519728" alt="Example of CLI usage"
Installation
npm i -g juice-shop-ctf-cli
Usage
Open a command line and run:
juice-shop-ctf
Then simply follow the instructions of the command line tool. Finally, apply the generated insert-ctfd-challenges.sql
following the steps described in the next section.
Setting up CTFd and populating its database
-
Setup Docker host and Docker compose.
-
Follow steps 2-4 from the CTFd Docker setup to download the source code, create containers and start them.
-
After running docker-compose up
from previous step, you should be able to browse to your CTFd instance UI (<<docker host IP>>:8000
by default) and create an admin user and CTF name.
-
Once you have done this, run docker-compose down
or use Ctrl-C
to shut down CTFd. Note: Unlike a usual Docker container, data will persist even afterwards.
-
Add the following section to the docker-compose.yml
file and then run docker-compose up
again:
ports:
- "3306:3306"
-
You can then use your favourite MySQL client to connect to the CTFd database (default credentials are root with no password) and run the INSERT
statement you created.
-
When that is done, browse back to your CTFd instance UI and check everything has worked correctly.
-
If everything has worked, do another docker-compose down
, remove the ports section you added to docker-compose.yml
and then do docker-compose up
again and you are ready to go!
Alternative approach without node.js
- Download the
GenerateCTFdInserts.html file.
- Open that file in your local browser and follow the instructions
inside.
Troubleshooting data:image/s3,"s3://crabby-images/a423c/a423cd53df837e0be9a49c60f9928c541afbb64c" alt="Gitter"
If you need help with the application setup please check the
Troubleshooting section below or post your specific problem or
question in the
official Gitter Chat.
- If using Docker Toolbox on Windows make sure that you also enable port
forwarding for all required ports from Host
127.0.0.1:XXXX
to
0.0.0.0:XXXX
for TCP in the default
VM's network adapter in
VirtualBox. For CTFd you need ports 8000
permanantly and 3306
during setup.
Contributing
data:image/s3,"s3://crabby-images/f225f/f225fd62b04c2281f6f96dcca5547eac0b602b26" alt="HuBoard"
Found a bug? Got an idea for enhancement? Improvement for cheating
prevention?
Feel free to
create an issue
or
post your ideas in the chat!
Pull requests are also highly welcome - please refer to
CONTRIBUTING.md for details.
Donations
PayPal data:image/s3,"s3://crabby-images/1b47c/1b47cf9a26e146334f99a2a10df8c504288c58f3" alt="PayPal"
PayPal donations via above button go to the OWASP Foundations and are
earmarked for "Juice Shop". This is the preferred way to support the
project.
Others
data:image/s3,"s3://crabby-images/d1347/d1347aea2bc83ba62c3e586f8e1643d84f916def" alt="Gratipay"
data:image/s3,"s3://crabby-images/9a615/9a61504a22ff08cf25882e12a5d1d96dcea67cb4" alt="Ether"
Contributors
Ordered by date of first contribution.
Auto-generated on Wed, 01 Feb
2017 20:01:35 GMT.
Licensing data:image/s3,"s3://crabby-images/5ce21/5ce21ecc5c7c0f1c6358cbf1bb486c5f4959e9ee" alt="license"
This program is free software: you can redistribute it and/or modify it
under the terms of the MIT license. OWASP Juice Shop and any
contributions are Copyright © by Bjoern Kimminich 2016-2017.
data:image/s3,"s3://crabby-images/3e783/3e7831f0adcd0c0b1331fe65e64bd095eade00c2" alt="Juice Shop Logo"