Skip to content

Latest commit

 

History

History
77 lines (61 loc) · 2.97 KB

README.md

File metadata and controls

77 lines (61 loc) · 2.97 KB

This project provides a Docker image to build Wireshark with quantum-safe cryptography support through the Open Quantum Safe (OQS) provider. This Docker image allows Wireshark to analyze network traffic encrypted with post-quantum cryptographic protocols.

System Requirements

  • Docker: Ensure Docker is installed and running on your system.
  • X-Window System (for GUI Display):
    • Linux:
      • Run the following commands to allow Docker to access the display:
        xhost +local
        export DISPLAY=:0
        
    • Windows:
      • Install an X server such as VcXsrv and configure it with the following options:
        • Disable access control
        • Disable native OpenGL
      • In PowerShell, set the display environment variable:
        $env:DISPLAY="<your_host_ip>:0"
        
    • macOS:
      • Install an X server, such as XQuartz, and start it.
      • Run the following command in the terminal to allow Docker to access the display:
        xhost +
        
      • Set the display environment variable in the terminal:
        export DISPLAY=<your_host_ip>:0
        

Note: Replace <your_host_ip> with your system's IP address. Use :0 as the default display port unless configured otherwise.

Building Instructions

Run the following commands to build and launch Wireshark with OQS support:

git clone https://github.com/open-quantum-safe/oqs-demos
cd oqs-demos/wireshark
docker build -t oqs-wireshark .
docker run --rm -it --net=host -e DISPLAY=$DISPLAY -v /tmp/.X11-unix:/tmp/.X11-unix oqs-wireshark

Explanation of Docker Options

  • --net=host: Shares the host network with the container.
  • -e DISPLAY: Sets the display variable for GUI.
  • -v /tmp/.X11-unix:/tmp/.X11-unix: Mounts the X11 Unix socket for GUI access.

Project Components

  1. Dockerfile: Builds Wireshark with OpenSSL, liboqs, and OQS provider.
  2. generate_qsc_header.py: Processes oqs-provider/oqs-template/generate.yml with the qsc_template.jinja2 to generate qsc.h, defining post-quantum KEMs and SIGs for Wireshark.

Usage

For detailed usage instructions, refer to USAGE.md.

Build Configuration and Updates

Customize the build using the following Dockerfile arguments:

  • UBUNTU_VERSION: Specifies the Ubuntu version.
  • WIRESHARK_VERSION: Defines the Wireshark version to build.
  • OPENSSL_TAG: Sets the OpenSSL version to build.
  • LIBOQS_TAG: Specifies the liboqs version to include.
  • OQSPROVIDER_TAG: Defines the Open Quantum Safe provider version.
  • INSTALLDIR: Sets the installation path for OQS libraries.

To keep the build up-to-date, update the arguments as needed to include the latest versions.