mark-sim / MTP

Many-Time Pad Interactive

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

MTP

Keys in One-time pad encryption (OTP) should only be used once, when they get reused we can do a Many-time pad attack.

MTP Interactive uses automated cryptanalysis to present a partial decryption which can be solved interactively.

Install

Python 3.7 required

pip install mtp

Usage

mtp examples/sample.ciphertexts

asciicast

Intstructions

Cursor movement is similar to Sublime Text:

  • Left, Right, Up and Down for simple movement
  • Home, End, Page Up and Page Down for larger movement
  • Left Click for jumping to mouse cursor

Letters can be entered using the keyboard any time.

The menu can be opened with the escape key. The "Export" button in the menu will write the JSON state of the decryption to a file named 'result.json'

You can exit the program cleanly using the "Quit" menu button.

Window resizing and text size changes are supported.

Development

Use a Python 3.7 virtual environment to develop on this project

virtualenv venv -p python3.7
source ./venv/bin/activate
pip install -r requirements.txt

Pull Requests and Issues welcome!

About

Many-Time Pad Interactive

License:MIT License


Languages

Language:Python 100.0%