Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Building DEF CON CTF with Ruby
Search
vito
February 21, 2014
Programming
0
600
Building DEF CON CTF with Ruby
Presented at Big Ruby Conference, Grapevine, TX, Feb. 20 2014
vito
February 21, 2014
Tweet
Share
More Decks by vito
See All by vito
Modernizing SQL Injection CTF Challenges
vito
0
190
Raw Water: Quenching Your Thirst for SQL Injection
vito
0
85
Lessons Learned from Five Years of Building Capture the Flag
vito
0
500
What I've Learned Writing CTF Challenges
vito
0
160
Capture the Flag: An Owner's Manual
vito
0
100
Other Decks in Programming
See All in Programming
脳の「省エネモード」をデバッグする ~System 1(直感)と System 2(論理)の切り替え~
panda728
PRO
0
130
Implementation Patterns
denyspoltorak
0
140
2年のAppleウォレットパス開発の振り返り
muno92
PRO
0
130
Basic Architectures
denyspoltorak
0
150
perlをWebAssembly上で動かすと何が嬉しいの??? / Where does Perl-on-Wasm actually make sense?
mackee
0
250
[AI Engineering Summit Tokyo 2025] LLMは計画業務のゲームチェンジャーか? 最適化業務における活⽤の可能性と限界
terryu16
1
150
TerraformとStrands AgentsでAmazon Bedrock AgentCoreのSSO認証付きエージェントを量産しよう!
neruneruo
4
2.1k
re:Invent 2025 のイケてるサービスを紹介する
maroon1st
0
160
モデル駆動設計をやってみようワークショップ開催報告(Modeling Forum2025) / model driven design workshop report
haru860
0
290
Python札幌 LT資料
t3tra
7
1.1k
PostgreSQLで手軽にDuckDBを使う!DuckDB&pg_duckdb入門/osc25hi-duckdb
takahashiikki
0
220
[AtCoder Conference 2025] LLMを使った業務AHCの上⼿な解き⽅
terryu16
6
970
Featured
See All Featured
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
300
XXLCSS - How to scale CSS and keep your sanity
sugarenia
249
1.3M
Scaling GitHub
holman
464
140k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.7k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.3k
The Hidden Cost of Media on the Web [PixelPalooza 2025]
tammyeverts
2
130
SEO for Brand Visibility & Recognition
aleyda
0
4.1k
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
150
AI in Enterprises - Java and Open Source to the Rescue
ivargrimstad
0
1.1k
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.1k
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
0
34
Transcript
Building DEF CON CTF with Ruby
Hello Vito Genovese @vito_lbs
[email protected]
Building DEF CON CTF •DEF CON and CTF •Team building
•Qualifications •Finals
What is DEF CON? “DEF CON is one of the
oldest continuous running hacker conventions around, and also one of the largest.” - DEF CON FAQ
What is DEF CON? “Black Hat… is more the university…
DEF CON is the fraternity party.” - USA Today, “Suits and punks convene in Las Vegas for hacker conferences,” Aug. 1 2006
What is DEF CON?
What is DEF CON?
What is CTF? (Capture The Flag)
Jeopardy-Style CTF •Pick a problem •Hack it •Get points
Attack-Defense CTF 1. Hack services 2. Steal tokens every round
3. Get points 1. Patch services 2. Pass SLA checks 3. Don’t lose points
Competing in CTF •Build a team •Get really good at
assembly •Get good at web vulns and crypto too •Compete and solve problems •Write up solutions
Competing in CTF
Sample Challenges http://hypeman.shallweplayaga.me http://worsemedicine.shallweplayaga.me
Hour 30
Building DEF CON CTF •DEF CON and CTF •Team building
•Qualifications •Finals
Team Building “Dark Tangent is looking for new CTF organizers,
want to help write a proposal?”
Team Building Software vulnerability experts Hardware engineers Network ops deity
Web application generalist
Team Building •Opinionated smart people •That need to work together
•On a software project with dozens of moving parts •On a very public stage •With immovable deadlines
Team Building Always have an exit strategy
Building DEF CON CTF •DEF CON and CTF •Team building
•Qualifications •Finals
Qualifications “Quals”
Quals “Jeopardy-style” Self-contained questions Open Entry 48 hours over a
weekend
None
Quals Scoreboard Rails Unicorn Heroku 1GB Dynos $50/month Postgres
Quals Scoreboard No Redis No memcached
Quals Scoreboard No push Only polling
Quals Scoreboard
Quals Scoreboard
Quals Scoreboard Game Start Adjusting dynos
Quals Challenges •Sinatra •PHP •Python •x86 •Golang •ARM
Sinatra Used Heroku It ruled
PHP, Python, x86, Golang EC2 Started with Micro Upgraded to
Large
PHP, Python, x86, Golang Never use Micro instances
PHP, Python, x86, Golang Sometimes you get DoS’d
ARM Challenges
Quals Problems I slept… Through a part where we had
to edit a question and put something on S3.
Quals Problems Some challenges weren’t ready until halfway through the
game
https://twitter.com/roman_soft/status/346325078369263616
Quals •IRC and Twitter: invaluable •Have a reset password flow
•Don’t forget public views •Fight bus numbers
Building DEF CON CTF •DEF CON and CTF •Team building
•Qualifications •Finals
Finals OMG
None
Finals http://www.cnbc.com/id/101179977
Finals
Finals
Finals Twenty Teams Twenty Servers One Network
Finals •Attack-defense style •Teams get a server running services •Find
vulnerabilities in services •Patch own vulnerabilities •Exploit vulnerabilities on other teams
Finals Scoring Fifty-thousand flags Five-minute rounds Tokens from services redeemed
for flags Flags lost when stolen and downtime Zero-sum for game theory reasons
Finals Scoreboard Rails, Apache, Passenger, Postgres Ubuntu on Mac Mini
HTTPS Client Certificates Kibana (Logstash, Elasticsearch) No push, no polling, just meta refresh
Finals Scoreboard Client certs rule No password resets No hacking,
no sniffing Twenty CDs of certs and keys… eh
Kibana
None
None
Kibana Log Everything
Tokens and Uptime Console Ruby script Restartable in a sensible
fashion Use Postgres and wall clock time as state Save immediately, don’t queue
Tokens and Uptime Two weeks prior: “I’m just going to
call a shell script, everyone else write your own uptime checker.”
Tokens and Uptime Three hours in: “Uh, how do we
make these shell scripts time out?”
Tokens and Uptime Ten hours in: “We should run these
in parallel.”
Tokens and Uptime Sixteen hours in: “Huh some team is
puking binary out.”
Finals Problems Teams could score on themselves
Finals Problems Flags didn’t get redistributed correctly
Finals Problems Have a better way to find issues than
rails console, SQL, and log queries
None
Finals Problems API Documentation
Finals Problems Life’s easy when you have 160 users and
they’re all right there
Finals Team Boxes
Finals Team Boxes Services run as dedicated users Teams have
sudo to service No root
None
Finals Lessons Scheduled downtime is the best
Building DEF CON CTF •DEF CON and CTF •Team building
•Qualifications •Finals
Lessons Stuff will break
Lessons Own your mistakes
Lessons Fight scope creep
Lessons JFDI
Thanks Vito Genovese @vito_lbs
[email protected]
https://legitbs.net http://bit.ly/br-ctf
Bonus Slides
DEF CON and Jeopardy
Quals Expenses What How much Heroku $126 AWS $138 Cloudflare
$20 Whisky $340
Finals Services ARM binaries ASLR, NX bit, some PIE
Finals Services Release new services Update existing services
Finals Team Boxes Boot from MicroSD Start container from iSCSI