The objective of this project is to implement the various components of a security-enhanced EMAIL system similar to PGP (Pretty Good Privacy) and GnuPG which is based on the openPGP standard.
Details on how to run, sample input commands are given below, as well as on problem statement.
- lab2.py : python program as specified in problem statement.
- usernames.txt : file containing 11 distinct usernames for which can be used to test the program, new names can be added.
- README : has instrutions and sample cases to run.
- COMMENTS.txt : feedback and experience of the project.
- typescripts: folder containing 3 session records, each corresponding to CONF, AUIN, COAI, of commands shown below.
- Used library cryptography, https://pypi.org/project/cryptography
- Use the format from the problem statement, can change sender, receiver names for testing. Can also change inputfile, outputfile as reuqired. Finally, we can also select the DigestAlgo among one of "sha512, sha3-512", and EncryptionAlgo among one of "des_ede3-cbc, aes-256-cbc".
- Remember to keep the RSA key size same during further testing as kept for CreateKeys. You can create keys for everyone at the beginning, and use the same set of keys for all further executions of the program.
- For simplicity, all usernames are in lower-case alphabets
Initialization: python3 lab2.py CreateKeys usernames.txt 2048
CONF:
-
between bob and alice, using SHA512 and AES
- python3 lab2.py CreateMail CONF bob alice msg.txt enc_conf.txt sha512 aes-256-cbc 2048
- python3 lab2.py ReadMail CONF bob alice enc_conf.txt dec_conf.txt sha512 aes-256-cbc 2048
-
between jim and pam, using SHA3-512 and 3DES
- python3 lab2.py CreateMail CONF jim pam msg.txt enc_conf.txt sha3-512 des-ede3-cbc 2048
- python3 lab2.py ReadMail CONF jim pam enc_conf.txt dec_conf.txt sha3-512 des-ede3-cbc 2048
AUIN:
-
between tim and rob, using SHA512 and 3DES
- python3 lab2.py CreateMail AUIN tim rob msg.txt enc_auin.txt sha512 des-ede3-cbc 2048
- python3 lab2.py ReadMail AUIN tim rob enc_auin.txt dec_auin.txt sha512 des-ede3-cbc 2048
-
between kathy and nancy, using SHA3-512 and AES
- python3 lab2.py CreateMail AUIN kathy nancy msg.txt enc_auin.txt sha3-512 aes-256-cbc 2048
- python3 lab2.py ReadMail AUIN kathy nancy enc_auin.txt dec_auin.txt sha3-512 aes-256-cbc 2048
COAI
-
between harry and darth, using SHA3-512 and AES
- python3 lab2.py CreateMail COAI harry darth msg.txt enc_coai.txt sha3-512 aes-256-cbc 2048
- python3 lab2.py ReadMail COAI harry darth enc_coai.txt dec_coai.txt sha3-512 aes-256-cbc 2048
-
between charlie and gary, using SHA512 and 3DES
- python3 lab2.py CreateMail COAI charlie gary msg.txt enc_coai.txt sha512 des-ede3-cbc 2048
- python3 lab2.py ReadMail COAI charlie gary enc_coai.txt dec_coai.txt sha512 des-ede3-cbc 2048
- The above given sequence of commands use different keys at every stage, using all 12 user keys.
- It also checks all combination of hash and encryption functions given.
- The command sequence given has used RSA keys of length 2048. Entire exercise can be repeated for other key size too.
- typescript record for all these runs are also attached
- If there is any mismatch in encryption and decryption, (possibilities: sender/receiver names, digest/encryption functions, input file names, or RSA key size) the program will be unable to decrypt. will be throwing error.
- There are some combinations which wont work when using lower key_length of RSA, like 1024 or 512, due to restrictions of RSA, and length of bytes to be encoded.