/
EncodingDecoding.py
88 lines (70 loc) · 2.48 KB
/
EncodingDecoding.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#!/usr/bin/env python
import os
import sys
import logging
import argparse
import base64
# To Encode/Decode Base64
def base64_encode_decode(action, data):
if action == 'decode':
decoded = base64.b64decode(data)
logging.info("decoded result: {}".format(decoded))
else:
encoded = base64.b64encode(data)
logging.info("encoded result: {}".format(encoded))
# Caeser Cypher
def caeser_cypher(key, action, data):
result_str = ""
if action == 'decode':
key = -key
for sym in data:
if sym.isalpha():
num = ord(sym)
num += key
if sym.isupper():
if num > ord('Z'):
num -= 26
elif num < ord('A'):
num += 26
else:
if num > ord('z'):
num -= 26
elif num < ord('a'):
num += 26
result_str += chr(num)
else:
result_str += sym
logging.info("OUTPUT: {}".format(result_str))
# To parse the arguments passed
def argument_parser():
parser = argparse.ArgumentParser()
parser.add_argument("method", choices=['base64', 'caeser', 'vigenere', 'DES', 'RSA'], help="which type of encryption/decryption to be used.")
group = parser.add_mutually_exclusive_group(required=True)
group.add_argument("--encode", help="For encoding a string")
group.add_argument("--decode", help="For decoding")
parser.add_argument("-k", "--key", type=int, help="Key to encrypt or decrypt")
parser.add_argument("-v", "--verbose", action="store_true")
args = parser.parse_args()
return args
def main():
# Get all the arguments
args = argument_parser()
# Check the verbosity level
if args.verbose:
logging.basicConfig(level=logging.DEBUG, format='%(funcName)s:%(levelname)s:%(message)s')
else:
logging.basicConfig(level=logging.INFO, format='%(funcName)s:%(levelname)s:%(message)s')
method = args.method
action = 'encode' if args.encode else 'decode'
data = args.encode if action=='encode' else args.decode
logging.debug("{} this {} string using {}".format(action, data, method))
if method == 'base64':
base64_encode_decode(action, data)
if method == 'caeser':
key = args.key
if key >=0 and key < 27:
caeser_cypher(key, action, data)
else:
logging.error("Key should be in the range 0-26")
if __name__ == "__main__":
main()