Skip to content
forked from Samsung/Fluff

A tool designed to synthesise semantically correct JavaScript snippets given arbitrary data. Useful for fuzzing.

License

Notifications You must be signed in to change notification settings

MarcinDominiak/Fluff

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fluff

A tool designed to synthesise semantically correct JavaScript snippets given arbitrary data.

Useful for fuzzing.

JS Runtimes supported out-of-the-box

Requirements

  • docker
  • make

Building

  • (optional) Check if you have access to docker (run docker info)
  • (optional) Specify desired version of JS runtime in Makefile.conf
  • Run make (jerryscript | njs | duktape | v8)
  • If everything builds correctly the process will result in:
    • build/fluff_* - binary to fuzz
    • build/fluff_*_dry - binary that will convert Fluff bytecode to JS testcase (stdout)
    • build/grammars
      • js_grammar.yaml - es5.1 grammar file
      • js_grammar_es6.yaml - es6 grammar file

Usage

Typical fuzzing setup:

  • Create input folder and sample testcase, i.e. mkdir in && echo "420" >> in/testcase
  • Start fuzzing using afl-fuzz, for example: afl-fuzz -m none -i in -o out ./fluff_njs @@ js_grammar.yaml
  • (optional) you can use build container to run fuzzing, requires some manual work
docker run -it -d -v path/to/fluff/repository/build:/home/build/fluff /bin/bash
docker exec -it container_number bash
# afl-fuzz is preinstalled in /home/build/afl
  • Enjoy your cup of tea/coffee and wait for crashes

Description

Detailed information about the design of Fluff can be read in the whitepaper.

Contributing

Patches, additions and other contributions are welcome! If you see a feature which you could implement or a bug which you could fix please send us a message or a pull request. If you have found some interesting bug with this tool, please leave us a message/github issue for the future Hall Of Fame.

Contact

If you want to drop us a message, feel free to send a mail to [email protected] or [email protected].

About

A tool designed to synthesise semantically correct JavaScript snippets given arbitrary data. Useful for fuzzing.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 82.0%
  • Python 14.2%
  • Dockerfile 1.5%
  • Shell 1.2%
  • Other 1.1%