Skip to main content

A python package that offers high flexibility for implementing and experimenting with non-classical DES.

Project description

Maintenance made-with-python PyPI pyversions PyPI version PyPI status GitTutorial Downloads

DESfiddle

A simple to use python package for implementing and experimenting with the famous DES encryption algorithm. It implements both classical (default settings from the textbook description of DES) and non-classical DES. Check out DES app for a very specific implementation demonstrating avalanche effect and weak keys using the package.

Motivation

There are quite a few DES packages for python but none of them offer such high flexibility to implement a non-classical version of the DES. This package is aimed specifically to experiment with the different hyperparamters that can be tweaked while implementing DES.

Features

  • Only package till date to implement a non-classical version of DES.
  • Lots of hyperparameters* to tweak-
    • Number of rounds
    • Halfwidth for plaintext & key
    • Hamming distance for plaintext & key
    • Permutation boxes (Initial, Final & Inverse)
    • Shift arrays
    • S-boxes
    • Expansion box
  • Implementing classical DES is as easy as leaving the hyperparameters to their default values and the rest will be taken care of automatically.
  • Each function has a detailed doc string attached to it, thus minimising the need to navigate to the docs for usage referencing. So, if you quickly wanna see the function description just type in help(<function_name>) in the python interpreter.

Bonus: This package can be a life-saver for CSE 537- Network Security course taught at IIT (BHU).

*Tweaking some of these may require changing the source code as of the current release

Installation

Run the following command in your terminal/command prompt-

$ pip install DESfiddle

Note: If you dont have pip installed, follow these steps.

Importing and Usage

# Importing
import DESfiddle.utils as dfu

# Usage
permutation_arr = dfu.generate_permutation(64)
# Importing
from DESfiddle.utils import *
# or just specify the function name you wanna import

# Usage
permutation_arr = generate_permutation(64)

Code Examples

from DESfiddle.utils import *

# Inputs in binary setting
plaintext = "0101010101010101010101010101010101010101010101010101010101010101"
key = "1111111111111111111111111111111100000000000000000000000000000000"

# Settings
nor = 16
halfwidth = 32
hamming_dist = 1

# Hamming the plaintext in binary mode
ref_pt_arr = preprocess_plaintext(plaintext, halfwidth)
pt_arr = preprocess_plaintext(plaintext, halfwidth, hamming_dist)
key = preprocess_key(key, halfwidth)
rkb,rkh = generate_round_keys(key,nor, halfwidth)
ref_ciphertext, ref_round_ciphertexts = encrypt(ref_pt_arr, rkb, nor, halfwidth)
_, round_ciphertexts = encrypt(pt_arr, rkb, nor, halfwidth)
diff = calc_diff(ref_round_ciphertexts, round_ciphertexts)

# Hamming the key in binary mode
pt_arr = preprocess_plaintext(plaintext, halfwidth)
ref_key = preprocess_key(key,halfwidth)
key = preprocess_key(key, halfwidth, hamming_dist)
ref_rkb, ref_rkh = generate_round_keys(ref_key, nor, halfwidth)
rkb,_ = generate_round_keys(key, nor, halfwidth)
ref_ciphertext, ref_round_ciphertexts = encrypt(pt_arr, ref_rkb, nor, halfwidth)
_, round_ciphertexts = encrypt(pt_arr, rkb, nor, halfwidth)
diff = calc_diff(ref_round_ciphertexts, round_ciphertexts)
from DESfiddle.utils import *

# Inputs in ASCII setting
plaintext = "This is so cool"
key = "Yesss"

# Settings
nor = 16
halfwidth = 32
hamming_dist = 1

# Preprocessing when input in ASCII
plaintext = txt_to_hex(plaintext)
plaintext = hex_to_bin(plaintext)
key = txt_to_hex(key)
key = hex_to_bin(key)

# Hamming the plaintext in binary mode
ref_pt_arr = preprocess_plaintext(plaintext, halfwidth)
pt_arr = preprocess_plaintext(plaintext, halfwidth, hamming_dist)
key = preprocess_key(key, halfwidth)
rkb,rkh = generate_round_keys(key,nor, halfwidth)
ref_ciphertext, ref_round_ciphertexts = encrypt(ref_pt_arr, rkb, nor, halfwidth)
_, round_ciphertexts = encrypt(pt_arr, rkb, nor, halfwidth)
diff = calc_diff(ref_round_ciphertexts, round_ciphertexts)

# Hamming the key in binary mode
pt_arr = preprocess_plaintext(plaintext, halfwidth)
ref_key = preprocess_key(key,halfwidth)
key = preprocess_key(key, halfwidth, hamming_dist)
ref_rkb, ref_rkh = generate_round_keys(ref_key, nor, halfwidth)
rkb,_ = generate_round_keys(key, nor, halfwidth)
ref_ciphertext, ref_round_ciphertexts = encrypt(pt_arr, ref_rkb, nor, halfwidth)
_, round_ciphertexts = encrypt(pt_arr, rkb, nor, halfwidth)
diff = calc_diff(ref_round_ciphertexts, round_ciphertexts)

Contributing Guidelines

Thanks for taking the time to contribute!

The following is a set of guidelines for contributing to DESfiddle. These are just guidelines, not rules, so use your best judgement and feel free to propose changes to this document in a pull request.

Getting Started

DESfiddle is built over python. So if you are new to python, please head over to this great website.

Community

  • The whole DESfiddle documentation, such as setting up a development environment, the project, and testing, can be read here.
  • If you have any questions regarding DESfiddle, open an issue or ask it directly on Linkedin.

Issue

Ensure the bug was not already reported by searching on GitHub under issues. If you're unable to find an open issue addressing the bug, open a new issue.

Write detailed information

Detailed information is very helpful to understand an issue, for example-

  • How to reproduce the issue, step-by-step.
  • The expected behavior (or what is wrong).
  • Screenshots for GUI issues.
  • The application version.
  • The operating system.
  • The DESfiddle version.

Pull requests

Pull Requests are always welcome.

  • When you edit the code, please run python -m unittest to test your code before you git commit.
  • Ensure the PR description clearly describes the problem and solution. It should include-
    • The operating system used while testing
    • DESfiddle version number
    • The relevant issue number, if applicable.

Version

Follows syntax vM.M.P First is major and means not backwards compatible changes. Second is minor and means backwards compatible changes. Third is patch and means small backwards compatible changes.

The manual place of source of truth for the version is at setup.py

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

DESfiddle-1.0.0.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

DESfiddle-1.0.0-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file DESfiddle-1.0.0.tar.gz.

File metadata

  • Download URL: DESfiddle-1.0.0.tar.gz
  • Upload date:
  • Size: 9.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for DESfiddle-1.0.0.tar.gz
Algorithm Hash digest
SHA256 ff82eea8e20906bebdf8c12e86cffa2a949d140c81436fe08a8e4578cdf9f3cc
MD5 cfe7ade67c27bf0bea22e84faa87f12e
BLAKE2b-256 37112c360c41f94ec00abb70b68a41ccfcc0b63068d1f33a94a15ceb57dec869

See more details on using hashes here.

File details

Details for the file DESfiddle-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: DESfiddle-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4

File hashes

Hashes for DESfiddle-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3a8ff9afeb4b41346d11fbebc42c2b119b9242209aca8ce5d472bf7ff1d6aeed
MD5 fd26f34fd94c74baad9a6f82f5166cf7
BLAKE2b-256 c1de8de5f8863ccdc64e9c60116e88d5bf15325b61de8b7fb30552394d44705a

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