/competition-fuzzer

Template repository for the Fuzzing Competition

Primary LanguagePythonMIT LicenseMIT

Competition Participant Fuzzer

Template repository for the Fuzzing Competition

Competition Entry Instructions

  1. Fork this template repo (keep it private to avoid integrity disputes)
  2. Give dylanjwolff access to your Github repository
  3. Fill out the Google Form
  4. Make changes to your fuzzer (include all new files/dependencies in the Dockerfile) -- DO NOT change the name of fuzzer.py
  5. Check that the CI job passes for your changes
  6. Cut a tar.gz release on Github to have it included in the next benchmarking run

Competition Leaderboard and Scoring:

https://nus-fuzzing-hackathon-2024.github.io/

CI Job

Please make sure to enable the CI job to check that your fuzzer is working properly:

  1. On the forked repo Github web interface, navigate to: Settings → Actions → General → Workflow Permissions
  2. Select “Read and write permissions”, then click “Save”
  3. Verify CI job is enabled by making a small commit (such as changing the team name in the README.md file)

Dependencies

We are using Python 3.10 in the evaluation environment.

Install all Python package dependencies needed by the Fuzzing Book baseline fuzzer with:

pip install -r requirements.txt

You may want to do this in a Python virtual environment to avoid global dependency conflicts.

Usage

The fuzzer expects a file named bug.py to be in the same directory as the fuzzer file (fuzzer.py). DO NOT RENAME THE FUZZER FILE -- the competition infrastructure will run python fuzzer.py to start your fuzzer.

The bug.py file will have two functions: an entrypoint that is fuzzed by the fuzzer and get_initial_corpus function which returns a list of initial inputs for the fuzzer. Several example bugs are included in the examples directory.

To run the fuzzer on an example bug, copy e.g. examples/1/bug.py to the base directory of this repository before running the fuzzer with the command above. I.e.:

cp examples/1/bug.py .
python fuzzer.py

Whether or not the bug has been triggered will be detected by the competition infrastructure; no need to implement a special exception handler or detection mechanism yourself. In these examples, finding the bug is indicated by the fuzzer exiting with a particular exit code (219). The detection method will be different in the competition, so don't search the program for a particular exit code etc. to find the bug location.

Implementation Ideas

Below are some sample ideas for fuzzer implementations (not exhaustive!). Entries marked with a '†' are options we believe will be more straightforward to implement.

Coverage Feedback

Mutation Strategy

Comparison Instrumentation and Branch Distance

Gradient Descent Fuzzing

Taint Analysis or Dataflow Guided Fuzzing

Inference-Based:

Propagation-Based:

The Fuzzing Book gives an intro and some scaffolding code for dataflow analysis, but we are not interested in command injection specifically for the competition micro-benchmarks. You would instead need to find a way to leverage dataflow analysis to cover additional conditional branches within the benchmark programs.

Concolic Execution (White Box Fuzzing / Dynamic Symbolic Execution)

Improve the Fuzzing Book white box fuzzer!

Hybrid Fuzzing

Combine the fuzzing book implementations of Concolic and Greybox fuzzers!