cryptanalysis/main.py
2022-06-23 21:33:43 +02:00

110 lines
2.7 KiB
Python

# coding: utf-8
from argparse import ArgumentParser
import matplotlib.pyplot as plt
from lorem import text as loremtext
def checkArguments():
args = ArgumentParser(description='Cryptanalyst')
args.add_argument('-f', '--filename', help='Text to analyze')
args.add_argument('-s', '--stats', help='Statistics', action='store_true')
args.add_argument('-d', '--decrypt', help='Decrypt Caesar text', action='store_true')
return args.parse_args()
def readCipherText(filename):
"""
This read the file passed in argument and return the data of it
"""
file = []
with open(filename, 'r') as f:
data = f.readlines()
for entry in data:
file.append(entry.strip())
return file
def stats(file=None):
"""
This function get a stats of all letter occurrence in a text
"""
if file is None:
text = loremtext()
else:
text = file
lettersOccurence = {}
letterUpperToAscii = ord('A') # Get the ASCII code
for i in range (0, 26):
lettersOccurence[chr(i + letterUpperToAscii)] = 0
for line in text:
for letter in line:
letter = letter.upper()
if letter in lettersOccurence:
lettersOccurence[letter] = lettersOccurence[letter] + 1
x = [chr(letter + 65) for letter in range(0, 26)]
y = [lettersOccurence[tmp] for tmp in lettersOccurence]
largeur = 0.5
plt.bar(x, y, largeur)
plt.show()
def decryptCaesarText(cipherFile):
"""
This function breach the caesar ciphertext with all key
"""
if cipherFile is None:
return
letterAToAscii = ord('A') # Get the ASCII code
letterZToAscii = ord('Z') # Get the ASCII code
letteraToAscii = ord('a') # Get the ASCII code
letterzToAscii = ord('z') # Get the ASCII code
for key in range (0, 26):
foo = []
for line in cipherFile:
newLine = str()
for letter in line:
letter = letter.upper()
letterAscii = ord(letter)
if letterAscii >= letterAToAscii and letterAscii <= letterZToAscii:
newLetter = getNewLetter(letterAscii, letterAToAscii, key)
elif letterAscii >= letteraToAscii and letterAscii <= letterzToAscii:
newLetter = getNewLetter(letteraToAscii, key)
else:
newLetter = letter
newLine = newLine + newLetter
foo.append(newLine)
print(f"key: {key}")
print(foo)
def getNewLetter(letterAscii, letterToAscii, key):
"""
This function return the new letter and we substract with the key.
The function return the new letter into a char
"""
letterAscii = letterAscii - letterToAscii
res = ((letterAscii - key) % 26) + letterToAscii
return chr(res)
def main():
args = checkArguments()
cipherFile = None
if args.filename:
cipherFile = readCipherText(args.filename)
if args.stats:
stats(cipherFile)
if args.decrypt:
decryptCaesarText(cipherFile)
if __name__ == "__main__":
main()