37 lines
847 B
Python
37 lines
847 B
Python
import argparse
|
|
|
|
|
|
def caesar(ptextletter, keyletter):
|
|
ptextNum = ord(ptextletter) - ord('A')
|
|
keyletterNum = ord(keyletter) - ord('A')
|
|
return chr((ptextNum + keyletterNum) % 26 + ord('A'))
|
|
|
|
|
|
def encryption(plaintext, key):
|
|
ciphertext = ''
|
|
for i in range(len(plaintext)):
|
|
ciphertext += caesar(plaintext[i], key[i % len(key)])
|
|
return ciphertext
|
|
|
|
|
|
def decryption(ciphertext, key):
|
|
return ciphertext
|
|
|
|
|
|
def main():
|
|
# parse command line argument
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument('--ptext', type=str)
|
|
parser.add_argument('--key', type=str)
|
|
args = parser.parse_args()
|
|
|
|
key = args.key
|
|
ciphertext = encryption(args.ptext, key)
|
|
|
|
print("Ciphertext: " + ciphertext)
|
|
print("Decrypted plaintext: " + decryption(ciphertext, key))
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|