completely ridiculous API (crAPI) will help you to understand the ten most critical API security risks. crAPI is vulnerable by design, but you'll be able to safely run it to educate/train yourself.
crAPI is modern, built on top of a microservices architecture. When time has come to buy your first car, sign up for an account and start your journey. To know more about crAPI, please check crAPI's overview.
You'll need to have Docker and docker compose installed and running on your host system. Also, the version of docker compose should be 1.27.0 or above. Check your docker compose version using:
docker compose version
Upgrade your docker compose version if you get errors like
ERROR: Invalid interpolation format for ...
You can use prebuilt images generated by our CI workflow by downloading the docker compose and .env files.
- 
To use the latest stable version. - Linux Machine
 curl -o /tmp/crapi.zip https://github.com/OWASP/crAPI/archive/refs/heads/main.zip unzip /tmp/crapi.zip cd crAPI-main/deploy/docker docker compose pull docker compose -f docker-compose.yml --compatibility up -dTo override server configurations, change the values of the variables present in the .env file or add the respective variables to the start of the docker compose command. For example to expose the system to all network interfaces. LISTEN_IP="0.0.0.0" docker compose -f docker-compose.yml --compatibility up -d- Windows Machine
 curl.exe -o crapi.zip https://github.com/OWASP/crAPI/archive/refs/heads/main.zip tar -xf .\crapi.zip cd crAPI-main/deploy/docker docker compose pull docker compose -f docker-compose.yml --compatibility up -dTo override server configurations, change the values of the variables present in the .env file or add the respective variables to the start of the docker compose command. For example to expose the system to all network interfaces. LISTEN_IP="0.0.0.0" docker compose -f docker-compose.yml --compatibility up -d
- 
To use the latest development version - Linux Machine
 curl -o /tmp/crapi.zip https://github.com/OWASP/crAPI/archive/refs/heads/develop.zip unzip /tmp/crapi.zip cd crAPI-develop/deploy/docker docker compose pull docker compose -f docker-compose.yml --compatibility up -dTo override server configurations, change the values of the variables present in the .env file or add the respective variables to the start of the docker compose command. For example to expose the system to all network interfaces. LISTEN_IP="0.0.0.0" docker compose -f docker-compose.yml --compatibility up -d- Windows Machine
 curl.exe -o crapi.zip https://github.com/OWASP/crAPI/archive/refs/heads/develop.zip tar -xf .\crapi.zip cd crAPI-develop/deploy/docker docker compose pull docker compose -f docker-compose.yml --compatibility up -dTo override server configurations, change the values of the variables present in the .env file or add the respective variables to the start of the docker compose command. For example to expose the system to all network interfaces. LISTEN_IP="0.0.0.0" docker compose -f docker-compose.yml --compatibility up -d
Visit http://localhost:8888
Note: All emails are sent to mailhog service by default and can be checked on http://localhost:8025 You can change the smtp configuration if required however all emails with domain example.com will still go to mailhog.
This option allows you to run crAPI within a virtual machine, thus isolated from your system. You'll need to have Vagrant and, for example VirtualBox installed.
- Clone crAPI repository
$ git clone [REPOSITORY-URL]
- Start crAPI Virtual Machine
$ cd deploy/vagrant && vagrant up
- Visit http://192.168.33.20
Note: All emails are sent to mailhog service and can be checked on http://192.168.33.20:8025
Once you're done playing with crAPI, you can remove it completely from your system running the following command from the repository root directory
$ cd deploy/vagrant && vagrant destroy
For more deployment options visit the setup instructions for more details.
To know more about challenges in crAPI. Visit challenges
If you need any help with installing and running crAPI you can check out this guide: Troubleshooting guide crAPI. If this doesn't solve your problem, please create an issue in Github Issues.