CTFs as you need them
 
 
 
 
Go to file
Kevin Chung d861b70603 Fixing page previews 2017-12-28 04:09:42 -05:00
.github Issue template (#455) 2017-11-14 16:40:36 -05:00
CTFd Fixing page previews 2017-12-28 04:09:42 -05:00
migrations Adding theme migration (#524) 2017-12-13 16:40:34 -05:00
scripts Add Vagrant with docker support (#285) (#355) 2017-08-20 19:31:32 -04:00
tests Guarantee ctf version (#538) 2017-12-22 16:22:31 -05:00
.dockerignore Adding .dockerignore and making docker-entrypoint consider DATABASE_URL (#312) 2017-07-13 02:43:17 -04:00
.gitignore Add plugin wrappers for plugin related utils functions (#410) 2017-10-14 17:17:06 -04:00
.travis.yml Version 1.1 CTFd (#514) 2017-12-11 06:42:07 -05:00
CHANGELOG.md Guarantee ctf version (#538) 2017-12-22 16:22:31 -05:00
Dockerfile Updating Docker files 2017-04-08 17:35:18 -04:00
LICENSE Update LICENSE 2016-10-14 00:54:42 -04:00
README.md Update README.md 2017-12-12 00:47:14 -05:00
Vagrantfile Switching to Bento Ubuntu for VMWare support (#481) 2017-11-25 05:39:01 -05:00
ctfd.ini Allow CTFd to run with script_root != '/' and PostgreSQL (#125) 2016-06-22 00:18:09 -04:00
development.txt Version 1.1 CTFd (#514) 2017-12-11 06:42:07 -05:00
docker-compose.yml Fixes #315 (#316) 2017-07-16 02:50:32 -04:00
docker-entrypoint.sh Adding .dockerignore and making docker-entrypoint consider DATABASE_URL (#312) 2017-07-13 02:43:17 -04:00
export.py Upgrading exports (#283) 2017-06-16 17:49:37 -04:00
import.py Choose segments with import.py 2017-12-21 23:34:27 -05:00
manage.py Marking 1.0.0 (#196) 2017-01-24 23:06:16 -05:00
populate.py Use strings for key type (#409) 2017-10-14 16:37:41 -04:00
prepare.sh Mark prepare.sh executable 2017-09-27 22:32:01 -04:00
requirements.txt Version 1.1 CTFd (#514) 2017-12-11 06:42:07 -05:00
serve.py Hints (#232) 2017-03-28 21:17:56 -04:00
setup.cfg Starting to write tests 2017-01-07 02:44:31 -05:00
wsgi.py Latest set of changes (#190) 2017-01-10 03:35:48 -05:00

README.md

Build Status CTFd Slack

What is CTFd?

CTFd is a Capture The Flag framework focusing on ease of use and customizability. It comes with everything you need to run a CTF and it's easy to customize with plugins and themes.

CTFd is a CTF in a can.

Features

  • Create your own challenges, categories, hints, and flags from the Admin Interface
    • Static & Regex based flags
    • Users can unlock hints for free or with points
    • File uploads to the server or Amazon S3
    • Limit challenge attempts & hide challenges
    • Automatic submission throttling
  • Scoreboard with automatic tie resolution
    • Hide Scores from the public
    • Freeze Scores at a specific time
    • Dynamic Scoring
  • Scoregraphs comparing the top 10 teams and team progress graphs
  • Markdown content management system
  • SMTP + Mailgun email support
    • Email confirmation support
    • Forgot password support
  • Automatic competition starting and ending
  • Team management & hiding
  • Customize everything using the plugin and theme interfaces
  • Importing and Exporting of CTF data for archival
  • And a lot more...

Install

  1. Run ./prepare.sh to install dependencies using apt.
  2. Modify CTFd/config.py to your liking.
  3. Use python serve.py in a terminal to drop into debug mode.
  4. Here are some deployment options
  5. You can check out the Getting Started guide for a breakdown of some of the features you need to get started.

Live Demo

https://demo.ctfd.io/

Support

To get basic support, you can join the CTFd Slack Community: CTFd Slack

If you prefer commercial support or have a special project, send us an email: support@ctfd.io.

Managed Hosting

Looking to use CTFd but don't want to deal with managing infrastructure? Check out the CTFd website for managed CTFd deployments.

HackerFire

Looking for CTF challenges to work on? HackerFire is a learning focused CTF built using CTFd. It features a wide variety of challenges and is updated with new content frequently. It also contains custom knowledge resources to teach newcomers about the techniques used to solve a challenge.

Credits