Skip to main content

PASTIS framework for collaborative fuzzing

Project description

The PASTIS project is a fuzzing framework aiming at combining various software testing techniques

within the same workflow to perform collaborative fuzzing also called ensemble fuzzing.

At the moment it supports the following fuzzing engines:

Quick start

Installation

The PASTIS framework can be installed with:

pip install pastis-framework

The pip package will install all dependencies and the tritondse

engine.

AFL++

To install AFL++ please refer to the official documentation.

Honggfuzz (>= v2.6)

To install Honggfuzz please refer to the official documentation.

Usage

The main component is the broker that will serve the appropriate configurations to fuzzing

engines and that will aggregate results. An example is the following:

tar xvf doc/figs/fsm-demo.tar.gz && cd fsm-demo

make

pastis-broker -b bin -s initial -w output

It will run the broker using binaries in the bin directory. Initial corpus

is initial and the whole output workspace will be save in output. By default

it will listen on the local interface on port 5555.

Then fuzzing engines can be launched to start testing the software.

pastis-aflpp online

Or:

pastis-tritondse online

Full documentation is available: here

Adding a Fuzzer

Integrating a fuzzer requires writing a Python driver using the libpasts library

installed by the package. It requires implementing some callbacks to receive the initial

configuration and also to receive inputs from the broker. Conversely the API enables

sending newly generated inputs to the broker.

The process is further detailed in the documentation.

Note

We warmly welcome any Pull Request to add the support for a new fuzzing engine.


Docker

You can also run PASTIS using Docker:

# Pull from GitHub's registry.

docker pull ghcr.io/quarkslab/pastis:latest



# Or build the image.

docker build -t pastis .



# And run a container.

docker run -v <HOST-WORKSPACE>:/workspace --cap-add=SYS_PTRACE --user $(id -u $USER):$(id -g $USER) -it ghcr.io/quarkslab/pastis # or pastis if you buily the image locally.

To open another terminal to an already running container:

docker exec -it $(docker ps | grep 'pastis' | awk '{print $1}') /bin/bash

The PASTIS Docker image has already installed all the needed dependencies such as AFL++ and Honggfuzz.


Papers and conference

  • Symbolic Execution the Swiss-Knife of the Reverse Engineer Toolbox

    Venue: KLEE Workshop, 2022 [:books:] [:movie_camera:]

    Authors: Robin David, Richard Abou Chaaya, Christian Heitman

  • From source code to crash test-case through software testing automation

    Venue: European Cyber Week, C&ESAR Workshop, 2021 paper slides

    Authors: Robin David, Jonathan Salwan, Justin Bourroux

Cite Pastis

soon

Contributors

Pastis is powered by Quarkslab and initially financed by DGA-MI.

All contributions

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pastis-framework-1.0.13.tar.gz (89.4 kB view details)

Uploaded Source

Built Distribution

pastis_framework-1.0.13-py3-none-any.whl (105.6 kB view details)

Uploaded Python 3

File details

Details for the file pastis-framework-1.0.13.tar.gz.

File metadata

  • Download URL: pastis-framework-1.0.13.tar.gz
  • Upload date:
  • Size: 89.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.9

File hashes

Hashes for pastis-framework-1.0.13.tar.gz
Algorithm Hash digest
SHA256 bae83cd70a4f7008b506d117a89e27404273911887df7bc2c3a2ecdf0e2e3149
MD5 bcbfa293eab64c2fbeae58cdfcf7e305
BLAKE2b-256 8282c659e045b488699b54388756cef8f2029cf6a5f8fab1cad3af3e4c35a25f

See more details on using hashes here.

File details

Details for the file pastis_framework-1.0.13-py3-none-any.whl.

File metadata

File hashes

Hashes for pastis_framework-1.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 e24da5b184c6f2f0eacd9eee21f200c7ccf63ba11769e7537bc6557af8b95aa3
MD5 ebdda01853260e6388b7c204856c98e5
BLAKE2b-256 57eb93805dde916e8cf91494b53f0816abea82e6e41636ab96b8b79e639ced52

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page